@0xsquid/react-hooks 6.7.0-beta.0 → 6.7.0-rollup-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.
Files changed (250) hide show
  1. package/dist/hooks/index.d.ts +5 -4
  2. package/dist/index.esm.js +16892 -0
  3. package/dist/index.esm.js.map +1 -0
  4. package/dist/index.js +17096 -6
  5. package/dist/index.js.map +1 -1
  6. package/dist/secretService-Cc7emxDy.js +162 -0
  7. package/dist/secretService-Cc7emxDy.js.map +1 -0
  8. package/dist/{services/external/secretService.js → secretService-SEqSyHG0.js} +37 -8
  9. package/dist/secretService-SEqSyHG0.js.map +1 -0
  10. package/package.json +18 -4
  11. package/dist/core/abis/ics20.json +0 -128
  12. package/dist/core/connectors/bitcoin/errors/index.js +0 -22
  13. package/dist/core/connectors/bitcoin/errors/index.js.map +0 -1
  14. package/dist/core/connectors/bitcoin/helpers.js +0 -86
  15. package/dist/core/connectors/bitcoin/helpers.js.map +0 -1
  16. package/dist/core/connectors/bitcoin/index.js +0 -2
  17. package/dist/core/connectors/bitcoin/index.js.map +0 -1
  18. package/dist/core/connectors/bitcoin/wallets/index.js +0 -4
  19. package/dist/core/connectors/bitcoin/wallets/index.js.map +0 -1
  20. package/dist/core/connectors/bitcoin/wallets/keplr.js +0 -28
  21. package/dist/core/connectors/bitcoin/wallets/keplr.js.map +0 -1
  22. package/dist/core/connectors/bitcoin/wallets/phantom.js +0 -56
  23. package/dist/core/connectors/bitcoin/wallets/phantom.js.map +0 -1
  24. package/dist/core/connectors/bitcoin/wallets/unisat.js +0 -28
  25. package/dist/core/connectors/bitcoin/wallets/unisat.js.map +0 -1
  26. package/dist/core/constants.js +0 -144
  27. package/dist/core/constants.js.map +0 -1
  28. package/dist/core/externalLinks.js +0 -21
  29. package/dist/core/externalLinks.js.map +0 -1
  30. package/dist/core/index.js +0 -4
  31. package/dist/core/index.js.map +0 -1
  32. package/dist/core/multicall3.js +0 -442
  33. package/dist/core/multicall3.js.map +0 -1
  34. package/dist/core/providers/CosmosProvider.js +0 -13
  35. package/dist/core/providers/CosmosProvider.js.map +0 -1
  36. package/dist/core/providers/SolanaProvider.js +0 -15
  37. package/dist/core/providers/SolanaProvider.js.map +0 -1
  38. package/dist/core/providers/SuiProvider.js +0 -15
  39. package/dist/core/providers/SuiProvider.js.map +0 -1
  40. package/dist/core/queries/queries-keys.js +0 -204
  41. package/dist/core/queries/queries-keys.js.map +0 -1
  42. package/dist/core/queries/react-query-config.js +0 -11
  43. package/dist/core/queries/react-query-config.js.map +0 -1
  44. package/dist/core/types/config.js +0 -2
  45. package/dist/core/types/config.js.map +0 -1
  46. package/dist/core/types/dex.js +0 -33
  47. package/dist/core/types/dex.js.map +0 -1
  48. package/dist/core/types/error.js +0 -12
  49. package/dist/core/types/error.js.map +0 -1
  50. package/dist/core/types/event.js +0 -2
  51. package/dist/core/types/event.js.map +0 -1
  52. package/dist/core/types/index.js +0 -2
  53. package/dist/core/types/index.js.map +0 -1
  54. package/dist/core/types/rpc.js +0 -2
  55. package/dist/core/types/rpc.js.map +0 -1
  56. package/dist/core/types/sui.js +0 -2
  57. package/dist/core/types/sui.js.map +0 -1
  58. package/dist/core/types/swap.js +0 -2
  59. package/dist/core/types/swap.js.map +0 -1
  60. package/dist/core/types/tokens.js +0 -2
  61. package/dist/core/types/tokens.js.map +0 -1
  62. package/dist/core/types/transaction.js +0 -41
  63. package/dist/core/types/transaction.js.map +0 -1
  64. package/dist/core/types/wallet.js +0 -26
  65. package/dist/core/types/wallet.js.map +0 -1
  66. package/dist/core/wagmiConfig.js +0 -60
  67. package/dist/core/wagmiConfig.js.map +0 -1
  68. package/dist/core/wallets.js +0 -549
  69. package/dist/core/wallets.js.map +0 -1
  70. package/dist/hooks/chains/useSquidChains.js +0 -107
  71. package/dist/hooks/chains/useSquidChains.js.map +0 -1
  72. package/dist/hooks/client/useClient.js +0 -6
  73. package/dist/hooks/client/useClient.js.map +0 -1
  74. package/dist/hooks/cosmos/useCosmos.js +0 -172
  75. package/dist/hooks/cosmos/useCosmos.js.map +0 -1
  76. package/dist/hooks/cosmos/useCosmosForChain.js +0 -33
  77. package/dist/hooks/cosmos/useCosmosForChain.js.map +0 -1
  78. package/dist/hooks/index.js +0 -44
  79. package/dist/hooks/index.js.map +0 -1
  80. package/dist/hooks/navigation/useKeyboardNavigation.js +0 -67
  81. package/dist/hooks/navigation/useKeyboardNavigation.js.map +0 -1
  82. package/dist/hooks/query/useSquidQueryClient.js +0 -23
  83. package/dist/hooks/query/useSquidQueryClient.js.map +0 -1
  84. package/dist/hooks/solana/useSolana.js +0 -104
  85. package/dist/hooks/solana/useSolana.js.map +0 -1
  86. package/dist/hooks/squid/useSquid.js +0 -55
  87. package/dist/hooks/squid/useSquid.js.map +0 -1
  88. package/dist/hooks/store/useAddressBookStore.js +0 -26
  89. package/dist/hooks/store/useAddressBookStore.js.map +0 -1
  90. package/dist/hooks/store/useAssetsColorsStore.js +0 -7
  91. package/dist/hooks/store/useAssetsColorsStore.js.map +0 -1
  92. package/dist/hooks/store/useDepositAddressStore.js +0 -12
  93. package/dist/hooks/store/useDepositAddressStore.js.map +0 -1
  94. package/dist/hooks/store/useFavoriteTokensStore.js +0 -28
  95. package/dist/hooks/store/useFavoriteTokensStore.js.map +0 -1
  96. package/dist/hooks/store/useHistoryStore.js +0 -41
  97. package/dist/hooks/store/useHistoryStore.js.map +0 -1
  98. package/dist/hooks/store/useSquidStore.js +0 -56
  99. package/dist/hooks/store/useSquidStore.js.map +0 -1
  100. package/dist/hooks/store/useWalletStore.js +0 -42
  101. package/dist/hooks/store/useWalletStore.js.map +0 -1
  102. package/dist/hooks/sui/useSui.js +0 -28
  103. package/dist/hooks/sui/useSui.js.map +0 -1
  104. package/dist/hooks/sui/useSuiClient.js +0 -16
  105. package/dist/hooks/sui/useSuiClient.js.map +0 -1
  106. package/dist/hooks/sui/useSuiWallets.js +0 -42
  107. package/dist/hooks/sui/useSuiWallets.js.map +0 -1
  108. package/dist/hooks/swap/useDepositAddress.js +0 -63
  109. package/dist/hooks/swap/useDepositAddress.js.map +0 -1
  110. package/dist/hooks/swap/useSwap.js +0 -209
  111. package/dist/hooks/swap/useSwap.js.map +0 -1
  112. package/dist/hooks/tokens/useAllConnectedWalletBalances.js +0 -103
  113. package/dist/hooks/tokens/useAllConnectedWalletBalances.js.map +0 -1
  114. package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.js +0 -119
  115. package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.js.map +0 -1
  116. package/dist/hooks/tokens/useBalance.js +0 -136
  117. package/dist/hooks/tokens/useBalance.js.map +0 -1
  118. package/dist/hooks/tokens/useMultiChainBalance.js +0 -68
  119. package/dist/hooks/tokens/useMultiChainBalance.js.map +0 -1
  120. package/dist/hooks/tokens/useMultipleTokenPrices.js +0 -46
  121. package/dist/hooks/tokens/useMultipleTokenPrices.js.map +0 -1
  122. package/dist/hooks/tokens/useNativeBalance.js +0 -217
  123. package/dist/hooks/tokens/useNativeBalance.js.map +0 -1
  124. package/dist/hooks/tokens/useNativeTokenForChain.js +0 -28
  125. package/dist/hooks/tokens/useNativeTokenForChain.js.map +0 -1
  126. package/dist/hooks/tokens/useSingleTokenPrice.js +0 -38
  127. package/dist/hooks/tokens/useSingleTokenPrice.js.map +0 -1
  128. package/dist/hooks/tokens/useSquidTokens.js +0 -80
  129. package/dist/hooks/tokens/useSquidTokens.js.map +0 -1
  130. package/dist/hooks/tokens/useTokenHistoricalData.js +0 -23
  131. package/dist/hooks/tokens/useTokenHistoricalData.js.map +0 -1
  132. package/dist/hooks/transaction/useAllTransactionsStatus.js +0 -68
  133. package/dist/hooks/transaction/useAllTransactionsStatus.js.map +0 -1
  134. package/dist/hooks/transaction/useApproval.js +0 -223
  135. package/dist/hooks/transaction/useApproval.js.map +0 -1
  136. package/dist/hooks/transaction/useErc20Allowance.js +0 -43
  137. package/dist/hooks/transaction/useErc20Allowance.js.map +0 -1
  138. package/dist/hooks/transaction/useEstimate.js +0 -118
  139. package/dist/hooks/transaction/useEstimate.js.map +0 -1
  140. package/dist/hooks/transaction/useEstimatePriceImpact.js +0 -31
  141. package/dist/hooks/transaction/useEstimatePriceImpact.js.map +0 -1
  142. package/dist/hooks/transaction/useExecuteTransaction.js +0 -605
  143. package/dist/hooks/transaction/useExecuteTransaction.js.map +0 -1
  144. package/dist/hooks/transaction/useGetRoute.js +0 -224
  145. package/dist/hooks/transaction/useGetRoute.js.map +0 -1
  146. package/dist/hooks/transaction/useIcs20Allowance.js +0 -40
  147. package/dist/hooks/transaction/useIcs20Allowance.js.map +0 -1
  148. package/dist/hooks/transaction/useRouteWarnings.js +0 -19
  149. package/dist/hooks/transaction/useRouteWarnings.js.map +0 -1
  150. package/dist/hooks/transaction/useSingleTransaction.js +0 -91
  151. package/dist/hooks/transaction/useSingleTransaction.js.map +0 -1
  152. package/dist/hooks/user/useAvatar.js +0 -34
  153. package/dist/hooks/user/useAvatar.js.map +0 -1
  154. package/dist/hooks/user/useHistory.js +0 -106
  155. package/dist/hooks/user/useHistory.js.map +0 -1
  156. package/dist/hooks/user/useUserParams.js +0 -33
  157. package/dist/hooks/user/useUserParams.js.map +0 -1
  158. package/dist/hooks/wallet/useAddToken.js +0 -49
  159. package/dist/hooks/wallet/useAddToken.js.map +0 -1
  160. package/dist/hooks/wallet/useAutoConnect.js +0 -74
  161. package/dist/hooks/wallet/useAutoConnect.js.map +0 -1
  162. package/dist/hooks/wallet/useEns.js +0 -69
  163. package/dist/hooks/wallet/useEns.js.map +0 -1
  164. package/dist/hooks/wallet/useGnosisContext.js +0 -78
  165. package/dist/hooks/wallet/useGnosisContext.js.map +0 -1
  166. package/dist/hooks/wallet/useIntegratorContext.js +0 -39
  167. package/dist/hooks/wallet/useIntegratorContext.js.map +0 -1
  168. package/dist/hooks/wallet/useMultiChainWallet.js +0 -175
  169. package/dist/hooks/wallet/useMultiChainWallet.js.map +0 -1
  170. package/dist/hooks/wallet/useSigner.js +0 -76
  171. package/dist/hooks/wallet/useSigner.js.map +0 -1
  172. package/dist/hooks/wallet/useWallet.js +0 -206
  173. package/dist/hooks/wallet/useWallet.js.map +0 -1
  174. package/dist/hooks/wallet/useWallets.js +0 -36
  175. package/dist/hooks/wallet/useWallets.js.map +0 -1
  176. package/dist/provider/index.js +0 -113
  177. package/dist/provider/index.js.map +0 -1
  178. package/dist/services/external/ens.js +0 -66
  179. package/dist/services/external/ens.js.map +0 -1
  180. package/dist/services/external/rpcService.js +0 -421
  181. package/dist/services/external/rpcService.js.map +0 -1
  182. package/dist/services/external/secretService.js.map +0 -1
  183. package/dist/services/external/suiRpcClient.js +0 -80
  184. package/dist/services/external/suiRpcClient.js.map +0 -1
  185. package/dist/services/external/tokenDataService.js +0 -108
  186. package/dist/services/external/tokenDataService.js.map +0 -1
  187. package/dist/services/index.js +0 -16
  188. package/dist/services/index.js.map +0 -1
  189. package/dist/services/internal/apiService.js +0 -21
  190. package/dist/services/internal/apiService.js.map +0 -1
  191. package/dist/services/internal/assetsService.js +0 -586
  192. package/dist/services/internal/assetsService.js.map +0 -1
  193. package/dist/services/internal/bitcoinService.js +0 -51
  194. package/dist/services/internal/bitcoinService.js.map +0 -1
  195. package/dist/services/internal/configService.js +0 -215
  196. package/dist/services/internal/configService.js.map +0 -1
  197. package/dist/services/internal/cosmosService.js +0 -141
  198. package/dist/services/internal/cosmosService.js.map +0 -1
  199. package/dist/services/internal/errorService.js +0 -188
  200. package/dist/services/internal/errorService.js.map +0 -1
  201. package/dist/services/internal/estimateService.js +0 -221
  202. package/dist/services/internal/estimateService.js.map +0 -1
  203. package/dist/services/internal/eventService.js +0 -156
  204. package/dist/services/internal/eventService.js.map +0 -1
  205. package/dist/services/internal/evmService.js +0 -42
  206. package/dist/services/internal/evmService.js.map +0 -1
  207. package/dist/services/internal/numberService.js +0 -171
  208. package/dist/services/internal/numberService.js.map +0 -1
  209. package/dist/services/internal/priceService.js +0 -53
  210. package/dist/services/internal/priceService.js.map +0 -1
  211. package/dist/services/internal/searchService.js +0 -98
  212. package/dist/services/internal/searchService.js.map +0 -1
  213. package/dist/services/internal/solanaService.js +0 -109
  214. package/dist/services/internal/solanaService.js.map +0 -1
  215. package/dist/services/internal/suiService.js +0 -119
  216. package/dist/services/internal/suiService.js.map +0 -1
  217. package/dist/services/internal/transactionService.js +0 -207
  218. package/dist/services/internal/transactionService.js.map +0 -1
  219. package/dist/services/internal/transactionStatusService.js +0 -315
  220. package/dist/services/internal/transactionStatusService.js.map +0 -1
  221. package/dist/services/internal/walletService.js +0 -464
  222. package/dist/services/internal/walletService.js.map +0 -1
  223. package/dist/tests/apiService.test.js +0 -40
  224. package/dist/tests/apiService.test.js.map +0 -1
  225. package/dist/tests/assetsService.test.js +0 -500
  226. package/dist/tests/assetsService.test.js.map +0 -1
  227. package/dist/tests/configService.test.js +0 -673
  228. package/dist/tests/configService.test.js.map +0 -1
  229. package/dist/tests/estimateService.test.js +0 -355
  230. package/dist/tests/estimateService.test.js.map +0 -1
  231. package/dist/tests/fetchSquidData.js +0 -36
  232. package/dist/tests/fetchSquidData.js.map +0 -1
  233. package/dist/tests/jest-svg-transform.d.ts +0 -0
  234. package/dist/tests/jest-svg-transform.js +0 -21
  235. package/dist/tests/jest-svg-transform.js.map +0 -1
  236. package/dist/tests/numberService.test.js +0 -135
  237. package/dist/tests/numberService.test.js.map +0 -1
  238. package/dist/tests/priceService.test.js +0 -38
  239. package/dist/tests/priceService.test.js.map +0 -1
  240. package/dist/tests/sample.json +0 -0
  241. package/dist/tests/searchService.test.js +0 -92
  242. package/dist/tests/searchService.test.js.map +0 -1
  243. package/dist/tests/swapConfig.test.js +0 -332
  244. package/dist/tests/swapConfig.test.js.map +0 -1
  245. package/dist/tests/transactionService.test.js +0 -53
  246. package/dist/tests/transactionService.test.js.map +0 -1
  247. package/dist/tests/transactionStatusService.test.js +0 -165
  248. package/dist/tests/transactionStatusService.test.js.map +0 -1
  249. package/dist/tests/walletService.test.js +0 -264
  250. package/dist/tests/walletService.test.js.map +0 -1
