From 6c070464dd5ffaebaa70e90c2f89f0cf19515f10 Mon Sep 17 00:00:00 2001 From: James Grugett Date: Tue, 19 Jul 2022 15:39:15 -0500 Subject: [PATCH] Use static props to load leaderboard fast --- web/lib/firebase/users.ts | 4 +- web/pages/leaderboards.tsx | 152 ++++++++++++++++++------------------- 2 files changed, 76 insertions(+), 80 deletions(-) diff --git a/web/lib/firebase/users.ts b/web/lib/firebase/users.ts index 77c5c48d..884dde04 100644 --- a/web/lib/firebase/users.ts +++ b/web/lib/firebase/users.ts @@ -275,7 +275,7 @@ export function getTopTraders(period: Period) { limit(20) ) - return getValues(topTraders) + return getValues(topTraders) } export function getTopCreators(period: Period) { @@ -284,7 +284,7 @@ export function getTopCreators(period: Period) { orderBy('creatorVolumeCached.' + period, 'desc'), limit(20) ) - return getValues(topCreators) + return getValues(topCreators) } export async function getTopFollowed() { diff --git a/web/pages/leaderboards.tsx b/web/pages/leaderboards.tsx index 061f3a19..6f15e13e 100644 --- a/web/pages/leaderboards.tsx +++ b/web/pages/leaderboards.tsx @@ -9,97 +9,96 @@ import { User, } from 'web/lib/firebase/users' import { formatMoney } from 'common/util/format' -import { fromPropz, usePropz } from 'web/hooks/use-propz' import { useEffect, useState } from 'react' -import { LoadingIndicator } from 'web/components/loading-indicator' import { Title } from 'web/components/title' import { Tabs } from 'web/components/layout/tabs' import { useTracking } from 'web/hooks/use-tracking' -export const getStaticProps = fromPropz(getStaticPropz) -export async function getStaticPropz() { - return queryLeaderboardUsers('allTime') -} -const queryLeaderboardUsers = async (period: Period) => { - const [topTraders, topCreators, topFollowed] = await Promise.all([ - getTopTraders(period).catch(() => {}), - getTopCreators(period).catch(() => {}), - getTopFollowed().catch(() => {}), - ]) +export async function getStaticProps() { + const props = await fetchProps() + return { - props: { - topTraders, - topCreators, - topFollowed, - }, + props, revalidate: 60, // regenerate after a minute } } -export default function Leaderboards(props: { +const fetchProps = async () => { + const [allTime, monthly, weekly, daily] = await Promise.all([ + queryLeaderboardUsers('allTime'), + queryLeaderboardUsers('monthly'), + queryLeaderboardUsers('weekly'), + queryLeaderboardUsers('daily'), + ]) + const topFollowed = await getTopFollowed() + + return { + allTime, + monthly, + weekly, + daily, + topFollowed, + } +} + +const queryLeaderboardUsers = async (period: Period) => { + const [topTraders, topCreators] = await Promise.all([ + getTopTraders(period), + getTopCreators(period), + ]) + return { + topTraders, + topCreators, + } +} + +type leaderboard = { topTraders: User[] topCreators: User[] +} + +export default function Leaderboards(_props: { + allTime: leaderboard + monthly: leaderboard + weekly: leaderboard + daily: leaderboard topFollowed: User[] }) { - props = usePropz(props, getStaticPropz) ?? { - topTraders: [], - topCreators: [], - topFollowed: [], - } - const { topFollowed } = props - const [topTradersState, setTopTraders] = useState(props.topTraders) - const [topCreatorsState, setTopCreators] = useState(props.topCreators) - const [isLoading, setLoading] = useState(false) - const [period, setPeriod] = useState('allTime') - + const [props, setProps] = useState[0]>(_props) useEffect(() => { - setLoading(true) - queryLeaderboardUsers(period).then((res) => { - setTopTraders(res.props.topTraders as User[]) - setTopCreators(res.props.topCreators as User[]) - setLoading(false) - }) - }, [period]) + fetchProps().then((props) => setProps(props)) + }, []) + + const { topFollowed } = props const LeaderboardWithPeriod = (period: Period) => { + const { topTraders, topCreators } = props[period] + return ( <> - {!isLoading ? ( - <> - {period === 'allTime' || - period == 'weekly' || - period === 'daily' ? ( //TODO: show other periods once they're available - - formatMoney(user.profitCached[period]), - }, - ]} - /> - ) : ( - <> - )} + formatMoney(user.profitCached[period]), + }, + ]} + /> - - formatMoney(user.creatorVolumeCached[period]), - }, - ]} - /> - - ) : ( - - )} + + formatMoney(user.creatorVolumeCached[period]), + }, + ]} + /> {period === 'allTime' ? ( @@ -128,19 +127,16 @@ export default function Leaderboards(props: { { - const period = ['allTime', 'monthly', 'weekly', 'daily'][index] - setPeriod(period as Period) - }} tabs={[ { title: 'All Time', content: LeaderboardWithPeriod('allTime'), }, - { - title: 'Monthly', - content: LeaderboardWithPeriod('monthly'), - }, + // TODO: Enable this near the end of July! + // { + // title: 'Monthly', + // content: LeaderboardWithPeriod('monthly'), + // }, { title: 'Weekly', content: LeaderboardWithPeriod('weekly'),