feat: vault modal header (#323)
* feat: vault modal header * fix: displaying zero values * feat: code comments
This commit is contained in:
parent
184a27e987
commit
bd07c20e47
@ -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'}
|
||||||
/>
|
/>
|
||||||
|
73
src/components/Modals/Vault/VaultModalContentHeader.tsx
Normal file
73
src/components/Modals/Vault/VaultModalContentHeader.tsx
Normal 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>
|
||||||
|
)
|
||||||
|
}
|
@ -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>
|
||||||
)
|
)
|
||||||
|
2
src/types/interfaces/vaults.d.ts
vendored
2
src/types/interfaces/vaults.d.ts
vendored
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user