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,703 @@
1
+ import { i as E, r as j, j as z, a as v, k as _, R as l, C as h, d as x, S as f, h as D, l as P, O as R, e as c, M as V, m as M, c as B } from "./index-CK94R-H7.js";
2
+ import { n as I, c as d, r as m, U as N } from "./if-defined-DRXJEhv7.js";
3
+ import { x as u } from "./lit-html-BRjl1r6K.js";
4
+ import "./index-BlviH5nG.js";
5
+ import "./index-BTlDgFSK.js";
6
+ import "./index-CD6dBcRj.js";
7
+ import { e as H, n as q } from "./ref-CXNmEjML.js";
8
+ import "./index-CRT8cAwG.js";
9
+ import "./index-CHXa5ke-.js";
10
+ const K = E`
11
+ :host {
12
+ position: relative;
13
+ display: inline-block;
14
+ }
15
+
16
+ input {
17
+ width: 50px;
18
+ height: 50px;
19
+ background: var(--wui-color-gray-glass-010);
20
+ border-radius: var(--wui-border-radius-xs);
21
+ border: 1px solid var(--wui-color-gray-glass-005);
22
+ font-family: var(--wui-font-family);
23
+ font-size: var(--wui-font-size-large);
24
+ font-weight: var(--wui-font-weight-regular);
25
+ letter-spacing: var(--wui-letter-spacing-large);
26
+ text-align: center;
27
+ color: var(--wui-color-fg-100);
28
+ caret-color: var(--wui-color-accent-100);
29
+ transition:
30
+ background-color var(--wui-ease-inout-power-1) var(--wui-duration-md),
31
+ border-color var(--wui-ease-inout-power-1) var(--wui-duration-md),
32
+ box-shadow var(--wui-ease-inout-power-1) var(--wui-duration-md);
33
+ will-change: background-color, border-color, box-shadow;
34
+ box-sizing: border-box;
35
+ -webkit-appearance: none;
36
+ -moz-appearance: textfield;
37
+ padding: 0px;
38
+ }
39
+
40
+ input::-webkit-outer-spin-button,
41
+ input::-webkit-inner-spin-button {
42
+ -webkit-appearance: none;
43
+ margin: 0;
44
+ }
45
+
46
+ input[type='number'] {
47
+ -moz-appearance: textfield;
48
+ }
49
+
50
+ input:disabled {
51
+ cursor: not-allowed;
52
+ border: 1px solid var(--wui-color-gray-glass-010);
53
+ background: var(--wui-color-gray-glass-005);
54
+ }
55
+
56
+ input:focus:enabled {
57
+ background-color: var(--wui-color-gray-glass-015);
58
+ border: 1px solid var(--wui-color-accent-100);
59
+ -webkit-box-shadow: 0px 0px 0px 4px var(--wui-box-shadow-blue);
60
+ -moz-box-shadow: 0px 0px 0px 4px var(--wui-box-shadow-blue);
61
+ box-shadow: 0px 0px 0px 4px var(--wui-box-shadow-blue);
62
+ }
63
+
64
+ @media (hover: hover) and (pointer: fine) {
65
+ input:hover:enabled {
66
+ background-color: var(--wui-color-gray-glass-015);
67
+ }
68
+ }
69
+ `;
70
+ var S = function(a, e, t, n) {
71
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
72
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
73
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
74
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
75
+ };
76
+ let g = class extends v {
77
+ constructor() {
78
+ super(...arguments), this.disabled = !1, this.value = "";
79
+ }
80
+ render() {
81
+ return u`<input
82
+ type="number"
83
+ maxlength="1"
84
+ inputmode="numeric"
85
+ autofocus
86
+ ?disabled=${this.disabled}
87
+ value=${this.value}
88
+ /> `;
89
+ }
90
+ };
91
+ g.styles = [j, z, K];
92
+ S([
93
+ I({ type: Boolean })
94
+ ], g.prototype, "disabled", void 0);
95
+ S([
96
+ I({ type: String })
97
+ ], g.prototype, "value", void 0);
98
+ g = S([
99
+ d("wui-input-numeric")
100
+ ], g);
101
+ const Y = E`
102
+ :host {
103
+ position: relative;
104
+ display: block;
105
+ }
106
+ `;
107
+ var C = function(a, e, t, n) {
108
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
109
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
110
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
111
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
112
+ };
113
+ let w = class extends v {
114
+ constructor() {
115
+ super(...arguments), this.length = 6, this.otp = "", this.values = Array.from({ length: this.length }).map(() => ""), this.numerics = [], this.shouldInputBeEnabled = (e) => this.values.slice(0, e).every((n) => n !== ""), this.handleKeyDown = (e, t) => {
116
+ const n = e.target, o = this.getInputElement(n), i = ["ArrowLeft", "ArrowRight", "Shift", "Delete"];
117
+ if (!o)
118
+ return;
119
+ i.includes(e.key) && e.preventDefault();
120
+ const r = o.selectionStart;
121
+ switch (e.key) {
122
+ case "ArrowLeft":
123
+ r && o.setSelectionRange(r + 1, r + 1), this.focusInputField("prev", t);
124
+ break;
125
+ case "ArrowRight":
126
+ this.focusInputField("next", t);
127
+ break;
128
+ case "Shift":
129
+ this.focusInputField("next", t);
130
+ break;
131
+ case "Delete":
132
+ o.value === "" ? this.focusInputField("prev", t) : this.updateInput(o, t, "");
133
+ break;
134
+ case "Backspace":
135
+ o.value === "" ? this.focusInputField("prev", t) : this.updateInput(o, t, "");
136
+ break;
137
+ }
138
+ }, this.focusInputField = (e, t) => {
139
+ if (e === "next") {
140
+ const n = t + 1;
141
+ if (!this.shouldInputBeEnabled(n))
142
+ return;
143
+ const o = this.numerics[n < this.length ? n : t], i = o ? this.getInputElement(o) : void 0;
144
+ i && (i.disabled = !1, i.focus());
145
+ }
146
+ if (e === "prev") {
147
+ const n = t - 1, o = this.numerics[n > -1 ? n : t], i = o ? this.getInputElement(o) : void 0;
148
+ i && i.focus();
149
+ }
150
+ };
151
+ }
152
+ firstUpdated() {
153
+ var t, n;
154
+ this.otp && (this.values = this.otp.split(""));
155
+ const e = (t = this.shadowRoot) == null ? void 0 : t.querySelectorAll("wui-input-numeric");
156
+ e && (this.numerics = Array.from(e)), (n = this.numerics[0]) == null || n.focus();
157
+ }
158
+ render() {
159
+ return u`
160
+ <wui-flex gap="xxs" data-testid="wui-otp-input">
161
+ ${Array.from({ length: this.length }).map((e, t) => u`
162
+ <wui-input-numeric
163
+ @input=${(n) => this.handleInput(n, t)}
164
+ @click=${(n) => this.selectInput(n)}
165
+ @keydown=${(n) => this.handleKeyDown(n, t)}
166
+ .disabled=${!this.shouldInputBeEnabled(t)}
167
+ .value=${this.values[t] || ""}
168
+ >
169
+ </wui-input-numeric>
170
+ `)}
171
+ </wui-flex>
172
+ `;
173
+ }
174
+ updateInput(e, t, n) {
175
+ const o = this.numerics[t], i = e || (o ? this.getInputElement(o) : void 0);
176
+ i && (i.value = n, this.values = this.values.map((r, s) => s === t ? n : r));
177
+ }
178
+ selectInput(e) {
179
+ const t = e.target;
180
+ if (t) {
181
+ const n = this.getInputElement(t);
182
+ n == null || n.select();
183
+ }
184
+ }
185
+ handleInput(e, t) {
186
+ const n = e.target, o = this.getInputElement(n);
187
+ if (o) {
188
+ const i = o.value;
189
+ e.inputType === "insertFromPaste" ? this.handlePaste(o, i, t) : N.isNumber(i) && e.data ? (this.updateInput(o, t, e.data), this.focusInputField("next", t)) : this.updateInput(o, t, "");
190
+ }
191
+ this.dispatchInputChangeEvent();
192
+ }
193
+ handlePaste(e, t, n) {
194
+ const o = t[0];
195
+ if (o && N.isNumber(o)) {
196
+ this.updateInput(e, n, o);
197
+ const r = t.substring(1);
198
+ if (n + 1 < this.length && r.length) {
199
+ const s = this.numerics[n + 1], $ = s ? this.getInputElement(s) : void 0;
200
+ $ && this.handlePaste($, r, n + 1);
201
+ } else
202
+ this.focusInputField("next", n);
203
+ } else
204
+ this.updateInput(e, n, "");
205
+ }
206
+ getInputElement(e) {
207
+ var t;
208
+ return (t = e.shadowRoot) != null && t.querySelector("input") ? e.shadowRoot.querySelector("input") : null;
209
+ }
210
+ dispatchInputChangeEvent() {
211
+ const e = this.values.join("");
212
+ this.dispatchEvent(new CustomEvent("inputChange", {
213
+ detail: e,
214
+ bubbles: !0,
215
+ composed: !0
216
+ }));
217
+ }
218
+ };
219
+ w.styles = [j, Y];
220
+ C([
221
+ I({ type: Number })
222
+ ], w.prototype, "length", void 0);
223
+ C([
224
+ I({ type: String })
225
+ ], w.prototype, "otp", void 0);
226
+ C([
227
+ m()
228
+ ], w.prototype, "values", void 0);
229
+ w = C([
230
+ d("wui-otp")
231
+ ], w);
232
+ const G = E`
233
+ wui-loading-spinner {
234
+ margin: 9px auto;
235
+ }
236
+
237
+ .email-display,
238
+ .email-display wui-text {
239
+ max-width: 100%;
240
+ }
241
+ `;
242
+ var O = function(a, e, t, n) {
243
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
244
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
245
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
246
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
247
+ };
248
+ const J = 6;
249
+ let p = class extends v {
250
+ firstUpdated() {
251
+ this.startOTPTimeout();
252
+ }
253
+ disconnectedCallback() {
254
+ clearTimeout(this.OTPTimeout);
255
+ }
256
+ constructor() {
257
+ var e;
258
+ super(), this.loading = !1, this.timeoutTimeLeft = _.getTimeToNextEmailLogin(), this.error = "", this.otp = "", this.email = (e = l.state.data) == null ? void 0 : e.email, this.authConnector = h.getAuthConnector();
259
+ }
260
+ render() {
261
+ if (!this.email)
262
+ throw new Error("w3m-email-otp-widget: No email provided");
263
+ const e = !!this.timeoutTimeLeft, t = this.getFooterLabels(e);
264
+ return u`
265
+ <wui-flex
266
+ flexDirection="column"
267
+ alignItems="center"
268
+ .padding=${["l", "0", "l", "0"]}
269
+ gap="l"
270
+ >
271
+ <wui-flex
272
+ class="email-display"
273
+ flexDirection="column"
274
+ alignItems="center"
275
+ .padding=${["0", "xl", "0", "xl"]}
276
+ >
277
+ <wui-text variant="paragraph-400" color="fg-100" align="center">
278
+ Enter the code we sent to
279
+ </wui-text>
280
+ <wui-text variant="paragraph-500" color="fg-100" lineClamp="1" align="center">
281
+ ${this.email}
282
+ </wui-text>
283
+ </wui-flex>
284
+
285
+ <wui-text variant="small-400" color="fg-200">The code expires in 20 minutes</wui-text>
286
+
287
+ ${this.loading ? u`<wui-loading-spinner size="xl" color="accent-100"></wui-loading-spinner>` : u` <wui-flex flexDirection="column" alignItems="center" gap="xs">
288
+ <wui-otp
289
+ dissabled
290
+ length="6"
291
+ @inputChange=${this.onOtpInputChange.bind(this)}
292
+ .otp=${this.otp}
293
+ ></wui-otp>
294
+ ${this.error ? u`
295
+ <wui-text variant="small-400" align="center" color="error-100">
296
+ ${this.error}. Try Again
297
+ </wui-text>
298
+ ` : null}
299
+ </wui-flex>`}
300
+
301
+ <wui-flex alignItems="center" gap="xs">
302
+ <wui-text variant="small-400" color="fg-200">${t.title}</wui-text>
303
+ <wui-link @click=${this.onResendCode.bind(this)} .disabled=${e}>
304
+ ${t.action}
305
+ </wui-link>
306
+ </wui-flex>
307
+ </wui-flex>
308
+ `;
309
+ }
310
+ startOTPTimeout() {
311
+ this.timeoutTimeLeft = _.getTimeToNextEmailLogin(), this.OTPTimeout = setInterval(() => {
312
+ this.timeoutTimeLeft > 0 ? this.timeoutTimeLeft = _.getTimeToNextEmailLogin() : clearInterval(this.OTPTimeout);
313
+ }, 1e3);
314
+ }
315
+ async onOtpInputChange(e) {
316
+ var t;
317
+ try {
318
+ this.loading || (this.otp = e.detail, this.authConnector && this.otp.length === J && (this.loading = !0, await ((t = this.onOtpSubmit) == null ? void 0 : t.call(this, this.otp))));
319
+ } catch (n) {
320
+ this.error = x.parseError(n), this.loading = !1;
321
+ }
322
+ }
323
+ async onResendCode() {
324
+ try {
325
+ if (this.onOtpResend) {
326
+ if (!this.loading && !this.timeoutTimeLeft) {
327
+ if (this.error = "", this.otp = "", !h.getAuthConnector() || !this.email)
328
+ throw new Error("w3m-email-otp-widget: Unable to resend email");
329
+ this.loading = !0, await this.onOtpResend(this.email), this.startOTPTimeout(), f.showSuccess("Code email resent");
330
+ }
331
+ } else this.onStartOver && this.onStartOver();
332
+ } catch (e) {
333
+ f.showError(e);
334
+ } finally {
335
+ this.loading = !1;
336
+ }
337
+ }
338
+ getFooterLabels(e) {
339
+ return this.onStartOver ? {
340
+ title: "Something wrong?",
341
+ action: `Try again ${e ? `in ${this.timeoutTimeLeft}s` : ""}`
342
+ } : {
343
+ title: "Didn't receive it?",
344
+ action: `Resend ${e ? `in ${this.timeoutTimeLeft}s` : "Code"}`
345
+ };
346
+ }
347
+ };
348
+ p.styles = G;
349
+ O([
350
+ m()
351
+ ], p.prototype, "loading", void 0);
352
+ O([
353
+ m()
354
+ ], p.prototype, "timeoutTimeLeft", void 0);
355
+ O([
356
+ m()
357
+ ], p.prototype, "error", void 0);
358
+ p = O([
359
+ d("w3m-email-otp-widget")
360
+ ], p);
361
+ var Q = function(a, e, t, n) {
362
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
363
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
364
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
365
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
366
+ };
367
+ let L = class extends p {
368
+ constructor() {
369
+ super(...arguments), this.onOtpSubmit = async (e) => {
370
+ var t, n;
371
+ try {
372
+ if (this.authConnector) {
373
+ const o = D.state.activeChain, i = P.getConnections(o), r = (t = R.state.remoteFeatures) == null ? void 0 : t.multiWallet, s = i.length > 0;
374
+ if (await this.authConnector.provider.connectOtp({ otp: e }), c.sendEvent({ type: "track", event: "EMAIL_VERIFICATION_CODE_PASS" }), o)
375
+ await P.connectExternal(this.authConnector, o);
376
+ else
377
+ throw new Error("Active chain is not set on ChainControll");
378
+ c.sendEvent({
379
+ type: "track",
380
+ event: "CONNECT_SUCCESS",
381
+ properties: {
382
+ method: "email",
383
+ name: this.authConnector.name || "Unknown",
384
+ caipNetworkId: (n = D.getActiveCaipNetwork()) == null ? void 0 : n.caipNetworkId
385
+ }
386
+ }), R.state.siwx ? V.close() : s && r ? (l.replace("ProfileWallets"), f.showSuccess("New Wallet Added")) : V.close();
387
+ }
388
+ } catch (o) {
389
+ throw c.sendEvent({
390
+ type: "track",
391
+ event: "EMAIL_VERIFICATION_CODE_FAIL",
392
+ properties: { message: x.parseError(o) }
393
+ }), o;
394
+ }
395
+ }, this.onOtpResend = async (e) => {
396
+ this.authConnector && (await this.authConnector.provider.connectEmail({ email: e }), c.sendEvent({ type: "track", event: "EMAIL_VERIFICATION_CODE_SENT" }));
397
+ };
398
+ }
399
+ };
400
+ L = Q([
401
+ d("w3m-email-verify-otp-view")
402
+ ], L);
403
+ const X = E`
404
+ wui-icon-box {
405
+ height: var(--wui-icon-box-size-xl);
406
+ width: var(--wui-icon-box-size-xl);
407
+ }
408
+ `;
409
+ var U = function(a, e, t, n) {
410
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
411
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
412
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
413
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
414
+ };
415
+ let y = class extends v {
416
+ constructor() {
417
+ var e;
418
+ super(), this.email = (e = l.state.data) == null ? void 0 : e.email, this.authConnector = h.getAuthConnector(), this.loading = !1, this.listenForDeviceApproval();
419
+ }
420
+ render() {
421
+ if (!this.email)
422
+ throw new Error("w3m-email-verify-device-view: No email provided");
423
+ if (!this.authConnector)
424
+ throw new Error("w3m-email-verify-device-view: No auth connector provided");
425
+ return u`
426
+ <wui-flex
427
+ flexDirection="column"
428
+ alignItems="center"
429
+ .padding=${["xxl", "s", "xxl", "s"]}
430
+ gap="l"
431
+ >
432
+ <wui-icon-box
433
+ size="xl"
434
+ iconcolor="accent-100"
435
+ backgroundcolor="accent-100"
436
+ icon="verify"
437
+ background="opaque"
438
+ ></wui-icon-box>
439
+
440
+ <wui-flex flexDirection="column" alignItems="center" gap="s">
441
+ <wui-flex flexDirection="column" alignItems="center">
442
+ <wui-text variant="paragraph-400" color="fg-100">
443
+ Approve the login link we sent to
444
+ </wui-text>
445
+ <wui-text variant="paragraph-400" color="fg-100"><b>${this.email}</b></wui-text>
446
+ </wui-flex>
447
+
448
+ <wui-text variant="small-400" color="fg-200" align="center">
449
+ The code expires in 20 minutes
450
+ </wui-text>
451
+
452
+ <wui-flex alignItems="center" id="w3m-resend-section" gap="xs">
453
+ <wui-text variant="small-400" color="fg-100" align="center">
454
+ Didn't receive it?
455
+ </wui-text>
456
+ <wui-link @click=${this.onResendCode.bind(this)} .disabled=${this.loading}>
457
+ Resend email
458
+ </wui-link>
459
+ </wui-flex>
460
+ </wui-flex>
461
+ </wui-flex>
462
+ `;
463
+ }
464
+ async listenForDeviceApproval() {
465
+ if (this.authConnector)
466
+ try {
467
+ await this.authConnector.provider.connectDevice(), c.sendEvent({ type: "track", event: "DEVICE_REGISTERED_FOR_EMAIL" }), c.sendEvent({ type: "track", event: "EMAIL_VERIFICATION_CODE_SENT" }), l.replace("EmailVerifyOtp", { email: this.email });
468
+ } catch {
469
+ l.goBack();
470
+ }
471
+ }
472
+ async onResendCode() {
473
+ try {
474
+ if (!this.loading) {
475
+ if (!this.authConnector || !this.email)
476
+ throw new Error("w3m-email-login-widget: Unable to resend email");
477
+ this.loading = !0, await this.authConnector.provider.connectEmail({ email: this.email }), this.listenForDeviceApproval(), f.showSuccess("Code email resent");
478
+ }
479
+ } catch (e) {
480
+ f.showError(e);
481
+ } finally {
482
+ this.loading = !1;
483
+ }
484
+ }
485
+ };
486
+ y.styles = X;
487
+ U([
488
+ m()
489
+ ], y.prototype, "loading", void 0);
490
+ y = U([
491
+ d("w3m-email-verify-device-view")
492
+ ], y);
493
+ const Z = E`
494
+ wui-email-input {
495
+ width: 100%;
496
+ }
497
+
498
+ form {
499
+ width: 100%;
500
+ display: block;
501
+ position: relative;
502
+ }
503
+ `;
504
+ var T = function(a, e, t, n) {
505
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
506
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
507
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
508
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
509
+ };
510
+ let b = class extends v {
511
+ constructor() {
512
+ var e, t;
513
+ super(...arguments), this.formRef = H(), this.initialEmail = ((e = l.state.data) == null ? void 0 : e.email) ?? "", this.redirectView = (t = l.state.data) == null ? void 0 : t.redirectView, this.email = "", this.loading = !1;
514
+ }
515
+ firstUpdated() {
516
+ var e;
517
+ (e = this.formRef.value) == null || e.addEventListener("keydown", (t) => {
518
+ t.key === "Enter" && this.onSubmitEmail(t);
519
+ });
520
+ }
521
+ render() {
522
+ return u`
523
+ <wui-flex flexDirection="column" padding="m" gap="m">
524
+ <form ${q(this.formRef)} @submit=${this.onSubmitEmail.bind(this)}>
525
+ <wui-email-input
526
+ value=${this.initialEmail}
527
+ .disabled=${this.loading}
528
+ @inputChange=${this.onEmailInputChange.bind(this)}
529
+ >
530
+ </wui-email-input>
531
+ <input type="submit" hidden />
532
+ </form>
533
+ ${this.buttonsTemplate()}
534
+ </wui-flex>
535
+ `;
536
+ }
537
+ onEmailInputChange(e) {
538
+ this.email = e.detail;
539
+ }
540
+ async onSubmitEmail(e) {
541
+ try {
542
+ if (this.loading)
543
+ return;
544
+ this.loading = !0, e.preventDefault();
545
+ const t = h.getAuthConnector();
546
+ if (!t)
547
+ throw new Error("w3m-update-email-wallet: Auth connector not found");
548
+ const n = await t.provider.updateEmail({ email: this.email });
549
+ c.sendEvent({ type: "track", event: "EMAIL_EDIT" }), n.action === "VERIFY_SECONDARY_OTP" ? l.push("UpdateEmailSecondaryOtp", {
550
+ email: this.initialEmail,
551
+ newEmail: this.email,
552
+ redirectView: this.redirectView
553
+ }) : l.push("UpdateEmailPrimaryOtp", {
554
+ email: this.initialEmail,
555
+ newEmail: this.email,
556
+ redirectView: this.redirectView
557
+ });
558
+ } catch (t) {
559
+ f.showError(t), this.loading = !1;
560
+ }
561
+ }
562
+ buttonsTemplate() {
563
+ const e = !this.loading && this.email.length > 3 && this.email !== this.initialEmail;
564
+ return this.redirectView ? u`
565
+ <wui-flex gap="s">
566
+ <wui-button size="md" variant="neutral" fullWidth @click=${l.goBack}>
567
+ Cancel
568
+ </wui-button>
569
+
570
+ <wui-button
571
+ size="md"
572
+ variant="main"
573
+ fullWidth
574
+ @click=${this.onSubmitEmail.bind(this)}
575
+ .disabled=${!e}
576
+ .loading=${this.loading}
577
+ >
578
+ Save
579
+ </wui-button>
580
+ </wui-flex>
581
+ ` : u`
582
+ <wui-button
583
+ size="md"
584
+ variant="main"
585
+ fullWidth
586
+ @click=${this.onSubmitEmail.bind(this)}
587
+ .disabled=${!e}
588
+ .loading=${this.loading}
589
+ >
590
+ Save
591
+ </wui-button>
592
+ `;
593
+ }
594
+ };
595
+ b.styles = Z;
596
+ T([
597
+ m()
598
+ ], b.prototype, "email", void 0);
599
+ T([
600
+ m()
601
+ ], b.prototype, "loading", void 0);
602
+ b = T([
603
+ d("w3m-update-email-wallet-view")
604
+ ], b);
605
+ var ee = function(a, e, t, n) {
606
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
607
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
608
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
609
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
610
+ };
611
+ let W = class extends p {
612
+ constructor() {
613
+ var e;
614
+ super(), this.email = (e = l.state.data) == null ? void 0 : e.email, this.onOtpSubmit = async (t) => {
615
+ try {
616
+ this.authConnector && (await this.authConnector.provider.updateEmailPrimaryOtp({ otp: t }), c.sendEvent({ type: "track", event: "EMAIL_VERIFICATION_CODE_PASS" }), l.replace("UpdateEmailSecondaryOtp", l.state.data));
617
+ } catch (n) {
618
+ throw c.sendEvent({
619
+ type: "track",
620
+ event: "EMAIL_VERIFICATION_CODE_FAIL",
621
+ properties: { message: x.parseError(n) }
622
+ }), n;
623
+ }
624
+ }, this.onStartOver = () => {
625
+ l.replace("UpdateEmailWallet", l.state.data);
626
+ };
627
+ }
628
+ };
629
+ W = ee([
630
+ d("w3m-update-email-primary-otp-view")
631
+ ], W);
632
+ var te = function(a, e, t, n) {
633
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
634
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
635
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
636
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
637
+ };
638
+ let F = class extends p {
639
+ constructor() {
640
+ var e, t;
641
+ super(), this.email = (e = l.state.data) == null ? void 0 : e.newEmail, this.redirectView = (t = l.state.data) == null ? void 0 : t.redirectView, this.onOtpSubmit = async (n) => {
642
+ try {
643
+ this.authConnector && (await this.authConnector.provider.updateEmailSecondaryOtp({ otp: n }), c.sendEvent({ type: "track", event: "EMAIL_VERIFICATION_CODE_PASS" }), this.redirectView && l.reset(this.redirectView));
644
+ } catch (o) {
645
+ throw c.sendEvent({
646
+ type: "track",
647
+ event: "EMAIL_VERIFICATION_CODE_FAIL",
648
+ properties: { message: x.parseError(o) }
649
+ }), o;
650
+ }
651
+ }, this.onStartOver = () => {
652
+ l.replace("UpdateEmailWallet", l.state.data);
653
+ };
654
+ }
655
+ };
656
+ F = te([
657
+ d("w3m-update-email-secondary-otp-view")
658
+ ], F);
659
+ var k = function(a, e, t, n) {
660
+ var o = arguments.length, i = o < 3 ? e : n === null ? n = Object.getOwnPropertyDescriptor(e, t) : n, r;
661
+ if (typeof Reflect == "object" && typeof Reflect.decorate == "function") i = Reflect.decorate(a, e, t, n);
662
+ else for (var s = a.length - 1; s >= 0; s--) (r = a[s]) && (i = (o < 3 ? r(i) : o > 3 ? r(e, t, i) : r(e, t)) || i);
663
+ return o > 3 && i && Object.defineProperty(e, t, i), i;
664
+ };
665
+ let A = class extends v {
666
+ constructor() {
667
+ var e;
668
+ super(), this.authConnector = h.getAuthConnector(), this.isEmailEnabled = (e = R.state.remoteFeatures) == null ? void 0 : e.email, this.isAuthEnabled = this.checkIfAuthEnabled(h.state.connectors), this.connectors = h.state.connectors, h.subscribeKey("connectors", (t) => {
669
+ this.connectors = t, this.isAuthEnabled = this.checkIfAuthEnabled(this.connectors);
670
+ });
671
+ }
672
+ render() {
673
+ if (!this.isEmailEnabled)
674
+ throw new Error("w3m-email-login-view: Email is not enabled");
675
+ if (!this.isAuthEnabled)
676
+ throw new Error("w3m-email-login-view: No auth connector provided");
677
+ return u`<wui-flex
678
+ flexDirection="column"
679
+ .padding=${["3xs", "m", "m", "m"]}
680
+ gap="l"
681
+ >
682
+ <w3m-email-login-widget></w3m-email-login-widget>
683
+ </wui-flex> `;
684
+ }
685
+ checkIfAuthEnabled(e) {
686
+ const t = e.filter((o) => o.type === M.CONNECTOR_TYPE_AUTH).map((o) => o.chain);
687
+ return B.AUTH_CONNECTOR_SUPPORTED_CHAINS.some((o) => t.includes(o));
688
+ }
689
+ };
690
+ k([
691
+ m()
692
+ ], A.prototype, "connectors", void 0);
693
+ A = k([
694
+ d("w3m-email-login-view")
695
+ ], A);
696
+ export {
697
+ A as W3mEmailLoginView,
698
+ y as W3mEmailVerifyDeviceView,
699
+ L as W3mEmailVerifyOtpView,
700
+ W as W3mUpdateEmailPrimaryOtpView,
701
+ F as W3mUpdateEmailSecondaryOtpView,
702
+ b as W3mUpdateEmailWalletView
703
+ };