Support user profiles on /[username]

Currently all bets are also shown
This commit is contained in:
Austin Chen 2021-12-15 17:34:36 -08:00
parent 8e119a6338
commit 9df78a4963
5 changed files with 49 additions and 30 deletions

View File

@ -10,6 +10,7 @@ import {
path,
} from '../lib/firebase/contracts'
import { formatMoney } from '../lib/util/format'
import { User } from '../lib/firebase/users'
export function ContractDetails(props: { contract: Contract }) {
const { contract } = props
@ -95,9 +96,8 @@ export function ContractsGrid(props: { contracts: Contract[] }) {
)
}
export function ContractsList(props: {}) {
const creator = useUser()
export function ContractsList(props: { creator: User }) {
const { creator } = props
const [contracts, setContracts] = useState<Contract[]>([])
useEffect(() => {

View File

@ -5,6 +5,11 @@ import {
setDoc,
getDoc,
onSnapshot,
collection,
query,
where,
limit,
getDocs,
} from 'firebase/firestore'
import { getAuth } from 'firebase/auth'
import { ref, getStorage, uploadBytes, getDownloadURL } from 'firebase/storage'
@ -35,6 +40,15 @@ export async function getUser(userId: string) {
return docSnap.data() as User
}
export async function getUserByUsername(username: string) {
// Find a user whose username matches the given username, or null if no such user exists.
const userCollection = collection(db, 'users')
const q = query(userCollection, where('username', '==', username), limit(1))
const docs = await getDocs(q)
const users = docs.docs.map((doc) => doc.data() as User)
return users[0] || null
}
export async function setUser(userId: string, user: User) {
await setDoc(doc(db, 'users', userId), user)
}

View File

@ -1,18 +1,23 @@
import { useRouter } from 'next/router'
import React from 'react'
import { Header } from '../../components/header'
import { Col } from '../../components/layout/col'
import { Title } from '../../components/title'
import React, { useEffect, useState } from 'react'
import { getUserByUsername, User } from '../../lib/firebase/users'
import { UserPage } from '../account'
import Error from 'next/error'
// For now, render a placeholder page
export default function ContractPage() {
export default function UserProfile() {
const router = useRouter()
const [user, setUser] = useState<User | null>(null)
const { username } = router.query as { username: string }
useEffect(() => {
if (username) {
getUserByUsername(username).then(setUser)
}
}, [username])
return (
<Col className="max-w-7xl mx-auto sm:px-6 lg:px-8">
<Header />
<Title text={username} />
</Col>
const errorMessage = `Who is this "${username}" you speak of..`
return user ? (
<UserPage user={user} />
) : (
<Error statusCode={404} title={errorMessage} />
)
}

View File

@ -64,29 +64,29 @@ function SignInCard() {
)
}
export default function Account() {
const user = useUser()
export function UserPage(props: { user: User }) {
const { user } = props
return (
<div>
<Header />
<div className="max-w-4xl pt-8 pb-0 sm:pb-8 mx-auto">
{user ? (
<div>
<UserCard user={user} />
<Title className="px-2" text="Your markets" />
<ContractsList />
<ContractsList creator={user} />
<Spacer h={4} />
<Title className="px-2" text="Your bets" />
<BetsList user={user} />
</div>
) : (
<SignInCard />
)}
</div>
</div>
)
}
export default function Account() {
const user = useUser()
return user ? <UserPage user={user} /> : <SignInCard />
}

View File

@ -115,7 +115,7 @@ export default function NewContract() {
<Title text="Your markets" />
<ContractsList />
<ContractsList creator={creator} />
</div>
</div>
)