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,52 @@
1
+ import type { SequenceIndexerGateway } from "@0xsequence/indexer";
2
+ import type { TokenBalanceExtended } from "../../tokenBalances.js";
3
+ export interface Token {
4
+ id: number;
5
+ name: string;
6
+ symbol: string;
7
+ balance: string;
8
+ imageUrl: string;
9
+ chainId: number;
10
+ contractAddress: string;
11
+ balanceUsdFormatted: string;
12
+ tokenPriceUsd: number;
13
+ contractInfo?: {
14
+ decimals: number;
15
+ symbol: string;
16
+ name: string;
17
+ };
18
+ }
19
+ export type TokenFormatted = Token & TokenBalanceExtended & {
20
+ balanceFormatted: string;
21
+ tokenPriceUsd: number;
22
+ balanceUsdFormatted: string;
23
+ isNative: boolean;
24
+ tokenName: string;
25
+ priceUsd: number;
26
+ isSufficientBalance: boolean;
27
+ chainName: string;
28
+ };
29
+ export type UseTokenListProps = {
30
+ onContinue: (selectedToken: Token) => void;
31
+ targetAmountUsd?: number | null;
32
+ indexerGatewayClient: SequenceIndexerGateway;
33
+ onError: (error: Error | string | null) => void;
34
+ };
35
+ export type UseTokenListReturn = {
36
+ selectedToken: Token | null;
37
+ searchQuery: string;
38
+ handleTokenSelect: (token: TokenFormatted) => void;
39
+ filteredTokens: TokenBalanceExtended[];
40
+ isLoadingSortedTokens: boolean;
41
+ balanceError: Error | null;
42
+ showContinueButton: boolean;
43
+ isTokenSelected: (token: TokenBalanceExtended) => boolean;
44
+ setSearchQuery: (query: string) => void;
45
+ filteredTokensFormatted: TokenFormatted[];
46
+ totalBalanceUsd: number;
47
+ totalBalanceUsdFormatted: string;
48
+ isLoadingTotalBalanceUsd: boolean;
49
+ showInsufficientBalance: boolean;
50
+ };
51
+ export declare function useTokenList({ onContinue, targetAmountUsd, indexerGatewayClient, onError, }: UseTokenListProps): UseTokenListReturn;
52
+ //# sourceMappingURL=useTokenList.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTokenList.d.ts","sourceRoot":"","sources":["../../../src/widget/hooks/useTokenList.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAA;AAOjE,OAAO,KAAK,EACV,oBAAoB,EAErB,MAAM,wBAAwB,CAAA;AAS/B,MAAM,WAAW,KAAK;IACpB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,MAAM,CAAA;IACd,OAAO,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,MAAM,CAAA;IACf,eAAe,EAAE,MAAM,CAAA;IACvB,mBAAmB,EAAE,MAAM,CAAA;IAC3B,aAAa,EAAE,MAAM,CAAA;IACrB,YAAY,CAAC,EAAE;QACb,QAAQ,EAAE,MAAM,CAAA;QAChB,MAAM,EAAE,MAAM,CAAA;QACd,IAAI,EAAE,MAAM,CAAA;KACb,CAAA;CACF;AAED,MAAM,MAAM,cAAc,GAAG,KAAK,GAChC,oBAAoB,GAAG;IACrB,gBAAgB,EAAE,MAAM,CAAA;IACxB,aAAa,EAAE,MAAM,CAAA;IACrB,mBAAmB,EAAE,MAAM,CAAA;IAC3B,QAAQ,EAAE,OAAO,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,EAAE,MAAM,CAAA;IAChB,mBAAmB,EAAE,OAAO,CAAA;IAC5B,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAEH,MAAM,MAAM,iBAAiB,GAAG;IAC9B,UAAU,EAAE,CAAC,aAAa,EAAE,KAAK,KAAK,IAAI,CAAA;IAC1C,eAAe,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC/B,oBAAoB,EAAE,sBAAsB,CAAA;IAC5C,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,GAAG,MAAM,GAAG,IAAI,KAAK,IAAI,CAAA;CAChD,CAAA;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC/B,aAAa,EAAE,KAAK,GAAG,IAAI,CAAA;IAC3B,WAAW,EAAE,MAAM,CAAA;IACnB,iBAAiB,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAA;IAClD,cAAc,EAAE,oBAAoB,EAAE,CAAA;IACtC,qBAAqB,EAAE,OAAO,CAAA;IAC9B,YAAY,EAAE,KAAK,GAAG,IAAI,CAAA;IAC1B,kBAAkB,EAAE,OAAO,CAAA;IAC3B,eAAe,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,OAAO,CAAA;IACzD,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IACvC,uBAAuB,EAAE,cAAc,EAAE,CAAA;IACzC,eAAe,EAAE,MAAM,CAAA;IACvB,wBAAwB,EAAE,MAAM,CAAA;IAChC,wBAAwB,EAAE,OAAO,CAAA;IACjC,uBAAuB,EAAE,OAAO,CAAA;CACjC,CAAA;AAED,wBAAgB,YAAY,CAAC,EAC3B,UAAU,EACV,eAAe,EACf,oBAAoB,EACpB,OAAO,GACR,EAAE,iBAAiB,GAAG,kBAAkB,CA+TxC"}
@@ -0,0 +1,252 @@
1
+ import { ResourceStatus } from "@0xsequence/indexer";
2
+ import { Address } from "ox";
3
+ import { useEffect, useMemo, useState } from "react";
4
+ import { isAddressEqual, zeroAddress } from "viem";
5
+ import { useAccount } from "wagmi";
6
+ import { getChainInfo, useSupportedChains } from "../../chains.js";
7
+ import { formatBalance, useAccountTotalBalanceUsd, useHasSufficientBalanceUsd, useTokenBalances, } from "../../tokenBalances.js";
8
+ import { getFormatttedTokenName, useSourceTokenList } from "../../tokens.js";
9
+ export function useTokenList({ onContinue, targetAmountUsd, indexerGatewayClient, onError, }) {
10
+ const [selectedToken, setSelectedToken] = useState(null);
11
+ const [searchQuery, setSearchQuery] = useState("");
12
+ const { address } = useAccount();
13
+ const { sortedTokens: allSortedTokens, isLoadingSortedTokens, balanceError, } = useTokenBalances(address, indexerGatewayClient);
14
+ const { totalBalanceUsd, totalBalanceUsdFormatted, isLoadingTotalBalanceUsd, } = useAccountTotalBalanceUsd(address);
15
+ const { hasSufficientBalanceUsd, isLoadingHasSufficientBalanceUsd, hasSufficientBalanceUsdError, } = useHasSufficientBalanceUsd(address, targetAmountUsd);
16
+ const showContinueButton = false;
17
+ const sourceTokenList = useSourceTokenList();
18
+ const { supportedChains: supportedToChains } = useSupportedChains();
19
+ const supportedChainIds = useMemo(() => {
20
+ return new Set(supportedToChains.map((c) => c.id));
21
+ }, [supportedToChains]);
22
+ const sortedTokens = useMemo(() => {
23
+ return allSortedTokens.filter((token) => {
24
+ if (!supportedChainIds.has(token.chainId)) {
25
+ return false;
26
+ }
27
+ return (!token.contractAddress ||
28
+ sourceTokenList.includes(token.contractInfo?.symbol || ""));
29
+ });
30
+ }, [allSortedTokens, sourceTokenList, supportedChainIds]);
31
+ useEffect(() => {
32
+ if (onError) {
33
+ onError(balanceError);
34
+ }
35
+ }, [balanceError, onError]);
36
+ const handleTokenSelect = (token) => {
37
+ const isNative = !("contractAddress" in token);
38
+ const chainInfo = getChainInfo(token.chainId);
39
+ const imageUrl = token.imageUrl;
40
+ let formattedToken;
41
+ if (isNative) {
42
+ formattedToken = {
43
+ id: token.chainId,
44
+ name: chainInfo?.nativeCurrency.name || "Native Token",
45
+ symbol: chainInfo?.nativeCurrency.symbol || "ETH",
46
+ balance: token.balance,
47
+ imageUrl,
48
+ chainId: token.chainId,
49
+ contractAddress: zeroAddress,
50
+ balanceUsdFormatted: token.balanceUsdFormatted ?? "",
51
+ tokenPriceUsd: token.price?.value ?? 0,
52
+ contractInfo: {
53
+ decimals: 18,
54
+ symbol: chainInfo?.nativeCurrency.symbol || "ETH",
55
+ name: chainInfo?.nativeCurrency.name || "Native Token",
56
+ },
57
+ };
58
+ }
59
+ else {
60
+ formattedToken = {
61
+ id: token.chainId,
62
+ name: token.contractInfo?.name || "Unknown Token",
63
+ symbol: token.contractInfo?.symbol || "???",
64
+ balance: token.balance,
65
+ imageUrl,
66
+ chainId: token.chainId,
67
+ contractAddress: token.contractAddress,
68
+ contractInfo: {
69
+ ...token.contractInfo,
70
+ name: token.contractInfo?.name ?? "Unknown Token",
71
+ symbol: token.contractInfo?.symbol ?? "???",
72
+ decimals: token.contractInfo?.decimals ?? 18,
73
+ },
74
+ balanceUsdFormatted: token.balanceUsdFormatted ?? "",
75
+ tokenPriceUsd: token.price?.value ?? 0,
76
+ };
77
+ }
78
+ setSelectedToken(formattedToken);
79
+ const canContinue = (!targetAmountUsd || (targetAmountUsd && hasSufficientBalanceUsd)) &&
80
+ token.isSufficientBalance;
81
+ if (!canContinue) {
82
+ console.warn("[trails-sdk] Cannot continue with token selection", {
83
+ token: formattedToken,
84
+ targetAmountUsd,
85
+ hasSufficientBalanceUsd,
86
+ isSufficientBalance: token.isSufficientBalance,
87
+ });
88
+ }
89
+ onContinue(formattedToken);
90
+ };
91
+ const isTokenSelected = (token) => {
92
+ if (!selectedToken)
93
+ return false;
94
+ const isNative = !("contractAddress" in token);
95
+ return (selectedToken.chainId === token.chainId &&
96
+ (isNative
97
+ ? selectedToken.contractAddress === zeroAddress
98
+ : isAddressEqual(Address.from(selectedToken.contractAddress), Address.from(token.contractAddress))));
99
+ };
100
+ const filteredTokens = useMemo(() => {
101
+ if (!searchQuery.trim()) {
102
+ return sortedTokens;
103
+ }
104
+ const query = searchQuery.toLowerCase().trim();
105
+ const queryParts = query.split(/\s+/).filter((part) => part.length > 0);
106
+ return sortedTokens.filter((token) => {
107
+ const isNative = !("contractAddress" in token);
108
+ const chainInfo = getChainInfo(token.chainId);
109
+ const chainName = chainInfo?.name || "";
110
+ const chainNameLower = chainName.toLowerCase();
111
+ if (isNative) {
112
+ const nativeSymbol = chainInfo?.nativeCurrency.symbol || "ETH";
113
+ const nativeName = chainInfo?.nativeCurrency.name || "Native Token";
114
+ const nativeSymbolLower = nativeSymbol.toLowerCase();
115
+ const nativeNameLower = nativeName.toLowerCase();
116
+ // If multiple query parts, check if they match chain + token combination
117
+ if (queryParts.length > 1) {
118
+ const matchesChain = queryParts.some((part) => chainNameLower.includes(part));
119
+ const matchesToken = queryParts.some((part) => nativeSymbolLower.includes(part) ||
120
+ nativeNameLower.includes(part));
121
+ return matchesChain && matchesToken;
122
+ }
123
+ // Single query part - match against any field
124
+ return queryParts.some((part) => nativeSymbolLower.includes(part) ||
125
+ nativeNameLower.includes(part) ||
126
+ chainNameLower.includes(part));
127
+ }
128
+ const tokenSymbol = token.contractInfo?.symbol || "???";
129
+ const tokenName = token.contractInfo?.name || "Unknown Token";
130
+ const tokenSymbolLower = tokenSymbol.toLowerCase();
131
+ const tokenNameLower = tokenName.toLowerCase();
132
+ // If multiple query parts, check if they match chain + token combination
133
+ if (queryParts.length > 1) {
134
+ const matchesChain = queryParts.some((part) => chainNameLower.includes(part));
135
+ const matchesToken = queryParts.some((part) => tokenSymbolLower.includes(part) || tokenNameLower.includes(part));
136
+ return matchesChain && matchesToken;
137
+ }
138
+ // Single query part - match against any field
139
+ return queryParts.some((part) => tokenSymbolLower.includes(part) ||
140
+ tokenNameLower.includes(part) ||
141
+ chainNameLower.includes(part));
142
+ });
143
+ }, [sortedTokens, searchQuery]);
144
+ const filteredTokensFormatted = useMemo(() => {
145
+ return filteredTokens.map((token) => {
146
+ const isNative = !("contractAddress" in token);
147
+ const chainInfo = getChainInfo(token.chainId);
148
+ const nativeSymbol = chainInfo?.nativeCurrency.symbol || "ETH";
149
+ const tokenSymbol = isNative
150
+ ? nativeSymbol
151
+ : token.contractInfo?.symbol || "???";
152
+ const contractAddress = isNative ? zeroAddress : token.contractAddress;
153
+ let imageContractAddress = contractAddress;
154
+ if (tokenSymbol === "WETH") {
155
+ imageContractAddress = zeroAddress;
156
+ }
157
+ const imageUrl = `https://assets.sequence.info/images/tokens/small/${token.chainId}/${imageContractAddress}.webp`;
158
+ const currentTokenName = token.contractInfo?.name || "";
159
+ const tokenName = getFormatttedTokenName(currentTokenName, tokenSymbol, token.chainId);
160
+ const formattedBalance = formatBalance(token.balance, isNative ? 18 : token.contractInfo?.decimals);
161
+ const priceUsd = Number(token.price?.value) ?? 0;
162
+ const balanceUsdFormatted = token.balanceUsdFormatted ?? "";
163
+ const decimals = isNative ? 18 : (token.contractInfo?.decimals ?? 18);
164
+ let isSufficientBalance = true;
165
+ if (targetAmountUsd) {
166
+ isSufficientBalance = (token.balanceUsd ?? 0) >= targetAmountUsd;
167
+ }
168
+ const chainName = chainInfo?.name || "";
169
+ return {
170
+ ...token,
171
+ id: token.chainId,
172
+ contractInfo: {
173
+ ...token.contractInfo,
174
+ chainId: Number(token.chainId),
175
+ source: token.contractInfo?.source || "",
176
+ type: token.contractInfo?.type || "",
177
+ logoURI: token.contractInfo?.logoURI || "",
178
+ deployed: token.contractInfo?.deployed || false,
179
+ bytecodeHash: token.contractInfo?.bytecodeHash || "",
180
+ updatedAt: token.contractInfo?.updatedAt || "",
181
+ queuedAt: token.contractInfo?.queuedAt || "",
182
+ extensions: token.contractInfo
183
+ ?.extensions || {
184
+ link: "",
185
+ description: "",
186
+ categories: [],
187
+ ogImage: "",
188
+ ogName: "",
189
+ originChainId: 0,
190
+ originAddress: "",
191
+ blacklist: false,
192
+ verified: false,
193
+ featureIndex: 0,
194
+ verifiedBy: "",
195
+ featured: false,
196
+ },
197
+ status: token.contractInfo?.status ||
198
+ ResourceStatus.NOT_AVAILABLE,
199
+ address: contractAddress,
200
+ name: tokenName,
201
+ symbol: tokenSymbol,
202
+ decimals: decimals,
203
+ },
204
+ name: tokenName,
205
+ symbol: tokenSymbol,
206
+ balanceFormatted: formattedBalance,
207
+ imageUrl,
208
+ chainId: token.chainId,
209
+ contractAddress: contractAddress,
210
+ balanceUsdFormatted,
211
+ tokenPriceUsd: priceUsd,
212
+ isNative: isNative,
213
+ tokenName: tokenName,
214
+ priceUsd: priceUsd,
215
+ isSufficientBalance,
216
+ chainName,
217
+ };
218
+ });
219
+ }, [filteredTokens, targetAmountUsd]);
220
+ const showInsufficientBalance = useMemo(() => {
221
+ return ((totalBalanceUsd &&
222
+ targetAmountUsd &&
223
+ !hasSufficientBalanceUsd &&
224
+ !isLoadingHasSufficientBalanceUsd &&
225
+ !hasSufficientBalanceUsdError) ||
226
+ (filteredTokensFormatted?.length > 0 &&
227
+ !filteredTokensFormatted.some((token) => token.isSufficientBalance)));
228
+ }, [
229
+ targetAmountUsd,
230
+ hasSufficientBalanceUsd,
231
+ isLoadingHasSufficientBalanceUsd,
232
+ hasSufficientBalanceUsdError,
233
+ filteredTokensFormatted,
234
+ totalBalanceUsd,
235
+ ]);
236
+ return {
237
+ selectedToken,
238
+ searchQuery,
239
+ handleTokenSelect,
240
+ filteredTokens,
241
+ isLoadingSortedTokens,
242
+ balanceError,
243
+ showContinueButton,
244
+ isTokenSelected,
245
+ setSearchQuery,
246
+ filteredTokensFormatted,
247
+ totalBalanceUsd,
248
+ totalBalanceUsdFormatted,
249
+ isLoadingTotalBalanceUsd,
250
+ showInsufficientBalance,
251
+ };
252
+ }
@@ -0,0 +1,17 @@
1
+ import "./index-CK94R-H7.js";
2
+ import { b as c } from "./lit-html-BRjl1r6K.js";
3
+ const e = c`<svg
4
+ xmlns="http://www.w3.org/2000/svg"
5
+ width="28"
6
+ height="28"
7
+ viewBox="0 0 28 28"
8
+ fill="none">
9
+ <path
10
+ fill="#949E9E"
11
+ fill-rule="evenodd"
12
+ d="M7.974 2.975h12.052c1.248 0 2.296 0 3.143.092.89.096 1.723.307 2.461.844a4.9 4.9 0 0 1 1.084 1.084c.537.738.748 1.57.844 2.461.092.847.092 1.895.092 3.143v6.802c0 1.248 0 2.296-.092 3.143-.096.89-.307 1.723-.844 2.461a4.9 4.9 0 0 1-1.084 1.084c-.738.537-1.57.748-2.461.844-.847.092-1.895.092-3.143.092H7.974c-1.247 0-2.296 0-3.143-.092-.89-.096-1.723-.307-2.461-.844a4.901 4.901 0 0 1-1.084-1.084c-.537-.738-.748-1.571-.844-2.461C.35 19.697.35 18.649.35 17.4v-6.802c0-1.248 0-2.296.092-3.143.096-.89.307-1.723.844-2.461A4.9 4.9 0 0 1 2.37 3.91c.738-.537 1.571-.748 2.461-.844.847-.092 1.895-.092 3.143-.092ZM5.133 5.85c-.652.071-.936.194-1.117.326a2.1 2.1 0 0 0-.465.465c-.132.181-.255.465-.325 1.117-.074.678-.076 1.573-.076 2.917v6.65c0 1.344.002 2.239.076 2.917.07.652.193.936.325 1.117a2.1 2.1 0 0 0 .465.465c.181.132.465.255 1.117.326.678.073 1.574.075 2.917.075h11.9c1.344 0 2.239-.002 2.917-.075.652-.071.936-.194 1.117-.326.179-.13.335-.286.465-.465.132-.181.255-.465.326-1.117.073-.678.075-1.573.075-2.917v-6.65c0-1.344-.002-2.239-.075-2.917-.071-.652-.194-.936-.326-1.117a2.1 2.1 0 0 0-.465-.465c-.181-.132-.465-.255-1.117-.326-.678-.073-1.573-.075-2.917-.075H8.05c-1.343 0-2.239.002-2.917.075Zm.467 7.275a3.15 3.15 0 1 1 6.3 0 3.15 3.15 0 0 1-6.3 0Zm8.75-1.75a1.4 1.4 0 0 1 1.4-1.4h3.5a1.4 1.4 0 0 1 0 2.8h-3.5a1.4 1.4 0 0 1-1.4-1.4Zm0 5.25a1.4 1.4 0 0 1 1.4-1.4H21a1.4 1.4 0 1 1 0 2.8h-5.25a1.4 1.4 0 0 1-1.4-1.4Z"
13
+ clip-rule="evenodd"/>
14
+ </svg>`;
15
+ export {
16
+ e as idSvg
17
+ };