From 298d994a36df277220c6dd30c9c6583ae0f0efd9 Mon Sep 17 00:00:00 2001 From: Spacebean Date: Fri, 21 Jun 2024 17:35:49 -0600 Subject: [PATCH] feat: fix twa reserves query --- .../src/wells/useMultiFlowPumpTWAReserves.tsx | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/projects/dex-ui/src/wells/useMultiFlowPumpTWAReserves.tsx b/projects/dex-ui/src/wells/useMultiFlowPumpTWAReserves.tsx index d4a0420ce3..88c1dfa7ae 100644 --- a/projects/dex-ui/src/wells/useMultiFlowPumpTWAReserves.tsx +++ b/projects/dex-ui/src/wells/useMultiFlowPumpTWAReserves.tsx @@ -12,14 +12,14 @@ import { config } from "src/utils/wagmi/config"; export const useMultiFlowPumpTWAReserves = () => { const { data: wells } = useWells(); - const { getIsMultiPumpWell } = useBeanstalkSiloWhitelist(); + const { getIsMultiPumpWell, getIsWhitelisted } = useBeanstalkSiloWhitelist(); const sdk = useSdk(); const query = useQuery({ queryKey: ["wells", "multiFlowPumpTWAReserves"], queryFn: async () => { - const whitelistedWells = (wells || []).filter((well) => getIsMultiPumpWell(well)); + const whitelistedWells = (wells || []).filter((well) => getIsMultiPumpWell(well) && getIsWhitelisted(well) ); const [{ timestamp: seasonTimestamp }, ...wellOracleSnapshots] = await Promise.all([ sdk.contracts.beanstalk.time(), @@ -42,24 +42,23 @@ export const useMultiFlowPumpTWAReserves = () => { const twaReservesResult: any[] = await multicall(config, { contracts: calls }); const mapping: Record = {}; - let index = 0; whitelistedWells.forEach((well) => { const twa = [TokenValue.ZERO, TokenValue.ZERO]; const numPumps = well.pumps?.length || 1; - well.pumps?.forEach((_pump) => { - const twaResult = twaReservesResult[index]; + well.pumps?.forEach((_pump, index) => { + const indexedResult = twaReservesResult[index]; + if (indexedResult.error) return; + + const reserves = indexedResult?.result?.[0] const token1 = well.tokens?.[0]; const token2 = well.tokens?.[1]; - const reserves = twaResult["twaReserves"]; - - if (token1 && token2 && reserves.length === 2) { + if (token1 && token2 && reserves.length === 2 && reserves.length === 2) { twa[0] = twa[0].add(TokenValue.fromBlockchain(reserves[0], token1.decimals)); twa[1] = twa[1].add(TokenValue.fromBlockchain(reserves[1], token2.decimals)); } - index += 1; }); /// In case there is more than one pump, divide the reserves by the number of pumps