MP-3376: overpay on repay (#438)

* MP-3376: overpay on repay

* fix: remove Buffer and fix NaN on useSpring
This commit is contained in:
Linkie Link 2023-09-07 10:28:57 +02:00 committed by GitHub
parent 93e725fc59
commit 1e4fd898df
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 17 additions and 8 deletions

View File

@ -19,7 +19,6 @@ import { FormattedNumber } from 'components/FormattedNumber'
import { SortAsc, SortDesc, SortNone } from 'components/Icons' import { SortAsc, SortDesc, SortNone } from 'components/Icons'
import Text from 'components/Text' import Text from 'components/Text'
import { ASSETS } from 'constants/assets' import { ASSETS } from 'constants/assets'
import { BN_ZERO } from 'constants/math'
import { ORACLE_DENOM } from 'constants/oracle' import { ORACLE_DENOM } from 'constants/oracle'
import useCurrentAccount from 'hooks/useCurrentAccount' import useCurrentAccount from 'hooks/useCurrentAccount'
import useStore from 'store' import useStore from 'store'
@ -85,8 +84,8 @@ export default function Index(props: Props) {
accessorKey: 'size', accessorKey: 'size',
header: 'Size', header: 'Size',
cell: ({ row }) => { cell: ({ row }) => {
if (row.original.amount.isEqualTo(BN_ZERO)) if (row.original.type === 'vault')
return <span className='w-full text-xs text-center'>&ndash;</span> return <p className='text-xs text-right number'>&ndash;</p>
const color = getAmountChangeColor(row.original.type, row.original.amountChange) const color = getAmountChangeColor(row.original.type, row.original.amountChange)
const amount = demagnify( const amount = demagnify(
row.original.amount, row.original.amount,
@ -229,4 +228,4 @@ export default function Index(props: Props) {
</tbody> </tbody>
</table> </table>
) )
} }

View File

@ -28,8 +28,8 @@ export const FormattedNumber = React.memo(
}, [props.amount]) }, [props.amount])
const springAmount = useSpring({ const springAmount = useSpring({
number: props.amount, number: isNaN(props.amount) ? 0 : props.amount,
from: { number: prevAmountRef.current }, from: { number: isNaN(prevAmountRef.current) ? 0 : prevAmountRef.current },
config: { duration: 1000 }, config: { duration: 1000 },
}) })

View File

@ -65,6 +65,7 @@ function BorrowModal(props: Props) {
const { simulateBorrow, simulateRepay } = useUpdatedAccount(account) const { simulateBorrow, simulateRepay } = useUpdatedAccount(account)
const { autoLendEnabledAccountIds } = useAutoLend() const { autoLendEnabledAccountIds } = useAutoLend()
const apr = modal.marketData?.borrowRate ?? '0'
const isAutoLendEnabled = autoLendEnabledAccountIds.includes(account.id) const isAutoLendEnabled = autoLendEnabledAccountIds.includes(account.id)
const { computeMaxBorrowAmount } = useHealthComputer(account) const { computeMaxBorrowAmount } = useHealthComputer(account)
@ -112,7 +113,13 @@ function BorrowModal(props: Props) {
(newAmount: BigNumber) => { (newAmount: BigNumber) => {
const coin = BNCoin.fromDenomAndBigNumber(asset.denom, newAmount) const coin = BNCoin.fromDenomAndBigNumber(asset.denom, newAmount)
if (!amount.isEqualTo(newAmount)) setAmount(newAmount) if (!amount.isEqualTo(newAmount)) setAmount(newAmount)
if (isRepay) simulateRepay(coin) if (isRepay) {
const totalDebt = BN(getDebtAmount(modal))
const repayCoin = coin.amount.isGreaterThan(totalDebt)
? BNCoin.fromDenomAndBigNumber(asset.denom, totalDebt)
: coin
simulateRepay(repayCoin)
}
}, },
[asset, amount, isRepay, simulateRepay], [asset, amount, isRepay, simulateRepay],
) )
@ -124,7 +131,10 @@ function BorrowModal(props: Props) {
const lendBalance = account.lends.find(byDenom(asset.denom))?.amount ?? BN_ZERO const lendBalance = account.lends.find(byDenom(asset.denom))?.amount ?? BN_ZERO
const maxBalance = depositBalance.plus(lendBalance) const maxBalance = depositBalance.plus(lendBalance)
const totalDebt = BN(getDebtAmount(modal)) const totalDebt = BN(getDebtAmount(modal))
const maxRepayAmount = BigNumber.min(maxBalance, totalDebt) const maxRepayAmount = BigNumber.min(
maxBalance,
totalDebt.times(1 + Number(apr) / 365 / 24).integerValue(),
)
setMax(maxRepayAmount) setMax(maxRepayAmount)
return return
} }