@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.
- 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 +227 -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/index.d.ts +7 -1
- package/build/components/Pages/Send/index.js +17 -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/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 +2 -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/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/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 +1 -0
- package/build/solana/hooks/utils.js +10 -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/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 -19627
- 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,96 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { ChainTypeEnum } from '@openfort/openfort-js';
|
|
3
|
+
import { useEffect } from 'react';
|
|
4
|
+
import { UserRoundIcon, ReceiveIcon } from '../../../assets/icons.js';
|
|
5
|
+
import { BALANCE_INVALIDATE_EVENT, fetchSolanaBalance } from '../../../hooks/useBalance.js';
|
|
6
|
+
import useLocales from '../../../hooks/useLocales.js';
|
|
7
|
+
import { useOpenfortCore } from '../../../openfort/useOpenfort.js';
|
|
8
|
+
import { useAsyncData } from '../../../shared/hooks/useAsyncData.js';
|
|
9
|
+
import { useSolanaEmbeddedWallet } from '../../../solana/hooks/useSolanaEmbeddedWallet.js';
|
|
10
|
+
import { formatSol } from '../../../solana/hooks/utils.js';
|
|
11
|
+
import { useSolanaContext } from '../../../solana/SolanaContext.js';
|
|
12
|
+
import { nFormatter } from '../../../utils/index.js';
|
|
13
|
+
import { logger } from '../../../utils/logger.js';
|
|
14
|
+
import Avatar from '../../Common/Avatar/index.js';
|
|
15
|
+
import Button from '../../Common/Button/index.js';
|
|
16
|
+
import { CopyText } from '../../Common/CopyToClipboard/CopyText.js';
|
|
17
|
+
import { useThemeContext } from '../../ConnectKitThemeProvider/ConnectKitThemeProvider.js';
|
|
18
|
+
import { routes } from '../../Openfort/types.js';
|
|
19
|
+
import { useOpenfort } from '../../Openfort/useOpenfort.js';
|
|
20
|
+
import { PageContent } from '../../PageContent/index.js';
|
|
21
|
+
import { ConnectedPageLayout } from './ConnectedPageLayout.js';
|
|
22
|
+
import { LinkedProvidersToggle, Balance, ActionButton } from './styles.js';
|
|
23
|
+
import { truncateSolanaAddress } from '../../../utils/format.js';
|
|
24
|
+
|
|
25
|
+
const SolanaConnected = () => {
|
|
26
|
+
var _a, _b, _c, _d, _e;
|
|
27
|
+
const context = useOpenfort();
|
|
28
|
+
const { setHeaderLeftSlot, setRoute } = context;
|
|
29
|
+
const locales = useLocales();
|
|
30
|
+
const wallet = useSolanaEmbeddedWallet();
|
|
31
|
+
const { embeddedAccounts } = useOpenfortCore();
|
|
32
|
+
const { rpcUrl } = useSolanaContext();
|
|
33
|
+
const hasSolanaWallets = ((_a = embeddedAccounts === null || embeddedAccounts === void 0 ? void 0 : embeddedAccounts.filter((a) => a.chainType === ChainTypeEnum.SVM)) !== null && _a !== void 0 ? _a : []).length > 0;
|
|
34
|
+
const isAddressLoading = wallet.status === 'connected' && !wallet.address;
|
|
35
|
+
const address = wallet.status === 'connected' && wallet.address ? wallet.address : undefined;
|
|
36
|
+
const { triggerResize } = context;
|
|
37
|
+
// When the address becomes available, trigger a modal resize so the modal
|
|
38
|
+
// height (measured via offsetHeight) reflects the full connected layout.
|
|
39
|
+
useEffect(() => {
|
|
40
|
+
if (address)
|
|
41
|
+
triggerResize();
|
|
42
|
+
}, [address, triggerResize]);
|
|
43
|
+
const balanceResult = useAsyncData({
|
|
44
|
+
queryKey: ['solana-balance', address, rpcUrl],
|
|
45
|
+
queryFn: async () => {
|
|
46
|
+
if (!address || !rpcUrl)
|
|
47
|
+
return null;
|
|
48
|
+
try {
|
|
49
|
+
const balanceLamports = await fetchSolanaBalance(address, rpcUrl, 'confirmed');
|
|
50
|
+
return balanceLamports.value;
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
logger.error('Failed to fetch Solana balance:', error);
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
enabled: Boolean(address && rpcUrl),
|
|
58
|
+
});
|
|
59
|
+
useEffect(() => {
|
|
60
|
+
if (!address || !rpcUrl)
|
|
61
|
+
return;
|
|
62
|
+
const handler = () => balanceResult.refetch().catch(() => { });
|
|
63
|
+
window.addEventListener(BALANCE_INVALIDATE_EVENT, handler);
|
|
64
|
+
return () => window.removeEventListener(BALANCE_INVALIDATE_EVENT, handler);
|
|
65
|
+
}, [address, rpcUrl, balanceResult.refetch]);
|
|
66
|
+
const lamports = balanceResult.data;
|
|
67
|
+
const isBalanceLoading = balanceResult.isLoading;
|
|
68
|
+
const balanceSol = lamports != null ? formatSol(BigInt(lamports), 9) : null;
|
|
69
|
+
// Re-measure when balance loads so the modal expands to fit balance + actions.
|
|
70
|
+
useEffect(() => {
|
|
71
|
+
if (!isBalanceLoading)
|
|
72
|
+
triggerResize();
|
|
73
|
+
}, [isBalanceLoading, triggerResize]);
|
|
74
|
+
useEffect(() => {
|
|
75
|
+
if (!address) {
|
|
76
|
+
setHeaderLeftSlot(null);
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
setHeaderLeftSlot(jsx(LinkedProvidersToggle, { type: "button", onClick: () => setRoute(routes.PROFILE), "aria-label": "Profile", title: "Profile", children: jsx(UserRoundIcon, {}) }));
|
|
80
|
+
return () => {
|
|
81
|
+
setHeaderLeftSlot(null);
|
|
82
|
+
};
|
|
83
|
+
}, [address, setHeaderLeftSlot, setRoute]);
|
|
84
|
+
const themeContext = useThemeContext();
|
|
85
|
+
const solanaUI = (_c = (_b = context.walletConfig) === null || _b === void 0 ? void 0 : _b.solana) === null || _c === void 0 ? void 0 : _c.ui;
|
|
86
|
+
const CustomAvatar = solanaUI === null || solanaUI === void 0 ? void 0 : solanaUI.customAvatar;
|
|
87
|
+
const separator = ['web95', 'rounded', 'minimal'].includes((_e = (_d = themeContext.theme) !== null && _d !== void 0 ? _d : context.uiConfig.theme) !== null && _e !== void 0 ? _e : '')
|
|
88
|
+
? '....'
|
|
89
|
+
: undefined;
|
|
90
|
+
const avatar = address ? CustomAvatar ? jsx(CustomAvatar, { address: address }) : jsx(Avatar, { address: address }) : jsx("span", {});
|
|
91
|
+
const balanceNode = balanceSol != null && !isBalanceLoading ? (jsxs(Balance, { initial: { opacity: 0 }, animate: { opacity: 1 }, exit: { opacity: 0 }, transition: { duration: 0.2 }, children: [nFormatter(Number(balanceSol)), " SOL"] }, "solana-balance")) : null;
|
|
92
|
+
return (jsx(PageContent, { onBack: null, header: locales.profileScreen_heading, children: jsx(ConnectedPageLayout, { address: address !== null && address !== void 0 ? address : '', displayName: jsx(CopyText, { value: address !== null && address !== void 0 ? address : '', children: truncateSolanaAddress(address !== null && address !== void 0 ? address : '', separator) }), avatar: avatar, balance: balanceNode, actions: jsx(ActionButton, { icon: jsx(ReceiveIcon, {}), onClick: () => context.setRoute(routes.SOL_RECEIVE), children: "Get" }), hideBalance: context === null || context === void 0 ? void 0 : context.uiConfig.hideBalance, isBalanceLoading: isBalanceLoading, isAddressLoading: isAddressLoading, noWalletFallback: hasSolanaWallets ? (jsx(Button, { onClick: () => setRoute(routes.SOL_WALLETS), children: "Manage wallets" })) : (jsx(Button, { onClick: () => setRoute(routes.SOL_CREATE_WALLET), children: "Create Solana Wallet" })) }) }));
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
export { SolanaConnected as default };
|
|
96
|
+
//# sourceMappingURL=SolanaConnected.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SolanaConnected.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
export
|
|
1
|
+
import type React from 'react';
|
|
2
|
+
export declare const Connected: React.FC;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { ChainTypeEnum } from '@openfort/openfort-js';
|
|
3
|
+
import { useOpenfortCore } from '../../../openfort/useOpenfort.js';
|
|
4
|
+
import EthereumConnected from './EthereumConnected.js';
|
|
5
|
+
import SolanaConnected from './SolanaConnected.js';
|
|
6
|
+
|
|
7
|
+
const CONNECTED_REGISTRY = {
|
|
8
|
+
[ChainTypeEnum.EVM]: EthereumConnected,
|
|
9
|
+
[ChainTypeEnum.SVM]: SolanaConnected,
|
|
10
|
+
};
|
|
11
|
+
const Connected = () => {
|
|
12
|
+
const { chainType } = useOpenfortCore();
|
|
13
|
+
const Component = CONNECTED_REGISTRY[chainType];
|
|
14
|
+
return Component ? jsx(Component, {}) : null;
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
export { Connected };
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
import { motion } from 'framer-motion';
|
|
2
|
+
import { keyframes } from 'styled-components';
|
|
3
|
+
import defaultTheme from '../../../constants/defaultTheme.js';
|
|
4
|
+
import styled from '../../../styles/styled/index.js';
|
|
5
|
+
import Button from '../../Common/Button/index.js';
|
|
6
|
+
import { InnerContainer } from '../../Common/Button/styles.js';
|
|
7
|
+
|
|
8
|
+
const AvatarContainer = styled(motion.div) `
|
|
9
|
+
padding: 18px 0 20px;
|
|
10
|
+
@media only screen and (max-width: ${defaultTheme.mobileWidth}px) {
|
|
11
|
+
padding: 16px 0 20px;
|
|
12
|
+
}
|
|
13
|
+
`;
|
|
14
|
+
const AvatarInner = styled(motion.div) `
|
|
15
|
+
position: relative;
|
|
16
|
+
display: inline-block;
|
|
17
|
+
`;
|
|
18
|
+
const ChainSelectorContainer = styled(motion.div) `
|
|
19
|
+
z-index: 3;
|
|
20
|
+
position: absolute;
|
|
21
|
+
bottom: 0px;
|
|
22
|
+
right: -16px;
|
|
23
|
+
`;
|
|
24
|
+
const BalanceContainer = styled(motion.div) `
|
|
25
|
+
position: relative;
|
|
26
|
+
height: 24px;
|
|
27
|
+
margin-top: 4px;
|
|
28
|
+
`;
|
|
29
|
+
const Balance = styled(motion.div) `
|
|
30
|
+
position: relative;
|
|
31
|
+
font-size: 20px;
|
|
32
|
+
`;
|
|
33
|
+
const PlaceholderKeyframes = keyframes `
|
|
34
|
+
0%{ background-position: 100% 0; }
|
|
35
|
+
100%{ background-position: -100% 0; }
|
|
36
|
+
`;
|
|
37
|
+
const LoadingBalance = styled(motion.div) `
|
|
38
|
+
width: 25%;
|
|
39
|
+
height: 24px;
|
|
40
|
+
margin: 0 auto;
|
|
41
|
+
position: relative;
|
|
42
|
+
overflow: hidden;
|
|
43
|
+
border-radius: 10px;
|
|
44
|
+
background: var(--ck-body-background-secondary);
|
|
45
|
+
inset: 0;
|
|
46
|
+
&:before {
|
|
47
|
+
z-index: 4;
|
|
48
|
+
content: '';
|
|
49
|
+
position: absolute;
|
|
50
|
+
inset: 0;
|
|
51
|
+
background-image: linear-gradient(
|
|
52
|
+
90deg,
|
|
53
|
+
var(--ck-body-background-transparent) 50%,
|
|
54
|
+
var(--ck-body-background),
|
|
55
|
+
var(--ck-body-background-transparent)
|
|
56
|
+
);
|
|
57
|
+
opacity: 0.75;
|
|
58
|
+
background-size: 200% 100%;
|
|
59
|
+
animation: ${PlaceholderKeyframes} 1000ms linear infinite both;
|
|
60
|
+
}
|
|
61
|
+
`;
|
|
62
|
+
const Unsupported = styled(motion.div) `
|
|
63
|
+
z-index: 2;
|
|
64
|
+
width: 100%;
|
|
65
|
+
height: 100%;
|
|
66
|
+
min-width: 13px;
|
|
67
|
+
min-height: 13px;
|
|
68
|
+
color: var(--ck-body-color-danger, red);
|
|
69
|
+
`;
|
|
70
|
+
const ActionButtonsContainer = styled.div `
|
|
71
|
+
display: flex;
|
|
72
|
+
gap: 12px;
|
|
73
|
+
margin-top: 20px;
|
|
74
|
+
`;
|
|
75
|
+
const ActionButton = styled(Button) `
|
|
76
|
+
flex: 1;
|
|
77
|
+
margin: 0;
|
|
78
|
+
height: 48px;
|
|
79
|
+
font-size: 16px;
|
|
80
|
+
|
|
81
|
+
${InnerContainer} {
|
|
82
|
+
gap: 8px;
|
|
83
|
+
white-space: nowrap;
|
|
84
|
+
}
|
|
85
|
+
`;
|
|
86
|
+
const DisconnectButton = styled(Button) `
|
|
87
|
+
margin-top: 4px;
|
|
88
|
+
`;
|
|
89
|
+
const LinkedProvidersToggle = styled.button `
|
|
90
|
+
align-self: flex-start;
|
|
91
|
+
display: inline-flex;
|
|
92
|
+
align-items: center;
|
|
93
|
+
justify-content: center;
|
|
94
|
+
width: 36px;
|
|
95
|
+
height: 36px;
|
|
96
|
+
padding: 0;
|
|
97
|
+
border-radius: 999px;
|
|
98
|
+
border: 1px solid var(--ck-body-divider);
|
|
99
|
+
background: var(--ck-secondary-button-background);
|
|
100
|
+
color: var(--ck-body-color);
|
|
101
|
+
cursor: pointer;
|
|
102
|
+
transition: background 150ms ease, border-color 150ms ease, color 150ms ease;
|
|
103
|
+
margin: 0;
|
|
104
|
+
|
|
105
|
+
&:hover {
|
|
106
|
+
background: var(--ck-secondary-button-hover-background);
|
|
107
|
+
border-color: var(--ck-body-color-muted);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
&:disabled {
|
|
111
|
+
cursor: not-allowed;
|
|
112
|
+
opacity: 0.6;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
svg {
|
|
116
|
+
width: 18px;
|
|
117
|
+
height: 18px;
|
|
118
|
+
}
|
|
119
|
+
`;
|
|
120
|
+
|
|
121
|
+
export { ActionButton, ActionButtonsContainer, AvatarContainer, AvatarInner, Balance, BalanceContainer, ChainSelectorContainer, DisconnectButton, LinkedProvidersToggle, LoadingBalance, Unsupported };
|
|
122
|
+
//# sourceMappingURL=styles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"styles.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useEffect } from 'react';
|
|
3
|
+
import Loader from '../../Common/Loading/index.js';
|
|
4
|
+
import { useOpenfort } from '../../Openfort/useOpenfort.js';
|
|
5
|
+
import { PageContent } from '../../PageContent/index.js';
|
|
6
|
+
|
|
7
|
+
const ConnectedSuccess = () => {
|
|
8
|
+
const { setOpen } = useOpenfort();
|
|
9
|
+
// hide on connect
|
|
10
|
+
useEffect(() => {
|
|
11
|
+
setTimeout(() => {
|
|
12
|
+
setOpen(false);
|
|
13
|
+
}, 1000);
|
|
14
|
+
}, []);
|
|
15
|
+
return (jsx(PageContent, { children: jsx(Loader, { isLoading: false, isSuccess: true, header: "Connected" }) }));
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
export { ConnectedSuccess as default };
|
|
19
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useState, useEffect } from 'react';
|
|
3
|
+
import { useEthereumBridge } from '../../../ethereum/OpenfortEthereumBridgeContext.js';
|
|
4
|
+
import useIsMobile from '../../../hooks/useIsMobile.js';
|
|
5
|
+
import { useWalletConnectModal } from '../../../hooks/useWalletConnectModal.js';
|
|
6
|
+
import { logger } from '../../../utils/logger.js';
|
|
7
|
+
import ConnectorList from '../../Common/ConnectorList/index.js';
|
|
8
|
+
import Loader from '../../Common/Loading/index.js';
|
|
9
|
+
import { routes } from '../../Openfort/types.js';
|
|
10
|
+
import { useOpenfort } from '../../Openfort/useOpenfort.js';
|
|
11
|
+
import { PageContent } from '../../PageContent/index.js';
|
|
12
|
+
|
|
13
|
+
let hasWarnedConnectors = false;
|
|
14
|
+
const ConnectWithMobile = () => {
|
|
15
|
+
var _a, _b;
|
|
16
|
+
const { open: openWalletConnectModal } = useWalletConnectModal();
|
|
17
|
+
const [error, setError] = useState(undefined);
|
|
18
|
+
const bridge = useEthereumBridge();
|
|
19
|
+
const connector = (_a = bridge === null || bridge === void 0 ? void 0 : bridge.account) === null || _a === void 0 ? void 0 : _a.connector;
|
|
20
|
+
const address = (_b = bridge === null || bridge === void 0 ? void 0 : bridge.account) === null || _b === void 0 ? void 0 : _b.address;
|
|
21
|
+
const { setRoute, setConnector } = useOpenfort();
|
|
22
|
+
const openWCModal = async () => {
|
|
23
|
+
setError(undefined);
|
|
24
|
+
const { error } = await openWalletConnectModal();
|
|
25
|
+
if (error) {
|
|
26
|
+
setError(error);
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
useEffect(() => {
|
|
30
|
+
openWCModal();
|
|
31
|
+
}, []);
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
if (connector && address) {
|
|
34
|
+
const walletConnectDeeplinkChoice = localStorage.getItem('WALLETCONNECT_DEEPLINK_CHOICE');
|
|
35
|
+
if (walletConnectDeeplinkChoice) {
|
|
36
|
+
try {
|
|
37
|
+
const parsedChoice = JSON.parse(walletConnectDeeplinkChoice);
|
|
38
|
+
if (parsedChoice &&
|
|
39
|
+
typeof parsedChoice === 'object' &&
|
|
40
|
+
'name' in parsedChoice &&
|
|
41
|
+
typeof parsedChoice.name === 'string') {
|
|
42
|
+
setConnector({ id: parsedChoice.name });
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
setConnector({ id: connector.id });
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
catch {
|
|
49
|
+
setConnector({ id: connector.id });
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
setConnector({ id: connector.id });
|
|
54
|
+
}
|
|
55
|
+
setRoute(routes.CONNECT_WITH_MOBILE);
|
|
56
|
+
}
|
|
57
|
+
}, [address, connector]);
|
|
58
|
+
return (jsx(Loader, { header: error ? 'Error connecting wallet.' : `Connecting...`, isError: !!error, description: error, onRetry: () => openWCModal() }));
|
|
59
|
+
};
|
|
60
|
+
const Connectors = ({ logoutOnBack }) => {
|
|
61
|
+
const isMobile = useIsMobile();
|
|
62
|
+
// Runtime deprecation warning
|
|
63
|
+
if (process.env.NODE_ENV === 'development' && !hasWarnedConnectors) {
|
|
64
|
+
logger.warn('[@openfort/react] <Connectors /> is deprecated and will be moved to @openfort/react/wagmi in v3.0.\n' +
|
|
65
|
+
'For embedded wallets, external wallet connections are not needed.\n' +
|
|
66
|
+
'See: https://openfort.io/docs/migration/external-wallets');
|
|
67
|
+
hasWarnedConnectors = true;
|
|
68
|
+
}
|
|
69
|
+
return (jsx(PageContent, { logoutOnBack: logoutOnBack, width: 312, children: isMobile ? jsx(ConnectWithMobile, {}) : jsx(ConnectorList, {}) }));
|
|
70
|
+
};
|
|
71
|
+
|
|
72
|
+
export { Connectors as default };
|
|
73
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { useRef, useEffect } from 'react';
|
|
3
|
+
import { useGuestAuth } from '../../../hooks/openfort/auth/useGuestAuth.js';
|
|
4
|
+
import { logger } from '../../../utils/logger.js';
|
|
5
|
+
import Loader from '../../Common/Loading/index.js';
|
|
6
|
+
import { routes } from '../../Openfort/types.js';
|
|
7
|
+
import { useOpenfort } from '../../Openfort/useOpenfort.js';
|
|
8
|
+
import { PageContent } from '../../PageContent/index.js';
|
|
9
|
+
|
|
10
|
+
const CreateGuestUserPage = () => {
|
|
11
|
+
const { setRoute } = useOpenfort();
|
|
12
|
+
const { signUpGuest, error } = useGuestAuth({
|
|
13
|
+
recoverWalletAutomatically: false,
|
|
14
|
+
onSuccess: () => setRoute(routes.LOAD_WALLETS),
|
|
15
|
+
});
|
|
16
|
+
const initialized = useRef(false);
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
if (initialized.current)
|
|
19
|
+
return;
|
|
20
|
+
initialized.current = true;
|
|
21
|
+
logger.log('Signing up guest user...');
|
|
22
|
+
signUpGuest();
|
|
23
|
+
}, []);
|
|
24
|
+
return (jsx(PageContent, { onBack: null, children: jsx(Loader, { header: error ? 'Error creating guest user.' : 'Creating guest user...', isError: !!error, onRetry: () => signUpGuest() }) }));
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
export { CreateGuestUserPage as default };
|
|
28
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { type SetOnBackFunction } from '../../PageContent';
|
|
2
|
+
declare const SolanaCreateWallet: ({ onBack, logoutOnBack }: {
|
|
3
|
+
onBack: SetOnBackFunction;
|
|
4
|
+
logoutOnBack: boolean;
|
|
5
|
+
}) => import("react/jsx-runtime").JSX.Element | null;
|
|
6
|
+
export default SolanaCreateWallet;
|
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
+
import { RecoveryMethod, EmbeddedState } from '@openfort/openfort-js';
|
|
3
|
+
import { motion } from 'framer-motion';
|
|
4
|
+
import { useState, useEffect, useCallback, useMemo } from 'react';
|
|
5
|
+
import { PhoneIcon, EmailIcon, FingerPrintIcon, KeyIcon, LockIcon } from '../../../assets/icons.js';
|
|
6
|
+
import { OpenfortError } from '../../../types.js';
|
|
7
|
+
import { useOpenfortCore } from '../../../openfort/useOpenfort.js';
|
|
8
|
+
import { useRecoveryOTP } from '../../../shared/hooks/useRecoveryOTP.js';
|
|
9
|
+
import { handleOtpRecoveryError } from '../../../shared/utils/otpError.js';
|
|
10
|
+
import { useSolanaEmbeddedWallet } from '../../../solana/hooks/useSolanaEmbeddedWallet.js';
|
|
11
|
+
import { logger } from '../../../utils/logger.js';
|
|
12
|
+
import Button from '../../Common/Button/index.js';
|
|
13
|
+
import FitText from '../../Common/FitText/index.js';
|
|
14
|
+
import Input from '../../Common/Input/index.js';
|
|
15
|
+
import Loader from '../../Common/Loading/index.js';
|
|
16
|
+
import { ModalHeading, ModalBody } from '../../Common/Modal/styles.js';
|
|
17
|
+
import { OtpInputStandalone } from '../../Common/OTPInput/index.js';
|
|
18
|
+
import TickList from '../../Common/TickList/index.js';
|
|
19
|
+
import { FloatingGraphic } from '../../FloatingGraphic/index.js';
|
|
20
|
+
import { routes } from '../../Openfort/types.js';
|
|
21
|
+
import { useOpenfort } from '../../Openfort/useOpenfort.js';
|
|
22
|
+
import { PageContent } from '../../PageContent/index.js';
|
|
23
|
+
import { PasswordStrengthIndicator } from '../../PasswordStrength/PasswordStrengthIndicator.js';
|
|
24
|
+
import { getPasswordStrength, MEDIUM_SCORE_THRESHOLD } from '../../PasswordStrength/password-utility.js';
|
|
25
|
+
import { Body, ResultContainer, FooterTextButton, FooterButtonText } from '../EmailOTP/styles.js';
|
|
26
|
+
import { ProvidersButton, ProviderLabel, ProviderIcon } from '../Providers/styles.js';
|
|
27
|
+
import { OtherMethodButton } from './styles.js';
|
|
28
|
+
|
|
29
|
+
const OtherMethod = ({ currentMethod, onChangeMethod, }) => {
|
|
30
|
+
const { uiConfig } = useOpenfort();
|
|
31
|
+
const otherMethods = useMemo(() => {
|
|
32
|
+
return uiConfig.walletRecovery.allowedMethods.filter((method) => method !== currentMethod);
|
|
33
|
+
}, [uiConfig, currentMethod]);
|
|
34
|
+
if (otherMethods.length === 0)
|
|
35
|
+
return null;
|
|
36
|
+
if (otherMethods.length === 1) {
|
|
37
|
+
const method = otherMethods[0];
|
|
38
|
+
let text;
|
|
39
|
+
switch (method) {
|
|
40
|
+
case RecoveryMethod.PASSWORD:
|
|
41
|
+
text = 'Use password recovery instead';
|
|
42
|
+
break;
|
|
43
|
+
case RecoveryMethod.AUTOMATIC:
|
|
44
|
+
text = 'Skip for now';
|
|
45
|
+
break;
|
|
46
|
+
case RecoveryMethod.PASSKEY:
|
|
47
|
+
text = 'Use passkey recovery instead';
|
|
48
|
+
break;
|
|
49
|
+
default:
|
|
50
|
+
text = method;
|
|
51
|
+
}
|
|
52
|
+
return jsx(OtherMethodButton, { onClick: () => onChangeMethod(method), children: text });
|
|
53
|
+
}
|
|
54
|
+
return jsx(OtherMethodButton, { onClick: () => onChangeMethod('other'), children: "Choose another recovery method" });
|
|
55
|
+
};
|
|
56
|
+
const SolanaCreateAutomatic = ({ onBack, logoutOnBack }) => {
|
|
57
|
+
var _a;
|
|
58
|
+
const { embeddedState } = useOpenfortCore();
|
|
59
|
+
const { setRoute, triggerResize } = useOpenfort();
|
|
60
|
+
const embeddedWallet = useSolanaEmbeddedWallet();
|
|
61
|
+
const { isEnabled: isWalletRecoveryOTPEnabled, requestOTP } = useRecoveryOTP();
|
|
62
|
+
const [recoveryError, setRecoveryError] = useState(null);
|
|
63
|
+
const [shouldCreate, setShouldCreate] = useState(false);
|
|
64
|
+
const [needsOTP, setNeedsOTP] = useState(false);
|
|
65
|
+
const [otpResponse, setOtpResponse] = useState(null);
|
|
66
|
+
const [otpStatus, setOtpStatus] = useState('idle');
|
|
67
|
+
const [error, setError] = useState(false);
|
|
68
|
+
const handleCompleteOtp = async (otp) => {
|
|
69
|
+
setOtpStatus('loading');
|
|
70
|
+
try {
|
|
71
|
+
await embeddedWallet.create({
|
|
72
|
+
recoveryMethod: RecoveryMethod.AUTOMATIC,
|
|
73
|
+
otpCode: otp,
|
|
74
|
+
});
|
|
75
|
+
setOtpStatus('success');
|
|
76
|
+
setRoute(routes.SOL_CONNECTED);
|
|
77
|
+
}
|
|
78
|
+
catch (err) {
|
|
79
|
+
setOtpStatus('error');
|
|
80
|
+
setError(err instanceof OpenfortError ? err.message : 'There was an error verifying the OTP. Please try again.');
|
|
81
|
+
setTimeout(() => {
|
|
82
|
+
setOtpStatus('idle');
|
|
83
|
+
setError(false);
|
|
84
|
+
}, 1000);
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
useEffect(() => {
|
|
88
|
+
if (!shouldCreate)
|
|
89
|
+
return;
|
|
90
|
+
(async () => {
|
|
91
|
+
logger.log('Creating Solana wallet with automatic recovery');
|
|
92
|
+
try {
|
|
93
|
+
await embeddedWallet.create({ recoveryMethod: RecoveryMethod.AUTOMATIC });
|
|
94
|
+
setRoute(routes.SOL_CONNECTED);
|
|
95
|
+
}
|
|
96
|
+
catch (err) {
|
|
97
|
+
const { error, isOTPRequired } = handleOtpRecoveryError(err, isWalletRecoveryOTPEnabled);
|
|
98
|
+
if (isOTPRequired && isWalletRecoveryOTPEnabled) {
|
|
99
|
+
try {
|
|
100
|
+
const response = await requestOTP();
|
|
101
|
+
setNeedsOTP(true);
|
|
102
|
+
setOtpResponse(response);
|
|
103
|
+
}
|
|
104
|
+
catch (otpErr) {
|
|
105
|
+
logger.log('Error requesting OTP for wallet creation', otpErr);
|
|
106
|
+
setRecoveryError(new Error('Failed to send recovery code'));
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
logger.log('Error creating Solana wallet', err);
|
|
111
|
+
setRecoveryError(error);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
triggerResize();
|
|
115
|
+
})();
|
|
116
|
+
}, [shouldCreate]);
|
|
117
|
+
const [canSendOtp, setCanSendOtp] = useState(true);
|
|
118
|
+
useEffect(() => {
|
|
119
|
+
if (embeddedState === EmbeddedState.EMBEDDED_SIGNER_NOT_CONFIGURED) {
|
|
120
|
+
setShouldCreate(true);
|
|
121
|
+
}
|
|
122
|
+
}, [embeddedState]);
|
|
123
|
+
const handleResendClick = useCallback(() => {
|
|
124
|
+
setOtpStatus('send-otp');
|
|
125
|
+
setCanSendOtp(false);
|
|
126
|
+
}, []);
|
|
127
|
+
const isResendDisabled = !canSendOtp || otpStatus === 'sending-otp' || otpStatus === 'send-otp';
|
|
128
|
+
const sendButtonText = useMemo(() => {
|
|
129
|
+
if (!canSendOtp)
|
|
130
|
+
return 'Code Sent!';
|
|
131
|
+
if (otpStatus === 'sending-otp')
|
|
132
|
+
return 'Sending...';
|
|
133
|
+
return 'Resend Code';
|
|
134
|
+
}, [canSendOtp, otpStatus]);
|
|
135
|
+
if (needsOTP && isWalletRecoveryOTPEnabled) {
|
|
136
|
+
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'))) {
|
|
137
|
+
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" })] }));
|
|
138
|
+
}
|
|
139
|
+
return (jsxs(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: [jsx(ModalHeading, { children: "Enter your code" }), jsx(FloatingGraphic, { height: "100px", marginTop: "8px", marginBottom: "10px", logoCenter: {
|
|
140
|
+
logo: (otpResponse === null || otpResponse === void 0 ? void 0 : otpResponse.sentTo) === 'phone' ? jsx(PhoneIcon, {}) : jsx(EmailIcon, {}),
|
|
141
|
+
} }), 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 })] })] })] }));
|
|
142
|
+
}
|
|
143
|
+
return (jsx(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: jsx(Loader, { isError: !!recoveryError, header: recoveryError ? 'Error creating wallet.' : 'Creating wallet...', description: recoveryError ? recoveryError.message : undefined }) }));
|
|
144
|
+
};
|
|
145
|
+
const SolanaCreatePasskey = ({ onChangeMethod, onBack, logoutOnBack, }) => {
|
|
146
|
+
const { triggerResize, setRoute } = useOpenfort();
|
|
147
|
+
const embeddedWallet = useSolanaEmbeddedWallet();
|
|
148
|
+
const { embeddedState } = useOpenfortCore();
|
|
149
|
+
const [shouldCreate, setShouldCreate] = useState(false);
|
|
150
|
+
const [recoveryError, setRecoveryError] = useState(null);
|
|
151
|
+
useEffect(() => {
|
|
152
|
+
if (!shouldCreate)
|
|
153
|
+
return;
|
|
154
|
+
(async () => {
|
|
155
|
+
logger.log('Creating Solana wallet with passkey recovery');
|
|
156
|
+
try {
|
|
157
|
+
await embeddedWallet.create({ recoveryMethod: RecoveryMethod.PASSKEY });
|
|
158
|
+
setRoute(routes.SOL_CONNECTED);
|
|
159
|
+
}
|
|
160
|
+
catch (err) {
|
|
161
|
+
logger.log('Error creating Solana wallet with passkey', err);
|
|
162
|
+
setRecoveryError(new Error('Failed to create wallet'));
|
|
163
|
+
setShouldCreate(false);
|
|
164
|
+
}
|
|
165
|
+
})();
|
|
166
|
+
}, [shouldCreate]);
|
|
167
|
+
useEffect(() => {
|
|
168
|
+
if (embeddedState === EmbeddedState.EMBEDDED_SIGNER_NOT_CONFIGURED) {
|
|
169
|
+
setShouldCreate(true);
|
|
170
|
+
}
|
|
171
|
+
}, [embeddedState]);
|
|
172
|
+
useEffect(() => {
|
|
173
|
+
if (recoveryError)
|
|
174
|
+
triggerResize();
|
|
175
|
+
}, [recoveryError]);
|
|
176
|
+
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: () => setShouldCreate(true) }), jsx(OtherMethod, { currentMethod: RecoveryMethod.PASSKEY, onChangeMethod: onChangeMethod })] }));
|
|
177
|
+
};
|
|
178
|
+
const SolanaCreatePassword = ({ onChangeMethod, onBack, logoutOnBack, }) => {
|
|
179
|
+
const [recoveryPhrase, setRecoveryPhrase] = useState('');
|
|
180
|
+
const [recoveryError, setRecoveryError] = useState(false);
|
|
181
|
+
const { triggerResize, setRoute } = useOpenfort();
|
|
182
|
+
const [showPasswordIsTooWeakError, setShowPasswordIsTooWeakError] = useState(false);
|
|
183
|
+
const [loading, setLoading] = useState(false);
|
|
184
|
+
const embeddedWallet = useSolanaEmbeddedWallet();
|
|
185
|
+
const handleSubmit = async () => {
|
|
186
|
+
if (getPasswordStrength(recoveryPhrase) < MEDIUM_SCORE_THRESHOLD) {
|
|
187
|
+
setShowPasswordIsTooWeakError(true);
|
|
188
|
+
return;
|
|
189
|
+
}
|
|
190
|
+
setLoading(true);
|
|
191
|
+
try {
|
|
192
|
+
await embeddedWallet.create({
|
|
193
|
+
recoveryMethod: RecoveryMethod.PASSWORD,
|
|
194
|
+
password: recoveryPhrase,
|
|
195
|
+
});
|
|
196
|
+
setRoute(routes.SOL_CONNECTED);
|
|
197
|
+
}
|
|
198
|
+
catch (err) {
|
|
199
|
+
setRecoveryError(err instanceof OpenfortError ? err.message : 'Failed to create wallet. Please try again.');
|
|
200
|
+
}
|
|
201
|
+
setLoading(false);
|
|
202
|
+
};
|
|
203
|
+
useEffect(() => {
|
|
204
|
+
if (recoveryError)
|
|
205
|
+
triggerResize();
|
|
206
|
+
}, [recoveryError]);
|
|
207
|
+
return (jsxs(PageContent, { onBack: onBack, logoutOnBack: logoutOnBack, children: [jsx(FloatingGraphic, { height: "80px", logoCenter: { logo: jsx(KeyIcon, {}), size: '1.2' }, logoTopLeft: { logo: jsx(LockIcon, {}), size: '0.75' }, logoBottomRight: { logo: jsx(LockIcon, {}), size: '0.5' } }), 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) => {
|
|
208
|
+
e.preventDefault();
|
|
209
|
+
handleSubmit();
|
|
210
|
+
}, children: [jsx(Input, { value: recoveryPhrase, onChange: (e) => {
|
|
211
|
+
if (showPasswordIsTooWeakError)
|
|
212
|
+
setShowPasswordIsTooWeakError(false);
|
|
213
|
+
setRecoveryPhrase(e.target.value);
|
|
214
|
+
}, 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 })] })] }));
|
|
215
|
+
};
|
|
216
|
+
const ChooseRecoveryMethod = ({ onChangeMethod, onBack, logoutOnBack, }) => {
|
|
217
|
+
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, {}) })] }) })] }));
|
|
218
|
+
};
|
|
219
|
+
const recoveryMethodComponents = {
|
|
220
|
+
[RecoveryMethod.AUTOMATIC]: ({ onBack, logoutOnBack }) => (jsx(SolanaCreateAutomatic, { onBack: onBack, logoutOnBack: logoutOnBack })),
|
|
221
|
+
[RecoveryMethod.PASSKEY]: SolanaCreatePasskey,
|
|
222
|
+
[RecoveryMethod.PASSWORD]: SolanaCreatePassword,
|
|
223
|
+
other: ChooseRecoveryMethod,
|
|
224
|
+
};
|
|
225
|
+
const SolanaCreateWallet = ({ onBack, logoutOnBack }) => {
|
|
226
|
+
const { uiConfig, triggerResize } = useOpenfort();
|
|
227
|
+
const [userSelectedMethod, setUserSelectedMethod] = useState(null);
|
|
228
|
+
useEffect(() => {
|
|
229
|
+
triggerResize();
|
|
230
|
+
}, [userSelectedMethod]);
|
|
231
|
+
const method = userSelectedMethod !== null && userSelectedMethod !== void 0 ? userSelectedMethod : uiConfig.walletRecovery.defaultMethod;
|
|
232
|
+
const Component = recoveryMethodComponents[method];
|
|
233
|
+
if (!Component) {
|
|
234
|
+
logger.error(`Unsupported recovery method: ${method}`);
|
|
235
|
+
return null;
|
|
236
|
+
}
|
|
237
|
+
return jsx(Component, { onChangeMethod: setUserSelectedMethod, onBack: onBack, logoutOnBack: logoutOnBack });
|
|
238
|
+
};
|
|
239
|
+
|
|
240
|
+
export { SolanaCreateWallet as default };
|
|
241
|
+
//# sourceMappingURL=SolanaCreateWallet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SolanaCreateWallet.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|