@web3auth/modal 10.0.0-beta.0 → 10.0.0-beta.11
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/README.md +2 -2
- package/dist/lib.cjs/node_modules/style-inject/dist/style-inject.es.js +1 -1
- package/dist/lib.cjs/packages/modal/src/config.js +3 -3
- package/dist/lib.cjs/packages/modal/src/index.js +1 -0
- package/dist/lib.cjs/packages/modal/src/modalManager.js +278 -174
- package/dist/lib.cjs/packages/modal/src/react/Web3AuthProvider.js +9 -3
- package/dist/lib.cjs/packages/modal/src/react/context/WalletServicesInnerContext.js +72 -0
- package/dist/lib.cjs/packages/modal/src/react/context/Web3AuthInnerContext.js +51 -107
- package/dist/lib.cjs/packages/modal/src/react/hooks/useCheckout.js +34 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useEnableMFA.js +30 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useIdentityToken.js +42 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useManageMFA.js +30 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useSwap.js +34 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useSwitchChain.js +32 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletConnectScanner.js +34 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletServicesPlugin.js +13 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useWalletUI.js +34 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3Auth.js +21 -8
- package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthConnect.js +63 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthDisconnect.js +30 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthInner.js +15 -0
- package/dist/lib.cjs/packages/modal/src/react/hooks/useWeb3AuthUser.js +50 -0
- package/dist/lib.cjs/packages/modal/src/react/index.js +24 -3
- package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignAndSendTransaction.js +36 -0
- package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignMessage.js +37 -0
- package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSignTransaction.js +36 -0
- package/dist/lib.cjs/packages/modal/src/react/solana/hooks/useSolanaWallet.js +43 -0
- package/dist/lib.cjs/packages/modal/src/react/solana/index.js +13 -0
- package/dist/lib.cjs/packages/modal/src/react/wagmi/constants.js +16 -0
- package/dist/lib.cjs/packages/modal/src/react/wagmi/index.js +7 -0
- package/dist/lib.cjs/packages/modal/src/react/wagmi/provider.js +195 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/BottomSheet/BottomSheet.js +60 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Button/Button.js +47 -22
- package/dist/lib.cjs/packages/modal/src/ui/components/Button/Button.type.js +8 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Button/ButtonSocial/ButtonSocial.js +53 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Button/ButtonWallet/ButtonWallet.js +76 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWallet.js +208 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.js +65 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/{ExternalWallet/ExternalWalletChainNamespace.js → ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.js} +29 -30
- package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.js +49 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletList/ConnectWalletList.js +148 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.js +99 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.js +55 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Embed/Embed.js +70 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Footer/Footer.js +50 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Image/Image.js +90 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Loader/Loader.js +151 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Login/Login.js +527 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Login/LoginOtp/LoginOtp.js +119 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Login/LoginPasswordLess/LoginPasswordLess.js +122 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/LoginHint/LoginHint.js +52 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Modal/Modal.js +87 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Otp/Otp.js +190 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/PulseLoader/PulseLoader.js +18 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Root/Root.js +509 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/SocialLoginList/SocialLoginList.js +137 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Toast/Toast.js +70 -0
- package/dist/lib.cjs/packages/modal/src/ui/components/Widget/Widget.js +242 -0
- package/dist/lib.cjs/packages/modal/src/ui/config.js +13 -1
- package/dist/lib.cjs/packages/modal/src/ui/constants.js +48 -0
- package/dist/lib.cjs/packages/modal/src/ui/context/RootContext.js +29 -0
- package/dist/lib.cjs/packages/modal/src/ui/context/ThemeContext.js +2 -2
- package/dist/lib.cjs/packages/modal/src/ui/css/index.css.js +8 -0
- package/dist/lib.cjs/packages/modal/src/ui/handlers/AbstractHandler.js +121 -0
- package/dist/lib.cjs/packages/modal/src/ui/handlers/EmailPasswordlessHandler.js +57 -0
- package/dist/lib.cjs/packages/modal/src/ui/handlers/SmsPasswordlessHandler.js +57 -0
- package/dist/lib.cjs/packages/modal/src/ui/handlers/factory.js +19 -0
- package/dist/lib.cjs/packages/modal/src/ui/i18n/dutch.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/english.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/french.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/german.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/japanese.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/korean.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/mandarin.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/portuguese.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/spanish.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/i18n/turkish.json.js +41 -5
- package/dist/lib.cjs/packages/modal/src/ui/interfaces.js +7 -10
- package/dist/lib.cjs/packages/modal/src/ui/loginModal.js +99 -62
- package/dist/lib.cjs/packages/modal/src/ui/utils.js +123 -5
- package/dist/lib.cjs/packages/modal/src/vue/WalletServicesInnerProvider.js +70 -0
- package/dist/lib.cjs/packages/modal/src/vue/Web3AuthProvider.js +38 -78
- package/dist/lib.cjs/packages/modal/src/vue/composables/useCheckout.js +34 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useEnableMFA.js +32 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useIdentityToken.js +44 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useManageMFA.js +32 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useSwap.js +34 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useSwitchChain.js +32 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletConnectScanner.js +34 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletServicesPlugin.js +13 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useWalletUI.js +34 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3Auth.js +2 -4
- package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthConnect.js +66 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthDisconnect.js +32 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthInner.js +12 -0
- package/dist/lib.cjs/packages/modal/src/vue/composables/useWeb3AuthUser.js +53 -0
- package/dist/lib.cjs/packages/modal/src/vue/index.js +24 -0
- package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignAndSendTransaction.js +36 -0
- package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignMessage.js +38 -0
- package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSignTransaction.js +36 -0
- package/dist/lib.cjs/packages/modal/src/vue/solana/composables/useSolanaWallet.js +53 -0
- package/dist/lib.cjs/packages/modal/src/vue/solana/index.js +13 -0
- package/dist/lib.cjs/packages/modal/src/vue/wagmi/constants.js +16 -0
- package/dist/lib.cjs/packages/modal/src/vue/wagmi/index.js +7 -0
- package/dist/lib.cjs/packages/modal/src/vue/wagmi/provider.js +233 -0
- package/dist/lib.cjs/types/config.d.ts +1 -0
- package/dist/lib.cjs/types/interface.d.ts +2 -3
- package/dist/lib.cjs/types/modalManager.d.ts +11 -4
- package/dist/lib.cjs/types/react/Web3AuthProvider.d.ts +1 -1
- package/dist/lib.cjs/types/react/context/WalletServicesInnerContext.d.ts +6 -0
- package/dist/lib.cjs/types/react/hooks/index.d.ts +13 -1
- package/dist/lib.cjs/types/react/hooks/useCheckout.d.ts +8 -0
- package/dist/lib.cjs/types/react/hooks/useEnableMFA.d.ts +7 -0
- package/dist/lib.cjs/types/react/hooks/useIdentityToken.d.ts +13 -0
- package/dist/lib.cjs/types/react/hooks/useManageMFA.d.ts +7 -0
- package/dist/lib.cjs/types/react/hooks/useSwap.d.ts +8 -0
- package/dist/lib.cjs/types/react/hooks/useSwitchChain.d.ts +7 -0
- package/dist/lib.cjs/types/react/hooks/useWalletConnectScanner.d.ts +8 -0
- package/dist/lib.cjs/types/react/hooks/useWalletServicesPlugin.d.ts +2 -0
- package/dist/lib.cjs/types/react/hooks/useWalletUI.d.ts +8 -0
- package/dist/lib.cjs/types/react/hooks/useWeb3Auth.d.ts +2 -1
- package/dist/lib.cjs/types/react/hooks/useWeb3AuthConnect.d.ts +10 -0
- package/dist/lib.cjs/types/react/hooks/useWeb3AuthDisconnect.d.ts +9 -0
- package/dist/lib.cjs/types/react/hooks/useWeb3AuthInner.d.ts +2 -0
- package/dist/lib.cjs/types/react/hooks/useWeb3AuthUser.d.ts +9 -0
- package/dist/lib.cjs/types/react/index.d.ts +0 -1
- package/dist/lib.cjs/types/react/interfaces.d.ts +7 -2
- package/dist/lib.cjs/types/react/solana/hooks/index.d.ts +4 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSignAndSendTransaction.d.ts +8 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSignMessage.d.ts +8 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSignTransaction.d.ts +13 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSolanaWallet.d.ts +8 -0
- package/dist/lib.cjs/types/react/solana/index.d.ts +1 -0
- package/dist/lib.cjs/types/react/wagmi/constants.d.ts +43 -0
- package/dist/lib.cjs/types/react/wagmi/index.d.ts +2 -0
- package/dist/lib.cjs/types/react/wagmi/interface.d.ts +4 -0
- package/dist/lib.cjs/types/react/wagmi/provider.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/BottomSheet/BottomSheet.d.ts +7 -0
- package/dist/lib.cjs/types/ui/components/BottomSheet/BottomSheet.type.d.ts +7 -0
- package/dist/lib.cjs/types/ui/components/BottomSheet/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Button/Button.d.ts +2 -15
- package/dist/lib.cjs/types/ui/components/Button/Button.type.d.ts +12 -0
- package/dist/lib.cjs/types/ui/components/Button/ButtonSocial/ButtonSocial.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/Button/ButtonSocial/ButtonSocial.type.d.ts +14 -0
- package/dist/lib.cjs/types/ui/components/Button/ButtonSocial/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Button/ButtonWallet/ButtonWallet.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/Button/ButtonWallet/ButtonWallet.type.d.ts +13 -0
- package/dist/lib.cjs/types/ui/components/Button/ButtonWallet/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Button/index.d.ts +1 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWallet.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWallet.type.d.ts +25 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.type.d.ts +13 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainFilter/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.type.d.ts +10 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletChainNamespaceSelect/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.type.d.ts +6 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletHeader/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletList/ConnectWalletList.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletList/ConnectWalletList.type.d.ts +19 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletList/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.type.d.ts +8 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletQrCode/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.type.d.ts +9 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/ConnectWalletSearch/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/ConnectWallet/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Embed/Embed.d.ts +8 -0
- package/dist/lib.cjs/types/ui/components/Embed/Embed.type.d.ts +12 -0
- package/dist/lib.cjs/types/ui/components/Embed/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Footer/Footer.d.ts +7 -0
- package/dist/lib.cjs/types/ui/components/Footer/Footer.type.d.ts +4 -0
- package/dist/lib.cjs/types/ui/components/Footer/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Image/Image.d.ts +7 -0
- package/dist/lib.cjs/types/ui/components/{Image.d.ts → Image/Image.type.d.ts} +2 -1
- package/dist/lib.cjs/types/ui/components/Image/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Loader/Loader.d.ts +8 -0
- package/dist/lib.cjs/types/ui/components/Loader/Loader.type.d.ts +12 -0
- package/dist/lib.cjs/types/ui/components/Loader/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Login/Login.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/Login/Login.type.d.ts +29 -0
- package/dist/lib.cjs/types/ui/components/Login/LoginOtp/LoginOtp.d.ts +8 -0
- package/dist/lib.cjs/types/ui/components/Login/LoginOtp/LoginOtp.type.d.ts +11 -0
- package/dist/lib.cjs/types/ui/components/Login/LoginOtp/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Login/LoginPasswordLess/LoginPasswordLess.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/Login/LoginPasswordLess/LoginPasswordLess.type.d.ts +13 -0
- package/dist/lib.cjs/types/ui/components/Login/LoginPasswordLess/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Login/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/LoginHint/LoginHint.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/LoginHint/LoginHint.type.d.ts +6 -0
- package/dist/lib.cjs/types/ui/components/LoginHint/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Modal/Modal.d.ts +8 -0
- package/dist/lib.cjs/types/ui/components/Modal/Modal.type.d.ts +14 -0
- package/dist/lib.cjs/types/ui/components/Modal/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Otp/Otp.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/Otp/Otp.type.d.ts +22 -0
- package/dist/lib.cjs/types/ui/components/Otp/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/PulseLoader/PulseLoader.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/PulseLoader/index.d.ts +1 -0
- package/dist/lib.cjs/types/ui/components/Root/Root.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/Root/Root.type.d.ts +27 -0
- package/dist/lib.cjs/types/ui/components/Root/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/SocialLoginList/SocialLoginList.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/SocialLoginList/SocialLoginList.type.d.ts +11 -0
- package/dist/lib.cjs/types/ui/components/SocialLoginList/index.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Toast/Toast.d.ts +2 -0
- package/dist/lib.cjs/types/ui/components/Toast/index.d.ts +1 -0
- package/dist/lib.cjs/types/ui/components/Widget/Widget.d.ts +3 -0
- package/dist/lib.cjs/types/ui/components/{Modal.d.ts → Widget/Widget.type.d.ts} +4 -5
- package/dist/lib.cjs/types/ui/components/Widget/index.d.ts +1 -0
- package/dist/lib.cjs/types/ui/config.d.ts +5 -2
- package/dist/lib.cjs/types/ui/constants.d.ts +17 -0
- package/dist/lib.cjs/types/ui/context/RootContext.d.ts +27 -0
- package/dist/lib.cjs/types/ui/handlers/AbstractHandler.d.ts +21 -0
- package/dist/lib.cjs/types/ui/handlers/EmailPasswordlessHandler.d.ts +10 -0
- package/dist/lib.cjs/types/ui/handlers/SmsPasswordlessHandler.d.ts +9 -0
- package/dist/lib.cjs/types/ui/handlers/factory.d.ts +5 -0
- package/dist/lib.cjs/types/ui/interfaces.d.ts +127 -18
- package/dist/lib.cjs/types/ui/loginModal.d.ts +10 -8
- package/dist/lib.cjs/types/ui/utils.d.ts +18 -3
- package/dist/lib.cjs/types/vue/WalletServicesInnerProvider.d.ts +1 -0
- package/dist/lib.cjs/types/vue/composables/index.d.ts +12 -0
- package/dist/lib.cjs/types/vue/composables/useCheckout.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useEnableMFA.d.ts +8 -0
- package/dist/lib.cjs/types/vue/composables/useIdentityToken.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useManageMFA.d.ts +8 -0
- package/dist/lib.cjs/types/vue/composables/useSwap.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useSwitchChain.d.ts +10 -0
- package/dist/lib.cjs/types/vue/composables/useWalletConnectScanner.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useWalletServicesPlugin.d.ts +2 -0
- package/dist/lib.cjs/types/vue/composables/useWalletUI.d.ts +9 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3Auth.d.ts +3 -2
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthConnect.d.ts +11 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthDisconnect.d.ts +10 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthInner.d.ts +2 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthUser.d.ts +10 -0
- package/dist/lib.cjs/types/vue/interfaces.d.ts +10 -18
- package/dist/lib.cjs/types/vue/solana/composables/index.d.ts +4 -0
- package/dist/lib.cjs/types/vue/solana/composables/useSignAndSendTransaction.d.ts +9 -0
- package/dist/lib.cjs/types/vue/solana/composables/useSignMessage.d.ts +9 -0
- package/dist/lib.cjs/types/vue/solana/composables/useSignTransaction.d.ts +9 -0
- package/dist/lib.cjs/types/vue/solana/composables/useSolanaWallet.d.ts +9 -0
- package/dist/lib.cjs/types/vue/solana/index.d.ts +1 -0
- package/dist/lib.cjs/types/vue/wagmi/constants.d.ts +43 -0
- package/dist/lib.cjs/types/vue/wagmi/index.d.ts +2 -0
- package/dist/lib.cjs/types/vue/wagmi/interface.d.ts +4 -0
- package/dist/lib.cjs/types/vue/wagmi/provider.d.ts +17 -0
- package/dist/lib.esm/node_modules/style-inject/dist/style-inject.es.js +1 -1
- package/dist/lib.esm/packages/modal/src/config.js +3 -4
- package/dist/lib.esm/packages/modal/src/index.js +1 -1
- package/dist/lib.esm/packages/modal/src/modalManager.js +291 -178
- package/dist/lib.esm/packages/modal/src/react/Web3AuthProvider.js +9 -3
- package/dist/lib.esm/packages/modal/src/react/context/WalletServicesInnerContext.js +69 -0
- package/dist/lib.esm/packages/modal/src/react/context/Web3AuthInnerContext.js +42 -98
- package/dist/lib.esm/packages/modal/src/react/hooks/useCheckout.js +32 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useEnableMFA.js +28 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useIdentityToken.js +40 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useManageMFA.js +28 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useSwap.js +32 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useSwitchChain.js +30 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useWalletConnectScanner.js +32 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useWalletServicesPlugin.js +11 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useWalletUI.js +32 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3Auth.js +21 -8
- package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthConnect.js +61 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthDisconnect.js +28 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthInner.js +13 -0
- package/dist/lib.esm/packages/modal/src/react/hooks/useWeb3AuthUser.js +48 -0
- package/dist/lib.esm/packages/modal/src/react/index.js +12 -1
- package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignAndSendTransaction.js +34 -0
- package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignMessage.js +35 -0
- package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSignTransaction.js +34 -0
- package/dist/lib.esm/packages/modal/src/react/solana/hooks/useSolanaWallet.js +41 -0
- package/dist/lib.esm/packages/modal/src/react/solana/index.js +4 -0
- package/dist/lib.esm/packages/modal/src/react/wagmi/constants.js +14 -0
- package/dist/lib.esm/packages/modal/src/react/wagmi/index.js +1 -0
- package/dist/lib.esm/packages/modal/src/react/wagmi/provider.js +194 -0
- package/dist/lib.esm/packages/modal/src/ui/components/BottomSheet/BottomSheet.js +58 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Button/Button.js +48 -24
- package/dist/lib.esm/packages/modal/src/ui/components/Button/Button.type.js +6 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Button/ButtonSocial/ButtonSocial.js +51 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Button/ButtonWallet/ButtonWallet.js +74 -0
- package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWallet.js +206 -0
- package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletChainFilter/ConnectWalletChainFilter.js +63 -0
- package/dist/lib.esm/packages/modal/src/ui/components/{ExternalWallet/ExternalWalletChainNamespace.js → ConnectWallet/ConnectWalletChainNamespaceSelect/ConnectWalletChainNamespaceSelect.js} +29 -31
- package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletHeader/ConnectWalletHeader.js +47 -0
- package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletList/ConnectWalletList.js +146 -0
- package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletQrCode/ConnectWalletQrCode.js +97 -0
- package/dist/lib.esm/packages/modal/src/ui/components/ConnectWallet/ConnectWalletSearch/ConnectWalletSearch.js +56 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Embed/Embed.js +68 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Footer/Footer.js +48 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Image/Image.js +88 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Loader/Loader.js +152 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Login/Login.js +531 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Login/LoginOtp/LoginOtp.js +118 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Login/LoginPasswordLess/LoginPasswordLess.js +120 -0
- package/dist/lib.esm/packages/modal/src/ui/components/LoginHint/LoginHint.js +50 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Modal/Modal.js +85 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Otp/Otp.js +188 -0
- package/dist/lib.esm/packages/modal/src/ui/components/PulseLoader/PulseLoader.js +16 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Root/Root.js +520 -0
- package/dist/lib.esm/packages/modal/src/ui/components/SocialLoginList/SocialLoginList.js +135 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Toast/Toast.js +68 -0
- package/dist/lib.esm/packages/modal/src/ui/components/Widget/Widget.js +245 -0
- package/dist/lib.esm/packages/modal/src/ui/config.js +11 -3
- package/dist/lib.esm/packages/modal/src/ui/constants.js +40 -0
- package/dist/lib.esm/packages/modal/src/ui/context/RootContext.js +27 -0
- package/dist/lib.esm/packages/modal/src/ui/css/index.css.js +6 -0
- package/dist/lib.esm/packages/modal/src/ui/handlers/AbstractHandler.js +119 -0
- package/dist/lib.esm/packages/modal/src/ui/handlers/EmailPasswordlessHandler.js +55 -0
- package/dist/lib.esm/packages/modal/src/ui/handlers/SmsPasswordlessHandler.js +55 -0
- package/dist/lib.esm/packages/modal/src/ui/handlers/factory.js +17 -0
- package/dist/lib.esm/packages/modal/src/ui/i18n/dutch.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/english.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/french.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/german.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/japanese.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/korean.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/mandarin.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/portuguese.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/spanish.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/i18n/turkish.json.js +41 -6
- package/dist/lib.esm/packages/modal/src/ui/interfaces.js +8 -9
- package/dist/lib.esm/packages/modal/src/ui/loginModal.js +100 -63
- package/dist/lib.esm/packages/modal/src/ui/utils.js +121 -7
- package/dist/lib.esm/packages/modal/src/vue/WalletServicesInnerProvider.js +69 -0
- package/dist/lib.esm/packages/modal/src/vue/Web3AuthProvider.js +40 -79
- package/dist/lib.esm/packages/modal/src/vue/composables/useCheckout.js +32 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useEnableMFA.js +30 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useIdentityToken.js +42 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useManageMFA.js +30 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useSwap.js +32 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useSwitchChain.js +30 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useWalletConnectScanner.js +32 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useWalletServicesPlugin.js +11 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useWalletUI.js +32 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3Auth.js +2 -4
- package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthConnect.js +64 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthDisconnect.js +30 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthInner.js +10 -0
- package/dist/lib.esm/packages/modal/src/vue/composables/useWeb3AuthUser.js +51 -0
- package/dist/lib.esm/packages/modal/src/vue/index.js +12 -0
- package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignAndSendTransaction.js +34 -0
- package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignMessage.js +36 -0
- package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSignTransaction.js +34 -0
- package/dist/lib.esm/packages/modal/src/vue/solana/composables/useSolanaWallet.js +51 -0
- package/dist/lib.esm/packages/modal/src/vue/solana/index.js +4 -0
- package/dist/lib.esm/packages/modal/src/vue/wagmi/constants.js +14 -0
- package/dist/lib.esm/packages/modal/src/vue/wagmi/index.js +1 -0
- package/dist/lib.esm/packages/modal/src/vue/wagmi/provider.js +234 -0
- package/dist/modal.umd.min.js +1 -1
- package/dist/modal.umd.min.js.LICENSE.txt +8 -34
- package/package.json +70 -19
- package/dist/lib.cjs/packages/modal/src/ui/assets/arrow-left-dark.svg.js +0 -7
- package/dist/lib.cjs/packages/modal/src/ui/assets/arrow-left-light.svg.js +0 -7
- package/dist/lib.cjs/packages/modal/src/ui/assets/x-dark.svg.js +0 -7
- package/dist/lib.cjs/packages/modal/src/ui/assets/x-light.svg.js +0 -7
- package/dist/lib.cjs/packages/modal/src/ui/components/AdapterLoader.js +0 -108
- package/dist/lib.cjs/packages/modal/src/ui/components/Button/styles.css.js +0 -8
- package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletButton.js +0 -44
- package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletConnect.js +0 -67
- package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletDetails.js +0 -43
- package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletHeader.js +0 -46
- package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallet/ExternalWalletInstall.js +0 -167
- package/dist/lib.cjs/packages/modal/src/ui/components/ExternalWallets.js +0 -279
- package/dist/lib.cjs/packages/modal/src/ui/components/Footer.js +0 -20
- package/dist/lib.cjs/packages/modal/src/ui/components/Header.js +0 -81
- package/dist/lib.cjs/packages/modal/src/ui/components/Icon.js +0 -73
- package/dist/lib.cjs/packages/modal/src/ui/components/Image.js +0 -51
- package/dist/lib.cjs/packages/modal/src/ui/components/Loader.js +0 -59
- package/dist/lib.cjs/packages/modal/src/ui/components/Modal.js +0 -278
- package/dist/lib.cjs/packages/modal/src/ui/components/SelfCustodyViaWeb3Auth.js +0 -30
- package/dist/lib.cjs/packages/modal/src/ui/components/SocialLoginPasswordless.js +0 -150
- package/dist/lib.cjs/packages/modal/src/ui/components/SocialLogins.js +0 -153
- package/dist/lib.cjs/packages/modal/src/ui/components/WalletConnect.js +0 -84
- package/dist/lib.cjs/packages/modal/src/ui/css/web3auth.css.js +0 -8
- package/dist/lib.cjs/types/react/context/index.d.ts +0 -1
- package/dist/lib.cjs/types/ui/components/AdapterLoader.d.ts +0 -11
- package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletButton.d.ts +0 -7
- package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletChainNamespace.d.ts +0 -9
- package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletConnect.d.ts +0 -9
- package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletDetails.d.ts +0 -10
- package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletHeader.d.ts +0 -8
- package/dist/lib.cjs/types/ui/components/ExternalWallet/ExternalWalletInstall.d.ts +0 -8
- package/dist/lib.cjs/types/ui/components/ExternalWallets.d.ts +0 -15
- package/dist/lib.cjs/types/ui/components/Footer.d.ts +0 -1
- package/dist/lib.cjs/types/ui/components/Header.d.ts +0 -8
- package/dist/lib.cjs/types/ui/components/Icon.d.ts +0 -9
- package/dist/lib.cjs/types/ui/components/Loader.d.ts +0 -10
- package/dist/lib.cjs/types/ui/components/SelfCustodyViaWeb3Auth.d.ts +0 -1
- package/dist/lib.cjs/types/ui/components/SocialLoginPasswordless.d.ts +0 -14
- package/dist/lib.cjs/types/ui/components/SocialLogins.d.ts +0 -10
- package/dist/lib.cjs/types/ui/components/WalletConnect.d.ts +0 -8
- package/dist/lib.esm/packages/modal/src/ui/assets/arrow-left-dark.svg.js +0 -5
- package/dist/lib.esm/packages/modal/src/ui/assets/arrow-left-light.svg.js +0 -5
- package/dist/lib.esm/packages/modal/src/ui/assets/x-dark.svg.js +0 -5
- package/dist/lib.esm/packages/modal/src/ui/assets/x-light.svg.js +0 -5
- package/dist/lib.esm/packages/modal/src/ui/components/AdapterLoader.js +0 -106
- package/dist/lib.esm/packages/modal/src/ui/components/Button/styles.css.js +0 -6
- package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletButton.js +0 -42
- package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletConnect.js +0 -65
- package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletDetails.js +0 -44
- package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletHeader.js +0 -44
- package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallet/ExternalWalletInstall.js +0 -165
- package/dist/lib.esm/packages/modal/src/ui/components/ExternalWallets.js +0 -281
- package/dist/lib.esm/packages/modal/src/ui/components/Footer.js +0 -18
- package/dist/lib.esm/packages/modal/src/ui/components/Header.js +0 -79
- package/dist/lib.esm/packages/modal/src/ui/components/Icon.js +0 -71
- package/dist/lib.esm/packages/modal/src/ui/components/Image.js +0 -49
- package/dist/lib.esm/packages/modal/src/ui/components/Loader.js +0 -57
- package/dist/lib.esm/packages/modal/src/ui/components/Modal.js +0 -277
- package/dist/lib.esm/packages/modal/src/ui/components/SelfCustodyViaWeb3Auth.js +0 -28
- package/dist/lib.esm/packages/modal/src/ui/components/SocialLoginPasswordless.js +0 -148
- package/dist/lib.esm/packages/modal/src/ui/components/SocialLogins.js +0 -152
- package/dist/lib.esm/packages/modal/src/ui/components/WalletConnect.js +0 -82
- package/dist/lib.esm/packages/modal/src/ui/css/web3auth.css.js +0 -6
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import cn from 'classnames';
|
|
2
|
+
import { useContext, useMemo } from 'react';
|
|
3
|
+
import { useTranslation } from 'react-i18next';
|
|
4
|
+
import { ThemedContext } from '../../../context/ThemeContext.js';
|
|
5
|
+
import i18nInstance from '../../../localeImport.js';
|
|
6
|
+
import { formatIOSMobile, getIcons } from '../../../utils.js';
|
|
7
|
+
import Image from '../../Image/Image.js';
|
|
8
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
9
|
+
|
|
10
|
+
function ButtonWallet(props) {
|
|
11
|
+
const [t] = useTranslation(undefined, {
|
|
12
|
+
i18n: i18nInstance
|
|
13
|
+
});
|
|
14
|
+
const {
|
|
15
|
+
deviceDetails,
|
|
16
|
+
button,
|
|
17
|
+
walletConnectUri,
|
|
18
|
+
onClick,
|
|
19
|
+
label,
|
|
20
|
+
buttonRadius
|
|
21
|
+
} = props;
|
|
22
|
+
const isDark = useContext(ThemedContext);
|
|
23
|
+
const isLink = useMemo(() => deviceDetails.platform !== "desktop" && button.href && button.hasWalletConnect && !button.hasInjectedWallet, [deviceDetails, button]);
|
|
24
|
+
const href = useMemo(() => button.href ? formatIOSMobile({
|
|
25
|
+
uri: walletConnectUri,
|
|
26
|
+
link: button.href
|
|
27
|
+
}) : walletConnectUri, [button, walletConnectUri]);
|
|
28
|
+
const handleBtnClick = () => {
|
|
29
|
+
if (href && isLink) {
|
|
30
|
+
window.open(href, "_blank");
|
|
31
|
+
} else if (onClick) {
|
|
32
|
+
onClick();
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
return /*#__PURE__*/jsxs("button", {
|
|
36
|
+
type: "button",
|
|
37
|
+
className: cn(`w3a--group w3a--relative w3a--overflow-hidden w3a--flex w3a--w-full w3a--items-center w3a--justify-between w3a--bg-app-gray-50 w3a--p-3 hover:w3a--bg-app-gray-200
|
|
38
|
+
hover:w3a--text-app-gray-900 dark:w3a--bg-app-gray-800 dark:hover:w3a--bg-app-gray-600 active:w3a--scale-95 w3a--transition-all w3a--duration-150`, {
|
|
39
|
+
"w3a--rounded-full": buttonRadius === "pill",
|
|
40
|
+
"w3a--rounded-lg": buttonRadius === "rounded",
|
|
41
|
+
"w3a--rounded-none": buttonRadius === "square"
|
|
42
|
+
}),
|
|
43
|
+
onClick: handleBtnClick,
|
|
44
|
+
children: [/*#__PURE__*/jsxs("div", {
|
|
45
|
+
className: "w3a--flex w3a--items-center w3a--gap-x-2",
|
|
46
|
+
children: [/*#__PURE__*/jsx("figure", {
|
|
47
|
+
className: "w3a--size-5",
|
|
48
|
+
children: /*#__PURE__*/jsx(Image, {
|
|
49
|
+
imageData: button.icon,
|
|
50
|
+
imageId: `login-${button.name}`,
|
|
51
|
+
hoverImageId: `login-${button.name}`,
|
|
52
|
+
fallbackImageId: "wallet",
|
|
53
|
+
height: "24",
|
|
54
|
+
width: "24",
|
|
55
|
+
isButton: true,
|
|
56
|
+
extension: button.imgExtension || "webp"
|
|
57
|
+
})
|
|
58
|
+
}), /*#__PURE__*/jsx("p", {
|
|
59
|
+
className: "w3a--max-w-[180px] w3a--truncate w3a--text-base w3a--font-normal w3a--text-app-gray-700 dark:w3a--text-app-white",
|
|
60
|
+
children: label
|
|
61
|
+
})]
|
|
62
|
+
}), button.hasInjectedWallet && /*#__PURE__*/jsx("span", {
|
|
63
|
+
className: "w3a--absolute w3a--right-4 w3a--top-1/2 w3a--flex w3a--w-auto -w3a--translate-y-1/2 w3a--items-center w3a--rounded-md w3a--bg-app-primary-100 w3a--px-2 w3a--py-1 w3a--text-xs w3a--font-medium w3a--text-app-primary-800 w3a--transition-all w3a--duration-300 group-hover:w3a--translate-x-6 group-hover:w3a--opacity-0 dark:w3a--border dark:w3a--border-app-primary-400 dark:w3a--bg-transparent dark:w3a--text-app-primary-400",
|
|
64
|
+
children: t("modal.external.installed")
|
|
65
|
+
}), /*#__PURE__*/jsx("img", {
|
|
66
|
+
id: "injected-wallet-arrow",
|
|
67
|
+
className: "w3a--absolute w3a--right-4 w3a--top-1/2 -w3a--translate-x-10 -w3a--translate-y-1/2 w3a--opacity-0 w3a--transition-all w3a--duration-300 group-hover:w3a--translate-x-0 group-hover:w3a--opacity-100",
|
|
68
|
+
src: getIcons(isDark ? "chevron-right-light" : "chevron-right-dark"),
|
|
69
|
+
alt: "arrow"
|
|
70
|
+
})]
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
export { ButtonWallet as default };
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import _objectSpread from '@babel/runtime/helpers/objectSpread2';
|
|
2
|
+
import { WALLET_CONNECTORS } from '@web3auth/no-modal';
|
|
3
|
+
import { useContext, useState, useMemo } from 'react';
|
|
4
|
+
import { CONNECT_WALLET_PAGES } from '../../constants.js';
|
|
5
|
+
import { RootContext } from '../../context/RootContext.js';
|
|
6
|
+
import ConnectWalletChainFilter from './ConnectWalletChainFilter/ConnectWalletChainFilter.js';
|
|
7
|
+
import ConnectWalletHeader from './ConnectWalletHeader/ConnectWalletHeader.js';
|
|
8
|
+
import ConnectWalletList from './ConnectWalletList/ConnectWalletList.js';
|
|
9
|
+
import ConnectWalletQrCode from './ConnectWalletQrCode/ConnectWalletQrCode.js';
|
|
10
|
+
import ConnectWalletSearch from './ConnectWalletSearch/ConnectWalletSearch.js';
|
|
11
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
12
|
+
|
|
13
|
+
function ConnectWallet(props) {
|
|
14
|
+
var _selectedButton$walle;
|
|
15
|
+
const {
|
|
16
|
+
isDark,
|
|
17
|
+
config,
|
|
18
|
+
walletConnectUri,
|
|
19
|
+
metamaskConnectUri,
|
|
20
|
+
walletRegistry,
|
|
21
|
+
allExternalButtons,
|
|
22
|
+
customConnectorButtons,
|
|
23
|
+
connectorVisibilityMap,
|
|
24
|
+
deviceDetails,
|
|
25
|
+
buttonRadius = "pill",
|
|
26
|
+
chainNamespace,
|
|
27
|
+
onBackClick,
|
|
28
|
+
handleExternalWalletClick,
|
|
29
|
+
handleWalletDetailsHeight
|
|
30
|
+
} = props;
|
|
31
|
+
const {
|
|
32
|
+
bodyState,
|
|
33
|
+
setBodyState
|
|
34
|
+
} = useContext(RootContext);
|
|
35
|
+
const [currentPage, setCurrentPage] = useState(CONNECT_WALLET_PAGES.CONNECT_WALLET);
|
|
36
|
+
const [selectedWallet, setSelectedWallet] = useState(false);
|
|
37
|
+
const [isLoading] = useState(false);
|
|
38
|
+
const [selectedButton, setSelectedButton] = useState(null);
|
|
39
|
+
const [walletSearch, setWalletSearch] = useState("");
|
|
40
|
+
const [selectedChain, setSelectedChain] = useState("all");
|
|
41
|
+
const [isShowAllWallets, setIsShowAllWallets] = useState(false);
|
|
42
|
+
const handleBack = () => {
|
|
43
|
+
if (!selectedWallet && currentPage === CONNECT_WALLET_PAGES.CONNECT_WALLET && onBackClick) {
|
|
44
|
+
onBackClick(false);
|
|
45
|
+
return;
|
|
46
|
+
}
|
|
47
|
+
if (selectedWallet) {
|
|
48
|
+
setCurrentPage(CONNECT_WALLET_PAGES.CONNECT_WALLET);
|
|
49
|
+
setSelectedWallet(false);
|
|
50
|
+
handleWalletDetailsHeight();
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
const walletDiscoverySupported = useMemo(() => {
|
|
54
|
+
const supported = walletRegistry && Object.keys(walletRegistry.default || {}).length > 0 && Object.keys(walletRegistry.others || {}).length > 0;
|
|
55
|
+
return supported;
|
|
56
|
+
}, [walletRegistry]);
|
|
57
|
+
const allUniqueButtons = useMemo(() => {
|
|
58
|
+
const uniqueButtonSet = new Set();
|
|
59
|
+
return customConnectorButtons.concat(allExternalButtons).filter(button => {
|
|
60
|
+
if (uniqueButtonSet.has(button.name)) return false;
|
|
61
|
+
uniqueButtonSet.add(button.name);
|
|
62
|
+
return true;
|
|
63
|
+
});
|
|
64
|
+
}, [allExternalButtons, customConnectorButtons]);
|
|
65
|
+
const defaultButtonKeys = useMemo(() => new Set(Object.keys(walletRegistry.default)), [walletRegistry]);
|
|
66
|
+
const defaultButtons = useMemo(() => {
|
|
67
|
+
// display order: default injected buttons > custom adapter buttons > default non-injected buttons
|
|
68
|
+
const buttons = [...allExternalButtons.filter(button => button.hasInjectedWallet && defaultButtonKeys.has(button.name)), ...customConnectorButtons, ...allExternalButtons.filter(button => !button.hasInjectedWallet && defaultButtonKeys.has(button.name))].sort((a, _) => a.name === WALLET_CONNECTORS.METAMASK ? -1 : 1);
|
|
69
|
+
const buttonSet = new Set();
|
|
70
|
+
return buttons.filter(button => {
|
|
71
|
+
if (buttonSet.has(button.name)) return false;
|
|
72
|
+
buttonSet.add(button.name);
|
|
73
|
+
return true;
|
|
74
|
+
}).filter(button => {
|
|
75
|
+
var _button$chainNamespac;
|
|
76
|
+
return selectedChain === "all" || ((_button$chainNamespac = button.chainNamespaces) === null || _button$chainNamespac === void 0 ? void 0 : _button$chainNamespac.includes(selectedChain));
|
|
77
|
+
});
|
|
78
|
+
}, [allExternalButtons, customConnectorButtons, defaultButtonKeys, selectedChain]);
|
|
79
|
+
const installedWalletButtons = useMemo(() => {
|
|
80
|
+
const visibilityMap = connectorVisibilityMap;
|
|
81
|
+
return Object.keys(config).reduce((acc, localConnector) => {
|
|
82
|
+
if (localConnector !== WALLET_CONNECTORS.WALLET_CONNECT_V2 && visibilityMap[localConnector]) {
|
|
83
|
+
acc.push({
|
|
84
|
+
name: localConnector,
|
|
85
|
+
displayName: config[localConnector].label || localConnector,
|
|
86
|
+
hasInjectedWallet: config[localConnector].isInjected,
|
|
87
|
+
hasWalletConnect: false,
|
|
88
|
+
hasInstallLinks: false
|
|
89
|
+
});
|
|
90
|
+
}
|
|
91
|
+
return acc;
|
|
92
|
+
}, []);
|
|
93
|
+
}, [connectorVisibilityMap, config]);
|
|
94
|
+
const handleWalletSearch = e => {
|
|
95
|
+
const searchValue = e.target.value;
|
|
96
|
+
setWalletSearch(searchValue);
|
|
97
|
+
};
|
|
98
|
+
const handleChainFilterChange = chain => {
|
|
99
|
+
setSelectedChain(chain);
|
|
100
|
+
setIsShowAllWallets(false);
|
|
101
|
+
};
|
|
102
|
+
const filteredButtons = useMemo(() => {
|
|
103
|
+
if (walletDiscoverySupported) {
|
|
104
|
+
return [...allUniqueButtons.filter(button => button.hasInjectedWallet), ...allUniqueButtons.filter(button => !button.hasInjectedWallet)].sort((a, _) => a.name === WALLET_CONNECTORS.METAMASK ? -1 : 1).filter(button => selectedChain === "all" || button.chainNamespaces.includes(selectedChain)).filter(button => button.name.toLowerCase().includes(walletSearch.toLowerCase()));
|
|
105
|
+
}
|
|
106
|
+
return installedWalletButtons;
|
|
107
|
+
}, [walletDiscoverySupported, installedWalletButtons, walletSearch, allUniqueButtons, selectedChain]);
|
|
108
|
+
const externalButtons = useMemo(() => {
|
|
109
|
+
if (walletDiscoverySupported && !walletSearch && !isShowAllWallets) {
|
|
110
|
+
return defaultButtons;
|
|
111
|
+
}
|
|
112
|
+
return filteredButtons;
|
|
113
|
+
}, [walletDiscoverySupported, walletSearch, filteredButtons, defaultButtons, isShowAllWallets]);
|
|
114
|
+
const totalExternalWalletsCount = useMemo(() => filteredButtons.length, [filteredButtons]);
|
|
115
|
+
const initialWalletCount = useMemo(() => {
|
|
116
|
+
if (isShowAllWallets) return totalExternalWalletsCount;
|
|
117
|
+
return walletDiscoverySupported ? defaultButtons.length : installedWalletButtons.length;
|
|
118
|
+
}, [walletDiscoverySupported, defaultButtons, installedWalletButtons, isShowAllWallets, totalExternalWalletsCount]);
|
|
119
|
+
const handleWalletClick = button => {
|
|
120
|
+
var _button$chainNamespac2, _button$chainNamespac3;
|
|
121
|
+
// show chain namespace selector if the button is an injected connector with multiple chain namespaces
|
|
122
|
+
const isChainNamespaceSelectorRequired = button.hasInjectedWallet && ((_button$chainNamespac2 = button.chainNamespaces) === null || _button$chainNamespac2 === void 0 ? void 0 : _button$chainNamespac2.length) > 1;
|
|
123
|
+
if (isChainNamespaceSelectorRequired) {
|
|
124
|
+
setBodyState(_objectSpread(_objectSpread({}, bodyState), {}, {
|
|
125
|
+
multiChainSelector: {
|
|
126
|
+
show: true,
|
|
127
|
+
wallet: button
|
|
128
|
+
}
|
|
129
|
+
}));
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
const isInjectedConnectorAndSingleChainNamespace = button.hasInjectedWallet && ((_button$chainNamespac3 = button.chainNamespaces) === null || _button$chainNamespac3 === void 0 ? void 0 : _button$chainNamespac3.length) === 1;
|
|
133
|
+
// if doesn't have wallet connect & doesn't have install links, must be a custom connector
|
|
134
|
+
const isCustomConnector = !button.hasInjectedWallet && !button.hasWalletConnect && !button.hasInstallLinks;
|
|
135
|
+
if (isInjectedConnectorAndSingleChainNamespace || isCustomConnector) {
|
|
136
|
+
return handleExternalWalletClick({
|
|
137
|
+
connector: button.name
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
if (button.hasWalletConnect || !isInjectedConnectorAndSingleChainNamespace) {
|
|
141
|
+
setSelectedButton(button);
|
|
142
|
+
setSelectedWallet(true);
|
|
143
|
+
setCurrentPage(CONNECT_WALLET_PAGES.SELECTED_WALLET);
|
|
144
|
+
handleWalletDetailsHeight();
|
|
145
|
+
} else {
|
|
146
|
+
setBodyState(_objectSpread(_objectSpread({}, bodyState), {}, {
|
|
147
|
+
installLinks: {
|
|
148
|
+
show: true,
|
|
149
|
+
wallet: button
|
|
150
|
+
}
|
|
151
|
+
}));
|
|
152
|
+
}
|
|
153
|
+
};
|
|
154
|
+
const handleMoreWallets = () => {
|
|
155
|
+
setIsShowAllWallets(true);
|
|
156
|
+
};
|
|
157
|
+
const qrCodeValue = useMemo(() => {
|
|
158
|
+
if (!selectedWallet) return null;
|
|
159
|
+
if (selectedButton.name === WALLET_CONNECTORS.METAMASK && !selectedButton.hasInjectedWallet) {
|
|
160
|
+
return metamaskConnectUri;
|
|
161
|
+
}
|
|
162
|
+
return walletConnectUri;
|
|
163
|
+
}, [metamaskConnectUri, selectedButton, selectedWallet, walletConnectUri]);
|
|
164
|
+
return /*#__PURE__*/jsxs("div", {
|
|
165
|
+
className: "w3a--relative w3a--flex w3a--flex-1 w3a--flex-col w3a--gap-y-4",
|
|
166
|
+
children: [/*#__PURE__*/jsx(ConnectWalletHeader, {
|
|
167
|
+
onBackClick: handleBack,
|
|
168
|
+
currentPage: currentPage,
|
|
169
|
+
selectedButton: selectedButton
|
|
170
|
+
}), selectedWallet ? /*#__PURE__*/jsx(ConnectWalletQrCode, {
|
|
171
|
+
qrCodeValue: qrCodeValue,
|
|
172
|
+
isDark: isDark,
|
|
173
|
+
selectedButton: selectedButton,
|
|
174
|
+
primaryColor: (_selectedButton$walle = selectedButton.walletRegistryItem) === null || _selectedButton$walle === void 0 ? void 0 : _selectedButton$walle.primaryColor,
|
|
175
|
+
logoImage: `https://images.web3auth.io/login-${selectedButton.name}.${selectedButton.imgExtension}`
|
|
176
|
+
}) : /*#__PURE__*/jsxs("div", {
|
|
177
|
+
className: "w3a--flex w3a--flex-col w3a--gap-y-2",
|
|
178
|
+
children: [/*#__PURE__*/jsx(ConnectWalletChainFilter, {
|
|
179
|
+
isDark: isDark,
|
|
180
|
+
isLoading: isLoading,
|
|
181
|
+
selectedChain: selectedChain,
|
|
182
|
+
setSelectedChain: handleChainFilterChange,
|
|
183
|
+
chainNamespace: chainNamespace
|
|
184
|
+
}), /*#__PURE__*/jsx(ConnectWalletSearch, {
|
|
185
|
+
totalExternalWalletCount: totalExternalWalletsCount,
|
|
186
|
+
isLoading: isLoading,
|
|
187
|
+
walletSearch: walletSearch,
|
|
188
|
+
handleWalletSearch: handleWalletSearch,
|
|
189
|
+
buttonRadius: buttonRadius
|
|
190
|
+
}), /*#__PURE__*/jsx(ConnectWalletList, {
|
|
191
|
+
externalButtons: externalButtons,
|
|
192
|
+
isLoading: isLoading,
|
|
193
|
+
totalExternalWalletsCount: totalExternalWalletsCount,
|
|
194
|
+
initialWalletCount: initialWalletCount,
|
|
195
|
+
handleWalletClick: handleWalletClick,
|
|
196
|
+
handleMoreWallets: handleMoreWallets,
|
|
197
|
+
isDark: isDark,
|
|
198
|
+
deviceDetails: deviceDetails,
|
|
199
|
+
walletConnectUri: walletConnectUri,
|
|
200
|
+
buttonRadius: buttonRadius
|
|
201
|
+
})]
|
|
202
|
+
})]
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
export { ConnectWallet as default };
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { useMemo } from 'react';
|
|
2
|
+
import { useTranslation } from 'react-i18next';
|
|
3
|
+
import i18nInstance from '../../../localeImport.js';
|
|
4
|
+
import { cn, getIcons } from '../../../utils.js';
|
|
5
|
+
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
6
|
+
|
|
7
|
+
function ConnectWalletChainFilter(props) {
|
|
8
|
+
const {
|
|
9
|
+
isDark,
|
|
10
|
+
isLoading,
|
|
11
|
+
selectedChain,
|
|
12
|
+
setSelectedChain,
|
|
13
|
+
chainNamespace
|
|
14
|
+
} = props;
|
|
15
|
+
const [t] = useTranslation(undefined, {
|
|
16
|
+
i18n: i18nInstance
|
|
17
|
+
});
|
|
18
|
+
const chains = useMemo(() => {
|
|
19
|
+
const chains = [{
|
|
20
|
+
id: "all",
|
|
21
|
+
name: "modal.allChains",
|
|
22
|
+
icon: ""
|
|
23
|
+
}];
|
|
24
|
+
for (const chain of chainNamespace) {
|
|
25
|
+
chains.push({
|
|
26
|
+
id: chain,
|
|
27
|
+
name: chain === "eip155" ? "EVM" : chain,
|
|
28
|
+
icon: chain === "eip155" ? "ethereum" : chain
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
return chains;
|
|
32
|
+
}, [chainNamespace]);
|
|
33
|
+
if (isLoading) {
|
|
34
|
+
return /*#__PURE__*/jsx("div", {
|
|
35
|
+
className: "w3a--flex w3a--items-center w3a--justify-between w3a--gap-x-2",
|
|
36
|
+
children: Array.from({
|
|
37
|
+
length: chains.length
|
|
38
|
+
}).map((_, index) => /*#__PURE__*/jsx("div", {
|
|
39
|
+
className: "w3a--h-12 w3a--w-[100px] w3a--animate-pulse w3a--rounded-2xl w3a--bg-app-gray-200 dark:w3a--bg-app-gray-700"
|
|
40
|
+
}, `chain-loader-${index}`))
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
return /*#__PURE__*/jsx("div", {
|
|
44
|
+
className: "w3a--flex w3a--items-center w3a--justify-items-start w3a--gap-x-4",
|
|
45
|
+
children: chains.map(chain => /*#__PURE__*/jsxs("button", {
|
|
46
|
+
type: "button",
|
|
47
|
+
className: cn("w3a--flex w3a--w-[104px] w3a--items-center w3a--justify-center w3a--gap-x-1 w3a--text-xs w3a--font-medium w3a--px-4 w3a--py-3 w3a--text-app-gray-500 dark:w3a--text-app-gray-300 hover:w3a--bg-app-gray-200 dark:hover:w3a--bg-app-gray-700 w3a--h-12 w3a--rounded-2xl w3a--border w3a--border-transparent", {
|
|
48
|
+
"w3a--bg-app-gray-100 dark:w3a--bg-app-gray-800 w3a--border-app-gray-200 dark:w3a--border-app-gray-700 w3a--text-app-gray-900 dark:w3a--text-app-white hover:!w3a--bg-app-gray-100 dark:hover:!w3a--bg-app-gray-800": selectedChain === chain.id
|
|
49
|
+
}),
|
|
50
|
+
onClick: () => setSelectedChain(chain.id),
|
|
51
|
+
children: [chain.icon && /*#__PURE__*/jsx("img", {
|
|
52
|
+
src: getIcons(isDark ? `${chain.icon}-dark` : `${chain.icon}-light`),
|
|
53
|
+
alt: chain.name,
|
|
54
|
+
className: "w3a--size-5 w3a--object-contain"
|
|
55
|
+
}), /*#__PURE__*/jsx("span", {
|
|
56
|
+
className: "first-letter:w3a--capitalize",
|
|
57
|
+
children: t(chain.name)
|
|
58
|
+
})]
|
|
59
|
+
}, chain.id))
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
export { ConnectWalletChainFilter as default };
|
|
@@ -1,23 +1,19 @@
|
|
|
1
1
|
import { useTranslation } from 'react-i18next';
|
|
2
|
-
import i18nInstance from '
|
|
3
|
-
import
|
|
4
|
-
import Image from '
|
|
5
|
-
import ExternalWalletHeader from './ExternalWalletHeader.js';
|
|
2
|
+
import i18nInstance from '../../../localeImport.js';
|
|
3
|
+
import { getIcons } from '../../../utils.js';
|
|
4
|
+
import Image from '../../Image/Image.js';
|
|
6
5
|
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
7
6
|
|
|
8
|
-
|
|
7
|
+
const ConnectWalletChainNamespaceSelect = props => {
|
|
9
8
|
const {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
closeModal,
|
|
9
|
+
isDark,
|
|
10
|
+
wallet,
|
|
13
11
|
handleExternalWalletClick
|
|
14
12
|
} = props;
|
|
15
13
|
const [t] = useTranslation(undefined, {
|
|
16
14
|
i18n: i18nInstance
|
|
17
15
|
});
|
|
18
|
-
|
|
19
|
-
// chainNames should be available when selecting a chain namespace
|
|
20
|
-
const chainNamespaces = button.chainNamespaces.map(chainNamespace => {
|
|
16
|
+
const chainNamespaces = wallet.chainNamespaces.map(chainNamespace => {
|
|
21
17
|
const imageId = chainNamespace === "eip155" ? "evm" : chainNamespace;
|
|
22
18
|
const displayName = chainNamespace === "eip155" ? "EVM" : chainNamespace;
|
|
23
19
|
return {
|
|
@@ -27,25 +23,27 @@ function ExternalWalletChainNamespace(props) {
|
|
|
27
23
|
};
|
|
28
24
|
});
|
|
29
25
|
return /*#__PURE__*/jsxs("div", {
|
|
30
|
-
children: [/*#__PURE__*/jsx(
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
26
|
+
children: [/*#__PURE__*/jsx("div", {
|
|
27
|
+
className: "w3a--flex w3a--items-center w3a--justify-center",
|
|
28
|
+
children: /*#__PURE__*/jsx("p", {
|
|
29
|
+
className: "w3a--text-base w3a--font-medium w3a--text-app-gray-900 dark:w3a--text-app-white",
|
|
30
|
+
children: t("modal.external.select-chain")
|
|
31
|
+
})
|
|
34
32
|
}), /*#__PURE__*/jsx("div", {
|
|
35
|
-
className: "w3a--flex w3a--justify-center
|
|
33
|
+
className: "w3a--my-6 w3a--flex w3a--justify-center",
|
|
36
34
|
children: /*#__PURE__*/jsx(Image, {
|
|
37
|
-
imageId: `login-${
|
|
38
|
-
hoverImageId: `login-${
|
|
35
|
+
imageId: `login-${wallet.name}`,
|
|
36
|
+
hoverImageId: `login-${wallet.name}`,
|
|
39
37
|
fallbackImageId: "wallet",
|
|
40
38
|
height: "100",
|
|
41
39
|
width: "100",
|
|
42
40
|
isButton: true,
|
|
43
|
-
extension:
|
|
41
|
+
extension: wallet.imgExtension
|
|
44
42
|
})
|
|
45
43
|
}), /*#__PURE__*/jsx("p", {
|
|
46
|
-
className: "w3a--text-center w3a--text-sm w3a--text-app-gray-500
|
|
44
|
+
className: "w3a--my-6 w3a--text-center w3a--text-sm w3a--text-app-gray-500",
|
|
47
45
|
children: t("modal.external.select-chain-description", {
|
|
48
|
-
wallet:
|
|
46
|
+
wallet: wallet.displayName
|
|
49
47
|
})
|
|
50
48
|
}), /*#__PURE__*/jsx("ul", {
|
|
51
49
|
className: "w3a--flex w3a--flex-col w3a--gap-3",
|
|
@@ -54,15 +52,13 @@ function ExternalWalletChainNamespace(props) {
|
|
|
54
52
|
displayName,
|
|
55
53
|
imageId
|
|
56
54
|
}) => /*#__PURE__*/jsx("li", {
|
|
57
|
-
children: /*#__PURE__*/jsxs(
|
|
58
|
-
variant: "tertiary",
|
|
55
|
+
children: /*#__PURE__*/jsxs("button", {
|
|
59
56
|
type: "button",
|
|
57
|
+
className: "w3a--btn w3a--group w3a--relative w3a--h-11 w3a--w-full w3a--items-center !w3a--justify-between w3a--overflow-hidden w3a--rounded-full",
|
|
60
58
|
onClick: () => handleExternalWalletClick({
|
|
61
|
-
connector:
|
|
59
|
+
connector: wallet.name,
|
|
62
60
|
chainNamespace
|
|
63
61
|
}),
|
|
64
|
-
className: "w3a--w-full w3a--size-xl !w3a--justify-between w3a--items-center wallet-btn",
|
|
65
|
-
title: displayName,
|
|
66
62
|
children: [/*#__PURE__*/jsxs("div", {
|
|
67
63
|
className: "w3a--flex w3a--items-center",
|
|
68
64
|
children: [/*#__PURE__*/jsx(Image, {
|
|
@@ -77,14 +73,16 @@ function ExternalWalletChainNamespace(props) {
|
|
|
77
73
|
className: "w3a--ml-2 w3a--text-left w3a--text-sm first-letter:w3a--capitalize",
|
|
78
74
|
children: displayName
|
|
79
75
|
})]
|
|
80
|
-
}), /*#__PURE__*/jsx("
|
|
81
|
-
|
|
82
|
-
|
|
76
|
+
}), /*#__PURE__*/jsx("img", {
|
|
77
|
+
id: "chain-namespace-arrow",
|
|
78
|
+
className: "w3a--absolute w3a--right-4 w3a--top-1/2 -w3a--translate-x-6 -w3a--translate-y-1/2 w3a--opacity-0 w3a--transition-all w3a--duration-300 group-hover:w3a--translate-x-0 group-hover:w3a--opacity-100",
|
|
79
|
+
src: getIcons(isDark ? "chevron-right-dark" : "chevron-right-light"),
|
|
80
|
+
alt: "arrow"
|
|
83
81
|
})]
|
|
84
82
|
})
|
|
85
83
|
}, chainNamespace))
|
|
86
84
|
})]
|
|
87
85
|
});
|
|
88
|
-
}
|
|
86
|
+
};
|
|
89
87
|
|
|
90
|
-
export {
|
|
88
|
+
export { ConnectWalletChainNamespaceSelect as default };
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { useTranslation } from 'react-i18next';
|
|
2
|
+
import { CONNECT_WALLET_PAGES } from '../../../constants.js';
|
|
3
|
+
import i18nInstance from '../../../localeImport.js';
|
|
4
|
+
import { jsxs, jsx } from 'react/jsx-runtime';
|
|
5
|
+
|
|
6
|
+
function ConnectWalletHeader(props) {
|
|
7
|
+
const {
|
|
8
|
+
onBackClick,
|
|
9
|
+
currentPage,
|
|
10
|
+
selectedButton
|
|
11
|
+
} = props;
|
|
12
|
+
const [t] = useTranslation(undefined, {
|
|
13
|
+
i18n: i18nInstance
|
|
14
|
+
});
|
|
15
|
+
const handleBack = () => {
|
|
16
|
+
if (onBackClick) {
|
|
17
|
+
onBackClick();
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
return /*#__PURE__*/jsxs("div", {
|
|
21
|
+
className: "w3a--flex w3a--items-center w3a--justify-between",
|
|
22
|
+
children: [/*#__PURE__*/jsx("button", {
|
|
23
|
+
type: "button",
|
|
24
|
+
className: "w3a--z-20 w3a--flex w3a--size-5 w3a--cursor-pointer w3a--items-center w3a--justify-center w3a--rounded-full",
|
|
25
|
+
onClick: handleBack,
|
|
26
|
+
children: /*#__PURE__*/jsx("svg", {
|
|
27
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
28
|
+
fill: "none",
|
|
29
|
+
viewBox: "0 0 20 20",
|
|
30
|
+
className: "w3a--text-app-gray-500 hover:w3a--text-app-gray-900 dark:w3a--text-app-gray-200 dark:hover:w3a--text-app-white",
|
|
31
|
+
children: /*#__PURE__*/jsx("path", {
|
|
32
|
+
fill: "currentColor",
|
|
33
|
+
fillRule: "evenodd",
|
|
34
|
+
d: "M9.707 16.707a1 1 0 0 1-1.414 0l-6-6a1 1 0 0 1 0-1.414l6-6a1 1 0 0 1 1.414 1.414L5.414 9H17a1 1 0 1 1 0 2H5.414l4.293 4.293a1 1 0 0 1 0 1.414",
|
|
35
|
+
clipRule: "evenodd"
|
|
36
|
+
})
|
|
37
|
+
})
|
|
38
|
+
}), /*#__PURE__*/jsx("p", {
|
|
39
|
+
className: "w3a--text-base w3a--font-medium w3a--text-app-gray-900 dark:w3a--text-app-white",
|
|
40
|
+
children: currentPage === CONNECT_WALLET_PAGES.SELECTED_WALLET ? selectedButton === null || selectedButton === void 0 ? void 0 : selectedButton.displayName : currentPage === CONNECT_WALLET_PAGES.CONNECT_WALLET ? t("modal.connectYourWallet") : currentPage
|
|
41
|
+
}), /*#__PURE__*/jsx("div", {
|
|
42
|
+
className: "w3a--z-[-1] w3a--size-5"
|
|
43
|
+
})]
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
export { ConnectWalletHeader as default };
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
import { useState } from 'react';
|
|
2
|
+
import { useTranslation } from 'react-i18next';
|
|
3
|
+
import i18nInstance from '../../../localeImport.js';
|
|
4
|
+
import { cn, getIcons } from '../../../utils.js';
|
|
5
|
+
import Button from '../../Button/Button.js';
|
|
6
|
+
import { BUTTON_TYPE } from '../../Button/Button.type.js';
|
|
7
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
8
|
+
|
|
9
|
+
function NoWalletsFound() {
|
|
10
|
+
const [t] = useTranslation(undefined, {
|
|
11
|
+
i18n: i18nInstance
|
|
12
|
+
});
|
|
13
|
+
return /*#__PURE__*/jsx("div", {
|
|
14
|
+
className: "w3a--flex w3a--w-full w3a--items-center w3a--justify-center w3a--py-6 w3a--text-center w3a--text-app-gray-400 dark:w3a--text-app-gray-500",
|
|
15
|
+
children: t("modal.external.no-wallets-found")
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
function WalletsFound(props) {
|
|
19
|
+
const {
|
|
20
|
+
externalButtons,
|
|
21
|
+
isLoading,
|
|
22
|
+
handleWalletClick,
|
|
23
|
+
deviceDetails,
|
|
24
|
+
walletConnectUri,
|
|
25
|
+
buttonRadius
|
|
26
|
+
} = props;
|
|
27
|
+
if (isLoading) {
|
|
28
|
+
return /*#__PURE__*/jsx("div", {
|
|
29
|
+
className: "w3a--flex w3a--flex-col w3a--gap-y-2",
|
|
30
|
+
children: Array.from({
|
|
31
|
+
length: 6
|
|
32
|
+
}).map((_, index) => /*#__PURE__*/jsx("div", {
|
|
33
|
+
className: cn("w3a--h-12 w3a--w-full w3a--animate-pulse w3a--rounded-2xl w3a--bg-app-gray-200 dark:w3a--bg-app-gray-700", {
|
|
34
|
+
"w3a--rounded-full": buttonRadius === "pill",
|
|
35
|
+
"w3a--rounded-lg": buttonRadius === "rounded",
|
|
36
|
+
"w3a--rounded-none": buttonRadius === "square"
|
|
37
|
+
})
|
|
38
|
+
}, `loader-${index}`))
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
return /*#__PURE__*/jsx("div", {
|
|
42
|
+
className: "w3a--flex w3a--flex-col w3a--gap-y-2 w3a--pr-1.5",
|
|
43
|
+
children: externalButtons.map(button => /*#__PURE__*/jsx(Button, {
|
|
44
|
+
type: BUTTON_TYPE.WALLET,
|
|
45
|
+
props: {
|
|
46
|
+
label: button.displayName,
|
|
47
|
+
onClick: () => handleWalletClick(button),
|
|
48
|
+
button,
|
|
49
|
+
deviceDetails,
|
|
50
|
+
walletConnectUri,
|
|
51
|
+
buttonRadius
|
|
52
|
+
}
|
|
53
|
+
}, button.name))
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
function MoreWalletsButton(props) {
|
|
57
|
+
const {
|
|
58
|
+
totalExternalWalletsCount,
|
|
59
|
+
initialWalletCount,
|
|
60
|
+
handleMoreWallets,
|
|
61
|
+
isLoading,
|
|
62
|
+
isDark,
|
|
63
|
+
buttonRadius
|
|
64
|
+
} = props;
|
|
65
|
+
const [t] = useTranslation(undefined, {
|
|
66
|
+
i18n: i18nInstance
|
|
67
|
+
});
|
|
68
|
+
const onMoreWalletsClick = () => {
|
|
69
|
+
if (handleMoreWallets) {
|
|
70
|
+
handleMoreWallets();
|
|
71
|
+
}
|
|
72
|
+
};
|
|
73
|
+
if (isLoading && initialWalletCount < totalExternalWalletsCount) {
|
|
74
|
+
return /*#__PURE__*/jsx("div", {
|
|
75
|
+
className: cn("w3a--h-12 w3a--w-full w3a--animate-pulse w3a--bg-app-gray-200 dark:w3a--bg-app-gray-700", {
|
|
76
|
+
"w3a--rounded-full": buttonRadius === "pill",
|
|
77
|
+
"w3a--rounded-lg": buttonRadius === "rounded",
|
|
78
|
+
"w3a--rounded-none": buttonRadius === "square"
|
|
79
|
+
})
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
return /*#__PURE__*/jsxs("button", {
|
|
83
|
+
type: "button",
|
|
84
|
+
className: cn("w3a--flex w3a--items-center w3a--justify-start w3a--gap-x-2 w3a--bg-app-gray-50 w3a--p-3 hover:w3a--bg-app-gray-200 dark:w3a--bg-app-gray-800 dark:hover:w3a--bg-app-gray-600 active:w3a--scale-95 w3a--transition-all w3a--duration-150 w3a--mr-2.5", {
|
|
85
|
+
"w3a--rounded-full": buttonRadius === "pill",
|
|
86
|
+
"w3a--rounded-lg": buttonRadius === "rounded",
|
|
87
|
+
"w3a--rounded-none": buttonRadius === "square"
|
|
88
|
+
}),
|
|
89
|
+
onClick: onMoreWalletsClick,
|
|
90
|
+
children: [/*#__PURE__*/jsx("img", {
|
|
91
|
+
src: getIcons(isDark ? "view-dark" : "view-light"),
|
|
92
|
+
alt: "view",
|
|
93
|
+
height: "24",
|
|
94
|
+
width: "24"
|
|
95
|
+
}), /*#__PURE__*/jsx("p", {
|
|
96
|
+
className: "w3a--text-base w3a--font-normal w3a--text-app-gray-700 dark:w3a--text-app-white",
|
|
97
|
+
children: t("modal.connect-wallet.more-wallets")
|
|
98
|
+
}), /*#__PURE__*/jsx("span", {
|
|
99
|
+
className: "w3a--inline-flex w3a--items-center w3a--rounded-full w3a--bg-app-primary-100 w3a--px-2 w3a--py-1 w3a--text-xs w3a--font-medium w3a--text-app-primary-800 dark:w3a--border dark:w3a--border-app-primary-400 dark:w3a--bg-transparent dark:w3a--text-app-primary-400",
|
|
100
|
+
children: totalExternalWalletsCount - initialWalletCount
|
|
101
|
+
})]
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
function ConnectWalletList(props) {
|
|
105
|
+
const {
|
|
106
|
+
externalButtons,
|
|
107
|
+
isLoading,
|
|
108
|
+
totalExternalWalletsCount,
|
|
109
|
+
initialWalletCount,
|
|
110
|
+
handleWalletClick,
|
|
111
|
+
handleMoreWallets,
|
|
112
|
+
isDark,
|
|
113
|
+
deviceDetails,
|
|
114
|
+
walletConnectUri,
|
|
115
|
+
buttonRadius
|
|
116
|
+
} = props;
|
|
117
|
+
const [showMoreWallets, setShowMoreWallets] = useState(true);
|
|
118
|
+
const onShowMoreWalletsClick = () => {
|
|
119
|
+
setShowMoreWallets(false);
|
|
120
|
+
handleMoreWallets();
|
|
121
|
+
};
|
|
122
|
+
return /*#__PURE__*/jsxs(Fragment, {
|
|
123
|
+
children: [/*#__PURE__*/jsx("ul", {
|
|
124
|
+
className: cn("w3a--overflow-y-auto w3a--flex w3a--flex-col w3a--gap-y-2 w3a--h-[280px] w3a--social-container w3a--pr-2.5", {
|
|
125
|
+
"w3a--h-[328px]": !showMoreWallets
|
|
126
|
+
}),
|
|
127
|
+
children: externalButtons.length === 0 ? /*#__PURE__*/jsx(NoWalletsFound, {}) : /*#__PURE__*/jsx(WalletsFound, {
|
|
128
|
+
externalButtons: externalButtons,
|
|
129
|
+
isLoading: isLoading,
|
|
130
|
+
handleWalletClick: handleWalletClick,
|
|
131
|
+
deviceDetails: deviceDetails,
|
|
132
|
+
walletConnectUri: walletConnectUri,
|
|
133
|
+
buttonRadius: buttonRadius
|
|
134
|
+
})
|
|
135
|
+
}), showMoreWallets && totalExternalWalletsCount > 15 && !isLoading && initialWalletCount < totalExternalWalletsCount && /*#__PURE__*/jsx(MoreWalletsButton, {
|
|
136
|
+
totalExternalWalletsCount: totalExternalWalletsCount,
|
|
137
|
+
initialWalletCount: initialWalletCount,
|
|
138
|
+
handleMoreWallets: onShowMoreWalletsClick,
|
|
139
|
+
isLoading: isLoading,
|
|
140
|
+
isDark: isDark,
|
|
141
|
+
buttonRadius: buttonRadius
|
|
142
|
+
})]
|
|
143
|
+
});
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
export { ConnectWalletList as default };
|