mango-v4-ui/components/account/AccountOverview.tsx

142 lines
5.1 KiB
TypeScript

import { useMemo, useState } from 'react'
import AccountActions from './AccountActions'
import useMangoGroup from 'hooks/useMangoGroup'
import useMangoAccount from 'hooks/useMangoAccount'
import { toUiDecimalsForQuote } from '@blockworks-foundation/mango-v4'
import useAccountPerformanceData from 'hooks/useAccountPerformanceData'
import dayjs from 'dayjs'
import AccountHeroStats from './AccountHeroStats'
import { useTranslation } from 'react-i18next'
import Explore from '@components/explore/Explore'
import DetailedAreaOrBarChart from '@components/shared/DetailedAreaOrBarChart'
import { formatYAxis } from 'utils/formatting'
import { useWallet } from '@solana/wallet-adapter-react'
import ConnectEmptyState from '@components/shared/ConnectEmptyState'
import CreateAccountModal from '@components/modals/CreateAccountModal'
import { FaceSmileIcon } from '@heroicons/react/20/solid'
import Button from '@components/shared/Button'
const EMPTY_STATE_WRAPPER_CLASSES =
'flex h-[180px] flex-col justify-center pb-4 md:h-full'
const DEFAULT_CHART_DATA = [
{
account_equity: 0,
time: dayjs().subtract(1, 'hour').toISOString(),
borrow_interest_cumulative_usd: 0,
deposit_interest_cumulative_usd: 0,
pnl: 0,
spot_value: 0,
transfer_balance: 0,
},
{
account_equity: 0,
time: dayjs().toISOString(),
borrow_interest_cumulative_usd: 0,
deposit_interest_cumulative_usd: 0,
pnl: 0,
spot_value: 0,
transfer_balance: 0,
},
]
const AccountOverview = () => {
const { t } = useTranslation(['common', 'governance'])
const { group } = useMangoGroup()
const { mangoAccount, initialLoad } = useMangoAccount()
const { connected } = useWallet()
const { performanceData, loadingPerformanceData } =
useAccountPerformanceData()
const [daysToShow, setDaysToShow] = useState('1')
const [showCreateAccountModal, setShowCreateAccountModal] = useState(false)
const accountValue = useMemo(() => {
if (!group || !mangoAccount) return 0
return toUiDecimalsForQuote(mangoAccount.getEquity(group).toNumber())
}, [group, mangoAccount])
const latestAccountData = useMemo(() => {
if (!performanceData || !performanceData?.length) return []
const latestDataItem = performanceData[performanceData.length - 1]
return [
{
account_equity: accountValue,
time: dayjs().toISOString(),
borrow_interest_cumulative_usd:
latestDataItem.borrow_interest_cumulative_usd,
deposit_interest_cumulative_usd:
latestDataItem.deposit_interest_cumulative_usd,
pnl: latestDataItem.pnl,
spot_value: latestDataItem.spot_value,
transfer_balance: latestDataItem.transfer_balance,
},
]
}, [accountValue, performanceData])
const chartData = useMemo(() => {
if (performanceData && performanceData?.length)
return performanceData.concat(latestAccountData)
if (!latestAccountData.length) {
return DEFAULT_CHART_DATA
}
}, [latestAccountData, performanceData])
return (
<>
<div className="grid grid-cols-12 border-b border-th-bkg-3">
<div className="col-span-12 border-b border-th-bkg-3 pt-4 md:col-span-8 md:border-b-0 md:border-r">
<div className="flex h-full w-full flex-col justify-between">
{mangoAccount || (connected && initialLoad) ? (
<div className="px-4 pb-4 md:px-6">
<DetailedAreaOrBarChart
changeAsPercent
data={chartData}
daysToShow={daysToShow}
setDaysToShow={setDaysToShow}
loading={loadingPerformanceData || initialLoad}
heightClass="h-[180px] lg:h-[205px]"
hideAxis
loaderHeightClass="h-[290px] lg:h-[315px]"
prefix="$"
tickFormat={(x) => `$${formatYAxis(x)}`}
title={t('account-value')}
xKey="time"
yKey="account_equity"
isPrivate
/>
</div>
) : connected ? (
<div className={EMPTY_STATE_WRAPPER_CLASSES}>
<div className="flex flex-col items-center">
<FaceSmileIcon className="mb-2 h-6 w-6 text-th-fgd-4" />
<p className="mb-4">Create a Mango Account to get started</p>
<Button onClick={() => setShowCreateAccountModal(true)}>
{t('create-account')}
</Button>
</div>
</div>
) : (
<div className={EMPTY_STATE_WRAPPER_CLASSES}>
<ConnectEmptyState text={t('governance:connect-wallet')} />
</div>
)}
<AccountActions />
</div>
</div>
<div className="col-span-12 md:col-span-4">
<AccountHeroStats accountValue={accountValue} />
</div>
</div>
<Explore />
{showCreateAccountModal ? (
<CreateAccountModal
isOpen={showCreateAccountModal}
onClose={() => setShowCreateAccountModal(false)}
/>
) : null}
</>
)
}
export default AccountOverview