From 9cd7106dcda0c2c980c555b8d2af50d67e2f1591 Mon Sep 17 00:00:00 2001 From: martines3000 Date: Tue, 8 Oct 2024 15:44:07 +0200 Subject: [PATCH 1/3] chore: add reservers to availalbe liquidity --- .../src/components/InputDialog/index.tsx | 2 +- .../components/MarketsView/MarketOverview.tsx | 8 +-- .../src/hooks/useMarketBalanceOfBase.ts | 49 +++++++++++-------- apps/frontend/src/hooks/useTotalReserves.ts | 4 +- 4 files changed, 37 insertions(+), 26 deletions(-) diff --git a/apps/frontend/src/components/InputDialog/index.tsx b/apps/frontend/src/components/InputDialog/index.tsx index 069438c8..5ca20019 100644 --- a/apps/frontend/src/components/InputDialog/index.tsx +++ b/apps/frontend/src/components/InputDialog/index.tsx @@ -53,7 +53,7 @@ export const InputDialog = () => { } = useMarketStore(); const { data: priceData } = usePrice(); - const marketBalanceOfBase = useMarketBalanceOfBase(); + const { data: marketBalanceOfBase } = useMarketBalanceOfBase(); const { mutate: supplyCollateral } = useSupplyCollateral({ actionTokenAssetId, diff --git a/apps/frontend/src/components/MarketsView/MarketOverview.tsx b/apps/frontend/src/components/MarketsView/MarketOverview.tsx index 41755ebb..3150a835 100644 --- a/apps/frontend/src/components/MarketsView/MarketOverview.tsx +++ b/apps/frontend/src/components/MarketsView/MarketOverview.tsx @@ -46,14 +46,14 @@ export default function MarketOverview({ }: MarketOverviewProps) { const { data: borrowRate } = useBorrowRate(baseAsset); const { data: supplyRate } = useSupplyRate(baseAsset); - const { data: totalReserves } = useTotalReserves(baseAsset); + const { data: totalReserves } = useTotalReserves(); const { data: collateralConfigurations } = useCollateralConfigurations(baseAsset); const { data: marketConfiguration } = useMarketConfiguration(baseAsset); const borrowApr = useMemo(() => getBorrowApr(borrowRate), [borrowRate]); const supplyApr = useMemo(() => getSupplyApr(supplyRate), [supplyRate]); - const availableLiquidity = useMarketBalanceOfBase(baseAsset); + const { data: availableLiquidity } = useMarketBalanceOfBase(baseAsset); const { data: totalCollateral } = useTotalCollateral(baseAsset); const { data: marketBasics } = useMarketBasics(baseAsset); @@ -195,7 +195,9 @@ export default function MarketOverview({ Available Liquidity
- {getFormattedPrice(availableLiquidity.formatted)} + {getFormattedPrice( + availableLiquidity?.formatted ?? BigNumber(0) + )}
diff --git a/apps/frontend/src/hooks/useMarketBalanceOfBase.ts b/apps/frontend/src/hooks/useMarketBalanceOfBase.ts index 4a1b486f..5a8c07e9 100644 --- a/apps/frontend/src/hooks/useMarketBalanceOfBase.ts +++ b/apps/frontend/src/hooks/useMarketBalanceOfBase.ts @@ -2,31 +2,40 @@ import { formatUnits } from '@/utils'; import BigNumber from 'bignumber.js'; import { useMarketBasics } from './useMarketBasics'; import { useMarketConfiguration } from './useMarketConfiguration'; +import { useQuery } from '@tanstack/react-query'; +import { useMarketStore } from '@/stores'; +import { useTotalReserves } from './useTotalReserves'; export const useMarketBalanceOfBase = (marketParam?: string) => { const { data: marketBasics } = useMarketBasics(marketParam); const { data: marketConfiguration } = useMarketConfiguration(marketParam); + const { data: totalReserves } = useTotalReserves(marketParam); + const { market: storeMarket } = useMarketStore(); + const market = marketParam ?? storeMarket; - if ( - !marketBasics || - !marketBasics.total_borrow_base || - !marketBasics.total_supply_base || - !marketConfiguration - ) - return { - raw: BigNumber(0), - formatted: BigNumber(0), - }; + return useQuery({ + queryKey: ['marketBalanceOfBase', market], + queryFn: async () => { + if (!marketBasics || !marketConfiguration || !totalReserves) { + return { + raw: BigNumber(0), + formatted: BigNumber(0), + }; + } - const balanceOfBase = BigNumber( - marketBasics.total_supply_base.toString() - ).minus(BigNumber(marketBasics.total_borrow_base.toString())); + const balanceOfBase = BigNumber(marketBasics.total_supply_base.toString()) + .minus(BigNumber(marketBasics.total_borrow_base.toString())) + .plus(totalReserves); - return { - raw: balanceOfBase, - formatted: formatUnits( - balanceOfBase, - marketConfiguration.baseTokenDecimals - ), - }; + return { + raw: balanceOfBase, + formatted: formatUnits( + balanceOfBase, + marketConfiguration.baseTokenDecimals + ), + }; + }, + refetchOnWindowFocus: false, + enabled: !!marketBasics && !!marketConfiguration && !!totalReserves, + }); }; diff --git a/apps/frontend/src/hooks/useTotalReserves.ts b/apps/frontend/src/hooks/useTotalReserves.ts index 77d465f9..f7bb52a9 100644 --- a/apps/frontend/src/hooks/useTotalReserves.ts +++ b/apps/frontend/src/hooks/useTotalReserves.ts @@ -6,7 +6,7 @@ import { useQuery } from '@tanstack/react-query'; import BigNumber from 'bignumber.js'; import { useProvider } from './useProvider'; -export const useTotalReserves = (assetId: string, marketParam?: string) => { +export const useTotalReserves = (marketParam?: string) => { const provider = useProvider(); const { market: storeMarket } = useMarketStore(); const market = marketParam ?? storeMarket; @@ -14,7 +14,7 @@ export const useTotalReserves = (assetId: string, marketParam?: string) => { return useQuery({ queryKey: ['totalReserves', market], queryFn: async () => { - if (!provider || !assetId) return BigNumber(0); + if (!provider) return BigNumber(0); const marketContract = new Market( appConfig.markets[market].marketAddress, From ae67f38f916852ebeebd190d5a38be229246fd91 Mon Sep 17 00:00:00 2001 From: martines3000 Date: Tue, 8 Oct 2024 15:44:21 +0200 Subject: [PATCH 2/3] chore: lint --- apps/frontend/src/hooks/useMarketBalanceOfBase.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/apps/frontend/src/hooks/useMarketBalanceOfBase.ts b/apps/frontend/src/hooks/useMarketBalanceOfBase.ts index 5a8c07e9..64403903 100644 --- a/apps/frontend/src/hooks/useMarketBalanceOfBase.ts +++ b/apps/frontend/src/hooks/useMarketBalanceOfBase.ts @@ -1,9 +1,9 @@ +import { useMarketStore } from '@/stores'; import { formatUnits } from '@/utils'; +import { useQuery } from '@tanstack/react-query'; import BigNumber from 'bignumber.js'; import { useMarketBasics } from './useMarketBasics'; import { useMarketConfiguration } from './useMarketConfiguration'; -import { useQuery } from '@tanstack/react-query'; -import { useMarketStore } from '@/stores'; import { useTotalReserves } from './useTotalReserves'; export const useMarketBalanceOfBase = (marketParam?: string) => { From ed0b33599d58706003deefc3b1a887bf5b479a68 Mon Sep 17 00:00:00 2001 From: martines3000 Date: Wed, 9 Oct 2024 10:34:39 +0200 Subject: [PATCH 3/3] chore: changesets --- .changeset/light-garlics-notice.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/light-garlics-notice.md diff --git a/.changeset/light-garlics-notice.md b/.changeset/light-garlics-notice.md new file mode 100644 index 00000000..08158ed6 --- /dev/null +++ b/.changeset/light-garlics-notice.md @@ -0,0 +1,5 @@ +--- +"swaylend-dapp": patch +--- + +Fixes wrong calculation of available liquidity on the dapp