@openfort/react 0.3.2 → 1.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (692) hide show
  1. package/build/assets/browsers.js +13 -0
  2. package/build/assets/browsers.js.map +1 -0
  3. package/build/assets/chains.js +139 -0
  4. package/build/assets/chains.js.map +1 -0
  5. package/build/assets/icons.js +41 -0
  6. package/build/assets/icons.js.map +1 -0
  7. package/build/assets/logos.js +173 -0
  8. package/build/assets/logos.js.map +1 -0
  9. package/build/assets/wave.js +6 -0
  10. package/build/assets/wave.js.map +1 -0
  11. package/build/components/BalanceButton/index.js +89 -0
  12. package/build/components/BalanceButton/index.js.map +1 -0
  13. package/build/components/Common/Alert/index.js +10 -0
  14. package/build/components/Common/Alert/index.js.map +1 -0
  15. package/build/components/Common/Alert/styles.js +55 -0
  16. package/build/components/Common/Alert/styles.js.map +1 -0
  17. package/build/components/Common/Avatar/index.d.ts +11 -3
  18. package/build/components/Common/Avatar/index.js +100 -0
  19. package/build/components/Common/Avatar/index.js.map +1 -0
  20. package/build/components/Common/Avatar/styles.js +59 -0
  21. package/build/components/Common/Avatar/styles.js.map +1 -0
  22. package/build/components/Common/BrowserIcon/index.js +28 -0
  23. package/build/components/Common/BrowserIcon/index.js.map +1 -0
  24. package/build/components/Common/BrowserIcon/styles.js +20 -0
  25. package/build/components/Common/BrowserIcon/styles.js.map +1 -0
  26. package/build/components/Common/Button/index.js +36 -0
  27. package/build/components/Common/Button/index.js.map +1 -0
  28. package/build/components/Common/Button/styles.js +302 -0
  29. package/build/components/Common/Button/styles.js.map +1 -0
  30. package/build/components/Common/Button/types.d.ts +1 -0
  31. package/build/components/Common/Chain/index.d.ts +8 -0
  32. package/build/components/Common/Chain/index.js +38 -0
  33. package/build/components/Common/Chain/index.js.map +1 -0
  34. package/build/components/Common/Chain/styles.js +94 -0
  35. package/build/components/Common/Chain/styles.js.map +1 -0
  36. package/build/components/Common/ConnectorList/index.js +58 -0
  37. package/build/components/Common/ConnectorList/index.js.map +1 -0
  38. package/build/components/Common/ConnectorList/styles.js +324 -0
  39. package/build/components/Common/ConnectorList/styles.js.map +1 -0
  40. package/build/components/Common/CopyToClipboard/CopyButton.js +12 -0
  41. package/build/components/Common/CopyToClipboard/CopyButton.js.map +1 -0
  42. package/build/components/Common/CopyToClipboard/CopyIcon.js +76 -0
  43. package/build/components/Common/CopyToClipboard/CopyIcon.js.map +1 -0
  44. package/build/components/Common/CopyToClipboard/CopyIconButton.js +38 -0
  45. package/build/components/Common/CopyToClipboard/CopyIconButton.js.map +1 -0
  46. package/build/components/Common/CopyToClipboard/CopyText.js +26 -0
  47. package/build/components/Common/CopyToClipboard/CopyText.js.map +1 -0
  48. package/build/components/Common/CustomQRCode/QRCode.js +60 -0
  49. package/build/components/Common/CustomQRCode/QRCode.js.map +1 -0
  50. package/build/components/Common/CustomQRCode/index.js +22 -0
  51. package/build/components/Common/CustomQRCode/index.js.map +1 -0
  52. package/build/components/Common/CustomQRCode/styles.js +155 -0
  53. package/build/components/Common/CustomQRCode/styles.js.map +1 -0
  54. package/build/components/Common/FitText/index.js +28 -0
  55. package/build/components/Common/FitText/index.js.map +1 -0
  56. package/build/components/Common/Input/index.js +17 -0
  57. package/build/components/Common/Input/index.js.map +1 -0
  58. package/build/components/Common/Input/styles.js +53 -0
  59. package/build/components/Common/Input/styles.js.map +1 -0
  60. package/build/components/Common/LargeButton/index.js +10 -0
  61. package/build/components/Common/LargeButton/index.js.map +1 -0
  62. package/build/components/Common/LargeButton/styles.js +69 -0
  63. package/build/components/Common/LargeButton/styles.js.map +1 -0
  64. package/build/components/Common/Loading/index.js +96 -0
  65. package/build/components/Common/Loading/index.js.map +1 -0
  66. package/build/components/Common/Modal/index.js +272 -0
  67. package/build/components/Common/Modal/index.js.map +1 -0
  68. package/build/components/Common/Modal/styles.d.ts +0 -1
  69. package/build/components/Common/Modal/styles.js +657 -0
  70. package/build/components/Common/Modal/styles.js.map +1 -0
  71. package/build/components/Common/OTPInput/index.js +108 -0
  72. package/build/components/Common/OTPInput/index.js.map +1 -0
  73. package/build/components/Common/OTPInput/styles.js +153 -0
  74. package/build/components/Common/OTPInput/styles.js.map +1 -0
  75. package/build/components/Common/Portal/index.js +31 -0
  76. package/build/components/Common/Portal/index.js.map +1 -0
  77. package/build/components/Common/PoweredByFooter/index.js +103 -0
  78. package/build/components/Common/PoweredByFooter/index.js.map +1 -0
  79. package/build/components/Common/Providers/ProviderHeader.d.ts +2 -2
  80. package/build/components/Common/Providers/ProviderHeader.js +55 -0
  81. package/build/components/Common/Providers/ProviderHeader.js.map +1 -0
  82. package/build/components/Common/Providers/ProviderIcon.d.ts +2 -2
  83. package/build/components/Common/Providers/ProviderIcon.js +41 -0
  84. package/build/components/Common/Providers/ProviderIcon.js.map +1 -0
  85. package/build/components/Common/Providers/getProviderName.d.ts +1 -1
  86. package/build/components/Common/Providers/getProviderName.js +15 -0
  87. package/build/components/Common/Providers/getProviderName.js.map +1 -0
  88. package/build/components/Common/ScrollArea/index.js +58 -0
  89. package/build/components/Common/ScrollArea/index.js.map +1 -0
  90. package/build/components/Common/ScrollArea/styles.js +168 -0
  91. package/build/components/Common/ScrollArea/styles.js.map +1 -0
  92. package/build/components/Common/Spinner/index.js +24 -0
  93. package/build/components/Common/Spinner/index.js.map +1 -0
  94. package/build/components/Common/Spinner/styles.js +22 -0
  95. package/build/components/Common/Spinner/styles.js.map +1 -0
  96. package/build/components/Common/SquircleSpinner/index.js +15 -0
  97. package/build/components/Common/SquircleSpinner/index.js.map +1 -0
  98. package/build/components/Common/SquircleSpinner/styles.js +66 -0
  99. package/build/components/Common/SquircleSpinner/styles.js.map +1 -0
  100. package/build/components/Common/ThemedButton/index.js +25 -0
  101. package/build/components/Common/ThemedButton/index.js.map +1 -0
  102. package/build/components/Common/ThemedButton/styles.js +152 -0
  103. package/build/components/Common/ThemedButton/styles.js.map +1 -0
  104. package/build/components/Common/TickList/index.js +11 -0
  105. package/build/components/Common/TickList/index.js.map +1 -0
  106. package/build/components/Common/TickList/styles.js +28 -0
  107. package/build/components/Common/TickList/styles.js.map +1 -0
  108. package/build/components/Common/Tooltip/index.js +91 -0
  109. package/build/components/Common/Tooltip/index.js.map +1 -0
  110. package/build/components/Common/Tooltip/styles.js +81 -0
  111. package/build/components/Common/Tooltip/styles.js.map +1 -0
  112. package/build/components/Common/WalletRecoveryIcon/index.d.ts +4 -0
  113. package/build/components/Common/WalletRecoveryIcon/index.js +19 -0
  114. package/build/components/Common/WalletRecoveryIcon/index.js.map +1 -0
  115. package/build/components/ConnectButton/index.d.ts +12 -4
  116. package/build/components/ConnectButton/index.js +266 -0
  117. package/build/components/ConnectButton/index.js.map +1 -0
  118. package/build/components/ConnectButton/styles.js +50 -0
  119. package/build/components/ConnectButton/styles.js.map +1 -0
  120. package/build/components/ConnectKitThemeProvider/ConnectKitThemeProvider.js +20 -0
  121. package/build/components/ConnectKitThemeProvider/ConnectKitThemeProvider.js.map +1 -0
  122. package/build/components/ConnectModal/ConnectUsing.d.ts +1 -1
  123. package/build/components/ConnectModal/ConnectUsing.js +68 -0
  124. package/build/components/ConnectModal/ConnectUsing.js.map +1 -0
  125. package/build/components/ConnectModal/ConnectWithInjector/CircleSpinner/index.js +17 -0
  126. package/build/components/ConnectModal/ConnectWithInjector/CircleSpinner/index.js.map +1 -0
  127. package/build/components/ConnectModal/ConnectWithInjector/CircleSpinner/styles.js +118 -0
  128. package/build/components/ConnectModal/ConnectWithInjector/CircleSpinner/styles.js.map +1 -0
  129. package/build/components/ConnectModal/ConnectWithInjector/index.d.ts +0 -2
  130. package/build/components/ConnectModal/ConnectWithInjector/index.js +295 -0
  131. package/build/components/ConnectModal/ConnectWithInjector/index.js.map +1 -0
  132. package/build/components/ConnectModal/ConnectWithInjector/styles.js +133 -0
  133. package/build/components/ConnectModal/ConnectWithInjector/styles.js.map +1 -0
  134. package/build/components/ConnectModal/ConnectWithMobile.js +99 -0
  135. package/build/components/ConnectModal/ConnectWithMobile.js.map +1 -0
  136. package/build/components/ConnectModal/ConnectWithOAuth.js +128 -0
  137. package/build/components/ConnectModal/ConnectWithOAuth.js.map +1 -0
  138. package/build/components/ConnectModal/ConnectWithQRCode.js +78 -0
  139. package/build/components/ConnectModal/ConnectWithQRCode.js.map +1 -0
  140. package/build/components/ConnectModal/index.js +227 -0
  141. package/build/components/ConnectModal/index.js.map +1 -0
  142. package/build/components/FloatingGraphic/index.js +13 -0
  143. package/build/components/FloatingGraphic/index.js.map +1 -0
  144. package/build/components/FloatingGraphic/styles.js +175 -0
  145. package/build/components/FloatingGraphic/styles.js.map +1 -0
  146. package/build/components/Openfort/OpenfortProvider.d.ts +10 -25
  147. package/build/components/Openfort/OpenfortProvider.js +351 -0
  148. package/build/components/Openfort/OpenfortProvider.js.map +1 -0
  149. package/build/components/Openfort/context.d.ts +48 -5
  150. package/build/components/Openfort/context.js +7 -0
  151. package/build/components/Openfort/context.js.map +1 -0
  152. package/build/components/Openfort/routeHelpers.d.ts +5 -0
  153. package/build/components/Openfort/routeHelpers.js +20 -0
  154. package/build/components/Openfort/routeHelpers.js.map +1 -0
  155. package/build/components/Openfort/types.d.ts +57 -23
  156. package/build/components/Openfort/types.js +119 -0
  157. package/build/components/Openfort/types.js.map +1 -0
  158. package/build/components/Openfort/useOpenfort.d.ts +2 -0
  159. package/build/components/Openfort/useOpenfort.js +12 -0
  160. package/build/components/Openfort/useOpenfort.js.map +1 -0
  161. package/build/components/PageContent/index.js +55 -0
  162. package/build/components/PageContent/index.js.map +1 -0
  163. package/build/components/PageContent/styles.js +11 -0
  164. package/build/components/PageContent/styles.js.map +1 -0
  165. package/build/components/Pages/About/graphics.js +193 -0
  166. package/build/components/Pages/About/graphics.js.map +1 -0
  167. package/build/components/Pages/About/index.js +142 -0
  168. package/build/components/Pages/About/index.js.map +1 -0
  169. package/build/components/Pages/About/styles.js +142 -0
  170. package/build/components/Pages/About/styles.js.map +1 -0
  171. package/build/components/Pages/AssetInventory/index.js +66 -0
  172. package/build/components/Pages/AssetInventory/index.js.map +1 -0
  173. package/build/components/Pages/Buy/coinbaseApi.js +106 -0
  174. package/build/components/Pages/Buy/coinbaseApi.js.map +1 -0
  175. package/build/components/Pages/Buy/index.js +88 -0
  176. package/build/components/Pages/Buy/index.js.map +1 -0
  177. package/build/components/Pages/Buy/onrampApi.js +57 -0
  178. package/build/components/Pages/Buy/onrampApi.js.map +1 -0
  179. package/build/components/Pages/Buy/providers.js +39 -0
  180. package/build/components/Pages/Buy/providers.js.map +1 -0
  181. package/build/components/Pages/Buy/stripeApi.js +74 -0
  182. package/build/components/Pages/Buy/stripeApi.js.map +1 -0
  183. package/build/components/Pages/Buy/styles.js +230 -0
  184. package/build/components/Pages/Buy/styles.js.map +1 -0
  185. package/build/components/Pages/Buy/utils.js +71 -0
  186. package/build/components/Pages/Buy/utils.js.map +1 -0
  187. package/build/components/Pages/BuyComplete/index.js +47 -0
  188. package/build/components/Pages/BuyComplete/index.js.map +1 -0
  189. package/build/components/Pages/BuyProcessing/index.js +231 -0
  190. package/build/components/Pages/BuyProcessing/index.js.map +1 -0
  191. package/build/components/Pages/BuyProviderSelect/index.js +55 -0
  192. package/build/components/Pages/BuyProviderSelect/index.js.map +1 -0
  193. package/build/components/Pages/BuyProviderSelect/styles.js +103 -0
  194. package/build/components/Pages/BuyProviderSelect/styles.js.map +1 -0
  195. package/build/components/Pages/BuySelectProvider/index.js +245 -0
  196. package/build/components/Pages/BuySelectProvider/index.js.map +1 -0
  197. package/build/components/Pages/Connected/ConnectedPageLayout.d.ts +22 -0
  198. package/build/components/Pages/Connected/ConnectedPageLayout.js +11 -0
  199. package/build/components/Pages/Connected/ConnectedPageLayout.js.map +1 -0
  200. package/build/components/Pages/Connected/EthereumConnected.d.ts +3 -0
  201. package/build/components/Pages/Connected/EthereumConnected.js +133 -0
  202. package/build/components/Pages/Connected/EthereumConnected.js.map +1 -0
  203. package/build/components/Pages/Connected/SolanaConnected.d.ts +3 -0
  204. package/build/components/Pages/Connected/SolanaConnected.js +96 -0
  205. package/build/components/Pages/Connected/SolanaConnected.js.map +1 -0
  206. package/build/components/Pages/Connected/index.d.ts +2 -2
  207. package/build/components/Pages/Connected/index.js +18 -0
  208. package/build/components/Pages/Connected/index.js.map +1 -0
  209. package/build/components/Pages/Connected/styles.js +122 -0
  210. package/build/components/Pages/Connected/styles.js.map +1 -0
  211. package/build/components/Pages/ConnectedSuccess/index.js +19 -0
  212. package/build/components/Pages/ConnectedSuccess/index.js.map +1 -0
  213. package/build/components/Pages/Connectors/index.js +73 -0
  214. package/build/components/Pages/Connectors/index.js.map +1 -0
  215. package/build/components/Pages/CreateGuestUserPage/index.js +28 -0
  216. package/build/components/Pages/CreateGuestUserPage/index.js.map +1 -0
  217. package/build/components/Pages/CreateWallet/SolanaCreateWallet.d.ts +6 -0
  218. package/build/components/Pages/CreateWallet/SolanaCreateWallet.js +241 -0
  219. package/build/components/Pages/CreateWallet/SolanaCreateWallet.js.map +1 -0
  220. package/build/components/Pages/CreateWallet/index.js +303 -0
  221. package/build/components/Pages/CreateWallet/index.js.map +1 -0
  222. package/build/components/Pages/CreateWallet/styles.js +17 -0
  223. package/build/components/Pages/CreateWallet/styles.js.map +1 -0
  224. package/build/components/Pages/DownloadApp/index.js +32 -0
  225. package/build/components/Pages/DownloadApp/index.js.map +1 -0
  226. package/build/components/Pages/EmailLogin/index.js +118 -0
  227. package/build/components/Pages/EmailLogin/index.js.map +1 -0
  228. package/build/components/Pages/EmailLogin/styles.js +24 -0
  229. package/build/components/Pages/EmailLogin/styles.js.map +1 -0
  230. package/build/components/Pages/EmailOTP/index.js +116 -0
  231. package/build/components/Pages/EmailOTP/index.js.map +1 -0
  232. package/build/components/Pages/EmailOTP/styles.js +38 -0
  233. package/build/components/Pages/EmailOTP/styles.js.map +1 -0
  234. package/build/components/Pages/EmailVerification/index.js +86 -0
  235. package/build/components/Pages/EmailVerification/index.js.map +1 -0
  236. package/build/components/Pages/ExportKey/index.js +44 -0
  237. package/build/components/Pages/ExportKey/index.js.map +1 -0
  238. package/build/components/Pages/ForgotPassword/index.js +129 -0
  239. package/build/components/Pages/ForgotPassword/index.js.map +1 -0
  240. package/build/components/Pages/LinkEmail/index.js +63 -0
  241. package/build/components/Pages/LinkEmail/index.js.map +1 -0
  242. package/build/components/Pages/LinkedProvider/index.d.ts +3 -0
  243. package/build/components/Pages/LinkedProvider/index.js +90 -0
  244. package/build/components/Pages/LinkedProvider/index.js.map +1 -0
  245. package/build/components/Pages/LinkedProviders/index.js +45 -0
  246. package/build/components/Pages/LinkedProviders/index.js.map +1 -0
  247. package/build/components/Pages/LinkedProviders/styles.js +51 -0
  248. package/build/components/Pages/LinkedProviders/styles.js.map +1 -0
  249. package/build/components/Pages/LoadWallets/index.js +91 -0
  250. package/build/components/Pages/LoadWallets/index.js.map +1 -0
  251. package/build/components/Pages/Loading/index.js +61 -0
  252. package/build/components/Pages/Loading/index.js.map +1 -0
  253. package/build/components/Pages/MobileConnectors/index.js +71 -0
  254. package/build/components/Pages/MobileConnectors/index.js.map +1 -0
  255. package/build/components/Pages/MobileConnectors/styles.js +65 -0
  256. package/build/components/Pages/MobileConnectors/styles.js.map +1 -0
  257. package/build/components/Pages/NoAssetsAvailable/index.js +45 -0
  258. package/build/components/Pages/NoAssetsAvailable/index.js.map +1 -0
  259. package/build/components/Pages/NoAssetsAvailable/styles.js +10 -0
  260. package/build/components/Pages/NoAssetsAvailable/styles.js.map +1 -0
  261. package/build/components/Pages/Onboarding/index.js +20 -0
  262. package/build/components/Pages/Onboarding/index.js.map +1 -0
  263. package/build/components/Pages/PhoneOTP/index.js +128 -0
  264. package/build/components/Pages/PhoneOTP/index.js.map +1 -0
  265. package/build/components/Pages/PhoneOTP/styles.js +38 -0
  266. package/build/components/Pages/PhoneOTP/styles.js.map +1 -0
  267. package/build/components/Pages/Profile/index.js +35 -0
  268. package/build/components/Pages/Profile/index.js.map +1 -0
  269. package/build/components/Pages/Providers/index.js +157 -0
  270. package/build/components/Pages/Providers/index.js.map +1 -0
  271. package/build/components/Pages/Providers/styles.js +156 -0
  272. package/build/components/Pages/Providers/styles.js.map +1 -0
  273. package/build/components/Pages/Receive/index.js +61 -0
  274. package/build/components/Pages/Receive/index.js.map +1 -0
  275. package/build/components/Pages/Receive/styles.d.ts +1 -0
  276. package/build/components/Pages/Receive/styles.js +52 -0
  277. package/build/components/Pages/Receive/styles.js.map +1 -0
  278. package/build/components/Pages/Recover/index.js +252 -0
  279. package/build/components/Pages/Recover/index.js.map +1 -0
  280. package/build/components/Pages/Recover/recoveryRegistry.d.ts +32 -0
  281. package/build/components/Pages/Recover/recoveryRegistry.js +61 -0
  282. package/build/components/Pages/Recover/recoveryRegistry.js.map +1 -0
  283. package/build/components/Pages/RemoveLinkedProvider/index.js +104 -0
  284. package/build/components/Pages/RemoveLinkedProvider/index.js.map +1 -0
  285. package/build/components/Pages/SelectToken/index.js +102 -0
  286. package/build/components/Pages/SelectToken/index.js.map +1 -0
  287. package/build/components/Pages/SelectToken/styles.js +78 -0
  288. package/build/components/Pages/SelectToken/styles.js.map +1 -0
  289. package/build/components/Pages/SelectWalletToRecover/index.d.ts +1 -2
  290. package/build/components/Pages/SelectWalletToRecover/index.js +70 -0
  291. package/build/components/Pages/SelectWalletToRecover/index.js.map +1 -0
  292. package/build/components/Pages/Send/EthereumSend.d.ts +1 -0
  293. package/build/components/Pages/Send/EthereumSend.js +88 -0
  294. package/build/components/Pages/Send/EthereumSend.js.map +1 -0
  295. package/build/components/Pages/Send/index.d.ts +7 -1
  296. package/build/components/Pages/Send/index.js +17 -0
  297. package/build/components/Pages/Send/index.js.map +1 -0
  298. package/build/components/Pages/Send/styles.js +112 -0
  299. package/build/components/Pages/Send/styles.js.map +1 -0
  300. package/build/components/Pages/Send/utils.d.ts +1 -1
  301. package/build/components/Pages/Send/utils.js +63 -0
  302. package/build/components/Pages/Send/utils.js.map +1 -0
  303. package/build/components/Pages/SendConfirmation/EstimatedFees.js +66 -0
  304. package/build/components/Pages/SendConfirmation/EstimatedFees.js.map +1 -0
  305. package/build/components/Pages/SendConfirmation/index.js +331 -0
  306. package/build/components/Pages/SendConfirmation/index.js.map +1 -0
  307. package/build/components/Pages/SendConfirmation/styles.js +129 -0
  308. package/build/components/Pages/SendConfirmation/styles.js.map +1 -0
  309. package/build/components/Pages/SocialProviders/index.js +15 -0
  310. package/build/components/Pages/SocialProviders/index.js.map +1 -0
  311. package/build/components/PasswordStrength/PasswordStrengthIndicator.js +62 -0
  312. package/build/components/PasswordStrength/PasswordStrengthIndicator.js.map +1 -0
  313. package/build/components/PasswordStrength/password-utility.js +128 -0
  314. package/build/components/PasswordStrength/password-utility.js.map +1 -0
  315. package/build/constants/chainConfigs.js +316 -0
  316. package/build/constants/chainConfigs.js.map +1 -0
  317. package/build/constants/defaultTheme.js +6 -0
  318. package/build/constants/defaultTheme.js.map +1 -0
  319. package/build/constants/openfort.d.ts +4 -0
  320. package/build/constants/openfort.js +8 -0
  321. package/build/constants/openfort.js.map +1 -0
  322. package/build/core/ConnectionStrategy.d.ts +31 -0
  323. package/build/core/ConnectionStrategy.js +9 -0
  324. package/build/core/ConnectionStrategy.js.map +1 -0
  325. package/build/core/ConnectionStrategyContext.d.ts +16 -0
  326. package/build/core/ConnectionStrategyContext.js +22 -0
  327. package/build/core/ConnectionStrategyContext.js.map +1 -0
  328. package/build/core/errors.d.ts +1 -0
  329. package/build/core/strategies/EthereumBridgeStrategy.d.ts +11 -0
  330. package/build/core/strategies/EthereumBridgeStrategy.js +83 -0
  331. package/build/core/strategies/EthereumBridgeStrategy.js.map +1 -0
  332. package/build/core/strategies/EthereumEmbeddedStrategy.d.ts +8 -0
  333. package/build/core/strategies/EthereumEmbeddedStrategy.js +85 -0
  334. package/build/core/strategies/EthereumEmbeddedStrategy.js.map +1 -0
  335. package/build/core/strategies/SolanaEmbeddedStrategy.d.ts +9 -0
  336. package/build/core/strategies/SolanaEmbeddedStrategy.js +53 -0
  337. package/build/core/strategies/SolanaEmbeddedStrategy.js.map +1 -0
  338. package/build/core/strategyUtils.d.ts +6 -0
  339. package/build/core/strategyUtils.js +31 -0
  340. package/build/core/strategyUtils.js.map +1 -0
  341. package/build/ethereum/OpenfortEthereumBridgeContext.d.ts +87 -0
  342. package/build/ethereum/OpenfortEthereumBridgeContext.js +18 -0
  343. package/build/ethereum/OpenfortEthereumBridgeContext.js.map +1 -0
  344. package/build/ethereum/hooks/getEmbeddedWalletClient.d.ts +14 -0
  345. package/build/ethereum/hooks/getEmbeddedWalletClient.js +24 -0
  346. package/build/ethereum/hooks/getEmbeddedWalletClient.js.map +1 -0
  347. package/build/ethereum/hooks/useEthereumEmbeddedWallet.d.ts +17 -0
  348. package/build/ethereum/hooks/useEthereumEmbeddedWallet.js +425 -0
  349. package/build/ethereum/hooks/useEthereumEmbeddedWallet.js.map +1 -0
  350. package/build/ethereum/hooks/useEthereumWalletAssets.d.ts +29 -0
  351. package/build/ethereum/hooks/useEthereumWalletAssets.js +204 -0
  352. package/build/ethereum/hooks/useEthereumWalletAssets.js.map +1 -0
  353. package/build/ethereum/index.d.ts +11 -0
  354. package/build/ethereum/index.js +3 -0
  355. package/build/ethereum/index.js.map +1 -0
  356. package/build/ethereum/types.d.ts +140 -0
  357. package/build/hooks/openfort/auth/requestEmailVerification.js +21 -0
  358. package/build/hooks/openfort/auth/requestEmailVerification.js.map +1 -0
  359. package/build/hooks/openfort/auth/status.js +11 -0
  360. package/build/hooks/openfort/auth/status.js.map +1 -0
  361. package/build/hooks/openfort/auth/useAuthCallback.d.ts +2 -1
  362. package/build/hooks/openfort/auth/useAuthCallback.js +197 -0
  363. package/build/hooks/openfort/auth/useAuthCallback.js.map +1 -0
  364. package/build/hooks/openfort/auth/useConnectToWalletPostAuth.d.ts +2 -2
  365. package/build/hooks/openfort/auth/useConnectToWalletPostAuth.js +161 -0
  366. package/build/hooks/openfort/auth/useConnectToWalletPostAuth.js.map +1 -0
  367. package/build/hooks/openfort/auth/useEmailAuth.d.ts +4 -3
  368. package/build/hooks/openfort/auth/useEmailAuth.js +496 -0
  369. package/build/hooks/openfort/auth/useEmailAuth.js.map +1 -0
  370. package/build/hooks/openfort/auth/useEmailOtpAuth.d.ts +4 -3
  371. package/build/hooks/openfort/auth/useEmailOtpAuth.js +151 -0
  372. package/build/hooks/openfort/auth/useEmailOtpAuth.js.map +1 -0
  373. package/build/hooks/openfort/auth/useGuestAuth.d.ts +4 -3
  374. package/build/hooks/openfort/auth/useGuestAuth.js +142 -0
  375. package/build/hooks/openfort/auth/useGuestAuth.js.map +1 -0
  376. package/build/hooks/openfort/auth/useOAuth.d.ts +4 -3
  377. package/build/hooks/openfort/auth/useOAuth.js +217 -0
  378. package/build/hooks/openfort/auth/useOAuth.js.map +1 -0
  379. package/build/hooks/openfort/auth/usePhoneOtpAuth.d.ts +4 -3
  380. package/build/hooks/openfort/auth/usePhoneOtpAuth.js +174 -0
  381. package/build/hooks/openfort/auth/usePhoneOtpAuth.js.map +1 -0
  382. package/build/hooks/openfort/auth/useSignOut.d.ts +2 -1
  383. package/build/hooks/openfort/auth/useSignOut.js +104 -0
  384. package/build/hooks/openfort/auth/useSignOut.js.map +1 -0
  385. package/build/hooks/openfort/hookConsistency.js +17 -0
  386. package/build/hooks/openfort/hookConsistency.js.map +1 -0
  387. package/build/hooks/openfort/use7702Authorization.js +73 -0
  388. package/build/hooks/openfort/use7702Authorization.js.map +1 -0
  389. package/build/hooks/openfort/useGrantPermissions.d.ts +7 -76
  390. package/build/hooks/openfort/useGrantPermissions.js +221 -0
  391. package/build/hooks/openfort/useGrantPermissions.js.map +1 -0
  392. package/build/hooks/openfort/useProviders.js +75 -0
  393. package/build/hooks/openfort/useProviders.js.map +1 -0
  394. package/build/hooks/openfort/useRevokePermissions.d.ts +2 -1
  395. package/build/hooks/openfort/useRevokePermissions.js +126 -0
  396. package/build/hooks/openfort/useRevokePermissions.js.map +1 -0
  397. package/build/hooks/openfort/useUI.d.ts +4 -45
  398. package/build/hooks/openfort/useUI.js +122 -0
  399. package/build/hooks/openfort/useUI.js.map +1 -0
  400. package/build/hooks/openfort/useUser.d.ts +12 -35
  401. package/build/hooks/openfort/useUser.js +61 -0
  402. package/build/hooks/openfort/useUser.js.map +1 -0
  403. package/build/hooks/openfort/walletTypes.d.ts +32 -0
  404. package/build/hooks/openfort/walletTypes.js +53 -0
  405. package/build/hooks/openfort/walletTypes.js.map +1 -0
  406. package/build/hooks/useBalance.d.ts +50 -0
  407. package/build/hooks/useBalance.js +80 -0
  408. package/build/hooks/useBalance.js.map +1 -0
  409. package/build/hooks/useConnectLifecycle.d.ts +7 -0
  410. package/build/hooks/useConnectLifecycle.js +43 -0
  411. package/build/hooks/useConnectLifecycle.js.map +1 -0
  412. package/build/hooks/useConnectors.d.ts +3 -5
  413. package/build/hooks/useConnectors.js +26 -0
  414. package/build/hooks/useConnectors.js.map +1 -0
  415. package/build/hooks/useCopyToClipboard.js +29 -0
  416. package/build/hooks/useCopyToClipboard.js.map +1 -0
  417. package/build/hooks/useFitText.js +125 -0
  418. package/build/hooks/useFitText.js.map +1 -0
  419. package/build/hooks/useFocusTrap.d.ts +4 -1
  420. package/build/hooks/useFocusTrap.js +60 -0
  421. package/build/hooks/useFocusTrap.js.map +1 -0
  422. package/build/hooks/useGoogleFont.js +43 -0
  423. package/build/hooks/useGoogleFont.js.map +1 -0
  424. package/build/hooks/useIsMobile.js +17 -0
  425. package/build/hooks/useIsMobile.js.map +1 -0
  426. package/build/hooks/useIsMounted.js +10 -0
  427. package/build/hooks/useIsMounted.js.map +1 -0
  428. package/build/hooks/useLastConnector.js +39 -0
  429. package/build/hooks/useLastConnector.js.map +1 -0
  430. package/build/hooks/useLocales.d.ts +1 -1
  431. package/build/hooks/useLocales.js +68 -0
  432. package/build/hooks/useLocales.js.map +1 -0
  433. package/build/hooks/useLockBodyScroll.js +53 -0
  434. package/build/hooks/useLockBodyScroll.js.map +1 -0
  435. package/build/hooks/usePrevious.js +14 -0
  436. package/build/hooks/usePrevious.js.map +1 -0
  437. package/build/hooks/useResolvedIdentity.d.ts +70 -0
  438. package/build/hooks/useResolvedIdentity.js +90 -0
  439. package/build/hooks/useResolvedIdentity.js.map +1 -0
  440. package/build/hooks/useRouteProps.d.ts +10 -5
  441. package/build/hooks/useRouteProps.js +27 -0
  442. package/build/hooks/useRouteProps.js.map +1 -0
  443. package/build/hooks/useWalletConnectModal.js +59 -0
  444. package/build/hooks/useWalletConnectModal.js.map +1 -0
  445. package/build/hooks/useWindowSize.js +23 -0
  446. package/build/hooks/useWindowSize.js.map +1 -0
  447. package/build/index.d.ts +61 -16
  448. package/build/index.js +31 -0
  449. package/build/index.js.map +1 -0
  450. package/build/localizations/index.js +57 -0
  451. package/build/localizations/index.js.map +1 -0
  452. package/build/localizations/locales/ar-AE.js +100 -0
  453. package/build/localizations/locales/ar-AE.js.map +1 -0
  454. package/build/localizations/locales/ca-AD.js +98 -0
  455. package/build/localizations/locales/ca-AD.js.map +1 -0
  456. package/build/localizations/locales/ee-EE.js +98 -0
  457. package/build/localizations/locales/ee-EE.js.map +1 -0
  458. package/build/localizations/locales/en-US.js +115 -0
  459. package/build/localizations/locales/en-US.js.map +1 -0
  460. package/build/localizations/locales/es-ES.js +98 -0
  461. package/build/localizations/locales/es-ES.js.map +1 -0
  462. package/build/localizations/locales/fa-IR.js +98 -0
  463. package/build/localizations/locales/fa-IR.js.map +1 -0
  464. package/build/localizations/locales/fr-FR.js +98 -0
  465. package/build/localizations/locales/fr-FR.js.map +1 -0
  466. package/build/localizations/locales/ja-JP.js +98 -0
  467. package/build/localizations/locales/ja-JP.js.map +1 -0
  468. package/build/localizations/locales/pt-BR.js +98 -0
  469. package/build/localizations/locales/pt-BR.js.map +1 -0
  470. package/build/localizations/locales/ru-RU.js +98 -0
  471. package/build/localizations/locales/ru-RU.js.map +1 -0
  472. package/build/localizations/locales/tr-TR.js +98 -0
  473. package/build/localizations/locales/tr-TR.js.map +1 -0
  474. package/build/localizations/locales/vi-VN.js +98 -0
  475. package/build/localizations/locales/vi-VN.js.map +1 -0
  476. package/build/localizations/locales/zh-CN.js +98 -0
  477. package/build/localizations/locales/zh-CN.js.map +1 -0
  478. package/build/openfort/CoreOpenfortProvider.d.ts +9 -22
  479. package/build/openfort/CoreOpenfortProvider.js +389 -0
  480. package/build/openfort/CoreOpenfortProvider.js.map +1 -0
  481. package/build/{hooks/useConnectCallback.d.ts → openfort/connectCallbackTypes.d.ts} +2 -2
  482. package/build/openfort/context.d.ts +3 -2
  483. package/build/openfort/context.js +6 -0
  484. package/build/openfort/context.js.map +1 -0
  485. package/build/openfort/core/client.d.ts +2 -1
  486. package/build/openfort/core/client.js +23 -0
  487. package/build/openfort/core/client.js.map +1 -0
  488. package/build/openfort/hooks/useActiveAddressSync.d.ts +20 -0
  489. package/build/openfort/hooks/useActiveAddressSync.js +76 -0
  490. package/build/openfort/hooks/useActiveAddressSync.js.map +1 -0
  491. package/build/openfort/hooks/useAutoRecovery.d.ts +26 -0
  492. package/build/openfort/hooks/useAutoRecovery.js +102 -0
  493. package/build/openfort/hooks/useAutoRecovery.js.map +1 -0
  494. package/build/openfort/hooks/useEmbeddedStateMachine.d.ts +31 -0
  495. package/build/openfort/hooks/useEmbeddedStateMachine.js +77 -0
  496. package/build/openfort/hooks/useEmbeddedStateMachine.js.map +1 -0
  497. package/build/openfort/selectors.d.ts +9 -0
  498. package/build/openfort/selectors.js +15 -0
  499. package/build/openfort/selectors.js.map +1 -0
  500. package/build/openfort/store.d.ts +46 -0
  501. package/build/openfort/store.js +116 -0
  502. package/build/openfort/store.js.map +1 -0
  503. package/build/openfort/useOpenfort.d.ts +9 -3
  504. package/build/openfort/useOpenfort.js +15 -0
  505. package/build/openfort/useOpenfort.js.map +1 -0
  506. package/build/openfort/useOpenfortStore.d.ts +2 -0
  507. package/build/openfort/useOpenfortStore.js +13 -0
  508. package/build/openfort/useOpenfortStore.js.map +1 -0
  509. package/build/query/index.d.ts +2 -0
  510. package/build/query/queryKeys.d.ts +12 -0
  511. package/build/query/queryKeys.js +15 -0
  512. package/build/query/queryKeys.js.map +1 -0
  513. package/build/query/queryOptions.d.ts +23 -0
  514. package/build/query/queryOptions.js +31 -0
  515. package/build/query/queryOptions.js.map +1 -0
  516. package/build/shared/hooks/useAsyncData.d.ts +19 -0
  517. package/build/shared/hooks/useAsyncData.js +69 -0
  518. package/build/shared/hooks/useAsyncData.js.map +1 -0
  519. package/build/shared/hooks/useRecoveryOTP.d.ts +11 -0
  520. package/build/shared/hooks/useRecoveryOTP.js +64 -0
  521. package/build/shared/hooks/useRecoveryOTP.js.map +1 -0
  522. package/build/shared/types.d.ts +65 -0
  523. package/build/shared/utils/embeddedWalletStatusMapper.d.ts +15 -0
  524. package/build/shared/utils/embeddedWalletStatusMapper.js +22 -0
  525. package/build/shared/utils/embeddedWalletStatusMapper.js.map +1 -0
  526. package/build/shared/utils/explorer.d.ts +24 -0
  527. package/build/shared/utils/explorer.js +71 -0
  528. package/build/shared/utils/explorer.js.map +1 -0
  529. package/build/shared/utils/otpError.d.ts +8 -0
  530. package/build/shared/utils/otpError.js +17 -0
  531. package/build/shared/utils/otpError.js.map +1 -0
  532. package/build/shared/utils/recovery.d.ts +15 -0
  533. package/build/shared/utils/recovery.js +96 -0
  534. package/build/shared/utils/recovery.js.map +1 -0
  535. package/build/shared/utils/walletStatusProps.d.ts +18 -0
  536. package/build/shared/utils/walletStatusProps.js +45 -0
  537. package/build/shared/utils/walletStatusProps.js.map +1 -0
  538. package/build/siwe/create-siwe-message.d.ts +15 -1
  539. package/build/siwe/create-siwe-message.js +32 -0
  540. package/build/siwe/create-siwe-message.js.map +1 -0
  541. package/build/solana/SolanaContext.d.ts +43 -0
  542. package/build/solana/SolanaContext.js +87 -0
  543. package/build/solana/SolanaContext.js.map +1 -0
  544. package/build/solana/hooks/recoveryResolver.d.ts +16 -0
  545. package/build/solana/hooks/recoveryResolver.js +39 -0
  546. package/build/solana/hooks/recoveryResolver.js.map +1 -0
  547. package/build/solana/hooks/useSolanaEmbeddedWallet.d.ts +17 -0
  548. package/build/solana/hooks/useSolanaEmbeddedWallet.js +389 -0
  549. package/build/solana/hooks/useSolanaEmbeddedWallet.js.map +1 -0
  550. package/build/solana/hooks/utils.d.ts +1 -0
  551. package/build/solana/hooks/utils.js +10 -0
  552. package/build/solana/hooks/utils.js.map +1 -0
  553. package/build/solana/index.d.ts +12 -0
  554. package/build/solana/index.js +2 -0
  555. package/build/solana/index.js.map +1 -0
  556. package/build/solana/operations.d.ts +22 -0
  557. package/build/solana/operations.js +40 -0
  558. package/build/solana/operations.js.map +1 -0
  559. package/build/solana/provider.d.ts +131 -0
  560. package/build/solana/provider.js +126 -0
  561. package/build/solana/provider.js.map +1 -0
  562. package/build/solana/types.d.ts +253 -0
  563. package/build/styles/index.js +334 -0
  564. package/build/styles/index.js.map +1 -0
  565. package/build/styles/styled/index.js +14 -0
  566. package/build/styles/styled/index.js.map +1 -0
  567. package/build/styles/themes/base.js +147 -0
  568. package/build/styles/themes/base.js.map +1 -0
  569. package/build/styles/themes/index.js +13 -0
  570. package/build/styles/themes/index.js.map +1 -0
  571. package/build/styles/themes/midnight.js +78 -0
  572. package/build/styles/themes/midnight.js.map +1 -0
  573. package/build/styles/themes/minimal.js +100 -0
  574. package/build/styles/themes/minimal.js.map +1 -0
  575. package/build/styles/themes/nouns.js +83 -0
  576. package/build/styles/themes/nouns.js.map +1 -0
  577. package/build/styles/themes/retro.js +110 -0
  578. package/build/styles/themes/retro.js.map +1 -0
  579. package/build/styles/themes/rounded.js +110 -0
  580. package/build/styles/themes/rounded.js.map +1 -0
  581. package/build/styles/themes/soft.js +73 -0
  582. package/build/styles/themes/soft.js.map +1 -0
  583. package/build/styles/themes/web95.js +136 -0
  584. package/build/styles/themes/web95.js.map +1 -0
  585. package/build/types.d.ts +5 -6
  586. package/build/types.js +33 -0
  587. package/build/types.js.map +1 -0
  588. package/build/utils/banner.d.ts +1 -0
  589. package/build/utils/banner.js +14 -0
  590. package/build/utils/banner.js.map +1 -0
  591. package/build/utils/errorHandling.js +331 -0
  592. package/build/utils/errorHandling.js.map +1 -0
  593. package/build/utils/format.d.ts +18 -0
  594. package/build/utils/format.js +59 -0
  595. package/build/utils/format.js.map +1 -0
  596. package/build/utils/index.d.ts +2 -3
  597. package/build/utils/index.js +67 -0
  598. package/build/utils/index.js.map +1 -0
  599. package/build/utils/logger.js +13 -0
  600. package/build/utils/logger.js.map +1 -0
  601. package/build/utils/oauthErrorHandler.d.ts +1 -1
  602. package/build/utils/oauthErrorHandler.js +42 -0
  603. package/build/utils/oauthErrorHandler.js.map +1 -0
  604. package/build/utils/p3.js +14 -0
  605. package/build/utils/p3.js.map +1 -0
  606. package/build/utils/rpc.d.ts +34 -0
  607. package/build/utils/rpc.js +93 -0
  608. package/build/utils/rpc.js.map +1 -0
  609. package/build/utils/useOnUserReturn.js +25 -0
  610. package/build/utils/useOnUserReturn.js.map +1 -0
  611. package/build/utils/validation.js +7 -0
  612. package/build/utils/validation.js.map +1 -0
  613. package/build/utils/wallets.d.ts +6 -0
  614. package/build/utils/wallets.js +14 -0
  615. package/build/utils/wallets.js.map +1 -0
  616. package/build/version.d.ts +1 -1
  617. package/build/version.js +4 -0
  618. package/build/version.js.map +1 -0
  619. package/build/wagmi/OpenfortWagmiBridge.d.ts +3 -0
  620. package/build/wagmi/OpenfortWagmiBridge.js +166 -0
  621. package/build/wagmi/OpenfortWagmiBridge.js.map +1 -0
  622. package/build/wagmi/components/ChainSelect/index.js +140 -0
  623. package/build/wagmi/components/ChainSelect/index.js.map +1 -0
  624. package/build/wagmi/components/ChainSelectDropdown/index.js +144 -0
  625. package/build/wagmi/components/ChainSelectDropdown/index.js.map +1 -0
  626. package/build/wagmi/components/ChainSelectDropdown/styles.js +47 -0
  627. package/build/wagmi/components/ChainSelectDropdown/styles.js.map +1 -0
  628. package/build/wagmi/components/ChainSelectList/index.js +109 -0
  629. package/build/wagmi/components/ChainSelectList/index.js.map +1 -0
  630. package/build/wagmi/components/ChainSelectList/styles.js +225 -0
  631. package/build/wagmi/components/ChainSelectList/styles.js.map +1 -0
  632. package/build/wagmi/components/SwitchNetworks/index.js +22 -0
  633. package/build/wagmi/components/SwitchNetworks/index.js.map +1 -0
  634. package/build/wagmi/connectorFilter.d.ts +6 -0
  635. package/build/wagmi/connectorFilter.js +16 -0
  636. package/build/wagmi/connectorFilter.js.map +1 -0
  637. package/build/{defaultConfig.d.ts → wagmi/defaultConfig.d.ts} +1 -2
  638. package/build/wagmi/defaultConfig.js +27 -0
  639. package/build/wagmi/defaultConfig.js.map +1 -0
  640. package/build/wagmi/defaultConnectors.js +36 -0
  641. package/build/wagmi/defaultConnectors.js.map +1 -0
  642. package/build/wagmi/embeddedConnector.d.ts +4 -0
  643. package/build/wagmi/embeddedConnector.js +80 -0
  644. package/build/wagmi/embeddedConnector.js.map +1 -0
  645. package/build/wagmi/index.d.ts +10 -0
  646. package/build/wagmi/index.js +10 -0
  647. package/build/wagmi/index.js.map +1 -0
  648. package/build/wagmi/useChainIsSupported.d.ts +20 -0
  649. package/build/wagmi/useChainIsSupported.js +30 -0
  650. package/build/wagmi/useChainIsSupported.js.map +1 -0
  651. package/build/wagmi/useChains.d.ts +29 -0
  652. package/build/wagmi/useChains.js +38 -0
  653. package/build/wagmi/useChains.js.map +1 -0
  654. package/build/wagmi/useConnectWithSiwe.d.ts +22 -0
  655. package/build/wagmi/useConnectWithSiwe.js +115 -0
  656. package/build/wagmi/useConnectWithSiwe.js.map +1 -0
  657. package/build/wagmi/useEmbeddedWalletWagmiSync.d.ts +2 -0
  658. package/build/wagmi/useEmbeddedWalletWagmiSync.js +55 -0
  659. package/build/wagmi/useEmbeddedWalletWagmiSync.js.map +1 -0
  660. package/build/wagmi/useWalletAuth.d.ts +24 -0
  661. package/build/wagmi/useWalletAuth.js +180 -0
  662. package/build/wagmi/useWalletAuth.js.map +1 -0
  663. package/build/wallets/useExternalConnectors.d.ts +17 -0
  664. package/build/wallets/useExternalConnectors.js +98 -0
  665. package/build/wallets/useExternalConnectors.js.map +1 -0
  666. package/build/wallets/walletConfigs.js +344 -0
  667. package/build/wallets/walletConfigs.js.map +1 -0
  668. package/package.json +62 -11
  669. package/build/components/PageLayout/index.d.ts +0 -6
  670. package/build/components/contexts/web3/index.d.ts +0 -13
  671. package/build/constants/erc20.d.ts +0 -42
  672. package/build/hooks/openfort/auth/useWalletAuth.d.ts +0 -20
  673. package/build/hooks/openfort/useConnectWithSiwe.d.ts +0 -8
  674. package/build/hooks/openfort/useWalletAssets.d.ts +0 -16
  675. package/build/hooks/openfort/useWallets.d.ts +0 -134
  676. package/build/hooks/useChainIsSupported.d.ts +0 -24
  677. package/build/hooks/useChains.d.ts +0 -41
  678. package/build/hooks/useConnect.d.ts +0 -24
  679. package/build/hooks/useEnsFallbackConfig.d.ts +0 -1
  680. package/build/index.es.js +0 -19627
  681. package/build/index.es.js.map +0 -1
  682. package/build/openfortCustomTypes.d.ts +0 -10
  683. package/build/wallets/index.d.ts +0 -7
  684. package/build/wallets/useWagmiWallets.d.ts +0 -9
  685. /package/build/components/Pages/{SoicalProviders → SocialProviders}/index.d.ts +0 -0
  686. /package/build/{components/Common → wagmi/components}/ChainSelect/index.d.ts +0 -0
  687. /package/build/{components/Common → wagmi/components}/ChainSelectDropdown/index.d.ts +0 -0
  688. /package/build/{components/Common → wagmi/components}/ChainSelectDropdown/styles.d.ts +0 -0
  689. /package/build/{components/Common → wagmi/components}/ChainSelectList/index.d.ts +0 -0
  690. /package/build/{components/Common → wagmi/components}/ChainSelectList/styles.d.ts +0 -0
  691. /package/build/{components/Pages → wagmi/components}/SwitchNetworks/index.d.ts +0 -0
  692. /package/build/{defaultConnectors.d.ts → wagmi/defaultConnectors.d.ts} +0 -0
