Link to UserPage with @username

This commit is contained in:
Austin Chen 2021-12-15 18:04:36 -08:00
parent 9df78a4963
commit 64dde4f482
3 changed files with 32 additions and 4 deletions

View File

@ -11,6 +11,7 @@ import { Spacer } from './layout/spacer'
import { Contract, path } from '../lib/firebase/contracts' import { Contract, path } from '../lib/firebase/contracts'
import { Row } from './layout/row' import { Row } from './layout/row'
import { calculateWinnings, currentValue } from '../lib/calculation/contract' import { calculateWinnings, currentValue } from '../lib/calculation/contract'
import { UserLink } from '../pages/account'
export function BetsList(props: { user: User }) { export function BetsList(props: { user: User }) {
const { user } = props const { user } = props
@ -65,7 +66,9 @@ function MyContractBets(props: { contractId: string; bets: Bet[] }) {
</div> </div>
<Row className="gap-2 text-gray-500 text-sm"> <Row className="gap-2 text-gray-500 text-sm">
<div>By {contract.creatorName}</div> <div>
<UserLink displayName={contract.creatorName} />
</div>
{resolution && <div></div>} {resolution && <div></div>}
{resolution === 'YES' && ( {resolution === 'YES' && (
<div className="text-primary">Resolved YES</div> <div className="text-primary">Resolved YES</div>

View File

@ -2,7 +2,6 @@ import Link from 'next/link'
import { Col } from '../components/layout/col' import { Col } from '../components/layout/col'
import { Row } from '../components/layout/row' import { Row } from '../components/layout/row'
import { useEffect, useState } from 'react' import { useEffect, useState } from 'react'
import { useUser } from '../hooks/use-user'
import { import {
compute, compute,
Contract, Contract,
@ -11,6 +10,7 @@ import {
} from '../lib/firebase/contracts' } from '../lib/firebase/contracts'
import { formatMoney } from '../lib/util/format' import { formatMoney } from '../lib/util/format'
import { User } from '../lib/firebase/users' import { User } from '../lib/firebase/users'
import { UserLink } from '../pages/account'
export function ContractDetails(props: { contract: Contract }) { export function ContractDetails(props: { contract: Contract }) {
const { contract } = props const { contract } = props
@ -18,7 +18,9 @@ export function ContractDetails(props: { contract: Contract }) {
return ( return (
<Row className="flex-wrap text-sm text-gray-500"> <Row className="flex-wrap text-sm text-gray-500">
<div className="whitespace-nowrap">By {contract.creatorName}</div> <div className="whitespace-nowrap">
<UserLink displayName={contract.creatorName} />
</div>
<div className="mx-2"></div> <div className="mx-2"></div>
<div className="whitespace-nowrap"> <div className="whitespace-nowrap">
{resolvedDate ? `${createdDate} - ${resolvedDate}` : createdDate} {resolvedDate ? `${createdDate} - ${resolvedDate}` : createdDate}

View File

@ -7,6 +7,26 @@ import { Row } from '../components/layout/row'
import { formatMoney } from '../lib/util/format' import { formatMoney } from '../lib/util/format'
import { BetsList } from '../components/bets-list' import { BetsList } from '../components/bets-list'
import { Spacer } from '../components/layout/spacer' import { Spacer } from '../components/layout/spacer'
import Link from 'next/link'
import clsx from 'clsx'
export function UserLink(props: { displayName: string; className?: string }) {
const { displayName, className } = props
const username = displayName.replace(/\s+/g, '')
return (
<Link href={`/${username}`}>
<a
className={clsx(
'hover:underline hover:decoration-indigo-400 hover:decoration-2',
className
)}
>
@{username}
</a>
</Link>
)
}
function UserCard(props: { user: User }) { function UserCard(props: { user: User }) {
const { user } = props const { user } = props
@ -23,7 +43,10 @@ function UserCard(props: { user: User }) {
)} )}
</div> </div>
<div className="max-w-md card-body"> <div className="max-w-md card-body">
<h2 className="card-title font-major-mono">{user?.name}</h2> <UserLink
displayName={user?.name}
className="card-title font-major-mono"
/>
<p>{user?.email}</p> <p>{user?.email}</p>
<p>{formatMoney(user?.balance)}</p> <p>{formatMoney(user?.balance)}</p>
<div className="card-actions"> <div className="card-actions">