@openfort/react 0.3.1 → 1.0.0
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.
- package/build/assets/browsers.js +13 -0
- package/build/assets/browsers.js.map +1 -0
- package/build/assets/chains.js +139 -0
- package/build/assets/chains.js.map +1 -0
- package/build/assets/icons.js +41 -0
- package/build/assets/icons.js.map +1 -0
- package/build/assets/logos.js +173 -0
- package/build/assets/logos.js.map +1 -0
- package/build/assets/wave.js +6 -0
- package/build/assets/wave.js.map +1 -0
- package/build/components/BalanceButton/index.js +89 -0
- package/build/components/BalanceButton/index.js.map +1 -0
- package/build/components/Common/Alert/index.js +10 -0
- package/build/components/Common/Alert/index.js.map +1 -0
- package/build/components/Common/Alert/styles.js +55 -0
- package/build/components/Common/Alert/styles.js.map +1 -0
- package/build/components/Common/Avatar/index.d.ts +11 -3
- package/build/components/Common/Avatar/index.js +100 -0
- package/build/components/Common/Avatar/index.js.map +1 -0
- package/build/components/Common/Avatar/styles.js +59 -0
- package/build/components/Common/Avatar/styles.js.map +1 -0
- package/build/components/Common/BrowserIcon/index.js +28 -0
- package/build/components/Common/BrowserIcon/index.js.map +1 -0
- package/build/components/Common/BrowserIcon/styles.js +20 -0
- package/build/components/Common/BrowserIcon/styles.js.map +1 -0
- package/build/components/Common/Button/index.js +36 -0
- package/build/components/Common/Button/index.js.map +1 -0
- package/build/components/Common/Button/styles.js +302 -0
- package/build/components/Common/Button/styles.js.map +1 -0
- package/build/components/Common/Button/types.d.ts +1 -0
- package/build/components/Common/Chain/index.d.ts +8 -0
- package/build/components/Common/Chain/index.js +38 -0
- package/build/components/Common/Chain/index.js.map +1 -0
- package/build/components/Common/Chain/styles.js +94 -0
- package/build/components/Common/Chain/styles.js.map +1 -0
- package/build/components/Common/ConnectorList/index.js +58 -0
- package/build/components/Common/ConnectorList/index.js.map +1 -0
- package/build/components/Common/ConnectorList/styles.js +324 -0
- package/build/components/Common/ConnectorList/styles.js.map +1 -0
- package/build/components/Common/CopyToClipboard/CopyButton.js +12 -0
- package/build/components/Common/CopyToClipboard/CopyButton.js.map +1 -0
- package/build/components/Common/CopyToClipboard/CopyIcon.js +76 -0
- package/build/components/Common/CopyToClipboard/CopyIcon.js.map +1 -0
- package/build/components/Common/CopyToClipboard/CopyIconButton.js +38 -0
- package/build/components/Common/CopyToClipboard/CopyIconButton.js.map +1 -0
- package/build/components/Common/CopyToClipboard/CopyText.js +26 -0
- package/build/components/Common/CopyToClipboard/CopyText.js.map +1 -0
- package/build/components/Common/CustomQRCode/QRCode.js +60 -0
- package/build/components/Common/CustomQRCode/QRCode.js.map +1 -0
- package/build/components/Common/CustomQRCode/index.js +22 -0
- package/build/components/Common/CustomQRCode/index.js.map +1 -0
- package/build/components/Common/CustomQRCode/styles.js +155 -0
- package/build/components/Common/CustomQRCode/styles.js.map +1 -0
- package/build/components/Common/FitText/index.js +28 -0
- package/build/components/Common/FitText/index.js.map +1 -0
- package/build/components/Common/Input/index.js +17 -0
- package/build/components/Common/Input/index.js.map +1 -0
- package/build/components/Common/Input/styles.js +53 -0
- package/build/components/Common/Input/styles.js.map +1 -0
- package/build/components/Common/LargeButton/index.js +10 -0
- package/build/components/Common/LargeButton/index.js.map +1 -0
- package/build/components/Common/LargeButton/styles.js +69 -0
- package/build/components/Common/LargeButton/styles.js.map +1 -0
- package/build/components/Common/Loading/index.js +96 -0
- package/build/components/Common/Loading/index.js.map +1 -0
- package/build/components/Common/Modal/index.js +272 -0
- package/build/components/Common/Modal/index.js.map +1 -0
- package/build/components/Common/Modal/styles.d.ts +0 -1
- package/build/components/Common/Modal/styles.js +657 -0
- package/build/components/Common/Modal/styles.js.map +1 -0
- package/build/components/Common/OTPInput/index.js +108 -0
- package/build/components/Common/OTPInput/index.js.map +1 -0
- package/build/components/Common/OTPInput/styles.js +153 -0
- package/build/components/Common/OTPInput/styles.js.map +1 -0
- package/build/components/Common/Portal/index.js +31 -0
- package/build/components/Common/Portal/index.js.map +1 -0
- package/build/components/Common/PoweredByFooter/index.js +103 -0
- package/build/components/Common/PoweredByFooter/index.js.map +1 -0
- package/build/components/Common/Providers/ProviderHeader.d.ts +2 -2
- package/build/components/Common/Providers/ProviderHeader.js +55 -0
- package/build/components/Common/Providers/ProviderHeader.js.map +1 -0
- package/build/components/Common/Providers/ProviderIcon.d.ts +2 -2
- package/build/components/Common/Providers/ProviderIcon.js +41 -0
- package/build/components/Common/Providers/ProviderIcon.js.map +1 -0
- package/build/components/Common/Providers/getProviderName.d.ts +1 -1
- package/build/components/Common/Providers/getProviderName.js +15 -0
- package/build/components/Common/Providers/getProviderName.js.map +1 -0
- package/build/components/Common/ScrollArea/index.js +58 -0
- package/build/components/Common/ScrollArea/index.js.map +1 -0
- package/build/components/Common/ScrollArea/styles.js +168 -0
- package/build/components/Common/ScrollArea/styles.js.map +1 -0
- package/build/components/Common/Spinner/index.js +24 -0
- package/build/components/Common/Spinner/index.js.map +1 -0
- package/build/components/Common/Spinner/styles.js +22 -0
- package/build/components/Common/Spinner/styles.js.map +1 -0
- package/build/components/Common/SquircleSpinner/index.js +15 -0
- package/build/components/Common/SquircleSpinner/index.js.map +1 -0
- package/build/components/Common/SquircleSpinner/styles.js +66 -0
- package/build/components/Common/SquircleSpinner/styles.js.map +1 -0
- package/build/components/Common/ThemedButton/index.js +25 -0
- package/build/components/Common/ThemedButton/index.js.map +1 -0
- package/build/components/Common/ThemedButton/styles.js +152 -0
- package/build/components/Common/ThemedButton/styles.js.map +1 -0
- package/build/components/Common/TickList/index.js +11 -0
- package/build/components/Common/TickList/index.js.map +1 -0
- package/build/components/Common/TickList/styles.js +28 -0
- package/build/components/Common/TickList/styles.js.map +1 -0
- package/build/components/Common/Tooltip/index.js +91 -0
- package/build/components/Common/Tooltip/index.js.map +1 -0
- package/build/components/Common/Tooltip/styles.js +81 -0
- package/build/components/Common/Tooltip/styles.js.map +1 -0
- package/build/components/Common/WalletRecoveryIcon/index.d.ts +4 -0
- package/build/components/Common/WalletRecoveryIcon/index.js +19 -0
- package/build/components/Common/WalletRecoveryIcon/index.js.map +1 -0
- package/build/components/ConnectButton/index.d.ts +12 -4
- package/build/components/ConnectButton/index.js +266 -0
- package/build/components/ConnectButton/index.js.map +1 -0
- package/build/components/ConnectButton/styles.js +50 -0
- package/build/components/ConnectButton/styles.js.map +1 -0
- package/build/components/ConnectKitThemeProvider/ConnectKitThemeProvider.js +20 -0
- package/build/components/ConnectKitThemeProvider/ConnectKitThemeProvider.js.map +1 -0
- package/build/components/ConnectModal/ConnectUsing.d.ts +1 -1
- package/build/components/ConnectModal/ConnectUsing.js +68 -0
- package/build/components/ConnectModal/ConnectUsing.js.map +1 -0
- package/build/components/ConnectModal/ConnectWithInjector/CircleSpinner/index.js +17 -0
- package/build/components/ConnectModal/ConnectWithInjector/CircleSpinner/index.js.map +1 -0
- package/build/components/ConnectModal/ConnectWithInjector/CircleSpinner/styles.js +118 -0
- package/build/components/ConnectModal/ConnectWithInjector/CircleSpinner/styles.js.map +1 -0
- package/build/components/ConnectModal/ConnectWithInjector/index.d.ts +0 -2
- package/build/components/ConnectModal/ConnectWithInjector/index.js +295 -0
- package/build/components/ConnectModal/ConnectWithInjector/index.js.map +1 -0
- package/build/components/ConnectModal/ConnectWithInjector/styles.js +133 -0
- package/build/components/ConnectModal/ConnectWithInjector/styles.js.map +1 -0
- package/build/components/ConnectModal/ConnectWithMobile.js +99 -0
- package/build/components/ConnectModal/ConnectWithMobile.js.map +1 -0
- package/build/components/ConnectModal/ConnectWithOAuth.js +128 -0
- package/build/components/ConnectModal/ConnectWithOAuth.js.map +1 -0
- package/build/components/ConnectModal/ConnectWithQRCode.js +78 -0
- package/build/components/ConnectModal/ConnectWithQRCode.js.map +1 -0
- package/build/components/ConnectModal/index.js +230 -0
- package/build/components/ConnectModal/index.js.map +1 -0
- package/build/components/FloatingGraphic/index.js +13 -0
- package/build/components/FloatingGraphic/index.js.map +1 -0
- package/build/components/FloatingGraphic/styles.js +175 -0
- package/build/components/FloatingGraphic/styles.js.map +1 -0
- package/build/components/Openfort/OpenfortProvider.d.ts +10 -25
- package/build/components/Openfort/OpenfortProvider.js +351 -0
- package/build/components/Openfort/OpenfortProvider.js.map +1 -0
- package/build/components/Openfort/context.d.ts +48 -5
- package/build/components/Openfort/context.js +7 -0
- package/build/components/Openfort/context.js.map +1 -0
- package/build/components/Openfort/routeHelpers.d.ts +5 -0
- package/build/components/Openfort/routeHelpers.js +20 -0
- package/build/components/Openfort/routeHelpers.js.map +1 -0
- package/build/components/Openfort/types.d.ts +57 -23
- package/build/components/Openfort/types.js +119 -0
- package/build/components/Openfort/types.js.map +1 -0
- package/build/components/Openfort/useOpenfort.d.ts +2 -0
- package/build/components/Openfort/useOpenfort.js +12 -0
- package/build/components/Openfort/useOpenfort.js.map +1 -0
- package/build/components/PageContent/index.js +55 -0
- package/build/components/PageContent/index.js.map +1 -0
- package/build/components/PageContent/styles.js +11 -0
- package/build/components/PageContent/styles.js.map +1 -0
- package/build/components/Pages/About/graphics.js +193 -0
- package/build/components/Pages/About/graphics.js.map +1 -0
- package/build/components/Pages/About/index.js +142 -0
- package/build/components/Pages/About/index.js.map +1 -0
- package/build/components/Pages/About/styles.js +142 -0
- package/build/components/Pages/About/styles.js.map +1 -0
- package/build/components/Pages/AssetInventory/index.js +66 -0
- package/build/components/Pages/AssetInventory/index.js.map +1 -0
- package/build/components/Pages/Buy/coinbaseApi.js +106 -0
- package/build/components/Pages/Buy/coinbaseApi.js.map +1 -0
- package/build/components/Pages/Buy/index.js +88 -0
- package/build/components/Pages/Buy/index.js.map +1 -0
- package/build/components/Pages/Buy/onrampApi.js +57 -0
- package/build/components/Pages/Buy/onrampApi.js.map +1 -0
- package/build/components/Pages/Buy/providers.js +39 -0
- package/build/components/Pages/Buy/providers.js.map +1 -0
- package/build/components/Pages/Buy/stripeApi.js +74 -0
- package/build/components/Pages/Buy/stripeApi.js.map +1 -0
- package/build/components/Pages/Buy/styles.js +230 -0
- package/build/components/Pages/Buy/styles.js.map +1 -0
- package/build/components/Pages/Buy/utils.js +71 -0
- package/build/components/Pages/Buy/utils.js.map +1 -0
- package/build/components/Pages/BuyComplete/index.js +47 -0
- package/build/components/Pages/BuyComplete/index.js.map +1 -0
- package/build/components/Pages/BuyProcessing/index.js +231 -0
- package/build/components/Pages/BuyProcessing/index.js.map +1 -0
- package/build/components/Pages/BuyProviderSelect/index.js +55 -0
- package/build/components/Pages/BuyProviderSelect/index.js.map +1 -0
- package/build/components/Pages/BuyProviderSelect/styles.js +103 -0
- package/build/components/Pages/BuyProviderSelect/styles.js.map +1 -0
- package/build/components/Pages/BuySelectProvider/index.js +245 -0
- package/build/components/Pages/BuySelectProvider/index.js.map +1 -0
- package/build/components/Pages/Connected/ConnectedPageLayout.d.ts +22 -0
- package/build/components/Pages/Connected/ConnectedPageLayout.js +11 -0
- package/build/components/Pages/Connected/ConnectedPageLayout.js.map +1 -0
- package/build/components/Pages/Connected/EthereumConnected.d.ts +3 -0
- package/build/components/Pages/Connected/EthereumConnected.js +133 -0
- package/build/components/Pages/Connected/EthereumConnected.js.map +1 -0
- package/build/components/Pages/Connected/SolanaConnected.d.ts +3 -0
- package/build/components/Pages/Connected/SolanaConnected.js +96 -0
- package/build/components/Pages/Connected/SolanaConnected.js.map +1 -0
- package/build/components/Pages/Connected/index.d.ts +2 -2
- package/build/components/Pages/Connected/index.js +18 -0
- package/build/components/Pages/Connected/index.js.map +1 -0
- package/build/components/Pages/Connected/styles.js +122 -0
- package/build/components/Pages/Connected/styles.js.map +1 -0
- package/build/components/Pages/ConnectedSuccess/index.js +19 -0
- package/build/components/Pages/ConnectedSuccess/index.js.map +1 -0
- package/build/components/Pages/Connectors/index.js +73 -0
- package/build/components/Pages/Connectors/index.js.map +1 -0
- package/build/components/Pages/CreateGuestUserPage/index.js +28 -0
- package/build/components/Pages/CreateGuestUserPage/index.js.map +1 -0
- package/build/components/Pages/CreateWallet/SolanaCreateWallet.d.ts +6 -0
- package/build/components/Pages/CreateWallet/SolanaCreateWallet.js +241 -0
- package/build/components/Pages/CreateWallet/SolanaCreateWallet.js.map +1 -0
- package/build/components/Pages/CreateWallet/index.js +303 -0
- package/build/components/Pages/CreateWallet/index.js.map +1 -0
- package/build/components/Pages/CreateWallet/styles.js +17 -0
- package/build/components/Pages/CreateWallet/styles.js.map +1 -0
- package/build/components/Pages/DownloadApp/index.js +32 -0
- package/build/components/Pages/DownloadApp/index.js.map +1 -0
- package/build/components/Pages/EmailLogin/index.js +118 -0
- package/build/components/Pages/EmailLogin/index.js.map +1 -0
- package/build/components/Pages/EmailLogin/styles.js +24 -0
- package/build/components/Pages/EmailLogin/styles.js.map +1 -0
- package/build/components/Pages/EmailOTP/index.js +116 -0
- package/build/components/Pages/EmailOTP/index.js.map +1 -0
- package/build/components/Pages/EmailOTP/styles.js +38 -0
- package/build/components/Pages/EmailOTP/styles.js.map +1 -0
- package/build/components/Pages/EmailVerification/index.js +86 -0
- package/build/components/Pages/EmailVerification/index.js.map +1 -0
- package/build/components/Pages/ExportKey/index.js +44 -0
- package/build/components/Pages/ExportKey/index.js.map +1 -0
- package/build/components/Pages/ForgotPassword/index.js +129 -0
- package/build/components/Pages/ForgotPassword/index.js.map +1 -0
- package/build/components/Pages/LinkEmail/index.js +63 -0
- package/build/components/Pages/LinkEmail/index.js.map +1 -0
- package/build/components/Pages/LinkedProvider/index.d.ts +3 -0
- package/build/components/Pages/LinkedProvider/index.js +90 -0
- package/build/components/Pages/LinkedProvider/index.js.map +1 -0
- package/build/components/Pages/LinkedProviders/index.js +45 -0
- package/build/components/Pages/LinkedProviders/index.js.map +1 -0
- package/build/components/Pages/LinkedProviders/styles.js +51 -0
- package/build/components/Pages/LinkedProviders/styles.js.map +1 -0
- package/build/components/Pages/LoadWallets/index.js +91 -0
- package/build/components/Pages/LoadWallets/index.js.map +1 -0
- package/build/components/Pages/Loading/index.js +61 -0
- package/build/components/Pages/Loading/index.js.map +1 -0
- package/build/components/Pages/MobileConnectors/index.js +71 -0
- package/build/components/Pages/MobileConnectors/index.js.map +1 -0
- package/build/components/Pages/MobileConnectors/styles.js +65 -0
- package/build/components/Pages/MobileConnectors/styles.js.map +1 -0
- package/build/components/Pages/NoAssetsAvailable/index.js +45 -0
- package/build/components/Pages/NoAssetsAvailable/index.js.map +1 -0
- package/build/components/Pages/NoAssetsAvailable/styles.js +10 -0
- package/build/components/Pages/NoAssetsAvailable/styles.js.map +1 -0
- package/build/components/Pages/Onboarding/index.js +20 -0
- package/build/components/Pages/Onboarding/index.js.map +1 -0
- package/build/components/Pages/PhoneOTP/index.js +128 -0
- package/build/components/Pages/PhoneOTP/index.js.map +1 -0
- package/build/components/Pages/PhoneOTP/styles.js +38 -0
- package/build/components/Pages/PhoneOTP/styles.js.map +1 -0
- package/build/components/Pages/Profile/index.js +35 -0
- package/build/components/Pages/Profile/index.js.map +1 -0
- package/build/components/Pages/Providers/index.js +157 -0
- package/build/components/Pages/Providers/index.js.map +1 -0
- package/build/components/Pages/Providers/styles.js +156 -0
- package/build/components/Pages/Providers/styles.js.map +1 -0
- package/build/components/Pages/Receive/index.js +61 -0
- package/build/components/Pages/Receive/index.js.map +1 -0
- package/build/components/Pages/Receive/styles.d.ts +1 -0
- package/build/components/Pages/Receive/styles.js +52 -0
- package/build/components/Pages/Receive/styles.js.map +1 -0
- package/build/components/Pages/Recover/index.js +252 -0
- package/build/components/Pages/Recover/index.js.map +1 -0
- package/build/components/Pages/Recover/recoveryRegistry.d.ts +32 -0
- package/build/components/Pages/Recover/recoveryRegistry.js +61 -0
- package/build/components/Pages/Recover/recoveryRegistry.js.map +1 -0
- package/build/components/Pages/RemoveLinkedProvider/index.js +104 -0
- package/build/components/Pages/RemoveLinkedProvider/index.js.map +1 -0
- package/build/components/Pages/SelectToken/index.js +102 -0
- package/build/components/Pages/SelectToken/index.js.map +1 -0
- package/build/components/Pages/SelectToken/styles.js +78 -0
- package/build/components/Pages/SelectToken/styles.js.map +1 -0
- package/build/components/Pages/SelectWalletToRecover/index.d.ts +1 -2
- package/build/components/Pages/SelectWalletToRecover/index.js +70 -0
- package/build/components/Pages/SelectWalletToRecover/index.js.map +1 -0
- package/build/components/Pages/Send/EthereumSend.d.ts +1 -0
- package/build/components/Pages/Send/EthereumSend.js +88 -0
- package/build/components/Pages/Send/EthereumSend.js.map +1 -0
- package/build/components/Pages/Send/SolanaSend.d.ts +1 -0
- package/build/components/Pages/Send/SolanaSend.js +93 -0
- package/build/components/Pages/Send/SolanaSend.js.map +1 -0
- package/build/components/Pages/Send/index.d.ts +7 -1
- package/build/components/Pages/Send/index.js +18 -0
- package/build/components/Pages/Send/index.js.map +1 -0
- package/build/components/Pages/Send/styles.js +112 -0
- package/build/components/Pages/Send/styles.js.map +1 -0
- package/build/components/Pages/Send/utils.d.ts +1 -1
- package/build/components/Pages/Send/utils.js +63 -0
- package/build/components/Pages/Send/utils.js.map +1 -0
- package/build/components/Pages/SendConfirmation/EstimatedFees.js +66 -0
- package/build/components/Pages/SendConfirmation/EstimatedFees.js.map +1 -0
- package/build/components/Pages/SendConfirmation/index.js +331 -0
- package/build/components/Pages/SendConfirmation/index.js.map +1 -0
- package/build/components/Pages/SendConfirmation/styles.js +129 -0
- package/build/components/Pages/SendConfirmation/styles.js.map +1 -0
- package/build/components/Pages/SocialProviders/index.js +15 -0
- package/build/components/Pages/SocialProviders/index.js.map +1 -0
- package/build/components/Pages/SolanaSendConfirmation/index.d.ts +1 -0
- package/build/components/Pages/SolanaSendConfirmation/index.js +152 -0
- package/build/components/Pages/SolanaSendConfirmation/index.js.map +1 -0
- package/build/components/Pages/SolanaWallets/index.d.ts +1 -0
- package/build/components/Pages/SolanaWallets/index.js +36 -0
- package/build/components/Pages/SolanaWallets/index.js.map +1 -0
- package/build/components/PasswordStrength/PasswordStrengthIndicator.js +62 -0
- package/build/components/PasswordStrength/PasswordStrengthIndicator.js.map +1 -0
- package/build/components/PasswordStrength/password-utility.js +128 -0
- package/build/components/PasswordStrength/password-utility.js.map +1 -0
- package/build/constants/chainConfigs.js +316 -0
- package/build/constants/chainConfigs.js.map +1 -0
- package/build/constants/defaultTheme.js +6 -0
- package/build/constants/defaultTheme.js.map +1 -0
- package/build/constants/openfort.d.ts +4 -0
- package/build/constants/openfort.js +8 -0
- package/build/constants/openfort.js.map +1 -0
- package/build/core/ConnectionStrategy.d.ts +31 -0
- package/build/core/ConnectionStrategy.js +9 -0
- package/build/core/ConnectionStrategy.js.map +1 -0
- package/build/core/ConnectionStrategyContext.d.ts +16 -0
- package/build/core/ConnectionStrategyContext.js +22 -0
- package/build/core/ConnectionStrategyContext.js.map +1 -0
- package/build/core/errors.d.ts +1 -0
- package/build/core/strategies/EthereumBridgeStrategy.d.ts +11 -0
- package/build/core/strategies/EthereumBridgeStrategy.js +83 -0
- package/build/core/strategies/EthereumBridgeStrategy.js.map +1 -0
- package/build/core/strategies/EthereumEmbeddedStrategy.d.ts +8 -0
- package/build/core/strategies/EthereumEmbeddedStrategy.js +85 -0
- package/build/core/strategies/EthereumEmbeddedStrategy.js.map +1 -0
- package/build/core/strategies/SolanaEmbeddedStrategy.d.ts +9 -0
- package/build/core/strategies/SolanaEmbeddedStrategy.js +53 -0
- package/build/core/strategies/SolanaEmbeddedStrategy.js.map +1 -0
- package/build/core/strategyUtils.d.ts +6 -0
- package/build/core/strategyUtils.js +31 -0
- package/build/core/strategyUtils.js.map +1 -0
- package/build/ethereum/OpenfortEthereumBridgeContext.d.ts +87 -0
- package/build/ethereum/OpenfortEthereumBridgeContext.js +18 -0
- package/build/ethereum/OpenfortEthereumBridgeContext.js.map +1 -0
- package/build/ethereum/hooks/getEmbeddedWalletClient.d.ts +14 -0
- package/build/ethereum/hooks/getEmbeddedWalletClient.js +24 -0
- package/build/ethereum/hooks/getEmbeddedWalletClient.js.map +1 -0
- package/build/ethereum/hooks/useEthereumEmbeddedWallet.d.ts +17 -0
- package/build/ethereum/hooks/useEthereumEmbeddedWallet.js +425 -0
- package/build/ethereum/hooks/useEthereumEmbeddedWallet.js.map +1 -0
- package/build/ethereum/hooks/useEthereumWalletAssets.d.ts +29 -0
- package/build/ethereum/hooks/useEthereumWalletAssets.js +204 -0
- package/build/ethereum/hooks/useEthereumWalletAssets.js.map +1 -0
- package/build/ethereum/index.d.ts +11 -0
- package/build/ethereum/index.js +3 -0
- package/build/ethereum/index.js.map +1 -0
- package/build/ethereum/types.d.ts +140 -0
- package/build/hooks/openfort/auth/requestEmailVerification.js +21 -0
- package/build/hooks/openfort/auth/requestEmailVerification.js.map +1 -0
- package/build/hooks/openfort/auth/status.js +11 -0
- package/build/hooks/openfort/auth/status.js.map +1 -0
- package/build/hooks/openfort/auth/useAuthCallback.d.ts +2 -1
- package/build/hooks/openfort/auth/useAuthCallback.js +197 -0
- package/build/hooks/openfort/auth/useAuthCallback.js.map +1 -0
- package/build/hooks/openfort/auth/useConnectToWalletPostAuth.d.ts +3 -2
- package/build/hooks/openfort/auth/useConnectToWalletPostAuth.js +161 -0
- package/build/hooks/openfort/auth/useConnectToWalletPostAuth.js.map +1 -0
- package/build/hooks/openfort/auth/useEmailAuth.d.ts +4 -3
- package/build/hooks/openfort/auth/useEmailAuth.js +496 -0
- package/build/hooks/openfort/auth/useEmailAuth.js.map +1 -0
- package/build/hooks/openfort/auth/useEmailOtpAuth.d.ts +4 -3
- package/build/hooks/openfort/auth/useEmailOtpAuth.js +151 -0
- package/build/hooks/openfort/auth/useEmailOtpAuth.js.map +1 -0
- package/build/hooks/openfort/auth/useGuestAuth.d.ts +4 -3
- package/build/hooks/openfort/auth/useGuestAuth.js +142 -0
- package/build/hooks/openfort/auth/useGuestAuth.js.map +1 -0
- package/build/hooks/openfort/auth/useOAuth.d.ts +4 -3
- package/build/hooks/openfort/auth/useOAuth.js +217 -0
- package/build/hooks/openfort/auth/useOAuth.js.map +1 -0
- package/build/hooks/openfort/auth/usePhoneOtpAuth.d.ts +4 -3
- package/build/hooks/openfort/auth/usePhoneOtpAuth.js +174 -0
- package/build/hooks/openfort/auth/usePhoneOtpAuth.js.map +1 -0
- package/build/hooks/openfort/auth/useSignOut.d.ts +2 -1
- package/build/hooks/openfort/auth/useSignOut.js +104 -0
- package/build/hooks/openfort/auth/useSignOut.js.map +1 -0
- package/build/hooks/openfort/hookConsistency.js +17 -0
- package/build/hooks/openfort/hookConsistency.js.map +1 -0
- package/build/hooks/openfort/use7702Authorization.js +73 -0
- package/build/hooks/openfort/use7702Authorization.js.map +1 -0
- package/build/hooks/openfort/useGrantPermissions.d.ts +7 -76
- package/build/hooks/openfort/useGrantPermissions.js +221 -0
- package/build/hooks/openfort/useGrantPermissions.js.map +1 -0
- package/build/hooks/openfort/useProviders.js +75 -0
- package/build/hooks/openfort/useProviders.js.map +1 -0
- package/build/hooks/openfort/useRevokePermissions.d.ts +2 -1
- package/build/hooks/openfort/useRevokePermissions.js +126 -0
- package/build/hooks/openfort/useRevokePermissions.js.map +1 -0
- package/build/hooks/openfort/useUI.d.ts +4 -45
- package/build/hooks/openfort/useUI.js +122 -0
- package/build/hooks/openfort/useUI.js.map +1 -0
- package/build/hooks/openfort/useUser.d.ts +12 -35
- package/build/hooks/openfort/useUser.js +61 -0
- package/build/hooks/openfort/useUser.js.map +1 -0
- package/build/hooks/openfort/walletTypes.d.ts +32 -0
- package/build/hooks/openfort/walletTypes.js +53 -0
- package/build/hooks/openfort/walletTypes.js.map +1 -0
- package/build/hooks/useBalance.d.ts +50 -0
- package/build/hooks/useBalance.js +80 -0
- package/build/hooks/useBalance.js.map +1 -0
- package/build/hooks/useConnectLifecycle.d.ts +7 -0
- package/build/hooks/useConnectLifecycle.js +43 -0
- package/build/hooks/useConnectLifecycle.js.map +1 -0
- package/build/hooks/useConnectors.d.ts +3 -5
- package/build/hooks/useConnectors.js +26 -0
- package/build/hooks/useConnectors.js.map +1 -0
- package/build/hooks/useCopyToClipboard.js +29 -0
- package/build/hooks/useCopyToClipboard.js.map +1 -0
- package/build/hooks/useFitText.js +125 -0
- package/build/hooks/useFitText.js.map +1 -0
- package/build/hooks/useFocusTrap.d.ts +4 -1
- package/build/hooks/useFocusTrap.js +60 -0
- package/build/hooks/useFocusTrap.js.map +1 -0
- package/build/hooks/useGoogleFont.js +43 -0
- package/build/hooks/useGoogleFont.js.map +1 -0
- package/build/hooks/useIsMobile.js +17 -0
- package/build/hooks/useIsMobile.js.map +1 -0
- package/build/hooks/useIsMounted.js +10 -0
- package/build/hooks/useIsMounted.js.map +1 -0
- package/build/hooks/useLastConnector.js +39 -0
- package/build/hooks/useLastConnector.js.map +1 -0
- package/build/hooks/useLocales.d.ts +1 -1
- package/build/hooks/useLocales.js +68 -0
- package/build/hooks/useLocales.js.map +1 -0
- package/build/hooks/useLockBodyScroll.js +53 -0
- package/build/hooks/useLockBodyScroll.js.map +1 -0
- package/build/hooks/usePrevious.js +14 -0
- package/build/hooks/usePrevious.js.map +1 -0
- package/build/hooks/useResolvedIdentity.d.ts +70 -0
- package/build/hooks/useResolvedIdentity.js +90 -0
- package/build/hooks/useResolvedIdentity.js.map +1 -0
- package/build/hooks/useRouteProps.d.ts +10 -5
- package/build/hooks/useRouteProps.js +27 -0
- package/build/hooks/useRouteProps.js.map +1 -0
- package/build/hooks/useWalletConnectModal.js +59 -0
- package/build/hooks/useWalletConnectModal.js.map +1 -0
- package/build/hooks/useWindowSize.js +23 -0
- package/build/hooks/useWindowSize.js.map +1 -0
- package/build/index.d.ts +61 -16
- package/build/index.js +31 -0
- package/build/index.js.map +1 -0
- package/build/localizations/index.js +57 -0
- package/build/localizations/index.js.map +1 -0
- package/build/localizations/locales/ar-AE.js +100 -0
- package/build/localizations/locales/ar-AE.js.map +1 -0
- package/build/localizations/locales/ca-AD.js +98 -0
- package/build/localizations/locales/ca-AD.js.map +1 -0
- package/build/localizations/locales/ee-EE.js +98 -0
- package/build/localizations/locales/ee-EE.js.map +1 -0
- package/build/localizations/locales/en-US.js +115 -0
- package/build/localizations/locales/en-US.js.map +1 -0
- package/build/localizations/locales/es-ES.js +98 -0
- package/build/localizations/locales/es-ES.js.map +1 -0
- package/build/localizations/locales/fa-IR.js +98 -0
- package/build/localizations/locales/fa-IR.js.map +1 -0
- package/build/localizations/locales/fr-FR.js +98 -0
- package/build/localizations/locales/fr-FR.js.map +1 -0
- package/build/localizations/locales/ja-JP.js +98 -0
- package/build/localizations/locales/ja-JP.js.map +1 -0
- package/build/localizations/locales/pt-BR.js +98 -0
- package/build/localizations/locales/pt-BR.js.map +1 -0
- package/build/localizations/locales/ru-RU.js +98 -0
- package/build/localizations/locales/ru-RU.js.map +1 -0
- package/build/localizations/locales/tr-TR.js +98 -0
- package/build/localizations/locales/tr-TR.js.map +1 -0
- package/build/localizations/locales/vi-VN.js +98 -0
- package/build/localizations/locales/vi-VN.js.map +1 -0
- package/build/localizations/locales/zh-CN.js +98 -0
- package/build/localizations/locales/zh-CN.js.map +1 -0
- package/build/openfort/CoreOpenfortProvider.d.ts +9 -22
- package/build/openfort/CoreOpenfortProvider.js +389 -0
- package/build/openfort/CoreOpenfortProvider.js.map +1 -0
- package/build/{hooks/useConnectCallback.d.ts → openfort/connectCallbackTypes.d.ts} +2 -2
- package/build/openfort/context.d.ts +3 -2
- package/build/openfort/context.js +6 -0
- package/build/openfort/context.js.map +1 -0
- package/build/openfort/core/client.d.ts +2 -1
- package/build/openfort/core/client.js +23 -0
- package/build/openfort/core/client.js.map +1 -0
- package/build/openfort/hooks/useActiveAddressSync.d.ts +20 -0
- package/build/openfort/hooks/useActiveAddressSync.js +76 -0
- package/build/openfort/hooks/useActiveAddressSync.js.map +1 -0
- package/build/openfort/hooks/useAutoRecovery.d.ts +26 -0
- package/build/openfort/hooks/useAutoRecovery.js +102 -0
- package/build/openfort/hooks/useAutoRecovery.js.map +1 -0
- package/build/openfort/hooks/useEmbeddedStateMachine.d.ts +31 -0
- package/build/openfort/hooks/useEmbeddedStateMachine.js +77 -0
- package/build/openfort/hooks/useEmbeddedStateMachine.js.map +1 -0
- package/build/openfort/selectors.d.ts +9 -0
- package/build/openfort/selectors.js +15 -0
- package/build/openfort/selectors.js.map +1 -0
- package/build/openfort/store.d.ts +46 -0
- package/build/openfort/store.js +116 -0
- package/build/openfort/store.js.map +1 -0
- package/build/openfort/useOpenfort.d.ts +9 -3
- package/build/openfort/useOpenfort.js +15 -0
- package/build/openfort/useOpenfort.js.map +1 -0
- package/build/openfort/useOpenfortStore.d.ts +2 -0
- package/build/openfort/useOpenfortStore.js +13 -0
- package/build/openfort/useOpenfortStore.js.map +1 -0
- package/build/query/index.d.ts +2 -0
- package/build/query/queryKeys.d.ts +12 -0
- package/build/query/queryKeys.js +15 -0
- package/build/query/queryKeys.js.map +1 -0
- package/build/query/queryOptions.d.ts +23 -0
- package/build/query/queryOptions.js +31 -0
- package/build/query/queryOptions.js.map +1 -0
- package/build/shared/hooks/useAsyncData.d.ts +19 -0
- package/build/shared/hooks/useAsyncData.js +69 -0
- package/build/shared/hooks/useAsyncData.js.map +1 -0
- package/build/shared/hooks/useRecoveryOTP.d.ts +11 -0
- package/build/shared/hooks/useRecoveryOTP.js +64 -0
- package/build/shared/hooks/useRecoveryOTP.js.map +1 -0
- package/build/shared/types.d.ts +65 -0
- package/build/shared/utils/embeddedWalletStatusMapper.d.ts +15 -0
- package/build/shared/utils/embeddedWalletStatusMapper.js +22 -0
- package/build/shared/utils/embeddedWalletStatusMapper.js.map +1 -0
- package/build/shared/utils/explorer.d.ts +24 -0
- package/build/shared/utils/explorer.js +71 -0
- package/build/shared/utils/explorer.js.map +1 -0
- package/build/shared/utils/otpError.d.ts +8 -0
- package/build/shared/utils/otpError.js +17 -0
- package/build/shared/utils/otpError.js.map +1 -0
- package/build/shared/utils/recovery.d.ts +15 -0
- package/build/shared/utils/recovery.js +96 -0
- package/build/shared/utils/recovery.js.map +1 -0
- package/build/shared/utils/validation.d.ts +15 -0
- package/build/shared/utils/validation.js +27 -0
- package/build/shared/utils/validation.js.map +1 -0
- package/build/shared/utils/walletStatusProps.d.ts +18 -0
- package/build/shared/utils/walletStatusProps.js +45 -0
- package/build/shared/utils/walletStatusProps.js.map +1 -0
- package/build/siwe/create-siwe-message.d.ts +15 -1
- package/build/siwe/create-siwe-message.js +32 -0
- package/build/siwe/create-siwe-message.js.map +1 -0
- package/build/solana/SolanaContext.d.ts +43 -0
- package/build/solana/SolanaContext.js +87 -0
- package/build/solana/SolanaContext.js.map +1 -0
- package/build/solana/constants.d.ts +21 -0
- package/build/solana/constants.js +24 -0
- package/build/solana/constants.js.map +1 -0
- package/build/solana/hooks/recoveryResolver.d.ts +16 -0
- package/build/solana/hooks/recoveryResolver.js +39 -0
- package/build/solana/hooks/recoveryResolver.js.map +1 -0
- package/build/solana/hooks/useSolanaEmbeddedWallet.d.ts +17 -0
- package/build/solana/hooks/useSolanaEmbeddedWallet.js +389 -0
- package/build/solana/hooks/useSolanaEmbeddedWallet.js.map +1 -0
- package/build/solana/hooks/utils.d.ts +2 -0
- package/build/solana/hooks/utils.js +18 -0
- package/build/solana/hooks/utils.js.map +1 -0
- package/build/solana/index.d.ts +12 -0
- package/build/solana/index.js +2 -0
- package/build/solana/index.js.map +1 -0
- package/build/solana/operations.d.ts +22 -0
- package/build/solana/operations.js +40 -0
- package/build/solana/operations.js.map +1 -0
- package/build/solana/provider.d.ts +131 -0
- package/build/solana/provider.js +126 -0
- package/build/solana/provider.js.map +1 -0
- package/build/solana/types.d.ts +253 -0
- package/build/solana/utils/transfer.d.ts +9 -0
- package/build/solana/utils/transfer.js +20 -0
- package/build/solana/utils/transfer.js.map +1 -0
- package/build/styles/index.js +334 -0
- package/build/styles/index.js.map +1 -0
- package/build/styles/styled/index.js +14 -0
- package/build/styles/styled/index.js.map +1 -0
- package/build/styles/themes/base.js +147 -0
- package/build/styles/themes/base.js.map +1 -0
- package/build/styles/themes/index.js +13 -0
- package/build/styles/themes/index.js.map +1 -0
- package/build/styles/themes/midnight.js +78 -0
- package/build/styles/themes/midnight.js.map +1 -0
- package/build/styles/themes/minimal.js +100 -0
- package/build/styles/themes/minimal.js.map +1 -0
- package/build/styles/themes/nouns.js +83 -0
- package/build/styles/themes/nouns.js.map +1 -0
- package/build/styles/themes/retro.js +110 -0
- package/build/styles/themes/retro.js.map +1 -0
- package/build/styles/themes/rounded.js +110 -0
- package/build/styles/themes/rounded.js.map +1 -0
- package/build/styles/themes/soft.js +73 -0
- package/build/styles/themes/soft.js.map +1 -0
- package/build/styles/themes/web95.js +136 -0
- package/build/styles/themes/web95.js.map +1 -0
- package/build/types.d.ts +5 -6
- package/build/types.js +33 -0
- package/build/types.js.map +1 -0
- package/build/utils/banner.d.ts +1 -0
- package/build/utils/banner.js +14 -0
- package/build/utils/banner.js.map +1 -0
- package/build/utils/errorHandling.js +331 -0
- package/build/utils/errorHandling.js.map +1 -0
- package/build/utils/format.d.ts +18 -0
- package/build/utils/format.js +59 -0
- package/build/utils/format.js.map +1 -0
- package/build/utils/index.d.ts +2 -3
- package/build/utils/index.js +67 -0
- package/build/utils/index.js.map +1 -0
- package/build/utils/logger.js +13 -0
- package/build/utils/logger.js.map +1 -0
- package/build/utils/oauthErrorHandler.d.ts +1 -1
- package/build/utils/oauthErrorHandler.js +42 -0
- package/build/utils/oauthErrorHandler.js.map +1 -0
- package/build/utils/p3.js +14 -0
- package/build/utils/p3.js.map +1 -0
- package/build/utils/rpc.d.ts +34 -0
- package/build/utils/rpc.js +93 -0
- package/build/utils/rpc.js.map +1 -0
- package/build/utils/useOnUserReturn.js +25 -0
- package/build/utils/useOnUserReturn.js.map +1 -0
- package/build/utils/validation.js +7 -0
- package/build/utils/validation.js.map +1 -0
- package/build/utils/wallets.d.ts +6 -0
- package/build/utils/wallets.js +14 -0
- package/build/utils/wallets.js.map +1 -0
- package/build/version.d.ts +1 -1
- package/build/version.js +4 -0
- package/build/version.js.map +1 -0
- package/build/wagmi/OpenfortWagmiBridge.d.ts +3 -0
- package/build/wagmi/OpenfortWagmiBridge.js +166 -0
- package/build/wagmi/OpenfortWagmiBridge.js.map +1 -0
- package/build/wagmi/components/ChainSelect/index.js +140 -0
- package/build/wagmi/components/ChainSelect/index.js.map +1 -0
- package/build/wagmi/components/ChainSelectDropdown/index.js +144 -0
- package/build/wagmi/components/ChainSelectDropdown/index.js.map +1 -0
- package/build/wagmi/components/ChainSelectDropdown/styles.js +47 -0
- package/build/wagmi/components/ChainSelectDropdown/styles.js.map +1 -0
- package/build/wagmi/components/ChainSelectList/index.js +109 -0
- package/build/wagmi/components/ChainSelectList/index.js.map +1 -0
- package/build/wagmi/components/ChainSelectList/styles.js +225 -0
- package/build/wagmi/components/ChainSelectList/styles.js.map +1 -0
- package/build/wagmi/components/SwitchNetworks/index.js +22 -0
- package/build/wagmi/components/SwitchNetworks/index.js.map +1 -0
- package/build/wagmi/connectorFilter.d.ts +6 -0
- package/build/wagmi/connectorFilter.js +16 -0
- package/build/wagmi/connectorFilter.js.map +1 -0
- package/build/{defaultConfig.d.ts → wagmi/defaultConfig.d.ts} +1 -2
- package/build/wagmi/defaultConfig.js +27 -0
- package/build/wagmi/defaultConfig.js.map +1 -0
- package/build/wagmi/defaultConnectors.js +36 -0
- package/build/wagmi/defaultConnectors.js.map +1 -0
- package/build/wagmi/embeddedConnector.d.ts +4 -0
- package/build/wagmi/embeddedConnector.js +80 -0
- package/build/wagmi/embeddedConnector.js.map +1 -0
- package/build/wagmi/index.d.ts +10 -0
- package/build/wagmi/index.js +10 -0
- package/build/wagmi/index.js.map +1 -0
- package/build/wagmi/useChainIsSupported.d.ts +20 -0
- package/build/wagmi/useChainIsSupported.js +30 -0
- package/build/wagmi/useChainIsSupported.js.map +1 -0
- package/build/wagmi/useChains.d.ts +29 -0
- package/build/wagmi/useChains.js +38 -0
- package/build/wagmi/useChains.js.map +1 -0
- package/build/wagmi/useConnectWithSiwe.d.ts +22 -0
- package/build/wagmi/useConnectWithSiwe.js +115 -0
- package/build/wagmi/useConnectWithSiwe.js.map +1 -0
- package/build/wagmi/useEmbeddedWalletWagmiSync.d.ts +2 -0
- package/build/wagmi/useEmbeddedWalletWagmiSync.js +55 -0
- package/build/wagmi/useEmbeddedWalletWagmiSync.js.map +1 -0
- package/build/wagmi/useWalletAuth.d.ts +24 -0
- package/build/wagmi/useWalletAuth.js +180 -0
- package/build/wagmi/useWalletAuth.js.map +1 -0
- package/build/wallets/useExternalConnectors.d.ts +17 -0
- package/build/wallets/useExternalConnectors.js +98 -0
- package/build/wallets/useExternalConnectors.js.map +1 -0
- package/build/wallets/walletConfigs.js +344 -0
- package/build/wallets/walletConfigs.js.map +1 -0
- package/package.json +62 -11
- package/build/components/PageLayout/index.d.ts +0 -6
- package/build/components/contexts/web3/index.d.ts +0 -13
- package/build/constants/erc20.d.ts +0 -42
- package/build/hooks/openfort/auth/useWalletAuth.d.ts +0 -20
- package/build/hooks/openfort/useConnectWithSiwe.d.ts +0 -8
- package/build/hooks/openfort/useWalletAssets.d.ts +0 -16
- package/build/hooks/openfort/useWallets.d.ts +0 -134
- package/build/hooks/useChainIsSupported.d.ts +0 -24
- package/build/hooks/useChains.d.ts +0 -41
- package/build/hooks/useConnect.d.ts +0 -24
- package/build/hooks/useEnsFallbackConfig.d.ts +0 -1
- package/build/index.es.js +0 -19620
- package/build/index.es.js.map +0 -1
- package/build/openfortCustomTypes.d.ts +0 -10
- package/build/wallets/index.d.ts +0 -7
- package/build/wallets/useWagmiWallets.d.ts +0 -9
- /package/build/components/Pages/{SoicalProviders → SocialProviders}/index.d.ts +0 -0
- /package/build/{components/Common → wagmi/components}/ChainSelect/index.d.ts +0 -0
- /package/build/{components/Common → wagmi/components}/ChainSelectDropdown/index.d.ts +0 -0
- /package/build/{components/Common → wagmi/components}/ChainSelectDropdown/styles.d.ts +0 -0
- /package/build/{components/Common → wagmi/components}/ChainSelectList/index.d.ts +0 -0
- /package/build/{components/Common → wagmi/components}/ChainSelectList/styles.d.ts +0 -0
- /package/build/{components/Pages → wagmi/components}/SwitchNetworks/index.d.ts +0 -0
- /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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|