feat: vault modal header (#323)

* feat: vault modal header

* fix: displaying zero values

* feat: code comments
This commit is contained in:
Yusuf Seyrek 2023-07-28 12:12:13 +03:00 committed by GitHub
parent 184a27e987
commit bd07c20e47
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 114 additions and 13 deletions

View File

@ -20,7 +20,7 @@ function DetailsHeader({ data }: Props) {
<> <>
<TitleAndSubCell <TitleAndSubCell
title={ title={
<> <div className='flex flex-row'>
<FormattedNumber amount={assetApy.toNumber()} options={{ suffix: '%' }} animate /> <FormattedNumber amount={assetApy.toNumber()} options={{ suffix: '%' }} animate />
<FormattedNumber <FormattedNumber
className='ml-2 text-xs' className='ml-2 text-xs'
@ -28,7 +28,7 @@ function DetailsHeader({ data }: Props) {
options={{ suffix: '%/day' }} options={{ suffix: '%/day' }}
animate animate
/> />
</> </div>
} }
sub={'APY'} sub={'APY'}
/> />

View File

@ -0,0 +1,73 @@
import { useMemo } from 'react'
import DisplayCurrency from 'components/DisplayCurrency'
import { FormattedNumber } from 'components/FormattedNumber'
import TitleAndSubCell from 'components/TitleAndSubCell'
import { BN_ZERO } from 'constants/math'
import { BNCoin } from 'types/classes/BNCoin'
import { PRICE_ORACLE_DECIMALS } from 'constants/query'
import { BN } from 'utils/helpers'
interface Props {
vault: Vault | DepositedVault
}
export default function VaultModalContentHeader({ vault }: Props) {
const depositedValue = useMemo(() => {
if ('values' in vault) {
const value = vault.values.primary
.plus(vault.values.secondary)
.shiftedBy(-PRICE_ORACLE_DECIMALS)
// To eliminate super small leftover amounts
// If USD value is smaller than 0.001 returns 0
return BN(value.toFixed(PRICE_ORACLE_DECIMALS / 2))
} else {
return BN_ZERO
}
}, [vault])
return (
<div className='flex gap-6 border-b border-white/5 px-6 py-4 gradient-header'>
{vault.apy && (
<>
<TitleAndSubCell
title={
<div className='flex flex-row'>
<FormattedNumber
amount={vault.apy}
options={{ suffix: '%', decimals: -2 }}
animate
/>
<FormattedNumber
className='ml-2 text-xs'
amount={vault.apy / 365}
options={{ suffix: '%/day', decimals: -2 }}
animate
/>
</div>
}
sub={'Deposit APY'}
/>
<div className='h-100 w-[1px] bg-white/10'></div>
</>
)}
{!depositedValue.isZero() && (
<>
<TitleAndSubCell
title={<DisplayCurrency coin={BNCoin.fromDenomAndBigNumber('usd', depositedValue)} />}
sub={'Deposited'}
/>
<div className='h-100 w-[1px] bg-white/10'></div>
</>
)}
<TitleAndSubCell
title={
<DisplayCurrency coin={BNCoin.fromDenomAndBigNumber(vault.cap.denom, vault.cap.max)} />
}
sub={'Deposit Cap'}
/>
</div>
)
}

View File

@ -1,3 +1,6 @@
import { useCallback, useMemo } from 'react'
import moment from 'moment'
import VaultLogo from 'components/Earn/Farm/VaultLogo' import VaultLogo from 'components/Earn/Farm/VaultLogo'
import Modal from 'components/Modal' import Modal from 'components/Modal'
import VaultModalContent from 'components/Modals/Vault/VaultModalContent' import VaultModalContent from 'components/Modals/Vault/VaultModalContent'
@ -5,6 +8,9 @@ import Text from 'components/Text'
import { ASSETS } from 'constants/assets' import { ASSETS } from 'constants/assets'
import useCurrentAccount from 'hooks/useCurrentAccount' import useCurrentAccount from 'hooks/useCurrentAccount'
import useStore from 'store' import useStore from 'store'
import VaultModalContentHeader from 'components/Modals/Vault/VaultModalContentHeader'
import { InfoCircle } from 'components/Icons'
import { Tooltip } from 'components/Tooltip'
export default function VaultModalController() { export default function VaultModalController() {
const currentAccount = useCurrentAccount() const currentAccount = useCurrentAccount()
@ -32,28 +38,50 @@ interface Props {
} }
function VaultModal(props: Props) { function VaultModal(props: Props) {
function onClose() { const {
modal: { vault, isDeposited },
primaryAsset,
secondaryAsset,
currentAccount,
} = props
const onClose = useCallback(() => {
useStore.setState({ vaultModal: null }) useStore.setState({ vaultModal: null })
} }, [])
const unlockTime = useMemo(() => {
if ('unlocksAt' in vault && vault.unlocksAt) {
return moment(vault.unlocksAt)
}
}, [vault])
return ( return (
<Modal <Modal
onClose={onClose} onClose={onClose}
header={ header={
<span className='flex items-center gap-4 px-4'> <span className='flex items-center px-4'>
<VaultLogo vault={props.modal.vault} /> <VaultLogo vault={vault} />
<Text>{props.modal.vault.name}</Text> <Text className='pl-3 pr-2'>{vault.name}</Text>
{unlockTime && (
<Tooltip
content={`Account position for this vault unlocks at ${unlockTime}`}
type={'info'}
>
<InfoCircle width={16} height={16} />
</Tooltip>
)}
</span> </span>
} }
headerClassName='gradient-header pl-2 pr-2.5 py-2.5 border-b-white/5 border-b' headerClassName='gradient-header pl-2 pr-2.5 py-2.5 border-b-white/5 border-b'
contentClassName='flex flex-col' contentClassName='flex flex-col'
> >
<VaultModalContentHeader vault={vault} />
<VaultModalContent <VaultModalContent
vault={props.modal.vault} vault={vault}
primaryAsset={props.primaryAsset} primaryAsset={primaryAsset}
secondaryAsset={props.secondaryAsset} secondaryAsset={secondaryAsset}
account={props.currentAccount} account={currentAccount}
isDeposited={props.modal.isDeposited} isDeposited={isDeposited}
/> />
</Modal> </Modal>
) )

View File

@ -45,7 +45,7 @@ interface VaultValuesAndAmounts {
secondary: BigNumber secondary: BigNumber
locked: BigNumber locked: BigNumber
unlocked: BigNumber unlocked: BigNumber
unlocking: BigNumer unlocking: BigNumber
} }
values: { values: {
primary: BigNumber primary: BigNumber