@0xsquid/react-hooks 7.8.0 → 8.0.0-beta.1

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 (348) hide show
  1. package/dist/core/types/index.d.ts +2 -2
  2. package/dist/index-BVNZiGCx.js +6021 -0
  3. package/dist/index-BVNZiGCx.js.map +1 -0
  4. package/dist/index-BeLuO1uo.js +6021 -0
  5. package/dist/index-BeLuO1uo.js.map +1 -0
  6. package/dist/index-CGkGzcT3.js +41015 -0
  7. package/dist/index-CGkGzcT3.js.map +1 -0
  8. package/dist/index-DDz-C-VC.js +41267 -0
  9. package/dist/index-DDz-C-VC.js.map +1 -0
  10. package/dist/index.esm.js +36 -0
  11. package/dist/index.esm.js.map +1 -0
  12. package/dist/index.js +296 -6
  13. package/dist/index.js.map +1 -1
  14. package/dist/{services/external/secretService.js → secretService-D49fXkda.js} +43 -8
  15. package/dist/secretService-D49fXkda.js.map +1 -0
  16. package/dist/secretService-DeXE4j0J.js +168 -0
  17. package/dist/secretService-DeXE4j0J.js.map +1 -0
  18. package/package.json +18 -4
  19. package/dist/core/abis/ics20.json +0 -128
  20. package/dist/core/client/index.js +0 -38
  21. package/dist/core/client/index.js.map +0 -1
  22. package/dist/core/connectors/bitcoin/errors/index.js +0 -22
  23. package/dist/core/connectors/bitcoin/errors/index.js.map +0 -1
  24. package/dist/core/connectors/bitcoin/helpers.js +0 -91
  25. package/dist/core/connectors/bitcoin/helpers.js.map +0 -1
  26. package/dist/core/connectors/bitcoin/index.js +0 -2
  27. package/dist/core/connectors/bitcoin/index.js.map +0 -1
  28. package/dist/core/connectors/bitcoin/wallets/index.js +0 -4
  29. package/dist/core/connectors/bitcoin/wallets/index.js.map +0 -1
  30. package/dist/core/connectors/bitcoin/wallets/keplr.js +0 -28
  31. package/dist/core/connectors/bitcoin/wallets/keplr.js.map +0 -1
  32. package/dist/core/connectors/bitcoin/wallets/phantom.js +0 -56
  33. package/dist/core/connectors/bitcoin/wallets/phantom.js.map +0 -1
  34. package/dist/core/connectors/bitcoin/wallets/unisat.js +0 -28
  35. package/dist/core/connectors/bitcoin/wallets/unisat.js.map +0 -1
  36. package/dist/core/connectors/xrpl/CrossMark.js +0 -76
  37. package/dist/core/connectors/xrpl/CrossMark.js.map +0 -1
  38. package/dist/core/connectors/xrpl/WalletConnect.js +0 -194
  39. package/dist/core/connectors/xrpl/WalletConnect.js.map +0 -1
  40. package/dist/core/connectors/xrpl/Xaman.js +0 -71
  41. package/dist/core/connectors/xrpl/Xaman.js.map +0 -1
  42. package/dist/core/connectors/xrpl/XamanQr.js +0 -95
  43. package/dist/core/connectors/xrpl/XamanQr.js.map +0 -1
  44. package/dist/core/connectors/xrpl/XrplMetamaskSnap.js +0 -176
  45. package/dist/core/connectors/xrpl/XrplMetamaskSnap.js.map +0 -1
  46. package/dist/core/constants.js +0 -157
  47. package/dist/core/constants.js.map +0 -1
  48. package/dist/core/externalLinks.js +0 -21
  49. package/dist/core/externalLinks.js.map +0 -1
  50. package/dist/core/index.js +0 -4
  51. package/dist/core/index.js.map +0 -1
  52. package/dist/core/multicall3.js +0 -462
  53. package/dist/core/multicall3.js.map +0 -1
  54. package/dist/core/providers/BitcoinProvider.js +0 -15
  55. package/dist/core/providers/BitcoinProvider.js.map +0 -1
  56. package/dist/core/providers/CosmosProvider.js +0 -13
  57. package/dist/core/providers/CosmosProvider.js.map +0 -1
  58. package/dist/core/providers/EvmProvider.js +0 -15
  59. package/dist/core/providers/EvmProvider.js.map +0 -1
  60. package/dist/core/providers/SolanaProvider.js +0 -15
  61. package/dist/core/providers/SolanaProvider.js.map +0 -1
  62. package/dist/core/providers/SuiProvider.js +0 -15
  63. package/dist/core/providers/SuiProvider.js.map +0 -1
  64. package/dist/core/providers/XrplProvider.js +0 -15
  65. package/dist/core/providers/XrplProvider.js.map +0 -1
  66. package/dist/core/queries/queries-keys.js +0 -232
  67. package/dist/core/queries/queries-keys.js.map +0 -1
  68. package/dist/core/queries/react-query-config.js +0 -11
  69. package/dist/core/queries/react-query-config.js.map +0 -1
  70. package/dist/core/types/bitcoin.js +0 -2
  71. package/dist/core/types/bitcoin.js.map +0 -1
  72. package/dist/core/types/config.js +0 -2
  73. package/dist/core/types/config.js.map +0 -1
  74. package/dist/core/types/error.js +0 -18
  75. package/dist/core/types/error.js.map +0 -1
  76. package/dist/core/types/event.js +0 -2
  77. package/dist/core/types/event.js.map +0 -1
  78. package/dist/core/types/evm.js +0 -2
  79. package/dist/core/types/evm.js.map +0 -1
  80. package/dist/core/types/history.js +0 -7
  81. package/dist/core/types/history.js.map +0 -1
  82. package/dist/core/types/index.js +0 -4
  83. package/dist/core/types/index.js.map +0 -1
  84. package/dist/core/types/onramps/index.js +0 -3
  85. package/dist/core/types/onramps/index.js.map +0 -1
  86. package/dist/core/types/onramps/onramp.js +0 -2
  87. package/dist/core/types/onramps/onramp.js.map +0 -1
  88. package/dist/core/types/onramps/revolut.js +0 -2
  89. package/dist/core/types/onramps/revolut.js.map +0 -1
  90. package/dist/core/types/rpc.js +0 -2
  91. package/dist/core/types/rpc.js.map +0 -1
  92. package/dist/core/types/solana.js +0 -2
  93. package/dist/core/types/solana.js.map +0 -1
  94. package/dist/core/types/sui.js +0 -2
  95. package/dist/core/types/sui.js.map +0 -1
  96. package/dist/core/types/swap.js +0 -2
  97. package/dist/core/types/swap.js.map +0 -1
  98. package/dist/core/types/tokens.js +0 -2
  99. package/dist/core/types/tokens.js.map +0 -1
  100. package/dist/core/types/transaction.js +0 -47
  101. package/dist/core/types/transaction.js.map +0 -1
  102. package/dist/core/types/wallet.js +0 -19
  103. package/dist/core/types/wallet.js.map +0 -1
  104. package/dist/core/types/xrpl.js +0 -32
  105. package/dist/core/types/xrpl.js.map +0 -1
  106. package/dist/core/wagmiConfig.js +0 -81
  107. package/dist/core/wagmiConfig.js.map +0 -1
  108. package/dist/core/wallets.js +0 -357
  109. package/dist/core/wallets.js.map +0 -1
  110. package/dist/hooks/analytics/useTrackSearchEmpty.js +0 -22
  111. package/dist/hooks/analytics/useTrackSearchEmpty.js.map +0 -1
  112. package/dist/hooks/bitcoin/useBitcoin.js +0 -18
  113. package/dist/hooks/bitcoin/useBitcoin.js.map +0 -1
  114. package/dist/hooks/chains/useSquidChains.js +0 -96
  115. package/dist/hooks/chains/useSquidChains.js.map +0 -1
  116. package/dist/hooks/client/useClient.js +0 -63
  117. package/dist/hooks/client/useClient.js.map +0 -1
  118. package/dist/hooks/cosmos/useCosmos.js +0 -167
  119. package/dist/hooks/cosmos/useCosmos.js.map +0 -1
  120. package/dist/hooks/cosmos/useCosmosForChain.js +0 -29
  121. package/dist/hooks/cosmos/useCosmosForChain.js.map +0 -1
  122. package/dist/hooks/evm/useEvm.js +0 -68
  123. package/dist/hooks/evm/useEvm.js.map +0 -1
  124. package/dist/hooks/evm/useEvmWallets.js +0 -13
  125. package/dist/hooks/evm/useEvmWallets.js.map +0 -1
  126. package/dist/hooks/index.js +0 -54
  127. package/dist/hooks/index.js.map +0 -1
  128. package/dist/hooks/navigation/useKeyboardNavigation.js +0 -67
  129. package/dist/hooks/navigation/useKeyboardNavigation.js.map +0 -1
  130. package/dist/hooks/onramp/useFiatToCrypto.js +0 -298
  131. package/dist/hooks/onramp/useFiatToCrypto.js.map +0 -1
  132. package/dist/hooks/query/useSquidQueryClient.js +0 -23
  133. package/dist/hooks/query/useSquidQueryClient.js.map +0 -1
  134. package/dist/hooks/solana/useSolana.js +0 -81
  135. package/dist/hooks/solana/useSolana.js.map +0 -1
  136. package/dist/hooks/solana/useSolanaWallets.js +0 -8
  137. package/dist/hooks/solana/useSolanaWallets.js.map +0 -1
  138. package/dist/hooks/squid/useSquid.js +0 -55
  139. package/dist/hooks/squid/useSquid.js.map +0 -1
  140. package/dist/hooks/store/useAddressBookStore.js +0 -30
  141. package/dist/hooks/store/useAddressBookStore.js.map +0 -1
  142. package/dist/hooks/store/useAssetsColorsStore.js +0 -7
  143. package/dist/hooks/store/useAssetsColorsStore.js.map +0 -1
  144. package/dist/hooks/store/useDepositAddressStore.js +0 -12
  145. package/dist/hooks/store/useDepositAddressStore.js.map +0 -1
  146. package/dist/hooks/store/useFavoriteTokensStore.js +0 -28
  147. package/dist/hooks/store/useFavoriteTokensStore.js.map +0 -1
  148. package/dist/hooks/store/useHistoryStore.js +0 -129
  149. package/dist/hooks/store/useHistoryStore.js.map +0 -1
  150. package/dist/hooks/store/useSendTransactionStore.js +0 -21
  151. package/dist/hooks/store/useSendTransactionStore.js.map +0 -1
  152. package/dist/hooks/store/useSquidStore.js +0 -54
  153. package/dist/hooks/store/useSquidStore.js.map +0 -1
  154. package/dist/hooks/store/useWalletStore.js +0 -61
  155. package/dist/hooks/store/useWalletStore.js.map +0 -1
  156. package/dist/hooks/sui/useSui.js +0 -81
  157. package/dist/hooks/sui/useSui.js.map +0 -1
  158. package/dist/hooks/sui/useSuiWallets.js +0 -23
  159. package/dist/hooks/sui/useSuiWallets.js.map +0 -1
  160. package/dist/hooks/swap/useDepositAddress.js +0 -63
  161. package/dist/hooks/swap/useDepositAddress.js.map +0 -1
  162. package/dist/hooks/swap/useSwap.js +0 -228
  163. package/dist/hooks/swap/useSwap.js.map +0 -1
  164. package/dist/hooks/tokens/useAllConnectedWalletBalances.js +0 -114
  165. package/dist/hooks/tokens/useAllConnectedWalletBalances.js.map +0 -1
  166. package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.js +0 -130
  167. package/dist/hooks/tokens/useAllTokensWithBalanceForChainType.js.map +0 -1
  168. package/dist/hooks/tokens/useBalance.js +0 -157
  169. package/dist/hooks/tokens/useBalance.js.map +0 -1
  170. package/dist/hooks/tokens/useMultiChainBalance.js +0 -77
  171. package/dist/hooks/tokens/useMultiChainBalance.js.map +0 -1
  172. package/dist/hooks/tokens/useMultipleTokenPrices.js +0 -46
  173. package/dist/hooks/tokens/useMultipleTokenPrices.js.map +0 -1
  174. package/dist/hooks/tokens/useNativeBalance.js +0 -249
  175. package/dist/hooks/tokens/useNativeBalance.js.map +0 -1
  176. package/dist/hooks/tokens/useNativeTokenForChain.js +0 -30
  177. package/dist/hooks/tokens/useNativeTokenForChain.js.map +0 -1
  178. package/dist/hooks/tokens/useSingleTokenPrice.js +0 -38
  179. package/dist/hooks/tokens/useSingleTokenPrice.js.map +0 -1
  180. package/dist/hooks/tokens/useSquidTokens.js +0 -75
  181. package/dist/hooks/tokens/useSquidTokens.js.map +0 -1
  182. package/dist/hooks/tokens/useTokenHistoricalData.js +0 -23
  183. package/dist/hooks/tokens/useTokenHistoricalData.js.map +0 -1
  184. package/dist/hooks/transaction/send/useEstimateSendTransactionGas.js +0 -58
  185. package/dist/hooks/transaction/send/useEstimateSendTransactionGas.js.map +0 -1
  186. package/dist/hooks/transaction/send/useSendTransaction.js +0 -245
  187. package/dist/hooks/transaction/send/useSendTransaction.js.map +0 -1
  188. package/dist/hooks/transaction/send/useSendTransactionGas.js +0 -73
  189. package/dist/hooks/transaction/send/useSendTransactionGas.js.map +0 -1
  190. package/dist/hooks/transaction/useAllTransactionsStatus.js +0 -127
  191. package/dist/hooks/transaction/useAllTransactionsStatus.js.map +0 -1
  192. package/dist/hooks/transaction/useApproval.js +0 -246
  193. package/dist/hooks/transaction/useApproval.js.map +0 -1
  194. package/dist/hooks/transaction/useErc20Allowance.js +0 -43
  195. package/dist/hooks/transaction/useErc20Allowance.js.map +0 -1
  196. package/dist/hooks/transaction/useEstimate.js +0 -115
  197. package/dist/hooks/transaction/useEstimate.js.map +0 -1
  198. package/dist/hooks/transaction/useEstimatePriceImpact.js +0 -31
  199. package/dist/hooks/transaction/useEstimatePriceImpact.js.map +0 -1
  200. package/dist/hooks/transaction/useExecuteTransaction.js +0 -678
  201. package/dist/hooks/transaction/useExecuteTransaction.js.map +0 -1
  202. package/dist/hooks/transaction/useGetRoute.js +0 -207
  203. package/dist/hooks/transaction/useGetRoute.js.map +0 -1
  204. package/dist/hooks/transaction/useIcs20Allowance.js +0 -46
  205. package/dist/hooks/transaction/useIcs20Allowance.js.map +0 -1
  206. package/dist/hooks/transaction/useRouteWarnings.js +0 -19
  207. package/dist/hooks/transaction/useRouteWarnings.js.map +0 -1
  208. package/dist/hooks/transaction/useSendTransactionStatus.js +0 -63
  209. package/dist/hooks/transaction/useSendTransactionStatus.js.map +0 -1
  210. package/dist/hooks/transaction/useSwapTransactionStatus.js +0 -114
  211. package/dist/hooks/transaction/useSwapTransactionStatus.js.map +0 -1
  212. package/dist/hooks/user/useAvatar.js +0 -40
  213. package/dist/hooks/user/useAvatar.js.map +0 -1
  214. package/dist/hooks/user/useHistory.js +0 -103
  215. package/dist/hooks/user/useHistory.js.map +0 -1
  216. package/dist/hooks/user/useUserParams.js +0 -33
  217. package/dist/hooks/user/useUserParams.js.map +0 -1
  218. package/dist/hooks/utils/useUtils.js +0 -20
  219. package/dist/hooks/utils/useUtils.js.map +0 -1
  220. package/dist/hooks/wallet/useAddToken.js +0 -49
  221. package/dist/hooks/wallet/useAddToken.js.map +0 -1
  222. package/dist/hooks/wallet/useAutoConnect.js +0 -92
  223. package/dist/hooks/wallet/useAutoConnect.js.map +0 -1
  224. package/dist/hooks/wallet/useEns.js +0 -57
  225. package/dist/hooks/wallet/useEns.js.map +0 -1
  226. package/dist/hooks/wallet/useGnosisContext.js +0 -74
  227. package/dist/hooks/wallet/useGnosisContext.js.map +0 -1
  228. package/dist/hooks/wallet/useIntegratorContext.js +0 -39
  229. package/dist/hooks/wallet/useIntegratorContext.js.map +0 -1
  230. package/dist/hooks/wallet/useMultiChainWallet.js +0 -210
  231. package/dist/hooks/wallet/useMultiChainWallet.js.map +0 -1
  232. package/dist/hooks/wallet/useSigner.js +0 -68
  233. package/dist/hooks/wallet/useSigner.js.map +0 -1
  234. package/dist/hooks/wallet/useStandardWallets.js +0 -26
  235. package/dist/hooks/wallet/useStandardWallets.js.map +0 -1
  236. package/dist/hooks/wallet/useWallet.js +0 -199
  237. package/dist/hooks/wallet/useWallet.js.map +0 -1
  238. package/dist/hooks/wallet/useWallets.js +0 -33
  239. package/dist/hooks/wallet/useWallets.js.map +0 -1
  240. package/dist/hooks/xrpl/useXrpl.js +0 -55
  241. package/dist/hooks/xrpl/useXrpl.js.map +0 -1
  242. package/dist/hooks/xrpl/useXrplTrustLine.js +0 -159
  243. package/dist/hooks/xrpl/useXrplTrustLine.js.map +0 -1
  244. package/dist/hooks/xrpl/useXrplWallets.js +0 -51
  245. package/dist/hooks/xrpl/useXrplWallets.js.map +0 -1
  246. package/dist/provider/index.js +0 -118
  247. package/dist/provider/index.js.map +0 -1
  248. package/dist/services/external/cosmosRestClient.js +0 -45
  249. package/dist/services/external/cosmosRestClient.js.map +0 -1
  250. package/dist/services/external/ens.js +0 -66
  251. package/dist/services/external/ens.js.map +0 -1
  252. package/dist/services/external/index.js +0 -3
  253. package/dist/services/external/index.js.map +0 -1
  254. package/dist/services/external/onrampAdapter.js +0 -52
  255. package/dist/services/external/onrampAdapter.js.map +0 -1
  256. package/dist/services/external/rpcService.js +0 -411
  257. package/dist/services/external/rpcService.js.map +0 -1
  258. package/dist/services/external/secretService.js.map +0 -1
  259. package/dist/services/external/suiRpcClient.js +0 -80
  260. package/dist/services/external/suiRpcClient.js.map +0 -1
  261. package/dist/services/external/tokenDataService.js +0 -108
  262. package/dist/services/external/tokenDataService.js.map +0 -1
  263. package/dist/services/external/websocket.js +0 -34
  264. package/dist/services/external/websocket.js.map +0 -1
  265. package/dist/services/external/xaman.js +0 -78
  266. package/dist/services/external/xaman.js.map +0 -1
  267. package/dist/services/external/xrplRpcClient.js +0 -167
  268. package/dist/services/external/xrplRpcClient.js.map +0 -1
  269. package/dist/services/index.js +0 -19
  270. package/dist/services/index.js.map +0 -1
  271. package/dist/services/internal/apiService.js +0 -21
  272. package/dist/services/internal/apiService.js.map +0 -1
  273. package/dist/services/internal/assetsService.js +0 -575
  274. package/dist/services/internal/assetsService.js.map +0 -1
  275. package/dist/services/internal/bitcoinService.js +0 -20
  276. package/dist/services/internal/bitcoinService.js.map +0 -1
  277. package/dist/services/internal/configService.js +0 -198
  278. package/dist/services/internal/configService.js.map +0 -1
  279. package/dist/services/internal/cosmosService.js +0 -141
  280. package/dist/services/internal/cosmosService.js.map +0 -1
  281. package/dist/services/internal/countryCurrencyMap.js +0 -1102
  282. package/dist/services/internal/countryCurrencyMap.js.map +0 -1
  283. package/dist/services/internal/errorService.js +0 -190
  284. package/dist/services/internal/errorService.js.map +0 -1
  285. package/dist/services/internal/estimateService.js +0 -225
  286. package/dist/services/internal/estimateService.js.map +0 -1
  287. package/dist/services/internal/eventService.js +0 -219
  288. package/dist/services/internal/eventService.js.map +0 -1
  289. package/dist/services/internal/evmService.js +0 -67
  290. package/dist/services/internal/evmService.js.map +0 -1
  291. package/dist/services/internal/fiatToCryptoService.js +0 -84
  292. package/dist/services/internal/fiatToCryptoService.js.map +0 -1
  293. package/dist/services/internal/fiatToCryptoService.test.js +0 -45
  294. package/dist/services/internal/fiatToCryptoService.test.js.map +0 -1
  295. package/dist/services/internal/numberService.js +0 -199
  296. package/dist/services/internal/numberService.js.map +0 -1
  297. package/dist/services/internal/priceService.js +0 -53
  298. package/dist/services/internal/priceService.js.map +0 -1
  299. package/dist/services/internal/searchService.js +0 -98
  300. package/dist/services/internal/searchService.js.map +0 -1
  301. package/dist/services/internal/sendTransaction.js +0 -191
  302. package/dist/services/internal/sendTransaction.js.map +0 -1
  303. package/dist/services/internal/sendTransactionStatus.js +0 -134
  304. package/dist/services/internal/sendTransactionStatus.js.map +0 -1
  305. package/dist/services/internal/solanaService.js +0 -142
  306. package/dist/services/internal/solanaService.js.map +0 -1
  307. package/dist/services/internal/suiService.js +0 -81
  308. package/dist/services/internal/suiService.js.map +0 -1
  309. package/dist/services/internal/transactionService.js +0 -210
  310. package/dist/services/internal/transactionService.js.map +0 -1
  311. package/dist/services/internal/transactionStatusService.js +0 -390
  312. package/dist/services/internal/transactionStatusService.js.map +0 -1
  313. package/dist/services/internal/walletService.js +0 -546
  314. package/dist/services/internal/walletService.js.map +0 -1
  315. package/dist/services/internal/walletStandardService.js +0 -128
  316. package/dist/services/internal/walletStandardService.js.map +0 -1
  317. package/dist/services/internal/xionService.js +0 -6
  318. package/dist/services/internal/xionService.js.map +0 -1
  319. package/dist/services/internal/xrplService.js +0 -52
  320. package/dist/services/internal/xrplService.js.map +0 -1
  321. package/dist/tests/apiService.test.js +0 -40
  322. package/dist/tests/apiService.test.js.map +0 -1
  323. package/dist/tests/assetsService.test.js +0 -614
  324. package/dist/tests/assetsService.test.js.map +0 -1
  325. package/dist/tests/configService.test.js +0 -641
  326. package/dist/tests/configService.test.js.map +0 -1
  327. package/dist/tests/estimateService.test.js +0 -429
  328. package/dist/tests/estimateService.test.js.map +0 -1
  329. package/dist/tests/fetchSquidData.js +0 -36
  330. package/dist/tests/fetchSquidData.js.map +0 -1
  331. package/dist/tests/jest-svg-transform.d.ts +0 -0
  332. package/dist/tests/jest-svg-transform.js +0 -21
  333. package/dist/tests/jest-svg-transform.js.map +0 -1
  334. package/dist/tests/numberService.test.js +0 -166
  335. package/dist/tests/numberService.test.js.map +0 -1
  336. package/dist/tests/priceService.test.js +0 -38
  337. package/dist/tests/priceService.test.js.map +0 -1
  338. package/dist/tests/sample.json +0 -0
  339. package/dist/tests/searchService.test.js +0 -86
  340. package/dist/tests/searchService.test.js.map +0 -1
  341. package/dist/tests/swapConfig.test.js +0 -332
  342. package/dist/tests/swapConfig.test.js.map +0 -1
  343. package/dist/tests/transactionService.test.js +0 -53
  344. package/dist/tests/transactionService.test.js.map +0 -1
  345. package/dist/tests/transactionStatusService.test.js +0 -165
  346. package/dist/tests/transactionStatusService.test.js.map +0 -1
  347. package/dist/tests/walletService.test.js +0 -488
  348. 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":"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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,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"}