mango-v4-ui/components/stats/StatsPage.tsx

73 lines
2.1 KiB
TypeScript
Raw Normal View History

2022-10-08 04:37:08 -07:00
import TabButtons from '@components/shared/TabButtons'
2023-04-16 21:25:21 -07:00
import TokenPage from '@components/token/TokenPage'
2022-12-20 00:16:05 -08:00
import mangoStore from '@store/mangoStore'
import useMangoGroup from 'hooks/useMangoGroup'
import { useViewport } from 'hooks/useViewport'
2023-04-13 04:56:18 -07:00
import { useRouter } from 'next/router'
2023-04-24 12:25:45 -07:00
import { useEffect, useMemo, useState } from 'react'
import { breakpoints } from 'utils/theme'
2022-12-20 00:16:05 -08:00
import MangoStats from './MangoStats'
2023-04-26 19:33:03 -07:00
import PerpStats from './PerpStats'
2023-04-13 04:56:18 -07:00
import PerpStatsPage from './PerpStatsPage'
2022-10-08 04:37:08 -07:00
import SpotMarketsTable from './SpotMarketsTable'
import TokenStats from './TokenStats'
2023-02-16 16:24:57 -08:00
const TABS = ['tokens', 'perp-markets', 'spot-markets', 'mango-stats']
2022-10-08 04:37:08 -07:00
const StatsPage = () => {
2023-04-24 12:25:45 -07:00
const [activeTab, setActiveTab] = useState('tokens')
2023-01-03 14:20:00 -08:00
const actions = mangoStore.getState().actions
2023-04-11 20:38:21 -07:00
const perpStats = mangoStore((s) => s.perpStats.data)
2022-12-20 00:16:05 -08:00
const { group } = useMangoGroup()
const { width } = useViewport()
const fullWidthTabs = width ? width < breakpoints.lg : false
2023-04-13 04:56:18 -07:00
const router = useRouter()
const { market } = router.query
2023-04-16 21:25:21 -07:00
const { token } = router.query
2022-12-20 00:16:05 -08:00
useEffect(() => {
2023-04-11 20:38:21 -07:00
if (group && (!perpStats || !perpStats.length)) {
2022-12-20 00:16:05 -08:00
actions.fetchPerpStats()
}
2023-04-11 20:38:21 -07:00
}, [group, perpStats])
2022-12-20 00:16:05 -08:00
2022-10-08 04:37:08 -07:00
const tabsWithCount: [string, number][] = useMemo(() => {
return TABS.map((t) => [t, 0])
}, [])
2023-04-13 04:56:18 -07:00
return market ? (
<PerpStatsPage />
2023-04-16 21:25:21 -07:00
) : token ? (
<TokenPage />
2023-04-13 04:56:18 -07:00
) : (
2022-10-08 04:37:08 -07:00
<div className="pb-20 md:pb-16">
<div className="border-b border-th-bkg-3">
<TabButtons
activeValue={activeTab}
fillWidth={fullWidthTabs}
onChange={(v) => setActiveTab(v)}
showBorders
values={tabsWithCount}
/>
</div>
2022-10-08 04:37:08 -07:00
<TabContent activeTab={activeTab} />
</div>
)
}
export default StatsPage
const TabContent = ({ activeTab }: { activeTab: string }) => {
switch (activeTab) {
case 'tokens':
return <TokenStats />
2023-02-16 16:24:57 -08:00
case 'perp-markets':
2023-04-26 19:33:03 -07:00
return <PerpStats />
2023-02-16 16:24:57 -08:00
case 'spot-markets':
2022-10-08 04:37:08 -07:00
return <SpotMarketsTable />
2023-02-16 16:24:57 -08:00
case 'mango-stats':
2022-12-20 00:16:05 -08:00
return <MangoStats />
2022-10-08 04:37:08 -07:00
default:
return <TokenStats />
}
}