diff --git a/src/hooks/swap/useAllRoutes.ts b/src/hooks/swap/useAllRoutes.ts index 744be87..232f276 100644 --- a/src/hooks/swap/useAllRoutes.ts +++ b/src/hooks/swap/useAllRoutes.ts @@ -20,7 +20,7 @@ function poolEquals(poolA: Pool, poolB: Pool): boolean { function computeAllRoutes( currencyIn: Currency, currencyOut: Currency, - pools: { tokens: [Token, Token], pool: { address: Address, liquidity: string, price: string, tick: string } }[], + pools: { tokens: [Token, Token], pool: { address: Address, liquidity: string, price: string, tick: string, fee: string } }[], chainId: number, currentPath: Pool[] = [], allPaths: Route[] = [], @@ -36,9 +36,9 @@ function computeAllRoutes( const [tokenA, tokenB] = pool.tokens - const { liquidity, price, tick } = pool.pool + const { liquidity, price, tick, fee } = pool.pool - const newPool = new Pool(tokenA, tokenB, INITIAL_POOL_FEE, price, liquidity, Number(tick), DEFAULT_TICK_SPACING) + const newPool = new Pool(tokenA, tokenB, +fee as unknown as 100, price, liquidity, Number(tick), DEFAULT_TICK_SPACING) if (!newPool.involvesToken(tokenIn) || currentPath.find((pathPool) => poolEquals(newPool, pathPool))) continue diff --git a/src/hooks/swap/useSwapCallback.ts b/src/hooks/swap/useSwapCallback.ts index 41434b4..26d46f1 100644 --- a/src/hooks/swap/useSwapCallback.ts +++ b/src/hooks/swap/useSwapCallback.ts @@ -109,7 +109,8 @@ export function useSwapCallback( const { config: swapConfig } = usePrepareAlgebraRouterMulticall({ args: bestCall && [bestCall.calldata], value: BigInt(bestCall?.value || 0), - enabled: Boolean(bestCall) + enabled: Boolean(bestCall), + gas: bestCall ? bestCall.gasEstimate * (10000n + 2000n) / 10000n : undefined }) const { data: swapData, writeAsync: swapCallback } = useContractWrite(swapConfig) diff --git a/src/hooks/swap/useSwapPools.ts b/src/hooks/swap/useSwapPools.ts index 03fcd0c..37ea793 100644 --- a/src/hooks/swap/useSwapPools.ts +++ b/src/hooks/swap/useSwapPools.ts @@ -14,7 +14,7 @@ export function useSwapPools( currencyIn?: Currency, currencyOut?: Currency ): { - pools: { tokens: [Token, Token], pool: { address: Address, liquidity: string, price: string, tick: string, token0: TokenFieldsFragment, token1: TokenFieldsFragment } }[] + pools: { tokens: [Token, Token], pool: { address: Address, liquidity: string, price: string, tick: string, fee: string, token0: TokenFieldsFragment, token1: TokenFieldsFragment } }[] loading: boolean } { @@ -47,7 +47,7 @@ export function useSwapPools( // address // }).read.globalState())) - const pools = poolsData.data && poolsData.data.pools.map(pool => ({ address: pool.id, liquidity: pool.liquidity, price: pool.sqrtPrice, tick: pool.tick, token0: pool.token0, token1: pool.token1 })) + const pools = poolsData.data && poolsData.data.pools.map(pool => ({ address: pool.id, liquidity: pool.liquidity, price: pool.sqrtPrice, tick: pool.tick, fee: pool.fee, token0: pool.token0, token1: pool.token1 })) setExistingPools(pools)