@0xsquid/react-hooks 7.8.0 → 8.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index-B3FG6tRj.js +6021 -0
- package/dist/index-B3FG6tRj.js.map +1 -0
- package/dist/index-CeIwio11.js +41015 -0
- package/dist/index-CeIwio11.js.map +1 -0
- package/dist/index-CjYMwYuT.js +41267 -0
- package/dist/index-CjYMwYuT.js.map +1 -0
- package/dist/index-CoxuUJzG.js +6021 -0
- package/dist/index-CoxuUJzG.js.map +1 -0
- package/dist/index.esm.js +36 -0
- package/dist/index.esm.js.map +1 -0
- package/dist/index.js +292 -6
- package/dist/index.js.map +1 -1
- package/dist/secretService-C6ack504.js +168 -0
- package/dist/secretService-C6ack504.js.map +1 -0
- package/dist/{services/external/secretService.js → secretService-CgLleYSR.js} +43 -8
- package/dist/secretService-CgLleYSR.js.map +1 -0
- package/package.json +18 -4
- package/dist/core/abis/ics20.json +0 -128
- package/dist/core/client/index.js +0 -38
- package/dist/core/client/index.js.map +0 -1
- package/dist/core/connectors/bitcoin/errors/index.js +0 -22
- package/dist/core/connectors/bitcoin/errors/index.js.map +0 -1
- package/dist/core/connectors/bitcoin/helpers.js +0 -91
- package/dist/core/connectors/bitcoin/helpers.js.map +0 -1
- package/dist/core/connectors/bitcoin/index.js +0 -2
- package/dist/core/connectors/bitcoin/index.js.map +0 -1
- package/dist/core/connectors/bitcoin/wallets/index.js +0 -4
- package/dist/core/connectors/bitcoin/wallets/index.js.map +0 -1
- package/dist/core/connectors/bitcoin/wallets/keplr.js +0 -28
- package/dist/core/connectors/bitcoin/wallets/keplr.js.map +0 -1
- package/dist/core/connectors/bitcoin/wallets/phantom.js +0 -56
- package/dist/core/connectors/bitcoin/wallets/phantom.js.map +0 -1
- package/dist/core/connectors/bitcoin/wallets/unisat.js +0 -28
- package/dist/core/connectors/bitcoin/wallets/unisat.js.map +0 -1
- package/dist/core/connectors/xrpl/CrossMark.js +0 -76
- package/dist/core/connectors/xrpl/CrossMark.js.map +0 -1
- package/dist/core/connectors/xrpl/WalletConnect.js +0 -194
- package/dist/core/connectors/xrpl/WalletConnect.js.map +0 -1
- package/dist/core/connectors/xrpl/Xaman.js +0 -71
- package/dist/core/connectors/xrpl/Xaman.js.map +0 -1
- package/dist/core/connectors/xrpl/XamanQr.js +0 -95
- package/dist/core/connectors/xrpl/XamanQr.js.map +0 -1
- package/dist/core/connectors/xrpl/XrplMetamaskSnap.js +0 -176
- package/dist/core/connectors/xrpl/XrplMetamaskSnap.js.map +0 -1
- package/dist/core/constants.js +0 -157
- package/dist/core/constants.js.map +0 -1
- package/dist/core/externalLinks.js +0 -21
- package/dist/core/externalLinks.js.map +0 -1
- package/dist/core/index.js +0 -4
- package/dist/core/index.js.map +0 -1
- package/dist/core/multicall3.js +0 -462
- package/dist/core/multicall3.js.map +0 -1
- package/dist/core/providers/BitcoinProvider.js +0 -15
- package/dist/core/providers/BitcoinProvider.js.map +0 -1
- package/dist/core/providers/CosmosProvider.js +0 -13
- package/dist/core/providers/CosmosProvider.js.map +0 -1
- package/dist/core/providers/EvmProvider.js +0 -15
- package/dist/core/providers/EvmProvider.js.map +0 -1
- package/dist/core/providers/SolanaProvider.js +0 -15
- package/dist/core/providers/SolanaProvider.js.map +0 -1
- package/dist/core/providers/SuiProvider.js +0 -15
- package/dist/core/providers/SuiProvider.js.map +0 -1
- package/dist/core/providers/XrplProvider.js +0 -15
- package/dist/core/providers/XrplProvider.js.map +0 -1
- package/dist/core/queries/queries-keys.js +0 -232
- package/dist/core/queries/queries-keys.js.map +0 -1
- package/dist/core/queries/react-query-config.js +0 -11
- package/dist/core/queries/react-query-config.js.map +0 -1
- package/dist/core/types/bitcoin.js +0 -2
- package/dist/core/types/bitcoin.js.map +0 -1
- package/dist/core/types/config.js +0 -2
- package/dist/core/types/config.js.map +0 -1
- package/dist/core/types/error.js +0 -18
- package/dist/core/types/error.js.map +0 -1
- package/dist/core/types/event.js +0 -2
- package/dist/core/types/event.js.map +0 -1
- package/dist/core/types/evm.js +0 -2
- package/dist/core/types/evm.js.map +0 -1
- package/dist/core/types/history.js +0 -7
- package/dist/core/types/history.js.map +0 -1
- package/dist/core/types/index.js +0 -4
- package/dist/core/types/index.js.map +0 -1
- package/dist/core/types/onramps/index.js +0 -3
- package/dist/core/types/onramps/index.js.map +0 -1
- package/dist/core/types/onramps/onramp.js +0 -2
- package/dist/core/types/onramps/onramp.js.map +0 -1
- package/dist/core/types/onramps/revolut.js +0 -2
- package/dist/core/types/onramps/revolut.js.map +0 -1
- package/dist/core/types/rpc.js +0 -2
- package/dist/core/types/rpc.js.map +0 -1
- package/dist/core/types/solana.js +0 -2
- package/dist/core/types/solana.js.map +0 -1
- package/dist/core/types/sui.js +0 -2
- package/dist/core/types/sui.js.map +0 -1
- package/dist/core/types/swap.js +0 -2
- package/dist/core/types/swap.js.map +0 -1
- package/dist/core/types/tokens.js +0 -2
- package/dist/core/types/tokens.js.map +0 -1
- package/dist/core/types/transaction.js +0 -47
- package/dist/core/types/transaction.js.map +0 -1
- package/dist/core/types/wallet.js +0 -19
- package/dist/core/types/wallet.js.map +0 -1
- package/dist/core/types/xrpl.js +0 -32
- package/dist/core/types/xrpl.js.map +0 -1
- package/dist/core/wagmiConfig.js +0 -81
- package/dist/core/wagmiConfig.js.map +0 -1
- package/dist/core/wallets.js +0 -357
- package/dist/core/wallets.js.map +0 -1
- package/dist/hooks/analytics/useTrackSearchEmpty.js +0 -22
- package/dist/hooks/analytics/useTrackSearchEmpty.js.map +0 -1
- package/dist/hooks/bitcoin/useBitcoin.js +0 -18
- package/dist/hooks/bitcoin/useBitcoin.js.map +0 -1
- package/dist/hooks/chains/useSquidChains.js +0 -96
- package/dist/hooks/chains/useSquidChains.js.map +0 -1
- package/dist/hooks/client/useClient.js +0 -63
- package/dist/hooks/client/useClient.js.map +0 -1
- package/dist/hooks/cosmos/useCosmos.js +0 -167
- package/dist/hooks/cosmos/useCosmos.js.map +0 -1
- package/dist/hooks/cosmos/useCosmosForChain.js +0 -29
- package/dist/hooks/cosmos/useCosmosForChain.js.map +0 -1
- package/dist/hooks/evm/useEvm.js +0 -68
- package/dist/hooks/evm/useEvm.js.map +0 -1
- package/dist/hooks/evm/useEvmWallets.js +0 -13
- package/dist/hooks/evm/useEvmWallets.js.map +0 -1
- package/dist/hooks/index.js +0 -54
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/navigation/useKeyboardNavigation.js +0 -67
- package/dist/hooks/navigation/useKeyboardNavigation.js.map +0 -1
- package/dist/hooks/onramp/useFiatToCrypto.js +0 -298
- package/dist/hooks/onramp/useFiatToCrypto.js.map +0 -1
- package/dist/hooks/query/useSquidQueryClient.js +0 -23
- package/dist/hooks/query/useSquidQueryClient.js.map +0 -1
- package/dist/hooks/solana/useSolana.js +0 -81
- package/dist/hooks/solana/useSolana.js.map +0 -1
- package/dist/hooks/solana/useSolanaWallets.js +0 -8
- package/dist/hooks/solana/useSolanaWallets.js.map +0 -1
- package/dist/hooks/squid/useSquid.js +0 -55
- package/dist/hooks/squid/useSquid.js.map +0 -1
- package/dist/hooks/store/useAddressBookStore.js +0 -30
- package/dist/hooks/store/useAddressBookStore.js.map +0 -1
- package/dist/hooks/store/useAssetsColorsStore.js +0 -7
- package/dist/hooks/store/useAssetsColorsStore.js.map +0 -1
- package/dist/hooks/store/useDepositAddressStore.js +0 -12
- package/dist/hooks/store/useDepositAddressStore.js.map +0 -1
- package/dist/hooks/store/useFavoriteTokensStore.js +0 -28
- package/dist/hooks/store/useFavoriteTokensStore.js.map +0 -1
- package/dist/hooks/store/useHistoryStore.js +0 -129
- package/dist/hooks/store/useHistoryStore.js.map +0 -1
- package/dist/hooks/store/useSendTransactionStore.js +0 -21
- package/dist/hooks/store/useSendTransactionStore.js.map +0 -1
- package/dist/hooks/store/useSquidStore.js +0 -54
- package/dist/hooks/store/useSquidStore.js.map +0 -1
- package/dist/hooks/store/useWalletStore.js +0 -61
- package/dist/hooks/store/useWalletStore.js.map +0 -1
- package/dist/hooks/sui/useSui.js +0 -81
- package/dist/hooks/sui/useSui.js.map +0 -1
- package/dist/hooks/sui/useSuiWallets.js +0 -23
- package/dist/hooks/sui/useSuiWallets.js.map +0 -1
- package/dist/hooks/swap/useDepositAddress.js +0 -63
- package/dist/hooks/swap/useDepositAddress.js.map +0 -1
- package/dist/hooks/swap/useSwap.js +0 -228
- package/dist/hooks/swap/useSwap.js.map +0 -1
- package/dist/hooks/tokens/useAllConnectedWalletBalances.js +0 -114
- package/dist/hooks/tokens/useAllConnectedWalletBalances.js.map +0 -1
- package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.js +0 -130
- package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.js.map +0 -1
- package/dist/hooks/tokens/useBalance.js +0 -157
- package/dist/hooks/tokens/useBalance.js.map +0 -1
- package/dist/hooks/tokens/useMultiChainBalance.js +0 -77
- package/dist/hooks/tokens/useMultiChainBalance.js.map +0 -1
- package/dist/hooks/tokens/useMultipleTokenPrices.js +0 -46
- package/dist/hooks/tokens/useMultipleTokenPrices.js.map +0 -1
- package/dist/hooks/tokens/useNativeBalance.js +0 -249
- package/dist/hooks/tokens/useNativeBalance.js.map +0 -1
- package/dist/hooks/tokens/useNativeTokenForChain.js +0 -30
- package/dist/hooks/tokens/useNativeTokenForChain.js.map +0 -1
- package/dist/hooks/tokens/useSingleTokenPrice.js +0 -38
- package/dist/hooks/tokens/useSingleTokenPrice.js.map +0 -1
- package/dist/hooks/tokens/useSquidTokens.js +0 -75
- package/dist/hooks/tokens/useSquidTokens.js.map +0 -1
- package/dist/hooks/tokens/useTokenHistoricalData.js +0 -23
- package/dist/hooks/tokens/useTokenHistoricalData.js.map +0 -1
- package/dist/hooks/transaction/send/useEstimateSendTransactionGas.js +0 -58
- package/dist/hooks/transaction/send/useEstimateSendTransactionGas.js.map +0 -1
- package/dist/hooks/transaction/send/useSendTransaction.js +0 -245
- package/dist/hooks/transaction/send/useSendTransaction.js.map +0 -1
- package/dist/hooks/transaction/send/useSendTransactionGas.js +0 -73
- package/dist/hooks/transaction/send/useSendTransactionGas.js.map +0 -1
- package/dist/hooks/transaction/useAllTransactionsStatus.js +0 -127
- package/dist/hooks/transaction/useAllTransactionsStatus.js.map +0 -1
- package/dist/hooks/transaction/useApproval.js +0 -246
- package/dist/hooks/transaction/useApproval.js.map +0 -1
- package/dist/hooks/transaction/useErc20Allowance.js +0 -43
- package/dist/hooks/transaction/useErc20Allowance.js.map +0 -1
- package/dist/hooks/transaction/useEstimate.js +0 -115
- package/dist/hooks/transaction/useEstimate.js.map +0 -1
- package/dist/hooks/transaction/useEstimatePriceImpact.js +0 -31
- package/dist/hooks/transaction/useEstimatePriceImpact.js.map +0 -1
- package/dist/hooks/transaction/useExecuteTransaction.js +0 -678
- package/dist/hooks/transaction/useExecuteTransaction.js.map +0 -1
- package/dist/hooks/transaction/useGetRoute.js +0 -207
- package/dist/hooks/transaction/useGetRoute.js.map +0 -1
- package/dist/hooks/transaction/useIcs20Allowance.js +0 -46
- package/dist/hooks/transaction/useIcs20Allowance.js.map +0 -1
- package/dist/hooks/transaction/useRouteWarnings.js +0 -19
- package/dist/hooks/transaction/useRouteWarnings.js.map +0 -1
- package/dist/hooks/transaction/useSendTransactionStatus.js +0 -63
- package/dist/hooks/transaction/useSendTransactionStatus.js.map +0 -1
- package/dist/hooks/transaction/useSwapTransactionStatus.js +0 -114
- package/dist/hooks/transaction/useSwapTransactionStatus.js.map +0 -1
- package/dist/hooks/user/useAvatar.js +0 -40
- package/dist/hooks/user/useAvatar.js.map +0 -1
- package/dist/hooks/user/useHistory.js +0 -103
- package/dist/hooks/user/useHistory.js.map +0 -1
- package/dist/hooks/user/useUserParams.js +0 -33
- package/dist/hooks/user/useUserParams.js.map +0 -1
- package/dist/hooks/utils/useUtils.js +0 -20
- package/dist/hooks/utils/useUtils.js.map +0 -1
- package/dist/hooks/wallet/useAddToken.js +0 -49
- package/dist/hooks/wallet/useAddToken.js.map +0 -1
- package/dist/hooks/wallet/useAutoConnect.js +0 -92
- package/dist/hooks/wallet/useAutoConnect.js.map +0 -1
- package/dist/hooks/wallet/useEns.js +0 -57
- package/dist/hooks/wallet/useEns.js.map +0 -1
- package/dist/hooks/wallet/useGnosisContext.js +0 -74
- package/dist/hooks/wallet/useGnosisContext.js.map +0 -1
- package/dist/hooks/wallet/useIntegratorContext.js +0 -39
- package/dist/hooks/wallet/useIntegratorContext.js.map +0 -1
- package/dist/hooks/wallet/useMultiChainWallet.js +0 -210
- package/dist/hooks/wallet/useMultiChainWallet.js.map +0 -1
- package/dist/hooks/wallet/useSigner.js +0 -68
- package/dist/hooks/wallet/useSigner.js.map +0 -1
- package/dist/hooks/wallet/useStandardWallets.js +0 -26
- package/dist/hooks/wallet/useStandardWallets.js.map +0 -1
- package/dist/hooks/wallet/useWallet.js +0 -199
- package/dist/hooks/wallet/useWallet.js.map +0 -1
- package/dist/hooks/wallet/useWallets.js +0 -33
- package/dist/hooks/wallet/useWallets.js.map +0 -1
- package/dist/hooks/xrpl/useXrpl.js +0 -55
- package/dist/hooks/xrpl/useXrpl.js.map +0 -1
- package/dist/hooks/xrpl/useXrplTrustLine.js +0 -159
- package/dist/hooks/xrpl/useXrplTrustLine.js.map +0 -1
- package/dist/hooks/xrpl/useXrplWallets.js +0 -51
- package/dist/hooks/xrpl/useXrplWallets.js.map +0 -1
- package/dist/provider/index.js +0 -118
- package/dist/provider/index.js.map +0 -1
- package/dist/services/external/cosmosRestClient.js +0 -45
- package/dist/services/external/cosmosRestClient.js.map +0 -1
- package/dist/services/external/ens.js +0 -66
- package/dist/services/external/ens.js.map +0 -1
- package/dist/services/external/index.js +0 -3
- package/dist/services/external/index.js.map +0 -1
- package/dist/services/external/onrampAdapter.js +0 -52
- package/dist/services/external/onrampAdapter.js.map +0 -1
- package/dist/services/external/rpcService.js +0 -411
- package/dist/services/external/rpcService.js.map +0 -1
- package/dist/services/external/secretService.js.map +0 -1
- package/dist/services/external/suiRpcClient.js +0 -80
- package/dist/services/external/suiRpcClient.js.map +0 -1
- package/dist/services/external/tokenDataService.js +0 -108
- package/dist/services/external/tokenDataService.js.map +0 -1
- package/dist/services/external/websocket.js +0 -34
- package/dist/services/external/websocket.js.map +0 -1
- package/dist/services/external/xaman.js +0 -78
- package/dist/services/external/xaman.js.map +0 -1
- package/dist/services/external/xrplRpcClient.js +0 -167
- package/dist/services/external/xrplRpcClient.js.map +0 -1
- package/dist/services/index.js +0 -19
- package/dist/services/index.js.map +0 -1
- package/dist/services/internal/apiService.js +0 -21
- package/dist/services/internal/apiService.js.map +0 -1
- package/dist/services/internal/assetsService.js +0 -575
- package/dist/services/internal/assetsService.js.map +0 -1
- package/dist/services/internal/bitcoinService.js +0 -20
- package/dist/services/internal/bitcoinService.js.map +0 -1
- package/dist/services/internal/configService.js +0 -198
- package/dist/services/internal/configService.js.map +0 -1
- package/dist/services/internal/cosmosService.js +0 -141
- package/dist/services/internal/cosmosService.js.map +0 -1
- package/dist/services/internal/countryCurrencyMap.js +0 -1102
- package/dist/services/internal/countryCurrencyMap.js.map +0 -1
- package/dist/services/internal/errorService.js +0 -190
- package/dist/services/internal/errorService.js.map +0 -1
- package/dist/services/internal/estimateService.js +0 -225
- package/dist/services/internal/estimateService.js.map +0 -1
- package/dist/services/internal/eventService.js +0 -219
- package/dist/services/internal/eventService.js.map +0 -1
- package/dist/services/internal/evmService.js +0 -67
- package/dist/services/internal/evmService.js.map +0 -1
- package/dist/services/internal/fiatToCryptoService.js +0 -84
- package/dist/services/internal/fiatToCryptoService.js.map +0 -1
- package/dist/services/internal/fiatToCryptoService.test.js +0 -45
- package/dist/services/internal/fiatToCryptoService.test.js.map +0 -1
- package/dist/services/internal/numberService.js +0 -199
- package/dist/services/internal/numberService.js.map +0 -1
- package/dist/services/internal/priceService.js +0 -53
- package/dist/services/internal/priceService.js.map +0 -1
- package/dist/services/internal/searchService.js +0 -98
- package/dist/services/internal/searchService.js.map +0 -1
- package/dist/services/internal/sendTransaction.js +0 -191
- package/dist/services/internal/sendTransaction.js.map +0 -1
- package/dist/services/internal/sendTransactionStatus.js +0 -134
- package/dist/services/internal/sendTransactionStatus.js.map +0 -1
- package/dist/services/internal/solanaService.js +0 -142
- package/dist/services/internal/solanaService.js.map +0 -1
- package/dist/services/internal/suiService.js +0 -81
- package/dist/services/internal/suiService.js.map +0 -1
- package/dist/services/internal/transactionService.js +0 -210
- package/dist/services/internal/transactionService.js.map +0 -1
- package/dist/services/internal/transactionStatusService.js +0 -390
- package/dist/services/internal/transactionStatusService.js.map +0 -1
- package/dist/services/internal/walletService.js +0 -546
- package/dist/services/internal/walletService.js.map +0 -1
- package/dist/services/internal/walletStandardService.js +0 -128
- package/dist/services/internal/walletStandardService.js.map +0 -1
- package/dist/services/internal/xionService.js +0 -6
- package/dist/services/internal/xionService.js.map +0 -1
- package/dist/services/internal/xrplService.js +0 -52
- package/dist/services/internal/xrplService.js.map +0 -1
- package/dist/tests/apiService.test.js +0 -40
- package/dist/tests/apiService.test.js.map +0 -1
- package/dist/tests/assetsService.test.js +0 -614
- package/dist/tests/assetsService.test.js.map +0 -1
- package/dist/tests/configService.test.js +0 -641
- package/dist/tests/configService.test.js.map +0 -1
- package/dist/tests/estimateService.test.js +0 -429
- package/dist/tests/estimateService.test.js.map +0 -1
- package/dist/tests/fetchSquidData.js +0 -36
- package/dist/tests/fetchSquidData.js.map +0 -1
- package/dist/tests/jest-svg-transform.d.ts +0 -0
- package/dist/tests/jest-svg-transform.js +0 -21
- package/dist/tests/jest-svg-transform.js.map +0 -1
- package/dist/tests/numberService.test.js +0 -166
- package/dist/tests/numberService.test.js.map +0 -1
- package/dist/tests/priceService.test.js +0 -38
- package/dist/tests/priceService.test.js.map +0 -1
- package/dist/tests/sample.json +0 -0
- package/dist/tests/searchService.test.js +0 -86
- package/dist/tests/searchService.test.js.map +0 -1
- package/dist/tests/swapConfig.test.js +0 -332
- package/dist/tests/swapConfig.test.js.map +0 -1
- package/dist/tests/transactionService.test.js +0 -53
- package/dist/tests/transactionService.test.js.map +0 -1
- package/dist/tests/transactionStatusService.test.js +0 -165
- package/dist/tests/transactionStatusService.test.js.map +0 -1
- package/dist/tests/walletService.test.js +0 -488
- package/dist/tests/walletService.test.js.map +0 -1
|
@@ -1,246 +0,0 @@
|
|
|
1
|
-
import { useMutation, useQuery, useQueryClient } from "@tanstack/react-query";
|
|
2
|
-
import { useAccount, usePublicClient, useSwitchChain, useWalletClient, } from "wagmi";
|
|
3
|
-
import { getPrefixKey, keys, QueryKeys } from "../../core/queries/queries-keys";
|
|
4
|
-
import { ChainType, } from "@0xsquid/squid-types";
|
|
5
|
-
import { ethers } from "ethers";
|
|
6
|
-
import ics20Abi from "../../core/abis/ics20.json";
|
|
7
|
-
import { CHAIN_IDS, nativeEvmTokenAddress } from "../../core/constants";
|
|
8
|
-
import { isEvmosChain, isProblematicConnector, sleep } from "../../services";
|
|
9
|
-
import { useSquidChains } from "../chains/useSquidChains";
|
|
10
|
-
import { useSquidStore } from "../store/useSquidStore";
|
|
11
|
-
import { useSwap } from "../swap/useSwap";
|
|
12
|
-
import { useMultiChainWallet } from "../wallet/useMultiChainWallet";
|
|
13
|
-
import { useSigner } from "../wallet/useSigner";
|
|
14
|
-
import { useErc20Allowance } from "./useErc20Allowance";
|
|
15
|
-
import { useIcs20Allowance } from "./useIcs20Allowance";
|
|
16
|
-
export const useApproval = ({ squidRoute, }) => {
|
|
17
|
-
const { data: walletClient } = useWalletClient();
|
|
18
|
-
const publicClient = usePublicClient();
|
|
19
|
-
const queryClient = useQueryClient();
|
|
20
|
-
const squid = useSquidStore((state) => state.squid);
|
|
21
|
-
const { fromChain, fromToken, fromPrice, isSameChain } = useSwap();
|
|
22
|
-
const { evmSigner } = useSigner({ chain: fromChain });
|
|
23
|
-
const { connector: activeConnector } = useAccount();
|
|
24
|
-
const { getChainType } = useSquidChains();
|
|
25
|
-
const { switchChainAsync } = useSwitchChain();
|
|
26
|
-
const { connectedAddress: { address: sourceUserAddress }, } = useMultiChainWallet(fromChain);
|
|
27
|
-
const isSrcChainEvmos = isEvmosChain(fromChain);
|
|
28
|
-
const isSagaSameChainSwap = isSameChain &&
|
|
29
|
-
fromChain?.chainId.toString() === CHAIN_IDS.SAGA_EVM.toString();
|
|
30
|
-
// Use ICS20 for Evmos chains, except for SAGA same chain swaps
|
|
31
|
-
const useIcs20 = isSrcChainEvmos && !isSagaSameChainSwap;
|
|
32
|
-
const { hasAllowance: hasErc20Allowance, query: erc20AllowanceQuery, allowanceInWei: erc20AllowanceInWei, } = useErc20Allowance({
|
|
33
|
-
tokenAddress: fromToken?.address,
|
|
34
|
-
ownerAddress: sourceUserAddress,
|
|
35
|
-
spenderAddress: squidRoute?.transactionRequest
|
|
36
|
-
?.target,
|
|
37
|
-
amount: BigInt(squidRoute?.params.fromAmount ?? "0"),
|
|
38
|
-
chainId: Number(fromChain?.chainId),
|
|
39
|
-
enabled: !useIcs20,
|
|
40
|
-
});
|
|
41
|
-
const { hasAllowance: hasIcs20Allowance, query: ics20AllowanceQuery, allowanceInWei: ics20AllowanceInWei, } = useIcs20Allowance({
|
|
42
|
-
ownerAddress: sourceUserAddress,
|
|
43
|
-
targetAddress: squidRoute?.transactionRequest
|
|
44
|
-
?.target,
|
|
45
|
-
amount: BigInt(squidRoute?.params.fromAmount ?? "0"),
|
|
46
|
-
chainId: Number(fromChain?.chainId),
|
|
47
|
-
enabled: useIcs20,
|
|
48
|
-
});
|
|
49
|
-
const hasAllowance = useIcs20 ? hasIcs20Allowance : hasErc20Allowance;
|
|
50
|
-
const allowanceInWei = useIcs20 ? ics20AllowanceInWei : erc20AllowanceInWei;
|
|
51
|
-
const allowanceQuery = useIcs20 ? ics20AllowanceQuery : erc20AllowanceQuery;
|
|
52
|
-
/**
|
|
53
|
-
* Checking if spending tokens is allowed for this source address
|
|
54
|
-
* On Success: storing the transaction
|
|
55
|
-
* On Error: Showing the error message if any
|
|
56
|
-
* @returns {boolean} approved
|
|
57
|
-
*/
|
|
58
|
-
const routeApproved = useQuery(keys().routeApproved(squidRoute, allowanceInWei), async () => {
|
|
59
|
-
// Approval is only needed for EVM chains
|
|
60
|
-
if (getChainType(squidRoute?.params.fromChain) === ChainType.EVM) {
|
|
61
|
-
return hasAllowance;
|
|
62
|
-
}
|
|
63
|
-
return true;
|
|
64
|
-
}, {
|
|
65
|
-
enabled: !!squidRoute &&
|
|
66
|
-
!!sourceUserAddress &&
|
|
67
|
-
!allowanceQuery?.isLoading &&
|
|
68
|
-
allowanceQuery?.isFetched,
|
|
69
|
-
});
|
|
70
|
-
// USDT has a very specific way of handling approvals
|
|
71
|
-
// ```
|
|
72
|
-
/// To change the approve amount you first have to reduce the addresses`
|
|
73
|
-
// allowance to zero by calling `approve(_spender, 0)` if it is not
|
|
74
|
-
// already 0 to mitigate the race condition described here:
|
|
75
|
-
// https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
|
|
76
|
-
// ```
|
|
77
|
-
// This is why we had an unpredictable gas error for USDT approvals
|
|
78
|
-
// So it needs a custom gas limit
|
|
79
|
-
//
|
|
80
|
-
// TODO: We're only doing it for USDT on Ethereum Mainnet, need to check if it's needed for USDT on other chains
|
|
81
|
-
const approveSpecificTokenToZero = async (token) => {
|
|
82
|
-
if (walletClient &&
|
|
83
|
-
token.symbol.toLowerCase() === "usdt" &&
|
|
84
|
-
token.chainId === CHAIN_IDS.ETHEREUM &&
|
|
85
|
-
fromToken) {
|
|
86
|
-
const fromChainRouterAddress = squidRoute?.transactionRequest?.target;
|
|
87
|
-
const allowance = await publicClient?.readContract({
|
|
88
|
-
address: token.address,
|
|
89
|
-
abi: [
|
|
90
|
-
{
|
|
91
|
-
constant: true,
|
|
92
|
-
inputs: [
|
|
93
|
-
{ name: "_owner", type: "address" },
|
|
94
|
-
{ name: "_spender", type: "address" },
|
|
95
|
-
],
|
|
96
|
-
name: "allowance",
|
|
97
|
-
outputs: [{ name: "remaining", type: "uint256" }],
|
|
98
|
-
type: "function",
|
|
99
|
-
},
|
|
100
|
-
],
|
|
101
|
-
functionName: "allowance",
|
|
102
|
-
args: [
|
|
103
|
-
sourceUserAddress,
|
|
104
|
-
fromChainRouterAddress,
|
|
105
|
-
],
|
|
106
|
-
});
|
|
107
|
-
if (allowance &&
|
|
108
|
-
BigInt(allowance.toString()) > BigInt(0) &&
|
|
109
|
-
publicClient) {
|
|
110
|
-
const approveAbi = [
|
|
111
|
-
{
|
|
112
|
-
constant: false,
|
|
113
|
-
inputs: [
|
|
114
|
-
{ name: "_spender", type: "address" },
|
|
115
|
-
{ name: "_value", type: "uint256" },
|
|
116
|
-
],
|
|
117
|
-
name: "approve",
|
|
118
|
-
outputs: [],
|
|
119
|
-
type: "function",
|
|
120
|
-
},
|
|
121
|
-
];
|
|
122
|
-
const contractCallArgs = {
|
|
123
|
-
address: token.address,
|
|
124
|
-
abi: approveAbi,
|
|
125
|
-
functionName: "approve",
|
|
126
|
-
args: [fromChainRouterAddress, BigInt(0)],
|
|
127
|
-
account: sourceUserAddress,
|
|
128
|
-
};
|
|
129
|
-
let request;
|
|
130
|
-
try {
|
|
131
|
-
const estimatedGas = await publicClient.estimateContractGas(contractCallArgs);
|
|
132
|
-
const gasLimit = (estimatedGas * 120n) / 100n;
|
|
133
|
-
const simulation = await publicClient.simulateContract({
|
|
134
|
-
...contractCallArgs,
|
|
135
|
-
gas: gasLimit,
|
|
136
|
-
});
|
|
137
|
-
request = simulation.request;
|
|
138
|
-
}
|
|
139
|
-
catch (estimationError) {
|
|
140
|
-
const simulation = await publicClient.simulateContract({
|
|
141
|
-
...contractCallArgs,
|
|
142
|
-
gas: 100000n, // Fallback gas limit
|
|
143
|
-
});
|
|
144
|
-
request = simulation.request;
|
|
145
|
-
}
|
|
146
|
-
if (request) {
|
|
147
|
-
await walletClient.writeContract(request);
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
return true;
|
|
152
|
-
};
|
|
153
|
-
/**
|
|
154
|
-
* Manually approve route if necessary
|
|
155
|
-
*/
|
|
156
|
-
const approveRoute = useMutation(async () => {
|
|
157
|
-
try {
|
|
158
|
-
if (fromToken?.address === nativeEvmTokenAddress) {
|
|
159
|
-
return true;
|
|
160
|
-
}
|
|
161
|
-
if (!!squidRoute && walletClient && fromToken && evmSigner && squid) {
|
|
162
|
-
await approveSpecificTokenToZero(fromToken);
|
|
163
|
-
try {
|
|
164
|
-
// If needed, we can switch the chain here
|
|
165
|
-
// If already on the correct chain, this will do nothing
|
|
166
|
-
await switchChainAsync({ chainId: Number(fromChain?.chainId) });
|
|
167
|
-
}
|
|
168
|
-
catch (error) {
|
|
169
|
-
console.error("Error switching network:", error);
|
|
170
|
-
}
|
|
171
|
-
let approveTx;
|
|
172
|
-
if (useIcs20) {
|
|
173
|
-
const channel = squidRoute.estimate.actions[0].data
|
|
174
|
-
.ibcChannel;
|
|
175
|
-
const ics20Interface = new ethers.Interface(ics20Abi);
|
|
176
|
-
const approveData = ics20Interface.encodeFunctionData("approve", [
|
|
177
|
-
squidRoute.params.fromAddress,
|
|
178
|
-
[
|
|
179
|
-
{
|
|
180
|
-
sourcePort: "transfer",
|
|
181
|
-
sourceChannel: channel,
|
|
182
|
-
spendLimit: [
|
|
183
|
-
{
|
|
184
|
-
denom: squidRoute.estimate.actions[0].fromToken
|
|
185
|
-
.originalAddress,
|
|
186
|
-
amount: squidRoute.params.fromAmount,
|
|
187
|
-
},
|
|
188
|
-
],
|
|
189
|
-
allowList: [],
|
|
190
|
-
allowedPacketData: ["*"],
|
|
191
|
-
},
|
|
192
|
-
],
|
|
193
|
-
]);
|
|
194
|
-
approveTx = await evmSigner.sendTransaction({
|
|
195
|
-
to: squidRoute.transactionRequest.target,
|
|
196
|
-
data: approveData,
|
|
197
|
-
value: "0",
|
|
198
|
-
gasLimit: squidRoute.transactionRequest
|
|
199
|
-
.gasLimit,
|
|
200
|
-
gasPrice: squidRoute.transactionRequest
|
|
201
|
-
.gasPrice,
|
|
202
|
-
});
|
|
203
|
-
}
|
|
204
|
-
else {
|
|
205
|
-
approveTx = await squid.approveRoute({
|
|
206
|
-
route: squidRoute,
|
|
207
|
-
signer: evmSigner,
|
|
208
|
-
// For security reasons, we don't want to allow infinite approvals in our frontends
|
|
209
|
-
executionSettings: {
|
|
210
|
-
infiniteApproval: false,
|
|
211
|
-
},
|
|
212
|
-
});
|
|
213
|
-
}
|
|
214
|
-
if (isProblematicConnector(activeConnector)) {
|
|
215
|
-
await sleep(3_000);
|
|
216
|
-
}
|
|
217
|
-
await approveTx?.wait();
|
|
218
|
-
return true;
|
|
219
|
-
}
|
|
220
|
-
return false;
|
|
221
|
-
}
|
|
222
|
-
catch (error) {
|
|
223
|
-
// Keep the error in the console to debug future issues
|
|
224
|
-
console.error(error);
|
|
225
|
-
return false;
|
|
226
|
-
}
|
|
227
|
-
}, {
|
|
228
|
-
onSuccess: async () => {
|
|
229
|
-
await allowanceQuery?.refetch();
|
|
230
|
-
queryClient.invalidateQueries(getPrefixKey(QueryKeys.RouteApproved));
|
|
231
|
-
// After an approval, we refetch the transaction query with all required parameters
|
|
232
|
-
// This is to ensure we're using the latest expiry timestamp
|
|
233
|
-
if (squidRoute) {
|
|
234
|
-
queryClient.refetchQueries({
|
|
235
|
-
queryKey: keys().transaction(squidRoute.params.fromChain, squidRoute.params.toChain, squidRoute.params.toToken, squidRoute.params.fromToken, fromPrice, squidRoute.params.slippage, squidRoute.params.receiveGasOnDestination, squidRoute.params.fromAddress, squidRoute.params.bypassGuardrails, squidRoute.params.toAddress, squidRoute.params.fallbackAddresses?.[0]?.address, squidRoute.params.quoteOnly, getChainType(squidRoute.params.fromChain), squidRoute.params.preHook, squidRoute.params.postHook),
|
|
236
|
-
});
|
|
237
|
-
}
|
|
238
|
-
},
|
|
239
|
-
});
|
|
240
|
-
return {
|
|
241
|
-
routeApproved,
|
|
242
|
-
approveRoute,
|
|
243
|
-
allowanceInWei,
|
|
244
|
-
};
|
|
245
|
-
};
|
|
246
|
-
//# sourceMappingURL=useApproval.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useApproval.js","sourceRoot":"","sources":["../../../src/hooks/transaction/useApproval.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC9E,OAAO,EACL,UAAU,EACV,eAAe,EACf,cAAc,EACd,eAAe,GAChB,MAAM,OAAO,CAAC;AACf,OAAO,EAAE,YAAY,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,iCAAiC,CAAC;AAGhF,OAAO,EACL,SAAS,GAIV,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAChC,OAAO,QAAQ,MAAM,4BAA4B,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AACxE,OAAO,EAAE,YAAY,EAAE,sBAAsB,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAC7E,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,EAC1B,UAAU,GAGX,EAAE,EAAE;IACH,MAAM,EAAE,IAAI,EAAE,YAAY,EAAE,GAAG,eAAe,EAAE,CAAC;IACjD,MAAM,YAAY,GAAG,eAAe,EAAE,CAAC;IACvC,MAAM,WAAW,GAAG,cAAc,EAAE,CAAC;IACrC,MAAM,KAAK,GAAG,aAAa,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IACpD,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,WAAW,EAAE,GAAG,OAAO,EAAE,CAAC;IACnE,MAAM,EAAE,SAAS,EAAE,GAAG,SAAS,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,CAAC;IACtD,MAAM,EAAE,SAAS,EAAE,eAAe,EAAE,GAAG,UAAU,EAAE,CAAC;IACpD,MAAM,EAAE,YAAY,EAAE,GAAG,cAAc,EAAE,CAAC;IAE1C,MAAM,EAAE,gBAAgB,EAAE,GAAG,cAAc,EAAE,CAAC;IAE9C,MAAM,EACJ,gBAAgB,EAAE,EAAE,OAAO,EAAE,iBAAiB,EAAE,GACjD,GAAG,mBAAmB,CAAC,SAAS,CAAC,CAAC;IAEnC,MAAM,eAAe,GAAG,YAAY,CAAC,SAAS,CAAC,CAAC;IAChD,MAAM,mBAAmB,GACvB,WAAW;QACX,SAAS,EAAE,OAAO,CAAC,QAAQ,EAAE,KAAK,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAElE,+DAA+D;IAC/D,MAAM,QAAQ,GAAG,eAAe,IAAI,CAAC,mBAAmB,CAAC;IAEzD,MAAM,EACJ,YAAY,EAAE,iBAAiB,EAC/B,KAAK,EAAE,mBAAmB,EAC1B,cAAc,EAAE,mBAAmB,GACpC,GAAG,iBAAiB,CAAC;QACpB,YAAY,EAAE,SAAS,EAAE,OAAO;QAChC,YAAY,EAAE,iBAAiB;QAC/B,cAAc,EAAG,UAAU,EAAE,kBAA2C;YACtE,EAAE,MAAM;QACV,MAAM,EAAE,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,UAAU,IAAI,GAAG,CAAC;QACpD,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC;QACnC,OAAO,EAAE,CAAC,QAAQ;KACnB,CAAC,CAAC;IAEH,MAAM,EACJ,YAAY,EAAE,iBAAiB,EAC/B,KAAK,EAAE,mBAAmB,EAC1B,cAAc,EAAE,mBAAmB,GACpC,GAAG,iBAAiB,CAAC;QACpB,YAAY,EAAE,iBAAiB;QAC/B,aAAa,EAAG,UAAU,EAAE,kBAA2C;YACrE,EAAE,MAAM;QACV,MAAM,EAAE,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,UAAU,IAAI,GAAG,CAAC;QACpD,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC;QACnC,OAAO,EAAE,QAAQ;KAClB,CAAC,CAAC;IAEH,MAAM,YAAY,GAAG,QAAQ,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,CAAC;IAEtE,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,mBAAmB,CAAC;IAE5E,MAAM,cAAc,GAAG,QAAQ,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,mBAAmB,CAAC;IAE5E;;;;;OAKG;IACH,MAAM,aAAa,GAAG,QAAQ,CAC5B,IAAI,EAAE,CAAC,aAAa,CAAC,UAAU,EAAE,cAAc,CAAC,EAChD,KAAK,IAAI,EAAE;QACT,yCAAyC;QACzC,IAAI,YAAY,CAAC,UAAU,EAAE,MAAM,CAAC,SAAS,CAAC,KAAK,SAAS,CAAC,GAAG,EAAE;YAChE,OAAO,YAAY,CAAC;SACrB;QAED,OAAO,IAAI,CAAC;IACd,CAAC,EACD;QACE,OAAO,EACL,CAAC,CAAC,UAAU;YACZ,CAAC,CAAC,iBAAiB;YACnB,CAAC,cAAc,EAAE,SAAS;YAC1B,cAAc,EAAE,SAAS;KAC5B,CACF,CAAC;IAEF,qDAAqD;IACrD,MAAM;IACN,wEAAwE;IACxE,oEAAoE;IACpE,4DAA4D;IAC5D,qEAAqE;IACrE,MAAM;IACN,mEAAmE;IACnE,iCAAiC;IACjC,EAAE;IACF,gHAAgH;IAChH,MAAM,0BAA0B,GAAG,KAAK,EAAE,KAAY,EAAE,EAAE;QACxD,IACE,YAAY;YACZ,KAAK,CAAC,MAAM,CAAC,WAAW,EAAE,KAAK,MAAM;YACrC,KAAK,CAAC,OAAO,KAAK,SAAS,CAAC,QAAQ;YACpC,SAAS,EACT;YACA,MAAM,sBAAsB,GAC1B,UAAU,EAAE,kBACb,EAAE,MAAM,CAAC;YAEV,MAAM,SAAS,GAAG,MAAM,YAAY,EAAE,YAAY,CAAC;gBACjD,OAAO,EAAE,KAAK,CAAC,OAAwB;gBACvC,GAAG,EAAE;oBACH;wBACE,QAAQ,EAAE,IAAI;wBACd,MAAM,EAAE;4BACN,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE;4BACnC,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE;yBACtC;wBACD,IAAI,EAAE,WAAW;wBACjB,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;wBACjD,IAAI,EAAE,UAAU;qBACjB;iBACF;gBACD,YAAY,EAAE,WAAW;gBACzB,IAAI,EAAE;oBACJ,iBAAkC;oBAClC,sBAAuC;iBACxC;aACF,CAAC,CAAC;YAEH,IACE,SAAS;gBACT,MAAM,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC;gBACxC,YAAY,EACZ;gBACA,MAAM,UAAU,GAAG;oBACjB;wBACE,QAAQ,EAAE,KAAK;wBACf,MAAM,EAAE;4BACN,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE;4BACrC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE;yBACpC;wBACD,IAAI,EAAE,SAAS;wBACf,OAAO,EAAE,EAAE;wBACX,IAAI,EAAE,UAAU;qBACjB;iBACO,CAAC;gBAEX,MAAM,gBAAgB,GAAG;oBACvB,OAAO,EAAE,KAAK,CAAC,OAAwB;oBACvC,GAAG,EAAE,UAAU;oBACf,YAAY,EAAE,SAAS;oBACvB,IAAI,EAAE,CAAC,sBAAuC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;oBAC1D,OAAO,EAAE,iBAAkC;iBACnC,CAAC;gBAEX,IAAI,OAAO,CAAC;gBAEZ,IAAI;oBACF,MAAM,YAAY,GAChB,MAAM,YAAY,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,CAAC;oBAE3D,MAAM,QAAQ,GAAG,CAAC,YAAY,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC;oBAE9C,MAAM,UAAU,GAAG,MAAM,YAAY,CAAC,gBAAgB,CAAC;wBACrD,GAAG,gBAAgB;wBACnB,GAAG,EAAE,QAAQ;qBACd,CAAC,CAAC;oBACH,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC;iBAC9B;gBAAC,OAAO,eAAe,EAAE;oBACxB,MAAM,UAAU,GAAG,MAAM,YAAY,CAAC,gBAAgB,CAAC;wBACrD,GAAG,gBAAgB;wBACnB,GAAG,EAAE,OAAO,EAAE,qBAAqB;qBACpC,CAAC,CAAC;oBACH,OAAO,GAAG,UAAU,CAAC,OAAO,CAAC;iBAC9B;gBAED,IAAI,OAAO,EAAE;oBACX,MAAM,YAAY,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;iBAC3C;aACF;SACF;QACD,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;IAEF;;OAEG;IACH,MAAM,YAAY,GAAG,WAAW,CAC9B,KAAK,IAAI,EAAE;QACT,IAAI;YACF,IAAI,SAAS,EAAE,OAAO,KAAK,qBAAqB,EAAE;gBAChD,OAAO,IAAI,CAAC;aACb;YACD,IAAI,CAAC,CAAC,UAAU,IAAI,YAAY,IAAI,SAAS,IAAI,SAAS,IAAI,KAAK,EAAE;gBACnE,MAAM,0BAA0B,CAAC,SAAS,CAAC,CAAC;gBAE5C,IAAI;oBACF,0CAA0C;oBAC1C,wDAAwD;oBACxD,MAAM,gBAAgB,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,EAAE,CAAC,CAAC;iBACjE;gBAAC,OAAO,KAAK,EAAE;oBACd,OAAO,CAAC,KAAK,CAAC,0BAA0B,EAAE,KAAK,CAAC,CAAC;iBAClD;gBAED,IAAI,SAAqC,CAAC;gBAE1C,IAAI,QAAQ,EAAE;oBACZ,MAAM,OAAO,GAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAY;yBACzD,UAAoB,CAAC;oBAExB,MAAM,cAAc,GAAG,IAAI,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;oBAEtD,MAAM,WAAW,GAAG,cAAc,CAAC,kBAAkB,CAAC,SAAS,EAAE;wBAC/D,UAAU,CAAC,MAAM,CAAC,WAAW;wBAC7B;4BACE;gCACE,UAAU,EAAE,UAAU;gCACtB,aAAa,EAAE,OAAO;gCACtB,UAAU,EAAE;oCACV;wCACE,KAAK,EACH,UAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS;6CACrC,eAAgB;wCACrB,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,UAAU;qCACrC;iCACF;gCACD,SAAS,EAAE,EAAE;gCACb,iBAAiB,EAAE,CAAC,GAAG,CAAC;6BACzB;yBACF;qBACF,CAAC,CAAC;oBAEH,SAAS,GAAG,MAAM,SAAS,CAAC,eAAe,CAAC;wBAC1C,EAAE,EAAG,UAAU,CAAC,kBAA0B,CAAC,MAAgB;wBAC3D,IAAI,EAAE,WAAW;wBACjB,KAAK,EAAE,GAAG;wBACV,QAAQ,EAAG,UAAU,CAAC,kBAA0B;6BAC7C,QAAkB;wBACrB,QAAQ,EAAG,UAAU,CAAC,kBAA0B;6BAC7C,QAAkB;qBACtB,CAAC,CAAC;iBACJ;qBAAM;oBACL,SAAS,GAAG,MAAM,KAAK,CAAC,YAAY,CAAC;wBACnC,KAAK,EAAE,UAAU;wBACjB,MAAM,EAAE,SAAS;wBACjB,mFAAmF;wBACnF,iBAAiB,EAAE;4BACjB,gBAAgB,EAAE,KAAK;yBACxB;qBACF,CAAC,CAAC;iBACJ;gBAED,IAAI,sBAAsB,CAAC,eAAe,CAAC,EAAE;oBAC3C,MAAM,KAAK,CAAC,KAAK,CAAC,CAAC;iBACpB;gBAED,MAAM,SAAS,EAAE,IAAI,EAAE,CAAC;gBAExB,OAAO,IAAI,CAAC;aACb;YACD,OAAO,KAAK,CAAC;SACd;QAAC,OAAO,KAAK,EAAE;YACd,uDAAuD;YACvD,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACrB,OAAO,KAAK,CAAC;SACd;IACH,CAAC,EACD;QACE,SAAS,EAAE,KAAK,IAAI,EAAE;YACpB,MAAM,cAAc,EAAE,OAAO,EAAE,CAAC;YAChC,WAAW,CAAC,iBAAiB,CAAC,YAAY,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC,CAAC;YAErE,mFAAmF;YACnF,4DAA4D;YAC5D,IAAI,UAAU,EAAE;gBACd,WAAW,CAAC,cAAc,CAAC;oBACzB,QAAQ,EAAE,IAAI,EAAE,CAAC,WAAW,CAC1B,UAAU,CAAC,MAAM,CAAC,SAAS,EAC3B,UAAU,CAAC,MAAM,CAAC,OAAO,EACzB,UAAU,CAAC,MAAM,CAAC,OAAO,EACzB,UAAU,CAAC,MAAM,CAAC,SAAS,EAC3B,SAAS,EACT,UAAU,CAAC,MAAM,CAAC,QAAQ,EAC1B,UAAU,CAAC,MAAM,CAAC,uBAAuB,EACzC,UAAU,CAAC,MAAM,CAAC,WAAW,EAC7B,UAAU,CAAC,MAAM,CAAC,gBAAgB,EAClC,UAAU,CAAC,MAAM,CAAC,SAAS,EAC3B,UAAU,CAAC,MAAM,CAAC,iBAAiB,EAAE,CAAC,CAAC,CAAC,EAAE,OAAO,EACjD,UAAU,CAAC,MAAM,CAAC,SAAS,EAC3B,YAAY,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,EACzC,UAAU,CAAC,MAAM,CAAC,OAAO,EACzB,UAAU,CAAC,MAAM,CAAC,QAAQ,CAC3B;iBACF,CAAC,CAAC;aACJ;QACH,CAAC;KACF,CACF,CAAC;IAEF,OAAO;QACL,aAAa;QACb,YAAY;QACZ,cAAc;KACf,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
import { erc20Abi } from "viem";
|
|
2
|
-
import { useReadContract } from "wagmi";
|
|
3
|
-
import { nativeEvmTokenAddress } from "../../core/constants";
|
|
4
|
-
import { parseEvmAddress } from "../../services";
|
|
5
|
-
export const useErc20Allowance = ({ tokenAddress, ownerAddress, spenderAddress, amount = BigInt(0), chainId, enabled = true, }) => {
|
|
6
|
-
const parsedTokenAddress = parseEvmAddress(tokenAddress);
|
|
7
|
-
const parsedOwnerAddress = parseEvmAddress(ownerAddress);
|
|
8
|
-
const parsedSpenderAddress = parseEvmAddress(spenderAddress);
|
|
9
|
-
const isNativeToken = parsedTokenAddress?.toLowerCase() === nativeEvmTokenAddress.toLowerCase();
|
|
10
|
-
const result = useReadContract({
|
|
11
|
-
abi: erc20Abi,
|
|
12
|
-
address: parsedTokenAddress ?? undefined,
|
|
13
|
-
functionName: "allowance",
|
|
14
|
-
chainId,
|
|
15
|
-
args: parsedOwnerAddress && parsedSpenderAddress
|
|
16
|
-
? [parsedOwnerAddress, parsedSpenderAddress]
|
|
17
|
-
: undefined,
|
|
18
|
-
query: {
|
|
19
|
-
enabled: enabled &&
|
|
20
|
-
Boolean(parsedTokenAddress &&
|
|
21
|
-
parsedOwnerAddress &&
|
|
22
|
-
parsedSpenderAddress &&
|
|
23
|
-
!isNativeToken),
|
|
24
|
-
},
|
|
25
|
-
});
|
|
26
|
-
if (!parsedTokenAddress || !parsedOwnerAddress || !parsedSpenderAddress) {
|
|
27
|
-
return {
|
|
28
|
-
hasAllowance: false,
|
|
29
|
-
error: new Error("Invalid or missing address"),
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
|
-
if (isNativeToken) {
|
|
33
|
-
return { hasAllowance: true, isNativeToken: true };
|
|
34
|
-
}
|
|
35
|
-
const allowanceInWei = result.data ?? BigInt(0);
|
|
36
|
-
const hasAllowance = allowanceInWei >= amount;
|
|
37
|
-
return {
|
|
38
|
-
query: result,
|
|
39
|
-
hasAllowance,
|
|
40
|
-
allowanceInWei,
|
|
41
|
-
};
|
|
42
|
-
};
|
|
43
|
-
//# sourceMappingURL=useErc20Allowance.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useErc20Allowance.js","sourceRoot":"","sources":["../../../src/hooks/transaction/useErc20Allowance.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,MAAM,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAWjD,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,EAChC,YAAY,EACZ,YAAY,EACZ,cAAc,EACd,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,EAClB,OAAO,EACP,OAAO,GAAG,IAAI,GACO,EAAE,EAAE;IACzB,MAAM,kBAAkB,GAAG,eAAe,CAAC,YAAY,CAAC,CAAC;IACzD,MAAM,kBAAkB,GAAG,eAAe,CAAC,YAAY,CAAC,CAAC;IACzD,MAAM,oBAAoB,GAAG,eAAe,CAAC,cAAc,CAAC,CAAC;IAC7D,MAAM,aAAa,GACjB,kBAAkB,EAAE,WAAW,EAAE,KAAK,qBAAqB,CAAC,WAAW,EAAE,CAAC;IAE5E,MAAM,MAAM,GAAG,eAAe,CAAC;QAC7B,GAAG,EAAE,QAAQ;QACb,OAAO,EAAE,kBAAkB,IAAI,SAAS;QACxC,YAAY,EAAE,WAAW;QACzB,OAAO;QACP,IAAI,EACF,kBAAkB,IAAI,oBAAoB;YACxC,CAAC,CAAC,CAAC,kBAAkB,EAAE,oBAAoB,CAAC;YAC5C,CAAC,CAAC,SAAS;QACf,KAAK,EAAE;YACL,OAAO,EACL,OAAO;gBACP,OAAO,CACL,kBAAkB;oBAChB,kBAAkB;oBAClB,oBAAoB;oBACpB,CAAC,aAAa,CACjB;SACJ;KACF,CAAC,CAAC;IAEH,IAAI,CAAC,kBAAkB,IAAI,CAAC,kBAAkB,IAAI,CAAC,oBAAoB,EAAE;QACvE,OAAO;YACL,YAAY,EAAE,KAAK;YACnB,KAAK,EAAE,IAAI,KAAK,CAAC,4BAA4B,CAAC;SAC/C,CAAC;KACH;IAED,IAAI,aAAa,EAAE;QACjB,OAAO,EAAE,YAAY,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC;KACpD;IAED,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC;IAChD,MAAM,YAAY,GAAG,cAAc,IAAI,MAAM,CAAC;IAE9C,OAAO;QACL,KAAK,EAAE,MAAM;QACb,YAAY;QACZ,cAAc;KACf,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -1,115 +0,0 @@
|
|
|
1
|
-
import { FeeType } from "@0xsquid/squid-types";
|
|
2
|
-
import { useMemo } from "react";
|
|
3
|
-
import { formatUsdAmount } from "../../services";
|
|
4
|
-
import { calculateEstimateResults, calculateTotalWithRefundEstimate, getProposedGasDestinationAmount, } from "../../services/internal/estimateService";
|
|
5
|
-
import { useConfigStore } from "../store/useSquidStore";
|
|
6
|
-
import { useSwap } from "../swap/useSwap";
|
|
7
|
-
import { useMultiChainBalance } from "../tokens/useMultiChainBalance";
|
|
8
|
-
import { useNativeBalance } from "../tokens/useNativeBalance";
|
|
9
|
-
import { useSingleTokenPrice } from "../tokens/useSingleTokenPrice";
|
|
10
|
-
import { useSquidTokens } from "../tokens/useSquidTokens";
|
|
11
|
-
const DEFAULT_PROVIDER_IMAGE_URL = "https://raw.githubusercontent.com/0xsquid/assets/main/images/webp128/providers/squid.webp";
|
|
12
|
-
const AXELAR_PROVIDER_IMAGE_URL = "https://raw.githubusercontent.com/0xsquid/assets/main/images/webp128/providers/axelar.webp";
|
|
13
|
-
export const useEstimate = (squidRoute) => {
|
|
14
|
-
const collectFees = useConfigStore((state) => state.config.collectFees);
|
|
15
|
-
const { tokens } = useSquidTokens();
|
|
16
|
-
const { fromChain, toChain } = useSwap();
|
|
17
|
-
const { nativeBalance } = useNativeBalance(fromChain);
|
|
18
|
-
const estimateResults = useMemo(() => calculateEstimateResults({
|
|
19
|
-
squidRoute,
|
|
20
|
-
tokens,
|
|
21
|
-
fromChain,
|
|
22
|
-
toChain,
|
|
23
|
-
collectFees: !!collectFees && collectFees.fee > 0,
|
|
24
|
-
nativeTokenBalanceFromChainWei: nativeBalance?.value ?? BigInt("0"),
|
|
25
|
-
}), [squidRoute, tokens, fromChain, toChain, collectFees, nativeBalance]);
|
|
26
|
-
const balanceFormatted = useMultiChainBalance({
|
|
27
|
-
chain: fromChain,
|
|
28
|
-
token: estimateResults.fromToken,
|
|
29
|
-
userAddress: squidRoute?.params.fromAddress ?? "",
|
|
30
|
-
enabled: !!squidRoute,
|
|
31
|
-
}).balance ?? "0";
|
|
32
|
-
const { getUSDValue } = useSingleTokenPrice(estimateResults.firstFeeCost?.token);
|
|
33
|
-
const totalWithRefundEstimate = useMemo(() => calculateTotalWithRefundEstimate(estimateResults.allFeeCosts, estimateResults.expectedGasRefundCost, getUSDValue), [
|
|
34
|
-
estimateResults.allFeeCosts,
|
|
35
|
-
estimateResults.expectedGasRefundCost,
|
|
36
|
-
getUSDValue,
|
|
37
|
-
]);
|
|
38
|
-
const proposedGasDestinationAmount = useMemo(() => getProposedGasDestinationAmount(estimateResults.destChainNativeToken?.symbol), [estimateResults.destChainNativeToken]);
|
|
39
|
-
const { feeCostsFormatted, totalFeeCostsUsd } = useMemo(() => {
|
|
40
|
-
const feeCosts = squidRoute?.estimate.feeCosts ?? [];
|
|
41
|
-
const feeCostsRenamed = [];
|
|
42
|
-
const feesToRename = [
|
|
43
|
-
{
|
|
44
|
-
newName: "CORAL fee",
|
|
45
|
-
match: [FeeType.EXECUTION_FEE, FeeType.SETTLEMENT_FEE],
|
|
46
|
-
imageUrl: DEFAULT_PROVIDER_IMAGE_URL,
|
|
47
|
-
},
|
|
48
|
-
{
|
|
49
|
-
newName: "Axelar fee",
|
|
50
|
-
match: [FeeType.GAS_RECEIVER_FEE, FeeType.BOOST_FEE],
|
|
51
|
-
imageUrl: AXELAR_PROVIDER_IMAGE_URL,
|
|
52
|
-
},
|
|
53
|
-
];
|
|
54
|
-
for (const fee of feeCosts) {
|
|
55
|
-
if (Number(fee.amountUsd) === 0)
|
|
56
|
-
continue;
|
|
57
|
-
const feeToRename = feesToRename.find(({ match }) => match.includes(fee.name));
|
|
58
|
-
if (feeToRename) {
|
|
59
|
-
const previousRenamedFeeIndex = feeCostsRenamed.findIndex((f) => f.name === feeToRename.newName);
|
|
60
|
-
if (feeCostsRenamed[previousRenamedFeeIndex] == null) {
|
|
61
|
-
feeCostsRenamed.push({
|
|
62
|
-
name: feeToRename.newName,
|
|
63
|
-
amountUsd: Number(fee.amountUsd),
|
|
64
|
-
imageUrl: feeToRename.imageUrl,
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
feeCostsRenamed[previousRenamedFeeIndex].amountUsd += Number(fee.amountUsd);
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
else {
|
|
72
|
-
feeCostsRenamed.push({
|
|
73
|
-
name: fee.name,
|
|
74
|
-
amountUsd: Number(fee.amountUsd),
|
|
75
|
-
// TODO: missing logoURI property, update types
|
|
76
|
-
imageUrl: fee?.logoURI || DEFAULT_PROVIDER_IMAGE_URL,
|
|
77
|
-
});
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
const feeCostsFormatted = feeCostsRenamed.map((fee) => ({
|
|
81
|
-
name: fee.name,
|
|
82
|
-
imageUrl: fee.imageUrl,
|
|
83
|
-
amountUsdFormatted: formatUsdAmount(fee.amountUsd, {
|
|
84
|
-
decimalPrecision: true,
|
|
85
|
-
}),
|
|
86
|
-
}));
|
|
87
|
-
const totalFeeCostsUsd = feeCosts.reduce((totalFees, currentFee) => {
|
|
88
|
-
return Number(totalFees) + Number(currentFee.amountUsd);
|
|
89
|
-
}, 0);
|
|
90
|
-
const totalFeeCostsUsdFormatted = formatUsdAmount(totalFeeCostsUsd, {
|
|
91
|
-
decimalPrecision: true,
|
|
92
|
-
});
|
|
93
|
-
return {
|
|
94
|
-
feeCostsFormatted,
|
|
95
|
-
totalFeeCostsUsd: totalFeeCostsUsdFormatted,
|
|
96
|
-
};
|
|
97
|
-
}, [squidRoute?.estimate.feeCosts]);
|
|
98
|
-
const slippageFormatted =
|
|
99
|
-
// TODO: update types
|
|
100
|
-
Number(squidRoute?.estimate?.aggregateSlippage ?? 0).toFixed(2) +
|
|
101
|
-
"%";
|
|
102
|
-
const enoughBalanceToSwap = +balanceFormatted >= 0 &&
|
|
103
|
-
+balanceFormatted > +estimateResults.fromAmountFormatted;
|
|
104
|
-
return {
|
|
105
|
-
...estimateResults,
|
|
106
|
-
balanceFormatted,
|
|
107
|
-
slippageFormatted,
|
|
108
|
-
totalWithRefundEstimate,
|
|
109
|
-
proposedGasDestinationAmount,
|
|
110
|
-
enoughBalanceToSwap,
|
|
111
|
-
feeCostsFormatted,
|
|
112
|
-
totalFeeCostsUsd,
|
|
113
|
-
};
|
|
114
|
-
};
|
|
115
|
-
//# sourceMappingURL=useEstimate.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useEstimate.js","sourceRoot":"","sources":["../../../src/hooks/transaction/useEstimate.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
import { useMemo } from "react";
|
|
2
|
-
import { useConfigStore } from "../store/useSquidStore";
|
|
3
|
-
export const useEstimatePriceImpact = ({ squidRoute, }) => {
|
|
4
|
-
const config = useConfigStore((state) => state.config);
|
|
5
|
-
const priceImpact = useMemo(() => {
|
|
6
|
-
const priceImpact = squidRoute?.estimate?.aggregatePriceImpact;
|
|
7
|
-
if (priceImpact == null)
|
|
8
|
-
return;
|
|
9
|
-
return Number(priceImpact).toFixed(2);
|
|
10
|
-
}, [squidRoute?.estimate.aggregatePriceImpact]);
|
|
11
|
-
const priceImpactStatus = useMemo(() => {
|
|
12
|
-
if (config.priceImpactWarnings !== undefined && priceImpact !== undefined) {
|
|
13
|
-
if (+priceImpact >= config.priceImpactWarnings.warning &&
|
|
14
|
-
+priceImpact < config.priceImpactWarnings.critical) {
|
|
15
|
-
return "warning";
|
|
16
|
-
}
|
|
17
|
-
if (+priceImpact >= config.priceImpactWarnings.critical) {
|
|
18
|
-
return "critical";
|
|
19
|
-
}
|
|
20
|
-
if (+priceImpact < config.priceImpactWarnings.warning) {
|
|
21
|
-
return "normal";
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
return undefined;
|
|
25
|
-
}, [config.priceImpactWarnings, priceImpact]);
|
|
26
|
-
return {
|
|
27
|
-
priceImpact,
|
|
28
|
-
priceImpactStatus,
|
|
29
|
-
};
|
|
30
|
-
};
|
|
31
|
-
//# sourceMappingURL=useEstimatePriceImpact.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"useEstimatePriceImpact.js","sourceRoot":"","sources":["../../../src/hooks/transaction/useEstimatePriceImpact.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAExD,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,EACrC,UAAU,GAGX,EAAE,EAAE;IACH,MAAM,MAAM,GAAG,cAAc,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAEvD,MAAM,WAAW,GAAuB,OAAO,CAAC,GAAG,EAAE;QACnD,MAAM,WAAW,GAAG,UAAU,EAAE,QAAQ,EAAE,oBAAoB,CAAC;QAE/D,IAAI,WAAW,IAAI,IAAI;YAAE,OAAO;QAEhC,OAAO,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IACxC,CAAC,EAAE,CAAC,UAAU,EAAE,QAAQ,CAAC,oBAAoB,CAAC,CAAC,CAAC;IAEhD,MAAM,iBAAiB,GAAG,OAAO,CAAC,GAAG,EAAE;QACrC,IAAI,MAAM,CAAC,mBAAmB,KAAK,SAAS,IAAI,WAAW,KAAK,SAAS,EAAE;YACzE,IACE,CAAC,WAAW,IAAI,MAAM,CAAC,mBAAmB,CAAC,OAAO;gBAClD,CAAC,WAAW,GAAG,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAClD;gBACA,OAAO,SAAS,CAAC;aAClB;YACD,IAAI,CAAC,WAAW,IAAI,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE;gBACvD,OAAO,UAAU,CAAC;aACnB;YACD,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,mBAAmB,CAAC,OAAO,EAAE;gBACrD,OAAO,QAAQ,CAAC;aACjB;SACF;QACD,OAAO,SAAS,CAAC;IACnB,CAAC,EAAE,CAAC,MAAM,CAAC,mBAAmB,EAAE,WAAW,CAAC,CAAC,CAAC;IAE9C,OAAO;QACL,WAAW;QACX,iBAAiB;KAClB,CAAC;AACJ,CAAC,CAAC"}
|