0xtrails 0.0.1 → 0.0.2

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 (359) hide show
  1. package/LICENSE +202 -0
  2. package/README.md +42 -0
  3. package/dist/abi.d.ts +37 -0
  4. package/dist/abi.d.ts.map +1 -0
  5. package/dist/abi.js +36 -0
  6. package/dist/apiClient.d.ts +9 -0
  7. package/dist/apiClient.d.ts.map +1 -0
  8. package/dist/apiClient.js +18 -0
  9. package/dist/buffer.d.ts +3 -0
  10. package/dist/buffer.d.ts.map +1 -0
  11. package/dist/buffer.js +8 -0
  12. package/dist/cctp.d.ts +84 -0
  13. package/dist/cctp.d.ts.map +1 -0
  14. package/dist/cctp.js +401 -0
  15. package/dist/chainSwitch.d.ts +7 -0
  16. package/dist/chainSwitch.d.ts.map +1 -0
  17. package/dist/chainSwitch.js +33 -0
  18. package/dist/chains.d.ts +13 -0
  19. package/dist/chains.d.ts.map +1 -0
  20. package/dist/chains.js +95 -0
  21. package/dist/constants.d.ts +11 -0
  22. package/dist/constants.d.ts.map +1 -0
  23. package/dist/constants.js +16 -0
  24. package/dist/encoders.d.ts +7 -0
  25. package/dist/encoders.d.ts.map +1 -0
  26. package/dist/encoders.js +8 -0
  27. package/dist/error.d.ts +2 -0
  28. package/dist/error.d.ts.map +1 -0
  29. package/dist/error.js +12 -0
  30. package/dist/explorer.d.ts +12 -0
  31. package/dist/explorer.d.ts.map +1 -0
  32. package/dist/explorer.js +18 -0
  33. package/dist/gasless.d.ts +116 -0
  34. package/dist/gasless.d.ts.map +1 -0
  35. package/dist/gasless.js +297 -0
  36. package/dist/index.d.ts +13 -0
  37. package/dist/index.d.ts.map +1 -0
  38. package/dist/index.js +9 -0
  39. package/dist/indexerClient.d.ts +9 -0
  40. package/dist/indexerClient.d.ts.map +1 -0
  41. package/dist/indexerClient.js +18 -0
  42. package/dist/intents.d.ts +83 -0
  43. package/dist/intents.d.ts.map +1 -0
  44. package/dist/intents.js +288 -0
  45. package/dist/metaTxnMonitor.d.ts +14 -0
  46. package/dist/metaTxnMonitor.d.ts.map +1 -0
  47. package/dist/metaTxnMonitor.js +121 -0
  48. package/dist/metaTxns.d.ts +6 -0
  49. package/dist/metaTxns.d.ts.map +1 -0
  50. package/dist/metaTxns.js +4 -0
  51. package/dist/paymasterSend.d.ts +90 -0
  52. package/dist/paymasterSend.d.ts.map +1 -0
  53. package/dist/paymasterSend.js +329 -0
  54. package/dist/preconditions.d.ts +11 -0
  55. package/dist/preconditions.d.ts.map +1 -0
  56. package/dist/preconditions.js +29 -0
  57. package/dist/prepareSend.d.ts +102 -0
  58. package/dist/prepareSend.d.ts.map +1 -0
  59. package/dist/prepareSend.js +1080 -0
  60. package/dist/prices.d.ts +18 -0
  61. package/dist/prices.d.ts.map +1 -0
  62. package/dist/prices.js +142 -0
  63. package/dist/queryParams.d.ts +9 -0
  64. package/dist/queryParams.d.ts.map +1 -0
  65. package/dist/queryParams.js +66 -0
  66. package/dist/relaySdk.d.ts +65 -0
  67. package/dist/relaySdk.d.ts.map +1 -0
  68. package/dist/relaySdk.js +314 -0
  69. package/dist/relayer.d.ts +23 -0
  70. package/dist/relayer.d.ts.map +1 -0
  71. package/dist/relayer.js +230 -0
  72. package/dist/sendUserOp.d.ts +140 -0
  73. package/dist/sendUserOp.d.ts.map +1 -0
  74. package/dist/sendUserOp.js +388 -0
  75. package/dist/sequenceWallet.d.ts +79 -0
  76. package/dist/sequenceWallet.d.ts.map +1 -0
  77. package/dist/sequenceWallet.js +374 -0
  78. package/dist/theme.d.ts +3 -0
  79. package/dist/theme.d.ts.map +1 -0
  80. package/dist/theme.js +1 -0
  81. package/dist/toSimpleSmartAccount.d.ts +95 -0
  82. package/dist/toSimpleSmartAccount.d.ts.map +1 -0
  83. package/dist/toSimpleSmartAccount.js +373 -0
  84. package/dist/tokenBalances.d.ts +118 -0
  85. package/dist/tokenBalances.d.ts.map +1 -0
  86. package/dist/tokenBalances.js +492 -0
  87. package/dist/tokens.d.ts +50 -0
  88. package/dist/tokens.d.ts.map +1 -0
  89. package/dist/tokens.js +356 -0
  90. package/dist/trails.d.ts +128 -0
  91. package/dist/trails.d.ts.map +1 -0
  92. package/dist/trails.js +1031 -0
  93. package/dist/umd/trails.min.js +12610 -0
  94. package/dist/umd/trails.min.js.map +1 -0
  95. package/dist/umd.d.ts +24 -0
  96. package/dist/umd.d.ts.map +1 -0
  97. package/dist/utils.d.ts +5 -0
  98. package/dist/utils.d.ts.map +1 -0
  99. package/dist/utils.js +9 -0
  100. package/dist/widget/ConstantsUtil-B-_-u8aQ.js +6 -0
  101. package/dist/widget/add-hVLs3ldJ.js +20 -0
  102. package/dist/widget/all-wallets-Cwxnx4BT.js +11 -0
  103. package/dist/widget/app-store-CAAVQjW0.js +22 -0
  104. package/dist/widget/apple-C3BSbglw.js +23 -0
  105. package/dist/widget/arrow-bottom-circle-BGU9MmsZ.js +16 -0
  106. package/dist/widget/arrow-bottom-hS_SA8Gp.js +13 -0
  107. package/dist/widget/arrow-left-CJZanWz7.js +13 -0
  108. package/dist/widget/arrow-right-C1qL8EMd.js +13 -0
  109. package/dist/widget/arrow-top-CbuCmbQs.js +13 -0
  110. package/dist/widget/bank-CXBEEGbb.js +19 -0
  111. package/dist/widget/bin-Dqzv3zCZ.js +9 -0
  112. package/dist/widget/bitcoin-4y3sovZp.js +18 -0
  113. package/dist/widget/browser-DyOl4_8m.js +1413 -0
  114. package/dist/widget/browser-t7Fh0sEU.js +19 -0
  115. package/dist/widget/card-Bo4CZkTs.js +19 -0
  116. package/dist/widget/ccip-BynehMIN.js +232 -0
  117. package/dist/widget/checkmark-DV6OKvnY.js +16 -0
  118. package/dist/widget/checkmark-bold-CAp1-IQ2.js +13 -0
  119. package/dist/widget/chevron-bottom-BjzsVzk9.js +13 -0
  120. package/dist/widget/chevron-left-CQZBDCiR.js +13 -0
  121. package/dist/widget/chevron-right-Dhg4zeZM.js +13 -0
  122. package/dist/widget/chevron-top-CDQmfJef.js +13 -0
  123. package/dist/widget/chrome-store-BNaC_b6w.js +66 -0
  124. package/dist/widget/circle-BC_GBj91.js +9 -0
  125. package/dist/widget/clock-BmF8-4a0.js +13 -0
  126. package/dist/widget/close-Bf61nZ8o.js +13 -0
  127. package/dist/widget/coinPlaceholder-7cZW2058.js +13 -0
  128. package/dist/widget/compass-CFC3yhnW.js +13 -0
  129. package/dist/widget/components/ChainImage.d.ts +8 -0
  130. package/dist/widget/components/ChainImage.d.ts.map +1 -0
  131. package/dist/widget/components/ChainImage.js +6 -0
  132. package/dist/widget/components/ConnectWallet.d.ts +18 -0
  133. package/dist/widget/components/ConnectWallet.d.ts.map +1 -0
  134. package/dist/widget/components/ConnectWallet.js +66 -0
  135. package/dist/widget/components/DebugScreensDropdown.d.ts +9 -0
  136. package/dist/widget/components/DebugScreensDropdown.d.ts.map +1 -0
  137. package/dist/widget/components/DebugScreensDropdown.js +40 -0
  138. package/dist/widget/components/FeeOptions.d.ts +17 -0
  139. package/dist/widget/components/FeeOptions.d.ts.map +1 -0
  140. package/dist/widget/components/FeeOptions.js +65 -0
  141. package/dist/widget/components/Footer.d.ts +9 -0
  142. package/dist/widget/components/Footer.d.ts.map +1 -0
  143. package/dist/widget/components/Footer.js +13 -0
  144. package/dist/widget/components/GreenCheckAnimation.d.ts +2 -0
  145. package/dist/widget/components/GreenCheckAnimation.d.ts.map +1 -0
  146. package/dist/widget/components/GreenCheckAnimation.js +74 -0
  147. package/dist/widget/components/Modal.d.ts +11 -0
  148. package/dist/widget/components/Modal.d.ts.map +1 -0
  149. package/dist/widget/components/Modal.js +36 -0
  150. package/dist/widget/components/Receipt.d.ts +13 -0
  151. package/dist/widget/components/Receipt.d.ts.map +1 -0
  152. package/dist/widget/components/Receipt.js +36 -0
  153. package/dist/widget/components/SendForm.d.ts +44 -0
  154. package/dist/widget/components/SendForm.d.ts.map +1 -0
  155. package/dist/widget/components/SendForm.js +177 -0
  156. package/dist/widget/components/TokenImage.d.ts +10 -0
  157. package/dist/widget/components/TokenImage.d.ts.map +1 -0
  158. package/dist/widget/components/TokenImage.js +8 -0
  159. package/dist/widget/components/TokenList.d.ts +16 -0
  160. package/dist/widget/components/TokenList.d.ts.map +1 -0
  161. package/dist/widget/components/TokenList.js +39 -0
  162. package/dist/widget/components/TransferPending.d.ts +11 -0
  163. package/dist/widget/components/TransferPending.d.ts.map +1 -0
  164. package/dist/widget/components/TransferPending.js +77 -0
  165. package/dist/widget/components/TransferPendingVertical.d.ts +18 -0
  166. package/dist/widget/components/TransferPendingVertical.d.ts.map +1 -0
  167. package/dist/widget/components/TransferPendingVertical.js +183 -0
  168. package/dist/widget/components/WalletConfirmation.d.ts +18 -0
  169. package/dist/widget/components/WalletConfirmation.d.ts.map +1 -0
  170. package/dist/widget/components/WalletConfirmation.js +22 -0
  171. package/dist/widget/config.d.ts +4 -0
  172. package/dist/widget/config.d.ts.map +1 -0
  173. package/dist/widget/config.js +3 -0
  174. package/dist/widget/copy-e0xXvKN0.js +20 -0
  175. package/dist/widget/cursor-CqM3v0xJ.js +8 -0
  176. package/dist/widget/cursor-transparent-CUQpdsCG.js +17 -0
  177. package/dist/widget/desktop-DUDGIRpM.js +14 -0
  178. package/dist/widget/disconnect-DUFST9QQ.js +13 -0
  179. package/dist/widget/discord-C1cj365Z.js +22 -0
  180. package/dist/widget/email-BHhmb_lX.js +703 -0
  181. package/dist/widget/embedded-wallet-CuuC4eah.js +467 -0
  182. package/dist/widget/ethereum-CfmBVfeB.js +15 -0
  183. package/dist/widget/etherscan-BSiynDhW.js +11 -0
  184. package/dist/widget/exclamation-triangle-DEiFNpHw.js +9 -0
  185. package/dist/widget/extension-mRmfCDxo.js +13 -0
  186. package/dist/widget/external-link-B4xMIVnW.js +13 -0
  187. package/dist/widget/facebook-CBAZStBR.js +31 -0
  188. package/dist/widget/farcaster-LHDEDf5S.js +17 -0
  189. package/dist/widget/filters-CBijuvFv.js +13 -0
  190. package/dist/widget/github-C3ILD420.js +23 -0
  191. package/dist/widget/google-CSj73POX.js +23 -0
  192. package/dist/widget/help-circle-2hdG5IdB.js +17 -0
  193. package/dist/widget/hooks/useAmountUsd.d.ts +13 -0
  194. package/dist/widget/hooks/useAmountUsd.d.ts.map +1 -0
  195. package/dist/widget/hooks/useAmountUsd.js +35 -0
  196. package/dist/widget/hooks/useSendForm.d.ts +125 -0
  197. package/dist/widget/hooks/useSendForm.d.ts.map +1 -0
  198. package/dist/widget/hooks/useSendForm.js +450 -0
  199. package/dist/widget/hooks/useTokenList.d.ts +52 -0
  200. package/dist/widget/hooks/useTokenList.d.ts.map +1 -0
  201. package/dist/widget/hooks/useTokenList.js +252 -0
  202. package/dist/widget/id-ByYSrwsd.js +17 -0
  203. package/dist/widget/if-defined-DRXJEhv7.js +752 -0
  204. package/dist/widget/image-C90L4Rf6.js +9 -0
  205. package/dist/widget/index-B3SlQ9v3.js +46 -0
  206. package/dist/widget/index-B8LPuLXQ.js +78 -0
  207. package/dist/widget/index-BDbworWA.js +171 -0
  208. package/dist/widget/index-BTlDgFSK.js +98 -0
  209. package/dist/widget/index-BUCcjXbd.js +306 -0
  210. package/dist/widget/index-BZ34edi2.js +1055 -0
  211. package/dist/widget/index-BiCU29wK.js +147 -0
  212. package/dist/widget/index-BlmqIKsY.js +266 -0
  213. package/dist/widget/index-BlviH5nG.js +55 -0
  214. package/dist/widget/index-Bwd5X3fS.js +8306 -0
  215. package/dist/widget/index-C5gmknHK.js +78 -0
  216. package/dist/widget/index-CD6dBcRj.js +76 -0
  217. package/dist/widget/index-CDlhy529.js +63 -0
  218. package/dist/widget/index-CHXa5ke-.js +59 -0
  219. package/dist/widget/index-CK94R-H7.js +22498 -0
  220. package/dist/widget/index-CQzo3m3x.js +182 -0
  221. package/dist/widget/index-CRT8cAwG.js +325 -0
  222. package/dist/widget/index-CY7Lt2Yu.js +310 -0
  223. package/dist/widget/index-CiKfAu1E.js +79 -0
  224. package/dist/widget/index-CkCu6rMi.js +258 -0
  225. package/dist/widget/index-CngLTu_R.js +517 -0
  226. package/dist/widget/index-CsMV8-em.js +2577 -0
  227. package/dist/widget/index-Cu2Wva8v.js +200 -0
  228. package/dist/widget/index-DKBxLTEF.js +240 -0
  229. package/dist/widget/index-DQEVT3dx.js +511 -0
  230. package/dist/widget/index-DU2HcCis.js +200 -0
  231. package/dist/widget/index-DutZGWNW.js +321 -0
  232. package/dist/widget/index-O0glArmc.js +182 -0
  233. package/dist/widget/index-O8FmRjKe.js +63719 -0
  234. package/dist/widget/index-RtKXrB6I.js +576 -0
  235. package/dist/widget/index-TIYtS0gE.js +88 -0
  236. package/dist/widget/index-dQNJvWHs.js +66 -0
  237. package/dist/widget/index-wmEwdsq7.js +909 -0
  238. package/dist/widget/index.d.ts +3 -0
  239. package/dist/widget/index.d.ts.map +1 -0
  240. package/dist/widget/index.js +2 -0
  241. package/dist/widget/info-DMPChDjV.js +8 -0
  242. package/dist/widget/info-circle-DAvS_7nY.js +17 -0
  243. package/dist/widget/lightbulb-DnZ9mNEs.js +8 -0
  244. package/dist/widget/lit-html-BRjl1r6K.js +243 -0
  245. package/dist/widget/mail-DpaVSOP8.js +13 -0
  246. package/dist/widget/mobile-CRvdyu7I.js +14 -0
  247. package/dist/widget/more-C5VqW9PR.js +16 -0
  248. package/dist/widget/network-placeholder-CZ0vApma.js +19 -0
  249. package/dist/widget/nftPlaceholder-7jjIK2bT.js +13 -0
  250. package/dist/widget/off-4mHjJLLX.js +9 -0
  251. package/dist/widget/onramp-Bc0ozVsw.js +929 -0
  252. package/dist/widget/play-store-Uocul8nC.js +37 -0
  253. package/dist/widget/plus-DrYF7siO.js +18 -0
  254. package/dist/widget/prepareSend-BQJmzM5B.js +54987 -0
  255. package/dist/widget/qr-code-DcnGMUB3.js +11 -0
  256. package/dist/widget/receive-fvIVd7R_.js +184 -0
  257. package/dist/widget/recycle-horizontal-DrDwXC4D.js +14 -0
  258. package/dist/widget/ref-CXNmEjML.js +41 -0
  259. package/dist/widget/refresh-OK9lIPLS.js +13 -0
  260. package/dist/widget/reown-logo-C-Qn7mS3.js +17 -0
  261. package/dist/widget/search-DZqv1oKg.js +13 -0
  262. package/dist/widget/send-CJlmI-xe.js +1039 -0
  263. package/dist/widget/send-otoEC8uU.js +20 -0
  264. package/dist/widget/socials-BJciurWF.js +599 -0
  265. package/dist/widget/solana-Bv5Hs_0T.js +18 -0
  266. package/dist/widget/swapHorizontal-BzOPGV37.js +13 -0
  267. package/dist/widget/swapHorizontalBold-axyHnSmj.js +13 -0
  268. package/dist/widget/swapHorizontalMedium-C6YOPfPz.js +21 -0
  269. package/dist/widget/swapHorizontalRoundedBold-yVcLbWNT.js +13 -0
  270. package/dist/widget/swapVertical-BDjxt9pE.js +13 -0
  271. package/dist/widget/swaps-DEWNj4kd.js +1637 -0
  272. package/dist/widget/telegram-BQJD7dlP.js +21 -0
  273. package/dist/widget/three-dots-DW9jmSMG.js +10 -0
  274. package/dist/widget/transactions-uCseGQQt.js +38 -0
  275. package/dist/widget/twitch-XugxDfOE.js +23 -0
  276. package/dist/widget/twitterIcon-DQVObQUL.js +11 -0
  277. package/dist/widget/types.d.ts +51 -0
  278. package/dist/widget/types.d.ts.map +1 -0
  279. package/dist/widget/types.js +1 -0
  280. package/dist/widget/verify-DpMYHxLf.js +13 -0
  281. package/dist/widget/verify-filled-KpEL6ZJ_.js +13 -0
  282. package/dist/widget/w3m-modal-C8e-6Kba.js +1047 -0
  283. package/dist/widget/wallet-D8ssEB0o.js +13 -0
  284. package/dist/widget/wallet-placeholder-HtAy21Wc.js +19 -0
  285. package/dist/widget/walletconnect-Bp_4XfrY.js +37 -0
  286. package/dist/widget/warning-circle-FgYS7P7n.js +17 -0
  287. package/dist/widget/widget/index.js +7 -0
  288. package/dist/widget/widget.d.ts +47 -0
  289. package/dist/widget/widget.d.ts.map +1 -0
  290. package/dist/widget/widget.js +932 -0
  291. package/dist/widget/x-DlZBoP9k.js +17 -0
  292. package/dist/widget/x-mark-Ba9pt-_h.js +8 -0
  293. package/package.json +102 -8
  294. package/src/abi.ts +38 -0
  295. package/src/apiClient.ts +32 -0
  296. package/src/buffer.ts +10 -0
  297. package/src/cctp.ts +579 -0
  298. package/src/chainSwitch.ts +55 -0
  299. package/src/chains.ts +124 -0
  300. package/src/constants.ts +26 -0
  301. package/src/encoders.ts +20 -0
  302. package/src/error.ts +15 -0
  303. package/src/explorer.ts +37 -0
  304. package/src/gasless.ts +545 -0
  305. package/src/index.ts +48 -0
  306. package/src/indexerClient.ts +36 -0
  307. package/src/intents.ts +537 -0
  308. package/src/metaTxnMonitor.ts +163 -0
  309. package/src/metaTxns.ts +21 -0
  310. package/src/paymasterSend.ts +503 -0
  311. package/src/preconditions.ts +52 -0
  312. package/src/prepareSend.ts +1849 -0
  313. package/src/prices.ts +186 -0
  314. package/src/queryParams.ts +80 -0
  315. package/src/relaySdk.ts +481 -0
  316. package/src/relayer.ts +255 -0
  317. package/src/sendUserOp.ts +570 -0
  318. package/src/sequenceWallet.ts +579 -0
  319. package/src/theme.ts +2 -0
  320. package/src/toSimpleSmartAccount.ts +567 -0
  321. package/src/tokenBalances.ts +760 -0
  322. package/src/tokens.ts +471 -0
  323. package/src/trails.ts +1591 -0
  324. package/src/types.d.ts +11 -0
  325. package/src/umd.tsx +49 -0
  326. package/src/utils.ts +16 -0
  327. package/src/vite-env.d.ts +4 -0
  328. package/src/widget/assets/MetaMask-icon-fox-with-margins.svg +31 -0
  329. package/src/widget/assets/MetaMask-icon-fox.svg +26 -0
  330. package/src/widget/assets/MetaMask-logo-black.svg +3 -0
  331. package/src/widget/assets/MetaMask-logo-white.svg +16 -0
  332. package/src/widget/assets/Privy_Brandmark_Black.svg +9 -0
  333. package/src/widget/assets/Privy_Brandmark_White.svg +9 -0
  334. package/src/widget/assets/Trails-logo-black.svg +11 -0
  335. package/src/widget/assets/Trails-logo-white.svg +11 -0
  336. package/src/widget/components/ChainImage.tsx +28 -0
  337. package/src/widget/components/ConnectWallet.tsx +206 -0
  338. package/src/widget/components/DebugScreensDropdown.tsx +88 -0
  339. package/src/widget/components/FeeOptions.tsx +199 -0
  340. package/src/widget/components/Footer.tsx +51 -0
  341. package/src/widget/components/GreenCheckAnimation.tsx +119 -0
  342. package/src/widget/components/Modal.tsx +97 -0
  343. package/src/widget/components/Receipt.tsx +237 -0
  344. package/src/widget/components/SendForm.tsx +695 -0
  345. package/src/widget/components/TokenImage.tsx +37 -0
  346. package/src/widget/components/TokenList.tsx +287 -0
  347. package/src/widget/components/TransferPending.tsx +204 -0
  348. package/src/widget/components/TransferPendingVertical.tsx +412 -0
  349. package/src/widget/components/WalletConfirmation.tsx +172 -0
  350. package/src/widget/config.ts +5 -0
  351. package/src/widget/hooks/useAmountUsd.ts +59 -0
  352. package/src/widget/hooks/useSendForm.ts +715 -0
  353. package/src/widget/hooks/useTokenList.ts +397 -0
  354. package/src/widget/index.css +2 -0
  355. package/src/widget/index.tsx +8 -0
  356. package/src/widget/types/svg.d.ts +8 -0
  357. package/src/widget/types.ts +59 -0
  358. package/src/widget/widget.tsx +1438 -0
  359. package/index.js +0 -1