@@ -1,223 +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 { evmSigner } = useSigner();
22
- const { connector: activeConnector } = useAccount();
23
- const { getChainType } = useSquidChains();
24
- const { fromChain, fromToken, fromPrice } = useSwap();
25
- const { switchChainAsync } = useSwitchChain();
26
- const { connectedAddress: { address: sourceUserAddress }, } = useMultiChainWallet(fromChain);
27
- const isSrcChainEvmos = isEvmosChain(fromChain);
28
- const { hasAllowance: hasErc20Allowance, query: erc20AllowanceQuery, allowanceInWei: erc20AllowanceInWei, } = useErc20Allowance({
29
- tokenAddress: fromToken?.address,
30
- ownerAddress: sourceUserAddress,
31
- spenderAddress: squidRoute?.transactionRequest
32
- ?.target,
33
- amount: BigInt(squidRoute?.params.fromAmount ?? "0"),
34
- chainId: Number(fromChain?.chainId),
35
- enabled: !isSrcChainEvmos,
36
- });
37
- const { hasAllowance: hasIcs20Allowance, query: ics20AllowanceQuery, allowanceInWei: ics20AllowanceInWei, } = useIcs20Allowance({
38
- ownerAddress: sourceUserAddress,
39
- targetAddress: squidRoute?.transactionRequest
40
- ?.target,
41
- amount: BigInt(squidRoute?.params.fromAmount ?? "0"),
42
- chainId: Number(fromChain?.chainId),
43
- enabled: isSrcChainEvmos,
44
- });
45
- const hasAllowance = isSrcChainEvmos ? hasIcs20Allowance : hasErc20Allowance;
46
- const allowanceInWei = isSrcChainEvmos
47
- ? ics20AllowanceInWei
48
- : erc20AllowanceInWei;
49
- const allowanceQuery = isSrcChainEvmos
50
- ? ics20AllowanceQuery
51
- : 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 && !!sourceUserAddress && allowanceQuery?.isSuccess,
66
- });
67
- // USDT has a very specific way of handling approvals
68
- // ```
69
- /// To change the approve amount you first have to reduce the addresses`
70
- // allowance to zero by calling `approve(_spender, 0)` if it is not
71
- // already 0 to mitigate the race condition described here:
72
- // https://github.com/ethereum/EIPs/issues/20#issuecomment-263524729
73
- // ```
74
- // This is why we had an unpredictable gas error for USDT approvals
75
- // So it needs a custom gas limit
76
- //
77
- // TODO: We're only doing it for USDT on Ethereum Mainnet, need to check if it's needed for USDT on other chains
78
- const approveSpecificTokenToZero = async (token) => {
79
- if (walletClient &&
80
- token.symbol.toLowerCase() === "usdt" &&
81
- token.chainId === CHAIN_IDS.ETHEREUM &&
82
- fromToken) {
83
- const fromChainRouterAddress = fromChain?.squidContracts.squidRouter;
84
- const allowance = await publicClient?.readContract({
85
- address: token.address,
86
- abi: [
87
- {
88
- constant: true,
89
- inputs: [
90
- { name: "_owner", type: "address" },
91
- { name: "_spender", type: "address" },
92
- ],
93
- name: "allowance",
94
- outputs: [{ name: "remaining", type: "uint256" }],
95
- type: "function",
96
- },
97
- ],
98
- functionName: "allowance",
99
- args: [
100
- sourceUserAddress,
101
- fromChainRouterAddress,
102
- ],
103
- });
104
- if (allowance &&
105
- BigInt(allowance.toString()) > BigInt(0) &&
106
- publicClient) {
107
- const { request } = await publicClient.simulateContract({
108
- address: token.address,
109
- abi: [
110
- {
111
- constant: false,
112
- inputs: [
113
- { name: "_spender", type: "address" },
114
- { name: "_value", type: "uint256" },
115
- ],
116
- name: "approve",
117
- outputs: [],
118
- type: "function",
119
- },
120
- ],
121
- functionName: "approve",
122
- args: [fromChainRouterAddress, BigInt(0)],
123
- account: sourceUserAddress,
124
- });
125
- await walletClient.writeContract(request);
126
- }
127
- }
128
- return true;
129
- };
130
- /**
131
- * Manually approve route if necessary
132
- */
133
- const approveRoute = useMutation(async () => {
134
- try {
135
- if (fromToken?.address === nativeEvmTokenAddress) {
136
- return true;
137
- }
138
- if (!!squidRoute && walletClient && fromToken && evmSigner && squid) {
139
- await approveSpecificTokenToZero(fromToken);
140
- try {
141
- // If needed, we can switch the chain here
142
- // If already on the correct chain, this will do nothing
143
- await switchChainAsync({ chainId: Number(fromChain?.chainId) });
144
- }
145
- catch (error) {
146
- console.error("Error switching network:", error);
147
- }
148
- let approveTx;
149
- if (isSrcChainEvmos) {
150
- const channel = squidRoute.estimate.actions[0].data
151
- .ibcChannel;
152
- const ics20Interface = new ethers.Interface(ics20Abi);
153
- const approveData = ics20Interface.encodeFunctionData("approve", [
154
- squidRoute.params.fromAddress,
155
- [
156
- {
157
- sourcePort: "transfer",
158
- sourceChannel: channel,
159
- spendLimit: [
160
- {
161
- denom: squidRoute.estimate.actions[0].fromToken
162
- .originalAddress,
163
- amount: squidRoute.params.fromAmount,
164
- },
165
- ],
166
- allowList: [],
167
- allowedPacketData: ["*"],
168
- },
169
- ],
170
- ]);
171
- approveTx = await evmSigner.sendTransaction({
172
- to: squidRoute.transactionRequest.target,
173
- data: approveData,
174
- value: "0",
175
- gasLimit: squidRoute.transactionRequest
176
- .gasLimit,
177
- gasPrice: squidRoute.transactionRequest
178
- .gasPrice,
179
- });
180
- }
181
- else {
182
- approveTx = await squid.approveRoute({
183
- route: squidRoute,
184
- signer: evmSigner,
185
- // For security reasons, we don't want to allow infinite approvals in our frontends
186
- executionSettings: {
187
- infiniteApproval: false,
188
- },
189
- });
190
- }
191
- if (isProblematicConnector(activeConnector)) {
192
- await sleep(3_000);
193
- }
194
- await approveTx?.wait();
195
- return true;
196
- }
197
- return false;
198
- }
199
- catch (error) {
200
- // Keep the error in the console to debug future issues
201
- console.error(error);
202
- return false;
203
- }
204
- }, {
205
- onSuccess: async () => {
206
- await allowanceQuery?.refetch();
207
- queryClient.invalidateQueries(getPrefixKey(QueryKeys.RouteApproved));
208
- // After an approval, we refetch the transaction query with all required parameters
209
- // This is to ensure we're using the latest expiry timestamp
210
- if (squidRoute) {
211
- queryClient.refetchQueries({
212
- 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)),
213
- });
214
- }
215
- },
216
- });
217
- return {
218
- routeApproved,
219
- approveRoute,
220
- allowanceInWei,
221
- };
222
- };
223
- //# sourceMappingURL=useApproval.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useApproval.js","sourceRoot":"","sources":["../../../src/hooks/transaction/useApproval.ts"],"names":[],"mappings":"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"}
@@ -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,118 +0,0 @@
1
- import { FeeType } from "@0xsquid/squid-types";
2
- import { useMemo } from "react";
3
- import { limitTradeSizeUsd } from "../../core/constants";
4
- import { formatUsdAmount } from "../../services";
5
- import { calculateEstimateResults, calculateTotalWithRefundEstimate, getProposedGasDestinationAmount, } from "../../services/internal/estimateService";
6
- import { useConfigStore } from "../store/useSquidStore";
7
- import { useSwap } from "../swap/useSwap";
8
- import { useMultiChainBalance } from "../tokens/useMultiChainBalance";
9
- import { useNativeBalance } from "../tokens/useNativeBalance";
10
- import { useSingleTokenPrice } from "../tokens/useSingleTokenPrice";
11
- import { useSquidTokens } from "../tokens/useSquidTokens";
12
- const DEFAULT_PROVIDER_IMAGE_URL = "https://raw.githubusercontent.com/0xsquid/assets/main/images/webp128/providers/squid.webp";
13
- const AXELAR_PROVIDER_IMAGE_URL = "https://raw.githubusercontent.com/0xsquid/assets/main/images/webp128/providers/axelar.webp";
14
- export const useEstimate = (squidRoute) => {
15
- const collectFees = useConfigStore((state) => state.config.collectFees);
16
- const { tokens } = useSquidTokens();
17
- const { fromChain, toChain } = useSwap();
18
- const { nativeBalance } = useNativeBalance(fromChain);
19
- const estimateResults = useMemo(() => calculateEstimateResults({
20
- squidRoute,
21
- tokens,
22
- fromChain,
23
- toChain,
24
- collectFees: !!collectFees && collectFees.fee > 0,
25
- nativeTokenBalanceFromChainWei: nativeBalance?.value ?? BigInt("0"),
26
- }), [squidRoute, tokens, fromChain, toChain, collectFees, nativeBalance]);
27
- const balanceFormatted = useMultiChainBalance({
28
- chain: fromChain,
29
- token: estimateResults.fromToken,
30
- userAddress: squidRoute?.params.fromAddress ?? "",
31
- enabled: !!squidRoute,
32
- }).balance ?? "0";
33
- const { getUSDValue } = useSingleTokenPrice(estimateResults.firstFeeCost?.token);
34
- const totalWithRefundEstimate = useMemo(() => calculateTotalWithRefundEstimate(estimateResults.allFeeCosts, estimateResults.expectedGasRefundCost, getUSDValue), [
35
- estimateResults.allFeeCosts,
36
- estimateResults.expectedGasRefundCost,
37
- getUSDValue,
38
- ]);
39
- const proposedGasDestinationAmount = useMemo(() => getProposedGasDestinationAmount(estimateResults.destChainNativeToken?.symbol), [estimateResults.destChainNativeToken]);
40
- const { feeCostsFormatted, totalFeeCostsUsd } = useMemo(() => {
41
- const feeCosts = squidRoute?.estimate.feeCosts ?? [];
42
- const feeCostsRenamed = [];
43
- const feesToRename = [
44
- {
45
- newName: "CORAL fee",
46
- match: [FeeType.EXECUTION_FEE, FeeType.SETTLEMENT_FEE],
47
- imageUrl: DEFAULT_PROVIDER_IMAGE_URL,
48
- },
49
- {
50
- newName: "Axelar fee",
51
- match: [FeeType.GAS_RECEIVER_FEE, FeeType.BOOST_FEE],
52
- imageUrl: AXELAR_PROVIDER_IMAGE_URL,
53
- },
54
- ];
55
- for (const fee of feeCosts) {
56
- if (Number(fee.amountUsd) === 0)
57
- continue;
58
- const feeToRename = feesToRename.find(({ match }) => match.includes(fee.name));
59
- if (feeToRename) {
60
- const previousRenamedFeeIndex = feeCostsRenamed.findIndex((f) => f.name === feeToRename.newName);
61
- if (feeCostsRenamed[previousRenamedFeeIndex] == null) {
62
- feeCostsRenamed.push({
63
- name: feeToRename.newName,
64
- amountUsd: Number(fee.amountUsd),
65
- imageUrl: feeToRename.imageUrl,
66
- });
67
- }
68
- else {
69
- feeCostsRenamed[previousRenamedFeeIndex].amountUsd += Number(fee.amountUsd);
70
- }
71
- }
72
- else {
73
- feeCostsRenamed.push({
74
- name: fee.name,
75
- amountUsd: Number(fee.amountUsd),
76
- // TODO: missing logoURI property, update types
77
- imageUrl: fee?.logoURI || DEFAULT_PROVIDER_IMAGE_URL,
78
- });
79
- }
80
- }
81
- const feeCostsFormatted = feeCostsRenamed.map((fee) => ({
82
- name: fee.name,
83
- imageUrl: fee.imageUrl,
84
- amountUsdFormatted: formatUsdAmount(fee.amountUsd, {
85
- decimalPrecision: true,
86
- }),
87
- }));
88
- const totalFeeCostsUsd = feeCosts.reduce((totalFees, currentFee) => {
89
- return Number(totalFees) + Number(currentFee.amountUsd);
90
- }, 0);
91
- const totalFeeCostsUsdFormatted = formatUsdAmount(totalFeeCostsUsd, {
92
- decimalPrecision: true,
93
- });
94
- return {
95
- feeCostsFormatted,
96
- totalFeeCostsUsd: totalFeeCostsUsdFormatted,
97
- };
98
- }, [squidRoute?.estimate.feeCosts]);
99
- const slippageFormatted =
100
- // TODO: update types
101
- Number(squidRoute?.estimate?.aggregateSlippage ?? 0).toFixed(2) +
102
- "%";
103
- const swapAmountExceedsLimit = estimateResults.toAmountUSDFloat > limitTradeSizeUsd;
104
- const enoughBalanceToSwap = +balanceFormatted >= 0 &&
105
- +balanceFormatted > +estimateResults.fromAmountFormatted;
106
- return {
107
- ...estimateResults,
108
- balanceFormatted,
109
- slippageFormatted,
110
- totalWithRefundEstimate,
111
- proposedGasDestinationAmount,
112
- swapAmountExceedsLimit,
113
- enoughBalanceToSwap,
114
- feeCostsFormatted,
115
- totalFeeCostsUsd,
116
- };
117
- };
118
- //# 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"}