18c7547c00
* added repay action percentage buffer * moved repay amount calculation to RepayFunds component * refetch interval added to credit account positions query * feat: revamp borrow and repay components to modals * remove references to deleted components * cosmo signing client added to wallet store * amount decimal normalized for borrow action * amount decimals conversion lifted for borrow and repay * refactor: moved hooks to mutations folder * update button disable condition and min input value * refactor: reset modal states when reopened * react-number-format dependency and borrow/repay modals revamp * renamed borrow modal state variable * style: borrow table ui revamp
82 lines
2.3 KiB
TypeScript
82 lines
2.3 KiB
TypeScript
import { useMutation, UseMutationOptions, useQueryClient } from '@tanstack/react-query'
|
|
import { useMemo } from 'react'
|
|
import { toast } from 'react-toastify'
|
|
import BigNumber from 'bignumber.js'
|
|
|
|
import useWalletStore from 'stores/useWalletStore'
|
|
import { contractAddresses } from 'config/contracts'
|
|
import { hardcodedFee } from 'utils/contants'
|
|
import useCreditManagerStore from 'stores/useCreditManagerStore'
|
|
import { queryKeys } from 'types/query-keys-factory'
|
|
import { getTokenDecimals } from 'utils/tokens'
|
|
|
|
// 0.001% buffer / slippage to avoid repay action from not fully repaying the debt amount
|
|
const REPAY_BUFFER = 1.00001
|
|
|
|
const useRepayFunds = (
|
|
amount: number,
|
|
denom: string,
|
|
options: Omit<UseMutationOptions, 'onError'>
|
|
) => {
|
|
const signingClient = useWalletStore((s) => s.signingClient)
|
|
const selectedAccount = useCreditManagerStore((s) => s.selectedAccount)
|
|
const address = useWalletStore((s) => s.address)
|
|
|
|
const queryClient = useQueryClient()
|
|
|
|
const adjustedAmount = BigNumber(amount).times(REPAY_BUFFER).decimalPlaces(0).toString()
|
|
|
|
const executeMsg = useMemo(() => {
|
|
return {
|
|
update_credit_account: {
|
|
account_id: selectedAccount,
|
|
actions: [
|
|
{
|
|
deposit: {
|
|
denom: denom,
|
|
amount: adjustedAmount,
|
|
},
|
|
},
|
|
{
|
|
repay: {
|
|
denom: denom,
|
|
amount: adjustedAmount,
|
|
},
|
|
},
|
|
],
|
|
},
|
|
}
|
|
}, [adjustedAmount, denom, selectedAccount])
|
|
|
|
return useMutation(
|
|
async () =>
|
|
await signingClient?.execute(
|
|
address,
|
|
contractAddresses.creditManager,
|
|
executeMsg,
|
|
hardcodedFee,
|
|
undefined,
|
|
[
|
|
{
|
|
denom,
|
|
amount: adjustedAmount,
|
|
},
|
|
]
|
|
),
|
|
{
|
|
onSettled: () => {
|
|
queryClient.invalidateQueries(queryKeys.creditAccountsPositions(selectedAccount ?? ''))
|
|
queryClient.invalidateQueries(queryKeys.tokenBalance(address, denom))
|
|
queryClient.invalidateQueries(queryKeys.allBalances(address))
|
|
queryClient.invalidateQueries(queryKeys.redbankBalances())
|
|
},
|
|
onError: (err: Error) => {
|
|
toast.error(err.message)
|
|
},
|
|
...options,
|
|
}
|
|
)
|
|
}
|
|
|
|
export default useRepayFunds
|