@@ -0,0 +1,13 @@
1
+ import type { SequenceAPIClient } from "@0xsequence/trails-api";
2
+ type UseAmountUsdProps = {
3
+ amount?: string | null;
4
+ token?: string | null;
5
+ chainId?: number | null;
6
+ apiClient: SequenceAPIClient;
7
+ };
8
+ export declare function useAmountUsd({ amount, token, chainId, apiClient, }: UseAmountUsdProps): {
9
+ amountUsd: number | null;
10
+ amountUsdFormatted: string;
11
+ };
12
+ export {};
13
+ //# sourceMappingURL=useAmountUsd.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAmountUsd.d.ts","sourceRoot":"","sources":["../../../src/widget/hooks/useAmountUsd.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAA;AAM/D,KAAK,iBAAiB,GAAG;IACvB,MAAM,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,SAAS,EAAE,iBAAiB,CAAA;CAC7B,CAAA;AAED,wBAAgB,YAAY,CAAC,EAC3B,MAAM,EACN,KAAK,EACL,OAAO,EACP,SAAS,GACV,EAAE,iBAAiB,GAAG;IACrB,SAAS,EAAE,MAAM,GAAG,IAAI,CAAA;IACxB,kBAAkB,EAAE,MAAM,CAAA;CAC3B,CAqCA"}
@@ -0,0 +1,35 @@
1
+ import { useQuery } from "@tanstack/react-query";
2
+ import { useTokenPrice } from "../../prices.js";
3
+ import { formatUsdValue } from "../../tokenBalances.js";
4
+ import { useTokenAddress } from "../../tokens.js";
5
+ export function useAmountUsd({ amount, token, chainId, apiClient, }) {
6
+ const isTokenAddress = token?.startsWith("0x");
7
+ const resolvedTokenAddress = useTokenAddress({
8
+ chainId,
9
+ tokenSymbol: isTokenAddress ? undefined : token,
10
+ });
11
+ const tokenAddress = isTokenAddress ? token : resolvedTokenAddress;
12
+ const { tokenPrice } = useTokenPrice(token && tokenAddress && chainId
13
+ ? {
14
+ tokenId: token,
15
+ contractAddress: tokenAddress,
16
+ chainId: Number(chainId),
17
+ }
18
+ : null, apiClient);
19
+ const { data: amountUsd } = useQuery({
20
+ queryKey: ["amountUsd", amount, tokenPrice?.price?.value],
21
+ queryFn: () => {
22
+ if (!amount || !tokenPrice?.price?.value) {
23
+ return null;
24
+ }
25
+ const tokenPriceValue = tokenPrice.price.value;
26
+ const value = Number(amount) * tokenPriceValue;
27
+ return value;
28
+ },
29
+ enabled: !!amount && !!tokenPrice?.price?.value,
30
+ });
31
+ return {
32
+ amountUsd: amountUsd || null,
33
+ amountUsdFormatted: formatUsdValue(amountUsd || 0),
34
+ };
35
+ }
@@ -0,0 +1,125 @@
1
+ import type { TokenPrice } from "@0xsequence/trails-api";
2
+ import type { MetaTxnReceipt } from "@0xsequence/trails-relayer";
3
+ import type React from "react";
4
+ import { type Account, type TransactionReceipt, type WalletClient } from "viem";
5
+ import { type TransactionState } from "../../prepareSend.js";
6
+ import { type RelayerEnv } from "../../relayer.js";
7
+ import type { Theme } from "../../theme.js";
8
+ import type { SupportedToken } from "../../tokens.js";
9
+ export interface Token {
10
+ id: number;
11
+ name: string;
12
+ symbol: string;
13
+ balance: string;
14
+ imageUrl: string;
15
+ chainId: number;
16
+ contractAddress: string;
17
+ tokenPriceUsd?: number;
18
+ balanceUsdFormatted?: string;
19
+ contractInfo?: {
20
+ decimals: number;
21
+ symbol: string;
22
+ name: string;
23
+ };
24
+ }
25
+ export type TokenInfo = {
26
+ symbol: string;
27
+ name: string;
28
+ imageUrl: string;
29
+ decimals: number;
30
+ };
31
+ type ChainInfo = {
32
+ id: number;
33
+ name: string;
34
+ imageUrl?: string;
35
+ };
36
+ type PaymasterUrl = {
37
+ chainId: number;
38
+ url: string;
39
+ };
40
+ export type OnCompleteProps = {
41
+ originChainId: number;
42
+ destinationChainId: number;
43
+ originUserTxReceipt: TransactionReceipt | null;
44
+ originMetaTxnReceipt: MetaTxnReceipt | null;
45
+ destinationMetaTxnReceipt: MetaTxnReceipt | null;
46
+ };
47
+ export type UseSendProps = {
48
+ account: Account;
49
+ sequenceProjectAccessKey: string;
50
+ apiUrl?: string;
51
+ env?: RelayerEnv;
52
+ toAmount?: string;
53
+ toRecipient?: string;
54
+ toChainId?: number;
55
+ toToken?: string;
56
+ toCalldata?: string;
57
+ walletClient: WalletClient;
58
+ theme: Theme;
59
+ onTransactionStateChange: (transactionStates: TransactionState[]) => void;
60
+ useSourceTokenForButtonText: boolean;
61
+ onError: (error: Error | string | null) => void;
62
+ onWaitingForWalletConfirm: (intentAddress: string, details: {
63
+ amount: string;
64
+ amountUsd: string;
65
+ tokenSymbol: string;
66
+ tokenName: string;
67
+ chainId: number;
68
+ imageUrl: string;
69
+ }) => void;
70
+ paymasterUrls?: PaymasterUrl[];
71
+ gasless?: boolean;
72
+ onSend: (amount: string, recipient: string) => void;
73
+ onConfirm: () => void;
74
+ onComplete: (result: OnCompleteProps) => void;
75
+ selectedToken: Token;
76
+ setWalletConfirmRetryHandler: (handler: () => Promise<void>) => void;
77
+ };
78
+ export type UseSendReturn = {
79
+ amount: string;
80
+ amountUsdFormatted: string;
81
+ balanceUsdFormatted: string;
82
+ chainInfo: ChainInfo | null;
83
+ error: string | null;
84
+ toChainId: number | undefined;
85
+ balanceFormatted: string;
86
+ handleRecipientInputChange: (e: React.ChangeEvent<HTMLInputElement>) => void;
87
+ handleSubmit: (e: React.FormEvent) => Promise<void>;
88
+ isChainDropdownOpen: boolean;
89
+ isSubmitting: boolean;
90
+ isTokenDropdownOpen: boolean;
91
+ recipient: string;
92
+ recipientInput: string;
93
+ selectedDestinationChain: ChainInfo | null;
94
+ selectedDestToken: TokenInfo;
95
+ setAmount: (amount: string) => void;
96
+ setRecipient: (recipient: string) => void;
97
+ setRecipientInput: (recipientInput: string) => void;
98
+ setSelectedDestinationChain: (chain: ChainInfo) => void;
99
+ setSelectedDestToken: (token: TokenInfo) => void;
100
+ setSelectedFeeToken: (token: TokenInfo) => void;
101
+ FEE_TOKENS: TokenInfo[];
102
+ supportedTokens: SupportedToken[];
103
+ supportedChains: ChainInfo[];
104
+ ensAddress: string | null;
105
+ isWaitingForWalletConfirm: boolean;
106
+ buttonText: string;
107
+ isValidRecipient: boolean;
108
+ useSourceTokenForButtonText: boolean;
109
+ destTokenPrices: TokenPrice[] | null;
110
+ selectedToken: Token;
111
+ selectedFeeToken: TokenInfo | null;
112
+ setIsChainDropdownOpen: (isOpen: boolean) => void;
113
+ setIsTokenDropdownOpen: (isOpen: boolean) => void;
114
+ toAmountFormatted: string;
115
+ destinationTokenAddress: string | null;
116
+ isValidCustomToken: boolean;
117
+ };
118
+ export declare function useSendForm({ account, sequenceProjectAccessKey, apiUrl, env, toAmount, // Custom specified amount
119
+ toRecipient, // Custom specified recipient
120
+ toChainId, // Custom specified destination chain id
121
+ toToken, // Custom specified destination token address or symbol
122
+ toCalldata, // Custom specified destination calldata
123
+ walletClient, onTransactionStateChange, useSourceTokenForButtonText, onError, onWaitingForWalletConfirm, paymasterUrls, gasless, selectedToken, onSend, onConfirm, onComplete, setWalletConfirmRetryHandler, }: UseSendProps): UseSendReturn;
124
+ export {};
125
+ //# sourceMappingURL=useSendForm.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useSendForm.d.ts","sourceRoot":"","sources":["../../../src/widget/hooks/useSendForm.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,450 @@
1
+ import { useCallback, useEffect, useMemo, useState } from "react";
2
+ import { formatUnits, getAddress, isAddress, parseUnits, } from "viem";
3
+ import { mainnet } from "viem/chains";
4
+ import { useEnsAddress } from "wagmi";
5
+ import { useAPIClient } from "../../apiClient.js";
6
+ import { getChainInfo, useSupportedChains } from "../../chains.js";
7
+ import { getFullErrorMessage } from "../../error.js";
8
+ import { prepareSend } from "../../prepareSend.js";
9
+ import { useTokenPrices } from "../../prices.js";
10
+ import { useQueryParams } from "../../queryParams.js";
11
+ import { getRelayer } from "../../relayer.js";
12
+ import { formatBalance, formatUsdValue, formatValue, } from "../../tokenBalances.js";
13
+ import { useSupportedTokens, useTokenAddress, useTokenInfo, } from "../../tokens.js";
14
+ import { DEFAULT_USE_V3_RELAYERS } from "../../constants.js";
15
+ // Add FEE_TOKENS constant after SUPPORTED_TOKENS
16
+ const FEE_TOKENS = [
17
+ {
18
+ symbol: "ETH",
19
+ name: "Ethereum",
20
+ imageUrl: `https://assets.sequence.info/images/tokens/large/1/0x0000000000000000000000000000000000000000.webp`,
21
+ decimals: 18,
22
+ },
23
+ {
24
+ symbol: "USDC",
25
+ name: "USD Coin",
26
+ imageUrl: `https://assets.sequence.info/images/tokens/large/1/0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48.webp`,
27
+ decimals: 6,
28
+ },
29
+ ];
30
+ export function useSendForm({ account, sequenceProjectAccessKey, apiUrl, env, toAmount, // Custom specified amount
31
+ toRecipient, // Custom specified recipient
32
+ toChainId, // Custom specified destination chain id
33
+ toToken, // Custom specified destination token address or symbol
34
+ toCalldata, // Custom specified destination calldata
35
+ walletClient, onTransactionStateChange, useSourceTokenForButtonText, onError, onWaitingForWalletConfirm, paymasterUrls, gasless, selectedToken, onSend, onConfirm, onComplete, setWalletConfirmRetryHandler, }) {
36
+ const [amount, setAmount] = useState(toAmount ?? "");
37
+ const [recipientInput, setRecipientInput] = useState(toRecipient ?? "");
38
+ const [recipient, setRecipient] = useState(toRecipient ?? "");
39
+ const [error, setError] = useState(null);
40
+ const { supportedChains } = useSupportedChains();
41
+ const { data: ensAddress } = useEnsAddress({
42
+ name: recipientInput?.endsWith(".eth") ? recipientInput : undefined,
43
+ chainId: mainnet.id,
44
+ query: {
45
+ enabled: !!recipientInput && recipientInput.endsWith(".eth"),
46
+ },
47
+ });
48
+ useEffect(() => {
49
+ if (ensAddress) {
50
+ setRecipient(ensAddress);
51
+ }
52
+ else {
53
+ setRecipient(recipientInput);
54
+ }
55
+ }, [ensAddress, recipientInput]);
56
+ useEffect(() => {
57
+ if (onError) {
58
+ onError(error);
59
+ }
60
+ }, [error, onError]);
61
+ const handleRecipientInputChange = (e) => {
62
+ setRecipientInput(e.target.value.trim());
63
+ };
64
+ const [selectedDestinationChain, setSelectedDestinationChain] = useState(() => {
65
+ const chain = supportedChains.find((chain) => chain.id === toChainId);
66
+ if (chain) {
67
+ return chain;
68
+ }
69
+ return supportedChains[0];
70
+ });
71
+ const { supportedTokens } = useSupportedTokens({
72
+ chainId: selectedDestinationChain?.id,
73
+ });
74
+ const isCustomToken = useMemo(() => toToken?.startsWith("0x"), [toToken]);
75
+ const { tokenInfo: customTokenInfo, isLoading: isLoadingCustomToken, error: errorCustomToken, } = useTokenInfo({
76
+ address: isCustomToken ? toToken : "",
77
+ chainId: toChainId,
78
+ });
79
+ const isValidCustomToken = useMemo(() => {
80
+ if (!isCustomToken) {
81
+ return true;
82
+ }
83
+ return Boolean(isCustomToken &&
84
+ !errorCustomToken &&
85
+ !isLoadingCustomToken &&
86
+ !!customTokenInfo);
87
+ }, [isCustomToken, errorCustomToken, isLoadingCustomToken, customTokenInfo]);
88
+ useEffect(() => {
89
+ if (isCustomToken && customTokenInfo && !isLoadingCustomToken) {
90
+ setSelectedDestToken(customTokenInfo);
91
+ }
92
+ }, [customTokenInfo, isCustomToken, isLoadingCustomToken]);
93
+ useEffect(() => {
94
+ if (isCustomToken && errorCustomToken && !isLoadingCustomToken) {
95
+ console.error("[trails-sdk] errorCustomToken", errorCustomToken);
96
+ setError(`Invalid custom toToken address. Error: ${errorCustomToken.message}`);
97
+ }
98
+ }, [errorCustomToken, isCustomToken, isLoadingCustomToken]);
99
+ const defaultDestToken = useMemo(() => {
100
+ if (selectedDestinationChain) {
101
+ return supportedTokens.find((token) => token.chainId === selectedDestinationChain.id);
102
+ }
103
+ return supportedTokens?.[0];
104
+ }, [supportedTokens, selectedDestinationChain]);
105
+ const [isChainDropdownOpen, setIsChainDropdownOpen] = useState(false);
106
+ const [isTokenDropdownOpen, setIsTokenDropdownOpen] = useState(false);
107
+ const [selectedDestToken, setSelectedDestToken] = useState(() => {
108
+ let token = defaultDestToken;
109
+ if (toToken && !isCustomToken) {
110
+ const isToTokenAddress = isAddress(toToken);
111
+ token = supportedTokens.find((token) => (isToTokenAddress // Match by specified destination token address or symbol
112
+ ? token.contractAddress === toToken
113
+ : token.symbol === toToken) &&
114
+ (toChainId // Match by specified destination chain id
115
+ ? token.chainId === toChainId
116
+ : selectedDestinationChain.id));
117
+ }
118
+ return token;
119
+ });
120
+ useEffect(() => {
121
+ if (!selectedDestToken && defaultDestToken) {
122
+ setSelectedDestToken(defaultDestToken);
123
+ }
124
+ }, [selectedDestToken, defaultDestToken]);
125
+ const apiClient = useAPIClient({
126
+ apiUrl,
127
+ projectAccessKey: sequenceProjectAccessKey,
128
+ });
129
+ const destTokenAddress = useTokenAddress({
130
+ chainId: selectedDestinationChain?.id,
131
+ tokenSymbol: selectedDestToken?.symbol,
132
+ });
133
+ const { tokenPrices: destTokenPrices } = useTokenPrices(selectedDestToken && destTokenAddress
134
+ ? [
135
+ {
136
+ tokenId: selectedDestToken.symbol,
137
+ contractAddress: destTokenAddress,
138
+ chainId: selectedDestinationChain.id,
139
+ },
140
+ ]
141
+ : [], apiClient);
142
+ // Update selectedChain when toChainId prop changes
143
+ useEffect(() => {
144
+ if (toChainId) {
145
+ const newChain = supportedChains.find((chain) => chain.id === toChainId);
146
+ if (newChain) {
147
+ setSelectedDestinationChain(newChain);
148
+ }
149
+ }
150
+ }, [toChainId, supportedChains]);
151
+ // Update selectedDestToken when toToken prop changes
152
+ useEffect(() => {
153
+ if (toToken && !isCustomToken) {
154
+ const isToTokenAddress = isAddress(toToken);
155
+ const newToken = supportedTokens.find((token) => (isToTokenAddress // Match by specified destination token address or symbol
156
+ ? token.contractAddress === toToken
157
+ : token.symbol === toToken) &&
158
+ (toChainId // Match by specified destination chain id
159
+ ? token.chainId === toChainId
160
+ : token.chainId === selectedDestinationChain.id));
161
+ if (newToken) {
162
+ setSelectedDestToken(newToken);
163
+ }
164
+ }
165
+ }, [
166
+ toToken,
167
+ supportedTokens,
168
+ toChainId,
169
+ selectedDestinationChain.id,
170
+ isCustomToken,
171
+ ]);
172
+ // Update amount when toAmount prop changes
173
+ useEffect(() => {
174
+ setAmount(toAmount ?? "");
175
+ }, [toAmount]);
176
+ const toAmountFormatted = useMemo(() => {
177
+ return formatValue(toAmount || 0);
178
+ }, [toAmount]);
179
+ // Update recipient when toRecipient prop changes
180
+ useEffect(() => {
181
+ setRecipientInput(toRecipient ?? "");
182
+ setRecipient(toRecipient ?? "");
183
+ }, [toRecipient]);
184
+ const chainInfo = getChainInfo(selectedToken.chainId);
185
+ const [isSubmitting, setIsSubmitting] = useState(false);
186
+ const [isWaitingForWalletConfirm, setIsWaitingForWalletConfirm] = useState(false);
187
+ const balanceFormatted = formatBalance(selectedToken.balance, selectedToken.contractInfo?.decimals);
188
+ const balanceUsdFormatted = selectedToken.balanceUsdFormatted ?? "";
189
+ const relayerConfig = useMemo(() => ({ env, useV3Relayers: DEFAULT_USE_V3_RELAYERS }), [env]);
190
+ const isValidRecipient = Boolean(recipient && isAddress(recipient));
191
+ // Calculate USD value
192
+ const amountUsdFormatted = useMemo(() => {
193
+ const amountUsd = Number(amount) * (destTokenPrices?.[0]?.price?.value ?? 0);
194
+ return formatUsdValue(amountUsd);
195
+ }, [amount, destTokenPrices]);
196
+ const [selectedFeeToken, setSelectedFeeToken] = useState(null);
197
+ const { hasParam } = useQueryParams();
198
+ const isDryMode = hasParam("dryMode", "true");
199
+ const destinationTokenAddressFromTokenSymbol = useTokenAddress({
200
+ chainId: selectedDestinationChain?.id,
201
+ tokenSymbol: selectedDestToken?.symbol,
202
+ });
203
+ const destinationTokenAddress = useMemo(() => {
204
+ if (isCustomToken) {
205
+ return toToken ?? null;
206
+ }
207
+ return destinationTokenAddressFromTokenSymbol ?? null;
208
+ }, [isCustomToken, toToken, destinationTokenAddressFromTokenSymbol]);
209
+ const processSend = useCallback(async () => {
210
+ try {
211
+ if (!destinationTokenAddress) {
212
+ return;
213
+ }
214
+ setError(null);
215
+ setIsSubmitting(true);
216
+ const decimals = selectedDestToken?.decimals;
217
+ const parsedAmount = parseUnits(amount, decimals).toString();
218
+ const originRelayer = getRelayer(relayerConfig, selectedToken.chainId);
219
+ const destinationRelayer = getRelayer(relayerConfig, selectedDestinationChain.id);
220
+ const sourceTokenDecimals = typeof selectedToken.contractInfo?.decimals === "number"
221
+ ? selectedToken.contractInfo.decimals
222
+ : null;
223
+ const destinationTokenDecimals = typeof selectedDestToken.decimals === "number"
224
+ ? selectedDestToken.decimals
225
+ : null;
226
+ if (sourceTokenDecimals === null || destinationTokenDecimals === null) {
227
+ setError("Invalid token decimals");
228
+ setIsSubmitting(false);
229
+ return;
230
+ }
231
+ const sourceTokenPriceUsd = selectedToken.tokenPriceUsd ?? null;
232
+ const destinationTokenPriceUsd = destTokenPrices?.[0]?.price?.value ?? null;
233
+ const options = {
234
+ account,
235
+ originTokenAddress: selectedToken.contractAddress,
236
+ originChainId: selectedToken.chainId,
237
+ originTokenAmount: selectedToken.balance,
238
+ destinationChainId: selectedDestinationChain.id,
239
+ recipient,
240
+ destinationTokenAddress,
241
+ destinationTokenAmount: parsedAmount,
242
+ destinationTokenSymbol: selectedDestToken.symbol,
243
+ sequenceProjectAccessKey,
244
+ fee: "0",
245
+ client: walletClient,
246
+ apiClient,
247
+ originRelayer,
248
+ destinationRelayer,
249
+ destinationCalldata: toCalldata,
250
+ dryMode: isDryMode,
251
+ onTransactionStateChange: (transactionStates) => {
252
+ onTransactionStateChange(transactionStates);
253
+ },
254
+ sourceTokenPriceUsd,
255
+ destinationTokenPriceUsd,
256
+ sourceTokenDecimals,
257
+ destinationTokenDecimals,
258
+ paymasterUrl: paymasterUrls?.find((p) => p.chainId.toString() === selectedToken.chainId.toString())?.url ?? undefined,
259
+ gasless,
260
+ relayerConfig,
261
+ };
262
+ console.log("[trails-sdk] options", options);
263
+ const { intentAddress, originSendAmount, send } = await prepareSend(options);
264
+ console.log("[trails-sdk] Intent address:", intentAddress?.toString());
265
+ function onOriginSend() {
266
+ console.log("[trails-sdk] onOriginSend called");
267
+ onConfirm();
268
+ setIsWaitingForWalletConfirm(false);
269
+ onSend(amount, recipient);
270
+ }
271
+ const originSendAmountFormatted = Number(formatUnits(BigInt(originSendAmount), selectedToken.contractInfo?.decimals ?? 18));
272
+ const originSendAmountUsdFormatted = originSendAmountFormatted * (sourceTokenPriceUsd ?? 0);
273
+ setIsWaitingForWalletConfirm(true);
274
+ onWaitingForWalletConfirm(intentAddress?.toString() ?? "", {
275
+ amount: formatValue(originSendAmountFormatted),
276
+ amountUsd: formatUsdValue(originSendAmountUsdFormatted),
277
+ tokenSymbol: selectedToken.symbol,
278
+ tokenName: selectedToken.name,
279
+ chainId: selectedToken.chainId,
280
+ imageUrl: selectedToken.imageUrl,
281
+ });
282
+ async function handleSend() {
283
+ console.log("[trails-sdk] handleRetry called, about to call send()");
284
+ // Wait for full send to complete
285
+ const { originUserTxReceipt, originMetaTxnReceipt, destinationMetaTxnReceipt, } = await send(onOriginSend);
286
+ console.log("[trails-sdk] send() completed, receipts:", {
287
+ originUserTxReceipt,
288
+ originMetaTxnReceipt,
289
+ destinationMetaTxnReceipt,
290
+ });
291
+ // Move to receipt screen
292
+ onComplete({
293
+ originChainId: selectedToken.chainId,
294
+ destinationChainId: selectedDestinationChain.id,
295
+ originUserTxReceipt,
296
+ originMetaTxnReceipt,
297
+ destinationMetaTxnReceipt,
298
+ });
299
+ }
300
+ async function walletConfirmRetryHandler() {
301
+ console.log("[trails-sdk] walletConfirmRetryHandler called");
302
+ try {
303
+ console.log("[trails-sdk] About to call handleRetry");
304
+ await handleSend();
305
+ console.log("[trails-sdk] handleRetry completed successfully");
306
+ }
307
+ catch (error) {
308
+ console.error("[trails-sdk] Error in prepareSend walletConfirmRetryHandler:", error);
309
+ const errorMessage = getFullErrorMessage(error);
310
+ setError(errorMessage);
311
+ if (onError) {
312
+ onError(errorMessage);
313
+ }
314
+ }
315
+ }
316
+ setWalletConfirmRetryHandler(() => walletConfirmRetryHandler);
317
+ await handleSend();
318
+ }
319
+ catch (error) {
320
+ console.error("[trails-sdk] Error in prepareSend:", error);
321
+ const errorMessage = getFullErrorMessage(error);
322
+ setError(errorMessage);
323
+ if (onError) {
324
+ onError(errorMessage);
325
+ }
326
+ }
327
+ setIsSubmitting(false);
328
+ setIsWaitingForWalletConfirm(false);
329
+ }, [
330
+ amount,
331
+ selectedToken,
332
+ onSend,
333
+ onConfirm,
334
+ onComplete,
335
+ walletClient,
336
+ apiClient,
337
+ relayerConfig,
338
+ isDryMode,
339
+ selectedDestToken,
340
+ selectedDestinationChain,
341
+ toCalldata,
342
+ paymasterUrls,
343
+ gasless,
344
+ sequenceProjectAccessKey,
345
+ account,
346
+ destTokenPrices,
347
+ setWalletConfirmRetryHandler,
348
+ onWaitingForWalletConfirm,
349
+ recipient,
350
+ onTransactionStateChange,
351
+ destinationTokenAddress,
352
+ onError,
353
+ ]);
354
+ const handleSubmit = async (e) => {
355
+ e.preventDefault();
356
+ processSend().catch((error) => {
357
+ console.error("[trails-sdk] Error in processSend:", error);
358
+ setError(error instanceof Error ? error.message : "An unexpected error occurred");
359
+ });
360
+ };
361
+ // Get button text based on recipient and calldata
362
+ const buttonText = useMemo(() => {
363
+ if (isWaitingForWalletConfirm)
364
+ return "Waiting for wallet...";
365
+ if (isSubmitting)
366
+ return "Processing...";
367
+ if (!amount)
368
+ return "Enter amount";
369
+ if (!isValidRecipient)
370
+ return "Enter recipient";
371
+ const amountFormatted = formatValue(amount);
372
+ const destTokenSymbol = selectedDestToken?.symbol ?? "Token";
373
+ try {
374
+ const checksummedRecipient = getAddress(recipient);
375
+ const checksummedAccount = getAddress(account.address);
376
+ if (checksummedRecipient === checksummedAccount) {
377
+ return `Receive ${amountFormatted} ${destTokenSymbol}`;
378
+ }
379
+ if (toCalldata) {
380
+ if (useSourceTokenForButtonText) {
381
+ const destPrice = destTokenPrices?.[0]?.price?.value ?? 0;
382
+ const sourcePrice = selectedToken.tokenPriceUsd ?? 0;
383
+ if (destPrice > 0 && sourcePrice > 0) {
384
+ const destAmountUsd = Number(amount) * destPrice;
385
+ const sourceAmount = destAmountUsd / sourcePrice;
386
+ const formattedSourceAmount = formatValue(sourceAmount);
387
+ return `Spend ~${formattedSourceAmount} ${selectedToken.symbol}`;
388
+ }
389
+ }
390
+ return `Spend ${amountFormatted} ${destTokenSymbol}`;
391
+ }
392
+ return `Pay ${amountFormatted} ${destTokenSymbol}`;
393
+ }
394
+ catch {
395
+ return `Send ${amountFormatted} ${destTokenSymbol}`;
396
+ }
397
+ }, [
398
+ amount,
399
+ isValidRecipient,
400
+ recipient,
401
+ account.address,
402
+ selectedDestToken?.symbol,
403
+ toCalldata,
404
+ isWaitingForWalletConfirm,
405
+ isSubmitting,
406
+ useSourceTokenForButtonText,
407
+ destTokenPrices,
408
+ selectedToken,
409
+ ]);
410
+ return {
411
+ amount,
412
+ amountUsdFormatted,
413
+ balanceUsdFormatted,
414
+ chainInfo,
415
+ toChainId,
416
+ error,
417
+ balanceFormatted,
418
+ handleRecipientInputChange,
419
+ handleSubmit,
420
+ isChainDropdownOpen,
421
+ isSubmitting,
422
+ isTokenDropdownOpen,
423
+ recipient,
424
+ recipientInput,
425
+ selectedDestinationChain,
426
+ selectedDestToken,
427
+ setAmount,
428
+ setRecipient,
429
+ setRecipientInput,
430
+ setSelectedDestinationChain,
431
+ setSelectedDestToken,
432
+ setSelectedFeeToken,
433
+ FEE_TOKENS,
434
+ supportedTokens,
435
+ supportedChains,
436
+ ensAddress: ensAddress ?? null,
437
+ isWaitingForWalletConfirm,
438
+ buttonText,
439
+ isValidRecipient,
440
+ useSourceTokenForButtonText,
441
+ destTokenPrices: destTokenPrices ?? null,
442
+ selectedToken,
443
+ selectedFeeToken,
444
+ setIsChainDropdownOpen,
445
+ setIsTokenDropdownOpen,
446
+ toAmountFormatted,
447
+ destinationTokenAddress,
448
+ isValidCustomToken,
449
+ };
450
+ }