From 9d8ad541fd5b77d374a6a2a0ca23908d13a1e0a7 Mon Sep 17 00:00:00 2001 From: jordansexton Date: Fri, 25 Jun 2021 17:07:03 -0500 Subject: [PATCH] [WIP] fix borrowing --- .../src/components/BorrowInput/index.tsx | 86 ++++--------------- .../lending/src/hooks/useBorrowingPower.ts | 5 +- 2 files changed, 17 insertions(+), 74 deletions(-) diff --git a/packages/lending/src/components/BorrowInput/index.tsx b/packages/lending/src/components/BorrowInput/index.tsx index 90ab01ce..3fb7e26b 100644 --- a/packages/lending/src/components/BorrowInput/index.tsx +++ b/packages/lending/src/components/BorrowInput/index.tsx @@ -15,7 +15,7 @@ import { useSliderInput, useUserBalance, useUserDeposits, - useUserObligationByReserve, + useUserObligationByReserve, useUserObligations } from '../../hooks'; import { Reserve, ReserveParser } from '../../models'; import CollateralInput from '../CollateralInput'; @@ -32,22 +32,15 @@ export const BorrowInput = (props: { }) => { const connection = useConnection(); const { wallet } = useWallet(); - const [collateralValue, setCollateralValue] = useState(''); - const [lastTyped, setLastTyped] = useState('collateral'); + const { userDeposits } = useUserDeposits(); + const { userObligations } = useUserObligations(); + const [pendingTx, setPendingTx] = useState(false); const [showConfirmation, setShowConfirmation] = useState(false); const borrowReserve = props.reserve; + const depositReserves = []; - const [depositReserveKey, setCollateralReserveKey] = useState(); - - const depositReserve = useMemo(() => { - const id: string = - cache.byParser(ReserveParser).find(acc => acc === depositReserveKey) || - ''; - - return cache.get(id) as ParsedAccount; - }, [depositReserveKey]); const borrowPrice = usePrice( borrowReserve.info.liquidity.mintPubkey.toBase58(), ); @@ -55,14 +48,7 @@ export const BorrowInput = (props: { depositReserve?.info.liquidity.mintPubkey.toBase58(), ); - const include = useMemo(() => new Set([depositReserve?.pubkey.toBase58()]), [ - depositReserve, - ]); - - const exclude = useMemo(() => new Set([]), []); - - const { userDeposits: accountBalance } = useUserDeposits(exclude, include); - const tokenBalance = accountBalance[0]?.info.amount || 0; + const tokenBalance = userDeposits[0]?.info.amount || 0; const convert = useCallback( (val: string | number) => { @@ -79,44 +65,18 @@ export const BorrowInput = (props: { const { value, setValue, pct } = useSliderInput(convert); useEffect(() => { - if (depositReserve && lastTyped === 'collateral') { - const ltv = borrowReserve.info.config.loanToValueRatio / 100; - - if (collateralValue) { - const nCollateralValue = parseFloat(collateralValue); - const borrowInUSD = nCollateralValue * collateralPrice * ltv; - const borrowAmount = borrowInUSD / borrowPrice; - setValue(borrowAmount.toString()); - } else { - setValue(''); - } - } - }, [ - lastTyped, - depositReserve, - collateralPrice, - borrowPrice, - borrowReserve, - collateralValue, - setValue, - ]); - - useEffect(() => { - if (depositReserve && lastTyped === 'borrow') { - const ltv = borrowReserve.info.config.loanToValueRatio / 100; - - if (value) { - const nValue = parseFloat(value); - const borrowInUSD = nValue * borrowPrice; - const collateralAmount = borrowInUSD / ltv / collateralPrice; - setCollateralValue(collateralAmount.toString()); - } else { - setCollateralValue(''); - } + const ltv = borrowReserve.info.config.loanToValueRatio / 100; + + if (value) { + const nValue = parseFloat(value); + const borrowInUSD = nValue * borrowPrice; + const collateralAmount = borrowInUSD / ltv / collateralPrice; + // @FIXME + setCollateralValue(collateralAmount.toString()); + } else { + setCollateralValue(''); } }, [ - lastTyped, - depositReserve, collateralPrice, borrowPrice, borrowReserve, @@ -198,19 +158,6 @@ export const BorrowInput = (props: { alignItems: 'center', }} > - { - setCollateralValue(val?.toString() || ''); - setLastTyped('collateral'); - }} - onCollateralReserve={key => { - setCollateralReserveKey(key); - }} - useFirstReserve={true} - />
{ setValue(val?.toString() || ''); - setLastTyped('borrow'); }} disabled={true} hideBalance={true} diff --git a/packages/lending/src/hooks/useBorrowingPower.ts b/packages/lending/src/hooks/useBorrowingPower.ts index e77bb337..0df07b82 100644 --- a/packages/lending/src/hooks/useBorrowingPower.ts +++ b/packages/lending/src/hooks/useBorrowingPower.ts @@ -25,10 +25,7 @@ export function useBorrowingPower( const liquidityMint = reserve?.info.liquidity.mintPubkey; const liquidityMintAddress = liquidityMint?.toBase58(); - const exclude = useMemo(() => new Set([key]), [key]); - const inlcude = undefined; - - const { totalInQuote } = useUserDeposits(exclude, inlcude); + const { totalInQuote } = useUserDeposits(); const price = usePrice(liquidityMintAddress);