import TabButtons from '@components/shared/TabButtons'
import TokenPage from '@components/token/TokenPage'
import mangoStore from '@store/mangoStore'
import useLocalStorageState from 'hooks/useLocalStorageState'
import useMangoGroup from 'hooks/useMangoGroup'
import { useViewport } from 'hooks/useViewport'
import { useRouter } from 'next/router'
import { useEffect, useMemo } from 'react'
import { STATS_TAB_KEY } from 'utils/constants'
import { breakpoints } from 'utils/theme'
import MangoStats from './MangoStats'
import PerpMarketsTable from './PerpMarketsTable'
import PerpStatsPage from './PerpStatsPage'
import SpotMarketsTable from './SpotMarketsTable'
import TokenStats from './TokenStats'
// const TABS = ['tokens', 'perp', 'spot', 'mango']
const TABS = ['tokens', 'perp-markets', 'spot-markets', 'mango-stats']
const StatsPage = () => {
const [activeTab, setActiveTab] = useLocalStorageState(
STATS_TAB_KEY,
'tokens'
)
const actions = mangoStore.getState().actions
const perpStats = mangoStore((s) => s.perpStats.data)
const { group } = useMangoGroup()
const { width } = useViewport()
const fullWidthTabs = width ? width < breakpoints.lg : false
const router = useRouter()
const { market } = router.query
const { token } = router.query
useEffect(() => {
if (group && (!perpStats || !perpStats.length)) {
actions.fetchPerpStats()
}
}, [group, perpStats])
const tabsWithCount: [string, number][] = useMemo(() => {
return TABS.map((t) => [t, 0])
}, [])
return market ? (