mars-v2-frontend/src/components/portfolio/Overview/Summary.tsx
2024-02-19 12:38:04 +01:00

105 lines
3.6 KiB
TypeScript

import { useMemo } from 'react'
import { useParams } from 'react-router-dom'
import useBorrowMarketAssetsTableData from 'components/borrow/Table/useBorrowMarketAssetsTableData'
import DisplayCurrency from 'components/common/DisplayCurrency'
import { FormattedNumber } from 'components/common/FormattedNumber'
import useLendingMarketAssetsTableData from 'components/earn/lend/Table/useLendingMarketAssetsTableData'
import SummarySkeleton from 'components/portfolio/SummarySkeleton'
import { MAX_AMOUNT_DECIMALS } from 'constants/math'
import useAccounts from 'hooks/accounts/useAccounts'
import useAllAssets from 'hooks/assets/useAllAssets'
import useHLSStakingAssets from 'hooks/useHLSStakingAssets'
import usePrices from 'hooks/usePrices'
import useVaultAprs from 'hooks/vaults/useVaultAprs'
import useStore from 'store'
import { getAccountSummaryStats } from 'utils/accounts'
import { DEFAULT_PORTFOLIO_STATS } from 'utils/constants'
export default function PortfolioSummary() {
const { address: urlAddress } = useParams()
const walletAddress = useStore((s) => s.address)
const { data: prices } = usePrices()
const data = useBorrowMarketAssetsTableData()
const borrowAssets = useMemo(() => data?.allAssets || [], [data])
const { allAssets: lendingAssets } = useLendingMarketAssetsTableData()
const { data: accounts } = useAccounts('default', urlAddress || walletAddress)
const { data: hlsStrategies } = useHLSStakingAssets()
const { data: vaultAprs } = useVaultAprs()
const assets = useAllAssets()
const stats = useMemo(() => {
if (!accounts?.length) return
const combinedAccount = accounts.reduce(
(combinedAccount, account) => {
combinedAccount.debts = combinedAccount.debts.concat(account.debts)
combinedAccount.deposits = combinedAccount.deposits.concat(account.deposits)
combinedAccount.lends = combinedAccount.lends.concat(account.lends)
combinedAccount.vaults = combinedAccount.vaults.concat(account.vaults)
return combinedAccount
},
{
id: '1',
deposits: [],
lends: [],
debts: [],
vaults: [],
perps: [],
kind: 'default',
} as Account,
)
const { positionValue, debts, netWorth, apr, leverage } = getAccountSummaryStats(
combinedAccount,
prices,
borrowAssets,
lendingAssets,
hlsStrategies,
assets,
vaultAprs,
)
return [
{
title: <DisplayCurrency className='text-xl' coin={positionValue} />,
sub: DEFAULT_PORTFOLIO_STATS[0].sub,
},
{
title: <DisplayCurrency className='text-xl' coin={debts} />,
sub: DEFAULT_PORTFOLIO_STATS[1].sub,
},
{
title: <DisplayCurrency className='text-xl' coin={netWorth} />,
sub: DEFAULT_PORTFOLIO_STATS[2].sub,
},
{
title: (
<FormattedNumber
className='text-xl'
amount={apr.toNumber()}
options={{
suffix: '%',
maxDecimals: apr.abs().isLessThan(0.1) ? MAX_AMOUNT_DECIMALS : 2,
minDecimals: 2,
}}
/>
),
sub: 'Combined APR',
},
{
title: (
<FormattedNumber
className='text-xl'
amount={isNaN(leverage.toNumber()) ? 1 : leverage.toNumber()}
options={{ suffix: 'x' }}
/>
),
sub: 'Combined leverage',
},
]
}, [accounts, assets, borrowAssets, hlsStrategies, lendingAssets, prices, vaultAprs])
if (!walletAddress && !urlAddress) return null
return <SummarySkeleton title='Portfolio Summary' stats={stats} accountId='' />
}