@web3auth/no-modal 10.0.0-beta.1 → 10.0.0-beta.10
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/dist/lib.cjs/base/connector/baseConnector.js +2 -1
- package/dist/lib.cjs/base/connector/constants.js +3 -1
- package/dist/lib.cjs/base/constants.js +7 -0
- package/dist/lib.cjs/base/cookie.js +38 -0
- package/dist/lib.cjs/base/deserialize.js +13 -0
- package/dist/lib.cjs/base/errors/index.js +3 -22
- package/dist/lib.cjs/base/utils.js +24 -6
- package/dist/lib.cjs/base/wallet/index.js +2 -4
- package/dist/lib.cjs/connectors/auth-connector/authConnector.js +63 -20
- package/dist/lib.cjs/connectors/coinbase-connector/coinbaseConnector.js +13 -5
- package/dist/lib.cjs/connectors/coinbase-connector/index.js +7 -0
- package/dist/lib.cjs/connectors/injected-evm-connector/injectedEvmConnector.js +7 -3
- package/dist/lib.cjs/connectors/injected-solana-connector/walletStandardConnector.js +7 -4
- package/dist/lib.cjs/connectors/metamask-connector/metamaskConnector.js +43 -15
- package/dist/lib.cjs/connectors/utils.js +10 -0
- package/dist/lib.cjs/connectors/wallet-connect-v2-connector/config.js +6 -1
- package/dist/lib.cjs/connectors/wallet-connect-v2-connector/walletConnectV2Connector.js +6 -2
- package/dist/lib.cjs/index.js +13 -9
- package/dist/lib.cjs/noModal.js +190 -69
- package/dist/lib.cjs/plugins/nft-checkout-plugin/plugin.js +2 -2
- package/dist/lib.cjs/plugins/wallet-services-plugin/plugin.js +1 -1
- package/dist/lib.cjs/providers/account-abstraction-provider/index.js +5 -0
- package/dist/lib.cjs/providers/account-abstraction-provider/providers/AccountAbstractionProvider.js +29 -2
- package/dist/lib.cjs/providers/account-abstraction-provider/rpc/ethRpcMiddlewares.js +25 -3
- package/dist/lib.cjs/providers/base-provider/baseProvider.js +2 -0
- package/dist/lib.cjs/providers/ethereum-mpc-provider/index.js +7 -0
- package/dist/lib.cjs/providers/xrpl-provider/index.js +9 -0
- package/dist/lib.cjs/react/Web3AuthProvider.js +19 -0
- package/dist/lib.cjs/react/{wallet-services-plugin/WalletServicesContext.js → context/WalletServicesInnerContext.js} +18 -33
- package/dist/lib.cjs/react/{no-modal → context}/Web3AuthInnerContext.js +37 -95
- package/dist/lib.cjs/react/hooks/useCheckout.js +45 -0
- package/dist/lib.cjs/react/hooks/useEnableMFA.js +30 -0
- package/dist/lib.cjs/react/hooks/useIdentityToken.js +42 -0
- package/dist/lib.cjs/react/hooks/useManageMFA.js +30 -0
- package/dist/lib.cjs/react/hooks/useSwap.js +45 -0
- package/dist/lib.cjs/react/hooks/useSwitchChain.js +32 -0
- package/dist/lib.cjs/react/hooks/useWalletConnectScanner.js +45 -0
- package/dist/lib.cjs/react/hooks/useWalletServicesPlugin.js +19 -0
- package/dist/lib.cjs/react/hooks/useWalletUI.js +45 -0
- package/dist/lib.cjs/react/hooks/useWeb3Auth.js +28 -0
- package/dist/lib.cjs/react/hooks/useWeb3AuthConnect.js +48 -0
- package/dist/lib.cjs/react/hooks/useWeb3AuthDisconnect.js +30 -0
- package/dist/lib.cjs/react/{no-modal/hooks/useWeb3Auth.js → hooks/useWeb3AuthInner.js} +9 -9
- package/dist/lib.cjs/react/hooks/useWeb3AuthUser.js +50 -0
- package/dist/lib.cjs/react/index.js +26 -9
- package/dist/lib.cjs/react/solana/hooks/useSignAndSendTransaction.js +35 -0
- package/dist/lib.cjs/react/solana/hooks/useSignMessage.js +36 -0
- package/dist/lib.cjs/react/solana/hooks/useSignTransaction.js +34 -0
- package/dist/lib.cjs/react/solana/hooks/useSolanaWallet.js +62 -0
- package/dist/lib.cjs/react/solana/index.js +13 -0
- package/dist/lib.cjs/react/wagmi/constants.js +16 -0
- package/dist/lib.cjs/react/wagmi/index.js +7 -0
- package/dist/lib.cjs/react/wagmi/provider.js +189 -0
- package/dist/lib.cjs/types/base/connector/baseConnector.d.ts +4 -5
- package/dist/lib.cjs/types/base/connector/constants.d.ts +2 -0
- package/dist/lib.cjs/types/base/connector/interfaces.d.ts +18 -16
- package/dist/lib.cjs/types/base/constants.d.ts +5 -0
- package/dist/lib.cjs/types/base/cookie.d.ts +10 -0
- package/dist/lib.cjs/types/base/core/IWeb3Auth.d.ts +40 -12
- package/dist/lib.cjs/types/base/deserialize.d.ts +3 -0
- package/dist/lib.cjs/types/base/errors/index.d.ts +1 -2
- package/dist/lib.cjs/types/base/hooks/index.d.ts +3 -23
- package/dist/lib.cjs/types/base/index.d.ts +1 -0
- package/dist/lib.cjs/types/base/interfaces.d.ts +9 -4
- package/dist/lib.cjs/types/base/plugin/IPlugin.d.ts +1 -1
- package/dist/lib.cjs/types/base/utils.d.ts +3 -1
- package/dist/lib.cjs/types/base/wallet/index.d.ts +18 -17
- package/dist/lib.cjs/types/connectors/auth-connector/authConnector.d.ts +5 -6
- package/dist/lib.cjs/types/connectors/auth-connector/interface.d.ts +3 -2
- package/dist/lib.cjs/types/connectors/coinbase-connector/coinbaseConnector.d.ts +1 -1
- package/dist/lib.cjs/types/connectors/index.d.ts +1 -1
- package/dist/lib.cjs/types/connectors/metamask-connector/index.d.ts +1 -1
- package/dist/lib.cjs/types/connectors/metamask-connector/metamaskConnector.d.ts +2 -2
- package/dist/lib.cjs/types/connectors/utils.d.ts +8 -0
- package/dist/lib.cjs/types/noModal.d.ts +20 -9
- package/dist/lib.cjs/types/plugins/nft-checkout-plugin/plugin.d.ts +2 -2
- package/dist/lib.cjs/types/plugins/wallet-services-plugin/plugin.d.ts +2 -2
- package/dist/lib.cjs/types/providers/account-abstraction-provider/providers/AccountAbstractionProvider.d.ts +3 -2
- package/dist/lib.cjs/types/providers/account-abstraction-provider/providers/smartAccounts/index.d.ts +1 -1
- package/dist/lib.cjs/types/providers/account-abstraction-provider/rpc/ethRpcMiddlewares.d.ts +4 -1
- package/dist/lib.cjs/types/providers/ethereum-mpc-provider/providers/signingProviders/EthereumSigningProvider.d.ts +1 -1
- package/dist/lib.cjs/types/providers/index.d.ts +0 -2
- package/dist/lib.cjs/types/providers/solana-provider/providers/injectedProviders/base/baseInjectedProvider.d.ts +1 -1
- package/dist/lib.cjs/types/providers/xrpl-provider/providers/privateKeyProviders/xrplPrivateKeyProvider.d.ts +1 -1
- package/dist/lib.cjs/types/react/context/WalletServicesInnerContext.d.ts +6 -0
- package/dist/lib.cjs/types/react/{no-modal → context}/Web3AuthInnerContext.d.ts +1 -1
- package/dist/lib.cjs/types/react/hooks/index.d.ts +13 -0
- 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/useWalletUI.d.ts +8 -0
- package/dist/lib.cjs/types/react/hooks/useWeb3Auth.d.ts +3 -0
- package/dist/lib.cjs/types/react/hooks/useWeb3AuthConnect.d.ts +9 -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 +3 -2
- package/dist/lib.cjs/types/react/interfaces.d.ts +21 -0
- package/dist/lib.cjs/types/react/solana/hooks/index.d.ts +4 -0
- package/dist/lib.cjs/types/react/solana/hooks/useSignAndSendTransaction.d.ts +9 -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 +14 -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 +1 -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/vue/WalletServicesInnerProvider.d.ts +1 -0
- package/dist/lib.cjs/types/vue/composables/index.d.ts +13 -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 -0
- package/dist/lib.cjs/types/vue/composables/useWeb3AuthConnect.d.ts +10 -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/{wallet-services-plugin/context.d.ts → context/WalletServicesContext.d.ts} +2 -2
- package/dist/lib.cjs/types/vue/context/index.d.ts +1 -0
- package/dist/lib.cjs/types/vue/index.d.ts +4 -2
- package/dist/lib.cjs/types/vue/interfaces.d.ts +30 -0
- package/dist/lib.cjs/types/vue/solana/composables/index.d.ts +4 -0
- package/dist/lib.cjs/types/vue/solana/composables/useSignAndSendTransaction.d.ts +10 -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 +10 -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.cjs/vue/{wallet-services-plugin/WalletServicesProvider.js → WalletServicesInnerProvider.js} +26 -43
- package/dist/lib.cjs/vue/{no-modal/Web3AuthProvider.js → Web3AuthProvider.js} +45 -86
- package/dist/lib.cjs/vue/composables/useCheckout.js +45 -0
- package/dist/lib.cjs/vue/composables/useEnableMFA.js +43 -0
- package/dist/lib.cjs/vue/composables/useIdentityToken.js +55 -0
- package/dist/lib.cjs/vue/composables/useManageMFA.js +43 -0
- package/dist/lib.cjs/vue/composables/useSwap.js +45 -0
- package/dist/lib.cjs/vue/composables/useSwitchChain.js +43 -0
- package/dist/lib.cjs/vue/composables/useWalletConnectScanner.js +45 -0
- package/dist/lib.cjs/vue/composables/useWalletServicesPlugin.js +12 -0
- package/dist/lib.cjs/vue/composables/useWalletUI.js +45 -0
- package/dist/lib.cjs/vue/composables/useWeb3Auth.js +28 -0
- package/dist/lib.cjs/vue/composables/useWeb3AuthConnect.js +61 -0
- package/dist/lib.cjs/vue/composables/useWeb3AuthDisconnect.js +43 -0
- package/dist/lib.cjs/vue/{no-modal/composables/useWeb3Auth.js → composables/useWeb3AuthInner.js} +9 -9
- package/dist/lib.cjs/vue/composables/useWeb3AuthUser.js +64 -0
- package/dist/lib.cjs/vue/index.js +28 -8
- package/dist/lib.cjs/vue/solana/composables/useSignAndSendTransaction.js +36 -0
- package/dist/lib.cjs/vue/solana/composables/useSignMessage.js +38 -0
- package/dist/lib.cjs/vue/solana/composables/useSignTransaction.js +36 -0
- package/dist/lib.cjs/vue/solana/composables/useSolanaWallet.js +64 -0
- package/dist/lib.cjs/vue/solana/index.js +13 -0
- package/dist/lib.cjs/vue/wagmi/constants.js +16 -0
- package/dist/lib.cjs/vue/wagmi/index.js +7 -0
- package/dist/lib.cjs/vue/wagmi/provider.js +244 -0
- package/dist/lib.esm/base/connector/baseConnector.js +6 -1
- package/dist/lib.esm/base/connector/constants.js +3 -1
- package/dist/lib.esm/base/constants.js +6 -1
- package/dist/lib.esm/base/cookie.js +34 -0
- package/dist/lib.esm/base/deserialize.js +11 -0
- package/dist/lib.esm/base/errors/index.js +14 -22
- package/dist/lib.esm/base/plugin/errors.js +2 -0
- package/dist/lib.esm/base/utils.js +28 -12
- package/dist/lib.esm/base/wallet/index.js +2 -4
- package/dist/lib.esm/connectors/auth-connector/authConnector.js +83 -30
- package/dist/lib.esm/connectors/base-evm-connector/baseEvmConnector.js +1 -8
- package/dist/lib.esm/connectors/base-solana-connector/baseSolanaConnector.js +1 -8
- package/dist/lib.esm/connectors/coinbase-connector/coinbaseConnector.js +16 -15
- package/dist/lib.esm/connectors/coinbase-connector/index.js +1 -0
- package/dist/lib.esm/connectors/injected-evm-connector/injectedEvmConnector.js +11 -12
- package/dist/lib.esm/connectors/injected-solana-connector/walletStandardConnector.js +13 -17
- package/dist/lib.esm/connectors/metamask-connector/metamaskConnector.js +52 -27
- package/dist/lib.esm/connectors/utils.js +14 -1
- package/dist/lib.esm/connectors/wallet-connect-v2-connector/WalletConnectV2Provider.js +8 -25
- package/dist/lib.esm/connectors/wallet-connect-v2-connector/config.js +20 -25
- package/dist/lib.esm/connectors/wallet-connect-v2-connector/walletConnectV2Connector.js +15 -15
- package/dist/lib.esm/connectors/wallet-connect-v2-connector/walletConnectV2Utils.js +1 -11
- package/dist/lib.esm/index.js +12 -14
- package/dist/lib.esm/noModal.js +217 -80
- package/dist/lib.esm/plugins/nft-checkout-plugin/embed.js +4 -1
- package/dist/lib.esm/plugins/nft-checkout-plugin/plugin.js +4 -10
- package/dist/lib.esm/plugins/wallet-services-plugin/plugin.js +7 -9
- package/dist/lib.esm/providers/account-abstraction-provider/index.js +2 -2
- package/dist/lib.esm/providers/account-abstraction-provider/providers/AccountAbstractionProvider.js +37 -20
- package/dist/lib.esm/providers/account-abstraction-provider/providers/utils.js +0 -10
- package/dist/lib.esm/providers/account-abstraction-provider/rpc/ethRpcMiddlewares.js +26 -3
- package/dist/lib.esm/providers/base-provider/baseProvider.js +7 -9
- package/dist/lib.esm/providers/base-provider/utils.js +3 -3
- package/dist/lib.esm/providers/ethereum-mpc-provider/index.js +1 -0
- package/dist/lib.esm/providers/ethereum-mpc-provider/providers/signingProviders/EthereumSigningProvider.js +4 -17
- package/dist/lib.esm/providers/ethereum-mpc-provider/providers/signingProviders/signingUtils.js +3 -13
- package/dist/lib.esm/providers/ethereum-mpc-provider/rpc/ethRpcMiddlewares.js +1 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/converter.js +1 -0
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/formatter.js +10 -11
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/interfaces.js +3 -3
- package/dist/lib.esm/providers/ethereum-provider/providers/privateKeyProviders/TransactionFormatter/utils.js +1 -0
- package/dist/lib.esm/providers/ethereum-provider/rpc/walletMidddleware.js +8 -0
- package/dist/lib.esm/providers/solana-provider/providers/injectedProviders/base/baseInjectedProvider.js +2 -15
- package/dist/lib.esm/providers/solana-provider/providers/injectedProviders/walletStandardProvider.js +5 -12
- package/dist/lib.esm/providers/solana-provider/rpc/solanaRpcMiddlewares.js +1 -1
- package/dist/lib.esm/providers/solana-provider/solanaWallet.js +3 -0
- package/dist/lib.esm/providers/xrpl-provider/index.js +2 -0
- package/dist/lib.esm/providers/xrpl-provider/providers/privateKeyProviders/xrplPrivateKeyProvider.js +3 -14
- package/dist/lib.esm/providers/xrpl-provider/rpc/xrplRpcMiddlewares.js +1 -0
- package/dist/lib.esm/react/Web3AuthProvider.js +17 -0
- package/dist/lib.esm/react/context/WalletServicesInnerContext.js +70 -0
- package/dist/lib.esm/react/context/Web3AuthInnerContext.js +129 -0
- package/dist/lib.esm/react/hooks/useCheckout.js +32 -0
- package/dist/lib.esm/react/hooks/useEnableMFA.js +28 -0
- package/dist/lib.esm/react/hooks/useIdentityToken.js +40 -0
- package/dist/lib.esm/react/hooks/useManageMFA.js +28 -0
- package/dist/lib.esm/react/hooks/useSwap.js +32 -0
- package/dist/lib.esm/react/hooks/useSwitchChain.js +30 -0
- package/dist/lib.esm/react/hooks/useWalletConnectScanner.js +32 -0
- package/dist/lib.esm/react/hooks/useWalletServicesPlugin.js +17 -0
- package/dist/lib.esm/react/hooks/useWalletUI.js +32 -0
- package/dist/lib.esm/react/hooks/useWeb3Auth.js +26 -0
- package/dist/lib.esm/react/hooks/useWeb3AuthConnect.js +46 -0
- package/dist/lib.esm/react/hooks/useWeb3AuthDisconnect.js +28 -0
- package/dist/lib.esm/react/hooks/useWeb3AuthInner.js +13 -0
- package/dist/lib.esm/react/hooks/useWeb3AuthUser.js +48 -0
- package/dist/lib.esm/react/index.js +14 -5
- package/dist/lib.esm/react/solana/hooks/useSignAndSendTransaction.js +33 -0
- package/dist/lib.esm/react/solana/hooks/useSignMessage.js +34 -0
- package/dist/lib.esm/react/solana/hooks/useSignTransaction.js +32 -0
- package/dist/lib.esm/react/solana/hooks/useSolanaWallet.js +42 -0
- package/dist/lib.esm/react/solana/index.js +4 -0
- package/dist/lib.esm/react/wagmi/constants.js +14 -0
- package/dist/lib.esm/react/wagmi/index.js +1 -0
- package/dist/lib.esm/react/wagmi/provider.js +179 -0
- package/dist/lib.esm/vue/WalletServicesInnerProvider.js +71 -0
- package/dist/lib.esm/vue/Web3AuthProvider.js +154 -0
- package/dist/lib.esm/vue/composables/useCheckout.js +32 -0
- package/dist/lib.esm/vue/composables/useEnableMFA.js +30 -0
- package/dist/lib.esm/vue/composables/useIdentityToken.js +42 -0
- package/dist/lib.esm/vue/composables/useManageMFA.js +30 -0
- package/dist/lib.esm/vue/composables/useSwap.js +32 -0
- package/dist/lib.esm/vue/composables/useSwitchChain.js +30 -0
- package/dist/lib.esm/vue/composables/useWalletConnectScanner.js +32 -0
- package/dist/lib.esm/vue/composables/useWalletServicesPlugin.js +10 -0
- package/dist/lib.esm/vue/composables/useWalletUI.js +32 -0
- package/dist/lib.esm/vue/composables/useWeb3Auth.js +26 -0
- package/dist/lib.esm/vue/composables/useWeb3AuthConnect.js +48 -0
- package/dist/lib.esm/vue/composables/useWeb3AuthDisconnect.js +30 -0
- package/dist/lib.esm/vue/composables/useWeb3AuthInner.js +11 -0
- package/dist/lib.esm/vue/composables/useWeb3AuthUser.js +51 -0
- package/dist/lib.esm/vue/index.js +15 -5
- package/dist/lib.esm/vue/solana/composables/useSignAndSendTransaction.js +34 -0
- package/dist/lib.esm/vue/solana/composables/useSignMessage.js +36 -0
- package/dist/lib.esm/vue/solana/composables/useSignTransaction.js +34 -0
- package/dist/lib.esm/vue/solana/composables/useSolanaWallet.js +51 -0
- package/dist/lib.esm/vue/solana/index.js +4 -0
- package/dist/lib.esm/vue/wagmi/constants.js +14 -0
- package/dist/lib.esm/vue/wagmi/index.js +1 -0
- package/dist/lib.esm/vue/wagmi/provider.js +237 -0
- package/dist/noModal.umd.min.js +1 -1
- package/dist/noModal.umd.min.js.LICENSE.txt +0 -26
- package/package.json +79 -20
- package/dist/lib.cjs/react/no-modal/Web3AuthProvider.js +0 -15
- package/dist/lib.cjs/react/wallet-services-plugin/WalletServicesProvider.js +0 -16
- package/dist/lib.cjs/react/wallet-services-plugin/hooks/useWalletServicesPlugin.js +0 -26
- package/dist/lib.cjs/types/react/no-modal/hooks/index.d.ts +0 -1
- package/dist/lib.cjs/types/react/no-modal/hooks/useWeb3Auth.d.ts +0 -2
- package/dist/lib.cjs/types/react/no-modal/index.d.ts +0 -3
- package/dist/lib.cjs/types/react/no-modal/interfaces.d.ts +0 -15
- package/dist/lib.cjs/types/react/wallet-services-plugin/WalletServicesContext.d.ts +0 -7
- package/dist/lib.cjs/types/react/wallet-services-plugin/WalletServicesProvider.d.ts +0 -7
- package/dist/lib.cjs/types/react/wallet-services-plugin/hooks/index.d.ts +0 -1
- package/dist/lib.cjs/types/react/wallet-services-plugin/index.d.ts +0 -4
- package/dist/lib.cjs/types/react/wallet-services-plugin/interfaces.d.ts +0 -5
- package/dist/lib.cjs/types/vue/no-modal/composables/index.d.ts +0 -1
- package/dist/lib.cjs/types/vue/no-modal/composables/useWeb3Auth.d.ts +0 -2
- package/dist/lib.cjs/types/vue/no-modal/index.d.ts +0 -3
- package/dist/lib.cjs/types/vue/no-modal/interfaces.d.ts +0 -39
- package/dist/lib.cjs/types/vue/wallet-services-plugin/WalletServicesProvider.d.ts +0 -1
- package/dist/lib.cjs/types/vue/wallet-services-plugin/composables/index.d.ts +0 -1
- package/dist/lib.cjs/types/vue/wallet-services-plugin/composables/useWalletServicesPlugin.d.ts +0 -2
- package/dist/lib.cjs/types/vue/wallet-services-plugin/index.d.ts +0 -4
- package/dist/lib.cjs/types/vue/wallet-services-plugin/interfaces.d.ts +0 -13
- package/dist/lib.cjs/vue/wallet-services-plugin/composables/useWalletServicesPlugin.js +0 -24
- package/dist/lib.esm/react/no-modal/Web3AuthInnerContext.js +0 -197
- package/dist/lib.esm/react/no-modal/Web3AuthProvider.js +0 -13
- package/dist/lib.esm/react/no-modal/hooks/useWeb3Auth.js +0 -24
- package/dist/lib.esm/react/wallet-services-plugin/WalletServicesContext.js +0 -95
- package/dist/lib.esm/react/wallet-services-plugin/WalletServicesProvider.js +0 -14
- package/dist/lib.esm/react/wallet-services-plugin/hooks/useWalletServicesPlugin.js +0 -24
- package/dist/lib.esm/vue/no-modal/Web3AuthProvider.js +0 -203
- package/dist/lib.esm/vue/no-modal/composables/useWeb3Auth.js +0 -22
- package/dist/lib.esm/vue/wallet-services-plugin/WalletServicesProvider.js +0 -96
- package/dist/lib.esm/vue/wallet-services-plugin/composables/useWalletServicesPlugin.js +0 -22
- /package/dist/lib.cjs/types/react/{no-modal/Web3AuthProvider.d.ts → Web3AuthProvider.d.ts} +0 -0
- /package/dist/lib.cjs/types/react/{wallet-services-plugin/hooks → hooks}/useWalletServicesPlugin.d.ts +0 -0
- /package/dist/lib.cjs/types/vue/{no-modal/Web3AuthProvider.d.ts → Web3AuthProvider.d.ts} +0 -0
- /package/dist/lib.cjs/vue/{wallet-services-plugin/context.js → context/WalletServicesContext.js} +0 -0
- /package/dist/lib.esm/vue/{wallet-services-plugin/context.js → context/WalletServicesContext.js} +0 -0
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { createContext, useContext, useState, useEffect, useMemo, createElement } from 'react';
|
|
2
|
+
import { EVM_PLUGINS, PLUGIN_EVENTS } from '../../base/plugin/IPlugin.js';
|
|
3
|
+
import { CONNECTOR_STATUS } from '../../base/connector/constants.js';
|
|
4
|
+
|
|
5
|
+
const WalletServicesContext = createContext(null);
|
|
6
|
+
function WalletServicesContextProvider({
|
|
7
|
+
children,
|
|
8
|
+
context
|
|
9
|
+
}) {
|
|
10
|
+
const web3AuthContext = useContext(context);
|
|
11
|
+
const {
|
|
12
|
+
getPlugin,
|
|
13
|
+
isInitialized,
|
|
14
|
+
isConnected
|
|
15
|
+
} = web3AuthContext;
|
|
16
|
+
const [ready, setReady] = useState(false);
|
|
17
|
+
const [connecting, setConnecting] = useState(false);
|
|
18
|
+
const [walletServicesPlugin, setWalletServicesPlugin] = useState(null);
|
|
19
|
+
useEffect(() => {
|
|
20
|
+
if (isInitialized) {
|
|
21
|
+
const plugin = getPlugin(EVM_PLUGINS.WALLET_SERVICES);
|
|
22
|
+
setWalletServicesPlugin(plugin);
|
|
23
|
+
}
|
|
24
|
+
}, [isInitialized, getPlugin]);
|
|
25
|
+
useEffect(() => {
|
|
26
|
+
if (isConnected) {
|
|
27
|
+
const plugin = getPlugin(EVM_PLUGINS.WALLET_SERVICES);
|
|
28
|
+
setWalletServicesPlugin(plugin);
|
|
29
|
+
// when rehydrating, the connectedListener may be registered after the connected event is emitted, we need to check the status here
|
|
30
|
+
if ((plugin === null || plugin === void 0 ? void 0 : plugin.status) === CONNECTOR_STATUS.CONNECTED) setReady(true);
|
|
31
|
+
}
|
|
32
|
+
}, [isConnected, getPlugin, walletServicesPlugin]);
|
|
33
|
+
useEffect(() => {
|
|
34
|
+
const connectedListener = () => {
|
|
35
|
+
setReady(true);
|
|
36
|
+
setConnecting(false);
|
|
37
|
+
};
|
|
38
|
+
const disconnectedListener = () => {
|
|
39
|
+
setReady(false);
|
|
40
|
+
setConnecting(false);
|
|
41
|
+
};
|
|
42
|
+
const connectingListener = () => {
|
|
43
|
+
setConnecting(true);
|
|
44
|
+
};
|
|
45
|
+
if (walletServicesPlugin) {
|
|
46
|
+
walletServicesPlugin.on(PLUGIN_EVENTS.CONNECTED, connectedListener);
|
|
47
|
+
walletServicesPlugin.on(PLUGIN_EVENTS.DISCONNECTED, disconnectedListener);
|
|
48
|
+
walletServicesPlugin.on(PLUGIN_EVENTS.CONNECTING, connectingListener);
|
|
49
|
+
}
|
|
50
|
+
return () => {
|
|
51
|
+
if (walletServicesPlugin) {
|
|
52
|
+
walletServicesPlugin.off(PLUGIN_EVENTS.CONNECTED, connectedListener);
|
|
53
|
+
walletServicesPlugin.off(PLUGIN_EVENTS.DISCONNECTED, disconnectedListener);
|
|
54
|
+
walletServicesPlugin.off(PLUGIN_EVENTS.CONNECTING, connectingListener);
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
}, [walletServicesPlugin]);
|
|
58
|
+
const value = useMemo(() => {
|
|
59
|
+
return {
|
|
60
|
+
plugin: walletServicesPlugin,
|
|
61
|
+
ready,
|
|
62
|
+
connecting
|
|
63
|
+
};
|
|
64
|
+
}, [walletServicesPlugin, ready, connecting]);
|
|
65
|
+
return createElement(WalletServicesContext.Provider, {
|
|
66
|
+
value
|
|
67
|
+
}, children);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
export { WalletServicesContext, WalletServicesContextProvider };
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import { createContext, useMemo, useState, useCallback, useEffect, createElement } from 'react';
|
|
2
|
+
import { Web3AuthNoModal } from '../../noModal.js';
|
|
3
|
+
import { WalletInitializationError } from '../../base/errors/index.js';
|
|
4
|
+
import { CONNECTOR_EVENTS, CONNECTOR_STATUS } from '../../base/connector/constants.js';
|
|
5
|
+
|
|
6
|
+
const Web3AuthInnerContext = createContext(null);
|
|
7
|
+
function Web3AuthInnerProvider(params) {
|
|
8
|
+
const {
|
|
9
|
+
children,
|
|
10
|
+
config,
|
|
11
|
+
initialState
|
|
12
|
+
} = params;
|
|
13
|
+
const {
|
|
14
|
+
web3AuthOptions
|
|
15
|
+
} = config;
|
|
16
|
+
const web3Auth = useMemo(() => {
|
|
17
|
+
setProvider(null);
|
|
18
|
+
return new Web3AuthNoModal(web3AuthOptions, initialState);
|
|
19
|
+
}, [web3AuthOptions, initialState]);
|
|
20
|
+
const [isInitializing, setIsInitializing] = useState(false);
|
|
21
|
+
const [initError, setInitError] = useState(null);
|
|
22
|
+
const [isConnected, setIsConnected] = useState(false);
|
|
23
|
+
const [provider, setProvider] = useState(null);
|
|
24
|
+
const [isInitialized, setIsInitialized] = useState(false);
|
|
25
|
+
const [status, setStatus] = useState(null);
|
|
26
|
+
const [isMFAEnabled, setIsMFAEnabled] = useState(false);
|
|
27
|
+
const getPlugin = useCallback(name => {
|
|
28
|
+
if (!web3Auth) throw WalletInitializationError.notReady();
|
|
29
|
+
return web3Auth.getPlugin(name);
|
|
30
|
+
}, [web3Auth]);
|
|
31
|
+
useEffect(() => {
|
|
32
|
+
const controller = new AbortController();
|
|
33
|
+
async function init() {
|
|
34
|
+
try {
|
|
35
|
+
setInitError(null);
|
|
36
|
+
setIsInitializing(true);
|
|
37
|
+
await web3Auth.init({
|
|
38
|
+
signal: controller.signal
|
|
39
|
+
});
|
|
40
|
+
} catch (error) {
|
|
41
|
+
setInitError(error);
|
|
42
|
+
} finally {
|
|
43
|
+
setIsInitializing(false);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
if (web3Auth) init();
|
|
47
|
+
return () => {
|
|
48
|
+
controller.abort();
|
|
49
|
+
};
|
|
50
|
+
}, [web3Auth]);
|
|
51
|
+
useEffect(() => {
|
|
52
|
+
const notReadyListener = () => setStatus(CONNECTOR_STATUS.NOT_READY);
|
|
53
|
+
const readyListener = () => {
|
|
54
|
+
setStatus(web3Auth.status);
|
|
55
|
+
setIsInitialized(true);
|
|
56
|
+
};
|
|
57
|
+
const connectedListener = data => {
|
|
58
|
+
setStatus(web3Auth.status);
|
|
59
|
+
// we do this because of rehydration issues. status connected is fired first but web3auth sdk is not ready yet.
|
|
60
|
+
if (web3Auth.status === CONNECTOR_STATUS.CONNECTED) {
|
|
61
|
+
setIsInitialized(true);
|
|
62
|
+
setIsConnected(true);
|
|
63
|
+
setProvider(data.provider);
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
const disconnectedListener = () => {
|
|
67
|
+
setStatus(web3Auth.status);
|
|
68
|
+
setIsConnected(false);
|
|
69
|
+
setProvider(null);
|
|
70
|
+
};
|
|
71
|
+
const connectingListener = () => {
|
|
72
|
+
setStatus(web3Auth.status);
|
|
73
|
+
};
|
|
74
|
+
const errorListener = () => {
|
|
75
|
+
setStatus(web3Auth.status);
|
|
76
|
+
};
|
|
77
|
+
const rehydrationErrorListener = () => {
|
|
78
|
+
setStatus(web3Auth.status);
|
|
79
|
+
setIsConnected(false);
|
|
80
|
+
setProvider(null);
|
|
81
|
+
};
|
|
82
|
+
const mfaEnabledListener = isMFAEnabled => {
|
|
83
|
+
if (typeof isMFAEnabled === "boolean") setIsMFAEnabled(isMFAEnabled);
|
|
84
|
+
};
|
|
85
|
+
if (web3Auth) {
|
|
86
|
+
// web3Auth is initialized here.
|
|
87
|
+
setStatus(web3Auth.status);
|
|
88
|
+
web3Auth.on(CONNECTOR_EVENTS.NOT_READY, notReadyListener);
|
|
89
|
+
web3Auth.on(CONNECTOR_EVENTS.READY, readyListener);
|
|
90
|
+
web3Auth.on(CONNECTOR_EVENTS.CONNECTED, connectedListener);
|
|
91
|
+
web3Auth.on(CONNECTOR_EVENTS.DISCONNECTED, disconnectedListener);
|
|
92
|
+
web3Auth.on(CONNECTOR_EVENTS.CONNECTING, connectingListener);
|
|
93
|
+
web3Auth.on(CONNECTOR_EVENTS.ERRORED, errorListener);
|
|
94
|
+
web3Auth.on(CONNECTOR_EVENTS.REHYDRATION_ERROR, rehydrationErrorListener);
|
|
95
|
+
web3Auth.on(CONNECTOR_EVENTS.MFA_ENABLED, mfaEnabledListener);
|
|
96
|
+
}
|
|
97
|
+
return () => {
|
|
98
|
+
if (web3Auth) {
|
|
99
|
+
web3Auth.off(CONNECTOR_EVENTS.NOT_READY, notReadyListener);
|
|
100
|
+
web3Auth.off(CONNECTOR_EVENTS.READY, readyListener);
|
|
101
|
+
web3Auth.off(CONNECTOR_EVENTS.CONNECTED, connectedListener);
|
|
102
|
+
web3Auth.off(CONNECTOR_EVENTS.DISCONNECTED, disconnectedListener);
|
|
103
|
+
web3Auth.off(CONNECTOR_EVENTS.CONNECTING, connectingListener);
|
|
104
|
+
web3Auth.off(CONNECTOR_EVENTS.ERRORED, errorListener);
|
|
105
|
+
web3Auth.off(CONNECTOR_EVENTS.REHYDRATION_ERROR, rehydrationErrorListener);
|
|
106
|
+
web3Auth.off(CONNECTOR_EVENTS.MFA_ENABLED, mfaEnabledListener);
|
|
107
|
+
}
|
|
108
|
+
};
|
|
109
|
+
}, [web3Auth]);
|
|
110
|
+
const value = useMemo(() => {
|
|
111
|
+
return {
|
|
112
|
+
web3Auth,
|
|
113
|
+
isConnected,
|
|
114
|
+
isInitialized,
|
|
115
|
+
provider,
|
|
116
|
+
status,
|
|
117
|
+
isInitializing,
|
|
118
|
+
initError,
|
|
119
|
+
isMFAEnabled,
|
|
120
|
+
getPlugin,
|
|
121
|
+
setIsMFAEnabled
|
|
122
|
+
};
|
|
123
|
+
}, [web3Auth, isConnected, isInitialized, provider, status, getPlugin, isInitializing, initError, isMFAEnabled, setIsMFAEnabled]);
|
|
124
|
+
return createElement(Web3AuthInnerContext.Provider, {
|
|
125
|
+
value
|
|
126
|
+
}, children);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export { Web3AuthInnerContext, Web3AuthInnerProvider };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useWalletServicesPlugin } from './useWalletServicesPlugin.js';
|
|
3
|
+
import { WalletServicesPluginError } from '../../base/plugin/errors.js';
|
|
4
|
+
|
|
5
|
+
const useCheckout = () => {
|
|
6
|
+
const {
|
|
7
|
+
plugin,
|
|
8
|
+
ready
|
|
9
|
+
} = useWalletServicesPlugin();
|
|
10
|
+
const [loading, setLoading] = useState(false);
|
|
11
|
+
const [error, setError] = useState(null);
|
|
12
|
+
const showCheckout = useCallback(async showCheckoutParams => {
|
|
13
|
+
setLoading(true);
|
|
14
|
+
setError(null);
|
|
15
|
+
try {
|
|
16
|
+
if (!plugin) throw WalletServicesPluginError.notInitialized();
|
|
17
|
+
if (!ready) throw WalletServicesPluginError.walletPluginNotConnected();
|
|
18
|
+
await plugin.showCheckout(showCheckoutParams);
|
|
19
|
+
} catch (error) {
|
|
20
|
+
setError(error);
|
|
21
|
+
} finally {
|
|
22
|
+
setLoading(false);
|
|
23
|
+
}
|
|
24
|
+
}, [plugin, ready]);
|
|
25
|
+
return {
|
|
26
|
+
loading,
|
|
27
|
+
error,
|
|
28
|
+
showCheckout
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export { useCheckout };
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useWeb3AuthInner } from './useWeb3AuthInner.js';
|
|
3
|
+
|
|
4
|
+
const useEnableMFA = () => {
|
|
5
|
+
const {
|
|
6
|
+
web3Auth
|
|
7
|
+
} = useWeb3AuthInner();
|
|
8
|
+
const [loading, setLoading] = useState(false);
|
|
9
|
+
const [error, setError] = useState(null);
|
|
10
|
+
const enableMFA = useCallback(async params => {
|
|
11
|
+
setLoading(true);
|
|
12
|
+
setError(null);
|
|
13
|
+
try {
|
|
14
|
+
await web3Auth.enableMFA(params);
|
|
15
|
+
} catch (error) {
|
|
16
|
+
setError(error);
|
|
17
|
+
} finally {
|
|
18
|
+
setLoading(false);
|
|
19
|
+
}
|
|
20
|
+
}, [web3Auth]);
|
|
21
|
+
return {
|
|
22
|
+
loading,
|
|
23
|
+
error,
|
|
24
|
+
enableMFA
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
export { useEnableMFA };
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { useState, useCallback, useEffect } from 'react';
|
|
2
|
+
import { useWeb3AuthInner } from './useWeb3AuthInner.js';
|
|
3
|
+
|
|
4
|
+
const useIdentityToken = () => {
|
|
5
|
+
const {
|
|
6
|
+
web3Auth,
|
|
7
|
+
isConnected
|
|
8
|
+
} = useWeb3AuthInner();
|
|
9
|
+
const [loading, setLoading] = useState(false);
|
|
10
|
+
const [error, setError] = useState(null);
|
|
11
|
+
const [token, setToken] = useState(null);
|
|
12
|
+
const authenticateUser = useCallback(async () => {
|
|
13
|
+
setLoading(true);
|
|
14
|
+
setError(null);
|
|
15
|
+
try {
|
|
16
|
+
const userAuthInfo = await web3Auth.authenticateUser();
|
|
17
|
+
if (userAuthInfo !== null && userAuthInfo !== void 0 && userAuthInfo.idToken) {
|
|
18
|
+
setToken(userAuthInfo.idToken);
|
|
19
|
+
}
|
|
20
|
+
return userAuthInfo === null || userAuthInfo === void 0 ? void 0 : userAuthInfo.idToken;
|
|
21
|
+
} catch (error) {
|
|
22
|
+
setError(error);
|
|
23
|
+
} finally {
|
|
24
|
+
setLoading(false);
|
|
25
|
+
}
|
|
26
|
+
}, [web3Auth]);
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
if (!isConnected && token) {
|
|
29
|
+
setToken(null);
|
|
30
|
+
}
|
|
31
|
+
}, [isConnected, token]);
|
|
32
|
+
return {
|
|
33
|
+
loading,
|
|
34
|
+
error,
|
|
35
|
+
token,
|
|
36
|
+
authenticateUser
|
|
37
|
+
};
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export { useIdentityToken };
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useWeb3AuthInner } from './useWeb3AuthInner.js';
|
|
3
|
+
|
|
4
|
+
const useManageMFA = () => {
|
|
5
|
+
const {
|
|
6
|
+
web3Auth
|
|
7
|
+
} = useWeb3AuthInner();
|
|
8
|
+
const [loading, setLoading] = useState(false);
|
|
9
|
+
const [error, setError] = useState(null);
|
|
10
|
+
const manageMFA = useCallback(async params => {
|
|
11
|
+
setLoading(true);
|
|
12
|
+
setError(null);
|
|
13
|
+
try {
|
|
14
|
+
await web3Auth.manageMFA(params);
|
|
15
|
+
} catch (error) {
|
|
16
|
+
setError(error);
|
|
17
|
+
} finally {
|
|
18
|
+
setLoading(false);
|
|
19
|
+
}
|
|
20
|
+
}, [web3Auth]);
|
|
21
|
+
return {
|
|
22
|
+
loading,
|
|
23
|
+
error,
|
|
24
|
+
manageMFA
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
export { useManageMFA };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useWalletServicesPlugin } from './useWalletServicesPlugin.js';
|
|
3
|
+
import { WalletServicesPluginError } from '../../base/plugin/errors.js';
|
|
4
|
+
|
|
5
|
+
const useSwap = () => {
|
|
6
|
+
const {
|
|
7
|
+
plugin,
|
|
8
|
+
ready
|
|
9
|
+
} = useWalletServicesPlugin();
|
|
10
|
+
const [loading, setLoading] = useState(false);
|
|
11
|
+
const [error, setError] = useState(null);
|
|
12
|
+
const showSwap = useCallback(async showSwapParams => {
|
|
13
|
+
setLoading(true);
|
|
14
|
+
setError(null);
|
|
15
|
+
try {
|
|
16
|
+
if (!plugin) throw WalletServicesPluginError.notInitialized();
|
|
17
|
+
if (!ready) throw WalletServicesPluginError.walletPluginNotConnected();
|
|
18
|
+
await plugin.showSwap(showSwapParams);
|
|
19
|
+
} catch (error) {
|
|
20
|
+
setError(error);
|
|
21
|
+
} finally {
|
|
22
|
+
setLoading(false);
|
|
23
|
+
}
|
|
24
|
+
}, [plugin, ready]);
|
|
25
|
+
return {
|
|
26
|
+
loading,
|
|
27
|
+
error,
|
|
28
|
+
showSwap
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export { useSwap };
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useWeb3AuthInner } from './useWeb3AuthInner.js';
|
|
3
|
+
|
|
4
|
+
const useSwitchChain = () => {
|
|
5
|
+
const {
|
|
6
|
+
web3Auth
|
|
7
|
+
} = useWeb3AuthInner();
|
|
8
|
+
const [loading, setLoading] = useState(false);
|
|
9
|
+
const [error, setError] = useState(null);
|
|
10
|
+
const switchChain = useCallback(async chainId => {
|
|
11
|
+
setLoading(true);
|
|
12
|
+
setError(null);
|
|
13
|
+
try {
|
|
14
|
+
await web3Auth.switchChain({
|
|
15
|
+
chainId
|
|
16
|
+
});
|
|
17
|
+
} catch (error) {
|
|
18
|
+
setError(error);
|
|
19
|
+
} finally {
|
|
20
|
+
setLoading(false);
|
|
21
|
+
}
|
|
22
|
+
}, [web3Auth]);
|
|
23
|
+
return {
|
|
24
|
+
loading,
|
|
25
|
+
error,
|
|
26
|
+
switchChain
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
export { useSwitchChain };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useWalletServicesPlugin } from './useWalletServicesPlugin.js';
|
|
3
|
+
import { WalletServicesPluginError } from '../../base/plugin/errors.js';
|
|
4
|
+
|
|
5
|
+
const useWalletConnectScanner = () => {
|
|
6
|
+
const {
|
|
7
|
+
plugin,
|
|
8
|
+
ready
|
|
9
|
+
} = useWalletServicesPlugin();
|
|
10
|
+
const [loading, setLoading] = useState(false);
|
|
11
|
+
const [error, setError] = useState(null);
|
|
12
|
+
const showWalletConnectScanner = useCallback(async showWalletConnectScannerParams => {
|
|
13
|
+
if (!plugin) throw WalletServicesPluginError.notInitialized();
|
|
14
|
+
if (!ready) throw WalletServicesPluginError.walletPluginNotConnected();
|
|
15
|
+
setLoading(true);
|
|
16
|
+
setError(null);
|
|
17
|
+
try {
|
|
18
|
+
await plugin.showWalletConnectScanner(showWalletConnectScannerParams);
|
|
19
|
+
} catch (error) {
|
|
20
|
+
setError(error);
|
|
21
|
+
} finally {
|
|
22
|
+
setLoading(false);
|
|
23
|
+
}
|
|
24
|
+
}, [plugin, ready]);
|
|
25
|
+
return {
|
|
26
|
+
loading,
|
|
27
|
+
error,
|
|
28
|
+
showWalletConnectScanner
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export { useWalletConnectScanner };
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { WalletServicesContext } from '../context/WalletServicesInnerContext.js';
|
|
3
|
+
|
|
4
|
+
const useWalletServicesPlugin = () => {
|
|
5
|
+
const {
|
|
6
|
+
ready,
|
|
7
|
+
plugin,
|
|
8
|
+
connecting
|
|
9
|
+
} = useContext(WalletServicesContext);
|
|
10
|
+
return {
|
|
11
|
+
ready,
|
|
12
|
+
plugin,
|
|
13
|
+
connecting
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
export { useWalletServicesPlugin };
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useWalletServicesPlugin } from './useWalletServicesPlugin.js';
|
|
3
|
+
import { WalletServicesPluginError } from '../../base/plugin/errors.js';
|
|
4
|
+
|
|
5
|
+
const useWalletUI = () => {
|
|
6
|
+
const {
|
|
7
|
+
plugin,
|
|
8
|
+
ready
|
|
9
|
+
} = useWalletServicesPlugin();
|
|
10
|
+
const [loading, setLoading] = useState(false);
|
|
11
|
+
const [error, setError] = useState(null);
|
|
12
|
+
const showWalletUI = useCallback(async showWalletUiParams => {
|
|
13
|
+
setLoading(true);
|
|
14
|
+
setError(null);
|
|
15
|
+
try {
|
|
16
|
+
if (!plugin) throw WalletServicesPluginError.notInitialized();
|
|
17
|
+
if (!ready) throw WalletServicesPluginError.walletPluginNotConnected();
|
|
18
|
+
await plugin.showWalletUi(showWalletUiParams);
|
|
19
|
+
} catch (error) {
|
|
20
|
+
setError(error);
|
|
21
|
+
} finally {
|
|
22
|
+
setLoading(false);
|
|
23
|
+
}
|
|
24
|
+
}, [plugin, ready]);
|
|
25
|
+
return {
|
|
26
|
+
loading,
|
|
27
|
+
error,
|
|
28
|
+
showWalletUI
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export { useWalletUI };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { useWeb3AuthInner } from './useWeb3AuthInner.js';
|
|
2
|
+
|
|
3
|
+
const useWeb3Auth = () => {
|
|
4
|
+
const {
|
|
5
|
+
initError,
|
|
6
|
+
isConnected,
|
|
7
|
+
isInitialized,
|
|
8
|
+
isInitializing,
|
|
9
|
+
provider,
|
|
10
|
+
status,
|
|
11
|
+
web3Auth,
|
|
12
|
+
getPlugin
|
|
13
|
+
} = useWeb3AuthInner();
|
|
14
|
+
return {
|
|
15
|
+
initError,
|
|
16
|
+
isConnected,
|
|
17
|
+
isInitialized,
|
|
18
|
+
isInitializing,
|
|
19
|
+
provider,
|
|
20
|
+
status,
|
|
21
|
+
web3Auth,
|
|
22
|
+
getPlugin
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
export { useWeb3Auth };
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { useState, useEffect, useCallback } from 'react';
|
|
2
|
+
import { useWeb3AuthInner } from './useWeb3AuthInner.js';
|
|
3
|
+
|
|
4
|
+
const useWeb3AuthConnect = () => {
|
|
5
|
+
const context = useWeb3AuthInner();
|
|
6
|
+
const {
|
|
7
|
+
web3Auth,
|
|
8
|
+
isConnected
|
|
9
|
+
} = context;
|
|
10
|
+
const [loading, setLoading] = useState(false);
|
|
11
|
+
const [error, setError] = useState(null);
|
|
12
|
+
const [connectorName, setConnectorName] = useState(null);
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
if (!web3Auth) return;
|
|
15
|
+
if (!isConnected && connectorName) {
|
|
16
|
+
setConnectorName(null);
|
|
17
|
+
}
|
|
18
|
+
if (isConnected && !connectorName) {
|
|
19
|
+
setConnectorName(web3Auth.connectedConnectorName);
|
|
20
|
+
}
|
|
21
|
+
}, [isConnected, connectorName, web3Auth]);
|
|
22
|
+
const connect = useCallback(async (connector, params) => {
|
|
23
|
+
setLoading(true);
|
|
24
|
+
setError(null);
|
|
25
|
+
try {
|
|
26
|
+
const provider = await web3Auth.connectTo(connector, params);
|
|
27
|
+
if (provider) {
|
|
28
|
+
setConnectorName(web3Auth.connectedConnectorName);
|
|
29
|
+
}
|
|
30
|
+
return provider;
|
|
31
|
+
} catch (error) {
|
|
32
|
+
setError(error);
|
|
33
|
+
} finally {
|
|
34
|
+
setLoading(false);
|
|
35
|
+
}
|
|
36
|
+
}, [web3Auth]);
|
|
37
|
+
return {
|
|
38
|
+
isConnected,
|
|
39
|
+
loading,
|
|
40
|
+
error,
|
|
41
|
+
connectorName,
|
|
42
|
+
connect
|
|
43
|
+
};
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
export { useWeb3AuthConnect };
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { useState, useCallback } from 'react';
|
|
2
|
+
import { useWeb3AuthInner } from './useWeb3AuthInner.js';
|
|
3
|
+
|
|
4
|
+
const useWeb3AuthDisconnect = () => {
|
|
5
|
+
const {
|
|
6
|
+
web3Auth
|
|
7
|
+
} = useWeb3AuthInner();
|
|
8
|
+
const [loading, setLoading] = useState(false);
|
|
9
|
+
const [error, setError] = useState(null);
|
|
10
|
+
const disconnect = useCallback(async options => {
|
|
11
|
+
setLoading(true);
|
|
12
|
+
setError(null);
|
|
13
|
+
try {
|
|
14
|
+
await web3Auth.logout(options);
|
|
15
|
+
} catch (error) {
|
|
16
|
+
setError(error);
|
|
17
|
+
} finally {
|
|
18
|
+
setLoading(false);
|
|
19
|
+
}
|
|
20
|
+
}, [web3Auth]);
|
|
21
|
+
return {
|
|
22
|
+
loading,
|
|
23
|
+
error,
|
|
24
|
+
disconnect
|
|
25
|
+
};
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
export { useWeb3AuthDisconnect };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { useContext } from 'react';
|
|
2
|
+
import { Web3AuthInnerContext } from '../context/Web3AuthInnerContext.js';
|
|
3
|
+
import { WalletInitializationError } from '../../base/errors/index.js';
|
|
4
|
+
|
|
5
|
+
const useWeb3AuthInner = () => {
|
|
6
|
+
const context = useContext(Web3AuthInnerContext);
|
|
7
|
+
if (!context) {
|
|
8
|
+
throw WalletInitializationError.fromCode(1000, "usage of useWeb3Auth not wrapped in `Web3AuthContextProvider`.");
|
|
9
|
+
}
|
|
10
|
+
return context;
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export { useWeb3AuthInner };
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { useState, useCallback, useEffect } from 'react';
|
|
2
|
+
import { useWeb3AuthInner } from './useWeb3AuthInner.js';
|
|
3
|
+
|
|
4
|
+
const useWeb3AuthUser = () => {
|
|
5
|
+
const {
|
|
6
|
+
web3Auth,
|
|
7
|
+
isConnected,
|
|
8
|
+
isMFAEnabled,
|
|
9
|
+
setIsMFAEnabled
|
|
10
|
+
} = useWeb3AuthInner();
|
|
11
|
+
const [userInfo, setUserInfo] = useState(null);
|
|
12
|
+
const [loading, setLoading] = useState(false);
|
|
13
|
+
const [error, setError] = useState(null);
|
|
14
|
+
const getUserInfo = useCallback(async () => {
|
|
15
|
+
setLoading(true);
|
|
16
|
+
setError(null);
|
|
17
|
+
try {
|
|
18
|
+
const userInfo = await web3Auth.getUserInfo();
|
|
19
|
+
setUserInfo(userInfo);
|
|
20
|
+
return userInfo;
|
|
21
|
+
} catch (error) {
|
|
22
|
+
setError(error);
|
|
23
|
+
} finally {
|
|
24
|
+
setLoading(false);
|
|
25
|
+
}
|
|
26
|
+
}, [web3Auth]);
|
|
27
|
+
useEffect(() => {
|
|
28
|
+
const saveUserInfo = async () => {
|
|
29
|
+
const userInfo = await getUserInfo();
|
|
30
|
+
setUserInfo(userInfo);
|
|
31
|
+
setIsMFAEnabled((userInfo === null || userInfo === void 0 ? void 0 : userInfo.isMfaEnabled) || false);
|
|
32
|
+
};
|
|
33
|
+
if (isConnected && !userInfo) saveUserInfo();
|
|
34
|
+
if (!isConnected && userInfo) {
|
|
35
|
+
setUserInfo(null);
|
|
36
|
+
setIsMFAEnabled(false);
|
|
37
|
+
}
|
|
38
|
+
}, [isConnected, userInfo, getUserInfo, setIsMFAEnabled]);
|
|
39
|
+
return {
|
|
40
|
+
loading,
|
|
41
|
+
error,
|
|
42
|
+
userInfo,
|
|
43
|
+
isMFAEnabled,
|
|
44
|
+
getUserInfo
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
export { useWeb3AuthUser };
|
|
@@ -1,5 +1,14 @@
|
|
|
1
|
-
export {
|
|
2
|
-
export {
|
|
3
|
-
export {
|
|
4
|
-
export {
|
|
5
|
-
export {
|
|
1
|
+
export { Web3AuthProvider } from './Web3AuthProvider.js';
|
|
2
|
+
export { useCheckout } from './hooks/useCheckout.js';
|
|
3
|
+
export { useEnableMFA } from './hooks/useEnableMFA.js';
|
|
4
|
+
export { useIdentityToken } from './hooks/useIdentityToken.js';
|
|
5
|
+
export { useManageMFA } from './hooks/useManageMFA.js';
|
|
6
|
+
export { useSwap } from './hooks/useSwap.js';
|
|
7
|
+
export { useSwitchChain } from './hooks/useSwitchChain.js';
|
|
8
|
+
export { useWalletConnectScanner } from './hooks/useWalletConnectScanner.js';
|
|
9
|
+
export { useWalletServicesPlugin } from './hooks/useWalletServicesPlugin.js';
|
|
10
|
+
export { useWalletUI } from './hooks/useWalletUI.js';
|
|
11
|
+
export { useWeb3Auth } from './hooks/useWeb3Auth.js';
|
|
12
|
+
export { useWeb3AuthConnect } from './hooks/useWeb3AuthConnect.js';
|
|
13
|
+
export { useWeb3AuthDisconnect } from './hooks/useWeb3AuthDisconnect.js';
|
|
14
|
+
export { useWeb3AuthUser } from './hooks/useWeb3AuthUser.js';
|