@privy-io/react-auth 3.11.1-beta-20260122161812 → 3.12.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-BBWWze9O.js +1 -0
- package/dist/cjs/{Address-BJFF-dMG.js → Address-6qDWL5TN.js} +4 -4
- package/dist/cjs/AffirmativeConsentScreen-CCwAwjH1.js +6 -0
- package/dist/cjs/AllowlistRejectionScreen-DEMYbzGA.js +1 -0
- package/dist/cjs/AuthenticateWithWalletScreen-dBvBC7MB.js +1 -0
- package/dist/cjs/AwaitingEvmToSolBridgingScreen-D9NwI47L.js +2 -0
- package/dist/cjs/AwaitingExternalEthereumTransferScreen-D_0NulpI.js +2 -0
- package/dist/cjs/AwaitingPasswordlessCodeScreen-B4HAKL4-.js +103 -0
- package/dist/cjs/AwaitingSolToEvmBridgingScreen-CnuLLTC0.js +2 -0
- package/dist/cjs/{BridgeNetworkSelectionView-BNv-V9G2.js → BridgeNetworkSelectionView-DKA06V8u.js} +11 -11
- package/dist/cjs/CaptchaScreen-N-ueJQF3.js +1 -0
- package/dist/cjs/CoinbaseOnrampStatusScreen-06yaO6r4.js +16 -0
- package/dist/cjs/ConnectEmailForm-DZrCSv9t.js +3 -0
- package/dist/cjs/ConnectLedgerScreen-C7vGQocf.js +9 -0
- package/dist/cjs/ConnectOnlyLandingScreen-_9y9kOsT.js +1 -0
- package/dist/cjs/ConnectOnlyStatusScreen-mZHx4a7S.js +1 -0
- package/dist/cjs/ConnectOrCreateScreen-Cp4uExOd.js +1 -0
- package/dist/cjs/{ConnectPhoneForm-C8JEoPHB.js → ConnectPhoneForm-BWSmRonl.js} +1 -1
- package/dist/cjs/{ConnectWalletView-bug4GgVZ.js → ConnectWalletView-Bh1DK9t5.js} +6 -6
- package/dist/cjs/ConnectionStatusScreen-B27DUsGt.js +7 -0
- package/dist/cjs/CrossAppAuthScreen-BbLFbCdU.js +1 -0
- package/dist/cjs/CustomLandingScreenView-DP1fJrBU.js +23 -0
- package/dist/cjs/DelegatedActionsConsentScreen-DzWruJOn.js +1 -0
- package/dist/cjs/DelegatedActionsRevokeScreen-D-TwUXyj.js +1 -0
- package/dist/cjs/EmbeddedWalletConnectingScreen-CYav4Mjb.js +1 -0
- package/dist/cjs/EmbeddedWalletCreatedScreen-m0t_c_AA.js +1 -0
- package/dist/cjs/EmbeddedWalletKeyExportScreen-_4GMdJuo.js +40 -0
- package/dist/cjs/EmbeddedWalletOnAccountCreateScreen-B5-JBZRJ.js +1 -0
- package/dist/cjs/EmbeddedWalletPasswordUpdateScreen-CITAy3i6.js +1 -0
- package/dist/cjs/EmbeddedWalletPasswordUpdateSplashScreen-DG5LKyjo.js +1 -0
- package/dist/cjs/{EnrollTotp-BpzRLjKc.js → EnrollTotp-leOB_B4o.js} +8 -8
- package/dist/cjs/ErrorScreen-xNDIVXx8.js +4 -0
- package/dist/cjs/{FarcasterConnectStatusScreen-DuOFuio7.js → FarcasterConnectStatusScreen-Bzmd4izn.js} +9 -9
- package/dist/cjs/FarcasterSignerStatusScreen-Cxoi54pp.js +29 -0
- package/dist/cjs/FundSolWalletWithExternalSolanaWallet-BCyBv_xe.js +2 -0
- package/dist/cjs/{FundWalletMethodHeader-Dn7FrcOp.js → FundWalletMethodHeader-YwNCXAU_.js} +1 -1
- package/dist/cjs/FundingEditAmountScreen-CDlb4Acx.js +1 -0
- package/dist/cjs/FundingMethodSelectionScreen-DlPxjsJq.js +1 -0
- package/dist/cjs/InAppBrowserLoginNotPossible-Bdx0vKyA.js +1 -0
- package/dist/cjs/InstallWalletScreen-Cshn01eK.js +1 -0
- package/dist/cjs/LandingScreen-0FdwpJ9w.js +1 -0
- package/dist/cjs/{LinkConflictScreen-8h7pmzsL.js → LinkConflictScreen-BCzS7Szr.js} +7 -7
- package/dist/cjs/LinkEmailScreen-B7rxdQso.js +1 -0
- package/dist/cjs/{LinkPasskeyScreen-cUu7WCqn.js → LinkPasskeyScreen-o4qdrAL3.js} +10 -10
- package/dist/cjs/LinkPhoneScreen-DweFqlM1.js +1 -0
- package/dist/cjs/LoginFailedScreen-mHcvCBEz.js +1 -0
- package/dist/cjs/ManualTransferScreen-CfYgtyLD.js +1 -0
- package/dist/cjs/MfaAuthEnrollmentFlowScreen-D631h0XW.js +1 -0
- package/dist/cjs/MfaAuthVerifyFlowScreen-BZ3IyqAd.js +1 -0
- package/dist/cjs/MfaEnrollmentFlowScreen-_tNeX5lT.js +1 -0
- package/dist/cjs/MfaVerifyFlowScreen-D_7nkuBq.js +1 -0
- package/dist/cjs/{ModalHeader-7knkCFjH.js → ModalHeader-C5O9gNUP.js} +1 -1
- package/dist/cjs/{MoonpayStatusScreen-BWA_sZnz.js → MoonpayStatusScreen-DoFbZ_0d.js} +3 -3
- package/dist/cjs/OAuthStatusScreen-BZY7BiP5.js +1 -0
- package/dist/cjs/PasskeySelectSignupOrLogin-C3k_ixTz.js +1 -0
- package/dist/cjs/PasskeyStatusScreen-BX-SOBDr.js +3 -0
- package/dist/cjs/PasswordRecoveryScreen-VZQDtt5v.js +20 -0
- package/dist/cjs/{QrCode-DPcePk5I.js → QrCode-CLd3Ytk7.js} +3 -3
- package/dist/cjs/RecoveryOAuthStatusScreen-DKYx6ECd.js +1 -0
- package/dist/cjs/RecoveryPasswordCreateScreen-DP0xOBMA.js +1 -0
- package/dist/cjs/RecoverySelectionScreen-Bw9_M6y0.js +7 -0
- package/dist/cjs/{Screen-uapp8UP4.js → Screen-BSwlHqPg.js} +4 -4
- package/dist/cjs/{ScreenLayout-BENEZm1m.js → ScreenLayout-BtVIYAso.js} +1 -1
- package/dist/cjs/SetAutomaticRecoveryScreen-SUOUjBk4.js +14 -0
- package/dist/cjs/{SetWalletPasswordForm-NMSn8MW-.js → SetWalletPasswordForm-Gkq-DskE.js} +3 -3
- package/dist/cjs/SignRequestScreen-BNcy6yU_.js +26 -0
- package/dist/cjs/{StandardSignAndSendTransactionScreen-C0Af9uPz.js → StandardSignAndSendTransactionScreen-z_EUNaeD.js} +3 -3
- package/dist/cjs/TelegramAuthScreen-DV8KYJMX.js +1 -0
- package/dist/cjs/{TransactionDetails-BCQvuSov.js → TransactionDetails-DYow9ihU.js} +4 -4
- package/dist/cjs/{TransactionErrorView-DhdW4Ka8.js → TransactionErrorView-yUMJqqF2.js} +4 -4
- package/dist/cjs/TransferFromWalletScreen-Duk7CEcq.js +31 -0
- package/dist/cjs/TransferOrBridgeLoadingScreen-DuBLyfE1.js +6 -0
- package/dist/cjs/UpdateEmailScreen-DRJv5CZs.js +1 -0
- package/dist/cjs/UpdatePhoneScreen-C3myqOv0.js +1 -0
- package/dist/cjs/UserLimitReachedScreen-l_e6Vhr0.js +1 -0
- package/dist/cjs/{WalletInfoCard-DLnujds6.js → WalletInfoCard-CHEynRZS.js} +4 -4
- package/dist/cjs/{WalletInterstitialScreen-CMMSgAk9.js → WalletInterstitialScreen-BgoDwKIp.js} +1 -1
- package/dist/cjs/WalletLink-CZLtiI7E.js +22 -0
- package/dist/cjs/WalletOverflowButton-FlgoA77a.js +1 -0
- package/dist/cjs/abstract-smart-wallets.js +1 -1
- package/dist/cjs/{context-P14IM76D.js → context-BeSQM-Ma.js} +1 -1
- package/dist/cjs/ethers-XrYC9HG-.js +1 -0
- package/dist/cjs/extended-chains.js +1 -1
- package/dist/cjs/farcaster.js +1 -1
- package/dist/cjs/frame-Oz7volks.js +1 -0
- package/dist/cjs/{get-is-unified-wallet-DL_nMXp5.js → get-is-unified-wallet-BwdzQwn_.js} +1 -1
- package/dist/cjs/getErc20Balance-CN3JMVjF.js +1 -0
- package/dist/cjs/getErc20TokenInfo-DxDd_HN6.js +1 -0
- package/dist/cjs/getPublicClient-BsmZyCGX.js +1 -0
- package/dist/cjs/index-0-2WrPDo.js +12 -0
- package/dist/cjs/index-CzmnSRoa.js +174 -0
- package/dist/cjs/{index-BypMyGGH.js → index-W2ZSukRW.js} +1 -1
- package/dist/cjs/index.js +1 -1
- package/dist/cjs/{internal-context-NWsAL807.js → internal-context-BJv4f_bO.js} +1 -1
- package/dist/cjs/internal.js +1 -1
- package/dist/cjs/prepareFundingModalData-DDf6xLze.js +1 -0
- package/dist/cjs/{reservoir-CQGyEBb7.js → reservoir-Bx0HQwbb.js} +1 -1
- package/dist/cjs/{shared-CoZLntA9.js → shared-BcueHfN-.js} +6 -6
- package/dist/cjs/shouldProceedtoEmbeddedWalletCreationFlow-j6p9PEm-.js +1 -0
- package/dist/cjs/smart-wallets-BBh3vgRq.js +1 -0
- package/dist/cjs/smart-wallets.js +1 -1
- package/dist/cjs/solana.js +1 -1
- package/dist/cjs/{styles-DtykMHfN.js → styles-Csarwypj.js} +1 -1
- package/dist/cjs/to-ui-error-C4aac_aM.js +4 -0
- package/dist/cjs/ui.js +37 -37
- package/dist/cjs/use-export-wallet-C9HWu0Dq.js +1 -0
- package/dist/cjs/{use-sign-with-user-signer-BcAsQTGF.js → use-sign-with-user-signer-Cu_6Bx7m.js} +1 -1
- package/dist/cjs/useActiveWallet-vlXeDPzp.js +185 -0
- package/dist/cjs/{useGetSolPrice-C986iVoO.js → useGetSolPrice-Ca32VAbF.js} +1 -1
- package/dist/cjs/{useGetTokenPrice-cA2TnAzD.js → useGetTokenPrice-DJpJnTij.js} +1 -1
- package/dist/cjs/{useI18n-D4jKEXmt.js → useI18n-CnsBjm9v.js} +1 -1
- package/dist/cjs/usePrivy-Bx2PKTrU.js +1 -0
- package/dist/cjs/{useSolanaRpcClient-hHdPoMRE.js → useSolanaRpcClient-CYMWkK7E.js} +1 -1
- package/dist/cjs/useWalletBalance-DI8AY31i.js +1 -0
- package/dist/cjs/useWallets-BwB7ALB8.js +1 -0
- package/dist/cjs/useWallets-DMyuB5aJ.js +1 -0
- package/dist/dts/{events-context-vKnpI7Js.d.mts → events-context-DeukTtar.d.mts} +1 -1
- package/dist/dts/{events-context-vKnpI7Js.d.ts → events-context-DeukTtar.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 +40 -4
- package/dist/dts/index.d.ts +40 -4
- 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/{types-DAzgcrBH.d.mts → types-FifkyCQc.d.mts} +2 -1
- package/dist/dts/{types-DAzgcrBH.d.ts → types-FifkyCQc.d.ts} +2 -1
- package/dist/dts/ui.d.mts +1 -1
- package/dist/dts/ui.d.ts +1 -1
- package/dist/esm/AccountNotFoundScreen-C6S8_GyN.mjs +1 -0
- package/dist/esm/Address-QmAVCQtO.mjs +17 -0
- package/dist/esm/AffirmativeConsentScreen-QfJBfI_f.mjs +6 -0
- package/dist/esm/AllowlistRejectionScreen-CX57yv4U.mjs +1 -0
- package/dist/esm/AuthenticateWithWalletScreen-CZJ-aWhZ.mjs +1 -0
- package/dist/esm/AwaitingEvmToSolBridgingScreen-C1CMtT4Y.mjs +2 -0
- package/dist/esm/AwaitingExternalEthereumTransferScreen-DX91STcF.mjs +2 -0
- package/dist/esm/AwaitingPasswordlessCodeScreen-BuExr50N.mjs +103 -0
- package/dist/esm/AwaitingSolToEvmBridgingScreen-Bm1i_2qW.mjs +2 -0
- package/dist/esm/BridgeNetworkSelectionView-DQGcampg.mjs +69 -0
- package/dist/esm/CaptchaScreen-B-hFDb5f.mjs +1 -0
- package/dist/esm/CoinbaseOnrampStatusScreen-OHm2RUBv.mjs +16 -0
- package/dist/esm/ConnectEmailForm-Df5OtmDR.mjs +3 -0
- package/dist/esm/ConnectLedgerScreen-BHLYW-F3.mjs +9 -0
- package/dist/esm/ConnectOnlyLandingScreen-C6nzEwpN.mjs +1 -0
- package/dist/esm/ConnectOnlyStatusScreen-CremlXDY.mjs +1 -0
- package/dist/esm/ConnectOrCreateScreen-262UvCdD.mjs +1 -0
- package/dist/esm/{ConnectPhoneForm-C1eL0VZH.mjs → ConnectPhoneForm-BMtTIItD.mjs} +1 -1
- package/dist/esm/{ConnectWalletView-BtuPwm-c.mjs → ConnectWalletView-BMjEKo1_.mjs} +6 -6
- package/dist/esm/ConnectionStatusScreen-mk5beBL7.mjs +7 -0
- package/dist/esm/CrossAppAuthScreen-BXjEJQv6.mjs +1 -0
- package/dist/esm/CustomLandingScreenView-BlDfJaDr.mjs +23 -0
- package/dist/esm/DelegatedActionsConsentScreen-ANmQe-9G.mjs +1 -0
- package/dist/esm/DelegatedActionsRevokeScreen-D9X7mWmI.mjs +1 -0
- package/dist/esm/EmbeddedWalletConnectingScreen-2g-RrIvW.mjs +1 -0
- package/dist/esm/EmbeddedWalletCreatedScreen-BXTAv4_-.mjs +1 -0
- package/dist/esm/EmbeddedWalletKeyExportScreen-DYVHVHOj.mjs +40 -0
- package/dist/esm/EmbeddedWalletOnAccountCreateScreen-CYyMoMFF.mjs +1 -0
- package/dist/esm/EmbeddedWalletPasswordUpdateScreen-oT5ZcPQV.mjs +1 -0
- package/dist/esm/EmbeddedWalletPasswordUpdateSplashScreen-BQcHDyuV.mjs +1 -0
- package/dist/esm/{EnrollTotp-Bk2mWeF6.mjs → EnrollTotp-DVLg14UT.mjs} +8 -8
- package/dist/esm/ErrorScreen-CLfeO5pd.mjs +4 -0
- package/dist/esm/{FarcasterConnectStatusScreen-CHItJej_.mjs → FarcasterConnectStatusScreen-CUO9DKCJ.mjs} +7 -7
- package/dist/esm/FarcasterSignerStatusScreen-B135UOnV.mjs +28 -0
- package/dist/esm/FundSolWalletWithExternalSolanaWallet-DO3ttgom.mjs +1 -0
- package/dist/esm/{FundWalletMethodHeader-B3nAPYAR.mjs → FundWalletMethodHeader-PIxwFzzh.mjs} +1 -1
- package/dist/esm/FundingEditAmountScreen-BRQb2ffL.mjs +1 -0
- package/dist/esm/FundingMethodSelectionScreen-DTt1Z5RI.mjs +1 -0
- package/dist/esm/InAppBrowserLoginNotPossible-DH96QD2c.mjs +1 -0
- package/dist/esm/InstallWalletScreen-PnK6VfrP.mjs +1 -0
- package/dist/esm/LandingScreen-D_EvjOHf.mjs +1 -0
- package/dist/esm/{LinkConflictScreen-DmFrdpwb.mjs → LinkConflictScreen-B94e_-2N.mjs} +7 -7
- package/dist/esm/LinkEmailScreen-CT8gAQr3.mjs +1 -0
- package/dist/esm/LinkPasskeyScreen-DYfWSjKR.mjs +105 -0
- package/dist/esm/LinkPhoneScreen-ccrKA6tf.mjs +1 -0
- package/dist/esm/LoginFailedScreen-BwgxhbMf.mjs +1 -0
- package/dist/esm/ManualTransferScreen-DgCG2P3B.mjs +1 -0
- package/dist/esm/MfaAuthEnrollmentFlowScreen-CNVUTOnE.mjs +1 -0
- package/dist/esm/MfaAuthVerifyFlowScreen-2nvvFipu.mjs +1 -0
- package/dist/esm/MfaEnrollmentFlowScreen-DfnIqNNU.mjs +1 -0
- package/dist/esm/MfaVerifyFlowScreen-BwerwBz5.mjs +1 -0
- package/dist/esm/{ModalHeader-cnW8OaHH.mjs → ModalHeader-rCMpqA2a.mjs} +4 -4
- package/dist/esm/MoonpayStatusScreen-D5fRCEb3.mjs +16 -0
- package/dist/esm/OAuthStatusScreen-DtLgYw89.mjs +1 -0
- package/dist/esm/PasskeySelectSignupOrLogin-QoPhmagh.mjs +1 -0
- package/dist/esm/PasskeyStatusScreen-DzjU3ZVT.mjs +3 -0
- package/dist/esm/PasswordRecoveryScreen-LZYGRBkP.mjs +20 -0
- package/dist/esm/{QrCode-BVe4kf2z.mjs → QrCode-DjnQgnaZ.mjs} +3 -3
- package/dist/esm/RecoveryOAuthStatusScreen-DKfp8Udh.mjs +1 -0
- package/dist/esm/RecoveryPasswordCreateScreen-D4DI5Bom.mjs +1 -0
- package/dist/esm/RecoverySelectionScreen-B2V3518x.mjs +7 -0
- package/dist/esm/{Screen-DgjLPjok.mjs → Screen-CV2tt2Ap.mjs} +11 -11
- package/dist/esm/{ScreenLayout-x3-Xgy2E.mjs → ScreenLayout-DF3DCKOK.mjs} +1 -1
- package/dist/esm/SetAutomaticRecoveryScreen-C6cFVbSx.mjs +14 -0
- package/dist/esm/{SetWalletPasswordForm-Deqef3mc.mjs → SetWalletPasswordForm-ChA4tW4Y.mjs} +4 -4
- package/dist/esm/SignRequestScreen-BslfKJ1N.mjs +26 -0
- package/dist/esm/{StandardSignAndSendTransactionScreen-BGAjDFes.mjs → StandardSignAndSendTransactionScreen-D4OBsj5k.mjs} +3 -3
- package/dist/esm/TelegramAuthScreen-BJq5f_Rq.mjs +1 -0
- package/dist/esm/{TransactionDetails-8R96szrm.mjs → TransactionDetails-BP142O9n.mjs} +4 -4
- package/dist/esm/TransactionErrorView-BwwGMqSj.mjs +166 -0
- package/dist/esm/TransferFromWalletScreen-BHH0YcI4.mjs +31 -0
- package/dist/esm/TransferOrBridgeLoadingScreen-VLQTcf_6.mjs +6 -0
- package/dist/esm/UpdateEmailScreen-CMFBvYz5.mjs +1 -0
- package/dist/esm/UpdatePhoneScreen-DmhHcNq3.mjs +1 -0
- package/dist/esm/UserLimitReachedScreen-DNqgCf3B.mjs +1 -0
- package/dist/esm/{WalletInfoCard-CR6-S95l.mjs → WalletInfoCard-ChBHG5L5.mjs} +3 -3
- package/dist/esm/WalletInterstitialScreen-RS89fm6t.mjs +1 -0
- package/dist/esm/WalletLink-CN4enmsE.mjs +22 -0
- package/dist/esm/WalletOverflowButton-B-nEN4GW.mjs +1 -0
- package/dist/esm/abstract-smart-wallets.mjs +1 -1
- package/dist/esm/context-LVpDfP2H.mjs +1 -0
- package/dist/esm/ethers-BQ45eiVv.mjs +1 -0
- package/dist/esm/extended-chains.mjs +1 -1
- package/dist/esm/farcaster.mjs +1 -1
- package/dist/esm/{frame-cjQkGswH.mjs → frame-uzTmvtww.mjs} +1 -1
- package/dist/esm/get-is-unified-wallet-CNcx75Dp.mjs +1 -0
- package/dist/esm/getErc20Balance-DA4dGV9O.mjs +1 -0
- package/dist/esm/getErc20TokenInfo-CxatSwzi.mjs +1 -0
- package/dist/esm/getPublicClient-B4uPLKn-.mjs +1 -0
- package/dist/esm/{index-0TRQs0PD.mjs → index-2knYP69D.mjs} +3 -3
- package/dist/esm/index-DNz_w3-G.mjs +174 -0
- package/dist/esm/{index-Cp1MRWbr.mjs → index-DoasOxbi.mjs} +1 -1
- package/dist/esm/index.mjs +1 -1
- package/dist/esm/{internal-context-D4S2Sfvt.mjs → internal-context-Z-fyxadS.mjs} +1 -1
- package/dist/esm/internal.mjs +1 -1
- package/dist/esm/{paths-BzM95ysC.mjs → paths-3HW55qZg.mjs} +1 -1
- package/dist/esm/prepareFundingModalData-DjTxAoJ1.mjs +1 -0
- package/dist/esm/reservoir-0wfhnc0j.mjs +1 -0
- package/dist/esm/{shared-C0CllI3K.mjs → shared-DwO5pr5t.mjs} +1 -1
- package/dist/esm/shouldProceedtoEmbeddedWalletCreationFlow-Cv_C9s3_.mjs +1 -0
- package/dist/esm/smart-wallets-9LKzbfWj.mjs +1 -0
- package/dist/esm/smart-wallets.mjs +1 -1
- package/dist/esm/solana.mjs +1 -1
- package/dist/esm/{styles-Fji1ReGu.mjs → styles-BNn7MnP1.mjs} +1 -1
- package/dist/esm/to-ui-error-CCqAdorW.mjs +4 -0
- package/dist/esm/ui.mjs +37 -37
- package/dist/esm/use-export-wallet-DllHf-2F.mjs +1 -0
- package/dist/esm/{use-sign-with-user-signer--95w9BaG.mjs → use-sign-with-user-signer-Do5Oi_rb.mjs} +1 -1
- package/dist/esm/useActiveWallet-RZ4w-uGq.mjs +185 -0
- package/dist/esm/{useGetSolPrice-usp7QcwI.mjs → useGetSolPrice-DwwjjGbd.mjs} +1 -1
- package/dist/esm/{useGetTokenPrice-DgKSvh6T.mjs → useGetTokenPrice-DERdsrmf.mjs} +1 -1
- package/dist/esm/{useI18n-DleS41MU.mjs → useI18n-Dk9y58cU.mjs} +1 -1
- package/dist/esm/usePrivy-Dj52a5sp.mjs +1 -0
- package/dist/esm/useSolanaRpcClient-B7UDPdLi.mjs +1 -0
- package/dist/esm/useWalletBalance-CRXiZUj2.mjs +1 -0
- package/dist/esm/useWallets-DlGuNtGR.mjs +1 -0
- package/dist/esm/useWallets-cSQYA-Jk.mjs +1 -0
- package/package.json +6 -6
- package/dist/cjs/AccountNotFoundScreen-Clo67iWH.js +0 -1
- package/dist/cjs/AffirmativeConsentScreen-2FGovWDj.js +0 -6
- package/dist/cjs/AllowlistRejectionScreen-BLcPF2_b.js +0 -1
- package/dist/cjs/AuthenticateWithWalletScreen-ByOwd0gq.js +0 -1
- package/dist/cjs/AwaitingEvmToSolBridgingScreen-D_dh3tgw.js +0 -2
- package/dist/cjs/AwaitingExternalEthereumTransferScreen-CB4SnTRS.js +0 -2
- package/dist/cjs/AwaitingPasswordlessCodeScreen-D43lCvaw.js +0 -103
- package/dist/cjs/AwaitingSolToEvmBridgingScreen-ppOL2XCp.js +0 -2
- package/dist/cjs/CaptchaScreen-oTaZlLej.js +0 -1
- package/dist/cjs/CoinbaseOnrampStatusScreen-CO97CoDr.js +0 -16
- package/dist/cjs/ConnectEmailForm-DAA-nxD6.js +0 -3
- package/dist/cjs/ConnectLedgerScreen-3SrqHJBl.js +0 -9
- package/dist/cjs/ConnectOnlyLandingScreen-DkR-VnS2.js +0 -1
- package/dist/cjs/ConnectOnlyStatusScreen-Cafk-5gS.js +0 -1
- package/dist/cjs/ConnectOrCreateScreen-DttF-fCs.js +0 -1
- package/dist/cjs/ConnectionStatusScreen-BfU_d8ZK.js +0 -7
- package/dist/cjs/CrossAppAuthScreen-Bs_x-Isw.js +0 -1
- package/dist/cjs/CustomLandingScreenView-B93ZDqp2.js +0 -23
- package/dist/cjs/DelegatedActionsConsentScreen-Cx5lj2BJ.js +0 -1
- package/dist/cjs/DelegatedActionsRevokeScreen-BEucV6g6.js +0 -1
- package/dist/cjs/EmbeddedWalletConnectingScreen-BjZ_7QsX.js +0 -1
- package/dist/cjs/EmbeddedWalletCreatedScreen-CbmJzZZL.js +0 -1
- package/dist/cjs/EmbeddedWalletKeyExportScreen-CdMuowdD.js +0 -40
- package/dist/cjs/EmbeddedWalletOnAccountCreateScreen-C_EBP_oR.js +0 -1
- package/dist/cjs/EmbeddedWalletPasswordUpdateScreen-DQhHO_tI.js +0 -1
- package/dist/cjs/EmbeddedWalletPasswordUpdateSplashScreen-C1dTDHuI.js +0 -1
- package/dist/cjs/ErrorScreen-CPDISQKp.js +0 -4
- package/dist/cjs/FarcasterSignerStatusScreen-BYnokloK.js +0 -29
- package/dist/cjs/FundSolWalletWithExternalSolanaWallet-D-pMJTgQ.js +0 -2
- package/dist/cjs/FundingEditAmountScreen-CGYBcgzY.js +0 -1
- package/dist/cjs/FundingMethodSelectionScreen-32rXIiuR.js +0 -1
- package/dist/cjs/InAppBrowserLoginNotPossible-Wz6tWwN4.js +0 -1
- package/dist/cjs/InstallWalletScreen-C6na1HMV.js +0 -1
- package/dist/cjs/LandingScreen-GYoGjPT7.js +0 -1
- package/dist/cjs/LinkEmailScreen-Bz6DBn1S.js +0 -1
- package/dist/cjs/LinkPhoneScreen-BFB7atSV.js +0 -1
- package/dist/cjs/LoginFailedScreen-C3X4o4W8.js +0 -1
- package/dist/cjs/ManualTransferScreen-Bx5GRcIk.js +0 -1
- package/dist/cjs/MfaAuthEnrollmentFlowScreen-D8DE5e8S.js +0 -1
- package/dist/cjs/MfaAuthVerifyFlowScreen-BeJSdbHB.js +0 -1
- package/dist/cjs/MfaEnrollmentFlowScreen-0X-6htEq.js +0 -1
- package/dist/cjs/MfaVerifyFlowScreen-BgdY97r7.js +0 -1
- package/dist/cjs/OAuthStatusScreen-DZbrwgcX.js +0 -1
- package/dist/cjs/PasskeySelectSignupOrLogin-DWW-VE2d.js +0 -1
- package/dist/cjs/PasskeyStatusScreen-DiieGaFn.js +0 -3
- package/dist/cjs/PasswordRecoveryScreen-OhRzyQhB.js +0 -20
- package/dist/cjs/RecoveryOAuthStatusScreen-DPPwIU7C.js +0 -1
- package/dist/cjs/RecoveryPasswordCreateScreen-Bg-E6CB6.js +0 -1
- package/dist/cjs/RecoverySelectionScreen-CauE_byN.js +0 -7
- package/dist/cjs/SetAutomaticRecoveryScreen-59UByZZC.js +0 -14
- package/dist/cjs/SignRequestScreen-CYQvIjLY.js +0 -26
- package/dist/cjs/TelegramAuthScreen-DxghStcs.js +0 -1
- package/dist/cjs/TransferFromWalletScreen-DSMlo8kv.js +0 -31
- package/dist/cjs/TransferOrBridgeLoadingScreen-D9t_WQ5r.js +0 -6
- package/dist/cjs/UpdateEmailScreen-CrTIJ16u.js +0 -1
- package/dist/cjs/UpdatePhoneScreen-DQzmlkOL.js +0 -1
- package/dist/cjs/UserLimitReachedScreen-BQxNahAD.js +0 -1
- package/dist/cjs/WalletLink-Bg4We2eg.js +0 -22
- package/dist/cjs/WalletOverflowButton-aYewWDKS.js +0 -1
- package/dist/cjs/ethers-BlKEtatO.js +0 -1
- package/dist/cjs/frame-BmNfc9mp.js +0 -1
- package/dist/cjs/getErc20Balance-CP3UfGGz.js +0 -1
- package/dist/cjs/getErc20TokenInfo-CVfH_czS.js +0 -1
- package/dist/cjs/index-LczlN1Dt.js +0 -12
- package/dist/cjs/private-privy-provider-hH9v0z7o.js +0 -358
- package/dist/cjs/shouldProceedtoEmbeddedWalletCreationFlow-Cp0BucAr.js +0 -1
- package/dist/cjs/smart-wallets-DUl8PaqV.js +0 -1
- package/dist/cjs/state-DMsGOICm.js +0 -1
- package/dist/cjs/stripUrlOAuthParamsAndRemoveStateCode-2iUOCDfo.js +0 -1
- package/dist/cjs/to-ui-error-caFMQ6I1.js +0 -4
- package/dist/cjs/use-create-wallet-without-fallback-CrxEFfhb.js +0 -1
- package/dist/cjs/use-export-wallet-DeI8q3KQ.js +0 -1
- package/dist/cjs/useActiveWallet-BySNV0ev.js +0 -1
- package/dist/cjs/useLogout-zT9OSxoO.js +0 -1
- package/dist/cjs/useMfa-KC6CWm9H.js +0 -1
- package/dist/cjs/useMfaEnrollment-DA9sTwf_.js +0 -1
- package/dist/cjs/useWalletBalance-8waYUAmD.js +0 -1
- package/dist/cjs/useWallets-2ejSMVGq.js +0 -1
- package/dist/esm/AccountNotFoundScreen-Cn6aKFIC.mjs +0 -1
- package/dist/esm/Address-CDF4d_Ha.mjs +0 -17
- package/dist/esm/AffirmativeConsentScreen-DwMHTAWp.mjs +0 -6
- package/dist/esm/AllowlistRejectionScreen-CtVeBy5G.mjs +0 -1
- package/dist/esm/AuthenticateWithWalletScreen-CqqsqfqZ.mjs +0 -1
- package/dist/esm/AwaitingEvmToSolBridgingScreen-CLkDS6o-.mjs +0 -2
- package/dist/esm/AwaitingExternalEthereumTransferScreen-Is2FdGJS.mjs +0 -2
- package/dist/esm/AwaitingPasswordlessCodeScreen-CAwXjOBS.mjs +0 -103
- package/dist/esm/AwaitingSolToEvmBridgingScreen-BDhpWAv1.mjs +0 -2
- package/dist/esm/BridgeNetworkSelectionView-C5xaiL3n.mjs +0 -69
- package/dist/esm/CaptchaScreen-CZCosLCJ.mjs +0 -1
- package/dist/esm/CoinbaseOnrampStatusScreen-DxbYHDRy.mjs +0 -16
- package/dist/esm/ConnectEmailForm-c2xnQzqc.mjs +0 -3
- package/dist/esm/ConnectLedgerScreen-CmspFZG8.mjs +0 -9
- package/dist/esm/ConnectOnlyLandingScreen-JXhxU6Je.mjs +0 -1
- package/dist/esm/ConnectOnlyStatusScreen-CZO6dxUB.mjs +0 -1
- package/dist/esm/ConnectOrCreateScreen-DHwSpwLa.mjs +0 -1
- package/dist/esm/ConnectionStatusScreen-d8tOwFAz.mjs +0 -7
- package/dist/esm/CrossAppAuthScreen-CNvQYKBN.mjs +0 -1
- package/dist/esm/CustomLandingScreenView-82pnUZOi.mjs +0 -23
- package/dist/esm/DelegatedActionsConsentScreen-D2cB2Jqt.mjs +0 -1
- package/dist/esm/DelegatedActionsRevokeScreen-DIdnDrIo.mjs +0 -1
- package/dist/esm/EmbeddedWalletConnectingScreen-DNDkMjZg.mjs +0 -1
- package/dist/esm/EmbeddedWalletCreatedScreen-6rmCkBPR.mjs +0 -1
- package/dist/esm/EmbeddedWalletKeyExportScreen-CrrImf0B.mjs +0 -40
- package/dist/esm/EmbeddedWalletOnAccountCreateScreen-MTCypdEY.mjs +0 -1
- package/dist/esm/EmbeddedWalletPasswordUpdateScreen-o-ONaPrc.mjs +0 -1
- package/dist/esm/EmbeddedWalletPasswordUpdateSplashScreen-BpRZwJZg.mjs +0 -1
- package/dist/esm/ErrorScreen-C891Rurl.mjs +0 -4
- package/dist/esm/FarcasterSignerStatusScreen-P3NEju7D.mjs +0 -28
- package/dist/esm/FundSolWalletWithExternalSolanaWallet-CGZdr_3E.mjs +0 -1
- package/dist/esm/FundingEditAmountScreen-B0MYigL_.mjs +0 -1
- package/dist/esm/FundingMethodSelectionScreen-CNJYvozR.mjs +0 -1
- package/dist/esm/InAppBrowserLoginNotPossible-CVyW-cIh.mjs +0 -1
- package/dist/esm/InstallWalletScreen-Bfo00Txs.mjs +0 -1
- package/dist/esm/LandingScreen-tAGl1tss.mjs +0 -1
- package/dist/esm/LinkEmailScreen-C_G_4bbm.mjs +0 -1
- package/dist/esm/LinkPasskeyScreen-DhD51WvM.mjs +0 -105
- package/dist/esm/LinkPhoneScreen-Bi5gcAMm.mjs +0 -1
- package/dist/esm/LoginFailedScreen-DbAdNYji.mjs +0 -1
- package/dist/esm/ManualTransferScreen-CR2QvdVh.mjs +0 -1
- package/dist/esm/MfaAuthEnrollmentFlowScreen-BEotfobF.mjs +0 -1
- package/dist/esm/MfaAuthVerifyFlowScreen-Cygjr5sH.mjs +0 -1
- package/dist/esm/MfaEnrollmentFlowScreen-jupYBcsQ.mjs +0 -1
- package/dist/esm/MfaVerifyFlowScreen-B8ONcY5T.mjs +0 -1
- package/dist/esm/MoonpayStatusScreen-BjmXS-jc.mjs +0 -16
- package/dist/esm/OAuthStatusScreen-YcgvWTtC.mjs +0 -1
- package/dist/esm/PasskeySelectSignupOrLogin-Db4EFSYE.mjs +0 -1
- package/dist/esm/PasskeyStatusScreen-CR-3RNXX.mjs +0 -3
- package/dist/esm/PasswordRecoveryScreen-BnD1OdcX.mjs +0 -20
- package/dist/esm/RecoveryOAuthStatusScreen-DhLx5fOQ.mjs +0 -1
- package/dist/esm/RecoveryPasswordCreateScreen-BHOh-fE-.mjs +0 -1
- package/dist/esm/RecoverySelectionScreen-1seYQLsM.mjs +0 -7
- package/dist/esm/SetAutomaticRecoveryScreen-CZLgLNlt.mjs +0 -14
- package/dist/esm/SignRequestScreen-EwmYkZZk.mjs +0 -26
- package/dist/esm/TelegramAuthScreen-BMWr2M6a.mjs +0 -1
- package/dist/esm/TransactionErrorView-CcY_O062.mjs +0 -166
- package/dist/esm/TransferFromWalletScreen-BTsyTZMc.mjs +0 -31
- package/dist/esm/TransferOrBridgeLoadingScreen-DZ1diPi7.mjs +0 -6
- package/dist/esm/UpdateEmailScreen-DyXsKvGA.mjs +0 -1
- package/dist/esm/UpdatePhoneScreen-erzZ8qOI.mjs +0 -1
- package/dist/esm/UserLimitReachedScreen-CfiHSh4t.mjs +0 -1
- package/dist/esm/WalletInterstitialScreen-DCg6fl5S.mjs +0 -1
- package/dist/esm/WalletLink-CTp4jR2d.mjs +0 -22
- package/dist/esm/WalletOverflowButton-i2nGLvV0.mjs +0 -1
- package/dist/esm/context-i_OKSUqt.mjs +0 -1
- package/dist/esm/ethers-Cr0T35kS.mjs +0 -1
- package/dist/esm/get-is-unified-wallet-Bon2jknh.mjs +0 -1
- package/dist/esm/getErc20Balance-BDNkB-EL.mjs +0 -1
- package/dist/esm/getErc20TokenInfo-79BQbhYn.mjs +0 -1
- package/dist/esm/private-privy-provider-B2_rZ8aq.mjs +0 -358
- package/dist/esm/reservoir-DNdkSA7R.mjs +0 -1
- package/dist/esm/shouldProceedtoEmbeddedWalletCreationFlow-CDHNJbN9.mjs +0 -1
- package/dist/esm/smart-wallets-BNt96zAq.mjs +0 -1
- package/dist/esm/state-BG13el3v.mjs +0 -1
- package/dist/esm/stripUrlOAuthParamsAndRemoveStateCode-9jsyCRfN.mjs +0 -1
- package/dist/esm/to-ui-error-C46oK5ox.mjs +0 -4
- package/dist/esm/use-create-wallet-without-fallback-CY32SGw2.mjs +0 -1
- package/dist/esm/use-export-wallet-CWry8VMl.mjs +0 -1
- package/dist/esm/useActiveWallet-D-T43q8N.mjs +0 -1
- package/dist/esm/useLogout-CHtNPDaK.mjs +0 -1
- package/dist/esm/useMfa-D20h0FBp.mjs +0 -1
- package/dist/esm/useMfaEnrollment-BOyHpB2c.mjs +0 -1
- package/dist/esm/useSolanaRpcClient-O9yIYVIZ.mjs +0 -1
- package/dist/esm/useWalletBalance-CMO_I7jz.mjs +0 -1
- package/dist/esm/useWallets-B3ZcS4km.mjs +0 -1
|
@@ -1,358 +0,0 @@
|
|
|
1
|
-
import{jsxs as e,jsx as t,Fragment as n}from"react/jsx-runtime";import{createStore as r}from"mipd";import a,{useEffect as i,useContext as s,createContext as o,useRef as l,useCallback as c,useState as d,useMemo as u,Suspense as h,lazy as p}from"react";import*as w from"react-device-detect";import{isMobile as m,isSafari as y,isIOS as g,isAndroid as f}from"react-device-detect";import{getAddress as v,toHex as A,isAddress as b,isHex as C}from"viem/utils";import{ProviderErrors as k,DEFAULT_SUPPORTED_CHAIN_IDS as T,ConnectedStandardSolanaWallet as _,rpc as E,arbitrumSepolia as S,arbitrum as I,avalancheFuji as P,avalanche as W,baseSepolia as x,base as U,polygonAmoy as O,polygon as N,optimismSepolia as M,optimism as R,sepolia as D,mainnet as F,create as L}from"@privy-io/js-sdk-core";import{trigger as j}from"@privy-io/popup";import{b as z,c as q,d as B,P as H,f as $,e as V,a as K,g as G,h as Y,n as J,i as Z,u as Q,j as X,I as ee}from"./internal-context-D4S2Sfvt.mjs";import{s as te,a as ne,b as re,c as ae,d as ie,u as se,p as oe,e as le,f as ce,g as de,o as ue,h as he,i as pe,j as we,k as me,l as ye,m as ge,n as fe,q as ve,r as Ae,t as be,v as Ce,w as ke,x as Te,y as _e,z as Ee,A as Se,B as Ie,C as Pe,D as We,E as xe,F as Ue,G as Oe,H as Ne,I as Me,J as Re,K as De,L as Fe,M as Le,N as je,O as ze,P as qe,Q as Be,R as He,S as $e,T as Ve,U as Ke,V as Ge,W as Ye,X as Je,Y as Ze,Z as Qe,_ as Xe,$ as et,a0 as tt,a1 as nt,a2 as rt,a3 as at,a4 as it}from"./paths-BzM95ysC.mjs";import{base64 as st}from"@scure/base";import{createPublicClient as ot,http as lt,isAddress as ct,toHex as dt}from"viem";import{v4 as ut}from"uuid";import*as ht from"jose";import{base64url as pt}from"jose";import{h as wt,u as mt,a as yt,d as gt,j as ft,i as vt,g as At,e as bt,k as Ct,l as kt,P as Tt,c as _t,M as Et,m as St}from"./get-is-unified-wallet-Bon2jknh.mjs";import It from"eventemitter3";import{create as Pt}from"zustand";import{a as Wt,D as xt,b as Ut,c as Ot,d as Nt,V as Mt,e as Rt,f as Dt,H as Ft,O as Lt,S as jt,C as zt,h as qt,R as Bt,g as Ht,i as $t,j as Vt,k as Kt,l as Gt,I as Yt,m as Jt,n as Zt,o as Qt,p as Xt,u as en,W as tn}from"./context-i_OKSUqt.mjs";import{createCoinbaseWalletSDK as nn}from"@coinbase/wallet-sdk";import{EthereumProvider as rn,OPTIONAL_METHODS as an,OPTIONAL_EVENTS as sn}from"@walletconnect/ethereum-provider";import{ofetch as on}from"ofetch";import ln from"js-cookie";import{styled as cn,css as dn,createGlobalStyle as un}from"styled-components";import{u as hn,a as pn,p as wn,e as mn,P as yn}from"./events-context-CI0iqAXA.mjs";import{Transition as gn,Dialog as fn,TransitionChild as vn,DialogPanel as An}from"@headlessui/react";import{toViemTransactionSerializable as bn,STRING_TO_NUMBER_TXN_TYPE as Cn}from"@privy-io/ethereum";import{constructURL as kn}from"@privy-io/urls";class Tn{static parse(e){try{return new Tn(e)}catch(e){return null}}static throwIfNotWellFormedJwt(e){return ht.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=ht.decodeJwt(e)}}class _n extends Tn{static parse(e){try{return new _n(e)}catch(e){return null}}get appId(){return this._decoded.aid?this._decoded.aid:this.audience}}const En=Pt((()=>({listings:[],loading:!1}))),Sn=En.setState,In=e=>{let t;try{t=new URL(e).hostname}catch(e){return}return En.getState().listings.find((({homepage:e})=>{let n;try{n=new URL(e).hostname}catch(e){return!1}return t.includes(n)}))},Pn=(e=!0)=>{let t=Wt(),n=En((e=>e.listings)),r=En((e=>e.loading)),a=!!n.length;return i((()=>{e&&!a&&(Sn({listings:[],loading:!0}),(async e=>{let t=new URL("v3/wallets","https://explorer-api.walletconnect.com");t.searchParams.append("projectId",e);let n=await fetch(t);return n.ok?Object.values((await n.json()).listings).sort((({slug:e},{slug:t})=>"rainbow"===e&&"metamask"===t?1:"metamask"===e||"rainbow"===e?-1:1)):(console.debug(`Failed to fetch WalletConnect listings: ${await n.text().catch((()=>"No response."))}`),[])})(t.walletConnectCloudProjectId).then((e=>Sn({listings:e,loading:!1}))).catch((e=>{console.error(e),Sn({listings:[],loading:!1})})))}),[e,a,t.walletConnectCloudProjectId]),{listings:n,loading:r}},Wn=e=>{let{listings:t}=Pn();return t.find((({slug:t})=>xn(t)===xn(e)))};function xn(e){return"cryptocom"===e?"cryptocom-defi":"binance"===e?"binance-defi":e.replace(/[-_]wallet$/,"")}function Un(e){return["wallet_connect","backpack","binance","binanceus","bitget_wallet","bybit_wallet","cryptocom","haha_wallet","jupiter","metamask","okx_wallet","phantom","rabby_wallet","rainbow","ronin_wallet","safe","solflare","uniswap","zerion","kraken_wallet"].some((t=>e?.includes(t)))}const On=e=>e.isApexWallet?"Apex Wallet":e.isAvalanche?"Core Wallet":e.isBackpack?"Backpack":e.isBifrost?"Bifrost Wallet":e.isBitKeep?"BitKeep":e.isBitski?"Bitski":e.isBlockWallet?"BlockWallet":e.isBraveWallet?"Brave Wallet":e.isClover?"Clover":e.isCoin98?"Coin98 Wallet":e.isCoinbaseWallet?"Coinbase Wallet":e.isDawn?"Dawn Wallet":e.isDefiant?"Defiant":e.isDesig?"Desig Wallet":e.isEnkrypt?"Enkrypt":e.isExodus?"Exodus":e.isFordefi?"Fordefi":e.isFrame?"Frame":e.isFrontier?"Frontier Wallet":e.isGamestop?"GameStop Wallet":e.isHaqqWallet?"HAQQ Wallet":e.isHyperPay?"HyperPay Wallet":e.isImToken?"ImToken":e.isHaloWallet?"Halo Wallet":e.isKuCoinWallet?"KuCoin Wallet":e.isMathWallet?"MathWallet":e.isNovaWallet?"Nova Wallet":e.isOkxWallet||e.isOKExWallet?"OKX Wallet":e.isOneInchIOSWallet||e.isOneInchAndroidWallet?"1inch Wallet":e.isOneKey?"OneKey Wallet":e.isOpera?"Opera":e.isPhantom||"isPhantom"in e?"Phantom":e.isPortal?"Ripio Portal":e.isRabby?"Rabby Wallet":e.isRainbow?"Rainbow":e.isSafePal?"SafePal Wallet":e.isStatus?"Status":e.isSubWallet?"SubWallet":e.isTalisman?"Talisman":e.isTally||e.isTaho?"Taho":e.isTokenPocket?"TokenPocket":e.isTokenary?"Tokenary":e.isTrust||e.isTrustWallet?"Trust Wallet":e.isTTWallet?"TTWallet":e.isXDEFI?"XDEFI Wallet":e.isZeal?"Zeal":e.isZerion?"Zerion":e.isMetaMask?"MetaMask":void 0,Nn=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||"MetaMask"!==On(e))return!1;if(e.providers)for(let t of e.providers)if(!Nn(t))return!1;return!0},Mn=()=>{let e=window;if(!e.ethereum)return!1;if(e.ethereum.isCoinbaseWallet)return!0;if(e.ethereum.providers)for(let t of e.ethereum.providers)if(t&&t.isCoinbaseWallet)return!0;return!1},Rn=(e,t,n,r)=>{let a=Number(e),i=t.find((e=>e.id===a));if(!i)throw new z(`Unsupported chainId ${e}`,4901);return ot({transport:lt(Dn(i,n,r.appId)),chain:i})},Dn=(e,t,n)=>{let r,a=e.id,i=Number(e.id);if(e.rpcUrls.privyWalletOverride&&e.rpcUrls.privyWalletOverride.http[0])r=e.rpcUrls.privyWalletOverride.http[0];else if(t.rpcUrls&&t.rpcUrls[i])r=t.rpcUrls[i];else if(e.rpcUrls.privy?.http[0]){let t=new URL(e.rpcUrls.privy.http[0]);t.searchParams.append("privyAppId",n),r=t.toString()}else r=e.rpcUrls.public?.http[0]?e.rpcUrls.public.http[0]:e.rpcUrls.default?.http[0];if(!r)throw new z(`No RPC url found for ${a}`);return r},Fn=(e,t)=>{let n=[],r=[];for(let[a,i]of e.entries())a<t?n.push(i):r.push(i);return[n,r]},Ln=e=>!!String(e).toLowerCase().match(/^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/),jn=(e,t)=>{let n=e.slice(0),r=[];for(;n.length;)r.push(n.splice(0,t));return r},zn=(e,t=3,n=4,r="ethereum")=>{if(!e)return"";let a="ethereum"===r?2:0;return t+n+a+3>=e.length?e:`${e.slice(0,a+t)}...${e.slice(e.length-n,e.length)}`},qn=(e,t=3,n=4)=>zn(e,t,n,"solana"),Bn=e=>new Promise((t=>setTimeout(t,e)));function Hn(e,{interval:t=100,timeout:n=5e3}={}){return new Promise(((r,a)=>{let i,s=0,o=()=>{s>=n?a("Max attempts reached without result"):(i=e(),s+=t,null==i?setTimeout(o,t):r(i))};o()}))}const $n=(e,t={})=>{let n=t.delayMs||150,r=t.maxAttempts||270;return new Promise((async(a,i)=>{let s=!1,o=0;for(;!s&&o<r;){if(t.abortSignal?.aborted)return;e().then((e=>{s=!0,a(e)}),((...e)=>{s=!0,i(...e)})),o+=1,await Bn(n)}s||i(Error("Exceeded max attempts before resolving function"))}))},Vn=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),Kn=e=>"string"==typeof e?e:"0x"+e.toString(16);async function Gn({store:e,walletList:t,externalWalletConfig:n,walletChainType:r,timeout:a=3e3}){let i=!1,s=window;return new Promise((o=>{function l(){if(i)return;i=!0,window.removeEventListener("ethereum#initialized",l);let a=e.getProviders();console.debug("Detected injected providers:",a.map((e=>e.info)));let s=[];for(let e of a)t.includes("coinbase_wallet")&&"com.coinbase.wallet"===e.info.rdns||"solana-only"===r&&"app.phantom"===e.info.rdns||s.push({type:e.info.name.toLowerCase().replace(/\s/g,"_"),eip6963InjectedProvider:e});if("solana-only"!==r)for(let e of function(){let e=window,t=e.ethereum;if(!t)return[];let n=[];if(t.providers?.length)for(let e of t.providers)e&&n.push(e);return n.push(e.ethereum),n}()){let t=On(e);if(!a.some((e=>e.info.name===t))){if(Nn(e,!0)&&!s.find((e=>"metamask"===e.type))){s.push({type:"metamask",legacyInjectedProvider:e});continue}if("Phantom"===t&&!s.find((e=>"phantom"===e.type))){s.push({type:"phantom",legacyInjectedProvider:e});continue}if("Coinbase Wallet"===t&&!s.find((e=>"coinbase_wallet"===e.type&&"smartWalletOnly"!==n.coinbaseWallet?.config?.preference?.options))){s.push({type:"coinbase_wallet",legacyInjectedProvider:e});continue}s.find((e=>"unknown_browser_extension"===e.type))||s.push({type:"unknown_browser_extension",legacyInjectedProvider:e})}}o(s)}s.ethereum?l():(window.addEventListener("ethereum#initialized",l,{once:!0}),setTimeout((()=>{l()}),a))}))}function Yn(e){return`eip155:${String(Number(e))}`}const Jn=(e,t,n,r)=>{let a=Number(e),i=t.find((e=>e.id===a));if(!i)throw new z(`Unsupported chainId ${e}`,4901);return Dn(i,n,r)},Zn=(e,t)=>{let n=Number(e),r=t.find((e=>e.id===n));if(!r)throw new z(`Unsupported chainId ${e}`,4901);return r.blockExplorers?.default.url},Qn=e=>{let t={name:"string",version:"string",chainId:"uint256",verifyingContract:"address",salt:"bytes32"},n=e.types.EIP712Domain??Object.entries(e.domain).map((([e,n])=>{if(null!=n&&"string"==typeof e&&e in t)return{name:e,type:t[e]}})).filter((e=>void 0!==e));return{...e,types:{...e.types,EIP712Domain:n}}};function Xn(e,{min:t,max:n}){return Math.min(Math.max(e,t),n)}const er=e=>e?.map((e=>({signer_id:e.signerId,override_policy_ids:e.policyIds}))),tr=({style:n,...r})=>/*#__PURE__*/e("svg",{viewBox:"0 0 1024 1024",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...n},...r,children:[/*#__PURE__*/t("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M152 512C152 710.823 313.177 872 512 872C710.823 872 872 710.823 872 512C872 313.177 710.823 152 512 152C313.177 152 152 313.177 152 512ZM420 396C406.745 396 396 406.745 396 420V604C396 617.255 406.745 628 420 628H604C617.255 628 628 617.255 628 604V420C628 406.745 617.255 396 604 396H420Z",fill:"white"})]}),nr="data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PScwIDAgMTAyNCAxMDI0JyBmaWxsPSdub25lJyB4bWxucz0naHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnIHN0eWxlPSdoZWlnaHQ6MjhweDt3aWR0aDoyOHB4Jz48cmVjdCB3aWR0aD0nMTAyNCcgaGVpZ2h0PScxMDI0JyBmaWxsPScjMDA1MkZGJyByeD0nMTAwJyByeT0nMTAwJz48L3JlY3Q+PHBhdGggZmlsbC1ydWxlPSdldmVub2RkJyBjbGlwLXJ1bGU9J2V2ZW5vZGQnIGQ9J00xNTIgNTEyQzE1MiA3MTAuODIzIDMxMy4xNzcgODcyIDUxMiA4NzJDNzEwLjgyMyA4NzIgODcyIDcxMC44MjMgODcyIDUxMkM4NzIgMzEzLjE3NyA3MTAuODIzIDE1MiA1MTIgMTUyQzMxMy4xNzcgMTUyIDE1MiAzMTMuMTc3IDE1MiA1MTJaTTQyMCAzOTZDNDA2Ljc0NSAzOTYgMzk2IDQwNi43NDUgMzk2IDQyMFY2MDRDMzk2IDYxNy4yNTUgNDA2Ljc0NSA2MjggNDIwIDYyOEg2MDRDNjE3LjI1NSA2MjggNjI4IDYxNy4yNTUgNjI4IDYwNFY0MjBDNjI4IDQwNi43NDUgNjE3LjI1NSAzOTYgNjA0IDM5Nkg0MjBaJyBmaWxsPSd3aGl0ZSc+PC9wYXRoPjwvc3ZnPg==",rr="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwCAYAAABXAvmHAAAAAXNSR0IArs4c6QAAALZJREFUaEPtmjEOhDAMBNc/O14GvOzys3CAKK6eAlmaVGl2Zc+kTOU685vkc9/bnD2prZK5/TZY24z9P+g4F5hNh7/GdoG37WlAA5CATwgCxHENYISwQAMQII5rACOEBRqAAHFcAxghLNAABIjjGsAIYYEGIEAc1wBGCAs0AAHiuAYwQligAQgQxzWAEcICDUCAOK4BjBAWaAACxHENYISwQAMQII6fBjr+VHkW3+u+tfyxMpJaDgYzYxb/ALZVAAAAAElFTkSuQmCC";class ar extends z{constructor(){super("Wallet timeout"),this.type="wallet_error"}}const ir=e=>e instanceof z?e:e?.code?new or(e):new z("Unknown connector error",e);class sr extends q{constructor(e,t,n){super(e),this.type="provider_error",this.code=t,this.data=n}}class or extends sr{constructor(e){super(e.message,e.code,e.data);let t=Object.values(k).find((t=>t.eipCode===e.code));this.details=t||k.UNKNOWN_ERROR,-32002===e.code&&(e.message?.includes("already pending for origin")?e.message?.includes("wallet_requestPermissions")?this.details=k.E32002_CONNECTION_ALREADY_PENDING:this.details=k.E32002_REQUEST_ALREADY_PENDING:e.message?.includes("Already processing")&&e.message.includes("eth_requestAccounts")&&(this.details=k.E32002_WALLET_LOCKED))}}const lr={ERROR_USER_EXISTS:{message:"User already exists for this address",detail:"Try another address!",retryable:!1},ERROR_TIMED_OUT:{message:"Wallet request timed out",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_CONNECTION:{message:"Could not log in with wallet",detail:"Please try connecting again.",retryable:!0},ERROR_USER_LIMIT_REACHED:{message:"Unable to link",detail:"You've reached the maximum number of linked wallets.",retryable:!1},...k};class cr{get(e){let t=localStorage.getItem(e);return null===t?void 0:JSON.parse(t)}put(e,t){void 0!==t?localStorage.setItem(e,JSON.stringify(t)):this.del(e)}del(e){localStorage.removeItem(e)}getKeys(){return Object.entries(localStorage).map((([e])=>e))}}function dr(){try{let e="privy:__session_storage__test",t=new cr;return t.put(e,"blobby"),t.del(e),!0}catch(e){return!1}}var ur="undefined"!=typeof window&&window.localStorage?new cr:new class{get(e){return this._cache[e]}put(e,t){void 0!==t?this._cache[e]=t:this.del(e)}del(e){delete this._cache[e]}getKeys(){return Object.keys(this._cache)}constructor(){this._cache={}}};function hr(e){return"ethereum"===e.type}function pr(e,t){if(e.length!==t.length)return!1;for(let n=0;n<e.length;n++){let r=e[n],a=t[n];if(r?.address!==a?.address||r&&a&&hr(r)&&hr(a)&&r?.chainId!==a?.chainId||r?.connectorType!==a?.connectorType||r?.connectedAt!==a?.connectedAt||r?.walletClientType!==a?.walletClientType||r?.isConnected!==a?.isConnected||r?.linked!==a?.linked)return!1}return!0}class wr extends It{constructor(e){super(),this.walletClientType=e,this.connected=!1,this.initialized=!1}}const mr=(e,t)=>e.rpcTimeouts&&e.rpcTimeouts[t]||xt;let yr,gr;function fr(e){return"ethereum"===e.chainType}class vr extends wr{buildConnectedWallet(e,t,n,r){let a=async()=>!!this.wallets.find((t=>v(t.address)===v(e)));return{type:"ethereum",address:v(e),chainId:t,meta:n,imported:r,switchChain:async n=>{let r,i;if(!a)throw new z("Wallet is not currently connected.");let s=this.wallets.find((t=>v(t.address)===v(e)))?.chainId;if(!s)throw new z("Unable to determine current chainId.");if("number"==typeof n?(r=`0x${n.toString(16)}`,i=n):(r=n,i=Number(n)),s===Yn(r))return;let o=this.chains.find((e=>e.id===i));if(!o)throw new z(`Unsupported chainId: ${n}`);let l=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:r}]})};try{return await l()}catch(e){if(((e,t)=>{switch(t){case"coinbase_wallet":case"base_account":return e.message.includes("addEthereumChain");case"rabby_wallet":return e.message.includes("Unrecognized chain ID");default:return 4902===e.code||e.message?.includes("4902")}})(e,this.walletClientType))return"rabby_wallet"===this.walletClientType&&await Bn(300),await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:r,chainName:o.name,nativeCurrency:o.nativeCurrency,rpcUrls:[o.rpcUrls.default?.http[0]??""],blockExplorerUrls:[o.blockExplorers?.default.url??""]}]}),l();if("rainbow"===this.walletClientType&&e.message?.includes("wallet_switchEthereumChain"))throw new z(`Rainbow does not support the chainId ${t}`);throw e}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:a,getEthereumProvider:async()=>{if(!await a())throw new z("Wallet is not currently connected.");return this.proxyProvider},sign:async e=>{if(!await a())throw new z("Wallet is not currently connected.");return await this.sign(e)},disconnect:()=>{this.disconnect()}}}async syncAccounts(e){let t,n=e;try{if(void 0===n){let e=await $n((()=>this.proxyProvider.request({method:"eth_accounts"})),{maxAttempts:10,delayMs:500});console.debug(`eth_accounts for ${this.walletClientType}:`,e),Array.isArray(e)&&(n=e)}}catch(e){console.debug("Wallet did not respond to eth_accounts. Defaulting to prefetched accounts.",e)}if(!n||!Array.isArray(n)||n.length<=0||!n[0])return;let r=n[0];if(!ct(r))return void console.warn(`Invalid ethereum address reported by ${this.walletClientType}: ${r}`);let a=v(r),i=[];if("privy"===this.walletClientType){let e=ur.get(Ut(a));this.chains.find((t=>t.id===Number(e)))||(ur.del(Ut(a)),e=null),t=e||`0x${this.defaultChain.id.toString(16)}`;try{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:t}]})}catch(e){console.warn(`Unable to switch embedded wallet to chain ID ${t} on initialization`)}}else try{let e=await $n((()=>this.proxyProvider.request({method:"eth_chainId"})),{maxAttempts:10,delayMs:500});if(console.debug(`eth_chainId for ${this.walletClientType}:`,e),"string"==typeof e)t=e;else{if("number"!=typeof e)throw Error("Invalid chainId returned from provider");t=`0x${e.toString(16)}`}}catch(e){console.warn(`Failed to get chainId from provider, defaulting to ${Ot}`,e),t=Ot}let s=Yn(t);if(!i.find((e=>v(e.address)===a))){let e={name:this.walletBranding.name,icon:"string"==typeof this.walletBranding.icon?this.walletBranding.icon:void 0,id:this.walletBranding.id};i.push(this.buildConnectedWallet(v(r),s,e,"embedded_imported"===this.connectorType))}pr(i,this.wallets)||(this.wallets=i,this.emit("walletsUpdated"))}async getConnectedWallet(){let e=await this.proxyProvider.request({method:"eth_accounts"});return this.wallets.sort(((e,t)=>t.connectedAt-e.connectedAt)).find((t=>e.find((e=>v(e)===v(t.address)))))||null}async isConnected(){let e=await this.proxyProvider.request({method:"eth_accounts"});return Array.isArray(e)&&e.length>0}async sign(e){return await this.connect({showPrompt:!1}),this.proxyProvider.request({method:"personal_sign",params:[A(e),this.wallets[0]?.address]})}subscribeListeners(){this.proxyProvider.on("accountsChanged",this.onAccountsChanged),this.proxyProvider.on("chainChanged",this.onChainChanged),this.proxyProvider.on("disconnect",this.onDisconnect),this.proxyProvider.on("connect",this.onConnect)}unsubscribeListeners(){this.proxyProvider.removeListener("accountsChanged",this.onAccountsChanged),this.proxyProvider.removeListener("chainChanged",this.onChainChanged),this.proxyProvider.removeListener("disconnect",this.onDisconnect),this.proxyProvider.removeListener("connect",this.onConnect)}constructor(e,t,n,r){super(e),this.chainType="ethereum",this.onAccountsChanged=e=>{0===e.length?this.onDisconnect():this.syncAccounts(e)},this.onChainChanged=e=>{this.wallets.forEach((t=>{t.chainId=Yn(e),"privy"===this.walletClientType&&ur.put(Ut(t.address),e)})),this.emit("walletsUpdated")},this.onDisconnect=()=>{this.connected=!1,this.wallets=[],this.emit("walletsUpdated")},this.onConnect=async()=>{"base_account"===this.connectorType&&this.connected||(this.connected=!0,"coinbase_wallet"===this.connectorType&&await Bn(500),this.syncAccounts())},this.wallets=[],this.walletClientType=e,this.chains=t,this.defaultChain=n,this.rpcConfig=r,this.rpcTimeoutDuration=mr(r,e),this.connected=!1,this.initialized=!1}}class Ar{on(e,t){if(this.walletProvider)return this.walletProvider.on(e,t);this._subscriptions.push({eventName:e,listener:t})}async request(e){if(!this.walletProvider)throw new z(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),this.walletTimeout()]).catch((e=>{throw ir(e)}))}constructor(e,t){this.removeListener=(e,t)=>{if(this.walletProvider)try{return this.walletProvider.removeListener(e,t)}catch(e){console.warn("Unable to remove wallet provider listener")}},this.walletTimeout=(e=new ar,t=this.rpcTimeoutDuration)=>new Promise(((n,r)=>setTimeout((()=>{r(e)}),t))),this.setWalletProvider=e=>{this.walletProvider&&this._subscriptions.forEach((e=>{this.removeListener(e.eventName,e.listener)})),this.walletProvider=e,this._subscriptions.forEach((e=>{this.walletProvider?.on(e.eventName,e.listener)}))},this.walletProvider=e,this.rpcTimeoutDuration=t||xt,this._subscriptions=[]}}class br extends vr{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:rr,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 z("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([e[0]])}catch(e){throw ir(e)}}constructor(e,t,n,r,a){super("base_account",e,t,n),this.connectorType="base_account",this.walletClientType="base_account",this.displayName="Base",this.setBaseAccountSdk=a,this.proxyProvider=new Ar(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.baseAccountConfig={...r,appChainIds:[t.id].concat(e.map((e=>e.id)))},yr?(this.proxyProvider.setWalletProvider(yr.getProvider()),this.setBaseAccountSdk(yr)):this.importPromise=import("@base-org/account").then((({createBaseAccountSDK:e})=>{yr=e(this.baseAccountConfig),this.proxyProvider.setWalletProvider(yr.getProvider()),this.setBaseAccountSdk(yr)})).catch(console.error)}}let Cr=[1,11155111,137,10,8453,84532,42161,7777777,43114,56];class kr extends vr{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:nr,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 z("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([e[0]])}catch(e){throw ir(e)}}updateConnectionPreference(e){this.coinbaseWalletConfig={...this.coinbaseWalletConfig,preference:{...this.coinbaseWalletConfig.preference,options:e}},this.walletClientType="smartWalletOnly"===e?"coinbase_smart_wallet":"coinbase_wallet",gr=nn({...this.coinbaseWalletConfig}),this.proxyProvider.setWalletProvider(gr.getProvider())}constructor(e,t,n,r){if(super("coinbase_wallet",e,t,n),this.connectorType="coinbase_wallet",this.displayName="Coinbase Wallet",this.proxyProvider=new Ar(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.coinbaseWalletConfig={...r,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"),!gr){let e="eoaOnly"!==this.coinbaseWalletConfig.preference?.options?(this.coinbaseWalletConfig.appChainIds??[]).filter((e=>!Cr.includes(e))):[];e.length>0&&!e.every((e=>T.has(e)))&&console.info(`The configured chains are not supported by Coinbase Smart Wallet: ${e.join(", ")}`),gr=nn(this.coinbaseWalletConfig)}this.proxyProvider.setWalletProvider(gr.getProvider())}}class Tr extends vr{get walletBranding(){return{id:this.id,name:this.name,icon:this.icon}}async initialize(){this.initialized=!0,this.emit("initialized")}async connect(){throw Error("connect called for an uninstalled wallet via the EthereumNullConnector")}disconnect(){throw Error("disconnect called for an uninstalled wallet via the EthereumNullConnector")}promptConnection(e){throw Error(`promptConnection called for an uninstalled wallet via the EthereumNullConnector for ${e}`)}constructor({id:e,name:t,icon:n,walletClientType:r,defaultChain:a}){super(r,[],a,{}),this.connectorType="null",this.proxyProvider=new Ar(void 0,xt),this.id=e,this.name=t,this.icon=n}}const _r=({style:e,...n})=>/*#__PURE__*/t("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...n,children:/*#__PURE__*/t("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M9 17.25v1.007a3 3 0 01-.879 2.122L7.5 21h9l-.621-.621A3 3 0 0115 18.257V17.25m6-12V15a2.25 2.25 0 01-2.25 2.25H5.25A2.25 2.25 0 013 15V5.25m18 0A2.25 2.25 0 0018.75 3H5.25A2.25 2.25 0 003 5.25m18 0V12a2.25 2.25 0 01-2.25 2.25H5.25A2.25 2.25 0 013 12V5.25"})}),Er=({...n})=>/*#__PURE__*/e("svg",{xmlns:"http://www.w3.org/2000/svg",width:"32",height:"32",viewBox:"0 0 32 32",fill:"none",...n,children:[/*#__PURE__*/t("rect",{width:"32",height:"32",rx:"6",fill:"#121314"}),/*#__PURE__*/t("g",{transform:"translate(4, 4)",children:/*#__PURE__*/e("svg",{width:"24",height:"24",viewBox:"0 0 318.6 318.6",children:[/*#__PURE__*/t("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),/*#__PURE__*/t("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),/*#__PURE__*/t("path",{d:"m44.4 35.5 98.7 74.6-17.5-44.3zm193.9 171.3-26.5 40.6 56.7 15.6 16.3-55.3zm-204.4.9L50.1 263l56.7-15.6-26.5-40.6z",className:"s1 s2"}),/*#__PURE__*/t("path",{d:"m103.6 138.2-15.8 23.9 56.3 2.5-2-60.5zm111.3 0-39-34.8-1.3 61.2 56.2-2.5zM106.8 247.4l33.8-16.5-29.2-22.8zm71.1-16.5 33.9 16.5-4.7-39.3z",className:"s1 s2"}),/*#__PURE__*/t("path",{fill:"#d7c1b3",stroke:"#d7c1b3",className:"s1",d:"m211.8 247.4-33.9-16.5 2.7 22.1-.3 9.3zm-105 0 31.5 14.9-.2-9.3 2.5-22.1z"}),/*#__PURE__*/t("path",{fill:"#233447",stroke:"#233447",className:"s1",d:"m138.8 193.5-28.2-8.3 19.9-9.1zm40.9 0 8.3-17.4 20 9.1z"}),/*#__PURE__*/t("path",{fill:"#cd6116",stroke:"#cd6116",className:"s1",d:"m106.8 247.4 4.8-40.6-31.3.9zM207 206.8l4.8 40.6 26.5-39.7zm23.8-44.7-56.2 2.5 5.2 28.9 8.3-17.4 20 9.1zm-120.2 23.1 20-9.1 8.2 17.4 5.3-28.9-56.3-2.5z"}),/*#__PURE__*/t("path",{fill:"#e4751f",stroke:"#e4751f",className:"s1",d:"m87.8 162.1 23.6 46-.8-22.9zm120.3 23.1-1 22.9 23.7-46zm-64-20.6-5.3 28.9 6.6 34.1 1.5-44.9zm30.5 0-2.7 18 1.2 45 6.7-34.1z"}),/*#__PURE__*/t("path",{d:"m179.8 193.5-6.7 34.1 4.8 3.3 29.2-22.8 1-22.9zm-69.2-8.3.8 22.9 29.2 22.8 4.8-3.3-6.6-34.1z",className:"s3"}),/*#__PURE__*/t("path",{fill:"#c0ad9e",stroke:"#c0ad9e",className:"s1",d:"m180.3 262.3.3-9.3-2.5-2.2h-37.7l-2.3 2.2.2 9.3-31.5-14.9 11 9 22.3 15.5h38.3l22.4-15.5 11-9z"}),/*#__PURE__*/t("path",{fill:"#161616",stroke:"#161616",className:"s1",d:"m177.9 230.9-4.8-3.3h-27.7l-4.8 3.3-2.5 22.1 2.3-2.2h37.7l2.5 2.2z"}),/*#__PURE__*/t("path",{fill:"#763d16",stroke:"#763d16",className:"s1",d:"m278.3 114.2 8.5-40.8-12.7-37.9-96.2 71.4 37 31.3 52.3 15.3 11.6-13.5-5-3.6 8-7.3-6.2-4.8 8-6.1zM31.8 73.4l8.5 40.8-5.4 4 8 6.1-6.1 4.8 8 7.3-5 3.6 11.5 13.5 52.3-15.3 37-31.3-96.2-71.4z"}),/*#__PURE__*/t("path",{d:"m267.2 153.5-52.3-15.3 15.9 23.9-23.7 46 31.2-.4h46.5zm-163.6-15.3-52.3 15.3-17.4 54.2h46.4l31.1.4-23.6-46zm71 26.4 3.3-57.7 15.2-41.1h-67.5l15 41.1 3.5 57.7 1.2 18.2.1 44.8h27.7l.2-44.8z",className:"s3"})]})})]}),Sr=({style:n,...r})=>/*#__PURE__*/e("svg",{xmlns:"http://www.w3.org/2000/svg",width:"108",height:"108",viewBox:"0 0 108 108",fill:"none",style:{height:"28px",width:"28px",...n},...r,children:[/*#__PURE__*/t("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M46.5267 69.9229C42.0054 76.8509 34.4292 85.6182 24.348 85.6182C19.5824 85.6182 15 83.6563 15 75.1342C15 53.4305 44.6326 19.8327 72.1268 19.8327C87.768 19.8327 94 30.6846 94 43.0079C94 58.8258 83.7355 76.9122 73.5321 76.9122C70.2939 76.9122 68.7053 75.1342 68.7053 72.314C68.7053 71.5783 68.8275 70.7812 69.0719 69.9229C65.5893 75.8699 58.8685 81.3878 52.5754 81.3878C47.993 81.3878 45.6713 78.5063 45.6713 74.4598C45.6713 72.9884 45.9768 71.4556 46.5267 69.9229ZM83.6761 42.5794C83.6761 46.1704 81.5575 47.9658 79.1875 47.9658C76.7816 47.9658 74.6989 46.1704 74.6989 42.5794C74.6989 38.9885 76.7816 37.1931 79.1875 37.1931C81.5575 37.1931 83.6761 38.9885 83.6761 42.5794ZM70.2103 42.5795C70.2103 46.1704 68.0916 47.9658 65.7216 47.9658C63.3157 47.9658 61.233 46.1704 61.233 42.5795C61.233 38.9885 63.3157 37.1931 65.7216 37.1931C68.0916 37.1931 70.2103 38.9885 70.2103 42.5795Z",fill:"#FFFDF8"})]});function Ir(e,t){if(!Object.prototype.hasOwnProperty.call(e,t))throw TypeError("attempted to use private field on non-instance");return e}var Pr=0;class Wr extends vr{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 z("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw ir(e)}}constructor(e,t,n,r,a){super(a||"unknown",e,t,n),this.connectorType="injected",this.proxyProvider=new Ar(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=r;let i=r.provider;this.proxyProvider.setWalletProvider(i)}}var xr="__private_"+Pr+++"__walletBranding";class Ur extends vr{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 Ir(this,xr)[xr]??{name:"Browser Extension",icon:_r,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 z("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw ir(e)}}constructor(e,t,n,r,a){super(a??"unknown",e,t,n),Object.defineProperty(this,xr,{writable:!0,value:void 0}),this.connectorType="injected",this.proxyProvider=new Ar(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(r),"metamask"===a?Ir(this,xr)[xr]={name:"MetaMask",icon:Er,id:"io.metamask"}:"phantom"===a&&(Ir(this,xr)[xr]={name:"Phantom",icon:Sr,id:"phantom"})}}class Or extends Wr{disconnect(){console.warn("MetaMask does not support programmatic disconnect.")}async promptConnection(){try{m||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 z("Unable to retrieve accounts");await this.syncAccounts([e[0]])}catch(e){throw ir(e)}}}const Nr=["metamask","phantom","brave_wallet","rainbow","uniswap_wallet_extension","uniswap_extension","rabby_wallet","bybit_wallet","ronin_wallet","haha_wallet","crypto.com_wallet_extension","crypto.com_onchain","binance","bitget_wallet","coinbase_wallet","coinbase_smart_wallet","base_account","metamask","trust","safe","rainbow","uniswap","zerion","argent","spot","omni","cryptocom","blockchain","safepal","bitget_wallet","zengo","1inch","binance","exodus","mew_wallet","alphawallet","keyring_pro","mathwallet","unstoppable","obvious","ambire","internet_money_wallet","coin98","abc_wallet","arculus_wallet","haha","cling_wallet","broearn","copiosa","burrito_wallet","enjin_wallet","plasma_wallet","avacus","bee","pitaka","pltwallet","minerva","kryptogo","prema","slingshot","kriptonio","timeless","secux","bitizen","blocto","okx_wallet","safemoon","rabby_wallet","bybit_wallet","ronin_wallet","haha_wallet","privy","unknown","phantom","solflare","glow","backpack","jupiter","mobile_wallet_adapter"],Mr=Object.freeze({phantom:{client:"phantom",name:"Phantom",installLink:w.isFirefox?"https://addons.mozilla.org/en-US/firefox/addon/phantom-app/":"https://chrome.google.com/webstore/detail/phantom/bfnaelmomeimhlpmgjnjophhpkkoljpa?hl=en",chainTypes:["ethereum","solana"],get isInstalled(){if("phantom"in window){let e=window;if(e?.phantom?.ethereum?.isPhantom&&e?.phantom?.ethereum?.chainId||e?.phantom?.solana?.isPhantom)return!0}return!1},getMobileRedirect({useUniversalLink:e,isSolana:t,connectOnly:n}){let r=Dr({client:this.client,isSolana:t,connectOnly:n});return`${e?"phantom://":"https://phantom.app/ul/"}browse/${r}?ref=${r}`}},solflare:{client:"solflare",name:"Solflare",installLink:w.isFirefox?"https://addons.mozilla.org/es/firefox/addon/solflare-wallet/":"https://chromewebstore.google.com/detail/solflare-wallet/bhhhlbepdkbapadjdnnojkbgioiodbic",chainTypes:["solana"],get isInstalled(){return"solflare"in window&&!!window?.solflare?.isSolflare},getMobileRedirect({useUniversalLink:e,isSolana:t,connectOnly:n}){let r=Dr({client:this.client,isSolana:t,connectOnly:n});return`${e?"solflare://ul/v1/":"https://solflare.com/ul/v1/"}browse/${r}?ref=${r}`}},jupiter:{client:"jupiter",name:"Jupiter Wallet",installLink:"https://chromewebstore.google.com/detail/jupiter-wallet/iledlaeogohbilgbfhmbgkgmpplbfboh",chainTypes:["solana"],get isInstalled(){return"jupiter"in window&&!!window?.jupiter?.isJupiter},getMobileRedirect({isSolana:e,connectOnly:t}){let n=Dr({client:this.client,isSolana:e,connectOnly:t});return`jupjupjup://jup.ag/browse/${n}?ref=${n}`}},backpack:{client:"backpack",name:"Backpack",installLink:"https://chromewebstore.google.com/detail/backpack/aflkmfhebedbjioipglgcbcmnbpgliof",chainTypes:["ethereum","solana"],get isInstalled(){return!(!("backpack"in window)||!window?.backpack?.ethereum?.isBackpack&&!window?.backpack?.solana?.isBackpack)},getMobileRedirect({useUniversalLink:e,isSolana:t,connectOnly:n}){let r=Dr({client:this.client,isSolana:t,connectOnly:n});return`${e?"backpack://ul/v1/":"https://backpack.app/ul/v1/"}browse/${r}?ref=${r}`}},okx_wallet:{client:"okx_wallet",name:"OKX Wallet",installLink:"https://chromewebstore.google.com/detail/okx-wallet/mcohilncbfahbmgdjkbpemcciiolgcge",chainTypes:["ethereum","solana"],get isInstalled(){return"okxwallet"in window&&!!window?.okxwallet?.isOkxWallet},getMobileRedirect({isSolana:e,connectOnly:t}){return`okx://wallet/dapp/url?dappUrl=${Dr({client:this.client,isSolana:e,connectOnly:t})}`}}});function Rr({connectorType:e,walletClientType:t}){for(let n of Nr)if(e===n||t===n)return Mr[n]}function Dr({client:e,isSolana:t,connectOnly:n}){let r=new URL(window.location.href);return r.searchParams.set("privy_connector",t?"solana_adapter":"injected"),r.searchParams.set("privy_wallet_client",e),r.searchParams.set("privy_connect_only",String(n)),encodeURIComponent(r.href.replace(/\/$/g,""))}const Fr=()=>{let e=ur.get(Nt);return e&&Array.isArray(e)&&e.map((e=>(e=>e&&"string"==typeof e.address&&"string"==typeof e.connectorType&&"string"==typeof e.walletClientType&&"number"==typeof e.connectedAt)(e))).every(Boolean)?e:[]};let Lr=["phantom","glow","solflare","backpack","okx_wallet","walletconnect","mobile_wallet_adapter","jupiter"];function jr(e){return e.toLowerCase().split(" ").join("_")}class zr extends wr{get isInstalled(){return!0}get wallet(){return this._wallet}buildConnectedWallet(){return this._wallet.accounts.map((e=>({type:"solana",provider:new _({wallet:this._wallet,account:e}),address:e.address,connectedAt:Date.now(),walletClientType:this._wallet.name,connectorType:this.connectorType,imported:!1,meta:{name:this._wallet.name,id:this._wallet.name,icon:this._wallet.icon},isConnected:async()=>this._wallet.accounts.length>0,disconnect:async()=>{await this.disconnect()}})))}async syncAccounts(){this.wallets=this.buildConnectedWallet(),this.emit("walletsUpdated")}get walletBranding(){return{id:qr(this.wallet)?"walletconnect_solana":this.wallet.name,name:this.wallet.name,icon:this.wallet.icon}}async initialize(){this.subscribeListeners(),await this.syncAccounts(),this.shouldAttemptAutoConnect()&&(await(this.wallet.features["standard:connect"]?.connect({silent:!0}).catch((()=>{}))),await this.isConnected()&&await this.syncAccounts()),this.initialized=!0,this.emit("initialized")}async connect(e){if(e.showPrompt)try{await this.promptConnection()}catch(e){if(0===this._wallet.accounts.length)throw new B;throw e}if(!await this.isConnected())throw new B;return await this.syncAccounts(),this.getConnectedWallet()}async getConnectedWallet(){return this.wallets.sort(((e,t)=>t.connectedAt-e.connectedAt))[0]||null}async isConnected(){return this._wallet.accounts.length>0}subscribeListeners(){this._unsubscribeListeners=this.wallet.features["standard:events"]?.on("change",this.onChange)}unsubscribeListeners(){this._unsubscribeListeners?.()}shouldAttemptAutoConnect(){return!(!this.autoConnectEnabled||!Lr.includes(this.walletClientType))&&("phantom"!==this.walletClientType&&"metamask"!==this.walletClientType.toLowerCase()||Fr().some((({walletClientType:e})=>"phantom"===e||"metamask"===e.toLowerCase())))}constructor(e,t){super(jr(qr(e)?"walletconnect_solana":e.name)),this.chainType="solana",this.connectorType="solana_adapter",this.disconnect=async()=>{await(this.wallet.features["standard:disconnect"]?.disconnect().catch((e=>console.error("Error disconnecting",e)))),await this.syncAccounts()},this.promptConnection=async()=>{try{await(this.wallet.features["standard:connect"]?.connect())}catch(e){throw ir(e)}},this.onChange=()=>{this.syncAccounts()},this._wallet=e,this.autoConnectEnabled=t,this.wallets=[]}}function qr(e){return"isWalletConnectSolana"in e&&e.isWalletConnectSolana}class Br extends zr{get walletBranding(){return{id:this.id,name:this.name,icon:this.icon}}async initialize(){this.initialized=!0,this.emit("initialized")}async connect(){throw Error("connect called for an uninstalled wallet via the SolanaNullConnector")}constructor({id:e,name:t,icon:n}){super({name:t},!1),this.connectorType="null",this.proxyProvider=new Ar(void 0,xt),this.disconnect=async()=>{throw Error("disconnect called for an uninstalled wallet via the SolanaNullConnector")},this.promptConnection=async()=>{throw Error("promptConnection called for an uninstalled wallet via the SolanaNullConnector")},this.id=e,this.name=t,this.icon=n}}function Hr(e){return{name:e.metadata?.shortName||e.name||"",universalLink:e.mobile.universal,deepLink:e.mobile.native}}function $r(e,t){let n=Hr(t);if(m&&n.universalLink)return Jr(n.universalLink,e);if(n.deepLink)return Yr(n.deepLink,e);if(n.universalLink)return Jr(n.universalLink,e);throw new H(`Unsupported wallet ${t.id}`)}function Vr(e,t){let n=Hr(t);if(n.universalLink)return Jr(n.universalLink,e)}let Kr="WALLETCONNECT_DEEPLINK_CHOICE";function Gr(e){return e.startsWith("http://")||e.startsWith("https://")}function Yr(e,t){if(Gr(e))return Jr(e,t);let n=e;return n.includes("://")||(n=e.replaceAll("/","").replaceAll(":",""),n=`${n}://`),n.endsWith("/")||(n=`${n}/`),{redirect:`${n}wc?uri=${encodeURIComponent(t)}`,href:n}}function Jr(e,t){if(!Gr(e))return Yr(e,t);let n=e;return n.endsWith("/")||(n=`${n}/`),{redirect:`${n}wc?uri=${encodeURIComponent(t)}`,href:n}}function Zr(e,t){window.open(e,t,"noreferrer noopener")}const Qr=({style:n,...r})=>{let a=Wt();/*#__PURE__*/return e("svg",{width:"28",height:"28",viewBox:"0 0 28 28",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...n},...r,children:[/*#__PURE__*/t("rect",{width:"28",height:"28",rx:"3",fill:"dark"===a?.appearance.palette.colorScheme?"#3396ff":"#141414"}),/*#__PURE__*/t("g",{clipPath:"url(#clip0_1765_9946)",children:/*#__PURE__*/t("path",{d:"M8.09448 10.3941C11.3558 7.20196 16.6442 7.20196 19.9055 10.3941L20.2982 10.7782C20.3369 10.8157 20.3677 10.8606 20.3887 10.9102C20.4097 10.9599 20.4206 11.0132 20.4206 11.0671C20.4206 11.121 20.4097 11.1744 20.3887 11.224C20.3677 11.2737 20.3369 11.3186 20.2982 11.3561L18.9554 12.6702C18.9158 12.7086 18.8628 12.7301 18.8077 12.7301C18.7526 12.7301 18.6996 12.7086 18.66 12.6702L18.1198 12.1415C15.8448 9.91503 12.1557 9.91503 9.88015 12.1415L9.30167 12.7075C9.26207 12.7459 9.20909 12.7673 9.15395 12.7673C9.0988 12.7673 9.04582 12.7459 9.00622 12.7075L7.66346 11.3934C7.62475 11.3559 7.59397 11.3109 7.57295 11.2613C7.55193 11.2117 7.5411 11.1583 7.5411 11.1044C7.5411 11.0505 7.55193 10.9971 7.57295 10.9475C7.59397 10.8979 7.62475 10.8529 7.66346 10.8154L8.09448 10.3941ZM22.6829 13.1115L23.8776 14.2814C23.9163 14.319 23.9471 14.3639 23.9681 14.4135C23.9892 14.4632 24 14.5165 24 14.5704C24 14.6243 23.9892 14.6777 23.9681 14.7273C23.9471 14.777 23.9163 14.8219 23.8776 14.8594L18.4893 20.1332C18.4102 20.2101 18.3042 20.2531 18.1938 20.2531C18.0835 20.2531 17.9775 20.2101 17.8984 20.1332L14.0743 16.3901C14.0545 16.3708 14.0279 16.36 14.0003 16.36C13.9726 16.36 13.9461 16.3708 13.9263 16.3901L10.1021 20.1332C10.023 20.2101 9.91703 20.2531 9.8067 20.2531C9.69636 20.2531 9.59038 20.2101 9.51124 20.1332L4.12236 14.8594C4.08365 14.8219 4.05287 14.777 4.03185 14.7273C4.01083 14.6777 4 14.6243 4 14.5704C4 14.5165 4.01083 14.4632 4.03185 14.4135C4.05287 14.3639 4.08365 14.319 4.12236 14.2814L5.31767 13.1115C5.39678 13.0348 5.50265 12.9919 5.61285 12.9919C5.72305 12.9919 5.82892 13.0348 5.90803 13.1115L9.73216 16.8546C9.75194 16.874 9.7785 16.8848 9.80616 16.8848C9.83381 16.8848 9.86037 16.874 9.88015 16.8546L13.7043 13.1115C13.7834 13.0346 13.8894 12.9916 13.9997 12.9916C14.1101 12.9916 14.216 13.0346 14.2952 13.1115L18.1198 16.8546C18.1396 16.874 18.1662 16.8848 18.1938 16.8848C18.2215 16.8848 18.2481 16.874 18.2678 16.8546L22.092 13.1115C22.1711 13.0346 22.2771 12.9916 22.3874 12.9916C22.4977 12.9916 22.6037 13.0346 22.6829 13.1115Z",fill:"white"})}),/*#__PURE__*/t("defs",{children:/*#__PURE__*/t("clipPath",{id:"clip0_1765_9946",children:/*#__PURE__*/t("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})},Xr="data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAIGNIUk0AAHomAACAhAAA+gAAAIDoAAB1MAAA6mAAADqYAAAXcJy6UTwAAAAGYktHRAD/AP8A/6C9p5MAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAAHdElNRQfoDAIVODUC+w+GAAAGsUlEQVRYw6WXbYwWVxXHf+fOLAtCXYS2QJdIaClipGCTknXXNqBQMVHbfmhItH4Aral+IAEaG03UxJgYKQJGTUxtDWjaxDSNtcZqIGDwpRuW1oYiVqpdpZSlpC3qysu+PHPP3w/3mXnmeXZbPzjJZO7cefn/z/mfe865xlscq3dGDIguGiHLaMQVLja4s87FShcLo5jtApdddnHexUmHIy475JmdUkPRAQMu7gzT4ljnxJpdk0QPmMFkyAKN2OfOFpc2uuh1J3MZDrjAvXmVEQUuoosRxw642FcEG7IoDxiFxNiu8NYE+vcUYIFYRKKs113bXWx2Z34CoQZsVHOiCZ7mopdzdsFhv8NexEgRDHMxUSNREbh1bwNZwBsFblmfu/a4a6AEENYO5i3AOoEWeEUCF4MOOxBDMQAOk99OJALA2u80sBCwWGBZWG/yRwMaCAbBIAsQTJT3gea1OWfNeaPzvjoHEI85rA8ObtB1v7cIdJkIHgkh9AXpocy0LJjIKvB2wPpZB0v3wkrw5jdNEjeYeMhFX3BAyfn2ke9NUrgB9LrrcZcGJFCld4fWNddXbvbWfWzGR6xJFZsBGh0cBh3bBIxIEGTQ3W0h4NuDaSAzyAxCmGq11Vzf5uaa1aG8p+WFtrEYQGwvjICJkAEqvC+YNmcmMlMNvEaCdrcbyUvQAWDTjVuESHObM6cPGWHmzDwLaEtmzG9Z3qF1zUpXmuuZBb1z4bqeNC6f0WE1NtUTwHzEloiy3BvFisy0sYoLlQtT6XW15md2Qf9SY+2Ngfdca/TMSm/9ewz+/Boc/It45h/i4kSTsKw90SQJsPTvjSZbkWemDW7qTRZ0JEYJWSKxZJ7xmf6M224MzMzbX1s8F1YugjtvMg6eErt/4/z1jUrz1rXUKxnZC2zIg2mdBTK1mFUOKC1fOt/48kdzVixIz86Nij+eEacvpJWyZJ5xy7th8VzjjpuMJfMCW58QL73ekXPVlhsyE+vyzFiplJyauEIyrGIquruMq7qTxk+dcB495rzyTzFepCUWLIFv/kBg081Gd55WUk1IDGFTS89K++TDYxddzKnWcbluHd450xgdh7EGrOo1rr868PMTzqWJRGZ2d8oB/xpL33Xnxl2rjeNn4blXRXduzJ4B5y+28kWscAwXl+yeR654FFZPHoUb710YuPeDOUdPO48di1xptKpeEeHqOcYXNwQKGd88EDk3mqxtxPSfGRlsXRtYt8z4ytPOH/7eqpg1Aso7fYKgK4NPrMpYvsC4/poMA34yVJIQC3sCD9yecdsNyaV5yPj6ryJnR1PAvSNP4J+/1cgDfLbfePaMGGtM7Qdyl12WmKOmXgKKAp54vmBRTxfLrjE+tSYjBPjRM5FrrzIeuD2jf2lLzw8vN4JlfPVp581LsO1DgXv7jSzAiXPw/d+JiYLpjsu26Yfjf5O0rF5WoxsNT9G/bX0XKxakmPjlSee6HlizJJXSX7/oRDc+vjKR+f2wODcKd78/gR8/C9uedF44myJxmhh4OY/ipMQyqaWxmjn95TfEroMFOzbkvG+RceeqViPx1Aln1yEnOow1AnffHCpJAJ5/Vex4UvzptZRdY/O/1dJIS/NkcNmR6MTYah6qzseA4TfFtw4UvHBW1bc/O+7sPhwZHYf/jMODh5yfPudVbXj2TAJ/8XxrOZagNamj4Ei2/GNfuyRxh8t6BG2l15up+MIVODEiFr8rcPS0+O6RBF6mrrEGHHtFzOo2Lo7Dl37hvPQ6mNV6R9JYKgnYWcE37K5HlE2OT/5A0udaPUBHH+BQOMzuNsYLuDyZflTW+fTcmJFDHhJhaZqewMuewXDxcDR9IYyPN6Jj+6K4MF2vV8qBtZJScqVRNi6lpGONVJis5mpKi1WbgwsY+zIsBpcR8mzIZfuTRVZrtdu9odrptR/Xx5XONXJqBmCN0P6YMUQq9WJiwt0Je102WHdbpxSqydMObBWYdwDWLVcqcIMYe3NPjg0Ht84od0Ajju1w2XCr9e6QoqM9V23ZtnmI6cfAMMb9AY0YEHdb6oobEh4y3H3Ize6LsmGvN5IdUnhttdQ9UVrfLk/ljWEZ9wXsqAdQk1EA+O22GcgdZTke/bAs3OPY4HSdcB20HhvVtTMu0jmI8ekAhz2IICj2hKpNqI60NcuIRUHEej1quzubXa2tmZhenrfZmv3YYQ9ipDAIgvHptmblccuDjdRcmjFpWbDi/9ycZjZkRbk5jYztai/AUwiUx+qdEQB/m+25i9lxyvbcjrg45Lmd0uT/3p7/Fw6ODf+WO019AAAAJXRFWHRkYXRlOmNyZWF0ZQAyMDI0LTEyLTAyVDIxOjU2OjQ4KzAwOjAwMVpslgAAACV0RVh0ZGF0ZTptb2RpZnkAMjAyNC0xMi0wMlQyMTo1Njo0OCswMDowMEAH1CoAAAAodEVYdGRhdGU6dGltZXN0YW1wADIwMjQtMTItMDJUMjE6NTY6NTMrMDA6MDDZv6GRAAAAAElFTkSuQmCC";function ea(e){return"solana"===e.chainType}function ta(e){return"solana"===e.type}class na extends vr{async initialize(){let e=await this.createProvider();this.provider=e,this.proxyProvider.setWalletProvider(e),this.subscribeListeners(),e.session&&(this.walletProvider?.session?.peer.metadata.url&&(this.walletEntry=In(this.walletProvider?.session?.peer.metadata.url),this.walletClientType=this.walletEntry?.slug||"unknown"),this.connected=!0,await this.syncAccounts()),this.initialized=!0,this.emit("initialized")}async connect(e){return e.showPrompt&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return!!this.walletProvider?.connected}get walletBranding(){let e=this.walletProvider?.session?.peer.metadata.icons?.[0];return{name:Vn(this.walletProvider?.session?.peer.metadata.name||"")||"WalletConnect",icon:"string"==typeof e?e:Xr,id:this.walletProvider?.session?.peer.metadata.name.toLowerCase()||"wallet_connect_v2"}}async resetConnection(e){this.walletProvider&&this.walletProvider.connected&&(await this.walletProvider.disconnect(),this.walletProvider.signer.session=void 0,this.walletClientType=e,this.redirectUri=void 0,this.fallbackUniversalRedirectUri=void 0,function(){try{localStorage.removeItem(Kr)}catch{}}(),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise(((e,t)=>{(async()=>{let t="",n=await Promise.race([this.walletProvider?.enable(),this.proxyProvider.walletTimeout()]);if(n?.length&&(t=n[0]),!t||""===t)throw new z("Unable to retrieve address");this.walletProvider?.session?.peer.metadata.url&&(this.walletEntry=In(this.walletProvider?.session?.peer.metadata.url),this.walletClientType=this.walletEntry?.slug||"unknown",this.proxyProvider.rpcTimeoutDuration=mr(this.rpcConfig,this.walletClientType)),this.connected=!0,await this.syncAccounts(n),e()})().catch((e=>{t(e?ir(e):new z("Unknown error during connection"))}))}))}disconnect(){this.walletProvider?.disconnect().then((()=>this.onDisconnect())).catch((()=>console.warn("Unable to disconnect WalletConnect provider")))}get walletProvider(){return this.proxyProvider.walletProvider}setWalletProvider(e){this.proxyProvider.setWalletProvider(e)}async createProvider(){let e={};for(let t of this.chains){let n=Jn(t.id,this.chains,this.rpcConfig,this.privyAppId);n&&(e[t.id]=n)}let t=this.shouldEnforceDefaultChainOnConnect?[this.defaultChain.id]:[],n=this.chains.map((e=>e.id)),r=await rn.init({projectId:this.walletConnectCloudProjectId,chains:t,optionalChains:n,optionalEvents:sn,optionalMethods:an,rpcMap:e,showQrModal:!1,metadata:{description:this.privyAppName,name:this.privyAppName,url:window.location.origin,icons:[]}});return r.on("display_uri",(e=>{if(r.signer.abortPairingAttempt(),function(){try{localStorage.removeItem(Kr)}catch{}}(),!this.showPrivyQrModal)throw new z("WalletConnect modal not available - Privy handles wallet connections through its own UI");if(m&&this.walletEntry){let{redirect:t,href:n}=$r(e,this.walletEntry);Zr(t,"_self"),function({href:e,name:t}){try{localStorage.setItem(Kr,JSON.stringify({href:e,name:t}))}catch{}}({href:n,name:this.walletEntry.metadata?.shortName||this.walletEntry.name});let r=Vr(e,this.walletEntry);return this.redirectUri=t,this.fallbackUniversalRedirectUri=r?.redirect,this.showPrivyQrModal({native:t,universal:t})}if(this.redirectUri=void 0,this.walletEntry){let t=Vr(e,this.walletEntry);this.fallbackUniversalRedirectUri=t?.redirect}this.showPrivyQrModal({native:e,universal:void 0})})),r.on("connect",(()=>{r.session?.peer.metadata.url&&(this.walletEntry=In(r.session?.peer.metadata.url),this.walletClientType=this.walletEntry?.slug||"unknown")})),r}async enableProvider(){return this.walletProvider?.connected?Promise.resolve(this.walletProvider.accounts):await(this.walletProvider?.enable())}setWalletEntry(e,t){this.walletEntry=e,this.showPrivyQrModal=t}constructor({walletConnectCloudProjectId:e,rpcConfig:t,chains:n,defaultChain:r,shouldEnforceDefaultChainOnConnect:a,privyAppId:i,privyAppName:s,walletClientType:o}){super(o||"unknown",n,r,t),this.connectorType="wallet_connect_v2",this.privyAppId=i,this.privyAppName=s,this.walletConnectCloudProjectId=e,this.rpcConfig=t,this.shouldEnforceDefaultChainOnConnect=a,this.proxyProvider=new Ar(void 0,this.rpcTimeoutDuration),o&&(this.walletEntry=(e=>En.getState().listings.find((({slug:t})=>xn(t)===xn(e))))(o),this.walletClientType=o)}}class ra extends It{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 n=`${t.address}${t.walletClientType}${t.connectorType}${t.meta.id}`;return!e.has(n)&&(e.add(n),!0)}))}async initialize(e){if(this.initialized&&!e||(e&&this.removeAllConnectors(),this.externalWalletConfig.disableAllExternalWallets))return;let t=Gn({store:this.store,walletList:this.walletList,externalWalletConfig:this.externalWalletConfig,walletChainType:this.walletChainType}).then((e=>{e.forEach((({type:e,eip6963InjectedProvider:t,legacyInjectedProvider:n})=>{this.createEthereumWalletConnector({connectorType:"injected",walletClientType:e,providers:{eip6963InjectedProvider:t,legacyInjectedProvider:n}})}))}));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(Mr)))!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 Br({id:e.client,name:e.name})));this.externalWalletConfig.walletConnect.enabled&&(this.walletList.includes("wallet_connect_qr")||Un(this.walletList))&&"solana-only"!==this.walletChainType&&this.createEthereumWalletConnector({connectorType:"wallet_connect_v2",walletClientType:"unknown"});let n=this.walletList.includes("wallet_connect_qr_solana")||Un(this.walletList)&&"ethereum-only"!==this.walletChainType,r=this.externalWalletConfig.solana.connectors?.get()||[],a=async e=>{if(!n)return;let t=e.find((e=>"walletconnect_solana"===e.walletBranding?.id));t&&t.wallet&&await t.wallet.initialize({walletConnectCloudProjectId:this.walletConnectCloudProjectId,privyAppName:this.privyAppName})};a(r),r.filter((e=>n||"walletconnect_solana"!==e.walletBranding?.id)).forEach(this.addSolanaWalletConnector),this.externalWalletConfig.solana.connectors?._setOnConnectorsUpdated?.((e=>{a(e),e?.filter((e=>n||"walletconnect_solana"!==e.walletBranding?.id)).forEach(this.addSolanaWalletConnector)})),await t,this.initialized=!0}findWalletConnector(e,t,n){return"wallet_connect_v2"===e?this.walletConnectors.filter(fr).find((t=>t.connectorType===e&&(!n||t.wallets.some((e=>e.address===n)))))??null:this.walletConnectors.filter(fr).find((r=>r.connectorType===e&&r.walletClientType===t&&(!n||r.wallets.some((e=>e.address===n)))))??null}findSolanaWalletConnector(e){return this.walletConnectors.filter(ea).find((t=>"unknown"===t.walletClientType?t.walletBranding.id===e:t.walletClientType===e))??null}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")}async createEthereumWalletConnector({connectorType:e,walletClientType:t,providers:n,walletConfig:r}){let a=this.findWalletConnector(e,t);if(a&&fr(a))return a instanceof na&&a.resetConnection(t),a;let i=(()=>"injected"!==e?"coinbase_wallet"===e?new kr(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig.coinbaseWallet.config):"base_account"===e?new br(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig.baseAccount.config,this.setBaseAccountSdk):"null"!==e?new na({walletConnectCloudProjectId:this.walletConnectCloudProjectId,rpcConfig:this.rpcConfig,chains:this.chains,defaultChain:this.defaultChain,shouldEnforceDefaultChainOnConnect:this.shouldEnforceDefaultChainOnConnect,privyAppId:this.privyAppId,privyAppName:this.privyAppName,walletClientType:t}):r?new Tr({id:r.client,name:r.name,defaultChain:this.defaultChain,walletClientType:r.client}):null:"metamask"===t&&n?.eip6963InjectedProvider?new Or(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask"):"metamask"===t&&n?.legacyInjectedProvider?new Ur(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"metamask"):"phantom"===t&&n?.legacyInjectedProvider?new Ur(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"phantom"):n?.legacyInjectedProvider&&"unknown_browser_extension"===t?new Ur(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider):n?.eip6963InjectedProvider?new Wr(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,t):void 0)();return i&&this.addWalletConnector(i),i||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,n,r,a,i,s,o,l,c,d,u){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=n,this.chains=r,this.defaultChain=a,this.walletConnectors=[],this.initialized=!1,this.store=i,this.walletList=s,this.shouldEnforceDefaultChainOnConnect=o,this.externalWalletConfig=l,this.privyAppName=c,this.walletChainType=u||"ethereum-only",this.setBaseAccountSdk=d,this.storedConnections=Fr()}}const aa=Pt((()=>({identityToken:null})));function ia(){let{identityToken:e}=aa();return{identityToken:e}}let sa=[te,ne,re];class oa{async get(e,t){try{return await this.baseFetch(e,t)}catch(e){throw $(e)}}async post(e,t,n){try{return await this.baseFetch(e,{method:"POST",...t?{body:t}:{},...n})}catch(e){throw $(e)}}async delete(e,t){try{return await this.baseFetch(e,{method:"DELETE",...t})}catch(e){throw $(e)}}constructor({appId:e,appClientId:t,client:n,defaults:r}){this.appId=e,this.appClientId=t,this.clientAnalyticsId=n.clientAnalyticsId,this.sdkVersion=Mt,this.client=n,this.defaults=r,this.fallbackApiUrl=n.fallbackApiUrl,this.baseFetch=on.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 n=new Headers(t.headers);n.set("privy-app-id",this.appId),this.appClientId&&n.set("privy-client-id",this.appClientId),n.set("privy-ca-id",this.clientAnalyticsId||""),n.set("privy-client",`react-auth:${this.sdkVersion}`);let r=sa.includes(e.toString());if(!n.has("authorization")){let e=await this.client.getAccessToken({disableAutoRefresh:r});null!==e&&n.set("authorization",`Bearer ${e}`)}t.headers=n,t.retryDelay&&"number"==typeof t.retryDelay&&(t.retryDelay=3*t.retryDelay)},onRequestError:({error:e})=>{if(e instanceof DOMException&&"AbortError"===e.name)throw new V}})}}const la=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 ca{async authenticate(){if(!this.api)throw new H("Auth flow has no API instance");try{return await this.api.post(ae,{token:this.meta.token})}catch(e){throw $(e)}}async link(){if(!this.api)throw new H("Auth flow has no API instance");try{return await this.api.post(ie,{token:this.meta.token})}catch(e){throw $(e)}}constructor(e){this.meta={token:e}}}function da(e){return e?{"privy-ui":"t"}:void 0}class ua{async authenticate(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new H("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(oe,{email:this.meta.email,code:this.meta.emailCode,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw $(e)}}async link(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new H("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(le,{email:this.meta.email,code:this.meta.emailCode})}catch(e){throw $(e)}}async sendCodeEmail({email:e,captchaToken:t,withPrivyUi:n}){if(!this.api)throw new H("Auth flow has no API instance");if(e&&(this.meta.email=e),t&&(this.meta.captchaToken=t),!this.meta.email)throw new H("Email must be set when initialzing authentication.");let r=da(n);try{return await this.api.post(ce,{email:this.meta.email,token:this.meta.captchaToken},{headers:{...r}})}catch(e){throw $(e)}}constructor({email:e,captchaToken:t,disableSignup:n}){this.meta={email:e,captchaToken:t,disableSignup:n??!1}}}class ha extends ua{async link(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode||!this.meta.oldAddress)throw new H("Email, email code, and an old email address must be set prior to calling update.");try{return await this.api.post(se,{oldAddress:this.meta.oldAddress,newAddress:this.meta.email,code:this.meta.emailCode})}catch(e){throw $(e)}}constructor(e,t,n){super({email:t,captchaToken:n}),this.meta={email:t,captchaToken:n,oldAddress:e,disableSignup:!1}}}function pa(e){return crypto.getRandomValues(new Uint8Array(e))}class wa{getOrCreateGuestCredential(e){let t=Rt(e);if(dr()){if(ur.get(t))return ur.get(t);{let e=pt.encode(pa(32));return ur.put(t,e),e}}return pt.encode(pa(32))}async authenticate(){if(!this.api)throw new H("Auth flow has no API instance");try{return await this.api.post(de,{guest_credential:this.meta.guestCredential})}catch(e){throw $(e)}}async link(){throw Error("Linking is not supported for the guest flow")}constructor(e){this.meta={guestCredential:this.getOrCreateGuestCredential(e)}}}function ma(){return"undefined"!=typeof window&&"chrome-extension:"===window.location.protocol&&"chrome"in window}function ya(){if(!ma())return;let e=window.chrome;return e?.runtime?.id}function ga(){if(!ma())return!1;let e=window.chrome;return"function"==typeof e?.identity?.launchWebAuthFlow}async function fa(e){return new Promise(((t,n)=>{ga()?window.chrome.identity.launchWebAuthFlow({url:e,interactive:!0},(async e=>{try{let n=function(){if(!ma())return;let e=window.chrome;return e?.runtime?.lastError?.message}();if(n||!e){let e=`WebAuthFlow failed: ${n||"Response URI missing"}`;throw Error(e)}let r=new URL(e),a=ya();if(!a)throw Error("Invalid extension context");if("chrome-extension:"===r.protocol){if(r.hostname!==a)throw Error("Invalid responseUri origin")}else{if("https:"!==r.protocol)throw Error("Invalid responseUri protocol");{let e=r.hostname.split(".");if(3!==e.length||"chromiumapp"!==e[1]||"org"!==e[2]||e[0]!==a)throw Error("Invalid responseUri origin")}}let i=r.searchParams.get("privy_oauth_state"),s=r.searchParams.get("privy_oauth_code");if(!i||!s)throw Error("Invalid responseUri - missing required parameters");t({privyOAuthState:i,privyOAuthCode:s})}catch(e){n(e)}})):n(Error("Chrome identity API not available"))}))}function va(){return pt.encode(pa(36))}function Aa(){return va()}async function ba(e,t="S256"){if("S256"!=t)return e;{let t=await async function(e){let t=(new TextEncoder).encode(e);return new Uint8Array(await crypto.subtle.digest("SHA-256",t))}(e);return pt.encode(t)}}class Ca{addCaptchaToken(e){this.meta.captchaToken=e}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new H("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if("undefined"===this.meta.authorizationCode)throw new H("User denied confirmation during OAuth flow");let e=function(){let e=ur.get(Dt);if(!e)throw new H("Authentication error.");return e}();try{let t=await this.api.post(ue,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:e,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"});return ur.del(Dt),ur.del(Ft),ur.del(Lt),t}catch(e){let t=$(e);if(t.privyErrorCode)throw new H(t.message||"Invalid code during OAuth flow.",void 0,t.privyErrorCode);if("User denied confirmation during OAuth flow"===t.message)throw new H("Invalid code during oauth flow.",void 0,K.OAUTH_USER_DENIED);throw new H("Invalid code during OAuth flow.",void 0,K.UNKNOWN_AUTH_ERROR)}}async link(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new H("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if("undefined"===this.meta.authorizationCode)throw new H("User denied confirmation during OAuth flow");let e=ur.get(Dt);if(!e)throw new H("Authentication error.");try{let t=await this.api.post(he,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:e});return ur.del(Dt),t}catch(e){throw $(e)}}async getAuthorizationUrl(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.provider)throw new H("Provider must be set when initializing OAuth authentication.");let e=va();ur.put(Dt,e);let t=Aa();ur.put(jt,t);let n=await ba(e);this.meta.withPrivyUi||ur.put(Ft,!0),this.meta.disableSignup?ur.put(Lt,!0):ur.del(Lt);let r=da(this.meta.withPrivyUi),a=window.location.href,i=function(){let e=ya();if(e)return`https://${e}.chromiumapp.org`}();i&&(a=i);try{return await this.api.post(pe,{provider:this.meta.provider,redirect_to:this.meta.customOAuthRedirectUrl||a,token:this.meta.captchaToken,code_challenge:n,state_code:t},{headers:{...r}})}catch(e){throw $(e)}}constructor(e){this.meta=e}}function ka(){let e=new URLSearchParams(window.location.search),t=e.get("privy_oauth_code"),n=e.get("privy_oauth_state"),r=e.get("privy_oauth_provider");if(!t||!n||!r)return{inProgress:!1};let a=!1;try{a=!!window.opener.location.origin}catch{}return{inProgress:!0,authorizationCode:t,stateCode:n,provider:r,withPrivyUi:!ur.get(Ft),popupFlow:null!==window.opener&&a,disableSignup:!!ur.get(Lt)}}class Ta{execute(e){return null===this.promise&&(this.promise=(async()=>{try{return await this.fn(e)}finally{this.promise=null}})()),this.promise}constructor(e){this.promise=null,this.fn=e}}const _a=({address:e,chainId:t,nonce:n})=>`${window.location.host} wants you to sign in with your Ethereum account:\n${e}\n\nBy signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.\n\nURI: ${window.location.origin}\nVersion: 1\nChain ID: ${t}\nNonce: ${n}\nIssued At: ${(new Date).toISOString()}\nResources:\n- https://privy.io`;class Ea{get meta(){return{connectorType:this.wallet?.connectorType,walletClientType:this.wallet?.walletClientType,chainId:this.wallet?.chainId,address:this.wallet?.address,disableSignup:this._meta.disableSignup}}async authenticate(){if(!this.client)throw new H("SiweFlow has no client instance");try{if(this.preparedMessage&&this.signature)return await this.client.authenticateWithSiweInternal({message:this.preparedMessage,signature:this.signature,chainId:this.wallet?.chainId,walletClientType:this.walletClientType??this.wallet?.walletClientType,connectorType:this.connectorType??this.wallet?.connectorType,mode:this._meta.disableSignup?"no-signup":"login-or-sign-up"});if(!this.wallet)throw new H("SiweFlow has no wallet instance");let{message:e,signature:t}=await this.sign();return await this.client.authenticateWithSiweInternal({message:e,signature:t,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw $(e)}}async link(){if(!this.client)throw new H("SiweFlow has no client instance");try{if(!this.wallet)throw new H("SiweFlow has no wallet instance");let{message:e,signature:t}=await this.sign();return await this.client.linkWithSiweInternal({message:e,signature:t,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(e){throw $(e)}}async sign(){if(!this.client)throw new H("SiweFlow has no client instance");if(await this.buildMessage(),!this.preparedMessage)throw new H("Could not prepare SIWE message");if(!this.wallet)throw new H("SiweFlow has no wallet instance");let e=await this.wallet.sign(this.preparedMessage);return{message:this.preparedMessage,signature:e}}async _getNonceOnce(){if(!this.client)throw new H("SiweFlow has no client instance");if(!this.wallet)throw new H("UI SiweFlow has no wallet instance");return await this.client.generateSiweNonce({address:this.wallet.address,captchaToken:this.captchaToken})}async buildMessage(){if(!this.client)throw new H("SiweFlow has no client instance");if(!this.wallet)throw new H("SiweFlow has no wallet instance");let e=this.wallet.address,t=this.wallet.chainId.replace("eip155:","");return this.nonce||(this.nonce=await this.getNonceOnce.execute()),this.preparedMessage=_a({address:e,chainId:t,nonce:this.nonce}),this.preparedMessage}constructor(e,t,n,r=!1,a){this._meta={disableSignup:!1},this.getNonceOnce=new Ta(this._getNonceOnce.bind(this)),this.wallet=t,this.captchaToken=n,this.client=e,this._meta.disableSignup=r,this.preparedMessage=a?.message,this.signature=a?.signature,this.walletClientType=a?.walletClientType,this.connectorType=a?.connectorType}}class Sa{async authenticate(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new H("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(we,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw $(e)}}async link(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new H("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(me,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(e){throw $(e)}}async sendSmsCode({phoneNumber:e,captchaToken:t,withPrivyUi:n}){if(!this.api)throw new H("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),t&&(this.meta.captchaToken=t),!this.meta.phoneNumber)throw new H("phone nNumber must be set when initialzing authentication.");let r=da(n);try{return await this.api.post(ye,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken},{headers:{...r}})}catch(e){throw $(e)}}constructor({phoneNumber:e,captchaToken:t,disableSignup:n}){this.meta={phoneNumber:e,captchaToken:t,disableSignup:n??!1}}}class Ia extends Sa{async link(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode||!this.meta.oldPhoneNumber)throw new H("Phone number, sms code, and an old phone number must be set prior to calling update.");try{return await this.api.post(ge,{old_phone_number:this.meta.oldPhoneNumber,new_phone_number:this.meta.phoneNumber,code:this.meta.smsCode})}catch(e){throw $(e)}}constructor(e,t,n){super({phoneNumber:t,captchaToken:n}),this.meta={phoneNumber:t,captchaToken:n,oldPhoneNumber:e,disableSignup:!1}}}function Pa(){return!(y&&window.location.origin.startsWith("http://localhost"))}var Wa,xa=((Wa={}).PRIVY="privy_access_token",Wa.CUSTOMER="customer_access_token",Wa);class Ua{get token(){return this.privyAccessToken||this.customerAccessToken}getToken(e){return"privy_access_token"===e?this.privyAccessToken:this.customerAccessToken}get customerAccessToken(){return this._getToken(zt)}get privyAccessToken(){return this._getToken(qt)}_getToken(e){try{let t=ur.get(e);return"string"==typeof t?Tn.throwIfNotWellFormedJwt(t):null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=ur.get(Bt);return"string"==typeof e?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}getProviderAccessToken(e){try{let t=ur.get(Ht(e));if("string"!=typeof t)return null;{let n=new Tn(t);return n.isExpired()?(ur.del(Ht(e)),null):n.value}}catch(e){return console.error(e),null}}get mightHaveServerCookies(){try{let e=ln.get($t);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),n="string"==typeof this.refreshToken&&this.refreshToken!==Vt;return this.mightHaveServerCookies||t&&n}hasActiveAccessToken(e){let t=Tn.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?ur.put(Ht(e),t):ur.del(Ht(e))}updateIdentityToken(e){"string"==typeof e?this.storeIdentityToken(e):this.clearIdentityToken()}async _authenticate(e){try{let t=await e.authenticate(),{user:n,is_new_user:r,oauth_tokens:a}=t;this.handleTokenResponse(t);let i=a?{provider:a.provider,accessToken:a.access_token,accessTokenExpiresInSeconds:a.access_token_expires_in_seconds,refreshToken:a.refresh_token,refreshTokenExpiresInSeconds:a.refresh_token_expires_in_seconds,scopes:a.scopes}:void 0;return this._trackAuthenticateEvents(e,r),{user:wt(n),isNewUser:r,oAuthTokens:i}}catch(e){throw console.warn("Error authenticating session"),G(e)}}_trackAuthenticateEvents(e,t){let n=function(e){return e instanceof ua?"email":e instanceof Sa?"sms":e instanceof Ea?"siwe":e instanceof wa?"guest":e instanceof ca?"custom_auth":e instanceof Ca?e.meta.provider:null}(e);n&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate",payload:{method:n,isNewUser:t}}),"siwe"===n&&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(),n=t.oauth_tokens,r=n?{provider:n.provider,accessToken:n.access_token,accessTokenExpiresInSeconds:n.access_token_expires_in_seconds,refreshToken:n.refresh_token,refreshTokenExpiresInSeconds:n.refresh_token_expires_in_seconds,scopes:n.scopes}:void 0;return{user:wt(t),oAuthTokens:r}}catch(e){throw console.warn("Error linking account"),G(e)}}async _refresh(){if(!this.api)throw new H("Session has no API instance");if(!this.client)throw new H("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 n;if(!(e&&t||this.mightHaveServerCookies))return null;{let r={};e&&(r.authorization=`Bearer ${e}`),n=await this.api.post(te,t?{refresh_token:t}:{},{headers:r})}return this.handleTokenResponse(n),wt(n.user)}catch(e){if(e instanceof Y&&e.privyErrorCode===K.MISSING_OR_INVALID_TOKEN)return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw G(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(ne,{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=ur.get(zt);if(ur.put(zt,e),!this.client?.useServerCookies){let t=Tn.parse(e)?.expiration;ln.set(Kt,e,{sameSite:"Strict",secure:Pa(),expires:t?new Date(1e3*t):void 0})}t!==e&&this.client?.onStoreCustomerAccessToken?.(e)}else ur.del(zt),ln.remove(Kt),this.client?.onDeleteCustomerAccessToken?.()}storeRefreshToken(e){"string"==typeof e?(ur.put(Bt,e),this.client?.useServerCookies||ln.set($t,"t",{sameSite:"Strict",secure:Pa(),expires:30})):(ur.del(Bt),ln.remove(Gt),ln.remove($t))}storePrivyAccessToken(e){"string"==typeof e?ur.put(qt,e):ur.del(qt)}storeIdentityToken(e){if(aa.setState({identityToken:e}),this.client?.useServerCookies)return;ur.put(Yt,e);let t=Tn.parse(e)?.expiration;ln.set(Jt,e,{sameSite:"Strict",secure:Pa(),expires:t?new Date(1e3*t):void 0})}clearIdentityToken(){ur.del(Yt),aa.setState({identityToken:null}),ln.remove(Jt)}constructor(){this.authenticateOnce=new Ta((async e=>this._authenticate(e))),this.linkOnce=new Ta((async e=>this._link(e))),this.refreshOnce=new Ta(this._refresh.bind(this)),this.destroyOnce=new Ta(this._destroy.bind(this))}}let Oa,Na;var Ma=0,Ra="__private_"+Ma+++"__getOrGenerateClientAnalyticsId";class Da{getAppId(){return this.appId}initializeConnectorManager({walletConnectCloudProjectId:e,rpcConfig:t,chains:n,defaultChain:r,store:a,walletList:i,shouldEnforceDefaultChainOnConnect:s,externalWalletConfig:o,appName:l,walletChainType:c,setBaseAccountSdk:d}){this.connectors||(this.connectors=new ra(this.appId,e,t,n,r,a,i,s,o,l,d,c))}generateApi(){let e=new oa({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 H("No auth flow in progress.");return this.session.authenticate(this.authFlow)}async link(){if(!this.authFlow)throw new H("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(fe,{action:"verify"})}catch(e){throw $(e)}}async initMfaPasskeyVerification(){try{let e=await this.api.post(ve,{});return la(e.options)}catch(e){throw $(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(Ae,{});return wt(e)}catch(e){throw G(e)}}async unlinkEmail(e){try{let t=await this.api.post(be,{address:e});return await this.getAuthenticatedUser()??wt(t)}catch(e){throw G(e)}}async unlinkPhone(e){try{let t=await this.api.post(Ce,{phoneNumber:e});return await this.getAuthenticatedUser()??wt(t)}catch(e){throw G(e)}}async unlinkEthereumWallet(e){try{let t=await this.api.post(ke,{address:e});return await this.getAuthenticatedUser()??wt(t)}catch(e){throw G(e)}}async unlinkSolanaWallet(e){try{let t=await this.api.post(Te,{address:e});return await this.getAuthenticatedUser()??wt(t)}catch(e){throw G(e)}}async unlinkOAuth(e,t){try{let n=await this.api.post(_e,{provider:e,subject:t});return await this.getAuthenticatedUser()??wt(n)}catch(e){throw G(e)}}async unlinkFarcaster(e){try{let t=await this.api.post(Ee,{fid:e});return await this.getAuthenticatedUser()??wt(t)}catch(e){throw G(e)}}async unlinkTelegram(e){try{let t=await this.api.post(Se,{telegram_user_id:e});return await this.getAuthenticatedUser()??wt(t)}catch(e){throw G(e)}}async revokeDelegatedWallet(){try{await this.api.post(Ie,{})}catch(e){throw G(e)}}async createAnalyticsEvent({eventName:e,payload:t,timestamp:n,options:r}){if("undefined"!=typeof window)try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(re,{event_name:e,client_id:this.clientAnalyticsId,payload:{...t||{},clientTimestamp:n?n.toISOString():(new Date).toISOString()}},{retry:-1,keepalive:r?.keepAlive??!1})}catch(e){console.log("Unable to submit event. This is not an issue.")}}async signMoonpayOnRampUrl(e){try{return this.api.post(Pe,e)}catch(e){throw G(e)}}async initCoinbaseOnRamp(e){try{return this.api.post(We,e)}catch(e){throw G(e)}}async getCoinbaseOnRampStatus({partnerUserId:e}){try{return this.api.get(`${xe}?partnerUserId=${e}`)}catch(e){throw G(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(xa.CUSTOMER,e)}async getPrivyAccessToken(e){return await this._getToken(xa.PRIVY,e)}async _getToken(e,t){return this.session.getToken(e)?this.session.hasActiveAccessToken(e)?this.session.hasRefreshCredentials(e)?_n.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 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(n){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(Ue,{address:e,token:t})).nonce}catch(e){throw G(e)}}async authenticateWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a,mode:i}){return await this.api.post(Oe,{message:e,signature:t,chainId:n,walletClientType:r,connectorType:a,mode:i})}async linkWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a}){return await this.api.post(Ne,{message:e,signature:t,chainId:n,walletClientType:r,connectorType:a})}async linkSmartWallet({message:e,signature:t,smartWalletType:n,smartWalletVersion:r}){try{let a=await this.api.post(Me,{message:e,signature:t,smart_wallet_type:n,smart_wallet_version:r});return wt(a)}catch(e){throw G(e)}}async linkWithSiwe({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a}){try{let i=await this.linkWithSiweInternal({message:e,signature:t,chainId:n,walletClientType:r,connectorType:a});return wt(i)}catch(e){throw G(e)}}async generateSiwsNonce({address:e,captchaToken:t}){try{return(await this.api.post(Re,{address:e,token:t})).nonce}catch(e){throw G(e)}}async authenticateWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i="plain"}){return await this.api.post(De,{message:e,signature:t,walletClientType:n,connectorType:r,mode:a,message_type:i})}async authenticateWithSiws({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i="plain"}){let s=await this.authenticateWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,mode:a,messageType:i});this.session.handleTokenResponse(s);let o=wt(s.user);if(!o)throw Error("Authentication failed - no user returned");return{user:o,isNewUser:s.is_new_user||!1}}async sendAccountTransferRequest({nonce:e,account:t,accountType:n,externalWalletMetadata:r,telegramAuthResult:a,telegramWebAppData:i,farcasterEmbeddedAddress:s,oAuthUserInfo:o}){try{let l,c;switch(n){case"email":l=He,c={nonce:e,email:t};break;case"sms":l=Be,c={nonce:e,phoneNumber:t};break;case"siwe":if(l=qe,!r)throw Error("Wallet parameters must be defined");c={nonce:e,address:t,...r};break;case"farcaster":l=ze,c={nonce:e,farcaster_id:t,farcaster_embedded_address:s};break;case"telegram":l=je,c={nonce:e,telegram_auth_result:a,telegram_web_app_data:i};break;case"siws":l=Le,c={nonce:e,address:t,...r};break;case"custom":case"guest":case"passkey":throw Error("Invalid transfer account type");default:l=Fe,c={nonce:e,userInfo:o}}let d=await this.api.post(l,c);return await this.getAuthenticatedUser()??wt(d)}catch(e){throw G(e)}}async linkWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a="plain"}){return await this.api.post($e,{message:e,signature:t,walletClientType:n,connectorType:r,message_type:a})}async linkWithSiws({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a="plain"}){try{let i=await this.linkWithSiwsInternal({message:e,signature:t,walletClientType:n,connectorType:r,messageType:a});return wt(i)}catch(e){throw G(e)}}async updateUserAndIdToken(){try{let e=await this.api.get(Ve);return this.session.updateIdentityToken(e.identity_token),wt(e.user)}catch(e){throw G(e)}}async scanTransaction(e){try{return await this.api.post(Ke,e)}catch(e){throw G(e)}}constructor({apiUrl:e=Zt,appId:t,appClientId:n,timeout:r=Qt}){Object.defineProperty(this,Ra,{value:Fa}),this._cachedProviderAppDetails={},this.apiUrl=e,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=e!==Zt&&e.startsWith("https://privy."),this.timeout=r,this.appId=t,this.appClientId=n,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,Ra)[Ra](),Oa||(Oa=new Ua),this.session=Oa,this.api=this.generateApi(),this.session.client=this}}function Fa(){if("undefined"==typeof window)return null;try{let e=ur.get(Xt);if("string"==typeof e&&e.length>0)return e}catch(e){}let e=ut();try{return ur.put(Xt,e),e}catch(t){return e}}function La(){if(!Na)throw new H("No global PrivyClient instance found. Please ensure you have initialized the PrivyProvider.");return Na}async function ja(){return await(Na?.updateUserAndIdToken()),Na?.useServerCookies?aa.getState().identityToken:Promise.resolve(ur.get(Yt)||null)}function za(e){Na||(Na=new Da({appId:e.appId,appClientId:e.clientId,apiUrl:e.apiUrl}))}let qa=/*#__PURE__*/o({plugins:{current:{}}});const Ba=({children:e})=>{let n=l({});/*#__PURE__*/return t(qa.Provider,{value:{plugins:n},children:e})},Ha=(...e)=>{let{plugins:t}=s(qa);i((()=>{for(let n of e)t.current[n.id]=n;return()=>{for(let n of e)delete t.current[n.id]}}),[t])},$a=()=>{let{plugins:e}=s(qa);return c((t=>e.current[t]),[e])};class Va{get meta(){return this._meta}async authenticate(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.channelToken)throw new H("Auth flow must be initialized first");try{let e=await this.api.post(Ge,{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 H("No response from authentication");return e}catch(e){throw $(e)}}async link(){if(!this.api)throw new H("Auth flow has no API instance");try{return await this.api.post(Ye,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid})}catch(e){throw $(e)}}async _startChannelOnce(){if(!this.api)throw new H("Auth flow has no API instance");let e=await this.api.post(Je,{token:this.captchaToken});m&&!g&&e.connect_uri&&Zr(e.connect_uri,"_blank"),this._meta={...this._meta,connectUri:e.connect_uri,channelToken:e.channel_token}}async initializeFarcasterConnect(){if(!this.api)throw new H("Auth flow has no API instance");await this.startChannelOnce.execute()}async _pollForReady(){if(!this.api)throw new H("Auth flow has no API instance");if(!this.meta.channelToken)throw new H("Auth flow must be initialized first");let e=await this.api.get(Ze,{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 Ta(this._startChannelOnce.bind(this)),this.pollForReady=new Ta(this._pollForReady.bind(this)),this._meta.disableSignup=t}}class Ka{async initRegisterFlow(e){if(!this.api)throw new H("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 H("Auth flow has no API instance");this.authenticateForRegistration=!1,this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute(e)}async initLinkFlow(){if(!this.api)throw new H("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 H("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new H("WebAuthn is not supported in this browser");this.meta.initRegisterResponse||(this.meta.initRegisterResponse=await this.initRegisterOnce.execute());try{let t=this.meta.initRegisterResponse.options,n=await e.startRegistration({optionsJSON:this._transformInitLinkOptionsToCamelCase(t)});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(Qe,{relying_party:this.meta.initRegisterResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new H("Passkey request timed out or rejected by user.",void 0,K.PASSKEY_NOT_ALLOWED);throw $(e)}}async authenticate(){if(this.authenticateForRegistration)return this.register();let e=await import("@simplewebauthn/browser");if(!this.api)throw new H("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new H("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 n=await e.startAuthentication({optionsJSON:this._transformInitAuthenticateOptionsToCamelCase({...this.meta.initAuthenticateResponse.options,allow_credentials:t})});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(Xe,{relying_party:this.meta.initAuthenticateResponse.relying_party,challenge:this.meta.initAuthenticateResponse.options.challenge,authenticator_response:this._transformAuthenticationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new H("Passkey request timed out or rejected by user.",void 0,K.PASSKEY_NOT_ALLOWED);throw $(e)}}async link(){let e=await import("@simplewebauthn/browser");if(!this.api)throw new H("Auth flow has no API instance");if(!e.browserSupportsWebAuthn())throw new H("WebAuthn is not supported in this browser");this.meta.initLinkResponse||(this.meta.initLinkResponse=await this.initLinkOnce.execute());try{let t=this.meta.initLinkResponse.options,n=await e.startRegistration({optionsJSON:this._transformInitLinkOptionsToCamelCase(t)});return this.meta.setPasskeyAuthState?.({status:"submitting-response"}),await this.api.post(et,{relying_party:this.meta.initLinkResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(n)})}catch(e){if("NotAllowedError"===e.name)throw new H("Passkey request timed out or rejected by user.",void 0,K.PASSKEY_NOT_ALLOWED);throw $(e)}}async _initRegisterOnce(e){if(!this.api)throw new H("Auth flow has no API instance");let t=da(e);return await this.api.post(tt,{token:this.meta.captchaToken},{headers:{...t}})}async _initAuthenticateOnce(e){if(!this.api)throw new H("Auth flow has no API instance");let t=da(e);return await this.api.post(nt,{token:this.meta.captchaToken},{headers:{...t}})}async _initLinkOnce(){if(!this.api)throw new H("Auth flow has no API instance");return await this.api.post(rt,{})}_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:n}){this.authenticateForRegistration=!1,this.initRegisterOnce=new Ta(this._initRegisterOnce.bind(this)),this.initAuthenticateOnce=new Ta(this._initAuthenticateOnce.bind(this)),this.initLinkOnce=new Ta(this._initLinkOnce.bind(this)),this.meta={captchaToken:e,setPasskeyAuthState:t,hints:n}}}const Ga=({address:e,nonce:t})=>`${window.location.host} wants you to sign in with your Solana account:\n${e}\n\n${`You are proving you own ${e}.`}\n\nURI: ${window.location.origin}\nVersion: 1\nChain ID: mainnet\nNonce: ${t}\nIssued At: ${(new Date).toISOString()}\nResources:\n- https://privy.io`;class Ya{get meta(){return{connectorType:this.wallet.connectorType,walletClientType:this.wallet.walletClientType,disableSignup:this._meta.disableSignup,messageType:this._meta.messageType,address:this.wallet?.address}}set messageType(e){this._meta.messageType=e}async authenticate(){if(!this.client)throw new H("SiwsFlow has no client instance");try{let{message:e,signature:t}=await this.sign();return await this.client.authenticateWithSiwsInternal({message:e,signature:t,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up",messageType:this.meta.messageType})}catch(e){throw $(e)}}async link(){if(!this.client)throw new H("SiwsFlow has no client instance");try{let{message:e,signature:t}=await this.sign();return await this.client.linkWithSiwsInternal({message:e,signature:t,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType,messageType:this.meta.messageType})}catch(e){throw $(e)}}async sign(){let e,t;if(!this.client)throw new H("SiwsFlow has no client instance");await this.buildMessage();let n="transaction"===this.meta.messageType;if(!this.preparedMessage)throw new H("Could not prepare SIWS message");if(!n&&!this.wallet.provider.signMessage||n&&!this.wallet.provider.signTransaction)throw new H("Wallet does not support the necessary signing methods");if(n&&this._plugin){let n=await this.wallet.provider.signTransaction({transaction:st.decode(this.preparedMessage)});e=st.encode(n.signedTransaction),t=this._plugin.getSignatureFromTransaction(n.signedTransaction,this.wallet.address)}else{e=this.preparedMessage;let n=await this.wallet.provider.signMessage({message:(new TextEncoder).encode(this.preparedMessage)});t=st.encode(n.signature)}return{message:e,signature:t}}async _getNonceOnce(){if(!this.client)throw new H("SiwsFlow has no client instance");return await this.client.generateSiwsNonce({address:this.wallet.address,captchaToken:this.captchaToken})}async buildMessage(){if(!this.client)throw new H("SiwsFlow has no client instance");let e=this.wallet.address;return this.nonce||(this.nonce=await this.getNonceOnce.execute()),"transaction"===this.meta.messageType&&this._plugin?this.preparedMessage=this._plugin.createSiwsMemoTransaction({address:e,nonce:this.nonce}):this.preparedMessage=Ga({address:e,nonce:this.nonce}),this.preparedMessage}constructor(e,t,n,r=!1,a="plain",i){this._meta={disableSignup:!1,messageType:"plain"},this.getNonceOnce=new Ta(this._getNonceOnce.bind(this)),this.wallet=e,this.captchaToken=n,this.client=t,this._meta.disableSignup=r,this._meta.messageType=a,this._plugin=i}}const Ja=/*#__PURE__*/o({enabled:!1,siteKey:"",provider:void 0,appId:void 0,token:void 0,error:void 0,status:"disabled",setToken:J,setError:J,setExecuting:J,waitForResult:()=>Promise.resolve(""),ref:{current:null},remove:Z,reset:J,execute:J});class Za extends q{constructor(e,t,n){super(e||"Captcha failed"),this.type="Captcha",t instanceof Error&&(this.cause=t),this.privyErrorCode=n}}const Qa=({children:e,appId:n,captchaSiteKey:r,enabledCaptchaProvider:a})=>{let i=l(null),s=l(null),[o,c]=d(),[h,p]=d(),[w,m]=d(!1),y=u((()=>a?w||o||h?!w||o||h?o&&!h?{status:"success",token:o}:h?{status:"error",error:h}:{status:"ready"}:{status:"loading"}:{status:"ready"}:{status:"disabled"}),[a,o,h,w]),g=u((()=>a?"turnstile"===a?{remove:()=>{i.current?.remove(),m(!1),p(void 0),c(void 0)},reset:()=>{i.current?.reset(),m(!1),p(void 0),c(void 0)},execute:()=>{m(!0),i.current?.execute()},waitForResult:async()=>{try{return await Hn((()=>i.current?.getResponse()),{interval:200,timeout:2e4})}catch(e){throw new Za("Captcha failed",null,K.CAPTCHA_TIMEOUT)}}}:{remove:()=>{s.current?.removeCaptcha(),m(!1),p(void 0),c(void 0)},reset:()=>{s.current?.resetCaptcha(),m(!1),p(void 0),c(void 0)},execute:()=>{m(!0),s.current?.execute()},waitForResult:async()=>{try{return await Hn((()=>{let e=s.current?.getResponse();if(e)return e}),{interval:200,timeout:2e4})}catch(e){throw new Za("Captcha failed",null,K.CAPTCHA_TIMEOUT)}}}:null),[a]),f=u((()=>{if(!a||!g)return{...y,enabled:!1,siteKey:"",appId:n,setToken:J,setError:J,setExecuting:J,waitForResult:()=>Promise.resolve(void 0),remove:Z,reset:J,execute:J,provider:void 0,ref:{current:null}};let e={...y,enabled:!0,appId:n,setToken:c,setError:p,setExecuting:m};return"turnstile"===a?{...e,provider:"turnstile",ref:i,siteKey:r.split("t:")[1]??"",...g}:{...e,provider:"hcaptcha",ref:s,siteKey:r.split("h:")[1]??"",...g}}),[y,a,g,n,r]);/*#__PURE__*/return t(Ja.Provider,{value:f,children:e})},Xa=()=>s(Ja);async function ei(e){if(e.enabled){if("error"===e.status)throw new Za(e.error,null,K.CAPTCHA_FAILURE);return"success"===e.status?e.token:(e.execute(),await e.waitForResult())}}class ti{async authenticate(){if(!this.api)throw new H("Auth flow has no API instance");try{return await this.api.post(at,{captcha_token:this.meta.captchaToken,telegram_auth_result:this.meta.telegramAuthResult,telegram_web_app_data:this.meta.telegramWebAppData,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw $(e)}}async link(){if(!this.api)throw new H("Auth flow has no API instance");try{return await this.api.post(it,{telegram_auth_result:this.meta.telegramAuthResult,telegram_web_app_data:this.meta.telegramWebAppData})}catch(e){throw $(e)}}constructor(e,t=!1){this.meta={disableSignup:!1},this.meta={captchaToken:e,disableSignup:!1},this.meta.disableSignup=t}}function ni(e){let t={detail:"",retryable:!1};return e?.privyErrorCode===K.LINKED_TO_ANOTHER_USER&&(t.detail="This account has already been linked to another user."),e?.privyErrorCode===K.DISALLOWED_LOGIN_METHOD&&(t.detail="Login with Telegram not allowed."),e?.privyErrorCode===K.INVALID_DATA&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===K.CANNOT_LINK_MORE_OF_TYPE&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===K.INVALID_CREDENTIALS&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode===K.TOO_MANY_REQUESTS&&(t.detail="Too many requests. Please wait before trying again."),e?.privyErrorCode===K.TOO_MANY_REQUESTS&&e.message.includes("rate limit")&&(t.detail="Request limit reached for Telegram. Please wait a moment and try again."),e instanceof Za&&(t.retryable=!0,t.detail="Something went wrong. Try again."),t}function ri(e){return Object.fromEntries(decodeURIComponent(e).split("&").map((e=>e.split("=").map(decodeURIComponent))))}function ai(){let e=new URL(window.location.href);e.searchParams.delete("id"),e.searchParams.delete("hash"),e.searchParams.delete("auth_date"),e.searchParams.delete("first_name"),e.searchParams.delete("last_name"),e.searchParams.delete("username"),e.searchParams.delete("photo_url"),e.hash="",window.history.replaceState({},"",e)}async function ii(){let e=La();return e?e.getAccessToken():Promise.resolve(ur.get(qt)||ur.get(zt)||null)}let si=/*#__PURE__*/p((()=>import("./TurnstileWrapper-Co-t5mTh.mjs"))),oi=/*#__PURE__*/p((()=>import("./HCaptchaWrapper-CUi9LJsp.mjs")));const li=n=>{let r=Xa();return i((()=>r.remove),[r.remove]),r.enabled&&r.provider?/*#__PURE__*/t(h,{fallback:null,children:/*#__PURE__*/e("div",{className:"hidden h-0 w-0",children:["turnstile"===r.provider&&/*#__PURE__*/t(si,{...n,captchaContext:r}),"hcaptcha"===r.provider&&/*#__PURE__*/t(oi,{...n,captchaContext:r})]})}):null};var ci=/*#__PURE__*/Object.freeze({__proto__:null,AccountNotFoundScreen:()=>import("./AccountNotFoundScreen-Cn6aKFIC.mjs"),AffirmativeConsentScreen:()=>import("./AffirmativeConsentScreen-DwMHTAWp.mjs"),AllowlistRejectionScreen:()=>import("./AllowlistRejectionScreen-CtVeBy5G.mjs"),AuthenticateWithWalletScreen:()=>import("./AuthenticateWithWalletScreen-CqqsqfqZ.mjs"),AwaitingEvmToSolBridgingScreen:()=>import("./AwaitingEvmToSolBridgingScreen-CLkDS6o-.mjs"),AwaitingExternalEthereumTransferScreen:()=>import("./AwaitingExternalEthereumTransferScreen-Is2FdGJS.mjs"),AwaitingPasswordlessCodeScreen:()=>import("./AwaitingPasswordlessCodeScreen-CAwXjOBS.mjs"),AwaitingSolToEvmBridgingScreen:()=>import("./AwaitingSolToEvmBridgingScreen-BDhpWAv1.mjs"),CaptchaScreen:()=>import("./CaptchaScreen-CZCosLCJ.mjs"),CoinbaseOnrampStatusScreen:()=>import("./CoinbaseOnrampStatusScreen-DxbYHDRy.mjs"),ConnectLedgerScreen:()=>import("./ConnectLedgerScreen-CmspFZG8.mjs"),ConnectOnlyLandingScreen:()=>import("./ConnectOnlyLandingScreen-JXhxU6Je.mjs"),ConnectOnlyStatusScreen:()=>import("./ConnectOnlyStatusScreen-CZO6dxUB.mjs"),ConnectOrCreateScreen:()=>import("./ConnectOrCreateScreen-DHwSpwLa.mjs"),ConnectionStatusScreen:()=>import("./ConnectionStatusScreen-d8tOwFAz.mjs"),CrossAppAuthScreen:()=>import("./CrossAppAuthScreen-CNvQYKBN.mjs"),DelegatedActionsConsentScreen:()=>import("./DelegatedActionsConsentScreen-D2cB2Jqt.mjs"),DelegatedActionsRevokeScreen:()=>import("./DelegatedActionsRevokeScreen-DIdnDrIo.mjs"),EmbeddedWalletConnectingScreen:()=>import("./EmbeddedWalletConnectingScreen-DNDkMjZg.mjs"),EmbeddedWalletCreatedScreen:()=>import("./EmbeddedWalletCreatedScreen-6rmCkBPR.mjs"),EmbeddedWalletKeyExportScreen:()=>import("./EmbeddedWalletKeyExportScreen-CrrImf0B.mjs"),EmbeddedWalletOnAccountCreateScreen:()=>import("./EmbeddedWalletOnAccountCreateScreen-MTCypdEY.mjs"),EmbeddedWalletPasswordCreateScreen:()=>import("./RecoveryPasswordCreateScreen-BHOh-fE-.mjs"),EmbeddedWalletPasswordUpdateScreen:()=>import("./EmbeddedWalletPasswordUpdateScreen-o-ONaPrc.mjs"),EmbeddedWalletPasswordUpdateSplashScreen:()=>import("./EmbeddedWalletPasswordUpdateSplashScreen-BpRZwJZg.mjs"),ErrorScreen:()=>import("./ErrorScreen-C891Rurl.mjs"),FarcasterConnectStatusScreen:()=>import("./FarcasterConnectStatusScreen-CHItJej_.mjs"),FarcasterSignerStatusScreen:()=>import("./FarcasterSignerStatusScreen-P3NEju7D.mjs"),FundSolWalletWithExternalSolanaWallet:()=>import("./FundSolWalletWithExternalSolanaWallet-CGZdr_3E.mjs"),FundingAmountEditScreen:()=>import("./FundingEditAmountScreen-B0MYigL_.mjs"),FundingMethodSelectionScreen:()=>import("./FundingMethodSelectionScreen-CNJYvozR.mjs"),InAppBrowserLoginNotPossible:()=>import("./InAppBrowserLoginNotPossible-CVyW-cIh.mjs"),InstallWalletScreen:()=>import("./InstallWalletScreen-Bfo00Txs.mjs"),LandingScreen:()=>import("./LandingScreen-tAGl1tss.mjs"),LinkConflictScreen:()=>import("./LinkConflictScreen-DmFrdpwb.mjs"),LinkEmailScreen:()=>import("./LinkEmailScreen-C_G_4bbm.mjs"),LinkPasskeyScreen:()=>import("./LinkPasskeyScreen-DhD51WvM.mjs"),LinkPhoneScreen:()=>import("./LinkPhoneScreen-Bi5gcAMm.mjs"),LoginFailedScreen:()=>import("./LoginFailedScreen-DbAdNYji.mjs"),ManualTransferScreen:()=>import("./ManualTransferScreen-CR2QvdVh.mjs"),MfaAuthEnrollmentFlowScreen:()=>import("./MfaAuthEnrollmentFlowScreen-BEotfobF.mjs"),MfaAuthVerifyFlowScreen:()=>import("./MfaAuthVerifyFlowScreen-Cygjr5sH.mjs"),MfaEnrollmentFlowScreen:()=>import("./MfaEnrollmentFlowScreen-jupYBcsQ.mjs"),MoonpayStatusScreen:()=>import("./MoonpayStatusScreen-BjmXS-jc.mjs"),OAuthStatusScreen:()=>import("./OAuthStatusScreen-YcgvWTtC.mjs"),PasskeySelectSignupOrLogin:()=>import("./PasskeySelectSignupOrLogin-Db4EFSYE.mjs"),PasskeyStatusScreen:()=>import("./PasskeyStatusScreen-CR-3RNXX.mjs"),PasswordRecoveryScreen:()=>import("./PasswordRecoveryScreen-BnD1OdcX.mjs"),RecoveryOAuthScreen:()=>import("./RecoveryOAuthStatusScreen-DhLx5fOQ.mjs"),RecoverySelectionScreen:()=>import("./RecoverySelectionScreen-1seYQLsM.mjs"),SendTransactionScreen:()=>import("./index-0TRQs0PD.mjs"),SetAutomaticRecoveryScreen:()=>import("./SetAutomaticRecoveryScreen-CZLgLNlt.mjs"),SignRequestScreen:()=>import("./SignRequestScreen-EwmYkZZk.mjs"),StandardSignAndSendTransactionScreen:()=>import("./StandardSignAndSendTransactionScreen-BGAjDFes.mjs"),TelegramAuthScreen:()=>import("./TelegramAuthScreen-BMWr2M6a.mjs"),TransferFromWalletScreen:()=>import("./TransferFromWalletScreen-BTsyTZMc.mjs"),UpdateEmailScreen:()=>import("./UpdateEmailScreen-DyXsKvGA.mjs"),UpdatePhoneScreen:()=>import("./UpdatePhoneScreen-erzZ8qOI.mjs"),UserLimitReachedScreen:()=>import("./UserLimitReachedScreen-CfiHSh4t.mjs"),WalletInterstitialScreen:()=>import("./WalletInterstitialScreen-DCg6fl5S.mjs")});const di=e=>{let[t,n]=d("auto");return i((()=>{let t=new ResizeObserver((e=>{n(e[0]?.contentRect.height??"auto")}));return e.current&&t.observe(e.current),()=>{e.current&&t.unobserve(e.current)}}),[e.current]),t};function ui(e){hn("configureMfa",e)}const hi=cn.div`
|
|
2
|
-
text-align: left;
|
|
3
|
-
flex-grow: 1;
|
|
4
|
-
`,pi=cn.div`
|
|
5
|
-
display: flex;
|
|
6
|
-
flex-direction: column;
|
|
7
|
-
justify-content: flex-end;
|
|
8
|
-
flex-grow: 1;
|
|
9
|
-
`,wi=cn.div`
|
|
10
|
-
display: flex;
|
|
11
|
-
flex-direction: column;
|
|
12
|
-
gap: 8px;
|
|
13
|
-
|
|
14
|
-
/* for Internet Explorer, Edge */
|
|
15
|
-
-ms-overflow-style: none;
|
|
16
|
-
|
|
17
|
-
/* for Firefox */
|
|
18
|
-
scrollbar-width: none;
|
|
19
|
-
|
|
20
|
-
/* for Chrome, Safari, and Opera */
|
|
21
|
-
&::-webkit-scrollbar {
|
|
22
|
-
display: none;
|
|
23
|
-
}
|
|
24
|
-
`,mi=cn(wi)`
|
|
25
|
-
${e=>"light"===e.$colorScheme?"background: linear-gradient(var(--privy-color-background), var(--privy-color-background) 70%) bottom, linear-gradient(rgba(0, 0, 0, 0) 20%, rgba(0, 0, 0, 0.06)) bottom;":"dark"===e.$colorScheme?"background: linear-gradient(var(--privy-color-background), var(--privy-color-background) 70%) bottom, linear-gradient(rgba(255, 255, 255, 0) 20%, rgba(255, 255, 255, 0.06)) bottom;":void 0}
|
|
26
|
-
|
|
27
|
-
background-repeat: no-repeat;
|
|
28
|
-
background-size:
|
|
29
|
-
100% 32px,
|
|
30
|
-
100% 16px;
|
|
31
|
-
background-attachment: local, scroll;
|
|
32
|
-
max-height: 400px;
|
|
33
|
-
overflow-y: auto;
|
|
34
|
-
scrollbar-width: none;
|
|
35
|
-
padding: 3px;
|
|
36
|
-
`;let yi=dn`
|
|
37
|
-
&& {
|
|
38
|
-
width: 100%;
|
|
39
|
-
font-size: 16px;
|
|
40
|
-
line-height: 24px;
|
|
41
|
-
min-height: 56px;
|
|
42
|
-
|
|
43
|
-
/* Tablet and Up */
|
|
44
|
-
@media (min-width: 440px) {
|
|
45
|
-
font-size: 14px;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
display: flex;
|
|
49
|
-
gap: 12px;
|
|
50
|
-
align-items: center;
|
|
51
|
-
color: var(--privy-color-foreground);
|
|
52
|
-
|
|
53
|
-
padding: 10px 12px;
|
|
54
|
-
border: 1px solid var(--privy-color-foreground-4) !important;
|
|
55
|
-
border-radius: var(--privy-border-radius-md);
|
|
56
|
-
transition: background-color 200ms ease;
|
|
57
|
-
|
|
58
|
-
cursor: pointer;
|
|
59
|
-
|
|
60
|
-
&:hover {
|
|
61
|
-
background-color: var(--privy-color-background-2);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
&:disabled {
|
|
65
|
-
cursor: pointer;
|
|
66
|
-
background-color: var(--privy-color-background-2);
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
`;const gi=cn.div`
|
|
70
|
-
text-align: center;
|
|
71
|
-
font-size: 14px;
|
|
72
|
-
margin-bottom: 24px;
|
|
73
|
-
`,fi=cn.button.attrs({className:"login-method-button"})`
|
|
74
|
-
${yi}
|
|
75
|
-
`;cn.a`
|
|
76
|
-
${yi}
|
|
77
|
-
`;const vi=cn.div`
|
|
78
|
-
width: 32px;
|
|
79
|
-
height: 32px;
|
|
80
|
-
border-radius: ${e=>e.$fullSize?"0":"4px"};
|
|
81
|
-
background: ${e=>e.$fullSize?"transparent":"var(--privy-color-background-2)"};
|
|
82
|
-
display: flex;
|
|
83
|
-
align-items: center;
|
|
84
|
-
justify-content: center;
|
|
85
|
-
flex-shrink: 0;
|
|
86
|
-
|
|
87
|
-
svg {
|
|
88
|
-
width: ${e=>e.$fullSize?"32px":"18px"};
|
|
89
|
-
height: ${e=>e.$fullSize?"32px":"18px"};
|
|
90
|
-
color: ${e=>e.$fullSize?"inherit":"var(--privy-color-icon-muted)"};
|
|
91
|
-
}
|
|
92
|
-
`,Ai=cn.div`
|
|
93
|
-
width: 100%;
|
|
94
|
-
height: 100%;
|
|
95
|
-
min-height: inherit;
|
|
96
|
-
display: flex;
|
|
97
|
-
flex-direction: column;
|
|
98
|
-
${e=>e.$if?"display: none;":""}
|
|
99
|
-
`,bi=cn.div`
|
|
100
|
-
width: 100%;
|
|
101
|
-
height: 100%;
|
|
102
|
-
padding: ${e=>e.$withPadding?"64px 0px":"0px"};
|
|
103
|
-
`,Ci=cn.div`
|
|
104
|
-
display: flex;
|
|
105
|
-
flex-direction: column;
|
|
106
|
-
align-items: center;
|
|
107
|
-
justify-content: center;
|
|
108
|
-
margin-bottom: 32px;
|
|
109
|
-
gap: 12px;
|
|
110
|
-
& h3 {
|
|
111
|
-
font-size: 18px;
|
|
112
|
-
font-style: normal;
|
|
113
|
-
font-weight: 600;
|
|
114
|
-
line-height: 24px;
|
|
115
|
-
}
|
|
116
|
-
& p {
|
|
117
|
-
max-width: 300px;
|
|
118
|
-
font-size: 14px;
|
|
119
|
-
font-style: normal;
|
|
120
|
-
font-weight: 400;
|
|
121
|
-
line-height: 20px;
|
|
122
|
-
}
|
|
123
|
-
`,ki=Pt((()=>({inProgressMfaFlow:void 0})));const Ti=un`
|
|
124
|
-
:root {
|
|
125
|
-
${e=>_i(e.palette)}
|
|
126
|
-
};
|
|
127
|
-
`;const _i=e=>{let t=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);return dn`
|
|
128
|
-
${Object.entries(t).map((([e,t])=>`${e}: ${t};`)).join("\n")}
|
|
129
|
-
`},Ei=cn.div`
|
|
130
|
-
// css normalize only the privy application to avoid conflicts
|
|
131
|
-
// with consuming application
|
|
132
|
-
${"\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"}
|
|
133
|
-
|
|
134
|
-
// Privy styles
|
|
135
|
-
color: var(--privy-color-foreground-2);
|
|
136
|
-
|
|
137
|
-
h3 {
|
|
138
|
-
font-size: 16px;
|
|
139
|
-
line-height: 24px;
|
|
140
|
-
font-weight: 500;
|
|
141
|
-
color: var(--privy-color-foreground-2);
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
h4 {
|
|
145
|
-
font-size: 14px;
|
|
146
|
-
line-height: 20px;
|
|
147
|
-
font-weight: 500;
|
|
148
|
-
color: var(--privy-color-foreground);
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
p {
|
|
152
|
-
font-size: 13px;
|
|
153
|
-
line-height: 20px;
|
|
154
|
-
color: var(--privy-color-foreground-2);
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
button:focus,
|
|
158
|
-
input:focus,
|
|
159
|
-
optgroup:focus,
|
|
160
|
-
select:focus,
|
|
161
|
-
textarea:focus {
|
|
162
|
-
outline: none;
|
|
163
|
-
border-color: var(--privy-color-accent-light);
|
|
164
|
-
box-shadow: 0 0 0 3px var(--privy-color-border-focus);
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
.mobile-only {
|
|
168
|
-
@media (min-width: 441px) {
|
|
169
|
-
display: none;
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
/* Animations */
|
|
174
|
-
|
|
175
|
-
@keyframes fadein {
|
|
176
|
-
0% {
|
|
177
|
-
opacity: 0;
|
|
178
|
-
}
|
|
179
|
-
100% {
|
|
180
|
-
opacity: 1;
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
`,Si=({children:n,open:r,onClick:i,...s})=>/*#__PURE__*/t(gn,{show:r,as:a.Fragment,children:/*#__PURE__*/e(fn,{onClose:i,...s,as:Pi,children:[/*#__PURE__*/t(vn,{as:a.Fragment,enterFrom:"entering",leaveTo:"leaving",children:/*#__PURE__*/t(Ii,{id:"privy-dialog-backdrop","aria-hidden":"true"})}),/*#__PURE__*/t(Wi,{children:/*#__PURE__*/t(vn,{as:a.Fragment,enterFrom:"entering",leaveTo:"leaving",children:/*#__PURE__*/t(An,{as:xi,children:n})})})]})});let Ii=cn.div`
|
|
184
|
-
position: fixed;
|
|
185
|
-
inset: 0;
|
|
186
|
-
|
|
187
|
-
transition: backdrop-filter 100ms ease;
|
|
188
|
-
backdrop-filter: blur(3px);
|
|
189
|
-
-webkit-backdrop-filter: blur(3px);
|
|
190
|
-
|
|
191
|
-
&.entering,
|
|
192
|
-
&.leaving {
|
|
193
|
-
backdrop-filter: unset;
|
|
194
|
-
-webkit-backdrop-filter: unset;
|
|
195
|
-
}
|
|
196
|
-
`,Pi=cn.div`
|
|
197
|
-
position: relative;
|
|
198
|
-
z-index: 999999;
|
|
199
|
-
`,Wi=cn.div`
|
|
200
|
-
position: fixed;
|
|
201
|
-
inset: 0;
|
|
202
|
-
display: flex;
|
|
203
|
-
align-items: center;
|
|
204
|
-
justify-content: center;
|
|
205
|
-
width: 100vw;
|
|
206
|
-
min-height: 100vh;
|
|
207
|
-
`;const xi=cn.div`
|
|
208
|
-
// reset some default dialog styles
|
|
209
|
-
padding: 0;
|
|
210
|
-
background: transparent;
|
|
211
|
-
border: none;
|
|
212
|
-
width: 100%;
|
|
213
|
-
pointer-events: auto;
|
|
214
|
-
|
|
215
|
-
outline: none;
|
|
216
|
-
display: block;
|
|
217
|
-
|
|
218
|
-
/*
|
|
219
|
-
* Normally it is bad to mix media queries like this We are doing
|
|
220
|
-
* this here specifically for animations to avoid weird jank.
|
|
221
|
-
*/
|
|
222
|
-
/* Mobile animation is a bottom drawer */
|
|
223
|
-
@media (max-width: 440px) {
|
|
224
|
-
opacity: 1;
|
|
225
|
-
transform: translate3d(0, 0, 0);
|
|
226
|
-
transition: transform 200ms ease-in;
|
|
227
|
-
position: fixed;
|
|
228
|
-
bottom: 0;
|
|
229
|
-
|
|
230
|
-
&.entering,
|
|
231
|
-
&.leaving {
|
|
232
|
-
opacity: 0;
|
|
233
|
-
transform: translate3d(0, 100%, 0);
|
|
234
|
-
transition:
|
|
235
|
-
transform 150ms ease-in 0ms,
|
|
236
|
-
opacity 0ms ease 150ms;
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
/* Tablet/Desktop animation is a fade in */
|
|
241
|
-
@media (min-width: 441px) {
|
|
242
|
-
opacity: 1;
|
|
243
|
-
transition: opacity 100ms ease-in;
|
|
244
|
-
|
|
245
|
-
&.entering,
|
|
246
|
-
&.leaving {
|
|
247
|
-
opacity: 0;
|
|
248
|
-
transition-delay: 5ms;
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
margin: auto;
|
|
252
|
-
width: 360px;
|
|
253
|
-
box-shadow: 0px 8px 36px rgba(55, 65, 81, 0.15);
|
|
254
|
-
border-radius: var(--privy-border-radius-lg);
|
|
255
|
-
}
|
|
256
|
-
`;cn.div`
|
|
257
|
-
display: flex;
|
|
258
|
-
flex-direction: column;
|
|
259
|
-
align-items: center;
|
|
260
|
-
justify-content: center;
|
|
261
|
-
height: 100%;
|
|
262
|
-
`;const Ui=({success:n,fail:r})=>/*#__PURE__*/e(Ni,{children:[/*#__PURE__*/t(Oi,{children:/*#__PURE__*/t(Ri,{className:n?"success":r?"fail":""})}),/*#__PURE__*/t(Oi,{children:/*#__PURE__*/t(Mi,{className:n?"success":r?"fail":""})})]});let Oi=cn.span`
|
|
263
|
-
&& {
|
|
264
|
-
position: absolute;
|
|
265
|
-
top: 0;
|
|
266
|
-
left: 0;
|
|
267
|
-
z-index: 2;
|
|
268
|
-
}
|
|
269
|
-
`,Ni=cn.span`
|
|
270
|
-
position: relative;
|
|
271
|
-
width: 82px;
|
|
272
|
-
height: 82px;
|
|
273
|
-
display: inline-block;
|
|
274
|
-
`;const Mi=cn.span`
|
|
275
|
-
&& {
|
|
276
|
-
width: 82px;
|
|
277
|
-
height: 82px;
|
|
278
|
-
border-width: 4px;
|
|
279
|
-
border-style: solid;
|
|
280
|
-
border-color: ${e=>e.color??"var(--privy-color-icon-subtle)"};
|
|
281
|
-
border-bottom-color: transparent;
|
|
282
|
-
border-radius: 50%;
|
|
283
|
-
display: inline-block;
|
|
284
|
-
box-sizing: border-box;
|
|
285
|
-
animation: rotation 1.2s linear infinite;
|
|
286
|
-
transition: border-color 800ms;
|
|
287
|
-
}
|
|
288
|
-
|
|
289
|
-
@keyframes rotation {
|
|
290
|
-
0% {
|
|
291
|
-
transform: rotate(0deg);
|
|
292
|
-
}
|
|
293
|
-
100% {
|
|
294
|
-
transform: rotate(360deg);
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
&&&.success {
|
|
299
|
-
border-color: var(--privy-color-icon-success);
|
|
300
|
-
border-bottom-color: var(--privy-color-icon-success);
|
|
301
|
-
}
|
|
302
|
-
|
|
303
|
-
&&&.fail {
|
|
304
|
-
border-color: var(--privy-color-icon-error);
|
|
305
|
-
border-bottom-color: var(--privy-color-icon-error);
|
|
306
|
-
}
|
|
307
|
-
`,Ri=cn(Mi)`
|
|
308
|
-
&& {
|
|
309
|
-
border-bottom-color: ${e=>e.color??"var(--privy-color-border-default)"};
|
|
310
|
-
border-color: ${e=>e.color??"var(--privy-color-border-default)"};
|
|
311
|
-
animation: none;
|
|
312
|
-
opacity: 0.5;
|
|
313
|
-
}
|
|
314
|
-
`,Di=e=>/*#__PURE__*/t(Fi,{color:e.color||"var(--privy-color-foreground-3)"});let Fi=cn(Mi)`
|
|
315
|
-
&& {
|
|
316
|
-
height: 1rem;
|
|
317
|
-
width: 1rem;
|
|
318
|
-
margin: 2px 0;
|
|
319
|
-
border-width: 1.5px;
|
|
320
|
-
|
|
321
|
-
/* Override default Loader to match button transitions */
|
|
322
|
-
transition: border-color 200ms ease;
|
|
323
|
-
}
|
|
324
|
-
`;const Li=()=>{let{ready:e}=mt(),{currentScreen:t}=yt(),[n,r]=d(null),[a,s]=d(!1),o=function(e){let[t,n]=d(!1),r=l(null),a=l(null),s=l(null);return i((()=>{if(r.current&&(clearTimeout(r.current),r.current=null),a.current&&(clearTimeout(a.current),a.current=null),e)s.current=Date.now(),r.current=setTimeout((()=>{n(!0)}),150);else if(null!==s.current){let e=Date.now()-s.current;if(e>=150){let t=Math.max(0,400-(e-150));a.current=setTimeout((()=>{n(!1),s.current=null}),t)}else r.current&&(clearTimeout(r.current),r.current=null),n(!1),s.current=null}return()=>{r.current&&clearTimeout(r.current),a.current&&clearTimeout(a.current)}}),[e]),t}(a);return i((()=>{if(!t)return r(null),void s(!1);s(!0),ci[t]().then((n=>{(!t||e||n.default.isShownBeforeReady)&&(r((()=>n.default.component)),s(!1))})).catch((()=>{r(null),s(!1)}))}),[t,e]),{component:n,isLoading:o}};let ji=/*#__PURE__*/p((()=>import("./MfaVerifyFlowScreen-B8ONcY5T.mjs"))),zi=/*#__PURE__*/p((()=>(e=>ci[e]().then((e=>({default:e.default.component}))))("MfaAuthVerifyFlowScreen"))),qi=()=>/*#__PURE__*/t(Gi,{children:/*#__PURE__*/t(Mi,{})}),Bi=()=>{let{currentScreen:r}=yt(),a=ki((e=>e.inProgressMfaFlow)),s=()=>ki.setState({inProgressMfaFlow:void 0}),{component:o,isLoading:l}=Li();return function(){let{isModalOpen:e}=mt(),{headless:t}=Wt(),{currentScreen:n}=yt(),{status:r,execute:a,reset:s,enabled:o}=Xa(),[l,c]=d(!1);i((()=>{!e&&o&&s()}),[e,o,s]),i((()=>{n?ci[n]().then((e=>{c(!!e.default.isCaptchaRequired)})).catch((()=>{c(!1)})):c(!1)}),[n]),i((()=>{e&&l&&!t&&"ready"===r&&o&&a()}),[e,l,t,r,o,a])}(),r||"txn"!==a?l?/*#__PURE__*/t(qi,{}):o?
|
|
325
|
-
/*#__PURE__*/e(n,{children:[/*#__PURE__*/t(Ai,{$if:!!a,children:/*#__PURE__*/t(h,{children:/*#__PURE__*/t(o,{})})}),/*#__PURE__*/e(h,{children:["txn"===a&&/*#__PURE__*/t(ji,{onClose:s}),"auth"===a&&/*#__PURE__*/t(zi,{})]})]}):null:/*#__PURE__*/t(h,{children:/*#__PURE__*/t(ji,{onClose:s})})},Hi=()=>{let e=l(null);/*#__PURE__*/return t(Ki,{style:{height:di(e)},id:"privy-modal-content",children:/*#__PURE__*/t("div",{ref:e,children:/*#__PURE__*/t(Bi,{})})})};const $i=({open:e})=>{let n=Wt(),{gracefulClosePrivyModal:r}=(()=>{let{closePrivyModal:e}=Q(),{onUserCloseViaDialogOrKeybindRef:t}=yt();return{gracefulClosePrivyModal:c((()=>{if(!t?.current)return e({shouldCallAuthOnSuccess:!1});t.current()}),[e])}})(),a=ki((e=>e.inProgressMfaFlow));return ui({onMfaRequired:()=>{n.mfa.noPromptOnMfaRequired||ki.setState({inProgressMfaFlow:"txn"})}}),n.render.standalone?/*#__PURE__*/t(Ei,{children:/*#__PURE__*/t(Vi,{id:"privy-modal-content",children:/*#__PURE__*/t(Bi,{})})}):/*#__PURE__*/t(Si,{open:!(!e&&!a),id:"privy-dialog","aria-label":"log in or sign up","aria-labelledby":"privy-dialog-title",onClick:()=>r(),children:/*#__PURE__*/t(Ei,{children:/*#__PURE__*/t(Hi,{})})})};let Vi=cn.div`
|
|
326
|
-
display: flex;
|
|
327
|
-
flex-direction: column;
|
|
328
|
-
text-align: center;
|
|
329
|
-
font-size: 14px;
|
|
330
|
-
line-height: 20px;
|
|
331
|
-
width: 100%;
|
|
332
|
-
background: var(--privy-color-background);
|
|
333
|
-
padding: 0 16px;
|
|
334
|
-
`,Ki=cn(Vi)`
|
|
335
|
-
transition: height 150ms ease-out;
|
|
336
|
-
overflow-x: hidden;
|
|
337
|
-
overflow-y: auto;
|
|
338
|
-
scrollbar-width: none;
|
|
339
|
-
|
|
340
|
-
// Ensure the modal gets pinned to the top if it ever gets too tall
|
|
341
|
-
max-height: calc(100svh - 32px);
|
|
342
|
-
|
|
343
|
-
border-radius: var(--privy-border-radius-lg) var(--privy-border-radius-lg) 0 0;
|
|
344
|
-
box-shadow: 0px 0px 36px rgba(55, 65, 81, 0.15);
|
|
345
|
-
|
|
346
|
-
@media (min-width: 441px) {
|
|
347
|
-
box-shadow: 0px 8px 36px rgba(55, 65, 81, 0.15);
|
|
348
|
-
border-radius: var(--privy-border-radius-lg);
|
|
349
|
-
}
|
|
350
|
-
`,Gi=cn.div`
|
|
351
|
-
display: flex;
|
|
352
|
-
align-items: center;
|
|
353
|
-
justify-content: center;
|
|
354
|
-
min-height: 300px;
|
|
355
|
-
padding: 2rem;
|
|
356
|
-
`;function Yi(e){let n=l(null),r=l();return i((()=>{r.current?.remove(),r.current=function({botUsername:e,scriptHost:t}){let n=document.createElement("script"),{origin:r}=new URL(t);return n.async=!0,n.src=`${r}/js/telegram-login.js`,n.setAttribute("data-telegram-login",e),n.setAttribute("data-request-access","write"),n.setAttribute("data-lang","en"),n}(e),n.current?.after(r.current)}),[e]),/*#__PURE__*/t("div",{ref:n,hidden:!0})}const Ji=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4","csw_signUserOperation","secp256k1_sign"];class Zi extends Error{constructor(e,t,n){super(e),this.code=t,this.data=n}}class Qi extends It{async handleSendTransaction(e){if(!e.params||!Array.isArray(e.params))throw new Zi(`Invalid params for ${e.method}`,4200);let t=e.params[0];if(!await ii()||!this.address)throw new Zi("Disconnected",4900);let{hash:n}=await Bo(t,{address:this.address});return n}async handleSignTransaction(e){if(!e.params||!Array.isArray(e.params))throw new Zi(`Invalid params for ${e.method}`,4200);let t=e.params[0];if(!await ii()||!this.address)throw new Zi("Disconnected",4900);let{signature:n}=await qo(t,{address:this.address});return n}handleSwitchEthereumChain(e){let t;if(!e.params||!Array.isArray(e.params))throw new Zi(`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 Zi(`Invalid params for ${e.method}`,4200);t=e.params[0].chainId}this.chainId=Number(t),this.publicClient=Rn(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],n=e.params[1],{signature:r}=await jo({message:t},{address:n});return r}async handleSignedTypedData(e){if(!e.params||!Array.isArray(e.params))throw Error("Invalid params for eth_signTypedData_v4");let t=e.params[0],n="string"==typeof e.params[1]?JSON.parse(e.params[1]):e.params[1],{signature:r}=await zo(Qn(n),{address:t});return r}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:Kn(this.chainId)};return await this.publicClient.estimateGas({account:t.from??this.address,...bn(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 Kn(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=>Ji.includes(e))(e.method))return this.publicClient.request({method:e.method,params:e.params});{let t=await ii();if(await Ho({address:this.address}),!t||!this.address)throw new Zi("Disconnected",4900);try{let n={method:e.method,params:e.params},r=this.walletAccount;return r&>(r)?this.handleWalletApiRequest(n,r,t):(await this.walletProxy.rpc({accessToken:t,entropyId:this.entropyId,entropyIdVerifier:this.entropyIdVerifier,chainType:"ethereum",hdWalletIndex:this.walletIndex,request:n})).response.data}catch(e){throw console.error(e),new Zi("Disconnected",4900)}}}async handleWalletApiRequest(e,t,n){let r=this.privyClient;if(!r)throw new Zi("Disconnected",4900);if("secp256k1_sign"===e.method){let a=await E(r,(async({message:e})=>this.walletProxy.signWithUserSigner({accessToken:n,message:e})),{chain_type:"ethereum",method:"secp256k1_sign",wallet_id:t.id,params:{hash:e.params[0]}});if("secp256k1_sign"!==a.method)throw new Zi(`Invalid params for ${e.method}`,4200);return a.data.signature}throw new Zi(`Method not supported: ${e.method}`,4200)}constructor({walletProxy:e,address:t,entropyId:n,entropyIdVerifier:r,rpcConfig:a,chains:i,appId:s,chainId:o=1,walletIndex:l,privyClient:c,walletAccount:d}){super(),this.walletProxy=e,this.address=t,this.entropyId=n,this.entropyIdVerifier=r,this.chainId=o,this.rpcConfig=a,this.chains=i,this.publicClient=Rn(o,this.chains,a,{appId:s}),this.rpcTimeoutDuration=mr(a,"privy"),this.appId=s,this.walletIndex=l,this.privyClient=c,this.walletAccount=d}}const Xi=e=>{if("ethereum"===e.chainType)return{entropyId:e.address,entropyIdVerifier:"ethereum-address-verifier"};if("solana"===e.chainType)return{entropyId:e.address,entropyIdVerifier:"solana-address-verifier"};throw Error("Failed to get account entropy details")},es=(e,t)=>{if(t?.imported)return Xi(t);let n=ft(e);if(!n)throw Error("Failed to find primary wallet");return Xi(n)},ts=({...e})=>/*#__PURE__*/t("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:/*#__PURE__*/t("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M2.37126 11.0323C2.37126 12.696 3.90598 13.4421 5.40654 13.4468C8.91753 13.4468 12.8021 11.2897 12.7819 7.67984C12.7673 5.07728 10.3748 2.86167 7.54357 2.88296C4.8495 2.88296 2.21821 4.6411 2.21803 7.03628C2.21803 7.67951 2.58722 8.30178 3.55231 8.37184C2.74763 9.16826 2.37126 10.1225 2.37126 11.0323ZM7.55283 8.68012C8.11562 8.68012 8.57186 8.13217 8.57186 7.45624C8.57186 6.78032 8.11562 6.23237 7.55283 6.23237C6.99003 6.23237 6.53379 6.78032 6.53379 7.45624C6.53379 8.13217 6.99003 8.68012 7.55283 8.68012ZM10.4747 8.68012C11.0375 8.68012 11.4937 8.13217 11.4937 7.45625C11.4937 6.78032 11.0375 6.23237 10.4747 6.23237C9.91186 6.23237 9.45562 6.78032 9.45562 7.45625C9.45562 8.13217 9.91186 8.68012 10.4747 8.68012Z",fill:e.color||"var(--privy-color-foreground-3)"})}),ns=e=>{hn("fundWallet",e);let{fundWallet:t}=Q();return{fundWallet:({address:e,options:n})=>t(e,n)}};let rs=[],as=[];const is=/*#__PURE__*/o(null);function ss(){let e=s(is),{wallets:t}=(()=>{let e=Wt(),{user:t}=mt(),{walletProxy:n,privy:r}=Q(),{fundWallet:a}=ns(),[i,s]=d(e.defaultChain.id),o=u((()=>t?.linkedAccounts.filter((e=>"wallet"===e.type&&"ethereum"===e.chainType&&null!==e.walletIndex&&"privy"===e.walletClientType))??rs),[t]);return{wallets:u((()=>{if(!n)return as;let l=Fr();return o.map((o=>{let c=()=>{if(!t)throw new H("User not ready");let{entropyId:a,entropyIdVerifier:s}=es(t,o);return new Qi({walletProxy:n,address:o.address,entropyId:a,entropyIdVerifier:s,rpcConfig:e.rpcConfig,chains:e.chains,appId:e.id,chainId:i,walletIndex:o.walletIndex,privyClient:r,walletAccount:o})},d=l.find((e=>e.address===o.address&&e.connectorType===o.connectorType&&e.walletClientType===o.walletClientType))?.connectedAt??o.firstVerifiedAt?.getTime()??Date.now();return{fund:async e=>{await a({address:o.address,options:e})},type:"ethereum",chainId:`eip155:${i}`,switchChain:async e=>{s(Number(e))},getEthereumProvider:async()=>c(),sign:async e=>{let t=c();return await t.request({method:"personal_sign",params:[A(e),o.address]})},address:o.address,connectedAt:d,walletClientType:"privy",connectorType:"embedded",imported:o.imported,meta:{name:"Privy Wallet",icon:ts,id:"io.privy.wallet"},isConnected:async()=>!0,disconnect:()=>{},linked:!0,loginOrLink:async()=>{throw new H("Cannot link or login with embedded wallet")},unlink:async()=>{throw new H("Cannot unlink with embedded wallet")},walletIndex:o.walletIndex}}))}),[o,i,n])}})();return null===e?(console.warn("`useWallets` was called outside the PrivyProvider component"),{wallets:[],ready:!1}):u((()=>({wallets:[...t,...e.wallets].sort(((e,t)=>t.connectedAt-e.connectedAt)),ready:e.ready})),[e.wallets,e.ready,t])}const os=()=>{let{ready:e,wallets:t}=ss();return i((()=>{if(!e)return;let n=t.map((e=>({address:e.address,connectorType:e.connectorType,walletClientType:e.walletClientType,connectedAt:e.connectedAt,id:e.meta.id})));ur.put(Nt,n)}),[e,t]),null},ls=["error","invalid_request_arguments","wallet_not_on_device","invalid_recovery_pin","insufficient_funds","missing_or_invalid_mfa","mfa_verification_max_attempts_reached","mfa_timeout","twilio_verification_failed"];class cs extends Error{constructor(e,t){super(t),this.type=e}}function ds(e){let t=e.type;return"string"==typeof t&&ls.includes(t)}function us(e){return ds(e)&&"wallet_not_on_device"===e.type}function hs(e){return ds(e)&&("invalid_recovery_pin"===e.type||"invalid_request_arguments"===e.type)}function ps(e){return!!ds(e)&&"mfa_timeout"===e.type}function ws(e){return!!ds(e)&&"missing_or_invalid_mfa"===e.type}function ms(e){return!!ds(e)&&"mfa_verification_max_attempts_reached"===e.type}function ys(e){return!(!ds(e)||!e.message.includes("code 429"))}function gs(e){return!!function(e){let t=e.type;return"string"==typeof t&&"client_error"===t}(e)&&"MFA canceled"===e.message}async function fs(e,t,n,r,a,i=!1){let s=i,o=async o=>{if(s&&t&&t.length>0){o===(i?0:1)?a("configureMfa","onMfaRequired",{mfaMethods:t}):r.current?.reject(new cs("missing_or_invalid_mfa","MFA verification failed, retry."));let s=await new Promise(((e,t)=>{n.current={resolve:e,reject:t},setTimeout((()=>{let e=new cs("mfa_timeout","Timed out waiting for MFA code");r.current?.reject(e),t(e)}),3e5)}));return await e(s)}return await e()},l=null;for(let e=0;e<4;e++)try{l=await o(e),r.current?.resolve(void 0);break}catch(e){if("missing_or_invalid_mfa"!==e.type)throw r.current?.resolve(void 0),e;s=!0}if(null===l){let e=new cs("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw r.current?.reject(e),e}return l}var vs;let As=(vs=0,()=>"id-"+vs++);function bs(e){return void 0!==e.error}let Cs=new class{enqueue(e,t){this.callbacks[e]=t}dequeue(e,t){let n=this.callbacks[t];if(!n)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 n;default:throw Error(`invalid wallet event type ${e}`)}}constructor(){this.callbacks={}}},ks=new Map,Ts=(e,t)=>"bigint"==typeof t?t.toString():t;function _s(e,t,n,r){let a=n.contentWindow;if(!a)throw Error("iframe not initialized");let i=((e,t)=>`${e}${JSON.stringify(t,Ts)}`)(e,t);if("privy:wallet:create"===e){let e=ks.get(i);if(e)return e}let s=new Promise(((n,i)=>{let s=As();Cs.enqueue(s,{resolve:n,reject:i}),a.postMessage({id:s,event:e,data:t},r)})).finally((()=>{ks.delete(i)}));return ks.set(i,s),s}function Es(e){let n=en(),r=l(null),a=l(e.mfaMethods),s=pn(),[o,c]=d(!1);return i((()=>{a.current=e.mfaMethods}),[e.mfaMethods]),i((()=>{if(!o)return;let t=r.current;if(!t)return;function n(t){var n;t&&t.origin===e.origin&&"string"==typeof(n=t.data).event&&/^privy:.+/.test(n.event)&&function(e){switch(e.event){case"privy:iframe:ready":let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data);case"privy:user-signer:sign":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:add":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:set-recovery":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:connect":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:recover":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallets:rpc":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:wallet:create":let n=Cs.dequeue(e.event,e.id);return bs(e)?n.reject(new cs(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallets:import":let r=Cs.dequeue(e.event,e.id);return bs(e)?r.reject(new cs(e.error.type,e.error.message)):r.resolve(e.data);case"privy:mfa:verify":let a=Cs.dequeue(e.event,e.id);return bs(e)?a.reject(new cs(e.error.type,e.error.message)):a.resolve(e.data);case"privy:mfa:init-enrollment":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:submit-enrollment":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:unenroll":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:mfa:clear":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:auth:unlink-passkey":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:solana-wallet:create":let i=Cs.dequeue(e.event,e.id);return bs(e)?i.reject(new cs(e.error.type,e.error.message)):i.resolve(e.data);case"privy:farcaster:init-signer":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:farcaster:sign":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}case"privy:delegated-actions:consent":{let t=Cs.dequeue(e.event,e.id);return bs(e)?t.reject(new cs(e.error.type,e.error.message)):t.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}(t.data)}let i={signWithUserSigner:n=>fs((r=>_s("privy:user-signer:sign",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),addWallet:n=>fs((r=>_s("privy:wallets:add",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),setRecovery:n=>fs((r=>_s("privy:wallets:set-recovery",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),connect:n=>fs((r=>_s("privy:wallets:connect",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),recover:n=>fs((r=>_s("privy:wallets:recover",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s,!n.recoveryAccessToken&&!n.recoveryPassword&&!n.recoverySecretOverride),rpc:n=>fs((r=>_s("privy:wallets:rpc",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),create:n=>_s("privy:wallet:create",n,t,e.origin),importWallet:n=>_s("privy:wallets:import",n,t,e.origin),createSolana:n=>fs((r=>_s("privy:solana-wallet:create",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),createDelegatedAction:n=>_s("privy:delegated-actions:consent",n,t,e.origin),verifyMfa:n=>fs((r=>_s("privy:mfa:verify",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s,!0),initEnrollMfa:n=>fs((r=>_s("privy:mfa:init-enrollment",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),submitEnrollMfa:n=>fs((r=>_s("privy:mfa:submit-enrollment",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),unenrollMfa:n=>fs((r=>_s("privy:mfa:unenroll",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),clearMfa:n=>_s("privy:mfa:clear",n,t,e.origin),unlinkPasskeyAccount:n=>fs((r=>_s("privy:auth:unlink-passkey",{...n,...r},t,e.origin)),a.current,e.mfaPromise,e.mfaSubmitPromise,s),initFarcasterSigner:n=>_s("privy:farcaster:init-signer",n,t,e.origin),signFarcasterMessage:n=>_s("privy:farcaster:sign",n,t,e.origin)};window.addEventListener("message",n);let l=new AbortController;return $n((()=>_s("privy:iframe:ready",{},t,e.origin)),{abortSignal:l.signal}).then((()=>e.onLoad(i)),((...t)=>{console.warn("Privy iframe failed to load: ",...t),e.onLoadFailed()})),()=>{window.removeEventListener("message",n),l.abort()}}),[o]),n?
|
|
357
|
-
/*#__PURE__*/t("iframe",{ref:r,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},onLoad:()=>c(!0),src:kn({origin:e.origin,path:`/apps/${e.appId}/embedded-wallets`,query:{caid:e.clientAnalyticsId,client_id:e.appClientId}})}):null}function Ss(e){return["ethereum","solana"].includes(e.chainType)}const Is=({address:e,user:t})=>{let n=t.linkedAccounts.find((t=>"wallet"===t.type&&"privy"===t.walletClientType&&t.address===e));if(!n)throw new H("Address to delegate is not associated with current user.");if(!Ss(n))throw new H(`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,walletIndex:n.walletIndex??0}},Ps=({address:e,user:t})=>{let n=t.linkedAccounts.find((t=>"wallet"===t.type&&"privy"===t.walletClientType&&t.address===e));if(!n)throw new H("Address to delegate is not associated with current user.");let r=n.imported?n:ft(t);if(!r)throw new H("Unable to determine root address for delegated address.");if(!Ss(r))throw new H(`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,imported:r.imported}},Ws=e=>e.linkedAccounts.filter((e=>"wallet"===e.type&&"privy"===e.walletClientType&&e.delegated));function xs(e){let t=e.replace("eip155:","");if(t)return parseInt(t);throw Error("Chain ID not compatible with CAIP-2 format.")}const Us="popup-privy-oauth",Os="PRIVY_OAUTH_USE_BROADCAST_CHANNEL";class Ns{async authenticate(){if(!this.api)throw new H("Auth flow has no API instance");try{return await this.api.post(ue,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:this.meta.codeVerifier,provider:this.meta.provider,mode:this.meta.disableSignup?"no-signup":"login-or-sign-up"})}catch(e){throw $(e)}}async link(){if(!this.api)throw new H("Auth flow has no API instance");try{return await this.api.post(he,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:this.meta.codeVerifier,provider:this.meta.provider})}catch(e){throw $(e)}}constructor(e){this.meta=e}}async function Ms({api:e,requesterAppId:t,providerAppId:n}){let r=(await e.get(`/api/v1/apps/${t}/cross-app/connections`)).connections.find((e=>e.provider_app_id===n));if(!r)throw new H("Invalid connected app");return{name:r.provider_app_name,logoUrl:r.provider_app_icon_url||void 0,apiUrl:r.provider_app_custom_api_url,readOnly:r.read_only,customAuthAuthorizeUrl:r.provider_app_custom_auth_authorize_url,customAuthTransactUrl:r.provider_app_custom_auth_transact_url}}const Rs=async({user:e,address:t,client:n,request:r,requesterAppId:a,reconnect:i})=>{n.createAnalyticsEvent({eventName:"cross_app_request_started",payload:{address:t,method:r.method}});let s=e?.linkedAccounts.find((e=>"cross_app"===e.type&&(e.embeddedWallets.some((e=>e.address===t))||e.smartWallets.some((e=>e.address===t)))));if(!e||!s)throw n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Cannot request a signature with this wallet address",address:t}}),new H("Cannot request a signature with this wallet address");let o=n.getProviderAccessToken(s.providerApp.id),l=await Ms({api:n.api,requesterAppId:a,providerAppId:s.providerApp.id});if(!o){if(l.readOnly)throw console.error("cannot transact against a read-only provider app"),new H("Cannot transact against a read-only provider app");await i({appId:s.providerApp.id,action:"link"})&&(o=n.getProviderAccessToken(s.providerApp.id))}if(!o)throw n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Transactions require a valid token",address:t}}),new H("Transactions require a valid token");let c=new URL(l.customAuthTransactUrl||`${l.apiUrl}/oauth/transact`);c.searchParams.set("token",o||""),c.searchParams.set("request",Ds(r));let d=j({location:c.href});if(!d)throw n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Missing token",address:t}}),new H("Failed to initialize signature request");return new Promise(((e,a)=>{let i=setTimeout((()=>{c(),a(new H("Request timeout")),n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"Request timeout",address:t}})}),12e4),o=setInterval((()=>{d.closed&&(c(),a(new H("User rejected request")),n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:"User rejected request",address:t}}))}),300),l=i=>{i.data&&("set"===i.data.token?.action&&void 0!==i.data.token?.value?n.storeProviderAccessToken(s.providerApp.id,i.data.token.value):"clear"===i.data.token?.action&&n.storeProviderAccessToken(s.providerApp.id,null),"PRIVY_CROSS_APP_ACTION_RESPONSE"===i.data.type&&i.data.result&&(c(),e(i.data.result),n.createAnalyticsEvent({eventName:"cross_app_request_success",payload:{address:t,method:r.method}})),"PRIVY_CROSS_APP_ACTION_ERROR"===i.data.type&&i.data.error&&(c(),a(i.data.error),n.createAnalyticsEvent({eventName:"cross_app_request_error",payload:{error:i.data.error,address:t}})))};window.addEventListener("message",l);let c=()=>{d.close(),clearInterval(o),clearTimeout(i),window.removeEventListener("message",l)}}))};let Ds=e=>JSON.stringify({content:{request:{request:Fs(e,dt)}},timestamp:Date.now(),callbackUrl:window.origin});const Fs=(e,t)=>"bigint"==typeof e?t(e):Array.isArray(e)?e.map((e=>Fs(e,t))):e&&"object"==typeof e?Object.fromEntries(Object.entries(e).map((([e,n])=>[e,Fs(n,t)]))):e;function Ls({isCreatingWallet:e,skipSplashScreen:t}){return e?"EmbeddedWalletPasswordCreateScreen":t?"EmbeddedWalletPasswordUpdateScreen":"EmbeddedWalletPasswordUpdateSplashScreen"}function js({walletAction:e,availableRecoveryMethods:t,legacySetWalletPasswordFlow:n,isResettingPassword:r,showAutomaticRecovery:a}){return a?"SetAutomaticRecoveryScreen":n||1===t.length?Ls({isCreatingWallet:"create"===e,skipSplashScreen:r}):"RecoverySelectionScreen"}function zs(e){switch(e){case"user-passcode":return"PasswordRecoveryScreen";case"google-drive":case"icloud":return"RecoveryOAuthScreen";default:throw Error("Recovery method not supported")}}const qs=e=>e.filter((e=>"wallets"===e.method||("exchange"===e.method?"coinbase"===e.provider:"card"===e.method||"payment-request"===e.method?"coinbase"===e.provider||"moonpay"===e.provider:(e.method,!1)))),Bs={[F.id]:"0xa0b86991c6218b36c1d19d4a2e9eb0ce3606eb48",[D.id]:"0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238",[R.id]:"0x0b2c639c533813f4aa9d7837caf62653d097ff85",[M.id]:"0x5fd84259d66Cd46123540766Be93DFE6D43130D7",[N.id]:"0x3c499c542cef5e3811e1192ce70d8cc03d5c3359",[O.id]:"0x41e94eb019c0762f9bfcf9fb1e58725bfb0e7582",[U.id]:"0x833589fCD6eDb6E08f4c7C32D4f71b54bdA02913",[x.id]:"0x036CbD53842c5426634e7929541eC2318f3dCF7e",[W.id]:"0xB97EF9Ef8734C71904D8002F8b6Bc66Dd9c48a6E",[P.id]:"0x5425890298aed601595a70ab815c96711a31bc65",[I.id]:"0xaf88d065e77c8cC2239327C5EDb3A432268e5831",[S.id]:"0x75faf114eafb1BDbe2F0316DF893fd58CE46AA4d"},Hs=({address:e,appConfig:t,fundWalletConfig:n,methodScreen:r,chainIdOverride:a,comingFromSendTransactionScreen:i=!1,onComplete:s,onError:o})=>{let l,c;if(!t.fundingConfig)throw Error("Wallet funding is not enabled");let d=qs(t.fundingConfig.options);if(d.length<1)throw Error("Wallet funding is not enabled");l=a||(n?.chain?n.chain.id:xs(t.fundingConfig.defaultRecommendedCurrency.chain));let u=t.chains.find((e=>e.id===l));if(!u)throw new H(`Funding chain ${l} is not in PrivyProvider chains list`);let h=n?.amount??t.fundingConfig.defaultRecommendedAmount,p=!1;function w(){if(!l)return;let e=Bs[l];d.find((e=>"wallets"===e.method))&&!e&&console.warn("Attempting to fund with USDC on chain where USDC address is not known. Funding via external wallet will be disabled."),c=e,p=!0}n&&"asset"in n?"USDC"===n.asset?w():"string"!=typeof n.asset&&"erc20"in n.asset&&(p=((e,t)=>e===Bs[t.id])(c=n.asset.erc20,u)):"USDC"===t.fundingConfig.defaultRecommendedCurrency.asset&&w();let m=n?.defaultFundingMethod;return{chainType:"ethereum",address:e,amount:h,chain:u,erc20Address:c,erc20ContractInfo:p?{symbol:"USDC",decimals:6}:void 0,isUSDC:p,methodScreen:r,supportedOptions:d,comingFromSendTransactionScreen:i,defaultFundingMethod:m,usingDefaultFundingMethod:!!m,preferredCardProvider:n?.card?.preferredProvider,crossChainBridgingEnabled:t.fundingConfig.crossChainBridgingEnabled??!1,solanaChain:"solana:mainnet",uiConfig:n&&"uiConfig"in n?n.uiConfig:void 0,externalSolanaFundingScreen:null,onComplete:s??(()=>{}),onError:o??(()=>{})}};function $s({address:e,fundWalletConfig:t,appConfig:n,comingFromSendTransactionScreen:r,externalSolanaFundingScreen:a,methodScreen:i}){if(!n.fundingConfig)throw Error("Wallet funding is not enabled");let s=qs(n.fundingConfig.options);if(s.length<1)throw Error("Wallet funding is not enabled");if("USDC"===t?.asset&&"solana:testnet"===t?.chain)throw Error("USDC funding is not supported on the Solana testnet");let o=t?.amount??n.fundingConfig.defaultRecommendedAmount,l=t?.defaultFundingMethod;return{chainType:"solana",address:e,supportedOptions:s,amount:o,isUSDC:"USDC"===t?.asset,methodScreen:i,comingFromSendTransactionScreen:r,chain:t?.chain||"solana:mainnet",crossChainBridgingEnabled:n.fundingConfig.crossChainBridgingEnabled??!1,defaultFundingMethod:l,preferredCardProvider:t?.card?.preferredProvider,usingDefaultFundingMethod:!!l,uiConfig:t?.uiConfig,externalSolanaFundingScreen:a,onComplete:()=>{},onError:()=>{}}}function Vs(e,t){if(e.onComplete)switch(t){case"external":e.fundingResult?e.onComplete({...e.fundingResult,fundingMethod:t}):e.onComplete({status:"cancelled",address:e.address,fundingMethod:t,amount:e.amount});break;case null:e.onComplete({status:"cancelled",address:e.address,fundingMethod:void 0,amount:e.amount});break;default:e.onComplete({status:"completed",address:e.address,fundingMethod:t,amount:e.amount})}}function Ks(e,t,n,r,a,i,s){return{...e,funding:e?.funding?{...e.funding,fundingResult:{status:t,address:e.funding.address,fundingMethod:void 0,transactionHash:n,amount:e.funding.amount,assetType:a?i?.symbol||"ETH":s.nativeCurrency.symbol||"ETH",metadata:{walletClientType:r}}}:void 0,solanaFundingData:e?.solanaFundingData,sendTransaction:e?.sendTransaction}}const Gs=new Map([["FundingMethodSelectionScreen",null],["TransferFromWalletScreen","external"],["FundingAmountEditScreen","external"],["ConnectOnlyLandingScreen","external"],["ConnectOnlyStatusScreen","external"],["AwaitingExternalEthereumTransferScreen","external"],["AwaitingEvmToSolBridgingScreen","external"],["AwaitingSolToEvmBridgingScreen","external"],["ManualTransferScreen","manual"],["MoonpayStatusScreen","moonpay"]]);function Ys(e){let t=e.toLowerCase();return!!window?.webkit?.messageHandlers?.ReactNativeWebView||!!window?.ReactNativeWebView||["fbav","fban","instagram","snapchat","linkedinapp"].some((e=>t.includes(e)))}async function Js({rpc:e,address:t}){return(await e.getBalance(t,{commitment:"confirmed"}).send()).value??0n}let Zs={apple_oauth:"apple",custom_auth:"custom",discord_oauth:"discord",email:"email",farcaster:"farcaster",github_oauth:"github",google_oauth:"google",instagram_oauth:"instagram",linkedin_oauth:"linkedin",passkey:"passkey",phone:"sms",spotify_oauth:"spotify",telegram:"telegram",tiktok_oauth:"tiktok",line_oauth:"line",twitch_oauth:"twitch",twitter_oauth:"twitter",wallet:"siwe",smart_wallet:"siwe",cross_app:"privy:"};const Qs=e=>{if(vt(e))return{displayName:e.replace("custom:",""),loginMethod:"custom"};let t=Zs[e];return"wallet"===e||"phone"===e?{displayName:e,loginMethod:t}:{displayName:t,loginMethod:t}},Xs=(e,t)=>!At(e)&&("all-users"===t||"users-without-wallets"===t&&!eo(e).length);let eo=e=>e.linkedAccounts.filter((e=>"wallet"===e.type&&"ethereum"===e.chainType));const to=(e,t)=>!bt(e)&&("all-users"===t||"users-without-wallets"===t&&!no(e).length);let no=e=>e.linkedAccounts.filter((e=>"wallet"===e.type&&"solana"===e.chainType));async function ro(e,t,n,r){let a=bn(e),{chain:i,...s}=await(async()=>r?await r():await t.prepareTransactionRequest({...a,account:{address:n,type:"json-rpc"}}))();return{...s,type:Cn[s.type]}}const ao=()=>{let e=Wt(),{user:t}=mt(),{client:n,refreshSessionAndUser:r,walletProxy:a}=Q();return{migrate:c((async()=>{if("legacy-embedded-wallets-only"===e.embeddedWallets.mode)return{success:!0,migrated:!1};if(!t)throw new H("User must be authenticated before migrating wallets",K.MUST_BE_AUTHENTICATED);if(!a)throw new H("Cannot connect to wallet proxy");let i=await n.getAccessToken();if(!i)throw new H("User must be authenticated before migrating wallets",K.MUST_BE_AUTHENTICATED);let s=t.linkedAccounts.filter((e=>"wallet"===e.type&&"privy"===e.walletClientType&&Ss(e)&&!gt(e)));if(0===s.length)return{success:!0,migrated:!1};let o=s.filter((e=>e.imported)),l=s.filter((e=>!e.imported));if(l.length>0){let e=l.find((e=>"ethereum"===e.chainType&&0===e.walletIndex))??l.find((e=>"solana"===e.chainType&&0===e.walletIndex))??null;if(!e)throw new H("Primary wallet not found");let{entropyId:t,entropyIdVerifier:n}=Xi(e);try{await a.connect({accessToken:i,entropyId:t,entropyIdVerifier:n})}catch(r){if(!us(r)||"privy"!==e.recoveryMethod)throw r;await a.recover({accessToken:i,entropyId:t,entropyIdVerifier:n})}await a.createDelegatedAction({accessToken:i,rootWallet:{address:e.address,chainType:e.chainType,imported:!1},delegatedWallets:l.map((e=>({address:e.address,chainType:e.chainType,walletIndex:e.walletIndex??0})))})}for(let e of o){let{entropyId:t,entropyIdVerifier:n}=Xi(e);try{await a.connect({accessToken:i,entropyId:t,entropyIdVerifier:n})}catch(o){if(!us(o)||"privy"!==e.recoveryMethod)throw o;await a.recover({accessToken:i,entropyId:t,entropyIdVerifier:n})}await a.createDelegatedAction({accessToken:i,rootWallet:{address:e.address,chainType:e.chainType,imported:!0},delegatedWallets:[{address:e.address,chainType:e.chainType,walletIndex:e.walletIndex??0}]})}return await r(),{success:!0,migrated:!0}}),[e.embeddedWallets.mode,t,a,n,r])}},io=({disabled:e})=>{let{migrate:t}=ao(),{user:n}=mt(),{walletProxy:r}=Q(),a=l(!1);return i((()=>{!e&&!a.current&&n&&r&&(a.current=!0,t().catch((e=>{console.debug("Unable to migrate wallets: ",e)})).finally((()=>{a.current=!1})))}),[n,r,e,t]),null},so=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}),oo=Symbol("solana-funding-plugin"),lo=Symbol("solana-ledger-plugin");let co=/*#__PURE__*/o({});const uo=({children:e})=>{let n=Wt(),[r,a]=d({});return hn("login",{onComplete:({loginAccount:e})=>{e&&"passkey"!==e.type&&"cross_app"!==e.type&&("wallet"!==e.type||"privy"!==e.walletClientType)&&(ur.put(ho(n.id),e.type),"wallet"===e.type?(ur.put(po(n.id),e.walletClientType),ur.put(wo(n.id),e.chainType),a({accountType:e.type,walletClientType:e.walletClientType,chainType:e.chainType})):(ur.del(po(n.id)),ur.del(wo(n.id)),a({accountType:e.type})))}}),i((()=>{if(!n.id)return;let e=ur.get(ho(n.id)),t=ur.get(po(n.id)),r=ur.get(wo(n.id));e&&a("wallet"===e?{accountType:e,walletClientType:t,chainType:r}:{accountType:e})}),[n.id]),/*#__PURE__*/t(co.Provider,{value:r,children:e})};let ho=e=>`privy:${e}:recent-login-method`,po=e=>`privy:${e}:recent-login-wallet-client`,wo=e=>`privy:${e}:recent-login-chain-type`;const mo=()=>s(co),yo=Pt((()=>({ethereum:[]}))),go=()=>yo.getState().ethereum,fo=(e,{chainType:t,walletIndex:n}={})=>e?.linkedAccounts.filter((e=>!("wallet"!==e.type||"privy"!==e.walletClientType||void 0!==n&&e.walletIndex!==n||void 0!==t&&e.chainType!==t)))??[],vo=e=>e.reduce(((e,t)=>!e||e.walletIndex<t.walletIndex?t:e),null),Ao=async({user:e,accessToken:t,proxy:n,refreshSessionAndUser:r,privy:a,appConfig:i,recoverEmbeddedWallet:s,setUser:o,walletIndex:l,chainType:c,recoveryMethod:d,recoveryPassword:u,recoveryAccessToken:h})=>{if(0===l)if("user-controlled-server-wallets-only"===i.embeddedWallets.mode)await L(a,{request:{chain_type:c}});else if("ethereum"===c){let r=bt(e);r&&await s({address:r.address}),await n.create({accessToken:t,solanaAddress:r?.address,recoveryMethod:d,recoveryPassword:u,recoveryAccessToken:h})}else{if("solana"!==c)throw Error("Invalid input to create wallet");{let r=At(e);r&&await s({address:r.address}),await n.createSolana({accessToken:t,ethereumAddress:r?.address,recoveryMethod:d,recoveryPassword:u,recoveryAccessToken:h})}}else if("user-controlled-server-wallets-only"===i.embeddedWallets.mode)await L(a,{request:{chain_type:c}});else{let{entropyId:r,entropyIdVerifier:a}=es(e);await s(),await n.addWallet({accessToken:t,entropyId:r,entropyIdVerifier:a,chainType:c,hdWalletIndex:l})}let p=await r(),w=fo(p,{chainType:c,walletIndex:l})[0];return o(p),{user:p,account:w}};let bo=async({accessToken:e,appConfig:t,privy:n,emitPrivyEvent:r,proxy:a,refreshSessionAndUser:i,recoverEmbeddedWallet:s,user:o,walletIndex:l,setModalData:c,openModal:d,chainType:u,setUser:h})=>{if(l<0)throw r("createWallet","onError",K.EMBEDDED_WALLET_CREATE_ERROR),Error(`A negative walletIndex (${l}) is invalid.`);let p=ft(o);if(l>0&&!p)throw r("createWallet","onError",K.EMBEDDED_WALLET_NOT_FOUND),Error("Must have an existing embedded wallet to create an additional wallet.");if(t.embeddedWallets.requireUserOwnedRecoveryOnCreate&&"user-controlled-server-wallets-only"===t.embeddedWallets.mode)throw r("createWallet","onError",K.EMBEDDED_WALLET_CREATE_ERROR),Error("User owned recovery not yet supported for this app.");if(!p&&t.embeddedWallets.requireUserOwnedRecoveryOnCreate)return await Co({emitPrivyEvent:r,setModalData:c,openModal:d,chainType:u});let w=fo(o,{chainType:u,walletIndex:l})[0];if(w)return{user:o,account:w};if(0===l&&!a)return Co({emitPrivyEvent:r,setModalData:c,openModal:d,chainType:u});if(!a)throw r("createWallet","onError",K.UNKNOWN_EMBEDDED_WALLET_ERROR),Error("Failed to connect to wallet proxy");return Ao({appConfig:t,walletIndex:l,chainType:u,user:o,accessToken:e,proxy:a,refreshSessionAndUser:i,privy:n,recoverEmbeddedWallet:s,setUser:h})},Co=async({emitPrivyEvent:e,setModalData:t,openModal:n,chainType:r})=>new Promise(((a,i)=>{t({createWallet:{onSuccess:({user:t,account:n})=>{e("createWallet","onSuccess",{wallet:n}),a({user:t,account:n})},onFailure:t=>{e("createWallet","onError",K.UNKNOWN_EMBEDDED_WALLET_ERROR),i(t)},callAuthOnSuccessOnClose:!1,shouldCreateEth:"ethereum"===r,shouldCreateSol:"solana"===r}}),n("EmbeddedWalletOnAccountCreateScreen")}));const ko=()=>{let e=Wt(),t=pn(),{setModalData:n}=yt(),{initializeWalletProxy:r,recoverEmbeddedWallet:a,setUser:i,openModal:s,refreshSessionAndUser:o,privy:l,client:c}=Q();return{create:async({chainType:d,options:u,latestUser:h})=>{let p=h;if(p||(p=await o()),!p)throw t("createWallet","onError",K.MUST_BE_AUTHENTICATED),Error("User must be authenticated before creating a Privy wallet");return await(async({appConfig:e,getAccessToken:t,initializeWalletProxy:n,user:r,privy:a,emitPrivyEvent:i,recoverEmbeddedWallet:s,setModalData:o,openModal:l,setUser:c,options:d,timeoutDuration:u,refreshSessionAndUser:h,chainType:p})=>{let[w,m]=await Promise.all([n(u),t()]);if(!m||!r)throw i("createWallet","onError",K.MUST_BE_AUTHENTICATED),Error("User must be authenticated before creating a Privy wallet");if(!w&&e.customAuth?.enabled)throw i("createWallet","onError",K.UNKNOWN_EMBEDDED_WALLET_ERROR),Error("Failed to connect to wallet proxy");if(d&&"walletIndex"in d&&"number"==typeof d.walletIndex){if("user-controlled-server-wallets-only"===e.embeddedWallets.mode)throw i("createWallet","onError",K.INVALID_DATA),Error("Invalid input, use `createAdditional` instead of `walletIndex` to create additional wallets.");return bo({accessToken:m,appConfig:e,privy:a,emitPrivyEvent:i,openModal:l,proxy:w,refreshSessionAndUser:h,recoverEmbeddedWallet:s,setModalData:o,user:r,walletIndex:d.walletIndex,chainType:p,setUser:c})}let y=d&&"createAdditional"in d&&d.createAdditional,g=fo(r,{chainType:p});if(g[0]&&!y)throw i("createWallet","onError",K.EMBEDDED_WALLET_ALREADY_EXISTS),Error("User already has an embedded wallet.");return bo({accessToken:m,appConfig:e,privy:a,emitPrivyEvent:i,openModal:l,proxy:w,recoverEmbeddedWallet:s,setModalData:o,user:r,walletIndex:(vo(g)?.walletIndex??-1)+1,chainType:p,refreshSessionAndUser:h,setUser:c})})({appConfig:e,privy:l,getAccessToken:()=>c.getAccessToken(),refreshSessionAndUser:o,initializeWalletProxy:r,user:p,emitPrivyEvent:t,recoverEmbeddedWallet:a,setModalData:n,openModal:s,setUser:i,options:u,timeoutDuration:tn,chainType:d})}}};function To(e){let{create:t}=ko();return hn("createWallet",e),{createWallet:async e=>{e&&"target"in e&&e&&(e=void 0);let{account:n}=await t({chainType:"ethereum",options:e});return n}}}const _o=async({emitPrivyEvent:e,getAccessToken:t,initializeWalletProxy:n,refreshSessionAndUser:r,user:a,appConfig:i},{privateKey:s,chainType:o,additionalSigners:l})=>{if(!a)throw e("linkAccount","onError",K.MUST_BE_AUTHENTICATED,{linkMethod:"siwe"}),new H("User must be authenticated before linking an account.");let c="user-controlled-server-wallets-only"===i.embeddedWallets.mode?"tee":"on-device";if(l&&"on-device"===c)throw new H("Specifying additionalSigners is only supported for TEE execution and this app uses On-device execution. Learn more https://docs.privy.io/recipes/tee-wallet-migration-guide");let[d,u]=await Promise.all([t(),n(15e3)]);if(!u||!d)throw e("linkAccount","onError",K.MUST_BE_AUTHENTICATED,{linkMethod:"siwe"}),new H("User must be authenticated before linking an account.");let{address:h}=await u.importWallet({privateKey:s,accessToken:d,chainType:o,mode:c,additionalSigners:l}),p=await r(),w="solana"===o?Ct(p):kt(p),m=w?.find((e=>e.address===h));if(!m)throw e("createWallet","onError",K.UNKNOWN_EMBEDDED_WALLET_ERROR),Error("Failed to import wallet");return e("createWallet","onSuccess",{wallet:m}),m},Eo=()=>{let{user:e}=mt(),{client:t,refreshSessionAndUser:n,initializeWalletProxy:r}=Q(),a=pn(),i=Wt();return{importWallet:c((({privateKey:s,additionalSigners:o})=>_o({getAccessToken:()=>t.getAccessToken(),user:e,initializeWalletProxy:r,refreshSessionAndUser:n,emitPrivyEvent:a,appConfig:i},{privateKey:s,chainType:"ethereum",additionalSigners:o})),[e,t,n,r,a,i])}},So=()=>{let{importWallet:e}=Eo(),{createWallet:t}=To();return{...s(Tt),importWallet:e,createWallet:t}};function Io({subscribe:e,getExternalJwt:t,enabled:n=!0,onAuthenticated:r,onUnauthenticated:a,onError:s}){let{client:o,onCustomAuthAuthenticated:c}=Q(),{logout:u,authenticated:h,ready:p}=So();if(!o)throw new H("`useSyncJwtBasedAuthState` must be used within a `PrivyProvider`");let[w,m]=d({status:"initial"}),y=l(),g=l(!1),f=l(t);i((()=>{f.current=t}),[t]);let v=l(r);i((()=>{v.current=r}),[r]);let A=l(a);i((()=>{A.current=a}),[a]);let b=l(s);return i((()=>{b.current=s}),[s]),i((()=>{if(!n||!p)return;let t=async()=>{if(!g.current){g.current=!0;try{m({status:"loading"});let e=await f.current();if(void 0!==y.current&&y.current===e)return void m({status:"done"});if(!e)return h&&(await u(),A.current?.()),y.current=e,void m({status:"done"});o.startAuthFlow(new ca(e));let{user:t,isNewUser:n=!1}=await o.authenticate();if(!t)throw new H("Failed to sync with custom auth provider");v.current?.({user:t,isNewUser:n}),c(t,n),y.current=e,m({status:"done"})}catch(e){if(console.warn(e),await u().catch((()=>{})),A.current?.(),e instanceof Y&&e.privyErrorCode===K.LINKED_TO_ANOTHER_USER)return m({status:"initial"}),void setTimeout((()=>{t()}),0);b.current?.(e),m({status:"error",error:e})}finally{g.current=!1}}};return t(),e(t)}),[e,o,c,h,u,n,p]),n?{state:w}:{state:{status:"not-enabled"}}}let Po=Pt((()=>({jwtAuthFlowState:{status:"not-enabled"}})));const Wo=()=>Po((e=>e.jwtAuthFlowState));function xo({customAuth:e}){let{jwtAuthFlowState:t}=function({customAuth:e}){let t=pn(),n=l(),r=c((e=>(n.current=e,()=>{n.current=void 0})),[]),a=e?.getCustomAccessToken??(()=>Promise.resolve(void 0)),{state:s}=Io({enabled:!0===e?.enabled,subscribe:r,getExternalJwt:a,onAuthenticated:({user:e,isNewUser:n})=>{t("login","onComplete",{user:e,isNewUser:n,wasAlreadyAuthenticated:!1,loginMethod:"custom",loginAccount:null}),t("customAuth","onAuthenticated",{user:e})},onUnauthenticated:()=>{t("customAuth","onUnauthenticated")},onError:e=>{t("login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR)}});return i((()=>{(async()=>{e&&!e.isLoading&&n.current?.()})()}),[e?.enabled,e?.getCustomAccessToken,e?.isLoading]),{jwtAuthFlowState:s}}({customAuth:e});return i((()=>{Po.setState({jwtAuthFlowState:t})}),[t]),null}const Uo=/*#__PURE__*/o(!1),Oo=()=>{if(s(Uo))throw new H("Multiple PrivyProvider instances found","Found multiple instances of PrivyProvider, ensure there is only one mounted in your application tree.")};let No,Mo,Ro,Do,Fo;const Lo=n=>{let a=n.client,s=n.privy,o=$a(),h=Wt();Pn(Un(h?.appearance.walletList??[]));let[p,w]=d(!1),m=ki((e=>e.inProgressMfaFlow)),[y,g]=d(!1),[k,T]=d(null),_=yo((e=>e.ethereum)),[S,I]=d(void 0),[P,W]=d(!1),[x,U]=d(null),[O,N]=d(!1),[M,R]=d({status:"disconnected",connectedWallet:null,connectError:null,connector:null,connectRetry:J}),[D,F]=d({status:"initial"}),[L,B]=d({status:"initial"}),[V,G]=d({status:"initial"}),[Y,Z]=d({status:"initial"}),[Q,te]=d({status:"initial"}),[ne,re]=d({status:"initial"}),[ae,ie]=d(null),se=en(),[oe,le]=d({}),[ce,de]=d(null),ue=l(null),[he,we]=d(!1),[me,ye]=d(!1),ge=l(null),fe=l(null),ve=l(wn),[Ae,be]=d(!1),[Ce,ke]=d(!1),Te=c((e=>{ke(e),!e&&x&&ci[x]().then((e=>{e.default.isUnauthenticatedScreem&&U(null)}))}),[x]);a.onStoreCustomerAccessToken=e=>{e&&mn(ve,"accessToken","onAccessTokenGranted",{accessToken:e})},a.onDeleteCustomerAccessToken=()=>{T(null),Te(!1),mn(ve,"accessToken","onAccessTokenRemoved")};let _e=l(null),Ee=l(null),Se=l(!1),Ie=({showWalletUIs:e})=>Se.current?Se.current:void 0!==e?!e:!h.embeddedWallets.showWalletUIs,Pe=e=>{U(e),setTimeout((()=>{w(!0)}),15)};i((()=>{ae&&ue.current?.(ae)}),[ae]);let We=c(((e,t)=>{T(e),W(t),Te(!0),ye(!0)}),[]);i((()=>{me&&ae&&k&&(async()=>{let e=Xs(k,h.embeddedWallets.ethereum.createOnLogin),t=to(k,h.embeddedWallets.solana.createOnLogin),n=await ii();if(n){if(e&&t){let e=await ae.create({accessToken:n});return await ae.createSolana({accessToken:n,ethereumAddress:e?.address}),void ye(!1)}if(t)return await ae.createSolana({accessToken:n,ethereumAddress:At(k)?.address}),await Ye.refreshSessionAndUser(),void ye(!1);if(e)return await ae.create({accessToken:n}),void ye(!1)}})().catch(console.error)}),[me&&ae&&k]),i((()=>{if(h.externalWallets.solana.connectors)return h.externalWallets.solana.connectors.onMount(),()=>h.externalWallets.solana.connectors?.onUnmount()}),[h.externalWallets.solana.connectors]),i((()=>{!y&&se&&async function(){let e,t=xe(),n=Ue(),i=r();a.initializeConnectorManager({walletConnectCloudProjectId:h.walletConnectCloudProjectId,rpcConfig:h.rpcConfig,chains:h.chains,defaultChain:h.defaultChain,store:i,walletList:h.appearance.walletList,shouldEnforceDefaultChainOnConnect:h.shouldEnforceDefaultChainOnConnect,externalWalletConfig:h.externalWallets,appName:h.name??"Privy",walletChainType:h.appearance.walletChainType,setBaseAccountSdk:I}),a.connectors?.on("connectorInitialized",(()=>{e&&clearTimeout(e);let t=a.connectors.walletConnectors.length,n=a.connectors.walletConnectors.reduce(((e,t)=>e+(t.initialized?1:0)),0);n===t?be(!0):e=setTimeout((()=>{console.debug({message:"Unable to initialize all expected connectors before timeout",initialized:n,expected:t}),be(!0)}),1500)})),a.connectors?.initialize().then((()=>{De()}));let s=await a.getAuthenticatedUser(),o=!!s;h.legal.requireUsersAcceptTerms&&s&&!s.hasAcceptedTerms?(await a.logout(),Ye.setReadyToTrue(!0),mn(ve,"logout","onSuccess")):(h.customAuth?.enabled||(Te(!!s),s&&mn(ve,"login","onComplete",{user:s,isNewUser:!1,wasAlreadyAuthenticated:!0,loginMethod:null,loginAccount:null}),T(s)),t?Ee.current=o?"link":"login":n&&!o?(Ee.current="login",le({telegramAuthModalData:{seamlessAuth:!0}}),Pe("TelegramAuthScreen")):Ye.setReadyToTrue(!!s))}()}),[a,ce,y,se]),i((()=>{if(y){if(!k||!k.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType)))return void we(!!ae);if([..._].some((e=>"privy"===e.walletClientType)))return void we(!0);we(!!ae)}}),[y,k,_,ae]),i((()=>{a.connectors?.setWalletList(h.appearance.walletList)}),[h.appearance.walletList.join()]);let xe=()=>{let e=ka();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&&e.provider.startsWith("privy:")&&!e.popupFlow&&(new BroadcastChannel(Us).postMessage({type:"PRIVY_OAUTH_RESPONSE",stateCode:e.stateCode,authorizationCode:e.authorizationCode}),window.close()),!!e.inProgress&&!!e.withPrivyUi&&(a.startAuthFlow(new Ca({...e,customOAuthRedirectUrl:h.customOAuthRedirectUrl})),Pe("OAuthStatusScreen"),!0))},Ue=()=>{let e=function(){let e;return(e=function(){let e=new URLSearchParams(window.location.search),t=Number(e.get("id")||""),n=e.get("hash"),r=Number(e.get("auth_date")||""),a=e.get("first_name");if(t&&a&&r&&n)return Object.fromEntries(e.entries())}())?(ai(),{flowType:"login-url",authData:e}):(e=function(){let e=window.location.hash;if(!e||!e.startsWith("#tgWebAppData"))return;let t=ri(e.replace("#tgWebAppData=","")),{user:n,auth_date:r,hash:a}=t;return n&&r&&a?t:void 0}())?(ai(),{flowType:"web-app",authData:e}):void 0}();if(!e||!h.loginMethods.telegram||!h.loginConfig.telegramAuthConfiguration?.seamlessAuthEnabled)return;let t=new ti;return a.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},Oe=async(e,t,n,r)=>{if("solana_adapter"!==e)Ne(await(a.connectors?.createEthereumWalletConnector({connectorType:e,walletClientType:t}))||null,t,n,r);else{let e=a.connectors?.findSolanaWalletConnector(t);if(!e)return;Ne(e,t,n,r)}};async function Ne(e,t,n,r){if(!e)return R({status:"disconnected",connectedWallet:null,connectError:new z("Unable to connect to wallet."),connector:null,connectRetry:J}),r?.(null,n);R({status:"disconnected",connectedWallet:null,connectError:null,connector:e,connectRetry:J}),e instanceof na&&t&&await e.resetConnection(t),R({connector:e,status:"connecting",connectedWallet:null,connectError:null,connectRetry:()=>Ne(e,t,n,r)});try{let t=await e.connect({showPrompt:!0});if((!t||hr(t))&&h.shouldEnforceDefaultChainOnConnect&&!h.chains.find((e=>e.id===Number(t?.chainId.replace("eip155:",""))))&&("wallet_connect_v2"!==t?.connectorType||"metamask"!==t?.walletClientType)){R((t=>({...t,connector:e,status:"switching_to_supported_chain",connectedWallet:null,connectError:null,connectRetry:J})));try{await(t?.switchChain(h.defaultChain.id)),t&&(t.chainId=Yn(A(h.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${h.defaultChain.id}`)}}return R((e=>({...e,status:"connected",connectedWallet:t,connectError:null,connectRetry:J}))),t&&mn(ve,"connectWallet","onSuccess",{wallet:t}),r?.(t,n)}catch(e){return e instanceof q?(console.warn(e.cause?e.cause:e.message),mn(ve,"connectWallet","onError",e.privyErrorCode||K.GENERIC_CONNECT_WALLET_ERROR)):(console.warn(e),mn(ve,"connectWallet","onError",K.UNKNOWN_CONNECT_WALLET_ERROR)),R((t=>({...t,status:"disconnected",connectedWallet:null,connectError:e}))),r?.(null,n)}}let Me=async(e,t,n)=>{if(null===e||!hr(e))return;let r=new Ea(a,e,t,n);a.startAuthFlow(r)},Re=async(e,t,n,r="plain")=>{let i=o(lo);if("transaction"===r&&!i)throw new H("useSolanaLedger plugin hook must be mounted");if(null===e||!ta(e))return;let s=new Ya(e,a,t,n,r,i);a.startAuthFlow(s)},De=async()=>{let e=new URLSearchParams(window.location.search),t=e.get("privy_connector"),n=e.get("privy_wallet_client"),r="true"===e.get("privy_connect_only");if(!t||!n)return;let i=Rr({connectorType:t,walletClientType:n});if(!i||!i.isInstalled)return Pe("LoginFailedScreen");if(!a.connectors)throw new H("Connector not initialized");await Pe(r?"ConnectOnlyStatusScreen":"ConnectionStatusScreen");let s=new URL(window.location.href);s.searchParams.delete("privy_connector"),s.searchParams.delete("privy_wallet_client"),s.searchParams.delete("privy_connect_only"),window.history.pushState({},"",s),Oe(t,n,void 0,r?void 0:"solana_adapter"===t?Re:Me)};i((()=>{y&&Ce&&null===k&&a.getAuthenticatedUser().then(T)}),[y,Ce,k,a]);let Fe=e=>{if(!Ce)throw mn(ve,"linkAccount","onError",K.MUST_BE_AUTHENTICATED,{linkMethod:e}),new H("User must be authenticated before linking an account.")},Le=e=>{if(!Ce||!k)return!1;if("privy"===e.walletClientType)return!0;for(let t of k.linkedAccounts)if("wallet"===t.type&&t.address===e.address&&"privy"!==t.walletClientType)return!0;return!1},je=()=>{yo.setState((e=>{let t=a.connectors?.wallets.filter(hr).map((e=>({...e,linked:Le(e),loginOrLink:async()=>{if(!await e.isConnected())throw new H("Wallet is not connected");if("embedded"===e.connectorType&&"privy"===e.walletClientType)throw new H("Cannot link or login with embedded wallet");(async e=>{let t;if(!a.connectors)throw new H("Connector not initialized");t="ethereum"===e.type?a.connectors.findWalletConnector(e.connectorType,e.walletClientType)||null:a.connectors.findSolanaWalletConnector(e.walletClientType)||null,R((n=>({...n,connector:t,status:"connected",connectedWallet:e,connectError:null,connectRetry:J}))),h.captcha.enabledProvider&&!Ce?(le({captchaModalData:{callback:t=>hr(e)?Me(e,t):Re(e,t),userIntentRequired:!1,onSuccessNavigateTo:"ConnectionStatusScreen",onErrorNavigateTo:"ErrorScreen"}}),await Pe("CaptchaScreen")):(hr(e)?await Me(e):await Re(e),await Pe("ConnectionStatusScreen"))})(e)},fund:async t=>{await Ye.fundWallet(e.address,t)},unlink:async()=>{if(!Ce)throw new H("User is not authenticated.");if("embedded"===e.connectorType&&"privy"===e.walletClientType)throw new H("Cannot unlink an embedded wallet");T(await a.unlinkEthereumWallet(e.address))}})))||[];return pr(e.ethereum,t)?{}:{ethereum:t}}))};i((()=>{je()}),[k?.linkedAccounts,Ce,y]),i((()=>{if(y){if(!a.connectors)throw new H("Connector not initialized");je(),a.connectors.on("walletsUpdated",je)}}),[y]),i((()=>{[...h.loginMethodsAndOrder?.primary??[],...h.loginMethodsAndOrder?.overflow??[]].filter((e=>e.startsWith("privy:"))).forEach((e=>a.getCrossAppProviderDetails(e.replace("privy:",""))))}),[!!a]);let ze=({transaction:e,sponsor:t,uiOptions:r,fundWalletConfig:i,address:o,signOnly:l})=>new Promise((async(c,d)=>{let{requesterAppId:u}=r||{},p=l?"signTransaction":"sendTransaction",w=o?_t(k,o):At(k);if(!w&&o){let n=St(go(),o);if(n){if(t)throw new H("Cannot sponsor transactions for externally connected wallet.");try{let t=await n.getEthereumProvider(),r={...e,from:o,chainId:e.chainId||Number(n.chainId.replace("eip155:","")),value:void 0!==e.value?A(e.value):void 0},a=await t.request({method:"sendTransaction"===p?"eth_sendTransaction":"eth_signTransaction",params:[r]});return mn(ve,p,"onSuccess",{hash:a}),void c({hash:a})}catch(e){return mn(ve,p,"onError",K.TRANSACTION_FAILURE),void d(e??new or("Unable to "+p+e))}}}if(!w)return mn(ve,p,"onError",K.EMBEDDED_WALLET_NOT_FOUND),void d(new H("No embedded or connected wallet found for address."));if(!Ce||!k)return mn(ve,p,"onError",K.MUST_BE_AUTHENTICATED),void d(Error("User must be authenticated before signing with a Privy wallet"));let m=w.address,y=w.walletIndex??0,{entropyId:g,entropyIdVerifier:f}=es(k,w),b=Je.wallets.find((e=>"privy"===e.walletClientType&&v(e.address)===v(m)));if(!b)return mn(ve,p,"onError",K.EMBEDDED_WALLET_NOT_FOUND),void d(Error("Must have a Privy wallet before signing"));let T=await b.getEthereumProvider(),_=await T.request({method:"eth_chainId"}),S=e.chainId?Number(e.chainId):xs(_);(e=>{if(!h.chains.map((e=>e.id)).includes(e))throw new z(`Chain ID ${e} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,K.UNSUPPORTED_CHAIN_ID)})(S);let I={...e,from:e.from??m,chainId:S},P=await ii();if(!P||!ae)return mn(ve,p,"onError",K.EMBEDDED_WALLET_NOT_FOUND),void d(Error("Must have valid access token and Privy wallet to send transaction"));let W=Rn(I.chainId,h.chains,h.rpcConfig,{appId:n.appId}),x=gt(w),U=async({transactionRequest:e})=>{try{let n;if(!await Ye.recoverEmbeddedWallet({address:m}))throw mn(ve,p,"onError",K.UNKNOWN_CONNECT_WALLET_ERROR),d(Error("Unable to connect to wallet")),Error("Unable to connect to wallet");if(t){let t=await(async({transactionRequest:e})=>{if(!x)throw new H("Sponsoring is only supported for wallets on the TEE stack");if(l)throw new H("Cannot sponsor a sign transaction request");let t=e=>null==e?void 0:A(e),n=await E(s,(async({message:e})=>await ae.signWithUserSigner({accessToken:P,requesterAppId:u,message:e})),{chain_type:"ethereum",method:"eth_sendTransaction",caip2:Yn(A(e.chainId)),sponsor:!0,params:{transaction:{from:e.from,to:e.to,chain_id:t(e.chainId),data:C(e.data)?e.data?e.data:A(Uint8Array.from(e.data)):void 0,value:t(e.value)}},wallet_id:w.id});if(n.data&&"hash"in n.data)return n.data.hash;throw new or("Unable to sign transaction")})({transactionRequest:e});return mn(ve,"sendTransaction","onSuccess",{hash:t}),t}if(x){let t=e=>null==e?void 0:A(e),r=await E(s,(async({message:e})=>await ae.signWithUserSigner({accessToken:P,requesterAppId:u,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:C(e.data)?e.data?e.data:A(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:w.id});if(!r.data||!("signed_transaction"in r.data))throw new or("Unable to sign transaction");n=r.data.signed_transaction}else n=await async function({accessToken:e,entropyId:t,entropyIdVerifier:n,transactingWalletIndex:r,walletProxy:a,transactionRequest:i,requesterAppId:s}){return(await a.rpc({entropyId:t,entropyIdVerifier:n,hdWalletIndex:r??0,chainType:"ethereum",accessToken:e,requesterAppId:s,request:{method:"eth_signTransaction",params:[i]}})).response.data}({accessToken:P,entropyId:g,entropyIdVerifier:f,transactingWalletIndex:y,walletProxy:ae,transactionRequest:e,requesterAppId:u});if(l)return mn(ve,"signTransaction","onSuccess",{signature:n}),n;{let e=await W.sendRawTransaction({serializedTransaction:n});return mn(ve,"sendTransaction","onSuccess",{hash:e}),e}}catch(e){throw mn(ve,p,"onError",K.TRANSACTION_FAILURE),e}};if(Ie({showWalletUIs:r?.showWalletUIs})){let e=l||t?I:await ro(I,W,I.from);try{let t=await U({transactionRequest:e});l?mn(ve,"signTransaction","onSuccess",{signature:t}):mn(ve,"sendTransaction","onSuccess",{hash:t}),c({hash:t})}catch(e){mn(ve,p,"onError",K.TRANSACTION_FAILURE),d(e)}}else{let e={connectingWalletAddress:m,recoveryMethod:w.recoveryMethod,entropyId:g,entropyIdVerifier:f,onCompleteNavigateTo:"SendTransactionScreen",isUnifiedWallet:x,onFailure:e=>{mn(ve,p,"onError",K.UNKNOWN_CONNECT_WALLET_ERROR),d(e)}},n=(e=>!!e.fundingConfig&&qs(e.fundingConfig.options).length>=1)(h)?Hs({address:m,appConfig:h,fundWalletConfig:i,methodScreen:"FundingMethodSelectionScreen",chainIdOverride:I.chainId,comingFromSendTransactionScreen:!0}):void 0;le({connectWallet:e,sendTransaction:{transactionRequest:I,transactingWalletIndex:y,transactingWalletAddress:m,entropyId:g,entropyIdVerifier:f,signOnly:l,scanTransaction:async()=>{let e=await ro(I,W,I.from);return await a.scanTransaction({metadata:{domain:h.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})=>U({transactionRequest:e}),onSuccess:e=>{l?mn(ve,"signTransaction","onSuccess",{signature:e.hash}):mn(ve,"sendTransaction","onSuccess",{hash:e.hash}),c(e)},onFailure:e=>{mn(ve,p,"onError",K.TRANSACTION_FAILURE),d(e)},uiOptions:r||{},fundWalletConfig:i,requesterAppId:u},funding:n}),Pe("EmbeddedWalletConnectingScreen")}}));function qe(){return new Promise((async(e,t)=>{let n=await ii();if(!n||!ae)throw Error("Must have valid access token to enroll in MFA");try{await ae.verifyMfa({accessToken:n}),e()}catch(e){t(e)}}))}let Be=e=>e?.linkedAccounts.filter((e=>null!==e.latestVerifiedAt&&!("wallet"===e.type&&"privy"===e.walletClientType))).sort(((e,t)=>t.latestVerifiedAt.getTime()-e.latestVerifiedAt.getTime()))[0],He=e=>{let t=k?.linkedAccounts.filter((t=>t.type===e)).length??0,{displayName:n,loginMethod:r}=Qs(e);if("passkey"===e&&t>=5||"passkey"!==e&&t>=1)throw mn(ve,"linkAccount","onError",K.CANNOT_LINK_MORE_OF_TYPE,{linkMethod:r}),new H(`User already has an account of type ${n} linked.`)};async function $e({showAutomaticRecovery:e=!1,legacySetWalletPasswordFlow:t=!1}){U(null);let n=t?"setWalletPassword":"setWalletRecovery";if(!Ce||!k)throw mn(ve,n,"onError",K.MUST_BE_AUTHENTICATED),Error("User must be authenticated before adding recovery method to Privy wallet");let r=ft(k);if(!r||!ae)throw mn(ve,n,"onError",K.EMBEDDED_WALLET_NOT_FOUND),Error("Must have a Privy wallet to add a recovery method");let a=gt(r);if(a)throw mn(ve,n,"onError",K.UNSUPPORTED_WALLET_TYPE),new H("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 qe()}catch(e){throw mn(ve,n,"onError",K.MISSING_MFA_CREDENTIALS),e}return new Promise(((i,s)=>{let o="user-passcode"===r.recoveryMethod,l=js({walletAction:"update",availableRecoveryMethods:h.embeddedWallets.userOwnedRecoveryOptions,legacySetWalletPasswordFlow:t,isResettingPassword:o,showAutomaticRecovery:e}),{entropyId:c,entropyIdVerifier:d}=es(k),u={recoveryMethod:r.recoveryMethod,connectingWalletAddress:r.address,onCompleteNavigateTo:l,shouldForceMFA:!1,entropyId:c,isUnifiedWallet:a,entropyIdVerifier:d,onFailure:e=>{mn(ve,n,"onError",K.UNKNOWN_CONNECT_WALLET_ERROR),s(e)}};le({setWalletPassword:{onSuccess:e=>{mn(ve,n,"onSuccess",{method:"user-passcode",wallet:e}),i(e)},onFailure:e=>{mn(ve,n,"onError",K.USER_EXITED_SET_PASSWORD_FLOW),s(e)},callAuthOnSuccessOnClose:!1},recoverWallet:{entropyId:c,entropyIdVerifier:d,onFailure:s},connectWallet:u,recoverySelection:{isInAccountCreateFlow:!1,isResettingPassword:o,shouldCreateEth:!1,shouldCreateSol:!1}}),Pe("EmbeddedWalletConnectingScreen")}))}async function Ve({appId:e,action:t,disableSignup:n}){let r=await ii();if("link"===t&&!r)throw mn(ve,"linkAccount","onError",K.MUST_BE_AUTHENTICATED,{linkMethod:`privy:${e}`}),new H("User must be authenticated before linking an account.");if("login"===t&&r)throw mn(ve,"login","onError",K.UNKNOWN_AUTH_ERROR),new H("Attempted to log in, but user is already logged in. Use a `link` helper instead.");_e.current=`privy:${e}`,Ee.current=t;let i=j();return a.createAnalyticsEvent({eventName:"cross_app_auth_started",payload:{providerAppId:e}}),new Promise((async(r,s)=>{let{name:o,logoUrl:l}=await Ms({api:a.api,providerAppId:e,requesterAppId:h.id});le({crossAppAuth:{appId:e,name:o,logoUrl:l,action:t,popup:i,disableSignup:n,onSuccess:r,onError:s}}),Pe("CrossAppAuthScreen")}))}let Ke={ready:y,authenticated:Ce,user:k,walletConnectors:a.connectors||null,connectWallet:e=>{e&&"target"in e&&e&&(e=void 0),le({externalConnectWallet:{walletList:e?.walletList&&e?.walletList.length>0?e.walletList:void 0,walletChainType:e?.walletChainType,description:e?.description,hideHeader:e?.hideHeader}}),Pe("ConnectOnlyLandingScreen")},linkWallet:e=>(e&&"target"in e&&e&&(e=void 0),Fe("siwe"),_e.current="siwe",Ee.current="link",le({...oe,externalConnectWallet:{...oe.externalConnectWallet,walletList:e?.walletList,walletChainType:e?.walletChainType,description:e?.description||`Link a wallet to your ${h?.name} account`}}),Pe("AuthenticateWithWalletScreen")),startCrossAppAuthFlow:Ve,linkEmail:()=>{Fe("email"),He("email"),_e.current="email",Ee.current="link",Pe("LinkEmailScreen")},linkPhone:()=>{Fe("sms"),He("phone"),_e.current="sms",Ee.current="link",Pe("LinkPhoneScreen")},linkGoogle:async()=>{Fe("google"),He("google_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("google")},linkTwitter:async()=>{Fe("twitter"),He("twitter_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("twitter")},linkTwitch:async()=>{Fe("twitch"),He("twitch_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("twitch")},linkDiscord:async()=>{Fe("discord"),He("discord_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("discord")},linkGithub:async()=>{Fe("github"),He("github_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("github")},linkSpotify:async()=>{Fe("spotify"),He("spotify_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("spotify")},linkInstagram:async()=>{Fe("instagram"),He("instagram_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("instagram")},linkTiktok:async()=>{Fe("tiktok"),He("tiktok_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("tiktok")},linkLine:async()=>{Fe("line"),He("line_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("line")},linkLinkedIn:async()=>{Fe("linkedin"),He("linkedin_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("linkedin")},linkApple:async()=>{Fe("apple"),He("apple_oauth"),Ee.current="link",await Ye.initLoginWithOAuth("apple")},linkPasskey:async()=>{Fe("passkey"),He("passkey"),await Ye.initLinkWithPasskey(),Pe("LinkPasskeyScreen")},linkTelegram:async e=>{if(Fe("telegram"),He("telegram"),Ee.current="link",_e.current="telegram",e?.launchParams)if(e.launchParams.initDataRaw){let t=new ti;a.startAuthFlow(t),t.meta.telegramAuthResult=void 0,t.meta.telegramWebAppData=ri(e.launchParams.initDataRaw),le({telegramAuthModalData:{seamlessAuth:!0}}),Pe("TelegramAuthScreen")}else mn(ve,"linkAccount","onError",K.INVALID_DATA,{linkMethod:"telegram"});else await Ye.initLoginWithTelegram();Pe("TelegramAuthScreen")},linkFarcaster:async()=>{Fe("farcaster"),He("farcaster"),await Ye.initLoginWithFarcaster(),Ee.current="link",_e.current="farcaster",Pe("FarcasterConnectStatusScreen")},updateEmail:()=>{if(Fe("email"),!k?.email)throw new H("User does not have an email linked to their account.");Ee.current="update",_e.current="email",Pe("UpdateEmailScreen")},updatePhone:()=>{if(Fe("sms"),!k?.phone)throw new H("User does not have a phone number linked to their account.");Ee.current="update",_e.current="sms",Pe("UpdatePhoneScreen")},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(!y){let e=await new Promise((e=>{de((t=>e.bind(t)))}));if(de(null),e)return void console.warn(t)}!k||k.isGuest?(Ee.current="login",le({login:e}),Pe("LandingScreen")):console.warn(t)},connectOrCreateWallet:async()=>{y||(await new Promise((e=>{de((()=>e))})),de(null)),Ce?console.warn("User must be unauthenticated to `connectOrCreateWallet`"):(Ee.current="connect-or-create",Pe("ConnectOrCreateScreen"))},logout:async()=>{if(Ee.current=null,_e.current=null,k&&a.clearProviderAcccessTokens(k),U(null),await a.logout(),k&&ae)try{await ae.clearMfa({userId:k.id})}catch(e){}T(null),Te(!1),B({status:"initial"}),G({status:"initial"}),F({status:"initial"}),Z({status:"initial"}),te({status:"initial"}),re({status:"initial"}),mn(ve,"logout","onSuccess"),w(!1),ur.del(Xt),ur.del(Rt(h.id))},getAccessToken:c((async()=>{let e=await a.getCustomerAccessToken();return e&&!Ce&&Te(!0),e}),[a,Ce]),unlinkWallet:async e=>{let t;return T(t=e.startsWith("0x")?await a.unlinkEthereumWallet(e):await a.unlinkSolanaWallet(e)),t},unlinkEmail:async e=>{let t=await a.unlinkEmail(e);return T(t),t},unlinkPhone:async e=>{let t=await a.unlinkPhone(e);return T(t),t},unlinkGoogle:async e=>{let t=await a.unlinkOAuth("google",e);return T(t),t},unlinkTwitter:async e=>{let t=await a.unlinkOAuth("twitter",e);return T(t),t},unlinkTwitch:async e=>{let t=await a.unlinkOAuth("twitch",e);return T(t),t},unlinkDiscord:async e=>{let t=await a.unlinkOAuth("discord",e);return T(t),t},unlinkGithub:async e=>{let t=await a.unlinkOAuth("github",e);return T(t),t},unlinkSpotify:async e=>{let t=await a.unlinkOAuth("spotify",e);return T(t),t},unlinkInstagram:async e=>{let t=await a.unlinkOAuth("instagram",e);return T(t),t},unlinkTiktok:async e=>{let t=await a.unlinkOAuth("tiktok",e);return T(t),t},unlinkLine:async e=>{let t=await a.unlinkOAuth("line",e);return T(t),t},unlinkLinkedIn:async e=>{let t=await a.unlinkOAuth("linkedin",e);return T(t),t},unlinkApple:async e=>{let t=await a.unlinkOAuth("apple",e);return T(t),t},unlinkFarcaster:async e=>{let t=await a.unlinkFarcaster(e);return T(t),t},unlinkTelegram:async e=>{let t=await a.unlinkTelegram(e);return T(t),t},unlinkPasskey:async e=>{let t=await ii();if(!t)throw Error("Must have valid access token to enroll in MFA");if(!ae)throw Error("Wallet proxy not initialized.");let n=h.passkeys.shouldUnenrollMfaOnUnlink;await ae.unlinkPasskeyAccount({credentialId:e,accessToken:t,removeAsMfa:n});let r=await a.getAuthenticatedUser();return T(r),r},unlinkCrossAppAccount:async({subject:e})=>{let t=k?.linkedAccounts.find((t=>"cross_app"===t.type&&t.subject===e))?.providerApp;if(!t)throw new H("Invalid subject");a.storeProviderAccessToken(t.id,null);let n=await a.unlinkOAuth(`privy:${t.id}`,e);return T(n),n},setWalletRecovery:async e=>$e({legacySetWalletPasswordFlow:!1,showAutomaticRecovery:e?.showAutomaticRecovery??!1}),setWalletPassword:async()=>$e({legacySetWalletPasswordFlow:!0,showAutomaticRecovery:!1}),signMessage:(e,t)=>new Promise((async(n,r)=>{let{requesterAppId:i}=t?.uiOptions||{},o=e.message,l=t?.address?_t(k,t.address):At(k);if(!l&&void 0!==t?.address){let e=St(go(),t.address);if(e)try{let t=await e.getEthereumProvider(),r=await t.request({method:"personal_sign",params:[o,e.address]});return mn(ve,"signMessage","onSuccess",{signature:r}),void n({signature:r})}catch(e){return mn(ve,"signMessage","onError",K.UNABLE_TO_SIGN),void r(e??new or("Unable to sign message"))}}if(!l)throw new H("No embedded or connected wallet found for address.");if(!Ce||!k)return mn(ve,"signMessage","onError",K.MUST_BE_AUTHENTICATED),void r(Error("User must be authenticated before signing with a Privy wallet"));let c=l.address,d=l.walletIndex??0,{entropyId:u,entropyIdVerifier:h}=es(k,l),p=gt(l);if("string"!=typeof o||o.length<1)return mn(ve,"signMessage","onError",K.INVALID_MESSAGE),void r(Error("Message must be a non-empty string"));let w=async()=>{let t;if(!Ce)throw Error("User must be authenticated before signing with a Privy wallet");let n=await ii();if(!ae||!n||!await Ye.recoverEmbeddedWallet({address:c}))throw Error("Unable to connect to wallet");if(a.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_started",payload:{walletAddress:c,requesterAppId:i}}),p){let r=C(e.message,{strict:!0}),a=await E(s,(async({message:e})=>await ae.signWithUserSigner({accessToken:n,requesterAppId:i,message:e})),{chain_type:"ethereum",method:"personal_sign",params:r?{message:o.slice(2),encoding:"hex"}:{message:o,encoding:"utf-8"},wallet_id:l.id});if(!a.data||!("signature"in a.data))throw new or("Unable to sign message");t=a.data.signature}else{let{response:e}=await ae.rpc({accessToken:n,entropyId:u,entropyIdVerifier:h,chainType:"ethereum",hdWalletIndex:d,requesterAppId:i,request:{method:"personal_sign",params:[o,c]}});t=e.data}return a.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_completed",payload:{walletAddress:c,requesterAppId:i}}),t};if(Ie({showWalletUIs:t?.uiOptions?.showWalletUIs}))try{let e=await w();mn(ve,"signMessage","onSuccess",{signature:e}),n({signature:e})}catch(e){mn(ve,"signMessage","onError",K.UNABLE_TO_SIGN),r(e??new or("Unable to sign message"))}else le({signMessage:{method:"personal_sign",data:o,confirmAndSign:w,onSuccess:e=>{mn(ve,"signMessage","onSuccess",{signature:e}),n({signature:e})},onFailure:e=>{mn(ve,"signMessage","onError",K.UNABLE_TO_SIGN),r(e)},uiOptions:t?.uiOptions||{}},connectWallet:{recoveryMethod:l.recoveryMethod,connectingWalletAddress:c,entropyId:u,entropyIdVerifier:h,onCompleteNavigateTo:"SignRequestScreen",isUnifiedWallet:p,onFailure:e=>{mn(ve,"signMessage","onError",K.UNKNOWN_CONNECT_WALLET_ERROR),r(e)}}}),Pe("EmbeddedWalletConnectingScreen")})),signTypedData:(e,t)=>new Promise((async(n,r)=>{let{requesterAppId:i}=t?.uiOptions||{},o=t?.address?_t(k,t.address):At(k);if(!o&&t?.address){let a=St(go(),t.address);if(a)try{let t=await a.getEthereumProvider(),r=Qn(e),i=await t.request({method:"eth_signTypedData_v4",params:[a.address,r]});return mn(ve,"signTypedData","onSuccess",{signature:i}),void n({signature:i})}catch(e){return mn(ve,"signTypedData","onError",K.UNABLE_TO_SIGN),void r(e??new or("Unable to sign typed data "+e))}}if(!o)throw new H("No embedded or connected wallet found for address.");if(!Ce||!k)return mn(ve,"signTypedData","onError",K.MUST_BE_AUTHENTICATED),void r(Error("User must be authenticated before signing with a Privy wallet"));let l=o.address,c=o.walletIndex??0,{entropyId:d,entropyIdVerifier:u}=es(k,o),h=gt(o),p=Qn(e),w=async()=>{let e;if(!Ce)throw Error("User must be authenticated before signing with a Privy wallet");let t=await ii();if(!ae||!t||!await Ye.recoverEmbeddedWallet({address:l}))throw Error("Unable to connect to wallet");if(a.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_started",payload:{walletAddress:l,requesterAppId:i}}),h){let{domain:n,types:r,primaryType:a,message:l}=p,c=await E(s,(async({message:e})=>await ae.signWithUserSigner({accessToken:t,requesterAppId:i,message:e})),{chain_type:"ethereum",method:"eth_signTypedData_v4",params:{typed_data:{domain:n,types:r,primary_type:a,message:l}},wallet_id:o.id});if(!c.data||!("signature"in c.data))throw new or("Unable to sign message");e=c.data.signature}else{let{response:n}=await ae.rpc({accessToken:t,entropyId:d,entropyIdVerifier:u,chainType:"ethereum",hdWalletIndex:c,requesterAppId:i,request:{method:"eth_signTypedData_v4",params:[l,p]}});e=n.data}return a.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_completed",payload:{walletAddress:l,requesterAppId:i}}),e};if(Ie({showWalletUIs:t?.uiOptions?.showWalletUIs}))try{let e=await w();mn(ve,"signTypedData","onSuccess",{signature:e}),n({signature:e})}catch(e){mn(ve,"signTypedData","onError",K.UNABLE_TO_SIGN),r(e??new or("Unable to sign message"))}else le({signMessage:{method:"eth_signTypedData_v4",data:p,confirmAndSign:w,onSuccess:e=>{mn(ve,"signTypedData","onSuccess",{signature:e}),n({signature:e})},onFailure:e=>{mn(ve,"signTypedData","onError",K.UNABLE_TO_SIGN),r(e)},uiOptions:t?.uiOptions||{}},connectWallet:{recoveryMethod:o.recoveryMethod,connectingWalletAddress:o.address,entropyId:d,isUnifiedWallet:h,entropyIdVerifier:u,onCompleteNavigateTo:"SignRequestScreen",onFailure:e=>{mn(ve,"signMessage","onError",K.UNKNOWN_CONNECT_WALLET_ERROR),r(e)}}}),Pe("EmbeddedWalletConnectingScreen")})),sendTransaction:async(e,t)=>await ze({transaction:e,sponsor:t?.sponsor,uiOptions:t?.uiOptions,fundWalletConfig:t?.fundWalletConfig,address:t?.address,signOnly:!1}),signTransaction:async(e,t)=>({signature:(await ze({transaction:e,uiOptions:t?.uiOptions,address:t?.address,signOnly:!0})).hash}),exportWallet:e=>new Promise((async(t,r)=>{if(!Ce||!k)return void r(Error("User must be authenticated before exporting their Privy wallet"));e&&"target"in e&&e&&(e=void 0);let i=e?.address?_t(k,e.address):At(k);if(!i)return void r(new H("User must have an embedded wallet."));let s=i.address,{entropyId:o,entropyIdVerifier:l}=es(k,i),c=gt(i);if(!s)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(!b(s))return void r(Error("Must provide a valid Ethereum address."));let d={recoveryMethod:i.recoveryMethod,connectingWalletAddress:i.address,isUnifiedWallet:c,entropyId:o,entropyIdVerifier:l,onCompleteNavigateTo:"EmbeddedWalletKeyExportScreen",onFailure:r,shouldForceMFA:!0};le(oe),await ii()&&ae?ae?Ss(i)?(le({keyExport:{appId:n.appId,appClientId:n.clientId,origin:a.apiUrl,address:i.address,entropyId:o,entropyIdVerifier:l,hdWalletIndex:i.walletIndex,chainType:i.chainType,walletId:i.id,isUnifiedWallet:c,imported:i.imported,onSuccess:t,onFailure:r},connectWallet:d}),Pe("EmbeddedWalletConnectingScreen")):r(Error(`Export is not supported for ${i.chainType} wallets`)):r(Error("Must have a Privy wallet before exporting")):r(Error("Must have valid access token to enroll in MFA"))})),promptMfa:qe,async init(e){switch(e){case"sms":return void await a.initMfaSmsVerification();case"passkey":return await a.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 H("Invalid MFA code");ge.current?.resolve({mfaMethod:e,mfaCode:t,relyingParty:window.origin}),await new Promise(((e,t)=>{fe.current={resolve:e,reject:t}}));break;case"passkey":if("string"==typeof t)throw new H("Invalid authenticator response");let n=await import("@simplewebauthn/browser"),r=so(await n.startAuthentication({optionsJSON:t}));ge.current?.resolve({mfaMethod:e,mfaCode:r,relyingParty:window.origin}),await new Promise(((e,t)=>{fe.current={resolve:e,reject:t}}));break;default:throw ge.current?.reject(new H("Unsupported MFA method")),new H(`Unsupported MFA method: ${e}`)}},cancel(){ge.current?.reject(new H("MFA canceled"))},async initEnrollmentWithSms(e){let t=await ii();if(!t||!ae)throw Error("Must have valid access token to enroll in MFA");await ae.initEnrollMfa({method:"sms",accessToken:t,phoneNumber:e.phoneNumber})},enrollInMfa:e=>new Promise(((t,n)=>{if(!e)return Ye.closePrivyModal(),void t();h.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."),le({mfaEnrollmentFlow:{mfaMethods:h.mfa.methods,shouldUnlinkOnUnenrollMfa:h.passkeys.shouldUnlinkOnUnenrollMfa,onSuccess:t,onFailure:n}}),Pe("MfaEnrollmentFlowScreen")})),async initEnrollmentWithTotp(){let e=await ii();if(!e||!ae)throw Error("Must have valid access token to enroll in MFA");let t=await ae.initEnrollMfa({method:"totp",accessToken:e});return{secret:t.secret,authUrl:t.authUrl}},async submitEnrollmentWithSms(e){let t=await ii();if(!t||!ae)throw Error("Must have valid access token to enroll in MFA");await ae.submitEnrollMfa({method:"sms",accessToken:t,phoneNumber:e.phoneNumber,code:e.mfaCode}),T(await a.getAuthenticatedUser())},async submitEnrollmentWithTotp(e){let t=await ii();if(!t||!ae)throw Error("Must have valid access token to enroll in MFA");await ae.submitEnrollMfa({method:"totp",accessToken:t,code:e.mfaCode}),T(await a.getAuthenticatedUser())},async initEnrollmentWithPasskey(){},async submitEnrollmentWithPasskey({credentialIds:e},t={}){let n=await ii();if(!n||!ae)throw Error("Must have valid access token to enroll in MFA");await ae.submitEnrollMfa({method:"passkey",accessToken:n,credentialIds:e,removeForLogin:t.removeForLogin}),T(await a.getAuthenticatedUser())},async unenroll(e,t={}){let n=await ii();if(!n||!ae)throw Error("Must have valid access token to remove MFA");"passkey"===e?await ae.submitEnrollMfa({method:"passkey",accessToken:n,credentialIds:[],removeForLogin:t.removeForLogin}):await ae.unenrollMfa({method:e,accessToken:n}),T(await a.getAuthenticatedUser())},requestFarcasterSignerFromWarpcast:async()=>{let e=await ii(),t=k?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!e)throw Error("Must have valid access token to connect with Farcaster");if(!ae||!t)throw Error("Must have an embedded wallet to use Farcaster signers");if(gt(t))throw new H("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(!k?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await Ye.recoverEmbeddedWallet({address:t.address}))throw Error("Unable to connect to wallet");let n=await ae.initFarcasterSigner({address:t.address,hdWalletIndex:null,accessToken:e,mfaCode:null,mfaMethod:null,relyingParty:window.origin});"approved"===n.status&&T(await a.getAuthenticatedUser()||k||null),le({farcasterSigner:n}),Pe("FarcasterSignerStatusScreen")},getFarcasterSignerPublicKey:async()=>{let e,t=await ii(),n=k?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!ae||!n)throw Error("Must have an embedded wallet to use Farcaster signers");if(gt(n))throw new H("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(!k?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await Ye.recoverEmbeddedWallet({address:n.address}))throw Error("Unable to connect to wallet");if(!k.farcaster?.signerPublicKey)throw Error("Must have a Farcaster signer public key to sign");return e=k.farcaster.signerPublicKey.slice(2),Uint8Array.from(e.match(/.{1,2}/g).map((e=>parseInt(e,16))))},signFarcasterMessage:async e=>{let t=await ii(),n=k?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!ae||!n)throw Error("Must have an embedded wallet to use Farcaster signers");if(gt(n))throw new H("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(!k?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");if(!await Ye.recoverEmbeddedWallet({address:n.address}))throw Error("Unable to connect to wallet");if(!k.farcaster?.signerPublicKey)throw Error("Must have a Farcaster signer public key to sign");let r=await import("@simplewebauthn/browser"),a=await ae.signFarcasterMessage({address:n.address,hdWalletIndex:null,accessToken:t,mfaCode:null,mfaMethod:null,payload:{hash:r.bufferToBase64URLString(e)},fid:BigInt(k.farcaster.fid),relyingParty:window.origin});return new Uint8Array(r.base64URLStringToBuffer(a.signature))},signMessageWithCrossAppWallet(e,{address:t,chainId:n}){let r=k?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return Rs({user:k,client:a,address:t,requesterAppId:h.id,request:{method:r?"privy_signSmartWalletMessage":"personal_sign",params:[e,t],chainId:n},reconnect:Ve})},signTypedDataWithCrossAppWallet(e,{address:t,chainId:n}){let r=k?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t)))),i=Qn(e);return Rs({user:k,client:a,address:t,requesterAppId:h.id,request:{method:r?"privy_signSmartWalletTypedData":"eth_signTypedData_v4",params:[t,i],chainId:n},reconnect:Ve})},sendTransactionWithCrossAppWallet(e,{address:t}){let n=k?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return Rs({user:k,client:a,address:t,requesterAppId:h.id,request:{method:n?"privy_sendSmartWalletTx":"eth_sendTransaction",params:[e],chainId:e.chainId},reconnect:Ve})},signTransactionWithCrossAppWallet(e,{address:t}){let n=k?.linkedAccounts.some((e=>"cross_app"===e.type&&e.smartWallets.some((e=>e.address===t))));return Rs({user:k,client:a,address:t,requesterAppId:h.id,request:{method:n?"privy_signSmartWalletTx":"eth_signTransaction",params:[e],chainId:e.chainId},reconnect:Ve})},isModalOpen:p||!!m,mfaMethods:h.mfa.methods};No=Ke.signMessage,Mo=Ke.signTypedData,Do=async(e,t)=>await ze({transaction:e,...t,signOnly:!1}),Ro=async(e,t)=>({signature:(await ze({transaction:e,...t,signOnly:!0})).hash});let Ge=async e=>{let t,n,r;N(!0),te({status:"loading"}),a.startAuthFlow(new Ca({...e,customOAuthRedirectUrl:h.customOAuthRedirectUrl}));let i=ur.get(jt),s=e.stateCode;if(i!==s)throw a.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:e.provider,storedStateCode:i??"",returnedStateCode:s??""}}),N(!1),new H("Unexpected auth flow. This may be a phishing attempt.",void 0,K.OAUTH_UNEXPECTED);if(null!==await a.getAccessToken())try{({user:t,oAuthTokens:r}=await a.link()),_e.current=e.provider;let n=Be(t);t&&n&&mn(ve,"linkAccount","onSuccess",{user:t,linkMethod:_e.current,linkedAccount:n})}catch(t){throw N(!1),mn(ve,"linkAccount","onError",t.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:e.provider}),t}else try{({user:t,isNewUser:n,oAuthTokens:r}=await a.authenticate()),_e.current=e.provider;let i=Be(t);t&&i&&void 0!==n&&mn(ve,"login","onComplete",{user:t,isNewUser:n,wasAlreadyAuthenticated:!1,loginMethod:_e.current,loginAccount:i})}catch(e){throw N(!1),te({status:"error",error:e}),mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),e}return T(t),W(n||!1),Te(!0),N(!1),te({status:"done"}),r&&t&&mn(ve,"oAuthAuthorization","onOAuthTokenGrant",{oAuthTokens:r,user:t}),t??void 0},Ye={privy:s,setAuthenticated:Te,setUser:T,setIsNewUser:W,isNewUserThisSession:P,pendingTransaction:null,walletConnectionStatus:M,setWalletConnectionStatus:R,connectors:a.connectors?.walletConnectors??[],rpcConfig:h.rpcConfig,chains:h.chains,appId:n.appId,showFiatPrices:"native-token"!==h.embeddedWallets.priceDisplay.primary,clientAnalyticsId:a.clientAnalyticsId,onCustomAuthAuthenticated:We,hideWalletUIs:Se,isHeadlessSigning:c(Ie,[h.embeddedWallets.showWalletUIs]),emailOtpState:L,setEmailOtpState:B,smsOtpState:V,setSmsOtpState:G,oAuthState:Q,setOAuthState:te,telegramAuthState:ne,setTelegramAuthState:re,siweState:Y,setSiweState:Z,isHeadlessOAuthLoading:O,baseAccountSdk:S,setBaseAccountSdk:I,nativeTokenSymbolForChainId:e=>h.chains.find((t=>t.id===Number(e)))?.nativeCurrency.symbol,initializeWalletProxy:async e=>{if(ae)return ae;let t=new Promise((e=>{ue.current=e})),n=new Promise((t=>setTimeout((()=>t(null)),e))),r=await Promise.race([t,n]);return ue.current=null,r},getAuthFlow:()=>a.authFlow,getAuthMeta:()=>a.authFlow?.meta,client:a,closePrivyModal:async(e={shouldCallAuthOnSuccess:!0,isSuccess:!1})=>{let t,r=y&&Ce&&k;if(r&&_e.current&&(t=Be(k)),"login"===Ee.current)e.shouldCallAuthOnSuccess&&r&&_e.current?mn(ve,"login","onComplete",{user:k,isNewUser:P,wasAlreadyAuthenticated:!1,loginMethod:_e.current,loginAccount:t??null}):mn(ve,"login","onError",K.USER_EXITED_AUTH_FLOW);else if("link"===Ee.current&&t)e.isSuccess&&r&&_e.current?mn(ve,"linkAccount","onSuccess",{user:k,linkMethod:_e.current,linkedAccount:t}):_e.current&&mn(ve,"linkAccount","onError",K.USER_EXITED_LINK_FLOW,{linkMethod:_e.current});else if("update"===Ee.current&&t)e.isSuccess&&r&&_e.current?mn(ve,"update","onSuccess",{user:k,updateMethod:_e.current,updatedAccount:t}):_e.current&&mn(ve,"update","onError",K.USER_EXITED_UPDATE_FLOW,{linkMethod:_e.current});else if("connect-or-create"===Ee.current){let e=go();e[0]?mn(ve,"connectOrCreateWallet","onSuccess",{wallet:e[0]}):mn(ve,"connectOrCreateWallet","onError",K.USER_EXITED_AUTH_FLOW)}let i=x&&Gs.has(x),s="ErrorScreen"===x&&oe.errorModalData&&Gs.has(oe.errorModalData.previousScreen);if((i||s)&&oe.funding){let e,t=Gs.get(x)??null;if(s&&oe.funding?.onError){let e=oe.errorModalData?.error,t=e?.privyErrorCode||K.UNKNOWN_FUNDING_ERROR,n=new H(e?.message||"Funding failed",e,t);oe.funding?.onError?.(n)}if("solana"===oe.funding.chainType){let n=h.solanaRpcs[oe.funding.chain];if(!n)return console.warn("Unable to load solana rpc, skipping balance"),mn(ve,"fundSolanaWallet","onUserExited",{address:oe.funding.address,fundingMethod:t,chain:oe.funding.chain,balance:e}),w(!1),void Vs(oe.funding,t);if(o(oo))try{e=await Js({rpc:n.rpc,address:oe.funding.address})}catch{console.error("Unable to pull wallet balance")}else console.warn("Unable to load solana plugin, skipping balance");mn(ve,"fundSolanaWallet","onUserExited",{address:oe.funding.address,fundingMethod:t,chain:oe.funding.chain,balance:e})}else{let r=Rn(oe.funding.chain.id,h.chains,h.rpcConfig,{appId:n.appId});try{e=await r.getBalance({address:oe.funding.address})}catch{console.error("Unable to pull wallet balance")}mn(ve,"fundWallet","onUserExited",{address:oe.funding.address,chain:oe.funding.chain,fundingMethod:t,balance:e}),Vs(oe.funding,t)}}le((e=>({...e,externalConnectWallet:{}}))),Ee.current=null,_e.current=null,W(!1),w(!1),R({status:"disconnected",connectedWallet:null,connector:null,connectError:null,connectRetry:()=>{}}),setTimeout((()=>{a.authFlow=void 0}),200)},openPrivyModal:Pe,connectWallet:Ne,initLoginWithWallet:async(e,t,n,r)=>{hr(e)?(_e.current="siwe",Me(e,t,n)):(_e.current="siws",Re(e,t,n,r))},loginWithWallet:async()=>{let e,t,n;if(!y)throw new X;if(a.authFlow instanceof Ea?e="siwe":a.authFlow instanceof Ya&&(e="siws"),!e)throw new H("Must initialize SIWE/SIWS flow first.");if(null!==await a.getAccessToken())try{({user:t}=await a.link()),_e.current=e}catch(t){throw mn(ve,"linkAccount","onError",t.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}else try{({user:t,isNewUser:n}=await a.authenticate()),_e.current=e}catch(e){throw mn(ve,"login","onError",e.privyErrorCode||K.GENERIC_CONNECT_WALLET_ERROR),e}T(t||k||null),W(n||!1),Te(!0)},delegateWallet:async({address:e,chainType:t,showDelegationUIs:n})=>new Promise((async(r,a)=>{let i=await ii();if(!Ce||!k||!i)throw new H("User must be authenticated and have an embedded wallet to delegate actions.");if("solana"!==t&&"ethereum"!==t)throw new H("Only Solana and Ethereum embedded wallets are supported for delegation and revocation.");let s=Ye.walletProxy??await Ye.initializeWalletProxy(15e3);if(!s)throw new H("Wallet proxy not initialized.");if((({address:e,user:t})=>!!Ws(t).find((t=>t.address===e)))({address:e,user:k}))return r();let o=_t(k,e);if(!o)throw new H("Address to delegate is not associated with current user.");if(gt(o))throw new H("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 l=Is({address:e,user:k}),c=Ps({address:e,user:k}),d=async()=>{await s.createDelegatedAction({accessToken:i,rootWallet:c,delegatedWallets:[l]}),await Ye.refreshSessionAndUser()};if(await Ye.recoverEmbeddedWallet({address:e}),n)le({delegatedActions:{consent:{address:e,onDelegate:d,onSuccess:async()=>{r()},onError:async e=>{a(e)}}}}),Pe("DelegatedActionsConsentScreen");else try{await d(),r()}catch(e){a(e)}})),revokeDelegatedWallets:async({showDelegationUIs:e})=>new Promise((async(t,n)=>{if(!Ce||!k)throw new H("User must be authenticated and have an embedded wallet to revoke a delegated wallet.");let r=Ws(k);if(0===r.length)throw new H("User has no delegated wallets to revoke.");if(r.some(gt))throw new H("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 a.revokeDelegatedWallet(),await Ye.refreshSessionAndUser()};if(e)le({delegatedActions:{revoke:{onRevoke:i,onSuccess:async()=>{t()},onError:async e=>{n(e)}}}}),Pe("DelegatedActionsRevokeScreen");else try{await i(),t()}catch(e){n(e)}})),initLoginWithFarcaster:async(e,t)=>{let n=new Va(e,t);a.startAuthFlow(n);try{_e.current="farcaster",await n.initializeFarcasterConnect()}catch(e){throw"login"===Ee.current?mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR):"link"===Ee.current&&mn(ve,"linkAccount","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR,{linkMethod:"farcaster"}),e}},loginWithFarcaster:async()=>{let e,t;if(!y)throw new X;if(!(a.authFlow instanceof Va))throw new H("Must initialize Farcaster flow first.");if(null!==await a.getAccessToken())try{({user:e}=await a.link()),_e.current="farcaster"}catch(e){throw mn(ve,"linkAccount","onError",e.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:"farcaster"}),e}else try{({user:e,isNewUser:t}=await a.authenticate()),_e.current="farcaster"}catch(e){throw mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),e}T(e||null),W(t||!1),Te(!0)},async crossAppAuthFlow({appId:e,popup:t,action:n,disableSignup:r}){let i=`privy:${e}`;_e.current=i;let{url:s,stateCode:o,codeVerifier:l}=await async function({api:e,appId:t}){let n=va(),r=Aa(),a=await ba(n);try{let{url:i}=await e.post(pe,{provider:`privy:${t}`,redirect_to:window.location.href,code_challenge:a,state_code:r});return{url:i,stateCode:r,codeVerifier:n}}catch(e){throw $(e)}}({api:a.api,appId:e});if(!s)throw a.createAnalyticsEvent({eventName:"cross_app_auth_error",payload:{error:"Unable to open cross-app auth popup",appId:e}}),new H("No authorization URL returned for cross-app auth.");try{let c=await async function({url:e,popup:t}){return t.location=e,new Promise(((e,n)=>{let r,a=setTimeout((()=>{n(new H("Authorization request timed out after 2 minutes.")),i()}),12e4);function i(){t?.close(),window.removeEventListener("message",o)}let s=setInterval((()=>{t?.closed&&!r&&(i(),clearInterval(s),clearTimeout(a),n(new H("User rejected request")))}),300);function o(t){t.data&&("PRIVY_OAUTH_RESPONSE"===t.data.type&&t.data.stateCode&&t.data.authorizationCode&&(clearTimeout(a),e(t.data),i()),"PRIVY_OAUTH_ERROR"===t.data.type&&(clearTimeout(a),n(new H(t.data.error)),i()),t.data.type===Os&&((r=new BroadcastChannel(Us)).onmessage=o))}window.addEventListener("message",o)}))}({url:s,popup:t,provider:i}),d=c.stateCode,u=c.authorizationCode;if(d!==o)throw a.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:i,storedStateCode:o??"",returnedStateCode:d??""}}),new H("Unexpected auth flow. This may be a phishing attempt.",void 0,K.OAUTH_UNEXPECTED);let h=await async function({appId:e,stateCode:t,codeVerifier:n,authorizationCode:r,action:a,client:i,disableSignup:s}){if(!r||!t)throw new H("[Cross-App AuthFlow] Authorization and state codes code must be set prior to calling authenicate.");if("undefined"===r)throw new H("User denied confirmation during cross-app auth flow");try{let o=new Ns({authorizationCode:r,stateCode:t,codeVerifier:n,provider:`privy:${e}`,disableSignup:!!s});i.startAuthFlow(o);let l="link"===a?await i.link():await i.authenticate(),c=l.oAuthTokens?.accessToken;return console.debug(),c}catch(e){let t=$(e);if(t.privyErrorCode===K.ACCOUNT_TRANSFER_REQUIRED)throw t;if(t.privyErrorCode)throw new H(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 H("Invalid code during cross-app auth flow.",void 0,K.OAUTH_USER_DENIED);throw new H("Invalid code during cross-app auth flow.",void 0,K.UNKNOWN_AUTH_ERROR)}}({appId:e,codeVerifier:l,stateCode:d,authorizationCode:u,action:n,client:a,disableSignup:r});h&&a.storeProviderAccessToken(e,h);let p=await Ye.refreshSessionAndUser();if(!p)throw new H("Unable to update user");return a.createAnalyticsEvent({eventName:"cross_app_auth_completed",payload:{providerAppId:e}}),p}catch(e){throw a.createAnalyticsEvent({eventName:"cross_app_auth_error",payload:{error:e.toString(),provider:i}}),e}},async initLoginWithOAuth(e,t,n){if(_e.current=e,!dr())return void Pe("InAppBrowserLoginNotPossible");if("google"===e&&!h.allowOAuthInEmbeddedBrowsers&&Ys(window.navigator.userAgent))return void Pe("InAppBrowserLoginNotPossible");"twitter"===e&&window.opener&&window.opener.postMessage({type:Os},"*"),ur.del(Ft),ur.del(Lt);let r=new Ca({provider:e,disableSignup:!!n,withPrivyUi:!0,customOAuthRedirectUrl:h.customOAuthRedirectUrl});t&&r.addCaptchaToken(t),a.startAuthFlow(r);let i=await a.authFlow.getAuthorizationUrl();if(i&&i.url)if("twitter"===e&&f&&(i.url=i.url.replace("x.com","twitter.com")),"chrome-extension:"===window.location.protocol&&ga())try{let{privyOAuthCode:e,privyOAuthState:t}=await fa(i.url);Pe("OAuthStatusScreen"),r.meta.stateCode=t,r.meta.authorizationCode=e}catch(e){throw console.error("OAuth in chrome extension flow failed:",e),e}else window.location.assign(i.url)},async initLoginWithTelegram(e,t){if(!y)throw new X;_e.current="telegram";let n=new ti(e,t);a.startAuthFlow(n),re({status:"loading"}),n.meta.telegramWebAppData=void 0,n.meta.telegramAuthResult=await new Promise(((e,t)=>h.loginConfig.telegramAuthConfiguration?window.Telegram?void window.Telegram.Login.auth({bot_id:h.loginConfig.telegramAuthConfiguration.botId,request_access:!0},(n=>n?e(n):("link"===Ee.current?mn(ve,"linkAccount","onError",K.FAILED_TO_LINK_ACCOUNT,{linkMethod:"telegram"}):"login"===Ee.current?mn(ve,"login","onError",K.INVALID_CREDENTIALS):"update"===Ee.current&&mn(ve,"login","onError",K.FAILED_TO_UPDATE_ACCOUNT),t(new H("Telegram auth failed or was canceled by the client"))))):t(new H("Telegram was not initialized")):t(new H("Telegram Auth configuration is not loaded"))))},async loginWithTelegram(e){let t,n;if(!(a.authFlow instanceof ti))throw new H("Must initialize Telegram flow before calling loginWithTelegram");a.authFlow.meta.captchaToken||=e?.captchaToken;let r=await ii(),i=e?.intent||Ee.current;if("login"===i)try{let e=await a.authenticate();t=e.user,n=e.isNewUser,_e.current="telegram"}catch(e){throw mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),e}else{if("link"!==i)throw new H("Unknown auth intent");try{t=(await a.link()).user,_e.current="telegram"}catch(e){throw mn(ve,"linkAccount","onError",e.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:"telegram"}),e}}T(t),W(n||!1),Te(!0),re({status:"done"});let s=t?.linkedAccounts.find((({type:e})=>"telegram"===e))||null;return{user:t,isNewUser:n||!1,wasAlreadyAuthenticated:!!r,loginAccount:s}},async loginWithOAuth(e){let t,n,r;if(!(a.authFlow instanceof Ca))throw new H("Must initialize OAuth flow before calling loginWithOAuth");let i=ur.get(jt),s=a.authFlow.meta.stateCode;if(i!==s)throw a.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:e,storedStateCode:i??"",returnedStateCode:s??""}}),new H("Unexpected auth flow. This may be a phishing attempt.",void 0,K.OAUTH_UNEXPECTED);if(null!==await a.getAccessToken())try{let n=await a.link();t=n.user,r=n.oAuthTokens,_e.current=e}catch(t){throw mn(ve,"linkAccount","onError",t.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}else try{let i=await a.authenticate();t=i.user,n=i.isNewUser,r=i.oAuthTokens,_e.current=e}catch(t){throw"login"===Ee.current?mn(ve,"login","onError",t.privyErrorCode||K.UNKNOWN_AUTH_ERROR):"link"===Ee.current&&mn(ve,"linkAccount","onError",t.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:e}),t}return T(t),W(n||!1),Te(!0),r&&t&&mn(ve,"oAuthAuthorization","onOAuthTokenGrant",{oAuthTokens:r,user:t}),r},passkeyAuthState:D,setPasskeyAuthState:F,async initSignupWithPasskey({captchaToken:e,withPrivyUi:t}){let n=new Ka({captchaToken:e,setPasskeyAuthState:F,hints:h.passkeys.registration?.hints});a.startAuthFlow(n),Ee.current="login";try{_e.current="passkey",F({status:"generating-challenge"}),await n.initRegisterFlow(t),F({status:"awaiting-passkey"})}catch(e){throw F({status:"error",error:e}),mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),e}},async signupWithPasskey(){let e,t;if(!y)throw new X;if(!(a.authFlow instanceof Ka))throw new H("Must initialize Passkey flow first.");if("passkey"!==_e.current){let e=new H("Must init login with Passkey flow first.");throw F({status:"error",error:e}),e}let n=await ii();try{_e.current="passkey",F({status:"awaiting-passkey"}),({user:e,isNewUser:t}=await a.authenticate())}catch(e){throw F({status:"error",error:e}),mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),e}T(e),W(t||!1),Te(!0),F({status:"done"});let r=e?.linkedAccounts.find((({type:e})=>"passkey"===e))||null;return{user:e,isNewUser:t||!1,wasAlreadyAuthenticated:!!n,loginAccount:r}},async initLoginWithPasskey({captchaToken:e,withPrivyUi:t}){let n=new Ka({captchaToken:e,setPasskeyAuthState:F,hints:void 0});a.startAuthFlow(n),Ee.current="login";try{_e.current="passkey",F({status:"generating-challenge"}),await n.initAuthenticationFlow(t),F({status:"awaiting-passkey"})}catch(e){throw F({status:"error",error:e}),mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),e}},async loginWithPasskey(e){let t,n;if(!y)throw new X;if(!(a.authFlow instanceof Ka))throw new H("Must initialize Passkey flow first.");if(e?.credentialIds&&(a.authFlow.meta.allowedCredentialsIds=e.credentialIds),"passkey"!==_e.current){let e=new H("Must init login with Passkey flow first.");throw F({status:"error",error:e}),e}let r=await ii();try{_e.current="passkey",F({status:"awaiting-passkey"}),({user:t,isNewUser:n}=await a.authenticate())}catch(e){throw F({status:"error",error:e}),mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),e}T(t),W(n||!1),Te(!0),F({status:"done"});let i=t?.linkedAccounts.find((({type:e})=>"passkey"===e))||null;return{user:t,isNewUser:n||!1,wasAlreadyAuthenticated:!!r,loginAccount:i}},async initLinkWithPasskey(e){let t=new Ka({captchaToken:e,hints:h.passkeys.registration?.hints});a.startAuthFlow(t),Ee.current="link",_e.current="passkey",F({status:"generating-challenge"});try{await t.initLinkFlow(),F({status:"awaiting-passkey"})}catch(e){throw mn(ve,"linkAccount","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR,{linkMethod:"passkey"}),F({status:"error",error:e}),e}},async linkWithPasskey(){let e;if(!y)throw new X;if(!(a.authFlow instanceof Ka))throw new H("Must initialize Passkey flow first.");if("passkey"!==_e.current)throw new H("Must init login with Passkey flow first.");try{_e.current="passkey",({user:e}=await a.link())}catch(e){throw mn(ve,"linkAccount","onError",e.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:"passkey"}),e}return T(e||k||null),F({status:"done"}),e},async initLoginWithHeadlessOAuth(e,t,n){if(!dr())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&&!h.allowOAuthInEmbeddedBrowsers&&Ys(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 r=new Ca({provider:e,withPrivyUi:!1,disableSignup:n??!1,customOAuthRedirectUrl:h.customOAuthRedirectUrl});t&&r.addCaptchaToken(t),te({status:"loading"});let i=await a.startAuthFlow(r).getAuthorizationUrl();if(i?.url)if("chrome-extension:"===window.location.protocol&&ga())try{let{privyOAuthCode:e,privyOAuthState:t}=await fa(i.url);r.meta.stateCode=t,r.meta.authorizationCode=e,await Ge(r.meta)}catch(e){throw te({status:"error",error:e}),e}else window.location.assign(i.url)},loginWithHeadlessOAuth:Ge,initLoginWithEmail:async({email:e,captchaToken:t,disableSignup:n,withPrivyUi:r})=>{let i=new ua({email:e,captchaToken:t,disableSignup:n});a.startAuthFlow(i);try{_e.current="email",B({status:"sending-code"});let e=await i.sendCodeEmail({withPrivyUi:r});if(e?.ssoRedirectUrl)return window.location.href=e.ssoRedirectUrl,void await Bn(1e4);B({status:"awaiting-code-input"})}catch(e){throw B({status:"error",error:e}),"login"===Ee.current?mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR):"link"===Ee.current&&mn(ve,"linkAccount","onError",e.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:"email"}),e}},initUpdateEmail:async({oldAddress:e,newAddress:t,captchaToken:n})=>{let r=new ha(e,t,n);a.startAuthFlow(r);try{await r.sendCodeEmail({withPrivyUi:!0})}catch(e){throw mn(ve,"update","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR,{linkMethod:_e.current}),e}},initUpdatePhone:async(e,t,n)=>{let r=new Ia(e,t,n);a.startAuthFlow(r);try{await r.sendSmsCode({withPrivyUi:!0})}catch(e){mn(ve,"update","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR,{linkMethod:_e.current})}},initLoginWithSms:async({phoneNumber:e,captchaToken:t,disableSignup:n,withPrivyUi:r})=>{G({status:"sending-code"});let i=new Sa({phoneNumber:e,captchaToken:t,disableSignup:n});a.startAuthFlow(i);try{_e.current="sms",await i.sendSmsCode({withPrivyUi:r}),G({status:"awaiting-code-input"})}catch(e){throw G({status:"error",error:e}),"login"===Ee.current?mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR):"link"===Ee.current&&mn(ve,"linkAccount","onError",e.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:"sms"}),e}},resendEmailCode:async()=>{await(a.authFlow?.sendCodeEmail({withPrivyUi:!0}))},resendSmsCode:async()=>{await(a.authFlow?.sendSmsCode({withPrivyUi:!0}))},loginWithCode:async e=>{let t,n;function r(e){a.authFlow instanceof ua?B(e):a.authFlow instanceof Sa&&G(e)}if(r({status:"submitting-code"}),!y){let e=new X;throw r({status:"error",error:e}),e}if(a.authFlow instanceof ua)a.authFlow.meta.emailCode=e.trim();else{if(!(a.authFlow instanceof Sa)){let e=new H("Must initialize a passwordless code flow first");throw r({status:"error",error:e}),e}a.authFlow.meta.smsCode=e.trim()}let i=await ii();if("link"===Ee.current)try{({user:t}=await a.link())}catch(e){throw r({status:"error",error:e}),mn(ve,"linkAccount","onError",e.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:_e.current}),e}else if("update"===Ee.current)try{({user:t}=await a.link())}catch(e){throw r({status:"error",error:e}),mn(ve,"update","onError",e.privyErrorCode||K.FAILED_TO_UPDATE_ACCOUNT,{linkMethod:_e.current}),e}else try{({user:t,isNewUser:n}=await a.authenticate())}catch(e){throw r({status:"error",error:e}),mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),e}let s=t||k;T(s||null),W(n||!1),Te(!0),r({status:"done"});let o=null;return a.authFlow instanceof ua?o=s?.linkedAccounts.find((({type:e})=>"email"===e))||null:a.authFlow instanceof Sa&&(o=s?.linkedAccounts.find((({type:e})=>"phone"===e))||null),{user:s,isNewUser:n||!1,wasAlreadyAuthenticated:!!i,linkedAccount:o}},generateSiweMessage:async({address:e,chainId:t,captchaToken:n})=>{Ee.current=Ce?"link":"login",_e.current="siwe",Z({status:"generating-message"});let r=await a.generateSiweNonce({address:e,captchaToken:n});return Z({status:"awaiting-signature"}),_a({address:e,chainId:t.replace("eip155:",""),nonce:r})},generateSiweMessageForSmartWallet:async({address:e,chainId:t})=>{let n=await a.generateSiweNonce({address:e});return _a({address:e,chainId:t.replace("eip155:",""),nonce:n})},linkSmartWallet:async({message:e,signature:t,smartWalletType:n,smartWalletVersion:r})=>{let i;i=await a.linkSmartWallet({message:e,signature:t,smartWalletType:n,smartWalletVersion:r}),T((i=await Ye.refreshSessionAndUser()??i)||k||null)},loginWithSiwe:async({message:e,signature:t,captchaToken:n,disableSignup:r,walletClientType:i,connectorType:s})=>{let o,l=null;try{if(k)throw Error("User already authenticated");let c=new Ea(a,void 0,n,r,{message:e,signature:t,walletClientType:i,connectorType:s});a.startAuthFlow(c),_e.current="siwe",Ee.current="login",Z({status:"submitting-signature"});let d=await a.authenticate();if(({user:l,isNewUser:o}=d),!l)throw Error("Authentication failed - no user returned")}catch(e){throw mn(ve,"login","onError",e.privyErrorCode||K.UNKNOWN_AUTH_ERROR),Z({status:"error",error:e}),e}return T(l),W(o||!1),Te(!0),Z({status:"done"}),Ee.current=null,_e.current=null,{user:l,isNewUser:o||!1}},linkWithSiwe:async({message:e,signature:t,chainId:n,walletClientType:r,connectorType:i})=>{let s;Fe("siwe");let o=null;try{Z({status:"submitting-signature"}),s=await a.linkWithSiwe({message:e,signature:t,chainId:n,walletClientType:r,connectorType:i}),s=await Ye.refreshSessionAndUser()??s,Z({status:"done"}),(o=Be(s)||null)&&mn(ve,"linkAccount","onSuccess",{user:s,linkMethod:"siwe",linkedAccount:o})}catch(e){throw mn(ve,"linkAccount","onError",e.privyErrorCode||K.FAILED_TO_LINK_ACCOUNT,{linkMethod:"siwe"}),Ee.current=null,_e.current=null,Z({status:"error",error:e}),e}let l=s||k;return T(l||null),Ee.current=null,_e.current=null,{user:l,linkedAccount:o}},refreshSessionAndUser:async()=>{let e=await a.getAuthenticatedUser();return Te(!!e),T(e),e},walletProxy:ae,createAnalyticsEvent:({eventName:e,payload:t,timestamp:n})=>a.createAnalyticsEvent({eventName:e,payload:t,timestamp:n}),acceptTerms:async()=>{let e=await a.acceptTerms();return T(e),e},getUsdTokenPrice:e=>a.getUsdTokenPrice(e),getUsdPriceForSol:()=>a.getUsdPriceForSol(),getSplTokenMetadata:e=>a.getSplTokenMetadata(e),recoverEmbeddedWallet:async e=>new Promise((async(t,n)=>{if(!k)return void t(!0);let r=e?.address?_t(k,e.address):ft(k)||kt(k).at(0)||Ct(k).at(0);if(!r||gt(r))return void t(!0);let i=await ii();if(!i||!ae||!r)return void n(Error("Must have valid access token and Privy wallet to recover wallet"));let{entropyId:s,entropyIdVerifier:o}=es(k,r);try{await ae.connect({accessToken:i,entropyId:s,entropyIdVerifier:o}),t(!0)}catch(e){if(us(e)&&"privy"===r.recoveryMethod){let e;a.createAnalyticsEvent({eventName:"embedded_wallet_pinless_recovery_started",payload:{walletAddress:r.address}});try{e=await ae.recover({entropyId:s,entropyIdVerifier:o,accessToken:i})}catch(e){return void n(e)}e.entropyId||n(Error("Unable to recover wallet")),a.createAnalyticsEvent({eventName:"embedded_wallet_recovery_completed",payload:{walletAddress:r.address}}),t(!0)}else us(e)&&"privy"!==r.recoveryMethod&&"privy-v2"!==r.recoveryMethod?(le({recoverWallet:{entropyId:s,entropyIdVerifier:o,onFailure:n,onSuccess:()=>t(!0)},recoveryOAuthStatus:{provider:r.recoveryMethod,action:"recover",shouldCreateEth:!1,shouldCreateSol:!1}}),Pe(zs(r.recoveryMethod))):n(e)}})),setReadyToTrue:e=>{g(!0),ce?.(e)},updateWallets:()=>je(),fundWallet:async(e,t)=>{let n="FundingMethodSelectionScreen";return new Promise(((r,a)=>{le({funding:{...Hs({address:e,appConfig:h,fundWalletConfig:t,methodScreen:n,onComplete:r,onError:a})}}),Pe(n)}))},openModal:Pe,requestFarcasterSignerStatus:async e=>{let t=await ii(),n=k?.linkedAccounts.find((e=>"wallet"===e.type&&"privy"===e.walletClientType));if(!t)throw Error("Must have valid access token to connect with Farcaster");if(!ae||!n)throw Error("Must have an embedded wallet to use Farcaster signers");if(!k?.farcaster?.fid)throw Error("Must have Farcaster account to use Farcaster signers");let r=await a.requestFarcasterSignerStatus(e);return"approved"===r.status&&T(await a.getAuthenticatedUser()||k||null),r},connectCoinbaseSmartWallet:async()=>{h.externalWallets.coinbaseWallet.config.preference={...h.externalWallets.coinbaseWallet.config.preference,options:"smartWalletOnly"};let e=a.connectors?.findWalletConnector("coinbase_wallet","coinbase_smart_wallet")||a.connectors?.findWalletConnector("coinbase_wallet","coinbase_wallet");if(e)return e.updateConnectionPreference("smartWalletOnly"),Ne(e);await Oe("coinbase_wallet","coinbase_smart_wallet")},connectBaseAccount:async()=>{let e=a.connectors?.findWalletConnector("base_account","base_account");if(e)return Ne(e);await Oe("base_account","base_account")},initiateAccountTransfer:async({nonce:e,account:t,accountType:n,externalWalletMetadata:r,telegramAuthResult:i,telegramWebAppData:s,farcasterEmbeddedAddress:o,oAuthUserInfo:l})=>{let c=await a.sendAccountTransferRequest({nonce:e,account:t,accountType:n,externalWalletMetadata:r,telegramAuthResult:i,telegramWebAppData:s,farcasterEmbeddedAddress:o,oAuthUserInfo:l});return T(c),c},inProgressAuthFlowRef:Ee,inProgressLoginOrLinkMethodRef:_e};Fo=Ye.recoverEmbeddedWallet,Ye.recoverEmbeddedWallet;let Je=u((()=>({wallets:_,ready:he&&Ae})),[_,he,Ae]),Ze=a.authFlow instanceof ti,{siteKey:Qe,enabledProvider:Xe}=h.captcha,et=!h.headless&&Xe&&!Ce&&(y||Ze);/*#__PURE__*/return t(Uo.Provider,{value:!0,children:/*#__PURE__*/t(Tt.Provider,{value:Ke,children:/*#__PURE__*/t(yn.Provider,{value:ve,children:/*#__PURE__*/t(is.Provider,{value:Je,children:/*#__PURE__*/t(Qa,{appId:h.id,captchaSiteKey:Qe,enabledCaptchaProvider:Xe,children:/*#__PURE__*/e(ee.Provider,{value:Ye,children:[/*#__PURE__*/t(uo,{children:/*#__PURE__*/e(Et,{data:oe,setModalData:le,setInitialScreen:U,initialScreen:x,authenticated:Ce,open:p,children:[n.children,/*#__PURE__*/t(xo,{customAuth:h.customAuth}),et&&/*#__PURE__*/t(li,{delayedExecution:!1}),/*#__PURE__*/t(os,{}),/*#__PURE__*/t(io,{disabled:h.embeddedWallets.disableAutomaticMigration}),/*#__PURE__*/t(Ti,{palette:h.appearance.palette||{}}),!h.render.standalone&&/*#__PURE__*/t($i,{open:p})]})}),/*#__PURE__*/t(Es,{appId:n.appId,appClientId:n.clientId,clientAnalyticsId:a.clientAnalyticsId,origin:a.apiUrl,mfaMethods:k?.mfaMethods,mfaPromise:ge,mfaSubmitPromise:fe,onLoad:ie,onLoadFailed:()=>null}),h.loginConfig.telegramAuthConfiguration&&
|
|
358
|
-
/*#__PURE__*/t(Ai,{$if:!0,children:/*#__PURE__*/t(Yi,{scriptHost:n.apiUrl||Zt,botUsername:h.loginConfig.telegramAuthConfiguration.botName})})]})})})})})})},jo=(e,t)=>No(e,t),zo=(e,t)=>Mo(e,t),qo=(e,t)=>Ro(e,t),Bo=(e,t)=>Do(e,t),Ho=e=>Fo(e);export{xs as $,$i as A,li as B,Za as C,ra as D,vr as E,ws as F,wa as G,ms as H,ps as I,Da as J,ja as K,ia as L,ui as M,To as N,ns as O,Ba as P,Eo as Q,ao as R,zn as S,Tn as T,ha as U,mo as V,wr as W,di as X,Di as Y,hr as Z,ta as _,ur as a,jr as a$,ea as a0,zr as a1,Xr as a2,$r as a3,_o as a4,oo as a5,Ha as a6,lo as a7,$s as a8,Ss as a9,gi as aA,pi as aB,Er as aC,Mr as aD,Qr as aE,Tr as aF,Br as aG,Ln as aH,ys as aI,gs as aJ,Xn as aK,jn as aL,Ui as aM,Zn as aN,Rn as aO,ro as aP,cs as aQ,sr as aR,ni as aS,hs as aT,va as aU,Aa as aV,ba as aW,Ao as aX,Ls as aY,Js as aZ,Ks as a_,lr as aa,Wn as ab,_r as ac,or as ad,ar as ae,$a as af,Ya as ag,Bn as ah,na as ai,Mn as aj,Ea as ak,Ta as al,us as am,zs as an,Mi as ao,fi as ap,Ai as aq,vi as ar,bi as as,Ci as at,Qs as au,hi as av,Un as aw,mi as ax,Pn as ay,Fn as az,Lo as b,qn as b0,ts as b1,Ri as b2,Rr as b3,Ys as b4,nr as b5,rr as b6,wi as b7,js as b8,Sr as b9,tr as ba,ii as c,es as d,za as e,Xa as f,La as g,ka as h,ei as i,So as j,so as k,ki as l,ko as m,to as n,ss as o,Ga as p,Dn as q,ca as r,Xs as s,la as t,Oo as u,Wo as v,Io as w,er as x,Is as y,Ps as z};
|