67d0a6c0c2
* Create Top Followed Users leaderboard * Switch to increment/decrement approach for caching user follower counts * Backfill script for user follow counts * Appease ESLint * Address review comment Co-authored-by: James Grugett <jahooma@gmail.com>
86 lines
2.1 KiB
TypeScript
86 lines
2.1 KiB
TypeScript
import { Col } from 'web/components/layout/col'
|
|
import { Leaderboard } from 'web/components/leaderboard'
|
|
import { Page } from 'web/components/page'
|
|
import {
|
|
getTopCreators,
|
|
getTopTraders,
|
|
getTopFollowed,
|
|
User,
|
|
} from 'web/lib/firebase/users'
|
|
import { formatMoney } from 'common/util/format'
|
|
import { fromPropz, usePropz } from 'web/hooks/use-propz'
|
|
import { useTracking } from 'web/hooks/use-tracking'
|
|
|
|
export const getStaticProps = fromPropz(getStaticPropz)
|
|
export async function getStaticPropz() {
|
|
const [topTraders, topCreators, topFollowed] = await Promise.all([
|
|
getTopTraders().catch(() => {}),
|
|
getTopCreators().catch(() => {}),
|
|
getTopFollowed().catch(() => {}),
|
|
])
|
|
|
|
return {
|
|
props: {
|
|
topTraders,
|
|
topCreators,
|
|
topFollowed,
|
|
},
|
|
|
|
revalidate: 60, // regenerate after a minute
|
|
}
|
|
}
|
|
|
|
export default function Leaderboards(props: {
|
|
topTraders: User[]
|
|
topCreators: User[]
|
|
topFollowed: User[]
|
|
}) {
|
|
props = usePropz(props, getStaticPropz) ?? {
|
|
topTraders: [],
|
|
topCreators: [],
|
|
topFollowed: [],
|
|
}
|
|
const { topTraders, topCreators, topFollowed } = props
|
|
|
|
useTracking('view leaderboards')
|
|
|
|
return (
|
|
<Page>
|
|
<Col className="mx-4 items-center gap-10 lg:mx-0 lg:flex-row">
|
|
<Leaderboard
|
|
title="🏅 Top bettors"
|
|
users={topTraders}
|
|
columns={[
|
|
{
|
|
header: 'Total profit',
|
|
renderCell: (user) => formatMoney(user.totalPnLCached),
|
|
},
|
|
]}
|
|
/>
|
|
<Leaderboard
|
|
title="🏅 Top creators"
|
|
users={topCreators}
|
|
columns={[
|
|
{
|
|
header: 'Total bet',
|
|
renderCell: (user) => formatMoney(user.creatorVolumeCached),
|
|
},
|
|
]}
|
|
/>
|
|
</Col>
|
|
<Col className="mx-4 my-10 w-1/2 items-center gap-10 lg:mx-0 lg:flex-row">
|
|
<Leaderboard
|
|
title="👀 Most followed"
|
|
users={topFollowed}
|
|
columns={[
|
|
{
|
|
header: 'Number of followers',
|
|
renderCell: (user) => user.followerCountCached,
|
|
},
|
|
]}
|
|
/>
|
|
</Col>
|
|
</Page>
|
|
)
|
|
}
|