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

123 lines
4.2 KiB
TypeScript
Raw Normal View History

2023-02-23 16:28:49 -08:00
import mangoStore from '@store/mangoStore'
import { useTranslation } from 'next-i18next'
import { useEffect, useMemo, useState } from 'react'
import dayjs from 'dayjs'
2023-01-19 02:42:39 -08:00
import { formatYAxis } from 'utils/formatting'
2023-01-29 20:13:38 -08:00
import useBanksWithBalances from 'hooks/useBanksWithBalances'
import useMangoGroup from 'hooks/useMangoGroup'
2023-04-23 23:21:05 -07:00
import { toUiDecimals } from '@blockworks-foundation/mango-v4'
import DetailedAreaOrBarChart from '@components/shared/DetailedAreaOrBarChart'
2023-04-23 23:21:05 -07:00
const TokenStatsCharts = () => {
const { t } = useTranslation(['common', 'token', 'trade'])
const { group } = useMangoGroup()
const mangoStats = mangoStore((s) => s.tokenStats.mangoStats)
const initialStatsLoad = mangoStore((s) => s.tokenStats.initialLoad)
2023-02-09 16:38:20 -08:00
const loadingStats = mangoStore((s) => s.tokenStats.loading)
const [borrowDaysToShow, setBorrowDaysToShow] = useState('30')
const [depositDaysToShow, setDepositDaysToShow] = useState('30')
2023-01-29 20:13:38 -08:00
const banks = useBanksWithBalances()
useEffect(() => {
if (group && !initialStatsLoad) {
const actions = mangoStore.getState().actions
actions.fetchTokenStats()
}
}, [group, initialStatsLoad])
2023-04-23 23:21:05 -07:00
const [
currentTotalDepositValue,
currentTotalBorrowValue,
currentCollectedFeesValue,
] = useMemo(() => {
if (banks.length) {
return [
2023-01-29 20:13:38 -08:00
banks.reduce((a, c) => a + c.bank.uiPrice * c.bank.uiDeposits(), 0),
banks.reduce((a, c) => a + c.bank.uiPrice * c.bank.uiBorrows(), 0),
2023-04-23 23:21:05 -07:00
banks.reduce(
(a, c) =>
a +
c.bank.uiPrice *
toUiDecimals(c.bank.collectedFeesNative, c.bank.mintDecimals),
2023-07-21 11:47:53 -07:00
0,
2023-04-23 23:21:05 -07:00
),
]
}
2023-04-23 23:21:05 -07:00
return [0, 0, 0]
}, [banks])
return (
<>
2023-04-23 23:21:05 -07:00
<div className="col-span-2 border-b border-th-bkg-3 py-4 px-6 md:col-span-1 md:border-r">
<DetailedAreaOrBarChart
data={mangoStats.concat([
{
date: dayjs().toISOString(),
depositValue: Math.floor(currentTotalDepositValue),
borrowValue: Math.floor(currentTotalBorrowValue),
2023-04-23 23:21:05 -07:00
feesCollected: currentCollectedFeesValue,
},
])}
daysToShow={depositDaysToShow}
setDaysToShow={setDepositDaysToShow}
2023-01-19 16:56:22 -08:00
loading={loadingStats}
heightClass="h-64"
2023-01-19 16:56:22 -08:00
loaderHeightClass="h-[350px]"
prefix="$"
2023-01-19 02:42:39 -08:00
tickFormat={(x) => `$${formatYAxis(x)}`}
title={t('total-deposit-value')}
xKey="date"
yKey={'depositValue'}
/>
</div>
2023-04-23 23:21:05 -07:00
<div className="col-span-2 border-b border-th-bkg-3 py-4 px-6 md:col-span-1 md:pl-6">
<DetailedAreaOrBarChart
data={mangoStats.concat([
{
date: dayjs().toISOString(),
borrowValue: Math.floor(currentTotalBorrowValue),
depositValue: Math.floor(currentTotalDepositValue),
2023-04-23 23:21:05 -07:00
feesCollected: currentCollectedFeesValue,
},
])}
daysToShow={borrowDaysToShow}
setDaysToShow={setBorrowDaysToShow}
heightClass="h-64"
2023-01-19 16:56:22 -08:00
loaderHeightClass="h-[350px]"
loading={loadingStats}
prefix="$"
2023-01-19 02:42:39 -08:00
tickFormat={(x) => `$${formatYAxis(x)}`}
title={t('total-borrow-value')}
xKey="date"
yKey={'borrowValue'}
/>
</div>
2023-04-23 23:21:05 -07:00
<div className="col-span-2 border-b border-th-bkg-3 py-4 px-6 md:col-span-1 md:border-r md:pl-6">
<DetailedAreaOrBarChart
data={mangoStats.concat([
2023-04-23 23:21:05 -07:00
{
date: dayjs().toISOString(),
borrowValue: Math.floor(currentTotalBorrowValue),
depositValue: Math.floor(currentTotalDepositValue),
feesCollected: currentCollectedFeesValue,
},
])}
daysToShow={borrowDaysToShow}
setDaysToShow={setBorrowDaysToShow}
heightClass="h-64"
loaderHeightClass="h-[350px]"
loading={loadingStats}
prefix="$"
tickFormat={(x) => `$${formatYAxis(x)}`}
title={t('token:token-fees-collected')}
tooltipContent={t('token:tooltip-token-fees-collected')}
2023-04-23 23:21:05 -07:00
xKey="date"
yKey={'feesCollected'}
/>
</div>
</>
)
}
2023-04-23 23:21:05 -07:00
export default TokenStatsCharts