fix: fixed Borrow infinite render (#488)
* fix: fixed Borrow infinite render * feat: added a Repay not available info * tidy: updated wording
This commit is contained in:
parent
9ced4ab6c9
commit
ca5e424700
@ -8,7 +8,7 @@ import Card from 'components/Card'
|
|||||||
import DisplayCurrency from 'components/DisplayCurrency'
|
import DisplayCurrency from 'components/DisplayCurrency'
|
||||||
import Divider from 'components/Divider'
|
import Divider from 'components/Divider'
|
||||||
import { FormattedNumber } from 'components/FormattedNumber'
|
import { FormattedNumber } from 'components/FormattedNumber'
|
||||||
import { ArrowRight } from 'components/Icons'
|
import { ArrowRight, InfoCircle } from 'components/Icons'
|
||||||
import Modal from 'components/Modal'
|
import Modal from 'components/Modal'
|
||||||
import Switch from 'components/Switch'
|
import Switch from 'components/Switch'
|
||||||
import Text from 'components/Text'
|
import Text from 'components/Text'
|
||||||
@ -28,6 +28,11 @@ import { formatPercent, formatValue } from 'utils/formatters'
|
|||||||
import { BN } from 'utils/helpers'
|
import { BN } from 'utils/helpers'
|
||||||
import { getDebtAmountWithInterest } from 'utils/tokens'
|
import { getDebtAmountWithInterest } from 'utils/tokens'
|
||||||
|
|
||||||
|
interface Props {
|
||||||
|
account: Account
|
||||||
|
modal: BorrowModal
|
||||||
|
}
|
||||||
|
|
||||||
function getDebtAmount(modal: BorrowModal) {
|
function getDebtAmount(modal: BorrowModal) {
|
||||||
return BN((modal.marketData as BorrowMarketTableData)?.debt ?? 0).toString()
|
return BN((modal.marketData as BorrowMarketTableData)?.debt ?? 0).toString()
|
||||||
}
|
}
|
||||||
@ -37,9 +42,21 @@ function getAssetLogo(modal: BorrowModal) {
|
|||||||
return <AssetImage asset={modal.asset} size={24} />
|
return <AssetImage asset={modal.asset} size={24} />
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Props {
|
function RepayNotAvailable(props: { asset: Asset }) {
|
||||||
account: Account
|
return (
|
||||||
modal: BorrowModal
|
<Card className='mt-6'>
|
||||||
|
<div className='flex items-start p-4'>
|
||||||
|
<InfoCircle width={26} className='mr-2' />
|
||||||
|
<div className='flex flex-col gap-1'>
|
||||||
|
<Text size='sm'>No funds for repay</Text>
|
||||||
|
<Text
|
||||||
|
size='xs'
|
||||||
|
className='text-white/40'
|
||||||
|
>{`Unfortunately you don't have any ${props.asset.symbol} in your Credit Account to repay the debt.`}</Text>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</Card>
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function BorrowModalController() {
|
export default function BorrowModalController() {
|
||||||
@ -69,11 +86,24 @@ function BorrowModal(props: Props) {
|
|||||||
const { computeMaxBorrowAmount } = useHealthComputer(account)
|
const { computeMaxBorrowAmount } = useHealthComputer(account)
|
||||||
const totalDebt = BN(getDebtAmount(modal))
|
const totalDebt = BN(getDebtAmount(modal))
|
||||||
|
|
||||||
|
const [depositBalance, lendBalance] = useMemo(
|
||||||
|
() => [
|
||||||
|
account.deposits.find(byDenom(asset.denom))?.amount ?? BN_ZERO,
|
||||||
|
account.lends.find(byDenom(asset.denom))?.amount ?? BN_ZERO,
|
||||||
|
],
|
||||||
|
[account, asset.denom],
|
||||||
|
)
|
||||||
|
|
||||||
const totalDebtRepayAmount = useMemo(
|
const totalDebtRepayAmount = useMemo(
|
||||||
() => getDebtAmountWithInterest(totalDebt, Number(apr)),
|
() => getDebtAmountWithInterest(totalDebt, Number(apr)),
|
||||||
[totalDebt, apr],
|
[totalDebt, apr],
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const maxRepayAmount = useMemo(() => {
|
||||||
|
const maxBalance = depositBalance.plus(lendBalance)
|
||||||
|
return isRepay ? BigNumber.min(maxBalance, totalDebtRepayAmount) : BN_ZERO
|
||||||
|
}, [depositBalance, lendBalance, isRepay, totalDebtRepayAmount])
|
||||||
|
|
||||||
function resetState() {
|
function resetState() {
|
||||||
setAmount(BN_ZERO)
|
setAmount(BN_ZERO)
|
||||||
}
|
}
|
||||||
@ -131,26 +161,20 @@ function BorrowModal(props: Props) {
|
|||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!account || isRepay) return
|
if (!account || isRepay) return
|
||||||
if (maxBorrow !== max) setMax(maxBorrow)
|
if (maxBorrow.isEqualTo(max)) return
|
||||||
|
setMax(maxBorrow)
|
||||||
}, [account, isRepay, maxBorrow, max])
|
}, [account, isRepay, maxBorrow, max])
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!account) return
|
if (!isRepay) return
|
||||||
if (isRepay) {
|
if (maxRepayAmount.isEqualTo(max)) return
|
||||||
const depositBalance = account.deposits.find(byDenom(asset.denom))?.amount ?? BN_ZERO
|
setMax(maxRepayAmount)
|
||||||
const lendBalance = account.lends.find(byDenom(asset.denom))?.amount ?? BN_ZERO
|
}, [isRepay, max, maxRepayAmount])
|
||||||
const maxBalance = depositBalance.plus(lendBalance)
|
|
||||||
const maxRepayAmount = BigNumber.min(maxBalance, totalDebtRepayAmount)
|
|
||||||
setMax(maxRepayAmount)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}, [account, asset.denom, isRepay, totalDebtRepayAmount])
|
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (amount.isGreaterThan(max)) {
|
if (amount.isLessThanOrEqualTo(max)) return
|
||||||
handleChange(max)
|
handleChange(max)
|
||||||
setAmount(max)
|
setAmount(max)
|
||||||
}
|
|
||||||
}, [amount, max, handleChange])
|
}, [amount, max, handleChange])
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
@ -223,9 +247,11 @@ function BorrowModal(props: Props) {
|
|||||||
onChange={handleChange}
|
onChange={handleChange}
|
||||||
amount={amount}
|
amount={amount}
|
||||||
max={max}
|
max={max}
|
||||||
|
disabled={max.isZero()}
|
||||||
className='w-full'
|
className='w-full'
|
||||||
maxText='Max'
|
maxText='Max'
|
||||||
/>
|
/>
|
||||||
|
{isRepay && maxRepayAmount.isZero() && <RepayNotAvailable asset={asset} />}
|
||||||
{!isRepay && (
|
{!isRepay && (
|
||||||
<>
|
<>
|
||||||
<Divider className='my-6' />
|
<Divider className='my-6' />
|
||||||
|
@ -128,32 +128,34 @@ export default function Slider(props: Props) {
|
|||||||
disabled={props.disabled}
|
disabled={props.disabled}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<div onMouseEnter={handleShowTooltip} onMouseLeave={handleHideTooltip}>
|
{!props.disabled && (
|
||||||
<DraggableElement
|
<div onMouseEnter={handleShowTooltip} onMouseLeave={handleHideTooltip}>
|
||||||
nodeRef={nodeRef}
|
<DraggableElement
|
||||||
axis='x'
|
nodeRef={nodeRef}
|
||||||
grid={[sliderRect.width / 100, 0]}
|
axis='x'
|
||||||
bounds={{ left: 0, right: sliderRect.width }}
|
grid={[sliderRect.width / 100, 0]}
|
||||||
positionOffset={{ x: (props.value / 100) * -12, y: 0 }}
|
bounds={{ left: 0, right: sliderRect.width }}
|
||||||
onDrag={handleDrag}
|
positionOffset={{ x: (props.value / 100) * -12, y: 0 }}
|
||||||
onStop={() => setIsDragging(false)}
|
onDrag={handleDrag}
|
||||||
position={{ x: (sliderRect.width / 100) * props.value, y: 0 }}
|
onStop={() => setIsDragging(false)}
|
||||||
>
|
position={{ x: (sliderRect.width / 100) * props.value, y: 0 }}
|
||||||
<div ref={nodeRef} className='absolute z-20 leading-3'>
|
>
|
||||||
<div
|
<div ref={nodeRef} className='absolute z-20 leading-3'>
|
||||||
className={
|
<div
|
||||||
'z-20 h-3 w-3 rotate-45 hover:cursor-pointer rounded-xs border-[2px] border-white bg-martian-red'
|
className={
|
||||||
}
|
'z-20 h-3 w-3 rotate-45 hover:cursor-pointer rounded-xs border-[2px] border-white bg-martian-red'
|
||||||
/>
|
}
|
||||||
{(showTooltip || isDragging) && (
|
/>
|
||||||
<div className='absolute -top-8 left-1/2 -translate-x-1/2 rounded-xs bg-martian-red px-2 py-[2px] text-xs'>
|
{(showTooltip || isDragging) && (
|
||||||
<OverlayMark className='absolute h-2 -translate-x-1/2 -bottom-2 left-1/2 -z-1 text-martian-red' />
|
<div className='absolute -top-8 left-1/2 -translate-x-1/2 rounded-xs bg-martian-red px-2 py-[2px] text-xs'>
|
||||||
{props.value.toFixed(0)}%
|
<OverlayMark className='absolute h-2 -translate-x-1/2 -bottom-2 left-1/2 -z-1 text-martian-red' />
|
||||||
</div>
|
{props.value.toFixed(0)}%
|
||||||
)}
|
</div>
|
||||||
</div>
|
)}
|
||||||
</DraggableElement>
|
</div>
|
||||||
</div>
|
</DraggableElement>
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
@ -170,7 +172,9 @@ function Mark(props: MarkProps) {
|
|||||||
<button
|
<button
|
||||||
onClick={() => props.onClick(props.value)}
|
onClick={() => props.onClick(props.value)}
|
||||||
className={`z-20 h-3 w-3 rotate-45 rounded-xs border-[1px] border-white/20 hover:border-[2px] hover:border-white ${
|
className={`z-20 h-3 w-3 rotate-45 rounded-xs border-[1px] border-white/20 hover:border-[2px] hover:border-white ${
|
||||||
props.sliderValue >= props.value ? 'bg-martian-red hover:border-white' : 'bg-grey-medium'
|
props.sliderValue >= props.value && !props.disabled
|
||||||
|
? 'bg-martian-red hover:border-white'
|
||||||
|
: 'bg-grey-medium'
|
||||||
}`}
|
}`}
|
||||||
disabled={props.disabled}
|
disabled={props.disabled}
|
||||||
></button>
|
></button>
|
||||||
|
Loading…
Reference in New Issue
Block a user