@@ -0,0 +1,303 @@
1
+ import { jsx, jsxs } from 'react/jsx-runtime';
2
+ import { ChainTypeEnum, RecoveryMethod, EmbeddedState } from '@openfort/openfort-js';
3
+ import { motion } from 'framer-motion';
4
+ import { useEffect, useState, useCallback, useMemo } from 'react';
5
+ import { PlusIcon, PhoneIcon, EmailIcon, FingerPrintIcon, KeyIcon, ShieldIcon, LockIcon } from '../../../assets/icons.js';
6
+ import Logos from '../../../assets/logos.js';
7
+ import { OpenfortError } from '../../../types.js';
8
+ import { useEthereumEmbeddedWallet } from '../../../ethereum/hooks/useEthereumEmbeddedWallet.js';
9
+ import { useOpenfortCore } from '../../../openfort/useOpenfort.js';
10
+ import { useRecoveryOTP } from '../../../shared/hooks/useRecoveryOTP.js';
11
+ import { handleOtpRecoveryError } from '../../../shared/utils/otpError.js';
12
+ import { useSolanaEmbeddedWallet } from '../../../solana/hooks/useSolanaEmbeddedWallet.js';
13
+ import { logger } from '../../../utils/logger.js';
14
+ import Button from '../../Common/Button/index.js';
15
+ import FitText from '../../Common/FitText/index.js';
16
+ import Input from '../../Common/Input/index.js';
17
+ import Loader from '../../Common/Loading/index.js';
18
+ import { ModalHeading, ModalBody } from '../../Common/Modal/styles.js';
19
+ import { OtpInputStandalone } from '../../Common/OTPInput/index.js';
20
+ import TickList from '../../Common/TickList/index.js';
21
+ import { FloatingGraphic } from '../../FloatingGraphic/index.js';
22
+ import { routes, LinkWalletOnSignUpOption } from '../../Openfort/types.js';
23
+ import { useOpenfort } from '../../Openfort/useOpenfort.js';
24
+ import { PageContent } from '../../PageContent/index.js';
25
+ import { PasswordStrengthIndicator } from '../../PasswordStrength/PasswordStrengthIndicator.js';
26
+ import { getPasswordStrength, MEDIUM_SCORE_THRESHOLD } from '../../PasswordStrength/password-utility.js';
27
+ import Connectors from '../Connectors/index.js';
28
+ import { Body, ResultContainer, FooterTextButton, FooterButtonText } from '../EmailOTP/styles.js';
29
+ import { ProvidersButton, ProviderLabel, ProviderIcon } from '../Providers/styles.js';
30
+ import SolanaCreateWallet from './SolanaCreateWallet.js';
31
+ import { OtherMethodButton } from './styles.js';
32
+
33
+ const OtherMethod = ({ currentMethod, onChangeMethod, }) => {
34
+ const { uiConfig } = useOpenfort();
35
+ const otherMethods = useMemo(() => {
36
+ const allowedMethods = uiConfig.walletRecovery.allowedMethods;
37
+ const otherMethods = allowedMethods.filter((method) => method !== currentMethod);
38
+ return otherMethods;
39
+ }, [uiConfig, currentMethod]);
40
+ if (otherMethods.length === 0)
41
+ return null;
42
+ if (otherMethods.length === 1) {
43
+ const method = otherMethods[0];
44
+ let text;
45
+ switch (method) {
46
+ case RecoveryMethod.PASSWORD:
47
+ text = 'Use password recovery instead';
48
+ break;
49
+ case RecoveryMethod.AUTOMATIC:
50
+ text = 'Skip for now';
51
+ break;
52
+ case RecoveryMethod.PASSKEY:
53
+ text = 'Use passkey recovery instead';
54
+ break;
55
+ default:
56
+ text = method;
57
+ }
58
+ return (jsx(OtherMethodButton, { onClick: () => {
59
+ onChangeMethod(method);
60
+ }, children: text }));
61
+ }
62
+ return jsx(OtherMethodButton, { onClick: () => onChangeMethod('other'), children: "Choose another recovery method" });
63
+ };
64
+ const CreateWalletAutomaticRecovery = ({ onBack, logoutOnBack, }) => {
65
+ var _a;
66
+ const { embeddedState } = useOpenfortCore();
67
+ const { setRoute, triggerResize } = useOpenfort();
68
+ const [recoveryError, setRecoveryError] = useState(null);
69
+ const { create } = useEthereumEmbeddedWallet();
70
+ const { isEnabled: isWalletRecoveryOTPEnabled, requestOTP } = useRecoveryOTP();
71
+ const [shouldCreateWallet, setShouldCreateWallet] = useState(false);
72
+ const [needsOTP, setNeedsOTP] = useState(false);
73
+ const [otpResponse, setOtpResponse] = useState(null);
74
+ const [otpStatus, setOtpStatus] = useState('idle');
75
+ const [error, setError] = useState(false);
76
+ const handleCompleteOtp = async (otp) => {
77
+ setOtpStatus('loading');
78
+ try {
79
+ await create({
80
+ recoveryMethod: RecoveryMethod.AUTOMATIC,
81
+ otpCode: otp,
82
+ });
83
+ setOtpStatus('success');
84
+ setRoute(routes.CONNECTED_SUCCESS);
85
+ }
86
+ catch (err) {
87
+ setOtpStatus('error');
88
+ setError(err instanceof OpenfortError ? err.message : 'There was an error verifying the OTP');
89
+ logger.log('Error verifying OTP for wallet recovery', err);
90
+ setTimeout(() => {
91
+ setOtpStatus('idle');
92
+ setError(false);
93
+ }, 1000);
94
+ }
95
+ };
96
+ useEffect(() => {
97
+ if (!shouldCreateWallet)
98
+ return;
99
+ (async () => {
100
+ logger.log('Creating wallet Automatic recover');
101
+ try {
102
+ await create({ recoveryMethod: RecoveryMethod.AUTOMATIC });
103
+ setRoute(routes.CONNECTED_SUCCESS);
104
+ }
105
+ catch (err) {
106
+ const { error, isOTPRequired } = handleOtpRecoveryError(err, isWalletRecoveryOTPEnabled);
107
+ if (isOTPRequired && isWalletRecoveryOTPEnabled) {
108
+ try {
109
+ const res = await requestOTP();
110
+ setNeedsOTP(true);
111
+ setOtpResponse(res);
112
+ }
113
+ catch (otpErr) {
114
+ logger.log('Error requesting OTP for wallet recovery', otpErr);
115
+ setRecoveryError(new Error('Failed to send recovery code'));
116
+ }
117
+ }
118
+ else {
119
+ logger.log('Error creating wallet', err);
120
+ setRecoveryError(error);
121
+ }
122
+ }
123
+ triggerResize();
124
+ })();
125
+ }, [shouldCreateWallet, create, isWalletRecoveryOTPEnabled, requestOTP, triggerResize]);
126
+ const [canSendOtp, setCanSendOtp] = useState(true);
127
+ useEffect(() => {
128
+ if (embeddedState === EmbeddedState.EMBEDDED_SIGNER_NOT_CONFIGURED) {
129
+ setShouldCreateWallet(true);
130
+ }
131
+ }, [embeddedState]);
132
+ const handleResendClick = useCallback(() => {
133
+ setOtpStatus('send-otp');
134
+ setCanSendOtp(false);
135
+ }, []);
136
+ const isResendDisabled = !canSendOtp || otpStatus === 'sending-otp' || otpStatus === 'send-otp';
137
+ const sendButtonText = useMemo(() => {
138
+ if (!canSendOtp)
139
+ return 'Code Sent!';
140
+ if (otpStatus === 'sending-otp')
141
+ return 'Sending...';
142
+ return 'Resend Code';
143
+ }, [canSendOtp, otpStatus]);
144
+ if (needsOTP && isWalletRecoveryOTPEnabled) {
145
+ if ((!(otpResponse === null || otpResponse === void 0 ? void 0 : otpResponse.email) && !(otpResponse === null || otpResponse === void 0 ? void 0 : otpResponse.phone)) || ((_a = otpResponse.email) === null || _a === void 0 ? void 0 : _a.includes('@openfort.anonymous'))) {
146
+ return (jsxs(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: [jsx(Loader, { isError: true, description: 'You cannot create a wallet without authentication, please link email or phone to continue.', header: 'Cannot create wallet.' }), jsx(Button, { onClick: () => setRoute(routes.PROVIDERS), children: "Add an authentication method" })] }));
147
+ }
148
+ return (jsxs(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: [jsx(ModalHeading, { children: "Enter your code" }), jsx(FloatingGraphic, { height: "100px", marginTop: "8px", marginBottom: "10px", logoCenter: {
149
+ logo: (otpResponse === null || otpResponse === void 0 ? void 0 : otpResponse.sentTo) === 'phone' ? jsx(PhoneIcon, {}) : jsx(EmailIcon, {}),
150
+ } }), jsxs(ModalBody, { children: [jsxs(Body, { children: ["Please check ", jsx("b", { children: (otpResponse === null || otpResponse === void 0 ? void 0 : otpResponse.sentTo) === 'phone' ? otpResponse === null || otpResponse === void 0 ? void 0 : otpResponse.phone : otpResponse === null || otpResponse === void 0 ? void 0 : otpResponse.email }), " and enter your code below."] }), jsx(OtpInputStandalone, { length: 9, scale: "80%", onComplete: handleCompleteOtp, isLoading: otpStatus === 'loading', isError: otpStatus === 'error', isSuccess: otpStatus === 'success' }), jsxs(ResultContainer, { children: [otpStatus === 'success' && jsx(ModalBody, { "$valid": true, children: "Code verified successfully!" }), otpStatus === 'error' && jsx(ModalBody, { "$error": true, children: error || 'Invalid code. Please try again.' })] }), jsxs(FooterTextButton, { children: ["Didn't receive the code?", ' ', jsx(FooterButtonText, { type: "button", onClick: handleResendClick, disabled: isResendDisabled, children: sendButtonText })] })] })] }));
151
+ }
152
+ return (jsx(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: jsx(Loader, { isError: !!recoveryError, header: recoveryError ? 'Error creating wallet.' : `Creating wallet...`, description: recoveryError ? recoveryError.message : undefined }) }));
153
+ };
154
+ const CreateWalletPasskeyRecovery = ({ onChangeMethod, onBack, logoutOnBack, }) => {
155
+ const { triggerResize, setRoute } = useOpenfort();
156
+ const { create } = useEthereumEmbeddedWallet();
157
+ const [shouldCreateWallet, setShouldCreateWallet] = useState(false);
158
+ const [recoveryError, setRecoveryError] = useState(null);
159
+ const { embeddedState } = useOpenfortCore();
160
+ useEffect(() => {
161
+ if (!shouldCreateWallet)
162
+ return;
163
+ (async () => {
164
+ logger.log('Creating wallet passkey recovery');
165
+ try {
166
+ await create({ recoveryMethod: RecoveryMethod.PASSKEY });
167
+ setRoute(routes.CONNECTED_SUCCESS);
168
+ }
169
+ catch (err) {
170
+ logger.log('Error creating wallet', err);
171
+ setRecoveryError(new Error('Failed to create wallet'));
172
+ setShouldCreateWallet(false);
173
+ }
174
+ })();
175
+ }, [shouldCreateWallet, create]);
176
+ useEffect(() => {
177
+ if (embeddedState === EmbeddedState.EMBEDDED_SIGNER_NOT_CONFIGURED) {
178
+ setShouldCreateWallet(true);
179
+ }
180
+ }, [embeddedState]);
181
+ useEffect(() => {
182
+ if (recoveryError)
183
+ triggerResize();
184
+ }, [recoveryError]);
185
+ return (jsxs(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: [jsx(Loader, { icon: jsx(FingerPrintIcon, {}), isError: !!recoveryError, header: recoveryError ? 'Invalid passkey.' : 'Creating wallet with passkey...', description: recoveryError ? 'There was an error creating your passkey. Please try again.' : undefined, onRetry: () => setShouldCreateWallet(true) }), jsx(OtherMethod, { currentMethod: RecoveryMethod.PASSKEY, onChangeMethod: onChangeMethod })] }));
186
+ };
187
+ const CreateWalletPasswordRecovery = ({ onChangeMethod, onBack, logoutOnBack, }) => {
188
+ const [recoveryPhrase, setRecoveryPhrase] = useState('');
189
+ const [recoveryError, setRecoveryError] = useState(false);
190
+ const { triggerResize, setRoute } = useOpenfort();
191
+ const [showPasswordIsTooWeakError, setShowPasswordIsTooWeakError] = useState(false);
192
+ const [loading, setLoading] = useState(false);
193
+ const { create } = useEthereumEmbeddedWallet();
194
+ const handleSubmit = async () => {
195
+ if (getPasswordStrength(recoveryPhrase) < MEDIUM_SCORE_THRESHOLD) {
196
+ setShowPasswordIsTooWeakError(true);
197
+ return;
198
+ }
199
+ setLoading(true);
200
+ try {
201
+ await create({
202
+ recoveryMethod: RecoveryMethod.PASSWORD,
203
+ password: recoveryPhrase,
204
+ });
205
+ logger.log('Recovery success');
206
+ setRoute(routes.CONNECTED_SUCCESS);
207
+ }
208
+ catch (err) {
209
+ setRecoveryError(err instanceof OpenfortError ? err.message : 'There was an error recovering your account');
210
+ }
211
+ setLoading(false);
212
+ };
213
+ useEffect(() => {
214
+ if (recoveryError)
215
+ triggerResize();
216
+ }, [recoveryError]);
217
+ return (jsxs(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: [jsx(FloatingGraphic, { height: "80px", logoCenter: {
218
+ logo: jsx(KeyIcon, {}),
219
+ size: '1.2',
220
+ }, logoTopLeft: {
221
+ logo: jsx(ShieldIcon, {}),
222
+ size: '0.75',
223
+ }, logoBottomRight: {
224
+ logo: jsx(LockIcon, {}),
225
+ size: '0.5',
226
+ } }), jsx(ModalHeading, { children: "Secure your wallet" }), jsxs(ModalBody, { style: { textAlign: 'center' }, children: [jsx(FitText, { children: "Set a password for your wallet." }), jsxs("form", { onSubmit: (e) => {
227
+ e.preventDefault();
228
+ handleSubmit();
229
+ }, children: [jsx(Input, { value: recoveryPhrase, onChange: (e) => {
230
+ if (showPasswordIsTooWeakError)
231
+ setShowPasswordIsTooWeakError(false);
232
+ setRecoveryPhrase(e.target.value);
233
+ }, type: "password", placeholder: "Enter your password", autoComplete: "off" }), jsx(PasswordStrengthIndicator, { password: recoveryPhrase, showPasswordIsTooWeakError: showPasswordIsTooWeakError }), jsx(TickList, { items: ['You will use this password to access your wallet', "Make sure it's strong and memorable"] }), recoveryError && (jsx(motion.div, { initial: { opacity: 0 }, animate: { opacity: 1 }, exit: { opacity: 0 }, children: jsx(ModalBody, { style: { height: 24, marginTop: 12 }, "$error": true, children: jsx(FitText, { children: recoveryError }) }) }, recoveryError)), jsx(Button, { onClick: handleSubmit, waiting: loading, disabled: loading, children: "Create wallet" })] }), jsx(OtherMethod, { currentMethod: RecoveryMethod.PASSWORD, onChangeMethod: onChangeMethod })] })] }));
234
+ };
235
+ const ChooseRecoveryMethod = ({ onChangeMethod, onBack, logoutOnBack, }) => {
236
+ return (jsxs(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: [jsx(ModalHeading, { children: "Choose a recovery method" }), jsx(ProvidersButton, { children: jsxs(Button, { onClick: () => onChangeMethod(RecoveryMethod.PASSKEY), children: [jsx(ProviderLabel, { children: "Passkey" }), jsx(ProviderIcon, { children: jsx(FingerPrintIcon, {}) })] }) }), jsx(ProvidersButton, { children: jsxs(Button, { onClick: () => onChangeMethod(RecoveryMethod.PASSWORD), children: [jsx(ProviderLabel, { children: "Password" }), jsx(ProviderIcon, { children: jsx(KeyIcon, {}) })] }) }), jsx(ProvidersButton, { children: jsxs(Button, { onClick: () => onChangeMethod(RecoveryMethod.AUTOMATIC), children: [jsx(ProviderLabel, { children: "Automatic" }), jsx(ProviderIcon, { children: jsx(LockIcon, {}) })] }) })] }));
237
+ };
238
+ const CreateEmbeddedWallet = ({ onBack, logoutOnBack }) => {
239
+ const { uiConfig, triggerResize } = useOpenfort();
240
+ const [userSelectedMethod, setUserSelectedMethod] = useState(null);
241
+ useEffect(() => {
242
+ triggerResize();
243
+ }, [userSelectedMethod]);
244
+ const method = userSelectedMethod !== null && userSelectedMethod !== void 0 ? userSelectedMethod : uiConfig.walletRecovery.defaultMethod;
245
+ switch (method) {
246
+ case RecoveryMethod.PASSWORD:
247
+ return (jsx(CreateWalletPasswordRecovery, { onChangeMethod: setUserSelectedMethod, onBack: onBack, logoutOnBack: logoutOnBack }));
248
+ case RecoveryMethod.AUTOMATIC:
249
+ return jsx(CreateWalletAutomaticRecovery, { onBack: onBack, logoutOnBack: logoutOnBack });
250
+ case RecoveryMethod.PASSKEY:
251
+ return (jsx(CreateWalletPasskeyRecovery, { onChangeMethod: setUserSelectedMethod, onBack: onBack, logoutOnBack: logoutOnBack }));
252
+ case 'other':
253
+ return (jsx(ChooseRecoveryMethod, { onChangeMethod: setUserSelectedMethod, onBack: () => {
254
+ setUserSelectedMethod(null);
255
+ }, logoutOnBack: logoutOnBack }));
256
+ default:
257
+ logger.error(`Unsupported recovery method: ${userSelectedMethod}${uiConfig.walletRecovery.defaultMethod}`);
258
+ return null;
259
+ }
260
+ };
261
+ const CreateOrConnectWallet = () => {
262
+ const [showCreateEmbeddedWallet, setShowCreateEmbeddedWallet] = useState(false);
263
+ const { setRoute } = useOpenfort();
264
+ if (showCreateEmbeddedWallet)
265
+ return jsx(CreateEmbeddedWallet, { onBack: () => setShowCreateEmbeddedWallet(false), logoutOnBack: false });
266
+ return (jsxs(PageContent, { onBack: routes.PROVIDERS, logoutOnBack: true, children: [jsx(ModalHeading, { children: "Choose an option" }), jsx(ProvidersButton, { children: jsxs(Button, { onClick: () => setShowCreateEmbeddedWallet(true), children: [jsx(ProviderLabel, { children: "Create Wallet" }), jsx(ProviderIcon, { children: jsx(PlusIcon, {}) })] }) }), jsx(ProvidersButton, { children: jsxs(Button, { onClick: () => {
267
+ setRoute({ route: routes.CONNECTORS, connectType: 'link' });
268
+ }, children: [jsx(ProviderLabel, { children: "Connect Wallet" }), jsx(ProviderIcon, { children: jsx(Logos.OtherWallets, {}) })] }) })] }));
269
+ };
270
+ const EthereumCreateWallet = () => {
271
+ const { uiConfig, walletConfig, setRoute } = useOpenfort();
272
+ const { user } = useOpenfortCore();
273
+ const { chainType } = useOpenfortCore();
274
+ // Use chain-specific hooks
275
+ const ethereumWallet = useEthereumEmbeddedWallet();
276
+ const solanaWallet = useSolanaEmbeddedWallet();
277
+ const wallet = chainType === ChainTypeEnum.EVM ? ethereumWallet : solanaWallet;
278
+ const isConnected = wallet.status === 'connected';
279
+ useEffect(() => {
280
+ if (isConnected && user)
281
+ setRoute(routes.CONNECTED_SUCCESS);
282
+ }, [isConnected, user, setRoute]);
283
+ if (uiConfig.linkWalletOnSignUp === LinkWalletOnSignUpOption.OPTIONAL) {
284
+ return jsx(CreateOrConnectWallet, {});
285
+ }
286
+ if (uiConfig.linkWalletOnSignUp === LinkWalletOnSignUpOption.REQUIRED ||
287
+ (!walletConfig && uiConfig.linkWalletOnSignUp !== LinkWalletOnSignUpOption.DISABLED)) {
288
+ return jsx(Connectors, { logoutOnBack: true });
289
+ }
290
+ return jsx(CreateEmbeddedWallet, { onBack: routes.PROVIDERS, logoutOnBack: true });
291
+ };
292
+ const createWalletByChain = {
293
+ [ChainTypeEnum.EVM]: jsx(EthereumCreateWallet, {}),
294
+ [ChainTypeEnum.SVM]: jsx(SolanaCreateWallet, { onBack: routes.PROVIDERS, logoutOnBack: true }),
295
+ };
296
+ const CreateWallet = () => {
297
+ var _a;
298
+ const { chainType } = useOpenfortCore();
299
+ return (_a = createWalletByChain[chainType]) !== null && _a !== void 0 ? _a : createWalletByChain[ChainTypeEnum.EVM];
300
+ };
301
+
302
+ export { CreateWallet as default };
303
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,17 @@
1
+ import styled from '../../../styles/styled/index.js';
2
+
3
+ const OtherMethodButton = styled.button `
4
+ width: 100%;
5
+ color: var(--ck-body-color-muted);
6
+ background: none;
7
+ font-size: 14px;
8
+ margin-top: 10px;
9
+ transition: color 0.2s;
10
+
11
+ &:hover {
12
+ color: var(--ck-body-color);
13
+ }
14
+ `;
15
+
16
+ export { OtherMethodButton };
17
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,32 @@
1
+ import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
2
+ import useLocales from '../../../hooks/useLocales.js';
3
+ import { useExternalConnector } from '../../../wallets/useExternalConnectors.js';
4
+ import CustomQRCode from '../../Common/CustomQRCode/index.js';
5
+ import { ModalContent, ModalBody } from '../../Common/Modal/styles.js';
6
+ import { useOpenfort } from '../../Openfort/useOpenfort.js';
7
+ import { PageContent } from '../../PageContent/index.js';
8
+
9
+ const DownloadApp = () => {
10
+ var _a, _b, _c, _d;
11
+ const context = useOpenfort();
12
+ const wallet = useExternalConnector(context.connector.id);
13
+ const locales = useLocales({
14
+ CONNECTORNAME: (_a = wallet === null || wallet === void 0 ? void 0 : wallet.name) !== null && _a !== void 0 ? _a : 'UNKNOWN CONNECTOR',
15
+ });
16
+ if (!wallet)
17
+ return jsx(Fragment, { children: "Wallet not found" });
18
+ const downloads = {
19
+ ios: (_b = wallet.downloadUrls) === null || _b === void 0 ? void 0 : _b.ios,
20
+ android: (_c = wallet.downloadUrls) === null || _c === void 0 ? void 0 : _c.android,
21
+ redirect: (_d = wallet.downloadUrls) === null || _d === void 0 ? void 0 : _d.download,
22
+ };
23
+ const bodycopy = downloads.ios && downloads.android
24
+ ? locales.downloadAppScreen_iosAndroid
25
+ : downloads.ios
26
+ ? locales.downloadAppScreen_ios
27
+ : locales.downloadAppScreen_android;
28
+ return (jsx(PageContent, { children: jsxs(ModalContent, { style: { paddingBottom: 4, gap: 14 }, children: [downloads.redirect && jsx(CustomQRCode, { value: downloads.redirect }), !downloads.redirect && jsx(Fragment, { children: "No download link available" }), jsx(ModalBody, { style: { fontSize: 15, lineHeight: '20px', padding: '0 12px' }, children: bodycopy })] }) }));
29
+ };
30
+
31
+ export { DownloadApp as default };
32
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,118 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { AnimatePresence, motion } from 'framer-motion';
3
+ import React, { useMemo } from 'react';
4
+ import { useEmailAuth } from '../../../hooks/openfort/auth/useEmailAuth.js';
5
+ import { logger } from '../../../utils/logger.js';
6
+ import Button from '../../Common/Button/index.js';
7
+ import { TextLinkButton } from '../../Common/Button/styles.js';
8
+ import FitText from '../../Common/FitText/index.js';
9
+ import Input from '../../Common/Input/index.js';
10
+ import { ModalBody } from '../../Common/Modal/styles.js';
11
+ import { TextContainer } from '../../ConnectButton/styles.js';
12
+ import { routes } from '../../Openfort/types.js';
13
+ import { useOpenfort } from '../../Openfort/useOpenfort.js';
14
+ import { PageContent } from '../../PageContent/index.js';
15
+ import { FooterContainer } from './styles.js';
16
+
17
+ // TODO: Localize
18
+ const textVariants = {
19
+ initial: {
20
+ opacity: 0,
21
+ },
22
+ animate: {
23
+ opacity: 1,
24
+ transition: {
25
+ duration: 0.3,
26
+ ease: [0.25, 1, 0.5, 1],
27
+ },
28
+ },
29
+ exit: {
30
+ position: 'absolute',
31
+ opacity: 0,
32
+ transition: {
33
+ duration: 0,
34
+ },
35
+ },
36
+ };
37
+ const EmailLogin = () => {
38
+ const [password, setPassword] = React.useState('');
39
+ const { setRoute, triggerResize, setEmailInput: setEmail, emailInput: email, previousRoute } = useOpenfort();
40
+ const [isRegister, setIsRegister] = React.useState(false);
41
+ const { signUpEmail, signInEmail, error: loginError, isLoading: loginLoading, } = useEmailAuth({
42
+ recoverWalletAutomatically: false,
43
+ });
44
+ const handleSubmit = async () => {
45
+ if (isRegister) {
46
+ return handleSignUp();
47
+ }
48
+ setIsRegister(false);
49
+ setTimeout(() => {
50
+ triggerResize();
51
+ });
52
+ const { error, requiresEmailVerification } = await signInEmail({
53
+ email,
54
+ password,
55
+ });
56
+ logger.log('SIGN IN RESPONSE', { error, requiresEmailVerification });
57
+ if (!error) {
58
+ if (requiresEmailVerification) {
59
+ setRoute(routes.EMAIL_VERIFICATION);
60
+ }
61
+ else {
62
+ setRoute(routes.LOAD_WALLETS);
63
+ }
64
+ }
65
+ else {
66
+ setTimeout(() => {
67
+ triggerResize();
68
+ }, 100);
69
+ }
70
+ };
71
+ const handleSignUp = async () => {
72
+ setIsRegister(true);
73
+ setTimeout(() => {
74
+ triggerResize();
75
+ });
76
+ const { error, requiresEmailVerification } = await signUpEmail({
77
+ email,
78
+ password,
79
+ });
80
+ logger.log('SIGN UP RESPONSE', { error, requiresEmailVerification });
81
+ if (!error) {
82
+ if (requiresEmailVerification) {
83
+ setRoute(routes.EMAIL_VERIFICATION);
84
+ }
85
+ else {
86
+ setEmail('');
87
+ setRoute(routes.LOAD_WALLETS);
88
+ }
89
+ }
90
+ else {
91
+ setTimeout(() => {
92
+ triggerResize();
93
+ }, 100);
94
+ }
95
+ };
96
+ const handleToggle = () => {
97
+ setIsRegister((prev) => !prev);
98
+ };
99
+ const errorMessage = loginError
100
+ ? loginError.message === 'Unauthorized'
101
+ ? 'Invalid email or password'
102
+ : loginError.message
103
+ : null;
104
+ const onBack = useMemo(() => {
105
+ if ((previousRoute === null || previousRoute === void 0 ? void 0 : previousRoute.route) === routes.EMAIL_VERIFICATION)
106
+ return routes.PROVIDERS;
107
+ return 'back';
108
+ }, [previousRoute]);
109
+ return (jsxs(PageContent, { onBack: onBack, children: [jsxs("form", { onSubmit: (e) => {
110
+ e.preventDefault();
111
+ handleSubmit();
112
+ }, noValidate: true, children: [jsx(Input, { style: { marginTop: 0 }, value: email, onChange: (e) => setEmail(e.target.value), type: "email", placeholder: "Enter your email", disabled: loginLoading }), jsx(Input, { value: password, onChange: (e) => setPassword(e.target.value), type: "password", placeholder: "Enter your password", disabled: loginLoading, autoFocus: true }), jsx(ModalBody, { style: { marginTop: 12 }, "$error": !!loginError, children: jsx(AnimatePresence, { initial: false, children: jsxs(motion.div, { initial: 'initial', animate: 'animate', exit: 'exit', variants: textVariants, children: [jsx(FitText, { maxFontSize: 80, children: jsx("span", { style: { textAlign: 'center', color: 'var(--color-error)', marginRight: '4px' }, children: errorMessage }) }, loginError ? 'text-error' : 'text-no-error'), jsx(FitText, { maxFontSize: 80, children: jsx(TextLinkButton, { type: "button", onClick: () => {
113
+ setRoute(routes.FORGOT_PASSWORD);
114
+ }, children: "Forgot password?" }) })] }, loginError ? 'error' : 'no-error') }) }), jsx(Button, { onClick: handleSubmit, disabled: loginLoading, waiting: loginLoading, children: jsx(AnimatePresence, { initial: false, children: loginLoading ? (jsx(TextContainer, { initial: 'initial', animate: 'animate', exit: 'exit', variants: textVariants, children: isRegister ? 'Signing up...' : 'Logging in...' }, "connectedText")) : isRegister ? (jsx(TextContainer, { initial: 'initial', animate: 'animate', exit: 'exit', variants: textVariants, children: "Sign up" }, "connectedText")) : (jsx(TextContainer, { initial: 'initial', animate: 'animate', exit: 'exit', variants: textVariants, children: "Sign in" }, "connectedText")) }) })] }), jsxs(FooterContainer, { children: ["or", jsx("button", { type: "button", onClick: handleToggle, disabled: loginLoading, children: isRegister ? 'Sign in' : 'Sign up' })] })] }));
115
+ };
116
+
117
+ export { EmailLogin as default };
118
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,24 @@
1
+ import styled from '../../../styles/styled/index.js';
2
+
3
+ const FooterContainer = styled.span `
4
+ padding: 12px 4px 0px 0px;
5
+ display: flex;
6
+ align-items: center;
7
+ justify-content: center;
8
+ gap: 6px;
9
+ line-height: 1rem;
10
+ color: var(--ck-body-disclaimer-color, var(--ck-body-color-muted, inherit));
11
+
12
+ & button {
13
+ color: var(--ck-body-disclaimer-link-color, inherit);
14
+ font-weight: var(--ck-body-disclaimer-font-weight, 400);
15
+ text-decoration: none;
16
+ transition: color 200ms ease;
17
+ &:hover {
18
+ color: var(--ck-body-disclaimer-link-hover-color, inherit);
19
+ }
20
+ }
21
+ `;
22
+
23
+ export { FooterContainer };
24
+ //# sourceMappingURL=styles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,116 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { useMemo, useState, useRef, useCallback, useEffect } from 'react';
3
+ import { EmailIcon } from '../../../assets/icons.js';
4
+ import { useEmailOtpAuth } from '../../../hooks/openfort/auth/useEmailOtpAuth.js';
5
+ import { logger } from '../../../utils/logger.js';
6
+ import { ModalHeading, ModalBody } from '../../Common/Modal/styles.js';
7
+ import { OtpInputStandalone } from '../../Common/OTPInput/index.js';
8
+ import PoweredByFooter from '../../Common/PoweredByFooter/index.js';
9
+ import { FloatingGraphic } from '../../FloatingGraphic/index.js';
10
+ import { routes } from '../../Openfort/types.js';
11
+ import { useOpenfort } from '../../Openfort/useOpenfort.js';
12
+ import { PageContent } from '../../PageContent/index.js';
13
+ import { Body, ResultContainer, FooterTextButton, FooterButtonText } from './styles.js';
14
+
15
+ const RESEND_COOLDOWN_MS = 10000;
16
+ const SUCCESS_REDIRECT_DELAY_MS = 2000;
17
+ const ERROR_DISPLAY_DURATION_MS = 2000;
18
+ const EmailOTP = () => {
19
+ const { emailInput: email, previousRoute, setRoute, setEmailInput } = useOpenfort();
20
+ const { isLoading, requestEmailOtp, signInEmailOtp } = useEmailOtpAuth({
21
+ recoverWalletAutomatically: false,
22
+ });
23
+ const onBack = useMemo(() => {
24
+ if ((previousRoute === null || previousRoute === void 0 ? void 0 : previousRoute.route) === routes.EMAIL_VERIFICATION)
25
+ return routes.PROVIDERS;
26
+ return 'back';
27
+ }, [previousRoute]);
28
+ const [canSendOtp, setCanSendOtp] = useState(true);
29
+ const [status, setStatus] = useState('idle');
30
+ // Single ref to track if initial OTP request has been made
31
+ const hasRequestedInitialOtpRef = useRef(false);
32
+ // Memoize the OTP request function to prevent unnecessary recreations
33
+ const sendOtpRequest = useCallback(async () => {
34
+ const { error } = await requestEmailOtp({ email });
35
+ if (error) {
36
+ logger.error('Error requesting email OTP:', error);
37
+ setStatus('error');
38
+ }
39
+ else {
40
+ setStatus('idle');
41
+ }
42
+ }, [email, requestEmailOtp]);
43
+ // Initial OTP request on mount
44
+ useEffect(() => {
45
+ if (hasRequestedInitialOtpRef.current)
46
+ return;
47
+ hasRequestedInitialOtpRef.current = true;
48
+ sendOtpRequest();
49
+ }, [sendOtpRequest]);
50
+ // Handle OTP completion
51
+ const handleComplete = useCallback(async (otp) => {
52
+ logger.log('OTP entered:', otp);
53
+ setStatus('loading');
54
+ const { error } = await signInEmailOtp({ email, otp });
55
+ if (error) {
56
+ logger.error('Error logging in with email OTP:', error);
57
+ setStatus('error');
58
+ }
59
+ else {
60
+ setStatus('success');
61
+ }
62
+ }, [email, signInEmailOtp]);
63
+ // Handle status changes and side effects
64
+ useEffect(() => {
65
+ let timeoutId;
66
+ switch (status) {
67
+ case 'send-otp':
68
+ setStatus('sending-otp');
69
+ sendOtpRequest();
70
+ break;
71
+ case 'success':
72
+ timeoutId = setTimeout(() => {
73
+ setEmailInput('');
74
+ setRoute(routes.LOAD_WALLETS);
75
+ }, SUCCESS_REDIRECT_DELAY_MS);
76
+ break;
77
+ case 'error':
78
+ timeoutId = setTimeout(() => {
79
+ setStatus('idle');
80
+ }, ERROR_DISPLAY_DURATION_MS);
81
+ break;
82
+ }
83
+ return () => {
84
+ if (timeoutId)
85
+ clearTimeout(timeoutId);
86
+ };
87
+ }, [status, sendOtpRequest, setEmailInput, setRoute]);
88
+ // Handle resend cooldown
89
+ useEffect(() => {
90
+ if (canSendOtp)
91
+ return;
92
+ const timerId = setTimeout(() => {
93
+ setCanSendOtp(true);
94
+ }, RESEND_COOLDOWN_MS);
95
+ return () => clearTimeout(timerId);
96
+ }, [canSendOtp]);
97
+ // Memoize button text to avoid recalculation
98
+ const sendButtonText = useMemo(() => {
99
+ if (!canSendOtp)
100
+ return 'Code Sent!';
101
+ if (status === 'sending-otp')
102
+ return 'Sending...';
103
+ return 'Resend Code';
104
+ }, [canSendOtp, status]);
105
+ const handleResendClick = useCallback(() => {
106
+ setStatus('send-otp');
107
+ setCanSendOtp(false);
108
+ }, []);
109
+ const isResendDisabled = !canSendOtp || status === 'sending-otp' || status === 'send-otp';
110
+ return (jsxs(PageContent, { onBack: onBack, children: [jsx(ModalHeading, { children: "Enter your code" }), jsx(FloatingGraphic, { height: "100px", marginTop: "8px", marginBottom: "10px", logoCenter: {
111
+ logo: jsx(EmailIcon, {}),
112
+ } }), jsxs(ModalBody, { children: [jsxs(Body, { children: ["Please check ", jsx("b", { children: email }), " for an email from openfort.io and enter your code below."] }), jsx(OtpInputStandalone, { onComplete: handleComplete, isLoading: status === 'loading' || isLoading, isError: status === 'error', isSuccess: status === 'success' }), jsxs(ResultContainer, { children: [status === 'success' && jsx(ModalBody, { "$valid": true, children: "Code verified successfully!" }), status === 'error' && jsx(ModalBody, { "$error": true, children: "Invalid code. Please try again." })] }), jsxs(FooterTextButton, { children: ["Didn't receive the code?", ' ', jsx(FooterButtonText, { type: "button", onClick: handleResendClick, disabled: isResendDisabled, children: sendButtonText })] })] }), jsx(PoweredByFooter, {})] }));
113
+ };
114
+
115
+ export { EmailOTP as default };
116
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}