@privy-io/react-auth 3.7.0 → 3.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/AccountNotFoundScreen-jSbfPu_e.js +1 -0
- package/dist/cjs/Address-CZQd_MIA.js +1 -0
- package/dist/cjs/AffirmativeConsentScreen-7a4hl59A.js +1 -0
- package/dist/cjs/AllowlistRejectionScreen-B6roj0JU.js +1 -0
- package/dist/cjs/AuthenticateWithWalletScreen-BcBapHrq.js +1 -0
- package/dist/cjs/AwaitingEvmToSolBridgingScreen-D1Xd83Hp.js +2 -0
- package/dist/cjs/AwaitingExternalEthereumTransferScreen-COL0WYkT.js +2 -0
- package/dist/cjs/AwaitingPasswordlessCodeScreen-Cx5fqGf6.js +1 -0
- package/dist/cjs/AwaitingSolToEvmBridgingScreen-DYS3lDs0.js +2 -0
- package/dist/cjs/BridgeNetworkSelectionView-uivzU_Y9.js +1 -0
- package/dist/cjs/Button-nXApC2Jy.js +2 -0
- package/dist/cjs/CaptchaScreen-025syTLo.js +1 -0
- package/dist/cjs/Checkbox-DXPQZFlQ.js +1 -0
- package/dist/cjs/Chip-ChrHHazc.js +1 -0
- package/dist/cjs/CoinbaseOnrampStatusScreen-ORl8wt4H.js +1 -0
- package/dist/cjs/Column-C2bAbJE0.js +1 -0
- package/dist/cjs/ConnectEmailForm-BEv-7qU9.js +1 -0
- package/dist/cjs/ConnectLedgerScreen-DBYExlWR.js +1 -0
- package/dist/cjs/ConnectOnlyLandingScreen-bOhkl0xJ.js +1 -0
- package/dist/cjs/ConnectOnlyStatusScreen-DvTrLHyY.js +1 -0
- package/dist/cjs/ConnectOrCreateScreen-Dh4EFU5N.js +1 -0
- package/dist/cjs/ConnectPhoneForm-DK-bg2D5.js +1 -0
- package/dist/cjs/ConnectWalletView-4vj7Sq7-.js +1 -0
- package/dist/cjs/ConnectionStatusScreen-Ct-KTCXS.js +1 -0
- package/dist/cjs/CopyToClipboard-fd8Z3kQX.js +1 -0
- package/dist/cjs/CrossAppAuthScreen-B-DtA7IH.js +1 -0
- package/dist/cjs/CustomLandingScreenView-tt_NEfU6.js +2 -0
- package/dist/cjs/DelegatedActionsConsentScreen-B5WlYn7z.js +1 -0
- package/dist/cjs/DelegatedActionsRevokeScreen-2g_ydX-Y.js +1 -0
- package/dist/cjs/EmailInputForm-tjrhBacA.js +1 -0
- package/dist/cjs/EmbeddedWalletConnectingScreen-9seYvsTF.js +1 -0
- package/dist/cjs/EmbeddedWalletCreatedScreen-PycFyIz6.js +1 -0
- package/dist/cjs/EmbeddedWalletKeyExportScreen-BDTDQY1f.js +2 -0
- package/dist/cjs/EmbeddedWalletOnAccountCreateScreen-B0tXEtG9.js +1 -0
- package/dist/cjs/EmbeddedWalletPasswordUpdateScreen-ZfgU86hx.js +1 -0
- package/dist/cjs/EmbeddedWalletPasswordUpdateSplashScreen-tP8rSVUL.js +1 -0
- package/dist/cjs/EnrollTotp-DZ5fIrXr.js +1 -0
- package/dist/cjs/ErrorBanner-CMjaobRI.js +1 -0
- package/dist/cjs/ErrorMessage-f0cRWc29.js +1 -0
- package/dist/cjs/ErrorScreen-Cob9AO30.js +1 -0
- package/dist/cjs/FarcasterConnectStatusScreen-C5FoWA6N.js +2 -0
- package/dist/cjs/FarcasterSignerStatusScreen-CDYkqsxz.js +2 -0
- package/dist/cjs/FundSolWalletWithExternalSolanaWallet-DC_xoE6W.js +2 -0
- package/dist/cjs/FundWalletMethodHeader-zYWhBIiS.js +1 -0
- package/dist/cjs/FundingEditAmountScreen-BB7-k00c.js +1 -0
- package/dist/cjs/FundingMethodSelectionScreen-BrV94GD2.js +1 -0
- package/dist/cjs/InAppBrowserLoginNotPossible-y8g07-kU.js +1 -0
- package/dist/cjs/InfoBanner-CTx1eRnV.js +1 -0
- package/dist/cjs/InjectedWalletIcon-UY3nMvZo.js +1 -0
- package/dist/cjs/InstallWalletScreen-CmGi6mS1.js +1 -0
- package/dist/cjs/JsonTree-xaeo0q6z.js +1 -0
- package/dist/cjs/LabelXs-CYMv6rOZ.js +1 -0
- package/dist/cjs/LandingScreen-B9jb8n_d.js +1 -0
- package/dist/cjs/Layouts-dRL0OSpp.js +1 -0
- package/dist/cjs/Link-DmzPZ_M7.js +1 -0
- package/dist/cjs/LinkConflictScreen-BJXyOu2J.js +1 -0
- package/dist/cjs/LinkEmailScreen-zyJFrvy-.js +1 -0
- package/dist/cjs/LinkPasskeyScreen-Bw7Xs741.js +1 -0
- package/dist/cjs/LinkPhoneScreen-C4JQblY3.js +1 -0
- package/dist/cjs/LoadingSkeleton-DoCrfGnl.js +1 -0
- package/dist/cjs/LoginFailedScreen-CGT-2B2h.js +1 -0
- package/dist/cjs/ManualTransferScreen-DPz98CSt.js +1 -0
- package/dist/cjs/MfaAuthEnrollmentFlowScreen-BBKMKDGR.js +1 -0
- package/dist/cjs/MfaAuthVerifyFlowScreen-3LKUo_xV.js +1 -0
- package/dist/cjs/MfaEnrollmentFlowScreen-B2YgNRCC.js +1 -0
- package/dist/cjs/MfaVerifyFlowScreen-BhVqkM2f.js +1 -0
- package/dist/cjs/ModalHeader-DbV81e3m.js +3 -0
- package/dist/cjs/MoonpayStatusScreen-yghPhz7v.js +1 -0
- package/dist/cjs/NetworkIcon-BZ9Mj6vV.js +1 -0
- package/dist/cjs/OAuthStatusScreen-q9MFItPT.js +1 -0
- package/dist/cjs/OpenLink-BpCUf9iR.js +1 -0
- package/dist/cjs/PasskeySelectSignupOrLogin-BKBH0QxK.js +1 -0
- package/dist/cjs/PasskeyStatusScreen-DVx4lzwq.js +1 -0
- package/dist/cjs/PasswordRecoveryScreen-BmGdXVfh.js +1 -0
- package/dist/cjs/PinInput-DSI6rjOn.js +1 -0
- package/dist/cjs/QrCode-Ua_0cVUP.js +2 -0
- package/dist/cjs/RecoveryOAuthStatusScreen-DUobwBXF.js +1 -0
- package/dist/cjs/RecoveryPasswordCreateScreen-vQG4ErlF.js +1 -0
- package/dist/cjs/RecoverySelectionScreen-E2l_NO8y.js +1 -0
- package/dist/cjs/Row-CxDF-VMy.js +1 -0
- package/dist/cjs/Screen-65eQbiHD.js +9 -0
- package/dist/cjs/ScreenHeader-CyURV6Ti.js +2 -0
- package/dist/cjs/ScreenLayout-B_60rKhZ.js +1 -0
- package/dist/cjs/SetAutomaticRecoveryScreen-DQolobOz.js +1 -0
- package/dist/cjs/SetWalletPasswordForm-8g-lawop.js +2 -0
- package/dist/cjs/SignRequestScreen-BAgmmVVW.js +1 -0
- package/dist/cjs/StackedContainer-ByB6Mdu0.js +1 -0
- package/dist/cjs/StandardSignAndSendTransactionScreen-BUB57iWU.js +1 -0
- package/dist/cjs/Subtitle-Dtmrw8l5.js +1 -0
- package/dist/cjs/TelegramAuthScreen-D5uhx6WN.js +1 -0
- package/dist/cjs/Title-C-tHJvrb.js +1 -0
- package/dist/cjs/TodoList-Cm_a93ef.js +2 -0
- package/dist/cjs/TransactionDetails-BefABtVQ.js +3 -0
- package/dist/cjs/TransactionErrorView-QKWh4urc.js +2 -0
- package/dist/cjs/TransferFromWalletScreen-C_0IpL-A.js +1 -0
- package/dist/cjs/TransferOrBridgeLoadingScreen-C6t1_cTP.js +1 -0
- package/dist/cjs/UpdateEmailScreen-BUAgWudx.js +1 -0
- package/dist/cjs/UpdatePhoneScreen-DefnuTEZ.js +1 -0
- package/dist/cjs/UserLimitReachedScreen-B76r_-LC.js +1 -0
- package/dist/cjs/Value-C-XtZyFa.js +1 -0
- package/dist/cjs/WalletButtonList-bICzXZXM.js +1 -0
- package/dist/cjs/WalletCards-BfpeHH5n.js +1 -0
- package/dist/cjs/WalletInfoCard-CscdnrUV.js +1 -0
- package/dist/cjs/WalletInterstitialScreen-CG1k3EvV.js +1 -0
- package/dist/cjs/WalletLink-DF6dDjkz.js +3 -0
- package/dist/cjs/WarningBanner-B_Gs_15p.js +1 -0
- package/dist/cjs/abstract-smart-wallets.js +1 -1
- package/dist/cjs/analytics-C6C_4JmG.js +1 -0
- package/dist/cjs/capitalizeFirstLetter-D-K8mqBm.js +1 -0
- package/dist/cjs/context-JUEgi5-6.js +1 -0
- package/dist/cjs/copy-BiZ7dtqy.js +1 -0
- package/dist/cjs/ethers-uj8IknV_.js +1 -0
- package/dist/cjs/events-context-Di6--rDg.js +1 -0
- package/dist/cjs/extended-chains.js +1 -1
- package/dist/cjs/farcaster-CWHXGAib.js +1 -0
- package/dist/cjs/farcaster.js +1 -1
- package/dist/cjs/formatErc20TokenAmount-DxwoWe7e.js +1 -0
- package/dist/cjs/frame-bPqBJ8fS.js +1 -0
- package/dist/cjs/get-is-unified-wallet-DmiciSes.js +1 -0
- package/dist/cjs/getChainName-C4rO8-3n.js +1 -0
- package/dist/cjs/getErc20Balance-BZ5-OGfD.js +1 -0
- package/dist/cjs/getErc20TokenInfo-HX7DgcWx.js +1 -0
- package/dist/cjs/getFormattedUsdFromLamports-Mu2fqwL2.js +1 -0
- package/dist/cjs/getPublicClient-EjAv8R2z.js +1 -0
- package/dist/cjs/getUsdcMintAddress-REYZSOb9.js +1 -0
- package/dist/cjs/index-BNNk54gK.js +1 -0
- package/dist/cjs/index-CRFXS9pP.js +1 -0
- package/dist/cjs/index-Cuv6j_Y0.js +1 -0
- package/dist/cjs/index-DvDeCr_m.js +5 -0
- package/dist/cjs/index.js +1 -6
- package/dist/cjs/internal-context-VDPFkIXN.js +1 -0
- package/dist/cjs/internal.js +1 -1
- package/dist/cjs/paths-DizMb-lU.js +1 -0
- package/dist/cjs/prepareFundingModalData-BVlyr8l5.js +1 -0
- package/dist/cjs/reservoir-3I-Vkf2B.js +1 -0
- package/dist/cjs/shared-BPGwTh8c.js +1 -0
- package/dist/cjs/shared-CT5ocsPG.js +1 -0
- package/dist/cjs/shouldProceedtoEmbeddedWalletCreationFlow-DcjqezwI.js +1 -0
- package/dist/cjs/smart-wallets-B7vHjGAW.js +1 -0
- package/dist/cjs/smart-wallets.js +1 -1
- package/dist/cjs/solana.js +1 -1
- package/dist/cjs/styles-Ca_DS00a.js +1 -0
- package/dist/cjs/styles-D4VeJNv1.js +1 -0
- package/dist/cjs/telegram-D3O0_F1a.js +1 -0
- package/dist/cjs/to-ui-error-a-xwbRKZ.js +1 -0
- package/dist/cjs/transaction-DjF5X-by.js +1 -0
- package/dist/cjs/transfer-Cit146vy.js +1 -0
- package/dist/cjs/twitch-BNvhZb2Y.js +1 -0
- package/dist/cjs/twitter-BVVRWkcG.js +1 -0
- package/dist/cjs/ui.js +2 -2
- package/dist/cjs/use-create-wallet-without-fallback-DSOJS4h0.js +1 -0
- package/dist/cjs/use-export-wallet-BRFTskbr.js +1 -0
- package/dist/cjs/{use-sign-with-user-signer-BtJVKMQr.js → use-sign-with-user-signer-On9f1Fag.js} +1 -1
- package/dist/cjs/useActiveWallet-DcxqWAsq.js +1 -0
- package/dist/cjs/useGetSolPrice-eOpcFeNE.js +1 -0
- package/dist/cjs/useGetTokenPrice-EcT0H5rf.js +1 -0
- package/dist/cjs/useI18n-hYSvbQCq.js +1 -0
- package/dist/cjs/usePrivy-CXPeoT5g.js +1 -0
- package/dist/cjs/useSolanaRpcClient-mfV88iJm.js +1 -0
- package/dist/cjs/useWalletBalance-CQAgfkRc.js +1 -0
- package/dist/cjs/useWallets-TxPVNWGS.js +1 -0
- package/dist/cjs/useWallets-h2xCj02C.js +1 -0
- package/dist/dts/{events-context-CCElA92Y.d.mts → events-context-CkFXl3uc.d.mts} +1 -1
- package/dist/dts/{events-context-CCElA92Y.d.ts → events-context-CkFXl3uc.d.ts} +1 -1
- package/dist/dts/extended-chains.d.mts +1 -1
- package/dist/dts/extended-chains.d.ts +1 -1
- package/dist/dts/farcaster.d.mts +1 -1
- package/dist/dts/farcaster.d.ts +1 -1
- package/dist/dts/index.d.mts +11 -9
- package/dist/dts/index.d.ts +11 -9
- package/dist/dts/internal.d.mts +1 -1
- package/dist/dts/internal.d.ts +1 -1
- package/dist/dts/smart-wallets.d.mts +1 -1
- package/dist/dts/smart-wallets.d.ts +1 -1
- package/dist/dts/solana.d.mts +3 -3
- package/dist/dts/solana.d.ts +3 -3
- package/dist/dts/ui.d.mts +1 -1
- package/dist/dts/ui.d.ts +1 -1
- package/dist/esm/AccountNotFoundScreen-CmhSsknC.mjs +1 -0
- package/dist/esm/Address-DtXA0OPS.mjs +1 -0
- package/dist/esm/AffirmativeConsentScreen-C6AcYU94.mjs +1 -0
- package/dist/esm/AllowlistRejectionScreen-BuH5iBJ3.mjs +1 -0
- package/dist/esm/AuthenticateWithWalletScreen-CKJqrLEm.mjs +1 -0
- package/dist/esm/AwaitingEvmToSolBridgingScreen-DuO5iRV2.mjs +2 -0
- package/dist/esm/AwaitingExternalEthereumTransferScreen-C50_Dj-N.mjs +2 -0
- package/dist/esm/AwaitingPasswordlessCodeScreen-Bb0UxW46.mjs +1 -0
- package/dist/esm/AwaitingSolToEvmBridgingScreen-YsM6M4T9.mjs +2 -0
- package/dist/esm/BridgeNetworkSelectionView-Bu0vi9_a.mjs +1 -0
- package/dist/esm/Button-DJ-mtuuD.mjs +2 -0
- package/dist/esm/CaptchaScreen-CWQAXaCK.mjs +1 -0
- package/dist/esm/Checkbox-NmGCZeKL.mjs +1 -0
- package/dist/esm/Chip-Bsgj4Yc-.mjs +1 -0
- package/dist/esm/CoinbaseOnrampStatusScreen-NdySyA5D.mjs +1 -0
- package/dist/esm/Column-DQ5Vw9t1.mjs +1 -0
- package/dist/esm/ConnectEmailForm-DUgOCS2V.mjs +1 -0
- package/dist/esm/ConnectLedgerScreen-3wp1wuP2.mjs +1 -0
- package/dist/esm/ConnectOnlyLandingScreen-BVkcUaO6.mjs +1 -0
- package/dist/esm/ConnectOnlyStatusScreen-CyT_IEgy.mjs +1 -0
- package/dist/esm/ConnectOrCreateScreen-BlIxCxVJ.mjs +1 -0
- package/dist/esm/ConnectPhoneForm-CbuSfwAI.mjs +1 -0
- package/dist/esm/ConnectWalletView-DVDOSzi0.mjs +1 -0
- package/dist/esm/ConnectionStatusScreen-DNdZyKcL.mjs +1 -0
- package/dist/esm/CopyToClipboard-DatKc59_.mjs +1 -0
- package/dist/esm/CrossAppAuthScreen-DEF_slEx.mjs +1 -0
- package/dist/esm/CustomLandingScreenView-DWt9lv8W.mjs +2 -0
- package/dist/esm/DelegatedActionsConsentScreen-DqeBCJkz.mjs +1 -0
- package/dist/esm/DelegatedActionsRevokeScreen-B-xLCB1j.mjs +1 -0
- package/dist/esm/EmailInputForm-B4hjCxRU.mjs +1 -0
- package/dist/esm/EmbeddedWalletConnectingScreen-BCg7qeI6.mjs +1 -0
- package/dist/esm/EmbeddedWalletCreatedScreen-jGepSDyo.mjs +1 -0
- package/dist/esm/EmbeddedWalletKeyExportScreen-DX22sVNh.mjs +2 -0
- package/dist/esm/EmbeddedWalletOnAccountCreateScreen-hkifQ988.mjs +1 -0
- package/dist/esm/EmbeddedWalletPasswordUpdateScreen-CezgHp88.mjs +1 -0
- package/dist/esm/EmbeddedWalletPasswordUpdateSplashScreen-BFamfPb_.mjs +1 -0
- package/dist/esm/EnrollTotp-BzAm1Ya4.mjs +1 -0
- package/dist/esm/ErrorBanner-BdiArMwu.mjs +1 -0
- package/dist/esm/ErrorMessage-Cx8GKGhL.mjs +1 -0
- package/dist/esm/ErrorScreen-DFAo4S7A.mjs +1 -0
- package/dist/esm/FarcasterConnectStatusScreen-Ys1uAk-s.mjs +1 -0
- package/dist/esm/FarcasterSignerStatusScreen-DIfmv7Ft.mjs +1 -0
- package/dist/esm/FundSolWalletWithExternalSolanaWallet-CkEgl8wO.mjs +1 -0
- package/dist/esm/FundWalletMethodHeader-CbTaIDLQ.mjs +1 -0
- package/dist/esm/FundingEditAmountScreen-Cz4tmsMX.mjs +1 -0
- package/dist/esm/FundingMethodSelectionScreen-fBauGI0K.mjs +1 -0
- package/dist/esm/InAppBrowserLoginNotPossible-DBhsoAkw.mjs +1 -0
- package/dist/esm/InfoBanner-D6C6Bt8L.mjs +1 -0
- package/dist/esm/InjectedWalletIcon-DLcYOGDj.mjs +1 -0
- package/dist/esm/InstallWalletScreen-CEcl2LHj.mjs +1 -0
- package/dist/esm/JsonTree-Bvd2C29R.mjs +1 -0
- package/dist/esm/LabelXs-BOisBtqT.mjs +1 -0
- package/dist/esm/LandingScreen-BvRIrtFN.mjs +1 -0
- package/dist/esm/Layouts-Bmf8DxNP.mjs +1 -0
- package/dist/esm/Link-DwjLfHwW.mjs +1 -0
- package/dist/esm/LinkConflictScreen-Bg9QTrJX.mjs +1 -0
- package/dist/esm/LinkEmailScreen-SlCMvM43.mjs +1 -0
- package/dist/esm/LinkPasskeyScreen-CNFL2N09.mjs +1 -0
- package/dist/esm/LinkPhoneScreen-DnPAvact.mjs +1 -0
- package/dist/esm/LoadingSkeleton-CHdaq3pb.mjs +1 -0
- package/dist/esm/LoginFailedScreen-CkxfR75o.mjs +1 -0
- package/dist/esm/ManualTransferScreen-px_MUbVh.mjs +1 -0
- package/dist/esm/MfaAuthEnrollmentFlowScreen-RbHifi_a.mjs +1 -0
- package/dist/esm/MfaAuthVerifyFlowScreen-B3SIiFnH.mjs +1 -0
- package/dist/esm/MfaEnrollmentFlowScreen-LgmZFVEZ.mjs +1 -0
- package/dist/esm/MfaVerifyFlowScreen-DZkVptvz.mjs +1 -0
- package/dist/esm/ModalHeader-D7WajfD8.mjs +3 -0
- package/dist/esm/MoonpayStatusScreen-CBc4DLDR.mjs +1 -0
- package/dist/esm/NetworkIcon-B48ilzF8.mjs +1 -0
- package/dist/esm/OAuthStatusScreen-DvD84FHd.mjs +1 -0
- package/dist/esm/OpenLink-BpeNYBKs.mjs +1 -0
- package/dist/esm/PasskeySelectSignupOrLogin-DZP4Hj5r.mjs +1 -0
- package/dist/esm/PasskeyStatusScreen-bP3yfXNt.mjs +1 -0
- package/dist/esm/PasswordRecoveryScreen-Bt_Cf8-l.mjs +1 -0
- package/dist/esm/PinInput-C3_MNxMt.mjs +1 -0
- package/dist/esm/QrCode-zzqjquVm.mjs +2 -0
- package/dist/esm/RecoveryOAuthStatusScreen-y6_gmb9s.mjs +1 -0
- package/dist/esm/RecoveryPasswordCreateScreen-CloUjFKm.mjs +1 -0
- package/dist/esm/RecoverySelectionScreen-FxCwz-PR.mjs +1 -0
- package/dist/esm/Row-CG0lSY5Z.mjs +1 -0
- package/dist/esm/Screen-dwi2CitY.mjs +8 -0
- package/dist/esm/ScreenHeader-Biz1wq02.mjs +2 -0
- package/dist/esm/ScreenLayout-Dmrhdwtt.mjs +1 -0
- package/dist/esm/SetAutomaticRecoveryScreen-Db5Xg_sQ.mjs +1 -0
- package/dist/esm/SetWalletPasswordForm-ZtRqoZYj.mjs +2 -0
- package/dist/esm/SignRequestScreen-DdAK4SlJ.mjs +1 -0
- package/dist/esm/StackedContainer-BrIQsdas.mjs +1 -0
- package/dist/esm/StandardSignAndSendTransactionScreen-C0IrbkCx.mjs +1 -0
- package/dist/esm/Subtitle-DkvfP2Ev.mjs +1 -0
- package/dist/esm/TelegramAuthScreen-vp2lrJFZ.mjs +1 -0
- package/dist/esm/Title-D0pfZff-.mjs +1 -0
- package/dist/esm/TodoList-Dn0Qu-vv.mjs +2 -0
- package/dist/esm/TransactionDetails-fgHkAnf9.mjs +3 -0
- package/dist/esm/TransactionErrorView-Dgp1KSy5.mjs +2 -0
- package/dist/esm/TransferFromWalletScreen-CTAGaF9C.mjs +1 -0
- package/dist/esm/TransferOrBridgeLoadingScreen-D3vBwM_o.mjs +1 -0
- package/dist/esm/UpdateEmailScreen-BBtChP9Q.mjs +1 -0
- package/dist/esm/UpdatePhoneScreen-Byn7UW7u.mjs +1 -0
- package/dist/esm/UserLimitReachedScreen-DXDqdBpt.mjs +1 -0
- package/dist/esm/Value-B4M62ove.mjs +1 -0
- package/dist/esm/WalletButtonList-CGloXTN0.mjs +1 -0
- package/dist/esm/WalletCards-DH1rqayz.mjs +1 -0
- package/dist/esm/WalletInfoCard-DAv0WFcc.mjs +1 -0
- package/dist/esm/WalletInterstitialScreen-CKiSWjpa.mjs +1 -0
- package/dist/esm/WalletLink-CjuEskpb.mjs +3 -0
- package/dist/esm/WarningBanner-BDp-QC9i.mjs +1 -0
- package/dist/esm/abstract-smart-wallets.mjs +1 -1
- package/dist/esm/analytics-mkkvFRju.mjs +1 -0
- package/dist/esm/capitalizeFirstLetter-DmLYqXsO.mjs +1 -0
- package/dist/esm/{events-context-ClaboIDc.mjs → context-Cb5MFcME.mjs} +1 -1
- package/dist/esm/copy-Bx2Jwc5_.mjs +1 -0
- package/dist/esm/ethers-CpMSCMOg.mjs +1 -0
- package/dist/esm/events-context-CI0iqAXA.mjs +1 -0
- package/dist/esm/extended-chains.mjs +1 -1
- package/dist/esm/farcaster-DPlSjvF5.mjs +1 -0
- package/dist/esm/farcaster.mjs +1 -1
- package/dist/esm/formatErc20TokenAmount-BuPk9xcy.mjs +1 -0
- package/dist/esm/frame-BMa3kyjk.mjs +1 -0
- package/dist/esm/get-is-unified-wallet-DymQMSJy.mjs +1 -0
- package/dist/esm/getChainName-DjpPdUSc.mjs +1 -0
- package/dist/esm/getErc20Balance-Dtau1386.mjs +1 -0
- package/dist/esm/getErc20TokenInfo-CKA_MDcy.mjs +1 -0
- package/dist/esm/getFormattedUsdFromLamports-B6EqSEho.mjs +1 -0
- package/dist/esm/getPublicClient-IxRndou_.mjs +1 -0
- package/dist/esm/getUsdcMintAddress-DFI1hv05.mjs +1 -0
- package/dist/esm/index-B_e8abKi.mjs +1 -0
- package/dist/esm/index-CI666IP9.mjs +5 -0
- package/dist/esm/index-CJMgUOnw.mjs +1 -0
- package/dist/esm/index-DdlRJsoj.mjs +1 -0
- package/dist/esm/index.mjs +1 -5
- package/dist/esm/internal-context-Cvo1WmWN.mjs +1 -0
- package/dist/esm/internal.mjs +1 -1
- package/dist/esm/paths-3HW55qZg.mjs +1 -0
- package/dist/esm/prepareFundingModalData-BUyu5Vhr.mjs +1 -0
- package/dist/esm/reservoir-B0V48m2I.mjs +1 -0
- package/dist/esm/shared-CtYf3O54.mjs +1 -0
- package/dist/esm/shared-DsP7M4P5.mjs +1 -0
- package/dist/esm/shouldProceedtoEmbeddedWalletCreationFlow-CxerhsH3.mjs +1 -0
- package/dist/esm/smart-wallets-Cbhn7qlU.mjs +1 -0
- package/dist/esm/smart-wallets.mjs +1 -1
- package/dist/esm/solana.mjs +1 -1
- package/dist/esm/styles-BxA7nKxI.mjs +1 -0
- package/dist/esm/styles-DY17fuAX.mjs +1 -0
- package/dist/esm/telegram-B-JqnkqZ.mjs +1 -0
- package/dist/esm/to-ui-error-B3m2hl6e.mjs +1 -0
- package/dist/esm/transaction-CnfuREWo.mjs +1 -0
- package/dist/esm/transfer-CMPmjPsM.mjs +1 -0
- package/dist/esm/twitch-5IOe4sIQ.mjs +1 -0
- package/dist/esm/twitter-6jomarO4.mjs +1 -0
- package/dist/esm/ui.mjs +2 -2
- package/dist/esm/use-create-wallet-without-fallback-DodUf3VP.mjs +1 -0
- package/dist/esm/use-export-wallet-CWslDKqf.mjs +1 -0
- package/dist/esm/use-sign-with-user-signer-LJ6ROduD.mjs +1 -0
- package/dist/esm/useActiveWallet-hrZcON-K.mjs +1 -0
- package/dist/esm/useGetSolPrice-Bi0pPiUW.mjs +1 -0
- package/dist/esm/useGetTokenPrice-B4XVfxeD.mjs +1 -0
- package/dist/esm/useI18n-ByKvnaXP.mjs +1 -0
- package/dist/esm/usePrivy-D3OPY7tm.mjs +1 -0
- package/dist/esm/useSolanaRpcClient-DjD2ma5c.mjs +1 -0
- package/dist/esm/useWalletBalance-Xca4-c_r.mjs +1 -0
- package/dist/esm/useWallets-BplPx0Pz.mjs +1 -0
- package/dist/esm/useWallets-CQMJYOF9.mjs +1 -0
- package/package.json +15 -9
- package/dist/cjs/EmbeddedWalletConnectingScreen-JRafXI8d.js +0 -27
- package/dist/cjs/SignRequestScreen-Dy02euV9.js +0 -1
- package/dist/cjs/events-context-7-Gs8c_9.js +0 -1
- package/dist/cjs/frame-B2orQ_lK.js +0 -1
- package/dist/cjs/internal-context-CeWKmK5u.js +0 -1
- package/dist/cjs/smart-wallets-DaqaXBrW.js +0 -1
- package/dist/cjs/use-export-wallet-Cz8MVlvJ.js +0 -2
- package/dist/cjs/useActiveWallet-C5D3a-je.js +0 -1
- package/dist/cjs/usePrivy-BdYU4BZI.js +0 -1
- package/dist/esm/EmbeddedWalletConnectingScreen-D50stmJi.mjs +0 -25
- package/dist/esm/SignRequestScreen-D9o7VhNz.mjs +0 -1
- package/dist/esm/frame-Dj70FEYB.mjs +0 -1
- package/dist/esm/internal-context-eGSwROSk.mjs +0 -1
- package/dist/esm/smart-wallets-BXT3GZwg.mjs +0 -1
- package/dist/esm/use-export-wallet-DTiEdSYz.mjs +0 -1
- package/dist/esm/use-sign-with-user-signer-DaTvrd5T.mjs +0 -1
- package/dist/esm/useActiveWallet-B8DSbnuu.mjs +0 -1
- package/dist/esm/usePrivy-BCcRF869.mjs +0 -1
- package/dist/dts/{types-B6UNnZ2P.d.mts → types-BkkvIRg5.d.mts} +134 -134
- package/dist/dts/{types-B6UNnZ2P.d.ts → types-BkkvIRg5.d.ts} +134 -134
package/dist/cjs/index.js
CHANGED
|
@@ -1,6 +1 @@
|
|
|
1
|
-
"use strict";var e=require("react/jsx-runtime"),t=require("mipd"),r=require("react"),n=require("react-device-detect"),i=require("viem/utils"),a=require("@privy-io/js-sdk-core"),o=require("@privy-io/popup"),s=require("./internal-context-CeWKmK5u.js"),l=require("./EmbeddedWalletConnectingScreen-JRafXI8d.js"),c=require("uuid"),d=require("jose"),u=require("eventemitter3"),h=require("@coinbase/wallet-sdk"),p=require("@privy-io/ethereum"),y=require("./events-context-7-Gs8c_9.js"),m=require("ofetch"),w=require("js-cookie"),g=require("zustand"),v=require("@marsidev/react-turnstile"),f=require("styled-components"),C=require("./useActiveWallet-C5D3a-je.js"),E=require("@heroicons/react/24/outline/DevicePhoneMobileIcon"),A=require("@heroicons/react/24/outline/FingerPrintIcon"),P=require("@heroicons/react/24/outline/PhoneIcon"),k=require("@heroicons/react/24/outline/ShieldCheckIcon"),T=require("@heroicons/react/24/outline/CalendarIcon"),x=require("@heroicons/react/24/outline/ExclamationTriangleIcon"),b=require("viem"),S=require("@headlessui/react"),_=require("@privy-io/urls"),I=require("./usePrivy-BdYU4BZI.js"),U=require("lucide-react"),W=require("./SignRequestScreen-Dy02euV9.js"),R=require("@heroicons/react/24/outline/EnvelopeIcon"),N=require("@heroicons/react/24/outline/QuestionMarkCircleIcon"),O=require("@heroicons/react/24/solid/CheckBadgeIcon"),M=require("@heroicons/react/24/solid/IdentificationIcon"),j=require("@heroicons/react/24/outline/ChevronRightIcon"),F=require("@heroicons/react/24/outline/MinusCircleIcon"),L=require("@heroicons/react/24/outline/ArrowRightEndOnRectangleIcon"),D=require("@heroicons/react/24/outline/ClockIcon"),q=require("@heroicons/react/24/outline/CheckCircleIcon"),B=require("@heroicons/react/24/solid/ShieldCheckIcon"),H=require("@heroicons/react/24/outline/GlobeAltIcon"),z=require("./frame-B2orQ_lK.js"),K=require("@privy-io/routes"),V=require("x402/client"),$=require("@privy-io/api-base"),Y=require("viem/accounts"),G=require("./use-sign-with-user-signer-BtJVKMQr.js"),Z=require("./getEmbeddedConnectedWallet-6TsVZJkD.js");function J(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}function X(e){if(e&&"object"==typeof e&&"default"in e)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(r){if("default"!==r){var n=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,n.get?n:{enumerable:!0,get:function(){return e[r]}})}})),t.default=e,Object.freeze(t)}require("fast-password-entropy"),require("secure-password-utilities"),require("secure-password-utilities/wordlists"),require("@heroicons/react/24/outline/UserCircleIcon"),require("@heroicons/react/24/outline/ArrowLeftIcon"),require("@heroicons/react/24/outline/ArrowRightIcon"),require("@heroicons/react/24/outline/XMarkIcon"),require("@heroicons/react/20/solid/CheckIcon"),require("@heroicons/react/24/outline/WalletIcon"),require("@heroicons/react/24/outline/ExclamationCircleIcon"),require("@heroicons/react/24/outline/Square2StackIcon"),require("@heroicons/react/24/outline"),require("@tanstack/react-virtual"),require("@heroicons/react/24/outline/CheckIcon"),require("qrcode"),require("@scure/base"),require("@walletconnect/ethereum-provider"),require("@heroicons/react/24/outline/CreditCardIcon"),require("@heroicons/react/24/outline/QrCodeIcon"),require("@heroicons/react/24/solid/ArrowsRightLeftIcon"),require("@heroicons/react/24/outline/InformationCircleIcon"),require("@heroicons/react/24/outline/ClipboardDocumentCheckIcon"),require("@heroicons/react/24/outline/ClipboardDocumentIcon"),require("@heroicons/react/24/outline/ChevronDownIcon"),require("@heroicons/react/24/solid/CheckCircleIcon"),require("@heroicons/react/24/outline/LockClosedIcon"),require("@heroicons/react/24/outline/PencilSquareIcon"),require("@heroicons/react/24/outline/ArrowPathIcon"),require("@heroicons/react/24/outline/EyeIcon"),require("@heroicons/react/24/outline/EyeSlashIcon"),require("@heroicons/react/24/outline/KeyIcon"),require("@heroicons/react/24/outline/ArrowDownTrayIcon"),require("@heroicons/react/24/outline/DocumentDuplicateIcon"),require("@heroicons/react/24/solid/XCircleIcon"),require("tinycolor2");var Q=/*#__PURE__*/J(r),ee=/*#__PURE__*/J(a),te=/*#__PURE__*/X(d),re=/*#__PURE__*/J(u),ne=/*#__PURE__*/J(w),ie=/*#__PURE__*/J(E),ae=/*#__PURE__*/J(A),oe=/*#__PURE__*/J(P),se=/*#__PURE__*/J(k),le=/*#__PURE__*/J(T),ce=/*#__PURE__*/J(x),de=/*#__PURE__*/J(R),ue=/*#__PURE__*/J(N),he=/*#__PURE__*/J(O),pe=/*#__PURE__*/J(M),ye=/*#__PURE__*/J(j),me=/*#__PURE__*/J(F),we=/*#__PURE__*/J(L),ge=/*#__PURE__*/J(D),ve=/*#__PURE__*/J(q),fe=/*#__PURE__*/J(B),Ce=/*#__PURE__*/J(H);function Ee(e){return e?{"privy-ui":"t"}:void 0}class Ae{async authenticate(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new s.PrivyClientError("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(s.passwordlessAuthenticatePath,{email:this.meta.email,code:this.meta.emailCode,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw s.formatApiError(e)}}async link(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new s.PrivyClientError("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(s.passwordlessLinkPath,{email:this.meta.email,code:this.meta.emailCode})}catch(e){throw s.formatApiError(e)}}async sendCodeEmail({email:e,captchaToken:t,withPrivyUi:r}){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(e&&(this.meta.email=e),t&&(this.meta.captchaToken=t),!this.meta.email)throw new s.PrivyClientError("Email must be set when initialzing authentication.");let n=Ee(r);try{return await this.api.post(s.passwordlessInitPath,{email:this.meta.email,token:this.meta.captchaToken},{headers:{...n}})}catch(e){throw s.formatApiError(e)}}constructor({email:e,captchaToken:t,disableSignup:r}){this.meta={email:e,captchaToken:t,disableSignup:r??!1}}}class Pe extends Ae{async link(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode||!this.meta.oldAddress)throw new s.PrivyClientError("Email, email code, and an old email address must be set prior to calling update.");try{return await this.api.post(s.updateEmailPath,{oldAddress:this.meta.oldAddress,newAddress:this.meta.email,code:this.meta.emailCode})}catch(e){throw s.formatApiError(e)}}constructor(e,t,r){super({email:t,captchaToken:r}),this.meta={email:t,captchaToken:r,oldAddress:e,disableSignup:!1}}}class ke{get meta(){return this._meta}async authenticate(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.channelToken)throw new s.PrivyClientError("Auth flow must be initialized first");try{let e=await this.api.post(s.farcasterAuthenticatePath,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"});if(!e)throw new s.PrivyClientError("No response from authentication");return e}catch(e){throw s.formatApiError(e)}}async link(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");try{return await this.api.post(s.farcasterLinkPath,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid})}catch(e){throw s.formatApiError(e)}}async _startChannelOnce(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");let e=await this.api.post(s.farcasterInitPath,{token:this.captchaToken});n.isMobile&&!n.isIOS&&e.connect_uri&&l.openHref(e.connect_uri,"_blank"),this._meta={...this._meta,connectUri:e.connect_uri,channelToken:e.channel_token}}async initializeFarcasterConnect(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");await this.startChannelOnce.execute()}async _pollForReady(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.channelToken)throw new s.PrivyClientError("Auth flow must be initialized first");let e=await this.api.get(s.farcasterStatusPath,{headers:{"farcaster-channel-token":this.meta.channelToken}});return"completed"===e.state&&(this.message=e.message,this.signature=e.signature,this.fid=e.fid,!0)}constructor(e,t=!1){this._meta={disableSignup:!1},this.captchaToken=e,this.startChannelOnce=new l.RunEffectOnce(this._startChannelOnce.bind(this)),this.pollForReady=new l.RunEffectOnce(this._pollForReady.bind(this)),this._meta.disableSignup=t}}function Te(){return"undefined"!=typeof window&&"chrome-extension:"===window.location.protocol&&"chrome"in window}function xe(){if(!Te())return;let e=window.chrome;return e?.runtime?.id}function be(){if(!Te())return!1;let e=window.chrome;return"function"==typeof e?.identity?.launchWebAuthFlow}async function Se(e){return new Promise(((t,r)=>{be()?window.chrome.identity.launchWebAuthFlow({url:e,interactive:!0},(async e=>{try{let r=function(){if(!Te())return;let e=window.chrome;return e?.runtime?.lastError?.message}();if(r||!e){let e=`WebAuthFlow failed: ${r||"Response URI missing"}`;throw Error(e)}let n=new URL(e),i=xe();if(!i)throw Error("Invalid extension context");if("chrome-extension:"===n.protocol){if(n.hostname!==i)throw Error("Invalid responseUri origin")}else{if("https:"!==n.protocol)throw Error("Invalid responseUri protocol");{let e=n.hostname.split(".");if(3!==e.length||"chromiumapp"!==e[1]||"org"!==e[2]||e[0]!==i)throw Error("Invalid responseUri origin")}}let a=n.searchParams.get("privy_oauth_state"),o=n.searchParams.get("privy_oauth_code");if(!a||!o)throw Error("Invalid responseUri - missing required parameters");t({privyOAuthState:a,privyOAuthCode:o})}catch(e){r(e)}})):r(Error("Chrome identity API not available"))}))}class _e{addCaptchaToken(e){this.meta.captchaToken=e}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new s.PrivyClientError("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if("undefined"===this.meta.authorizationCode)throw new s.PrivyClientError("User denied confirmation during OAuth flow");let e=l.getCodeVerifier();try{let t=await this.api.post(s.oAuthAuthenticatePath,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:e,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"});return l.p.del(y.CODE_VERIFIER_KEY),l.p.del(y.HEADLESS_OAUTH_KEY),l.p.del(y.OAUTH_DISABLE_SIGNUP_KEY),t}catch(e){let t=s.formatApiError(e);if(t.privyErrorCode)throw new s.PrivyClientError(t.message||"Invalid code during OAuth flow.",void 0,t.privyErrorCode);if("User denied confirmation during OAuth flow"===t.message)throw new s.PrivyClientError("Invalid code during oauth flow.",void 0,s.PrivyErrorCode.OAUTH_USER_DENIED);throw new s.PrivyClientError("Invalid code during OAuth flow.",void 0,s.PrivyErrorCode.UNKNOWN_AUTH_ERROR)}}async link(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new s.PrivyClientError("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if("undefined"===this.meta.authorizationCode)throw new s.PrivyClientError("User denied confirmation during OAuth flow");let e=l.p.get(y.CODE_VERIFIER_KEY);if(!e)throw new s.PrivyClientError("Authentication error.");try{let t=await this.api.post(s.oAuthLinkPath,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:e});return l.p.del(y.CODE_VERIFIER_KEY),t}catch(e){throw s.formatApiError(e)}}async getAuthorizationUrl(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.provider)throw new s.PrivyClientError("Provider must be set when initializing OAuth authentication.");let e=l.createCodeVerifier();l.p.put(y.CODE_VERIFIER_KEY,e);let t=l.createStateCode();l.p.put(y.STATE_CODE_KEY,t);let r=await l.deriveCodeChallengeFromCodeVerifier(e);this.meta.withPrivyUi||l.p.put(y.HEADLESS_OAUTH_KEY,!0),this.meta.disableSignup?l.p.put(y.OAUTH_DISABLE_SIGNUP_KEY,!0):l.p.del(y.OAUTH_DISABLE_SIGNUP_KEY);let n=Ee(this.meta.withPrivyUi),i=window.location.href,a=function(){let e=xe();if(e)return`https://${e}.chromiumapp.org`}();a&&(i=a);try{return await this.api.post(s.oAuthInitPath,{provider:this.meta.provider,redirect_to:this.meta.customOAuthRedirectUrl||i,token:this.meta.captchaToken,code_challenge:r,state_code:t},{headers:{...n}})}catch(e){throw s.formatApiError(e)}}constructor(e){this.meta=e}}const Ie=({style:t})=>/*#__PURE__*/e.jsx(Ce.default,{style:{color:"var(--privy-color-error)",...t}});let Ue={google:{name:"Google",component:l.Google},discord:{name:"Discord",component:l.Discord},github:{name:"Github",component:l.Github},linkedin:{name:"LinkedIn",component:l.LinkedIn},twitter:{name:"Twitter",component:l.Twitter},spotify:{name:"Spotify",component:l.Spotify},instagram:{name:"Instagram",component:l.Instagram},tiktok:{name:"Tiktok",component:l.Tiktok},line:{name:"LINE",component:l.Line},twitch:{name:"Twitch",component:l.Twitch},apple:{name:"Apple",component:l.Apple}},We=({iconUrl:e,...t})=>Q.default.createElement("svg",{width:"33",height:"32",viewBox:"0 0 33 32",fill:"none",xmlns:"http://www.w3.org/2000/svg",...t},Q.default.createElement("foreignObject",{x:"2",y:"2",width:"29",height:"28"},Q.default.createElement("img",{src:e,width:"29",height:"28",style:{display:"block",objectFit:"contain",borderRadius:"4px"},alt:"Provider icon"})));const Re=(e,t)=>{if(e in Ue)return Ue[e];if(l.isCustomOAuthProvider(e)&&t){let r=t.find((t=>t.provider===e));if(r)return{name:r.provider_display_name,component:e=>Q.default.createElement(We,{...e,iconUrl:r.provider_icon_url})}}return{name:"Unknown",component:Ie}};function Ne(){let e=new URLSearchParams(window.location.search),t=e.get("privy_oauth_code"),r=e.get("privy_oauth_state"),n=e.get("privy_oauth_provider");if(!t||!r||!n)return{inProgress:!1};let i=!1;try{i=!!window.opener.location.origin}catch{}return{inProgress:!0,authorizationCode:t,stateCode:r,provider:n,withPrivyUi:!l.p.get(y.HEADLESS_OAUTH_KEY),popupFlow:null!==window.opener&&i,disableSignup:!!l.p.get(y.OAUTH_DISABLE_SIGNUP_KEY)}}class Oe{async initRegisterFlow(e){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");this.authenticateForRegistration=!0,this.meta.initRegisterResponse=await this.initRegisterOnce.execute(e)}async initAuthenticationFlow(e){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");this.authenticateForRegistration=!1,this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute(e)}async initLinkFlow(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");this.meta.initLinkResponse=await this.initLinkOnce.execute()}async register(){let e=await import("@simplewebauthn/browser");if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new s.PrivyClientError("WebAuthn is not supported in this browser");this.meta.initRegisterResponse||(this.meta.initRegisterResponse=await this.initRegisterOnce.execute());try{let t=this.meta.initRegisterResponse.options,r=await e.startRegistration({optionsJSON:this._transformInitLinkOptionsToCamelCase(t)});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(s.passkeyRegisterPath,{relying_party:this.meta.initRegisterResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(r)})}catch(e){if("NotAllowedError"===e.name)throw new s.PrivyClientError("Passkey request timed out or rejected by user.",void 0,s.PrivyErrorCode.PASSKEY_NOT_ALLOWED);throw s.formatApiError(e)}}async authenticate(){if(this.authenticateForRegistration)return this.register();let e=await import("@simplewebauthn/browser");if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new s.PrivyClientError("WebAuthn is not supported in this browser");this.meta.initAuthenticateResponse||(this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute());let t=this.meta.allowedCredentialsIds?.map((e=>({type:"public-key",id:e})))??this.meta.initAuthenticateResponse.options.allow_credentials;try{let r=await e.startAuthentication({optionsJSON:this._transformInitAuthenticateOptionsToCamelCase({...this.meta.initAuthenticateResponse.options,allow_credentials:t})});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(s.passkeyAuthenticatePath,{relying_party:this.meta.initAuthenticateResponse.relying_party,challenge:this.meta.initAuthenticateResponse.options.challenge,authenticator_response:this._transformAuthenticationResponseToSnakeCase(r)})}catch(e){if("NotAllowedError"===e.name)throw new s.PrivyClientError("Passkey request timed out or rejected by user.",void 0,s.PrivyErrorCode.PASSKEY_NOT_ALLOWED);throw s.formatApiError(e)}}async link(){let e=await import("@simplewebauthn/browser");if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new s.PrivyClientError("WebAuthn is not supported in this browser");this.meta.initLinkResponse||(this.meta.initLinkResponse=await this.initLinkOnce.execute());try{let t=this.meta.initLinkResponse.options,r=await e.startRegistration({optionsJSON:this._transformInitLinkOptionsToCamelCase(t)});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(s.passkeyLinkPath,{relying_party:this.meta.initLinkResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(r)})}catch(e){if("NotAllowedError"===e.name)throw new s.PrivyClientError("Passkey request timed out or rejected by user.",void 0,s.PrivyErrorCode.PASSKEY_NOT_ALLOWED);throw s.formatApiError(e)}}async _initRegisterOnce(e){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");let t=Ee(e);return await this.api.post(s.passkeyInitRegisterPath,{token:this.meta.captchaToken},{headers:{...t}})}async _initAuthenticateOnce(e){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");let t=Ee(e);return await this.api.post(s.passkeyInitAuthenticatePath,{token:this.meta.captchaToken},{headers:{...t}})}async _initLinkOnce(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");return await this.api.post(s.passkeyInitLinkPath,{})}_transformInitLinkOptionsToCamelCase(e){return{rp:e.rp,user:{id:e.user.id,name:e.user.name,displayName:e.user.display_name},challenge:e.challenge,pubKeyCredParams:e.pub_key_cred_params.map((e=>({type:e.type,alg:e.alg}))),timeout:e.timeout,excludeCredentials:e.exclude_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports}))),authenticatorSelection:{authenticatorAttachment:e.authenticator_selection?.authenticator_attachment,requireResidentKey:e.authenticator_selection?.require_resident_key,residentKey:e.authenticator_selection?.resident_key,userVerification:e.authenticator_selection?.user_verification},attestation:e.attestation,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props?.rk,hmacCreateSecret:e.extensions?.hmac_create_secret},hints:this.meta.hints}}_transformRegistrationResponseToSnakeCase(e){return{id:e.id,raw_id:e.rawId,response:{client_data_json:e.response.clientDataJSON,attestation_object:e.response.attestationObject,authenticator_data:e.response.authenticatorData},authenticator_attachment:e.authenticatorAttachment,client_extension_results:{app_id:e.clientExtensionResults.appid,cred_props:e.clientExtensionResults.credProps,hmac_create_secret:e.clientExtensionResults.hmacCreateSecret},type:e.type}}_transformInitAuthenticateOptionsToCamelCase(e){return{rpId:e.rp_id,challenge:e.challenge,allowCredentials:e.allow_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports})))||[],timeout:e.timeout,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props,hmacCreateSecret:e.extensions?.hmac_create_secret},userVerification:e.user_verification}}_transformAuthenticationResponseToSnakeCase(e){return{id:e.id,raw_id:e.rawId,response:{client_data_json:e.response.clientDataJSON,authenticator_data:e.response.authenticatorData,signature:e.response.signature,user_handle:e.response.userHandle},authenticator_attachment:e.authenticatorAttachment,client_extension_results:{app_id:e.clientExtensionResults.appid,cred_props:e.clientExtensionResults.credProps,hmac_create_secret:e.clientExtensionResults.hmacCreateSecret},type:e.type}}constructor({captchaToken:e,setPasskeyAuthState:t,hints:r}){this.authenticateForRegistration=!1,this.initRegisterOnce=new l.RunEffectOnce(this._initRegisterOnce.bind(this)),this.initAuthenticateOnce=new l.RunEffectOnce(this._initAuthenticateOnce.bind(this)),this.initLinkOnce=new l.RunEffectOnce(this._initLinkOnce.bind(this)),this.meta={captchaToken:e,setPasskeyAuthState:t,hints:r}}}class Me{async authenticate(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new s.PrivyClientError("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(s.passwordlessSmsAuthenticatePath,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw s.formatApiError(e)}}async link(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new s.PrivyClientError("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(s.passwordlessSmsLinkPath,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(e){throw s.formatApiError(e)}}async sendSmsCode({phoneNumber:e,captchaToken:t,withPrivyUi:r}){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),t&&(this.meta.captchaToken=t),!this.meta.phoneNumber)throw new s.PrivyClientError("phone nNumber must be set when initialzing authentication.");let n=Ee(r);try{return await this.api.post(s.passwordlessSmsInitPath,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken},{headers:{...n}})}catch(e){throw s.formatApiError(e)}}constructor({phoneNumber:e,captchaToken:t,disableSignup:r}){this.meta={phoneNumber:e,captchaToken:t,disableSignup:r??!1}}}class je extends Me{async link(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode||!this.meta.oldPhoneNumber)throw new s.PrivyClientError("Phone number, sms code, and an old phone number must be set prior to calling update.");try{return await this.api.post(s.updatePhonePath,{old_phone_number:this.meta.oldPhoneNumber,new_phone_number:this.meta.phoneNumber,code:this.meta.smsCode})}catch(e){throw s.formatApiError(e)}}constructor(e,t,r){super({phoneNumber:t,captchaToken:r}),this.meta={phoneNumber:t,captchaToken:r,oldPhoneNumber:e,disableSignup:!1}}}class Fe{static parse(e){try{return new Fe(e)}catch(e){return null}}static throwIfNotWellFormedJwt(e){return te.decodeJwt(e),e}get subject(){return this._decoded.sub}get expiration(){return this._decoded.exp}get issuer(){return this._decoded.iss}get audience(){return this._decoded.aud}isExpired(e=0){return Date.now()>=1e3*(this.expiration-e)}constructor(e){this.value=e,this._decoded=te.decodeJwt(e)}}class Le extends Fe{static parse(e){try{return new Le(e)}catch(e){return null}}get appId(){return this._decoded.aid?this._decoded.aid:this.audience}}let De,qe;class Be extends l.EthereumWalletConnector{async initialize(){await this.importPromise,await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){this.proxyProvider.walletProvider.disconnect(),this.onDisconnect()}get walletBranding(){return{name:this.displayName,icon:l.BASE_ACCOUNT_DATA_URI,id:"com.coinbase.wallet"}}async promptConnection(){try{await this.importPromise;let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new s.PrivyConnectorError("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([e[0]])}catch(e){throw l.formatConnectorError(e)}}constructor(e,t,r,n,i){super("base_account",e,t,r),this.connectorType="base_account",this.walletClientType="base_account",this.displayName="Base",this.setBaseAccountSdk=i,this.proxyProvider=new l.PrivyProxyProvider(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.baseAccountConfig={...n,appChainIds:[t.id].concat(e.map((e=>e.id)))},De?(this.proxyProvider.setWalletProvider(De.getProvider()),this.setBaseAccountSdk(De),console.log("Base Account SDK Initialized")):this.importPromise=import("@base-org/account").then((({createBaseAccountSDK:e})=>{De=e(this.baseAccountConfig),this.proxyProvider.setWalletProvider(De.getProvider()),this.setBaseAccountSdk(De),console.log("Base Account SDK Initialized")})).catch(console.error)}}let He=[1,11155111,137,10,8453,84532,42161,7777777,43114,56];class ze extends l.EthereumWalletConnector{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){this.proxyProvider.walletProvider.disconnect(),this.onDisconnect()}get walletBranding(){return{name:this.displayName,icon:l.COINBASE_WALLET_DATA_URI,id:"com.coinbase.wallet"}}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new s.PrivyConnectorError("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([e[0]])}catch(e){throw l.formatConnectorError(e)}}updateConnectionPreference(e){this.coinbaseWalletConfig={...this.coinbaseWalletConfig,preference:{...this.coinbaseWalletConfig.preference,options:e}},this.walletClientType="smartWalletOnly"===e?"coinbase_smart_wallet":"coinbase_wallet",qe=h.createCoinbaseWalletSDK({...this.coinbaseWalletConfig}),this.proxyProvider.setWalletProvider(qe.getProvider())}constructor(e,t,r,n){if(super("coinbase_wallet",e,t,r),this.connectorType="coinbase_wallet",this.displayName="Coinbase Wallet",this.proxyProvider=new l.PrivyProxyProvider(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.coinbaseWalletConfig={...n,appChainIds:[t.id].concat(e.map((e=>e.id)))},this.walletClientType="smartWalletOnly"===this.coinbaseWalletConfig.preference?.options?"coinbase_smart_wallet":"coinbase_wallet","coinbase_smart_wallet"===this.walletClientType&&(this.displayName="Coinbase Smart Wallet"),!qe){let e="eoaOnly"!==this.coinbaseWalletConfig.preference?.options?(this.coinbaseWalletConfig.appChainIds??[]).filter((e=>!He.includes(e))):[];e.length>0&&!e.every((e=>a.DEFAULT_SUPPORTED_CHAIN_IDS.has(e)))&&console.info(`The configured chains are not supported by Coinbase Smart Wallet: ${e.join(", ")}`),qe=h.createCoinbaseWalletSDK(this.coinbaseWalletConfig)}this.proxyProvider.setWalletProvider(qe.getProvider())}}class Ke extends l.EthereumWalletConnector{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[l.toHex(e?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:l.Blobby,id:"io.privy.wallet"}}disconnect(){this.connected=!1}async promptConnection(){}constructor({provider:e,chains:t,defaultChain:r,rpcConfig:n,imported:i,walletIndex:a}){super("privy",t,r,n),this.connectorType="embedded",this.proxyProvider=e,this.walletIndex=a,i&&(this.connectorType="embedded_imported"),this.subscribeListeners()}}const Ve=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4","csw_signUserOperation","secp256k1_sign"];class $e extends Error{constructor(e,t,r){super(e),this.code=t,this.data=r}}class Ye extends re.default{async handleSendTransaction(e){if(!e.params||!Array.isArray(e.params))throw new $e(`Invalid params for ${e.method}`,4200);let t=e.params[0];if(!await mi()||!this.address)throw new $e("Disconnected",4900);let{hash:r}=await fi(t,{address:this.address});return r}async handleSignTransaction(e){if(!e.params||!Array.isArray(e.params))throw new $e(`Invalid params for ${e.method}`,4200);let t=e.params[0];if(!await mi()||!this.address)throw new $e("Disconnected",4900);let{signature:r}=await vi(t,{address:this.address});return r}handleSwitchEthereumChain(e){let t;if(!e.params||!Array.isArray(e.params))throw new $e(`Invalid params for ${e.method}`,4200);if("string"==typeof e.params[0])t=e.params[0];else{if(!("chainId"in e.params[0])||"string"!=typeof e.params[0].chainId)throw new $e(`Invalid params for ${e.method}`,4200);t=e.params[0].chainId}this.chainId=Number(t),this.publicClient=l.getPublicClient(this.chainId,this.chains,this.rpcConfig,{appId:this.appId}),this.emit("chainChanged",t)}async handlePersonalSign(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for personal_sign");let t=e.params[0],r=e.params[1],{signature:n}=await wi({message:t},{address:r});return n}async handleSignedTypedData(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for eth_signTypedData_v4");let t=e.params[0],r="string"==typeof e.params[1]?JSON.parse(e.params[1]):e.params[1],{signature:n}=await gi(l.generateTypedDataWithDomainType(r),{address:t});return n}async handleEstimateGas(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for eth_estimateGas");delete e.params[0].gasPrice,delete e.params[0].maxFeePerGas,delete e.params[0].maxPriorityFeePerGas;let t={...e.params[0],chainId:l.toHex(this.chainId)};return await this.publicClient.estimateGas({account:t.from??this.address,...p.toViemTransactionSerializable(t)})}async request(e){switch(console.debug("Embedded1193Provider.request() called with args",e),e.method){case"eth_accounts":case"eth_requestAccounts":return this.address?[this.address]:[];case"eth_chainId":return l.toHex(this.chainId);case"eth_estimateGas":return this.handleEstimateGas(e);case"eth_sendTransaction":return this.handleSendTransaction(e);case"eth_signTransaction":return this.handleSignTransaction(e);case"wallet_switchEthereumChain":return this.handleSwitchEthereumChain(e);case"personal_sign":return this.handlePersonalSign(e);case"eth_signTypedData_v4":return this.handleSignedTypedData(e)}if(!(e=>Ve.includes(e))(e.method))return this.publicClient.request({method:e.method,params:e.params});{let t=await mi();if(await Ci({address:this.address}),!t||!this.address)throw new $e("Disconnected",4900);try{let r={method:e.method,params:e.params},n=this.walletAccount;return n&&l.getIsUnifiedWallet(n)?this.handleWalletApiRequest(r,n,t):(await this.walletProxy.rpc({accessToken:t,entropyId:this.entropyId,entropyIdVerifier:this.entropyIdVerifier,chainType:"ethereum",hdWalletIndex:this.walletIndex,request:r})).response.data}catch(e){throw console.error(e),new $e("Disconnected",4900)}}}async handleWalletApiRequest(e,t,r){let n=this.privyClient;if(!n)throw new $e("Disconnected",4900);if("secp256k1_sign"===e.method){let i=await a.rpc(n,(async({message:e})=>this.walletProxy.signWithUserSigner({accessToken:r,message:e})),{chain_type:"ethereum",method:"secp256k1_sign",wallet_id:t.id,params:{hash:e.params[0]}});if("secp256k1_sign"!==i.method)throw new $e(`Invalid params for ${e.method}`,4200);return i.data.signature}throw new $e(`Method not supported: ${e.method}`,4200)}constructor({walletProxy:e,address:t,entropyId:r,entropyIdVerifier:n,rpcConfig:i,chains:a,appId:o,chainId:s=1,walletIndex:c,privyClient:d,walletAccount:u}){super(),this.walletProxy=e,this.address=t,this.entropyId=r,this.entropyIdVerifier=n,this.chainId=s,this.rpcConfig=i,this.chains=a,this.publicClient=l.getPublicClient(s,this.chains,i,{appId:o}),this.rpcTimeoutDuration=l.getRpcTimeout(i,"privy"),this.appId=o,this.walletIndex=c,this.privyClient=d,this.walletAccount=u}}function Ge(e,t){if(!Object.prototype.hasOwnProperty.call(e,t))throw TypeError("attempted to use private field on non-instance");return e}var Ze=0;class Je extends l.EthereumWalletConnector{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return{name:this.providerDetail.info.name,icon:this.providerDetail.info.icon,id:this.providerDetail.info.rdns}}disconnect(){console.warn(`Programmatic disconnect with ${this.providerDetail.info.name} is not yet supported.`)}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new s.PrivyConnectorError("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw l.formatConnectorError(e)}}constructor(e,t,r,n,i){super(i||"unknown",e,t,r),this.connectorType="injected",this.proxyProvider=new l.PrivyProxyProvider(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=n;let a=n.provider;this.proxyProvider.setWalletProvider(a)}}var Xe="__private_"+Ze+++"__walletBranding";class Qe extends l.EthereumWalletConnector{async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return Ge(this,Xe)[Xe]??{name:"Browser Extension",icon:l.BrowserExtensionWallet,id:"extension"}}disconnect(){console.warn("Programmatic disconnect with browser wallets is not yet supported.")}async promptConnection(){try{let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new s.PrivyConnectorError("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw l.formatConnectorError(e)}}constructor(e,t,r,n,i){super(i??"unknown",e,t,r),Object.defineProperty(this,Xe,{writable:!0,value:void 0}),this.connectorType="injected",this.proxyProvider=new l.PrivyProxyProvider(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(n),"metamask"===i?Ge(this,Xe)[Xe]={name:"MetaMask",icon:l.Metamask,id:"io.metamask"}:"phantom"===i&&(Ge(this,Xe)[Xe]={name:"Phantom",icon:l.Phantom,id:"phantom"})}}class et extends Je{disconnect(){console.warn("MetaMask does not support programmatic disconnect.")}async promptConnection(){try{n.isMobile||await this.proxyProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]});let e=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!e||0===e.length||!e[0])throw new s.PrivyConnectorError("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw l.formatConnectorError(e)}}}class tt extends re.default{get wallets(){let e=new Set;return this.walletConnectors.flatMap((e=>e.wallets)).sort(((e,t)=>e.connectedAt&&t.connectedAt?t.connectedAt-e.connectedAt:0)).filter((t=>{let r=`${t.address}${t.walletClientType}${t.connectorType}${t.meta.id}`;return!e.has(r)&&(e.add(r),!0)}))}async initialize(e){if(this.initialized&&!e||(e&&this.removeAllConnectors(),this.externalWalletConfig.disableAllExternalWallets))return;let t=l.detectInjectedConnectors({store:this.store,walletList:this.walletList,externalWalletConfig:this.externalWalletConfig,walletChainType:this.walletChainType}).then((e=>{e.forEach((({type:e,eip6963InjectedProvider:t,legacyInjectedProvider:r})=>{this.createEthereumWalletConnector({connectorType:"injected",walletClientType:e,providers:{eip6963InjectedProvider:t,legacyInjectedProvider:r}})}))}));for(let e of(this.walletList.includes("coinbase_wallet")&&this.createEthereumWalletConnector({connectorType:"coinbase_wallet",walletClientType:"coinbase_wallet"}),this.walletList.includes("base_account")&&this.createEthereumWalletConnector({connectorType:"base_account",walletClientType:"base_account"}),Object.values(l.mobileWalletsConfig)))!e.isInstalled&&this.walletList.includes(e.client)&&(["ethereum-only","ethereum-and-solana"].includes(this.walletChainType)&&e.chainTypes.includes("ethereum")&&this.createEthereumWalletConnector({connectorType:"null",walletClientType:e.client,walletConfig:e}),["ethereum-and-solana","solana-only"].includes(this.walletChainType)&&e.chainTypes.includes("solana")&&this.addSolanaWalletConnector(new l.SolanaNullConnector({id:e.client,name:e.name})));this.externalWalletConfig.walletConnect.enabled&&(this.walletList.includes("wallet_connect_qr")||l.shouldFetchWcRegistryListings(this.walletList))&&"solana-only"!==this.walletChainType&&this.createEthereumWalletConnector({connectorType:"wallet_connect_v2",walletClientType:"unknown"});let r=this.walletList.includes("wallet_connect_qr_solana"),n=this.externalWalletConfig.solana.connectors?.get()||[],i=async e=>{if(!r)return;let t=e.find((e=>"walletconnect_solana"===e.walletBranding?.id));t&&t.wallet&&await t.wallet.initialize({walletConnectCloudProjectId:this.walletConnectCloudProjectId,privyAppName:this.privyAppName})};i(n),n.filter((e=>r||"walletconnect_solana"!==e.walletBranding?.id)).forEach(this.addSolanaWalletConnector),this.externalWalletConfig.solana.connectors?._setOnConnectorsUpdated?.((e=>{i(e),e?.filter((e=>r||"walletconnect_solana"!==e.walletBranding?.id)).forEach(this.addSolanaWalletConnector)})),await t,this.initialized=!0}findWalletConnector(e,t,r){return"wallet_connect_v2"===e?this.walletConnectors.filter(l.isEthereumWalletConnector).find((t=>t.connectorType===e&&(!r||t.wallets.some((e=>e.address===r)))))??null:this.walletConnectors.filter(l.isEthereumWalletConnector).find((n=>n.connectorType===e&&n.walletClientType===t&&(!r||n.wallets.some((e=>e.address===r)))))??null}findSolanaWalletConnector(e){return this.walletConnectors.filter(l.isSolanaWalletConnector).find((t=>"unknown"===t.walletClientType?t.walletBranding.id===e:t.walletClientType===e))??null}findEmbeddedWalletConnectors(){return this.walletConnectors.filter((e=>"embedded"===e.connectorType))}findImportedWalletConnectors(){return this.walletConnectors.filter((e=>"embedded_imported"===e.connectorType))}onInitialized(e){e.wallets.forEach((e=>{let t=this.storedConnections.find((t=>t.address===e.address&&t.connectorType===e.connectorType&&("solana"===e.type&&"unknown"===t.walletClientType&&"unknown"===e.walletClientType?e.meta.id===t.id:t.walletClientType===e.walletClientType)));t&&(e.connectedAt=t.connectedAt)})),this.emit("walletsUpdated"),this.emit("connectorInitialized")}onWalletsUpdated(e){e.initialized&&this.emit("walletsUpdated")}addEmbeddedWalletConnectors({walletProxy:e,user:t,embeddedWallets:r,defaultChain:n,appId:i,privyClient:a}){let{entropyId:o,entropyIdVerifier:s}=l.getEntropyDetailsForUser(t);for(let t of r){let r=this.findEmbeddedWalletConnectors().find((e=>e.walletIndex===t.walletIndex));if(r&&l.isEthereumWalletConnector(r))r.proxyProvider.walletProxy=e;else{let r=new Ke({provider:new Ye({walletProxy:e,address:t.address,entropyId:o,entropyIdVerifier:s,rpcConfig:this.rpcConfig,chains:this.chains,appId:i,chainId:n.id,walletIndex:t.walletIndex,privyClient:a,walletAccount:t}),chains:this.chains,defaultChain:n,rpcConfig:this.rpcConfig,imported:!1,walletIndex:t.walletIndex});this.addWalletConnector(r)}}}addImportedWalletConnector(e,t,r,n){let i=this.findWalletConnector("embedded_imported","privy",t);if(i&&l.isEthereumWalletConnector(i))i.proxyProvider.walletProxy=e;else{let i=new Ke({provider:new Ye({walletProxy:e,address:t,entropyId:t,entropyIdVerifier:"ethereum-address-verifier",walletIndex:0,rpcConfig:this.rpcConfig,chains:this.chains,appId:n,chainId:r.id}),chains:this.chains,walletIndex:0,defaultChain:r,rpcConfig:this.rpcConfig,imported:!0});this.addWalletConnector(i)}}removeEmbeddedWalletConnectors(){this.walletConnectors=this.walletConnectors.filter((e=>"embedded"!==e.connectorType)),this.storedConnections=l.loadConnectionHistory(),this.emit("walletsUpdated")}removeImportedWalletConnectors(){let e=this.findImportedWalletConnectors();e.length&&(e.forEach((e=>{let t=this.walletConnectors.indexOf(e);this.walletConnectors.splice(t,1)})),this.storedConnections=l.loadConnectionHistory(),this.emit("walletsUpdated"))}async createEthereumWalletConnector({connectorType:e,walletClientType:t,providers:r,walletConfig:n}){let i=this.findWalletConnector(e,t);if(i&&l.isEthereumWalletConnector(i))return i instanceof l.WalletConnectV2WalletConnector&&i.resetConnection(t),i;let a=(()=>"injected"!==e?"coinbase_wallet"===e?new ze(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig.coinbaseWallet.config):"base_account"===e?new Be(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig.baseAccount.config,this.setBaseAccountSdk):"null"!==e?new l.WalletConnectV2WalletConnector({walletConnectCloudProjectId:this.walletConnectCloudProjectId,rpcConfig:this.rpcConfig,chains:this.chains,defaultChain:this.defaultChain,shouldEnforceDefaultChainOnConnect:this.shouldEnforceDefaultChainOnConnect,privyAppId:this.privyAppId,privyAppName:this.privyAppName,walletClientType:t}):n?new l.EthereumNullConnector({id:n.client,name:n.name,defaultChain:this.defaultChain,walletClientType:n.client}):null:"metamask"===t&&r?.eip6963InjectedProvider?new et(this.chains,this.defaultChain,this.rpcConfig,r?.eip6963InjectedProvider,"metamask"):"metamask"===t&&r?.legacyInjectedProvider?new Qe(this.chains,this.defaultChain,this.rpcConfig,r?.legacyInjectedProvider,"metamask"):"phantom"===t&&r?.legacyInjectedProvider?new Qe(this.chains,this.defaultChain,this.rpcConfig,r?.legacyInjectedProvider,"phantom"):r?.legacyInjectedProvider&&"unknown_browser_extension"===t?new Qe(this.chains,this.defaultChain,this.rpcConfig,r?.legacyInjectedProvider):r?.eip6963InjectedProvider?new Je(this.chains,this.defaultChain,this.rpcConfig,r?.eip6963InjectedProvider,t):void 0)();return a&&this.addWalletConnector(a),a||null}addWalletConnector(e){this.walletConnectors.push(e),e.on("initialized",(()=>this.onInitialized(e))),e.on("walletsUpdated",(()=>this.onWalletsUpdated(e))),e.initialize().catch((e=>{console.debug("Failed to initialize connector",e)}))}setWalletList(e){this.walletList=e,this.initialized&&this.initialize(!0).catch(console.error)}removeAllConnectors(){for(let e of this.walletConnectors)e.removeAllListeners();this.walletConnectors=[]}constructor(e,t,r,n,i,a,o,s,c,d,u,h){super(),this.addSolanaWalletConnector=async e=>{let t=this.findSolanaWalletConnector(e.walletClientType);if(!t||"null"===t.connectorType){if("null"===t?.connectorType){let e=this.walletConnectors.indexOf(t);this.walletConnectors.splice(e,1)}this.addWalletConnector(e)}},this.privyAppId=e,this.walletConnectCloudProjectId=t,this.rpcConfig=r,this.chains=n,this.defaultChain=i,this.walletConnectors=[],this.initialized=!1,this.store=a,this.walletList=o,this.shouldEnforceDefaultChainOnConnect=s,this.externalWalletConfig=c,this.privyAppName=d,this.walletChainType=h||"ethereum-only",this.setBaseAccountSdk=u,this.storedConnections=l.loadConnectionHistory()}}let rt=[s.sessionsRefreshPath,s.sessionsLogoutPath,s.analyticsEventsPath];class nt{async get(e,t){try{return await this.baseFetch(e,t)}catch(e){throw s.formatApiError(e)}}async post(e,t,r){try{return await this.baseFetch(e,{method:"POST",...t?{body:t}:{},...r})}catch(e){throw s.formatApiError(e)}}async delete(e,t){try{return await this.baseFetch(e,{method:"DELETE",...t})}catch(e){throw s.formatApiError(e)}}constructor({appId:e,appClientId:t,client:r,defaults:n}){this.appId=e,this.appClientId=t,this.clientAnalyticsId=r.clientAnalyticsId,this.sdkVersion=y.VERSION,this.client=r,this.defaults=n,this.fallbackApiUrl=r.fallbackApiUrl,this.baseFetch=m.ofetch.create({baseURL:this.defaults.baseURL,timeout:this.defaults.timeout,retry:3,retryDelay:500,retryStatusCodes:[408,409,425,500,502,503,504],credentials:"include",onRequest:async({request:e,options:t})=>{let r=new Headers(t.headers);r.set("privy-app-id",this.appId),this.appClientId&&r.set("privy-client-id",this.appClientId),r.set("privy-ca-id",this.clientAnalyticsId||""),r.set("privy-client",`react-auth:${this.sdkVersion}`);let n=rt.includes(e.toString());if(!r.has("authorization")){let e=await this.client.getAccessToken({disableAutoRefresh:n});null!==e&&r.set("authorization",`Bearer ${e}`)}t.headers=r,t.retryDelay&&"number"==typeof t.retryDelay&&(t.retryDelay=3*t.retryDelay)},onRequestError:({error:e})=>{if(e instanceof DOMException&&"AbortError"===e.name)throw new s.PrivyTimeoutError}})}}let it=/paymaster\.biconomy\.io\/api/i,at={mode:"SPONSORED",calculateGasLimits:!0,expiryDuration:300,sponsorshipInfo:{webhookData:{},smartAccountInfo:{name:"BICONOMY",version:"2.0.0"}}};const ot=(e,t)=>e&&it.test(e)?at:t&&t.policy_id?{policyId:t.policy_id}:void 0,st=e=>({rpId:e.rp_id,challenge:e.challenge,allowCredentials:e.allow_credentials?.map((e=>({id:e.id,type:e.type,transports:e.transports})))||[],timeout:e.timeout,extensions:{appid:e.extensions?.app_id,credProps:e.extensions?.cred_props,hmacCreateSecret:e.extensions?.hmac_create_secret},userVerification:e.user_verification});class lt{async authenticate(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");try{return await this.api.post(s.customJwtAccountAuthenticatePath,{token:this.meta.token})}catch(e){throw s.formatApiError(e)}}async link(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");try{return await this.api.post(s.customJwtAccountLinkPath,{token:this.meta.token})}catch(e){throw s.formatApiError(e)}}constructor(e){this.meta={token:e}}}class ct{getOrCreateGuestCredential(e){let t=y.getGuestCredentialStorageKey(e);if(l.e$1()){if(l.p.get(t))return l.p.get(t);{let e=d.base64url.encode(l.randomBytes(32));return l.p.put(t,e),e}}return d.base64url.encode(l.randomBytes(32))}async authenticate(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");try{return await this.api.post(s.guestAccountAuthenticatePath,{guest_credential:this.meta.guestCredential})}catch(e){throw s.formatApiError(e)}}async link(){throw Error("Linking is not supported for the guest flow")}constructor(e){this.meta={guestCredential:this.getOrCreateGuestCredential(e)}}}function dt(){return!(n.isSafari&&window.location.origin.startsWith("http://localhost"))}const ut=g.create((()=>({identityToken:null})));var ht,pt=((ht={}).PRIVY="privy_access_token",ht.CUSTOMER="customer_access_token",ht);class yt{get token(){return this.privyAccessToken||this.customerAccessToken}getToken(e){return"privy_access_token"===e?this.privyAccessToken:this.customerAccessToken}get customerAccessToken(){return this._getToken(y.CUSTOMER_ACCESS_TOKEN_STORAGE_KEY)}get privyAccessToken(){return this._getToken(y.PRIVY_ACCESS_TOKEN_STORAGE_KEY)}_getToken(e){try{let t=l.p.get(e);return"string"==typeof t?Fe.throwIfNotWellFormedJwt(t):null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=l.p.get(y.REFRESH_TOKEN_STORAGE_KEY);return"string"==typeof e?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}getProviderAccessToken(e){try{let t=l.p.get(y.getProviderAccessTokenStorageKey(e));if("string"!=typeof t)return null;{let r=new Fe(t);return r.isExpired()?(l.p.del(y.getProviderAccessTokenStorageKey(e)),null):r.value}}catch(e){return console.error(e),null}}get mightHaveServerCookies(){try{let e=ne.default.get(y.SESSION_COOKIE_KEY);return void 0!==e&&e.length>0}catch(e){console.error(e)}return!1}hasRefreshCredentials(e="privy_access_token"){let t="string"==typeof this.getToken(e),r="string"==typeof this.refreshToken&&this.refreshToken!==y.DEPRECATED_REFRESH_TOKEN;return this.mightHaveServerCookies||t&&r}hasActiveAccessToken(e){let t=Fe.parse(this.getToken(e));return null!==t&&!t.isExpired(30)}authenticate(e){return this.authenticateOnce.execute(e)}link(e){return this.linkOnce.execute(e)}refresh(){return this.refreshOnce.execute()}destroy(){return this.destroyOnce.execute()}storeProviderAccessToken(e,t){"string"==typeof t?l.p.put(y.getProviderAccessTokenStorageKey(e),t):l.p.del(y.getProviderAccessTokenStorageKey(e))}updateIdentityToken(e){"string"==typeof e?this.storeIdentityToken(e):this.clearIdentityToken()}async _authenticate(e){try{let t=await e.authenticate(),{user:r,is_new_user:n,oauth_tokens:i}=t;this.handleTokenResponse(t);let a=i?{provider:i.provider,accessToken:i.access_token,accessTokenExpiresInSeconds:i.access_token_expires_in_seconds,refreshToken:i.refresh_token,refreshTokenExpiresInSeconds:i.refresh_token_expires_in_seconds,scopes:i.scopes}:void 0;return this._trackAuthenticateEvents(e,n),{user:l.convertUserResponseToUser(r),isNewUser:n,oAuthTokens:a}}catch(e){throw console.warn("Error authenticating session"),s.formatPrivyError(e)}}_trackAuthenticateEvents(e,t){let r=function(e){return e instanceof Ae?"email":e instanceof Me?"sms":e instanceof l.SiweFlow?"siwe":e instanceof ct?"guest":e instanceof lt?"custom_auth":e instanceof _e?e.meta.provider:null}(e);r&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate",payload:{method:r,isNewUser:t}}),"siwe"===r&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate_siwe",payload:{connectorType:e.meta.connectorType,walletClientType:e.meta.walletClientType}})}async _link(e){try{let t=await e.link(),r=t.oauth_tokens,n=r?{provider:r.provider,accessToken:r.access_token,accessTokenExpiresInSeconds:r.access_token_expires_in_seconds,refreshToken:r.refresh_token,refreshTokenExpiresInSeconds:r.refresh_token_expires_in_seconds,scopes:r.scopes}:void 0;return{user:l.convertUserResponseToUser(t),oAuthTokens:n}}catch(e){throw console.warn("Error linking account"),s.formatPrivyError(e)}}async _refresh(){if(!this.api)throw new s.PrivyClientError("Session has no API instance");if(!this.client)throw new s.PrivyClientError("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let e=this.token,t=this.refreshToken;if(this.client.useServerCookies&&!this.mightHaveServerCookies&&this.token&&window.location.origin===this.client.apiUrl)return this.destroyLocalState(),null;try{let r;if(!(e&&t||this.mightHaveServerCookies))return null;{let n={};e&&(n.authorization=`Bearer ${e}`),r=await this.api.post(s.sessionsRefreshPath,t?{refresh_token:t}:{},{headers:n})}return this.handleTokenResponse(r),l.convertUserResponseToUser(r.user)}catch(e){if(e instanceof s.PrivyApiError&&e.privyErrorCode===s.PrivyErrorCode.MISSING_OR_INVALID_TOKEN)return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw s.formatPrivyError(e)}}handleTokenResponse(e){e.session_update_action&&"set"!==e.session_update_action?"clear"===e.session_update_action?this.destroyLocalState():"ignore"===e.session_update_action&&(e.token&&(this.storeCustomerAccessToken(e.token),this.storePrivyAccessToken(e.privy_access_token)),e.identity_token&&this.storeIdentityToken(e.identity_token)):this._storeAllTokens(e)}_storeAllTokens(e){this.storeRefreshToken(e.refresh_token),this.storeCustomerAccessToken(e.token),this.storePrivyAccessToken(e.privy_access_token),e.identity_token&&this.storeIdentityToken(e.identity_token)}async _destroy(){try{await(this.api?.post(s.sessionsLogoutPath,{refresh_token:this.refreshToken}))}catch(e){console.warn("Error destroying session")}this.destroyLocalState()}destroyLocalState(){this.storeRefreshToken(null),this.storeCustomerAccessToken(null),this.storePrivyAccessToken(null),this.clearIdentityToken()}storeCustomerAccessToken(e){if("string"==typeof e){let t=l.p.get(y.CUSTOMER_ACCESS_TOKEN_STORAGE_KEY);if(l.p.put(y.CUSTOMER_ACCESS_TOKEN_STORAGE_KEY,e),!this.client?.useServerCookies){let t=Fe.parse(e)?.expiration;ne.default.set(y.CUSTOMER_ACCESS_TOKEN_COOKIE_KEY,e,{sameSite:"Strict",secure:dt(),expires:t?new Date(1e3*t):void 0})}t!==e&&this.client?.onStoreCustomerAccessToken?.(e)}else l.p.del(y.CUSTOMER_ACCESS_TOKEN_STORAGE_KEY),ne.default.remove(y.CUSTOMER_ACCESS_TOKEN_COOKIE_KEY),this.client?.onDeleteCustomerAccessToken?.()}storeRefreshToken(e){"string"==typeof e?(l.p.put(y.REFRESH_TOKEN_STORAGE_KEY,e),this.client?.useServerCookies||ne.default.set(y.SESSION_COOKIE_KEY,"t",{sameSite:"Strict",secure:dt(),expires:30})):(l.p.del(y.REFRESH_TOKEN_STORAGE_KEY),ne.default.remove(y.REFRESH_TOKEN_COOKIE_KEY),ne.default.remove(y.SESSION_COOKIE_KEY))}storePrivyAccessToken(e){"string"==typeof e?l.p.put(y.PRIVY_ACCESS_TOKEN_STORAGE_KEY,e):l.p.del(y.PRIVY_ACCESS_TOKEN_STORAGE_KEY)}storeIdentityToken(e){if(ut.setState({identityToken:e}),this.client?.useServerCookies)return;l.p.put(y.IDENTITY_TOKEN_STORAGE_KEY,e);let t=Fe.parse(e)?.expiration;ne.default.set(y.IDENTITY_TOKEN_COOKIE_KEY,e,{sameSite:"Strict",secure:dt(),expires:t?new Date(1e3*t):void 0})}clearIdentityToken(){l.p.del(y.IDENTITY_TOKEN_STORAGE_KEY),ut.setState({identityToken:null}),ne.default.remove(y.IDENTITY_TOKEN_COOKIE_KEY)}constructor(){this.authenticateOnce=new l.RunEffectOnce((async e=>this._authenticate(e))),this.linkOnce=new l.RunEffectOnce((async e=>this._link(e))),this.refreshOnce=new l.RunEffectOnce(this._refresh.bind(this)),this.destroyOnce=new l.RunEffectOnce(this._destroy.bind(this))}}let mt;var wt=0,gt="__private_"+wt+++"__getOrGenerateClientAnalyticsId";class vt{getAppId(){return this.appId}initializeConnectorManager({walletConnectCloudProjectId:e,rpcConfig:t,chains:r,defaultChain:n,store:i,walletList:a,shouldEnforceDefaultChainOnConnect:o,externalWalletConfig:s,appName:l,walletChainType:c,setBaseAccountSdk:d}){this.connectors||(this.connectors=new tt(this.appId,e,t,r,n,i,a,o,s,l,d,c))}generateApi(){let e=new nt({appId:this.appId,appClientId:this.appClientId,client:this,defaults:{baseURL:this.apiUrl,timeout:this.timeout}});return this.session.api=e,e}updateApiUrl(e){this.apiUrl=e||this.fallbackApiUrl,this.api=this.generateApi(),e&&(this.useServerCookies=!0)}authenticate(){if(!this.authFlow)throw new s.PrivyClientError("No auth flow in progress.");return this.session.authenticate(this.authFlow)}async link(){if(!this.authFlow)throw new s.PrivyClientError("No auth flow in progress.");let{oAuthTokens:e}=await this.session.link(this.authFlow);return{user:await this.getAuthenticatedUser(),oAuthTokens:e}}storeProviderAccessToken(e,t){this.session.storeProviderAccessToken(e,t)}getProviderAccessToken(e){return this.session.getProviderAccessToken(e)}async logout(){await this.session.destroy(),this.authFlow=void 0}clearProviderAcccessTokens(e){e.linkedAccounts.filter((e=>"cross_app"===e.type)).forEach((e=>{this.storeProviderAccessToken(e.providerApp.id,null)}))}startAuthFlow(e){return e.api=this.api,this.authFlow=e,this.authFlow}async initMfaSmsVerification(){try{await this.api.post(s.mfaPasswordlessSmsInitPath,{action:"verify"})}catch(e){throw s.formatApiError(e)}}async initMfaPasskeyVerification(){try{let e=await this.api.post(s.mfaPasskeyInitPath,{});return st(e.options)}catch(e){throw s.formatApiError(e)}}async getCrossAppProviderDetails(e){try{return this._cachedProviderAppDetails[e]||(this._cachedProviderAppDetails[e]=await this.api.get(`/api/v1/apps/${e}/cross-app/details`)),this._cachedProviderAppDetails[e]}catch(e){console.error("Error fetching cross app provider details",e)}}async acceptTerms(){try{let e=await this.api.post(s.acceptTermsPath,{});return l.convertUserResponseToUser(e)}catch(e){throw s.formatPrivyError(e)}}async unlinkEmail(e){try{let t=await this.api.post(s.unlinkEmailPath,{address:e});return await this.getAuthenticatedUser()??l.convertUserResponseToUser(t)}catch(e){throw s.formatPrivyError(e)}}async unlinkPhone(e){try{let t=await this.api.post(s.unlinkPhonePath,{phoneNumber:e});return await this.getAuthenticatedUser()??l.convertUserResponseToUser(t)}catch(e){throw s.formatPrivyError(e)}}async unlinkEthereumWallet(e){try{let t=await this.api.post(s.unlinkWalletPath,{address:e});return await this.getAuthenticatedUser()??l.convertUserResponseToUser(t)}catch(e){throw s.formatPrivyError(e)}}async unlinkSolanaWallet(e){try{let t=await this.api.post(s.siwsUnlinkWalletPath,{address:e});return await this.getAuthenticatedUser()??l.convertUserResponseToUser(t)}catch(e){throw s.formatPrivyError(e)}}async unlinkOAuth(e,t){try{let r=await this.api.post(s.unlinkOAuthPath,{provider:e,subject:t});return await this.getAuthenticatedUser()??l.convertUserResponseToUser(r)}catch(e){throw s.formatPrivyError(e)}}async unlinkFarcaster(e){try{let t=await this.api.post(s.unlinkFarcasterPath,{fid:e});return await this.getAuthenticatedUser()??l.convertUserResponseToUser(t)}catch(e){throw s.formatPrivyError(e)}}async unlinkTelegram(e){try{let t=await this.api.post(s.telegramAccountUnlinkPath,{telegram_user_id:e});return await this.getAuthenticatedUser()??l.convertUserResponseToUser(t)}catch(e){throw s.formatPrivyError(e)}}async revokeDelegatedWallet(){try{await this.api.post(s.delegatedActionsRevokePath,{})}catch(e){throw s.formatPrivyError(e)}}async createAnalyticsEvent({eventName:e,payload:t,timestamp:r,options:n}){if("undefined"!=typeof window)try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(s.analyticsEventsPath,{event_name:e,client_id:this.clientAnalyticsId,payload:{...t||{},clientTimestamp:r?r.toISOString():(new Date).toISOString()}},{retry:-1,keepalive:n?.keepAlive??!1})}catch(e){console.log("Unable to submit event. This is not an issue.")}}async signMoonpayOnRampUrl(e){try{return this.api.post(s.moonpayPluginOnRampPath,e)}catch(e){throw s.formatPrivyError(e)}}async initCoinbaseOnRamp(e){try{return this.api.post(s.coinbaseOnRampInitPath,e)}catch(e){throw s.formatPrivyError(e)}}async getCoinbaseOnRampStatus({partnerUserId:e}){try{return this.api.get(`${s.coinbaseOnRampStatusPath}?partnerUserId=${e}`)}catch(e){throw s.formatPrivyError(e)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){return await this.getPrivyAccessToken(e)||await this.getCustomerAccessToken(e)}async getCustomerAccessToken(e){return await this._getToken(pt.CUSTOMER,e)}async getPrivyAccessToken(e){return await this._getToken(pt.PRIVY,e)}async _getToken(e,t){return this.session.getToken(e)?this.session.hasActiveAccessToken(e)?this.session.hasRefreshCredentials(e)?Le.parse(this.session.getToken(e))?.appId!==this.appId?(await this.logout(),null):this.session.getToken(e):(this.session.destroyLocalState(),null):!t?.disableAutoRefresh&&this.session.hasRefreshCredentials(e)?(await this.session.refresh(),this.session.getToken(e)):null:null}async getSmartWalletsConfig(){try{let e={},t=this.session.token;t&&(e.authorization=`Bearer ${t}`);let r=await this.api.get(`/api/v1/apps/${this.appId}/smart_wallets`,{baseURL:this.fallbackApiUrl,headers:e});return r.enabled?{enabled:r.enabled,smartWalletVersion:r.smart_wallet_version,smartWalletType:r.smart_wallet_type,configuredNetworks:r.configured_networks.map((e=>({chainId:e.chain_id,bundlerUrl:e.bundler_url,paymasterUrl:e.paymaster_url,paymasterContext:ot(e.paymaster_url,e.paymaster_context)})))}:{enabled:r.enabled}}catch(e){throw s.formatPrivyError(e)}}async getUsdTokenPrice(e){try{return(await this.api.get(`/api/v1/token_price?chainId=${e.id}&tokenSymbol=${e.nativeCurrency.symbol}`)).usd}catch(t){return void console.error(`Unable to fetch token price for chain with id ${e.id}`)}}async getUsdPriceForSol(){try{return(await this.api.get("/api/v1/token_price?chainId=0&tokenSymbol=SOL")).usd}catch(e){return void console.error("Unable to fetch token price for SOL")}}async getSplTokenMetadata({mintAddress:e,cluster:t}){try{return await this.api.get(`/api/v1/spl_token_info?mint_address=${e}&cluster=${t}`)}catch(r){return void console.error(`Unable to fetch token metadata for ${t}:${e}`)}}async requestFarcasterSignerStatus(e){try{return await this.api.post("/api/v1/farcaster/signer/status",{ed25519_public_key:e})}catch(e){throw console.error("Unable to fetch Farcaster signer status"),e}}async generateSiweNonce({address:e,captchaToken:t}){try{return(await this.api.post(s.siweInitPath,{address:e,token:t})).nonce}catch(e){throw s.formatPrivyError(e)}}async authenticateWithSiweInternal({message:e,signature:t,chainId:r,walletClientType:n,connectorType:i,mode:a}){return await this.api.post(s.siweAuthenticatePath,{message:e,signature:t,chainId:r,walletClientType:n,connectorType:i,mode:a})}async linkWithSiweInternal({message:e,signature:t,chainId:r,walletClientType:n,connectorType:i}){return await this.api.post(s.siweLinkPath,{message:e,signature:t,chainId:r,walletClientType:n,connectorType:i})}async linkSmartWallet({message:e,signature:t,smartWalletType:r,smartWalletVersion:n}){try{let i=await this.api.post(s.smartWalletLinkPath,{message:e,signature:t,smart_wallet_type:r,smart_wallet_version:n});return l.convertUserResponseToUser(i)}catch(e){throw s.formatPrivyError(e)}}async linkWithSiwe({message:e,signature:t,chainId:r,walletClientType:n,connectorType:i}){try{let a=await this.linkWithSiweInternal({message:e,signature:t,chainId:r,walletClientType:n,connectorType:i});return l.convertUserResponseToUser(a)}catch(e){throw s.formatPrivyError(e)}}async generateSiwsNonce({address:e,captchaToken:t}){try{return(await this.api.post(s.siwsInitPath,{address:e,token:t})).nonce}catch(e){throw s.formatPrivyError(e)}}async authenticateWithSiwsInternal({message:e,signature:t,walletClientType:r,connectorType:n,mode:i,messageType:a="plain"}){return await this.api.post(s.siwsAuthenticatePath,{message:e,signature:t,walletClientType:r,connectorType:n,mode:i,message_type:a})}async authenticateWithSiws({message:e,signature:t,walletClientType:r,connectorType:n,mode:i,messageType:a="plain"}){let o=await this.authenticateWithSiwsInternal({message:e,signature:t,walletClientType:r,connectorType:n,mode:i,messageType:a});this.session.handleTokenResponse(o);let s=l.convertUserResponseToUser(o.user);if(!s)throw Error("Authentication failed - no user returned");return{user:s,isNewUser:o.is_new_user||!1}}async sendAccountTransferRequest({nonce:e,account:t,accountType:r,externalWalletMetadata:n,telegramAuthResult:i,telegramWebAppData:a,farcasterEmbeddedAddress:o,oAuthUserInfo:c}){try{let d,u;switch(r){case"email":d=s.transferEmailPath,u={nonce:e,email:t};break;case"sms":d=s.transferPhonePath,u={nonce:e,phoneNumber:t};break;case"siwe":if(d=s.transferWalletPath,!n)throw Error("Wallet parameters must be defined");u={nonce:e,address:t,...n};break;case"farcaster":d=s.transferFarcasterPath,u={nonce:e,farcaster_id:t,farcaster_embedded_address:o};break;case"telegram":d=s.telegramAccountTransferPath,u={nonce:e,telegram_auth_result:i,telegram_web_app_data:a};break;case"siws":d=s.siwsTransferPath,u={nonce:e,address:t,...n};break;case"custom":case"guest":case"passkey":throw Error("Invalid transfer account type");default:d=s.transferOAuthPath,u={nonce:e,userInfo:c}}let h=await this.api.post(d,u);return await this.getAuthenticatedUser()??l.convertUserResponseToUser(h)}catch(e){throw s.formatPrivyError(e)}}async linkWithSiwsInternal({message:e,signature:t,walletClientType:r,connectorType:n,messageType:i="plain"}){return await this.api.post(s.siwsLinkPath,{message:e,signature:t,walletClientType:r,connectorType:n,message_type:i})}async linkWithSiws({message:e,signature:t,walletClientType:r,connectorType:n,messageType:i="plain"}){try{let a=await this.linkWithSiwsInternal({message:e,signature:t,walletClientType:r,connectorType:n,messageType:i});return l.convertUserResponseToUser(a)}catch(e){throw s.formatPrivyError(e)}}async updateUserAndIdToken(){try{let e=await this.api.get(s.usersMePath);return this.session.updateIdentityToken(e.identity_token),l.convertUserResponseToUser(e.user)}catch(e){throw s.formatPrivyError(e)}}async scanTransaction(e){try{return await this.api.post(s.transactionScanningPath,e)}catch(e){throw s.formatPrivyError(e)}}constructor({apiUrl:e=y.DEFAULT_PRIVY_API_URL,appId:t,appClientId:r,timeout:n=y.DEFAULT_API_TIMEOUT_MS}){Object.defineProperty(this,gt,{value:ft}),this._cachedProviderAppDetails={},this.apiUrl=e,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=e!==y.DEFAULT_PRIVY_API_URL&&e.startsWith("https://privy."),this.timeout=n,this.appId=t,this.appClientId=r,this.clientAnalyticsId=function(e,t){if(!Object.prototype.hasOwnProperty.call(e,t))throw TypeError("attempted to use private field on non-instance");return e}(this,gt)[gt](),mt||(mt=new yt),this.session=mt,this.api=this.generateApi(),this.session.client=this}}function ft(){if("undefined"==typeof window)return null;try{let e=l.p.get(y.CLIENT_ANALYTICS_ID_KEY);if("string"==typeof e&&e.length>0)return e}catch(e){}let e=c.v4();try{return l.p.put(y.CLIENT_ANALYTICS_ID_KEY,e),e}catch(t){return e}}const Ct=({delayedExecution:t,...n})=>{let{enabled:i,siteKey:a,appId:o,setError:s,setToken:c,setExecuting:d,ref:u}=l.useCaptcha(),[,h]=r.useMemo((()=>a?.split("t:")||[]),[a]);if(r.useEffect((()=>u.current?.remove),[]),!i)return null;if(!h)throw Error("Unsupported captcha site key");/*#__PURE__*/return e.jsx("div",{className:"hidden h-0 w-0",children:/*#__PURE__*/e.jsx(v.Turnstile,{...n,ref:u,siteKey:h,options:{action:o,size:"invisible",...t?{appearance:"execute",execution:"execute"}:{appearance:"always",execution:"render"}},onUnsupported:()=>{n.onUnsupported?.(),console.warn("Browser does not support Turnstile.")},onError:e=>{n.onError?.(e),s("Captcha failed"),d(!1)},onSuccess:e=>{n.onSuccess?.(e),c(e),d(!1)},onExpire:e=>{n.onExpire?.(e);try{u.current?.reset(),s(void 0),c(void 0)}catch(e){s("expired_and_failed_reset")}}})})};function Et(e){y.usePrivyEventSubscription("configureMfa",e)}const At=/*#__PURE__*/f.styled.div.withConfig({displayName:"AppLogoContainer",componentId:"sc-ba98f772-0"})(["display:flex;flex-direction:column;align-items:center;padding:0px 0px 30px;@media (max-width:440px){padding:10px 10px 20px;}"]),Pt=/*#__PURE__*/f.styled.div.withConfig({displayName:"Title",componentId:"sc-ba98f772-1"})(["font-size:18px;line-height:30px;text-align:center;font-weight:600;margin-bottom:10px;"]),kt=/*#__PURE__*/f.styled.div.withConfig({displayName:"SubTitle",componentId:"sc-ba98f772-2"})(["font-size:0.875rem;text-align:center;"]),Tt=/*#__PURE__*/f.styled.div.withConfig({displayName:"Container",componentId:"sc-ba98f772-3"})(["display:flex;flex-direction:column;align-items:center;gap:10px;flex-grow:1;padding:20px 0;@media (max-width:440px){padding:10px 10px 20px;}"]),xt=/*#__PURE__*/f.styled.div.withConfig({displayName:"List",componentId:"sc-ba98f772-4"})(["display:flex;flex-direction:column;align-items:stretch;gap:0.75rem;padding:1rem 0rem 0rem;flex-grow:1;width:100%;"]),bt=/*#__PURE__*/f.styled.div.withConfig({displayName:"ListItemIcon",componentId:"sc-ba98f772-5"})(["width:25px;display:flex;align-items:center;justify-content:flex-start;> svg{z-index:2;height:25px !important;width:25px !important;color:var(--privy-color-accent);}"]),St=/*#__PURE__*/f.styled.div.withConfig({displayName:"ListItem",componentId:"sc-ba98f772-6"})(["display:flex;align-items:center;gap:10px;font-size:0.875rem;line-height:1rem;text-align:left;"]),_t=/*#__PURE__*/f.styled.div.withConfig({displayName:"BottomSection",componentId:"sc-ba98f772-7"})(["display:flex;flex-direction:column;gap:10px;padding-top:20px;"]),It=/*#__PURE__*/f.styled.div.withConfig({displayName:"MethodList",componentId:"sc-ba98f772-8"})(["display:flex;flex-direction:column;align-items:stretch;gap:1rem;padding:1rem 0rem 0rem;flex-grow:1;width:100%;"]),Ut=/*#__PURE__*/f.styled.div.withConfig({displayName:"MethodListItem",componentId:"sc-ba98f772-9"})(["display:flex;gap:5px;width:100%;position:relative;"]),Wt=/*#__PURE__*/f.styled.button.withConfig({displayName:"RemoveMethodButton",componentId:"sc-ba98f772-10"})(["&&{background-color:transparent;color:var(--privy-color-foreground-3);padding:0 0.75rem;display:flex;align-items:center;height:100%;> svg{z-index:2;height:20px !important;width:20px !important;}}&&:hover{color:var(--privy-color-error);}"]),Rt=/*#__PURE__*/f.styled.div.withConfig({displayName:"MethodText",componentId:"sc-ba98f772-11"})(["display:flex;align-items:center;gap:0.5rem;> svg{z-index:2;height:20px !important;width:20px !important;}"]),Nt=/*#__PURE__*/f.styled.div.withConfig({displayName:"ExtraText",componentId:"sc-ba98f772-12"})(["display:flex;align-items:center;gap:6px;font-weight:400 !important;color:",";> svg{z-index:2;height:18px !important;width:18px !important;display:flex !important;align-items:flex-end;}"],(e=>e.$isAccent?"var(--privy-color-accent)":"var(--privy-color-foreground-3)")),Ot=/*#__PURE__*/f.styled.div.withConfig({displayName:"SmsInsecureText",componentId:"sc-ba98f772-13"})(["width:100%;display:flex;justify-content:space-between;"]),Mt=/*#__PURE__*/f.styled.p.withConfig({displayName:"TermsText",componentId:"sc-ba98f772-14"})(["text-align:left;width:100%;color:var(--privy-color-foreground-3) !important;"]),jt=/*#__PURE__*/f.styled.button.withConfig({displayName:"PrimaryTextButton",componentId:"sc-ba98f772-15"})(["display:flex;flex-direction:row;align-items:center;justify-content:center;user-select:none;&{width:100%;cursor:pointer;border-radius:var(--privy-border-radius-md);font-size:0.875rem;line-height:1rem;font-style:normal;font-weight:500;line-height:22px;letter-spacing:-0.016px;}&&{color:",";background-color:transparent;padding:0.5rem 0px;}&:hover{text-decoration:underline;}"],(e=>"dark"===e.theme?"var(--privy-color-foreground-2)":"var(--privy-color-accent)")),Ft=/*#__PURE__*/f.styled.div.withConfig({displayName:"IconWrapper",componentId:"sc-ba98f772-16"})(["display:flex;align-items:center;justify-content:center;color:var(--privy-color-accent);width:100%;> svg{z-index:2;width:3rem;height:3rem;}"]),Lt=/*#__PURE__*/f.styled.div.withConfig({displayName:"ErrorMessage",componentId:"sc-ba98f772-17"})(["color:var(--privy-color-error);"]),Dt=({handleClose:t,user:r,onSelect:n})=>/*#__PURE__*/e.jsxs(l.ScreenLayout,{title:"Verify your identity",subtitle:"Choose a verification method",icon:se.default,iconVariant:"subtle",onClose:t,showClose:!0,watermark:!0,children:[/*#__PURE__*/e.jsxs(It,{children:[r.mfaMethods.includes("totp")&&/*#__PURE__*/e.jsxs(l.LoginMethodButton,{onClick:()=>n("totp"),children:[/*#__PURE__*/e.jsx(l.LoginMethodIconWrapper,{children:/*#__PURE__*/e.jsx(ie.default,{})}),"Authenticator app"]},"totp"),r.mfaMethods.includes("sms")&&/*#__PURE__*/e.jsxs(l.LoginMethodButton,{onClick:()=>n("sms"),children:[/*#__PURE__*/e.jsx(l.LoginMethodIconWrapper,{children:/*#__PURE__*/e.jsx(oe.default,{})}),"SMS"]},"sms"),r.mfaMethods.includes("passkey")&&/*#__PURE__*/e.jsxs(l.LoginMethodButton,{onClick:()=>n("passkey"),children:[/*#__PURE__*/e.jsx(l.LoginMethodIconWrapper,{children:/*#__PURE__*/e.jsx(ae.default,{})}),"Passkey"]},"passkey")]}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]}),qt=({pendingTransaction:t})=>{let{wallets:n}=l.useWallets(),{walletProxy:i,rpcConfig:a,chains:o,appId:c,nativeTokenSymbolForChainId:d}=s.usePrivyInternal(),[u,h]=r.useState(null),[p,y]=r.useState(t),{tokenPrice:m}=l.useGetTokenPrice(p.chainId),w=d(t.chainId)||"ETH",g=r.useMemo((()=>n.find((e=>"privy"===e.walletClientType))),[n]);return r.useEffect((()=>{(async function(){if(!i||!g)return p;let e=l.getPublicClient(p.chainId,o,a,{appId:c}),t=await l.prepareTransactionRequest(p,e,g.address);return h(b.toHex(BigInt(t.gas??0))),t})().then(y).catch(console.error)}),[i]),g?/*#__PURE__*/e.jsx(Bt,{children:/*#__PURE__*/e.jsx(l.TransactionDetails,{from:g.address,to:p.to,txn:p,gas:u??void 0,tokenPrice:m,tokenSymbol:w})}):null};let Bt=/*#__PURE__*/f.styled.div.withConfig({displayName:"TransactionInfoWrapper",componentId:"sc-8d9a2f57-0"})(["width:100%;padding:1rem 0;"]);const Ht=({style:t,...r})=>/*#__PURE__*/e.jsx("svg",{x:0,y:0,width:"65",height:"64",viewBox:"0 0 65 64",style:{height:"64px",width:"65px",...t},fill:"currentColor",xmlns:"http://www.w3.org/2000/svg",...r,children:/*#__PURE__*/e.jsx("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M3.71369 17.5625V10.375C3.71369 6.44625 6.85845 3.25 10.7238 3.25H17.7953C18.6783 3.25 19.3941 2.52244 19.3941 1.625C19.3941 0.727562 18.6783 0 17.7953 0H10.7238C5.09529 0 0.516113 4.65419 0.516113 10.375V17.5625C0.516113 18.4599 1.23194 19.1875 2.1149 19.1875C2.99787 19.1875 3.71369 18.4599 3.71369 17.5625ZM17.7953 60.7501C18.6783 60.7501 19.3941 61.4777 19.3941 62.3751C19.3941 63.2726 18.6783 64.0001 17.7953 64.0001H10.7238C5.09529 64.0001 0.516113 59.3459 0.516113 53.6251V46.4376C0.516113 45.5402 1.23194 44.8126 2.1149 44.8126C2.99787 44.8126 3.71369 45.5402 3.71369 46.4376V53.6251C3.71369 57.5538 6.85845 60.7501 10.7238 60.7501H17.7953ZM63.4839 46.4376V53.6251C63.4839 59.3459 58.9048 64.0001 53.2763 64.0001H46.2047C45.3217 64.0001 44.6059 63.2726 44.6059 62.3751C44.6059 61.4777 45.3217 60.7501 46.2047 60.7501H53.2763C57.1416 60.7501 60.2864 57.5538 60.2864 53.6251V46.4376C60.2864 45.5402 61.0022 44.8126 61.8851 44.8126C62.7681 44.8126 63.4839 45.5402 63.4839 46.4376ZM63.4839 10.375V17.5625C63.4839 18.4599 62.7681 19.1875 61.8851 19.1875C61.0022 19.1875 60.2864 18.4599 60.2864 17.5625V10.375C60.2864 6.44625 57.1416 3.25 53.2763 3.25H46.2047C45.3217 3.25 44.6059 2.52244 44.6059 1.625C44.6059 0.727562 45.3217 0 46.2047 0H53.2763C58.9048 0 63.4839 4.65419 63.4839 10.375ZM43.0331 47.3022C43.7067 46.6698 43.7483 45.6022 43.1262 44.9176C42.5039 44.233 41.4536 44.1906 40.78 44.823C38.3832 47.0732 35.265 48.3125 31.9997 48.3125C28.7344 48.3125 25.6162 47.0732 23.2194 44.823C22.5457 44.1906 21.4955 44.233 20.8732 44.9176C20.251 45.6022 20.2927 46.6698 20.9663 47.3022C23.9784 50.1301 27.8968 51.6875 31.9997 51.6875C36.1026 51.6875 40.021 50.1301 43.0331 47.3022ZM35.3207 24.1249V36.1249C35.3207 38.5029 33.4173 40.4374 31.0777 40.4374H29.7249C28.8079 40.4374 28.0646 39.6819 28.0646 38.7499C28.0646 37.8179 28.8079 37.0624 29.7249 37.0624H31.0777C31.5863 37.0624 32.0001 36.6419 32.0001 36.1249V24.1249C32.0001 23.1929 32.7434 22.4374 33.6604 22.4374C34.5774 22.4374 35.3207 23.1929 35.3207 24.1249ZM46.7581 28.8437V24.0312C46.7581 23.151 46.056 22.4374 45.19 22.4374C44.324 22.4374 43.622 23.151 43.622 24.0312V28.8437C43.622 29.7239 44.324 30.4374 45.19 30.4374C46.056 30.4374 46.7581 29.7239 46.7581 28.8437ZM17.6109 28.8437C17.6109 29.7239 18.313 30.4374 19.1789 30.4374C20.0449 30.4374 20.747 29.7239 20.747 28.8437V24.0312C20.747 23.151 20.0449 22.4374 19.1789 22.4374C18.313 22.4374 17.6109 23.151 17.6109 24.0312V28.8437Z"})}),zt=({hasBlockingError:t,error:r,onClose:n,onBack:i,handleSubmit:a,account:o,submitSuccess:c})=>{let{pendingTransaction:d}=s.usePrivyInternal();/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:n},"header"),/*#__PURE__*/e.jsx(l.e$2,{children:/*#__PURE__*/e.jsxs("div",{children:[/*#__PURE__*/e.jsx(l.ConnectionLoader,{success:c,fail:!!r}),r?/*#__PURE__*/e.jsx(ce.default,{style:{width:"38px",height:"38px"}}):/*#__PURE__*/e.jsx(Ht,{style:{width:"38px",height:"38px"}})]})}),/*#__PURE__*/e.jsx(Pt,{style:{marginTop:"1rem"},children:"Verifying with passkey"}),/*#__PURE__*/e.jsxs(xt,{children:[/*#__PURE__*/e.jsxs(St,{children:[/*#__PURE__*/e.jsx(bt,{children:/*#__PURE__*/e.jsx(se.default,{})}),"Approve this action using your touch, face, PIN, or hardware key."]}),/*#__PURE__*/e.jsxs(St,{children:[/*#__PURE__*/e.jsx(bt,{children:/*#__PURE__*/e.jsx(le.default,{})}),"You last added a passkey on"," ",o?.firstVerifiedAt?.toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric"}),"."]})]}),d&&/*#__PURE__*/e.jsx(Tt,{children:/*#__PURE__*/e.jsx(qt,{pendingTransaction:d})}),r&&/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(Lt,{style:{marginTop:"1.25rem"},children:r.message}),/*#__PURE__*/e.jsx(l.PrimaryButton,{disabled:t,onClick:a,style:{margin:"1.25rem auto 0"},children:"Try again"})]}),i&&/*#__PURE__*/e.jsx(jt,{style:{marginTop:"1rem"},onClick:i,children:"Choose another method"}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]})};let Kt=Array(6).fill("");var Vt,$t=((Vt=$t||{})[Vt.RESET_AFTER_DELAY=0]="RESET_AFTER_DELAY",Vt[Vt.CLEAR_ON_NEXT_VALID_INPUT=1]="CLEAR_ON_NEXT_VALID_INPUT",Vt);function Yt(e){return/^[0-9]{1}$/.test(e)}function Gt(e){return 6===e.length&&e.every(Yt)}const Zt=({onChange:t,disabled:i,errorReasonOverride:a,success:o})=>{let[s,l]=r.useState(Kt),[c,d]=r.useState(null),[u,h]=r.useState(null),p=async e=>{e.preventDefault();let r=e.currentTarget.value.replace(/\s+/g,"");if(""===r)return;let n=s.reduce(((e,t)=>e+Number(Yt(t))),0),i=r.split(""),a=!i.every(Yt),o=i.length+n>6;if(a)return d("Passcode can only be numbers"),void h(1);if(o)return d("Passcode must be exactly 6 numbers"),void h(1);d(null),h(null);let c=Number(e.currentTarget.name?.charAt(4)),u=[...r||[""]].slice(0,6-c),p=[...s.slice(0,c),...u,...s.slice(c+u.length)];l(p);let y=Math.min(Math.max(c+u.length,0),5),m=document.querySelector(`input[name=pin-${y}]`);if(m?.focus(),Gt(p))try{await t(p.join(""));let e=document.querySelector(`input[name=pin-${y}]`);e?.blur()}catch(e){h(1),d(e.message)}else try{await t(null)}catch(e){h(1),d(e.message)}},y=o?"success":!(!a&&!c)?"fail":"";/*#__PURE__*/return e.jsx(e.Fragment,{children:/*#__PURE__*/e.jsxs(Jt,{children:[/*#__PURE__*/e.jsx("div",{children:s.map(((r,a)=>/*#__PURE__*/e.jsx("input",{name:`pin-${a}`,type:"text",value:s[a],onChange:p,onKeyUp:e=>{"Backspace"===e.key&&(e=>{1===u&&(d(null),h(null));let r=[...s.slice(0,e),"",...s.slice(e+1)];if(l(r),e>0){let t=document.querySelector(`input[name=pin-${e-1}]`);t?.focus()}Gt(r)?t(r.join("")):t(null)})(a)},inputMode:"numeric",autoFocus:0===a,pattern:"[0-9]",className:y,autoComplete:n.isMobile?"one-time-code":"off",disabled:i},a)))}),/*#__PURE__*/e.jsx("div",{children:/*#__PURE__*/e.jsx(Xt,{$fail:!!a||!!c,children:a||c})})]})})};let Jt=/*#__PURE__*/f.styled.div.withConfig({displayName:"PinInputContainer",componentId:"sc-7a171f6-0"})(["display:flex;flex-direction:column;width:100%;gap:8px;@media (max-width:440px){margin-top:8px;margin-bottom:8px;}> div:nth-child(1){display:flex;justify-content:center;gap:0.5rem;width:100%;border-radius:var(--privy-border-radius-md);> input{border:1px solid var(--privy-color-foreground-4);background:var(--privy-color-background);border-radius:var(--privy-border-radius-md);padding:8px 10px;height:58px;width:46px;text-align:center;font-size:18px;}> input:disabled{background:var(--privy-color-background-2);}> input:focus{border:1px solid var(--privy-color-accent);}> input:invalid{border:1px solid var(--privy-color-error);}> input.success{border:1px solid var(--privy-color-success);}> input.fail{border:1px solid var(--privy-color-error);animation:shake 180ms;animation-iteration-count:2;}}@keyframes shake{0%{transform:translate(1px,0px);}33%{transform:translate(-1px,0px);}67%{transform:translate(-1px,0px);}100%{transform:translate(1px,0px);}}"]),Xt=/*#__PURE__*/f.styled.div.withConfig({displayName:"InputHelp",componentId:"sc-7a171f6-1"})(["line-height:20px;font-size:13px;display:flex;justify-content:flex-start;width:100%;color:",";"],(e=>e.$fail?"var(--privy-color-error)":"var(--privy-color-foreground-3)"));const Qt=({selectedMethod:t,submitSuccess:r,hasBlockingError:n,onClose:i,onBack:a,handleSubmitCode:o})=>{let c=y.useAppConfig(),{pendingTransaction:d}=s.usePrivyInternal();switch(t){case"sms":/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:i},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(oe.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Enter verification code"}),/*#__PURE__*/e.jsxs(Tt,{children:[/*#__PURE__*/e.jsx(Zt,{success:r,disabled:n,onChange:o}),/*#__PURE__*/e.jsxs(kt,{children:["To continue, please enter the 6-digit code sent to your ",/*#__PURE__*/e.jsx("strong",{children:"mobile device"})]}),d&&/*#__PURE__*/e.jsx(qt,{pendingTransaction:d})]}),a&&/*#__PURE__*/e.jsx(jt,{theme:c?.appearance.palette.colorScheme,onClick:a,children:"Choose another method"}),/*#__PURE__*/e.jsx(l.SecondaryButton,{onClick:i,children:"Cancel"}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]});case"totp":/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:i},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(ie.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Enter verification code"}),/*#__PURE__*/e.jsxs(Tt,{children:[/*#__PURE__*/e.jsx(Zt,{success:r,disabled:n,onChange:o}),/*#__PURE__*/e.jsxs(kt,{children:["To continue, please enter the 6-digit code generated from your"," ",/*#__PURE__*/e.jsx("strong",{children:"authenticator app"})]}),d&&/*#__PURE__*/e.jsx(qt,{pendingTransaction:d})]}),a&&/*#__PURE__*/e.jsx(jt,{theme:c?.appearance.palette.colorScheme,onClick:a,children:"Choose another method"}),/*#__PURE__*/e.jsx(l.SecondaryButton,{onClick:i,children:"Cancel"}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]});default:return null}},er=e=>l.errorIndicatesMaxMfaRetries(e)?{isBlocking:!0,error:Error("You have exceeded the maximum number of attempts. Please close this window and try again in 10 seconds.")}:l.errorIndicatesMfaVerificationFailed(e)?{isBlocking:!1,error:Error("The code you entered is not valid")}:l.errorIndicatesMfaTimeout(e)?{isBlocking:!0,error:Error("You have exceeded the time limit for code entry. Please try again in 30 seconds.")}:(console.error(e),{isBlocking:!1,error:Error("Something went wrong.")}),tr={component:()=>{let{user:t}=l.usePrivyContext(),{data:n}=l.usePrivyModal(),[i,a]=r.useState(t?.mfaMethods[0]),[o,s]=r.useState(!1),[c,d]=r.useState(),[u,h]=r.useState();if(r.useEffect((()=>{a(t?.mfaMethods[0])}),[t?.mfaMethods]),!n?.mfaVerify)throw Error("Missing modal data for MFA verification screen.");let{onFailure:p,onSuccess:y,generateOptions:m,verifyTotpCode:w,verifyPasskey:g,verifySmsCode:v,sendSmsCode:f}=n.mfaVerify,C=async e=>{if("passkey"!==e)try{a(e),"sms"===e&&(a(e),await f()),"totp"===e&&a(e)}catch(e){console.error(e)}else try{a(e);let t=await m();if(!t)throw Error("something went wrong");d(t),await g(t),s(!0),h(void 0),y()}catch(e){h(er(e))}},E=async e=>{h(void 0);try{if(!e||!i)return;if("passkey"===i){if(!c)throw Error("Missing passkey challenge");await g(c)}else"sms"===i?await v(e):"totp"===i&&await w(e);h(void 0),s(!0),y()}catch(e){throw er(e).error}},A=()=>{u||!o?p(u?.error??Error("Canceled MFA verification.")):y()},P=r.useRef(!1);return r.useEffect((()=>{!P.current&&i&&(P.current=!0,C(i).finally((()=>{P.current=!1})))}),[open]),t?"passkey"===i?/*#__PURE__*/e.jsx(zt,{account:t.linkedAccounts.filter((e=>"passkey"===e.type&&e.enrolledInMfa)).sort(((e,t)=>t.firstVerifiedAt.valueOf()-e.firstVerifiedAt.valueOf()))[0],submitSuccess:o,hasBlockingError:u?.isBlocking??!1,error:u?.error,onClose:A,onBack:()=>{a(void 0),h(void 0)},handleSubmit:()=>E(c).catch(h)}):"sms"===i||"totp"===i?/*#__PURE__*/e.jsx(Qt,{selectedMethod:i,submitSuccess:o,hasBlockingError:u?.isBlocking??!1,handleSubmitCode:E,onClose:A,onBack:t.mfaMethods.length>1?()=>a(void 0):void 0}):/*#__PURE__*/e.jsx(Dt,{user:t,onSelect:C,handleClose:A}):null}};function rr(){let{promptMfa:e,init:t,submit:n,cancel:i,mfaMethods:a}=r.useContext(l.PrivyContext);return{promptMfa:e,init:t,submit:n,cancel:i,mfaMethods:a}}const nr=({onClose:t})=>{let{user:n}=l.usePrivyContext(),[i,a]=r.useState(n?.mfaMethods[0]??null),{init:o,cancel:s,submit:c}=rr(),[d,u]=r.useState(!1),[h,p]=r.useState(null),[y,m]=r.useState();r.useEffect((()=>{a(n?.mfaMethods[0]??null)}),[n?.mfaMethods]);let w=r.useRef(!1);async function g(e){m(void 0);try{if(!e||!i)return;await c(i,e),u(!0),m(void 0),t()}catch(e){throw er(e).error}}async function v(e){if("passkey"!==e)try{a(e),await o(e)}catch(e){console.error(e)}else try{a(e);let r=await o(e);if(!r)throw Error("something went wrong");p(r),await c(e,r),u(!0),m(void 0),t()}catch(e){m(er(e))}}r.useEffect((()=>{!w.current&&i&&(w.current=!0,v(i).finally((()=>{w.current=!1})))}),[]);let f=()=>{a(null),m(void 0),s(),t()};return n?"passkey"===i?/*#__PURE__*/e.jsx(zt,{account:n.linkedAccounts.filter((e=>"passkey"===e.type&&e.enrolledInMfa)).sort(((e,t)=>t.firstVerifiedAt.valueOf()-e.firstVerifiedAt.valueOf()))[0],submitSuccess:d,hasBlockingError:y?.isBlocking??!1,error:y?.error,onClose:f,onBack:()=>{a(null),m(void 0)},handleSubmit:()=>g(h).catch(m)}):i?/*#__PURE__*/e.jsx(Qt,{submitSuccess:d,hasBlockingError:y?.isBlocking??!1,handleSubmitCode:g,selectedMethod:i,onClose:f,onBack:n.mfaMethods.length>1?()=>a(null):void 0}):/*#__PURE__*/e.jsx(Dt,{user:n,onSelect:v,handleClose:f}):null},ir=g.create((()=>({inProgressMfaFlow:void 0})));const ar=/*#__PURE__*/f.createGlobalStyle([":root{","};"],(e=>or(e.palette)));const or=e=>
|
|
2
|
-
/*#__PURE__*/f.css(["",""],Object.entries(function(e){return{"--privy-color-background":e.background,"--privy-color-background-2":e.background2,"--privy-color-background-3":e.background3,"--privy-color-foreground":e.foreground,"--privy-color-foreground-2":e.foreground2,"--privy-color-foreground-3":e.foreground3,"--privy-color-foreground-4":e.foreground4,"--privy-color-foreground-accent":e.foregroundAccent,"--privy-color-accent":e.accent,"--privy-color-accent-light":e.accentLight,"--privy-color-accent-hover":e.accentHover,"--privy-color-accent-dark":e.accentDark,"--privy-color-accent-darkest":e.accentDarkest,"--privy-color-success":e.success,"--privy-color-success-dark":e.successDark,"--privy-color-success-light":e.successLight,"--privy-color-success-bg":e.successBg,"--privy-color-error":e.error,"--privy-color-error-light":e.errorLight,"--privy-color-error-bg":e.errorBg,"--privy-color-error-bg-hover":e.errorBgHover,"--privy-color-warn":e.warn,"--privy-color-warn-light":e.warnLight,"--privy-color-warn-bg":e.warnBg,"--privy-color-warning-dark":e.warningDark,"--privy-color-error-dark":e.errorDark,"--privy-color-info-bg":e.infoBg,"--privy-color-info-bg-hover":e.infoBgHover,"--privy-color-border-default":e.borderDefault,"--privy-color-border-hover":e.borderHover,"--privy-color-border-focus":e.borderFocus,"--privy-color-border-error":e.borderError,"--privy-color-border-success":e.borderSuccess,"--privy-color-border-warning":e.borderWarning,"--privy-color-border-info":e.borderInfo,"--privy-color-border-interactive":e.borderInteractive,"--privy-color-border-interactive-hover":e.borderInteractiveHover,"--privy-color-background-hover":e.backgroundHover,"--privy-color-background-clicked":e.backgroundClicked,"--privy-color-background-disabled":e.backgroundDisabled,"--privy-color-background-interactive":e.backgroundInteractive,"--privy-color-background-interactive-hover":e.backgroundInteractiveHover,"--privy-color-background-interactive-clicked":e.backgroundInteractiveClicked,"--privy-color-background-interactive-disabled":e.backgroundInteractiveDisabled,"--privy-color-foreground-hover":e.foregroundHover,"--privy-color-foreground-clicked":e.foregroundClicked,"--privy-color-foreground-disabled":e.foregroundDisabled,"--privy-color-foreground-interactive":e.foregroundInteractive,"--privy-color-foreground-interactive-hover":e.foregroundInteractiveHover,"--privy-link-navigation-color":e.linkNavigationColor,"--privy-link-navigation-decoration":e.linkNavigationDecoration,"--privy-accent-has-good-contrast":e.accentHasGoodContrast,"--privy-color-icon-default":e.iconDefault,"--privy-color-icon-muted":e.iconMuted,"--privy-color-icon-subtle":e.iconSubtle,"--privy-color-icon-inverse":e.iconInverse,"--privy-color-icon-success":e.iconSuccess,"--privy-color-icon-warning":e.iconWarning,"--privy-color-icon-error":e.iconError,"--privy-color-icon-interactive":e.iconInteractive,"--privy-color-icon-default-hover":e.iconDefaultHover,"--privy-color-icon-muted-hover":e.iconMutedHover,"--privy-color-icon-subtle-hover":e.iconSubtleHover,"--privy-color-icon-default-clicked":e.iconDefaultClicked,"--privy-color-icon-muted-clicked":e.iconMutedClicked,"--privy-color-icon-subtle-clicked":e.iconSubtleClicked,"--privy-color-icon-default-disabled":e.iconDefaultDisabled,"--privy-color-icon-muted-disabled":e.iconMutedDisabled,"--privy-color-icon-subtle-disabled":e.iconSubtleDisabled,"--privy-color-icon-error-hover":e.iconErrorHover,"--privy-color-icon-interactive-hover":e.iconInteractiveHover,"--privy-color-icon-error-clicked":e.iconErrorClicked,"--privy-color-icon-interactive-clicked":e.iconInteractiveClicked,"--privy-color-icon-muted-disabled-alt":e.iconMutedDisabledAlt,"--privy-color-icon-subtle-disabled-alt":e.iconSubtleDisabledAlt,"--privy-border-radius-xs":"6px","--privy-border-radius-sm":"8px","--privy-border-radius-md":"12px","--privy-border-radius-mdlg":"16px","--privy-border-radius-lg":"24px","--privy-border-radius-full":"9999px","--privy-height-modal-full":"620px","--privy-height-modal-compact":"480px"}}(e)).map((([e,t])=>`${e}: ${t};`)).join("\n")),sr=/*#__PURE__*/f.styled.div.withConfig({displayName:"StylesWrapper",componentId:"sc-188229e4-0"})([""," color:var(--privy-color-foreground-2);h3{font-size:16px;line-height:24px;font-weight:500;color:var(--privy-color-foreground-2);}h4{font-size:14px;line-height:20px;font-weight:500;color:var(--privy-color-foreground);}p{font-size:13px;line-height:20px;color:var(--privy-color-foreground-2);}button:focus,input:focus,optgroup:focus,select:focus,textarea:focus{outline:none;border-color:var(--privy-color-accent-light);box-shadow:0 0 0 3px var(--privy-color-border-focus);}.mobile-only{@media (min-width:441px){display:none;}}@keyframes fadein{0%{opacity:0;}100%{opacity:1;}}"],"\n *,\n ::before,\n ::after {\n box-sizing: border-box;\n border-width: 0;\n border-style: solid;\n }\n\n line-height: 1.15;\n -webkit-text-size-adjust: 100%;\n -moz-tab-size: 4;\n tab-size: 4;\n font-feature-settings: normal;\n\n margin: 0;\n font-family: system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif,\n 'Apple Color Emoji', 'Segoe UI Emoji';\n\n hr {\n height: 0;\n color: inherit;\n border-top-width: 1px;\n }\n\n abbr:where([title]) {\n text-decoration: underline dotted;\n }\n\n h1,\n h2,\n h3,\n h4,\n h5,\n h6 {\n font-size: inherit;\n font-weight: inherit;\n font-family: system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif,\n 'Apple Color Emoji', 'Segoe UI Emoji';\n display: inline;\n }\n\n a {\n color: inherit;\n text-decoration: inherit;\n }\n\n b,\n strong {\n font-weight: bolder;\n }\n\n code,\n kbd,\n samp,\n pre {\n font-family: ui-monospace, SFMono-Regular, Consolas, 'Liberation Mono', Menlo, monospace;\n font-size: 1em;\n }\n\n small {\n font-size: 80%;\n }\n\n sub,\n sup {\n font-size: 75%;\n line-height: 0;\n position: relative;\n vertical-align: baseline;\n }\n\n sub {\n bottom: -0.25em;\n }\n\n sup {\n top: -0.5em;\n }\n\n table {\n text-indent: 0;\n border-color: inherit;\n border-collapse: collapse;\n }\n\n button,\n input,\n optgroup,\n select,\n textarea {\n font-family: inherit;\n font-size: 100%;\n font-weight: inherit;\n line-height: inherit;\n color: inherit;\n margin: 0;\n padding: 0;\n }\n\n button,\n select {\n text-transform: none;\n }\n\n button,\n [type='button'],\n [type='reset'],\n [type='submit'] {\n -webkit-appearance: button;\n background-color: transparent;\n background-image: none;\n }\n\n ::-moz-focus-inner {\n border-style: none;\n padding: 0;\n }\n\n :-moz-focusring {\n outline: 1px dotted ButtonText;\n }\n\n :-moz-ui-invalid {\n box-shadow: none;\n }\n\n legend {\n padding: 0;\n }\n\n progress {\n vertical-align: baseline;\n }\n\n ::-webkit-inner-spin-button,\n ::-webkit-outer-spin-button {\n height: auto;\n }\n\n [type='search'] {\n -webkit-appearance: textfield;\n outline-offset: -2px;\n }\n\n ::-webkit-search-decoration {\n -webkit-appearance: none;\n }\n\n ::-webkit-file-upload-button {\n -webkit-appearance: button;\n font: inherit;\n }\n\n summary {\n display: list-item;\n }\n\n blockquote,\n dl,\n dd,\n h1,\n h2,\n h3,\n h4,\n h5,\n h6,\n hr,\n figure,\n p,\n pre {\n margin: 0;\n }\n\n fieldset {\n margin: 0;\n padding: 0;\n }\n\n legend {\n padding: 0;\n }\n\n ol,\n ul,\n menu {\n list-style: none;\n margin: 0;\n padding: 0;\n }\n\n textarea {\n resize: vertical;\n }\n\n input::placeholder,\n textarea::placeholder {\n opacity: 1;\n color: #9ca3af;\n }\n\n button,\n [role='button'] {\n cursor: pointer;\n }\n\n :disabled {\n cursor: default;\n }\n\n img,\n svg,\n video,\n canvas,\n audio,\n iframe,\n embed,\n object {\n display: block;\n }\n\n img,\n video {\n max-width: 100%;\n height: auto;\n }\n\n [hidden] {\n display: none;\n }\n"),lr=({children:t,open:r,onClick:n,...i})=>/*#__PURE__*/e.jsx(S.Transition,{show:r,as:Q.default.Fragment,children:/*#__PURE__*/e.jsxs(S.Dialog,{onClose:n,...i,as:dr,children:[/*#__PURE__*/e.jsx(S.TransitionChild,{as:Q.default.Fragment,enterFrom:"entering",leaveTo:"leaving",children:/*#__PURE__*/e.jsx(cr,{id:"privy-dialog-backdrop","aria-hidden":"true"})}),/*#__PURE__*/e.jsx(ur,{children:/*#__PURE__*/e.jsx(S.TransitionChild,{as:Q.default.Fragment,enterFrom:"entering",leaveTo:"leaving",children:/*#__PURE__*/e.jsx(S.DialogPanel,{as:hr,children:t})})})]})});let cr=/*#__PURE__*/f.styled.div.withConfig({displayName:"Backdrop",componentId:"sc-3cfde0b5-0"})(["position:fixed;inset:0;transition:backdrop-filter 100ms ease;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);&.entering,&.leaving{backdrop-filter:unset;-webkit-backdrop-filter:unset;}"]),dr=/*#__PURE__*/f.styled.div.withConfig({displayName:"DialogWrapper",componentId:"sc-3cfde0b5-1"})(["position:relative;z-index:999999;"]),ur=/*#__PURE__*/f.styled.div.withConfig({displayName:"DialogContainer",componentId:"sc-3cfde0b5-2"})(["position:fixed;inset:0;display:flex;align-items:center;justify-content:center;width:100vw;min-height:100vh;"]);const hr=/*#__PURE__*/f.styled.div.withConfig({displayName:"Panel",componentId:"sc-3cfde0b5-3"})(["padding:0;background:transparent;border:none;width:100%;pointer-events:auto;outline:none;display:block;@media (max-width:440px){opacity:1;transform:translate3d(0,0,0);transition:transform 200ms ease-in;position:fixed;bottom:0;&.entering,&.leaving{opacity:0;transform:translate3d(0,100%,0);transition:transform 150ms ease-in 0ms,opacity 0ms ease 150ms;}}@media (min-width:441px){opacity:1;transition:opacity 100ms ease-in;&.entering,&.leaving{opacity:0;transition-delay:5ms;}margin:auto;width:360px;box-shadow:0px 8px 36px rgba(55,65,81,0.15);border-radius:var(--privy-border-radius-lg);}"]),pr=/*#__PURE__*/f.styled.div.withConfig({displayName:"CenterItem",componentId:"sc-3cfde0b5-4"})(["display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;"]);let yr=()=>{let{ready:t,isModalOpen:n}=l.usePrivyContext(),{headless:i}=y.useAppConfig(),{currentScreen:a}=l.usePrivyModal(),{status:o,execute:s,reset:c,enabled:d}=l.useCaptcha(),u=ir((e=>e.inProgressMfaFlow)),h=()=>ir.setState({inProgressMfaFlow:void 0}),p=n&&a&&a.isCaptchaRequired&&!i&&"ready"===o;return r.useEffect((()=>{p&&s()}),[p]),r.useEffect((()=>{!n&&d&&c()}),[n,d]),a&&!t&&a.isShownBeforeReady?/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{}),/*#__PURE__*/e.jsx(l.RefactorSpacerTop,{}),/*#__PURE__*/e.jsx(pr,{children:/*#__PURE__*/e.jsx(l.Loader,{})}),/*#__PURE__*/e.jsx(l.RefactorSpacerBottom,{}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]}):a||"txn"!==u?a?
|
|
3
|
-
/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.Hide,{$if:!!u,children:/*#__PURE__*/e.jsx(a.component,{})}),"txn"===u&&/*#__PURE__*/e.jsx(nr,{onClose:h}),"auth"===u&&/*#__PURE__*/e.jsx(tr.component,{})]}):null:/*#__PURE__*/e.jsx(nr,{onClose:h})},mr=()=>{let t=r.useRef(null);/*#__PURE__*/return e.jsx(vr,{style:{height:C.useElementHeight(t)},id:"privy-modal-content",children:/*#__PURE__*/e.jsx("div",{ref:t,children:/*#__PURE__*/e.jsx(yr,{})})})};const wr=({open:t})=>{let n=y.useAppConfig(),{gracefulClosePrivyModal:i}=(()=>{let{closePrivyModal:e}=s.usePrivyInternal(),{onUserCloseViaDialogOrKeybindRef:t}=l.usePrivyModal();return{gracefulClosePrivyModal:r.useCallback((()=>{if(!t?.current)return e({shouldCallAuthOnSuccess:!1});t.current()}),[e])}})(),a=ir((e=>e.inProgressMfaFlow));return Et({onMfaRequired:()=>{n.mfa.noPromptOnMfaRequired||ir.setState({inProgressMfaFlow:"txn"})}}),n.render.standalone?/*#__PURE__*/e.jsx(sr,{children:/*#__PURE__*/e.jsx(gr,{id:"privy-modal-content",children:/*#__PURE__*/e.jsx(yr,{})})}):/*#__PURE__*/e.jsx(lr,{open:!(!t&&!a),id:"privy-dialog","aria-label":"log in or sign up","aria-labelledby":"privy-dialog-title",onClick:()=>i(),children:/*#__PURE__*/e.jsx(sr,{children:/*#__PURE__*/e.jsx(mr,{})})})};let gr=/*#__PURE__*/f.styled.div.withConfig({displayName:"ContentWrapper",componentId:"sc-c903accd-0"})(["display:flex;flex-direction:column;text-align:center;font-size:14px;line-height:20px;width:100%;background:var(--privy-color-background);padding:0 16px;"]),vr=/*#__PURE__*/f.styled(gr).withConfig({displayName:"BaseModal",componentId:"sc-c903accd-1"})(["transition:height 150ms ease-out;overflow-x:hidden;overflow-y:auto;scrollbar-width:none;max-height:calc(100svh - 32px);border-radius:var(--privy-border-radius-lg) var(--privy-border-radius-lg) 0 0;box-shadow:0px 0px 36px rgba(55,65,81,0.15);@media (min-width:441px){box-shadow:0px 8px 36px rgba(55,65,81,0.15);border-radius:var(--privy-border-radius-lg);}"]);function fr(t){let n=r.useRef(null),i=r.useRef();return r.useEffect((()=>{i.current?.remove(),i.current=function({botUsername:e,scriptHost:t}){let r=document.createElement("script"),{origin:n}=new URL(t);return r.async=!0,r.src=`${n}/js/telegram-login.js`,r.setAttribute("data-telegram-login",e),r.setAttribute("data-request-access","write"),r.setAttribute("data-lang","en"),r}(t),n.current?.after(i.current)}),[t]),/*#__PURE__*/e.jsx("div",{ref:n,hidden:!0})}const Cr=()=>{let{ready:e}=l.useWallets(),{client:t}=s.usePrivyInternal();return r.useEffect((()=>{let r=()=>{if(!t.connectors||!e)return;let r=t.connectors.wallets.map((e=>({address:e.address,connectorType:e.connectorType,walletClientType:e.walletClientType,connectedAt:e.connectedAt,id:e.meta.id})));l.p.put(y.CONNECTIONS_HISTORY_KEY,r)};return t.connectors?.on("walletsUpdated",r),()=>{t.connectors?.off("walletsUpdated",r)}}),[e,t.connectors]),null};async function Er(e,t,r,n,i,a=!1){let o=a,s=async s=>{if(o&&t&&t.length>0){s===(a?0:1)?i("configureMfa","onMfaRequired",{mfaMethods:t}):n.current?.reject(new l.PrivyIframeError("missing_or_invalid_mfa","MFA verification failed, retry."));let o=await new Promise(((e,t)=>{r.current={resolve:e,reject:t},setTimeout((()=>{let e=new l.PrivyIframeError("mfa_timeout","Timed out waiting for MFA code");n.current?.reject(e),t(e)}),3e5)}));return await e(o)}return await e()},c=null;for(let e=0;e<4;e++)try{c=await s(e),n.current?.resolve(void 0);break}catch(e){if("missing_or_invalid_mfa"!==e.type)throw n.current?.resolve(void 0),e;o=!0}if(null===c){let e=new l.PrivyIframeError("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw n.current?.reject(e),e}return c}var Ar;let Pr=(Ar=0,()=>"id-"+Ar++);function kr(e){return void 0!==e.error}let Tr=new class{enqueue(e,t){this.callbacks[e]=t}dequeue(e,t){let r=this.callbacks[t];if(!r)throw Error(`cannot dequeue ${e} event: no event found for id ${t}`);switch(delete this.callbacks[t],e){case"privy:iframe:ready":case"privy:user-signer:sign":case"privy:wallets:add":case"privy:wallets:import":case"privy:wallets:set-recovery":case"privy:wallets:connect":case"privy:wallets:recover":case"privy:wallets:rpc":case"privy:wallet:create":case"privy:mfa:verify":case"privy:mfa:init-enrollment":case"privy:mfa:submit-enrollment":case"privy:mfa:unenroll":case"privy:mfa:clear":case"privy:auth:unlink-passkey":case"privy:farcaster:init-signer":case"privy:farcaster:sign":case"privy:solana-wallet:create":case"privy:delegated-actions:consent":return r;default:throw Error(`invalid wallet event type ${e}`)}}constructor(){this.callbacks={}}},xr=new Map,br=(e,t)=>"bigint"==typeof t?t.toString():t;function Sr(e,t,r,n){let i=r.contentWindow;if(!i)throw Error("iframe not initialized");let a=((e,t)=>`${e}${JSON.stringify(t,br)}`)(e,t);if("privy:wallet:create"===e){let e=xr.get(a);if(e)return e}let o=new Promise(((r,a)=>{let o=Pr();Tr.enqueue(o,{resolve:r,reject:a}),i.postMessage({id:o,event:e,data:t},n)})).finally((()=>{xr.delete(a)}));return xr.set(a,o),o}function _r(t){let n=y.useIsServerConfigLoaded(),i=r.useRef(null),a=r.useRef(t.mfaMethods),o=y.useEmitPrivyEvent(),[s,c]=r.useState(!1);return r.useEffect((()=>{a.current=t.mfaMethods}),[t.mfaMethods]),r.useEffect((()=>{if(!s)return;let e=i.current;if(!e)return;function r(e){var r;e&&e.origin===t.origin&&"string"==typeof(r=e.data).event&&/^privy:.+/.test(r.event)&&function(e){switch(e.event){case"privy:iframe:ready":let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data);case"privy:user-signer:sign":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:add":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:set-recovery":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:connect":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:recover":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:rpc":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallet:create":let r=Tr.dequeue(e.event,e.id);return kr(e)?r.reject(new l.PrivyIframeError(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallets:import":let n=Tr.dequeue(e.event,e.id);return kr(e)?n.reject(new l.PrivyIframeError(e.error.type,e.error.message)):n.resolve(e.data);case"privy:mfa:verify":let i=Tr.dequeue(e.event,e.id);return kr(e)?i.reject(new l.PrivyIframeError(e.error.type,e.error.message)):i.resolve(e.data);case"privy:mfa:init-enrollment":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:submit-enrollment":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:unenroll":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:clear":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:auth:unlink-passkey":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:solana-wallet:create":let a=Tr.dequeue(e.event,e.id);return kr(e)?a.reject(new l.PrivyIframeError(e.error.type,e.error.message)):a.resolve(e.data);case"privy:farcaster:init-signer":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:farcaster:sign":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:delegated-actions:consent":{let t=Tr.dequeue(e.event,e.id);return kr(e)?t.reject(new l.PrivyIframeError(e.error.type,e.error.message)):t.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}(e.data)}let n={signWithUserSigner:r=>Er((n=>Sr("privy:user-signer:sign",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),addWallet:r=>Er((n=>Sr("privy:wallets:add",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),setRecovery:r=>Er((n=>Sr("privy:wallets:set-recovery",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),connect:r=>Er((n=>Sr("privy:wallets:connect",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),recover:r=>Er((n=>Sr("privy:wallets:recover",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o,!r.recoveryAccessToken&&!r.recoveryPassword&&!r.recoverySecretOverride),rpc:r=>Er((n=>Sr("privy:wallets:rpc",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),create:r=>Sr("privy:wallet:create",r,e,t.origin),importWallet:r=>Sr("privy:wallets:import",r,e,t.origin),createSolana:r=>Er((n=>Sr("privy:solana-wallet:create",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),createDelegatedAction:r=>Sr("privy:delegated-actions:consent",r,e,t.origin),verifyMfa:r=>Er((n=>Sr("privy:mfa:verify",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o,!0),initEnrollMfa:r=>Er((n=>Sr("privy:mfa:init-enrollment",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),submitEnrollMfa:r=>Er((n=>Sr("privy:mfa:submit-enrollment",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),unenrollMfa:r=>Er((n=>Sr("privy:mfa:unenroll",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),clearMfa:r=>Sr("privy:mfa:clear",r,e,t.origin),unlinkPasskeyAccount:r=>Er((n=>Sr("privy:auth:unlink-passkey",{...r,...n},e,t.origin)),a.current,t.mfaPromise,t.mfaSubmitPromise,o),initFarcasterSigner:r=>Sr("privy:farcaster:init-signer",r,e,t.origin),signFarcasterMessage:r=>Sr("privy:farcaster:sign",r,e,t.origin)};window.addEventListener("message",r);let c=new AbortController;return l.invokeUntilSettled((()=>Sr("privy:iframe:ready",{},e,t.origin)),{abortSignal:c.signal}).then((()=>t.onLoad(n)),((...e)=>{console.warn("Privy iframe failed to load: ",...e),t.onLoadFailed()})),()=>{window.removeEventListener("message",r),c.abort()}}),[s]),n?
|
|
4
|
-
/*#__PURE__*/e.jsx("iframe",{ref:i,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},onLoad:()=>c(!0),src:_.constructURL({origin:t.origin,path:`/apps/${t.appId}/embedded-wallets`,query:{caid:t.clientAnalyticsId,client_id:t.appClientId}})}):null}const Ir=({address:e,user:t})=>{let r=t.linkedAccounts.find((t=>"wallet"===t.type&&"privy"===t.walletClientType&&t.address===e));if(!r)throw new s.PrivyClientError("Address to delegate is not associated with current user.");if(!I.isFirstClassChainWallet(r))throw new s.PrivyClientError(`useDelegatedActions is not supported for ${r.chainType} wallets. Use the useSessionSigners hook to provision server side access on behalf of your users.`);return{address:r.address,chainType:r.chainType,walletIndex:r.walletIndex??0}},Ur=({address:e,user:t})=>{let r=t.linkedAccounts.find((t=>"wallet"===t.type&&"privy"===t.walletClientType&&t.address===e));if(!r)throw new s.PrivyClientError("Address to delegate is not associated with current user.");let n=r.imported?r:l.getPrivyPrimaryWallet(t);if(!n)throw new s.PrivyClientError("Unable to determine root address for delegated address.");if(!I.isFirstClassChainWallet(n))throw new s.PrivyClientError(`useDelegatedActions is not supported for ${n.chainType} wallets. Use the useSessionSigners hook to provision server side access on behalf of your users.`);return{address:n.address,chainType:n.chainType,imported:n.imported}},Wr=e=>e.linkedAccounts.filter((e=>"wallet"===e.type&&"privy"===e.walletClientType&&e.delegated));const Rr="popup-privy-oauth",Nr="PRIVY_OAUTH_USE_BROADCAST_CHANNEL";class Or{async authenticate(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");try{return await this.api.post(s.oAuthAuthenticatePath,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:this.meta.codeVerifier,provider:this.meta.provider})}catch(e){throw s.formatApiError(e)}}async link(){if(!this.api)throw new s.PrivyClientError("Auth flow has no API instance");try{return await this.api.post(s.oAuthLinkPath,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:this.meta.codeVerifier,provider:this.meta.provider})}catch(e){throw s.formatApiError(e)}}constructor({authorizationCode:e,stateCode:t,codeVerifier:r,provider:n}){this.meta={authorizationCode:e,stateCode:t,codeVerifier:r,provider:n}}}async function Mr({api:e,requesterAppId:t,providerAppId:r}){let n=(await e.get(`/api/v1/apps/${t}/cross-app/connections`)).connections.find((e=>e.provider_app_id===r));if(!n)throw new s.PrivyClientError("Invalid connected app");return{name:n.provider_app_name,logoUrl:n.provider_app_icon_url||void 0,apiUrl:n.provider_app_custom_api_url,readOnly:n.read_only,customAuthAuthorizeUrl:n.provider_app_custom_auth_authorize_url,customAuthTransactUrl:n.provider_app_custom_auth_transact_url}}const jr=async({user:e,address:t,client:r,request:n,requesterAppId:i,reconnect:a})=>{r.createAnalyticsEvent({eventName:"cross_app_request_started",payload:{address:t,method:n.method}});let l=e?.linkedAccounts.find((e=>"cross_app"===e.type&&(e.embeddedWallets.some((e=>e.address===t))||e.smartWallets.some((e=>e.address===t)))));if(!e||!l)throw r.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Cannot request a signature with this wallet address",address:t}}),new s.PrivyClientError("Cannot request a signature with this wallet address");let c=r.getProviderAccessToken(l.providerApp.id),d=await Mr({api:r.api,requesterAppId:i,providerAppId:l.providerApp.id});if(!c){if(d.readOnly)throw console.error("cannot transact against a read-only provider app"),new s.PrivyClientError("Cannot transact against a read-only provider app");await a({appId:l.providerApp.id,action:"link"})&&(c=r.getProviderAccessToken(l.providerApp.id))}if(!c)throw r.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Transactions require a valid token",address:t}}),new s.PrivyClientError("Transactions require a valid token");let u=new URL(d.customAuthTransactUrl||`${d.apiUrl}/oauth/transact`);u.searchParams.set("token",c||""),u.searchParams.set("request",Fr(n));let h=o.trigger({location:u.href});if(!h)throw r.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Missing token",address:t}}),new s.PrivyClientError("Failed to initialize signature request");return new Promise(((e,i)=>{let a=setTimeout((()=>{d(),i(new s.PrivyClientError("Request timeout")),r.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Request timeout",address:t}})}),12e4),o=setInterval((()=>{h.closed&&(d(),i(new s.PrivyClientError("User rejected request")),r.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"User rejected request",address:t}}))}),300),c=a=>{a.data&&("set"===a.data.token?.action&&void 0!==a.data.token?.value?r.storeProviderAccessToken(l.providerApp.id,a.data.token.value):"clear"===a.data.token?.action&&r.storeProviderAccessToken(l.providerApp.id,null),"PRIVY_CROSS_APP_ACTION_RESPONSE"===a.data.type&&a.data.result&&(d(),e(a.data.result),r.createAnalyticsEvent({eventName:"cross_app_request_success",payload:{address:t,method:n.method}})),"PRIVY_CROSS_APP_ACTION_ERROR"===a.data.type&&a.data.error&&(d(),i(a.data.error),r.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:a.data.error,address:t}})))};window.addEventListener("message",c);let d=()=>{h.close(),clearInterval(o),clearTimeout(a),window.removeEventListener("message",c)}}))};let Fr=e=>JSON.stringify({content:{request:{request:Lr(e,b.toHex)}},timestamp:Date.now(),callbackUrl:window.origin});const Lr=(e,t)=>"bigint"==typeof e?t(e):Array.isArray(e)?e.map((e=>Lr(e,t))):e&&"object"==typeof e?Object.fromEntries(Object.entries(e).map((([e,r])=>[e,Lr(r,t)]))):e,Dr=({passkeys:t,isLoading:r,errorReason:n,success:i,expanded:a,onLinkPasskey:o,onUnlinkPasskey:s,onExpand:c,onBack:d,onClose:u})=>i?/*#__PURE__*/e.jsx(l.ScreenLayout,{title:"Passkeys updated",icon:U.CheckCircle,iconVariant:"success",primaryCta:{label:"Done",onClick:u},onClose:u,watermark:!0}):a?/*#__PURE__*/e.jsx(l.ScreenLayout,{icon:U.FingerprintIcon,title:"Your passkeys",onBack:d,onClose:u,watermark:!0,children:/*#__PURE__*/e.jsx(Br,{passkeys:t,expanded:a,onUnlink:s,onExpand:c})}):/*#__PURE__*/e.jsx(l.ScreenLayout,{icon:U.FingerprintIcon,title:"Set up passkey verification",subtitle:"Verify with passkey",primaryCta:{label:"Add new passkey",onClick:o,loading:r},onClose:u,watermark:!0,helpText:n||void 0,children:0===t.length?/*#__PURE__*/e.jsx(Hr,{}):/*#__PURE__*/e.jsx(qr,{children:/*#__PURE__*/e.jsx(Br,{passkeys:t,expanded:a,onUnlink:s,onExpand:c})})});let qr=/*#__PURE__*/f.styled.div.withConfig({displayName:"ContentContainer",componentId:"sc-d4c46a0c-0"})(["margin-bottom:12px;"]),Br=({passkeys:t,expanded:n,onUnlink:i,onExpand:a})=>{let[o,s]=r.useState([]),c=n?t.length:2,d=e=>e.authenticatorName?e.createdWithBrowser?`${e.authenticatorName} on ${e.createdWithBrowser}`:e.authenticatorName:e.createdWithBrowser?e.createdWithOs?`${e.createdWithBrowser} on ${e.createdWithOs}`:`${e.createdWithBrowser}`:"Unknown device";/*#__PURE__*/return e.jsxs("div",{children:[/*#__PURE__*/e.jsx(Gr,{children:"Your passkeys"}),/*#__PURE__*/e.jsxs(Yr,{children:[t.slice(0,c).map((t=>/*#__PURE__*/e.jsxs(Xr,{children:[/*#__PURE__*/e.jsxs("div",{children:[/*#__PURE__*/e.jsx(Zr,{children:d(t)}),/*#__PURE__*/e.jsxs(Jr,{children:["Last used:"," ",(t.latestVerifiedAt??t.firstVerifiedAt)?.toLocaleString()??"N/A"]})]}),/*#__PURE__*/e.jsx(en,{disabled:o.includes(t.credentialId),onClick:()=>(async e=>{s((t=>t.concat([e]))),await i(e),s((t=>t.filter((t=>t!==e))))})(t.credentialId),children:o.includes(t.credentialId)?/*#__PURE__*/e.jsx(l.ButtonLoader,{}):/*#__PURE__*/e.jsx(U.Trash2,{size:16})})]},t.credentialId))),t.length>2&&!n&&/*#__PURE__*/e.jsx($r,{onClick:a,children:"View all"})]})]})},Hr=()=>/*#__PURE__*/e.jsxs(l.TodoList,{style:{color:"var(--privy-color-foreground)"},children:[/*#__PURE__*/e.jsx(l.TodoItem,{children:"Verify with Touch ID, Face ID, PIN, or hardware key"}),/*#__PURE__*/e.jsx(l.TodoItem,{children:"Takes seconds to set up and use"}),/*#__PURE__*/e.jsx(l.TodoItem,{children:"Use your passkey to verify transactions and login to your account"})]});const zr={component:()=>{let{user:t,unlinkPasskey:n}=l.usePrivyContext(),{linkWithPasskey:i,closePrivyModal:a}=s.usePrivyInternal(),o=t?.linkedAccounts.filter((e=>"passkey"===e.type)),[c,d]=r.useState(!1),[u,h]=r.useState(""),[p,y]=r.useState(!1),[m,w]=r.useState(!1);return r.useEffect((()=>{0===o.length&&w(!1)}),[o.length]),/*#__PURE__*/e.jsx(Dr,{passkeys:o,isLoading:c,errorReason:u,success:p,expanded:m,onLinkPasskey:()=>{d(!0),i().then((()=>y(!0))).catch((e=>{if(e instanceof s.PrivyError){if(e.privyErrorCode===s.PrivyErrorCode.CANNOT_LINK_MORE_OF_TYPE)return void h("Cannot link more passkeys to account.");if(e.privyErrorCode===s.PrivyErrorCode.PASSKEY_NOT_ALLOWED)return void h("Passkey request timed out or rejected by user.")}h("Unknown error occurred.")})).finally((()=>{d(!1)}))},onUnlinkPasskey:async e=>(d(!0),await n(e).then((()=>y(!0))).catch((e=>{e instanceof s.PrivyError&&e.privyErrorCode===s.PrivyErrorCode.MISSING_MFA_CREDENTIALS?h("Cannot unlink a passkey enrolled in MFA"):h("Unknown error occurred.")})).finally((()=>{d(!1)}))),onExpand:()=>w(!0),onBack:()=>w(!1),onClose:()=>a()})}},Kr=/*#__PURE__*/f.styled.div.withConfig({displayName:"DoubleIconWrapper",componentId:"sc-d4c46a0c-1"})(["display:flex;align-items:center;justify-content:center;width:180px;height:90px;border-radius:50%;svg + svg{margin-left:12px;}> svg{z-index:2;color:var(--privy-color-accent) !important;stroke:var(--privy-color-accent) !important;fill:var(--privy-color-accent) !important;}"]);let Vr=/*#__PURE__*/f.css(["&&{width:100%;font-size:0.875rem;line-height:1rem;@media (min-width:440px){font-size:14px;}display:flex;gap:12px;justify-content:center;padding:6px 8px;background-color:var(--privy-color-background);transition:background-color 200ms ease;color:var(--privy-color-accent) !important;:focus{outline:none;box-shadow:none;}}"]);const $r=/*#__PURE__*/f.styled.button.withConfig({displayName:"LinkButton",componentId:"sc-d4c46a0c-2"})(["",""],Vr);let Yr=/*#__PURE__*/f.styled.div.withConfig({displayName:"List",componentId:"sc-d4c46a0c-3"})(["display:flex;flex-direction:column;align-items:stretch;gap:0.8rem;padding:0.5rem 0rem 0rem;flex-grow:1;width:100%;"]),Gr=/*#__PURE__*/f.styled.div.withConfig({displayName:"PasskeyListTitle",componentId:"sc-d4c46a0c-4"})(["line-height:20px;height:20px;font-size:1em;font-weight:450;display:flex;justify-content:flex-beginning;width:100%;"]),Zr=/*#__PURE__*/f.styled.div.withConfig({displayName:"PasskeyItemTitle",componentId:"sc-d4c46a0c-5"})(["font-size:1em;line-height:1.3em;font-weight:500;color:var(--privy-color-foreground-2);padding:0.2em 0;"]),Jr=/*#__PURE__*/f.styled.div.withConfig({displayName:"PasskeyItemSubtitle",componentId:"sc-d4c46a0c-6"})(["font-size:0.875rem;line-height:1rem;color:#64668b;padding:0.2em 0;"]),Xr=/*#__PURE__*/f.styled.div.withConfig({displayName:"PasskeyListItem",componentId:"sc-d4c46a0c-7"})(["display:flex;align-items:center;justify-content:space-between;padding:1em;gap:10px;font-size:0.875rem;line-height:1rem;text-align:left;border-radius:8px;border:1px solid #e2e3f0 !important;width:100%;height:5em;"]),Qr=/*#__PURE__*/f.css([":focus,:hover,:active{outline:none;}display:flex;width:2em;height:2em;justify-content:center;align-items:center;svg{color:var(--privy-color-error);}svg:hover{color:var(--privy-color-foreground-3);}"]),en=/*#__PURE__*/f.styled.button.withConfig({displayName:"PasskeyItemUnlinkButton",componentId:"sc-d4c46a0c-8"})(["",""],Qr);const tn=new Map([[l.FundingMethodSelectionScreen,null],[l.TransferFromWalletScreen,"external"],[l.AwaitingExternalEthereumTransferScreen,"external"],[l.AwaitingEvmToSolBridgingScreen,"external"],[l.AwaitingSolToEvmBridgingScreen,"external"],[l.ManualTransferScreen,"manual"],[l.MoonpayStatusScreen,"moonpay"]]),rn=()=>{let e=y.useAppConfig(),{user:t}=l.usePrivyContext(),{client:n,refreshSessionAndUser:i,walletProxy:a}=s.usePrivyInternal();return{migrate:r.useCallback((async()=>{if("legacy-embedded-wallets-only"===e.embeddedWallets.mode)return{success:!0};if(!t)throw new s.PrivyClientError("User must be authenticated before migrating wallets",s.PrivyErrorCode.MUST_BE_AUTHENTICATED);if(!a)throw new s.PrivyClientError("Cannot connect to wallet proxy");let r=await n.getAccessToken();if(!r)throw new s.PrivyClientError("User must be authenticated before migrating wallets",s.PrivyErrorCode.MUST_BE_AUTHENTICATED);let o=t.linkedAccounts.filter((e=>"wallet"===e.type&&"privy"===e.walletClientType&&I.isFirstClassChainWallet(e)&&!l.getIsUnifiedWallet(e)));if(0===o.length)return{success:!0};let c=o.filter((e=>e.imported)),d=o.filter((e=>!e.imported));if(d.length>0){let e=d.find((e=>"ethereum"===e.chainType&&0===e.walletIndex))??d.find((e=>"solana"===e.chainType&&0===e.walletIndex))??null;if(!e)throw new s.PrivyClientError("Primary wallet not found");let{entropyId:t,entropyIdVerifier:n}=l.toEntropyDetailsFromAccount(e);try{await a.connect({accessToken:r,entropyId:t,entropyIdVerifier:n})}catch(i){if(!l.errorIndicatesRecoveryIsNeeded(i)||"privy"!==e.recoveryMethod)throw i;await a.recover({accessToken:r,entropyId:t,entropyIdVerifier:n})}await a.createDelegatedAction({accessToken:r,rootWallet:{address:e.address,chainType:e.chainType,imported:!1},delegatedWallets:d.map((e=>({address:e.address,chainType:e.chainType,walletIndex:e.walletIndex??0})))})}for(let e of c){let{entropyId:t,entropyIdVerifier:n}=l.toEntropyDetailsFromAccount(e);try{await a.connect({accessToken:r,entropyId:t,entropyIdVerifier:n})}catch(c){if(!l.errorIndicatesRecoveryIsNeeded(c)||"privy"!==e.recoveryMethod)throw c;await a.recover({accessToken:r,entropyId:t,entropyIdVerifier:n})}await a.createDelegatedAction({accessToken:r,rootWallet:{address:e.address,chainType:e.chainType,imported:!0},delegatedWallets:[{address:e.address,chainType:e.chainType,walletIndex:e.walletIndex??0}]})}return await i(),{success:!0}}),[e.embeddedWallets.mode,t,a,n,i])}},nn=({disabled:e})=>{let{migrate:t}=rn(),{user:n}=l.usePrivyContext(),{walletProxy:i}=s.usePrivyInternal();return r.useEffect((()=>{!e&&n&&i&&t().catch((e=>{console.debug("Unable to migrate wallets: ",e)}))}),[n,i,e,t]),null},an=e=>({id:e.id,raw_id:e.rawId,response:{client_data_json:e.response.clientDataJSON,authenticator_data:e.response.authenticatorData,signature:e.response.signature,user_handle:e.response.userHandle},authenticator_attachment:e.authenticatorAttachment,client_extension_results:{app_id:e.clientExtensionResults.appid,cred_props:e.clientExtensionResults.credProps,hmac_create_secret:e.clientExtensionResults.hmacCreateSecret},type:e.type}),on=({providerApp:t,success:n,error:i,onClose:a})=>{let{title:o,subtitle:s}=r.useMemo((()=>n?{title:`Successfully connected with ${t.name}`,subtitle:"You're good to go!"}:i?{title:"Authentication failed",subtitle:i.message}:{title:`Connecting to ${t.name}`,subtitle:`Please check the pop-up from ${t.name} to continue`}),[n,i,t.name]);/*#__PURE__*/return e.jsx(l.ScreenLayout,{title:o,subtitle:s,icon:t.logoUrl,iconVariant:"loading",iconLoadingStatus:{success:n,fail:!!i},onBack:a,watermark:!0})},sn={component:()=>{let t=y.useAppConfig(),{data:n,navigate:i,setModalData:a,onUserCloseViaDialogOrKeybindRef:o}=l.usePrivyModal(),{crossAppAuthFlow:c,updateWallets:d,closePrivyModal:u,createAnalyticsEvent:h}=s.usePrivyInternal(),{logout:p}=C.useLogout(),[m,w]=r.useState({}),g=n?.crossAppAuth,v={id:g.appId,name:g.name,logoUrl:g.logoUrl},f=new s.PrivyClientError(`There was an issue connecting your ${v.name} account. Please try again.`),E=new l.RunEffectOnce((async e=>{if(g.popup)try{let t=await c({appId:e,popup:g.popup,action:g.action});w({data:t})}catch(e){if(e instanceof s.PrivyClientError)w({error:e});else if(e instanceof s.PrivyApiError){if(e.privyErrorCode===s.PrivyErrorCode.ACCOUNT_TRANSFER_REQUIRED&&e.data?.data?.nonce)return a({accountTransfer:{nonce:e.data?.data?.nonce,account:e.data?.data?.subject,displayName:e.data?.data?.account?.displayName,linkMethod:`privy:${v.id}`,embeddedWalletAddress:e.data?.data?.otherUser?.embeddedWalletAddress,oAuthUserInfo:e.data?.data?.otherUser?.oAuthUserInfo}}),void i(l.LinkConflictScreen);g.popup&&g.popup.close(),w({error:f})}else w({error:f})}else w({error:f})})),A=()=>{m.data&&(d(),g.onSuccess(m.data),u({shouldCallAuthOnSuccess:!0,isSuccess:!0})),g.onError(m.error??new s.PrivyClientError("User canceled flow")),u({shouldCallAuthOnSuccess:!1,isSuccess:!1})};return o.current=A,r.useEffect((()=>{v.id.length&&E.execute(v.id)}),[v.id]),r.useEffect((()=>{if(!m.data)return;let e=m.data;if(t.legal.requireUsersAcceptTerms&&!e.hasAcceptedTerms){let e=setTimeout((()=>{i(l.AffirmativeConsentScreen)}),y.DEFAULT_SUCCESS_SCREEN_DURATION_MS);return()=>clearTimeout(e)}if(l.shouldProceedtoEmbeddedWalletCreationFlow(e,t.embeddedWallets)){let e=setTimeout((()=>{a({createWallet:{onSuccess:()=>{},onFailure:e=>{console.error(e),h({eventName:"embedded_wallet_creation_failure_logout",payload:{error:e,provider:`privy:${v.id}`,screen:"CrossAppAuthScreen"}}),p()},callAuthOnSuccessOnClose:!0}}),i(l.EmbeddedWalletOnAccountCreateScreen)}),y.DEFAULT_SUCCESS_SCREEN_DURATION_MS);return()=>clearTimeout(e)}let r=setTimeout(A,y.DEFAULT_SUCCESS_SCREEN_DURATION_MS);return()=>clearTimeout(r)}),[m.data]),/*#__PURE__*/e.jsx(on,{providerApp:v,success:!!m.data,error:m.error,onClose:A})}},ln=({appName:t,address:r,success:n,error:i,onAccept:a,onDecline:o,onClose:s})=>n||i?/*#__PURE__*/e.jsx(l.ScreenLayout,{title:i?"Something went wrong":"Success!",subtitle:i?"Please try again.":`You've successfully granted delegated action permissions to ${t}.`,icon:i?U.AlertCircle:U.CheckCircle,iconVariant:i?"error":"success",onBack:s,watermark:!0}):/*#__PURE__*/e.jsx(l.ScreenLayout,{title:"Enable offline access",subtitle:`By confirming, ${t} will be able to use your wallet for you even when you're not around. You can revoke this later.`,icon:U.CloudUpload,primaryCta:{label:"Accept",onClick:a},secondaryCta:{label:"Not now",onClick:o},onBack:s,watermark:!0,children:/*#__PURE__*/e.jsx(l.WalletInfoCard,{address:r,title:"Wallet"})}),cn={component:()=>{let{data:t}=l.usePrivyModal(),n=y.useAppConfig(),{closePrivyModal:i}=s.usePrivyInternal(),[a,o]=r.useState(!1),[c,d]=r.useState(),{address:u,onDelegate:h,onSuccess:p,onError:m}=t.delegatedActions.consent,w=async()=>{a?p():m(c??new s.PrivyClientError("User declined delegating actions.")),i({shouldCallAuthOnSuccess:!1})};return r.useEffect((()=>{if(!a&&!c)return;let e=setTimeout(w,y.DEFAULT_SUCCESS_SCREEN_LONG_DURATION_MS);return()=>clearTimeout(e)}),[a,c]),/*#__PURE__*/e.jsx(ln,{appName:n.name,address:u,success:a,error:c,onAccept:async()=>{try{await h(),o(!0)}catch(e){d(e)}},onDecline:()=>{w()},onClose:w})}},dn=({appName:t,success:r,error:n,onRevoke:i,onDeny:a,onClose:o})=>r||n?/*#__PURE__*/e.jsx(l.ScreenLayout,{title:n?"Something went wrong":"Success!",subtitle:n?"Please try again.":"You've successfully revoked permissions.",icon:n?U.AlertCircle:U.CheckCircle,iconVariant:n?"error":"success",onBack:o,watermark:!0}):/*#__PURE__*/e.jsx(l.ScreenLayout,{title:"Revoke offline access to wallet",subtitle:`By confirming, ${t} will no longer be able to use this wallet on your behalf when you are not online.`,icon:U.Ban,primaryCta:{label:"Confirm",onClick:i},secondaryCta:{label:"Deny",onClick:a},onBack:o,watermark:!0}),un={component:()=>{let{data:t}=l.usePrivyModal(),n=y.useAppConfig(),{closePrivyModal:i}=s.usePrivyInternal(),[a,o]=r.useState(!1),[c,d]=r.useState(),{onRevoke:u,onSuccess:h,onError:p}=t.delegatedActions.revoke,m=async()=>{a?h():p(c??new s.PrivyClientError("User declined revoking access to their delegated wallet.")),i({shouldCallAuthOnSuccess:!1})};return r.useEffect((()=>{if(!a&&!c)return;let e=setTimeout(m,y.DEFAULT_SUCCESS_SCREEN_LONG_DURATION_MS);return()=>clearTimeout(e)}),[a,c]),/*#__PURE__*/e.jsx(dn,{appName:n.name,success:a,error:c,onRevoke:async()=>{try{await u(),o(!0)}catch(e){d(e)}},onDeny:()=>{m()},onClose:m})}};let hn="#8a63d2";const pn=({appName:t,loading:r,success:i,errorMessage:a,connectUri:o,onBack:s,onClose:c,onOpenFarcaster:d})=>n.isMobile||r?n.isIOS?/*#__PURE__*/e.jsx(l.ScreenLayout,{title:a?a.message:"Add a signer to Farcaster",subtitle:a?a.detail:`This will allow ${t} to add casts, likes, follows, and more on your behalf.`,icon:l.Farcaster,iconVariant:"loading",iconLoadingStatus:{success:i,fail:!!a},primaryCta:o&&d?{label:"Open Farcaster app",onClick:d}:void 0,onBack:s,onClose:c,watermark:!0}):/*#__PURE__*/e.jsx(l.ScreenLayout,{title:a?a.message:"Requesting signer from Farcaster",subtitle:a?a.detail:"This should only take a moment",icon:l.Farcaster,iconVariant:"loading",iconLoadingStatus:{success:i,fail:!!a},onBack:s,onClose:c,watermark:!0,children:o&&n.isMobile&&/*#__PURE__*/e.jsx(yn,{children:/*#__PURE__*/e.jsx(l.OpenLinkButton,{text:"Take me to Farcaster",url:o,color:hn})})}):
|
|
5
|
-
/*#__PURE__*/e.jsx(l.ScreenLayout,{title:"Add a signer to Farcaster",subtitle:`This will allow ${t} to add casts, likes, follows, and more on your behalf.`,onBack:s,onClose:c,watermark:!0,children:/*#__PURE__*/e.jsxs(mn,{children:[/*#__PURE__*/e.jsx(wn,{children:o?/*#__PURE__*/e.jsx(l.QrCode,{url:o,size:275,squareLogoElement:l.Farcaster}):/*#__PURE__*/e.jsx(fn,{children:/*#__PURE__*/e.jsx(l.Loader,{})})}),/*#__PURE__*/e.jsxs(gn,{children:[/*#__PURE__*/e.jsx(vn,{children:"Or copy this link and paste it into a phone browser to open the Farcaster app."}),o&&/*#__PURE__*/e.jsx(W.CopytoClipboardButton,{text:o,itemName:"link",color:hn})]})]})});let yn=/*#__PURE__*/f.styled.div.withConfig({displayName:"MobileLinkContainer",componentId:"sc-75c99bb6-0"})(["margin-top:24px;"]),mn=/*#__PURE__*/f.styled.div.withConfig({displayName:"ContentContainer",componentId:"sc-75c99bb6-1"})(["display:flex;flex-direction:column;align-items:center;gap:24px;"]),wn=/*#__PURE__*/f.styled.div.withConfig({displayName:"QrContainer",componentId:"sc-75c99bb6-2"})(["padding:24px;position:relative;display:flex;align-items:center;justify-content:center;min-height:275px;"]),gn=/*#__PURE__*/f.styled.div.withConfig({displayName:"InstructionsContainer",componentId:"sc-75c99bb6-3"})(["display:flex;flex-direction:column;align-items:center;gap:16px;"]),vn=/*#__PURE__*/f.styled.div.withConfig({displayName:"InstructionText",componentId:"sc-75c99bb6-4"})(["font-size:0.875rem;text-align:center;color:var(--privy-color-foreground-2);"]),fn=/*#__PURE__*/f.styled.div.withConfig({displayName:"LoaderWrapper",componentId:"sc-75c99bb6-5"})(["position:relative;width:82px;height:82px;"]);const Cn={component:()=>{let{lastScreen:t,navigateBack:n,data:i}=l.usePrivyModal(),a=y.useAppConfig(),{requestFarcasterSignerStatus:o,closePrivyModal:c}=s.usePrivyInternal(),[d,u]=r.useState(void 0),[h,p]=r.useState(!1),[m,w]=r.useState(!1),g=r.useRef([]),v=i?.farcasterSigner;r.useEffect((()=>{let e=Date.now(),t=setInterval((async()=>{if(!v?.public_key)return clearInterval(t),void u({retryable:!0,message:"Connect failed",detail:"Something went wrong. Please try again."});"approved"===v.status&&(clearInterval(t),p(!1),w(!0),g.current.push(setTimeout((()=>c({shouldCallAuthOnSuccess:!1,isSuccess:!0})),y.DEFAULT_SUCCESS_SCREEN_DURATION_MS)));let r=await o(v?.public_key),n=Date.now()-e;"approved"===r.status?(clearInterval(t),p(!1),w(!0),g.current.push(setTimeout((()=>c({shouldCallAuthOnSuccess:!1,isSuccess:!0})),y.DEFAULT_SUCCESS_SCREEN_DURATION_MS))):n>3e5?(clearInterval(t),u({retryable:!0,message:"Connect failed",detail:"The request timed out. Try again."})):"revoked"===r.status&&(clearInterval(t),u({retryable:!0,message:"Request rejected",detail:"The request was rejected. Please try again."}))}),2e3);return()=>{clearInterval(t),g.current.forEach((e=>clearTimeout(e)))}}),[]);let f="pending_approval"===v?.status?v.signer_approval_url:void 0;/*#__PURE__*/return e.jsx(pn,{appName:a.name,loading:h,success:m,errorMessage:d,connectUri:f,onBack:t?n:void 0,onClose:c,onOpenFarcaster:()=>{f&&(window.location.href=f)}})}},En=({onClose:t})=>/*#__PURE__*/e.jsx(l.ScreenLayout,{title:"Could not log in with provider",subtitle:"It looks like you're using an in-app browser. To log in, please try again using an external browser.",icon:U.ExternalLink,primaryCta:{label:"Close",onClick:t},watermark:!0}),An={component:()=>{let{closePrivyModal:t}=s.usePrivyInternal();/*#__PURE__*/return e.jsx(En,{onClose:()=>t()})}},Pn=({title:t="Connect your email",subtitle:r="Add your email to your account"})=>/*#__PURE__*/e.jsx(l.ScreenLayout,{title:t,subtitle:r,icon:de.default,watermark:!0,children:/*#__PURE__*/e.jsx(l.BottomPusherContainer,{children:/*#__PURE__*/e.jsx(l.ConnectEmailForm,{stacked:!0})})}),kn={component:()=>{let t=y.useAppConfig();/*#__PURE__*/return e.jsx(Pn,{subtitle:`Add your email to your ${t?.name} account`})}},Tn=({title:t="Connect your phone",subtitle:n="Add your number to your account",onSubmit:i,isSubmitting:a=!1})=>{let[o,s]=r.useState(null),c=async()=>{o?.qualifiedPhoneNumber&&await i(o)};/*#__PURE__*/return e.jsx(l.ScreenLayout,{title:t,subtitle:n,icon:oe.default,primaryCta:{label:a?"Submitting":"Submit",onClick:c,disabled:!o?.isValid||a},watermark:!0,children:/*#__PURE__*/e.jsx(l.ConnectPhoneNumberForm,{onChange:e=>{s(e)},onSubmit:c,noIncludeSubmitButton:!0,hideRecent:!0})})},xn={component:()=>{let{currentScreen:t,data:n,navigate:i,setModalData:a}=l.usePrivyModal(),o=y.useAppConfig(),{initLoginWithSms:c}=s.usePrivyInternal(),[d,u]=r.useState(!1);/*#__PURE__*/return e.jsx(Tn,{subtitle:`Add your number to your ${o?.name} account`,onSubmit:async e=>{u(!0);try{await c({phoneNumber:e.qualifiedPhoneNumber,withPrivyUi:!0}),i(l.AwaitingPasswordlessCodeScreen)}catch(e){a({errorModalData:{error:e,previousScreen:n?.errorModalData?.previousScreen||t||xn}}),i(l.ErrorScreen)}finally{u(!1)}},isSubmitting:d})}},bn=({title:t="Could not connect with wallet",subtitle:r="Please check that Phantom multichain is enabled and try again.",primaryCtaText:n="Try again",secondaryCtaText:i="Cancel",onTryAgain:a,onCancel:o})=>/*#__PURE__*/e.jsx(l.ScreenLayout,{title:t,subtitle:r,icon:U.XCircle,iconVariant:"error",primaryCta:{label:n,onClick:a},secondaryCta:{label:i,onClick:o},watermark:!0}),Sn={component:()=>{let{closePrivyModal:t}=s.usePrivyInternal(),{navigate:r}=l.usePrivyModal();/*#__PURE__*/return e.jsx(bn,{onTryAgain:()=>{r(l.LandingScreen)},onCancel:async()=>{await t()}})}};function _n(){let{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,initEnrollmentWithPasskey:n,submitEnrollmentWithSms:i,submitEnrollmentWithTotp:a,submitEnrollmentWithPasskey:o,unenroll:s,enrollInMfa:c}=r.useContext(l.PrivyContext);return{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,initEnrollmentWithPasskey:n,submitEnrollmentWithSms:i,submitEnrollmentWithTotp:a,submitEnrollmentWithPasskey:o,unenrollWithSms:()=>s("sms"),unenrollWithTotp:()=>s("totp"),unenrollWithPasskey:e=>s("passkey",e),showMfaEnrollmentModal:()=>c(!0),closeMfaEnrollmentModal:()=>c(!1)}}const In=t=>/*#__PURE__*/e.jsxs(Un,{xmlns:"http://www.w3.org/2000/svg",fill:"none",width:"88",height:"89",viewBox:"0 0 88 89",...t,children:[/*#__PURE__*/e.jsx("rect",{y:"0.666016",width:"88",height:"88",rx:"44"}),/*#__PURE__*/e.jsx("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M45.2463 20.9106C44.5473 20.2486 43.4527 20.2486 42.7537 20.9106C37.8798 25.5263 31.3034 28.3546 24.0625 28.3546C23.9473 28.3546 23.8323 28.3539 23.7174 28.3525C22.9263 28.3427 22.2202 28.8471 21.9731 29.5987C20.9761 32.6311 20.4375 35.8693 20.4375 39.2297C20.4375 53.5896 30.259 65.651 43.5482 69.0714C43.8446 69.1477 44.1554 69.1477 44.4518 69.0714C57.741 65.651 67.5625 53.5896 67.5625 39.2297C67.5625 35.8693 67.0239 32.6311 66.0269 29.5987C65.7798 28.8471 65.0737 28.3427 64.2826 28.3525C64.1677 28.3539 64.0527 28.3546 63.9375 28.3546C56.6966 28.3546 50.1202 25.5263 45.2463 20.9106ZM52.7249 40.2829C53.3067 39.4683 53.1181 38.3363 52.3035 37.7545C51.4889 37.1726 50.3569 37.3613 49.7751 38.1759L41.9562 49.1223L38.0316 45.1977C37.3238 44.4899 36.1762 44.4899 35.4684 45.1977C34.7605 45.9056 34.7605 47.0532 35.4684 47.761L40.9059 53.1985C41.2826 53.5752 41.806 53.7671 42.337 53.7232C42.868 53.6792 43.3527 53.4039 43.6624 52.9704L52.7249 40.2829Z"})]});let Un=/*#__PURE__*/f.styled.svg.withConfig({displayName:"StyledSvg",componentId:"sc-59fa943f-0"})(["height:90px;width:90px;> rect{","}> path{fill:white;}"],(e=>"success"===e.color?"fill: var(--privy-color-success);":"fill: var(--privy-color-accent);"));const Wn=({showIntro:t,userMfaMethods:r,appMfaMethods:n,userHasAuthSms:i,isTotpLoading:a,isPasskeyLoading:o,error:s,onClose:c,backFn:d,handleSelectMethod:u,setRemovingMfaMethod:h})=>{let p=r.reduce(((e,t)=>({...e,[t]:!0})),{}),y=n.reduce(((e,t)=>({...e,[t]:!0})),{});/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:t?d:void 0,onClose:c},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(se.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Choose a verification method"}),r.length>0?/*#__PURE__*/e.jsx(kt,{children:"To add or delete verification methods, verification is required."}):/*#__PURE__*/e.jsx(kt,{children:"How would you like to verify your identity?"}),s&&/*#__PURE__*/e.jsx(Lt,{style:{marginTop:"1.25rem"},children:s.message}),/*#__PURE__*/e.jsxs(It,{children:[(y.passkey||p.passkey)&&/*#__PURE__*/e.jsxs(Ut,{children:[/*#__PURE__*/e.jsx(l.LoginMethodButton,{style:{justifyContent:"center"},onClick:()=>u("passkey"),disabled:p.passkey||o,children:o?/*#__PURE__*/e.jsx(l.Loader,{style:{height:24,width:24,borderWidth:2},color:"var(--privy-color-foreground-3)"}):/*#__PURE__*/e.jsxs(Ot,{children:[/*#__PURE__*/e.jsxs(Rt,{children:[/*#__PURE__*/e.jsx(ae.default,{}),"Passkey"]}),p.passkey?/*#__PURE__*/e.jsx(Rn,{color:"green",children:"Enabled"}):/*#__PURE__*/e.jsx(Nt,{$isAccent:!0,children:/*#__PURE__*/e.jsx(ye.default,{})})]})}),p.passkey&&/*#__PURE__*/e.jsx(Wt,{style:{position:"absolute",right:0},onClick:()=>h("passkey"),children:/*#__PURE__*/e.jsx(me.default,{})})]},"passkey"),(y.totp||p.totp)&&/*#__PURE__*/e.jsxs(Ut,{children:[/*#__PURE__*/e.jsx(l.LoginMethodButton,{style:{justifyContent:"center"},disabled:p.totp||a,onClick:()=>u("totp"),children:a?/*#__PURE__*/e.jsx(l.Loader,{style:{height:24,width:24,borderWidth:2},color:"var(--privy-color-foreground-3)"}):/*#__PURE__*/e.jsxs(Ot,{children:[/*#__PURE__*/e.jsxs(Rt,{children:[/*#__PURE__*/e.jsx(ie.default,{}),"Authenticator app"]}),p.totp&&/*#__PURE__*/e.jsx(Rn,{color:"green",children:"Enabled"})]})}),p.totp&&/*#__PURE__*/e.jsx(Wt,{style:{position:"absolute",right:0},onClick:()=>h("totp"),children:/*#__PURE__*/e.jsx(me.default,{})})]},"totp"),(y.sms||p.sms)&&/*#__PURE__*/e.jsxs(Ut,{children:[/*#__PURE__*/e.jsx(l.LoginMethodButton,{disabled:p.sms||i,onClick:()=>u("sms"),children:/*#__PURE__*/e.jsxs(Ot,{children:[/*#__PURE__*/e.jsxs(Rt,{children:[/*#__PURE__*/e.jsx(oe.default,{}),"SMS"]}),p.sms&&/*#__PURE__*/e.jsx(Rn,{color:"green",children:"Enabled"}),i&&/*#__PURE__*/e.jsx(Nt,{children:"Disabled"})]})}),p.sms&&/*#__PURE__*/e.jsx(Wt,{style:{position:"absolute",right:0},onClick:()=>h("sms"),children:/*#__PURE__*/e.jsx(me.default,{})})]},"sms")]}),/*#__PURE__*/e.jsx(Nn,{children:"You can always change your selection later"}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]})};let Rn=/*#__PURE__*/f.styled(l.Chip).withConfig({displayName:"StyledChip",componentId:"sc-5f06df7f-0"})(["margin-right:1.5rem;"]),Nn=/*#__PURE__*/f.styled(Mt).withConfig({displayName:"StyledTerms",componentId:"sc-5f06df7f-1"})(["&&{margin-top:1rem;}text-align:center;"]);const On=({style:t,...r})=>/*#__PURE__*/e.jsxs("svg",{x:0,y:0,width:"65",height:"64",viewBox:"0 0 65 64",style:{height:"64px",width:"65px",...t},xmlns:"http://www.w3.org/2000/svg",...r,children:[/*#__PURE__*/e.jsxs("g",{clipPath:"url(#clip0_113_33841)",children:[/*#__PURE__*/e.jsx("path",{d:"M39.1193 0.943398C34.636 -0.174912 29.9185 -0.334713 25.328 0.656273C24.9732 0.732859 24.7477 1.08253 24.8243 1.43729C24.9009 1.79205 25.2506 2.01756 25.6053 1.94097C30.0015 0.991934 34.53 1.14842 38.8375 2.22802C49.1385 4.80983 57.7129 12.5548 60.9786 22.6718C62.2416 26.5843 62.7781 30.7505 62.8855 35.1167C62.8945 35.4795 63.1958 35.7664 63.5586 35.7575C63.9215 35.7485 64.2083 35.4472 64.1994 35.0843C64.0905 30.6582 63.5477 26.3849 62.2536 22.3432C58.8621 11.7515 49.9005 3.63265 39.1193 0.943398Z"}),/*#__PURE__*/e.jsx("path",{d:"M21.9931 2.93163C22.343 2.83511 22.5484 2.47325 22.4518 2.12339C22.3553 1.77352 21.9935 1.56815 21.6436 1.66466C16.8429 2.98903 10.0898 7.56519 5.91628 13.6786C5.91465 13.681 5.91304 13.6834 5.91145 13.6858C2.24684 19.2083 -0.0503572 26.1484 0.591012 32.8828C0.591623 32.8892 0.592328 32.8956 0.593127 32.902C0.746837 34.1317 1.00488 35.3591 1.26323 36.5879C1.80735 39.1761 2.35282 41.7706 1.92765 44.4064C1.86986 44.7647 2.11347 45.102 2.47177 45.1598C2.83007 45.2176 3.16738 44.974 3.22518 44.6157C3.66961 41.8605 3.11776 39.173 2.56581 36.4851C2.31054 35.2419 2.05525 33.9987 1.89847 32.7486C1.29525 26.3851 3.46802 19.7466 7.00418 14.416C11.0189 8.5373 17.5201 4.16562 21.9931 2.93163Z"}),/*#__PURE__*/e.jsx("path",{d:"M30.6166 4.39985C38.8671 3.89603 47.1159 7.26314 52.6556 13.7139C52.8921 13.9893 52.8605 14.4042 52.5852 14.6406C52.3099 14.8771 51.895 14.8455 51.6585 14.5702C46.3904 8.43576 38.541 5.23144 30.6927 5.71195C30.6899 5.71212 30.6871 5.71227 30.6843 5.71241C20.7592 6.19265 11.4643 12.9257 8.04547 22.3603C7.92183 22.7016 7.54498 22.8779 7.20375 22.7543C6.86253 22.6306 6.68616 22.2538 6.80981 21.9126C10.4114 11.9735 20.1717 4.90702 30.6166 4.39985Z"}),/*#__PURE__*/e.jsx("path",{d:"M54.6576 16.5848C54.4553 16.2836 54.047 16.2033 53.7457 16.4057C53.4444 16.608 53.3642 17.0163 53.5665 17.3176C56.6376 21.8904 57.9074 26.8665 58.4094 32.7717C58.4401 33.1333 58.7582 33.4016 59.1199 33.3708C59.4815 33.3401 59.7497 33.022 59.719 32.6604C59.206 26.6261 57.8965 21.4076 54.6576 16.5848Z"}),/*#__PURE__*/e.jsx("path",{d:"M59.2796 35.4504C59.6419 35.4277 59.9539 35.703 59.9765 36.0653C60.2242 40.0279 60.2265 44.5112 59.7881 47.8243C59.7405 48.1841 59.4102 48.4372 59.0504 48.3896C58.6906 48.342 58.4376 48.0117 58.4852 47.6519C58.9077 44.4586 58.91 40.0704 58.6648 36.1473C58.6421 35.785 58.9174 35.473 59.2796 35.4504Z"}),/*#__PURE__*/e.jsx("path",{d:"M7.05311 25.5432C7.13829 25.1904 6.92135 24.8354 6.56855 24.7502C6.21576 24.665 5.86071 24.882 5.77553 25.2348C5.2932 27.2325 5.0428 29.2847 5.03288 31.3388C5.02266 33.4559 5.41742 35.5225 5.81234 37.5899C6.1354 39.2811 6.45855 40.9728 6.5602 42.6932C6.69373 44.9531 6.21839 47.2163 5.39698 49.3703C5.26766 49.7094 5.43774 50.0891 5.77685 50.2184C6.11596 50.3477 6.4957 50.1777 6.62502 49.8386C7.49325 47.5617 8.01954 45.1092 7.87221 42.6157C7.77126 40.9071 7.44813 39.2252 7.12512 37.5439C6.73099 35.4925 6.33704 33.442 6.34716 31.3451C6.35659 29.3933 6.59455 27.4425 7.05311 25.5432Z"}),/*#__PURE__*/e.jsx("path",{d:"M24.2964 10.94C24.4317 11.2768 24.2683 11.6595 23.9315 11.7947C17.1187 14.5307 12.0027 20.7047 10.959 27.9852C10.523 31.0269 10.9941 34.0398 11.465 37.052C11.7303 38.7483 11.9954 40.4443 12.0985 42.1451C12.3221 45.833 11.902 49.8839 9.50192 53.5696C9.30387 53.8737 8.89677 53.9597 8.59264 53.7617C8.28851 53.5636 8.20251 53.1565 8.40056 52.8524C10.5873 49.4944 11.0012 45.7644 10.7867 42.2246C10.6821 40.499 10.4185 38.7833 10.1552 37.0686C9.68265 33.9923 9.21067 30.9195 9.65804 27.7987C10.7724 20.025 16.221 13.4748 23.4417 10.5751C23.7785 10.4399 24.1612 10.6032 24.2964 10.94Z"}),/*#__PURE__*/e.jsx("path",{d:"M47.3662 14.6814C41.9915 9.64741 34.2017 7.89046 27.122 9.4433C26.7675 9.52105 26.5432 9.87147 26.6209 10.226C26.6987 10.5805 27.0491 10.8048 27.4036 10.7271C34.1075 9.25665 41.4426 10.934 46.4677 15.6406C50.7033 19.6077 53.1628 25.38 53.8066 31.6779C53.8435 32.0389 54.1661 32.3017 54.5272 32.2648C54.8883 32.2279 55.151 31.9053 55.1141 31.5442C54.4456 25.0047 51.8822 18.9111 47.3662 14.6814Z"}),/*#__PURE__*/e.jsx("path",{d:"M54.9766 34.6738C55.3376 34.6368 55.6604 34.8994 55.6975 35.2604C56.3216 41.337 56.0526 47.9003 55.1104 54.2496C55.0571 54.6086 54.7229 54.8565 54.3639 54.8032C54.0049 54.7499 53.7571 54.4157 53.8103 54.0567C54.7394 47.7957 55.001 41.3439 54.39 35.3947C54.353 35.0336 54.6156 34.7109 54.9766 34.6738Z"}),/*#__PURE__*/e.jsx("path",{d:"M32.0659 13.3553C21.9959 13.3553 13.814 21.3892 13.814 31.3219C13.814 32.3829 13.9081 33.4225 14.0876 34.4334C14.1511 34.7907 14.4922 35.029 14.8495 34.9655C15.2069 34.9021 15.4451 34.561 15.3817 34.2036C15.2155 33.2677 15.1283 32.305 15.1283 31.3219C15.1283 22.1352 22.7014 14.6696 32.0659 14.6696C36.2978 14.6696 40.1642 16.1949 43.1319 18.7152C43.4086 18.9501 43.8233 18.9163 44.0582 18.6396C44.2931 18.363 44.2593 17.9483 43.9827 17.7134C40.7847 14.9975 36.6188 13.3553 32.0659 13.3553Z"}),/*#__PURE__*/e.jsx("path",{d:"M45.455 20.1635C45.717 19.9123 46.133 19.921 46.3842 20.183C49.2843 23.2072 50.2126 27.9605 50.8269 31.9494C51.5188 36.4426 51.6244 40.826 51.6244 42.8585C51.6244 43.2214 51.3302 43.5156 50.9673 43.5156C50.6044 43.5156 50.3101 43.2214 50.3101 42.8585C50.3101 40.8589 50.2055 36.5497 49.5279 32.1494C48.9577 28.4462 48.1356 23.9082 45.4356 21.0927C45.1844 20.8307 45.1931 20.4147 45.455 20.1635Z"}),/*#__PURE__*/e.jsx("path",{d:"M51.4576 46.6219C51.4864 46.2601 51.2165 45.9435 50.8547 45.9146C50.493 45.8858 50.1763 46.1557 50.1474 46.5175C49.8247 50.5654 49.403 54.6088 48.5474 58.3439C48.4663 58.6977 48.6874 59.0502 49.0412 59.1312C49.3949 59.2123 49.7474 58.9912 49.8285 58.6374C50.7067 54.8039 51.134 50.6806 51.4576 46.6219Z"}),/*#__PURE__*/e.jsx("path",{d:"M15.1454 36.852C15.5015 36.7819 15.847 37.0137 15.9171 37.3698C17.3066 44.4257 16.3467 50.8355 12.6672 56.4502C12.4682 56.7537 12.0609 56.8385 11.7573 56.6396C11.4538 56.4407 11.369 56.0333 11.5679 55.7298C15.0299 50.4469 15.9617 44.3985 14.6276 37.6238C14.5575 37.2677 14.7893 36.9221 15.1454 36.852Z"}),/*#__PURE__*/e.jsx("path",{d:"M32.0659 17.631C25.5291 17.631 19.1165 22.691 18.462 29.0504C18.1754 31.8345 18.578 34.5769 18.9807 37.3204C19.3323 39.7159 19.684 42.1124 19.5772 44.5381C19.3328 50.0898 17.7039 54.6726 14.905 58.4471C14.6888 58.7386 14.7499 59.1502 15.0414 59.3663C15.333 59.5825 15.7445 59.5214 15.9607 59.2299C18.9293 55.2266 20.6354 50.386 20.8903 44.5959C20.9966 42.1811 20.6438 39.7923 20.2912 37.4051C19.888 34.6752 19.4851 31.9473 19.7694 29.1849C20.3444 23.5983 26.0946 18.9453 32.0659 18.9453C34.851 18.9453 42.057 20.4534 44.3492 27.9205C45.7856 32.5998 46.1774 38.9326 45.8295 45.0849C45.4816 51.2364 44.3994 57.12 42.9442 60.8928C42.8136 61.2314 42.9822 61.6118 43.3208 61.7424C43.6594 61.873 44.0398 61.7044 44.1704 61.3658C45.6929 57.4186 46.7895 51.386 47.1417 45.1591C47.4938 38.9329 47.1068 32.4249 45.6056 27.5348C43.0612 19.2461 35.0851 17.631 32.0659 17.631Z"}),/*#__PURE__*/e.jsx("path",{d:"M21.9529 56.4512C22.2569 56.6494 22.3426 57.0566 22.1444 57.3606C21.7369 57.9854 21.3784 58.6391 21.0199 59.2928C20.6614 59.9465 20.3028 60.6004 19.8953 61.2253C19.697 61.5293 19.2898 61.615 18.9858 61.4167C18.6819 61.2184 18.5962 60.8113 18.7944 60.5073C19.2019 59.8825 19.5604 59.2288 19.9189 58.5751C20.2774 57.9213 20.636 57.2675 21.0435 56.6426C21.2418 56.3386 21.649 56.2529 21.9529 56.4512Z"}),/*#__PURE__*/e.jsx("path",{d:"M27.5799 24.4525C27.8816 24.2508 27.9625 23.8426 27.7608 23.541C27.559 23.2393 27.1509 23.1583 26.8492 23.3601C24.247 25.1006 22.6505 27.494 22.6505 31.0002C22.6505 33.088 23.0203 34.7946 23.3997 36.5449C23.9674 39.1641 24.3524 41.7777 24.2832 44.468C24.1992 47.7349 23.56 50.7201 22.3313 53.564C22.1873 53.8971 22.3407 54.2839 22.6739 54.4278C23.0071 54.5718 23.3938 54.4184 23.5378 54.0852C24.8369 51.0784 25.509 47.9266 25.5971 44.5018C25.6689 41.7062 25.2732 38.9892 24.6845 36.267C24.3042 34.509 23.9648 32.9394 23.9648 31.0002C23.9648 27.9961 25.2863 25.9866 27.5799 24.4525Z"}),/*#__PURE__*/e.jsx("path",{d:"M30.1447 22.1436C32.8717 21.5877 35.8061 22.2746 37.966 24.0228C41.8241 27.1455 42.3372 32.8403 42.753 37.4549L42.7742 37.69C43.3115 43.6385 42.6964 49.4163 41.4575 55.2186C41.3817 55.5736 41.0326 55.7999 40.6776 55.7241C40.3227 55.6483 40.0964 55.2991 40.1722 54.9442C41.3926 49.2288 41.9873 43.5885 41.4652 37.8082C41.4479 37.6169 41.4307 37.4228 41.4133 37.2264L41.4131 37.2235C41.0438 33.0534 40.5812 27.8304 37.1392 25.0444C35.2926 23.5498 32.7599 22.9518 30.4073 23.4314C30.0517 23.5039 29.7046 23.2744 29.6321 22.9188C29.5596 22.5632 29.7891 22.2161 30.1447 22.1436Z"}),/*#__PURE__*/e.jsx("path",{d:"M40.5287 58.4885C40.6183 58.1368 40.4057 57.7791 40.054 57.6896C39.7023 57.6 39.3446 57.8126 39.2551 58.1643C38.8578 59.7247 38.2456 61.1333 37.4695 62.4301C37.2831 62.7415 37.3844 63.145 37.6958 63.3314C38.0072 63.5178 38.4108 63.4165 38.5972 63.1051C39.4336 61.7075 40.0977 60.1816 40.5287 58.4885Z"}),/*#__PURE__*/e.jsx("path",{d:"M37.3152 48.9521C37.6756 48.9948 37.9332 49.3215 37.8906 49.682C37.2699 54.9267 35.8688 59.6042 33.6205 63.6613C33.4446 63.9787 33.0446 64.0934 32.7272 63.9175C32.4097 63.7416 32.295 63.3417 32.4709 63.0242C34.6226 59.1416 35.9811 54.6339 36.5854 49.5275C36.6281 49.1671 36.9548 48.9095 37.3152 48.9521Z"}),/*#__PURE__*/e.jsx("path",{d:"M37.1798 30.6556C36.7242 28.2212 34.6349 26.3591 32.0985 26.3591C28.6638 26.3591 26.254 29.8212 27.1032 33.0422C28.54 38.7279 28.7759 44.2077 27.8032 49.4855L27.8025 49.4893C26.9584 54.228 25.3374 58.4908 23.1263 62.1031C22.9368 62.4127 23.0342 62.8172 23.3437 63.0067C23.6533 63.1962 24.0578 63.0988 24.2473 62.7893C26.5488 59.0292 28.2249 54.6109 29.0961 49.7218C30.106 44.2403 29.8558 38.5684 28.3765 32.7168L28.3748 32.7099C27.7378 30.3005 29.5133 27.6734 32.0985 27.6734C33.9641 27.6734 35.5393 29.0459 35.8871 30.8929C36.8436 36.4411 37.3418 41.5862 36.9871 46.016C36.9581 46.3778 37.2279 46.6945 37.5897 46.7235C37.9515 46.7525 38.2682 46.4827 38.2972 46.1209C38.6649 41.5294 38.1459 36.2576 37.1815 30.6648C37.1809 30.6617 37.1804 30.6586 37.1798 30.6556Z"}),/*#__PURE__*/e.jsx("path",{d:"M30.1376 59.1171C30.4604 59.283 30.5876 59.6792 30.4217 60.002L28.6804 63.3906C28.5145 63.7134 28.1184 63.8406 27.7956 63.6747C27.4728 63.5088 27.3456 63.1127 27.5114 62.7899L29.2527 59.4013C29.4186 59.0785 29.8147 58.9513 30.1376 59.1171Z"}),/*#__PURE__*/e.jsx("path",{d:"M32.5872 31.2892C32.5042 30.9359 32.1505 30.7168 31.7972 30.7998C31.4439 30.8828 31.2247 31.2365 31.3077 31.5898C33.5238 41.0232 33.2194 49.3066 30.5201 56.363C30.3905 56.702 30.5602 57.0819 30.8991 57.2115C31.2381 57.3412 31.618 57.1715 31.7477 56.8326C34.5622 49.475 34.8483 40.9141 32.5872 31.2892Z"})]}),/*#__PURE__*/e.jsx("defs",{children:/*#__PURE__*/e.jsx("clipPath",{id:"clip0_113_33841",children:/*#__PURE__*/e.jsx("rect",{width:"64",height:"64",fill:"white",transform:"translate(0.483887)"})})})]}),Mn=({onClose:t,onReset:n,submitEnrollmentWithPasskey:i})=>{let{user:a}=l.usePrivyContext(),{initLinkWithPasskey:o,linkWithPasskey:c}=s.usePrivyInternal(),d=y.useAppConfig(),[u,h]=r.useState(!1),[p,m]=r.useState(!1),[w,g]=r.useState(null),v=r.useMemo((()=>a?.linkedAccounts.filter((e=>"passkey"===e.type))??[]),[a]),f=async e=>{h(!0);try{await i(e)}catch(e){g(e)}finally{h(!1)}},C=async()=>{m(!0),g(null);try{await o();let e=await c(),t=e?.linkedAccounts.filter((e=>"passkey"===e.type)).map((e=>e.credentialId))??[];await f(t)}catch(e){g(e)}finally{m(!1)}};return 0===v.length||p?/*#__PURE__*/e.jsx(jn,{onReset:n,onClose:t,onClick:C,isCreating:p}):w?/*#__PURE__*/e.jsx(l.ErrorScreenView,{allowlistConfig:d.allowlistConfig,error:w,onBack:()=>g(null),onRetry:()=>g(null)}):/*#__PURE__*/e.jsx(Fn,{passkeys:v,isSubmitting:u,isCreating:p,onReset:n,onClose:t,onSubmitEnrollment:()=>f(v.map((e=>e.credentialId))),onAddPasskey:C})};let jn=({onReset:t,onClose:r,onClick:n,isCreating:i})=>/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:t,onClose:r},"header"),/*#__PURE__*/e.jsx(At,{children:/*#__PURE__*/e.jsxs(Kr,{children:[/*#__PURE__*/e.jsx(Ht,{}),/*#__PURE__*/e.jsx(On,{})]})}),/*#__PURE__*/e.jsx(Pt,{children:"Set up passkey verification"}),/*#__PURE__*/e.jsxs(xt,{children:[/*#__PURE__*/e.jsxs(St,{children:[/*#__PURE__*/e.jsx(bt,{children:/*#__PURE__*/e.jsx(se.default,{})}),"Verify with Touch ID, Face ID, PIN, or hardware key"]}),/*#__PURE__*/e.jsxs(St,{children:[/*#__PURE__*/e.jsx(bt,{children:/*#__PURE__*/e.jsx(ge.default,{})}),"Takes seconds to set up and use"]}),/*#__PURE__*/e.jsxs(St,{children:[/*#__PURE__*/e.jsx(bt,{children:/*#__PURE__*/e.jsx(we.default,{})}),"Use your passkey to verify transactions and login to your account"]})]}),/*#__PURE__*/e.jsx(l.PrimaryButton,{style:{marginTop:"2.25rem"},onClick:n,loading:i,children:"Add a new passkey"}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]}),Fn=({onReset:t,onClose:n,onAddPasskey:i,onSubmitEnrollment:a,passkeys:o,isSubmitting:s,isCreating:c})=>{let[d,u]=r.useState(!1),h=d?o.length:o.length>3?2:3;/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:d?()=>u(!1):t,onClose:n},"header"),!d&&/*#__PURE__*/e.jsx(At,{children:/*#__PURE__*/e.jsxs(Kr,{children:[/*#__PURE__*/e.jsx(Ht,{}),/*#__PURE__*/e.jsx(On,{})]})}),/*#__PURE__*/e.jsx(Pt,{children:"Enable your passkeys for verification"}),/*#__PURE__*/e.jsxs(xt,{children:[o.slice(0,h).map((t=>/*#__PURE__*/e.jsxs(Ln,{children:[/*#__PURE__*/e.jsx(Dn,{children:Bn(t)}),/*#__PURE__*/e.jsxs(qn,{children:["Last used: ",t.latestVerifiedAt?.toLocaleString()]})]},t.credentialId))),!d&&o.length>3&&/*#__PURE__*/e.jsx(Hn,{onClick:()=>u(!0),children:"View All"})]}),/*#__PURE__*/e.jsx(l.PrimaryButton,{style:{marginTop:"1.5rem"},onClick:a,loading:s,children:"Enable passkeys"}),o.length<5&&/*#__PURE__*/e.jsx(Hn,{style:{marginTop:"0.5rem"},onClick:i,disabled:c,children:c?/*#__PURE__*/e.jsx(l.Loader,{style:{height:"1rem",width:"1rem",borderWidth:2}}):"Add new passkey"}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]})},Ln=/*#__PURE__*/f.styled.div.withConfig({displayName:"PasskeyItem",componentId:"sc-23451ce2-0"})(["&&{padding:0.75rem 1rem;text-align:left;border-radius:0.5rem;border:1px solid var(--privy-color-foreground-4);width:100%;}"]),Dn=/*#__PURE__*/f.styled.div.withConfig({displayName:"PasskeyItemTitle",componentId:"sc-23451ce2-1"})(["font-size:0.875rem;line-height:1.375rem;font-weight:500;color:var(--privy-color-foreground-1);"]),qn=/*#__PURE__*/f.styled.div.withConfig({displayName:"PasskeyItemSubtitle",componentId:"sc-23451ce2-2"})(["font-size:0.75rem;font-weight:400;line-height:1.125rem;color:var(--privy-color-foreground-2);"]),Bn=e=>e.authenticatorName?e.createdWithBrowser?`${e.authenticatorName} on ${e.createdWithBrowser}`:e.authenticatorName:e.createdWithBrowser?e.createdWithOs?`${e.createdWithBrowser} on ${e.createdWithOs}`:`${e.createdWithBrowser}`:"Unknown device";const Hn=/*#__PURE__*/f.styled.button.withConfig({displayName:"StyledLink",componentId:"sc-23451ce2-3"})(["&&{width:100%;font-size:0.875rem;line-height:1rem;@media (min-width:440px){font-size:14px;}display:flex;gap:12px;justify-content:center;padding:0.75rem 1rem;background-color:var(--privy-color-background);transition:background-color 200ms ease;color:var(--privy-color-accent);:focus{outline:none;box-shadow:none;}}"]),zn=({appName:t,onComplete:n,onReset:i,onClose:o})=>{let[s,c]=r.useState(""),[d,u]=r.useState(!1),[h,p]=r.useState(null),[m,w]=r.useState("enroll"),{initEnrollmentWithSms:g,submitEnrollmentWithSms:v}=_n(),{data:f}=l.usePrivyModal(),C=y.useAppConfig();function E(){f?.mfaEnrollmentFlow?.onSuccess(),n()}return h?/*#__PURE__*/e.jsx(l.ErrorScreenView,{allowlistConfig:C.allowlistConfig,error:h,onBack:()=>p(null),onRetry:()=>p(null)}):"enroll"===m?/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:i,onClose:o},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(oe.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Set up SMS verification"}),/*#__PURE__*/e.jsxs(kt,{children:["We'll text a verification code to this mobile device whenever you use your ",t," ","wallet."]}),/*#__PURE__*/e.jsxs(Tt,{children:[/*#__PURE__*/e.jsx(l.ConnectPhoneNumberForm,{onSubmit:async function({qualifiedPhoneNumber:e}){try{await g({phoneNumber:e}),c(e),w("verify")}catch(e){p(e)}},hideRecent:!0}),/*#__PURE__*/e.jsxs(Mt,{children:["By providing your mobile number, you agree to receive text messages from ",C?.name,". Some carrier charges may apply"]})]}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]}):d?/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:E},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(ve.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"SMS verification added"}),/*#__PURE__*/e.jsxs(kt,{children:["From now on, you'll enter the verification code sent to your mobile device whenever you use your ",t," wallet."]}),/*#__PURE__*/e.jsx(_t,{children:/*#__PURE__*/e.jsx(l.PrimaryButton,{onClick:E,children:"Done"})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]}):/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:function(){"verify"===m?w("enroll"):i()},onClose:o},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(oe.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Enter enrollment code"}),/*#__PURE__*/e.jsxs(Tt,{children:[/*#__PURE__*/e.jsx(Zt,{onChange:async function(e){try{if(!e)return;await v({phoneNumber:s,mfaCode:e}),u(!0)}catch(e){if(l.errorIndicatesMfaRateLimit(e))throw Error("You have exceeded the maximum number of attempts. Please close this window and try again in 10 seconds.");if(l.errorIndicatesMfaVerificationFailed(e))throw Error("The code you entered is not valid");if(l.errorIndicatesMfaTimeout(e))throw Error("You have exceeded the time limit for code entry. Please try again in 30 seconds.");throw l.errorIndicatesMfaCanceled(e)?Error("Verification canceled"):Error("Unknown error")}}}),/*#__PURE__*/e.jsxs(kt,{children:["To continue, enter the 6-digit code sent to ",/*#__PURE__*/e.jsx("strong",{children:a.lastFourDigits(s)})]})]}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]})},Kn=({size:t,authUrl:r})=>/*#__PURE__*/e.jsx(l.QrCode,{url:r,squareLogoElement:fe.default,size:t,fgColor:"#1F1F1F"}),Vn=({onClose:t,onReset:n,totpInfo:i,submitEnrollmentWithTotp:a,error:o})=>{let[s,c]=r.useState("enroll");return"enroll"===s?/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:n,onClose:t},"header"),/*#__PURE__*/e.jsx(l.Title,{children:"Scan QR code"}),/*#__PURE__*/e.jsx(l.Subtitle,{children:"Open your authenticator app and scan this code to continue"}),/*#__PURE__*/e.jsx(l.CenteredItemWithPadding,{children:/*#__PURE__*/e.jsx(Kn,{authUrl:i.authUrl,size:240})}),/*#__PURE__*/e.jsx(l.LabelXs,{style:{textAlign:"left"},children:"Setup key"}),/*#__PURE__*/e.jsxs(l.Box,{style:{marginTop:"0.25rem"},children:[/*#__PURE__*/e.jsx(C.Column,{children:"•".repeat(16)}),/*#__PURE__*/e.jsx(W.CopytoClipboardButton,{itemName:" ",text:i.secret})]}),/*#__PURE__*/e.jsx(l.PrimaryButton,{style:{marginTop:"1rem"},onClick:function(){c("verify")},children:"Continue"}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]}):/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:function(){"verify"===s?c("enroll"):n()},onClose:t},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(ie.default,{})}),/*#__PURE__*/e.jsx(l.Title,{children:"Enter enrollment code"}),/*#__PURE__*/e.jsx(l.Subtitle,{children:"To continue, enter the 6-digit code generated from your authenticator app"}),/*#__PURE__*/e.jsx(Tt,{children:/*#__PURE__*/e.jsx(Zt,{onChange:async function(e){try{if(!e)return;await a({mfaCode:e})}catch(e){if(l.errorIndicatesMfaRateLimit(e))throw Error("You have exceeded the maximum number of attempts. Please close this window and try again in 10 seconds.");if(l.errorIndicatesMfaVerificationFailed(e))throw Error("The code you entered is not valid");if(l.errorIndicatesMfaTimeout(e))throw Error("You have exceeded the time limit for code entry. Please try again in 30 seconds.");throw l.errorIndicatesMfaCanceled(e)?Error("Verification canceled"):Error("Unknown error")}},errorReasonOverride:o?.message})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]})},$n={component:()=>{let{user:t,enrollInMfa:n,ready:i}=l.usePrivyContext(),[a,o]=r.useState(null),{unenrollWithSms:c,unenrollWithTotp:d,unenrollWithPasskey:u,submitEnrollmentWithTotp:h,initEnrollmentWithPasskey:p,submitEnrollmentWithPasskey:m,initEnrollmentWithTotp:w}=_n(),{data:g,onUserCloseViaDialogOrKeybindRef:v}=l.usePrivyModal(),f=y.useAppConfig(),{closePrivyModal:C}=s.usePrivyInternal(),{promptMfa:E}=rr(),[A,P]=r.useState(!1),[k,T]=r.useState(null),[x,b]=r.useState(null),S=()=>{C({shouldCallAuthOnSuccess:!0}),n(!1),setTimeout((()=>{o(null),T(null)}),500)},[_,I]=r.useState(!1),[U,W]=r.useState();v.current=S;let R=t?.mfaMethods.includes("sms"),N=!!t?.phone,O=t?.mfaMethods.includes("totp"),M=t?.mfaMethods.includes("passkey"),j=R||O||M,F=t?.linkedAccounts.filter((e=>"passkey"===e.type)).map((e=>e.credentialId))??[];function L(){o(null),T(null)}async function D(e=F){I(!0);try{return await p(),await m({credentialIds:e},{removeForLogin:g?.mfaEnrollmentFlow?.shouldUnlinkOnUnenrollMfa}),g?.mfaEnrollmentFlow?.onSuccess(),S()}catch(e){W(e)}finally{I(!1)}}if(r.useEffect((()=>{j&&P(!0)}),[j]),!i||!t||!f/*#__PURE__*/)return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:S},"header"),/*#__PURE__*/e.jsx(At,{children:/*#__PURE__*/e.jsx(In,{})}),/*#__PURE__*/e.jsx(Tt,{children:/*#__PURE__*/e.jsx(l.Loader,{})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]});if("sms"===a)/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:L,onClose:S},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(ue.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Remove SMS verification?"}),/*#__PURE__*/e.jsxs(kt,{children:["MFA adds an extra layer of security to your ",f?.name," account. Make sure you have other methods to secure your account."]}),/*#__PURE__*/e.jsx(_t,{children:/*#__PURE__*/e.jsx(l.PrimaryButton,{$warn:!0,onClick:async function(){o(null);try{await c()}catch(e){o(null)}},children:"Remove"})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]});if("totp"===a)/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:L,onClose:S},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(ue.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Remove authenticator app verification?"}),/*#__PURE__*/e.jsxs(kt,{children:["MFA adds an extra layer of security to your ",f?.name," account. Make sure you have other methods to secure your account."]}),/*#__PURE__*/e.jsx(_t,{children:/*#__PURE__*/e.jsx(l.PrimaryButton,{$warn:!0,onClick:async function(){o(null);try{await d()}catch(e){o(null)}},children:"Remove"})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]});if("passkey"===a){let t=g?.mfaEnrollmentFlow?.shouldUnlinkOnUnenrollMfa??!0;/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:L,onClose:S},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(ue.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Are you sure you want to remove this passkey?"}),/*#__PURE__*/e.jsx(kt,{children:t?"Removing your passkey will remove as both a verification method and a login method.":"Removing your passkey will remove as a verification method."}),/*#__PURE__*/e.jsx(_t,{children:/*#__PURE__*/e.jsx(l.PrimaryButton,{$warn:!0,onClick:async function(){o(null);try{await u({removeForLogin:g?.mfaEnrollmentFlow?.shouldUnlinkOnUnenrollMfa})}catch(e){o(null)}},children:"Remove"})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]})}if(0===g.mfaEnrollmentFlow.mfaMethods.length&&!j)/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:S},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(se.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Add more security"}),/*#__PURE__*/e.jsxs(kt,{children:[f?.name," does not have any verification methods enabled."]}),/*#__PURE__*/e.jsx(_t,{children:/*#__PURE__*/e.jsx(l.PrimaryButton,{onClick:S,children:"Close"})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]});let q=!j&&!A;return q?/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:S},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(se.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Transaction Protection"}),/*#__PURE__*/e.jsx(kt,{children:"Set up transaction protection to add an extra layer of security to your account"}),/*#__PURE__*/e.jsxs(xt,{children:[/*#__PURE__*/e.jsxs(St,{children:[/*#__PURE__*/e.jsx(bt,{children:/*#__PURE__*/e.jsx(he.default,{})}),"Enable 2-Step verification for your ",f?.name," wallet."]}),/*#__PURE__*/e.jsxs(St,{children:[/*#__PURE__*/e.jsx(bt,{children:/*#__PURE__*/e.jsx(pe.default,{})}),"You'll be prompted to authenticate to complete transactions."]})]}),/*#__PURE__*/e.jsxs(_t,{children:[/*#__PURE__*/e.jsx(l.PrimaryButton,{onClick:()=>P(!0),children:"Continue"}),/*#__PURE__*/e.jsx(l.SecondaryButton,{onClick:S,children:"Not now"})]}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]}):"sms"===k?/*#__PURE__*/e.jsx(zn,{appName:f?.name||"Privy",onComplete:S,onReset:L,onClose:S}):"totp"===k&&x?/*#__PURE__*/e.jsx(Vn,{onClose:S,onReset:L,submitEnrollmentWithTotp:({mfaCode:e})=>async function(e){try{return W(void 0),await h({mfaCode:e}),g?.mfaEnrollmentFlow?.onSuccess(),S()}catch(e){W(e)}finally{o(null)}}(e),totpInfo:{...x,appName:f?.name||"Privy"}}):"passkey"===k?/*#__PURE__*/e.jsx(Mn,{onReset:L,onClose:S,submitEnrollmentWithPasskey:D}):/*#__PURE__*/e.jsx(Wn,{showIntro:q,userMfaMethods:t.mfaMethods,appMfaMethods:f.mfa.methods,userHasAuthSms:N,backFn:function(){P(!1)},handleSelectMethod:async function(e){try{await E()}catch(e){return void W(e)}return"totp"===e?(T(e),b(null),void w().then((e=>{b(e)})).catch((()=>{b(null),L()}))):"passkey"===e&&1===F.length?await D():void T(e)},isTotpLoading:"totp"===k&&!x,isPasskeyLoading:_,error:U,onClose:S,setRemovingMfaMethod:async e=>{try{await E()}catch(e){return void W(e)}o(e)}})}},Yn=({providerName:t,ProviderLogo:r,success:n,errorMessage:i,onRetry:a})=>{let o=n?`Successfully connected with ${t}`:i?i.message:`Verifying connection to ${t}`;/*#__PURE__*/return e.jsx(l.ScreenLayout,{title:o,subtitle:n?"You're good to go!":i?i.detail:"Just a few moments more",icon:r,iconVariant:"loading",iconLoadingStatus:{success:n,fail:!!i},secondaryCta:i?.retryable&&a?{label:"Retry",onClick:a}:void 0,watermark:!0})},Gn={component:()=>{let{authenticated:t,logout:n,ready:i,user:a}=l.usePrivyContext(),{setModalData:o,navigate:c,resetNavigation:d}=l.usePrivyModal(),u=y.useAppConfig(),{getAuthMeta:h,initLoginWithOAuth:p,loginWithOAuth:m,updateWallets:w,setReadyToTrue:g,closePrivyModal:v,createAnalyticsEvent:f}=s.usePrivyInternal(),[C,E]=r.useState(!1),[A,P]=r.useState(void 0),k=h()?.provider||"google",{name:T,component:x}=Re(k,u.customOAuthProviders);return r.useEffect((()=>{m(k).then((()=>{E(!0),g(!0)})).catch((e=>{if(g(!1),e?.privyErrorCode===s.PrivyErrorCode.ALLOWLIST_REJECTED)return P(void 0),d(),void c(l.AllowlistRejectionScreen);if(e?.privyErrorCode===s.PrivyErrorCode.USER_LIMIT_REACHED)return console.error(new s.PrivyUserLimitReachedError(e).toString()),P(void 0),d(),void c(l.UserLimitReachedScreen);if(e?.privyErrorCode===s.PrivyErrorCode.USER_DOES_NOT_EXIST)return P(void 0),d(),void c(l.AccountNotFoundScreen);if(e?.privyErrorCode===s.PrivyErrorCode.ACCOUNT_TRANSFER_REQUIRED&&e.data?.data?.nonce)return P(void 0),d(),o({accountTransfer:{nonce:e.data?.data?.nonce,account:e.data?.data?.subject,displayName:e.data?.data?.account?.displayName,linkMethod:h()?.provider,embeddedWalletAddress:e.data?.data?.otherUser?.embeddedWalletAddress,oAuthUserInfo:e.data?.data?.otherUser?.oAuthUserInfo}}),void c(l.LinkConflictScreen);let{retryable:t,detail:r}=function(e,t,r){let n={detail:"",retryable:!1},i=l.e(t);if(e?.privyErrorCode===s.PrivyErrorCode.LINKED_TO_ANOTHER_USER&&(n.detail="This account has already been linked to another user."),e?.privyErrorCode===s.PrivyErrorCode.INVALID_CREDENTIALS&&(n.retryable=!0,n.detail="Something went wrong. Try again."),e.privyErrorCode===s.PrivyErrorCode.OAUTH_USER_DENIED&&(n.detail=`Retry and check ${i} to finish connecting your account.`,n.retryable=!0),e?.privyErrorCode===s.PrivyErrorCode.TOO_MANY_REQUESTS&&(n.detail="Too many requests. Please wait before trying again."),e?.privyErrorCode===s.PrivyErrorCode.TOO_MANY_REQUESTS&&e.message.includes("provider rate limit")){let e=Re(t,r).name;n.detail=`Request limit reached for ${e}. Please wait a moment and try again.`}if(e?.privyErrorCode===s.PrivyErrorCode.OAUTH_ACCOUNT_SUSPENDED){let e=Re(t,r).name;n.detail=`Your ${e} account is suspended. Please try another login method.`}return e?.privyErrorCode===s.PrivyErrorCode.CANNOT_LINK_MORE_OF_TYPE&&(n.detail="You cannot authorize more than one account for this user."),e?.privyErrorCode===s.PrivyErrorCode.OAUTH_UNEXPECTED&&t.startsWith("privy:")&&(n.detail="Something went wrong. Please try again."),n}(e,k,u.customOAuthProviders);P({retryable:t,detail:r,message:"Authentication failed"})})).finally((()=>{l.stripUrlOAuthParamsAndRemoveStateCode()}))}),[T,k]),r.useEffect((()=>{if(i&&t&&C&&a){if(u?.legal.requireUsersAcceptTerms&&!a.hasAcceptedTerms){let e=setTimeout((()=>{c(l.AffirmativeConsentScreen)}),y.DEFAULT_SUCCESS_SCREEN_DURATION_MS);return()=>clearTimeout(e)}if(l.shouldProceedtoEmbeddedWalletCreationFlow(a,u.embeddedWallets)){let e=setTimeout((()=>{o({createWallet:{onSuccess:()=>{},onFailure:e=>{console.error(e),f({eventName:"embedded_wallet_creation_failure_logout",payload:{error:e,provider:k,screen:"OAuthStatusScreen"}}),n()},callAuthOnSuccessOnClose:!0}}),c(l.EmbeddedWalletOnAccountCreateScreen)}),y.DEFAULT_SUCCESS_SCREEN_DURATION_MS);return()=>clearTimeout(e)}{let e=setTimeout((()=>v({shouldCallAuthOnSuccess:!0,isSuccess:!0})),y.DEFAULT_SUCCESS_SCREEN_DURATION_MS);return w(),()=>clearTimeout(e)}}}),[i,t,C,a]),/*#__PURE__*/e.jsx(Yn,{providerName:T,ProviderLogo:x,success:C,errorMessage:A,onRetry:A?.retryable?()=>{l.stripUrlOAuthParamsAndRemoveStateCode(),p(k),P(void 0)}:void 0})}},Zn=/*#__PURE__*/r.forwardRef(((t,n)=>{let[i,a]=r.useState(""),[o,c]=r.useState(""),[d,u]=r.useState(!1),{authenticated:h,user:p}=l.usePrivyContext(),{initUpdateEmail:m}=s.usePrivyInternal(),{navigate:w,setModalData:g,currentScreen:v}=l.usePrivyModal(),{enabled:f,token:C}=l.useCaptcha(),E=y.useAppConfig(),A=l.validateEmail(i)&&(E.disablePlusEmails&&i.includes("+")?(o||c("Please enter a valid email address without a '+'."),!1):(o&&c(""),!0)),P=d||!A,k=()=>{!f||C||h?(async e=>{if(!p?.email)throw Error("User is required to have an email address to update it.");u(!0);try{await m({oldAddress:p.email.address,newAddress:i,captchaToken:e}),w(l.AwaitingPasswordlessCodeScreen)}catch(e){g({errorModalData:{error:e,previousScreen:v||l.LandingScreen}}),w(l.ErrorScreen)}u(!1)})(C):(g({captchaModalData:{callback:e=>{if(!p?.email)throw Error("User is required to have an email address to update it.");return m({oldAddress:p.email.address,newAddress:i,captchaToken:e})},userIntentRequired:!1,onSuccessNavigateTo:l.AwaitingPasswordlessCodeScreen,onErrorNavigateTo:l.ErrorScreen}}),w(l.CaptchaScreen))};/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsxs(Jn,{children:[o&&/*#__PURE__*/e.jsx(l.ErrorMessage,{style:{marginTop:"0.25rem",textAlign:"left"},children:o}),/*#__PURE__*/e.jsxs(Xn,{$error:!!o,children:[/*#__PURE__*/e.jsx(l.LoginMethodIconWrapper,{children:/*#__PURE__*/e.jsx(U.Mail,{})}),/*#__PURE__*/e.jsx("input",{ref:n,id:"email-input",type:"email",placeholder:"your@email.com",onChange:e=>a(e.target.value),onKeyUp:e=>{"Enter"===e.key&&k()},value:i,autoComplete:"email"}),t.stacked?null:/*#__PURE__*/e.jsx(l.EmbeddedButton,{isSubmitting:d,onClick:k,disabled:P,children:"Submit"})]})]}),t.stacked?/*#__PURE__*/e.jsx(l.PrimaryButton,{loadingText:null,loading:d,disabled:P,onClick:k,style:{width:"100%"},children:"Submit"}):null]})}));let Jn=l.InputContainerForm,Xn=l.EmailUpdateForm;const Qn=({title:t="Update your email",subtitle:r="Add the email address you'd like to use going forward. We'll send you a confirmation code"})=>/*#__PURE__*/e.jsx(l.ScreenLayout,{title:t,subtitle:r,icon:de.default,watermark:!0,children:/*#__PURE__*/e.jsx(l.BottomPusherContainer,{children:/*#__PURE__*/e.jsx(Zn,{stacked:!0})})}),ei={component:()=>/*#__PURE__*/e.jsx(Qn,{})},ti=({title:t="Update your phone number",subtitle:n="Add the phone number you'd like to use going forward. We'll send you a confirmation code",onSubmit:i,isSubmitting:a=!1})=>{let[o,s]=r.useState(null);/*#__PURE__*/return e.jsx(l.ScreenLayout,{title:t,subtitle:n,icon:oe.default,primaryCta:{label:a?"Submitting":"Update",onClick:async()=>{o?.qualifiedPhoneNumber&&await i(o)},disabled:!o?.isValid||a},watermark:!0,children:/*#__PURE__*/e.jsx(l.ConnectPhoneNumberForm,{onChange:e=>{s(e)},onSubmit:async()=>{},noIncludeSubmitButton:!0,hideRecent:!0})})},ri={component:()=>{let{currentScreen:t,data:n,navigate:i,setModalData:a}=l.usePrivyModal(),{user:o}=l.usePrivyContext(),{initUpdatePhone:c}=s.usePrivyInternal(),[d,u]=r.useState(!1);/*#__PURE__*/return e.jsx(ti,{onSubmit:async e=>{u(!0);try{if(!o?.phone?.number)throw Error("User is required to have an phone number to update it.");await c(o?.phone?.number,e.qualifiedPhoneNumber),i(l.AwaitingPasswordlessCodeScreen)}catch(e){a({errorModalData:{error:e,previousScreen:n?.errorModalData?.previousScreen||t||xn}}),i(l.ErrorScreen)}finally{u(!1)}},isSubmitting:d})}},ni=g.create((()=>({ethereum:[]}))),ii=()=>ni.getState().ethereum;function ai({subscribe:e,getExternalJwt:t,enabled:n=!0,onAuthenticated:i,onUnauthenticated:a,onError:o}){let{client:l,onCustomAuthAuthenticated:c}=s.usePrivyInternal(),{logout:d,authenticated:u,ready:h}=I.usePrivy();if(!l)throw new s.PrivyClientError("`useSyncJwtBasedAuthState` must be used within a `PrivyProvider`");let[p,y]=r.useState({status:"initial"}),m=r.useRef(),w=r.useRef(!1),g=r.useRef(t);r.useEffect((()=>{g.current=t}),[t]);let v=r.useRef(i);r.useEffect((()=>{v.current=i}),[i]);let f=r.useRef(a);r.useEffect((()=>{f.current=a}),[a]);let C=r.useRef(o);return r.useEffect((()=>{C.current=o}),[o]),r.useEffect((()=>{if(!n||!h)return;let t=async()=>{if(!w.current){w.current=!0;try{y({status:"loading"});let e=await g.current();if(void 0!==m.current&&m.current===e)return void y({status:"done"});if(!e)return u&&(await d(),f.current?.()),m.current=e,void y({status:"done"});l.startAuthFlow(new lt(e));let{user:t,isNewUser:r=!1}=await l.authenticate();if(!t)throw new s.PrivyClientError("Failed to sync with custom auth provider");v.current?.({user:t,isNewUser:r}),c(t,r),m.current=e,y({status:"done"})}catch(e){if(console.warn(e),await d().catch((()=>{})),f.current?.(),e instanceof s.PrivyApiError&&e.privyErrorCode===s.PrivyErrorCode.LINKED_TO_ANOTHER_USER)return y({status:"initial"}),void setTimeout((()=>{t()}),0);C.current?.(e),y({status:"error",error:e})}finally{w.current=!1}}};return t(),e(t)}),[e,l,c,u,d,n,h]),n?{state:p}:{state:{status:"not-enabled"}}}let oi=g.create((()=>({jwtAuthFlowState:{status:"not-enabled"}})));function si({customAuth:e}){let{jwtAuthFlowState:t}=function({customAuth:e}){let t=y.useEmitPrivyEvent(),n=r.useRef(),i=r.useCallback((e=>(n.current=e,()=>{n.current=void 0})),[]),a=e?.getCustomAccessToken??(()=>Promise.resolve(void 0)),{state:o}=ai({enabled:!0===e?.enabled,subscribe:i,getExternalJwt:a,onAuthenticated:({user:e,isNewUser:r})=>{t("login","onComplete",{user:e,isNewUser:r,wasAlreadyAuthenticated:!1,loginMethod:"custom",loginAccount:null}),t("customAuth","onAuthenticated",{user:e})},onUnauthenticated:()=>{t("customAuth","onUnauthenticated")},onError:e=>{t("login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR)}});return r.useEffect((()=>{(async()=>{e&&!e.isLoading&&n.current?.()})()}),[e?.enabled,e?.getCustomAccessToken,e?.isLoading]),{jwtAuthFlowState:o}}({customAuth:e});return r.useEffect((()=>{oi.setState({jwtAuthFlowState:t})}),[t]),null}const li=/*#__PURE__*/r.createContext(!1);let ci,di,ui,hi,pi,yi;async function mi(){return ci?ci.getAccessToken():Promise.resolve(l.p.get(y.PRIVY_ACCESS_TOKEN_STORAGE_KEY)||l.p.get(y.CUSTOMER_ACCESS_TOKEN_STORAGE_KEY)||null)}const wi=(e,t)=>di(e,t),gi=(e,t)=>ui(e,t),vi=(e,t)=>hi(e,t),fi=(e,t)=>pi(e,t),Ci=e=>yi(e);let Ei=c=>{let d=c.client,u=c.privy,h=l.usePlugins(),p=y.useAppConfig();l.useExternalWalletListings(l.shouldFetchWcRegistryListings(p?.appearance.walletList??[]));let[m,w]=r.useState(!1),g=ir((e=>e.inProgressMfaFlow)),[v,f]=r.useState(!1),[C,E]=r.useState(!1),[A,P]=r.useState(null),k=ni((e=>e.ethereum)),[T,x]=r.useState(void 0),[b,S]=r.useState(!1),[_,U]=r.useState(null),[R,N]=r.useState(!1),[O,M]=r.useState({status:"disconnected",connectedWallet:null,connectError:null,connector:null,connectRetry:s.notImplemented}),[j,F]=r.useState({status:"initial"}),[L,D]=r.useState({status:"initial"}),[q,B]=r.useState({status:"initial"}),[H,z]=r.useState({status:"initial"}),[K,V]=r.useState({status:"initial"}),[$,Y]=r.useState({status:"initial"}),[G,Z]=r.useState(null),J=y.useIsServerConfigLoaded(),[X,Q]=r.useState({}),[ee,te]=r.useState(null),re=r.useRef(null),[ne,ie]=r.useState(!1),[ae,oe]=r.useState(!1),se=r.useRef(null),le=r.useRef(null),ce=r.useRef(y.privyEventsDefault),[de,ue]=r.useState(!1);d.onStoreCustomerAccessToken=e=>{e&&y.emitPrivyEvent(ce,"accessToken","onAccessTokenGranted",{accessToken:e})},d.onDeleteCustomerAccessToken=()=>{P(null),E(!1),y.emitPrivyEvent(ce,"accessToken","onAccessTokenRemoved")};let he=r.useRef(null),pe=r.useRef(null),ye=r.useRef(!1),me=({showWalletUIs:e})=>ye.current?ye.current:void 0!==e?!e:!p.embeddedWallets.showWalletUIs,we=e=>{U(e),setTimeout((()=>{w(!0)}),15)};r.useEffect((()=>{if(!A)return void d.connectors?.removeEmbeddedWalletConnectors();let e=l.getPrivyEthereumWallet(A),t=l.getPrivyEthereumHDWallets(A),r=l.getImportedPrivyEthereumWallets(A);e&&t.length||d.connectors?.removeEmbeddedWalletConnectors(),r.length||d.connectors?.removeImportedWalletConnectors(),d.connectors?G?(e&&d.connectors.addEmbeddedWalletConnectors({walletProxy:G,user:A,embeddedWallets:t,defaultChain:p.defaultChain,appId:c.appId,privyClient:u}),r.forEach((e=>d.connectors?.addImportedWalletConnector(G,e.address,p.defaultChain,c.appId)))):console.debug("Failed to add embedded wallet connector: Wallet proxy not initialized"):console.debug("Failed to add embedded wallet connector: Client connectors not initialized")}),[G,A]),r.useEffect((()=>{G&&re.current?.(G)}),[G]);let ge=r.useCallback(((e,t)=>{P(e),S(t),E(!0),oe(!0)}),[]);r.useEffect((()=>{ae&&G&&A&&(async()=>{let e=l.shouldCreateEmbeddedEthWallet(A,p.embeddedWallets.ethereum.createOnLogin),t=l.shouldCreateEmbeddedSolWallet(A,p.embeddedWallets.solana.createOnLogin),r=await mi();if(r){if(e&&t){let e=await G.create({accessToken:r});return await G.createSolana({accessToken:r,ethereumAddress:e?.address}),void oe(!1)}if(t)return await G.createSolana({accessToken:r,ethereumAddress:l.getPrivyEthereumWallet(A)?.address}),await Ke.refreshSessionAndUser(),void oe(!1);if(e)return await G.create({accessToken:r}),void oe(!1)}})().catch(console.error)}),[ae&&G&&A]),r.useEffect((()=>{if(p.externalWallets.solana.connectors)return p.externalWallets.solana.connectors.onMount(),()=>p.externalWallets.solana.connectors?.onUnmount()}),[p.externalWallets.solana.connectors]),r.useEffect((()=>{!v&&J&&async function(){let e,r=ve(),n=fe(),i=t.createStore();d.initializeConnectorManager({walletConnectCloudProjectId:p.walletConnectCloudProjectId,rpcConfig:p.rpcConfig,chains:p.chains,defaultChain:p.defaultChain,store:i,walletList:p.appearance.walletList,shouldEnforceDefaultChainOnConnect:p.shouldEnforceDefaultChainOnConnect,externalWalletConfig:p.externalWallets,appName:p.name??"Privy",walletChainType:p.appearance.walletChainType,setBaseAccountSdk:x}),d.connectors?.on("connectorInitialized",(()=>{e&&clearTimeout(e);let t=d.connectors.walletConnectors.length,r=d.connectors.walletConnectors.reduce(((e,t)=>e+(t.initialized?1:0)),0);r===t?ue(!0):e=setTimeout((()=>{console.debug({message:"Unable to initialize all expected connectors before timeout",initialized:r,expected:t}),ue(!0)}),1500)})),d.connectors?.initialize().then((()=>{Ie()}));let a=await d.getAuthenticatedUser(),o=!!a;p.legal.requireUsersAcceptTerms&&a&&!a.hasAcceptedTerms?(await d.logout(),Ke.setReadyToTrue(!0),y.emitPrivyEvent(ce,"logout","onSuccess")):(p.customAuth?.enabled||(E(!!a),a&&y.emitPrivyEvent(ce,"login","onComplete",{user:a,isNewUser:!1,wasAlreadyAuthenticated:!0,loginMethod:null,loginAccount:null}),P(a)),r?pe.current=o?"link":"login":n&&!o?(pe.current="login",Q({telegramAuthModalData:{seamlessAuth:!0}}),we(l.TelegramAuthScreen)):Ke.setReadyToTrue(!!a))}()}),[d,ee,v,J]),r.useEffect((()=>{if(v){if(!A||!A.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType)))return void ie(!!G);if([...k].some((e=>"privy"===e.walletClientType)))return void ie(!0);ie(!!G)}}),[v,A,k,G]),r.useEffect((()=>{d.connectors?.setWalletList(p.appearance.walletList)}),[p.appearance.walletList.join()]);let ve=()=>{let e=Ne();return e.inProgress&&e.popupFlow?window.opener.location.origin!==window.location.origin?void window.opener.postMessage({type:"PRIVY_OAUTH_ERROR",error:"Origins between parent and child windows do not match."}):"error"===e.authorizationCode?void window.opener.postMessage({type:"PRIVY_OAUTH_ERROR",error:"Something went wrong. Try again."}):void window.opener.postMessage({type:"PRIVY_OAUTH_RESPONSE",stateCode:e.stateCode,authorizationCode:e.authorizationCode}):(e.inProgress&&function(e){return e.startsWith("privy:")}(e.provider)&&!e.popupFlow&&(new BroadcastChannel(Rr).postMessage({type:"PRIVY_OAUTH_RESPONSE",stateCode:e.stateCode,authorizationCode:e.authorizationCode}),window.close()),!!e.inProgress&&!!e.withPrivyUi&&(d.startAuthFlow(new _e({...e,customOAuthRedirectUrl:p.customOAuthRedirectUrl})),we(Gn),!0))},fe=()=>{let e=l.detectCompletingTelegramFlow();if(!e||!p.loginMethods.telegram||!p.loginConfig.telegramAuthConfiguration?.seamlessAuthEnabled)return;let t=new l.TelegramAuthFlow;return d.startAuthFlow(t),"login-url"===e.flowType&&(t.meta.telegramWebAppData=void 0,t.meta.telegramAuthResult=e.authData),"web-app"===e.flowType&&(t.meta.telegramAuthResult=void 0,t.meta.telegramWebAppData=e.authData),!0},Ce=async(e,t,r,n)=>{if("solana_adapter"!==e)Ee(await(d.connectors?.createEthereumWalletConnector({connectorType:e,walletClientType:t}))||null,t,r,n);else{let e=d.connectors?.findSolanaWalletConnector(t);if(!e)return;Ee(e,t,r,n)}};async function Ee(e,t,r,n){if(!e)return M({status:"disconnected",connectedWallet:null,connectError:new s.PrivyConnectorError("Unable to connect to wallet."),connector:null,connectRetry:s.notImplemented}),n?.(null,r);M({status:"disconnected",connectedWallet:null,connectError:null,connector:e,connectRetry:s.notImplemented}),e instanceof l.WalletConnectV2WalletConnector&&t&&await e.resetConnection(t),M({connector:e,status:"connecting",connectedWallet:null,connectError:null,connectRetry:()=>Ee(e,t,r,n)});try{let t=await e.connect({showPrompt:!0});if((!t||l.isBaseConnectedEthereumWallet(t))&&p.shouldEnforceDefaultChainOnConnect&&!p.chains.find((e=>e.id===Number(t?.chainId.replace("eip155:",""))))&&("wallet_connect_v2"!==t?.connectorType||"metamask"!==t?.walletClientType)){M((t=>({...t,connector:e,status:"switching_to_supported_chain",connectedWallet:null,connectError:null,connectRetry:s.notImplemented})));try{await(t?.switchChain(p.defaultChain.id)),t&&(t.chainId=l.formatChainIdToCAIP2(i.toHex(p.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${p.defaultChain.id}`)}}return M((e=>({...e,status:"connected",connectedWallet:t,connectError:null,connectRetry:s.notImplemented}))),t&&y.emitPrivyEvent(ce,"connectWallet","onSuccess",{wallet:t}),n?.(t,r)}catch(e){return e instanceof s.PrivyError?(console.warn(e.cause?e.cause:e.message),y.emitPrivyEvent(ce,"connectWallet","onError",e.privyErrorCode||s.PrivyErrorCode.GENERIC_CONNECT_WALLET_ERROR)):(console.warn(e),y.emitPrivyEvent(ce,"connectWallet","onError",s.PrivyErrorCode.UNKNOWN_CONNECT_WALLET_ERROR)),M((t=>({...t,status:"disconnected",connectedWallet:null,connectError:e}))),n?.(null,r)}}let Te=async(e,t,r)=>{if(null===e||!l.isBaseConnectedEthereumWallet(e))return;let n=new l.SiweFlow(d,e,t,r);d.startAuthFlow(n)},xe=async(e,t,r,n="plain")=>{let i=h(l.SOLANA_LEDGER_PLUGIN_ID);if("transaction"===n&&!i)throw new s.PrivyClientError("useSolanaLedger plugin hook must be mounted");if(null===e||!l.isBaseConnectedSolanaWallet(e))return;let a=new l.SiwsFlow(e,d,t,r,n,i);d.startAuthFlow(a)},Ie=()=>{let e=new URLSearchParams(window.location.search),t=e.get("privy_connector"),r=e.get("privy_wallet_client"),n="true"===e.get("privy_connect_only");if(!t||!r)return;let i=l.getWalletConfigForConnector({connectorType:t,walletClientType:r});if(!i||!i.isInstalled)return we(Sn);if(!d.connectors)throw new s.PrivyClientError("Connector not initialized");we(n?l.ConnectOnlyStatusScreen:l.ConnectionStatusScreen);let a=new URL(window.location.href);a.searchParams.delete("privy_connector"),a.searchParams.delete("privy_wallet_client"),a.searchParams.delete("privy_connect_only"),window.history.pushState({},"",a),Ce(t,r,void 0,n?void 0:"solana_adapter"===t?xe:Te)};r.useEffect((()=>{v&&C&&null===A&&d.getAuthenticatedUser().then(P)}),[v,C,A,d]);let Ue=e=>{if(!C)throw y.emitPrivyEvent(ce,"linkAccount","onError",s.PrivyErrorCode.MUST_BE_AUTHENTICATED,{linkMethod:e}),new s.PrivyClientError("User must be authenticated before linking an account.")},We=e=>{if(!C||!A)return!1;if("privy"===e.walletClientType)return!0;for(let t of A.linkedAccounts)if("wallet"===t.type&&t.address===e.address&&"privy"!==t.walletClientType)return!0;return!1},Re=()=>{ni.setState((e=>{let t=d.connectors?.wallets.filter(l.isBaseConnectedEthereumWallet).map((e=>({...e,linked:We(e),loginOrLink:async()=>{if(!await e.isConnected())throw new s.PrivyClientError("Wallet is not connected");if("embedded"===e.connectorType&&"privy"===e.walletClientType)throw new s.PrivyClientError("Cannot link or login with embedded wallet");(async e=>{let t;if(!d.connectors)throw new s.PrivyClientError("Connector not initialized");t="ethereum"===e.type?d.connectors.findWalletConnector(e.connectorType,e.walletClientType)||null:d.connectors.findSolanaWalletConnector(e.walletClientType)||null,M((r=>({...r,connector:t,status:"connected",connectedWallet:e,connectError:null,connectRetry:s.notImplemented}))),p.captchaEnabled&&!C?(Q({captchaModalData:{callback:t=>l.isBaseConnectedEthereumWallet(e)?Te(e,t):xe(e,t),userIntentRequired:!1,onSuccessNavigateTo:l.ConnectionStatusScreen,onErrorNavigateTo:l.ErrorScreen}}),we(l.CaptchaScreen)):(l.isBaseConnectedEthereumWallet(e)?await Te(e):await xe(e),we(l.ConnectionStatusScreen))})(e)},fund:async t=>{await Ke.fundWallet(e.address,t)},unlink:async()=>{if(!C)throw new s.PrivyClientError("User is not authenticated.");if("embedded"===e.connectorType&&"privy"===e.walletClientType)throw new s.PrivyClientError("Cannot unlink an embedded wallet");P(await d.unlinkEthereumWallet(e.address))}})))||[];return l.areWalletArraysEqual(e.ethereum,t)?{}:{ethereum:t}}))};r.useEffect((()=>{Re()}),[A?.linkedAccounts,C,v]),r.useEffect((()=>{if(v){if(!d.connectors)throw new s.PrivyClientError("Connector not initialized");Re(),d.connectors.on("walletsUpdated",Re)}}),[v]),r.useEffect((()=>{[...p.loginMethodsAndOrder?.primary??[],...p.loginMethodsAndOrder?.overflow??[]].filter((e=>e.startsWith("privy:"))).forEach((e=>d.getCrossAppProviderDetails(e.replace("privy:",""))))}),[!!d]);let Fe=({transaction:e,sponsor:t,uiOptions:r,fundWalletConfig:n,address:o,signOnly:h})=>new Promise((async(m,w)=>{let{requesterAppId:g}=r||{},v=h?"signTransaction":"sendTransaction",f=o?l.getPrivyWalletWithAddress(A,o):l.getPrivyEthereumWallet(A);if(!f&&o){let r=l.getConnectedWalletWithAddress(ii(),o);if(r){if(t)throw new s.PrivyClientError("Cannot sponsor transactions for externally connected wallet.");try{let t=await r.getEthereumProvider(),n={...e,from:o,chainId:e.chainId||Number(r.chainId.replace("eip155:","")),value:void 0!==e.value?i.toHex(e.value):void 0},a=await t.request({method:"sendTransaction"===v?"eth_sendTransaction":"eth_signTransaction",params:[n]});return y.emitPrivyEvent(ce,v,"onSuccess",{hash:a}),void m({hash:a})}catch(e){return y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.TRANSACTION_FAILURE),void w(e??new l.PrivyProviderRpcError("Unable to "+v+e))}}}if(!f)return y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.EMBEDDED_WALLET_NOT_FOUND),void w(new s.PrivyClientError("No embedded or connected wallet found for address."));if(!C||!A)return y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.MUST_BE_AUTHENTICATED),void w(Error("User must be authenticated before signing with a Privy wallet"));let E=f.address,P=f.walletIndex??0,{entropyId:k,entropyIdVerifier:T}=l.getEntropyDetailsForUser(A,f),x=Ve.wallets.find((e=>"privy"===e.walletClientType&&i.getAddress(e.address)===i.getAddress(E)));if(!x)return y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.EMBEDDED_WALLET_NOT_FOUND),void w(Error("Must have a Privy wallet before signing"));let b=await x.getEthereumProvider(),S=await b.request({method:"eth_chainId"}),_=e.chainId?Number(e.chainId):I.extractChainIdFromCAIP2(S);(e=>{if(!p.chains.map((e=>e.id)).includes(e))throw new s.PrivyConnectorError(`Chain ID ${e} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,s.PrivyErrorCode.UNSUPPORTED_CHAIN_ID)})(_);let U={...e,from:e.from??E,chainId:_},W=await mi();if(!W||!G)return y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.EMBEDDED_WALLET_NOT_FOUND),void w(Error("Must have valid access token and Privy wallet to send transaction"));let R=l.getPublicClient(U.chainId,p.chains,p.rpcConfig,{appId:c.appId}),N=l.getIsUnifiedWallet(f),O=async({transactionRequest:e})=>{try{let r;if(!await Ke.recoverEmbeddedWallet({address:E}))throw y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.UNKNOWN_CONNECT_WALLET_ERROR),w(Error("Unable to connect to wallet")),Error("Unable to connect to wallet");if(t){let t=await(async({transactionRequest:e})=>{if(!N)throw new s.PrivyClientError("Sponsoring is only supported for wallets on the TEE stack");if(h)throw new s.PrivyClientError("Cannot sponsor a sign transaction request");let t=e=>null==e?void 0:i.toHex(e),r=await a.rpc(u,(async({message:e})=>await G.signWithUserSigner({accessToken:W,requesterAppId:g,message:e})),{chain_type:"ethereum",method:"eth_sendTransaction",caip2:l.formatChainIdToCAIP2(i.toHex(e.chainId)),sponsor:!0,params:{transaction:{from:e.from,to:e.to,chain_id:t(e.chainId),data:i.isHex(e.data)?e.data?e.data:i.toHex(Uint8Array.from(e.data)):void 0,value:t(e.value)}},wallet_id:f.id});if(r.data&&"hash"in r.data)return r.data.hash;throw new l.PrivyProviderRpcError("Unable to sign transaction")})({transactionRequest:e});return y.emitPrivyEvent(ce,"sendTransaction","onSuccess",{hash:t}),t}if(N){let t=e=>null==e?void 0:i.toHex(e),n=await a.rpc(u,(async({message:e})=>await G.signWithUserSigner({accessToken:W,requesterAppId:g,message:e})),{chain_type:"ethereum",method:"eth_signTransaction",params:{transaction:{from:e.from,to:e.to,nonce:t(e.nonce),chain_id:t(e.chainId),data:i.isHex(e.data)?e.data?e.data:i.toHex(Uint8Array.from(e.data)):void 0,value:t(e.value),type:e.type,gas_limit:t(e.gasLimit??e.gas),gas_price:t(e.gasPrice??e.gas),max_fee_per_gas:t(e.maxFeePerGas),max_priority_fee_per_gas:t(e.maxPriorityFeePerGas)}},wallet_id:f.id});if(!n.data||!("signed_transaction"in n.data))throw new l.PrivyProviderRpcError("Unable to sign transaction");r=n.data.signed_transaction}else r=await async function({accessToken:e,entropyId:t,entropyIdVerifier:r,transactingWalletIndex:n,walletProxy:i,transactionRequest:a,requesterAppId:o}){return(await i.rpc({entropyId:t,entropyIdVerifier:r,hdWalletIndex:n??0,chainType:"ethereum",accessToken:e,requesterAppId:o,request:{method:"eth_signTransaction",params:[a]}})).response.data}({accessToken:W,entropyId:k,entropyIdVerifier:T,transactingWalletIndex:P,walletProxy:G,transactionRequest:e,requesterAppId:g});if(h)return y.emitPrivyEvent(ce,"signTransaction","onSuccess",{signature:r}),r;{let e=await R.sendRawTransaction({serializedTransaction:r});return y.emitPrivyEvent(ce,"sendTransaction","onSuccess",{hash:e}),e}}catch(e){throw y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.TRANSACTION_FAILURE),e}};if(me({showWalletUIs:r?.showWalletUIs})){let e=h||t?U:await l.prepareTransactionRequest(U,R,U.from);try{let t=await O({transactionRequest:e});h?y.emitPrivyEvent(ce,"signTransaction","onSuccess",{signature:t}):y.emitPrivyEvent(ce,"sendTransaction","onSuccess",{hash:t}),m({hash:t})}catch(e){y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.TRANSACTION_FAILURE),w(e)}}else{let e={connectingWalletAddress:E,recoveryMethod:f.recoveryMethod,entropyId:k,entropyIdVerifier:T,onCompleteNavigateTo:l.SendTransactionScreen,isUnifiedWallet:N,onFailure:e=>{y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.UNKNOWN_CONNECT_WALLET_ERROR),w(e)}},i=(e=>!!e.fundingConfig&&I.filterSupportedOptions(e.fundingConfig.options).length>=1)(p)?I.prepareFundingModalData({address:E,appConfig:p,fundWalletConfig:n,methodScreen:l.FundingMethodSelectionScreen,chainIdOverride:U.chainId,comingFromSendTransactionScreen:!0}):void 0;Q({connectWallet:e,sendTransaction:{transactionRequest:U,transactingWalletIndex:P,transactingWalletAddress:E,entropyId:k,entropyIdVerifier:T,signOnly:h,scanTransaction:async()=>{let e=await l.prepareTransactionRequest(U,R,U.from);return await d.scanTransaction({metadata:{domain:p.embeddedWallets.transactionScanning.domain},chain_id:e.chainId.toString(),request:{method:"eth_sendTransaction",params:[{from:e.from,to:e.to,value:e.value?.toString(),gas:e.gas?.toString(),gasPrice:e.gasPrice?.toString(),nonce:e.nonce?.toString(),data:e.data}]}})},getIsSponsored:async()=>!!t,onConfirm:({transactionRequest:e})=>O({transactionRequest:e}),onSuccess:e=>{h?y.emitPrivyEvent(ce,"signTransaction","onSuccess",{signature:e.hash}):y.emitPrivyEvent(ce,"sendTransaction","onSuccess",{hash:e.hash}),m(e)},onFailure:e=>{y.emitPrivyEvent(ce,v,"onError",s.PrivyErrorCode.TRANSACTION_FAILURE),w(e)},uiOptions:r||{},fundWalletConfig:n,requesterAppId:g},funding:i}),we(l.EmbeddedWalletConnectingScreen)}}));function Le(){return new Promise((async(e,t)=>{let r=await mi();if(!r||!G)throw Error("Must have valid access token to enroll in MFA");try{await G.verifyMfa({accessToken:r}),e()}catch(e){t(e)}}))}let De=e=>e?.linkedAccounts.filter((e=>null!==e.latestVerifiedAt&&!("wallet"===e.type&&"privy"===e.walletClientType))).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime()))[0],qe=e=>{let t=A?.linkedAccounts.filter((t=>t.type===e)).length??0,{displayName:r,loginMethod:n}=l.toDisplayFromAccountType(e);if("passkey"===e&&t>=5||"passkey"!==e&&t>=1)throw y.emitPrivyEvent(ce,"linkAccount","onError",s.PrivyErrorCode.CANNOT_LINK_MORE_OF_TYPE,{linkMethod:n}),new s.PrivyClientError(`User already has an account of type ${r} linked.`)};async function Be({showAutomaticRecovery:e=!1,legacySetWalletPasswordFlow:t=!1}){U(null);let r=t?"setWalletPassword":"setWalletRecovery";if(!C||!A)throw y.emitPrivyEvent(ce,r,"onError",s.PrivyErrorCode.MUST_BE_AUTHENTICATED),Error("User must be authenticated before adding recovery method to Privy wallet");let n=l.getPrivyPrimaryWallet(A);if(!n||!G)throw y.emitPrivyEvent(ce,r,"onError",s.PrivyErrorCode.EMBEDDED_WALLET_NOT_FOUND),Error("Must have a Privy wallet to add a recovery method");let i=l.getIsUnifiedWallet(n);if(i)throw y.emitPrivyEvent(ce,r,"onError",s.PrivyErrorCode.UNSUPPORTED_WALLET_TYPE),new s.PrivyClientError("User owned wallet recovery is only supported for on-device execution and this app uses TEE execution. Learn more https://docs.privy.io/recipes/tee-wallet-migration-guide");try{await Le()}catch(e){throw y.emitPrivyEvent(ce,r,"onError",s.PrivyErrorCode.MISSING_MFA_CREDENTIALS),e}return new Promise(((a,o)=>{let c="user-passcode"===n.recoveryMethod,d=l.toEmbeddedWalletSetRecoveryScreen({walletAction:"update",availableRecoveryMethods:p.embeddedWallets.userOwnedRecoveryOptions,legacySetWalletPasswordFlow:t,isResettingPassword:c,showAutomaticRecovery:e}),{entropyId:u,entropyIdVerifier:h}=l.getEntropyDetailsForUser(A),m={recoveryMethod:n.recoveryMethod,connectingWalletAddress:n.address,onCompleteNavigateTo:d,shouldForceMFA:!1,entropyId:u,isUnifiedWallet:i,entropyIdVerifier:h,onFailure:e=>{y.emitPrivyEvent(ce,r,"onError",s.PrivyErrorCode.UNKNOWN_CONNECT_WALLET_ERROR),o(e)}};Q({setWalletPassword:{onSuccess:e=>{y.emitPrivyEvent(ce,r,"onSuccess",{method:"user-passcode",wallet:e}),a(e)},onFailure:e=>{y.emitPrivyEvent(ce,r,"onError",s.PrivyErrorCode.USER_EXITED_SET_PASSWORD_FLOW),o(e)},callAuthOnSuccessOnClose:!1},recoverWallet:{entropyId:u,entropyIdVerifier:h,onFailure:o},connectWallet:m,recoverySelection:{isInAccountCreateFlow:!1,isResettingPassword:c,shouldCreateEth:!1,shouldCreateSol:!1}}),we(l.EmbeddedWalletConnectingScreen)}))}async function He({appId:e,action:t}){let r=await mi();if("link"===t&&!r)throw y.emitPrivyEvent(ce,"linkAccount","onError",s.PrivyErrorCode.MUST_BE_AUTHENTICATED,{linkMethod:`privy:${e}`}),new s.PrivyClientError("User must be authenticated before linking an account.");if("login"===t&&r)throw y.emitPrivyEvent(ce,"login","onError",s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),new s.PrivyClientError("Attempted to log in, but user is already logged in. Use a `link` helper instead.");he.current=`privy:${e}`,pe.current=t;let n=o.trigger();return d.createAnalyticsEvent({eventName:"cross_app_auth_started",payload:{providerAppId:e}}),new Promise((async(r,i)=>{let{name:a,logoUrl:o}=await Mr({api:d.api,providerAppId:e,requesterAppId:p.id});Q({crossAppAuth:{appId:e,name:a,logoUrl:o,action:t,popup:n,onSuccess:r,onError:i}}),we(sn)}))}let ze={ready:v,authenticated:C,user:A,walletConnectors:d.connectors||null,connectWallet:e=>{e&&"target"in e&&e&&(e=void 0),Q({externalConnectWallet:{walletList:e?.walletList&&e?.walletList.length>0?e.walletList:void 0,walletChainType:e?.walletChainType,description:e?.description,hideHeader:e?.hideHeader}}),we(l.ConnectOnlyLandingScreen)},linkWallet:e=>{e&&"target"in e&&e&&(e=void 0),Ue("siwe"),he.current="siwe",pe.current="link",Q({...X,externalConnectWallet:{...X.externalConnectWallet,walletList:e?.walletList,walletChainType:e?.walletChainType,description:e?.description||`Link a wallet to your ${p?.name} account`}}),we(l.AuthenticateWithWalletScreen)},startCrossAppAuthFlow:He,linkEmail:()=>{Ue("email"),qe("email"),he.current="email",pe.current="link",we(kn)},linkPhone:()=>{Ue("sms"),qe("phone"),he.current="sms",pe.current="link",we(xn)},linkGoogle:async()=>{Ue("google"),qe("google_oauth"),pe.current="link",await Ke.initLoginWithOAuth("google")},linkTwitter:async()=>{Ue("twitter"),qe("twitter_oauth"),pe.current="link",await Ke.initLoginWithOAuth("twitter")},linkTwitch:async()=>{Ue("twitch"),qe("twitch_oauth"),pe.current="link",await Ke.initLoginWithOAuth("twitch")},linkDiscord:async()=>{Ue("discord"),qe("discord_oauth"),pe.current="link",await Ke.initLoginWithOAuth("discord")},linkGithub:async()=>{Ue("github"),qe("github_oauth"),pe.current="link",await Ke.initLoginWithOAuth("github")},linkSpotify:async()=>{Ue("spotify"),qe("spotify_oauth"),pe.current="link",await Ke.initLoginWithOAuth("spotify")},linkInstagram:async()=>{Ue("instagram"),qe("instagram_oauth"),pe.current="link",await Ke.initLoginWithOAuth("instagram")},linkTiktok:async()=>{Ue("tiktok"),qe("tiktok_oauth"),pe.current="link",await Ke.initLoginWithOAuth("tiktok")},linkLine:async()=>{Ue("line"),qe("line_oauth"),pe.current="link",await Ke.initLoginWithOAuth("line")},linkLinkedIn:async()=>{Ue("linkedin"),qe("linkedin_oauth"),pe.current="link",await Ke.initLoginWithOAuth("linkedin")},linkApple:async()=>{Ue("apple"),qe("apple_oauth"),pe.current="link",await Ke.initLoginWithOAuth("apple")},linkPasskey:async()=>{Ue("passkey"),qe("passkey"),await Ke.initLinkWithPasskey(),we(zr)},linkTelegram:async e=>{if(Ue("telegram"),qe("telegram"),pe.current="link",he.current="telegram",e?.launchParams)if(e.launchParams.initDataRaw){let t=new l.TelegramAuthFlow;d.startAuthFlow(t),t.meta.telegramAuthResult=void 0,t.meta.telegramWebAppData=l.convertInitDataRawToTelegramWebAppData(e.launchParams.initDataRaw),Q({telegramAuthModalData:{seamlessAuth:!0}}),we(l.TelegramAuthScreen)}else y.emitPrivyEvent(ce,"linkAccount","onError",s.PrivyErrorCode.INVALID_DATA,{linkMethod:"telegram"});else await Ke.initLoginWithTelegram();we(l.TelegramAuthScreen)},linkFarcaster:async()=>{Ue("farcaster"),qe("farcaster"),await Ke.initLoginWithFarcaster(),pe.current="link",he.current="farcaster",we(l.FarcasterConnectStatusScreen)},updateEmail:()=>{if(Ue("email"),!A?.email)throw new s.PrivyClientError("User does not have an email linked to their account.");pe.current="update",he.current="email",we(ei)},updatePhone:()=>{if(Ue("sms"),!A?.phone)throw new s.PrivyClientError("User does not have a phone number linked to their account.");pe.current="update",he.current="sms",we(ri)},login:async e=>{e&&"target"in e&&e&&(e=void 0);let t="Attempted to log in, but user is already logged in. Use a `link` helper instead.";if(!v){let e=await new Promise((e=>{te((t=>e.bind(t)))}));if(te(null),e)return void console.warn(t)}!A||A.isGuest?(pe.current="login",Q({login:e}),we(l.LandingScreen)):console.warn(t)},connectOrCreateWallet:async()=>{v||(await new Promise((e=>{te((()=>e))})),te(null)),C?console.warn("User must be unauthenticated to `connectOrCreateWallet`"):(pe.current="connect-or-create",we(l.ConnectOrCreateScreen))},logout:async()=>{if(pe.current=null,he.current=null,A&&d.clearProviderAcccessTokens(A),U(null),await d.logout(),A&&G)try{await G.clearMfa({userId:A.id})}catch(e){}P(null),E(!1),D({status:"initial"}),B({status:"initial"}),F({status:"initial"}),z({status:"initial"}),V({status:"initial"}),Y({status:"initial"}),y.emitPrivyEvent(ce,"logout","onSuccess"),w(!1),l.p.del(y.CLIENT_ANALYTICS_ID_KEY),l.p.del(y.getGuestCredentialStorageKey(p.id))},getAccessToken:r.useCallback((async()=>{let e=await d.getCustomerAccessToken();return e&&!C&&E(!0),e}),[d,C]),unlinkWallet:async e=>{let t;return P(t=e.startsWith("0x")?await d.unlinkEthereumWallet(e):await d.unlinkSolanaWallet(e)),t},unlinkEmail:async e=>{let t=await d.unlinkEmail(e);return P(t),t},unlinkPhone:async e=>{let t=await d.unlinkPhone(e);return P(t),t},unlinkGoogle:async e=>{let t=await d.unlinkOAuth("google",e);return P(t),t},unlinkTwitter:async e=>{let t=await d.unlinkOAuth("twitter",e);return P(t),t},unlinkTwitch:async e=>{let t=await d.unlinkOAuth("twitch",e);return P(t),t},unlinkDiscord:async e=>{let t=await d.unlinkOAuth("discord",e);return P(t),t},unlinkGithub:async e=>{let t=await d.unlinkOAuth("github",e);return P(t),t},unlinkSpotify:async e=>{let t=await d.unlinkOAuth("spotify",e);return P(t),t},unlinkInstagram:async e=>{let t=await d.unlinkOAuth("instagram",e);return P(t),t},unlinkTiktok:async e=>{let t=await d.unlinkOAuth("tiktok",e);return P(t),t},unlinkLine:async e=>{let t=await d.unlinkOAuth("line",e);return P(t),t},unlinkLinkedIn:async e=>{let t=await d.unlinkOAuth("linkedin",e);return P(t),t},unlinkApple:async e=>{let t=await d.unlinkOAuth("apple",e);return P(t),t},unlinkFarcaster:async e=>{let t=await d.unlinkFarcaster(e);return P(t),t},unlinkTelegram:async e=>{let t=await d.unlinkTelegram(e);return P(t),t},unlinkPasskey:async e=>{let t=await mi();if(!t)throw Error("Must have valid access token to enroll in MFA");if(!G)throw Error("Wallet proxy not initialized.");let r=p.passkeys.shouldUnenrollMfaOnUnlink;await G.unlinkPasskeyAccount({credentialId:e,accessToken:t,removeAsMfa:r});let n=await d.getAuthenticatedUser();return P(n),n},unlinkCrossAppAccount:async({subject:e})=>{let t=A?.linkedAccounts.find((t=>"cross_app"===t.type&&t.subject===e))?.providerApp;if(!t)throw new s.PrivyClientError("Invalid subject");d.storeProviderAccessToken(t.id,null);let r=await d.unlinkOAuth(`privy:${t.id}`,e);return P(r),r},setWalletRecovery:async e=>Be({legacySetWalletPasswordFlow:!1,showAutomaticRecovery:e?.showAutomaticRecovery??!1}),setWalletPassword:async()=>Be({legacySetWalletPasswordFlow:!0,showAutomaticRecovery:!1}),signMessage:(e,t)=>new Promise((async(r,n)=>{let{requesterAppId:o}=t?.uiOptions||{},c=e.message,h=t?.address?l.getPrivyWalletWithAddress(A,t.address):l.getPrivyEthereumWallet(A);if(!h&&void 0!==t?.address){let e=l.getConnectedWalletWithAddress(ii(),t.address);if(e)try{let t=await e.getEthereumProvider(),n=await t.request({method:"personal_sign",params:[c,e.address]});return y.emitPrivyEvent(ce,"signMessage","onSuccess",{signature:n}),void r({signature:n})}catch(e){return y.emitPrivyEvent(ce,"signMessage","onError",s.PrivyErrorCode.UNABLE_TO_SIGN),void n(e??new l.PrivyProviderRpcError("Unable to sign message"))}}if(!h)throw new s.PrivyClientError("No embedded or connected wallet found for address.");if(!C||!A)return y.emitPrivyEvent(ce,"signMessage","onError",s.PrivyErrorCode.MUST_BE_AUTHENTICATED),void n(Error("User must be authenticated before signing with a Privy wallet"));let p=h.address,m=h.walletIndex??0,{entropyId:w,entropyIdVerifier:g}=l.getEntropyDetailsForUser(A,h),v=l.getIsUnifiedWallet(h);if("string"!=typeof c||c.length<1)return y.emitPrivyEvent(ce,"signMessage","onError",s.PrivyErrorCode.INVALID_MESSAGE),void n(Error("Message must be a non-empty string"));let f=async()=>{let t;if(!C)throw Error("User must be authenticated before signing with a Privy wallet");let r=await mi();if(!G||!r||!await Ke.recoverEmbeddedWallet({address:p}))throw Error("Unable to connect to wallet");if(d.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_started",payload:{walletAddress:p,requesterAppId:o}}),v){let n=i.isHex(e.message,{strict:!0}),s=await a.rpc(u,(async({message:e})=>await G.signWithUserSigner({accessToken:r,requesterAppId:o,message:e})),{chain_type:"ethereum",method:"personal_sign",params:n?{message:c.slice(2),encoding:"hex"}:{message:c,encoding:"utf-8"},wallet_id:h.id});if(!s.data||!("signature"in s.data))throw new l.PrivyProviderRpcError("Unable to sign message");t=s.data.signature}else{let{response:e}=await G.rpc({accessToken:r,entropyId:w,entropyIdVerifier:g,chainType:"ethereum",hdWalletIndex:m,requesterAppId:o,request:{method:"personal_sign",params:[c,p]}});t=e.data}return d.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_completed",payload:{walletAddress:p,requesterAppId:o}}),t};if(me({showWalletUIs:t?.uiOptions?.showWalletUIs}))try{let e=await f();y.emitPrivyEvent(ce,"signMessage","onSuccess",{signature:e}),r({signature:e})}catch(e){y.emitPrivyEvent(ce,"signMessage","onError",s.PrivyErrorCode.UNABLE_TO_SIGN),n(e??new l.PrivyProviderRpcError("Unable to sign message"))}else Q({signMessage:{method:"personal_sign",data:c,confirmAndSign:f,onSuccess:e=>{y.emitPrivyEvent(ce,"signMessage","onSuccess",{signature:e}),r({signature:e})},onFailure:e=>{y.emitPrivyEvent(ce,"signMessage","onError",s.PrivyErrorCode.UNABLE_TO_SIGN),n(e)},uiOptions:t?.uiOptions||{}},connectWallet:{recoveryMethod:h.recoveryMethod,connectingWalletAddress:p,entropyId:w,entropyIdVerifier:g,onCompleteNavigateTo:W.SignRequestScreen,isUnifiedWallet:v,onFailure:e=>{y.emitPrivyEvent(ce,"signMessage","onError",s.PrivyErrorCode.UNKNOWN_CONNECT_WALLET_ERROR),n(e)}}}),we(l.EmbeddedWalletConnectingScreen)})),signTypedData:(e,t)=>new Promise((async(r,n)=>{let{requesterAppId:i}=t?.uiOptions||{},o=t?.address?l.getPrivyWalletWithAddress(A,t.address):l.getPrivyEthereumWallet(A);if(!o&&t?.address){let i=l.getConnectedWalletWithAddress(ii(),t.address);if(i)try{let t=await i.getEthereumProvider(),n=l.generateTypedDataWithDomainType(e),a=await t.request({method:"eth_signTypedData_v4",params:[i.address,n]});return y.emitPrivyEvent(ce,"signTypedData","onSuccess",{signature:a}),void r({signature:a})}catch(e){return y.emitPrivyEvent(ce,"signTypedData","onError",s.PrivyErrorCode.UNABLE_TO_SIGN),void n(e??new l.PrivyProviderRpcError("Unable to sign typed data "+e))}}if(!o)throw new s.PrivyClientError("No embedded or connected wallet found for address.");if(!C||!A)return y.emitPrivyEvent(ce,"signTypedData","onError",s.PrivyErrorCode.MUST_BE_AUTHENTICATED),void n(Error("User must be authenticated before signing with a Privy wallet"));let c=o.address,h=o.walletIndex??0,{entropyId:p,entropyIdVerifier:m}=l.getEntropyDetailsForUser(A,o),w=l.getIsUnifiedWallet(o),g=l.generateTypedDataWithDomainType(e),v=async()=>{let e;if(!C)throw Error("User must be authenticated before signing with a Privy wallet");let t=await mi();if(!G||!t||!await Ke.recoverEmbeddedWallet({address:c}))throw Error("Unable to connect to wallet");if(d.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_started",payload:{walletAddress:c,requesterAppId:i}}),w){let{domain:r,types:n,primaryType:s,message:c}=g,d=await a.rpc(u,(async({message:e})=>await G.signWithUserSigner({accessToken:t,requesterAppId:i,message:e})),{chain_type:"ethereum",method:"eth_signTypedData_v4",params:{typed_data:{domain:r,types:n,primary_type:s,message:c}},wallet_id:o.id});if(!d.data||!("signature"in d.data))throw new l.PrivyProviderRpcError("Unable to sign message");e=d.data.signature}else{let{response:r}=await G.rpc({accessToken:t,entropyId:p,entropyIdVerifier:m,chainType:"ethereum",hdWalletIndex:h,requesterAppId:i,request:{method:"eth_signTypedData_v4",params:[c,g]}});e=r.data}return d.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_completed",payload:{walletAddress:c,requesterAppId:i}}),e};if(me({showWalletUIs:t?.uiOptions?.showWalletUIs}))try{let e=await v();y.emitPrivyEvent(ce,"signTypedData","onSuccess",{signature:e}),r({signature:e})}catch(e){y.emitPrivyEvent(ce,"signTypedData","onError",s.PrivyErrorCode.UNABLE_TO_SIGN),n(e??new l.PrivyProviderRpcError("Unable to sign message"))}else Q({signMessage:{method:"eth_signTypedData_v4",data:g,confirmAndSign:v,onSuccess:e=>{y.emitPrivyEvent(ce,"signTypedData","onSuccess",{signature:e}),r({signature:e})},onFailure:e=>{y.emitPrivyEvent(ce,"signTypedData","onError",s.PrivyErrorCode.UNABLE_TO_SIGN),n(e)},uiOptions:t?.uiOptions||{}},connectWallet:{recoveryMethod:o.recoveryMethod,connectingWalletAddress:o.address,entropyId:p,isUnifiedWallet:w,entropyIdVerifier:m,onCompleteNavigateTo:W.SignRequestScreen,onFailure:e=>{y.emitPrivyEvent(ce,"signMessage","onError",s.PrivyErrorCode.UNKNOWN_CONNECT_WALLET_ERROR),n(e)}}}),we(l.EmbeddedWalletConnectingScreen)})),sendTransaction:async(e,t)=>await Fe({transaction:e,sponsor:t?.sponsor,uiOptions:t?.uiOptions,fundWalletConfig:t?.fundWalletConfig,address:t?.address,signOnly:!1}),signTransaction:async(e,t)=>({signature:(await Fe({transaction:e,uiOptions:t?.uiOptions,address:t?.address,signOnly:!0})).hash}),exportWallet:e=>new Promise((async(t,r)=>{if(!C||!A)return void r(Error("User must be authenticated before exporting their Privy wallet"));e&&"target"in e&&e&&(e=void 0);let n=e?.address?l.getPrivyWalletWithAddress(A,e.address):l.getPrivyEthereumWallet(A);if(!n)return void r(new s.PrivyClientError("User must have an embedded wallet."));let a=n.address,{entropyId:o,entropyIdVerifier:u}=l.getEntropyDetailsForUser(A,n),h=l.getIsUnifiedWallet(n);if(!a)return void r(Error("User does not have an HD Ethereum wallet. To export an imported wallet, pass the `address` of the wallet to `exportWallet`."));if(!i.isAddress(a))return void r(Error("Must provide a valid Ethereum address."));let p={recoveryMethod:n.recoveryMethod,connectingWalletAddress:n.address,isUnifiedWallet:h,entropyId:o,entropyIdVerifier:u,onCompleteNavigateTo:l.EmbeddedWalletKeyExportScreen,onFailure:r,shouldForceMFA:!0};Q(X),await mi()&&G?G?I.isFirstClassChainWallet(n)?(Q({keyExport:{appId:c.appId,appClientId:c.clientId,origin:d.apiUrl,address:n.address,entropyId:o,entropyIdVerifier:u,hdWalletIndex:n.walletIndex,chainType:n.chainType,walletId:n.id,isUnifiedWallet:h,imported:n.imported,onSuccess:t,onFailure:r},connectWallet:p}),we(l.EmbeddedWalletConnectingScreen)):r(Error(`Export is not supported for ${n.chainType} wallets`)):r(Error("Must have a Privy wallet before exporting")):r(Error("Must have valid access token to enroll in MFA"))})),promptMfa:Le,async init(e){switch(e){case"sms":return void await d.initMfaSmsVerification();case"passkey":return await d.initMfaPasskeyVerification();case"totp":return;default:throw Error(`Unsupported MFA method: ${e}`)}},async submit(e,t){switch(e){case"totp":case"sms":if("string"!=typeof t)throw new s.PrivyClientError("Invalid MFA code");se.current?.resolve({mfaMethod:e,mfaCode:t,relyingParty:window.origin}),await new Promise(((e,t)=>{le.current={resolve:e,reject:t}}));break;case"passkey":if("string"==typeof t)throw new s.PrivyClientError("Invalid authenticator response");let r=await import("@simplewebauthn/browser"),n=an(await r.startAuthentication({optionsJSON:t}));se.current?.resolve({mfaMethod:e,mfaCode:n,relyingParty:window.origin}),await new Promise(((e,t)=>{le.current={resolve:e,reject:t}}));break;default:throw se.current?.reject(new s.PrivyClientError("Unsupported MFA method")),new s.PrivyClientError(`Unsupported MFA method: ${e}`)}},cancel(){se.current?.reject(new s.PrivyClientError("MFA canceled"))},async initEnrollmentWithSms(e){let t=await mi();if(!t||!G)throw Error("Must have valid access token to enroll in MFA");await G.initEnrollMfa({method:"sms",accessToken:t,phoneNumber:e.phoneNumber})},enrollInMfa:e=>new Promise(((t,r)=>{if(!e)return Ke.closePrivyModal(),void t();p.mfa.noPromptOnMfaRequired&&console.warn("[Privy Warning] Triggering the 'showMfaEnrollmentModal' function when 'noPromptOnMfaRequired' is set to true is unexpected. If this is intentional, ensure that you are building custom UIs for MFA verification."),Q({mfaEnrollmentFlow:{mfaMethods:p.mfa.methods,shouldUnlinkOnUnenrollMfa:p.passkeys.shouldUnlinkOnUnenrollMfa,onSuccess:t,onFailure:r}}),we($n)})),async initEnrollmentWithTotp(){let e=await mi();if(!e||!G)throw Error("Must have valid access token to enroll in MFA");let t=await G.initEnrollMfa({method:"totp",accessToken:e});return{secret:t.secret,authUrl:t.authUrl}},async submitEnrollmentWithSms(e){let t=await mi();if(!t||!G)throw Error("Must have valid access token to enroll in MFA");await G.submitEnrollMfa({method:"sms",accessToken:t,phoneNumber:e.phoneNumber,code:e.mfaCode}),P(await d.getAuthenticatedUser())},async submitEnrollmentWithTotp(e){let t=await mi();if(!t||!G)throw Error("Must have valid access token to enroll in MFA");await G.submitEnrollMfa({method:"totp",accessToken:t,code:e.mfaCode}),P(await d.getAuthenticatedUser())},async initEnrollmentWithPasskey(){},async submitEnrollmentWithPasskey({credentialIds:e},t={}){let r=await mi();if(!r||!G)throw Error("Must have valid access token to enroll in MFA");await G.submitEnrollMfa({method:"passkey",accessToken:r,credentialIds:e,removeForLogin:t.removeForLogin}),P(await d.getAuthenticatedUser())},async unenroll(e,t={}){let r=await mi();if(!r||!G)throw Error("Must have valid access token to remove MFA");"passkey"===e?await G.submitEnrollMfa({method:"passkey",accessToken:r,credentialIds:[],removeForLogin:t.removeForLogin}):await G.unenrollMfa({method:e,accessToken:r}),P(await d.getAuthenticatedUser())},requestFarcasterSignerFromWarpcast:async()=>{let e=await mi(),t=A?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!e)throw Error("Must have valid access token to connect with Farcaster");if(!G||!t)throw Error("Must have an embedded wallet to use Farcaster signers");if(l.getIsUnifiedWallet(t))throw new s.PrivyClientError("Farcaster signers are only supported for on-device execution and this app uses TEE execution. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");if(!A?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await Ke.recoverEmbeddedWallet({address:t.address}))throw Error("Unable to connect to wallet");let r=await G.initFarcasterSigner({address:t.address,hdWalletIndex:null,accessToken:e,mfaCode:null,mfaMethod:null,relyingParty:window.origin});"approved"===r.status&&P(await d.getAuthenticatedUser()||A||null),Q({farcasterSigner:r}),we(Cn)},getFarcasterSignerPublicKey:async()=>{let e,t=await mi(),r=A?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!G||!r)throw Error("Must have an embedded wallet to use Farcaster signers");if(l.getIsUnifiedWallet(r))throw new s.PrivyClientError("Farcaster signers are only supported for on-device execution and this app uses TEE execution. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");if(!A?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await Ke.recoverEmbeddedWallet({address:r.address}))throw Error("Unable to connect to wallet");if(!A.farcaster?.signerPublicKey)throw Error("Must have a Farcaster signer public key to sign");return e=A.farcaster.signerPublicKey.slice(2),Uint8Array.from(e.match(/.{1,2}/g).map((e=>parseInt(e,16))))},signFarcasterMessage:async e=>{let t=await mi(),r=A?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!G||!r)throw Error("Must have an embedded wallet to use Farcaster signers");if(l.getIsUnifiedWallet(r))throw new s.PrivyClientError("Farcaster signers are only supported for on-device execution and this app uses TEE execution. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");if(!A?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await Ke.recoverEmbeddedWallet({address:r.address}))throw Error("Unable to connect to wallet");if(!A.farcaster?.signerPublicKey)throw Error("Must have a Farcaster signer public key to sign");let n=await import("@simplewebauthn/browser"),i=await G.signFarcasterMessage({address:r.address,hdWalletIndex:null,accessToken:t,mfaCode:null,mfaMethod:null,payload:{hash:n.bufferToBase64URLString(e)},fid:BigInt(A.farcaster.fid),relyingParty:window.origin});return new Uint8Array(n.base64URLStringToBuffer(i.signature))},signMessageWithCrossAppWallet(e,{address:t,chainId:r}){let n=A?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return jr({user:A,client:d,address:t,requesterAppId:p.id,request:{method:n?"privy_signSmartWalletMessage":"personal_sign",params:[e,t],chainId:r},reconnect:He})},signTypedDataWithCrossAppWallet(e,{address:t,chainId:r}){let n=A?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t)))),i=l.generateTypedDataWithDomainType(e);return jr({user:A,client:d,address:t,requesterAppId:p.id,request:{method:n?"privy_signSmartWalletTypedData":"eth_signTypedData_v4",params:[t,i],chainId:r},reconnect:He})},sendTransactionWithCrossAppWallet(e,{address:t}){let r=A?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return jr({user:A,client:d,address:t,requesterAppId:p.id,request:{method:r?"privy_sendSmartWalletTx":"eth_sendTransaction",params:[e],chainId:e.chainId},reconnect:He})},signTransactionWithCrossAppWallet(e,{address:t}){let r=A?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return jr({user:A,client:d,address:t,requesterAppId:p.id,request:{method:r?"privy_signSmartWalletTx":"eth_signTransaction",params:[e],chainId:e.chainId},reconnect:He})},isModalOpen:m||!!g,mfaMethods:p.mfa.methods};di=ze.signMessage,ui=ze.signTypedData,pi=async(e,t)=>await Fe({transaction:e,...t,signOnly:!1}),hi=async(e,t)=>({signature:(await Fe({transaction:e,...t,signOnly:!0})).hash});let Ke={privy:u,setAuthenticated:E,setUser:P,setIsNewUser:S,isNewUserThisSession:b,pendingTransaction:null,walletConnectionStatus:O,setWalletConnectionStatus:M,connectors:d.connectors?.walletConnectors??[],rpcConfig:p.rpcConfig,chains:p.chains,appId:c.appId,showFiatPrices:"native-token"!==p.embeddedWallets.priceDisplay.primary,clientAnalyticsId:d.clientAnalyticsId,onCustomAuthAuthenticated:ge,hideWalletUIs:ye,isHeadlessSigning:r.useCallback(me,[p.embeddedWallets.showWalletUIs]),emailOtpState:L,setEmailOtpState:D,smsOtpState:q,setSmsOtpState:B,oAuthState:K,setOAuthState:V,telegramAuthState:$,setTelegramAuthState:Y,siweState:H,setSiweState:z,isHeadlessOAuthLoading:R,baseAccountSdk:T,setBaseAccountSdk:x,nativeTokenSymbolForChainId:e=>p.chains.find((t=>t.id===Number(e)))?.nativeCurrency.symbol,initializeWalletProxy:async e=>{if(G)return G;let t=new Promise((e=>{re.current=e})),r=new Promise((t=>setTimeout((()=>t(null)),e))),n=await Promise.race([t,r]);return re.current=null,n},getAuthFlow:()=>d.authFlow,getAuthMeta:()=>d.authFlow?.meta,client:d,closePrivyModal:async(e={shouldCallAuthOnSuccess:!0,isSuccess:!1})=>{let t,r=v&&C&&A;if(r&&he.current&&(t=De(A)),"login"===pe.current)e.shouldCallAuthOnSuccess&&r&&he.current?y.emitPrivyEvent(ce,"login","onComplete",{user:A,isNewUser:b,wasAlreadyAuthenticated:!1,loginMethod:he.current,loginAccount:t??null}):y.emitPrivyEvent(ce,"login","onError",s.PrivyErrorCode.USER_EXITED_AUTH_FLOW);else if("link"===pe.current&&t)e.isSuccess&&r&&he.current?y.emitPrivyEvent(ce,"linkAccount","onSuccess",{user:A,linkMethod:he.current,linkedAccount:t}):he.current&&y.emitPrivyEvent(ce,"linkAccount","onError",s.PrivyErrorCode.USER_EXITED_LINK_FLOW,{linkMethod:he.current});else if("update"===pe.current&&t)e.isSuccess&&r&&he.current?y.emitPrivyEvent(ce,"update","onSuccess",{user:A,updateMethod:he.current,updatedAccount:t}):he.current&&y.emitPrivyEvent(ce,"update","onError",s.PrivyErrorCode.USER_EXITED_UPDATE_FLOW,{linkMethod:he.current});else if("connect-or-create"===pe.current){let e=ii();e[0]?y.emitPrivyEvent(ce,"connectOrCreateWallet","onSuccess",{wallet:e[0]}):y.emitPrivyEvent(ce,"connectOrCreateWallet","onError",s.PrivyErrorCode.USER_EXITED_AUTH_FLOW)}let n=_&&tn.has(_),i=_===l.ErrorScreen&&X.errorModalData&&tn.has(X.errorModalData.previousScreen);if((n||i)&&X.funding){let e,t=tn.get(_)??null;if("solana"===X.funding.chainType){let r=p.solanaRpcs[X.funding.chain];if(!r)return void console.warn("Unable to load solana rpc, skipping balance");if(h(l.SOLANA_FUNDING_PLUGIN_ID))try{e=await l.fetchWalletBalance({rpc:r.rpc,address:X.funding.address})}catch{console.error("Unable to pull wallet balance")}else console.warn("Unable to load solana plugin, skipping balance");y.emitPrivyEvent(ce,"fundSolanaWallet","onUserExited",{address:X.funding.address,fundingMethod:t,chain:X.funding.chain,balance:e})}else{let r=l.getPublicClient(X.funding.chain.id,p.chains,p.rpcConfig,{appId:c.appId});try{e=await r.getBalance({address:X.funding.address})}catch{console.error("Unable to pull wallet balance")}y.emitPrivyEvent(ce,"fundWallet","onUserExited",{address:X.funding.address,chain:X.funding.chain,fundingMethod:t,balance:e})}}Q((e=>({...e,externalConnectWallet:{}}))),pe.current=null,he.current=null,S(!1),w(!1),M({status:"disconnected",connectedWallet:null,connector:null,connectError:null,connectRetry:()=>{}}),setTimeout((()=>{d.authFlow=void 0}),200)},openPrivyModal:we,connectWallet:Ee,initLoginWithWallet:async(e,t,r,n)=>{l.isBaseConnectedEthereumWallet(e)?(he.current="siwe",Te(e,t,r)):(he.current="siws",xe(e,t,r,n))},loginWithWallet:async()=>{let e,t,r;if(!v)throw new s.PrivyNotReadyError;if(d.authFlow instanceof l.SiweFlow?e="siwe":d.authFlow instanceof l.SiwsFlow&&(e="siws"),!e)throw new s.PrivyClientError("Must initialize SIWE/SIWS flow first.");if(null!==await d.getAccessToken())try{({user:t}=await d.link()),he.current=e}catch(t){throw y.emitPrivyEvent(ce,"linkAccount","onError",t.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}else try{({user:t,isNewUser:r}=await d.authenticate()),he.current=e}catch(e){throw y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.GENERIC_CONNECT_WALLET_ERROR),e}P(t||A||null),S(r||!1),E(!0)},delegateWallet:async({address:e,chainType:t,showDelegationUIs:r})=>new Promise((async(n,i)=>{let a=await mi();if(!C||!A||!a)throw new s.PrivyClientError("User must be authenticated and have an embedded wallet to delegate actions.");if("solana"!==t&&"ethereum"!==t)throw new s.PrivyClientError("Only Solana and Ethereum embedded wallets are supported for delegation and revocation.");let o=Ke.walletProxy??await Ke.initializeWalletProxy(15e3);if(!o)throw new s.PrivyClientError("Wallet proxy not initialized.");if((({address:e,user:t})=>!!Wr(t).find((t=>t.address===e)))({address:e,user:A}))return n();let c=l.getPrivyWalletWithAddress(A,e);if(!c)throw new s.PrivyClientError("Address to delegate is not associated with current user.");if(l.getIsUnifiedWallet(c))throw new s.PrivyClientError("useDelegatedActions is only supported for on-device execution and this app uses TEE execution. Use the useSessionSigners hook to provision server side access on behalf of your users. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");let d=Ir({address:e,user:A}),u=Ur({address:e,user:A}),h=async()=>{await o.createDelegatedAction({accessToken:a,rootWallet:u,delegatedWallets:[d]}),await Ke.refreshSessionAndUser()};if(await Ke.recoverEmbeddedWallet({address:e}),r)Q({delegatedActions:{consent:{address:e,onDelegate:h,onSuccess:async()=>{n()},onError:async e=>{i(e)}}}}),we(cn);else try{await h(),n()}catch(e){i(e)}})),revokeDelegatedWallets:async({showDelegationUIs:e})=>new Promise((async(t,r)=>{if(!C||!A)throw new s.PrivyClientError("User must be authenticated and have an embedded wallet to revoke a delegated wallet.");let n=Wr(A);if(0===n.length)throw new s.PrivyClientError("User has no delegated wallets to revoke.");if(n.some(l.getIsUnifiedWallet))throw new s.PrivyClientError("useDelegatedActions is only supported for on-device execution and this app uses TEE execution. Use the useSessionSigners hook to provision server side access on behalf of your users. Learn more at https://docs.privy.io/recipes/tee-wallet-migration-guide");let i=async()=>{await d.revokeDelegatedWallet(),await Ke.refreshSessionAndUser()};if(e)Q({delegatedActions:{revoke:{onRevoke:i,onSuccess:async()=>{t()},onError:async e=>{r(e)}}}}),we(un);else try{await i(),t()}catch(e){r(e)}})),initLoginWithFarcaster:async(e,t)=>{let r=new ke(e,t);d.startAuthFlow(r);try{he.current="farcaster",await r.initializeFarcasterConnect()}catch(e){throw"login"===pe.current?y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR):"link"===pe.current&&y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:"farcaster"}),e}},loginWithFarcaster:async()=>{let e,t;if(!v)throw new s.PrivyNotReadyError;if(!(d.authFlow instanceof ke))throw new s.PrivyClientError("Must initialize Farcaster flow first.");if(null!==await d.getAccessToken())try{({user:e}=await d.link()),he.current="farcaster"}catch(e){throw y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:"farcaster"}),e}else try{({user:e,isNewUser:t}=await d.authenticate()),he.current="farcaster"}catch(e){throw y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}P(e||null),S(t||!1),E(!0)},async crossAppAuthFlow({appId:e,popup:t,action:r}){let n=`privy:${e}`;he.current=n;let{url:i,stateCode:a,codeVerifier:o}=await async function({api:e,appId:t}){let r=l.createCodeVerifier(),n=l.createStateCode(),i=await l.deriveCodeChallengeFromCodeVerifier(r);try{let{url:a}=await e.post(s.oAuthInitPath,{provider:`privy:${t}`,redirect_to:window.location.href,code_challenge:i,state_code:n});return{url:a,stateCode:n,codeVerifier:r}}catch(e){throw s.formatApiError(e)}}({api:d.api,appId:e});if(!i)throw d.createAnalyticsEvent({eventName:"cross_app_auth_error",payload:{error:"Unable to open cross-app auth popup",appId:e}}),new s.PrivyClientError("No authorization URL returned for cross-app auth.");try{let l=await async function({url:e,popup:t}){return t.location=e,new Promise(((e,r)=>{let n,i=setTimeout((()=>{r(new s.PrivyClientError("Authorization request timed out after 2 minutes.")),a()}),12e4);function a(){t?.close(),window.removeEventListener("message",l)}let o=setInterval((()=>{t?.closed&&!n&&(a(),clearInterval(o),clearTimeout(i),r(new s.PrivyClientError("User rejected request")))}),300);function l(t){t.data&&("PRIVY_OAUTH_RESPONSE"===t.data.type&&t.data.stateCode&&t.data.authorizationCode&&(clearTimeout(i),e(t.data),a()),"PRIVY_OAUTH_ERROR"===t.data.type&&(clearTimeout(i),r(new s.PrivyClientError(t.data.error)),a()),t.data.type===Nr&&((n=new BroadcastChannel(Rr)).onmessage=l))}window.addEventListener("message",l)}))}({url:i,popup:t,provider:n}),c=l.stateCode,u=l.authorizationCode;if(c!==a)throw d.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:n,storedStateCode:a??"",returnedStateCode:c??""}}),new s.PrivyClientError("Unexpected auth flow. This may be a phishing attempt.",void 0,s.PrivyErrorCode.OAUTH_UNEXPECTED);let h=await async function({appId:e,stateCode:t,codeVerifier:r,authorizationCode:n,action:i,client:a}){if(!n||!t)throw new s.PrivyClientError("[Cross-App AuthFlow] Authorization and state codes code must be set prior to calling authenicate.");if("undefined"===n)throw new s.PrivyClientError("User denied confirmation during cross-app auth flow");try{let o=new Or({authorizationCode:n,stateCode:t,codeVerifier:r,provider:`privy:${e}`});a.startAuthFlow(o);let s="link"===i?await a.link():await a.authenticate(),l=s.oAuthTokens?.accessToken;return console.debug(),l}catch(e){let t=s.formatApiError(e);if(t.privyErrorCode===s.PrivyErrorCode.ACCOUNT_TRANSFER_REQUIRED)throw t;if(t.privyErrorCode)throw new s.PrivyClientError(t.message||"Invalid code during cross-app auth flow.",void 0,t.privyErrorCode);if("User denied confirmation during cross-app auth flow"===t.message)throw new s.PrivyClientError("Invalid code during cross-app auth flow.",void 0,s.PrivyErrorCode.OAUTH_USER_DENIED);throw new s.PrivyClientError("Invalid code during cross-app auth flow.",void 0,s.PrivyErrorCode.UNKNOWN_AUTH_ERROR)}}({appId:e,codeVerifier:o,stateCode:c,authorizationCode:u,action:r,client:d});h&&d.storeProviderAccessToken(e,h);let p=await Ke.refreshSessionAndUser();if(!p)throw new s.PrivyClientError("Unable to update user");return d.createAnalyticsEvent({eventName:"cross_app_auth_completed",payload:{providerAppId:e}}),p}catch(e){throw d.createAnalyticsEvent({eventName:"cross_app_auth_error",payload:{error:e.toString(),provider:n}}),e}},async initLoginWithOAuth(e,t,r){if(he.current=e,!l.e$1())return void we(An);if("google"===e&&!p.allowOAuthInEmbeddedBrowsers&&l.e$3(window.navigator.userAgent))return void we(An);"twitter"===e&&window.opener&&window.opener.postMessage({type:Nr},"*"),l.p.del(y.HEADLESS_OAUTH_KEY),l.p.del(y.OAUTH_DISABLE_SIGNUP_KEY);let i=new _e({provider:e,disableSignup:!!r,withPrivyUi:!0,customOAuthRedirectUrl:p.customOAuthRedirectUrl});t&&i.addCaptchaToken(t),d.startAuthFlow(i);let a=await d.authFlow.getAuthorizationUrl();if(a&&a.url)if("twitter"===e&&n.isAndroid&&(a.url=a.url.replace("x.com","twitter.com")),"chrome-extension:"===window.location.protocol&&be())try{let{privyOAuthCode:e,privyOAuthState:t}=await Se(a.url);we(Gn),i.meta.stateCode=t,i.meta.authorizationCode=e}catch(e){throw console.error("OAuth in chrome extension flow failed:",e),e}else window.location.assign(a.url)},async initLoginWithTelegram(e,t){if(!v)throw new s.PrivyNotReadyError;he.current="telegram";let r=new l.TelegramAuthFlow(e,t);d.startAuthFlow(r),Y({status:"loading"}),r.meta.telegramWebAppData=void 0,r.meta.telegramAuthResult=await new Promise(((e,t)=>p.loginConfig.telegramAuthConfiguration?window.Telegram?void window.Telegram.Login.auth({bot_id:p.loginConfig.telegramAuthConfiguration.botId,request_access:!0},(r=>r?e(r):("link"===pe.current?y.emitPrivyEvent(ce,"linkAccount","onError",s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:"telegram"}):"login"===pe.current?y.emitPrivyEvent(ce,"login","onError",s.PrivyErrorCode.INVALID_CREDENTIALS):"update"===pe.current&&y.emitPrivyEvent(ce,"login","onError",s.PrivyErrorCode.FAILED_TO_UPDATE_ACCOUNT),t(new s.PrivyClientError("Telegram auth failed or was canceled by the client"))))):t(new s.PrivyClientError("Telegram was not initialized")):t(new s.PrivyClientError("Telegram Auth configuration is not loaded"))))},async loginWithTelegram(e){let t,r;if(!(d.authFlow instanceof l.TelegramAuthFlow))throw new s.PrivyClientError("Must initialize Telegram flow before calling loginWithTelegram");d.authFlow.meta.captchaToken||=e?.captchaToken;let n=await mi(),i=e?.intent||pe.current;if("login"===i)try{let e=await d.authenticate();t=e.user,r=e.isNewUser,he.current="telegram"}catch(e){throw y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}else{if("link"!==i)throw new s.PrivyClientError("Unknown auth intent");try{t=(await d.link()).user,he.current="telegram"}catch(e){throw y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:"telegram"}),e}}P(t),S(r||!1),E(!0),Y({status:"done"});let a=t?.linkedAccounts.find((({type:e})=>"telegram"===e))||null;return{user:t,isNewUser:r||!1,wasAlreadyAuthenticated:!!n,loginAccount:a}},async loginWithOAuth(e){let t,r,n;if(!(d.authFlow instanceof _e))throw new s.PrivyClientError("Must initialize OAuth flow before calling loginWithOAuth");let i=l.p.get(y.STATE_CODE_KEY),a=d.authFlow.meta.stateCode;if(i!==a)throw d.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:e,storedStateCode:i??"",returnedStateCode:a??""}}),new s.PrivyClientError("Unexpected auth flow. This may be a phishing attempt.",void 0,s.PrivyErrorCode.OAUTH_UNEXPECTED);if(null!==await d.getAccessToken())try{let r=await d.link();t=r.user,n=r.oAuthTokens,he.current=e}catch(t){throw y.emitPrivyEvent(ce,"linkAccount","onError",t.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}else try{let i=await d.authenticate();t=i.user,r=i.isNewUser,n=i.oAuthTokens,he.current=e}catch(t){throw"login"===pe.current?y.emitPrivyEvent(ce,"login","onError",t.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR):"link"===pe.current&&y.emitPrivyEvent(ce,"linkAccount","onError",t.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}return P(t),S(r||!1),E(!0),n&&t&&y.emitPrivyEvent(ce,"oAuthAuthorization","onOAuthTokenGrant",{oAuthTokens:n,user:t}),n},passkeyAuthState:j,setPasskeyAuthState:F,async initSignupWithPasskey({captchaToken:e,withPrivyUi:t}){let r=new Oe({captchaToken:e,setPasskeyAuthState:F,hints:p.passkeys.registration?.hints});d.startAuthFlow(r),pe.current="login";try{he.current="passkey",F({status:"generating-challenge"}),await r.initRegisterFlow(t),F({status:"awaiting-passkey"})}catch(e){throw F({status:"error",error:e}),y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}},async signupWithPasskey(){let e,t;if(!v)throw new s.PrivyNotReadyError;if(!(d.authFlow instanceof Oe))throw new s.PrivyClientError("Must initialize Passkey flow first.");if("passkey"!==he.current){let e=new s.PrivyClientError("Must init login with Passkey flow first.");throw F({status:"error",error:e}),e}let r=await mi();try{he.current="passkey",F({status:"awaiting-passkey"}),({user:e,isNewUser:t}=await d.authenticate())}catch(e){throw F({status:"error",error:e}),y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}P(e),S(t||!1),E(!0),F({status:"done"});let n=e?.linkedAccounts.find((({type:e})=>"passkey"===e))||null;return{user:e,isNewUser:t||!1,wasAlreadyAuthenticated:!!r,loginAccount:n}},async initLoginWithPasskey({captchaToken:e,withPrivyUi:t}){let r=new Oe({captchaToken:e,setPasskeyAuthState:F,hints:void 0});d.startAuthFlow(r),pe.current="login";try{he.current="passkey",F({status:"generating-challenge"}),await r.initAuthenticationFlow(t),F({status:"awaiting-passkey"})}catch(e){throw F({status:"error",error:e}),y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}},async loginWithPasskey(e){let t,r;if(!v)throw new s.PrivyNotReadyError;if(!(d.authFlow instanceof Oe))throw new s.PrivyClientError("Must initialize Passkey flow first.");if(e?.credentialIds&&(d.authFlow.meta.allowedCredentialsIds=e.credentialIds),"passkey"!==he.current){let e=new s.PrivyClientError("Must init login with Passkey flow first.");throw F({status:"error",error:e}),e}let n=await mi();try{he.current="passkey",F({status:"awaiting-passkey"}),({user:t,isNewUser:r}=await d.authenticate())}catch(e){throw F({status:"error",error:e}),y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}P(t),S(r||!1),E(!0),F({status:"done"});let i=t?.linkedAccounts.find((({type:e})=>"passkey"===e))||null;return{user:t,isNewUser:r||!1,wasAlreadyAuthenticated:!!n,loginAccount:i}},async initLinkWithPasskey(e){let t=new Oe({captchaToken:e,hints:p.passkeys.registration?.hints});d.startAuthFlow(t),pe.current="link",he.current="passkey",F({status:"generating-challenge"});try{await t.initLinkFlow(),F({status:"awaiting-passkey"})}catch(e){throw y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:"passkey"}),F({status:"error",error:e}),e}},async linkWithPasskey(){let e;if(!v)throw new s.PrivyNotReadyError;if(!(d.authFlow instanceof Oe))throw new s.PrivyClientError("Must initialize Passkey flow first.");if("passkey"!==he.current)throw new s.PrivyClientError("Must init login with Passkey flow first.");try{he.current="passkey",({user:e}=await d.link())}catch(e){throw y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:"passkey"}),e}return P(e||A||null),F({status:"done"}),e},async initLoginWithHeadlessOAuth(e,t,r){if(!l.e$1())throw Error("It looks like you're using an in-app browser. To log in, please try again using an external browser.");if("google"===e&&!p.allowOAuthInEmbeddedBrowsers&&l.e$3(window.navigator.userAgent))throw Error("It looks like you're using an in-app browser. To log in, please try again using an external browser.");let n=new _e({provider:e,withPrivyUi:!1,disableSignup:r??!1,customOAuthRedirectUrl:p.customOAuthRedirectUrl});t&&n.addCaptchaToken(t),V({status:"loading"});let i=await d.startAuthFlow(n).getAuthorizationUrl();if(i?.url)if("chrome-extension:"===window.location.protocol&&be())try{let{privyOAuthCode:e,privyOAuthState:t}=await Se(i.url);n.meta.stateCode=t,n.meta.authorizationCode=e,await this.loginWithHeadlessOAuth(n.meta)}catch(e){throw V({status:"error",error:e}),e}else window.location.assign(i.url)},async loginWithHeadlessOAuth(e){let t,r,n;N(!0),V({status:"loading"}),d.startAuthFlow(new _e({...e,customOAuthRedirectUrl:p.customOAuthRedirectUrl}));let i=l.p.get(y.STATE_CODE_KEY),a=e.stateCode;if(i!==a)throw d.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:e.provider,storedStateCode:i??"",returnedStateCode:a??""}}),N(!1),new s.PrivyClientError("Unexpected auth flow. This may be a phishing attempt.",void 0,s.PrivyErrorCode.OAUTH_UNEXPECTED);if(null!==await d.getAccessToken())try{({user:t,oAuthTokens:n}=await d.link()),he.current=e.provider;let r=De(t);t&&r&&y.emitPrivyEvent(ce,"linkAccount","onSuccess",{user:t,linkMethod:he.current,linkedAccount:r})}catch(t){throw N(!1),y.emitPrivyEvent(ce,"linkAccount","onError",t.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:e.provider}),t}else try{({user:t,isNewUser:r,oAuthTokens:n}=await d.authenticate()),he.current=e.provider;let i=De(t);t&&i&&void 0!==r&&y.emitPrivyEvent(ce,"login","onComplete",{user:t,isNewUser:r,wasAlreadyAuthenticated:!1,loginMethod:he.current,loginAccount:i})}catch(e){throw N(!1),V({status:"error",error:e}),y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}return P(t),S(r||!1),E(!0),N(!1),V({status:"done"}),n&&t&&y.emitPrivyEvent(ce,"oAuthAuthorization","onOAuthTokenGrant",{oAuthTokens:n,user:t}),t??void 0},initLoginWithEmail:async({email:e,captchaToken:t,disableSignup:r,withPrivyUi:n})=>{let i=new Ae({email:e,captchaToken:t,disableSignup:r});d.startAuthFlow(i);try{he.current="email",D({status:"sending-code"});let e=await i.sendCodeEmail({withPrivyUi:n});if(e?.ssoRedirectUrl)return window.location.href=e.ssoRedirectUrl,void await l.sleep(1e4);D({status:"awaiting-code-input"})}catch(e){throw D({status:"error",error:e}),"login"===pe.current?y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR):"link"===pe.current&&y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:"email"}),e}},initUpdateEmail:async({oldAddress:e,newAddress:t,captchaToken:r})=>{let n=new Pe(e,t,r);d.startAuthFlow(n);try{await n.sendCodeEmail({withPrivyUi:!0})}catch(e){throw y.emitPrivyEvent(ce,"update","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:he.current}),e}},initUpdatePhone:async(e,t,r)=>{let n=new je(e,t,r);d.startAuthFlow(n);try{await n.sendSmsCode({withPrivyUi:!0})}catch(e){y.emitPrivyEvent(ce,"update","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:he.current})}},initLoginWithSms:async({phoneNumber:e,captchaToken:t,disableSignup:r,withPrivyUi:n})=>{B({status:"sending-code"});let i=new Me({phoneNumber:e,captchaToken:t,disableSignup:r});d.startAuthFlow(i);try{he.current="sms",await i.sendSmsCode({withPrivyUi:n}),B({status:"awaiting-code-input"})}catch(e){throw B({status:"error",error:e}),"login"===pe.current?y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR):"link"===pe.current&&y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:"sms"}),e}},resendEmailCode:async()=>{await(d.authFlow?.sendCodeEmail({withPrivyUi:!0}))},resendSmsCode:async()=>{await(d.authFlow?.sendSmsCode({withPrivyUi:!0}))},loginWithCode:async e=>{let t,r;function n(e){d.authFlow instanceof Ae?D(e):d.authFlow instanceof Me&&B(e)}if(n({status:"submitting-code"}),!v){let e=new s.PrivyNotReadyError;throw n({status:"error",error:e}),e}if(d.authFlow instanceof Ae)d.authFlow.meta.emailCode=e.trim();else{if(!(d.authFlow instanceof Me)){let e=new s.PrivyClientError("Must initialize a passwordless code flow first");throw n({status:"error",error:e}),e}d.authFlow.meta.smsCode=e.trim()}let i=await mi();if("link"===pe.current)try{({user:t}=await d.link())}catch(e){throw n({status:"error",error:e}),y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:he.current}),e}else if("update"===pe.current)try{({user:t}=await d.link())}catch(e){throw n({status:"error",error:e}),y.emitPrivyEvent(ce,"update","onError",e.privyErrorCode||s.PrivyErrorCode.FAILED_TO_UPDATE_ACCOUNT,{linkMethod:he.current}),e}else try{({user:t,isNewUser:r}=await d.authenticate())}catch(e){throw n({status:"error",error:e}),y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}let a=t||A;P(a||null),S(r||!1),E(!0),n({status:"done"});let o=null;return d.authFlow instanceof Ae?o=a?.linkedAccounts.find((({type:e})=>"email"===e))||null:d.authFlow instanceof Me&&(o=a?.linkedAccounts.find((({type:e})=>"phone"===e))||null),{user:a,isNewUser:r||!1,wasAlreadyAuthenticated:!!i,linkedAccount:o}},generateSiweMessage:async({address:e,chainId:t,captchaToken:r})=>{pe.current=C?"link":"login",he.current="siwe",z({status:"generating-message"});let n=await d.generateSiweNonce({address:e,captchaToken:r});return z({status:"awaiting-signature"}),l.prepareSiweMessageWithNonce({address:e,chainId:t.replace("eip155:",""),nonce:n})},generateSiweMessageForSmartWallet:async({address:e,chainId:t})=>{let r=await d.generateSiweNonce({address:e});return l.prepareSiweMessageWithNonce({address:e,chainId:t.replace("eip155:",""),nonce:r})},linkSmartWallet:async({message:e,signature:t,smartWalletType:r,smartWalletVersion:n})=>{let i;i=await d.linkSmartWallet({message:e,signature:t,smartWalletType:r,smartWalletVersion:n}),P((i=await Ke.refreshSessionAndUser()??i)||A||null)},loginWithSiwe:async({message:e,signature:t,captchaToken:r,disableSignup:n,walletClientType:i,connectorType:a})=>{let o,c=null;try{if(A)throw Error("User already authenticated");let s=new l.SiweFlow(d,void 0,r,n,{message:e,signature:t,walletClientType:i,connectorType:a});d.startAuthFlow(s),he.current="siwe",pe.current="login",z({status:"submitting-signature"});let u=await d.authenticate();if(({user:c,isNewUser:o}=u),!c)throw Error("Authentication failed - no user returned")}catch(e){throw y.emitPrivyEvent(ce,"login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),z({status:"error",error:e}),e}return P(c),S(o||!1),E(!0),z({status:"done"}),pe.current=null,he.current=null,{user:c,isNewUser:o||!1}},linkWithSiwe:async({message:e,signature:t,chainId:r,walletClientType:n,connectorType:i})=>{let a;Ue("siwe");let o=null;try{z({status:"submitting-signature"}),a=await d.linkWithSiwe({message:e,signature:t,chainId:r,walletClientType:n,connectorType:i}),a=await Ke.refreshSessionAndUser()??a,z({status:"done"}),(o=De(a)||null)&&y.emitPrivyEvent(ce,"linkAccount","onSuccess",{user:a,linkMethod:"siwe",linkedAccount:o})}catch(e){throw y.emitPrivyEvent(ce,"linkAccount","onError",e.privyErrorCode||s.PrivyErrorCode.FAILED_TO_LINK_ACCOUNT,{linkMethod:"siwe"}),pe.current=null,he.current=null,z({status:"error",error:e}),e}let l=a||A;return P(l||null),pe.current=null,he.current=null,{user:l,linkedAccount:o}},refreshSessionAndUser:async()=>{let e=await d.getAuthenticatedUser();return E(!!e),P(e),e},walletProxy:G,createAnalyticsEvent:({eventName:e,payload:t,timestamp:r})=>d.createAnalyticsEvent({eventName:e,payload:t,timestamp:r}),acceptTerms:async()=>{let e=await d.acceptTerms();return P(e),e},getUsdTokenPrice:e=>d.getUsdTokenPrice(e),getUsdPriceForSol:()=>d.getUsdPriceForSol(),getSplTokenMetadata:e=>d.getSplTokenMetadata(e),recoverEmbeddedWallet:async e=>new Promise((async(t,r)=>{if(!A)return void t(!0);let n=e?.address?l.getPrivyWalletWithAddress(A,e.address):l.getPrivyPrimaryWallet(A)||l.getImportedPrivyEthereumWallets(A).at(0)||l.getImportedPrivySolanaWallets(A).at(0);if(!n||l.getIsUnifiedWallet(n))return void t(!0);let i=await mi();if(!i||!G||!n)return void r(Error("Must have valid access token and Privy wallet to recover wallet"));let{entropyId:a,entropyIdVerifier:o}=l.getEntropyDetailsForUser(A,n);try{await G.connect({accessToken:i,entropyId:a,entropyIdVerifier:o}),t(!0)}catch(e){if(l.errorIndicatesRecoveryIsNeeded(e)&&"privy"===n.recoveryMethod){let e;d.createAnalyticsEvent({eventName:"embedded_wallet_pinless_recovery_started",payload:{walletAddress:n.address}});try{e=await G.recover({entropyId:a,entropyIdVerifier:o,accessToken:i})}catch(e){return void r(e)}e.entropyId||r(Error("Unable to recover wallet")),d.createAnalyticsEvent({eventName:"embedded_wallet_recovery_completed",payload:{walletAddress:n.address}}),t(!0)}else l.errorIndicatesRecoveryIsNeeded(e)&&"privy"!==n.recoveryMethod&&"privy-v2"!==n.recoveryMethod?(Q({recoverWallet:{entropyId:a,entropyIdVerifier:o,onFailure:r,onSuccess:()=>t(!0)},recoveryOAuthStatus:{provider:n.recoveryMethod,action:"recover",shouldCreateEth:!1,shouldCreateSol:!1}}),we(l.embeddedWalletRecoveryScreen(n.recoveryMethod))):r(e)}})),setReadyToTrue:e=>{f(!0),ee?.(e)},updateWallets:()=>Re(),fundWallet:async(e,t)=>{Q({funding:I.prepareFundingModalData({address:e,appConfig:p,fundWalletConfig:t,methodScreen:l.FundingMethodSelectionScreen})}),we(l.FundingMethodSelectionScreen)},openModal:we,requestFarcasterSignerStatus:async e=>{let t=await mi(),r=A?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!G||!r)throw Error("Must have an embedded wallet to use Farcaster signers");if(!A?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");let n=await d.requestFarcasterSignerStatus(e);return"approved"===n.status&&P(await d.getAuthenticatedUser()||A||null),n},connectCoinbaseSmartWallet:async()=>{p.externalWallets.coinbaseWallet.config.preference={...p.externalWallets.coinbaseWallet.config.preference,options:"smartWalletOnly"};let e=d.connectors?.findWalletConnector("coinbase_wallet","coinbase_smart_wallet")||d.connectors?.findWalletConnector("coinbase_wallet","coinbase_wallet");if(e)return e.updateConnectionPreference("smartWalletOnly"),Ee(e);await Ce("coinbase_wallet","coinbase_smart_wallet")},connectBaseAccount:async()=>{let e=d.connectors?.findWalletConnector("base_account","base_account");if(e)return Ee(e);await Ce("base_account","base_account")},initiateAccountTransfer:async({nonce:e,account:t,accountType:r,externalWalletMetadata:n,telegramAuthResult:i,telegramWebAppData:a,farcasterEmbeddedAddress:o,oAuthUserInfo:s})=>{let l=await d.sendAccountTransferRequest({nonce:e,account:t,accountType:r,externalWalletMetadata:n,telegramAuthResult:i,telegramWebAppData:a,farcasterEmbeddedAddress:o,oAuthUserInfo:s});return P(l),l},inProgressAuthFlowRef:pe,inProgressLoginOrLinkMethodRef:he};yi=Ke.recoverEmbeddedWallet,Ke.recoverEmbeddedWallet;let Ve=r.useMemo((()=>({wallets:k,ready:ne&&de})),[k,ne,de]),$e=d.authFlow instanceof l.TelegramAuthFlow,Ye=!p.headless&&p.captchaEnabled&&!C&&(v||$e);/*#__PURE__*/return e.jsx(li.Provider,{value:!0,children:/*#__PURE__*/e.jsx(l.PrivyContext.Provider,{value:ze,children:/*#__PURE__*/e.jsx(y.PrivyEventsContext.Provider,{value:ce,children:/*#__PURE__*/e.jsx(l.UseWalletsContext.Provider,{value:Ve,children:/*#__PURE__*/e.jsx(l.CaptchaProvider,{...p,children:/*#__PURE__*/e.jsxs(s.InternalPrivyContext.Provider,{value:Ke,children:[/*#__PURE__*/e.jsx(l.RecentlyUsedAccountProvider,{children:/*#__PURE__*/e.jsxs(l.ModalProvider,{data:X,setModalData:Q,setInitialScreen:U,initialScreen:_,authenticated:C,open:m,children:[c.children,/*#__PURE__*/e.jsx(si,{customAuth:p.customAuth}),Ye&&/*#__PURE__*/e.jsx(Ct,{delayedExecution:!1}),/*#__PURE__*/e.jsx(Cr,{}),/*#__PURE__*/e.jsx(nn,{disabled:p.embeddedWallets.disableAutomaticMigration}),/*#__PURE__*/e.jsx(ar,{palette:p.appearance.palette||{}}),!p.render.standalone&&/*#__PURE__*/e.jsx(wr,{open:m})]})}),/*#__PURE__*/e.jsx(_r,{appId:c.appId,appClientId:c.clientId,clientAnalyticsId:d.clientAnalyticsId,origin:d.apiUrl,mfaMethods:A?.mfaMethods,mfaPromise:se,mfaSubmitPromise:le,onLoad:Z,onLoadFailed:()=>null}),p.loginConfig.telegramAuthConfiguration&&
|
|
6
|
-
/*#__PURE__*/e.jsx(l.Hide,{$if:!0,children:/*#__PURE__*/e.jsx(fr,{scriptHost:c.apiUrl||y.DEFAULT_PRIVY_API_URL,botUsername:p.loginConfig.telegramAuthConfiguration.botName})})]})})})})})})};const Ai=()=>{let{setModalData:e}=l.usePrivyModal(),{openModal:t,privy:n,closePrivyModal:i}=s.usePrivyInternal(),{user:a}=l.usePrivyContext();return r.useMemo((()=>({verify:async({standalone:r=!0}={standalone:!0})=>new Promise(((o,s)=>a?0===a.mfaMethods.length?o():(e((e=>({...e,mfaVerify:{onSuccess:async()=>{r?await i({shouldCallAuthOnSuccess:!1,isSuccess:!0}):ir.setState({inProgressMfaFlow:void 0}),o()},onFailure:async e=>{r?await i({shouldCallAuthOnSuccess:!1,isSuccess:!1}):ir.setState({inProgressMfaFlow:void 0}),s(e)},sendSmsCode:async()=>{throw Error("Not enabled")},verifySmsCode:async()=>{throw Error("Not enabled")},verifyTotpCode:async e=>{await n.fetchPrivyRoute(K.MfaAuthTotpVerify,{body:{code:e}})},generateOptions:async()=>st((await n.fetchPrivyRoute(K.MfaAuthPasskeyInit,{body:{}})).options),verifyPasskey:async e=>{let t=await import("@simplewebauthn/browser"),r=await t.startAuthentication({optionsJSON:e});await n.fetchPrivyRoute(K.MfaAuthPasskeyVerify,{body:{authenticator_response:an(r)}})}}}))),void(r?t(tr):ir.setState({inProgressMfaFlow:"auth"}))):s(Error("Must be logged in to verify MFA"))))})),[n,e,t,i])},Pi={component:()=>{let{user:t,ready:n}=l.usePrivyContext(),{data:i,onUserCloseViaDialogOrKeybindRef:a}=l.usePrivyModal(),o=y.useAppConfig(),[s,c]=r.useState(null),[d,u]=r.useState(null),[h,p]=r.useState(null),[m,w]=r.useState(!1),[g,v]=r.useState(!1),[f,C]=r.useState(),E=async()=>{f?A(f):t?await P({user:t}):A(Error("Must be logged in to manage MFA")),setTimeout((()=>{c(null),u(null)}),500)};if(a.current=E,!i?.mfaEnroll)throw Error("Missing modal data for MFA enrollment screen.");let{onFailure:A,onSuccess:P,onBack:k,mfaMethods:T,verify:x,generateTotpSecret:b,enrollTotp:S,unenrollTotp:_,enrollPasskey:I}=i.mfaEnroll,U=t?.mfaMethods.includes("sms"),W=t?.mfaMethods.includes("totp"),R=t?.mfaMethods.includes("passkey"),N=!!t?.phone,O=t?.linkedAccounts.filter((e=>"passkey"===e.type)).map((e=>e.credentialId))??[];function M(){c(null),u(null),C(void 0)}async function j(e=O){try{C(void 0),v(!0);let t=await I(e);return await P({user:t})}catch(e){C(e)}finally{v(!1),w(!1)}}if(!n||!t||!o)/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:E,backFn:k},"header"),/*#__PURE__*/e.jsx(At,{children:/*#__PURE__*/e.jsx(In,{})}),/*#__PURE__*/e.jsx(Tt,{children:/*#__PURE__*/e.jsx(l.Loader,{})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]});if("sms"===s)return null;if("totp"===s)/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:M,onClose:E},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(ue.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Remove authenticator app verification?"}),/*#__PURE__*/e.jsxs(kt,{children:["MFA adds an extra layer of security to your ",o?.name," account. Make sure you have other methods to secure your account."]}),/*#__PURE__*/e.jsx(_t,{children:/*#__PURE__*/e.jsx(l.PrimaryButton,{$warn:!0,onClick:async function(){try{C(void 0),v(!0);let e=await _();return await P({user:e})}catch(e){C(e)}finally{v(!1),c(null)}},loading:g,children:"Remove"})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]});if("passkey"===s){let t=i.mfaEnroll.shouldUnlinkOnUnenrollMfa??!0;/*#__PURE__*/return e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{backFn:M,onClose:E},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(ue.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Are you sure you want to remove this passkey?"}),/*#__PURE__*/e.jsx(kt,{children:t?"Removing your passkey will remove as both a verification method and a login method.":"Removing your passkey will remove as a verification method."}),/*#__PURE__*/e.jsx(_t,{children:/*#__PURE__*/e.jsx(l.PrimaryButton,{$warn:!0,onClick:async function(){try{C(void 0),v(!0);let e=await I([]);return await P({user:e})}catch(e){C(e)}finally{v(!1),c(null)}},loading:g,children:"Remove"})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]})}return 0!==T.length||U||W||R?"sms"===d?null:"totp"===d&&h?/*#__PURE__*/e.jsx(Vn,{onClose:E,onReset:M,submitEnrollmentWithTotp:e=>async function(e){try{C(void 0),v(!0);let t=await S(e);return await P({user:t})}catch(e){C(e)}finally{v(!1),c(null)}}(e.mfaCode),error:f,totpInfo:{...h,appName:o?.name||"Privy"}}):"passkey"===d?/*#__PURE__*/e.jsx(Mn,{onReset:M,onClose:E,submitEnrollmentWithPasskey:j}):/*#__PURE__*/e.jsx(Wn,{showIntro:!0,userMfaMethods:t.mfaMethods,appMfaMethods:o.mfa.methods,userHasAuthSms:N,backFn:k,handleSelectMethod:async function(e){C(void 0);try{await x()}catch(e){return void C(e)}return"totp"===e?(u(e),p(null),void b().then((({totpSecret:e,totpAuthUrl:t})=>{p({authUrl:t,secret:e})})).catch((()=>{p(null),M()}))):"passkey"===e&&1===O.length?await j():void u(e)},isTotpLoading:"totp"===d&&!h,isPasskeyLoading:m,error:f,onClose:E,setRemovingMfaMethod:async function(e){C(void 0);try{await x()}catch(e){return void C(e)}c(e)}}):/*#__PURE__*/e.jsxs(e.Fragment,{children:[/*#__PURE__*/e.jsx(l.ModalHeader,{onClose:E,backFn:k},"header"),/*#__PURE__*/e.jsx(Ft,{style:{marginBottom:"1.5rem"},children:/*#__PURE__*/e.jsx(se.default,{})}),/*#__PURE__*/e.jsx(Pt,{children:"Add more security"}),/*#__PURE__*/e.jsxs(kt,{children:[o?.name," does not have any verification methods enabled."]}),/*#__PURE__*/e.jsx(_t,{children:/*#__PURE__*/e.jsx(l.PrimaryButton,{onClick:E,children:"Close"})}),/*#__PURE__*/e.jsx(l.ModalFooter,{})]})}};const ki=async({wallet:e})=>{let t=await e.getEthereumProvider();return Y.toAccount({address:e.address,sign:async({hash:r})=>{if("privy"!==e.walletClientType)throw new a.PrivyClientError({error:"Unprefixed signing is not supported by external wallets.",code:"unsupported_wallet_type"});return await t.request({method:"secp256k1_sign",params:[r]})},signMessage:async({message:r})=>await t.request({method:"personal_sign",params:[r,e.address]}),signTypedData:async r=>await t.request({method:"eth_signTypedData_v4",params:[e.address,r]}),signTransaction:async e=>await t.request({method:"eth_signTransaction",params:[e]})})};let Ti=async(e,t,r,n,i)=>{if(!e)throw n("linkAccount","onError",s.PrivyErrorCode.MUST_BE_AUTHENTICATED,{linkMethod:i}),new s.PrivyClientError("User must be authenticated before linking an account.");if(!t?.linkedAccounts.some((e=>e.type.includes(i))))throw new s.PrivyClientError(`OAuth account of type ${i} not linked to the account.`);await r(i)};const xi=wr;Object.defineProperty(exports,"SUPPORTED_CHAINS",{enumerable:!0,get:function(){return a.DEFAULT_SUPPORTED_CHAINS}}),Object.defineProperty(exports,"addPrivyRpcToChain",{enumerable:!0,get:function(){return a.addPrivyRpcToChain}}),Object.defineProperty(exports,"addRpcUrlOverrideToChain",{enumerable:!0,get:function(){return a.addRpcUrlOverrideToChain}}),exports.EthereumWalletConnector=l.EthereumWalletConnector,exports.WalletConnector=l.WalletConnector,exports.errorIndicatesMaxMfaRetries=l.errorIndicatesMaxMfaRetries,exports.errorIndicatesMfaTimeout=l.errorIndicatesMfaTimeout,exports.errorIndicatesMfaVerificationFailed=l.errorIndicatesMfaVerificationFailed,exports.useWallets=l.useWallets,exports.VERSION=y.VERSION,exports.useActiveWallet=C.useActiveWallet,exports.useConnectWallet=C.useConnectWallet,exports.useFundWallet=C.useFundWallet,exports.useLogin=C.useLogin,exports.useLogout=C.useLogout,exports.useCreateWallet=I.useCreateWallet,exports.useImportWallet=I.useImportWallet,exports.usePrivy=I.usePrivy,exports.getEmbeddedConnectedWallet=Z.getEmbeddedConnectedWallet,exports.Captcha=Ct,exports.ConnectorManager=tt,exports.LoginModal=xi,exports.PrivyClient=vt,exports.PrivyModal=wr,exports.PrivyProvider=({config:t,...n})=>{(()=>{if(r.useContext(li))throw new s.PrivyClientError("Multiple PrivyProvider instances found","Found multiple instances of PrivyProvider, ensure there is only one mounted in your application tree.")})(),function(){if("undefined"==typeof window)return;let e=["localhost","127.0.0.1"].includes(window.location.hostname),t="https:"===window.location.protocol||"chrome-extension:"===window.location.protocol;if(!e&&!t)throw new s.PrivyClientError("Embedded wallet is only available over HTTPS")}(),function(e){if("string"!=typeof e||25!==e.length)throw new s.PrivyClientError("Cannot initialize the Privy provider with an invalid Privy app ID")}(n.appId),ci||(ci=new vt({appId:n.appId,appClientId:n.clientId,apiUrl:n.apiUrl}));let i=Object.assign({},t),a=r.useMemo((()=>new ee.default({appId:n.appId,clientId:n.clientId,storage:l.p,baseUrl:n.apiUrl,sdkVersion:"react-auth:3.7.0"})),[]);/*#__PURE__*/return e.jsx(y.PrivyAppConfigProvider,{client:a,legacyClient:ci,appClientId:n.clientId,clientConfig:i,children:/*#__PURE__*/e.jsx(l.PrivyPluginProvider,{children:/*#__PURE__*/e.jsx(Ei,{...n,client:ci,privy:a})})})},exports.getAccessToken=function(){return ci?ci.getCustomerAccessToken():Promise.resolve(l.p.get(y.CUSTOMER_ACCESS_TOKEN_STORAGE_KEY)||null)},exports.getIdentityToken=async function(){return await(ci?.updateUserAndIdToken()),ci?.useServerCookies?ut.getState().identityToken:Promise.resolve(l.p.get(y.IDENTITY_TOKEN_STORAGE_KEY)||null)},exports.toViemAccount=ki,exports.useAuthMfa=Ai,exports.useAuthMfaEnrollment=()=>{let e=y.useAppConfig(),{setModalData:t}=l.usePrivyModal(),{verify:n}=Ai(),{openModal:i,privy:a,closePrivyModal:o,refreshSessionAndUser:c,setUser:d}=s.usePrivyInternal();return r.useMemo((()=>({enroll:async r=>new Promise(((s,l)=>{t({mfaEnroll:{onSuccess:async e=>{await o({shouldCallAuthOnSuccess:!1,isSuccess:!0}),s(e)},onFailure:async e=>{await o({shouldCallAuthOnSuccess:!1,isSuccess:!1}),l(e)},onBack:r?.onBack?async()=>{await o({shouldCallAuthOnSuccess:!1,isSuccess:!1}),l(Error("User canceled MFA enrollment flow.")),r.onBack?.()}:void 0,verify:()=>n({standalone:!1}),shouldUnlinkOnUnenrollMfa:!0,mfaMethods:e.mfa.methods,sendSmsCode:async()=>{throw Error("Not enabled")},enrollSms:async()=>{throw Error("Not enabled")},unenrollSms:async()=>{throw Error("Not enabled")},generateTotpSecret:async()=>await a.fetchPrivyRoute(K.MfaAuthTotpInit,{body:{}}),enrollTotp:async e=>{await a.fetchPrivyRoute(K.MfaAuthTotpEnroll,{body:{code:e}});let t=await c();return d(t),t},unenrollTotp:async()=>{await a.fetchPrivyRoute(K.MfaAuthTotpUnenroll,{body:{}});let e=await c();return d(e),e},enrollPasskey:async e=>{await a.fetchPrivyRoute(K.MfaAuthPasskeyEnrollment,{body:{credential_ids:e,remove_for_login:!0}});let t=await c();return d(t),t}}}),i(Pi)}))})),[a,t,i,o])},exports.useAuthorizationSignature=()=>{let{signWithUserSigner:e}=G.useSignWithUserSigner();return r.useMemo((()=>({async generateAuthorizationSignature(t){let{targetAppId:r,...n}=t,{signature:i}=await a.generateAuthorizationSignature((async({message:t})=>e({message:t,targetAppId:r})),n);return{signature:i}}})),[e])},exports.useBaseAccountSdk=()=>{let{baseAccountSdk:e}=s.usePrivyInternal();return{baseAccountSdk:e}},exports.useConnectBaseAccount=()=>{let{connectBaseAccount:e}=s.usePrivyInternal();return{connectBaseAccount:e}},exports.useConnectCoinbaseSmartWallet=()=>{let{connectCoinbaseSmartWallet:e}=s.usePrivyInternal();return{connectCoinbaseSmartWallet:e}},exports.useConnectOrCreateWallet=e=>{let{connectOrCreateWallet:t}=l.usePrivyContext();return y.usePrivyEventSubscription("connectOrCreateWallet",e),{connectOrCreateWallet:t}},exports.useCrossAppAccounts=()=>{let{startCrossAppAuthFlow:e,unlinkCrossAppAccount:t,signMessageWithCrossAppWallet:r,signTypedDataWithCrossAppWallet:n,sendTransactionWithCrossAppWallet:i,signTransactionWithCrossAppWallet:a}=l.usePrivyContext();return{loginWithCrossAppAccount:({appId:t})=>e({appId:t,action:"login"}),linkCrossAppAccount:({appId:t})=>e({appId:t,action:"link"}),unlinkCrossAppAccount:t,signMessage:r,signTypedData:n,sendTransaction:i,signTransaction:a}},exports.useCustomAuth=e=>{let t=oi((e=>e.jwtAuthFlowState));return y.usePrivyEventSubscription("customAuth",e),{status:t}},exports.useDelegatedActions=()=>{let{revokeDelegatedWallets:e,delegateWallet:t}=s.usePrivyInternal();return{delegateWallet:async({address:e,chainType:r})=>await t({address:e,chainType:r,showDelegationUIs:!0}),revokeWallets:async()=>await e({showDelegationUIs:!0})}},exports.useFarcasterSigner=function(){let{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:r}=l.usePrivyContext();return{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:r}},exports.useGetAccessTokenForProvider=()=>r.useMemo((()=>({getAccessTokenForProvider:({appId:e})=>{try{let t=l.p.get(y.getProviderAccessTokenStorageKey(e));if("string"!=typeof t)return{token:null};{let r=new Fe(t);return r.isExpired()?(l.p.del(y.getProviderAccessTokenStorageKey(e)),{token:null}):{token:r.value}}}catch(e){return console.error(e),{token:null}}}})),[]),exports.useGuestAccounts=function(){let e=y.useAppConfig(),t=y.useEmitPrivyEvent(),{client:r,setUser:n,setAuthenticated:i,setIsNewUser:a,initializeWalletProxy:o}=s.usePrivyInternal(),{create:c}=I.useCreateWalletInternal();return{createGuestAccount:async()=>{if(!e.id||!r)throw Error("SDK not yet ready");r.startAuthFlow(new ct(e.id));try{let d=await r.authenticate(),u=d.user,h=d.isNewUser??!1;if(!u)throw new s.PrivyClientError("Unable to authenticate guest account");let p=await r.getAccessToken(),m=await o(y.WALLET_PROXY_TIMEOUT);if(p&&m)try{let t=l.shouldCreateEmbeddedEthWallet(u,e.embeddedWallets.ethereum.createOnLogin),r=l.shouldCreateEmbeddedSolWallet(u,e.embeddedWallets.solana.createOnLogin);t&&r?(u=(await c({chainType:"ethereum",latestUser:u})).user,u=(await c({chainType:"solana",latestUser:u})).user):r?u=(await c({chainType:"solana",latestUser:u})).user:t?u=(await c({chainType:"ethereum",latestUser:u})).user:n(u)}catch(e){n(u),console.warn("Unable to create embedded wallet for guest account")}return a(h),i(!0),t("login","onComplete",{user:u,isNewUser:h,wasAlreadyAuthenticated:!1,loginMethod:"guest",loginAccount:null}),u}catch(e){throw t("login","onError",e.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),e}}}},exports.useHeadlessDelegatedActions=()=>{let{revokeDelegatedWallets:e,delegateWallet:t}=s.usePrivyInternal();return{delegateWallet:async({address:e,chainType:r})=>await t({address:e,chainType:r,showDelegationUIs:!1}),revokeWallets:async()=>await e({showDelegationUIs:!1})}},exports.useIdentityToken=function(){let{identityToken:e}=ut();return{identityToken:e}},exports.useLinkAccount=function(e){let{linkEmail:t,linkPhone:n,linkWallet:i,linkGoogle:a,linkApple:o,linkTwitter:s,linkTwitch:c,linkDiscord:d,linkGithub:u,linkLinkedIn:h,linkTiktok:p,linkLine:m,linkSpotify:w,linkInstagram:g,linkTelegram:v,linkFarcaster:f,linkPasskey:C}=r.useContext(l.PrivyContext);return y.usePrivyEventSubscription("linkAccount",e),{linkEmail:t,linkPhone:n,linkWallet:i,linkGoogle:a,linkApple:o,linkTwitter:s,linkTwitch:c,linkDiscord:d,linkGithub:u,linkLinkedIn:h,linkTiktok:p,linkLine:m,linkSpotify:w,linkInstagram:g,linkFarcaster:f,linkTelegram:v,linkPasskey:C}},exports.useLinkJwtAccount=function(e){let{client:t}=s.usePrivyInternal(),[n,i]=r.useState({status:"initial"});return{linkWithCustomJwt:r.useCallback((async r=>{try{i({status:"initial"}),t.startAuthFlow(new lt(r)),i({status:"loading"});let{user:n}=await t.link();if(!n)throw Error("Error, user not found");let a=n.linkedAccounts.filter((e=>"custom_auth"===e.type)).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime())).at(0);return i({status:"done"}),e?.onSuccess?.({user:n,linkMethod:"custom",linkedAccount:a}),{user:n}}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:"custom"}),r}}),[t.startAuthFlow,t.link]),state:n}},exports.useLinkWithPasskey=e=>{let{initLinkWithPasskey:t,linkWithPasskey:n,passkeyAuthState:i,setPasskeyAuthState:a}=s.usePrivyInternal();return{linkWithPasskey:r.useCallback((async()=>{try{await t();let r=await n();if(!r)throw Error("Error, user not found");let i=r.linkedAccounts.filter((e=>"passkey"===e.type)).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime()))[0];e?.onSuccess?.({user:r,linkMethod:"passkey",linkedAccount:i})}catch(t){throw a({status:"error",error:t}),e?.onError?.(t.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:"passkey"}),t}}),[n]),state:i}},exports.useLinkWithSiwe=e=>{let t=l.useCaptcha(),{siweState:n,setSiweState:i,linkWithSiwe:a,generateSiweMessage:o}=s.usePrivyInternal();return{generateSiweMessage:r.useCallback((async({address:t,chainId:r})=>{try{if(!t||!r)throw Error("wallet address and chainId required to generate nonce");return await o({address:t,chainId:r}).then((e=>e))}catch(t){throw i({status:"error",error:t}),e?.onError?.(t.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:"siwe"}),t}}),[o]),linkWithSiwe:r.useCallback((async({signature:r,message:n,chainId:o,walletClientType:c,connectorType:d})=>{try{if(t.enabled&&"success"!==t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);let{user:i,linkedAccount:u}=await a({message:n,signature:r,chainId:o,walletClientType:c,connectorType:d});u&&e?.onSuccess?.({user:i,linkMethod:"siwe",linkedAccount:u})}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:"siwe"}),r}}),[a,t.status]),state:n}},exports.useLinkWithSiws=()=>{let e=l.useCaptcha(),{client:t,setUser:n,refreshSessionAndUser:i}=s.usePrivyInternal(),{authenticated:a}=I.usePrivy();return{generateSiwsMessage:r.useCallback((async({address:r})=>{let n;if(e.enabled&&"error"===e.status)throw new l.CaptchaError(e.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);e.enabled&&"success"!==e.status&&(e.execute(),n=await e.waitForResult());let i=await t.generateSiwsNonce({address:r,captchaToken:n});return l.prepareSiwsMessageWithNonce({address:r,nonce:i})}),[e,t]),linkWithSiws:r.useCallback((async({signature:r,message:o,walletClientType:c,connectorType:d})=>{if(!a)throw Error("User must be authenticated before linking");if(e.enabled&&"error"===e.status)throw new l.CaptchaError(e.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);let u=await t.linkWithSiws({message:o,signature:r,walletClientType:c,connectorType:d,messageType:"plain"}),h=(e=>{if(!e)return;let t=e.linkedAccounts;return t&&0!==t.length?t[t.length-1]:void 0})(u=await i()??u)||null;return n(u||null),{user:u,linkedAccount:h}}),[a,e,t,i,n])}},exports.useLoginWithEmail=e=>{let t=l.useCaptcha(),{emailOtpState:n,setEmailOtpState:i,initLoginWithEmail:a,loginWithCode:o}=s.usePrivyInternal();return{sendCode:r.useCallback((async({email:r,disableSignup:n})=>{try{let e;if(!r)throw Error("Email required to send OTP code");if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);return t.enabled&&"success"!==t.status&&(t.execute(),e=await t.waitForResult()),await a({email:r,captchaToken:e,disableSignup:n,withPrivyUi:!1})}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[a]),loginWithCode:r.useCallback((async({code:r})=>{try{if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);let{user:n,isNewUser:i,wasAlreadyAuthenticated:a,linkedAccount:c}=await o(r);e?.onComplete?.({user:n,isNewUser:i,wasAlreadyAuthenticated:a,loginMethod:"email",loginAccount:c})}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[o,t.status]),state:n}},exports.useLoginWithFarcasterV2=()=>{let{client:e,setAuthenticated:t,setUser:n}=s.usePrivyInternal();return r.useMemo((()=>({init:async()=>{if(!e)throw new s.PrivyClientError("Must initialize Privy client first.");let t=new z.FarcasterFramesFlow;return e.startAuthFlow(t),await t.init()},login:async({fid:r,message:i,signature:a})=>{if(!e)throw new s.PrivyClientError("Must initialize Privy client first.");if(!(e.authFlow instanceof z.FarcasterFramesFlow))throw new s.PrivyClientError("Must initialize Farcaster Mini App flow first.");e.authFlow.setAuthData({message:i,signature:a,fid:r});let{user:o}=await e.authenticate();if(!o)throw new s.PrivyClientError("Failed to login with Farcaster V2");return n(o),t(!0),{user:o}}})),[e,n,t])},exports.useLoginWithOAuth=e=>{y.usePrivyEventSubscription("login",e);let t=l.useCaptcha(),n=y.useIsServerConfigLoaded(),{ready:i,user:a}=l.usePrivyContext(),{initLoginWithHeadlessOAuth:o,loginWithHeadlessOAuth:c,oAuthState:d,setOAuthState:u,isHeadlessOAuthLoading:h}=s.usePrivyInternal(),p=r.useCallback((async e=>{try{if(t.enabled&&"success"!==t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);return await o(e.provider,t.token,e.disableSignup)}catch(e){throw u({status:"error",error:e}),e}}),[o,t]),m=r.useCallback((async()=>{let e=Ne();try{if(!e.inProgress)throw Error("Cannot login with OAuth because no OAuth flow is in progress");let t=e.provider;if(l.isCustomOAuthProvider(t)){if(a&&a.linkedAccounts.some((e=>e.type===t)))return console.warn("User is already logged in with this OAuth provider"),a}else if(a&&t in a&&a[t])return console.warn("User is already logged in with this OAuth provider"),a;if(e.popupFlow)return}catch(e){throw u({status:"error",error:e}),e}try{return await c(e)}catch(e){throw u({status:"error",error:e}),e}finally{l.stripUrlOAuthParamsAndRemoveStateCode()}}),[c]);return r.useEffect((()=>{let e=Ne();i&&n&&e.inProgress&&!e.withPrivyUi&&!e.popupFlow&&m().catch((()=>{}))}),[i,n]),{initOAuth:p,loading:h,state:d}},exports.useLoginWithPasskey=e=>{let t=l.useCaptcha(),{initLoginWithPasskey:n,loginWithPasskey:i,passkeyAuthState:a,setPasskeyAuthState:o}=s.usePrivyInternal();return{loginWithPasskey:r.useCallback((async r=>{try{let a;if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);t.enabled&&"success"!==t.status&&(t.execute(),a=await t.waitForResult()),await n({captchaToken:a,withPrivyUi:!1});let{user:o,isNewUser:c,wasAlreadyAuthenticated:d,loginAccount:u}=await i(r);e?.onComplete?.({user:o,isNewUser:c,wasAlreadyAuthenticated:d,loginMethod:"passkey",loginAccount:u})}catch(r){throw o({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[i,t.status]),state:a}},exports.useLoginWithSiwe=e=>{let t=l.useCaptcha(),{siweState:n,setSiweState:i,client:a,generateSiweMessage:o,loginWithSiwe:c}=s.usePrivyInternal();return{generateSiweNonce:r.useCallback((async r=>{try{let e;if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);t.enabled&&"success"!==t.status&&(t.execute(),e=await t.waitForResult()),i({status:"generating-message"});let n=await a.generateSiweNonce({address:r?.address,captchaToken:e});return i({status:"awaiting-signature"}),n}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[a,t]),generateSiweMessage:r.useCallback((async({address:r,chainId:n})=>{try{let e;if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);return t.enabled&&"success"!==t.status&&(t.execute(),e=await t.waitForResult()),await o({address:r,chainId:n,captchaToken:e})}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[o,t]),loginWithSiwe:r.useCallback((async({message:r,signature:n,disableSignup:a,walletClientType:o,connectorType:d})=>{try{let i;if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);t.enabled&&"success"!==t.status&&(t.execute(),i=await t.waitForResult());let{user:u,isNewUser:h}=await c({message:r,signature:n,captchaToken:i,disableSignup:a,walletClientType:o,connectorType:d});return e?.onComplete?.({user:u,isNewUser:h,wasAlreadyAuthenticated:!1,loginMethod:"siwe",loginAccount:null}),u}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[c,t.status]),state:n}},exports.useLoginWithSiws=()=>{let e=l.useCaptcha(),{client:t,setAuthenticated:n,setUser:i,setIsNewUser:a}=s.usePrivyInternal(),{authenticated:o}=I.usePrivy();return{generateSiwsMessage:r.useCallback((async({address:r})=>{let n;if(e.enabled&&"error"===e.status)throw new l.CaptchaError(e.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);e.enabled&&"success"!==e.status&&(e.execute(),n=await e.waitForResult());let i=await t.generateSiwsNonce({address:r,captchaToken:n});return l.prepareSiwsMessageWithNonce({address:r,nonce:i})}),[e,t]),loginWithSiws:r.useCallback((async({message:r,signature:c,disableSignup:d,walletClientType:u,connectorType:h})=>{if(o)throw Error("User already authenticated");if(e.enabled&&"error"===e.status)throw new l.CaptchaError(e.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);e.enabled&&"success"!==e.status&&(e.execute(),await e.waitForResult());let{user:p,isNewUser:y}=await t.authenticateWithSiws({message:r,signature:c,walletClientType:u,connectorType:h,mode:d?"no-signup":"login-or-sign-up",messageType:"plain"});if(!p)throw Error("Authentication failed - no user returned");return i(p),a(y||!1),n(!0),p}),[o,e,t,n,i,a])}},exports.useLoginWithSms=e=>{let t=l.useCaptcha(),{smsOtpState:n,setSmsOtpState:i,initLoginWithSms:a,loginWithCode:o}=s.usePrivyInternal();return{sendCode:r.useCallback((async({phoneNumber:r,disableSignup:n})=>{try{let e;if(!r)throw Error("SMS required to send OTP code");if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);return t.enabled&&"success"!==t.status&&(t.execute(),e=await t.waitForResult()),await a({phoneNumber:r,captchaToken:e,disableSignup:n,withPrivyUi:!1})}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[a]),loginWithCode:r.useCallback((async({code:r})=>{try{if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);let{user:n,isNewUser:i,wasAlreadyAuthenticated:a,linkedAccount:c}=await o(r);e?.onComplete?.({user:n,isNewUser:i,wasAlreadyAuthenticated:a,loginMethod:"sms",loginAccount:c})}catch(r){throw i({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[o,t.status]),state:n}},exports.useLoginWithTelegram=e=>{let t=l.useCaptcha(),{initLoginWithTelegram:n,loginWithTelegram:i,telegramAuthState:a,setTelegramAuthState:o}=s.usePrivyInternal();return{login:r.useCallback((async r=>{try{if(t.enabled&&"success"!==t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);await n(t.token,r?.disableSignup);let{user:a,isNewUser:o,loginAccount:c,wasAlreadyAuthenticated:d}=await i({intent:"login"});e?.onComplete?.({user:a,isNewUser:o,wasAlreadyAuthenticated:d,loginMethod:"telegram",loginAccount:c})}catch(r){throw o({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),r}}),[n,i,t]),state:a}},exports.useMfa=rr,exports.useMfaEnrollment=_n,exports.useMigrateWallets=rn,exports.useModalStatus=()=>{let{isModalOpen:e}=r.useContext(l.PrivyContext);return{isOpen:e}},exports.useOAuthTokens=function(e){let{authenticated:t,user:r}=l.usePrivyContext(),{initLoginWithOAuth:n}=s.usePrivyInternal(),i=y.useEmitPrivyEvent();return y.usePrivyEventSubscription("oAuthAuthorization",e),{reauthorize:e=>Ti(t,r,n,i,e.provider)}},exports.useRecoverEmbeddedWallet=()=>{let{user:e}=l.usePrivyContext(),{walletProxy:t}=s.usePrivyInternal();return{recover:r.useCallback((async r=>{if(!t)throw Error("Wallet proxy is not ready");let n=await mi();if(!e||!n)throw new s.PrivyClientError("User must be logged in before attempting to modify the recovery method.");let{entropyId:i,entropyIdVerifier:a}=l.getEntropyDetailsForUser(e);try{await t.recover({entropyId:i,entropyIdVerifier:a,accessToken:n,...r})}catch{throw new s.PrivyClientError("Unable to recover wallets")}}),[t,e])}},exports.useRegisterMfaListener=Et,exports.useSendTransaction=function(e){let{sendTransaction:t}=r.useContext(l.PrivyContext);return y.usePrivyEventSubscription("sendTransaction",e),{sendTransaction:t}},exports.useSessionSigners=()=>{let{addSessionSignersInternal:e,removeSessionSignersInternal:t}=(()=>{let{user:e}=l.usePrivyContext(),t=s.usePrivyInternal(),{signWithUserSigner:r}=G.useSignWithUserSigner(),n=async({wallet:n,additional_signers:i})=>{let o=await t.client.getAccessToken();if(!e||!o)throw new s.PrivyClientError("User must be authenticated and have an embedded wallet to delegate actions.");if(!n.id)throw new s.PrivyClientError("Wallet to add signers to must have ID on server");if(!t.walletProxy)throw new s.PrivyClientError("Wallet proxy not initialized.");await a.updateWallet(t.privy,{wallet_id:n.id},r,{additional_signers:i})};return{addSessionSignersInternal:async({address:r,signers:i})=>{let o=await t.client.getAccessToken();if(!e||!o)throw new s.PrivyClientError("User must be authenticated and have an embedded wallet to add a session signer.");let c=t.walletProxy??await t.initializeWalletProxy(15e3);if(!c)throw new s.PrivyClientError("Wallet proxy not initialized.");let d=l.getPrivyWalletWithAddress(e,r);if(!d)throw new s.PrivyClientError("Address to add signers too is not associated with current user.");if(l.getIsUnifiedWallet(d)){if(0===i.length)throw new s.PrivyClientError("Must specify at least one signer to add.");let e=[...(await a.getWallet(t.privy,{wallet_id:d.id})).additional_signers,...l.parseAdditionalSigners(i)];await n({wallet:d,additional_signers:e})}else{if(d.delegated)return{user:e};if(i.length>0)throw new s.PrivyClientError("Specifying signers in addSessionSigners is only supported for TEE execution and this app uses On-device execution. Pass an empty array for signers instead. Learn more https://docs.privy.io/recipes/tee-wallet-migration-guide");let n=Ir({address:r,user:e}),a=Ur({address:r,user:e});await t.recoverEmbeddedWallet({address:r}),await c.createDelegatedAction({accessToken:o,rootWallet:a,delegatedWallets:[n]})}let u=await t.refreshSessionAndUser();if(!u)throw Error("Could not refresh user");return{user:u}},removeSessionSignersInternal:async({address:r})=>{let i=await t.client.getAccessToken();if(!e||!i)throw new s.PrivyClientError("User must be authenticated and have an embedded wallet to delegate actions.");if(!(t.walletProxy??await t.initializeWalletProxy(15e3)))throw new s.PrivyClientError("Wallet proxy not initialized.");let a=l.getPrivyWalletWithAddress(e,r);if(!a)throw new s.PrivyClientError("Address to remove signers from is not associated with current user.");l.getIsUnifiedWallet(a)?await n({wallet:a,additional_signers:[]}):await t.client.revokeDelegatedWallet();let o=await t.refreshSessionAndUser();if(!o)throw Error("Could not refresh user");return{user:o}}}})();return{addSessionSigners:async({address:t,signers:r})=>e({address:t,signers:r}),removeSessionSigners:async({address:e})=>t({address:e})}},exports.useSetWalletRecovery=function(e){let{setWalletRecovery:t}=r.useContext(l.PrivyContext);return y.usePrivyEventSubscription("setWalletRecovery",e),{setWalletRecovery:t}},exports.useSign7702Authorization=()=>{let{ready:e,wallets:t}=l.useWallets(),{user:n}=l.usePrivyContext(),{rpcConfig:a,chains:o,appId:c}=s.usePrivyInternal();return{signAuthorization:r.useCallback((async(r,s)=>{let d;if(!n)throw Error("User must be authenticated before signing with a Privy wallet");if(!e)throw Error("Wallets are not ready");let u=s?.address??l.getPrivyEthereumWallet(n)?.address??b.zeroAddress,h=t.find((e=>b.getAddress(e.address)===b.getAddress(u)));if(!h)throw Error("Signing wallet not found.");let p=r.chainId??Number(h.chainId.split(":")[1]);if(0===p)d={chainId:0,address:r.contractAddress,nonce:r.nonce??0};else{let e=o.find((e=>e.id===p));if(!e)throw Error("Error, chain not configured in PrivyProvider config");let t=b.createWalletClient({account:u,chain:e,transport:b.http(l.getJsonRpcEndpointFromChain(e,a,c))});d=await t.prepareAuthorization({...r})}let y=await h.getEthereumProvider(),m=await y.request({method:"secp256k1_sign",params:[i.hashAuthorization(d)]});return{...d,...b.parseSignature(m)}}),[e,t,n,o])}},exports.useSignMessage=function(e){let{signMessage:t}=r.useContext(l.PrivyContext);return y.usePrivyEventSubscription("signMessage",e),{signMessage:t}},exports.useSignTransaction=function(){let{signTransaction:e}=r.useContext(l.PrivyContext);return{signTransaction:e}},exports.useSignTypedData=function(e){let{signTypedData:t}=r.useContext(l.PrivyContext);return y.usePrivyEventSubscription("signTypedData",e),{signTypedData:t}},exports.useSignupWithPasskey=e=>{let t=l.useCaptcha(),{initSignupWithPasskey:n,signupWithPasskey:i,passkeyAuthState:a,setPasskeyAuthState:o}=s.usePrivyInternal();return{signupWithPasskey:r.useCallback((async()=>{try{let r;if(t.enabled&&"error"===t.status)throw new l.CaptchaError(t.error,null,s.PrivyErrorCode.CAPTCHA_FAILURE);t.enabled&&"success"!==t.status&&(t.execute(),r=await t.waitForResult()),await n({captchaToken:r,withPrivyUi:!1});let{user:a,isNewUser:o,wasAlreadyAuthenticated:c,loginAccount:d}=await i();e?.onComplete?.({user:a,isNewUser:o,wasAlreadyAuthenticated:c,loginMethod:"passkey",loginAccount:d})}catch(t){throw o({status:"error",error:t}),e?.onError?.(t.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR),t}}),[i,t.status]),state:a}},exports.useSubscribeToJwtAuthWithFlag=function({isAuthenticated:e,isLoading:t,...n}){let i=r.useRef();r.useEffect((()=>{t||i.current?.()}),[e,t]);let a=r.useCallback((e=>(i.current=e,()=>{i.current=void 0})),[]);return ai({...n,subscribe:a})},exports.useSyncJwtBasedAuthState=ai,exports.useToken=function(e){let{getAccessToken:t}=r.useContext(l.PrivyContext);return y.usePrivyEventSubscription("accessToken",e),{getAccessToken:t}},exports.useUpdateAccount=function(e){let{updateEmail:t,updatePhone:n}=r.useContext(l.PrivyContext);return y.usePrivyEventSubscription("update",e),{updateEmail:t,updatePhone:n}},exports.useUpdateEmail=e=>{let{user:t}=l.usePrivyContext(),{loginWithCode:n,emailOtpState:i,setEmailOtpState:a,client:o,inProgressAuthFlowRef:c,inProgressLoginOrLinkMethodRef:d}=s.usePrivyInternal();return{state:i,sendCode:r.useCallback((async({newEmailAddress:r})=>{try{if(!t?.email)throw Error("User is required to have an email address to update it.");let e=new Pe(t.email.address,r);o.startAuthFlow(e),await e.sendCodeEmail({withPrivyUi:!1})}catch(r){a({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:"email"})}}),[t?.email]),verifyCode:r.useCallback((async({code:r})=>{try{if(!t?.email)throw Error("User is required to have an email address to update it.");c.current="update",d.current="email";let{user:i,linkedAccount:a}=await n(r);return e?.onSuccess?.({user:i,updateMethod:"email",updatedAccount:a}),{user:i}}catch(r){a({status:"error",error:r}),e?.onError?.(r.privyErrorCode||s.PrivyErrorCode.UNKNOWN_AUTH_ERROR,{linkMethod:"email"})}}),[t?.email])}},exports.useUser=()=>{let{setUser:e,client:t}=r.useContext(s.InternalPrivyContext),{user:n}=r.useContext(l.PrivyContext);return{user:n,refreshUser:r.useCallback((async()=>{let r=await(t?.updateUserAndIdToken());return e(r??null),r}),[t,e])}},exports.useX402Fetch=()=>{let{wallets:e}=l.useWallets();return r.useMemo((()=>({wrapFetchWithPayment:({walletAddress:t,fetch:r,maxValue:n=BigInt(1e5),paymentRequirementsSelector:i=V.selectPaymentRequirements,config:a})=>{let o=t||e[0]?.address;if(!o)throw new $.InvalidInputError("No wallet available for payment");let s=e.find((e=>l.areAddressesEqual(e.address,o)));if(!s)throw new $.InvalidInputError(`Wallet ${o} not found in connected wallets`);return async(e,t)=>{let o=await r(e,t);if(402!==o.status)return o;if(t?.__is402Retry)throw Error("Payment already attempted for this request");let{x402Version:l,accepts:c}=await o.json(),d=i(c,void 0,"exact");if(BigInt(d.maxAmountRequired)>n)throw new $.InvalidInputError("Payment amount exceeds maximum allowed");let u=await ki({wallet:s}),h=await V.createPaymentHeader(u,l,d,a),p={...t,headers:{...t?.headers||{},"X-PAYMENT":h,"Access-Control-Expose-Headers":"X-PAYMENT-RESPONSE"},__is402Retry:!0};return await r(e,p)}}})),[e])};
|
|
1
|
+
"use strict";var e=require("./index-DvDeCr_m.js"),t=require("./prepareFundingModalData-BVlyr8l5.js"),s=require("./useActiveWallet-DcxqWAsq.js"),r=require("./useWallets-h2xCj02C.js"),i=require("./usePrivy-CXPeoT5g.js"),o=require("./context-JUEgi5-6.js"),u=require("@privy-io/js-sdk-core"),n=require("./getEmbeddedConnectedWallet-6TsVZJkD.js");require("react/jsx-runtime"),require("react"),require("uuid"),require("jose"),require("./get-is-unified-wallet-DmiciSes.js"),require("viem"),require("./internal-context-VDPFkIXN.js"),require("ofetch"),require("eventemitter3"),require("@coinbase/wallet-sdk"),require("@privy-io/ethereum"),require("mipd"),require("react-device-detect"),require("viem/utils"),require("@privy-io/popup"),require("./paths-DizMb-lU.js"),require("@scure/base"),require("@marsidev/react-turnstile"),require("styled-components"),require("./events-context-Di6--rDg.js"),require("zustand"),require("@headlessui/react"),require("@walletconnect/ethereum-provider"),require("@privy-io/urls"),require("./getPublicClient-EjAv8R2z.js"),require("js-cookie"),require("./frame-bPqBJ8fS.js"),require("@privy-io/routes"),require("x402/client"),require("@privy-io/api-base"),require("viem/accounts"),require("./use-sign-with-user-signer-On9f1Fag.js"),require("tinycolor2"),exports.Captcha=e.Captcha,exports.ConnectorManager=e.ConnectorManager,exports.LoginModal=e.LoginModal,exports.PrivyClient=e.PrivyClient,exports.PrivyModal=e.PrivyModal,exports.PrivyProvider=e.PrivyProvider,exports.errorIndicatesMaxMfaRetries=e.errorIndicatesMaxMfaRetries,exports.errorIndicatesMfaTimeout=e.errorIndicatesMfaTimeout,exports.errorIndicatesMfaVerificationFailed=e.errorIndicatesMfaVerificationFailed,exports.getAccessToken=e.getCustomerAccessToken,exports.getIdentityToken=e.getIdentityToken,exports.toViemAccount=e.toViemAccount,exports.useAuthMfa=e.useAuthMfa,exports.useAuthMfaEnrollment=e.useAuthMfaEnrollment,exports.useAuthorizationSignature=e.useAuthorizationSignature,exports.useBaseAccountSdk=e.useBaseAccountSdk,exports.useConnectBaseAccount=e.useConnectBaseAccount,exports.useConnectCoinbaseSmartWallet=e.useConnectCoinbaseSmartWallet,exports.useConnectOrCreateWallet=e.useConnectOrCreateWallet,exports.useCrossAppAccounts=e.useCrossAppAccounts,exports.useCustomAuth=e.useCustomAuth,exports.useDelegatedActions=e.useDelegatedActions,exports.useFarcasterSigner=e.useFarcasterSigner,exports.useGetAccessTokenForProvider=e.useGetAccessTokenForProvider,exports.useGuestAccounts=e.useGuestAccounts,exports.useHeadlessDelegatedActions=e.useHeadlessDelegatedActions,exports.useIdentityToken=e.useIdentityToken,exports.useLinkAccount=e.useLinkAccount,exports.useLinkJwtAccount=e.useLinkJwtAccount,exports.useLinkWithPasskey=e.useLinkWithPasskey,exports.useLinkWithSiwe=e.useLinkWithSiwe,exports.useLinkWithSiws=e.useLinkWithSiws,exports.useLoginWithEmail=e.useLoginWithEmail,exports.useLoginWithFarcasterV2=e.useLoginWithFarcasterV2,exports.useLoginWithOAuth=e.useLoginWithOAuth,exports.useLoginWithPasskey=e.useLoginWithPasskey,exports.useLoginWithSiwe=e.useLoginWithSiwe,exports.useLoginWithSiws=e.useLoginWithSiws,exports.useLoginWithSms=e.useLoginWithSms,exports.useLoginWithTelegram=e.useLoginWithTelegram,exports.useMfa=e.useMfa,exports.useMfaEnrollment=e.useMfaEnrollment,exports.useMigrateWallets=e.useMigrateWallets,exports.useModalStatus=e.useModalStatus,exports.useOAuthTokens=e.useOAuthTokens,exports.useRecoverEmbeddedWallet=e.useRecoverEmbeddedWallet,exports.useRegisterMfaListener=e.useRegisterMfaListener,exports.useSendTransaction=e.useSendTransaction,exports.useSessionSigners=e.useSessionSigners,exports.useSetWalletRecovery=e.useSetWalletRecovery,exports.useSign7702Authorization=e.useSign7702Authorization,exports.useSignMessage=e.useSignMessage,exports.useSignTransaction=e.useSignTransaction,exports.useSignTypedData=e.useSignTypedData,exports.useSignupWithPasskey=e.useSignupWithPasskey,exports.useSubscribeToJwtAuthWithFlag=e.useSubscribeToJwtAuthWithFlag,exports.useSyncJwtBasedAuthState=e.useSyncJwtBasedAuthState,exports.useToken=e.useToken,exports.useUpdateAccount=e.useUpdateAccount,exports.useUpdateEmail=e.useUpdateEmail,exports.useUser=e.useUser,exports.useX402Fetch=e.useX402Fetch,exports.WalletConnector=t.WalletConnector,exports.EthereumWalletConnector=s.EthereumWalletConnector,exports.useActiveWallet=s.useActiveWallet,exports.useConnectWallet=s.useConnectWallet,exports.useFundWallet=s.useFundWallet,exports.useLogin=s.useLogin,exports.useLogout=s.useLogout,exports.useWallets=r.useWallets,exports.useCreateWallet=i.useCreateWallet,exports.useImportWallet=i.useImportWallet,exports.usePrivy=i.usePrivy,exports.VERSION=o.VERSION,Object.defineProperty(exports,"SUPPORTED_CHAINS",{enumerable:!0,get:function(){return u.DEFAULT_SUPPORTED_CHAINS}}),Object.defineProperty(exports,"addPrivyRpcToChain",{enumerable:!0,get:function(){return u.addPrivyRpcToChain}}),Object.defineProperty(exports,"addRpcUrlOverrideToChain",{enumerable:!0,get:function(){return u.addRpcUrlOverrideToChain}}),exports.getEmbeddedConnectedWallet=n.getEmbeddedConnectedWallet;
|