mango-ui-v3/pages/stats.tsx

105 lines
3.2 KiB
TypeScript

import { useState, useEffect } from 'react'
import TopBar from '../components/TopBar'
import PageBodyContainer from '../components/PageBodyContainer'
import StatsTotals from '../components/stats_page/StatsTotals'
import StatsAssets from '../components/stats_page/StatsAssets'
import StatsPerps from '../components/stats_page/StatsPerps'
import useMangoStats from '../hooks/useMangoStats'
import Swipeable from '../components/mobile/Swipeable'
import SwipeableTabs from '../components/mobile/SwipeableTabs'
import Tabs from '../components/Tabs'
import { useViewport } from '../hooks/useViewport'
import { breakpoints } from '../components/TradePageGrid'
import { serverSideTranslations } from 'next-i18next/serverSideTranslations'
import { useTranslation } from 'next-i18next'
export async function getStaticProps({ locale }) {
return {
props: {
...(await serverSideTranslations(locale, ['common'])),
// Will be passed to the page component as props
},
}
}
export default function StatsPage() {
const { t } = useTranslation('common')
const TABS = [
'Totals',
'Assets',
'Perps',
// 'Markets',
// 'Liquidations',
]
const { latestStats, stats, perpStats } = useMangoStats()
const [viewIndex, setViewIndex] = useState(0)
const [activeTab, setActiveTab] = useState(TABS[0])
const { width } = useViewport()
const isMobile = width ? width < breakpoints.sm : false
const handleChangeViewIndex = (index) => {
setViewIndex(index)
}
const handleTabChange = (tabName) => {
setActiveTab(tabName)
}
useEffect(() => {
// @ts-ignore
if (window.solana) {
// @ts-ignore
window.solana.connect({ onlyIfTrusted: true })
}
}, [])
return (
<div className={`bg-th-bkg-1 text-th-fgd-1 transition-all`}>
<TopBar />
<PageBodyContainer>
<div className="flex flex-col py-4 sm:flex-row md:pb-4 md:pt-10">
<h1>{t('stats')}</h1>
</div>
{!isMobile ? (
<Tabs activeTab={activeTab} onChange={handleTabChange} tabs={TABS} />
) : (
<SwipeableTabs
onChange={handleChangeViewIndex}
tabs={TABS}
tabIndex={viewIndex}
/>
)}
<div className="rounded-lg bg-th-bkg-2 p-4 sm:p-6">
{!isMobile ? (
<TabContent
activeTab={activeTab}
latestStats={latestStats}
perpStats={perpStats}
stats={stats}
/>
) : (
<Swipeable index={viewIndex} onChangeIndex={handleChangeViewIndex}>
<StatsTotals latestStats={latestStats} stats={stats} />
<StatsAssets latestStats={latestStats} stats={stats} />
<StatsPerps perpStats={perpStats} />
</Swipeable>
)}
</div>
</PageBodyContainer>
</div>
)
}
const TabContent = ({ activeTab, latestStats, perpStats, stats }) => {
switch (activeTab) {
case 'Totals':
return <StatsTotals latestStats={latestStats} stats={stats} />
case 'Assets':
return <StatsAssets latestStats={latestStats} stats={stats} />
case 'Perps':
return <StatsPerps perpStats={perpStats} />
default:
return <StatsTotals latestStats={latestStats} stats={stats} />
}
}