2022-11-29 16:45:00 +00:00
|
|
|
import classNames from 'classnames'
|
|
|
|
import { useEffect, useState } from 'react'
|
|
|
|
|
2022-12-06 09:20:22 +00:00
|
|
|
import FormattedNumber from 'components/FormattedNumber'
|
|
|
|
import Text from 'components/Text'
|
2022-11-29 16:45:00 +00:00
|
|
|
import Tooltip from 'components/Tooltip'
|
|
|
|
|
|
|
|
interface Props {
|
|
|
|
balance: number
|
|
|
|
limit: number
|
|
|
|
max: number
|
|
|
|
barHeight?: string
|
|
|
|
showTitle?: boolean
|
|
|
|
showPercentageText?: boolean
|
|
|
|
className?: string
|
|
|
|
hideValues?: boolean
|
2022-12-06 09:20:22 +00:00
|
|
|
decimals?: number
|
2022-11-29 16:45:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
export const BorrowCapacity = ({
|
|
|
|
balance,
|
|
|
|
limit,
|
|
|
|
max,
|
|
|
|
barHeight = '22px',
|
|
|
|
showTitle = true,
|
|
|
|
showPercentageText = true,
|
|
|
|
className,
|
|
|
|
hideValues,
|
2022-12-06 09:20:22 +00:00
|
|
|
decimals = 2,
|
2022-11-29 16:45:00 +00:00
|
|
|
}: Props) => {
|
|
|
|
const [percentOfMaxRound, setPercentOfMaxRound] = useState(0)
|
|
|
|
const [percentOfMaxRange, setPercentOfMaxRange] = useState(0)
|
|
|
|
const [limitPercentOfMax, setLimitPercentOfMax] = useState(0)
|
|
|
|
|
|
|
|
useEffect(
|
|
|
|
() => {
|
|
|
|
if (max === 0) {
|
|
|
|
setPercentOfMaxRound(0)
|
|
|
|
setPercentOfMaxRange(0)
|
|
|
|
setLimitPercentOfMax(0)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2022-12-06 09:20:22 +00:00
|
|
|
const pOfMax = +((balance / max) * 100)
|
|
|
|
setPercentOfMaxRound(+(Math.round(pOfMax * 100) / 100))
|
2022-11-29 16:45:00 +00:00
|
|
|
setPercentOfMaxRange(Math.min(Math.max(pOfMax, 0), 100))
|
|
|
|
setLimitPercentOfMax((limit / max) * 100)
|
|
|
|
}, // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
|
|
[balance, max],
|
|
|
|
)
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className={classNames('flex items-center justify-center', className)}>
|
|
|
|
<div style={{ width: '100%' }}>
|
|
|
|
<div
|
|
|
|
className='flex justify-between'
|
|
|
|
style={{
|
|
|
|
width: `${limitPercentOfMax ? limitPercentOfMax + 6 : '100'}%`,
|
|
|
|
marginBottom: !showTitle && hideValues ? 0 : 12,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<div className='text-sm-caps'>{showTitle && 'Borrow Capacity'}</div>
|
|
|
|
{!hideValues && (
|
|
|
|
<div
|
|
|
|
className={classNames(
|
|
|
|
'duration-800 transition-[opcity] delay-[1600ms] text-3xs-caps',
|
|
|
|
limitPercentOfMax ? 'opacity-60' : 'opacity-0',
|
|
|
|
)}
|
|
|
|
>
|
2022-12-06 09:20:22 +00:00
|
|
|
<FormattedNumber animate amount={limit} />
|
2022-11-29 16:45:00 +00:00
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
2022-12-06 09:20:22 +00:00
|
|
|
<Tooltip content={<Text size='sm'>Borrow Capacity Tooltip</Text>}>
|
|
|
|
<div className='relative'>
|
|
|
|
<div
|
|
|
|
className='overflow-hidden rounded-3xl border-r-2 border-r-loss '
|
|
|
|
style={{ height: barHeight }}
|
|
|
|
>
|
|
|
|
<div className='absolute h-full w-full rounded-lg shadow-inset gradient-hatched '>
|
2022-11-29 16:45:00 +00:00
|
|
|
<div
|
2022-12-06 09:20:22 +00:00
|
|
|
className='ease-loss absolute left-0 h-full max-w-full rounded-l-3xl bg-body-dark transition-[right] duration-1000'
|
2022-11-29 16:45:00 +00:00
|
|
|
style={{
|
2022-12-06 09:20:22 +00:00
|
|
|
right: `${limitPercentOfMax ? 100 - limitPercentOfMax : 100}%`,
|
2022-11-29 16:45:00 +00:00
|
|
|
}}
|
2022-12-06 09:20:22 +00:00
|
|
|
/>
|
|
|
|
|
|
|
|
<div className='absolute top-0 h-full w-full'>
|
|
|
|
<div
|
|
|
|
className='h-full rounded-lg transition-[width] duration-1000 ease-linear'
|
2022-11-29 16:45:00 +00:00
|
|
|
style={{
|
2022-12-06 09:20:22 +00:00
|
|
|
width: `${percentOfMaxRange || 0.02}%`,
|
|
|
|
WebkitMask: 'linear-gradient(#fff 0 0)',
|
2022-11-29 16:45:00 +00:00
|
|
|
}}
|
|
|
|
>
|
2022-12-06 09:20:22 +00:00
|
|
|
<div className='absolute top-0 bottom-0 left-0 right-0 gradient-limit' />
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div
|
|
|
|
className='absolute bottom-0 h-[120%] w-[1px] bg-white transition-[left] duration-1000 ease-linear'
|
|
|
|
style={{ left: `${limitPercentOfMax || 0}%` }}
|
|
|
|
/>
|
|
|
|
{showPercentageText ? (
|
|
|
|
<span className='absolute top-1/2 mt-[1px] w-full -translate-y-1/2 animate-fadein text-center opacity-0 text-2xs-caps'>
|
|
|
|
{max !== 0 && (
|
|
|
|
<FormattedNumber
|
|
|
|
className='text-white'
|
|
|
|
animate
|
|
|
|
amount={percentOfMaxRound}
|
|
|
|
minDecimals={decimals}
|
|
|
|
maxDecimals={decimals}
|
|
|
|
suffix='%'
|
|
|
|
abbreviated={false}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</span>
|
|
|
|
) : null}
|
|
|
|
</div>
|
2022-11-29 16:45:00 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</Tooltip>
|
|
|
|
{!hideValues && (
|
|
|
|
<div className='mt-2 flex opacity-60 text-3xs-caps'>
|
2022-12-06 09:20:22 +00:00
|
|
|
<FormattedNumber animate amount={balance} className='mr-1' />
|
2022-11-29 16:45:00 +00:00
|
|
|
<span className='mr-1'>of</span>
|
2022-12-06 09:20:22 +00:00
|
|
|
<FormattedNumber animate amount={max} />
|
2022-11-29 16:45:00 +00:00
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|