@privy-io/react-auth 1.68.0 → 1.69.0-beta-20240605203856

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/esm/index.js CHANGED
@@ -1,4 +1,4 @@
1
- var vc=(e,t,r)=>{if(!t.has(e))throw TypeError("Cannot "+r)};var xp=(e,t,r)=>(vc(e,t,"read from private field"),r?r.call(e):t.get(e)),Ua=(e,t,r)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,r)},Cc=(e,t,r,o)=>(vc(e,t,"write to private field"),o?o.call(e,r):t.set(e,r),r);var kp=(e,t,r)=>(vc(e,t,"access private method"),r);import{getAddress as Ti}from"@ethersproject/address";import{Web3Provider as Tp}from"@ethersproject/providers";import{createStore as rE}from"mipd";import{useEffect as Nr,useMemo as oE,useRef as Pi,useState as Ze}from"react";import{FetchError as b2}from"ofetch";var ze=class extends Error{constructor(r,o,n){super(r);o instanceof Error&&(this.cause=o),this.privyErrorCode=n}toString(){return`${this.type}${this.privyErrorCode?`-${this.privyErrorCode}`:""}: ${this.message}${this.cause?` [cause: ${this.cause}]`:""}`}},br=class extends ze{constructor(r,o,n,i,a){super(n,i,a);this.type=r;this.status=o}},T=class extends ze{constructor(r,o,n){super(r,o,n);this.type="client_error"}},Fa=class extends T{constructor(){super("Request timed out",void 0,"client_request_timeout")}};var te=class extends ze{constructor(r,o,n){super(r,o,n);this.type="connector_error"}},ne=e=>{if(e instanceof ze)return e;if(!(e instanceof b2))return st(e);if(!e.response)return new br("api_error",null,e.message,e);let{type:t,message:r,error:o,code:n}=e.data;return new br(t||"ApiError",e.response.status,r||o,e,n)},st=e=>e instanceof ze?e:e instanceof Error?new T(e.message,e):new T(`Internal error: ${e}`);var Dr=class extends T{constructor(){super("Method called before `ready`. Ensure you wait until `ready` is true before calling.")}},Tt=class extends T{constructor(t="Embedded wallet error",r){super(t,r,"unknown_embedded_wallet_error")}},Ba=class extends T{constructor(t="User must be authenticated"){super(t,void 0,"must_be_authenticated")}};var lr=class extends T{constructor(t){super("This application is in development mode and must be upgraded to production to log in new users.",t,"max_accounts_reached")}};var Ha="/api/v1/sessions",Ga="/api/v1/sessions/logout",Ap="/api/v1/sessions/fork",Va="/api/v1/sessions/fork/recover",Rp="/api/v1/siwe/init",Ip="/api/v1/siwe/authenticate",Mp="/api/v1/siwe/link",Wp="/api/v1/siwe/unlink",Lp="/api/v1/farcaster/init",Op="/api/v1/farcaster/authenticate",Np="/api/v1/farcaster/link",Dp="/api/v1/farcaster/status",Up="/api/v1/farcaster/unlink",Fp="/api/v1/passwordless/init",Bp="/api/v1/passwordless/authenticate",Hp="/api/v1/passwordless/link",Gp="/api/v1/passwordless/unlink",Vp="/api/v1/passwordless/update",zp="/api/v1/passwordless_sms/init",qp="/api/v1/passwordless_sms/link",$p="/api/v1/passwordless_sms/unlink",Kp="/api/v1/passwordless_sms/authenticate",jp="/api/v1/oauth/init",Yp="/api/v1/oauth/authenticate",Zp="/api/v1/oauth/link",Jp="/api/v1/oauth/unlink",Qp="/api/v1/recovery/oauth/init",Xp="/api/v1/recovery/oauth/init_icloud",eu="/api/v1/recovery/oauth/authenticate",tu="/api/v1/passkeys/link/init",ru="/api/v1/passkeys/authenticate/init",ou="/api/v1/passkeys/link",nu="/api/v1/passkeys/authenticate",iu="/api/v1/passkeys/unlink",au="/api/v1/telegram/authenticate",su="/api/v1/telegram/link",lu="/api/v1/telegram/unlink";var cu="/api/v1/mfa/passwordless_sms/init",du="/api/v1/mfa/passkeys/init",pu="/api/v1/users/me/accept_terms",za="/api/v1/analytics_events",uu="/api/v1/plugins/moonpay_on_ramp/sign",mu="/api/v1/custom_jwt_account/authenticate";var Sn=class{constructor(t){this.meta={token:t}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");try{let t=await this.api.post(mu,{token:this.meta.token});return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){throw new Error("Unimplemented")}};var go=class{constructor(t,r){this.meta={email:t,captchaToken:r}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new T("Email and email code must be set prior to calling authenticate.");try{let t=await this.api.post(Bp,{email:this.meta.email,code:this.meta.emailCode});return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new T("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(Hp,{email:this.meta.email,code:this.meta.emailCode})}catch(t){throw ne(t)}}async sendCodeEmail(t,r){if(!this.api)throw new T("Auth flow has no API instance");if(t&&(this.meta.email=t),r&&(this.meta.captchaToken=r),!this.meta.email)throw new T("Email must be set when initialzing authentication.");try{return await this.api.post(Fp,{email:this.meta.email,token:this.meta.captchaToken})}catch(o){throw ne(o)}}},qa=class extends go{constructor(r,o,n){super(o,n);this.meta={email:o,captchaToken:n,oldAddress:r}}async link(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode||!this.meta.oldAddress)throw new T("Email, email code, and an old email address must be set prior to calling update.");try{return await this.api.post(Vp,{oldAddress:this.meta.oldAddress,newAddress:this.meta.email,code:this.meta.emailCode})}catch(r){throw ne(r)}}};import{isMobile as P2,isIOS as S2}from"react-device-detect";var wc=class{constructor(){this._cache={}}get(t){return this._cache[t]}put(t,r){r!==void 0?this._cache[t]=r:this.del(t)}del(t){delete this._cache[t]}getKeys(){return Object.keys(this._cache)}},$a=class{get(t){let r=localStorage.getItem(t);return r===null?void 0:JSON.parse(r)}put(t,r){r!==void 0?localStorage.setItem(t,JSON.stringify(r)):this.del(t)}del(t){localStorage.removeItem(t)}getKeys(){return Object.entries(localStorage).map(([t])=>t)}};function bc(){try{let e="privy:__session_storage__test",t="blobby",r=new $a;return r.put(e,t),r.del(e),!0}catch{return!1}}function E2(){return typeof window<"u"&&window.localStorage?new $a:new wc}var Z=E2();import{StaticJsonRpcProvider as Si}from"@ethersproject/providers";function fu(){let e=window,t=e.ethereum;if(!t)return[];let r=[];if(t.providers?.length)for(let o of t.providers)o&&r.push(o);return r.push(e.ethereum),r}var Ka=e=>{if(e.isApexWallet)return"Apex Wallet";if(e.isAvalanche)return"Core Wallet";if(e.isBackpack)return"Backpack";if(e.isBifrost)return"Bifrost Wallet";if(e.isBitKeep)return"BitKeep";if(e.isBitski)return"Bitski";if(e.isBlockWallet)return"BlockWallet";if(e.isBraveWallet)return"Brave Wallet";if(e.isClover)return"Clover";if(e.isCoin98)return"Coin98 Wallet";if(e.isCoinbaseWallet)return"Coinbase Wallet";if(e.isDawn)return"Dawn Wallet";if(e.isDefiant)return"Defiant";if(e.isDesig)return"Desig Wallet";if(e.isEnkrypt)return"Enkrypt";if(e.isExodus)return"Exodus";if(e.isFordefi)return"Fordefi";if(e.isFrame)return"Frame";if(e.isFrontier)return"Frontier Wallet";if(e.isGamestop)return"GameStop Wallet";if(e.isHaqqWallet)return"HAQQ Wallet";if(e.isHyperPay)return"HyperPay Wallet";if(e.isImToken)return"ImToken";if(e.isHaloWallet)return"Halo Wallet";if(e.isKuCoinWallet)return"KuCoin Wallet";if(e.isMathWallet)return"MathWallet";if(e.isNovaWallet)return"Nova Wallet";if(e.isOkxWallet||e.isOKExWallet)return"OKX Wallet";if(e.isOneInchIOSWallet||e.isOneInchAndroidWallet)return"1inch Wallet";if(e.isOneKey)return"OneKey Wallet";if(e.isOpera)return"Opera";if(e.isPhantom)return"Phantom";if(e.isPortal)return"Ripio Portal";if(e.isRabby)return"Rabby Wallet";if(e.isRainbow)return"Rainbow";if(e.isSafePal)return"SafePal Wallet";if(e.isStatus)return"Status";if(e.isSubWallet)return"SubWallet";if(e.isTalisman)return"Talisman";if(e.isTally||e.isTaho)return"Taho";if(e.isTokenPocket)return"TokenPocket";if(e.isTokenary)return"Tokenary";if(e.isTrust||e.isTrustWallet)return"Trust Wallet";if(e.isTTWallet)return"TTWallet";if(e.isXDEFI)return"XDEFI Wallet";if(e.isZeal)return"Zeal";if(e.isZerion)return"Zerion";if(e.isMetaMask)return"MetaMask"};var Ec=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||Ka(e)!=="MetaMask")return!1;if(e.providers){for(let r of e.providers)if(!Ec(r))return!1}return!0},vo=()=>!!("phantom"in window&&window?.phantom?.ethereum?.isPhantom),ja=()=>{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};var hu=(e,t)=>{let r=[],o=[];for(let[n,i]of e.entries())n<t?r.push(i):o.push(i);return[r,o]},Ya=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,}))$/),yu=(e,t)=>{let r=e.slice(0),o=[];for(;r.length;)o.push(r.splice(0,t));return o},Co=(e,t=3,r=4)=>{if(!e)return"";let o=2,n=3;if(t+r+o+n>=e.length)return e;let i=e.slice(0,o+t),a=e.slice(e.length-r,e.length);return`${i}...${a}`},Tc=e=>new Promise(t=>setTimeout(t,e));function gu(e,{interval:t=100,timeout:r=5e3}={}){return new Promise((o,n)=>{let i=0,a,l=()=>{if(i>=r){n("Max attempts reached without result");return}if(a=e(),i+=t,a!=null){o(a);return}setTimeout(l,t)};l()})}var _i=(e,t={})=>{let r=t.delayMs||150,o=t.maxAttempts||270;return new Promise(async(n,i)=>{let a=!1,l=0;for(;!a&&l<o;){if(t.abortSignal?.aborted)return;e().then(s=>{a=!0,n(s)},(...s)=>{a=!0,i(...s)}),l+=1,await Tc(r)}a||i(new Error("Exceeded max attempts before resolving function"))})},Za=(e,t,r={},o={})=>{let n=new URL(t,e);for(let[a,l]of Object.entries(r))l!==void 0&&n.searchParams.set(a,l);let i=Object.entries(o);if(i.length>0){let a=new URLSearchParams;for(let[l,s]of i)a.append(l,s);n.hash=a.toString()}return n.href};var vu=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),qo=e=>typeof e=="string"?e:"0x"+e.toString(16);async function Cu(e,t,r,o=3e3){let n=!1,i=window;return new Promise(a=>{i.ethereum?l():(window.addEventListener("ethereum#initialized",l,{once:!0}),setTimeout(()=>{l()},o));function l(){if(n)return;n=!0,window.removeEventListener("ethereum#initialized",l);let s=e.getProviders(),c=[];for(let u of s)t.includes("coinbase_wallet")&&u.info.rdns==="com.coinbase.wallet"||c.push({type:u.info.name.toLowerCase().replace(/\s/g,"_"),eip6963InjectedProvider:u});for(let u of fu()){let h=Ka(u);if(!s.some(f=>f.info.name===h)){if(Ec(u,!0)&&!c.find(f=>f.type==="metamask")){c.push({type:"metamask",legacyInjectedProvider:u});continue}if(h==="Phantom"&&!c.find(f=>f.type==="phantom")){c.push({type:"phantom",legacyInjectedProvider:u});continue}if(h==="Coinbase Wallet"&&!c.find(f=>f.type==="coinbase_wallet"&&r?.coinbaseWallet?.connectionOptions!=="smartWalletOnly")){c.push({type:"coinbase_wallet",legacyInjectedProvider:u});continue}c.find(f=>f.type==="unknown_browser_extension")||c.push({type:"unknown_browser_extension",legacyInjectedProvider:u})}}a(c)}})}function _n(e){return`eip155:${String(Number(e))}`}var wu=(e,t,r,o)=>{let n=Number(e),i=t.find(l=>l.id===n);if(!i)throw new te(`Unsupported chainId ${e}`,4901);let a;if(i.rpcUrls.privyWalletOverride&&i.rpcUrls.privyWalletOverride.http[0])a=i.rpcUrls.privyWalletOverride.http[0];else if(r.rpcUrls&&r.rpcUrls[n])a=r.rpcUrls[n];else if(i.rpcUrls.privy?.http[0]){let l=new URL(i.rpcUrls.privy.http[0]);l.searchParams.append("privyAppId",o),a=l.toString()}else i.rpcUrls.public?.http[0]?a=i.rpcUrls.public.http[0]:a=i.rpcUrls.default?.http[0];if(!a)throw new te(`No RPC url found for ${e}`);return a},bu=(e,t)=>{let r=Number(e),o=t.find(n=>n.id===r);if(!o)throw new te(`Unsupported chainId ${e}`,4901);return o.blockExplorers?.default.url},ro=(e,t,r,o)=>{let n=Number(e),i=t.find(l=>l.id===n);if(!i)throw new te(`Unsupported chainId ${e}`,4901);let a;if(i.rpcUrls.privyWalletOverride&&i.rpcUrls.privyWalletOverride.http[0]?a=new Si(i.rpcUrls.privyWalletOverride.http[0]):r.rpcUrls&&r.rpcUrls[n]?a=new Si(r.rpcUrls[n]):i.rpcUrls.privy?.http[0]?a=new Si({url:i.rpcUrls.privy.http[0],headers:{"privy-app-id":o.appId}}):i.rpcUrls.public?.http[0]?a=new Si(i.rpcUrls.public.http[0]):a=new Si(i.rpcUrls.default?.http[0]),!a)throw new te(`No RPC url found for ${e}`);return a},Ja=e=>{let t={name:"string",version:"string",chainId:"uint256",verifyingContract:"address",salt:"bytes32"},r=e.types.EIP712Domain??Object.entries(e.domain).map(([o,n])=>{if(n!=null&&typeof o=="string"&&o in t)return{name:o,type:t[o]}}).filter(o=>o!==void 0);return{...e,types:{...e.types,EIP712Domain:r}}};var Qa=e=>{let t;try{t=new URL(e).hostname}catch{return}for(let[r,o]of Object.entries(Xa))if(t.includes(o.hostname))return{walletClientType:r,entry:o}};var Xa={metamask:{id:"c57ca95b47569778a828d19178114f4db188b89b763c899ba0be274e97267d96",displayName:"MetaMask",hostname:"metamask.io",mobile:{native:"metamask://",universal:"https://metamask.app.link"}},trust:{id:"4622a2b2d6af1c9844944291e5e7351a6aa24cd7b23099efac1b2fd875da31a0",displayName:"Trust",hostname:"trustwallet.com",mobile:{universal:"https://link.trustwallet.com"}},safe:{id:"225affb176778569276e484e1b92637ad061b01e13a048b35a9d280c3b58970f",displayName:"Safe",hostname:"safe.global",mobile:{universal:"https://app.safe.global/"}},rainbow:{id:"1ae92b26df02f0abca6304df07debccd18262fdf5fe82daa81593582dac9a369",displayName:"Rainbow",hostname:"rainbow.me",mobile:{native:"rainbow://",universal:"https://rnbwapp.com"}},uniswap:{id:"c03dfee351b6fcc421b4494ea33b9d4b92a984f87aa76d1663bb28705e95034a",displayName:"Uniswap",hostname:"uniswap.org",mobile:{universal:"https://uniswap.org/app",native:"uniswap://"}},zerion:{id:"ecc4036f814562b41a5268adc86270fba1365471402006302e70169465b7ac18",displayName:"Zerion",hostname:"zerion.io",mobile:{native:"zerion://",universal:"https://wallet.zerion.io"}},argent:{id:"bc949c5d968ae81310268bf9193f9c9fb7bb4e1283e1284af8f2bd4992535fd6",displayName:"Argent",hostname:"www.argent.xyz",mobile:{universal:"https://www.argent.xyz/app"}},spot:{id:"74f8092562bd79675e276d8b2062a83601a4106d30202f2d509195e30e19673d",displayName:"Spot",hostname:"www.spot-wallet.com",mobile:{universal:"https://spot.so"}},omni:{id:"afbd95522f4041c71dd4f1a065f971fd32372865b416f95a0b1db759ae33f2a7",displayName:"Omni",hostname:"omni.app",mobile:{universal:"https://links.omni.app"}},cryptocom:{id:"f2436c67184f158d1beda5df53298ee84abfc367581e4505134b5bcf5f46697d",displayName:"Crypto.com",hostname:"crypto.com",mobile:{universal:"https://wallet.crypto.com",native:"dfw://"}},blockchain:{id:"84b43e8ddfcd18e5fcb5d21e7277733f9cccef76f7d92c836d0e481db0c70c04",displayName:"Blockchain",hostname:"www.blockchain.com",mobile:{universal:"https://www.blockchain.com"}},safepal:{id:"0b415a746fb9ee99cce155c2ceca0c6f6061b1dbca2d722b3ba16381d0562150",displayName:"SafePal",hostname:"safepal.com",mobile:{universal:"https://link.safepal.io"}},bitkeep:{id:"38f5d18bd8522c244bdd70cb4a68e0e718865155811c043f052fb9f1c51de662",displayName:"BitKeep",hostname:"bitkeep.com",mobile:{universal:"https://bkapp.vip"}},zengo:{id:"9414d5a85c8f4eabc1b5b15ebe0cd399e1a2a9d35643ab0ad22a6e4a32f596f0",displayName:"ZenGo",hostname:"zengo.com",mobile:{universal:"https://get.zengo.com/"}},"1inch":{id:"c286eebc742a537cd1d6818363e9dc53b21759a1e8e5d9b263d0c03ec7703576",displayName:"1inch",hostname:"wallet.1inch.io",mobile:{universal:"https://wallet.1inch.io/wc/"}},binance:{id:"8a0ee50d1f22f6651afcae7eb4253e52a3310b90af5daef78a8c4929a9bb99d4",displayName:"Binance",hostname:"www.binance.com",mobile:{universal:"https://app.binance.com/cedefi"}},exodus:{id:"e9ff15be73584489ca4a66f64d32c4537711797e30b6660dbcb71ea72a42b1f4",displayName:"Exodus",hostname:"exodus.com",mobile:{universal:"https://exodus.com/m"}},mew_wallet:{id:"f5b4eeb6015d66be3f5940a895cbaa49ef3439e518cd771270e6b553b48f31d2",displayName:"MEW wallet",hostname:"mewwallet.com",mobile:{universal:"https://mewwallet.com"}},alphawallet:{id:"138f51c8d00ac7b9ac9d8dc75344d096a7dfe370a568aa167eabc0a21830ed98",displayName:"AlphaWallet",hostname:"alphawallet.com",mobile:{universal:"https://aw.app"}},keyring_pro:{id:"47bb07617af518642f3413a201ec5859faa63acb1dd175ca95085d35d38afb83",displayName:"KEYRING PRO",hostname:"keyring.app",mobile:{universal:"https://keyring.app/"}},mathwallet:{id:"7674bb4e353bf52886768a3ddc2a4562ce2f4191c80831291218ebd90f5f5e26",displayName:"MathWallet",hostname:"mathwallet.org",mobile:{universal:"https://www.mathwallet.org"}},unstoppable:{id:"8308656f4548bb81b3508afe355cfbb7f0cb6253d1cc7f998080601f838ecee3",displayName:"Unstoppable",hostname:"unstoppabledomains.com",mobile:{universal:"https://unstoppabledomains.com/mobile"}},obvious:{id:"031f0187049b7f96c6f039d1c9c8138ff7a17fd75d38b34350c7182232cc29aa",displayName:"Obvious",hostname:"obvious.technology",mobile:{universal:"https://wallet.obvious.technology"}},ambire:{id:"2c81da3add65899baeac53758a07e652eea46dbb5195b8074772c62a77bbf568",displayName:"Ambire",hostname:"www.ambire.com",mobile:{universal:"https://mobile.ambire.com"}},internet_money_wallet:{id:"dd43441a6368ec9046540c46c5fdc58f79926d17ce61a176444568ca7c970dcd",displayName:"Internet Money Wallet",hostname:"internetmoney.io",mobile:{universal:"https://internetmoney.io"}},coin98:{id:"2a3c89040ac3b723a1972a33a125b1db11e258a6975d3a61252cd64e6ea5ea01",displayName:"Coin98",hostname:"coin98.com",mobile:{universal:"https://coin98.services"}},abc_wallet:{id:"b956da9052132e3dabdcd78feb596d5194c99b7345d8c4bd7a47cabdcb69a25f",displayName:"ABC Wallet",hostname:"myabcwallet.io",mobile:{universal:"https://abcwalletconnect.page.link"}},arculus_wallet:{id:"0e4915107da5b3408b38e248f7a710f4529d54cd30e9d12ff0eb886d45c18e92",displayName:"Arculus Wallet",hostname:"www.getarculus.com",mobile:{universal:"https://gw.arculus.co/app"}},haha:{id:"719bd888109f5e8dd23419b20e749900ce4d2fc6858cf588395f19c82fd036b3",displayName:"HaHa",hostname:"www.haha.me",mobile:{universal:"https://haha.me"}},cling_wallet:{id:"942d0e22a7e6b520b0a03abcafc4dbe156a1fc151876e3c4a842f914277278ef",displayName:"Cling Wallet",hostname:"clingon.io",mobile:{universal:"https://cling.carrieverse.com/apple-app-site-association"}},broearn:{id:"8ff6eccefefa7506339201bc33346f92a43118d6ff7d6e71d499d8187a1c56a2",displayName:"Broearn",hostname:"www.broearn.com",mobile:{universal:"https://www.broearn.com/link/wallet/"}},copiosa:{id:"07f99a5d9849bb049d74830012b286f8b238e72b0337933ef22b84947409db80",displayName:"Copiosa",hostname:"copiosa.io",mobile:{universal:"https://copiosa.io/action/"}},burrito_wallet:{id:"8821748c25de9dbc4f72a691b25a6ddad9d7df12fa23333fd9c8b5fdc14cc819",displayName:"Burrito Wallet",hostname:"burritowallet.com",mobile:{universal:"https://burritowallet.com/wc?uri="}},enjin_wallet:{id:"bdc9433ffdaee55d31737d83b931caa1f17e30666f5b8e03eea794bac960eb4a",displayName:"Enjin Wallet",hostname:"enjin.io",mobile:{universal:"https://deeplink.wallet.enjin.io/"}},plasma_wallet:{id:"cbe13eb482c76f1fa401ff4c84d9acd0b8bc9af311ca0620a0b192fb28359b4e",displayName:"Plasma Wallet",hostname:"plasma-wallet.com",mobile:{universal:"https://plasma-wallet.com"}},avacus:{id:"94f785c0c8fb8c4f38cd9cd704416430bcaa2137f27e1468782d624bcd155a43",displayName:"Avacus",hostname:"avacus.cc",mobile:{universal:"https://avacus.app.link"}},bee:{id:"2cca8c1b0bea04ba37dee4017991d348cdb7b826804ab2bd31073254f345b715",displayName:"Bee",hostname:"www.beewallet.app",mobile:{universal:"https://beewallet.app/wc"}},pitaka:{id:"14e5d957c6eb62d3ee8fc6239703ac2d537d7e3552154836ca0beef775f630bc",displayName:"Pitaka",hostname:"pitaka.io",mobile:{universal:"https://app.pitaka.io"}},pltwallet:{id:"576c90ceaea34f29ff0104837cf2b2e23d201be43be1433feeb18d375430e1fd",displayName:"PLTwallet",hostname:"pltwallet.io",mobile:{universal:"https://pltwallet.io/"}},minerva:{id:"49bb9d698dbdf2c3d4627d66f99dd9fe90bba1eec84b143f56c64a51473c60bd",displayName:"Minerva",hostname:"minerva.digital",mobile:{universal:"https://minerva.digital"}},kryptogo:{id:"19418ecfd44963883e4d6abca1adeb2036f3b5ffb9bee0ec61f267a9641f878b",displayName:"KryptoGO",hostname:"kryptogo.com",mobile:{universal:"https://kryptogo.page.link"}},prema:{id:"5b8e33346dfb2a532748c247876db8d596734da8977905a27b947ba1e2cf465b",displayName:"PREMA",hostname:"premanft.com",mobile:{universal:"https://premanft.com"}},slingshot:{id:"d23de318f0f56038c5edb730a083216ff0cce00c1514e619ab32231cc9ec484b",displayName:"Slingshot",hostname:"slingshot.finance",mobile:{universal:"https://app.slingshot.finance"}},kriptonio:{id:"50df7da345f84e5a79aaf617df5167335a4b6751626df2e8a38f07029b3dde7b",displayName:"Kriptonio",hostname:"kriptonio.com",mobile:{universal:"https://app.kriptonio.com/mobile"}},timeless:{id:"9751385960bca290c13b443155288f892f62ee920337eda8c5a8874135daaea8",displayName:"Timeless",hostname:"timelesswallet.xyz",mobile:{universal:"https://timelesswallet.xyz"}},secux:{id:"6464873279d46030c0b6b005b33da6be5ed57a752be3ef1f857dc10eaf8028aa",displayName:"SecuX",hostname:"secuxtech.com",mobile:{universal:"https://wsweb.secuxtech.com"}},bitizen:{id:"41f20106359ff63cf732adf1f7dc1a157176c9b02fd266b50da6dcc1e9b86071",displayName:"Bitizen",hostname:"bitizen.org",mobile:{universal:"https://bitizen.org/wallet"}},blocto:{id:"14e7176536cb3706e221daaa3cfd7b88b7da8c7dfb64d1d241044164802c6bdd",displayName:"Blocto",hostname:"blocto.io",mobile:{universal:"https://blocto.app"}},safemoon:{id:"a0e04f1086aac204d4ebdd5f985c12ed226cd0006323fd8143715f9324da58d1",displayName:"SafeMoon",hostname:"safemoon.com",mobile:{universal:"https://safemoon.com/wc"}},okx_wallet:{id:"971e689d0a5be527bac79629b4ee9b925e82208e5168b733496a09c0faed0709",displayName:"OKX Wallet",hostname:"okx.com",mobile:{native:"okex://main"}},rabby_wallet:{id:"18388be9ac2d02726dbac9777c96efaac06d744b2f6d580fccdd4127a6d01fd1",displayName:"Rabby Wallet",hostname:"rabby.io",mobile:{}}};function T2(e){return{name:e.displayName||"",universalLink:e.mobile.universal,deepLink:e.mobile.native}}function Eu(e,t){let r=T2(t);if(r.deepLink)return xu(r.deepLink,e);if(r.universalLink)return ku(r.universalLink,e);throw new T(`Unsupported wallet ${t.id}`)}var Tu="WALLETCONNECT_DEEPLINK_CHOICE";function Pu(){try{localStorage.removeItem(Tu)}catch{}}function Su({href:e,name:t}){try{localStorage.setItem(Tu,JSON.stringify({href:e,name:t}))}catch{}}function _u(e){return e.startsWith("http://")||e.startsWith("https://")}function xu(e,t){if(_u(e))return ku(e,t);let r=e;r.includes("://")||(r=e.replaceAll("/","").replaceAll(":",""),r=`${r}://`),r.endsWith("/")||(r=`${r}/`);let o=encodeURIComponent(t);return{redirect:`${r}wc?uri=${o}`,href:r}}function ku(e,t){if(!_u(e))return xu(e,t);let r=e;r.endsWith("/")||(r=`${r}/`);let o=encodeURIComponent(t);return{redirect:`${r}wc?uri=${o}`,href:r}}function es(e,t){window.open(e,t,"noreferrer noopener")}var Fe=class{constructor(t){this.promise=null;this.fn=t}execute(t){return this.promise===null&&(this.promise=(async()=>{try{return await this.fn(t)}finally{this.promise=null}})()),this.promise}};var xi=class{constructor(t){this._meta={};this.captchaToken=t,this.startChannelOnce=new Fe(this._startChannelOnce.bind(this)),this.pollForReady=new Fe(this._pollForReady.bind(this))}get meta(){return this._meta}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.channelToken)throw new T("Auth flow must be initialized first");try{let t=await this.api.post(Op,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid});if(!t)throw new T("No response from authentication");return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");try{return await this.api.post(Np,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid})}catch(t){throw ne(t)}}async _startChannelOnce(){if(!this.api)throw new T("Auth flow has no API instance");let t=await this.api.post(Lp,{token:this.captchaToken});P2&&!S2&&t.connect_uri&&es(t.connect_uri,"_blank"),this._meta={connectUri:t.connect_uri,channelToken:t.channel_token}}async initializeFarcasterConnect(){if(!this.api)throw new T("Auth flow has no API instance");await this.startChannelOnce.execute()}async _pollForReady(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.channelToken)throw new T("Auth flow must be initialized first");let t=await this.api.get(Dp,{headers:{"farcaster-channel-token":this.meta.channelToken}});return t.state==="completed"?(this.message=t.message,this.signature=t.signature,this.fid=t.fid,!0):!1}};var Au="1.68.0";var Ru="34357d3c125c2bcf2ce2bc3309d98715",ki="https://auth.privy.io",Iu=2e4,Le=1400,Mu=2500,Pc=Au;var $o="privy:token",Sc="privy-token",ts="privy:refresh_token",Wu="privy-refresh-token",rs="privy-session",Ai="privy:session_transfer_token",x2="privy:wallet",Ri="privy:caid",Ko="privy:state_code",jo="privy:code_verifier",Yo="privy:headless_oauth",os=e=>`${x2}:${e}`,_c="privy:connectors",xc="privy:connections";var Zo=12e4,oo=1,kc="0x1",xn=3e4,Lu="https://api.moonpay.com/v1",Ou="https://api.moonpay.com/v1",Nu="pk_live_hirbpu0cVcLHrjktC9l7fbc9ctjv0SL",Du="pk_test_fqWjXZMSFwloh7orvJsRfjiUHXJqFzI",Uu="0x420000000000000000000000000000000000000F",Fu=["function getL1Fee(bytes memory _data) external view returns (uint256)"],Bu="deprecated";import{base64url as Vu}from"jose";async function Hu(e){let t=new TextEncoder().encode(e),r=await crypto.subtle.digest("SHA-256",t);return new Uint8Array(r)}function Gu(e){return crypto.getRandomValues(new Uint8Array(e))}var k2="S256",A2="S256";function Ii(){return Vu.encode(Gu(36))}function ns(){return Ii()}async function is(e,t=k2){if(t==A2){let r=await Hu(e);return Vu.encode(r)}else return e}function zu(){let e=Z.get(jo);if(!e)throw new T("Authentication error.");return e}function as(){return!!Z.get(Yo)}var Ur=class{constructor(t){let r=typeof t.headless=="boolean"?t.headless:as();this.meta={...t,headless:r}}addCaptchaToken(t){this.meta.captchaToken=t}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new T("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new T("User denied confirmation during OAuth flow");let t=zu();try{let r=await this.api.post(Yp,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:t});return Z.del(jo),this.meta.headless&&Z.del(Yo),{user:r.user,token:r.token,refresh_token:r.refresh_token,is_new_user:r.is_new_user,oauth_provider_tokens:r.oauth_provider_tokens}}catch(r){let o=ne(r);throw o.privyErrorCode?new T(o.message||"Invalid code during OAuth flow.",void 0,o.privyErrorCode):o.message==="User denied confirmation during OAuth flow"?new T("Invalid code during oauth flow.",void 0,"oauth_user_denied"):new T("Invalid code during OAuth flow.",void 0,"unknown_auth_error")}}async link(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new T("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new T("User denied confirmation during OAuth flow");let t=Z.get(jo);if(!t)throw new T("Authentication error.");try{let r=await this.api.post(Zp,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:t});return Z.del(jo),r}catch(r){throw ne(r)}}async getAuthorizationUrl(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.provider)throw new T("Provider must be set when initializing OAuth authentication.");let t=Ii();Z.put(jo,t);let r=ns();Z.put(Ko,r);let o=await is(t);this.meta.headless&&Z.put(Yo,!0);try{return await this.api.post(jp,{provider:this.meta.provider,redirect_to:window.location.href,token:this.meta.captchaToken,code_challenge:o,state_code:r})}catch(n){throw ne(n)}}};function Ac(e){return e.charAt(0).toUpperCase()+e.slice(1)}import{jsx as qu,jsxs as R2}from"react/jsx-runtime";var ss=({style:e,...t})=>R2("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"0px",y:"0px",viewBox:"0 0 24 24",style:{height:"24px",...e},...t,children:[qu("path",{d:"M17.0722 11.6888C17.0471 8.90571 19.3263 7.56847 19.429 7.50274C18.1466 5.60938 16.153 5.35154 15.4417 5.3212C13.7461 5.14678 12.1306 6.32982 11.269 6.32982C10.4074 6.32982 9.08004 5.34648 7.67246 5.37429C5.82158 5.40209 4.11595 6.45874 3.16171 8.13218C1.24068 11.4942 2.6708 16.4817 4.54423 19.2143C5.46091 20.549 6.55041 22.0531 7.98554 21.9975C9.36803 21.9419 9.88905 21.095 11.5571 21.095C13.2251 21.095 13.696 21.9975 15.1537 21.9697C16.6389 21.9393 17.5806 20.6046 18.4897 19.2648C19.5392 17.7153 19.9725 16.2137 19.9975 16.1354C19.965 16.1228 17.1022 15.0155 17.0722 11.6888Z",fill:"currentColor"}),qu("path",{d:"M14.3295 3.51373C15.0909 2.58347 15.6043 1.28921 15.4641 0C14.3671 0.0455014 13.0396 0.738135 12.2532 1.66838C11.5494 2.48994 10.9307 3.80695 11.0986 5.07089C12.3183 5.16694 13.5681 4.44145 14.3295 3.51373Z",fill:"currentColor"})]});import{jsx as Mi,jsxs as I2}from"react/jsx-runtime";var ls=({style:e,...t})=>I2("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"0px",y:"0px",viewBox:"0 0 71 55",style:{height:"24px",...e},...t,children:[Mi("g",{clipPath:"url(#clip0)",children:Mi("path",{d:"M60.1045 4.8978C55.5792 2.8214 50.7265 1.2916 45.6527 0.41542C45.5603 0.39851 45.468 0.440769 45.4204 0.525289C44.7963 1.6353 44.105 3.0834 43.6209 4.2216C38.1637 3.4046 32.7345 3.4046 27.3892 4.2216C26.905 3.0581 26.1886 1.6353 25.5617 0.525289C25.5141 0.443589 25.4218 0.40133 25.3294 0.41542C20.2584 1.2888 15.4057 2.8186 10.8776 4.8978C10.8384 4.9147 10.8048 4.9429 10.7825 4.9795C1.57795 18.7309 -0.943561 32.1443 0.293408 45.3914C0.299005 45.4562 0.335386 45.5182 0.385761 45.5576C6.45866 50.0174 12.3413 52.7249 18.1147 54.5195C18.2071 54.5477 18.305 54.5139 18.3638 54.4378C19.7295 52.5728 20.9469 50.6063 21.9907 48.5383C22.0523 48.4172 21.9935 48.2735 21.8676 48.2256C19.9366 47.4931 18.0979 46.6 16.3292 45.5858C16.1893 45.5041 16.1781 45.304 16.3068 45.2082C16.679 44.9293 17.0513 44.6391 17.4067 44.3461C17.471 44.2926 17.5606 44.2813 17.6362 44.3151C29.2558 49.6202 41.8354 49.6202 53.3179 44.3151C53.3935 44.2785 53.4831 44.2898 53.5502 44.3433C53.9057 44.6363 54.2779 44.9293 54.6529 45.2082C54.7816 45.304 54.7732 45.5041 54.6333 45.5858C52.8646 46.6197 51.0259 47.4931 49.0921 48.2228C48.9662 48.2707 48.9102 48.4172 48.9718 48.5383C50.038 50.6034 51.2554 52.5699 52.5959 54.435C52.6519 54.5139 52.7526 54.5477 52.845 54.5195C58.6464 52.7249 64.529 50.0174 70.6019 45.5576C70.6551 45.5182 70.6887 45.459 70.6943 45.3942C72.1747 30.0791 68.2147 16.7757 60.1968 4.9823C60.1772 4.9429 60.1437 4.9147 60.1045 4.8978ZM23.7259 37.3253C20.2276 37.3253 17.3451 34.1136 17.3451 30.1693C17.3451 26.225 20.1717 23.0133 23.7259 23.0133C27.308 23.0133 30.1626 26.2532 30.1066 30.1693C30.1066 34.1136 27.28 37.3253 23.7259 37.3253ZM47.3178 37.3253C43.8196 37.3253 40.9371 34.1136 40.9371 30.1693C40.9371 26.225 43.7636 23.0133 47.3178 23.0133C50.9 23.0133 53.7545 26.2532 53.6986 30.1693C53.6986 34.1136 50.9 37.3253 47.3178 37.3253Z",fill:"#5865F2"})}),Mi("defs",{children:Mi("clipPath",{id:"clip0",children:Mi("rect",{width:"71",height:"55",fill:"white"})})})]});import{jsx as $u}from"react/jsx-runtime";var cs=({style:e,...t})=>$u("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"24",y:"24",viewBox:"0 0 98 96",style:{height:"24px",...e},...t,children:$u("path",{d:"M48.854 0C21.839 0 0 22 0 49.217c0 21.756 13.993 40.172 33.405 46.69 2.427.49 3.316-1.059 3.316-2.362 0-1.141-.08-5.052-.08-9.127-13.59 2.934-16.42-5.867-16.42-5.867-2.184-5.704-5.42-7.17-5.42-7.17-4.448-3.015.324-3.015.324-3.015 4.934.326 7.523 5.052 7.523 5.052 4.367 7.496 11.404 5.378 14.235 4.074.404-3.178 1.699-5.378 3.074-6.6-10.839-1.141-22.243-5.378-22.243-24.283 0-5.378 1.94-9.778 5.014-13.2-.485-1.222-2.184-6.275.486-13.038 0 0 4.125-1.304 13.426 5.052a46.97 46.97 0 0 1 12.214-1.63c4.125 0 8.33.571 12.213 1.63 9.302-6.356 13.427-5.052 13.427-5.052 2.67 6.763.97 11.816.485 13.038 3.155 3.422 5.015 7.822 5.015 13.2 0 18.905-11.404 23.06-22.324 24.283 1.78 1.548 3.316 4.481 3.316 9.126 0 6.6-.08 11.897-.08 13.526 0 1.304.89 2.853 3.316 2.364 19.412-6.52 33.405-24.935 33.405-46.691C97.707 22 75.788 0 48.854 0z",fill:"currentColor"})});import{jsx as ds,jsxs as M2}from"react/jsx-runtime";var ps=({style:e,...t})=>M2("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"26px",width:"26px",...e},...t,children:[ds("path",{d:"M22.56 12.25C22.56 11.47 22.49 10.72 22.36 10H12V14.255H17.92C17.665 15.63 16.89 16.795 15.725 17.575V20.335H19.28C21.36 18.42 22.56 15.6 22.56 12.25Z",fill:"#4285F4"}),ds("path",{d:"M12 23C14.97 23 17.46 22.015 19.28 20.335L15.725 17.575C14.74 18.235 13.48 18.625 12 18.625C9.13504 18.625 6.71004 16.69 5.84504 14.09H2.17004V16.94C3.98004 20.535 7.70004 23 12 23Z",fill:"#34A853"}),ds("path",{d:"M5.845 14.09C5.625 13.43 5.5 12.725 5.5 12C5.5 11.275 5.625 10.57 5.845 9.91V7.06H2.17C1.4 8.59286 0.999321 10.2846 1 12C1 13.775 1.425 15.455 2.17 16.94L5.845 14.09Z",fill:"#FBBC05"}),ds("path",{d:"M12 5.375C13.615 5.375 15.065 5.93 16.205 7.02L19.36 3.865C17.455 2.09 14.965 1 12 1C7.70004 1 3.98004 3.465 2.17004 7.06L5.84504 9.91C6.71004 7.31 9.13504 5.375 12 5.375Z",fill:"#EA4335"})]});import{jsx as cr,jsxs as us}from"react/jsx-runtime";function ms(e){return us("svg",{xmlns:"http://www.w3.org/2000/svg",xmlnsXlink:"http://www.w3.org/1999/xlink",width:26,height:26,viewBox:"0 0 140 140",x:"0px",y:"0px",fill:"none",...e,children:[us("defs",{children:[us("linearGradient",{id:"b",children:[cr("stop",{offset:"0",stopColor:"#3771c8"}),cr("stop",{stopColor:"#3771c8",offset:".128"}),cr("stop",{offset:"1",stopColor:"#60f",stopOpacity:"0"})]}),us("linearGradient",{id:"a",children:[cr("stop",{offset:"0",stopColor:"#fd5"}),cr("stop",{offset:".1",stopColor:"#fd5"}),cr("stop",{offset:".5",stopColor:"#ff543e"}),cr("stop",{offset:"1",stopColor:"#c837ab"})]}),cr("radialGradient",{id:"c",cx:"158.429",cy:"578.088",r:"65",xlinkHref:"#a",gradientUnits:"userSpaceOnUse",gradientTransform:"matrix(0 -1.98198 1.8439 0 -1031.402 454.004)",fx:"158.429",fy:"578.088"}),cr("radialGradient",{id:"d",cx:"147.694",cy:"473.455",r:"65",xlinkHref:"#b",gradientUnits:"userSpaceOnUse",gradientTransform:"matrix(.17394 .86872 -3.5818 .71718 1648.348 -458.493)",fx:"147.694",fy:"473.455"})]}),cr("path",{fill:"url(#c)",d:"M65.03 0C37.888 0 29.95.028 28.407.156c-5.57.463-9.036 1.34-12.812 3.22-2.91 1.445-5.205 3.12-7.47 5.468C4 13.126 1.5 18.394.595 24.656c-.44 3.04-.568 3.66-.594 19.188-.01 5.176 0 11.988 0 21.125 0 27.12.03 35.05.16 36.59.45 5.42 1.3 8.83 3.1 12.56 3.44 7.14 10.01 12.5 17.75 14.5 2.68.69 5.64 1.07 9.44 1.25 1.61.07 18.02.12 34.44.12 16.42 0 32.84-.02 34.41-.1 4.4-.207 6.955-.55 9.78-1.28 7.79-2.01 14.24-7.29 17.75-14.53 1.765-3.64 2.66-7.18 3.065-12.317.088-1.12.125-18.977.125-36.81 0-17.836-.04-35.66-.128-36.78-.41-5.22-1.305-8.73-3.127-12.44-1.495-3.037-3.155-5.305-5.565-7.624C116.9 4 111.64 1.5 105.372.596 102.335.157 101.73.027 86.19 0H65.03z",transform:"translate(1.004 1)"}),cr("path",{fill:"url(#d)",d:"M65.03 0C37.888 0 29.95.028 28.407.156c-5.57.463-9.036 1.34-12.812 3.22-2.91 1.445-5.205 3.12-7.47 5.468C4 13.126 1.5 18.394.595 24.656c-.44 3.04-.568 3.66-.594 19.188-.01 5.176 0 11.988 0 21.125 0 27.12.03 35.05.16 36.59.45 5.42 1.3 8.83 3.1 12.56 3.44 7.14 10.01 12.5 17.75 14.5 2.68.69 5.64 1.07 9.44 1.25 1.61.07 18.02.12 34.44.12 16.42 0 32.84-.02 34.41-.1 4.4-.207 6.955-.55 9.78-1.28 7.79-2.01 14.24-7.29 17.75-14.53 1.765-3.64 2.66-7.18 3.065-12.317.088-1.12.125-18.977.125-36.81 0-17.836-.04-35.66-.128-36.78-.41-5.22-1.305-8.73-3.127-12.44-1.495-3.037-3.155-5.305-5.565-7.624C116.9 4 111.64 1.5 105.372.596 102.335.157 101.73.027 86.19 0H65.03z",transform:"translate(1.004 1)"}),cr("path",{fill:"#fff",d:"M66.004 18c-13.036 0-14.672.057-19.792.29-5.11.234-8.598 1.043-11.65 2.23-3.157 1.226-5.835 2.866-8.503 5.535-2.67 2.668-4.31 5.346-5.54 8.502-1.19 3.053-2 6.542-2.23 11.65C18.06 51.327 18 52.964 18 66s.058 14.667.29 19.787c.235 5.11 1.044 8.598 2.23 11.65 1.227 3.157 2.867 5.835 5.536 8.503 2.667 2.67 5.345 4.314 8.5 5.54 3.054 1.187 6.543 1.996 11.652 2.23 5.12.233 6.755.29 19.79.29 13.037 0 14.668-.057 19.788-.29 5.11-.234 8.602-1.043 11.656-2.23 3.156-1.226 5.83-2.87 8.497-5.54 2.67-2.668 4.31-5.346 5.54-8.502 1.18-3.053 1.99-6.542 2.23-11.65.23-5.12.29-6.752.29-19.788 0-13.036-.06-14.672-.29-19.792-.24-5.11-1.05-8.598-2.23-11.65-1.23-3.157-2.87-5.835-5.54-8.503-2.67-2.67-5.34-4.31-8.5-5.535-3.06-1.187-6.55-1.996-11.66-2.23-5.12-.233-6.75-.29-19.79-.29zm-4.306 8.65c1.278-.002 2.704 0 4.306 0 12.816 0 14.335.046 19.396.276 4.68.214 7.22.996 8.912 1.653 2.24.87 3.837 1.91 5.516 3.59 1.68 1.68 2.72 3.28 3.592 5.52.657 1.69 1.44 4.23 1.653 8.91.23 5.06.28 6.58.28 19.39s-.05 14.33-.28 19.39c-.214 4.68-.996 7.22-1.653 8.91-.87 2.24-1.912 3.835-3.592 5.514-1.68 1.68-3.275 2.72-5.516 3.59-1.69.66-4.232 1.44-8.912 1.654-5.06.23-6.58.28-19.396.28-12.817 0-14.336-.05-19.396-.28-4.68-.216-7.22-.998-8.913-1.655-2.24-.87-3.84-1.91-5.52-3.59-1.68-1.68-2.72-3.276-3.592-5.517-.657-1.69-1.44-4.23-1.653-8.91-.23-5.06-.276-6.58-.276-19.398s.046-14.33.276-19.39c.214-4.68.996-7.22 1.653-8.912.87-2.24 1.912-3.84 3.592-5.52 1.68-1.68 3.28-2.72 5.52-3.592 1.692-.66 4.233-1.44 8.913-1.655 4.428-.2 6.144-.26 15.09-.27zm29.928 7.97c-3.18 0-5.76 2.577-5.76 5.758 0 3.18 2.58 5.76 5.76 5.76 3.18 0 5.76-2.58 5.76-5.76 0-3.18-2.58-5.76-5.76-5.76zm-25.622 6.73c-13.613 0-24.65 11.037-24.65 24.65 0 13.613 11.037 24.645 24.65 24.645C79.617 90.645 90.65 79.613 90.65 66S79.616 41.35 66.003 41.35zm0 8.65c8.836 0 16 7.163 16 16 0 8.836-7.164 16-16 16-8.837 0-16-7.164-16-16 0-8.837 7.163-16 16-16z"})]})}import{jsx as fs}from"react/jsx-runtime";function hs({style:e,...t}){return fs("svg",{xmlns:"http://www.w3.org/2000/svg",xmlnsXlink:"http://www.w3.org/1999/xlink",viewBox:"0,0,256,256",style:{height:"26px",width:"26px",...e},...t,children:fs("g",{fill:"#0077b5",strokeWidth:"1",strokeLinecap:"butt",strokeLinejoin:"miter",strokeMiterlimit:"10",style:{mixBlendMode:"normal"},children:fs("g",{transform:"scale(5.12,5.12)",children:fs("path",{d:"M41,4h-32c-2.76,0 -5,2.24 -5,5v32c0,2.76 2.24,5 5,5h32c2.76,0 5,-2.24 5,-5v-32c0,-2.76 -2.24,-5 -5,-5zM17,20v19h-6v-19zM11,14.47c0,-1.4 1.2,-2.47 3,-2.47c1.8,0 2.93,1.07 3,2.47c0,1.4 -1.12,2.53 -3,2.53c-1.8,0 -3,-1.13 -3,-2.53zM39,39h-6c0,0 0,-9.26 0,-10c0,-2 -1,-4 -3.5,-4.04h-0.08c-2.42,0 -3.42,2.06 -3.42,4.04c0,0.91 0,10 0,10h-6v-19h6v2.56c0,0 1.93,-2.56 5.81,-2.56c3.97,0 7.19,2.73 7.19,8.26z"})})})})}import{jsx as Ku,jsxs as W2}from"react/jsx-runtime";function ys(e){return W2("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 496 512",...e,children:[Ku("path",{fill:"#1ed760",d:"M248 8C111.1 8 0 119.1 0 256s111.1 248 248 248 248-111.1 248-248S384.9 8 248 8Z"}),Ku("path",{d:"M406.6 231.1c-5.2 0-8.4-1.3-12.9-3.9-71.2-42.5-198.5-52.7-280.9-29.7-3.6 1-8.1 2.6-12.9 2.6-13.2 0-23.3-10.3-23.3-23.6 0-13.6 8.4-21.3 17.4-23.9 35.2-10.3 74.6-15.2 117.5-15.2 73 0 149.5 15.2 205.4 47.8 7.8 4.5 12.9 10.7 12.9 22.6 0 13.6-11 23.3-23.2 23.3zm-31 76.2c-5.2 0-8.7-2.3-12.3-4.2-62.5-37-155.7-51.9-238.6-29.4-4.8 1.3-7.4 2.6-11.9 2.6-10.7 0-19.4-8.7-19.4-19.4s5.2-17.8 15.5-20.7c27.8-7.8 56.2-13.6 97.8-13.6 64.9 0 127.6 16.1 177 45.5 8.1 4.8 11.3 11 11.3 19.7-.1 10.8-8.5 19.5-19.4 19.5zm-26.9 65.6c-4.2 0-6.8-1.3-10.7-3.6-62.4-37.6-135-39.2-206.7-24.5-3.9 1-9 2.6-11.9 2.6-9.7 0-15.8-7.7-15.8-15.8 0-10.3 6.1-15.2 13.6-16.8 81.9-18.1 165.6-16.5 237 26.2 6.1 3.9 9.7 7.4 9.7 16.5s-7.1 15.4-15.2 15.4z"})]})}import{jsx as Rc,jsxs as L2}from"react/jsx-runtime";function gs(e){return L2("svg",{xmlns:"http://www.w3.org/2000/svg",fillRule:"evenodd",clipRule:"evenodd",imageRendering:"optimizeQuality",shapeRendering:"geometricPrecision",textRendering:"geometricPrecision",viewBox:"0 0 293768 333327",width:24,height:24,...e,children:[Rc("path",{fill:"#26f4ee",d:"M204958 0c5369 45832 32829 78170 77253 81022v43471l-287 27V87593c-44424-2850-69965-30183-75333-76015l-47060-1v192819c6791 86790-60835 89368-86703 56462 30342 18977 79608 6642 73766-68039V0h58365zM78515 319644c-26591-5471-50770-21358-64969-44588-34496-56437-3401-148418 96651-157884v54345l-164 27v-40773C17274 145544 7961 245185 33650 286633c9906 15984 26169 27227 44864 33011z"}),Rc("path",{fill:"#fb2c53",d:"M218434 11587c3505 29920 15609 55386 35948 70259-27522-10602-43651-34934-47791-70262l11843 3zm63489 82463c3786 804 7734 1348 11844 1611v51530c-25770 2537-48321-5946-74600-21749l4034 88251c0 28460 106 41467-15166 67648-34260 58734-95927 63376-137628 35401 54529 22502 137077-4810 136916-103049v-96320c26279 15803 48830 24286 74600 21748V94050zm-171890 37247c5390-1122 11048-1985 16998-2548v54345c-21666 3569-35427 10222-41862 22528-20267 38754 5827 69491 35017 74111-33931 5638-73721-28750-49999-74111 6434-12304 18180-18959 39846-22528v-51797zm64479-119719h1808-1808z"}),Rc("path",{d:"M206590 11578c5369 45832 30910 73164 75333 76015v51528c-25770 2539-48321-5945-74600-21748v96320c206 125717-135035 135283-173673 72939-25688-41449-16376-141089 76383-155862v52323c-21666 3569-33412 10224-39846 22528-39762 76035 98926 121273 89342-1225V11577l47060 1z",fill:"#000000"})]})}import{jsx as ju}from"react/jsx-runtime";var vs=({style:e,...t})=>ju("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"24px",width:"24px",...e},...t,children:ju("path",{d:"M 14.285156 10.171875 L 23.222656 0 L 21.105469 0 L 13.34375 8.832031 L 7.148438 0 L 0 0 L 9.371094 13.355469 L 0 24.019531 L 2.117188 24.019531 L 10.308594 14.691406 L 16.851562 24.019531 L 24 24.019531 M 2.878906 1.5625 L 6.132812 1.5625 L 21.101562 22.535156 L 17.851562 22.535156",fill:"currentColor"})});var O2={google:{name:"Google",component:ps},discord:{name:"Discord",component:ls},github:{name:"Github",component:cs},linkedin:{name:"LinkedIn",component:hs},twitter:{name:"Twitter",component:vs},spotify:{name:"Spotify",component:ys},instagram:{name:"Instagram",component:ms},tiktok:{name:"Tiktok",component:gs},apple:{name:"Apple",component:ss}},Wi=e=>O2[e];function Yu(e,t){let r={detail:"",retryable:!1},o=Ac(t);if(e?.privyErrorCode==="linked_to_another_user"&&(r.detail="This account has already been linked to another user."),e?.privyErrorCode==="invalid_credentials"&&(r.retryable=!0,r.detail="Something went wrong. Try again."),e.privyErrorCode==="oauth_user_denied"&&(r.detail=`Retry and check ${o} to finish connecting your account.`,r.retryable=!0),e?.privyErrorCode==="too_many_requests"&&(r.detail="Too many requests. Please wait before trying again."),e?.privyErrorCode==="too_many_requests"&&e.message.includes("provider rate limit")){let n=Wi(t).name;r.detail=`Request limit reached for ${n}. Please wait a moment and try again.`}if(e?.privyErrorCode==="oauth_account_suspended"){let n=Wi(t).name;r.detail=`Your ${n} account is suspended. Please try another login method.`}return r}function Li(){let e=new URLSearchParams(window.location.search),t=e.get("privy_oauth_code"),r=e.get("privy_oauth_state"),o=e.get("privy_oauth_provider");return!t||!r||!o?{inProgress:!1}:{inProgress:!0,authorizationCode:t,stateCode:r,provider:o,headless:as(),popupFlow:window.opener!==null}}function Jo(){let e=new URL(window.location.href);e.searchParams.delete("privy_oauth_code"),e.searchParams.delete("privy_oauth_provider"),e.searchParams.delete("privy_oauth_state"),Z.del(Ko),window.history.replaceState({},"",e)}var Qo=class{constructor(t){this.initAuthenticateOnce=new Fe(this._initAuthenticateOnce.bind(this)),this.initLinkOnce=new Fe(this._initLinkOnce.bind(this)),this.meta={captchaToken:t}}async initAuthenticationFlow(){if(!this.api)throw new T("Auth flow has no API instance");this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute()}async initLinkFlow(){if(!this.api)throw new T("Auth flow has no API instance");this.meta.initLinkResponse=await this.initLinkOnce.execute()}async authenticate(){let t=await import("@simplewebauthn/browser");if(!this.api)throw new T("Auth flow has no API instance");if(!t.browserSupportsWebAuthn())throw new T("WebAuthn is not supported in this browser");this.meta.initAuthenticateResponse||(this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute());try{let r=await t.startAuthentication(this._transformInitAuthenticateOptionsToCamelCase(this.meta.initAuthenticateResponse.options)),o=await this.api.post(nu,{relying_party:this.meta.initAuthenticateResponse.relying_party,challenge:this.meta.initAuthenticateResponse.options.challenge,authenticator_response:this._transformAuthenticationResponseToSnakeCase(r)});return{user:o.user,token:o.token,refresh_token:o.refresh_token,is_new_user:o.is_new_user}}catch(r){throw r.name==="NotAllowedError"?new T("Passkey request timed out or rejected by user.",void 0,"passkey_not_allowed"):ne(r)}}async link(){let t=await import("@simplewebauthn/browser");if(!this.api)throw new T("Auth flow has no API instance");if(!t.browserSupportsWebAuthn())throw new T("WebAuthn is not supported in this browser");this.meta.initLinkResponse||(this.meta.initLinkResponse=await this.initLinkOnce.execute());try{let r=this.meta.initLinkResponse.options,o=await t.startRegistration(this._transformInitLinkOptionsToCamelCase(r));return await this.api.post(ou,{relying_party:this.meta.initLinkResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(o)})}catch(r){throw r.name==="NotAllowedError"?new T("Passkey request timed out or rejected by user.",void 0,"passkey_not_allowed"):ne(r)}}async _initAuthenticateOnce(){if(!this.api)throw new T("Auth flow has no API instance");return await this.api.post(ru,{token:this.meta.captchaToken})}async _initLinkOnce(){if(!this.api)throw new T("Auth flow has no API instance");return await this.api.post(tu,{})}_transformInitLinkOptionsToCamelCase(t){return{rp:t.rp,user:{id:t.user.id,name:t.user.name,displayName:t.user.display_name},challenge:t.challenge,pubKeyCredParams:t.pub_key_cred_params.map(r=>({type:r.type,alg:r.alg})),timeout:t.timeout,excludeCredentials:t.exclude_credentials?.map(r=>({id:r.id,type:r.type,transports:r.transports})),authenticatorSelection:{authenticatorAttachment:t.authenticator_selection?.authenticator_attachment,requireResidentKey:t.authenticator_selection?.require_resident_key,residentKey:t.authenticator_selection?.resident_key,userVerification:t.authenticator_selection?.user_verification},attestation:t.attestation,extensions:{appid:t.extensions?.app_id,credProps:t.extensions?.cred_props?.rk,hmacCreateSecret:t.extensions?.hmac_create_secret}}}_transformRegistrationResponseToSnakeCase(t){return{id:t.id,raw_id:t.rawId,response:{client_data_json:t.response.clientDataJSON,attestation_object:t.response.attestationObject,authenticator_data:t.response.authenticatorData},authenticator_attachment:t.authenticatorAttachment,client_extension_results:{app_id:t.clientExtensionResults.appid,cred_props:t.clientExtensionResults.credProps,hmac_create_secret:t.clientExtensionResults.hmacCreateSecret},type:t.type}}_transformInitAuthenticateOptionsToCamelCase(t){return{challenge:t.challenge,allowCredentials:t.allow_credentials?.map(r=>({id:r.id,type:r.type,transports:r.transports}))||[],timeout:t.timeout,extensions:{appid:t.extensions?.app_id,credProps:t.extensions?.cred_props,hmacCreateSecret:t.extensions?.hmac_create_secret},userVerification:t.user_verification}}_transformAuthenticationResponseToSnakeCase(t){return{id:t.id,raw_id:t.rawId,response:{client_data_json:t.response.clientDataJSON,authenticator_data:t.response.authenticatorData,signature:t.response.signature,user_handle:t.response.userHandle},authenticator_attachment:t.authenticatorAttachment,client_extension_results:{app_id:t.clientExtensionResults.appid,cred_props:t.clientExtensionResults.credProps,hmac_create_secret:t.clientExtensionResults.hmacCreateSecret},type:t.type}}};var Xo=class{constructor(t,r){this.createSiweMessage=(t,r,o,n,i,a,l)=>`${o} wants you to sign in with your Ethereum account:
1
+ var vc=(e,t,r)=>{if(!t.has(e))throw TypeError("Cannot "+r)};var xp=(e,t,r)=>(vc(e,t,"read from private field"),r?r.call(e):t.get(e)),Ua=(e,t,r)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,r)},Cc=(e,t,r,o)=>(vc(e,t,"write to private field"),o?o.call(e,r):t.set(e,r),r);var kp=(e,t,r)=>(vc(e,t,"access private method"),r);import{getAddress as Ti}from"@ethersproject/address";import{Web3Provider as Tp}from"@ethersproject/providers";import{createStore as rE}from"mipd";import{useEffect as Nr,useMemo as oE,useRef as Pi,useState as Ze}from"react";import{isAndroid as nE}from"react-device-detect";import{FetchError as b2}from"ofetch";var ze=class extends Error{constructor(r,o,n){super(r);o instanceof Error&&(this.cause=o),this.privyErrorCode=n}toString(){return`${this.type}${this.privyErrorCode?`-${this.privyErrorCode}`:""}: ${this.message}${this.cause?` [cause: ${this.cause}]`:""}`}},br=class extends ze{constructor(r,o,n,i,a){super(n,i,a);this.type=r;this.status=o}},T=class extends ze{constructor(r,o,n){super(r,o,n);this.type="client_error"}},Fa=class extends T{constructor(){super("Request timed out",void 0,"client_request_timeout")}};var te=class extends ze{constructor(r,o,n){super(r,o,n);this.type="connector_error"}},ne=e=>{if(e instanceof ze)return e;if(!(e instanceof b2))return st(e);if(!e.response)return new br("api_error",null,e.message,e);let{type:t,message:r,error:o,code:n}=e.data;return new br(t||"ApiError",e.response.status,r||o,e,n)},st=e=>e instanceof ze?e:e instanceof Error?new T(e.message,e):new T(`Internal error: ${e}`);var Dr=class extends T{constructor(){super("Method called before `ready`. Ensure you wait until `ready` is true before calling.")}},Tt=class extends T{constructor(t="Embedded wallet error",r){super(t,r,"unknown_embedded_wallet_error")}},Ba=class extends T{constructor(t="User must be authenticated"){super(t,void 0,"must_be_authenticated")}};var lr=class extends T{constructor(t){super("This application is in development mode and must be upgraded to production to log in new users.",t,"max_accounts_reached")}};var Ha="/api/v1/sessions",Ga="/api/v1/sessions/logout",Ap="/api/v1/sessions/fork",Va="/api/v1/sessions/fork/recover",Rp="/api/v1/siwe/init",Ip="/api/v1/siwe/authenticate",Mp="/api/v1/siwe/link",Wp="/api/v1/siwe/unlink",Lp="/api/v1/farcaster/init",Op="/api/v1/farcaster/authenticate",Np="/api/v1/farcaster/link",Dp="/api/v1/farcaster/status",Up="/api/v1/farcaster/unlink",Fp="/api/v1/passwordless/init",Bp="/api/v1/passwordless/authenticate",Hp="/api/v1/passwordless/link",Gp="/api/v1/passwordless/unlink",Vp="/api/v1/passwordless/update",zp="/api/v1/passwordless_sms/init",qp="/api/v1/passwordless_sms/link",$p="/api/v1/passwordless_sms/unlink",Kp="/api/v1/passwordless_sms/authenticate",jp="/api/v1/oauth/init",Yp="/api/v1/oauth/authenticate",Zp="/api/v1/oauth/link",Jp="/api/v1/oauth/unlink",Qp="/api/v1/recovery/oauth/init",Xp="/api/v1/recovery/oauth/init_icloud",eu="/api/v1/recovery/oauth/authenticate",tu="/api/v1/passkeys/link/init",ru="/api/v1/passkeys/authenticate/init",ou="/api/v1/passkeys/link",nu="/api/v1/passkeys/authenticate",iu="/api/v1/passkeys/unlink",au="/api/v1/telegram/authenticate",su="/api/v1/telegram/link",lu="/api/v1/telegram/unlink";var cu="/api/v1/mfa/passwordless_sms/init",du="/api/v1/mfa/passkeys/init",pu="/api/v1/users/me/accept_terms",za="/api/v1/analytics_events",uu="/api/v1/plugins/moonpay_on_ramp/sign",mu="/api/v1/custom_jwt_account/authenticate";var Sn=class{constructor(t){this.meta={token:t}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");try{let t=await this.api.post(mu,{token:this.meta.token});return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){throw new Error("Unimplemented")}};var go=class{constructor(t,r){this.meta={email:t,captchaToken:r}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new T("Email and email code must be set prior to calling authenticate.");try{let t=await this.api.post(Bp,{email:this.meta.email,code:this.meta.emailCode});return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new T("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(Hp,{email:this.meta.email,code:this.meta.emailCode})}catch(t){throw ne(t)}}async sendCodeEmail(t,r){if(!this.api)throw new T("Auth flow has no API instance");if(t&&(this.meta.email=t),r&&(this.meta.captchaToken=r),!this.meta.email)throw new T("Email must be set when initialzing authentication.");try{return await this.api.post(Fp,{email:this.meta.email,token:this.meta.captchaToken})}catch(o){throw ne(o)}}},qa=class extends go{constructor(r,o,n){super(o,n);this.meta={email:o,captchaToken:n,oldAddress:r}}async link(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode||!this.meta.oldAddress)throw new T("Email, email code, and an old email address must be set prior to calling update.");try{return await this.api.post(Vp,{oldAddress:this.meta.oldAddress,newAddress:this.meta.email,code:this.meta.emailCode})}catch(r){throw ne(r)}}};import{isMobile as P2,isIOS as S2}from"react-device-detect";var wc=class{constructor(){this._cache={}}get(t){return this._cache[t]}put(t,r){r!==void 0?this._cache[t]=r:this.del(t)}del(t){delete this._cache[t]}getKeys(){return Object.keys(this._cache)}},$a=class{get(t){let r=localStorage.getItem(t);return r===null?void 0:JSON.parse(r)}put(t,r){r!==void 0?localStorage.setItem(t,JSON.stringify(r)):this.del(t)}del(t){localStorage.removeItem(t)}getKeys(){return Object.entries(localStorage).map(([t])=>t)}};function bc(){try{let e="privy:__session_storage__test",t="blobby",r=new $a;return r.put(e,t),r.del(e),!0}catch{return!1}}function E2(){return typeof window<"u"&&window.localStorage?new $a:new wc}var Z=E2();import{StaticJsonRpcProvider as Si}from"@ethersproject/providers";function fu(){let e=window,t=e.ethereum;if(!t)return[];let r=[];if(t.providers?.length)for(let o of t.providers)o&&r.push(o);return r.push(e.ethereum),r}var Ka=e=>{if(e.isApexWallet)return"Apex Wallet";if(e.isAvalanche)return"Core Wallet";if(e.isBackpack)return"Backpack";if(e.isBifrost)return"Bifrost Wallet";if(e.isBitKeep)return"BitKeep";if(e.isBitski)return"Bitski";if(e.isBlockWallet)return"BlockWallet";if(e.isBraveWallet)return"Brave Wallet";if(e.isClover)return"Clover";if(e.isCoin98)return"Coin98 Wallet";if(e.isCoinbaseWallet)return"Coinbase Wallet";if(e.isDawn)return"Dawn Wallet";if(e.isDefiant)return"Defiant";if(e.isDesig)return"Desig Wallet";if(e.isEnkrypt)return"Enkrypt";if(e.isExodus)return"Exodus";if(e.isFordefi)return"Fordefi";if(e.isFrame)return"Frame";if(e.isFrontier)return"Frontier Wallet";if(e.isGamestop)return"GameStop Wallet";if(e.isHaqqWallet)return"HAQQ Wallet";if(e.isHyperPay)return"HyperPay Wallet";if(e.isImToken)return"ImToken";if(e.isHaloWallet)return"Halo Wallet";if(e.isKuCoinWallet)return"KuCoin Wallet";if(e.isMathWallet)return"MathWallet";if(e.isNovaWallet)return"Nova Wallet";if(e.isOkxWallet||e.isOKExWallet)return"OKX Wallet";if(e.isOneInchIOSWallet||e.isOneInchAndroidWallet)return"1inch Wallet";if(e.isOneKey)return"OneKey Wallet";if(e.isOpera)return"Opera";if(e.isPhantom)return"Phantom";if(e.isPortal)return"Ripio Portal";if(e.isRabby)return"Rabby Wallet";if(e.isRainbow)return"Rainbow";if(e.isSafePal)return"SafePal Wallet";if(e.isStatus)return"Status";if(e.isSubWallet)return"SubWallet";if(e.isTalisman)return"Talisman";if(e.isTally||e.isTaho)return"Taho";if(e.isTokenPocket)return"TokenPocket";if(e.isTokenary)return"Tokenary";if(e.isTrust||e.isTrustWallet)return"Trust Wallet";if(e.isTTWallet)return"TTWallet";if(e.isXDEFI)return"XDEFI Wallet";if(e.isZeal)return"Zeal";if(e.isZerion)return"Zerion";if(e.isMetaMask)return"MetaMask"};var Ec=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||Ka(e)!=="MetaMask")return!1;if(e.providers){for(let r of e.providers)if(!Ec(r))return!1}return!0},vo=()=>!!("phantom"in window&&window?.phantom?.ethereum?.isPhantom),ja=()=>{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};var hu=(e,t)=>{let r=[],o=[];for(let[n,i]of e.entries())n<t?r.push(i):o.push(i);return[r,o]},Ya=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,}))$/),yu=(e,t)=>{let r=e.slice(0),o=[];for(;r.length;)o.push(r.splice(0,t));return o},Co=(e,t=3,r=4)=>{if(!e)return"";let o=2,n=3;if(t+r+o+n>=e.length)return e;let i=e.slice(0,o+t),a=e.slice(e.length-r,e.length);return`${i}...${a}`},Tc=e=>new Promise(t=>setTimeout(t,e));function gu(e,{interval:t=100,timeout:r=5e3}={}){return new Promise((o,n)=>{let i=0,a,l=()=>{if(i>=r){n("Max attempts reached without result");return}if(a=e(),i+=t,a!=null){o(a);return}setTimeout(l,t)};l()})}var _i=(e,t={})=>{let r=t.delayMs||150,o=t.maxAttempts||270;return new Promise(async(n,i)=>{let a=!1,l=0;for(;!a&&l<o;){if(t.abortSignal?.aborted)return;e().then(s=>{a=!0,n(s)},(...s)=>{a=!0,i(...s)}),l+=1,await Tc(r)}a||i(new Error("Exceeded max attempts before resolving function"))})},Za=(e,t,r={},o={})=>{let n=new URL(t,e);for(let[a,l]of Object.entries(r))l!==void 0&&n.searchParams.set(a,l);let i=Object.entries(o);if(i.length>0){let a=new URLSearchParams;for(let[l,s]of i)a.append(l,s);n.hash=a.toString()}return n.href};var vu=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),qo=e=>typeof e=="string"?e:"0x"+e.toString(16);async function Cu(e,t,r,o=3e3){let n=!1,i=window;return new Promise(a=>{i.ethereum?l():(window.addEventListener("ethereum#initialized",l,{once:!0}),setTimeout(()=>{l()},o));function l(){if(n)return;n=!0,window.removeEventListener("ethereum#initialized",l);let s=e.getProviders(),c=[];for(let u of s)t.includes("coinbase_wallet")&&u.info.rdns==="com.coinbase.wallet"||c.push({type:u.info.name.toLowerCase().replace(/\s/g,"_"),eip6963InjectedProvider:u});for(let u of fu()){let h=Ka(u);if(!s.some(f=>f.info.name===h)){if(Ec(u,!0)&&!c.find(f=>f.type==="metamask")){c.push({type:"metamask",legacyInjectedProvider:u});continue}if(h==="Phantom"&&!c.find(f=>f.type==="phantom")){c.push({type:"phantom",legacyInjectedProvider:u});continue}if(h==="Coinbase Wallet"&&!c.find(f=>f.type==="coinbase_wallet"&&r?.coinbaseWallet?.connectionOptions!=="smartWalletOnly")){c.push({type:"coinbase_wallet",legacyInjectedProvider:u});continue}c.find(f=>f.type==="unknown_browser_extension")||c.push({type:"unknown_browser_extension",legacyInjectedProvider:u})}}a(c)}})}function _n(e){return`eip155:${String(Number(e))}`}var wu=(e,t,r,o)=>{let n=Number(e),i=t.find(l=>l.id===n);if(!i)throw new te(`Unsupported chainId ${e}`,4901);let a;if(i.rpcUrls.privyWalletOverride&&i.rpcUrls.privyWalletOverride.http[0])a=i.rpcUrls.privyWalletOverride.http[0];else if(r.rpcUrls&&r.rpcUrls[n])a=r.rpcUrls[n];else if(i.rpcUrls.privy?.http[0]){let l=new URL(i.rpcUrls.privy.http[0]);l.searchParams.append("privyAppId",o),a=l.toString()}else i.rpcUrls.public?.http[0]?a=i.rpcUrls.public.http[0]:a=i.rpcUrls.default?.http[0];if(!a)throw new te(`No RPC url found for ${e}`);return a},bu=(e,t)=>{let r=Number(e),o=t.find(n=>n.id===r);if(!o)throw new te(`Unsupported chainId ${e}`,4901);return o.blockExplorers?.default.url},ro=(e,t,r,o)=>{let n=Number(e),i=t.find(l=>l.id===n);if(!i)throw new te(`Unsupported chainId ${e}`,4901);let a;if(i.rpcUrls.privyWalletOverride&&i.rpcUrls.privyWalletOverride.http[0]?a=new Si(i.rpcUrls.privyWalletOverride.http[0]):r.rpcUrls&&r.rpcUrls[n]?a=new Si(r.rpcUrls[n]):i.rpcUrls.privy?.http[0]?a=new Si({url:i.rpcUrls.privy.http[0],headers:{"privy-app-id":o.appId}}):i.rpcUrls.public?.http[0]?a=new Si(i.rpcUrls.public.http[0]):a=new Si(i.rpcUrls.default?.http[0]),!a)throw new te(`No RPC url found for ${e}`);return a},Ja=e=>{let t={name:"string",version:"string",chainId:"uint256",verifyingContract:"address",salt:"bytes32"},r=e.types.EIP712Domain??Object.entries(e.domain).map(([o,n])=>{if(n!=null&&typeof o=="string"&&o in t)return{name:o,type:t[o]}}).filter(o=>o!==void 0);return{...e,types:{...e.types,EIP712Domain:r}}};var Qa=e=>{let t;try{t=new URL(e).hostname}catch{return}for(let[r,o]of Object.entries(Xa))if(t.includes(o.hostname))return{walletClientType:r,entry:o}};var Xa={metamask:{id:"c57ca95b47569778a828d19178114f4db188b89b763c899ba0be274e97267d96",displayName:"MetaMask",hostname:"metamask.io",mobile:{native:"metamask://",universal:"https://metamask.app.link"}},trust:{id:"4622a2b2d6af1c9844944291e5e7351a6aa24cd7b23099efac1b2fd875da31a0",displayName:"Trust",hostname:"trustwallet.com",mobile:{universal:"https://link.trustwallet.com"}},safe:{id:"225affb176778569276e484e1b92637ad061b01e13a048b35a9d280c3b58970f",displayName:"Safe",hostname:"safe.global",mobile:{universal:"https://app.safe.global/"}},rainbow:{id:"1ae92b26df02f0abca6304df07debccd18262fdf5fe82daa81593582dac9a369",displayName:"Rainbow",hostname:"rainbow.me",mobile:{native:"rainbow://",universal:"https://rnbwapp.com"}},uniswap:{id:"c03dfee351b6fcc421b4494ea33b9d4b92a984f87aa76d1663bb28705e95034a",displayName:"Uniswap",hostname:"uniswap.org",mobile:{universal:"https://uniswap.org/app",native:"uniswap://"}},zerion:{id:"ecc4036f814562b41a5268adc86270fba1365471402006302e70169465b7ac18",displayName:"Zerion",hostname:"zerion.io",mobile:{native:"zerion://",universal:"https://wallet.zerion.io"}},argent:{id:"bc949c5d968ae81310268bf9193f9c9fb7bb4e1283e1284af8f2bd4992535fd6",displayName:"Argent",hostname:"www.argent.xyz",mobile:{universal:"https://www.argent.xyz/app"}},spot:{id:"74f8092562bd79675e276d8b2062a83601a4106d30202f2d509195e30e19673d",displayName:"Spot",hostname:"www.spot-wallet.com",mobile:{universal:"https://spot.so"}},omni:{id:"afbd95522f4041c71dd4f1a065f971fd32372865b416f95a0b1db759ae33f2a7",displayName:"Omni",hostname:"omni.app",mobile:{universal:"https://links.omni.app"}},cryptocom:{id:"f2436c67184f158d1beda5df53298ee84abfc367581e4505134b5bcf5f46697d",displayName:"Crypto.com",hostname:"crypto.com",mobile:{universal:"https://wallet.crypto.com",native:"dfw://"}},blockchain:{id:"84b43e8ddfcd18e5fcb5d21e7277733f9cccef76f7d92c836d0e481db0c70c04",displayName:"Blockchain",hostname:"www.blockchain.com",mobile:{universal:"https://www.blockchain.com"}},safepal:{id:"0b415a746fb9ee99cce155c2ceca0c6f6061b1dbca2d722b3ba16381d0562150",displayName:"SafePal",hostname:"safepal.com",mobile:{universal:"https://link.safepal.io"}},bitkeep:{id:"38f5d18bd8522c244bdd70cb4a68e0e718865155811c043f052fb9f1c51de662",displayName:"BitKeep",hostname:"bitkeep.com",mobile:{universal:"https://bkapp.vip"}},zengo:{id:"9414d5a85c8f4eabc1b5b15ebe0cd399e1a2a9d35643ab0ad22a6e4a32f596f0",displayName:"ZenGo",hostname:"zengo.com",mobile:{universal:"https://get.zengo.com/"}},"1inch":{id:"c286eebc742a537cd1d6818363e9dc53b21759a1e8e5d9b263d0c03ec7703576",displayName:"1inch",hostname:"wallet.1inch.io",mobile:{universal:"https://wallet.1inch.io/wc/"}},binance:{id:"8a0ee50d1f22f6651afcae7eb4253e52a3310b90af5daef78a8c4929a9bb99d4",displayName:"Binance",hostname:"www.binance.com",mobile:{universal:"https://app.binance.com/cedefi"}},exodus:{id:"e9ff15be73584489ca4a66f64d32c4537711797e30b6660dbcb71ea72a42b1f4",displayName:"Exodus",hostname:"exodus.com",mobile:{universal:"https://exodus.com/m"}},mew_wallet:{id:"f5b4eeb6015d66be3f5940a895cbaa49ef3439e518cd771270e6b553b48f31d2",displayName:"MEW wallet",hostname:"mewwallet.com",mobile:{universal:"https://mewwallet.com"}},alphawallet:{id:"138f51c8d00ac7b9ac9d8dc75344d096a7dfe370a568aa167eabc0a21830ed98",displayName:"AlphaWallet",hostname:"alphawallet.com",mobile:{universal:"https://aw.app"}},keyring_pro:{id:"47bb07617af518642f3413a201ec5859faa63acb1dd175ca95085d35d38afb83",displayName:"KEYRING PRO",hostname:"keyring.app",mobile:{universal:"https://keyring.app/"}},mathwallet:{id:"7674bb4e353bf52886768a3ddc2a4562ce2f4191c80831291218ebd90f5f5e26",displayName:"MathWallet",hostname:"mathwallet.org",mobile:{universal:"https://www.mathwallet.org"}},unstoppable:{id:"8308656f4548bb81b3508afe355cfbb7f0cb6253d1cc7f998080601f838ecee3",displayName:"Unstoppable",hostname:"unstoppabledomains.com",mobile:{universal:"https://unstoppabledomains.com/mobile"}},obvious:{id:"031f0187049b7f96c6f039d1c9c8138ff7a17fd75d38b34350c7182232cc29aa",displayName:"Obvious",hostname:"obvious.technology",mobile:{universal:"https://wallet.obvious.technology"}},ambire:{id:"2c81da3add65899baeac53758a07e652eea46dbb5195b8074772c62a77bbf568",displayName:"Ambire",hostname:"www.ambire.com",mobile:{universal:"https://mobile.ambire.com"}},internet_money_wallet:{id:"dd43441a6368ec9046540c46c5fdc58f79926d17ce61a176444568ca7c970dcd",displayName:"Internet Money Wallet",hostname:"internetmoney.io",mobile:{universal:"https://internetmoney.io"}},coin98:{id:"2a3c89040ac3b723a1972a33a125b1db11e258a6975d3a61252cd64e6ea5ea01",displayName:"Coin98",hostname:"coin98.com",mobile:{universal:"https://coin98.services"}},abc_wallet:{id:"b956da9052132e3dabdcd78feb596d5194c99b7345d8c4bd7a47cabdcb69a25f",displayName:"ABC Wallet",hostname:"myabcwallet.io",mobile:{universal:"https://abcwalletconnect.page.link"}},arculus_wallet:{id:"0e4915107da5b3408b38e248f7a710f4529d54cd30e9d12ff0eb886d45c18e92",displayName:"Arculus Wallet",hostname:"www.getarculus.com",mobile:{universal:"https://gw.arculus.co/app"}},haha:{id:"719bd888109f5e8dd23419b20e749900ce4d2fc6858cf588395f19c82fd036b3",displayName:"HaHa",hostname:"www.haha.me",mobile:{universal:"https://haha.me"}},cling_wallet:{id:"942d0e22a7e6b520b0a03abcafc4dbe156a1fc151876e3c4a842f914277278ef",displayName:"Cling Wallet",hostname:"clingon.io",mobile:{universal:"https://cling.carrieverse.com/apple-app-site-association"}},broearn:{id:"8ff6eccefefa7506339201bc33346f92a43118d6ff7d6e71d499d8187a1c56a2",displayName:"Broearn",hostname:"www.broearn.com",mobile:{universal:"https://www.broearn.com/link/wallet/"}},copiosa:{id:"07f99a5d9849bb049d74830012b286f8b238e72b0337933ef22b84947409db80",displayName:"Copiosa",hostname:"copiosa.io",mobile:{universal:"https://copiosa.io/action/"}},burrito_wallet:{id:"8821748c25de9dbc4f72a691b25a6ddad9d7df12fa23333fd9c8b5fdc14cc819",displayName:"Burrito Wallet",hostname:"burritowallet.com",mobile:{universal:"https://burritowallet.com/wc?uri="}},enjin_wallet:{id:"bdc9433ffdaee55d31737d83b931caa1f17e30666f5b8e03eea794bac960eb4a",displayName:"Enjin Wallet",hostname:"enjin.io",mobile:{universal:"https://deeplink.wallet.enjin.io/"}},plasma_wallet:{id:"cbe13eb482c76f1fa401ff4c84d9acd0b8bc9af311ca0620a0b192fb28359b4e",displayName:"Plasma Wallet",hostname:"plasma-wallet.com",mobile:{universal:"https://plasma-wallet.com"}},avacus:{id:"94f785c0c8fb8c4f38cd9cd704416430bcaa2137f27e1468782d624bcd155a43",displayName:"Avacus",hostname:"avacus.cc",mobile:{universal:"https://avacus.app.link"}},bee:{id:"2cca8c1b0bea04ba37dee4017991d348cdb7b826804ab2bd31073254f345b715",displayName:"Bee",hostname:"www.beewallet.app",mobile:{universal:"https://beewallet.app/wc"}},pitaka:{id:"14e5d957c6eb62d3ee8fc6239703ac2d537d7e3552154836ca0beef775f630bc",displayName:"Pitaka",hostname:"pitaka.io",mobile:{universal:"https://app.pitaka.io"}},pltwallet:{id:"576c90ceaea34f29ff0104837cf2b2e23d201be43be1433feeb18d375430e1fd",displayName:"PLTwallet",hostname:"pltwallet.io",mobile:{universal:"https://pltwallet.io/"}},minerva:{id:"49bb9d698dbdf2c3d4627d66f99dd9fe90bba1eec84b143f56c64a51473c60bd",displayName:"Minerva",hostname:"minerva.digital",mobile:{universal:"https://minerva.digital"}},kryptogo:{id:"19418ecfd44963883e4d6abca1adeb2036f3b5ffb9bee0ec61f267a9641f878b",displayName:"KryptoGO",hostname:"kryptogo.com",mobile:{universal:"https://kryptogo.page.link"}},prema:{id:"5b8e33346dfb2a532748c247876db8d596734da8977905a27b947ba1e2cf465b",displayName:"PREMA",hostname:"premanft.com",mobile:{universal:"https://premanft.com"}},slingshot:{id:"d23de318f0f56038c5edb730a083216ff0cce00c1514e619ab32231cc9ec484b",displayName:"Slingshot",hostname:"slingshot.finance",mobile:{universal:"https://app.slingshot.finance"}},kriptonio:{id:"50df7da345f84e5a79aaf617df5167335a4b6751626df2e8a38f07029b3dde7b",displayName:"Kriptonio",hostname:"kriptonio.com",mobile:{universal:"https://app.kriptonio.com/mobile"}},timeless:{id:"9751385960bca290c13b443155288f892f62ee920337eda8c5a8874135daaea8",displayName:"Timeless",hostname:"timelesswallet.xyz",mobile:{universal:"https://timelesswallet.xyz"}},secux:{id:"6464873279d46030c0b6b005b33da6be5ed57a752be3ef1f857dc10eaf8028aa",displayName:"SecuX",hostname:"secuxtech.com",mobile:{universal:"https://wsweb.secuxtech.com"}},bitizen:{id:"41f20106359ff63cf732adf1f7dc1a157176c9b02fd266b50da6dcc1e9b86071",displayName:"Bitizen",hostname:"bitizen.org",mobile:{universal:"https://bitizen.org/wallet"}},blocto:{id:"14e7176536cb3706e221daaa3cfd7b88b7da8c7dfb64d1d241044164802c6bdd",displayName:"Blocto",hostname:"blocto.io",mobile:{universal:"https://blocto.app"}},safemoon:{id:"a0e04f1086aac204d4ebdd5f985c12ed226cd0006323fd8143715f9324da58d1",displayName:"SafeMoon",hostname:"safemoon.com",mobile:{universal:"https://safemoon.com/wc"}},okx_wallet:{id:"971e689d0a5be527bac79629b4ee9b925e82208e5168b733496a09c0faed0709",displayName:"OKX Wallet",hostname:"okx.com",mobile:{native:"okex://main"}},rabby_wallet:{id:"18388be9ac2d02726dbac9777c96efaac06d744b2f6d580fccdd4127a6d01fd1",displayName:"Rabby Wallet",hostname:"rabby.io",mobile:{}}};function T2(e){return{name:e.displayName||"",universalLink:e.mobile.universal,deepLink:e.mobile.native}}function Eu(e,t){let r=T2(t);if(r.deepLink)return xu(r.deepLink,e);if(r.universalLink)return ku(r.universalLink,e);throw new T(`Unsupported wallet ${t.id}`)}var Tu="WALLETCONNECT_DEEPLINK_CHOICE";function Pu(){try{localStorage.removeItem(Tu)}catch{}}function Su({href:e,name:t}){try{localStorage.setItem(Tu,JSON.stringify({href:e,name:t}))}catch{}}function _u(e){return e.startsWith("http://")||e.startsWith("https://")}function xu(e,t){if(_u(e))return ku(e,t);let r=e;r.includes("://")||(r=e.replaceAll("/","").replaceAll(":",""),r=`${r}://`),r.endsWith("/")||(r=`${r}/`);let o=encodeURIComponent(t);return{redirect:`${r}wc?uri=${o}`,href:r}}function ku(e,t){if(!_u(e))return xu(e,t);let r=e;r.endsWith("/")||(r=`${r}/`);let o=encodeURIComponent(t);return{redirect:`${r}wc?uri=${o}`,href:r}}function es(e,t){window.open(e,t,"noreferrer noopener")}var Fe=class{constructor(t){this.promise=null;this.fn=t}execute(t){return this.promise===null&&(this.promise=(async()=>{try{return await this.fn(t)}finally{this.promise=null}})()),this.promise}};var xi=class{constructor(t){this._meta={};this.captchaToken=t,this.startChannelOnce=new Fe(this._startChannelOnce.bind(this)),this.pollForReady=new Fe(this._pollForReady.bind(this))}get meta(){return this._meta}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.channelToken)throw new T("Auth flow must be initialized first");try{let t=await this.api.post(Op,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid});if(!t)throw new T("No response from authentication");return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");try{return await this.api.post(Np,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid})}catch(t){throw ne(t)}}async _startChannelOnce(){if(!this.api)throw new T("Auth flow has no API instance");let t=await this.api.post(Lp,{token:this.captchaToken});P2&&!S2&&t.connect_uri&&es(t.connect_uri,"_blank"),this._meta={connectUri:t.connect_uri,channelToken:t.channel_token}}async initializeFarcasterConnect(){if(!this.api)throw new T("Auth flow has no API instance");await this.startChannelOnce.execute()}async _pollForReady(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.channelToken)throw new T("Auth flow must be initialized first");let t=await this.api.get(Dp,{headers:{"farcaster-channel-token":this.meta.channelToken}});return t.state==="completed"?(this.message=t.message,this.signature=t.signature,this.fid=t.fid,!0):!1}};var Au="1.69.0-beta-20240605203856";var Ru="34357d3c125c2bcf2ce2bc3309d98715",ki="https://auth.privy.io",Iu=2e4,Le=1400,Mu=2500,Pc=Au;var $o="privy:token",Sc="privy-token",ts="privy:refresh_token",Wu="privy-refresh-token",rs="privy-session",Ai="privy:session_transfer_token",x2="privy:wallet",Ri="privy:caid",Ko="privy:state_code",jo="privy:code_verifier",Yo="privy:headless_oauth",os=e=>`${x2}:${e}`,_c="privy:connectors",xc="privy:connections";var Zo=12e4,oo=1,kc="0x1",xn=3e4,Lu="https://api.moonpay.com/v1",Ou="https://api.moonpay.com/v1",Nu="pk_live_hirbpu0cVcLHrjktC9l7fbc9ctjv0SL",Du="pk_test_fqWjXZMSFwloh7orvJsRfjiUHXJqFzI",Uu="0x420000000000000000000000000000000000000F",Fu=["function getL1Fee(bytes memory _data) external view returns (uint256)"],Bu="deprecated";import{base64url as Vu}from"jose";async function Hu(e){let t=new TextEncoder().encode(e),r=await crypto.subtle.digest("SHA-256",t);return new Uint8Array(r)}function Gu(e){return crypto.getRandomValues(new Uint8Array(e))}var k2="S256",A2="S256";function Ii(){return Vu.encode(Gu(36))}function ns(){return Ii()}async function is(e,t=k2){if(t==A2){let r=await Hu(e);return Vu.encode(r)}else return e}function zu(){let e=Z.get(jo);if(!e)throw new T("Authentication error.");return e}function as(){return!!Z.get(Yo)}var Ur=class{constructor(t){let r=typeof t.headless=="boolean"?t.headless:as();this.meta={...t,headless:r}}addCaptchaToken(t){this.meta.captchaToken=t}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new T("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new T("User denied confirmation during OAuth flow");let t=zu();try{let r=await this.api.post(Yp,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:t});return Z.del(jo),this.meta.headless&&Z.del(Yo),{user:r.user,token:r.token,refresh_token:r.refresh_token,is_new_user:r.is_new_user,oauth_provider_tokens:r.oauth_provider_tokens}}catch(r){let o=ne(r);throw o.privyErrorCode?new T(o.message||"Invalid code during OAuth flow.",void 0,o.privyErrorCode):o.message==="User denied confirmation during OAuth flow"?new T("Invalid code during oauth flow.",void 0,"oauth_user_denied"):new T("Invalid code during OAuth flow.",void 0,"unknown_auth_error")}}async link(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new T("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new T("User denied confirmation during OAuth flow");let t=Z.get(jo);if(!t)throw new T("Authentication error.");try{let r=await this.api.post(Zp,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:t});return Z.del(jo),r}catch(r){throw ne(r)}}async getAuthorizationUrl(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.provider)throw new T("Provider must be set when initializing OAuth authentication.");let t=Ii();Z.put(jo,t);let r=ns();Z.put(Ko,r);let o=await is(t);this.meta.headless&&Z.put(Yo,!0);try{return await this.api.post(jp,{provider:this.meta.provider,redirect_to:window.location.href,token:this.meta.captchaToken,code_challenge:o,state_code:r})}catch(n){throw ne(n)}}};function Ac(e){return e.charAt(0).toUpperCase()+e.slice(1)}import{jsx as qu,jsxs as R2}from"react/jsx-runtime";var ss=({style:e,...t})=>R2("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"0px",y:"0px",viewBox:"0 0 24 24",style:{height:"24px",...e},...t,children:[qu("path",{d:"M17.0722 11.6888C17.0471 8.90571 19.3263 7.56847 19.429 7.50274C18.1466 5.60938 16.153 5.35154 15.4417 5.3212C13.7461 5.14678 12.1306 6.32982 11.269 6.32982C10.4074 6.32982 9.08004 5.34648 7.67246 5.37429C5.82158 5.40209 4.11595 6.45874 3.16171 8.13218C1.24068 11.4942 2.6708 16.4817 4.54423 19.2143C5.46091 20.549 6.55041 22.0531 7.98554 21.9975C9.36803 21.9419 9.88905 21.095 11.5571 21.095C13.2251 21.095 13.696 21.9975 15.1537 21.9697C16.6389 21.9393 17.5806 20.6046 18.4897 19.2648C19.5392 17.7153 19.9725 16.2137 19.9975 16.1354C19.965 16.1228 17.1022 15.0155 17.0722 11.6888Z",fill:"currentColor"}),qu("path",{d:"M14.3295 3.51373C15.0909 2.58347 15.6043 1.28921 15.4641 0C14.3671 0.0455014 13.0396 0.738135 12.2532 1.66838C11.5494 2.48994 10.9307 3.80695 11.0986 5.07089C12.3183 5.16694 13.5681 4.44145 14.3295 3.51373Z",fill:"currentColor"})]});import{jsx as Mi,jsxs as I2}from"react/jsx-runtime";var ls=({style:e,...t})=>I2("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"0px",y:"0px",viewBox:"0 0 71 55",style:{height:"24px",...e},...t,children:[Mi("g",{clipPath:"url(#clip0)",children:Mi("path",{d:"M60.1045 4.8978C55.5792 2.8214 50.7265 1.2916 45.6527 0.41542C45.5603 0.39851 45.468 0.440769 45.4204 0.525289C44.7963 1.6353 44.105 3.0834 43.6209 4.2216C38.1637 3.4046 32.7345 3.4046 27.3892 4.2216C26.905 3.0581 26.1886 1.6353 25.5617 0.525289C25.5141 0.443589 25.4218 0.40133 25.3294 0.41542C20.2584 1.2888 15.4057 2.8186 10.8776 4.8978C10.8384 4.9147 10.8048 4.9429 10.7825 4.9795C1.57795 18.7309 -0.943561 32.1443 0.293408 45.3914C0.299005 45.4562 0.335386 45.5182 0.385761 45.5576C6.45866 50.0174 12.3413 52.7249 18.1147 54.5195C18.2071 54.5477 18.305 54.5139 18.3638 54.4378C19.7295 52.5728 20.9469 50.6063 21.9907 48.5383C22.0523 48.4172 21.9935 48.2735 21.8676 48.2256C19.9366 47.4931 18.0979 46.6 16.3292 45.5858C16.1893 45.5041 16.1781 45.304 16.3068 45.2082C16.679 44.9293 17.0513 44.6391 17.4067 44.3461C17.471 44.2926 17.5606 44.2813 17.6362 44.3151C29.2558 49.6202 41.8354 49.6202 53.3179 44.3151C53.3935 44.2785 53.4831 44.2898 53.5502 44.3433C53.9057 44.6363 54.2779 44.9293 54.6529 45.2082C54.7816 45.304 54.7732 45.5041 54.6333 45.5858C52.8646 46.6197 51.0259 47.4931 49.0921 48.2228C48.9662 48.2707 48.9102 48.4172 48.9718 48.5383C50.038 50.6034 51.2554 52.5699 52.5959 54.435C52.6519 54.5139 52.7526 54.5477 52.845 54.5195C58.6464 52.7249 64.529 50.0174 70.6019 45.5576C70.6551 45.5182 70.6887 45.459 70.6943 45.3942C72.1747 30.0791 68.2147 16.7757 60.1968 4.9823C60.1772 4.9429 60.1437 4.9147 60.1045 4.8978ZM23.7259 37.3253C20.2276 37.3253 17.3451 34.1136 17.3451 30.1693C17.3451 26.225 20.1717 23.0133 23.7259 23.0133C27.308 23.0133 30.1626 26.2532 30.1066 30.1693C30.1066 34.1136 27.28 37.3253 23.7259 37.3253ZM47.3178 37.3253C43.8196 37.3253 40.9371 34.1136 40.9371 30.1693C40.9371 26.225 43.7636 23.0133 47.3178 23.0133C50.9 23.0133 53.7545 26.2532 53.6986 30.1693C53.6986 34.1136 50.9 37.3253 47.3178 37.3253Z",fill:"#5865F2"})}),Mi("defs",{children:Mi("clipPath",{id:"clip0",children:Mi("rect",{width:"71",height:"55",fill:"white"})})})]});import{jsx as $u}from"react/jsx-runtime";var cs=({style:e,...t})=>$u("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"24",y:"24",viewBox:"0 0 98 96",style:{height:"24px",...e},...t,children:$u("path",{d:"M48.854 0C21.839 0 0 22 0 49.217c0 21.756 13.993 40.172 33.405 46.69 2.427.49 3.316-1.059 3.316-2.362 0-1.141-.08-5.052-.08-9.127-13.59 2.934-16.42-5.867-16.42-5.867-2.184-5.704-5.42-7.17-5.42-7.17-4.448-3.015.324-3.015.324-3.015 4.934.326 7.523 5.052 7.523 5.052 4.367 7.496 11.404 5.378 14.235 4.074.404-3.178 1.699-5.378 3.074-6.6-10.839-1.141-22.243-5.378-22.243-24.283 0-5.378 1.94-9.778 5.014-13.2-.485-1.222-2.184-6.275.486-13.038 0 0 4.125-1.304 13.426 5.052a46.97 46.97 0 0 1 12.214-1.63c4.125 0 8.33.571 12.213 1.63 9.302-6.356 13.427-5.052 13.427-5.052 2.67 6.763.97 11.816.485 13.038 3.155 3.422 5.015 7.822 5.015 13.2 0 18.905-11.404 23.06-22.324 24.283 1.78 1.548 3.316 4.481 3.316 9.126 0 6.6-.08 11.897-.08 13.526 0 1.304.89 2.853 3.316 2.364 19.412-6.52 33.405-24.935 33.405-46.691C97.707 22 75.788 0 48.854 0z",fill:"currentColor"})});import{jsx as ds,jsxs as M2}from"react/jsx-runtime";var ps=({style:e,...t})=>M2("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"26px",width:"26px",...e},...t,children:[ds("path",{d:"M22.56 12.25C22.56 11.47 22.49 10.72 22.36 10H12V14.255H17.92C17.665 15.63 16.89 16.795 15.725 17.575V20.335H19.28C21.36 18.42 22.56 15.6 22.56 12.25Z",fill:"#4285F4"}),ds("path",{d:"M12 23C14.97 23 17.46 22.015 19.28 20.335L15.725 17.575C14.74 18.235 13.48 18.625 12 18.625C9.13504 18.625 6.71004 16.69 5.84504 14.09H2.17004V16.94C3.98004 20.535 7.70004 23 12 23Z",fill:"#34A853"}),ds("path",{d:"M5.845 14.09C5.625 13.43 5.5 12.725 5.5 12C5.5 11.275 5.625 10.57 5.845 9.91V7.06H2.17C1.4 8.59286 0.999321 10.2846 1 12C1 13.775 1.425 15.455 2.17 16.94L5.845 14.09Z",fill:"#FBBC05"}),ds("path",{d:"M12 5.375C13.615 5.375 15.065 5.93 16.205 7.02L19.36 3.865C17.455 2.09 14.965 1 12 1C7.70004 1 3.98004 3.465 2.17004 7.06L5.84504 9.91C6.71004 7.31 9.13504 5.375 12 5.375Z",fill:"#EA4335"})]});import{jsx as cr,jsxs as us}from"react/jsx-runtime";function ms(e){return us("svg",{xmlns:"http://www.w3.org/2000/svg",xmlnsXlink:"http://www.w3.org/1999/xlink",width:26,height:26,viewBox:"0 0 140 140",x:"0px",y:"0px",fill:"none",...e,children:[us("defs",{children:[us("linearGradient",{id:"b",children:[cr("stop",{offset:"0",stopColor:"#3771c8"}),cr("stop",{stopColor:"#3771c8",offset:".128"}),cr("stop",{offset:"1",stopColor:"#60f",stopOpacity:"0"})]}),us("linearGradient",{id:"a",children:[cr("stop",{offset:"0",stopColor:"#fd5"}),cr("stop",{offset:".1",stopColor:"#fd5"}),cr("stop",{offset:".5",stopColor:"#ff543e"}),cr("stop",{offset:"1",stopColor:"#c837ab"})]}),cr("radialGradient",{id:"c",cx:"158.429",cy:"578.088",r:"65",xlinkHref:"#a",gradientUnits:"userSpaceOnUse",gradientTransform:"matrix(0 -1.98198 1.8439 0 -1031.402 454.004)",fx:"158.429",fy:"578.088"}),cr("radialGradient",{id:"d",cx:"147.694",cy:"473.455",r:"65",xlinkHref:"#b",gradientUnits:"userSpaceOnUse",gradientTransform:"matrix(.17394 .86872 -3.5818 .71718 1648.348 -458.493)",fx:"147.694",fy:"473.455"})]}),cr("path",{fill:"url(#c)",d:"M65.03 0C37.888 0 29.95.028 28.407.156c-5.57.463-9.036 1.34-12.812 3.22-2.91 1.445-5.205 3.12-7.47 5.468C4 13.126 1.5 18.394.595 24.656c-.44 3.04-.568 3.66-.594 19.188-.01 5.176 0 11.988 0 21.125 0 27.12.03 35.05.16 36.59.45 5.42 1.3 8.83 3.1 12.56 3.44 7.14 10.01 12.5 17.75 14.5 2.68.69 5.64 1.07 9.44 1.25 1.61.07 18.02.12 34.44.12 16.42 0 32.84-.02 34.41-.1 4.4-.207 6.955-.55 9.78-1.28 7.79-2.01 14.24-7.29 17.75-14.53 1.765-3.64 2.66-7.18 3.065-12.317.088-1.12.125-18.977.125-36.81 0-17.836-.04-35.66-.128-36.78-.41-5.22-1.305-8.73-3.127-12.44-1.495-3.037-3.155-5.305-5.565-7.624C116.9 4 111.64 1.5 105.372.596 102.335.157 101.73.027 86.19 0H65.03z",transform:"translate(1.004 1)"}),cr("path",{fill:"url(#d)",d:"M65.03 0C37.888 0 29.95.028 28.407.156c-5.57.463-9.036 1.34-12.812 3.22-2.91 1.445-5.205 3.12-7.47 5.468C4 13.126 1.5 18.394.595 24.656c-.44 3.04-.568 3.66-.594 19.188-.01 5.176 0 11.988 0 21.125 0 27.12.03 35.05.16 36.59.45 5.42 1.3 8.83 3.1 12.56 3.44 7.14 10.01 12.5 17.75 14.5 2.68.69 5.64 1.07 9.44 1.25 1.61.07 18.02.12 34.44.12 16.42 0 32.84-.02 34.41-.1 4.4-.207 6.955-.55 9.78-1.28 7.79-2.01 14.24-7.29 17.75-14.53 1.765-3.64 2.66-7.18 3.065-12.317.088-1.12.125-18.977.125-36.81 0-17.836-.04-35.66-.128-36.78-.41-5.22-1.305-8.73-3.127-12.44-1.495-3.037-3.155-5.305-5.565-7.624C116.9 4 111.64 1.5 105.372.596 102.335.157 101.73.027 86.19 0H65.03z",transform:"translate(1.004 1)"}),cr("path",{fill:"#fff",d:"M66.004 18c-13.036 0-14.672.057-19.792.29-5.11.234-8.598 1.043-11.65 2.23-3.157 1.226-5.835 2.866-8.503 5.535-2.67 2.668-4.31 5.346-5.54 8.502-1.19 3.053-2 6.542-2.23 11.65C18.06 51.327 18 52.964 18 66s.058 14.667.29 19.787c.235 5.11 1.044 8.598 2.23 11.65 1.227 3.157 2.867 5.835 5.536 8.503 2.667 2.67 5.345 4.314 8.5 5.54 3.054 1.187 6.543 1.996 11.652 2.23 5.12.233 6.755.29 19.79.29 13.037 0 14.668-.057 19.788-.29 5.11-.234 8.602-1.043 11.656-2.23 3.156-1.226 5.83-2.87 8.497-5.54 2.67-2.668 4.31-5.346 5.54-8.502 1.18-3.053 1.99-6.542 2.23-11.65.23-5.12.29-6.752.29-19.788 0-13.036-.06-14.672-.29-19.792-.24-5.11-1.05-8.598-2.23-11.65-1.23-3.157-2.87-5.835-5.54-8.503-2.67-2.67-5.34-4.31-8.5-5.535-3.06-1.187-6.55-1.996-11.66-2.23-5.12-.233-6.75-.29-19.79-.29zm-4.306 8.65c1.278-.002 2.704 0 4.306 0 12.816 0 14.335.046 19.396.276 4.68.214 7.22.996 8.912 1.653 2.24.87 3.837 1.91 5.516 3.59 1.68 1.68 2.72 3.28 3.592 5.52.657 1.69 1.44 4.23 1.653 8.91.23 5.06.28 6.58.28 19.39s-.05 14.33-.28 19.39c-.214 4.68-.996 7.22-1.653 8.91-.87 2.24-1.912 3.835-3.592 5.514-1.68 1.68-3.275 2.72-5.516 3.59-1.69.66-4.232 1.44-8.912 1.654-5.06.23-6.58.28-19.396.28-12.817 0-14.336-.05-19.396-.28-4.68-.216-7.22-.998-8.913-1.655-2.24-.87-3.84-1.91-5.52-3.59-1.68-1.68-2.72-3.276-3.592-5.517-.657-1.69-1.44-4.23-1.653-8.91-.23-5.06-.276-6.58-.276-19.398s.046-14.33.276-19.39c.214-4.68.996-7.22 1.653-8.912.87-2.24 1.912-3.84 3.592-5.52 1.68-1.68 3.28-2.72 5.52-3.592 1.692-.66 4.233-1.44 8.913-1.655 4.428-.2 6.144-.26 15.09-.27zm29.928 7.97c-3.18 0-5.76 2.577-5.76 5.758 0 3.18 2.58 5.76 5.76 5.76 3.18 0 5.76-2.58 5.76-5.76 0-3.18-2.58-5.76-5.76-5.76zm-25.622 6.73c-13.613 0-24.65 11.037-24.65 24.65 0 13.613 11.037 24.645 24.65 24.645C79.617 90.645 90.65 79.613 90.65 66S79.616 41.35 66.003 41.35zm0 8.65c8.836 0 16 7.163 16 16 0 8.836-7.164 16-16 16-8.837 0-16-7.164-16-16 0-8.837 7.163-16 16-16z"})]})}import{jsx as fs}from"react/jsx-runtime";function hs({style:e,...t}){return fs("svg",{xmlns:"http://www.w3.org/2000/svg",xmlnsXlink:"http://www.w3.org/1999/xlink",viewBox:"0,0,256,256",style:{height:"26px",width:"26px",...e},...t,children:fs("g",{fill:"#0077b5",strokeWidth:"1",strokeLinecap:"butt",strokeLinejoin:"miter",strokeMiterlimit:"10",style:{mixBlendMode:"normal"},children:fs("g",{transform:"scale(5.12,5.12)",children:fs("path",{d:"M41,4h-32c-2.76,0 -5,2.24 -5,5v32c0,2.76 2.24,5 5,5h32c2.76,0 5,-2.24 5,-5v-32c0,-2.76 -2.24,-5 -5,-5zM17,20v19h-6v-19zM11,14.47c0,-1.4 1.2,-2.47 3,-2.47c1.8,0 2.93,1.07 3,2.47c0,1.4 -1.12,2.53 -3,2.53c-1.8,0 -3,-1.13 -3,-2.53zM39,39h-6c0,0 0,-9.26 0,-10c0,-2 -1,-4 -3.5,-4.04h-0.08c-2.42,0 -3.42,2.06 -3.42,4.04c0,0.91 0,10 0,10h-6v-19h6v2.56c0,0 1.93,-2.56 5.81,-2.56c3.97,0 7.19,2.73 7.19,8.26z"})})})})}import{jsx as Ku,jsxs as W2}from"react/jsx-runtime";function ys(e){return W2("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 496 512",...e,children:[Ku("path",{fill:"#1ed760",d:"M248 8C111.1 8 0 119.1 0 256s111.1 248 248 248 248-111.1 248-248S384.9 8 248 8Z"}),Ku("path",{d:"M406.6 231.1c-5.2 0-8.4-1.3-12.9-3.9-71.2-42.5-198.5-52.7-280.9-29.7-3.6 1-8.1 2.6-12.9 2.6-13.2 0-23.3-10.3-23.3-23.6 0-13.6 8.4-21.3 17.4-23.9 35.2-10.3 74.6-15.2 117.5-15.2 73 0 149.5 15.2 205.4 47.8 7.8 4.5 12.9 10.7 12.9 22.6 0 13.6-11 23.3-23.2 23.3zm-31 76.2c-5.2 0-8.7-2.3-12.3-4.2-62.5-37-155.7-51.9-238.6-29.4-4.8 1.3-7.4 2.6-11.9 2.6-10.7 0-19.4-8.7-19.4-19.4s5.2-17.8 15.5-20.7c27.8-7.8 56.2-13.6 97.8-13.6 64.9 0 127.6 16.1 177 45.5 8.1 4.8 11.3 11 11.3 19.7-.1 10.8-8.5 19.5-19.4 19.5zm-26.9 65.6c-4.2 0-6.8-1.3-10.7-3.6-62.4-37.6-135-39.2-206.7-24.5-3.9 1-9 2.6-11.9 2.6-9.7 0-15.8-7.7-15.8-15.8 0-10.3 6.1-15.2 13.6-16.8 81.9-18.1 165.6-16.5 237 26.2 6.1 3.9 9.7 7.4 9.7 16.5s-7.1 15.4-15.2 15.4z"})]})}import{jsx as Rc,jsxs as L2}from"react/jsx-runtime";function gs(e){return L2("svg",{xmlns:"http://www.w3.org/2000/svg",fillRule:"evenodd",clipRule:"evenodd",imageRendering:"optimizeQuality",shapeRendering:"geometricPrecision",textRendering:"geometricPrecision",viewBox:"0 0 293768 333327",width:24,height:24,...e,children:[Rc("path",{fill:"#26f4ee",d:"M204958 0c5369 45832 32829 78170 77253 81022v43471l-287 27V87593c-44424-2850-69965-30183-75333-76015l-47060-1v192819c6791 86790-60835 89368-86703 56462 30342 18977 79608 6642 73766-68039V0h58365zM78515 319644c-26591-5471-50770-21358-64969-44588-34496-56437-3401-148418 96651-157884v54345l-164 27v-40773C17274 145544 7961 245185 33650 286633c9906 15984 26169 27227 44864 33011z"}),Rc("path",{fill:"#fb2c53",d:"M218434 11587c3505 29920 15609 55386 35948 70259-27522-10602-43651-34934-47791-70262l11843 3zm63489 82463c3786 804 7734 1348 11844 1611v51530c-25770 2537-48321-5946-74600-21749l4034 88251c0 28460 106 41467-15166 67648-34260 58734-95927 63376-137628 35401 54529 22502 137077-4810 136916-103049v-96320c26279 15803 48830 24286 74600 21748V94050zm-171890 37247c5390-1122 11048-1985 16998-2548v54345c-21666 3569-35427 10222-41862 22528-20267 38754 5827 69491 35017 74111-33931 5638-73721-28750-49999-74111 6434-12304 18180-18959 39846-22528v-51797zm64479-119719h1808-1808z"}),Rc("path",{d:"M206590 11578c5369 45832 30910 73164 75333 76015v51528c-25770 2539-48321-5945-74600-21748v96320c206 125717-135035 135283-173673 72939-25688-41449-16376-141089 76383-155862v52323c-21666 3569-33412 10224-39846 22528-39762 76035 98926 121273 89342-1225V11577l47060 1z",fill:"#000000"})]})}import{jsx as ju}from"react/jsx-runtime";var vs=({style:e,...t})=>ju("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"24px",width:"24px",...e},...t,children:ju("path",{d:"M 14.285156 10.171875 L 23.222656 0 L 21.105469 0 L 13.34375 8.832031 L 7.148438 0 L 0 0 L 9.371094 13.355469 L 0 24.019531 L 2.117188 24.019531 L 10.308594 14.691406 L 16.851562 24.019531 L 24 24.019531 M 2.878906 1.5625 L 6.132812 1.5625 L 21.101562 22.535156 L 17.851562 22.535156",fill:"currentColor"})});var O2={google:{name:"Google",component:ps},discord:{name:"Discord",component:ls},github:{name:"Github",component:cs},linkedin:{name:"LinkedIn",component:hs},twitter:{name:"Twitter",component:vs},spotify:{name:"Spotify",component:ys},instagram:{name:"Instagram",component:ms},tiktok:{name:"Tiktok",component:gs},apple:{name:"Apple",component:ss}},Wi=e=>O2[e];function Yu(e,t){let r={detail:"",retryable:!1},o=Ac(t);if(e?.privyErrorCode==="linked_to_another_user"&&(r.detail="This account has already been linked to another user."),e?.privyErrorCode==="invalid_credentials"&&(r.retryable=!0,r.detail="Something went wrong. Try again."),e.privyErrorCode==="oauth_user_denied"&&(r.detail=`Retry and check ${o} to finish connecting your account.`,r.retryable=!0),e?.privyErrorCode==="too_many_requests"&&(r.detail="Too many requests. Please wait before trying again."),e?.privyErrorCode==="too_many_requests"&&e.message.includes("provider rate limit")){let n=Wi(t).name;r.detail=`Request limit reached for ${n}. Please wait a moment and try again.`}if(e?.privyErrorCode==="oauth_account_suspended"){let n=Wi(t).name;r.detail=`Your ${n} account is suspended. Please try another login method.`}return r}function Li(){let e=new URLSearchParams(window.location.search),t=e.get("privy_oauth_code"),r=e.get("privy_oauth_state"),o=e.get("privy_oauth_provider");return!t||!r||!o?{inProgress:!1}:{inProgress:!0,authorizationCode:t,stateCode:r,provider:o,headless:as(),popupFlow:window.opener!==null}}function Jo(){let e=new URL(window.location.href);e.searchParams.delete("privy_oauth_code"),e.searchParams.delete("privy_oauth_provider"),e.searchParams.delete("privy_oauth_state"),Z.del(Ko),window.history.replaceState({},"",e)}var Qo=class{constructor(t){this.initAuthenticateOnce=new Fe(this._initAuthenticateOnce.bind(this)),this.initLinkOnce=new Fe(this._initLinkOnce.bind(this)),this.meta={captchaToken:t}}async initAuthenticationFlow(){if(!this.api)throw new T("Auth flow has no API instance");this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute()}async initLinkFlow(){if(!this.api)throw new T("Auth flow has no API instance");this.meta.initLinkResponse=await this.initLinkOnce.execute()}async authenticate(){let t=await import("@simplewebauthn/browser");if(!this.api)throw new T("Auth flow has no API instance");if(!t.browserSupportsWebAuthn())throw new T("WebAuthn is not supported in this browser");this.meta.initAuthenticateResponse||(this.meta.initAuthenticateResponse=await this.initAuthenticateOnce.execute());try{let r=await t.startAuthentication(this._transformInitAuthenticateOptionsToCamelCase(this.meta.initAuthenticateResponse.options)),o=await this.api.post(nu,{relying_party:this.meta.initAuthenticateResponse.relying_party,challenge:this.meta.initAuthenticateResponse.options.challenge,authenticator_response:this._transformAuthenticationResponseToSnakeCase(r)});return{user:o.user,token:o.token,refresh_token:o.refresh_token,is_new_user:o.is_new_user}}catch(r){throw r.name==="NotAllowedError"?new T("Passkey request timed out or rejected by user.",void 0,"passkey_not_allowed"):ne(r)}}async link(){let t=await import("@simplewebauthn/browser");if(!this.api)throw new T("Auth flow has no API instance");if(!t.browserSupportsWebAuthn())throw new T("WebAuthn is not supported in this browser");this.meta.initLinkResponse||(this.meta.initLinkResponse=await this.initLinkOnce.execute());try{let r=this.meta.initLinkResponse.options,o=await t.startRegistration(this._transformInitLinkOptionsToCamelCase(r));return await this.api.post(ou,{relying_party:this.meta.initLinkResponse.relying_party,authenticator_response:this._transformRegistrationResponseToSnakeCase(o)})}catch(r){throw r.name==="NotAllowedError"?new T("Passkey request timed out or rejected by user.",void 0,"passkey_not_allowed"):ne(r)}}async _initAuthenticateOnce(){if(!this.api)throw new T("Auth flow has no API instance");return await this.api.post(ru,{token:this.meta.captchaToken})}async _initLinkOnce(){if(!this.api)throw new T("Auth flow has no API instance");return await this.api.post(tu,{})}_transformInitLinkOptionsToCamelCase(t){return{rp:t.rp,user:{id:t.user.id,name:t.user.name,displayName:t.user.display_name},challenge:t.challenge,pubKeyCredParams:t.pub_key_cred_params.map(r=>({type:r.type,alg:r.alg})),timeout:t.timeout,excludeCredentials:t.exclude_credentials?.map(r=>({id:r.id,type:r.type,transports:r.transports})),authenticatorSelection:{authenticatorAttachment:t.authenticator_selection?.authenticator_attachment,requireResidentKey:t.authenticator_selection?.require_resident_key,residentKey:t.authenticator_selection?.resident_key,userVerification:t.authenticator_selection?.user_verification},attestation:t.attestation,extensions:{appid:t.extensions?.app_id,credProps:t.extensions?.cred_props?.rk,hmacCreateSecret:t.extensions?.hmac_create_secret}}}_transformRegistrationResponseToSnakeCase(t){return{id:t.id,raw_id:t.rawId,response:{client_data_json:t.response.clientDataJSON,attestation_object:t.response.attestationObject,authenticator_data:t.response.authenticatorData},authenticator_attachment:t.authenticatorAttachment,client_extension_results:{app_id:t.clientExtensionResults.appid,cred_props:t.clientExtensionResults.credProps,hmac_create_secret:t.clientExtensionResults.hmacCreateSecret},type:t.type}}_transformInitAuthenticateOptionsToCamelCase(t){return{challenge:t.challenge,allowCredentials:t.allow_credentials?.map(r=>({id:r.id,type:r.type,transports:r.transports}))||[],timeout:t.timeout,extensions:{appid:t.extensions?.app_id,credProps:t.extensions?.cred_props,hmacCreateSecret:t.extensions?.hmac_create_secret},userVerification:t.user_verification}}_transformAuthenticationResponseToSnakeCase(t){return{id:t.id,raw_id:t.rawId,response:{client_data_json:t.response.clientDataJSON,authenticator_data:t.response.authenticatorData,signature:t.response.signature,user_handle:t.response.userHandle},authenticator_attachment:t.authenticatorAttachment,client_extension_results:{app_id:t.clientExtensionResults.appid,cred_props:t.clientExtensionResults.credProps,hmac_create_secret:t.clientExtensionResults.hmacCreateSecret},type:t.type}}};var Xo=class{constructor(t,r){this.createSiweMessage=(t,r,o,n,i,a,l)=>`${o} wants you to sign in with your Ethereum account:
2
2
  ${r}
3
3
 
4
4
  ${l}
@@ -9,7 +9,7 @@ Chain ID: ${t}
9
9
  Nonce: ${a}
10
10
  Issued At: ${i}
11
11
  Resources:
12
- - https://privy.io`;this.getNonceOnce=new Fe(this._getNonceOnce.bind(this)),this.wallet=t,this.captchaToken=r}get meta(){return{connectorType:this.wallet.connectorType,walletClientType:this.wallet.walletClientType}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");try{let{message:t,signature:r}=await this.sign(),o=await this.api.post(Ip,{message:t,signature:r,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType});return{user:o.user,token:o.token,refresh_token:o.refresh_token,is_new_user:o.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");try{let{message:t,signature:r}=await this.sign();return await this.api.post(Mp,{message:t,signature:r,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(t){throw ne(t)}}async sign(){if(!this.api)throw new T("Auth flow has no API instance");if(await this.buildSiweMessage(),!this.preparedMessage)throw new T("Could not prepare SIWE message");let t=await this.wallet.sign(this.preparedMessage);return{message:this.preparedMessage,signature:t}}async _getNonceOnce(){if(!this.api)throw new T("Auth flow has no API instance");let t=this.wallet.address;return(await this.api.post(Rp,{address:t,token:this.captchaToken})).nonce}async buildSiweMessage(){if(!this.api)throw new T("Auth flow has no API instance");let t=this.wallet.address,r=this.wallet.chainId.replace("eip155:","");return this.nonce||(this.nonce=await this.getNonceOnce.execute()),this.preparedMessage=this.prepareMessage(r,t,this.nonce),this.preparedMessage}prepareMessage(t,r,o){let n=window.location.host,i=window.location.origin,a="By signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.",l=new Date().toISOString();return this.createSiweMessage(t,r,n,i,l,o,a)}};var en=class{constructor(t,r){this.meta={phoneNumber:t,captchaToken:r}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new T("phone number and sms code must be set prior to calling authenticate.");try{let t=await this.api.post(Kp,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new T("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(qp,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(t){throw ne(t)}}async sendSmsCode(t,r){if(!this.api)throw new T("Auth flow has no API instance");if(t&&(this.meta.phoneNumber=t),r&&(this.meta.captchaToken=r),!this.meta.phoneNumber)throw new T("phone nNumber must be set when initialzing authentication.");try{return await this.api.post(zp,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken})}catch(o){throw ne(o)}}};var Oi=class{constructor(t){this.meta={captchaToken:t}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");try{let t=await this.api.post(au,{captcha_token:this.meta.captchaToken,telegram_auth_result:this.meta.telegramAuthResult});return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");try{return await this.api.post(su,{telegram_auth_result:this.meta.telegramAuthResult})}catch(t){throw ne(t)}}};function Ic(e){let t={detail:"",retryable:!1};return e?.privyErrorCode==="linked_to_another_user"&&(t.detail="This account has already been linked to another user."),e?.privyErrorCode==="disallowed_login_method"&&(t.detail="Login with Telegram not allowed."),e?.privyErrorCode==="invalid_data"&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode==="cannot_link_more_of_type"&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode==="invalid_credentials"&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode==="too_many_requests"&&(t.detail="Too many requests. Please wait before trying again."),e?.privyErrorCode==="too_many_requests"&&e.message.includes("rate limit")&&(t.detail="Request limit reached for Telegram. Please wait a moment and try again."),t}import{v4 as k3}from"uuid";function j(e){return e?new Date(e*1e3):null}function N2(e){let t=[];for(let r of e){let o=r.type;switch(r.type){case"wallet":let n={address:r.address,type:r.type,imported:r.imported,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at),chainType:"ethereum",chainId:r.chain_id,walletClient:r.wallet_client_type==="privy"?"privy":"unknown",walletClientType:r.wallet_client_type,connectorType:r.connector_type,recoveryMethod:r.recovery_method};t.push(n);break;case"email":let i={address:r.address,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(i);break;case"phone":let a={number:r.phoneNumber,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(a);break;case"google_oauth":let l={subject:r.subject,email:r.email,name:r.name,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(l);break;case"spotify_oauth":let s={subject:r.subject,email:r.email,name:r.name,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(s);break;case"instagram_oauth":let c={subject:r.subject,username:r.username,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(c);break;case"twitter_oauth":let u={subject:r.subject,username:r.username,name:r.name,type:r.type,profilePictureUrl:r.profile_picture_url,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(u);break;case"discord_oauth":let h={subject:r.subject,username:r.username,email:r.email,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(h);break;case"github_oauth":let f={subject:r.subject,username:r.username,name:r.name,email:r.email,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(f);break;case"tiktok_oauth":let y={subject:r.subject,username:r.username,name:r.name,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(y);break;case"linkedin_oauth":let v={subject:r.subject,name:r.name,email:r.email,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(v);break;case"apple_oauth":let g={subject:r.subject,email:r.email,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(g);break;case"custom_auth":t.push({type:r.type,customUserId:r.custom_user_id,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)});break;case"farcaster":let x={type:r.type,fid:r.fid,ownerAddress:r.owner_address,displayName:r.display_name,username:r.username,bio:r.bio,pfp:r.profile_picture_url,url:r.homepage_url,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at),signerPublicKey:r.signer_public_key};t.push(x);break;case"passkey":let S={type:r.type,enrolledInMfa:r.enrolled_in_mfa,credentialId:r.credential_id,authenticatorName:r.authenticator_name,createdWithDevice:r.created_with_device,createdWithOs:r.created_with_os,createdWithBrowser:r.created_with_browser,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(S);break;case"telegram":let w={type:r.type,telegramUserId:r.telegram_user_id,firstName:r.first_name,lastName:r.last_name,username:r.username,photoUrl:r.photo_url,verifiedAt:j(r.first_verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(w);break;default:console.warn(`Unrecognized account type: ${o}. Please consider upgrading the Privy SDK.`)}}return t}function Wt(e,t){return e.slice().sort((r,o)=>(o.firstVerifiedAt??o.verifiedAt).getTime()-(r.firstVerifiedAt??r.verifiedAt).getTime()).find(r=>r.type===t)}var Me=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy"&&!t.imported)||null,Mc=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy"&&t.imported)||null,D2=e=>e.linkedAccounts.filter(t=>t.type==="wallet"),Lt=(e,t)=>t==="all-users"&&!Me(e)||t==="users-without-wallets"&&!D2(e)?.length;function $t(e){if(!e)return null;let t=N2(e.linked_accounts),r=Wt(t,"wallet"),o=Wt(t,"email"),n=Wt(t,"phone"),i=Wt(t,"google_oauth"),a=Wt(t,"twitter_oauth"),l=Wt(t,"discord_oauth"),s=Wt(t,"github_oauth"),c=Wt(t,"spotify_oauth"),u=Wt(t,"instagram_oauth"),h=Wt(t,"tiktok_oauth"),f=Wt(t,"linkedin_oauth"),y=Wt(t,"apple_oauth"),v=Wt(t,"farcaster"),g=Wt(t,"telegram"),x=e.mfa_methods.map(({type:w,verified_at:_})=>({type:w,verifiedAt:j(_)}));return{id:e.id,createdAt:j(e.created_at),linkedAccounts:t,email:o&&{address:o?.address},phone:n&&{number:n?.number},wallet:r&&{address:r.address,chainType:r.chainType,chainId:r.chainId,walletClient:r.walletClient,walletClientType:r.walletClientType,connectorType:r.connectorType,recoveryMethod:r.recoveryMethod,imported:r.imported},google:i&&{subject:i.subject,email:i.email,name:i.name},twitter:a&&{subject:a.subject,username:a.username,name:a.name,profilePictureUrl:a.profilePictureUrl},discord:l&&{subject:l.subject,username:l.username,email:l.email},github:s&&{subject:s.subject,username:s.username,name:s.name,email:s.email},spotify:c&&{subject:c.subject,email:c.email,name:c.name},instagram:u&&{subject:u.subject,username:u.username},tiktok:h&&{subject:h.subject,username:h.username,name:h.name},linkedin:f&&{subject:f.subject,name:f.name,email:f.email},apple:y&&{subject:y.subject,email:y.email},farcaster:v&&{fid:v.fid,ownerAddress:v.ownerAddress,displayName:v.displayName,username:v.username,bio:v.bio,pfp:v.pfp,url:v.url,signerPublicKey:v.signerPublicKey},telegram:g&&{telegramUserId:g.telegramUserId,firstName:g.firstName,lastName:g.lastName,username:g.username,photoUrl:g.photoUrl},mfaMethods:x.map(w=>w.type),hasAcceptedTerms:e.has_accepted_terms??!1}}import{getAddress as Om}from"@ethersproject/address";import{isHexString as E3}from"@ethersproject/bytes";import T3 from"eventemitter3";import K2 from"@coinbase/wallet-sdk";import{jsx as Zu,jsxs as U2}from"react/jsx-runtime";var Ni=({style:e,...t})=>U2("svg",{width:"1024",height:"1024",viewBox:"0 0 1024 1024",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...e},...t,children:[Zu("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),Zu("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"})]});import{getAddress as Br}from"@ethersproject/address";import{Web3Provider as rm}from"@ethersproject/providers";import{default as q2}from"eventemitter3";import z2 from"eventemitter3";var F2=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4"],Ju=e=>F2.includes(e);import{ErrorCode as B2}from"@ethersproject/logger";var kn=class extends te{constructor(){super("Wallet timeout");this.type="wallet_error"}},An=class extends te{constructor(){super("User rejected connection");this.type="wallet_error"}},Er=e=>{if(e instanceof te)return e;if(e?.code&&e?.reason){let t=new Be(e);return e.code===B2.ACTION_REJECTED&&(t.details=lt.E4001_USER_REJECTED_REQUEST),t}return e?.code?new Be(e):new te("Unknown connector error",e)},Kt=class extends ze{constructor(r,o,n){super(r);this.type="provider_error";this.code=o,this.data=n}},Be=class extends Kt{constructor(r){let o=r;super(o.message,o.code,o.data);let n=Object.values(lt).find(i=>i.eipCode===o.code);this.details=n||lt.UNKNOWN_ERROR,o.code===-32002&&(o.message?.includes("already pending for origin")?o.message?.includes("wallet_requestPermissions")?this.details=lt.E32002_CONNECTION_ALREADY_PENDING:this.details=lt.E32002_REQUEST_ALREADY_PENDING:o.message?.includes("Already processing")&&o.message.includes("eth_requestAccounts")&&(this.details=lt.E32002_WALLET_LOCKED))}},H2={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_REJECTED_CONNECTION:{message:"You rejected the request",detail:"Please try connecting again.",retryable:!0}},G2={E32002_CONNECTION_ALREADY_PENDING:{eipCode:-32002,message:"Connection request already pending",detail:"Don\u2019t see your wallet? Check your other browser windows.",retryable:!1},E32002_REQUEST_ALREADY_PENDING:{eipCode:-32002,message:"Resource request already pending",detail:"Don\u2019t see your wallet? Check your other browser windows.",retryable:!1},E32002_WALLET_LOCKED:{eipCode:-32002,message:"Wallet might be locked",detail:"Don\u2019t see your wallet? Check your other browser windows.",retryable:!1},E4001_USER_REJECTED_REQUEST:{eipCode:4001,message:"Signature rejected",detail:"Please try signing again.",retryable:!0}},V2={E4001_DEFAULT_USER_REJECTED_REQUEST:{eipCode:4001,message:"User Rejected Request",detail:"The user rejected the request.",default:!0,retryable:!0},E4100_DEFAULT_UNAUTHORIZED:{eipCode:4100,message:"Unauthorized",detail:"The requested method and/or account has not been authorized by the user.",default:!0,retryable:!1},E4200_DEFAULT_UNSUPPORTED_METHOD:{eipCode:4200,message:"Unsupported Method",detail:"The Provider does not support the requested method.",default:!0,retryable:!1},E4900_DEFAULT_DISCONNECTED:{eipCode:4900,message:"Disconnected",detail:"The Provider is disconnected from all chains.",default:!0,retryable:!0},E4901_DEFAULT_CHAIN_DISCONNECTED:{eipCode:4901,message:"Chain Disconnected",detail:"The Provider is not connected to the requested chain.",default:!0,retryable:!0},E32700_DEFAULT_PARSE_ERROR:{eipCode:-32700,message:"Parse error",detail:"Invalid JSON",default:!0,retryable:!1},E32600_DEFAULT_INVALID_REQUEST:{eipCode:-32600,message:"Invalid request",detail:"JSON is not a valid request object",default:!0,retryable:!1},E32601_DEFAULT_METHOD_NOT_FOUND:{eipCode:-32601,message:"Method not found",detail:"Method does not exist",default:!0,retryable:!1},E32602_DEFAULT_INVALID_PARAMS:{eipCode:-32602,message:"Invalid params",detail:"Invalid method parameters",default:!0,retryable:!1},E32603_DEFAULT_INTERNAL_ERROR:{eipCode:-32603,message:"Internal error",detail:"Internal JSON-RPC error",default:!0,retryable:!0},E32000_DEFAULT_INVALID_INPUT:{eipCode:-32e3,message:"Invalid input",detail:"Missing or invalid parameters",default:!0,retryable:!1},E32001_DEFAULT_RESOURCE_NOT_FOUND:{eipCode:-32001,message:"Resource not found",detail:"Requested resource not found",default:!0,retryable:!1},E32002_DEFAULT_RESOURCE_UNAVAILABLE:{eipCode:-32002,message:"Resource unavailable",detail:"Requested resource not available",default:!0,retryable:!0},E32003_DEFAULT_TRANSACTION_REJECTED:{eipCode:-32003,message:"Transaction rejected",detail:"Transaction creation failed",default:!0,retryable:!0},E32004_DEFAULT_METHOD_NOT_SUPPORTED:{eipCode:-32004,message:"Method not supported",detail:"Method is not implemented",default:!0,retryable:!1},E32005_DEFAULT_LIMIT_EXCEEDED:{eipCode:-32005,message:"Limit exceeded",detail:"Request exceeds defined limit",default:!0,retryable:!1},E32006_DEFAULT_JSON_RPC_VERSION_NOT_SUPPORTED:{eipCode:-32006,message:"JSON-RPC version not supported",detail:"Version of JSON-RPC protocol is not supported",default:!0,retryable:!1}},lt={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...V2,...G2},no={...H2,...lt};var Oe=class{constructor(t,r){this.removeListener=(t,r)=>{if(this.walletProvider)try{return this.walletProvider.removeListener(t,r)}catch{console.warn("Unable to remove wallet provider listener")}};this.walletTimeout=(t=new kn,r=this.rpcTimeoutDuration)=>new Promise((o,n)=>setTimeout(()=>{n(t)},r));this.setWalletProvider=t=>{this.walletProvider&&this._subscriptions.forEach(r=>{this.removeListener(r.eventName,r.listener)}),this.walletProvider=t,this._subscriptions.forEach(r=>{this.walletProvider?.on(r.eventName,r.listener)})};this.walletProvider=t,this.rpcTimeoutDuration=r||Zo,this._subscriptions=[]}on(t,r){if(this.walletProvider)return this.walletProvider.on(t,r);this._subscriptions.push({eventName:t,listener:r})}async request(t){if(!this.walletProvider)throw new te(`A wallet request of type ${t.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(t),this.walletTimeout()]).catch(r=>{throw Er(r)})}},wo=class extends Error{constructor(r,o,n){super(r);this.code=o,this.data=n}},Di=class extends z2{constructor(r,o,n,i,a,l=1){super();this.walletProxy=r,this.address=o,this.chainId=l,this.rpcConfig=n,this.chains=i,this.provider=ro(l,this.chains,n,{appId:a}),this.rpcTimeoutDuration=Rn(n,"privy"),this.appId=a}async handleSendTransaction(r){if(!r.params||!Array.isArray(r.params))throw new wo(`Invalid params for ${r.method}`,4200);let o=r.params[0];if(!await be()||!this.address)throw new wo("Disconnected",4900);return(await em(o)).hash}handleSwitchEthereumChain(r){if(!r.params||!Array.isArray(r.params))throw new wo(`Invalid params for ${r.method}`,4200);let o;if(typeof r.params[0]=="string")o=r.params[0];else if("chainId"in r.params[0]&&typeof r.params[0].chainId=="string")o=r.params[0].chainId;else throw new wo(`Invalid params for ${r.method}`,4200);this.chainId=Number(o),this.provider=ro(this.chainId,this.chains,this.rpcConfig,{appId:this.appId}),this.emit("chainChanged",o)}async handlePersonalSign(r){if(!r.params||!Array.isArray(r.params))throw new Error("Invalid params for personal_sign");let o=r.params[0],n=r.params[1];return await Qu(o,void 0,n)}async handleSignedTypedData(r){if(!r.params||!Array.isArray(r.params))throw new Error("Invalid params for eth_signTypedData_v4");let o=typeof r.params[1]=="string"?JSON.parse(r.params[1]):r.params[1];return await Xu(Ja(o))}async handleEstimateGas(r){if(!r.params||!Array.isArray(r.params))throw new Error("Invalid params for eth_estimateGas");delete r.params[0].gasPrice,delete r.params[0].maxFeePerGas,delete r.params[0].maxPriorityFeePerGas;let o={...r.params[0],chainId:qo(this.chainId)};try{return await this.provider.send("eth_estimateGas",[o])}catch(n){console.warn(`Gas estimation failed with error: ${n}. Retrying gas estimation by omitting the 'from' address`);try{return delete o.from,await this.provider.send("eth_estimateGas",[o])}catch(i){throw console.warn(`Gas estimation failed with error: ${i} when omitting the 'from' address`),n}}}async request(r){switch(console.debug("Embedded1193Provider.request() called with args",r),r.method){case"eth_accounts":case"eth_requestAccounts":return this.address?[this.address]:[];case"eth_chainId":return qo(this.chainId);case"eth_estimateGas":return this.handleEstimateGas(r);case"eth_sendTransaction":return this.handleSendTransaction(r);case"wallet_switchEthereumChain":return this.handleSwitchEthereumChain(r);case"personal_sign":return this.handlePersonalSign(r);case"eth_signTypedData_v4":return this.handleSignedTypedData(r);default:break}if(Ju(r.method)){let o=await be();if(await tm(),!o||!this.address)throw new wo("Disconnected",4900);try{return(await this.walletProxy.rpc({address:this.address,accessToken:o,request:{method:r.method,params:r.params}})).response.data}catch(n){throw console.error(n),new wo("Disconnected",4900)}}else return this.provider.send(r.method,r.params)}async connect(){let r=await be();if(!r||!this.address)return null;try{return(await this.walletProxy.connect({address:this.address,accessToken:r})).address}catch(o){return console.error(o),null}}},Fr=class extends Oe{constructor(r){super(r,r.rpcTimeoutDuration)}},bo=class extends Oe{constructor(t){super(t,t.rpcTimeoutDuration)}sendAsync(t,r){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};var $2=(e,t)=>{switch(t){case"coinbase_wallet":return e.message.includes("addEthereumChain");default:return e.code===4902||e.message?.includes("4902")}},Ot=class extends q2{constructor(r,o,n,i){super();this.onAccountsChanged=r=>{r.length===0?this.onDisconnect():this.syncAccounts(r)};this.onChainChanged=r=>{this.wallets.forEach(o=>{o.chainId=_n(r),this.walletClientType==="privy"&&Z.put(os(o.address),r)}),this.emit("walletsUpdated")};this.onDisconnect=()=>{this.connected=!1,this.wallets=[],this.emit("walletsUpdated")};this.onConnect=()=>{this.connected=!0,this.syncAccounts()};this.wallets=[],this.walletClientType=r,this.chains=o,this.defaultChain=n,this.rpcConfig=i,this.rpcTimeoutDuration=Rn(i,r),this.connected=!1,this.initialized=!1}buildConnectedWallet(r,o,n,i){let a=async()=>!!this.wallets.find(l=>Br(l.address)===Br(r));return{address:Br(r),chainId:o,meta:n,imported:i,switchChain:async l=>{if(!a)throw new te("Wallet is not currently connected.");let s=this.wallets.find(y=>Br(y.address)===Br(r))?.chainId;if(!s)throw new te("Unable to determine current chainId.");let c,u;if(typeof l=="number"?(c=`0x${l.toString(16)}`,u=l):(c=l,u=Number(l)),s===_n(c))return;let h=this.chains.find(y=>y.id===u);if(!h)throw new te(`Unsupported chainId: ${l}`);let f=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:c}]})};try{return await f()}catch(y){if($2(y,this.walletClientType))return await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:c,chainName:h.name,nativeCurrency:h.nativeCurrency,rpcUrls:[h.rpcUrls.default?.http[0]??""],blockExplorerUrls:[h.blockExplorers?.default.url??""]}]}),f();throw this.walletClientType==="rainbow"&&y.message?.includes("wallet_switchEthereumChain")?new te(`Rainbow does not support the chainId ${o}`):y}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:a,getEthereumProvider:async()=>{if(!await a())throw new te("Wallet is not currently connected.");return this.proxyProvider},getEthersProvider:async()=>{if(!await a())throw new te("Wallet is not currently connected.");return new rm(new Fr(this.proxyProvider))},getWeb3jsProvider:async()=>{if(!await a())throw new te("Wallet is not currently connected.");return new bo(this.proxyProvider)},sign:async l=>{if(!await a())throw new te("Wallet is not currently connected.");return await this.sign(l)},disconnect:()=>{this.disconnect()}}}async syncAccounts(r){let o=r;try{if(o===void 0){let c=await _i(()=>this.proxyProvider.request({method:"eth_accounts"}),{maxAttempts:10,delayMs:500});Array.isArray(c)&&(o=c)}}catch{console.warn("Wallet did not respond to eth_accounts. Defaulting to prefetched accounts.")}if(!o||!Array.isArray(o)||o.length<=0||!o[0])return;let n=o[0],i=Br(n),a=[],l;if(this.walletClientType==="privy"){let c=Z.get(os(i));this.chains.find(u=>u.id===Number(c))||(Z.del(os(i)),c=null),l=c||`0x${this.defaultChain.id.toString(16)}`;try{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:l}]})}catch{console.warn(`Unable to switch embedded wallet to chain ID ${l} on initialization`)}}else try{let c=await _i(()=>this.proxyProvider.request({method:"eth_chainId"}),{maxAttempts:10,delayMs:500});if(typeof c=="string")l=c;else if(typeof c=="number")l=`0x${c.toString(16)}`;else throw new Error("Invalid chainId returned from provider")}catch(c){console.warn(`Failed to get chainId from provider, defaulting to ${kc}`,c),l=kc}let s=_n(l);if(!a.find(c=>Br(c.address)===i)){let c={name:this.walletBranding.name,icon:typeof this.walletBranding.icon=="string"?this.walletBranding.icon:void 0,id:this.walletBranding.id};a.push(this.buildConnectedWallet(Br(n),s,c,this.connectorType==="embedded_imported"))}Cs(a,this.wallets)||(this.wallets=a,this.emit("walletsUpdated"))}async getConnectedWallet(){let r=await this.proxyProvider.request({method:"eth_accounts"});return this.wallets.sort((o,n)=>n.connectedAt-o.connectedAt).find(o=>r.find(n=>Br(n)===Br(o.address)))||null}async isConnected(){let r=await this.proxyProvider.request({method:"eth_accounts"});return Array.isArray(r)&&r.length>0}async sign(r){return await this.connect({showPrompt:!1}),new rm(new Fr(this.proxyProvider)).getSigner().signMessage(r)}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)}};var j2=[1,11155111,137,10,8453,84532,42161,7777777,43114,56],Y2=(e,t)=>e.makeWeb3Provider({options:t}),Wc,ws=class extends Ot{constructor(r,o,n,i,a,l){super("coinbase_wallet",r,o,n);this.connectorType="coinbase_wallet";this.displayName="Coinbase Wallet";if(this.proxyProvider=new Oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.connectionOptions=i.coinbaseWallet.connectionOptions??"eoaOnly",this.walletClientType=this.connectionOptions==="smartWalletOnly"?"coinbase_smart_wallet":"coinbase_wallet",this.walletClientType==="coinbase_smart_wallet"&&(this.displayName="Coinbase Smart Wallet"),!Wc){let s=[o.id].concat(r.map(u=>u.id)),c=this.connectionOptions!=="eoaOnly"?s.filter(u=>!j2.includes(u)):[];c.length>0&&console.warn(`The following configured chains are not supported by the Coinbase Smart Wallet: ${c.join(", ")}`),Wc=new K2({appName:a,appLogoUrl:l,appChainIds:s})}this.proxyProvider.setWalletProvider(Y2(Wc,this.connectionOptions))}async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(r){return r.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){this.proxyProvider.walletProvider.disconnect(),this.onDisconnect()}get walletBranding(){return{name:this.displayName,icon:Ni,id:"com.coinbase.wallet"}}async promptConnection(){try{let r=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!r||r.length===0||!r[0])throw new te("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([r[0]])}catch(r){throw Er(r)}}};import{jsx as om}from"react/jsx-runtime";var bs=({...e})=>om("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:om("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)"})});var Ui=class extends Ot{constructor(r,o,n,i,a=!1){super("privy",o,n,i);this.connectorType="embedded";this.proxyProvider=r,a&&(this.connectorType="embedded_imported"),this.subscribeListeners()}async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(r){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[qo(r?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:bs,id:"io.privy.wallet"}}disconnect(){this.connected=!1}async promptConnection(){}};import{jsx as nm}from"react/jsx-runtime";var In=({style:e,...t})=>nm("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...t,children:nm("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"})});import{jsx as jt,jsxs as Z2}from"react/jsx-runtime";var Mn=({style:e,...t})=>Z2("svg",{xmlns:"http://www.w3.org/2000/svg",xmlSpace:"preserve",x:0,y:0,viewBox:"0 0 318.6 318.6",width:"28",height:"28",style:{height:"28px",width:"28px",...e},...t,children:[jt("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),jt("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"})]});import{jsx as im,jsxs as J2}from"react/jsx-runtime";var Hr=({style:e,...t})=>J2("svg",{xmlns:"http://www.w3.org/2000/svg",width:"108",height:"108",viewBox:"0 0 108 108",fill:"none",style:{height:"28px",width:"28px",...e},...t,children:[im("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),im("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"})]});var Ln=class extends Ot{constructor(r,o,n,i,a){super(a||"unknown",r,o,n);this.connectorType="injected";this.proxyProvider=new Oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=i;let l=i.provider;this.proxyProvider.setWalletProvider(l)}async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(r){return r.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 r=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!r||r.length===0||!r[0])throw new te("Unable to retrieve accounts");await this.syncAccounts([r[0]])}catch(r){throw Er(r)}}},Wn,On=class extends Ot{constructor(r,o,n,i,a){super(a??"unknown",r,o,n);this.connectorType="injected";Ua(this,Wn,void 0);this.proxyProvider=new Oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(i),a==="metamask"?Cc(this,Wn,{name:"MetaMask",icon:Mn,id:"io.metamask"}):a==="phantom"&&Cc(this,Wn,{name:"Phantom",icon:Hr,id:"phantom"})}async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(r){return r.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return xp(this,Wn)??{name:"Browser Extension",icon:In,id:"extension"}}disconnect(){console.warn("Programmatic disconnect with browser wallets is not yet supported.")}async promptConnection(){try{let r=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!r||r.length===0||!r[0])throw new te("Unable to retrieve accounts");await this.syncAccounts([r[0]])}catch(r){throw Er(r)}}};Wn=new WeakMap;import{getAddress as IP}from"@ethersproject/address";import{Web3Provider as WP}from"@ethersproject/providers";import{isMobile as Q2}from"react-device-detect";var Es=class extends Ln{disconnect(){console.warn("MetaMask does not support programmatic disconnect.")}async promptConnection(){try{Q2||await this.proxyProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]});let t=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!t||t.length===0||!t[0])throw new te("Unable to retrieve accounts");await this.syncAccounts([t[0]])}catch(t){throw Er(t)}}};var Ts=class extends Ot{constructor(r,o){super(r,[],o,{});this.connectorType="null";this.proxyProvider=new Oe(void 0,Zo);this.connectorType=r}get walletBranding(){return{name:"Wallet",id:""}}async initialize(){this.initialized=!0,this.emit("initialized")}async connect(){throw new Error("connect called for an uninstalled wallet via the NullConnector")}disconnect(){throw new Error("disconnect called for an uninstalled wallet via the NullConnector")}promptConnection(r){throw new Error(`promptConnection called for an uninstalled wallet via the NullConnector for ${r}`)}};var Ps=class extends Ts{constructor(t){super("phantom",t)}get walletBranding(){return{name:"Phantom",icon:Hr,id:"phantom"}}};import{EthereumProvider as v3,OPTIONAL_EVENTS as C3,OPTIONAL_METHODS as w3}from"@walletconnect/ethereum-provider";import{isMobile as b3}from"react-device-detect";import{createContext as d3,useContext as p3,useEffect as Dc,useRef as u3,useState as m3}from"react";import{jsx as X2}from"react/jsx-runtime";function Ss({src:e,...t}){return X2("img",{src:e,...t,style:{display:"none"}})}import{useContext as Rm,useEffect as Am,useMemo as a3,useState as s3}from"react";import{createContext as l3}from"react";var Yt={appearance:{landingHeader:"Log in or sign up",theme:"light",accentColor:"#676FFF",walletList:["detected_wallets","metamask","coinbase_wallet","rainbow","wallet_connect"]},walletConnectCloudProjectId:Ru,rpcConfig:{rpcUrls:{},rpcTimeouts:{}},externalWallets:{coinbaseWallet:{connectionOptions:"eoaOnly"}},captchaEnabled:!1,_render:{standalone:!1},fiatOnRamp:{useSandbox:!1}};var am=({input:e})=>{if(!e||!e.primary[0])return;let t=[e.primary[0]],r=[];e.primary.length>4&&console.warn("You should not specify greater than 4 login methods in `loginMethodsAndOrder.primary`");for(let o of e.primary.slice(1))t.includes(o)?console.warn(`Duplicated login method: ${o}`):t.push(o);for(let o of e.overflow??[])!t.includes(o)&&!r.includes(o)?r.push(o):console.warn(`Duplicated login method: ${o}`);return{primary:t,overflow:r}};var e3=new Set(["coinbase_wallet","cryptocom","metamask","okx_wallet","phantom","rainbow","uniswap","zerion","wallet_connect","detected_wallets","rabby_wallet"]),sm=e=>e3.has(e),lm=(e,t,r)=>r.indexOf(e)===t,cm=({input:e,overrides:t})=>t?t.primary.concat(t.overflow??[]).filter(sm).filter(lm):e?e.filter(sm).filter(lm):Yt.appearance.walletList;var _s={id:42161,name:"Arbitrum One",network:"arbitrum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://arbitrum-mainnet.rpc.privy.systems"]},alchemy:{http:["https://arb-mainnet.g.alchemy.com/v2"],webSocket:["wss://arb-mainnet.g.alchemy.com/v2"]},infura:{http:["https://arbitrum-mainnet.infura.io/v3"],webSocket:["wss://arbitrum-mainnet.infura.io/ws/v3"]},default:{http:["https://arb1.arbitrum.io/rpc"]},public:{http:["https://arb1.arbitrum.io/rpc"]}},blockExplorers:{etherscan:{name:"Arbiscan",url:"https://arbiscan.io"},default:{name:"Arbiscan",url:"https://arbiscan.io"}}};var xs={id:421613,name:"Arbitrum Goerli",network:"arbitrum-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"AGOR",decimals:18},rpcUrls:{default:{http:["https://goerli-rollup.arbitrum.io/rpc"]}},blockExplorers:{default:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"}},testnet:!0};var ks={id:421614,name:"Arbitrum Sepolia",network:"arbitrum-sepolia",nativeCurrency:{name:"Arbitrum Sepolia Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://arbitrum-sepolia.rpc.privy.systems"]},default:{http:["https://sepolia-rollup.arbitrum.io/rpc"]},public:{http:["https://sepolia-rollup.arbitrum.io/rpc"]}},blockExplorers:{default:{name:"Blockscout",url:"https://sepolia-explorer.arbitrum.io"}},testnet:!0};var dm={id:43114,name:"Avalanche",network:"avalanche",nativeCurrency:{decimals:18,name:"Avalanche",symbol:"AVAX"},rpcUrls:{default:{http:["https://api.avax.network/ext/bc/C/rpc"]},public:{http:["https://api.avax.network/ext/bc/C/rpc"]}},blockExplorers:{etherscan:{name:"SnowTrace",url:"https://snowtrace.io"},default:{name:"SnowTrace",url:"https://snowtrace.io"}}};var pm={id:43113,name:"Avalanche Fuji",network:"avalanche-fuji",nativeCurrency:{decimals:18,name:"Avalanche Fuji",symbol:"AVAX"},rpcUrls:{default:{http:["https://api.avax-test.network/ext/bc/C/rpc"]},public:{http:["https://api.avax-test.network/ext/bc/C/rpc"]}},blockExplorers:{etherscan:{name:"SnowTrace",url:"https://testnet.snowtrace.io"},default:{name:"SnowTrace",url:"https://testnet.snowtrace.io"}},testnet:!0};var As={id:8453,network:"base",name:"Base",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://base-mainnet.rpc.privy.systems"]},blast:{http:["https://base-mainnet.blastapi.io"],webSocket:["wss://base-mainnet.blastapi.io"]},default:{http:["https://mainnet.base.org"]},public:{http:["https://mainnet.base.org"]}},blockExplorers:{etherscan:{name:"Basescan",url:"https://basescan.org"},default:{name:"Basescan",url:"https://basescan.org"}},testnet:!0};var Rs={id:84531,network:"base-goerli",name:"Base Goerli Testnet",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://goerli.base.org"]}},blockExplorers:{default:{name:"Basescan",url:"https://goerli.basescan.org"}},testnet:!0};var Is={id:84532,network:"base-sepolia",name:"Base Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://base-sepolia.rpc.privy.systems"]},default:{http:["https://sepolia.base.org"]},public:{http:["https://sepolia.base.org"]}},blockExplorers:{default:{name:"Blockscout",url:"https://base-sepolia.blockscout.com"}},testnet:!0};var um={id:80085,network:"berachain-artio",name:"Berachain Artio",nativeCurrency:{name:"BERA",symbol:"BERA",decimals:18},rpcUrls:{default:{http:["https://berachain-artio.rpc.privy.systems"]},public:{http:["https://berachain-artio.rpc.privy.systems"]}},blockExplorers:{default:{name:"Beratrail",url:"https://artio.beratrail.io"}},testnet:!0};var mm={id:42220,name:"Celo Mainnet",network:"celo",nativeCurrency:{decimals:18,name:"CELO",symbol:"CELO"},rpcUrls:{default:{http:["https://forno.celo.org"]},infura:{http:["https://celo-mainnet.infura.io/v3"]},public:{http:["https://forno.celo.org"]}},blockExplorers:{default:{name:"Celo Explorer",url:"https://explorer.celo.org/mainnet"},etherscan:{name:"CeloScan",url:"https://celoscan.io"}},testnet:!1};var fm={id:44787,name:"Celo Alfajores Testnet",network:"celo-alfajores",nativeCurrency:{decimals:18,name:"CELO",symbol:"CELO"},rpcUrls:{default:{http:["https://alfajores-forno.celo-testnet.org"]},infura:{http:["https://celo-alfajores.infura.io/v3"]},public:{http:["https://alfajores-forno.celo-testnet.org"]}},blockExplorers:{default:{name:"Celo Explorer",url:"https://explorer.celo.org/alfajores"},etherscan:{name:"CeloScan",url:"https://alfajores.celoscan.io/"}},testnet:!0};var hm={id:314,name:"Filecoin - Mainnet",network:"filecoin-mainnet",nativeCurrency:{decimals:18,name:"filecoin",symbol:"FIL"},rpcUrls:{default:{http:["https://api.node.glif.io/rpc/v1"]},public:{http:["https://api.node.glif.io/rpc/v1"]}},blockExplorers:{default:{name:"Filfox",url:"https://filfox.info/en"},filscan:{name:"Filscan",url:"https://filscan.io"},filscout:{name:"Filscout",url:"https://filscout.io/en"},glif:{name:"Glif",url:"https://explorer.glif.io"}}};var ym={id:314159,name:"Filecoin - Calibration testnet",network:"filecoin-calibration",nativeCurrency:{decimals:18,name:"testnet filecoin",symbol:"tFIL"},rpcUrls:{default:{http:["https://api.calibration.node.glif.io/rpc/v1"]},public:{http:["https://api.calibration.node.glif.io/rpc/v1"]}},blockExplorers:{default:{name:"Filscan",url:"https://calibration.filscan.io"}}};var gm={id:17069,name:"Garnet Holesky",network:"garnet-holesky",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.garnetchain.com"]},public:{http:["https://rpc.garnetchain.com"]}},blockExplorers:{default:{name:"Blockscout",url:"https://explorer.garnetchain.com"}}};var vm={id:5,network:"goerli",name:"Goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.ankr.com/eth_goerli"]}},blockExplorers:{default:{name:"Etherscan",url:"https://goerli.etherscan.io"}},testnet:!0};var Cm={id:17e3,name:"Holesky",network:"holesky",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://ethereum-holesky.publicnode.com"]},public:{http:["https://ethereum-holesky.publicnode.com"]}},blockExplorers:{etherscan:{name:"EtherScan",url:"https://holesky.etherscan.io"},default:{name:"EtherScan",url:"https://holesky.etherscan.io"}}};var wm={id:59144,network:"linea-mainnet",name:"Linea Mainnet",nativeCurrency:{name:"Linea Ether",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.linea.build"],webSocket:["wss://rpc.linea.build"]},public:{http:["https://rpc.linea.build"],webSocket:["wss://rpc.linea.build"]}},blockExplorers:{default:{name:"Etherscan",url:"https://lineascan.build"},etherscan:{name:"Etherscan",url:"https://lineascan.build"}},testnet:!1};var bm={id:59140,network:"linea-testnet",name:"Linea Goerli Testnet",nativeCurrency:{name:"Linea Ether",symbol:"ETH",decimals:18},rpcUrls:{infura:{http:["https://linea-goerli.infura.io/v3"],webSocket:["wss://linea-goerli.infura.io/ws/v3"]},default:{http:["https://rpc.goerli.linea.build"],webSocket:["wss://rpc.goerli.linea.build"]},public:{http:["https://rpc.goerli.linea.build"],webSocket:["wss://rpc.goerli.linea.build"]}},blockExplorers:{default:{name:"Etherscan",url:"https://goerli.lineascan.build"},etherscan:{name:"Etherscan",url:"https://goerli.lineascan.build"}},testnet:!0};var Ms={id:1,network:"homestead",name:"Ethereum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://mainnet.rpc.privy.systems"]},alchemy:{http:["https://eth-mainnet.g.alchemy.com/v2"],webSocket:["wss://eth-mainnet.g.alchemy.com/v2"]},infura:{http:["https://mainnet.infura.io/v3"],webSocket:["wss://mainnet.infura.io/ws/v3"]},default:{http:["https://cloudflare-eth.com"]},public:{http:["https://cloudflare-eth.com"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://etherscan.io"},default:{name:"Etherscan",url:"https://etherscan.io"}}};var Ws={id:10,name:"OP Mainnet",network:"optimism",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://optimism-mainnet.rpc.privy.systems"]},alchemy:{http:["https://opt-mainnet.g.alchemy.com/v2"],webSocket:["wss://opt-mainnet.g.alchemy.com/v2"]},infura:{http:["https://optimism-mainnet.infura.io/v3"],webSocket:["wss://optimism-mainnet.infura.io/ws/v3"]},default:{http:["https://mainnet.optimism.io"]},public:{http:["https://mainnet.optimism.io"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://optimistic.etherscan.io"},default:{name:"Optimism Explorer",url:"https://explorer.optimism.io"}}};var Ls={id:420,name:"Optimism Goerli Testnet",network:"optimism-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://goerli.optimism.io"]}},blockExplorers:{default:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"}},testnet:!0};var Os={id:11155420,name:"Optimism Sepolia",network:"optimism-sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://optimism-sepolia.rpc.privy.systems"]},default:{http:["https://sepolia.optimism.io"]},public:{http:["https://sepolia.optimism.io"]},infura:{http:["https://optimism-sepolia.infura.io/v3"]}},blockExplorers:{default:{name:"Blockscout",url:"https://optimism-sepolia.blockscout.com"}},testnet:!0};var Fi={id:137,name:"Polygon Mainnet",network:"matic",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{privy:{http:["https://polygon-mainnet.rpc.privy.systems"]},alchemy:{http:["https://polygon-mainnet.g.alchemy.com/v2"],webSocket:["wss://polygon-mainnet.g.alchemy.com/v2"]},infura:{http:["https://polygon-mainnet.infura.io/v3"],webSocket:["wss://polygon-mainnet.infura.io/ws/v3"]},default:{http:["https://polygon-rpc.com"]},public:{http:["https://polygon-rpc.com"]}},blockExplorers:{etherscan:{name:"PolygonScan",url:"https://polygonscan.com"},default:{name:"PolygonScan",url:"https://polygonscan.com"}}};var Bi={id:80001,name:"Mumbai",network:"maticmum",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{default:{http:["https://matic-mumbai.chainstacklabs.com"]}},blockExplorers:{default:{name:"PolygonScan",url:"https://mumbai.polygonscan.com"}},testnet:!0};var Em={id:690,name:"Redstone",network:"redstone",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.redstonechain.com"]},public:{http:["https://rpc.redstonechain.com"]}},blockExplorers:{default:{name:"Blockscout",url:"https://explorer.redstone.xyz/"}}};var Tm={id:17001,name:"Redstone Holesky",network:"redstone-holesky",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.holesky.redstone.xyz"]},public:{http:["https://rpc.holesky.redstone.xyz"]}},blockExplorers:{etherscan:{name:"EtherScan",url:"https://explorer.holesky.redstone.xyz"},default:{name:"EtherScan",url:"https://explorer.holesky.redstone.xyz"}}};var Pm={id:11155111,network:"sepolia",name:"Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"SEP",decimals:18},rpcUrls:{privy:{http:["https://sepolia.rpc.privy.systems"]},alchemy:{http:["https://eth-sepolia.g.alchemy.com/v2"],webSocket:["wss://eth-sepolia.g.alchemy.com/v2"]},infura:{http:["https://sepolia.infura.io/v3"],webSocket:["wss://sepolia.infura.io/ws/v3"]},default:{http:["https://rpc.sepolia.org"]},public:{http:["https://rpc.sepolia.org"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://sepolia.etherscan.io"},default:{name:"Etherscan",url:"https://sepolia.etherscan.io"}},testnet:!0};var Ns={id:7777777,name:"Zora",network:"zora",nativeCurrency:{decimals:18,name:"Ether",symbol:"ETH"},rpcUrls:{default:{http:["https://rpc.zora.energy"],webSocket:["wss://rpc.zora.energy"]},public:{http:["https://rpc.zora.energy"],webSocket:["wss://rpc.zora.energy"]}},blockExplorers:{default:{name:"Explorer",url:"https://explorer.zora.energy"}}};var Ds={id:999999999,name:"Zora Sepolia",network:"zora-sepolia",nativeCurrency:{decimals:18,name:"Zora Sepolia",symbol:"ETH"},rpcUrls:{default:{http:["https://sepolia.rpc.zora.energy"],webSocket:["wss://sepolia.rpc.zora.energy"]},public:{http:["https://sepolia.rpc.zora.energy"],webSocket:["wss://sepolia.rpc.zora.energy"]}},blockExplorers:{default:{name:"Zora Sepolia Explorer",url:"https://sepolia.explorer.zora.energy/"}},testnet:!0};var Us={id:999,name:"Zora Goerli Testnet",network:"zora-testnet",nativeCurrency:{decimals:18,name:"Zora Goerli",symbol:"ETH"},rpcUrls:{default:{http:["https://testnet.rpc.zora.energy"],webSocket:["wss://testnet.rpc.zora.energy"]},public:{http:["https://testnet.rpc.zora.energy"],webSocket:["wss://testnet.rpc.zora.energy"]}},blockExplorers:{default:{name:"Explorer",url:"https://testnet.explorer.zora.energy"}},testnet:!0};var Hi=[_s,xs,ks,vm,Pm,Ms,Ws,Ls,Os,Fi,Bi,mm,fm,hm,ym,As,Rs,Is,um,wm,bm,dm,pm,Ns,Us,Ds,Cm,Em,gm,Tm],i_=new Set(Hi.map(e=>e.id));import tn from"tinycolor2";var Sm="#FFFFFF",t3="#000000",r3=Sm,o3="#1E1E1D";function n3(e){return e<.8&&e>.2&&console.warn("Background color is not light or dark enough, which could lead to accessibility issues."),e>.5?"light":"dark"}function io(e,t){let r=Math.max(0,Math.min(1,e.toHsl().l+t));return tn({...e.toHsl(),l:r})}function _m({backgroundTheme:e,accentHex:t,successHex:r="#51BA81",warnHex:o="#FFB74D",errorHex:n="#EC6351",whiteHex:i=Sm,blackHex:a=t3}){let l;switch(e){case"light":l=r3;break;case"dark":l=o3;break;default:l=e;break}let s=tn(l),c=tn(t),u=tn(r),h=tn(o),f=tn(n),y=n3(s.getLuminance()),v=io(s,y==="light"?-.04:.11),g=io(s,y==="light"?-.88:.87),x=io(s,y==="light"?-.77:.75),S=io(s,y==="light"?-.43:.45).desaturate(y==="light"?60:20),w=io(s,y==="light"?-.08:.25).desaturate(y==="light"?60:20),_=io(c,.15),A=io(c,-.06),N=io(f,.3),I=tn(c.getLuminance()>.5?a:i),R=io(u,-.16);return{colorScheme:y,background:s.toHslString(),background2:v.toHslString(),foreground:g.toHslString(),foreground2:x.toHslString(),foreground3:S.toHslString(),foreground4:w.toHslString(),accent:c.toHslString(),accentLight:_.toHslString(),accentDark:A.toHslString(),foregroundAccent:I.toHslString(),success:u.toHslString(),successDark:R.toHslString(),error:f.toHslString(),errorLight:N.toHslString(),warn:h.toHslString()}}function Lc(e,t,r){let o=r?console.warn:()=>{},n,i,a,l,s,c,u,h,f,y,v,g,x,S,w;t?.loginMethods?(n=t.loginMethods.includes("email"),i=t.loginMethods.includes("sms"),l=t.loginMethods.includes("wallet"),s=t.loginMethods.includes("google"),c=t.loginMethods.includes("twitter"),u=t.loginMethods.includes("discord"),f=t.loginMethods.includes("spotify"),y=t.loginMethods.includes("instagram"),h=t.loginMethods.includes("tiktok"),g=t.loginMethods.includes("github"),v=t.loginMethods.includes("linkedin"),x=t.loginMethods.includes("apple"),S=t.loginMethods.includes("farcaster"),w=t.loginMethods.includes("telegram")):(n=e.emailAuth,i=e.smsAuth,l=e.walletAuth,s=e.googleOAuth,c=e.twitterOAuth,u=e.discordOAuth,g=e.githubOAuth,f=e.spotifyOAuth,y=e.instagramOAuth,h=e.tiktokOAuth,v=e.linkedinOAuth,x=e.appleOAuth,S=e.farcasterAuth,w=e.telegramAuth),typeof window<"u"&&typeof window.PublicKeyCredential!="function"?a=!1:e.passkeyAuth&&(a=!0);let _=[n,i].filter(Boolean),A=[s,c,u,g,f,y,h,v,x,S,w].filter(Boolean),N=[l].filter(Boolean);if(_.length+A.length+N.length===0)throw new Error("You must enable at least one login method");let I=t?.appearance?.showWalletLoginFirst!==void 0?t?.appearance?.showWalletLoginFirst:e.showWalletLoginFirst;I&&N.length===0?(o("You should only enable `showWalletLoginFirst` when `wallet` logins are also enabled. `showWalletLoginFirst` has been set to false"),I=!1):!I&&A.length+_.length===0&&(o("You should only disable `showWalletLoginFirst` when `email`, `sms`, or social logins are also enabled. `showWalletLoginFirst` has been set to true"),I=!0),t?.loginMethods&&t.loginMethodsAndOrder&&o("You should only configure one of `loginMethods` or `loginMethodsAndOrder`");let R=cm({input:t?.appearance?.walletList,overrides:t?.loginMethodsAndOrder}),B=am({input:t?.loginMethodsAndOrder}),K=t?.intl?.defaultCountry??"US",{chains:Y,defaultChain:W}=i3({additionalChains:t?.additionalChains,supportedChains:t?.supportedChains,defaultChainFromConfig:t?.defaultChain,hasRpcConfigDefined:Object.keys(t?.rpcConfig?.rpcUrls??{}).length>0}),V=!!t?.defaultChain,L=t?.customAuth?.getCustomAccessToken&&t?.customAuth?.enabled!==!1,ae,de=!(e.enforceWalletUis??!0);if(e.legacyWalletUiConfig??!0?L?ae=t?.embeddedWallets?.noPromptOnSignature??!0:ae=t?.embeddedWallets?.noPromptOnSignature??de:ae=de,t?.embeddedWallets?.waitForTransactionConfirmation===!1&&ae!==!0)throw new Error("Overriding `config.embeddedWallets.waitForTransactionConfirmation` requires that you disable wallet UIs in the dashboard.");let{requireUserPasswordOnCreate:pe,...we}=t?.embeddedWallets??{};return{id:e.id,name:e.name,allowlistConfig:e.allowlistConfig,legacyWalletUiConfig:e.legacyWalletUiConfig,appearance:{logo:t?.appearance?.logo??e.logoUrl,landingHeader:t?.appearance?.landingHeader??Yt.appearance.landingHeader,loginMessage:typeof t?.appearance?.loginMessage=="string"?t?.appearance?.loginMessage.slice(0,100):t?.appearance?.loginMessage,palette:_m({backgroundTheme:t?.appearance?.theme??Yt.appearance.theme,accentHex:t?.appearance?.accentColor??e.accentColor??Yt.appearance.accentColor}),loginGroupPriority:I?"web3-first":"web2-first",hideDirectWeb2Inputs:!!t?.appearance?.hideDirectWeb2Inputs,walletList:R},loginMethods:{wallet:l,email:n,sms:i,passkey:a,google:s,twitter:c,discord:u,github:g,spotify:f,instagram:y,tiktok:h,linkedin:v,apple:x,farcaster:S,telegram:w},loginMethodsAndOrder:B,legal:{termsAndConditionsUrl:t?.legal?.termsAndConditionsUrl??e.termsAndConditionsUrl,privacyPolicyUrl:t?.legal?.privacyPolicyUrl??e.privacyPolicyUrl,requireUsersAcceptTerms:e.requireUsersAcceptTerms??!1},walletConnectCloudProjectId:t?.walletConnectCloudProjectId??e.walletConnectCloudProjectId??Yt.walletConnectCloudProjectId,rpcConfig:{rpcUrls:t?.rpcConfig?.rpcUrls??Yt.rpcConfig.rpcUrls,rpcTimeouts:t?.rpcConfig?.rpcTimeouts??Yt.rpcConfig.rpcTimeouts},chains:Y,defaultChain:W,intl:{defaultCountry:K},shouldEnforceDefaultChainOnConnect:V,captchaEnabled:e.captchaEnabled??Yt.captchaEnabled,captchaSiteKey:e.captchaSiteKey,externalWallets:{coinbaseWallet:{connectionOptions:t?.externalWallets?.coinbaseWallet?.connectionOptions??Yt.externalWallets.coinbaseWallet.connectionOptions}},embeddedWallets:{...e.embeddedWalletConfig,...typeof pe=="boolean"?{requireUserOwnedRecoveryOnCreate:pe}:{},...L?{createOnLogin:"all-users",requireUserOwnedRecoveryOnCreate:!1,userOwnedRecoveryOptions:["user-passcode"]}:{},waitForTransactionConfirmation:!0,priceDisplay:{primary:"fiat-currency",secondary:"native-token"},...we,noPromptOnSignature:ae},mfa:{methods:e.mfaMethods??[],noPromptOnMfaRequired:t?.mfa?.noPromptOnMfaRequired??!1},customAuth:L?{enabled:!0,...t.customAuth}:void 0,fiatOnRamp:{enabled:e.fiatOnRampEnabled,useSandbox:t?.fiatOnRamp?.useSandbox??Yt.fiatOnRamp.useSandbox},loginConfig:{twitterOAuthOnMobileEnabled:e.twitterOAuthOnMobileEnabled??!1,telegramAuthConfiguration:e.telegramAuthConfiguration},headless:!!t?.headless,render:{standalone:t?._render?.standalone??Yt._render.standalone}}}function xm(e,t){if(!e)return{legacyCreateEmbeddedWalletFlag:t};let{appearance:r,additionalChains:o,supportedChains:n,defaultChain:i,...a}=e;return{...a,...o?{additionalChains:o.map(s=>s.id)}:void 0,...n?{supportedChains:n.map(s=>s.id)}:void 0,...i?{defaultChain:i.id}:void 0,legacyCreateEmbeddedWalletFlag:t}}function i3({additionalChains:e,supportedChains:t,defaultChainFromConfig:r,hasRpcConfigDefined:o}){let n;if(e&&t&&console.warn("You should only specify one of `additionalChains` or `supportedChains`. Using `supportedChains`."),t){if(t.length===0)throw new Error("`supportedChains` must contain at least one chain");t.filter(s=>s.rpcUrls.privyWalletOverride).length>0&&o&&console.warn("You have specified at least one `supportedChain` with `privyWalletOverride` but also have `rpcConfig` defined. The `rpcConfig` will be ignored. `rpcConfig` is deprecated and you should use `privyWalletOverride` in a `supportedChain`."),n=t.map(s=>s.rpcUrls.privyWalletOverride?s:Hi.find(u=>u.id===s.id)??s)}else n=Hi.concat(e??[]);let i=t?n[0]:Ms,a=r??i;if(!n.find(l=>l.id===a.id))throw new Error("`defaultChain` must be included in `supportedChains`");return{chains:n,defaultChain:a}}var km=function(e,t=0){let r=3735928559^t,o=1103547991^t;for(let n=0,i;n<e.length;n++)i=e.charCodeAt(n),r=Math.imul(r^i,2654435761),o=Math.imul(o^i,1597334677);return r=Math.imul(r^r>>>16,2246822507),r^=Math.imul(o^o>>>13,3266489909),o=Math.imul(o^o>>>16,2246822507),o^=Math.imul(r^r>>>13,3266489909),4294967296*(2097151&o)+(r>>>0)};import{jsx as c3}from"react/jsx-runtime";var Im={showWalletLoginFirst:!0,allowlistConfig:{errorTitle:null,errorDetail:null,errorCtaText:null,errorCtaLink:null},walletAuth:!0,emailAuth:!0,smsAuth:!1,googleOAuth:!1,twitterOAuth:!1,discordOAuth:!1,githubOAuth:!1,linkedinOAuth:!1,appleOAuth:!1,termsAndConditionsUrl:null,privacyPolicyUrl:null,embeddedWalletConfig:{createOnLogin:"off",requireUserOwnedRecoveryOnCreate:!1,userOwnedRecoveryOptions:["user-passcode"]},fiatOnRampEnabled:!1,captchaEnabled:!1,captchaSiteKey:""},Oc=Lc(Im,void 0,!1),Nc=l3({appConfig:Oc,isServerConfigLoaded:!1}),Mm=({children:e,legacyCreateEmbeddedWalletFlag:t,client:r,clientConfig:o})=>{let[n,i]=s3(null),a=a3(()=>Lc(n??Im,o,!!n),[n,o]);return Am(()=>{if(!n)return;let l=xm(o,t),s=km(JSON.stringify(l)).toString(),c=`privy:sent:${n.id}:${s}`;localStorage.getItem(c)||(r.createAnalyticsEvent({eventName:"sdk_initialize",payload:l}),localStorage.setItem(c,"t"))},[o,t,n]),Am(()=>{n||(async()=>{try{let s=await r.getServerConfig();s.customApiUrl&&r.updateApiUrl(s.customApiUrl),i(s)}catch(s){console.warn("Error generating app config: ",s)}})()},[]),c3(Nc.Provider,{value:{appConfig:a,isServerConfigLoaded:!!n},children:e})},ft=()=>{let{appConfig:e}=Rm(Nc);return e},Fs=()=>{let{isServerConfigLoaded:e}=Rm(Nc);return e};var b=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};import{jsx as h3,jsxs as y3}from"react/jsx-runtime";var Wm=d3({ready:!1,app:Oc,currentScreen:null,lastScreen:null,navigate:b,navigateBack:b,resetNavigation:b,setModalData:b,onUserCloseViaDialogOrKeybindRef:void 0}),f3=["LANDING","CONNECT_ONLY_LANDING_SCREEN",null],Lm=e=>{let t=ft(),r=e.authenticated,[o,n]=m3(e.initialScreen);Dc(()=>{!r&&!f3.includes(e.initialScreen)&&e.setInitialScreen(null)},[r]);let i=u3(null);Dc(()=>{e.open||(i.current=null)},[e.open]),Dc(()=>{i.current=null},[e.initialScreen]);let a={ready:!!t.id,app:t,data:e.data,setModalData:e.setModalData,currentScreen:e.initialScreen,lastScreen:o,navigate:(l,s=!0)=>{e.setInitialScreen(l),s&&n(e.initialScreen)},navigateBack:()=>{e.setInitialScreen(o)},resetNavigation:()=>{e.setInitialScreen(null),n(null)},onUserCloseViaDialogOrKeybindRef:i};return y3(Wm.Provider,{value:a,children:[(typeof t.appearance.logo=="string"||t.appearance.logo?.type==="img")&&h3(Ss,{src:typeof t.appearance.logo=="string"?t.appearance.logo:t.appearance.logo.props.src}),e.children]})},k=()=>p3(Wm);import{jsx as Nn,jsxs as g3}from"react/jsx-runtime";var Gi=({style:e,...t})=>{let{app:r}=k();return g3("svg",{width:"28",height:"28",viewBox:"0 0 28 28",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...e},...t,children:[Nn("rect",{width:"28",height:"28",rx:"3",fill:r?.appearance.palette.colorScheme==="dark"?"#3396ff":"#141414"}),Nn("g",{clipPath:"url(#clip0_1765_9946)",children:Nn("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"})}),Nn("defs",{children:Nn("clipPath",{id:"clip0_1765_9946",children:Nn("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})};var Gr=class extends Ot{constructor(r,o,n,i,a,l,s,c){super(c||"unknown",n,i,o);this.connectorType="wallet_connect_v2";this.privyAppId=l,this.privyAppName=s,this.walletConnectCloudProjectId=r,this.rpcConfig=o,this.shouldEnforceDefaultChainOnConnect=a,this.proxyProvider=new Oe(void 0,this.rpcTimeoutDuration),c&&(this.walletEntry=Xa[c],this.walletClientType=c)}async initialize(){let r=await this.createProvider();if(this.provider=r,this.proxyProvider.setWalletProvider(r),this.subscribeListeners(),r.session){if(this.walletProvider?.session?.peer.metadata.url){let n=Qa(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=n?.entry,this.walletClientType=n?.walletClientType||"unknown"}this.connected=!0,await this.syncAccounts()}this.initialized=!0,this.emit("initialized");let{WalletConnectModal:o}=await import("@walletconnect/modal");this.modal=new o({projectId:this.walletConnectCloudProjectId,themeVariables:{"--wcm-z-index":"1000000"}}),this.modal.subscribeModal(n=>{!n.open&&!this.walletProvider?.session&&this.onQrModalClosed&&this.onQrModalClosed()})}async connect(r){return r.showPrompt&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return!!this.walletProvider?.connected}get walletBranding(){return this.walletClientType==="metamask"?{name:"MetaMask",icon:Mn,id:"io.metamask"}:{name:vu(this.walletProvider?.session?.peer.metadata.name||"")||"WalletConnect",icon:this.walletProvider?.session?.peer.metadata.icons?.[0]||Gi,id:this.walletProvider?.session?.peer.metadata.name.toLowerCase()||"wallet_connect_v2"}}async resetConnection(r){this.walletProvider&&this.walletProvider.connected&&(await this.walletProvider.disconnect(),this.walletProvider.signer.session=void 0,this.walletEntry=Xa[r],this.walletClientType=r,this.redirectUri=void 0,Pu(),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise((r,o)=>{let n=()=>{o(new An)};this.onQrModalClosed=n,(async()=>{let a="",l=await Promise.race([this.walletProvider?.enable(),this.proxyProvider.walletTimeout()]);if(l?.length&&(a=l[0]),!a||a==="")throw new te("Unable to retrieve address");if(this.walletProvider?.session?.peer.metadata.url){let s=Qa(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=s?.entry,this.walletClientType=s?.walletClientType||"unknown",this.proxyProvider.rpcTimeoutDuration=Rn(this.rpcConfig,this.walletClientType)}this.connected=!0,await this.syncAccounts(l),r()})().catch(a=>{if(a){o(Er(a));return}o(new te("Unknown error during connection"))}).finally(()=>this.modal?.closeModal())})}disconnect(){this.walletProvider?.disconnect().then(()=>this.onDisconnect()).catch(()=>console.warn("Unable to disconnect Wallet Connect provider"))}get walletProvider(){return this.proxyProvider.walletProvider}setWalletProvider(r){this.proxyProvider.setWalletProvider(r)}async createProvider(){let r={};for(let a of this.chains){let l=wu(a.id,this.chains,this.rpcConfig,this.privyAppId);l&&(r[a.id]=l)}let o=this.shouldEnforceDefaultChainOnConnect?[this.defaultChain.id]:[],n=this.chains.map(a=>a.id),i=await v3.init({projectId:this.walletConnectCloudProjectId,chains:o,optionalChains:n,optionalEvents:C3,optionalMethods:w3,rpcMap:r,showQrModal:!1,metadata:{description:this.privyAppName,name:this.privyAppName,url:window.location.toString(),icons:[]}});return i.on("display_uri",a=>{if(i.signer.abortPairingAttempt(),b3&&this.walletEntry){let{redirect:l,href:s}=Eu(a,this.walletEntry);Su({href:s,name:this.walletEntry.displayName}),this.redirectUri=l,es(l,"_self")}else this.modal?.openModal({uri:a,chains:[this.defaultChain.id]})}),i.on("connect",()=>{if(this.modal?.closeModal(),i.session?.peer.metadata.url){let a=Qa(i.session?.peer.metadata.url);this.walletEntry=a?.entry,this.walletClientType=a?.walletClientType||"unknown"}}),i}async enableProvider(){return this.walletProvider?.connected?Promise.resolve(this.walletProvider.accounts):await this.walletProvider?.enable()}};var Fc=e=>{let t=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses")?.split(" ").filter(o=>E3(o)).map(o=>Om(o));return t?.length?!!e?.linkedAccounts.filter(o=>o.type=="wallet"&&t.includes(o.address)).length:!1},Rn=(e,t)=>e.rpcTimeouts?e.rpcTimeouts[t]||Zo:Zo,Vi=class extends T3{constructor(r,o,n,i,a,l,s,c,u,h,f){super();this.getEthereumProvider=()=>{let r=this.wallets[0],o=this.walletConnectors.find(n=>n.wallets.find(i=>i.address===r?.address));return!r||!o?new Oe:o.proxyProvider};this.privyAppId=r,this.walletConnectCloudProjectId=o,this.rpcConfig=n,this.chains=i,this.defaultChain=a,this.walletConnectors=[],this.initialized=!1,this.store=l,this.walletList=s,this.shouldEnforceDefaultChainOnConnect=c,this.externalWalletConfig=u,this.privyAppName=h,this.privyAppLogo=f,this.storedConnections=Uc()}get wallets(){let r=new Set,o=this.walletConnectors.flatMap(i=>i.wallets).sort((i,a)=>i.connectedAt&&a.connectedAt?a.connectedAt-i.connectedAt:0).filter(i=>{let a=`${i.address}${i.walletClientType}${i.connectorType}`;return r.has(a)?!1:(r.add(a),!0)}),n=o.findIndex(i=>i.address===(this.activeWallet?this.activeWallet:"unknown"));return n>=0&&o.unshift(o.splice(n,1)[0]),o}async initialize(){if(this.initialized)return;Z.get(_c)&&(Z.getKeys().forEach(o=>{o.startsWith("walletconnect")&&Z.del(o)}),Z.del(_c));let r=Cu(this.store,this.walletList,this.externalWalletConfig).then(o=>{o.forEach(({type:n,eip6963InjectedProvider:i,legacyInjectedProvider:a})=>{this.createWalletConnector("injected",n,{eip6963InjectedProvider:i,legacyInjectedProvider:a})})});this.walletList.includes("coinbase_wallet")&&this.createWalletConnector("coinbase_wallet","coinbase_wallet"),!vo()&&this.walletList.includes("phantom")&&this.createWalletConnector("phantom","phantom"),this.createWalletConnector("wallet_connect_v2","unknown"),await r,this.initialized=!0}findWalletConnector(r,o){return r==="wallet_connect_v2"?this.walletConnectors.find(n=>n.connectorType===r)??null:this.walletConnectors.find(n=>n.connectorType===r&&n.walletClientType===o)??null}onInitialized(r){r.wallets.forEach(o=>{let n=this.storedConnections.find(i=>i.address===o.address&&i.connectorType===o.connectorType&&i.walletClientType===o.walletClientType);n&&(o.connectedAt=n.connectedAt)}),this.saveConnectionHistory(),this.emit("walletsUpdated"),this.emit("connectorInitialized")}onWalletsUpdated(r){r.initialized&&(this.saveConnectionHistory(),this.emit("walletsUpdated"))}addEmbeddedWalletConnector(r,o,n,i){let a=this.findWalletConnector("embedded","privy");if(a)a.proxyProvider.walletProxy=r;else{let l=new Di(r,o,this.rpcConfig,this.chains,i,n.id),s=new Ui(l,this.chains,n,this.rpcConfig);this.addWalletConnector(s)}}addImportedWalletConnector(r,o,n,i){let a=this.findWalletConnector("embedded_imported","privy");if(a)a.proxyProvider.walletProxy=r;else{let l=new Di(r,o,this.rpcConfig,this.chains,i,n.id),s=!0,c=new Ui(l,this.chains,n,this.rpcConfig,s);this.addWalletConnector(c)}}removeEmbeddedWalletConnector(){let r=this.findWalletConnector("embedded","privy");if(r){let o=this.walletConnectors.indexOf(r);this.walletConnectors.splice(o,1),this.saveConnectionHistory(),this.storedConnections=Uc(),this.emit("walletsUpdated")}}removeImportedWalletConnector(){let r=this.findWalletConnector("embedded_imported","privy");if(r){let o=this.walletConnectors.indexOf(r);this.walletConnectors.splice(o,1),this.saveConnectionHistory(),this.storedConnections=Uc(),this.emit("walletsUpdated")}}async createWalletConnector(r,o,n){let i=this.findWalletConnector(r,o);if(i)return i instanceof Gr&&i.resetConnection(o),i;let l=(()=>{if(r==="injected"){if(o==="metamask"&&n?.eip6963InjectedProvider)return new Es(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask");if(o==="metamask"&&n?.legacyInjectedProvider)return new On(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"metamask");if(o==="phantom"&&n?.legacyInjectedProvider)return new On(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"phantom");if(n?.legacyInjectedProvider&&o==="unknown_browser_extension")return new On(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider);if(n?.eip6963InjectedProvider)return new Ln(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,o)}else return r==="coinbase_wallet"?new ws(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig,this.privyAppName,this.privyAppLogo):r==="phantom"?new Ps(this.defaultChain):new Gr(this.walletConnectCloudProjectId,this.rpcConfig,this.chains,this.defaultChain,this.shouldEnforceDefaultChainOnConnect,this.privyAppId,this.privyAppName,o)})();return l&&this.addWalletConnector(l),l||null}addWalletConnector(r){this.walletConnectors.push(r),r.on("initialized",()=>this.onInitialized(r)),r.on("walletsUpdated",()=>this.onWalletsUpdated(r)),r.initialize().catch(o=>{console.debug("Failed to initialize connector",o)})}saveConnectionHistory(){let r=this.wallets.map(o=>({address:o.address,connectorType:o.connectorType,walletClientType:o.walletClientType,connectedAt:o.connectedAt}));Z.put(xc,r)}async activeWalletSign(r){let o=this.wallets,n=o.length>0?o[0]:null;return n?n.sign(r):null}setActiveWallet(r){this.activeWallet=Om(r),this.emit("walletsUpdated")}};function Cs(e,t){if(e.length!==t.length)return!1;for(let r=0;r<e.length;r++){let o=e[r],n=t[r];if(o?.address!==n?.address||o?.chainId!==n?.chainId||o?.connectorType!==n?.connectorType||o?.connectedAt!==n?.connectedAt||o?.walletClientType!==n?.walletClientType||o?.isConnected!==n?.isConnected||o?.linked!==n?.linked)return!1}return!0}var P3=e=>e&&typeof e.address=="string"&&typeof e.connectorType=="string"&&typeof e.walletClientType=="string"&&typeof e.connectedAt=="number",Uc=()=>{let e=Z.get(xc);return e&&Array.isArray(e)&&e.map(o=>P3(o)).every(Boolean)?e:[]};import{ofetch as S3}from"ofetch";var _3=[Ha,Va,Ga,za],Bs=class{constructor({appId:t,appClientId:r,client:o,defaults:n}){this.appId=t,this.appClientId=r,this.clientAnalyticsId=o.clientAnalyticsId,this.sdkVersion=Pc,this.client=o,this.defaults=n,this.fallbackApiUrl=o.fallbackApiUrl,this.baseFetch=S3.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:i,options:a})=>{let l=new Headers(a.headers);l.set("privy-app-id",this.appId),this.appClientId&&l.set("privy-client-id",this.appClientId),l.set("privy-ca-id",this.clientAnalyticsId||""),l.set("privy-client",`react-auth:${this.sdkVersion}`);let s=_3.includes(i.toString());if(!l.has("authorization")){let c=await this.client.getAccessToken({disableAutoRefresh:s});c!==null&&l.set("authorization",`Bearer ${c}`)}a.headers=l,a.retryDelay&&(a.retryDelay=a.retryDelay*3)},onRequestError:({error:i})=>{if(i instanceof DOMException&&i.name==="AbortError")throw new Fa}})}async get(t,r){try{return await this.baseFetch(t,r)}catch(o){throw ne(o)}}async post(t,r,o){try{return await this.baseFetch(t,{method:"POST",...r?{body:r}:{},...o})}catch(n){throw ne(n)}}async delete(t,r){try{return await this.baseFetch(t,{method:"DELETE",...r})}catch(o){throw ne(o)}}};var Nm=e=>({challenge:e.challenge,allowCredentials:e.allow_credentials?.map(t=>({id:t.id,type:t.type,transports:t.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});import Dn from"js-cookie";function Dm(e){return e instanceof go?"email":e instanceof en?"sms":e instanceof Xo?"siwe":e instanceof Sn?"custom_auth":e instanceof Ur?e.meta.provider:null}import*as Um from"jose";var Vr=class{static parse(t){try{return new Vr(t)}catch{return null}}constructor(t){this.value=t,this._decoded=Um.decodeJwt(t)}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(t=0){let r=Date.now(),o=(this.expiration-t)*1e3;return r>=o}};var x3=30,Hs=class{constructor(){this.authenticateOnce=new Fe(async t=>this._authenticate(t)),this.linkOnce=new Fe(async t=>this._link(t)),this.refreshOnce=new Fe(this._refresh.bind(this)),this.destroyOnce=new Fe(this._destroy.bind(this)),this.forkSessionOnce=new Fe(this._forkSession.bind(this))}get token(){try{let t=Z.get($o);return typeof t=="string"?new Vr(t).value:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get refreshToken(){try{let t=Z.get(ts);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get forkedToken(){try{let t=Z.get(Ai);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get mightHaveServerCookies(){try{let t=Dn.get(rs);return t!==void 0&&t.length>0}catch(t){console.error(t)}return!1}hasRefreshCredentials(){return this.mightHaveServerCookies||typeof this.token=="string"&&typeof this.refreshToken=="string"&&this.refreshToken!==Bu}hasRecoveryCredentials(){return typeof this.forkedToken=="string"}hasActiveToken(){let t=Vr.parse(this.token);return t!==null&&!t.isExpired(x3)}authenticate(t){return this.authenticateOnce.execute(t)}link(t){return this.linkOnce.execute(t)}refresh(){return this.refreshOnce.execute()}forkSession(){return this.forkSessionOnce.execute()}destroy(){return this.destroyOnce.execute()}async _authenticate(t){try{let r=await t.authenticate(),{user:o,is_new_user:n,oauth_provider_tokens:i}=r;this.handleTokenResponse(r);let a=i?{provider:i.provider,accessToken:i.access_token,accessTokenExpiresInSeconds:i.access_token_expires_in_seconds,refreshToken:i.refresh_token,scopes:i.scopes}:void 0,l=Dm(t);return l&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate",payload:{method:l,isNewUser:n}}),l==="siwe"&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate_siwe",payload:{connectorType:t.meta.connectorType,walletClientType:t.meta.walletClientType}}),{user:$t(o),isNewUser:n,oAuthProviderTokens:a}}catch(r){throw console.warn("Error authenticating session"),st(r)}}async _link(t){try{let r=await t.link(),o=r.oauth_provider_tokens,n=o?{provider:o.provider,accessToken:o.access_token,accessTokenExpiresInSeconds:o.access_token_expires_in_seconds,refreshToken:o.refresh_token,scopes:o.scopes}:void 0;return{user:$t(r),oAuthProviderTokens:n}}catch(r){throw console.warn("Error linking account"),st(r)}}async _refresh(){if(!this.api)throw new T("Session has no API instance");if(!this.client)throw new T("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let t=this.token,r=this.refreshToken,o=this.forkedToken;try{let n;if(t&&r||this.mightHaveServerCookies){let i={};t&&(i.authorization=`Bearer ${t}`);let a=r?{refresh_token:r}:{};n=await this.api.post(Ha,a,{headers:i}),o&&this.clearForkedToken()}else if(o)n=await this.api.post(Va,{refresh_token:o}),this.clearForkedToken();else return null;return this.handleTokenResponse(n),$t(n.user)}catch(n){if(n instanceof br&&n.privyErrorCode==="missing_or_invalid_token")return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw st(n)}}handleTokenResponse(t){t.session_update_action?t.session_update_action==="set"?(this.storeRefreshToken(t.refresh_token),this.storeToken(t.token)):t.session_update_action==="clear"?this.destroyLocalState():t.session_update_action==="ignore"&&t.token&&this.storeToken(t.token):(this.storeRefreshToken(t.refresh_token),this.storeToken(t.token))}async _destroy(){try{await this.api?.post(Ga,{refresh_token:this.refreshToken})}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new T("Session has no API instance");let t=this.refreshToken;try{let r=await this.api.post(Ap,{refresh_token:t});return this.storeRefreshToken(r.refresh_token),this.storeToken(r.token),r.new_session_refresh_token}catch(r){throw st(r)}}destroyLocalState(){this.storeRefreshToken(null),this.storeToken(null),this.clearForkedToken()}storeToken(t){if(typeof t=="string"){let r=Z.get($o);if(Z.put($o,t),!this.client?.useServerCookies){let o=Vr.parse(t)?.expiration;Dn.set(Sc,t,{sameSite:"Strict",secure:!0,expires:o?new Date(o*1e3):void 0})}r!==t&&this.client?.onStoreToken?.(t)}else Z.del($o),Dn.remove(Sc),this.client?.onDeleteToken?.()}storeRefreshToken(t){typeof t=="string"?(Z.put(ts,t),this.client?.useServerCookies||Dn.set(rs,"t",{sameSite:"Strict",secure:!0,expires:30})):(Z.del(ts),Dn.remove(Wu),Dn.remove(rs))}clearForkedToken(){Z.del(Ai)}};var Bc,Gs,Fm,zi=class{constructor(t){Ua(this,Gs);this.apiUrl=t.apiUrl||ki,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=!1,this.timeout=t.timeout||Iu,this.appId=t.appId,this.appClientId=t.appClientId,this.clientAnalyticsId=kp(this,Gs,Fm).call(this),Bc||(Bc=new Hs),this.session=Bc,this.api=this.generateApi(),this.session.client=this}initializeConnectorManager({walletConnectCloudProjectId:t,rpcConfig:r,chains:o,defaultChain:n,store:i,walletList:a,shouldEnforceDefaultChainOnConnect:l,externalWalletConfig:s,appName:c}){this.connectors||(this.connectors=new Vi(this.appId,t,r,o,n,i,a,l,s,c))}sessionHasActiveToken(){return this.session.hasActiveToken()}generateApi(){let t=new Bs({appId:this.appId,appClientId:this.appClientId,client:this,defaults:{baseURL:this.apiUrl,timeout:this.timeout}});return this.session.api=t,t}updateApiUrl(t){this.apiUrl=t||this.fallbackApiUrl,this.api=this.generateApi(),t&&(this.useServerCookies=!0)}authenticate(){if(!this.authFlow)throw new T("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new T("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.authFlow=void 0}startAuthFlow(t){return t.api=this.api,this.authFlow=t,this.authFlow}async initMfaSmsVerification(){try{await this.api.post(cu,{action:"verify"})}catch(t){throw ne(t)}}async initMfaPasskeyVerification(){try{let t=await this.api.post(du,{});return Nm(t.options)}catch(t){throw ne(t)}}async unlinkEmail(t){try{let r=await this.api.post(Gp,{address:t});return $t(r)}catch(r){throw st(r)}}async acceptTerms(){try{let t=await this.api.post(pu,{});return $t(t)}catch(t){throw st(t)}}async unlinkPhone(t){try{let r=await this.api.post($p,{phoneNumber:t});return $t(r)}catch(r){throw st(r)}}async unlinkWallet(t){try{let r=await this.api.post(Wp,{address:t});return $t(r)}catch(r){throw st(r)}}async unlinkOAuth(t,r){try{let o=await this.api.post(Jp,{provider:t,subject:r});return $t(o)}catch(o){throw st(o)}}async unlinkFarcaster(t){try{let r=await this.api.post(Up,{fid:t});return $t(r)}catch(r){throw st(r)}}async unlinkTelegram(t){try{let r=await this.api.post(lu,{telegram_user_id:t});return $t(r)}catch(r){throw st(r)}}async unlinkPasskey(t){try{let r=await this.api.post(iu,{credential_id:t});return $t(r)}catch(r){throw st(r)}}async createAnalyticsEvent({eventName:t,payload:r,timestamp:o,options:n}){if(!(typeof window>"u"))try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(za,{event_name:t,client_id:this.clientAnalyticsId,payload:{...r||{},clientTimestamp:o?o.toISOString():new Date().toISOString()}},{retry:-1,keepalive:n?.keepAlive??!1})}catch{}}async signMoonpayOnRampUrl(t){try{return this.api.post(uu,t)}catch(r){throw st(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()||this.session.hasRecoveryCredentials()?this.session.refresh():null}async getAccessToken(t){return this.session.hasActiveToken()?Vr.parse(this.session.token)?.audience!==this.appId?(await this.logout(),null):this.session.token:!t?.disableAutoRefresh&&this.session.hasRefreshCredentials()?(await this.session.refresh(),this.session.token):null}async getServerConfig(){try{let t={},r=this.session.token;r&&(t.authorization=`Bearer ${r}`);let o=await this.api.get(`/api/v1/apps/${this.appId}`,{baseURL:this.fallbackApiUrl,headers:t}),n=o.telegram_auth_config?{botId:o.telegram_auth_config.bot_id,botName:o.telegram_auth_config.bot_name}:void 0;return{id:o.id,name:o.name,verificationKey:o.verification_key,logoUrl:o.logo_url||void 0,accentColor:o.accent_color||void 0,showWalletLoginFirst:o.show_wallet_login_first,allowlistConfig:{errorTitle:o.allowlist_config.error_title,errorDetail:o.allowlist_config.error_detail,errorCtaText:o.allowlist_config.cta_text,errorCtaLink:o.allowlist_config.cta_link},walletAuth:o.wallet_auth,emailAuth:o.email_auth,smsAuth:o.sms_auth,googleOAuth:o.google_oauth,twitterOAuth:o.twitter_oauth,discordOAuth:o.discord_oauth,githubOAuth:o.github_oauth,spotifyOAuth:o.spotify_oauth,instagramOAuth:o.instagram_oauth,tiktokOAuth:o.tiktok_oauth,linkedinOAuth:o.linkedin_oauth,appleOAuth:o.apple_oauth,farcasterAuth:o.farcaster_auth,passkeyAuth:o.passkey_auth,telegramAuth:o.telegram_auth,termsAndConditionsUrl:o.terms_and_conditions_url,embeddedWalletConfig:{createOnLogin:o.embedded_wallet_config?.create_on_login,userOwnedRecoveryOptions:o.embedded_wallet_config.user_owned_recovery_options,requireUserOwnedRecoveryOnCreate:o.embedded_wallet_config.require_user_owned_recovery_on_create},privacyPolicyUrl:o.privacy_policy_url,requireUsersAcceptTerms:o.require_users_accept_terms,customApiUrl:o.custom_api_url,walletConnectCloudProjectId:o.wallet_connect_cloud_project_id,fiatOnRampEnabled:o.fiat_on_ramp_enabled,captchaEnabled:o.captcha_enabled,captchaSiteKey:o.captcha_site_key,twitterOAuthOnMobileEnabled:o.twitter_oauth_on_mobile_enabled,createdAt:new Date(o.created_at*1e3),updatedAt:new Date(o.updated_at*1e3),mfaMethods:o.mfa_methods,enforceWalletUis:o.enforce_wallet_uis,legacyWalletUiConfig:o.legacy_wallet_ui_config,telegramAuthConfiguration:n}}catch(t){throw st(t)}}async getUsdTokenPrice(t){try{return(await this.api.get(`/api/v1/token_price?chainId=${t.id}&tokenSymbol=${t.nativeCurrency.symbol}`)).usd}catch{console.error(`Unable to fetch token price for chain with id ${t.id}`);return}}async requestFarcasterSignerStatus(t){try{return await this.api.post("/api/v1/farcaster/signer/status",{ed25519_public_key:t})}catch(r){throw console.error("Unable to fetch Farcaster signer status"),r}}async forkSession(){return await this.session.forkSession()}};Gs=new WeakSet,Fm=function(){if(typeof window>"u")return null;try{let r=Z.get(Ri);if(typeof r=="string"&&r.length>0)return r}catch{}let t=k3();try{return Z.put(Ri,t),t}catch{return t}};import{Turnstile as L3}from"@marsidev/react-turnstile";import{useEffect as O3,useMemo as N3}from"react";import{useMemo as A3,useRef as R3,useContext as I3,useState as Hc,createContext as M3}from"react";import{jsx as W3}from"react/jsx-runtime";var Bm=M3({siteKey:"",enabled:!1,appId:void 0,token:void 0,error:void 0,status:"disabled",setToken:b,setError:b,setExecuting:b,waitForResult:()=>Promise.resolve(""),ref:{current:null},remove:b,reset:b,execute:b}),Tr=class extends ze{constructor(r,o,n){super(r||"Captcha failed");this.type="Captcha";o instanceof Error&&(this.cause=o),this.privyErrorCode=n}},Hm=({children:e,id:t,captchaSiteKey:r,captchaEnabled:o})=>{let n=R3(null),[i,a]=Hc(),[l,s]=Hc(),[c,u]=Hc(!1),h=A3(()=>o?!c&&!i&&!l?{status:"ready"}:c&&!i&&!l?{status:"loading"}:i&&!l?{status:"success",token:i}:l?{status:"error",error:l}:{status:"ready"}:{status:"disabled"},[o,i,l,c]);return W3(Bm.Provider,{value:{...h,ref:n,enabled:o,siteKey:r,appId:t,setToken:a,setError:s,setExecuting:u,remove(){o&&(n.current?.remove(),u(!1),s(void 0),a(void 0))},reset(){o&&(n.current?.reset(),u(!1),s(void 0),a(void 0))},execute(){o&&(u(!0),n.current?.execute())},async waitForResult(){if(!o)return"";try{return await gu(()=>n.current?.getResponse(),{interval:200,timeout:2e4})}catch{throw new Tr("Captcha failed",null,"captcha_timeout")}}},children:e})},he=()=>I3(Bm);import{jsx as Gm}from"react/jsx-runtime";var Gc=e=>{let{enabled:t,siteKey:r,appId:o,setError:n,setToken:i,setExecuting:a,ref:l}=he(),[,s]=N3(()=>r?.split("t:")||[],[r]);if(O3(()=>l.current?.remove,[]),!t)return null;if(!s)throw new Error("Unsupported captcha site key");return Gm("div",{className:"hidden h-0 w-0",children:Gm(L3,{...e,ref:l,siteKey:s,options:{action:o,size:"invisible",...e.delayedExecution?{appearance:"execute",execution:"execute"}:{appearance:"always",execution:"render"}},onUnsupported:()=>{e.onUnsupported?.(),console.warn("Browser does not support Turnstile.")},onError:()=>{e.onError?.(),n("Captcha failed"),a(!1)},onSuccess:c=>{e.onSuccess?.(c),i(c),a(!1)},onExpire:()=>{e.onExpire?.();try{l.current?.reset(),n(void 0),i(void 0)}catch{n("expired_and_failed_reset")}}})})};import{useCallback as Db,useEffect as Jg,useRef as Ub,useState as Fb}from"react";import e2 from"styled-components";import{createContext as D3,useContext as U3}from"react";var Vc=D3({isNewUserThisSession:!1,linkingHint:null,walletConnectionStatus:null,mipdStore:null,connectors:[],rpcConfig:{rpcUrls:{}},showFiatPrices:!0,chains:[],clientAnalyticsId:null,pendingTransaction:null,appId:"notAdded",nativeTokenSymbolForChainId:b,initializeWalletProxy:b,getAuthMeta:b,getAuthFlow:b,closePrivyModal:b,openPrivyModal:b,connectWallet:b,initLoginWithWallet:b,loginWithWallet:b,initLoginWithFarcaster:b,loginWithFarcaster:b,loginWithCode:b,initLoginWithEmail:b,initLoginWithSms:b,initUpdateEmail:b,resendEmailCode:b,resendSmsCode:b,initLoginWithHeadlessOAuth:b,loginWithHeadlessOAuth:b,initLoginWithOAuth:b,recoveryOAuthFlow:b,loginWithOAuth:b,initLoginWithPasskey:b,loginWithPasskey:b,initLinkWithPasskey:b,linkWithPasskey:b,refreshUser:b,walletProxy:null,createAnalyticsEvent:b,acceptTerms:b,getUsdTokenPrice:b,recoverEmbeddedWallet:b,getFiatOnRampConfig:b,updateWallets:b,fundWallet:b,setReadyToTrue:b,requestFarcasterSignerStatus:b,initLoginWithTelegram:b,loginWithTelegram:b}),M=()=>U3(Vc);import{createContext as F3,useContext as B3}from"react";var ve=F3({ready:!1,authenticated:!1,user:null,walletConnectors:null,connectWallet:b,login:b,connectOrCreateWallet:b,linkEmail:b,linkPhone:b,linkFarcaster:b,linkWallet:b,linkGoogle:b,linkTwitter:b,linkDiscord:b,linkGithub:b,linkSpotify:b,linkInstagram:b,linkTelegram:b,linkTiktok:b,linkLinkedIn:b,linkApple:b,linkPasskey:b,updateEmail:b,logout:b,getAccessToken:b,getEthereumProvider:b,getEthersProvider:b,getWeb3jsProvider:b,unlinkEmail:b,unlinkPhone:b,unlinkWallet:b,unlinkGoogle:b,unlinkTwitter:b,unlinkDiscord:b,unlinkGithub:b,unlinkSpotify:b,unlinkInstagram:b,unlinkTiktok:b,unlinkLinkedIn:b,unlinkApple:b,unlinkFarcaster:b,unlinkTelegram:b,unlinkPasskey:b,setActiveWallet:b,forkSession:b,createWallet:b,importWallet:b,signMessage:b,signTypedData:b,enrollInMfa:b,initEnrollmentWithSms:b,initEnrollmentWithTotp:b,initEnrollmentWithPasskey:b,promptMfa:b,init:b,submitEnrollmentWithSms:b,submitEnrollmentWithTotp:b,submitEnrollmentWithPasskey:b,unenroll:b,submit:b,cancel:b,sendTransaction:b,exportWallet:b,setWalletPassword:b,requestFarcasterSignerFromWarpcast:b,getFarcasterSignerPublicKey:b,signFarcasterMessage:b,initLoginWithEmail:b,initLoginWithSms:b,otpState:{status:"initial"},loginWithCode:b,fundWallet:b,initLoginWithHeadlessOAuth:b,loginWithHeadlessOAuth:b,isHeadlessOAuthLoading:!1,isModalOpen:!1,mfaMethods:[]}),F=()=>B3(ve);import{useEffect as H3,useState as G3}from"react";var Vm=e=>{let[t,r]=G3("auto");return H3(()=>{let o=new ResizeObserver(n=>{r(n[0]?.contentRect.height??"auto")});return e.current&&o.observe(e.current),()=>{e.current&&o.unobserve(e.current)}},[e.current]),t};import{createContext as V3,useContext as z3,useEffect as q3}from"react";var zm={login:{onComplete:[],onError:[],onOAuthLoginComplete:[]},logout:{onSuccess:[]},connectWallet:{onSuccess:[],onError:[]},createWallet:{onSuccess:[],onError:[]},linkAccount:{onSuccess:[],onError:[]},configureMfa:{onMfaRequired:[]},setWalletPassword:{onSuccess:[],onError:[]},signMessage:{onSuccess:[],onError:[]},signTypedData:{onSuccess:[],onError:[]},sendTransaction:{onSuccess:[],onError:[]},accessToken:{onAccessTokenGranted:[],onAccessTokenRemoved:[]}},zc=V3(void 0),qm=()=>z3(zc);function He(e,t){if(!t)return;let o=qm().current[e];return q3(()=>{for(let[n,i]of Object.entries(t))o.hasOwnProperty(n)||console.warn(`Invalid event type "${n}" for action "${e}"`),o[n]?.push(i);return()=>{for(let[n,i]of Object.entries(t))o.hasOwnProperty(n)||console.warn(`Invalid event type "${n}" for action "${e}"`),o[n]=o[n]?.filter(a=>a!==i)}},[t])}function U(e,t,r,...o){for(let n of e.current[t][r])n(...o)}function Vs(){let e=qm();return(t,r,...o)=>U(e,t,r,...o)}function qc(e){He("configureMfa",e)}import Xm from"@heroicons/react/24/outline/ArrowTopRightOnSquareIcon";import d0 from"@heroicons/react/24/solid/DocumentCheckIcon";import p0 from"styled-components";import rn,{css as Yc}from"styled-components";import Kc from"styled-components";import{Fragment as K3,jsx as $c,jsxs as j3}from"react/jsx-runtime";var tt=({success:e,fail:t})=>j3(K3,{children:[$c(rt,{className:e?"success":t?"fail":""}),$c(jc,{className:e?"success":t?"fail":""})]}),rt=Kc.span`
12
+ - https://privy.io`;this.getNonceOnce=new Fe(this._getNonceOnce.bind(this)),this.wallet=t,this.captchaToken=r}get meta(){return{connectorType:this.wallet.connectorType,walletClientType:this.wallet.walletClientType}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");try{let{message:t,signature:r}=await this.sign(),o=await this.api.post(Ip,{message:t,signature:r,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType});return{user:o.user,token:o.token,refresh_token:o.refresh_token,is_new_user:o.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");try{let{message:t,signature:r}=await this.sign();return await this.api.post(Mp,{message:t,signature:r,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(t){throw ne(t)}}async sign(){if(!this.api)throw new T("Auth flow has no API instance");if(await this.buildSiweMessage(),!this.preparedMessage)throw new T("Could not prepare SIWE message");let t=await this.wallet.sign(this.preparedMessage);return{message:this.preparedMessage,signature:t}}async _getNonceOnce(){if(!this.api)throw new T("Auth flow has no API instance");let t=this.wallet.address;return(await this.api.post(Rp,{address:t,token:this.captchaToken})).nonce}async buildSiweMessage(){if(!this.api)throw new T("Auth flow has no API instance");let t=this.wallet.address,r=this.wallet.chainId.replace("eip155:","");return this.nonce||(this.nonce=await this.getNonceOnce.execute()),this.preparedMessage=this.prepareMessage(r,t,this.nonce),this.preparedMessage}prepareMessage(t,r,o){let n=window.location.host,i=window.location.origin,a="By signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.",l=new Date().toISOString();return this.createSiweMessage(t,r,n,i,l,o,a)}};var en=class{constructor(t,r){this.meta={phoneNumber:t,captchaToken:r}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new T("phone number and sms code must be set prior to calling authenticate.");try{let t=await this.api.post(Kp,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new T("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(qp,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(t){throw ne(t)}}async sendSmsCode(t,r){if(!this.api)throw new T("Auth flow has no API instance");if(t&&(this.meta.phoneNumber=t),r&&(this.meta.captchaToken=r),!this.meta.phoneNumber)throw new T("phone nNumber must be set when initialzing authentication.");try{return await this.api.post(zp,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken})}catch(o){throw ne(o)}}};var Oi=class{constructor(t){this.meta={captchaToken:t}}async authenticate(){if(!this.api)throw new T("Auth flow has no API instance");try{let t=await this.api.post(au,{captcha_token:this.meta.captchaToken,telegram_auth_result:this.meta.telegramAuthResult});return{user:t.user,token:t.token,refresh_token:t.refresh_token,is_new_user:t.is_new_user}}catch(t){throw ne(t)}}async link(){if(!this.api)throw new T("Auth flow has no API instance");try{return await this.api.post(su,{telegram_auth_result:this.meta.telegramAuthResult})}catch(t){throw ne(t)}}};function Ic(e){let t={detail:"",retryable:!1};return e?.privyErrorCode==="linked_to_another_user"&&(t.detail="This account has already been linked to another user."),e?.privyErrorCode==="disallowed_login_method"&&(t.detail="Login with Telegram not allowed."),e?.privyErrorCode==="invalid_data"&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode==="cannot_link_more_of_type"&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode==="invalid_credentials"&&(t.retryable=!0,t.detail="Something went wrong. Try again."),e?.privyErrorCode==="too_many_requests"&&(t.detail="Too many requests. Please wait before trying again."),e?.privyErrorCode==="too_many_requests"&&e.message.includes("rate limit")&&(t.detail="Request limit reached for Telegram. Please wait a moment and try again."),t}import{v4 as k3}from"uuid";function j(e){return e?new Date(e*1e3):null}function N2(e){let t=[];for(let r of e){let o=r.type;switch(r.type){case"wallet":let n={address:r.address,type:r.type,imported:r.imported,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at),chainType:"ethereum",chainId:r.chain_id,walletClient:r.wallet_client_type==="privy"?"privy":"unknown",walletClientType:r.wallet_client_type,connectorType:r.connector_type,recoveryMethod:r.recovery_method};t.push(n);break;case"email":let i={address:r.address,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(i);break;case"phone":let a={number:r.phoneNumber,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(a);break;case"google_oauth":let l={subject:r.subject,email:r.email,name:r.name,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(l);break;case"spotify_oauth":let s={subject:r.subject,email:r.email,name:r.name,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(s);break;case"instagram_oauth":let c={subject:r.subject,username:r.username,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(c);break;case"twitter_oauth":let u={subject:r.subject,username:r.username,name:r.name,type:r.type,profilePictureUrl:r.profile_picture_url,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(u);break;case"discord_oauth":let h={subject:r.subject,username:r.username,email:r.email,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(h);break;case"github_oauth":let f={subject:r.subject,username:r.username,name:r.name,email:r.email,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(f);break;case"tiktok_oauth":let y={subject:r.subject,username:r.username,name:r.name,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(y);break;case"linkedin_oauth":let v={subject:r.subject,name:r.name,email:r.email,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(v);break;case"apple_oauth":let g={subject:r.subject,email:r.email,type:r.type,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(g);break;case"custom_auth":t.push({type:r.type,customUserId:r.custom_user_id,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)});break;case"farcaster":let x={type:r.type,fid:r.fid,ownerAddress:r.owner_address,displayName:r.display_name,username:r.username,bio:r.bio,pfp:r.profile_picture_url,url:r.homepage_url,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at),signerPublicKey:r.signer_public_key};t.push(x);break;case"passkey":let S={type:r.type,enrolledInMfa:r.enrolled_in_mfa,credentialId:r.credential_id,authenticatorName:r.authenticator_name,createdWithDevice:r.created_with_device,createdWithOs:r.created_with_os,createdWithBrowser:r.created_with_browser,verifiedAt:j(r.verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(S);break;case"telegram":let w={type:r.type,telegramUserId:r.telegram_user_id,firstName:r.first_name,lastName:r.last_name,username:r.username,photoUrl:r.photo_url,verifiedAt:j(r.first_verified_at),firstVerifiedAt:j(r.first_verified_at),latestVerifiedAt:j(r.latest_verified_at)};t.push(w);break;default:console.warn(`Unrecognized account type: ${o}. Please consider upgrading the Privy SDK.`)}}return t}function Wt(e,t){return e.slice().sort((r,o)=>(o.firstVerifiedAt??o.verifiedAt).getTime()-(r.firstVerifiedAt??r.verifiedAt).getTime()).find(r=>r.type===t)}var Me=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy"&&!t.imported)||null,Mc=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy"&&t.imported)||null,D2=e=>e.linkedAccounts.filter(t=>t.type==="wallet"),Lt=(e,t)=>t==="all-users"&&!Me(e)||t==="users-without-wallets"&&!D2(e)?.length;function $t(e){if(!e)return null;let t=N2(e.linked_accounts),r=Wt(t,"wallet"),o=Wt(t,"email"),n=Wt(t,"phone"),i=Wt(t,"google_oauth"),a=Wt(t,"twitter_oauth"),l=Wt(t,"discord_oauth"),s=Wt(t,"github_oauth"),c=Wt(t,"spotify_oauth"),u=Wt(t,"instagram_oauth"),h=Wt(t,"tiktok_oauth"),f=Wt(t,"linkedin_oauth"),y=Wt(t,"apple_oauth"),v=Wt(t,"farcaster"),g=Wt(t,"telegram"),x=e.mfa_methods.map(({type:w,verified_at:_})=>({type:w,verifiedAt:j(_)}));return{id:e.id,createdAt:j(e.created_at),linkedAccounts:t,email:o&&{address:o?.address},phone:n&&{number:n?.number},wallet:r&&{address:r.address,chainType:r.chainType,chainId:r.chainId,walletClient:r.walletClient,walletClientType:r.walletClientType,connectorType:r.connectorType,recoveryMethod:r.recoveryMethod,imported:r.imported},google:i&&{subject:i.subject,email:i.email,name:i.name},twitter:a&&{subject:a.subject,username:a.username,name:a.name,profilePictureUrl:a.profilePictureUrl},discord:l&&{subject:l.subject,username:l.username,email:l.email},github:s&&{subject:s.subject,username:s.username,name:s.name,email:s.email},spotify:c&&{subject:c.subject,email:c.email,name:c.name},instagram:u&&{subject:u.subject,username:u.username},tiktok:h&&{subject:h.subject,username:h.username,name:h.name},linkedin:f&&{subject:f.subject,name:f.name,email:f.email},apple:y&&{subject:y.subject,email:y.email},farcaster:v&&{fid:v.fid,ownerAddress:v.ownerAddress,displayName:v.displayName,username:v.username,bio:v.bio,pfp:v.pfp,url:v.url,signerPublicKey:v.signerPublicKey},telegram:g&&{telegramUserId:g.telegramUserId,firstName:g.firstName,lastName:g.lastName,username:g.username,photoUrl:g.photoUrl},mfaMethods:x.map(w=>w.type),hasAcceptedTerms:e.has_accepted_terms??!1}}import{getAddress as Om}from"@ethersproject/address";import{isHexString as E3}from"@ethersproject/bytes";import T3 from"eventemitter3";import K2 from"@coinbase/wallet-sdk";import{jsx as Zu,jsxs as U2}from"react/jsx-runtime";var Ni=({style:e,...t})=>U2("svg",{width:"1024",height:"1024",viewBox:"0 0 1024 1024",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...e},...t,children:[Zu("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),Zu("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"})]});import{getAddress as Br}from"@ethersproject/address";import{Web3Provider as rm}from"@ethersproject/providers";import{default as q2}from"eventemitter3";import z2 from"eventemitter3";var F2=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4"],Ju=e=>F2.includes(e);import{ErrorCode as B2}from"@ethersproject/logger";var kn=class extends te{constructor(){super("Wallet timeout");this.type="wallet_error"}},An=class extends te{constructor(){super("User rejected connection");this.type="wallet_error"}},Er=e=>{if(e instanceof te)return e;if(e?.code&&e?.reason){let t=new Be(e);return e.code===B2.ACTION_REJECTED&&(t.details=lt.E4001_USER_REJECTED_REQUEST),t}return e?.code?new Be(e):new te("Unknown connector error",e)},Kt=class extends ze{constructor(r,o,n){super(r);this.type="provider_error";this.code=o,this.data=n}},Be=class extends Kt{constructor(r){let o=r;super(o.message,o.code,o.data);let n=Object.values(lt).find(i=>i.eipCode===o.code);this.details=n||lt.UNKNOWN_ERROR,o.code===-32002&&(o.message?.includes("already pending for origin")?o.message?.includes("wallet_requestPermissions")?this.details=lt.E32002_CONNECTION_ALREADY_PENDING:this.details=lt.E32002_REQUEST_ALREADY_PENDING:o.message?.includes("Already processing")&&o.message.includes("eth_requestAccounts")&&(this.details=lt.E32002_WALLET_LOCKED))}},H2={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_REJECTED_CONNECTION:{message:"You rejected the request",detail:"Please try connecting again.",retryable:!0}},G2={E32002_CONNECTION_ALREADY_PENDING:{eipCode:-32002,message:"Connection request already pending",detail:"Don\u2019t see your wallet? Check your other browser windows.",retryable:!1},E32002_REQUEST_ALREADY_PENDING:{eipCode:-32002,message:"Resource request already pending",detail:"Don\u2019t see your wallet? Check your other browser windows.",retryable:!1},E32002_WALLET_LOCKED:{eipCode:-32002,message:"Wallet might be locked",detail:"Don\u2019t see your wallet? Check your other browser windows.",retryable:!1},E4001_USER_REJECTED_REQUEST:{eipCode:4001,message:"Signature rejected",detail:"Please try signing again.",retryable:!0}},V2={E4001_DEFAULT_USER_REJECTED_REQUEST:{eipCode:4001,message:"User Rejected Request",detail:"The user rejected the request.",default:!0,retryable:!0},E4100_DEFAULT_UNAUTHORIZED:{eipCode:4100,message:"Unauthorized",detail:"The requested method and/or account has not been authorized by the user.",default:!0,retryable:!1},E4200_DEFAULT_UNSUPPORTED_METHOD:{eipCode:4200,message:"Unsupported Method",detail:"The Provider does not support the requested method.",default:!0,retryable:!1},E4900_DEFAULT_DISCONNECTED:{eipCode:4900,message:"Disconnected",detail:"The Provider is disconnected from all chains.",default:!0,retryable:!0},E4901_DEFAULT_CHAIN_DISCONNECTED:{eipCode:4901,message:"Chain Disconnected",detail:"The Provider is not connected to the requested chain.",default:!0,retryable:!0},E32700_DEFAULT_PARSE_ERROR:{eipCode:-32700,message:"Parse error",detail:"Invalid JSON",default:!0,retryable:!1},E32600_DEFAULT_INVALID_REQUEST:{eipCode:-32600,message:"Invalid request",detail:"JSON is not a valid request object",default:!0,retryable:!1},E32601_DEFAULT_METHOD_NOT_FOUND:{eipCode:-32601,message:"Method not found",detail:"Method does not exist",default:!0,retryable:!1},E32602_DEFAULT_INVALID_PARAMS:{eipCode:-32602,message:"Invalid params",detail:"Invalid method parameters",default:!0,retryable:!1},E32603_DEFAULT_INTERNAL_ERROR:{eipCode:-32603,message:"Internal error",detail:"Internal JSON-RPC error",default:!0,retryable:!0},E32000_DEFAULT_INVALID_INPUT:{eipCode:-32e3,message:"Invalid input",detail:"Missing or invalid parameters",default:!0,retryable:!1},E32001_DEFAULT_RESOURCE_NOT_FOUND:{eipCode:-32001,message:"Resource not found",detail:"Requested resource not found",default:!0,retryable:!1},E32002_DEFAULT_RESOURCE_UNAVAILABLE:{eipCode:-32002,message:"Resource unavailable",detail:"Requested resource not available",default:!0,retryable:!0},E32003_DEFAULT_TRANSACTION_REJECTED:{eipCode:-32003,message:"Transaction rejected",detail:"Transaction creation failed",default:!0,retryable:!0},E32004_DEFAULT_METHOD_NOT_SUPPORTED:{eipCode:-32004,message:"Method not supported",detail:"Method is not implemented",default:!0,retryable:!1},E32005_DEFAULT_LIMIT_EXCEEDED:{eipCode:-32005,message:"Limit exceeded",detail:"Request exceeds defined limit",default:!0,retryable:!1},E32006_DEFAULT_JSON_RPC_VERSION_NOT_SUPPORTED:{eipCode:-32006,message:"JSON-RPC version not supported",detail:"Version of JSON-RPC protocol is not supported",default:!0,retryable:!1}},lt={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...V2,...G2},no={...H2,...lt};var Oe=class{constructor(t,r){this.removeListener=(t,r)=>{if(this.walletProvider)try{return this.walletProvider.removeListener(t,r)}catch{console.warn("Unable to remove wallet provider listener")}};this.walletTimeout=(t=new kn,r=this.rpcTimeoutDuration)=>new Promise((o,n)=>setTimeout(()=>{n(t)},r));this.setWalletProvider=t=>{this.walletProvider&&this._subscriptions.forEach(r=>{this.removeListener(r.eventName,r.listener)}),this.walletProvider=t,this._subscriptions.forEach(r=>{this.walletProvider?.on(r.eventName,r.listener)})};this.walletProvider=t,this.rpcTimeoutDuration=r||Zo,this._subscriptions=[]}on(t,r){if(this.walletProvider)return this.walletProvider.on(t,r);this._subscriptions.push({eventName:t,listener:r})}async request(t){if(!this.walletProvider)throw new te(`A wallet request of type ${t.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(t),this.walletTimeout()]).catch(r=>{throw Er(r)})}},wo=class extends Error{constructor(r,o,n){super(r);this.code=o,this.data=n}},Di=class extends z2{constructor(r,o,n,i,a,l=1){super();this.walletProxy=r,this.address=o,this.chainId=l,this.rpcConfig=n,this.chains=i,this.provider=ro(l,this.chains,n,{appId:a}),this.rpcTimeoutDuration=Rn(n,"privy"),this.appId=a}async handleSendTransaction(r){if(!r.params||!Array.isArray(r.params))throw new wo(`Invalid params for ${r.method}`,4200);let o=r.params[0];if(!await be()||!this.address)throw new wo("Disconnected",4900);return(await em(o)).hash}handleSwitchEthereumChain(r){if(!r.params||!Array.isArray(r.params))throw new wo(`Invalid params for ${r.method}`,4200);let o;if(typeof r.params[0]=="string")o=r.params[0];else if("chainId"in r.params[0]&&typeof r.params[0].chainId=="string")o=r.params[0].chainId;else throw new wo(`Invalid params for ${r.method}`,4200);this.chainId=Number(o),this.provider=ro(this.chainId,this.chains,this.rpcConfig,{appId:this.appId}),this.emit("chainChanged",o)}async handlePersonalSign(r){if(!r.params||!Array.isArray(r.params))throw new Error("Invalid params for personal_sign");let o=r.params[0],n=r.params[1];return await Qu(o,void 0,n)}async handleSignedTypedData(r){if(!r.params||!Array.isArray(r.params))throw new Error("Invalid params for eth_signTypedData_v4");let o=typeof r.params[1]=="string"?JSON.parse(r.params[1]):r.params[1];return await Xu(Ja(o))}async handleEstimateGas(r){if(!r.params||!Array.isArray(r.params))throw new Error("Invalid params for eth_estimateGas");delete r.params[0].gasPrice,delete r.params[0].maxFeePerGas,delete r.params[0].maxPriorityFeePerGas;let o={...r.params[0],chainId:qo(this.chainId)};try{return await this.provider.send("eth_estimateGas",[o])}catch(n){console.warn(`Gas estimation failed with error: ${n}. Retrying gas estimation by omitting the 'from' address`);try{return delete o.from,await this.provider.send("eth_estimateGas",[o])}catch(i){throw console.warn(`Gas estimation failed with error: ${i} when omitting the 'from' address`),n}}}async request(r){switch(console.debug("Embedded1193Provider.request() called with args",r),r.method){case"eth_accounts":case"eth_requestAccounts":return this.address?[this.address]:[];case"eth_chainId":return qo(this.chainId);case"eth_estimateGas":return this.handleEstimateGas(r);case"eth_sendTransaction":return this.handleSendTransaction(r);case"wallet_switchEthereumChain":return this.handleSwitchEthereumChain(r);case"personal_sign":return this.handlePersonalSign(r);case"eth_signTypedData_v4":return this.handleSignedTypedData(r);default:break}if(Ju(r.method)){let o=await be();if(await tm(),!o||!this.address)throw new wo("Disconnected",4900);try{return(await this.walletProxy.rpc({address:this.address,accessToken:o,request:{method:r.method,params:r.params}})).response.data}catch(n){throw console.error(n),new wo("Disconnected",4900)}}else return this.provider.send(r.method,r.params)}async connect(){let r=await be();if(!r||!this.address)return null;try{return(await this.walletProxy.connect({address:this.address,accessToken:r})).address}catch(o){return console.error(o),null}}},Fr=class extends Oe{constructor(r){super(r,r.rpcTimeoutDuration)}},bo=class extends Oe{constructor(t){super(t,t.rpcTimeoutDuration)}sendAsync(t,r){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};var $2=(e,t)=>{switch(t){case"coinbase_wallet":return e.message.includes("addEthereumChain");default:return e.code===4902||e.message?.includes("4902")}},Ot=class extends q2{constructor(r,o,n,i){super();this.onAccountsChanged=r=>{r.length===0?this.onDisconnect():this.syncAccounts(r)};this.onChainChanged=r=>{this.wallets.forEach(o=>{o.chainId=_n(r),this.walletClientType==="privy"&&Z.put(os(o.address),r)}),this.emit("walletsUpdated")};this.onDisconnect=()=>{this.connected=!1,this.wallets=[],this.emit("walletsUpdated")};this.onConnect=()=>{this.connected=!0,this.syncAccounts()};this.wallets=[],this.walletClientType=r,this.chains=o,this.defaultChain=n,this.rpcConfig=i,this.rpcTimeoutDuration=Rn(i,r),this.connected=!1,this.initialized=!1}buildConnectedWallet(r,o,n,i){let a=async()=>!!this.wallets.find(l=>Br(l.address)===Br(r));return{address:Br(r),chainId:o,meta:n,imported:i,switchChain:async l=>{if(!a)throw new te("Wallet is not currently connected.");let s=this.wallets.find(y=>Br(y.address)===Br(r))?.chainId;if(!s)throw new te("Unable to determine current chainId.");let c,u;if(typeof l=="number"?(c=`0x${l.toString(16)}`,u=l):(c=l,u=Number(l)),s===_n(c))return;let h=this.chains.find(y=>y.id===u);if(!h)throw new te(`Unsupported chainId: ${l}`);let f=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:c}]})};try{return await f()}catch(y){if($2(y,this.walletClientType))return await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:c,chainName:h.name,nativeCurrency:h.nativeCurrency,rpcUrls:[h.rpcUrls.default?.http[0]??""],blockExplorerUrls:[h.blockExplorers?.default.url??""]}]}),f();throw this.walletClientType==="rainbow"&&y.message?.includes("wallet_switchEthereumChain")?new te(`Rainbow does not support the chainId ${o}`):y}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:a,getEthereumProvider:async()=>{if(!await a())throw new te("Wallet is not currently connected.");return this.proxyProvider},getEthersProvider:async()=>{if(!await a())throw new te("Wallet is not currently connected.");return new rm(new Fr(this.proxyProvider))},getWeb3jsProvider:async()=>{if(!await a())throw new te("Wallet is not currently connected.");return new bo(this.proxyProvider)},sign:async l=>{if(!await a())throw new te("Wallet is not currently connected.");return await this.sign(l)},disconnect:()=>{this.disconnect()}}}async syncAccounts(r){let o=r;try{if(o===void 0){let c=await _i(()=>this.proxyProvider.request({method:"eth_accounts"}),{maxAttempts:10,delayMs:500});Array.isArray(c)&&(o=c)}}catch{console.warn("Wallet did not respond to eth_accounts. Defaulting to prefetched accounts.")}if(!o||!Array.isArray(o)||o.length<=0||!o[0])return;let n=o[0],i=Br(n),a=[],l;if(this.walletClientType==="privy"){let c=Z.get(os(i));this.chains.find(u=>u.id===Number(c))||(Z.del(os(i)),c=null),l=c||`0x${this.defaultChain.id.toString(16)}`;try{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:l}]})}catch{console.warn(`Unable to switch embedded wallet to chain ID ${l} on initialization`)}}else try{let c=await _i(()=>this.proxyProvider.request({method:"eth_chainId"}),{maxAttempts:10,delayMs:500});if(typeof c=="string")l=c;else if(typeof c=="number")l=`0x${c.toString(16)}`;else throw new Error("Invalid chainId returned from provider")}catch(c){console.warn(`Failed to get chainId from provider, defaulting to ${kc}`,c),l=kc}let s=_n(l);if(!a.find(c=>Br(c.address)===i)){let c={name:this.walletBranding.name,icon:typeof this.walletBranding.icon=="string"?this.walletBranding.icon:void 0,id:this.walletBranding.id};a.push(this.buildConnectedWallet(Br(n),s,c,this.connectorType==="embedded_imported"))}Cs(a,this.wallets)||(this.wallets=a,this.emit("walletsUpdated"))}async getConnectedWallet(){let r=await this.proxyProvider.request({method:"eth_accounts"});return this.wallets.sort((o,n)=>n.connectedAt-o.connectedAt).find(o=>r.find(n=>Br(n)===Br(o.address)))||null}async isConnected(){let r=await this.proxyProvider.request({method:"eth_accounts"});return Array.isArray(r)&&r.length>0}async sign(r){return await this.connect({showPrompt:!1}),new rm(new Fr(this.proxyProvider)).getSigner().signMessage(r)}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)}};var j2=[1,11155111,137,10,8453,84532,42161,7777777,43114,56],Y2=(e,t)=>e.makeWeb3Provider({options:t}),Wc,ws=class extends Ot{constructor(r,o,n,i,a,l){super("coinbase_wallet",r,o,n);this.connectorType="coinbase_wallet";this.displayName="Coinbase Wallet";if(this.proxyProvider=new Oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.connectionOptions=i.coinbaseWallet.connectionOptions??"eoaOnly",this.walletClientType=this.connectionOptions==="smartWalletOnly"?"coinbase_smart_wallet":"coinbase_wallet",this.walletClientType==="coinbase_smart_wallet"&&(this.displayName="Coinbase Smart Wallet"),!Wc){let s=[o.id].concat(r.map(u=>u.id)),c=this.connectionOptions!=="eoaOnly"?s.filter(u=>!j2.includes(u)):[];c.length>0&&console.warn(`The following configured chains are not supported by the Coinbase Smart Wallet: ${c.join(", ")}`),Wc=new K2({appName:a,appLogoUrl:l,appChainIds:s})}this.proxyProvider.setWalletProvider(Y2(Wc,this.connectionOptions))}async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(r){return r.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){this.proxyProvider.walletProvider.disconnect(),this.onDisconnect()}get walletBranding(){return{name:this.displayName,icon:Ni,id:"com.coinbase.wallet"}}async promptConnection(){try{let r=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!r||r.length===0||!r[0])throw new te("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([r[0]])}catch(r){throw Er(r)}}};import{jsx as om}from"react/jsx-runtime";var bs=({...e})=>om("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:om("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)"})});var Ui=class extends Ot{constructor(r,o,n,i,a=!1){super("privy",o,n,i);this.connectorType="embedded";this.proxyProvider=r,a&&(this.connectorType="embedded_imported"),this.subscribeListeners()}async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(r){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[qo(r?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:bs,id:"io.privy.wallet"}}disconnect(){this.connected=!1}async promptConnection(){}};import{jsx as nm}from"react/jsx-runtime";var In=({style:e,...t})=>nm("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...t,children:nm("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"})});import{jsx as jt,jsxs as Z2}from"react/jsx-runtime";var Mn=({style:e,...t})=>Z2("svg",{xmlns:"http://www.w3.org/2000/svg",xmlSpace:"preserve",x:0,y:0,viewBox:"0 0 318.6 318.6",width:"28",height:"28",style:{height:"28px",width:"28px",...e},...t,children:[jt("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),jt("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"}),jt("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"})]});import{jsx as im,jsxs as J2}from"react/jsx-runtime";var Hr=({style:e,...t})=>J2("svg",{xmlns:"http://www.w3.org/2000/svg",width:"108",height:"108",viewBox:"0 0 108 108",fill:"none",style:{height:"28px",width:"28px",...e},...t,children:[im("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),im("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"})]});var Ln=class extends Ot{constructor(r,o,n,i,a){super(a||"unknown",r,o,n);this.connectorType="injected";this.proxyProvider=new Oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=i;let l=i.provider;this.proxyProvider.setWalletProvider(l)}async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(r){return r.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 r=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!r||r.length===0||!r[0])throw new te("Unable to retrieve accounts");await this.syncAccounts([r[0]])}catch(r){throw Er(r)}}},Wn,On=class extends Ot{constructor(r,o,n,i,a){super(a??"unknown",r,o,n);this.connectorType="injected";Ua(this,Wn,void 0);this.proxyProvider=new Oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(i),a==="metamask"?Cc(this,Wn,{name:"MetaMask",icon:Mn,id:"io.metamask"}):a==="phantom"&&Cc(this,Wn,{name:"Phantom",icon:Hr,id:"phantom"})}async initialize(){await this.syncAccounts(),this.initialized=!0,this.emit("initialized")}async connect(r){return r.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return xp(this,Wn)??{name:"Browser Extension",icon:In,id:"extension"}}disconnect(){console.warn("Programmatic disconnect with browser wallets is not yet supported.")}async promptConnection(){try{let r=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!r||r.length===0||!r[0])throw new te("Unable to retrieve accounts");await this.syncAccounts([r[0]])}catch(r){throw Er(r)}}};Wn=new WeakMap;import{getAddress as WP}from"@ethersproject/address";import{Web3Provider as OP}from"@ethersproject/providers";import{isMobile as Q2}from"react-device-detect";var Es=class extends Ln{disconnect(){console.warn("MetaMask does not support programmatic disconnect.")}async promptConnection(){try{Q2||await this.proxyProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]});let t=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!t||t.length===0||!t[0])throw new te("Unable to retrieve accounts");await this.syncAccounts([t[0]])}catch(t){throw Er(t)}}};var Ts=class extends Ot{constructor(r,o){super(r,[],o,{});this.connectorType="null";this.proxyProvider=new Oe(void 0,Zo);this.connectorType=r}get walletBranding(){return{name:"Wallet",id:""}}async initialize(){this.initialized=!0,this.emit("initialized")}async connect(){throw new Error("connect called for an uninstalled wallet via the NullConnector")}disconnect(){throw new Error("disconnect called for an uninstalled wallet via the NullConnector")}promptConnection(r){throw new Error(`promptConnection called for an uninstalled wallet via the NullConnector for ${r}`)}};var Ps=class extends Ts{constructor(t){super("phantom",t)}get walletBranding(){return{name:"Phantom",icon:Hr,id:"phantom"}}};import{EthereumProvider as v3,OPTIONAL_EVENTS as C3,OPTIONAL_METHODS as w3}from"@walletconnect/ethereum-provider";import{isMobile as b3}from"react-device-detect";import{createContext as d3,useContext as p3,useEffect as Dc,useRef as u3,useState as m3}from"react";import{jsx as X2}from"react/jsx-runtime";function Ss({src:e,...t}){return X2("img",{src:e,...t,style:{display:"none"}})}import{useContext as Rm,useEffect as Am,useMemo as a3,useState as s3}from"react";import{createContext as l3}from"react";var Yt={appearance:{landingHeader:"Log in or sign up",theme:"light",accentColor:"#676FFF",walletList:["detected_wallets","metamask","coinbase_wallet","rainbow","wallet_connect"]},walletConnectCloudProjectId:Ru,rpcConfig:{rpcUrls:{},rpcTimeouts:{}},externalWallets:{coinbaseWallet:{connectionOptions:"eoaOnly"}},captchaEnabled:!1,_render:{standalone:!1},fiatOnRamp:{useSandbox:!1}};var am=({input:e})=>{if(!e||!e.primary[0])return;let t=[e.primary[0]],r=[];e.primary.length>4&&console.warn("You should not specify greater than 4 login methods in `loginMethodsAndOrder.primary`");for(let o of e.primary.slice(1))t.includes(o)?console.warn(`Duplicated login method: ${o}`):t.push(o);for(let o of e.overflow??[])!t.includes(o)&&!r.includes(o)?r.push(o):console.warn(`Duplicated login method: ${o}`);return{primary:t,overflow:r}};var e3=new Set(["coinbase_wallet","cryptocom","metamask","okx_wallet","phantom","rainbow","uniswap","zerion","wallet_connect","detected_wallets","rabby_wallet"]),sm=e=>e3.has(e),lm=(e,t,r)=>r.indexOf(e)===t,cm=({input:e,overrides:t})=>t?t.primary.concat(t.overflow??[]).filter(sm).filter(lm):e?e.filter(sm).filter(lm):Yt.appearance.walletList;var _s={id:42161,name:"Arbitrum One",network:"arbitrum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://arbitrum-mainnet.rpc.privy.systems"]},alchemy:{http:["https://arb-mainnet.g.alchemy.com/v2"],webSocket:["wss://arb-mainnet.g.alchemy.com/v2"]},infura:{http:["https://arbitrum-mainnet.infura.io/v3"],webSocket:["wss://arbitrum-mainnet.infura.io/ws/v3"]},default:{http:["https://arb1.arbitrum.io/rpc"]},public:{http:["https://arb1.arbitrum.io/rpc"]}},blockExplorers:{etherscan:{name:"Arbiscan",url:"https://arbiscan.io"},default:{name:"Arbiscan",url:"https://arbiscan.io"}}};var xs={id:421613,name:"Arbitrum Goerli",network:"arbitrum-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"AGOR",decimals:18},rpcUrls:{default:{http:["https://goerli-rollup.arbitrum.io/rpc"]}},blockExplorers:{default:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"}},testnet:!0};var ks={id:421614,name:"Arbitrum Sepolia",network:"arbitrum-sepolia",nativeCurrency:{name:"Arbitrum Sepolia Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://arbitrum-sepolia.rpc.privy.systems"]},default:{http:["https://sepolia-rollup.arbitrum.io/rpc"]},public:{http:["https://sepolia-rollup.arbitrum.io/rpc"]}},blockExplorers:{default:{name:"Blockscout",url:"https://sepolia-explorer.arbitrum.io"}},testnet:!0};var dm={id:43114,name:"Avalanche",network:"avalanche",nativeCurrency:{decimals:18,name:"Avalanche",symbol:"AVAX"},rpcUrls:{default:{http:["https://api.avax.network/ext/bc/C/rpc"]},public:{http:["https://api.avax.network/ext/bc/C/rpc"]}},blockExplorers:{etherscan:{name:"SnowTrace",url:"https://snowtrace.io"},default:{name:"SnowTrace",url:"https://snowtrace.io"}}};var pm={id:43113,name:"Avalanche Fuji",network:"avalanche-fuji",nativeCurrency:{decimals:18,name:"Avalanche Fuji",symbol:"AVAX"},rpcUrls:{default:{http:["https://api.avax-test.network/ext/bc/C/rpc"]},public:{http:["https://api.avax-test.network/ext/bc/C/rpc"]}},blockExplorers:{etherscan:{name:"SnowTrace",url:"https://testnet.snowtrace.io"},default:{name:"SnowTrace",url:"https://testnet.snowtrace.io"}},testnet:!0};var As={id:8453,network:"base",name:"Base",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://base-mainnet.rpc.privy.systems"]},blast:{http:["https://base-mainnet.blastapi.io"],webSocket:["wss://base-mainnet.blastapi.io"]},default:{http:["https://mainnet.base.org"]},public:{http:["https://mainnet.base.org"]}},blockExplorers:{etherscan:{name:"Basescan",url:"https://basescan.org"},default:{name:"Basescan",url:"https://basescan.org"}},testnet:!0};var Rs={id:84531,network:"base-goerli",name:"Base Goerli Testnet",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://goerli.base.org"]}},blockExplorers:{default:{name:"Basescan",url:"https://goerli.basescan.org"}},testnet:!0};var Is={id:84532,network:"base-sepolia",name:"Base Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://base-sepolia.rpc.privy.systems"]},default:{http:["https://sepolia.base.org"]},public:{http:["https://sepolia.base.org"]}},blockExplorers:{default:{name:"Blockscout",url:"https://base-sepolia.blockscout.com"}},testnet:!0};var um={id:80085,network:"berachain-artio",name:"Berachain Artio",nativeCurrency:{name:"BERA",symbol:"BERA",decimals:18},rpcUrls:{default:{http:["https://berachain-artio.rpc.privy.systems"]},public:{http:["https://berachain-artio.rpc.privy.systems"]}},blockExplorers:{default:{name:"Beratrail",url:"https://artio.beratrail.io"}},testnet:!0};var mm={id:42220,name:"Celo Mainnet",network:"celo",nativeCurrency:{decimals:18,name:"CELO",symbol:"CELO"},rpcUrls:{default:{http:["https://forno.celo.org"]},infura:{http:["https://celo-mainnet.infura.io/v3"]},public:{http:["https://forno.celo.org"]}},blockExplorers:{default:{name:"Celo Explorer",url:"https://explorer.celo.org/mainnet"},etherscan:{name:"CeloScan",url:"https://celoscan.io"}},testnet:!1};var fm={id:44787,name:"Celo Alfajores Testnet",network:"celo-alfajores",nativeCurrency:{decimals:18,name:"CELO",symbol:"CELO"},rpcUrls:{default:{http:["https://alfajores-forno.celo-testnet.org"]},infura:{http:["https://celo-alfajores.infura.io/v3"]},public:{http:["https://alfajores-forno.celo-testnet.org"]}},blockExplorers:{default:{name:"Celo Explorer",url:"https://explorer.celo.org/alfajores"},etherscan:{name:"CeloScan",url:"https://alfajores.celoscan.io/"}},testnet:!0};var hm={id:314,name:"Filecoin - Mainnet",network:"filecoin-mainnet",nativeCurrency:{decimals:18,name:"filecoin",symbol:"FIL"},rpcUrls:{default:{http:["https://api.node.glif.io/rpc/v1"]},public:{http:["https://api.node.glif.io/rpc/v1"]}},blockExplorers:{default:{name:"Filfox",url:"https://filfox.info/en"},filscan:{name:"Filscan",url:"https://filscan.io"},filscout:{name:"Filscout",url:"https://filscout.io/en"},glif:{name:"Glif",url:"https://explorer.glif.io"}}};var ym={id:314159,name:"Filecoin - Calibration testnet",network:"filecoin-calibration",nativeCurrency:{decimals:18,name:"testnet filecoin",symbol:"tFIL"},rpcUrls:{default:{http:["https://api.calibration.node.glif.io/rpc/v1"]},public:{http:["https://api.calibration.node.glif.io/rpc/v1"]}},blockExplorers:{default:{name:"Filscan",url:"https://calibration.filscan.io"}}};var gm={id:17069,name:"Garnet Holesky",network:"garnet-holesky",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.garnetchain.com"]},public:{http:["https://rpc.garnetchain.com"]}},blockExplorers:{default:{name:"Blockscout",url:"https://explorer.garnetchain.com"}}};var vm={id:5,network:"goerli",name:"Goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.ankr.com/eth_goerli"]}},blockExplorers:{default:{name:"Etherscan",url:"https://goerli.etherscan.io"}},testnet:!0};var Cm={id:17e3,name:"Holesky",network:"holesky",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://ethereum-holesky.publicnode.com"]},public:{http:["https://ethereum-holesky.publicnode.com"]}},blockExplorers:{etherscan:{name:"EtherScan",url:"https://holesky.etherscan.io"},default:{name:"EtherScan",url:"https://holesky.etherscan.io"}}};var wm={id:59144,network:"linea-mainnet",name:"Linea Mainnet",nativeCurrency:{name:"Linea Ether",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.linea.build"],webSocket:["wss://rpc.linea.build"]},public:{http:["https://rpc.linea.build"],webSocket:["wss://rpc.linea.build"]}},blockExplorers:{default:{name:"Etherscan",url:"https://lineascan.build"},etherscan:{name:"Etherscan",url:"https://lineascan.build"}},testnet:!1};var bm={id:59140,network:"linea-testnet",name:"Linea Goerli Testnet",nativeCurrency:{name:"Linea Ether",symbol:"ETH",decimals:18},rpcUrls:{infura:{http:["https://linea-goerli.infura.io/v3"],webSocket:["wss://linea-goerli.infura.io/ws/v3"]},default:{http:["https://rpc.goerli.linea.build"],webSocket:["wss://rpc.goerli.linea.build"]},public:{http:["https://rpc.goerli.linea.build"],webSocket:["wss://rpc.goerli.linea.build"]}},blockExplorers:{default:{name:"Etherscan",url:"https://goerli.lineascan.build"},etherscan:{name:"Etherscan",url:"https://goerli.lineascan.build"}},testnet:!0};var Ms={id:1,network:"homestead",name:"Ethereum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://mainnet.rpc.privy.systems"]},alchemy:{http:["https://eth-mainnet.g.alchemy.com/v2"],webSocket:["wss://eth-mainnet.g.alchemy.com/v2"]},infura:{http:["https://mainnet.infura.io/v3"],webSocket:["wss://mainnet.infura.io/ws/v3"]},default:{http:["https://cloudflare-eth.com"]},public:{http:["https://cloudflare-eth.com"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://etherscan.io"},default:{name:"Etherscan",url:"https://etherscan.io"}}};var Ws={id:10,name:"OP Mainnet",network:"optimism",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://optimism-mainnet.rpc.privy.systems"]},alchemy:{http:["https://opt-mainnet.g.alchemy.com/v2"],webSocket:["wss://opt-mainnet.g.alchemy.com/v2"]},infura:{http:["https://optimism-mainnet.infura.io/v3"],webSocket:["wss://optimism-mainnet.infura.io/ws/v3"]},default:{http:["https://mainnet.optimism.io"]},public:{http:["https://mainnet.optimism.io"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://optimistic.etherscan.io"},default:{name:"Optimism Explorer",url:"https://explorer.optimism.io"}}};var Ls={id:420,name:"Optimism Goerli Testnet",network:"optimism-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://goerli.optimism.io"]}},blockExplorers:{default:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"}},testnet:!0};var Os={id:11155420,name:"Optimism Sepolia",network:"optimism-sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://optimism-sepolia.rpc.privy.systems"]},default:{http:["https://sepolia.optimism.io"]},public:{http:["https://sepolia.optimism.io"]},infura:{http:["https://optimism-sepolia.infura.io/v3"]}},blockExplorers:{default:{name:"Blockscout",url:"https://optimism-sepolia.blockscout.com"}},testnet:!0};var Fi={id:137,name:"Polygon Mainnet",network:"matic",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{privy:{http:["https://polygon-mainnet.rpc.privy.systems"]},alchemy:{http:["https://polygon-mainnet.g.alchemy.com/v2"],webSocket:["wss://polygon-mainnet.g.alchemy.com/v2"]},infura:{http:["https://polygon-mainnet.infura.io/v3"],webSocket:["wss://polygon-mainnet.infura.io/ws/v3"]},default:{http:["https://polygon-rpc.com"]},public:{http:["https://polygon-rpc.com"]}},blockExplorers:{etherscan:{name:"PolygonScan",url:"https://polygonscan.com"},default:{name:"PolygonScan",url:"https://polygonscan.com"}}};var Bi={id:80001,name:"Mumbai",network:"maticmum",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{default:{http:["https://matic-mumbai.chainstacklabs.com"]}},blockExplorers:{default:{name:"PolygonScan",url:"https://mumbai.polygonscan.com"}},testnet:!0};var Em={id:690,name:"Redstone",network:"redstone",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.redstonechain.com"]},public:{http:["https://rpc.redstonechain.com"]}},blockExplorers:{default:{name:"Blockscout",url:"https://explorer.redstone.xyz/"}}};var Tm={id:17001,name:"Redstone Holesky",network:"redstone-holesky",nativeCurrency:{name:"ETH",symbol:"ETH",decimals:18},rpcUrls:{default:{http:["https://rpc.holesky.redstone.xyz"]},public:{http:["https://rpc.holesky.redstone.xyz"]}},blockExplorers:{etherscan:{name:"EtherScan",url:"https://explorer.holesky.redstone.xyz"},default:{name:"EtherScan",url:"https://explorer.holesky.redstone.xyz"}}};var Pm={id:11155111,network:"sepolia",name:"Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"SEP",decimals:18},rpcUrls:{privy:{http:["https://sepolia.rpc.privy.systems"]},alchemy:{http:["https://eth-sepolia.g.alchemy.com/v2"],webSocket:["wss://eth-sepolia.g.alchemy.com/v2"]},infura:{http:["https://sepolia.infura.io/v3"],webSocket:["wss://sepolia.infura.io/ws/v3"]},default:{http:["https://rpc.sepolia.org"]},public:{http:["https://rpc.sepolia.org"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://sepolia.etherscan.io"},default:{name:"Etherscan",url:"https://sepolia.etherscan.io"}},testnet:!0};var Ns={id:7777777,name:"Zora",network:"zora",nativeCurrency:{decimals:18,name:"Ether",symbol:"ETH"},rpcUrls:{default:{http:["https://rpc.zora.energy"],webSocket:["wss://rpc.zora.energy"]},public:{http:["https://rpc.zora.energy"],webSocket:["wss://rpc.zora.energy"]}},blockExplorers:{default:{name:"Explorer",url:"https://explorer.zora.energy"}}};var Ds={id:999999999,name:"Zora Sepolia",network:"zora-sepolia",nativeCurrency:{decimals:18,name:"Zora Sepolia",symbol:"ETH"},rpcUrls:{default:{http:["https://sepolia.rpc.zora.energy"],webSocket:["wss://sepolia.rpc.zora.energy"]},public:{http:["https://sepolia.rpc.zora.energy"],webSocket:["wss://sepolia.rpc.zora.energy"]}},blockExplorers:{default:{name:"Zora Sepolia Explorer",url:"https://sepolia.explorer.zora.energy/"}},testnet:!0};var Us={id:999,name:"Zora Goerli Testnet",network:"zora-testnet",nativeCurrency:{decimals:18,name:"Zora Goerli",symbol:"ETH"},rpcUrls:{default:{http:["https://testnet.rpc.zora.energy"],webSocket:["wss://testnet.rpc.zora.energy"]},public:{http:["https://testnet.rpc.zora.energy"],webSocket:["wss://testnet.rpc.zora.energy"]}},blockExplorers:{default:{name:"Explorer",url:"https://testnet.explorer.zora.energy"}},testnet:!0};var Hi=[_s,xs,ks,vm,Pm,Ms,Ws,Ls,Os,Fi,Bi,mm,fm,hm,ym,As,Rs,Is,um,wm,bm,dm,pm,Ns,Us,Ds,Cm,Em,gm,Tm],s_=new Set(Hi.map(e=>e.id));import tn from"tinycolor2";var Sm="#FFFFFF",t3="#000000",r3=Sm,o3="#1E1E1D";function n3(e){return e<.8&&e>.2&&console.warn("Background color is not light or dark enough, which could lead to accessibility issues."),e>.5?"light":"dark"}function io(e,t){let r=Math.max(0,Math.min(1,e.toHsl().l+t));return tn({...e.toHsl(),l:r})}function _m({backgroundTheme:e,accentHex:t,successHex:r="#51BA81",warnHex:o="#FFB74D",errorHex:n="#EC6351",whiteHex:i=Sm,blackHex:a=t3}){let l;switch(e){case"light":l=r3;break;case"dark":l=o3;break;default:l=e;break}let s=tn(l),c=tn(t),u=tn(r),h=tn(o),f=tn(n),y=n3(s.getLuminance()),v=io(s,y==="light"?-.04:.11),g=io(s,y==="light"?-.88:.87),x=io(s,y==="light"?-.77:.75),S=io(s,y==="light"?-.43:.45).desaturate(y==="light"?60:20),w=io(s,y==="light"?-.08:.25).desaturate(y==="light"?60:20),_=io(c,.15),A=io(c,-.06),N=io(f,.3),I=tn(c.getLuminance()>.5?a:i),R=io(u,-.16);return{colorScheme:y,background:s.toHslString(),background2:v.toHslString(),foreground:g.toHslString(),foreground2:x.toHslString(),foreground3:S.toHslString(),foreground4:w.toHslString(),accent:c.toHslString(),accentLight:_.toHslString(),accentDark:A.toHslString(),foregroundAccent:I.toHslString(),success:u.toHslString(),successDark:R.toHslString(),error:f.toHslString(),errorLight:N.toHslString(),warn:h.toHslString()}}function Lc(e,t,r){let o=r?console.warn:()=>{},n,i,a,l,s,c,u,h,f,y,v,g,x,S,w;t?.loginMethods?(n=t.loginMethods.includes("email"),i=t.loginMethods.includes("sms"),l=t.loginMethods.includes("wallet"),s=t.loginMethods.includes("google"),c=t.loginMethods.includes("twitter"),u=t.loginMethods.includes("discord"),f=t.loginMethods.includes("spotify"),y=t.loginMethods.includes("instagram"),h=t.loginMethods.includes("tiktok"),g=t.loginMethods.includes("github"),v=t.loginMethods.includes("linkedin"),x=t.loginMethods.includes("apple"),S=t.loginMethods.includes("farcaster"),w=t.loginMethods.includes("telegram")):(n=e.emailAuth,i=e.smsAuth,l=e.walletAuth,s=e.googleOAuth,c=e.twitterOAuth,u=e.discordOAuth,g=e.githubOAuth,f=e.spotifyOAuth,y=e.instagramOAuth,h=e.tiktokOAuth,v=e.linkedinOAuth,x=e.appleOAuth,S=e.farcasterAuth,w=e.telegramAuth),typeof window<"u"&&typeof window.PublicKeyCredential!="function"?a=!1:e.passkeyAuth&&(a=!0);let _=[n,i].filter(Boolean),A=[s,c,u,g,f,y,h,v,x,S,w].filter(Boolean),N=[l].filter(Boolean);if(_.length+A.length+N.length===0)throw new Error("You must enable at least one login method");let I=t?.appearance?.showWalletLoginFirst!==void 0?t?.appearance?.showWalletLoginFirst:e.showWalletLoginFirst;I&&N.length===0?(o("You should only enable `showWalletLoginFirst` when `wallet` logins are also enabled. `showWalletLoginFirst` has been set to false"),I=!1):!I&&A.length+_.length===0&&(o("You should only disable `showWalletLoginFirst` when `email`, `sms`, or social logins are also enabled. `showWalletLoginFirst` has been set to true"),I=!0),t?.loginMethods&&t.loginMethodsAndOrder&&o("You should only configure one of `loginMethods` or `loginMethodsAndOrder`");let R=cm({input:t?.appearance?.walletList,overrides:t?.loginMethodsAndOrder}),B=am({input:t?.loginMethodsAndOrder}),K=t?.intl?.defaultCountry??"US",{chains:Y,defaultChain:W}=i3({additionalChains:t?.additionalChains,supportedChains:t?.supportedChains,defaultChainFromConfig:t?.defaultChain,hasRpcConfigDefined:Object.keys(t?.rpcConfig?.rpcUrls??{}).length>0}),V=!!t?.defaultChain,L=t?.customAuth?.getCustomAccessToken&&t?.customAuth?.enabled!==!1,ae,de=!(e.enforceWalletUis??!0);if(e.legacyWalletUiConfig??!0?L?ae=t?.embeddedWallets?.noPromptOnSignature??!0:ae=t?.embeddedWallets?.noPromptOnSignature??de:ae=de,t?.embeddedWallets?.waitForTransactionConfirmation===!1&&ae!==!0)throw new Error("Overriding `config.embeddedWallets.waitForTransactionConfirmation` requires that you disable wallet UIs in the dashboard.");let{requireUserPasswordOnCreate:pe,...we}=t?.embeddedWallets??{};return{id:e.id,name:e.name,allowlistConfig:e.allowlistConfig,legacyWalletUiConfig:e.legacyWalletUiConfig,appearance:{logo:t?.appearance?.logo??e.logoUrl,landingHeader:t?.appearance?.landingHeader??Yt.appearance.landingHeader,loginMessage:typeof t?.appearance?.loginMessage=="string"?t?.appearance?.loginMessage.slice(0,100):t?.appearance?.loginMessage,palette:_m({backgroundTheme:t?.appearance?.theme??Yt.appearance.theme,accentHex:t?.appearance?.accentColor??e.accentColor??Yt.appearance.accentColor}),loginGroupPriority:I?"web3-first":"web2-first",hideDirectWeb2Inputs:!!t?.appearance?.hideDirectWeb2Inputs,walletList:R},loginMethods:{wallet:l,email:n,sms:i,passkey:a,google:s,twitter:c,discord:u,github:g,spotify:f,instagram:y,tiktok:h,linkedin:v,apple:x,farcaster:S,telegram:w},loginMethodsAndOrder:B,legal:{termsAndConditionsUrl:t?.legal?.termsAndConditionsUrl??e.termsAndConditionsUrl,privacyPolicyUrl:t?.legal?.privacyPolicyUrl??e.privacyPolicyUrl,requireUsersAcceptTerms:e.requireUsersAcceptTerms??!1},walletConnectCloudProjectId:t?.walletConnectCloudProjectId??e.walletConnectCloudProjectId??Yt.walletConnectCloudProjectId,rpcConfig:{rpcUrls:t?.rpcConfig?.rpcUrls??Yt.rpcConfig.rpcUrls,rpcTimeouts:t?.rpcConfig?.rpcTimeouts??Yt.rpcConfig.rpcTimeouts},chains:Y,defaultChain:W,intl:{defaultCountry:K},shouldEnforceDefaultChainOnConnect:V,captchaEnabled:e.captchaEnabled??Yt.captchaEnabled,captchaSiteKey:e.captchaSiteKey,externalWallets:{coinbaseWallet:{connectionOptions:t?.externalWallets?.coinbaseWallet?.connectionOptions??Yt.externalWallets.coinbaseWallet.connectionOptions}},embeddedWallets:{...e.embeddedWalletConfig,...typeof pe=="boolean"?{requireUserOwnedRecoveryOnCreate:pe}:{},...L?{createOnLogin:"all-users",requireUserOwnedRecoveryOnCreate:!1,userOwnedRecoveryOptions:["user-passcode"]}:{},waitForTransactionConfirmation:!0,priceDisplay:{primary:"fiat-currency",secondary:"native-token"},...we,noPromptOnSignature:ae},mfa:{methods:e.mfaMethods??[],noPromptOnMfaRequired:t?.mfa?.noPromptOnMfaRequired??!1},customAuth:L?{enabled:!0,...t.customAuth}:void 0,fiatOnRamp:{enabled:e.fiatOnRampEnabled,useSandbox:t?.fiatOnRamp?.useSandbox??Yt.fiatOnRamp.useSandbox},loginConfig:{twitterOAuthOnMobileEnabled:e.twitterOAuthOnMobileEnabled??!1,telegramAuthConfiguration:e.telegramAuthConfiguration},headless:!!t?.headless,render:{standalone:t?._render?.standalone??Yt._render.standalone}}}function xm(e,t){if(!e)return{legacyCreateEmbeddedWalletFlag:t};let{appearance:r,additionalChains:o,supportedChains:n,defaultChain:i,...a}=e;return{...a,...o?{additionalChains:o.map(s=>s.id)}:void 0,...n?{supportedChains:n.map(s=>s.id)}:void 0,...i?{defaultChain:i.id}:void 0,legacyCreateEmbeddedWalletFlag:t}}function i3({additionalChains:e,supportedChains:t,defaultChainFromConfig:r,hasRpcConfigDefined:o}){let n;if(e&&t&&console.warn("You should only specify one of `additionalChains` or `supportedChains`. Using `supportedChains`."),t){if(t.length===0)throw new Error("`supportedChains` must contain at least one chain");t.filter(s=>s.rpcUrls.privyWalletOverride).length>0&&o&&console.warn("You have specified at least one `supportedChain` with `privyWalletOverride` but also have `rpcConfig` defined. The `rpcConfig` will be ignored. `rpcConfig` is deprecated and you should use `privyWalletOverride` in a `supportedChain`."),n=t.map(s=>s.rpcUrls.privyWalletOverride?s:Hi.find(u=>u.id===s.id)??s)}else n=Hi.concat(e??[]);let i=t?n[0]:Ms,a=r??i;if(!n.find(l=>l.id===a.id))throw new Error("`defaultChain` must be included in `supportedChains`");return{chains:n,defaultChain:a}}var km=function(e,t=0){let r=3735928559^t,o=1103547991^t;for(let n=0,i;n<e.length;n++)i=e.charCodeAt(n),r=Math.imul(r^i,2654435761),o=Math.imul(o^i,1597334677);return r=Math.imul(r^r>>>16,2246822507),r^=Math.imul(o^o>>>13,3266489909),o=Math.imul(o^o>>>16,2246822507),o^=Math.imul(r^r>>>13,3266489909),4294967296*(2097151&o)+(r>>>0)};import{jsx as c3}from"react/jsx-runtime";var Im={showWalletLoginFirst:!0,allowlistConfig:{errorTitle:null,errorDetail:null,errorCtaText:null,errorCtaLink:null},walletAuth:!0,emailAuth:!0,smsAuth:!1,googleOAuth:!1,twitterOAuth:!1,discordOAuth:!1,githubOAuth:!1,linkedinOAuth:!1,appleOAuth:!1,termsAndConditionsUrl:null,privacyPolicyUrl:null,embeddedWalletConfig:{createOnLogin:"off",requireUserOwnedRecoveryOnCreate:!1,userOwnedRecoveryOptions:["user-passcode"]},fiatOnRampEnabled:!1,captchaEnabled:!1,captchaSiteKey:""},Oc=Lc(Im,void 0,!1),Nc=l3({appConfig:Oc,isServerConfigLoaded:!1}),Mm=({children:e,legacyCreateEmbeddedWalletFlag:t,client:r,clientConfig:o})=>{let[n,i]=s3(null),a=a3(()=>Lc(n??Im,o,!!n),[n,o]);return Am(()=>{if(!n)return;let l=xm(o,t),s=km(JSON.stringify(l)).toString(),c=`privy:sent:${n.id}:${s}`;localStorage.getItem(c)||(r.createAnalyticsEvent({eventName:"sdk_initialize",payload:l}),localStorage.setItem(c,"t"))},[o,t,n]),Am(()=>{n||(async()=>{try{let s=await r.getServerConfig();s.customApiUrl&&r.updateApiUrl(s.customApiUrl),i(s)}catch(s){console.warn("Error generating app config: ",s)}})()},[]),c3(Nc.Provider,{value:{appConfig:a,isServerConfigLoaded:!!n},children:e})},ft=()=>{let{appConfig:e}=Rm(Nc);return e},Fs=()=>{let{isServerConfigLoaded:e}=Rm(Nc);return e};var b=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};import{jsx as h3,jsxs as y3}from"react/jsx-runtime";var Wm=d3({ready:!1,app:Oc,currentScreen:null,lastScreen:null,navigate:b,navigateBack:b,resetNavigation:b,setModalData:b,onUserCloseViaDialogOrKeybindRef:void 0}),f3=["LANDING","CONNECT_ONLY_LANDING_SCREEN",null],Lm=e=>{let t=ft(),r=e.authenticated,[o,n]=m3(e.initialScreen);Dc(()=>{!r&&!f3.includes(e.initialScreen)&&e.setInitialScreen(null)},[r]);let i=u3(null);Dc(()=>{e.open||(i.current=null)},[e.open]),Dc(()=>{i.current=null},[e.initialScreen]);let a={ready:!!t.id,app:t,data:e.data,setModalData:e.setModalData,currentScreen:e.initialScreen,lastScreen:o,navigate:(l,s=!0)=>{e.setInitialScreen(l),s&&n(e.initialScreen)},navigateBack:()=>{e.setInitialScreen(o)},resetNavigation:()=>{e.setInitialScreen(null),n(null)},onUserCloseViaDialogOrKeybindRef:i};return y3(Wm.Provider,{value:a,children:[(typeof t.appearance.logo=="string"||t.appearance.logo?.type==="img")&&h3(Ss,{src:typeof t.appearance.logo=="string"?t.appearance.logo:t.appearance.logo.props.src}),e.children]})},k=()=>p3(Wm);import{jsx as Nn,jsxs as g3}from"react/jsx-runtime";var Gi=({style:e,...t})=>{let{app:r}=k();return g3("svg",{width:"28",height:"28",viewBox:"0 0 28 28",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...e},...t,children:[Nn("rect",{width:"28",height:"28",rx:"3",fill:r?.appearance.palette.colorScheme==="dark"?"#3396ff":"#141414"}),Nn("g",{clipPath:"url(#clip0_1765_9946)",children:Nn("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"})}),Nn("defs",{children:Nn("clipPath",{id:"clip0_1765_9946",children:Nn("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})};var Gr=class extends Ot{constructor(r,o,n,i,a,l,s,c){super(c||"unknown",n,i,o);this.connectorType="wallet_connect_v2";this.privyAppId=l,this.privyAppName=s,this.walletConnectCloudProjectId=r,this.rpcConfig=o,this.shouldEnforceDefaultChainOnConnect=a,this.proxyProvider=new Oe(void 0,this.rpcTimeoutDuration),c&&(this.walletEntry=Xa[c],this.walletClientType=c)}async initialize(){let r=await this.createProvider();if(this.provider=r,this.proxyProvider.setWalletProvider(r),this.subscribeListeners(),r.session){if(this.walletProvider?.session?.peer.metadata.url){let n=Qa(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=n?.entry,this.walletClientType=n?.walletClientType||"unknown"}this.connected=!0,await this.syncAccounts()}this.initialized=!0,this.emit("initialized");let{WalletConnectModal:o}=await import("@walletconnect/modal");this.modal=new o({projectId:this.walletConnectCloudProjectId,themeVariables:{"--wcm-z-index":"1000000"}}),this.modal.subscribeModal(n=>{!n.open&&!this.walletProvider?.session&&this.onQrModalClosed&&this.onQrModalClosed()})}async connect(r){return r.showPrompt&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return!!this.walletProvider?.connected}get walletBranding(){return this.walletClientType==="metamask"?{name:"MetaMask",icon:Mn,id:"io.metamask"}:{name:vu(this.walletProvider?.session?.peer.metadata.name||"")||"WalletConnect",icon:this.walletProvider?.session?.peer.metadata.icons?.[0]||Gi,id:this.walletProvider?.session?.peer.metadata.name.toLowerCase()||"wallet_connect_v2"}}async resetConnection(r){this.walletProvider&&this.walletProvider.connected&&(await this.walletProvider.disconnect(),this.walletProvider.signer.session=void 0,this.walletEntry=Xa[r],this.walletClientType=r,this.redirectUri=void 0,Pu(),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise((r,o)=>{let n=()=>{o(new An)};this.onQrModalClosed=n,(async()=>{let a="",l=await Promise.race([this.walletProvider?.enable(),this.proxyProvider.walletTimeout()]);if(l?.length&&(a=l[0]),!a||a==="")throw new te("Unable to retrieve address");if(this.walletProvider?.session?.peer.metadata.url){let s=Qa(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=s?.entry,this.walletClientType=s?.walletClientType||"unknown",this.proxyProvider.rpcTimeoutDuration=Rn(this.rpcConfig,this.walletClientType)}this.connected=!0,await this.syncAccounts(l),r()})().catch(a=>{if(a){o(Er(a));return}o(new te("Unknown error during connection"))}).finally(()=>this.modal?.closeModal())})}disconnect(){this.walletProvider?.disconnect().then(()=>this.onDisconnect()).catch(()=>console.warn("Unable to disconnect Wallet Connect provider"))}get walletProvider(){return this.proxyProvider.walletProvider}setWalletProvider(r){this.proxyProvider.setWalletProvider(r)}async createProvider(){let r={};for(let a of this.chains){let l=wu(a.id,this.chains,this.rpcConfig,this.privyAppId);l&&(r[a.id]=l)}let o=this.shouldEnforceDefaultChainOnConnect?[this.defaultChain.id]:[],n=this.chains.map(a=>a.id),i=await v3.init({projectId:this.walletConnectCloudProjectId,chains:o,optionalChains:n,optionalEvents:C3,optionalMethods:w3,rpcMap:r,showQrModal:!1,metadata:{description:this.privyAppName,name:this.privyAppName,url:window.location.toString(),icons:[]}});return i.on("display_uri",a=>{if(i.signer.abortPairingAttempt(),b3&&this.walletEntry){let{redirect:l,href:s}=Eu(a,this.walletEntry);Su({href:s,name:this.walletEntry.displayName}),this.redirectUri=l,es(l,"_self")}else this.modal?.openModal({uri:a,chains:[this.defaultChain.id]})}),i.on("connect",()=>{if(this.modal?.closeModal(),i.session?.peer.metadata.url){let a=Qa(i.session?.peer.metadata.url);this.walletEntry=a?.entry,this.walletClientType=a?.walletClientType||"unknown"}}),i}async enableProvider(){return this.walletProvider?.connected?Promise.resolve(this.walletProvider.accounts):await this.walletProvider?.enable()}};var Fc=e=>{let t=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses")?.split(" ").filter(o=>E3(o)).map(o=>Om(o));return t?.length?!!e?.linkedAccounts.filter(o=>o.type=="wallet"&&t.includes(o.address)).length:!1},Rn=(e,t)=>e.rpcTimeouts?e.rpcTimeouts[t]||Zo:Zo,Vi=class extends T3{constructor(r,o,n,i,a,l,s,c,u,h,f){super();this.getEthereumProvider=()=>{let r=this.wallets[0],o=this.walletConnectors.find(n=>n.wallets.find(i=>i.address===r?.address));return!r||!o?new Oe:o.proxyProvider};this.privyAppId=r,this.walletConnectCloudProjectId=o,this.rpcConfig=n,this.chains=i,this.defaultChain=a,this.walletConnectors=[],this.initialized=!1,this.store=l,this.walletList=s,this.shouldEnforceDefaultChainOnConnect=c,this.externalWalletConfig=u,this.privyAppName=h,this.privyAppLogo=f,this.storedConnections=Uc()}get wallets(){let r=new Set,o=this.walletConnectors.flatMap(i=>i.wallets).sort((i,a)=>i.connectedAt&&a.connectedAt?a.connectedAt-i.connectedAt:0).filter(i=>{let a=`${i.address}${i.walletClientType}${i.connectorType}`;return r.has(a)?!1:(r.add(a),!0)}),n=o.findIndex(i=>i.address===(this.activeWallet?this.activeWallet:"unknown"));return n>=0&&o.unshift(o.splice(n,1)[0]),o}async initialize(){if(this.initialized)return;Z.get(_c)&&(Z.getKeys().forEach(o=>{o.startsWith("walletconnect")&&Z.del(o)}),Z.del(_c));let r=Cu(this.store,this.walletList,this.externalWalletConfig).then(o=>{o.forEach(({type:n,eip6963InjectedProvider:i,legacyInjectedProvider:a})=>{this.createWalletConnector("injected",n,{eip6963InjectedProvider:i,legacyInjectedProvider:a})})});this.walletList.includes("coinbase_wallet")&&this.createWalletConnector("coinbase_wallet","coinbase_wallet"),!vo()&&this.walletList.includes("phantom")&&this.createWalletConnector("phantom","phantom"),this.createWalletConnector("wallet_connect_v2","unknown"),await r,this.initialized=!0}findWalletConnector(r,o){return r==="wallet_connect_v2"?this.walletConnectors.find(n=>n.connectorType===r)??null:this.walletConnectors.find(n=>n.connectorType===r&&n.walletClientType===o)??null}onInitialized(r){r.wallets.forEach(o=>{let n=this.storedConnections.find(i=>i.address===o.address&&i.connectorType===o.connectorType&&i.walletClientType===o.walletClientType);n&&(o.connectedAt=n.connectedAt)}),this.saveConnectionHistory(),this.emit("walletsUpdated"),this.emit("connectorInitialized")}onWalletsUpdated(r){r.initialized&&(this.saveConnectionHistory(),this.emit("walletsUpdated"))}addEmbeddedWalletConnector(r,o,n,i){let a=this.findWalletConnector("embedded","privy");if(a)a.proxyProvider.walletProxy=r;else{let l=new Di(r,o,this.rpcConfig,this.chains,i,n.id),s=new Ui(l,this.chains,n,this.rpcConfig);this.addWalletConnector(s)}}addImportedWalletConnector(r,o,n,i){let a=this.findWalletConnector("embedded_imported","privy");if(a)a.proxyProvider.walletProxy=r;else{let l=new Di(r,o,this.rpcConfig,this.chains,i,n.id),s=!0,c=new Ui(l,this.chains,n,this.rpcConfig,s);this.addWalletConnector(c)}}removeEmbeddedWalletConnector(){let r=this.findWalletConnector("embedded","privy");if(r){let o=this.walletConnectors.indexOf(r);this.walletConnectors.splice(o,1),this.saveConnectionHistory(),this.storedConnections=Uc(),this.emit("walletsUpdated")}}removeImportedWalletConnector(){let r=this.findWalletConnector("embedded_imported","privy");if(r){let o=this.walletConnectors.indexOf(r);this.walletConnectors.splice(o,1),this.saveConnectionHistory(),this.storedConnections=Uc(),this.emit("walletsUpdated")}}async createWalletConnector(r,o,n){let i=this.findWalletConnector(r,o);if(i)return i instanceof Gr&&i.resetConnection(o),i;let l=(()=>{if(r==="injected"){if(o==="metamask"&&n?.eip6963InjectedProvider)return new Es(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask");if(o==="metamask"&&n?.legacyInjectedProvider)return new On(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"metamask");if(o==="phantom"&&n?.legacyInjectedProvider)return new On(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"phantom");if(n?.legacyInjectedProvider&&o==="unknown_browser_extension")return new On(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider);if(n?.eip6963InjectedProvider)return new Ln(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,o)}else return r==="coinbase_wallet"?new ws(this.chains,this.defaultChain,this.rpcConfig,this.externalWalletConfig,this.privyAppName,this.privyAppLogo):r==="phantom"?new Ps(this.defaultChain):new Gr(this.walletConnectCloudProjectId,this.rpcConfig,this.chains,this.defaultChain,this.shouldEnforceDefaultChainOnConnect,this.privyAppId,this.privyAppName,o)})();return l&&this.addWalletConnector(l),l||null}addWalletConnector(r){this.walletConnectors.push(r),r.on("initialized",()=>this.onInitialized(r)),r.on("walletsUpdated",()=>this.onWalletsUpdated(r)),r.initialize().catch(o=>{console.debug("Failed to initialize connector",o)})}saveConnectionHistory(){let r=this.wallets.map(o=>({address:o.address,connectorType:o.connectorType,walletClientType:o.walletClientType,connectedAt:o.connectedAt}));Z.put(xc,r)}async activeWalletSign(r){let o=this.wallets,n=o.length>0?o[0]:null;return n?n.sign(r):null}setActiveWallet(r){this.activeWallet=Om(r),this.emit("walletsUpdated")}};function Cs(e,t){if(e.length!==t.length)return!1;for(let r=0;r<e.length;r++){let o=e[r],n=t[r];if(o?.address!==n?.address||o?.chainId!==n?.chainId||o?.connectorType!==n?.connectorType||o?.connectedAt!==n?.connectedAt||o?.walletClientType!==n?.walletClientType||o?.isConnected!==n?.isConnected||o?.linked!==n?.linked)return!1}return!0}var P3=e=>e&&typeof e.address=="string"&&typeof e.connectorType=="string"&&typeof e.walletClientType=="string"&&typeof e.connectedAt=="number",Uc=()=>{let e=Z.get(xc);return e&&Array.isArray(e)&&e.map(o=>P3(o)).every(Boolean)?e:[]};import{ofetch as S3}from"ofetch";var _3=[Ha,Va,Ga,za],Bs=class{constructor({appId:t,appClientId:r,client:o,defaults:n}){this.appId=t,this.appClientId=r,this.clientAnalyticsId=o.clientAnalyticsId,this.sdkVersion=Pc,this.client=o,this.defaults=n,this.fallbackApiUrl=o.fallbackApiUrl,this.baseFetch=S3.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:i,options:a})=>{let l=new Headers(a.headers);l.set("privy-app-id",this.appId),this.appClientId&&l.set("privy-client-id",this.appClientId),l.set("privy-ca-id",this.clientAnalyticsId||""),l.set("privy-client",`react-auth:${this.sdkVersion}`);let s=_3.includes(i.toString());if(!l.has("authorization")){let c=await this.client.getAccessToken({disableAutoRefresh:s});c!==null&&l.set("authorization",`Bearer ${c}`)}a.headers=l,a.retryDelay&&(a.retryDelay=a.retryDelay*3)},onRequestError:({error:i})=>{if(i instanceof DOMException&&i.name==="AbortError")throw new Fa}})}async get(t,r){try{return await this.baseFetch(t,r)}catch(o){throw ne(o)}}async post(t,r,o){try{return await this.baseFetch(t,{method:"POST",...r?{body:r}:{},...o})}catch(n){throw ne(n)}}async delete(t,r){try{return await this.baseFetch(t,{method:"DELETE",...r})}catch(o){throw ne(o)}}};var Nm=e=>({challenge:e.challenge,allowCredentials:e.allow_credentials?.map(t=>({id:t.id,type:t.type,transports:t.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});import Dn from"js-cookie";function Dm(e){return e instanceof go?"email":e instanceof en?"sms":e instanceof Xo?"siwe":e instanceof Sn?"custom_auth":e instanceof Ur?e.meta.provider:null}import*as Um from"jose";var Vr=class{static parse(t){try{return new Vr(t)}catch{return null}}constructor(t){this.value=t,this._decoded=Um.decodeJwt(t)}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(t=0){let r=Date.now(),o=(this.expiration-t)*1e3;return r>=o}};var x3=30,Hs=class{constructor(){this.authenticateOnce=new Fe(async t=>this._authenticate(t)),this.linkOnce=new Fe(async t=>this._link(t)),this.refreshOnce=new Fe(this._refresh.bind(this)),this.destroyOnce=new Fe(this._destroy.bind(this)),this.forkSessionOnce=new Fe(this._forkSession.bind(this))}get token(){try{let t=Z.get($o);return typeof t=="string"?new Vr(t).value:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get refreshToken(){try{let t=Z.get(ts);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get forkedToken(){try{let t=Z.get(Ai);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get mightHaveServerCookies(){try{let t=Dn.get(rs);return t!==void 0&&t.length>0}catch(t){console.error(t)}return!1}hasRefreshCredentials(){return this.mightHaveServerCookies||typeof this.token=="string"&&typeof this.refreshToken=="string"&&this.refreshToken!==Bu}hasRecoveryCredentials(){return typeof this.forkedToken=="string"}hasActiveToken(){let t=Vr.parse(this.token);return t!==null&&!t.isExpired(x3)}authenticate(t){return this.authenticateOnce.execute(t)}link(t){return this.linkOnce.execute(t)}refresh(){return this.refreshOnce.execute()}forkSession(){return this.forkSessionOnce.execute()}destroy(){return this.destroyOnce.execute()}async _authenticate(t){try{let r=await t.authenticate(),{user:o,is_new_user:n,oauth_provider_tokens:i}=r;this.handleTokenResponse(r);let a=i?{provider:i.provider,accessToken:i.access_token,accessTokenExpiresInSeconds:i.access_token_expires_in_seconds,refreshToken:i.refresh_token,scopes:i.scopes}:void 0,l=Dm(t);return l&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate",payload:{method:l,isNewUser:n}}),l==="siwe"&&this.client&&this.client.createAnalyticsEvent({eventName:"sdk_authenticate_siwe",payload:{connectorType:t.meta.connectorType,walletClientType:t.meta.walletClientType}}),{user:$t(o),isNewUser:n,oAuthProviderTokens:a}}catch(r){throw console.warn("Error authenticating session"),st(r)}}async _link(t){try{let r=await t.link(),o=r.oauth_provider_tokens,n=o?{provider:o.provider,accessToken:o.access_token,accessTokenExpiresInSeconds:o.access_token_expires_in_seconds,refreshToken:o.refresh_token,scopes:o.scopes}:void 0;return{user:$t(r),oAuthProviderTokens:n}}catch(r){throw console.warn("Error linking account"),st(r)}}async _refresh(){if(!this.api)throw new T("Session has no API instance");if(!this.client)throw new T("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let t=this.token,r=this.refreshToken,o=this.forkedToken;try{let n;if(t&&r||this.mightHaveServerCookies){let i={};t&&(i.authorization=`Bearer ${t}`);let a=r?{refresh_token:r}:{};n=await this.api.post(Ha,a,{headers:i}),o&&this.clearForkedToken()}else if(o)n=await this.api.post(Va,{refresh_token:o}),this.clearForkedToken();else return null;return this.handleTokenResponse(n),$t(n.user)}catch(n){if(n instanceof br&&n.privyErrorCode==="missing_or_invalid_token")return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw st(n)}}handleTokenResponse(t){t.session_update_action?t.session_update_action==="set"?(this.storeRefreshToken(t.refresh_token),this.storeToken(t.token)):t.session_update_action==="clear"?this.destroyLocalState():t.session_update_action==="ignore"&&t.token&&this.storeToken(t.token):(this.storeRefreshToken(t.refresh_token),this.storeToken(t.token))}async _destroy(){try{await this.api?.post(Ga,{refresh_token:this.refreshToken})}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new T("Session has no API instance");let t=this.refreshToken;try{let r=await this.api.post(Ap,{refresh_token:t});return this.storeRefreshToken(r.refresh_token),this.storeToken(r.token),r.new_session_refresh_token}catch(r){throw st(r)}}destroyLocalState(){this.storeRefreshToken(null),this.storeToken(null),this.clearForkedToken()}storeToken(t){if(typeof t=="string"){let r=Z.get($o);if(Z.put($o,t),!this.client?.useServerCookies){let o=Vr.parse(t)?.expiration;Dn.set(Sc,t,{sameSite:"Strict",secure:!0,expires:o?new Date(o*1e3):void 0})}r!==t&&this.client?.onStoreToken?.(t)}else Z.del($o),Dn.remove(Sc),this.client?.onDeleteToken?.()}storeRefreshToken(t){typeof t=="string"?(Z.put(ts,t),this.client?.useServerCookies||Dn.set(rs,"t",{sameSite:"Strict",secure:!0,expires:30})):(Z.del(ts),Dn.remove(Wu),Dn.remove(rs))}clearForkedToken(){Z.del(Ai)}};var Bc,Gs,Fm,zi=class{constructor(t){Ua(this,Gs);this.apiUrl=t.apiUrl||ki,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=!1,this.timeout=t.timeout||Iu,this.appId=t.appId,this.appClientId=t.appClientId,this.clientAnalyticsId=kp(this,Gs,Fm).call(this),Bc||(Bc=new Hs),this.session=Bc,this.api=this.generateApi(),this.session.client=this}initializeConnectorManager({walletConnectCloudProjectId:t,rpcConfig:r,chains:o,defaultChain:n,store:i,walletList:a,shouldEnforceDefaultChainOnConnect:l,externalWalletConfig:s,appName:c}){this.connectors||(this.connectors=new Vi(this.appId,t,r,o,n,i,a,l,s,c))}sessionHasActiveToken(){return this.session.hasActiveToken()}generateApi(){let t=new Bs({appId:this.appId,appClientId:this.appClientId,client:this,defaults:{baseURL:this.apiUrl,timeout:this.timeout}});return this.session.api=t,t}updateApiUrl(t){this.apiUrl=t||this.fallbackApiUrl,this.api=this.generateApi(),t&&(this.useServerCookies=!0)}authenticate(){if(!this.authFlow)throw new T("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new T("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.authFlow=void 0}startAuthFlow(t){return t.api=this.api,this.authFlow=t,this.authFlow}async initMfaSmsVerification(){try{await this.api.post(cu,{action:"verify"})}catch(t){throw ne(t)}}async initMfaPasskeyVerification(){try{let t=await this.api.post(du,{});return Nm(t.options)}catch(t){throw ne(t)}}async unlinkEmail(t){try{let r=await this.api.post(Gp,{address:t});return $t(r)}catch(r){throw st(r)}}async acceptTerms(){try{let t=await this.api.post(pu,{});return $t(t)}catch(t){throw st(t)}}async unlinkPhone(t){try{let r=await this.api.post($p,{phoneNumber:t});return $t(r)}catch(r){throw st(r)}}async unlinkWallet(t){try{let r=await this.api.post(Wp,{address:t});return $t(r)}catch(r){throw st(r)}}async unlinkOAuth(t,r){try{let o=await this.api.post(Jp,{provider:t,subject:r});return $t(o)}catch(o){throw st(o)}}async unlinkFarcaster(t){try{let r=await this.api.post(Up,{fid:t});return $t(r)}catch(r){throw st(r)}}async unlinkTelegram(t){try{let r=await this.api.post(lu,{telegram_user_id:t});return $t(r)}catch(r){throw st(r)}}async unlinkPasskey(t){try{let r=await this.api.post(iu,{credential_id:t});return $t(r)}catch(r){throw st(r)}}async createAnalyticsEvent({eventName:t,payload:r,timestamp:o,options:n}){if(!(typeof window>"u"))try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(za,{event_name:t,client_id:this.clientAnalyticsId,payload:{...r||{},clientTimestamp:o?o.toISOString():new Date().toISOString()}},{retry:-1,keepalive:n?.keepAlive??!1})}catch{}}async signMoonpayOnRampUrl(t){try{return this.api.post(uu,t)}catch(r){throw st(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()||this.session.hasRecoveryCredentials()?this.session.refresh():null}async getAccessToken(t){return this.session.hasActiveToken()?Vr.parse(this.session.token)?.audience!==this.appId?(await this.logout(),null):this.session.token:!t?.disableAutoRefresh&&this.session.hasRefreshCredentials()?(await this.session.refresh(),this.session.token):null}async getServerConfig(){try{let t={},r=this.session.token;r&&(t.authorization=`Bearer ${r}`);let o=await this.api.get(`/api/v1/apps/${this.appId}`,{baseURL:this.fallbackApiUrl,headers:t}),n=o.telegram_auth_config?{botId:o.telegram_auth_config.bot_id,botName:o.telegram_auth_config.bot_name}:void 0;return{id:o.id,name:o.name,verificationKey:o.verification_key,logoUrl:o.logo_url||void 0,accentColor:o.accent_color||void 0,showWalletLoginFirst:o.show_wallet_login_first,allowlistConfig:{errorTitle:o.allowlist_config.error_title,errorDetail:o.allowlist_config.error_detail,errorCtaText:o.allowlist_config.cta_text,errorCtaLink:o.allowlist_config.cta_link},walletAuth:o.wallet_auth,emailAuth:o.email_auth,smsAuth:o.sms_auth,googleOAuth:o.google_oauth,twitterOAuth:o.twitter_oauth,discordOAuth:o.discord_oauth,githubOAuth:o.github_oauth,spotifyOAuth:o.spotify_oauth,instagramOAuth:o.instagram_oauth,tiktokOAuth:o.tiktok_oauth,linkedinOAuth:o.linkedin_oauth,appleOAuth:o.apple_oauth,farcasterAuth:o.farcaster_auth,passkeyAuth:o.passkey_auth,telegramAuth:o.telegram_auth,termsAndConditionsUrl:o.terms_and_conditions_url,embeddedWalletConfig:{createOnLogin:o.embedded_wallet_config?.create_on_login,userOwnedRecoveryOptions:o.embedded_wallet_config.user_owned_recovery_options,requireUserOwnedRecoveryOnCreate:o.embedded_wallet_config.require_user_owned_recovery_on_create},privacyPolicyUrl:o.privacy_policy_url,requireUsersAcceptTerms:o.require_users_accept_terms,customApiUrl:o.custom_api_url,walletConnectCloudProjectId:o.wallet_connect_cloud_project_id,fiatOnRampEnabled:o.fiat_on_ramp_enabled,captchaEnabled:o.captcha_enabled,captchaSiteKey:o.captcha_site_key,twitterOAuthOnMobileEnabled:o.twitter_oauth_on_mobile_enabled,createdAt:new Date(o.created_at*1e3),updatedAt:new Date(o.updated_at*1e3),mfaMethods:o.mfa_methods,enforceWalletUis:o.enforce_wallet_uis,legacyWalletUiConfig:o.legacy_wallet_ui_config,telegramAuthConfiguration:n}}catch(t){throw st(t)}}async getUsdTokenPrice(t){try{return(await this.api.get(`/api/v1/token_price?chainId=${t.id}&tokenSymbol=${t.nativeCurrency.symbol}`)).usd}catch{console.error(`Unable to fetch token price for chain with id ${t.id}`);return}}async requestFarcasterSignerStatus(t){try{return await this.api.post("/api/v1/farcaster/signer/status",{ed25519_public_key:t})}catch(r){throw console.error("Unable to fetch Farcaster signer status"),r}}async forkSession(){return await this.session.forkSession()}};Gs=new WeakSet,Fm=function(){if(typeof window>"u")return null;try{let r=Z.get(Ri);if(typeof r=="string"&&r.length>0)return r}catch{}let t=k3();try{return Z.put(Ri,t),t}catch{return t}};import{Turnstile as L3}from"@marsidev/react-turnstile";import{useEffect as O3,useMemo as N3}from"react";import{useMemo as A3,useRef as R3,useContext as I3,useState as Hc,createContext as M3}from"react";import{jsx as W3}from"react/jsx-runtime";var Bm=M3({siteKey:"",enabled:!1,appId:void 0,token:void 0,error:void 0,status:"disabled",setToken:b,setError:b,setExecuting:b,waitForResult:()=>Promise.resolve(""),ref:{current:null},remove:b,reset:b,execute:b}),Tr=class extends ze{constructor(r,o,n){super(r||"Captcha failed");this.type="Captcha";o instanceof Error&&(this.cause=o),this.privyErrorCode=n}},Hm=({children:e,id:t,captchaSiteKey:r,captchaEnabled:o})=>{let n=R3(null),[i,a]=Hc(),[l,s]=Hc(),[c,u]=Hc(!1),h=A3(()=>o?!c&&!i&&!l?{status:"ready"}:c&&!i&&!l?{status:"loading"}:i&&!l?{status:"success",token:i}:l?{status:"error",error:l}:{status:"ready"}:{status:"disabled"},[o,i,l,c]);return W3(Bm.Provider,{value:{...h,ref:n,enabled:o,siteKey:r,appId:t,setToken:a,setError:s,setExecuting:u,remove(){o&&(n.current?.remove(),u(!1),s(void 0),a(void 0))},reset(){o&&(n.current?.reset(),u(!1),s(void 0),a(void 0))},execute(){o&&(u(!0),n.current?.execute())},async waitForResult(){if(!o)return"";try{return await gu(()=>n.current?.getResponse(),{interval:200,timeout:2e4})}catch{throw new Tr("Captcha failed",null,"captcha_timeout")}}},children:e})},he=()=>I3(Bm);import{jsx as Gm}from"react/jsx-runtime";var Gc=e=>{let{enabled:t,siteKey:r,appId:o,setError:n,setToken:i,setExecuting:a,ref:l}=he(),[,s]=N3(()=>r?.split("t:")||[],[r]);if(O3(()=>l.current?.remove,[]),!t)return null;if(!s)throw new Error("Unsupported captcha site key");return Gm("div",{className:"hidden h-0 w-0",children:Gm(L3,{...e,ref:l,siteKey:s,options:{action:o,size:"invisible",...e.delayedExecution?{appearance:"execute",execution:"execute"}:{appearance:"always",execution:"render"}},onUnsupported:()=>{e.onUnsupported?.(),console.warn("Browser does not support Turnstile.")},onError:()=>{e.onError?.(),n("Captcha failed"),a(!1)},onSuccess:c=>{e.onSuccess?.(c),i(c),a(!1)},onExpire:()=>{e.onExpire?.();try{l.current?.reset(),n(void 0),i(void 0)}catch{n("expired_and_failed_reset")}}})})};import{useCallback as Db,useEffect as Jg,useRef as Ub,useState as Fb}from"react";import e2 from"styled-components";import{createContext as D3,useContext as U3}from"react";var Vc=D3({isNewUserThisSession:!1,linkingHint:null,walletConnectionStatus:null,mipdStore:null,connectors:[],rpcConfig:{rpcUrls:{}},showFiatPrices:!0,chains:[],clientAnalyticsId:null,pendingTransaction:null,appId:"notAdded",nativeTokenSymbolForChainId:b,initializeWalletProxy:b,getAuthMeta:b,getAuthFlow:b,closePrivyModal:b,openPrivyModal:b,connectWallet:b,initLoginWithWallet:b,loginWithWallet:b,initLoginWithFarcaster:b,loginWithFarcaster:b,loginWithCode:b,initLoginWithEmail:b,initLoginWithSms:b,initUpdateEmail:b,resendEmailCode:b,resendSmsCode:b,initLoginWithHeadlessOAuth:b,loginWithHeadlessOAuth:b,initLoginWithOAuth:b,recoveryOAuthFlow:b,loginWithOAuth:b,initLoginWithPasskey:b,loginWithPasskey:b,initLinkWithPasskey:b,linkWithPasskey:b,refreshUser:b,walletProxy:null,createAnalyticsEvent:b,acceptTerms:b,getUsdTokenPrice:b,recoverEmbeddedWallet:b,getFiatOnRampConfig:b,updateWallets:b,fundWallet:b,setReadyToTrue:b,requestFarcasterSignerStatus:b,initLoginWithTelegram:b,loginWithTelegram:b}),M=()=>U3(Vc);import{createContext as F3,useContext as B3}from"react";var ve=F3({ready:!1,authenticated:!1,user:null,walletConnectors:null,connectWallet:b,login:b,connectOrCreateWallet:b,linkEmail:b,linkPhone:b,linkFarcaster:b,linkWallet:b,linkGoogle:b,linkTwitter:b,linkDiscord:b,linkGithub:b,linkSpotify:b,linkInstagram:b,linkTelegram:b,linkTiktok:b,linkLinkedIn:b,linkApple:b,linkPasskey:b,updateEmail:b,logout:b,getAccessToken:b,getEthereumProvider:b,getEthersProvider:b,getWeb3jsProvider:b,unlinkEmail:b,unlinkPhone:b,unlinkWallet:b,unlinkGoogle:b,unlinkTwitter:b,unlinkDiscord:b,unlinkGithub:b,unlinkSpotify:b,unlinkInstagram:b,unlinkTiktok:b,unlinkLinkedIn:b,unlinkApple:b,unlinkFarcaster:b,unlinkTelegram:b,unlinkPasskey:b,setActiveWallet:b,forkSession:b,createWallet:b,importWallet:b,signMessage:b,signTypedData:b,enrollInMfa:b,initEnrollmentWithSms:b,initEnrollmentWithTotp:b,initEnrollmentWithPasskey:b,promptMfa:b,init:b,submitEnrollmentWithSms:b,submitEnrollmentWithTotp:b,submitEnrollmentWithPasskey:b,unenroll:b,submit:b,cancel:b,sendTransaction:b,exportWallet:b,setWalletPassword:b,requestFarcasterSignerFromWarpcast:b,getFarcasterSignerPublicKey:b,signFarcasterMessage:b,initLoginWithEmail:b,initLoginWithSms:b,otpState:{status:"initial"},loginWithCode:b,fundWallet:b,initLoginWithHeadlessOAuth:b,loginWithHeadlessOAuth:b,isHeadlessOAuthLoading:!1,isModalOpen:!1,mfaMethods:[]}),F=()=>B3(ve);import{useEffect as H3,useState as G3}from"react";var Vm=e=>{let[t,r]=G3("auto");return H3(()=>{let o=new ResizeObserver(n=>{r(n[0]?.contentRect.height??"auto")});return e.current&&o.observe(e.current),()=>{e.current&&o.unobserve(e.current)}},[e.current]),t};import{createContext as V3,useContext as z3,useEffect as q3}from"react";var zm={login:{onComplete:[],onError:[],onOAuthLoginComplete:[]},logout:{onSuccess:[]},connectWallet:{onSuccess:[],onError:[]},createWallet:{onSuccess:[],onError:[]},linkAccount:{onSuccess:[],onError:[]},configureMfa:{onMfaRequired:[]},setWalletPassword:{onSuccess:[],onError:[]},signMessage:{onSuccess:[],onError:[]},signTypedData:{onSuccess:[],onError:[]},sendTransaction:{onSuccess:[],onError:[]},accessToken:{onAccessTokenGranted:[],onAccessTokenRemoved:[]}},zc=V3(void 0),qm=()=>z3(zc);function He(e,t){if(!t)return;let o=qm().current[e];return q3(()=>{for(let[n,i]of Object.entries(t))o.hasOwnProperty(n)||console.warn(`Invalid event type "${n}" for action "${e}"`),o[n]?.push(i);return()=>{for(let[n,i]of Object.entries(t))o.hasOwnProperty(n)||console.warn(`Invalid event type "${n}" for action "${e}"`),o[n]=o[n]?.filter(a=>a!==i)}},[t])}function U(e,t,r,...o){for(let n of e.current[t][r])n(...o)}function Vs(){let e=qm();return(t,r,...o)=>U(e,t,r,...o)}function qc(e){He("configureMfa",e)}import Xm from"@heroicons/react/24/outline/ArrowTopRightOnSquareIcon";import d0 from"@heroicons/react/24/solid/DocumentCheckIcon";import p0 from"styled-components";import rn,{css as Yc}from"styled-components";import Kc from"styled-components";import{Fragment as K3,jsx as $c,jsxs as j3}from"react/jsx-runtime";var tt=({success:e,fail:t})=>j3(K3,{children:[$c(rt,{className:e?"success":t?"fail":""}),$c(jc,{className:e?"success":t?"fail":""})]}),rt=Kc.span`
13
13
  && {
14
14
  width: 82px;
15
15
  height: 82px;
@@ -85,7 +85,7 @@ Resources:
85
85
  color: var(--privy-color-foreground-3);
86
86
  cursor: not-allowed;
87
87
  }
88
- `,O=({children:e,loading:t,disabled:r,loadingText:o="Loading...",...n})=>dr($m,{disabled:t||r,...n,children:t?$s("span",{children:[dr(ao,{}),o?dr("span",{children:o}):null]}):e}),Ck=rn(O)`
88
+ `,O=({children:e,loading:t,disabled:r,loadingText:o="Loading...",...n})=>dr($m,{disabled:t||r,...n,children:t?$s("span",{children:[dr(ao,{}),o?dr("span",{children:o}):null]}):e}),bk=rn(O)`
89
89
  ${e=>e.hideAnimations&&Yc`
90
90
  && {
91
91
  transition: none;
@@ -196,7 +196,7 @@ Resources:
196
196
  cursor: not-allowed;
197
197
  }
198
198
  }
199
- `,wk=rn.div`
199
+ `,Ek=rn.div`
200
200
  /* Set to match height of SoftCtaButton to avoid reflow if conditionally rendered */
201
201
  height: 44px;
202
202
  `,Fn=({children:e,onClick:t,disabled:r,isSubmitting:o,...n})=>$s(Z3,{isSubmitting:o,onClick:t,disabled:r,...n,children:[dr("span",{children:e}),dr("span",{children:dr(ao,{})})]}),Z3=rn.button`
@@ -659,7 +659,7 @@ Resources:
659
659
  display: flex;
660
660
  flex-direction: column;
661
661
  gap: 8px;
662
- `,hA=Zt.div`
662
+ `,gA=Zt.div`
663
663
  display: flex;
664
664
  flex-direction: column;
665
665
  justify-content: space-between;
@@ -1174,7 +1174,7 @@ Resources:
1174
1174
  > :first-child {
1175
1175
  min-width: 24px;
1176
1176
  }
1177
- `,AW=gt.div`
1177
+ `,IW=gt.div`
1178
1178
  height: var(--privy-height-modal-full);
1179
1179
 
1180
1180
  @media (max-width: 440px) {
@@ -1243,7 +1243,7 @@ Resources:
1243
1243
  transition: all 0.1s ease-out;
1244
1244
  background: ${({label:e})=>e==="Strong"&&"#78dca6"||e==="Medium"&&"var(--privy-color-warn)"||"var(--privy-color-error)"};
1245
1245
  }
1246
- `;import{Fragment as aC,jsx as Xt,jsxs as fl}from"react/jsx-runtime";var lh=({buttonHideAnimations:e,buttonLoading:t,password:r,onSubmit:o,onBack:n})=>{let[i,a]=vd(!0),[l,s]=vd(!1),[c,u]=vd(""),h=r===c;return iC(()=>{c&&!l&&s(!0)},[c]),fl(aC,{children:[Xt(P,{closeable:!1,backFn:n}),Xt(Q,{}),fl(_o,{children:[fl(Ao,{children:[Xt(nC,{height:48,width:48,stroke:"var(--privy-color-background)",fill:"var(--privy-color-accent)"}),Xt("h3",{style:{color:"var(--privy-color-foreground)"},children:"Confirm your password"}),Xt("p",{style:{color:"var(--privy-color-foreground-2)"},children:"Please re-enter your password below to continue."})]}),fl(ko,{children:[Xt(oi,{value:c,onChange:f=>u(f.target.value),onBlur:()=>s(!0),placeholder:"confirm your password",type:i?"password":"text",style:{paddingRight:"2.3rem"}}),Xt(ni,{style:{right:"0.75rem"},children:i?Xt(ii,{onClick:()=>a(!1)}):Xt(ai,{onClick:()=>a(!0)})})]}),Xt(ml,{"aria-hidden":!l||h,error:!0,children:"Passwords do not match"})]}),Xt(xo,{onClick:o,loading:t,disabled:!h,hideAnimations:e,children:"Continue"}),Xt(re,{}),Xt(q,{protectedByPrivy:!0})]})};import dC from"@heroicons/react/24/outline/ExclamationTriangleIcon";import{useState as pC}from"react";import uC from"styled-components";import na from"styled-components";import{jsx as oa,jsxs as cC}from"react/jsx-runtime";var ch=({className:e,checked:t,color:r="var(--privy-color-accent)",...o})=>oa("label",{children:cC(sC,{className:e,children:[oa(ph,{checked:t,...o}),oa(lC,{color:r,checked:t,children:oa(dh,{viewBox:"0 0 24 24",children:oa("polyline",{points:"20 6 9 17 4 12"})})})]})});var HW=na.label`
1246
+ `;import{Fragment as aC,jsx as Xt,jsxs as fl}from"react/jsx-runtime";var lh=({buttonHideAnimations:e,buttonLoading:t,password:r,onSubmit:o,onBack:n})=>{let[i,a]=vd(!0),[l,s]=vd(!1),[c,u]=vd(""),h=r===c;return iC(()=>{c&&!l&&s(!0)},[c]),fl(aC,{children:[Xt(P,{closeable:!1,backFn:n}),Xt(Q,{}),fl(_o,{children:[fl(Ao,{children:[Xt(nC,{height:48,width:48,stroke:"var(--privy-color-background)",fill:"var(--privy-color-accent)"}),Xt("h3",{style:{color:"var(--privy-color-foreground)"},children:"Confirm your password"}),Xt("p",{style:{color:"var(--privy-color-foreground-2)"},children:"Please re-enter your password below to continue."})]}),fl(ko,{children:[Xt(oi,{value:c,onChange:f=>u(f.target.value),onBlur:()=>s(!0),placeholder:"confirm your password",type:i?"password":"text",style:{paddingRight:"2.3rem"}}),Xt(ni,{style:{right:"0.75rem"},children:i?Xt(ii,{onClick:()=>a(!1)}):Xt(ai,{onClick:()=>a(!0)})})]}),Xt(ml,{"aria-hidden":!l||h,error:!0,children:"Passwords do not match"})]}),Xt(xo,{onClick:o,loading:t,disabled:!h,hideAnimations:e,children:"Continue"}),Xt(re,{}),Xt(q,{protectedByPrivy:!0})]})};import dC from"@heroicons/react/24/outline/ExclamationTriangleIcon";import{useState as pC}from"react";import uC from"styled-components";import na from"styled-components";import{jsx as oa,jsxs as cC}from"react/jsx-runtime";var ch=({className:e,checked:t,color:r="var(--privy-color-accent)",...o})=>oa("label",{children:cC(sC,{className:e,children:[oa(ph,{checked:t,...o}),oa(lC,{color:r,checked:t,children:oa(dh,{viewBox:"0 0 24 24",children:oa("polyline",{points:"20 6 9 17 4 12"})})})]})});var VW=na.label`
1247
1247
  && {
1248
1248
  cursor: pointer;
1249
1249
  display: flex;
@@ -2052,7 +2052,7 @@ You will need this password to access your ${e} wallet on a new device. Please k
2052
2052
  font-size: 14px;
2053
2053
  line-height: 22.4px;
2054
2054
  font-weight: 400;
2055
- `;import Y6 from"@heroicons/react/24/outline/ChevronDownIcon";import{useContext as gn,useState as Z6}from"react";import Do from"styled-components";import{createContext as w1,useContext as hz}from"react";var ui=w1(void 0);var Ta=w1(void 0);import{Fragment as n7,jsx as Lr,jsxs as b1}from"react/jsx-runtime";var E1=({defaultValue:e,children:t})=>{let[r,o]=Z6(e||null),n=i=>{o(r===i?null:i)};return Lr(ui.Provider,{value:{activePanel:r,togglePanel:n},children:Lr(J6,{children:t})})},T1=({value:e,children:t})=>{let{activePanel:r,togglePanel:o}=gn(ui),n=r===e;return Lr(Ta.Provider,{value:{onToggle:()=>o(e),value:e},children:Lr(t7,{isActive:n,"data-open":n,children:t})})},P1=({children:e})=>{let{activePanel:t}=gn(ui),{onToggle:r,value:o}=gn(Ta),n=t===o;return b1(n7,{children:[b1(Q6,{onClick:r,"data-open":n,children:[Lr(e7,{children:e}),Lr(o7,{isactive:n,children:Lr(Y6,{height:"16px",width:"16px",strokeWidth:"2"})})]}),Lr(X6,{})]})},S1=({children:e})=>{let{activePanel:t}=gn(ui),{value:r}=gn(Ta);return Lr(r7,{"data-open":t===r,children:Lr(x1,{children:e})})},_1=({children:e})=>{let{activePanel:t}=gn(ui),{value:r}=gn(Ta);return Lr(x1,{children:typeof e=="function"?e({isActive:t===r}):e})},J6=Do.div`
2055
+ `;import Y6 from"@heroicons/react/24/outline/ChevronDownIcon";import{useContext as gn,useState as Z6}from"react";import Do from"styled-components";import{createContext as w1,useContext as gz}from"react";var ui=w1(void 0);var Ta=w1(void 0);import{Fragment as n7,jsx as Lr,jsxs as b1}from"react/jsx-runtime";var E1=({defaultValue:e,children:t})=>{let[r,o]=Z6(e||null),n=i=>{o(r===i?null:i)};return Lr(ui.Provider,{value:{activePanel:r,togglePanel:n},children:Lr(J6,{children:t})})},T1=({value:e,children:t})=>{let{activePanel:r,togglePanel:o}=gn(ui),n=r===e;return Lr(Ta.Provider,{value:{onToggle:()=>o(e),value:e},children:Lr(t7,{isActive:n,"data-open":n,children:t})})},P1=({children:e})=>{let{activePanel:t}=gn(ui),{onToggle:r,value:o}=gn(Ta),n=t===o;return b1(n7,{children:[b1(Q6,{onClick:r,"data-open":n,children:[Lr(e7,{children:e}),Lr(o7,{isactive:n,children:Lr(Y6,{height:"16px",width:"16px",strokeWidth:"2"})})]}),Lr(X6,{})]})},S1=({children:e})=>{let{activePanel:t}=gn(ui),{value:r}=gn(Ta);return Lr(r7,{"data-open":t===r,children:Lr(x1,{children:e})})},_1=({children:e})=>{let{activePanel:t}=gn(ui),{value:r}=gn(Ta);return Lr(x1,{children:typeof e=="function"?e({isActive:t===r}):e})},J6=Do.div`
2056
2056
  display: flex;
2057
2057
  flex-direction: column;
2058
2058
  width: 100%;
@@ -2215,7 +2215,7 @@ You will need this password to access your ${e} wallet on a new device. Please k
2215
2215
  overflow: hidden;
2216
2216
  max-width: 275px;
2217
2217
  text-overflow: ellipsis;
2218
- `;import{VoidSigner as R7}from"@ethersproject/abstract-signer";import{EtherscanProvider as Oq}from"@ethersproject/providers";import{BigNumber as U1}from"@ethersproject/bignumber";import{BigNumber as fi}from"@ethersproject/bignumber";import{Contract as T7}from"@ethersproject/contracts";import{serialize as P7}from"@ethersproject/transactions";var S7=81457,_7=168587773,hi=e=>[As.id,Rs.id,Is.id,Ws.id,Ls.id,Os.id,Ns.id,Us.id,Ds.id,S7,_7].includes(e),O1=async(e,t)=>{if(!hi(e.chainId))throw new Error("Invalid chain ID for OP Stack gas estimation.");if(e.type===void 0&&(e.type=2),e.maxPriorityFeePerGas&&e.maxFeePerGas||e.gasPrice)return e;try{if(!e.maxPriorityFeePerGas){let r=await t.send("eth_maxPriorityFeePerGas",[]);e.maxPriorityFeePerGas=r}if(e.maxFeePerGas&&(console.warn("maxFeePerGas is specified without maxPriorityFeePerGas - this can result in hung transactions."),e.maxPriorityFeePerGas>=e.maxFeePerGas))throw new Error("Overridden maxFeePerGas is less than or equal to the calculated maxPriorityFeePerGas. Please set both values or maxPriorityFeePerGas alone for correct gas estimation.");if(!e.maxFeePerGas){let{lastBaseFeePerGas:r}=await t.getFeeData();if(!r)throw new Error("Unable to fetch baseFee for last block.");let i=fi.from(r).mul(fi.from(126)).div(fi.from(100)).add(fi.from(e.maxPriorityFeePerGas));e.maxFeePerGas=xa(i)}}catch(r){throw new Error(`Failed to set gas price for OP stack transaction: ${r}.`)}return e};async function N1(e,t){if(!e.chainId||e.chainId&&!hi(e.chainId))return fi.from(0);let r=fi.from(0);try{let o=new T7(Uu,Fu,t),n=D1(e),i=P7(n);r=await o.getL1Fee(i)}catch{}return r}async function F1(e,t){try{return(await t.estimateGas(e)).toHexString()}catch(r){console.warn(`Gas estimation failed with error: ${r}. Retrying gas estimation by omitting the 'from' address`);try{let o={...e,from:void 0};return(await t.estimateGas(o)).toHexString()}catch(o){throw console.warn(`Gas estimation failed with error: ${o} when omitting the 'from' address`),r}}}var B1=async(e,t)=>{if(e.type===void 0&&(e.type=2),e.type===2){if(!e.maxFeePerGas||!e.maxPriorityFeePerGas){let r=await t.getFeeData();e.maxFeePerGas||(e.maxFeePerGas=r.maxFeePerGas?.toHexString()),e.maxPriorityFeePerGas||(e.maxPriorityFeePerGas=r.maxPriorityFeePerGas?.toHexString())}}else if(!e.gasPrice){let r=await t.getFeeData();e.gasPrice=r.gasPrice?.toHexString()}return e};async function yi(e,t){if(!e.gasLimit)throw new Be("gasLimit was not successfully set for transaction.");let r=Ct(e.gasLimit),o=U1.from(0);if(e.type==2)if(e.maxFeePerGas)o=Ct(e.maxFeePerGas);else throw new Be("maxFeePerGas was not successfully set for transaction of type 2.");else if(e.gasPrice)o=Ct(e.gasPrice);else throw new Be("gasPrice was not successfully set for transaction of type 0 or 1.");let n=r.mul(o),i=U1.from(0);if(e.chainId&&hi(e.chainId))try{i=await N1(e,t),n=n.add(i)}catch{}return{totalGasEstimate:n,l1ExecutionFeeEstimate:i}}import{BigNumber as Xd}from"@ethersproject/bignumber";var ep=e=>[_s.id,xs.id,ks.id].includes(e),H1=async(e,t)=>{if(!ep(e.chainId))throw new Error("Invalid chain ID for Arbitrum gas estimation.");if(e.type===void 0&&(e.type=2),e.maxFeePerGas)return e;try{let{lastBaseFeePerGas:r}=await t.getFeeData();if(r){let o=r.mul(Xd.from(120)).div(Xd.from(100));e.maxFeePerGas=xa(o),e.maxPriorityFeePerGas=xa(Xd.from(0))}}catch(r){throw new Error(`Failed to set gas price for Arbitrum transaction: ${r}.`)}return e};var tp=e=>[56,97].includes(e),G1=async(e,t)=>{if(!tp(e.chainId))throw new Error("Invalid chain ID for BSC gas estimation.");if(e.type===void 0?e.type=0:(e.type==1||e.type==2)&&console.warn("Transaction request type specified is incompatible for chain and will result in undefined behavior. Please use transaction type 0."),!e.gasPrice){let r=await t.getFeeData();e.gasPrice=r.gasPrice?.toHexString()}return e};import{parseUnits as V1}from"@ethersproject/units";import{ofetch as x7}from"ofetch";var rp={id:80002,name:"Polygon Amoy",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{privy:{http:["https://polygon-amoy.rpc.privy.systems"]},infura:{http:["https://polygon-amoy.infura.io/v3"],webSocket:["wss://polygon-amoy.infura.io/ws/v3"]},default:{http:["https://rpc-amoy.polygon.technology"]}},blockExplorers:{default:{name:"OK LINK",url:"https://www.oklink.com/amoy"}},testnet:!0};var np=e=>[Fi.id,Bi.id,rp.id].includes(e),op=e=>({maxPriorityFee:V1(e.maxPriorityFee.toFixed(9),"gwei").toHexString(),maxFee:V1(e.maxFee.toFixed(9),"gwei").toHexString()}),k7=e=>({safeLow:op(e.safeLow),standard:op(e.standard),fast:op(e.fast)}),A7=async e=>{let t="";switch(e){case Fi.id:t="https://gasstation.polygon.technology/v2";break;case Bi.id:t="https://gasstation-testnet.polygon.technology/v2";break;case rp.id:t="https://gasstation-testnet.polygon.technology/amoy";break;default:throw Error(`chainId ${e} does not support polygon gas stations`)}return k7(await x7(t))};async function z1(e){if(!np(e.chainId))throw new Error("Invalid chain ID for Polygon gas estimation.");if(e.type===void 0&&(e.type=2),e.maxPriorityFeePerGas&&e.maxFeePerGas)return e;try{let{standard:t}=await A7(e.chainId);e.maxPriorityFeePerGas||(e.maxPriorityFeePerGas=t.maxPriorityFee),e.maxFeePerGas||(e.maxFeePerGas=t.maxFee)}catch(t){throw new Error(`Failed to set gas prices from Polygon gas station with error: ${t}.`)}return e}function xa(e){if(typeof e=="number"||typeof e=="bigint"||typeof e=="string")return e;if(typeof e.toHexString=="function")return e.toHexString();throw new Error(`Expected numeric value but received ${e}`)}function D1(e){let t={};return e.to!==void 0&&(t.to=e.to),e.data!==void 0&&(t.data=e.data),e.chainId!==void 0&&(t.chainId=e.chainId),e.type!==void 0&&(t.type=e.type),e.accessList!==void 0&&(t.accessList=e.accessList),e.nonce!==void 0&&(t.nonce=Ct(e.nonce).toNumber()),e.gasLimit!==void 0&&(t.gasLimit=Ct(e.gasLimit)),e.gasPrice!==void 0&&(t.gasPrice=Ct(e.gasPrice)),e.value!==void 0&&(t.value=Ct(e.value)),e.maxFeePerGas!==void 0&&(t.maxFeePerGas=Ct(e.maxFeePerGas)),e.maxPriorityFeePerGas!==void 0&&(t.maxPriorityFeePerGas=Ct(e.maxPriorityFeePerGas)),t}async function gi(e,t,r){if(t.chainId=Number(t.chainId),q1(t),t.from||(t.from=e),!t.nonce){let o=new R7(e,r);t.nonce=await o.getTransactionCount("pending")}return t.gasLimit||(t.gas?(t.gasLimit=t.gas,delete t.gas):t.gasLimit=await F1(t,r)),typeof t.type=="string"&&$1(t.type)&&(t.type=Number(t.type)),[23294,23295].includes(t.chainId)&&(t.type=0),np(t.chainId)?t=await z1(t):ep(t.chainId)?t=await H1(t,r):hi(t.chainId)?t=await O1(t,r):tp(t.chainId)?t=await G1(t,r):t=await B1(t,r),t.type===0&&delete t.accessList,t.type!==2&&(delete t.maxPriorityFeePerGas,delete t.maxFeePerGas),t}async function Ql(e,t,r,o,n){o=Object.assign({chainId:oo},o),q1(o);let a=(await r.rpc({address:t,accessToken:e,request:{method:"eth_signTransaction",params:[o]}})).response.data;return await n.sendTransaction(a)}async function Xl(e,t,r,o){let n=await o.getBalance(e),i=t.value||0,l=!n.sub(Ct(i)).sub(r).isNegative();return{balance:n,hasSufficientFunds:l}}function q1(e){let t=["gasLimit","gasPrice","value","maxPriorityFeePerGas","maxFeePerGas"];for(let r of t){let o=e[r];if(!(typeof o>"u")&&!I7(o))throw new Error(`Transaction request property '${r}' must be a valid number, bigint, or hex string representing a quantity`)}if(typeof e.chainId!="number")throw new Error("Transaction request property 'chainId' must be a number")}function I7(e){let t=typeof e=="number",r=typeof e=="bigint",o=typeof e=="string"&&$1(e);return t||r||o}function $1(e){return/^-?0x[a-f0-9]+$/i.test(e)}function ec(e){return{to:e.to,from:e.from,contractAddress:e.contractAddress,transactionIndex:e.transactionIndex,root:e.root,logsBloom:e.logsBloom,blockHash:e.blockHash,transactionHash:e.transactionHash,logs:e.logs,blockNumber:e.blockNumber,confirmations:e.confirmations,byzantium:e.byzantium,type:e.type,status:e.status,gasUsed:e.gasUsed.toHexString(),cumulativeGasUsed:e.cumulativeGasUsed.toHexString(),effectiveGasPrice:e.effectiveGasPrice?e.effectiveGasPrice.toHexString():void 0}}import{useState as ip,useEffect as M7}from"react";var tc=e=>{let{showFiatPrices:t,getUsdTokenPrice:r,chains:o}=M(),[n,i]=ip(!0),[a,l]=ip(void 0),[s,c]=ip(void 0);return M7(()=>{let u=e.chainId||oo,h=o.find(y=>y.id===Number(u));if(!h)throw new te(`Unsupported chain: ${u}`);(async()=>{if(!t){i(!1);return}try{i(!0);let y=await r(h);y?c(y):l(new Error(`Unable to fetch token price on chain id ${h.id}`))}catch(y){l(y)}finally{i(!1)}})()},[e.chainId]),{tokenPrice:s,isTokenPriceLoading:n,tokenPriceError:a}};import{createContext as W7,useContext as L7}from"react";var ap=W7(null);function ka(){let e=L7(ap);if(e===null)throw new Error("`useWallets` was called outside the PrivyProvider component");return e}import{jsx as j1}from"react/jsx-runtime";var Aa=({pendingTransaction:e})=>{let{getAccessToken:t}=F(),{wallets:r}=ka(),{walletProxy:o,rpcConfig:n,chains:i,appId:a,nativeTokenSymbolForChainId:l}=M(),[s,c]=K1(null),[u,h]=K1(e),{tokenPrice:f}=tc(u),y=l(e.chainId)||"ETH",v=O7(()=>r.find(g=>g.walletClientType==="privy"),[r]);return N7(()=>{async function g(){if(!await t()||!o||!v)return u;let S=ro(u.chainId,i,n,{appId:a}),w=await gi(v.address,u,S),{totalGasEstimate:_}=await yi(w,S);return c(_.toHexString()),w}g().then(h).catch(console.error)},[o]),v?j1(U7,{children:j1(mi,{from:v.address,to:u.to,txn:u,gas:s??void 0,tokenPrice:f,tokenSymbol:y})}):null},U7=D7.div`
2218
+ `;import{VoidSigner as R7}from"@ethersproject/abstract-signer";import{EtherscanProvider as Dq}from"@ethersproject/providers";import{BigNumber as U1}from"@ethersproject/bignumber";import{BigNumber as fi}from"@ethersproject/bignumber";import{Contract as T7}from"@ethersproject/contracts";import{serialize as P7}from"@ethersproject/transactions";var S7=81457,_7=168587773,hi=e=>[As.id,Rs.id,Is.id,Ws.id,Ls.id,Os.id,Ns.id,Us.id,Ds.id,S7,_7].includes(e),O1=async(e,t)=>{if(!hi(e.chainId))throw new Error("Invalid chain ID for OP Stack gas estimation.");if(e.type===void 0&&(e.type=2),e.maxPriorityFeePerGas&&e.maxFeePerGas||e.gasPrice)return e;try{if(!e.maxPriorityFeePerGas){let r=await t.send("eth_maxPriorityFeePerGas",[]);e.maxPriorityFeePerGas=r}if(e.maxFeePerGas&&(console.warn("maxFeePerGas is specified without maxPriorityFeePerGas - this can result in hung transactions."),e.maxPriorityFeePerGas>=e.maxFeePerGas))throw new Error("Overridden maxFeePerGas is less than or equal to the calculated maxPriorityFeePerGas. Please set both values or maxPriorityFeePerGas alone for correct gas estimation.");if(!e.maxFeePerGas){let{lastBaseFeePerGas:r}=await t.getFeeData();if(!r)throw new Error("Unable to fetch baseFee for last block.");let i=fi.from(r).mul(fi.from(126)).div(fi.from(100)).add(fi.from(e.maxPriorityFeePerGas));e.maxFeePerGas=xa(i)}}catch(r){throw new Error(`Failed to set gas price for OP stack transaction: ${r}.`)}return e};async function N1(e,t){if(!e.chainId||e.chainId&&!hi(e.chainId))return fi.from(0);let r=fi.from(0);try{let o=new T7(Uu,Fu,t),n=D1(e),i=P7(n);r=await o.getL1Fee(i)}catch{}return r}async function F1(e,t){try{return(await t.estimateGas(e)).toHexString()}catch(r){console.warn(`Gas estimation failed with error: ${r}. Retrying gas estimation by omitting the 'from' address`);try{let o={...e,from:void 0};return(await t.estimateGas(o)).toHexString()}catch(o){throw console.warn(`Gas estimation failed with error: ${o} when omitting the 'from' address`),r}}}var B1=async(e,t)=>{if(e.type===void 0&&(e.type=2),e.type===2){if(!e.maxFeePerGas||!e.maxPriorityFeePerGas){let r=await t.getFeeData();e.maxFeePerGas||(e.maxFeePerGas=r.maxFeePerGas?.toHexString()),e.maxPriorityFeePerGas||(e.maxPriorityFeePerGas=r.maxPriorityFeePerGas?.toHexString())}}else if(!e.gasPrice){let r=await t.getFeeData();e.gasPrice=r.gasPrice?.toHexString()}return e};async function yi(e,t){if(!e.gasLimit)throw new Be("gasLimit was not successfully set for transaction.");let r=Ct(e.gasLimit),o=U1.from(0);if(e.type==2)if(e.maxFeePerGas)o=Ct(e.maxFeePerGas);else throw new Be("maxFeePerGas was not successfully set for transaction of type 2.");else if(e.gasPrice)o=Ct(e.gasPrice);else throw new Be("gasPrice was not successfully set for transaction of type 0 or 1.");let n=r.mul(o),i=U1.from(0);if(e.chainId&&hi(e.chainId))try{i=await N1(e,t),n=n.add(i)}catch{}return{totalGasEstimate:n,l1ExecutionFeeEstimate:i}}import{BigNumber as Xd}from"@ethersproject/bignumber";var ep=e=>[_s.id,xs.id,ks.id].includes(e),H1=async(e,t)=>{if(!ep(e.chainId))throw new Error("Invalid chain ID for Arbitrum gas estimation.");if(e.type===void 0&&(e.type=2),e.maxFeePerGas)return e;try{let{lastBaseFeePerGas:r}=await t.getFeeData();if(r){let o=r.mul(Xd.from(120)).div(Xd.from(100));e.maxFeePerGas=xa(o),e.maxPriorityFeePerGas=xa(Xd.from(0))}}catch(r){throw new Error(`Failed to set gas price for Arbitrum transaction: ${r}.`)}return e};var tp=e=>[56,97].includes(e),G1=async(e,t)=>{if(!tp(e.chainId))throw new Error("Invalid chain ID for BSC gas estimation.");if(e.type===void 0?e.type=0:(e.type==1||e.type==2)&&console.warn("Transaction request type specified is incompatible for chain and will result in undefined behavior. Please use transaction type 0."),!e.gasPrice){let r=await t.getFeeData();e.gasPrice=r.gasPrice?.toHexString()}return e};import{parseUnits as V1}from"@ethersproject/units";import{ofetch as x7}from"ofetch";var rp={id:80002,name:"Polygon Amoy",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{privy:{http:["https://polygon-amoy.rpc.privy.systems"]},infura:{http:["https://polygon-amoy.infura.io/v3"],webSocket:["wss://polygon-amoy.infura.io/ws/v3"]},default:{http:["https://rpc-amoy.polygon.technology"]}},blockExplorers:{default:{name:"OK LINK",url:"https://www.oklink.com/amoy"}},testnet:!0};var np=e=>[Fi.id,Bi.id,rp.id].includes(e),op=e=>({maxPriorityFee:V1(e.maxPriorityFee.toFixed(9),"gwei").toHexString(),maxFee:V1(e.maxFee.toFixed(9),"gwei").toHexString()}),k7=e=>({safeLow:op(e.safeLow),standard:op(e.standard),fast:op(e.fast)}),A7=async e=>{let t="";switch(e){case Fi.id:t="https://gasstation.polygon.technology/v2";break;case Bi.id:t="https://gasstation-testnet.polygon.technology/v2";break;case rp.id:t="https://gasstation-testnet.polygon.technology/amoy";break;default:throw Error(`chainId ${e} does not support polygon gas stations`)}return k7(await x7(t))};async function z1(e){if(!np(e.chainId))throw new Error("Invalid chain ID for Polygon gas estimation.");if(e.type===void 0&&(e.type=2),e.maxPriorityFeePerGas&&e.maxFeePerGas)return e;try{let{standard:t}=await A7(e.chainId);e.maxPriorityFeePerGas||(e.maxPriorityFeePerGas=t.maxPriorityFee),e.maxFeePerGas||(e.maxFeePerGas=t.maxFee)}catch(t){throw new Error(`Failed to set gas prices from Polygon gas station with error: ${t}.`)}return e}function xa(e){if(typeof e=="number"||typeof e=="bigint"||typeof e=="string")return e;if(typeof e.toHexString=="function")return e.toHexString();throw new Error(`Expected numeric value but received ${e}`)}function D1(e){let t={};return e.to!==void 0&&(t.to=e.to),e.data!==void 0&&(t.data=e.data),e.chainId!==void 0&&(t.chainId=e.chainId),e.type!==void 0&&(t.type=e.type),e.accessList!==void 0&&(t.accessList=e.accessList),e.nonce!==void 0&&(t.nonce=Ct(e.nonce).toNumber()),e.gasLimit!==void 0&&(t.gasLimit=Ct(e.gasLimit)),e.gasPrice!==void 0&&(t.gasPrice=Ct(e.gasPrice)),e.value!==void 0&&(t.value=Ct(e.value)),e.maxFeePerGas!==void 0&&(t.maxFeePerGas=Ct(e.maxFeePerGas)),e.maxPriorityFeePerGas!==void 0&&(t.maxPriorityFeePerGas=Ct(e.maxPriorityFeePerGas)),t}async function gi(e,t,r){if(t.chainId=Number(t.chainId),q1(t),t.from||(t.from=e),!t.nonce){let o=new R7(e,r);t.nonce=await o.getTransactionCount("pending")}return t.gasLimit||(t.gas?(t.gasLimit=t.gas,delete t.gas):t.gasLimit=await F1(t,r)),typeof t.type=="string"&&$1(t.type)&&(t.type=Number(t.type)),[23294,23295].includes(t.chainId)&&(t.type=0),np(t.chainId)?t=await z1(t):ep(t.chainId)?t=await H1(t,r):hi(t.chainId)?t=await O1(t,r):tp(t.chainId)?t=await G1(t,r):t=await B1(t,r),t.type===0&&delete t.accessList,t.type!==2&&(delete t.maxPriorityFeePerGas,delete t.maxFeePerGas),t}async function Ql(e,t,r,o,n){o=Object.assign({chainId:oo},o),q1(o);let a=(await r.rpc({address:t,accessToken:e,request:{method:"eth_signTransaction",params:[o]}})).response.data;return await n.sendTransaction(a)}async function Xl(e,t,r,o){let n=await o.getBalance(e),i=t.value||0,l=!n.sub(Ct(i)).sub(r).isNegative();return{balance:n,hasSufficientFunds:l}}function q1(e){let t=["gasLimit","gasPrice","value","maxPriorityFeePerGas","maxFeePerGas"];for(let r of t){let o=e[r];if(!(typeof o>"u")&&!I7(o))throw new Error(`Transaction request property '${r}' must be a valid number, bigint, or hex string representing a quantity`)}if(typeof e.chainId!="number")throw new Error("Transaction request property 'chainId' must be a number")}function I7(e){let t=typeof e=="number",r=typeof e=="bigint",o=typeof e=="string"&&$1(e);return t||r||o}function $1(e){return/^-?0x[a-f0-9]+$/i.test(e)}function ec(e){return{to:e.to,from:e.from,contractAddress:e.contractAddress,transactionIndex:e.transactionIndex,root:e.root,logsBloom:e.logsBloom,blockHash:e.blockHash,transactionHash:e.transactionHash,logs:e.logs,blockNumber:e.blockNumber,confirmations:e.confirmations,byzantium:e.byzantium,type:e.type,status:e.status,gasUsed:e.gasUsed.toHexString(),cumulativeGasUsed:e.cumulativeGasUsed.toHexString(),effectiveGasPrice:e.effectiveGasPrice?e.effectiveGasPrice.toHexString():void 0}}import{useState as ip,useEffect as M7}from"react";var tc=e=>{let{showFiatPrices:t,getUsdTokenPrice:r,chains:o}=M(),[n,i]=ip(!0),[a,l]=ip(void 0),[s,c]=ip(void 0);return M7(()=>{let u=e.chainId||oo,h=o.find(y=>y.id===Number(u));if(!h)throw new te(`Unsupported chain: ${u}`);(async()=>{if(!t){i(!1);return}try{i(!0);let y=await r(h);y?c(y):l(new Error(`Unable to fetch token price on chain id ${h.id}`))}catch(y){l(y)}finally{i(!1)}})()},[e.chainId]),{tokenPrice:s,isTokenPriceLoading:n,tokenPriceError:a}};import{createContext as W7,useContext as L7}from"react";var ap=W7(null);function ka(){let e=L7(ap);if(e===null)throw new Error("`useWallets` was called outside the PrivyProvider component");return e}import{jsx as j1}from"react/jsx-runtime";var Aa=({pendingTransaction:e})=>{let{getAccessToken:t}=F(),{wallets:r}=ka(),{walletProxy:o,rpcConfig:n,chains:i,appId:a,nativeTokenSymbolForChainId:l}=M(),[s,c]=K1(null),[u,h]=K1(e),{tokenPrice:f}=tc(u),y=l(e.chainId)||"ETH",v=O7(()=>r.find(g=>g.walletClientType==="privy"),[r]);return N7(()=>{async function g(){if(!await t()||!o||!v)return u;let S=ro(u.chainId,i,n,{appId:a}),w=await gi(v.address,u,S),{totalGasEstimate:_}=await yi(w,S);return c(_.toHexString()),w}g().then(h).catch(console.error)},[o]),v?j1(U7,{children:j1(mi,{from:v.address,to:u.to,txn:u,gas:s??void 0,tokenPrice:f,tokenSymbol:y})}):null},U7=D7.div`
2219
2219
  width: 100%;
2220
2220
  padding: 1rem 0;
2221
2221
  `;import F7 from"@heroicons/react/24/outline/CalendarIcon";import B7 from"@heroicons/react/24/outline/ExclamationTriangleIcon";import H7 from"@heroicons/react/24/outline/ShieldCheckIcon";import{Fragment as Y1,jsx as wt,jsxs as vi}from"react/jsx-runtime";var Z1=({hasBlockingError:e,error:t,onClose:r,onBack:o,handleSubmit:n,account:i,submitSuccess:a})=>{let{pendingTransaction:l}=M();return vi(Y1,{children:[wt(P,{onClose:r},"header"),wt(nt,{children:vi("div",{children:[wt(tt,{success:a,fail:!!t}),t?wt(B7,{style:{width:"38px",height:"38px"}}):wt(mn,{style:{width:"38px",height:"38px"}})]})}),wt(se,{style:{marginTop:"1rem"},children:"Verifying with passkey"}),vi(on,{children:[vi(Ut,{children:[wt(Dt,{children:wt(H7,{})}),"Approve this action using your touch, face, PIN, or hardware key."]}),vi(Ut,{children:[wt(Dt,{children:wt(F7,{})}),"You last added a passkey on"," ",i?.firstVerifiedAt?.toLocaleDateString(void 0,{month:"short",day:"numeric",year:"numeric"}),"."]})]}),l&&wt(pr,{children:wt(Aa,{pendingTransaction:l})}),t&&vi(Y1,{children:[wt(tl,{style:{marginTop:"1.25rem"},children:t.message}),wt(O,{disabled:e,onClick:n,style:{marginTop:"1.25rem"},children:"Try again"})]}),o&&wt(qi,{style:{marginTop:"1rem"},onClick:o,children:"Choose another method"}),wt(z,{})]})};import{Fragment as sp,jsx as ue,jsxs as Or}from"react/jsx-runtime";var lp=({open:e,onClose:t})=>{let{user:r}=F(),[o,n]=Ra(null),{init:i,cancel:a,submit:l}=ga(),[s,c]=Ra(!1),[u,h]=Ra(!1),[f,y]=Ra(null),[v,g]=Ra(null);j7(()=>{e&&r?.mfaMethods&&r.mfaMethods.length>0?w(r.mfaMethods[0]):n(null)},[r?.mfaMethods,e]);let x=N=>ud(N)?(c(!0),new Error("You have exceeded the maximum number of attempts. Please close this window and try again in 10 seconds.")):cn(N)?(c(!1),new Error("The code you entered is not valid")):ln(N)?(c(!0),new Error("You have exceeded the time limit for code entry. Please try again in 30 seconds.")):(console.error(N),c(!1),new Error("Something went wrong."));async function S(N){g(null);try{if(!N||!o)return;await l(o,N),h(!0),c(!1),t()}catch(I){throw x(I)}}async function w(N){if(N==="passkey"){try{n(N);let I=await i(N);if(!I)throw new Error("something went wrong");y(I),await l(N,I),h(!0),c(!1),t()}catch(I){g(x(I))}return}try{n(N),await i(N)}catch(I){console.error(I)}}let _=()=>{n(null),g(null),a(),t()},A=()=>{n(null),g(null)};if(!e||!r)return null;if(o==="passkey"){let N=r.linkedAccounts.filter(I=>I.type==="passkey"&&I.enrolledInMfa).sort((I,R)=>R.firstVerifiedAt.valueOf()-I.firstVerifiedAt.valueOf())[0];return ue(Z1,{account:N,selectedMethod:o,submitSuccess:u,hasBlockingError:s,error:v,onClose:_,onBack:A,handleSubmit:()=>S(f).catch(g)})}return o?ue(Y7,{submitSuccess:u,hasBlockingError:s,handleSubmitCode:S,selectedMethod:o,onClose:_,onBack:r.mfaMethods.length>1?()=>n(null):void 0}):Or(sp,{children:[ue(P,{onClose:_},"header"),ue(_e,{children:ue(Ne,{children:ue(q7,{})})}),ue(se,{children:"Verify your identity"}),ue(le,{children:"Choose a verification method"}),Or(Zs,{children:[r.mfaMethods.includes("totp")&&Or(Ee,{onClick:()=>w("totp"),children:[ue(G7,{}),"Authenticator App"]},"totp"),r.mfaMethods.includes("sms")&&Or(Ee,{onClick:()=>w("sms"),children:[ue(z7,{}),"SMS"]},"sms"),r.mfaMethods.includes("passkey")&&Or(Ee,{onClick:()=>w("passkey"),children:[ue(V7,{}),"Passkey"]},"passkey")]}),ue(z,{})]})},Y7=({selectedMethod:e,submitSuccess:t,hasBlockingError:r,onClose:o,onBack:n,handleSubmitCode:i})=>{let{app:a}=k(),{pendingTransaction:l}=M();switch(e){case"sms":return Or(sp,{children:[ue(P,{onClose:o},"header"),ue(_e,{children:ue(Ne,{children:ue(K7,{})})}),ue(se,{children:"Enter verification code"}),Or(pr,{children:[ue(hn,{success:t,disabled:r,onChange:i}),Or(le,{children:["To continue, please enter the 6-digit code sent to your ",ue("strong",{children:"mobile device"})]}),l&&ue(Aa,{pendingTransaction:l})]}),n&&ue(qi,{theme:a?.appearance.palette.colorScheme,onClick:n,children:"Choose another method"}),ue(Pr,{onClick:o,children:"Not now"}),ue(z,{})]});case"totp":return Or(sp,{children:[ue(P,{onClose:o},"header"),ue(_e,{children:ue(Ne,{children:ue($7,{})})}),ue(se,{children:"Enter verification code"}),Or(pr,{children:[ue(hn,{success:t,disabled:r,onChange:i}),Or(le,{children:["To continue, please enter the 6-digit code generated from your"," ",ue("strong",{children:"authenticator app"})]}),l&&ue(Aa,{pendingTransaction:l})]}),n&&ue(qi,{theme:a?.appearance.palette.colorScheme,onClick:n,children:"Choose another method"}),ue(Pr,{onClick:o,children:"Not now"}),ue(z,{})]});default:return null}};import{useEffect as J1,useState as Q1}from"react";import Z7 from"styled-components";import{Fragment as Q7,jsx as Xr,jsxs as rc}from"react/jsx-runtime";var X1=()=>{let{authenticated:e,logout:t,ready:r,user:o}=F(),{app:n,setModalData:i,navigate:a,resetNavigation:l}=k(),{getAuthMeta:s,initLoginWithOAuth:c,loginWithOAuth:u,updateWallets:h,setReadyToTrue:f,closePrivyModal:y,createAnalyticsEvent:v}=M(),[g,x]=Q1(!1),[S,w]=Q1(void 0),_=s()?.provider||"google",{name:A,component:N}=Wi(_),I=Vs(),R=Le;J1(()=>{u(_).then(Y=>{x(!0),f(!0),Y&&I("login","onOAuthLoginComplete",Y)}).catch(Y=>{if(Y?.privyErrorCode==="allowlist_rejected"){w(void 0),l(),a("ALLOWLIST_REJECTION_SCREEN");return}if(Y?.privyErrorCode==="max_accounts_reached"){console.error(new lr(Y).toString()),w(void 0),l(),a("USER_LIMIT_REACHED_SCREEN");return}let{retryable:W,detail:V}=Yu(Y,_);w({retryable:W,detail:V,message:"Authentication failed"}),f(!1)}).finally(()=>{Jo()})},[A,_]),J1(()=>{if(r&&e&&g&&o){if(n?.legal.requireUsersAcceptTerms&&!o.hasAcceptedTerms){let W=setTimeout(()=>{a("AFFIRMATIVE_CONSENT_SCREEN")},R);return()=>clearTimeout(W)}if(Lt(o,n?.embeddedWallets?.createOnLogin)){let W=setTimeout(()=>{i({createWallet:{onSuccess:()=>{},onFailure:V=>{console.error(V),v({eventName:"embedded_wallet_creation_failure_logout",payload:{error:V,provider:_,screen:"OAuthStatusScreen"}}),t()},callAuthOnSuccessOnClose:!0}}),a("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")},R);return()=>clearTimeout(W)}else{let W=setTimeout(()=>y({shouldCallAuthOnSuccess:!0,isSuccess:!0}),R);return h(),()=>clearTimeout(W)}}},[r,e,g,o]);let B=g?`Successfully connected with ${A}`:S?S.message:`Verifying connection to ${A}`,K="";return g?K="You\u2019re good to go!":S?K=S.detail:K="Just a few moments more",rc(Q7,{children:[Xr(P,{}),Xr(Q,{}),rc(J7,{children:[Xr(nt,{children:rc("div",{children:[Xr(tt,{success:g,fail:!!S}),Xr(N,{style:{width:"38px",height:"38px"}})]})}),rc(Ke,{children:[Xr("h3",{children:B}),Xr("p",{children:K})]}),S&&S?.retryable?Xr(Un,{onClick:()=>{Jo(),c(_),w(void 0)},disabled:!g&&!S?.retryable,children:"Retry"}):null]}),Xr(re,{}),Xr(z,{})]})},J7=Z7.div`
@@ -2236,7 +2236,7 @@ You will have to sign up with another method first to register a passkey for you
2236
2236
  justify-content: center;
2237
2237
  gap: 24px;
2238
2238
  width: 100%;
2239
- `,TK=tg.div`
2239
+ `,SK=tg.div`
2240
2240
  display: flex;
2241
2241
  align-items: center;
2242
2242
  justify-content: center;
@@ -3034,4 +3034,4 @@ You will have to sign up with another method first to register a passkey for you
3034
3034
  box-shadow: 0px 8px 36px rgba(55, 65, 81, 0.15);
3035
3035
  border-radius: var(--privy-border-radius-lg);
3036
3036
  }
3037
- `;import{useRef as o2,useEffect as qb}from"react";import{jsx as Kb}from"react/jsx-runtime";function $b({botUsername:e,scriptHost:t}){let r=document.createElement("script"),{origin:o}=new URL(t);return r.async=!0,r.src=`${o}/js/telegram-login.js`,r.setAttribute("data-telegram-login",e),r.setAttribute("data-request-access","write"),r.setAttribute("data-lang","en"),r}function n2(e){let t=o2(null),r=o2();return qb(()=>{r.current?.remove(),r.current=$b(e),t.current?.after(r.current)},[e]),Kb("div",{ref:t,hidden:!0})}import{useState as jb}from"react";import{useEffect as i2,useRef as a2}from"react";var mc=class{constructor(){this.callbacks={}}enqueue(t,r){this.callbacks[t]=r}dequeue(t,r){let o=this.callbacks[r];if(!o)throw new Error(`cannot dequeue ${t} event: no event found for id ${r}`);switch(delete this.callbacks[r],t){case"privy:iframe:ready":return o;case"privy:wallet:create":return o;case"privy:wallet:import":return o;case"privy:wallet:connect":return o;case"privy:wallet:recover":return o;case"privy:wallet:rpc":return o;case"privy:wallet:set-recovery-password":return o;case"privy:mfa:verify":return o;case"privy:mfa:init-enrollment":return o;case"privy:mfa:submit-enrollment":return o;case"privy:mfa:unenroll":return o;case"privy:mfa:clear":return o;case"privy:farcaster:init-signer":return o;case"privy:farcaster:sign":return o;default:throw new Error(`invalid wallet event type ${t}`)}}};async function Ho(e,t,r,o,n,i=!1){let a=i,l=async u=>{if(a&&t&&t.length>0){u===(i?0:1)?n("configureMfa","onMfaRequired",t):o.current?.reject(new De("missing_or_invalid_mfa","MFA verification failed, retry."));let h=await new Promise((f,y)=>{r.current={resolve:f,reject:y};let v=1e3*60*5;setTimeout(()=>{let g=new De("mfa_timeout","Timed out waiting for MFA code");o.current?.reject(g),y(g)},v)});return await e(h)}return await e()},s=4,c=null;for(let u=0;u<s;u++)try{c=await l(u),o.current?.resolve(void 0);break}catch(h){if(h.type==="missing_or_invalid_mfa")a=!0;else throw o.current?.resolve(void 0),h}if(c===null){let u=new De("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw o.current?.reject(u),u}return c}import{jsx as eE}from"react/jsx-runtime";var Yb=function(e){return()=>`id-${e++}`}(0);function Zb(e){return typeof e.event=="string"&&/^privy:.+/.test(e.event)}function Gt(e){return e.error!==void 0}var At=new mc,bp=new Map,Jb=(e,t)=>typeof t=="bigint"?t.toString():t,Qb=(e,t)=>`${e}${JSON.stringify(t,Jb)}`;function Vt(e,t,r,o){let n=r.contentWindow;if(!n)throw new Error("iframe not initialized");let i=Qb(e,t);if(e==="privy:wallet:create"){let l=bp.get(i);if(l)return l}let a=new Promise((l,s)=>{let c=Yb();At.enqueue(c,{resolve:l,reject:s}),n.postMessage({id:c,event:e,data:t},o)}).finally(()=>{bp.delete(i)});return bp.set(i,a),a}function Xb(e){switch(e.event){case"privy:iframe:ready":let t=At.dequeue(e.event,e.id);return Gt(e)?t.reject(new De(e.error.type,e.error.message)):t.resolve(e.data);case"privy:wallet:create":let r=At.dequeue(e.event,e.id);return Gt(e)?r.reject(new De(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallet:import":let o=At.dequeue(e.event,e.id);return Gt(e)?o.reject(new De(e.error.type,e.error.message)):o.resolve(e.data);case"privy:wallet:connect":let n=At.dequeue(e.event,e.id);return Gt(e)?n.reject(new De(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallet:recover":let i=At.dequeue(e.event,e.id);return Gt(e)?i.reject(new De(e.error.type,e.error.message)):i.resolve(e.data);case"privy:wallet:rpc":let a=At.dequeue(e.event,e.id);return Gt(e)?a.reject(new De(e.error.type,e.error.message)):a.resolve(e.data);case"privy:wallet:set-recovery-password":let l=At.dequeue(e.event,e.id);return Gt(e)?l.reject(new De(e.error.type,e.error.message)):l.resolve(e.data);case"privy:mfa:verify":let s=At.dequeue(e.event,e.id);return Gt(e)?s.reject(new De(e.error.type,e.error.message)):s.resolve(e.data);case"privy:mfa:init-enrollment":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:mfa:submit-enrollment":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:mfa:unenroll":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:mfa:clear":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:farcaster:init-signer":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:farcaster:sign":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}function s2(e){let t=a2(null),r=a2(e.mfaMethods),o=Vs(),[n,i]=jb(!1);return i2(()=>{r.current=e.mfaMethods},[e.mfaMethods]),i2(()=>{if(!n)return;let a=t.current;if(!a)return;function l(f){f&&f.origin===e.origin&&Zb(f.data)&&Xb(f.data)}let s={create(f){return Vt("privy:wallet:create",f,a,e.origin)},import(f){return Vt("privy:wallet:import",f,a,e.origin)},connect(f){return Vt("privy:wallet:connect",f,a,e.origin)},recover(f){return Ho(y=>Vt("privy:wallet:recover",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},rpc(f){return Ho(y=>Vt("privy:wallet:rpc",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},setRecoveryPassword(f){return Ho(y=>Vt("privy:wallet:set-recovery-password",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},verifyMfa(f){return Ho(y=>Vt("privy:mfa:verify",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},initEnrollMfa(f){return Ho(y=>Vt("privy:mfa:init-enrollment",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},submitEnrollMfa(f){return Ho(y=>Vt("privy:mfa:submit-enrollment",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},unenrollMfa(f){return Ho(y=>Vt("privy:mfa:unenroll",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},clearMfa(f){return Vt("privy:mfa:clear",f,a,e.origin)},initFarcasterSigner(f){return Vt("privy:farcaster:init-signer",f,a,e.origin)},signFarcasterMessage(f){return Vt("privy:farcaster:sign",f,a,e.origin)}};window.addEventListener("message",l);let c=()=>e.onLoad(s),u=(...f)=>{console.warn("Privy iframe failed to load: ",...f),e.onLoadFailed()},h=new AbortController;return _i(()=>Vt("privy:iframe:ready",{},a,e.origin),{abortSignal:h.signal}).then(c,u),()=>{window.removeEventListener("message",l),h.abort()}},[n]),eE("iframe",{ref:t,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},onLoad:()=>i(!0),src:Za(e.origin,`/apps/${e.appId}/embedded-wallets`,{caid:e.clientAnalyticsId,client_id:e.appClientId})})}function fc(e){let t=e.toLowerCase();return["fbav","fban","instagram","snapchat"].some(o=>t.includes(o))}var tE="https://cdn.apple-cloudkit.com";async function Ep({url:e,popup:t,provider:r}){return t.location=e,new Promise((n,i)=>{function a(){t?.close(),window.removeEventListener("message",l)}function l(s){s.data&&(s.data.type==="PRIVY_OAUTH_RESPONSE"&&s.data.stateCode&&s.data.authorizationCode&&(n(s.data),a()),s.origin===tE&&s.data.ckSession&&(n({type:"PRIVY_OAUTH_RESPONSE",ckWebAuthToken:s.data.ckSession}),a()),s.data.type==="PRIVY_OAUTH_ERROR"&&(i(s.data.error),a()))}window.addEventListener("message",l)})}var l2=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});import{jsx as vr,jsxs as c2}from"react/jsx-runtime";var ho;function nE(e){return typeof e=="string"&&e.length===25}function be(){if(!ho){let e=Z.get($o);return Promise.resolve(e||null)}return ho.getAccessToken()}var d2,Qu=(e,t,r)=>d2(e,t,r),p2,Xu=(e,t)=>p2(e,t),u2,em=(e,t)=>u2(e,t),m2,tm=()=>m2(),iE=()=>{let t=new URLSearchParams(window.location.search).get("privy_token");if(!t)return;Z.put(Ai,t);let r=new URL(window.location.href);r.searchParams.delete("privy_token"),window.history.pushState({},"",r)},aE=({config:e,...t})=>{if(!nE(t.appId))throw new T("Cannot initialize the Privy provider with an invalid Privy app ID");ho||(ho=new zi({appId:t.appId,appClientId:t.clientId,apiUrl:t.apiUrl||ki}));let r=Object.assign({},e);return t.createPrivyWalletOnLogin!==void 0&&r.embeddedWallets?.createOnLogin===void 0&&(r.embeddedWallets||(r.embeddedWallets={}),r.embeddedWallets.createOnLogin=t.createPrivyWalletOnLogin?"users-without-wallets":"off"),t.createPrivyWalletOnLogin!==void 0&&e?.embeddedWallets?.createOnLogin&&console.warn("Both `createPrivyWalletOnLogin` and `config.embeddedWallets.createOnLogin` are set. `createPrivyWalletOnLogin` is deprecated and should be removed."),vr(Mm,{client:ho,clientConfig:r,legacyCreateEmbeddedWalletFlag:t.createPrivyWalletOnLogin,children:vr(sE,{...t,client:ho})})},sE=e=>{let t=e.client,[r,o]=Ze(!1),[n,i]=Ze(!1),[a,l]=Ze(!1),[s,c]=Ze(null),[u,h]=Ze([]),f=Pi(u),[y,v]=Ze(!1),[g,x]=Ze(null),[S,w]=Ze(!1),[_,A]=Ze({status:"disconnected",connectedWallet:null,connectError:null,connector:null,connectRetry:b}),[N,I]=Ze({status:"initial"}),[R,B]=Ze(null),[K,Y]=Ze(null),[W,V]=Ze(null),L=ft(),ae=Fs(),[de,pe]=Ze(!0),[we,X]=Ze({}),[Et,Je]=Ze(null),[Rt,et]=Ze(null),[ir,Ie]=Ze(!1),[qe,ar]=Ze(!1),It=Pi(null),Ge=Pi(null),D=Pi(zm),[Go,Pe]=Ze(!1);t.onStoreToken=d=>{d&&U(D,"accessToken","onAccessTokenGranted",d)},t.onDeleteToken=()=>{c(null),l(!1),U(D,"accessToken","onAccessTokenRemoved")};let J=Pi(null),ee=Pi(null),ge=d=>{x(d),setTimeout(()=>{o(!0)},15),t.createAnalyticsEvent({eventName:"modal_open",payload:{initialScreen:d}})},Ue=d=>{L.embeddedWallets.createOnLogin!=="off"&&pe(!0),ge(d)};Nr(()=>{let d=()=>{document.visibilityState==="hidden"&&t.createAnalyticsEvent({eventName:"page_hidden",options:{keepAlive:!0}})};return document.addEventListener("visibilitychange",d),()=>{document.removeEventListener("visibilitychange",d)}},[]),Nr(()=>{if(!s){t.connectors?.removeEmbeddedWalletConnector();return}let d=Me(s),p=Mc(s);if(d||t.connectors?.removeEmbeddedWalletConnector(),p||t.connectors?.removeImportedWalletConnector(),!t.connectors){console.debug("Failed to add embedded wallet connector: Client connectors not initialized");return}if(!W){console.debug("Failed to add embedded wallet connector: Wallet proxy not initialized");return}d&&t.connectors.addEmbeddedWalletConnector(W,d.address,L.defaultChain,e.appId),p&&t.connectors.addImportedWalletConnector(W,p.address,L.defaultChain,e.appId)},[W,s]),Nr(()=>{W&&Rt?.(W)},[W]),Nr(()=>{(async()=>{if(!L.customAuth?.enabled)return;pe(!0);let{getCustomAccessToken:p,isLoading:m}=L.customAuth;if(!(!n||m))try{let C=await p();if(!C&&a){await Pn.logout();return}if(!C||a)return;t.startAuthFlow(new Sn(C));let{user:E,isNewUser:H}=await t.authenticate();if(!E){await Pn.logout();return}c(E||null),v(H||!1),l(!0),ar(!0)}catch(C){console.warn(C),a&&await Pn.logout()}})()},[L.customAuth?.enabled,L.customAuth?.getCustomAccessToken,L.customAuth?.isLoading,n,a]),Nr(()=>{qe&&W&&s&&Lt(s,L.embeddedWallets.createOnLogin)&&(ar(!1),Na(s,xn).catch(console.error))},[qe&&W&&s]),Nr(()=>{async function d(){let p=hc();iE();let m=rE();B(m),t.initializeConnectorManager({walletConnectCloudProjectId:L.walletConnectCloudProjectId,rpcConfig:L.rpcConfig,chains:L.chains,defaultChain:L.defaultChain,store:m,walletList:L.appearance.walletList,shouldEnforceDefaultChainOnConnect:L.shouldEnforceDefaultChainOnConnect,externalWalletConfig:L.externalWallets,appName:L.name??"Privy"});let C;t.connectors?.on("connectorInitialized",()=>{C&&clearTimeout(C);let H=t.connectors.walletConnectors.length,G=t.connectors.walletConnectors.reduce((fe,$e)=>fe+($e.initialized?1:0),0);G===H?Pe(!0):C=setTimeout(()=>{console.debug({message:"Unable to initialize all expected connectors before timeout",initialized:G,expected:H}),Pe(!0)},1500)}),t.connectors?.initialize().then(()=>{yc()});let E=await t.getAuthenticatedUser();L.customAuth?.enabled||(l(!!E),E&&U(D,"login","onComplete",E,!1,!0,null,null),c(E)),p||me.setReadyToTrue(!!E),p&&(E?ee.current="link":ee.current="login")}!n&&ae&&d()},[t,Et,n,ae]),Nr(()=>{if(!n)return;if(!s){Ie(!0);return}if(!!!s.linkedAccounts.find(m=>m.type==="wallet"&&m.walletClientType==="privy")){Ie(!0);return}let p=!!u.find(m=>m.walletClientType==="privy");Ie(p)},[n,s,u]);let hc=()=>{let d=Li();if(d.inProgress&&d.popupFlow){if(window.opener.location.origin!==window.location.origin){window.opener.postMessage({type:"PRIVY_OAUTH_ERROR",error:"Origins between parent and child windows do not match."});return}window.opener.postMessage({type:"PRIVY_OAUTH_RESPONSE",stateCode:d.stateCode,authorizationCode:d.authorizationCode});return}return!d.inProgress||d.headless?!1:(t.startAuthFlow(new Ur(d)),Ue("AWAITING_OAUTH_SCREEN"),!0)},En=async(d,p,m,C)=>{let E=await t.connectors?.createWalletConnector(d,p)||null;Tn(E,p,m,C)};async function Tn(d,p,m,C){if(d)A({status:"disconnected",connectedWallet:null,connectError:null,connector:d,connectRetry:b});else return A({status:"disconnected",connectedWallet:null,connectError:new te("Unable to connect to wallet."),connector:null,connectRetry:b}),C?.(null,m);d instanceof Gr&&p&&await d.resetConnection(p),A({connector:d,status:"connecting",connectedWallet:null,connectError:null,connectRetry:()=>Tn(d,p,m,C)});try{let E=await d.connect({showPrompt:!0});if(L.shouldEnforceDefaultChainOnConnect&&!L.chains.find(H=>H.id===Number(E?.chainId))&&!(E?.connectorType==="wallet_connect_v2"&&E?.walletClientType==="metamask")&&!(E?.connectorType==="coinbase_wallet"&&L.externalWallets.coinbaseWallet.connectionOptions!=="eoaOnly")){A(H=>({...H,connector:d,status:"switching_to_supported_chain",connectedWallet:null,connectError:null,connectRetry:b}));try{await E?.switchChain(L.defaultChain.id),E&&(E.chainId=_n(qo(L.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${L.defaultChain.id}`)}}return A(H=>({...H,status:"connected",connectedWallet:E,connectError:null,connectRetry:b})),E&&U(D,"connectWallet","onSuccess",E),C?.(E,m)}catch(E){return E instanceof ze?(console.warn(E.cause?E.cause:E.message),U(D,"connectWallet","onError",E.privyErrorCode||"generic_connect_wallet_error")):(console.warn(E),U(D,"connectWallet","onError","unknown_connect_wallet_error")),A(H=>({...H,status:"disconnected",connectedWallet:null,connectError:E})),C?.(null,m)}}let Vo=async(d,p)=>{if(d===null)return;let m=new Xo(d,p);t.startAuthFlow(m)},yc=()=>{let d=new URLSearchParams(window.location.search),p=d.get("privy_connector"),m=d.get("privy_wallet_client");if(!p||!m)return;if(m==="phantom"&&!vo()&&Ue("LOGIN_FAILED_SCREEN"),!t.connectors)throw new T("Connector not initialized");ge("AWAITING_CONNECTION");let C=new URL(window.location.href);C.searchParams.delete("privy_connector"),C.searchParams.delete("privy_wallet_client"),window.history.pushState({},"",C),En(p,m,void 0,Vo)};Nr(()=>{n&&a&&s===null&&t.getAuthenticatedUser().then(c)},[n,a,s,t]);let Ve=()=>{if(!a)throw U(D,"linkAccount","onError","must_be_authenticated"),new T("User must be authenticated before linking an account.")},yo=()=>{Ve(),J.current="siwe",ee.current="link",ge("LINK_WALLET_SCREEN")},Qe=d=>{if(!a||!s)return!1;if(d.walletClientType==="privy")return!0;for(let p of s.linkedAccounts)if(p.type==="wallet"&&p.address===d.address&&p.walletClientType!=="privy")return!0;return!1},zt=async d=>{if(!t.connectors)throw new T("Connector not initialized");let p=t.connectors.findWalletConnector(d.connectorType,d.walletClientType)||null;if(A(m=>({...m,connector:p,status:"connected",connectedWallet:d,connectError:null,connectRetry:b})),L.captchaEnabled&&!a){let m={callback:C=>Vo(d,C),userIntentRequired:!1,onSuccessNavigateTo:"AWAITING_CONNECTION",onErrorNavigateTo:"ERROR_SCREEN"};X({captchaModalData:m}),Ue("CAPTCHA_SCREEN")}else await Vo(d),Ue("AWAITING_CONNECTION")},Cr=async(d,p)=>{if(!L.fiatOnRamp.enabled)throw new T("Fiat on-ramp is not enabled");if(!p||!p.provider||p.provider==="moonpay"){let{signedUrl:m,externalTransactionId:C}=await ey(t,d,p?.config??{},L.appearance.palette,L.fiatOnRamp.useSandbox);return{signedUrl:m,externalTransactionId:C}}else throw new T("Unsupported fund provider. Currently supported option is `moonpay`.")},zo=()=>{h(d=>{let p=t.connectors?.wallets.map(m=>({...m,linked:Qe(m),loginOrLink:async()=>{if(!await m.isConnected())throw new T("Wallet is not connected");if(m.connectorType==="embedded"&&m.walletClientType==="privy")throw new T("Cannot link or login with embedded wallet");zt(m)},fund:async C=>{let{signedUrl:E,externalTransactionId:H}=await Cr(m.address,C);X({fiatOnRampPrompt:{signedUrl:E},fiatOnRampStatus:{externalTransactionId:H}}),ge("FIAT_ON_RAMP_PROMPT_SCREEN")},unlink:async()=>{if(!a)throw new T("User is not authenticated.");if(m.connectorType==="embedded"&&m.walletClientType==="privy")throw new T("Cannot unlink an embedded wallet");let C=await t.unlinkWallet(m.address);c(C)}}))||[];return Cs(d,p)?d:p})};Nr(()=>{zo()},[s?.linkedAccounts,a,n]),Nr(()=>{if(n){if(!t.connectors)throw new T("Connector not initialized");zo(),t.connectors.on("walletsUpdated",zo)}},[n]);let to=()=>{ge(a?"CONNECT_ONLY_AUTHENTICATED_SCREEN":"CONNECT_ONLY_LANDING_SCREEN")};Nr(()=>{if(!u[0])return;let d=u[0],p=f.current.find(C=>C.address===d.address),m;if(d.walletClientType==="privy"?m=s?.linkedAccounts.find(C=>C.type==="wallet"&&C.address===d.address&&C.walletClientType==="privy"):m=s?.linkedAccounts.find(C=>C.type==="wallet"&&C.address===d.address&&C.walletClientType!=="privy"),!p&&m){let C=Object.assign({},s);C.wallet=m&&{address:m.address,chainType:m.chainType,chainId:m.chainId,walletClient:m.walletClient,walletClientType:m.walletClientType,connectorType:m.connectorType,imported:m.imported},c(C)}f.current=u},[u]);let Na=async(d,p)=>{if(Me(d))throw U(D,"createWallet","onError","embedded_wallet_already_exists"),new Error("Only one Privy wallet per user is currently allowed");let[C,E]=await Promise.all([me.initializeWalletProxy(p),be()]);if(!C&&L.customAuth?.enabled)throw U(D,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to connect to wallet proxy");if(!C||!E||L.embeddedWallets?.requireUserOwnedRecoveryOnCreate)return new Promise((H,G)=>{pe(!0),X({createWallet:{onSuccess:$e=>{U(D,"createWallet","onSuccess",$e),H($e)},onFailure:$e=>{U(D,"createWallet","onError","unknown_embedded_wallet_error"),G($e)},callAuthOnSuccessOnClose:!1}}),ge("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")});{await C.create({accessToken:E});let H=await me.refreshUser(),G=Me(H);if(!G)throw U(D,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");return U(D,"createWallet","onSuccess",G),G}},g2=d=>{if(!L.chains.map(p=>p.id).includes(d))throw new te(`Chain ID ${d} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,"unsupported_chain_id")},Pp=(d,p,m)=>new Promise(async(C,E)=>{if(!a||!s){U(D,"sendTransaction","onError","must_be_authenticated"),E(new Error("User must be authenticated before signing with a Privy wallet"));return}let H=d.from,G=H?s?.linkedAccounts.find(Se=>Se.type==="wallet"&&Se.walletClientType==="privy"&&Se.address===H):Me(s);if(!G){U(D,"sendTransaction","onError","embedded_wallet_not_found"),E(new Error("Must have a Privy wallet before signing"));return}pe(!0);let fe=t.connectors?.findWalletConnector("embedded","privy")?.proxyProvider,$e=d.chainId?Number(d.chainId):fe.chainId;g2($e);let mt=Object.assign({},d,{chainId:$e}),sr=async()=>{let Se=await be();if(!Se||!W){U(D,"sendTransaction","onError","embedded_wallet_not_found"),E(new Error("Must have valid access token and Privy wallet to send transaction"));return}try{if(!await me.recoverEmbeddedWallet()){U(D,"sendTransaction","onError","unknown_connect_wallet_error"),E(new Error("Unable to connect to wallet"));return}let wr=ro(mt.chainId,L.chains,L.rpcConfig,{appId:e.appId}),gc=await gi(G.address,mt,wr);if(L.embeddedWallets.noPromptOnSignature){let{totalGasEstimate:C2}=await yi(gc,wr),{hasSufficientFunds:w2}=await Xl(G.address,gc,C2,wr);if(!w2)throw new Be(new Kt("Wallet has insufficient funds for this transaction.",lt.E32603_DEFAULT_INTERNAL_ERROR.eipCode))}let _p=await Ql(Se,G.address,W,gc,wr);U(D,"sendTransaction","onSuccess",_p),C(_p)}catch(Da){U(D,"sendTransaction","onError","transaction_failure"),E(Da)}};if(L.embeddedWallets.noPromptOnSignature)p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config"),sr();else{let Se={transactionRequest:mt,onSuccess:wr=>{U(D,"sendTransaction","onSuccess",wr),C(wr)},onFailure:wr=>{U(D,"sendTransaction","onError","transaction_failure"),E(wr)},uiOptions:p||{},fundWalletConfig:m},Da={onCompleteNavigateTo:"EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN",onFailure:wr=>{U(D,"sendTransaction","onError","unknown_connect_wallet_error"),E(wr)}};X({connectWallet:Da,sendTransaction:Se}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}});function Sp(){return new Promise(async(d,p)=>{let m=await be();if(!m||!W)throw new Error("Must have valid access token to enroll in MFA");try{await W.verifyMfa({accessToken:m}),d()}catch(C){p(C)}})}let Mt=d=>{if(d==="passkey"){if(s&&s.linkedAccounts.filter(p=>p.type==="passkey").length>=5)throw U(D,"linkAccount","onError","cannot_link_more_of_type"),new T(`User already has an account of type ${d} linked.`)}else if(s?.[d])throw U(D,"linkAccount","onError","cannot_link_more_of_type"),new T(`User already has an account of type ${d} linked.`)},Pn={ready:n,authenticated:a,user:s,walletConnectors:t.connectors||null,connectWallet:to,importWallet:async({privateKey:d})=>{Ve();let[p,m]=await Promise.all([me.initializeWalletProxy(15e3),be()]);if(p&&m){await p.import({privateKey:d,accessToken:m});let C=await me.refreshUser(),E=Mc(C);if(!E)throw U(D,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to import wallet");return U(D,"createWallet","onSuccess",E),E}else throw new T("User is not authenticated")},linkWallet:yo,linkEmail:()=>{Ve(),Mt("email"),J.current="email",ee.current="link",ge("LINK_EMAIL_SCREEN")},linkPhone:()=>{Ve(),Mt("phone"),J.current="sms",ee.current="link",ge("LINK_PHONE_SCREEN")},linkGoogle:async()=>{Ve(),Mt("google"),ee.current="link",await me.initLoginWithOAuth("google")},linkTwitter:async()=>{Ve(),Mt("twitter"),ee.current="link",await me.initLoginWithOAuth("twitter")},linkDiscord:async()=>{Ve(),Mt("discord"),ee.current="link",await me.initLoginWithOAuth("discord")},linkGithub:async()=>{Ve(),Mt("github"),ee.current="link",await me.initLoginWithOAuth("github")},linkSpotify:async()=>{Ve(),Mt("spotify"),ee.current="link",await me.initLoginWithOAuth("spotify")},linkInstagram:async()=>{Ve(),Mt("instagram"),ee.current="link",await me.initLoginWithOAuth("instagram")},linkTiktok:async()=>{Ve(),Mt("tiktok"),ee.current="link",await me.initLoginWithOAuth("tiktok")},linkLinkedIn:async()=>{Ve(),Mt("linkedin"),ee.current="link",await me.initLoginWithOAuth("linkedin")},linkApple:async()=>{Ve(),Mt("apple"),ee.current="link",await me.initLoginWithOAuth("apple")},linkPasskey:async()=>{Ve(),Mt("passkey"),await me.initLinkWithPasskey(),ge("LINK_PASSKEY_SCREEN")},linkTelegram:async()=>{Ve(),Mt("telegram"),ee.current="link",J.current="telegram",await me.initLoginWithTelegram(),ge("TELEGRAM_AUTH_SCREEN")},linkFarcaster:async()=>{Ve(),Mt("farcaster"),await me.initLoginWithFarcaster(),ee.current="link",J.current="farcaster",ge("AWAITING_FARCASTER_CONNECTION")},updateEmail:()=>{if(Ve(),!s?.email)throw new T("User does not have an email linked to their account.");ee.current="link",J.current="email",ge("UPDATE_EMAIL_SCREEN")},login:async()=>{let d="Attempted to log in, but user is already logged in. Use a `link` helper instead.";if(!n){let p=await new Promise(m=>{Je(C=>m.bind(C))});if(Je(null),p){console.warn(d);return}}if(a){console.warn(d);return}ee.current="login",Ue("LANDING")},connectOrCreateWallet:async()=>{if(n||(await new Promise(d=>{Je(()=>d)}),Je(null)),a){console.warn("User must be unauthenticated to `connectOrCreateWallet`");return}if(u[0]){console.warn("User must have no connected wallets to `connectOrCreateWallet`");return}Ue("CONNECT_OR_CREATE")},logout:async()=>{if(await t.logout(),s&&W)try{await W.clearMfa({userId:s.id})}catch{}c(null),l(!1),x(null),U(D,"logout","onSuccess"),ee.current=null,J.current=null,o(!1),Z.del(Ri)},getAccessToken:()=>t.getAccessToken(),getEthereumProvider:()=>{if(!s||!s.wallet)return new Oe;let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(C=>C.address===d?.address));return!d||!p?new Oe:p.proxyProvider},getEthersProvider:()=>{if(!s||!s.wallet)return new Tp(new Fr(new Oe));let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(C=>C.address===d?.address));return!d||!p?new Tp(new Fr(new Oe)):new Tp(new Fr(p.proxyProvider))},getWeb3jsProvider:()=>{if(!s||!s.wallet)return new bo(new Oe);let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(C=>C.address===d?.address));return!d||!p?new bo(new Oe):new bo(p.proxyProvider)},unlinkWallet:async d=>{let p=await t.unlinkWallet(d);return c(p),p},unlinkEmail:async d=>{let p=await t.unlinkEmail(d);return c(p),p},unlinkPhone:async d=>{let p=await t.unlinkPhone(d);return c(p),p},unlinkGoogle:async d=>{let p=await t.unlinkOAuth("google",d);return c(p),p},unlinkTwitter:async d=>{let p=await t.unlinkOAuth("twitter",d);return c(p),p},unlinkDiscord:async d=>{let p=await t.unlinkOAuth("discord",d);return c(p),p},unlinkGithub:async d=>{let p=await t.unlinkOAuth("github",d);return c(p),p},unlinkSpotify:async d=>{let p=await t.unlinkOAuth("spotify",d);return c(p),p},unlinkInstagram:async d=>{let p=await t.unlinkOAuth("instagram",d);return c(p),p},unlinkTiktok:async d=>{let p=await t.unlinkOAuth("tiktok",d);return c(p),p},unlinkLinkedIn:async d=>{let p=await t.unlinkOAuth("linkedin",d);return c(p),p},unlinkApple:async d=>{let p=await t.unlinkOAuth("apple",d);return c(p),p},unlinkFarcaster:async d=>{let p=await t.unlinkFarcaster(d);return c(p),p},unlinkTelegram:async d=>{let p=await t.unlinkTelegram(d);return c(p),p},unlinkPasskey:async d=>{let p=await t.unlinkPasskey(d);return c(p),p},setActiveWallet:async d=>{let p=u.find(C=>Ti(C.address)===Ti(d)),m=s?.linkedAccounts.find(C=>C.type==="wallet"&&Ti(C.address)===Ti(d));if(!p||!await p.isConnected())Y(d),yo();else if(!p.linked)p.loginOrLink();else{let C=Object.assign({},s);C.wallet=m&&{address:m.address,chainType:m.chainType,chainId:m.chainId,walletClient:m.walletClient,walletClientType:m.walletClientType,connectorType:m.connectorType,imported:m.imported},c(C)}},forkSession:()=>t.forkSession(),createWallet:async()=>{if(!a||!s)throw U(D,"createWallet","onError","must_be_authenticated"),new Error("User must be authenticated before creating a Privy wallet");return Na(s,15e3)},setWalletPassword:async()=>{if(!a||!s)throw U(D,"setWalletPassword","onError","must_be_authenticated"),new Error("User must be authenticated before adding password to Privy wallet");let d=Me(s);if(!d||!W)throw U(D,"setWalletPassword","onError","embedded_wallet_not_found"),new Error("Must have a Privy wallet to add a password");if(["google-drive","icloud"].includes(d.recoveryMethod))throw U(D,"setWalletPassword","onError","embedded_wallet_recovery_already_exists"),new Error("Cannot set password. Embedded wallet is set to recover using a cloud provider.");try{await Sp()}catch(p){throw U(D,"setWalletPassword","onError","missing_or_invalid_mfa"),p}return new Promise((p,m)=>{pe(!0);let C={onSuccess:G=>{U(D,"setWalletPassword","onSuccess",G),p(G)},onFailure:G=>{U(D,"setWalletPassword","onError","user_exited_set_password_flow"),m(G)},callAuthOnSuccessOnClose:!1},H={onCompleteNavigateTo:d.recoveryMethod==="user-passcode"?"EMBEDDED_WALLET_PASSWORD_UPDATE_SCREEN":"EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN",onFailure:G=>{U(D,"setWalletPassword","onError","unknown_connect_wallet_error"),m(G)}};X({setWalletPassword:C,createWallet:C,connectWallet:H}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")})},signMessage:(d,p,m)=>new Promise(async(C,E)=>{if(!a||!s){U(D,"signMessage","onError","must_be_authenticated"),E(new Error("User must be authenticated before signing with a Privy wallet"));return}let H=m?s?.linkedAccounts.find(fe=>fe.type==="wallet"&&fe.walletClientType==="privy"&&Ti(fe.address)===Ti(m)):Me(s);if(!H){U(D,"signMessage","onError","embedded_wallet_not_found"),E(new Error("Must have a Privy wallet before signing"));return}if(typeof d!="string"||d.length<1){U(D,"signMessage","onError","invalid_message"),E(new Error("Message must be a non-empty string"));return}pe(!0);let G=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let fe=await be();if(!W||!fe)throw new Error("Unable to connect to wallet");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_started",payload:{walletAddress:H.address}});let{response:mt}=await W.rpc({accessToken:fe,address:H.address,request:{method:"personal_sign",params:[d,H.address]}}),sr=mt.data;return t.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_completed",payload:{walletAddress:H.address}}),sr};if(L.embeddedWallets.noPromptOnSignature){p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let fe=await G();U(D,"signMessage","onSuccess",fe),C(fe)}catch(fe){U(D,"signMessage","onError","unable_to_sign"),E(fe??new Be("Unable to sign message"))}}else{let mt={method:"personal_sign",data:d,confirmAndSign:G,onSuccess:Se=>{U(D,"signMessage","onSuccess",Se),C(Se)},onFailure:Se=>{U(D,"signMessage","onError","unable_to_sign"),E(Se)},uiOptions:p||{}},sr={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:Se=>{U(D,"signMessage","onError","unknown_connect_wallet_error"),E(Se)},address:H.address};X({signMessage:mt,connectWallet:sr}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),signTypedData:(d,p)=>new Promise(async(m,C)=>{if(!a||!s){U(D,"signTypedData","onError","must_be_authenticated"),C(new Error("User must be authenticated before signing with a Privy wallet"));return}let E=Me(s);if(!E){U(D,"signTypedData","onError","embedded_wallet_not_found"),C(new Error("Must have a Privy wallet before signing"));return}pe(!0);let H=Ja(d),G=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let fe=await be();if(!W||!fe)throw new Error("Unable to connect to wallet");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_started",payload:{walletAddress:E.address}});let{response:mt}=await W.rpc({accessToken:fe,address:E.address,request:{method:"eth_signTypedData_v4",params:[E.address,H]}}),sr=mt.data;return t.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_completed",payload:{walletAddress:E.address}}),sr};if(L.embeddedWallets.noPromptOnSignature||(L.legacyWalletUiConfig??!1)){p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let fe=await G();U(D,"signTypedData","onSuccess",fe),m(fe)}catch(fe){U(D,"signTypedData","onError","unable_to_sign"),C(fe??new Be("Unable to sign message"))}}else{let mt={method:"eth_signTypedData_v4",data:H,confirmAndSign:G,onSuccess:Se=>{U(D,"signTypedData","onSuccess",Se),m(Se)},onFailure:Se=>{U(D,"signTypedData","onError","unable_to_sign"),C(Se)},uiOptions:p||{}},sr={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:Se=>{U(D,"signMessage","onError","unknown_connect_wallet_error"),C(Se)}};X({signMessage:mt,connectWallet:sr}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),sendTransaction:async(d,p,m)=>{let E=await(await Pp(d,p,m)).wait();return ec(E)},exportWallet:()=>new Promise(async(d,p)=>{if(!a||!s){p(new Error("User must be authenticated before exporting their Privy wallet"));return}if(!Me(s)){p(new Error("Must have a Privy wallet before exporting"));return}pe(!0);let C={onCompleteNavigateTo:"EMBEDDED_WALLET_KEY_EXPORT_SCREEN",onFailure:p,shouldForceMFA:!0};if(X(we),!await be()||!W){p(new Error("Must have valid access token to enroll in MFA"));return}if(!W){p(new Error("Must have a Privy wallet before exporting"));return}let H={appId:e.appId,appClientId:e.clientId,origin:t.apiUrl,onSuccess:d,onFailure:p};X({keyExport:H,connectWallet:C}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}),promptMfa:Sp,async init(d){switch(d){case"sms":await t.initMfaSmsVerification();return;case"passkey":return await t.initMfaPasskeyVerification();case"totp":return;default:throw new Error(`Unsupported MFA method: ${d}`)}},async submit(d,p){switch(d){case"totp":case"sms":if(typeof p!="string")throw new T("Invalid MFA code");It.current?.resolve({mfaMethod:d,mfaCode:p,relyingParty:window.origin}),await new Promise((H,G)=>{Ge.current={resolve:H,reject:G}});break;case"passkey":if(typeof p=="string")throw new T("Invalid authenticator response");let C=await(await import("@simplewebauthn/browser")).startAuthentication(p),E=l2(C);It.current?.resolve({mfaMethod:d,mfaCode:E,relyingParty:window.origin}),await new Promise((H,G)=>{Ge.current={resolve:H,reject:G}});break;default:throw It.current?.reject(new T("Unsupported MFA method")),new T(`Unsupported MFA method: ${d}`)}},cancel(){It.current?.reject(new T("MFA canceled"))},async initEnrollmentWithSms(d){let p=await be();if(!p||!W)throw new Error("Must have valid access token to enroll in MFA");await W.initEnrollMfa({method:"sms",accessToken:p,phoneNumber:d.phoneNumber})},enrollInMfa(d){return new Promise((p,m)=>{if(!d){me.closePrivyModal(),p();return}L.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."),X({mfaEnrollmentFlow:{mfaMethods:L.mfa.methods,onSuccess:p,onFailure:m}}),ge("MFA_ENROLLMENT_FLOW_SCREEN")})},async initEnrollmentWithTotp(){let d=await be();if(!d||!W)throw new Error("Must have valid access token to enroll in MFA");let p=await W.initEnrollMfa({method:"totp",accessToken:d});return{secret:p.secret,authUrl:p.authUrl}},async submitEnrollmentWithSms(d){let p=await be();if(!p||!W)throw new Error("Must have valid access token to enroll in MFA");await W.submitEnrollMfa({method:"sms",accessToken:p,phoneNumber:d.phoneNumber,code:d.mfaCode});let m=await t.getAuthenticatedUser();c(m)},async submitEnrollmentWithTotp(d){let p=await be();if(!p||!W)throw new Error("Must have valid access token to enroll in MFA");await W.submitEnrollMfa({method:"totp",accessToken:p,code:d.mfaCode});let m=await t.getAuthenticatedUser();c(m)},async initEnrollmentWithPasskey(){},async submitEnrollmentWithPasskey({credentialIds:d}){let p=await be();if(!p||!W)throw new Error("Must have valid access token to enroll in MFA");await W.submitEnrollMfa({method:"passkey",accessToken:p,credentialIds:d});let m=await t.getAuthenticatedUser();c(m)},async unenroll(d){let p=await be();if(!p||!W)throw new Error("Must have valid access token to remove MFA");d==="passkey"?await W.submitEnrollMfa({method:"passkey",accessToken:p,credentialIds:[]}):await W.unenrollMfa({method:d,accessToken:p});let m=await t.getAuthenticatedUser();c(m)},requestFarcasterSignerFromWarpcast:async()=>{let d=await be(),p=s?.linkedAccounts.find(E=>E.type==="wallet"&&E.walletClientType==="privy");if(!d)throw new Error("Must have valid access token to connect with Farcaster");if(!W||!p)throw new Error("Must have an embedded wallet to use Farcaster signers");if(!s?.farcaster?.fid)throw new Error("Must have Farcaster account to use Farcaster signers");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");let C=await W.initFarcasterSigner({address:p.address,hdWalletIndex:null,accessToken:d,mfaCode:null,mfaMethod:null,relyingParty:window.origin});if(C.status==="approved"){let E=await t.getAuthenticatedUser();c(E||s||null)}X({farcasterSigner:C}),ge("AWAITING_FARCASTER_SIGNER")},getFarcasterSignerPublicKey:async()=>{let d=await be(),p=s?.linkedAccounts.find(E=>E.type==="wallet"&&E.walletClientType==="privy");if(!d)throw new Error("Must have valid access token to connect with Farcaster");if(!W||!p)throw new Error("Must have an embedded wallet to use Farcaster signers");if(!s?.farcaster?.fid)throw new Error("Must have Farcaster account to use Farcaster signers");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");if(!s.farcaster?.signerPublicKey)throw new Error("Must have a Farcaster signer public key to sign");return(E=>Uint8Array.from(E.match(/.{1,2}/g).map(H=>parseInt(H,16))))(s.farcaster.signerPublicKey.slice(2))},signFarcasterMessage:async d=>{let p=await be(),m=s?.linkedAccounts.find(G=>G.type==="wallet"&&G.walletClientType==="privy");if(!p)throw new Error("Must have valid access token to connect with Farcaster");if(!W||!m)throw new Error("Must have an embedded wallet to use Farcaster signers");if(!s?.farcaster?.fid)throw new Error("Must have Farcaster account to use Farcaster signers");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");if(!s.farcaster?.signerPublicKey)throw new Error("Must have a Farcaster signer public key to sign");let E=await import("@simplewebauthn/browser"),H=await W.signFarcasterMessage({address:m.address,hdWalletIndex:null,accessToken:p,mfaCode:null,mfaMethod:null,payload:{hash:E.bufferToBase64URLString(d)},fid:BigInt(s.farcaster.fid),relyingParty:window.origin});return new Uint8Array(E.base64URLStringToBuffer(H.signature))},isHeadlessOAuthLoading:S,loginWithCode(d){return me.loginWithCode(d)},initLoginWithEmail(d){return me.initLoginWithEmail(d)},initLoginWithSms(d){return me.initLoginWithSms(d)},otpState:N,fundWallet(d,p){return me.fundWallet(d,p)},initLoginWithHeadlessOAuth(d,p){return me.initLoginWithHeadlessOAuth(d,p)},loginWithHeadlessOAuth(d){return me.loginWithHeadlessOAuth(d)},isModalOpen:r,mfaMethods:L.mfa.methods};d2=Pn.signMessage,p2=Pn.signTypedData,u2=async(...d)=>{let p=await Pp(...d);return L.embeddedWallets.waitForTransactionConfirmation&&await p.wait(),p};let me=(()=>({isNewUserThisSession:y,linkingHint:K,pendingTransaction:null,walletConnectionStatus:_,mipdStore:R,connectors:t.connectors?.walletConnectors??[],rpcConfig:L.rpcConfig,chains:L.chains,appId:e.appId,showFiatPrices:L.embeddedWallets.priceDisplay.primary!=="native-token",clientAnalyticsId:t.clientAnalyticsId,nativeTokenSymbolForChainId:d=>L.chains.find(p=>p.id===Number(d))?.nativeCurrency.symbol,initializeWalletProxy:async d=>{if(W)return W;let p=new Promise(E=>{et(()=>H=>E(H))}),m=new Promise(E=>setTimeout(()=>E(null),d)),C=await Promise.race([p,m]);return et(null),C},getAuthFlow:()=>t.authFlow,getAuthMeta:()=>t.authFlow?.meta,closePrivyModal:(d={shouldCallAuthOnSuccess:!0,isSuccess:!1})=>{let p=n&&a&&s,m;p&&J.current&&(m=s?.linkedAccounts.filter(C=>C.latestVerifiedAt!==null&&!(C.type==="wallet"&&C.walletClientType==="privy")).sort((C,E)=>E.latestVerifiedAt.getTime()-C.latestVerifiedAt.getTime())[0]),ee.current==="login"&&J.current?d.shouldCallAuthOnSuccess&&p?(U(D,"login","onComplete",s,y,!1,J.current,m??null),e.onSuccess?.(s,y)):U(D,"login","onError","exited_auth_flow"):ee.current==="link"&&J.current&&m&&(d.isSuccess&&p?U(D,"linkAccount","onSuccess",s,J.current,m):U(D,"linkAccount","onError","exited_link_flow")),Y(null),ee.current=null,J.current=null,v(!1),o(!1),setTimeout(()=>{t.authFlow=void 0},200),t.createAnalyticsEvent({eventName:"modal_closed"})},openPrivyModal:ge,connectWallet:Tn,initLoginWithWallet:async(d,p)=>{J.current="siwe",Vo(d,p)},loginWithWallet:async()=>{if(!n)throw new Dr;if(!(t.authFlow instanceof Xo))throw new T("Must initialize SIWE flow first.");let d,p;if(a)try{({user:d}=await t.link()),J.current="siwe"}catch(m){throw U(D,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{({user:d,isNewUser:p}=await t.authenticate()),J.current="siwe"}catch(m){throw U(D,"login","onError",m.privyErrorCode||"generic_connect_wallet_error"),m}c(d||s||null),v(p||!1),l(!0)},initLoginWithFarcaster:async d=>{let p=new xi(d);t.startAuthFlow(p);try{J.current="farcaster",await p.initializeFarcasterConnect()}catch(m){throw ee.current==="login"?U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",m.privyErrorCode||"unknown_auth_error"),m}},loginWithFarcaster:async()=>{if(!n)throw new Dr;if(!(t.authFlow instanceof xi))throw new T("Must initialize Farcaster flow first.");let d,p;if(a)try{({user:d}=await t.link()),J.current="farcaster"}catch(m){throw U(D,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{({user:d,isNewUser:p}=await t.authenticate()),J.current="farcaster"}catch(m){throw U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"),m}c(d||null),v(p||!1),l(!0)},async initLoginWithOAuth(d,p){if(J.current=d,bc()){if(d==="google"&&fc(window.navigator.userAgent)){Ue("IN_APP_BROWSER_LOGIN_NOT_POSSIBLE");return}}else{Ue("IN_APP_BROWSER_LOGIN_NOT_POSSIBLE");return}Z.del(Yo);let m=new Ur({provider:d});p&&m.addCaptchaToken(p),t.startAuthFlow(m);let C=await t.authFlow.getAuthorizationUrl();C&&C.url&&window.location.assign(C.url)},async initLoginWithTelegram(d){if(!n)throw new Dr;J.current="telegram";let p=new Oi(d);t.startAuthFlow(p),t.authFlow.meta.telegramAuthResult=await new Promise((m,C)=>{if(!L.loginConfig.telegramAuthConfiguration)return C("Telegram Auth configuration is not loaded");if(!window.Telegram)return C("Telegram was not initialized");window.Telegram.Login.auth({bot_id:L.loginConfig.telegramAuthConfiguration.botId,request_access:!0},E=>E?m(E):C("Telegram auth failed or was canceled by the client"))})},async loginWithTelegram(){if(!n)throw new Dr;if(!(t.authFlow instanceof Oi))throw new T("Must initialize Telegram flow before calling loginWithTelegram");let d,p;if(a)try{({user:d}=await t.link()),J.current="telegram"}catch(m){throw U(D,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{let m=await t.authenticate();d=m.user,p=m.isNewUser,J.current="telegram"}catch(m){throw ee.current==="login"?U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}c(d),v(p||!1),l(!0)},async recoveryOAuthFlow(d,p,m){let C,E;function H(G){if(!G)throw t.createAnalyticsEvent({eventName:"recovery_oauth_error",payload:{error:"Unable to open recovery OAuth popup",provider:d}}),new T("Recovery OAuth failed")}switch(d){case"google-drive":{let{url:G,codeVerifier:fe,stateCode:$e}=await md({api:ho.api,provider:d});H(G);let mt,sr;try{let Se=await Ep({url:G,popup:m,provider:d});if(mt=Se.stateCode,sr=Se.authorizationCode,mt!==$e)throw t.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:d,storedStateCode:$e??"",returnedStateCode:mt??""}}),new T("Unexpected auth flow. This may be a phishing attempt.")}catch(Se){throw t.createAnalyticsEvent({eventName:"recovery_oauth_error",payload:{error:Se.toString(),provider:d}}),new T("Recovery OAuth failed")}[C,E]=await Promise.all([be(),qf({api:ho.api,provider:d,codeVerifier:fe,stateCode:mt,authorizationCode:sr})]);break}case"icloud":{let{url:G}=await md({api:ho.api,provider:d});H(G);let{ckWebAuthToken:fe}=await Ep({url:G,popup:m,provider:d});E=fe,C=await be();break}}if(!W)throw new T("Cannot connect to wallet proxy");switch(p){case"recover":let G=we.recoverWallet?.privyWallet?.address;if(!G)throw new T("Recovery OAuth failed");t.createAnalyticsEvent({eventName:"embedded_wallet_recovery_started",payload:{walletAddress:G,recoveryMethod:d}}),await W.recover({address:G,accessToken:C,recoveryAccessToken:E,recoveryMethod:d}),t.createAnalyticsEvent({eventName:"embedded_wallet_recovery_completed",payload:{walletAddress:G,recoveryMethod:d}});break;case"create-wallet":t.createAnalyticsEvent({eventName:"embedded_wallet_creation_started"}),await W.create({accessToken:C,recoveryAccessToken:E,recoveryMethod:d});let fe=await me.refreshUser(),$e=Me(fe);if(!$e)throw U(D,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");t.createAnalyticsEvent({eventName:"embedded_wallet_creation_completed",payload:{walletAddress:$e.address}}),U(D,"createWallet","onSuccess",$e);break;default:throw new T("Unsupported recovery action")}},async loginWithOAuth(d){if(!(t.authFlow instanceof Ur))throw new T("Must initialize OAuth flow before calling loginWithOAuth");let p=Z.get(Ko),m=t.authFlow.meta.stateCode;if(p!==m)throw t.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:d,storedStateCode:p??"",returnedStateCode:m??""}}),new T("Unexpected auth flow. This may be a phishing attempt.");let C,E,H;if(a)try{let G=await t.link();C=G.user,H=G.oAuthProviderTokens,J.current=d}catch(G){throw U(D,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}else try{let G=await t.authenticate();C=G.user,E=G.isNewUser,H=G.oAuthProviderTokens,J.current=d}catch(G){throw ee.current==="login"?U(D,"login","onError",G.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}return c(C),v(E||!1),l(!0),H},async initLoginWithPasskey(d){let p=new Qo(d);t.startAuthFlow(p),ee.current="login";try{J.current="passkey",await p.initAuthenticationFlow()}catch(m){throw U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"),m}},async loginWithPasskey(){if(!n)throw new Dr;if(!(t.authFlow instanceof Qo))throw new T("Must initialize Passkey flow first.");if(J.current!=="passkey")throw new T("Must init login with Passkey flow first.");let d,p;try{J.current="passkey",{user:d,isNewUser:p}=await t.authenticate()}catch(m){throw U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"),m}c(d),v(p||!1),l(!0)},async initLinkWithPasskey(d){let p=new Qo(d);t.startAuthFlow(p),ee.current="link",J.current="passkey";try{await p.initLinkFlow()}catch(m){throw U(D,"linkAccount","onError",m.privyErrorCode||"unknown_auth_error"),m}},async linkWithPasskey(){if(!n)throw new Dr;if(!(t.authFlow instanceof Qo))throw new T("Must initialize Passkey flow first.");if(J.current!=="passkey")throw new T("Must init login with Passkey flow first.");let d;try{J.current="passkey",{user:d}=await t.link()}catch(p){throw U(D,"linkAccount","onError",p.privyErrorCode||"failed_to_link_account"),p}return c(d||s||null),d},async initLoginWithHeadlessOAuth(d,p){if(bc()){if(d==="google"&&fc(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.")}else throw Error("It looks like you're using an in-app browser. To log in, please try again using an external browser.");let m=new Ur({provider:d,headless:!0});p&&m.addCaptchaToken(p);let C=await t.startAuthFlow(m).getAuthorizationUrl();C?.url&&window.location.assign(C.url)},async loginWithHeadlessOAuth(d){w(!0),t.startAuthFlow(new Ur(d));let p=Z.get(Ko),m=d.stateCode;if(p!==m)throw t.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:d.provider,storedStateCode:p??"",returnedStateCode:m??""}}),w(!1),new T("Unexpected auth flow. This may be a phishing attempt.");let C,E;if(a)try{({user:C}=await t.link()),J.current=d.provider}catch(H){throw U(D,"linkAccount","onError",H.privyErrorCode||"failed_to_link_account"),H}else try{({user:C,isNewUser:E}=await t.authenticate()),J.current=d.provider}catch(H){throw ee.current==="login"?U(D,"login","onError",H.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",H.privyErrorCode||"failed_to_link_account"),H}return c(C),v(E||!1),l(!0),w(!1),C??void 0},initLoginWithEmail:async(d,p)=>{let m=new go(d,p);t.startAuthFlow(m);try{J.current="email",await m.sendCodeEmail()}catch(C){throw ee.current==="login"?U(D,"login","onError",C.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",C.privyErrorCode||"failed_to_link_account"),C}},initUpdateEmail:async(d,p,m)=>{let C=new qa(d,p,m);t.startAuthFlow(C),await C.sendCodeEmail()},initLoginWithSms:async(d,p)=>{I({status:"sending-code"});let m=new en(d,p);t.startAuthFlow(m);try{J.current="sms",await m.sendSmsCode(),I({status:"awaiting-code-input"})}catch(C){throw I({status:"error",error:C}),ee.current==="login"?U(D,"login","onError",C.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",C.privyErrorCode||"failed_to_link_account"),C}},resendEmailCode:async()=>{await t.authFlow?.sendCodeEmail()},resendSmsCode:async()=>{await t.authFlow?.sendSmsCode()},loginWithCode:async d=>{if(I({status:"submitting-code"}),!n){let E=new Dr;throw I({status:"error",error:E}),E}if(t.authFlow instanceof go)t.authFlow.meta.emailCode=d.trim();else if(t.authFlow instanceof en)t.authFlow.meta.smsCode=d.trim();else{let E=new T("Must initialize a passwordless code flow first");throw I({status:"error",error:E}),E}let p=await be(),m,C;if(p&&t.sessionHasActiveToken())try{({user:m}=await t.link())}catch(E){throw I({status:"error",error:E}),U(D,"linkAccount","onError",E.privyErrorCode||"failed_to_link_account"),E}else try{({user:m,isNewUser:C}=await t.authenticate())}catch(E){throw I({status:"error",error:E}),U(D,"login","onError",E.privyErrorCode||"unknown_auth_error"),E}c(m||s||null),v(C||!1),l(!0),I({status:"done"})},refreshUser:async()=>{let d=await t.getAuthenticatedUser();return c(d),d},walletProxy:W,createAnalyticsEvent:({eventName:d,payload:p,timestamp:m})=>t.createAnalyticsEvent({eventName:d,payload:p,timestamp:m}),acceptTerms:async()=>{let d=await t.acceptTerms();return c(d),d},getUsdTokenPrice:d=>t.getUsdTokenPrice(d),recoverEmbeddedWallet:async()=>new Promise(async(d,p)=>{let m=s?.linkedAccounts.find(E=>E.type==="wallet"&&E.walletClientType==="privy"),C=await be();if(!C||!W||!m){p(new Error("Must have valid access token and Privy wallet to recover wallet"));return}pe(!0);try{await W.connect({accessToken:C,address:m.address}),d(!0)}catch(E){if(Xn(E)&&m.recoveryMethod==="privy")t.createAnalyticsEvent({eventName:"embedded_wallet_pinless_recovery_started",payload:{walletAddress:m.address}}),(await W.recover({address:m.address,accessToken:C})).address||p(new Error("Unable to recover wallet")),t.createAnalyticsEvent({eventName:"embedded_wallet_recovery_completed",payload:{walletAddress:m.address}}),d(!0);else if(Xn(E)&&m.recoveryMethod!=="privy"){X({recoverWallet:{privyWallet:m,onFailure:p,onSuccess:()=>d(!0)},recoveryOAuthStatus:{provider:m.recoveryMethod,action:"recover"}});let H=pl(m.recoveryMethod);ge(H)}else p(E)}}),getFiatOnRampConfig:Cr,setReadyToTrue:d=>{i(!0),Et?.(d)},updateWallets:()=>zo(),fundWallet:async(d,p)=>{let{signedUrl:m,externalTransactionId:C}=await Cr(d,p);X({fiatOnRampPrompt:{signedUrl:m},fiatOnRampStatus:{externalTransactionId:C}}),ge("FIAT_ON_RAMP_PROMPT_SCREEN")},requestFarcasterSignerStatus:async d=>{let p=await be(),m=s?.linkedAccounts.find(E=>E.type==="wallet"&&E.walletClientType==="privy");if(!p)throw new Error("Must have valid access token to connect with Farcaster");if(!W||!m)throw new Error("Must have an embedded wallet to use Farcaster signers");if(!s?.farcaster?.fid)throw new Error("Must have Farcaster account to use Farcaster signers");let C=await t.requestFarcasterSignerStatus(d);if(C.status==="approved"){let E=await t.getAuthenticatedUser();c(E||s||null)}return C}}))();m2=me.recoverEmbeddedWallet;let v2=oE(()=>({wallets:u,ready:ir&&Go}),[u,ir,Go]);return vr(ve.Provider,{value:Pn,children:vr(zc.Provider,{value:D,children:vr(ap.Provider,{value:v2,children:vr(Hm,{...L,children:c2(Vc.Provider,{value:me,children:[c2(Lm,{data:we,setModalData:X,setInitialScreen:x,initialScreen:g,authenticated:a,open:r,children:[e.children,!L.headless&&L.captchaEnabled&&n&&!a&&vr(Gc,{delayedExecution:!1}),vr(Kg,{theme:{...L.appearance.palette||{}}}),!L.render.standalone&&vr(wp,{open:r})]}),de&&ae?vr(s2,{appId:e.appId,appClientId:e.clientId,clientAnalyticsId:t.clientAnalyticsId,origin:t.apiUrl,mfaMethods:s?.mfaMethods,mfaPromise:It,mfaSubmitPromise:Ge,onLoad:V,onLoadFailed:()=>null}):null,L.loginMethods.telegram&&L.loginConfig.telegramAuthConfiguration&&vr(_r,{if:!0,children:vr(n2,{scriptHost:e.apiUrl||ki,botUsername:L.loginConfig.telegramAuthConfiguration.botName})})]})})})})})};import{useContext as lE}from"react";function cE(e){let{login:t}=lE(ve);return He("login",e),{login:t}}import{useContext as dE}from"react";function pE(e){let{logout:t}=dE(ve);return He("logout",e),{logout:t}}import{useCallback as f2,useEffect as uE}from"react";function mE(){let e=he(),t=Fs(),{initLoginWithHeadlessOAuth:r,loginWithHeadlessOAuth:o,isHeadlessOAuthLoading:n,ready:i,user:a}=F(),l=f2(async c=>{if(e.enabled&&e.status!=="success")throw new Tr(e.error,null,"captcha_failure");return r(c.provider,e.token)},[r,e]),s=f2(async()=>{let c=Li();if(a)return console.warn("Cannot login with OAuth when already logged in"),a;if(!c.inProgress)throw new Error("Cannot login with OAuth because no OAuth flow is in progress");if(!c.popupFlow)try{return await o(c)}catch(u){throw u}finally{Jo()}},[o]);return uE(()=>{let c=Li();i&&t&&c.inProgress&&c.headless&&!c.popupFlow&&s()},[i,t]),{initOAuth:l,loginWithOAuth:s,loading:n}}import{useCallback as h2}from"react";var fE=()=>{let e=he(),{initLoginWithEmail:t,loginWithCode:r}=F(),o=h2(async({email:i})=>{if(!i)throw new Error("Email required to send OTP code");return t(i)},[t]),n=h2(async({code:i})=>{if(e.enabled&&e.status==="error")throw new Tr(e.error,null,"captcha_failure");return r(i)},[r,e.status]);return{sendCode:o,loginWithCode:n}};import{useCallback as y2}from"react";var hE=()=>{let e=he(),{initLoginWithSms:t,loginWithCode:r,otpState:o}=F(),n=y2(async({phoneNumber:a})=>{if(!a)throw new Error("SMS required to send OTP code");return t(a)},[t]),i=y2(async({code:a})=>{if(e.enabled&&e.status!=="success")throw new Tr(e.error,null,"captcha_failure");return r(a)},[r,e.status]);return{sendCode:n,loginWithCode:i,state:o}};import{useContext as yE}from"react";function gE(e){let{linkEmail:t,linkPhone:r,linkWallet:o,linkGoogle:n,linkApple:i,linkTwitter:a,linkDiscord:l,linkGithub:s,linkLinkedIn:c,linkTiktok:u,linkSpotify:h,linkInstagram:f,linkTelegram:y,linkFarcaster:v}=yE(ve);return He("linkAccount",e),{linkEmail:t,linkPhone:r,linkWallet:o,linkGoogle:n,linkApple:i,linkTwitter:a,linkDiscord:l,linkGithub:s,linkLinkedIn:c,linkTiktok:u,linkSpotify:h,linkInstagram:f,linkFarcaster:v,linkTelegram:y}}import{useContext as vE}from"react";function CE(e){let{connectWallet:t}=vE(ve);return He("connectWallet",e),{connectWallet:t}}import{useContext as wE}from"react";function bE(e){let{createWallet:t}=wE(ve);return He("createWallet",e),{createWallet:t}}var EE=()=>{let{fundWallet:e}=F();return{fundWallet:e}};import{useContext as TE}from"react";function PE(e){let{sendTransaction:t}=TE(ve);return He("sendTransaction",e),{sendTransaction:t}}import{useContext as SE}from"react";function _E(e){let{setWalletPassword:t}=SE(ve);return He("setWalletPassword",e),{setWalletPassword:t}}import{useContext as xE}from"react";function kE(e){let{signMessage:t}=xE(ve);return He("signMessage",e),{signMessage:t}}import{useContext as AE}from"react";function RE(e){let{signTypedData:t}=AE(ve);return He("signTypedData",e),{signTypedData:t}}import{useContext as IE}from"react";var ME=()=>{let{isModalOpen:e}=IE(ve);return{isOpen:e}};import{useContext as WE}from"react";function LE(e){let{getAccessToken:t}=WE(ve);return He("accessToken",e),{getAccessToken:t}}function OE(){let{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:r}=F();return{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:r}}function NE(e,t){return{...e,rpcUrls:{...e.rpcUrls,privyWalletOverride:{http:[t]}}}}export{Fr as AsExternalProvider,Gc as Captcha,Vi as ConnectorManager,wp as LoginModal,zi as PrivyClient,aE as PrivyProvider,Oe as PrivyProxyProvider,Hi as SUPPORTED_CHAINS,Pc as VERSION,Ot as WalletConnector,NE as addRpcUrlOverrideToChain,ud as errorIndicatesMaxMfaRetries,ln as errorIndicatesMfaTimeout,cn as errorIndicatesMfaVerificationFailed,be as getAccessToken,CE as useConnectWallet,bE as useCreateWallet,OE as useExperimentalFarcasterSigner,EE as useFundWallet,gE as useLinkAccount,cE as useLogin,fE as useLoginWithEmail,mE as useLoginWithOAuth,hE as useLoginWithSms,pE as useLogout,ga as useMfa,Wr as useMfaEnrollment,ME as useModalStatus,F as usePrivy,qc as useRegisterMfaListener,PE as useSendTransaction,_E as useSetWalletPassword,kE as useSignMessage,RE as useSignTypedData,LE as useToken,ka as useWallets};
3037
+ `;import{useRef as o2,useEffect as qb}from"react";import{jsx as Kb}from"react/jsx-runtime";function $b({botUsername:e,scriptHost:t}){let r=document.createElement("script"),{origin:o}=new URL(t);return r.async=!0,r.src=`${o}/js/telegram-login.js`,r.setAttribute("data-telegram-login",e),r.setAttribute("data-request-access","write"),r.setAttribute("data-lang","en"),r}function n2(e){let t=o2(null),r=o2();return qb(()=>{r.current?.remove(),r.current=$b(e),t.current?.after(r.current)},[e]),Kb("div",{ref:t,hidden:!0})}import{useState as jb}from"react";import{useEffect as i2,useRef as a2}from"react";var mc=class{constructor(){this.callbacks={}}enqueue(t,r){this.callbacks[t]=r}dequeue(t,r){let o=this.callbacks[r];if(!o)throw new Error(`cannot dequeue ${t} event: no event found for id ${r}`);switch(delete this.callbacks[r],t){case"privy:iframe:ready":return o;case"privy:wallet:create":return o;case"privy:wallet:import":return o;case"privy:wallet:connect":return o;case"privy:wallet:recover":return o;case"privy:wallet:rpc":return o;case"privy:wallet:set-recovery-password":return o;case"privy:mfa:verify":return o;case"privy:mfa:init-enrollment":return o;case"privy:mfa:submit-enrollment":return o;case"privy:mfa:unenroll":return o;case"privy:mfa:clear":return o;case"privy:farcaster:init-signer":return o;case"privy:farcaster:sign":return o;default:throw new Error(`invalid wallet event type ${t}`)}}};async function Ho(e,t,r,o,n,i=!1){let a=i,l=async u=>{if(a&&t&&t.length>0){u===(i?0:1)?n("configureMfa","onMfaRequired",t):o.current?.reject(new De("missing_or_invalid_mfa","MFA verification failed, retry."));let h=await new Promise((f,y)=>{r.current={resolve:f,reject:y};let v=1e3*60*5;setTimeout(()=>{let g=new De("mfa_timeout","Timed out waiting for MFA code");o.current?.reject(g),y(g)},v)});return await e(h)}return await e()},s=4,c=null;for(let u=0;u<s;u++)try{c=await l(u),o.current?.resolve(void 0);break}catch(h){if(h.type==="missing_or_invalid_mfa")a=!0;else throw o.current?.resolve(void 0),h}if(c===null){let u=new De("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw o.current?.reject(u),u}return c}import{jsx as eE}from"react/jsx-runtime";var Yb=function(e){return()=>`id-${e++}`}(0);function Zb(e){return typeof e.event=="string"&&/^privy:.+/.test(e.event)}function Gt(e){return e.error!==void 0}var At=new mc,bp=new Map,Jb=(e,t)=>typeof t=="bigint"?t.toString():t,Qb=(e,t)=>`${e}${JSON.stringify(t,Jb)}`;function Vt(e,t,r,o){let n=r.contentWindow;if(!n)throw new Error("iframe not initialized");let i=Qb(e,t);if(e==="privy:wallet:create"){let l=bp.get(i);if(l)return l}let a=new Promise((l,s)=>{let c=Yb();At.enqueue(c,{resolve:l,reject:s}),n.postMessage({id:c,event:e,data:t},o)}).finally(()=>{bp.delete(i)});return bp.set(i,a),a}function Xb(e){switch(e.event){case"privy:iframe:ready":let t=At.dequeue(e.event,e.id);return Gt(e)?t.reject(new De(e.error.type,e.error.message)):t.resolve(e.data);case"privy:wallet:create":let r=At.dequeue(e.event,e.id);return Gt(e)?r.reject(new De(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallet:import":let o=At.dequeue(e.event,e.id);return Gt(e)?o.reject(new De(e.error.type,e.error.message)):o.resolve(e.data);case"privy:wallet:connect":let n=At.dequeue(e.event,e.id);return Gt(e)?n.reject(new De(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallet:recover":let i=At.dequeue(e.event,e.id);return Gt(e)?i.reject(new De(e.error.type,e.error.message)):i.resolve(e.data);case"privy:wallet:rpc":let a=At.dequeue(e.event,e.id);return Gt(e)?a.reject(new De(e.error.type,e.error.message)):a.resolve(e.data);case"privy:wallet:set-recovery-password":let l=At.dequeue(e.event,e.id);return Gt(e)?l.reject(new De(e.error.type,e.error.message)):l.resolve(e.data);case"privy:mfa:verify":let s=At.dequeue(e.event,e.id);return Gt(e)?s.reject(new De(e.error.type,e.error.message)):s.resolve(e.data);case"privy:mfa:init-enrollment":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:mfa:submit-enrollment":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:mfa:unenroll":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:mfa:clear":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:farcaster:init-signer":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}case"privy:farcaster:sign":{let c=At.dequeue(e.event,e.id);return Gt(e)?c.reject(new De(e.error.type,e.error.message)):c.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}function s2(e){let t=a2(null),r=a2(e.mfaMethods),o=Vs(),[n,i]=jb(!1);return i2(()=>{r.current=e.mfaMethods},[e.mfaMethods]),i2(()=>{if(!n)return;let a=t.current;if(!a)return;function l(f){f&&f.origin===e.origin&&Zb(f.data)&&Xb(f.data)}let s={create(f){return Vt("privy:wallet:create",f,a,e.origin)},import(f){return Vt("privy:wallet:import",f,a,e.origin)},connect(f){return Vt("privy:wallet:connect",f,a,e.origin)},recover(f){return Ho(y=>Vt("privy:wallet:recover",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},rpc(f){return Ho(y=>Vt("privy:wallet:rpc",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},setRecoveryPassword(f){return Ho(y=>Vt("privy:wallet:set-recovery-password",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},verifyMfa(f){return Ho(y=>Vt("privy:mfa:verify",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},initEnrollMfa(f){return Ho(y=>Vt("privy:mfa:init-enrollment",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},submitEnrollMfa(f){return Ho(y=>Vt("privy:mfa:submit-enrollment",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},unenrollMfa(f){return Ho(y=>Vt("privy:mfa:unenroll",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},clearMfa(f){return Vt("privy:mfa:clear",f,a,e.origin)},initFarcasterSigner(f){return Vt("privy:farcaster:init-signer",f,a,e.origin)},signFarcasterMessage(f){return Vt("privy:farcaster:sign",f,a,e.origin)}};window.addEventListener("message",l);let c=()=>e.onLoad(s),u=(...f)=>{console.warn("Privy iframe failed to load: ",...f),e.onLoadFailed()},h=new AbortController;return _i(()=>Vt("privy:iframe:ready",{},a,e.origin),{abortSignal:h.signal}).then(c,u),()=>{window.removeEventListener("message",l),h.abort()}},[n]),eE("iframe",{ref:t,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},onLoad:()=>i(!0),src:Za(e.origin,`/apps/${e.appId}/embedded-wallets`,{caid:e.clientAnalyticsId,client_id:e.appClientId})})}function fc(e){let t=e.toLowerCase();return["fbav","fban","instagram","snapchat"].some(o=>t.includes(o))}var tE="https://cdn.apple-cloudkit.com";async function Ep({url:e,popup:t,provider:r}){return t.location=e,new Promise((n,i)=>{function a(){t?.close(),window.removeEventListener("message",l)}function l(s){s.data&&(s.data.type==="PRIVY_OAUTH_RESPONSE"&&s.data.stateCode&&s.data.authorizationCode&&(n(s.data),a()),s.origin===tE&&s.data.ckSession&&(n({type:"PRIVY_OAUTH_RESPONSE",ckWebAuthToken:s.data.ckSession}),a()),s.data.type==="PRIVY_OAUTH_ERROR"&&(i(s.data.error),a()))}window.addEventListener("message",l)})}var l2=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});import{jsx as vr,jsxs as c2}from"react/jsx-runtime";var ho;function iE(e){return typeof e=="string"&&e.length===25}function be(){if(!ho){let e=Z.get($o);return Promise.resolve(e||null)}return ho.getAccessToken()}var d2,Qu=(e,t,r)=>d2(e,t,r),p2,Xu=(e,t)=>p2(e,t),u2,em=(e,t)=>u2(e,t),m2,tm=()=>m2(),aE=()=>{let t=new URLSearchParams(window.location.search).get("privy_token");if(!t)return;Z.put(Ai,t);let r=new URL(window.location.href);r.searchParams.delete("privy_token"),window.history.pushState({},"",r)},sE=({config:e,...t})=>{if(!iE(t.appId))throw new T("Cannot initialize the Privy provider with an invalid Privy app ID");ho||(ho=new zi({appId:t.appId,appClientId:t.clientId,apiUrl:t.apiUrl||ki}));let r=Object.assign({},e);return t.createPrivyWalletOnLogin!==void 0&&r.embeddedWallets?.createOnLogin===void 0&&(r.embeddedWallets||(r.embeddedWallets={}),r.embeddedWallets.createOnLogin=t.createPrivyWalletOnLogin?"users-without-wallets":"off"),t.createPrivyWalletOnLogin!==void 0&&e?.embeddedWallets?.createOnLogin&&console.warn("Both `createPrivyWalletOnLogin` and `config.embeddedWallets.createOnLogin` are set. `createPrivyWalletOnLogin` is deprecated and should be removed."),vr(Mm,{client:ho,clientConfig:r,legacyCreateEmbeddedWalletFlag:t.createPrivyWalletOnLogin,children:vr(lE,{...t,client:ho})})},lE=e=>{let t=e.client,[r,o]=Ze(!1),[n,i]=Ze(!1),[a,l]=Ze(!1),[s,c]=Ze(null),[u,h]=Ze([]),f=Pi(u),[y,v]=Ze(!1),[g,x]=Ze(null),[S,w]=Ze(!1),[_,A]=Ze({status:"disconnected",connectedWallet:null,connectError:null,connector:null,connectRetry:b}),[N,I]=Ze({status:"initial"}),[R,B]=Ze(null),[K,Y]=Ze(null),[W,V]=Ze(null),L=ft(),ae=Fs(),[de,pe]=Ze(!0),[we,X]=Ze({}),[Et,Je]=Ze(null),[Rt,et]=Ze(null),[ir,Ie]=Ze(!1),[qe,ar]=Ze(!1),It=Pi(null),Ge=Pi(null),D=Pi(zm),[Go,Pe]=Ze(!1);t.onStoreToken=d=>{d&&U(D,"accessToken","onAccessTokenGranted",d)},t.onDeleteToken=()=>{c(null),l(!1),U(D,"accessToken","onAccessTokenRemoved")};let J=Pi(null),ee=Pi(null),ge=d=>{x(d),setTimeout(()=>{o(!0)},15),t.createAnalyticsEvent({eventName:"modal_open",payload:{initialScreen:d}})},Ue=d=>{L.embeddedWallets.createOnLogin!=="off"&&pe(!0),ge(d)};Nr(()=>{let d=()=>{document.visibilityState==="hidden"&&t.createAnalyticsEvent({eventName:"page_hidden",options:{keepAlive:!0}})};return document.addEventListener("visibilitychange",d),()=>{document.removeEventListener("visibilitychange",d)}},[]),Nr(()=>{if(!s){t.connectors?.removeEmbeddedWalletConnector();return}let d=Me(s),p=Mc(s);if(d||t.connectors?.removeEmbeddedWalletConnector(),p||t.connectors?.removeImportedWalletConnector(),!t.connectors){console.debug("Failed to add embedded wallet connector: Client connectors not initialized");return}if(!W){console.debug("Failed to add embedded wallet connector: Wallet proxy not initialized");return}d&&t.connectors.addEmbeddedWalletConnector(W,d.address,L.defaultChain,e.appId),p&&t.connectors.addImportedWalletConnector(W,p.address,L.defaultChain,e.appId)},[W,s]),Nr(()=>{W&&Rt?.(W)},[W]),Nr(()=>{(async()=>{if(!L.customAuth?.enabled)return;pe(!0);let{getCustomAccessToken:p,isLoading:m}=L.customAuth;if(!(!n||m))try{let C=await p();if(!C&&a){await Pn.logout();return}if(!C||a)return;t.startAuthFlow(new Sn(C));let{user:E,isNewUser:H}=await t.authenticate();if(!E){await Pn.logout();return}c(E||null),v(H||!1),l(!0),ar(!0)}catch(C){console.warn(C),a&&await Pn.logout()}})()},[L.customAuth?.enabled,L.customAuth?.getCustomAccessToken,L.customAuth?.isLoading,n,a]),Nr(()=>{qe&&W&&s&&Lt(s,L.embeddedWallets.createOnLogin)&&(ar(!1),Na(s,xn).catch(console.error))},[qe&&W&&s]),Nr(()=>{async function d(){let p=hc();aE();let m=rE();B(m),t.initializeConnectorManager({walletConnectCloudProjectId:L.walletConnectCloudProjectId,rpcConfig:L.rpcConfig,chains:L.chains,defaultChain:L.defaultChain,store:m,walletList:L.appearance.walletList,shouldEnforceDefaultChainOnConnect:L.shouldEnforceDefaultChainOnConnect,externalWalletConfig:L.externalWallets,appName:L.name??"Privy"});let C;t.connectors?.on("connectorInitialized",()=>{C&&clearTimeout(C);let H=t.connectors.walletConnectors.length,G=t.connectors.walletConnectors.reduce((fe,$e)=>fe+($e.initialized?1:0),0);G===H?Pe(!0):C=setTimeout(()=>{console.debug({message:"Unable to initialize all expected connectors before timeout",initialized:G,expected:H}),Pe(!0)},1500)}),t.connectors?.initialize().then(()=>{yc()});let E=await t.getAuthenticatedUser();L.customAuth?.enabled||(l(!!E),E&&U(D,"login","onComplete",E,!1,!0,null,null),c(E)),p||me.setReadyToTrue(!!E),p&&(E?ee.current="link":ee.current="login")}!n&&ae&&d()},[t,Et,n,ae]),Nr(()=>{if(!n)return;if(!s){Ie(!0);return}if(!!!s.linkedAccounts.find(m=>m.type==="wallet"&&m.walletClientType==="privy")){Ie(!0);return}let p=!!u.find(m=>m.walletClientType==="privy");Ie(p)},[n,s,u]);let hc=()=>{let d=Li();if(d.inProgress&&d.popupFlow){if(window.opener.location.origin!==window.location.origin){window.opener.postMessage({type:"PRIVY_OAUTH_ERROR",error:"Origins between parent and child windows do not match."});return}window.opener.postMessage({type:"PRIVY_OAUTH_RESPONSE",stateCode:d.stateCode,authorizationCode:d.authorizationCode});return}return!d.inProgress||d.headless?!1:(t.startAuthFlow(new Ur(d)),Ue("AWAITING_OAUTH_SCREEN"),!0)},En=async(d,p,m,C)=>{let E=await t.connectors?.createWalletConnector(d,p)||null;Tn(E,p,m,C)};async function Tn(d,p,m,C){if(d)A({status:"disconnected",connectedWallet:null,connectError:null,connector:d,connectRetry:b});else return A({status:"disconnected",connectedWallet:null,connectError:new te("Unable to connect to wallet."),connector:null,connectRetry:b}),C?.(null,m);d instanceof Gr&&p&&await d.resetConnection(p),A({connector:d,status:"connecting",connectedWallet:null,connectError:null,connectRetry:()=>Tn(d,p,m,C)});try{let E=await d.connect({showPrompt:!0});if(L.shouldEnforceDefaultChainOnConnect&&!L.chains.find(H=>H.id===Number(E?.chainId))&&!(E?.connectorType==="wallet_connect_v2"&&E?.walletClientType==="metamask")&&!(E?.connectorType==="coinbase_wallet"&&L.externalWallets.coinbaseWallet.connectionOptions!=="eoaOnly")){A(H=>({...H,connector:d,status:"switching_to_supported_chain",connectedWallet:null,connectError:null,connectRetry:b}));try{await E?.switchChain(L.defaultChain.id),E&&(E.chainId=_n(qo(L.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${L.defaultChain.id}`)}}return A(H=>({...H,status:"connected",connectedWallet:E,connectError:null,connectRetry:b})),E&&U(D,"connectWallet","onSuccess",E),C?.(E,m)}catch(E){return E instanceof ze?(console.warn(E.cause?E.cause:E.message),U(D,"connectWallet","onError",E.privyErrorCode||"generic_connect_wallet_error")):(console.warn(E),U(D,"connectWallet","onError","unknown_connect_wallet_error")),A(H=>({...H,status:"disconnected",connectedWallet:null,connectError:E})),C?.(null,m)}}let Vo=async(d,p)=>{if(d===null)return;let m=new Xo(d,p);t.startAuthFlow(m)},yc=()=>{let d=new URLSearchParams(window.location.search),p=d.get("privy_connector"),m=d.get("privy_wallet_client");if(!p||!m)return;if(m==="phantom"&&!vo()&&Ue("LOGIN_FAILED_SCREEN"),!t.connectors)throw new T("Connector not initialized");ge("AWAITING_CONNECTION");let C=new URL(window.location.href);C.searchParams.delete("privy_connector"),C.searchParams.delete("privy_wallet_client"),window.history.pushState({},"",C),En(p,m,void 0,Vo)};Nr(()=>{n&&a&&s===null&&t.getAuthenticatedUser().then(c)},[n,a,s,t]);let Ve=()=>{if(!a)throw U(D,"linkAccount","onError","must_be_authenticated"),new T("User must be authenticated before linking an account.")},yo=()=>{Ve(),J.current="siwe",ee.current="link",ge("LINK_WALLET_SCREEN")},Qe=d=>{if(!a||!s)return!1;if(d.walletClientType==="privy")return!0;for(let p of s.linkedAccounts)if(p.type==="wallet"&&p.address===d.address&&p.walletClientType!=="privy")return!0;return!1},zt=async d=>{if(!t.connectors)throw new T("Connector not initialized");let p=t.connectors.findWalletConnector(d.connectorType,d.walletClientType)||null;if(A(m=>({...m,connector:p,status:"connected",connectedWallet:d,connectError:null,connectRetry:b})),L.captchaEnabled&&!a){let m={callback:C=>Vo(d,C),userIntentRequired:!1,onSuccessNavigateTo:"AWAITING_CONNECTION",onErrorNavigateTo:"ERROR_SCREEN"};X({captchaModalData:m}),Ue("CAPTCHA_SCREEN")}else await Vo(d),Ue("AWAITING_CONNECTION")},Cr=async(d,p)=>{if(!L.fiatOnRamp.enabled)throw new T("Fiat on-ramp is not enabled");if(!p||!p.provider||p.provider==="moonpay"){let{signedUrl:m,externalTransactionId:C}=await ey(t,d,p?.config??{},L.appearance.palette,L.fiatOnRamp.useSandbox);return{signedUrl:m,externalTransactionId:C}}else throw new T("Unsupported fund provider. Currently supported option is `moonpay`.")},zo=()=>{h(d=>{let p=t.connectors?.wallets.map(m=>({...m,linked:Qe(m),loginOrLink:async()=>{if(!await m.isConnected())throw new T("Wallet is not connected");if(m.connectorType==="embedded"&&m.walletClientType==="privy")throw new T("Cannot link or login with embedded wallet");zt(m)},fund:async C=>{let{signedUrl:E,externalTransactionId:H}=await Cr(m.address,C);X({fiatOnRampPrompt:{signedUrl:E},fiatOnRampStatus:{externalTransactionId:H}}),ge("FIAT_ON_RAMP_PROMPT_SCREEN")},unlink:async()=>{if(!a)throw new T("User is not authenticated.");if(m.connectorType==="embedded"&&m.walletClientType==="privy")throw new T("Cannot unlink an embedded wallet");let C=await t.unlinkWallet(m.address);c(C)}}))||[];return Cs(d,p)?d:p})};Nr(()=>{zo()},[s?.linkedAccounts,a,n]),Nr(()=>{if(n){if(!t.connectors)throw new T("Connector not initialized");zo(),t.connectors.on("walletsUpdated",zo)}},[n]);let to=()=>{ge(a?"CONNECT_ONLY_AUTHENTICATED_SCREEN":"CONNECT_ONLY_LANDING_SCREEN")};Nr(()=>{if(!u[0])return;let d=u[0],p=f.current.find(C=>C.address===d.address),m;if(d.walletClientType==="privy"?m=s?.linkedAccounts.find(C=>C.type==="wallet"&&C.address===d.address&&C.walletClientType==="privy"):m=s?.linkedAccounts.find(C=>C.type==="wallet"&&C.address===d.address&&C.walletClientType!=="privy"),!p&&m){let C=Object.assign({},s);C.wallet=m&&{address:m.address,chainType:m.chainType,chainId:m.chainId,walletClient:m.walletClient,walletClientType:m.walletClientType,connectorType:m.connectorType,imported:m.imported},c(C)}f.current=u},[u]);let Na=async(d,p)=>{if(Me(d))throw U(D,"createWallet","onError","embedded_wallet_already_exists"),new Error("Only one Privy wallet per user is currently allowed");let[C,E]=await Promise.all([me.initializeWalletProxy(p),be()]);if(!C&&L.customAuth?.enabled)throw U(D,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to connect to wallet proxy");if(!C||!E||L.embeddedWallets?.requireUserOwnedRecoveryOnCreate)return new Promise((H,G)=>{pe(!0),X({createWallet:{onSuccess:$e=>{U(D,"createWallet","onSuccess",$e),H($e)},onFailure:$e=>{U(D,"createWallet","onError","unknown_embedded_wallet_error"),G($e)},callAuthOnSuccessOnClose:!1}}),ge("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")});{await C.create({accessToken:E});let H=await me.refreshUser(),G=Me(H);if(!G)throw U(D,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");return U(D,"createWallet","onSuccess",G),G}},g2=d=>{if(!L.chains.map(p=>p.id).includes(d))throw new te(`Chain ID ${d} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,"unsupported_chain_id")},Pp=(d,p,m)=>new Promise(async(C,E)=>{if(!a||!s){U(D,"sendTransaction","onError","must_be_authenticated"),E(new Error("User must be authenticated before signing with a Privy wallet"));return}let H=d.from,G=H?s?.linkedAccounts.find(Se=>Se.type==="wallet"&&Se.walletClientType==="privy"&&Se.address===H):Me(s);if(!G){U(D,"sendTransaction","onError","embedded_wallet_not_found"),E(new Error("Must have a Privy wallet before signing"));return}pe(!0);let fe=t.connectors?.findWalletConnector("embedded","privy")?.proxyProvider,$e=d.chainId?Number(d.chainId):fe.chainId;g2($e);let mt=Object.assign({},d,{chainId:$e}),sr=async()=>{let Se=await be();if(!Se||!W){U(D,"sendTransaction","onError","embedded_wallet_not_found"),E(new Error("Must have valid access token and Privy wallet to send transaction"));return}try{if(!await me.recoverEmbeddedWallet()){U(D,"sendTransaction","onError","unknown_connect_wallet_error"),E(new Error("Unable to connect to wallet"));return}let wr=ro(mt.chainId,L.chains,L.rpcConfig,{appId:e.appId}),gc=await gi(G.address,mt,wr);if(L.embeddedWallets.noPromptOnSignature){let{totalGasEstimate:C2}=await yi(gc,wr),{hasSufficientFunds:w2}=await Xl(G.address,gc,C2,wr);if(!w2)throw new Be(new Kt("Wallet has insufficient funds for this transaction.",lt.E32603_DEFAULT_INTERNAL_ERROR.eipCode))}let _p=await Ql(Se,G.address,W,gc,wr);U(D,"sendTransaction","onSuccess",_p),C(_p)}catch(Da){U(D,"sendTransaction","onError","transaction_failure"),E(Da)}};if(L.embeddedWallets.noPromptOnSignature)p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config"),sr();else{let Se={transactionRequest:mt,onSuccess:wr=>{U(D,"sendTransaction","onSuccess",wr),C(wr)},onFailure:wr=>{U(D,"sendTransaction","onError","transaction_failure"),E(wr)},uiOptions:p||{},fundWalletConfig:m},Da={onCompleteNavigateTo:"EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN",onFailure:wr=>{U(D,"sendTransaction","onError","unknown_connect_wallet_error"),E(wr)}};X({connectWallet:Da,sendTransaction:Se}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}});function Sp(){return new Promise(async(d,p)=>{let m=await be();if(!m||!W)throw new Error("Must have valid access token to enroll in MFA");try{await W.verifyMfa({accessToken:m}),d()}catch(C){p(C)}})}let Mt=d=>{if(d==="passkey"){if(s&&s.linkedAccounts.filter(p=>p.type==="passkey").length>=5)throw U(D,"linkAccount","onError","cannot_link_more_of_type"),new T(`User already has an account of type ${d} linked.`)}else if(s?.[d])throw U(D,"linkAccount","onError","cannot_link_more_of_type"),new T(`User already has an account of type ${d} linked.`)},Pn={ready:n,authenticated:a,user:s,walletConnectors:t.connectors||null,connectWallet:to,importWallet:async({privateKey:d})=>{Ve();let[p,m]=await Promise.all([me.initializeWalletProxy(15e3),be()]);if(p&&m){await p.import({privateKey:d,accessToken:m});let C=await me.refreshUser(),E=Mc(C);if(!E)throw U(D,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to import wallet");return U(D,"createWallet","onSuccess",E),E}else throw new T("User is not authenticated")},linkWallet:yo,linkEmail:()=>{Ve(),Mt("email"),J.current="email",ee.current="link",ge("LINK_EMAIL_SCREEN")},linkPhone:()=>{Ve(),Mt("phone"),J.current="sms",ee.current="link",ge("LINK_PHONE_SCREEN")},linkGoogle:async()=>{Ve(),Mt("google"),ee.current="link",await me.initLoginWithOAuth("google")},linkTwitter:async()=>{Ve(),Mt("twitter"),ee.current="link",await me.initLoginWithOAuth("twitter")},linkDiscord:async()=>{Ve(),Mt("discord"),ee.current="link",await me.initLoginWithOAuth("discord")},linkGithub:async()=>{Ve(),Mt("github"),ee.current="link",await me.initLoginWithOAuth("github")},linkSpotify:async()=>{Ve(),Mt("spotify"),ee.current="link",await me.initLoginWithOAuth("spotify")},linkInstagram:async()=>{Ve(),Mt("instagram"),ee.current="link",await me.initLoginWithOAuth("instagram")},linkTiktok:async()=>{Ve(),Mt("tiktok"),ee.current="link",await me.initLoginWithOAuth("tiktok")},linkLinkedIn:async()=>{Ve(),Mt("linkedin"),ee.current="link",await me.initLoginWithOAuth("linkedin")},linkApple:async()=>{Ve(),Mt("apple"),ee.current="link",await me.initLoginWithOAuth("apple")},linkPasskey:async()=>{Ve(),Mt("passkey"),await me.initLinkWithPasskey(),ge("LINK_PASSKEY_SCREEN")},linkTelegram:async()=>{Ve(),Mt("telegram"),ee.current="link",J.current="telegram",await me.initLoginWithTelegram(),ge("TELEGRAM_AUTH_SCREEN")},linkFarcaster:async()=>{Ve(),Mt("farcaster"),await me.initLoginWithFarcaster(),ee.current="link",J.current="farcaster",ge("AWAITING_FARCASTER_CONNECTION")},updateEmail:()=>{if(Ve(),!s?.email)throw new T("User does not have an email linked to their account.");ee.current="link",J.current="email",ge("UPDATE_EMAIL_SCREEN")},login:async()=>{let d="Attempted to log in, but user is already logged in. Use a `link` helper instead.";if(!n){let p=await new Promise(m=>{Je(C=>m.bind(C))});if(Je(null),p){console.warn(d);return}}if(a){console.warn(d);return}ee.current="login",Ue("LANDING")},connectOrCreateWallet:async()=>{if(n||(await new Promise(d=>{Je(()=>d)}),Je(null)),a){console.warn("User must be unauthenticated to `connectOrCreateWallet`");return}if(u[0]){console.warn("User must have no connected wallets to `connectOrCreateWallet`");return}Ue("CONNECT_OR_CREATE")},logout:async()=>{if(await t.logout(),s&&W)try{await W.clearMfa({userId:s.id})}catch{}c(null),l(!1),x(null),U(D,"logout","onSuccess"),ee.current=null,J.current=null,o(!1),Z.del(Ri)},getAccessToken:()=>t.getAccessToken(),getEthereumProvider:()=>{if(!s||!s.wallet)return new Oe;let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(C=>C.address===d?.address));return!d||!p?new Oe:p.proxyProvider},getEthersProvider:()=>{if(!s||!s.wallet)return new Tp(new Fr(new Oe));let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(C=>C.address===d?.address));return!d||!p?new Tp(new Fr(new Oe)):new Tp(new Fr(p.proxyProvider))},getWeb3jsProvider:()=>{if(!s||!s.wallet)return new bo(new Oe);let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(C=>C.address===d?.address));return!d||!p?new bo(new Oe):new bo(p.proxyProvider)},unlinkWallet:async d=>{let p=await t.unlinkWallet(d);return c(p),p},unlinkEmail:async d=>{let p=await t.unlinkEmail(d);return c(p),p},unlinkPhone:async d=>{let p=await t.unlinkPhone(d);return c(p),p},unlinkGoogle:async d=>{let p=await t.unlinkOAuth("google",d);return c(p),p},unlinkTwitter:async d=>{let p=await t.unlinkOAuth("twitter",d);return c(p),p},unlinkDiscord:async d=>{let p=await t.unlinkOAuth("discord",d);return c(p),p},unlinkGithub:async d=>{let p=await t.unlinkOAuth("github",d);return c(p),p},unlinkSpotify:async d=>{let p=await t.unlinkOAuth("spotify",d);return c(p),p},unlinkInstagram:async d=>{let p=await t.unlinkOAuth("instagram",d);return c(p),p},unlinkTiktok:async d=>{let p=await t.unlinkOAuth("tiktok",d);return c(p),p},unlinkLinkedIn:async d=>{let p=await t.unlinkOAuth("linkedin",d);return c(p),p},unlinkApple:async d=>{let p=await t.unlinkOAuth("apple",d);return c(p),p},unlinkFarcaster:async d=>{let p=await t.unlinkFarcaster(d);return c(p),p},unlinkTelegram:async d=>{let p=await t.unlinkTelegram(d);return c(p),p},unlinkPasskey:async d=>{let p=await t.unlinkPasskey(d);return c(p),p},setActiveWallet:async d=>{let p=u.find(C=>Ti(C.address)===Ti(d)),m=s?.linkedAccounts.find(C=>C.type==="wallet"&&Ti(C.address)===Ti(d));if(!p||!await p.isConnected())Y(d),yo();else if(!p.linked)p.loginOrLink();else{let C=Object.assign({},s);C.wallet=m&&{address:m.address,chainType:m.chainType,chainId:m.chainId,walletClient:m.walletClient,walletClientType:m.walletClientType,connectorType:m.connectorType,imported:m.imported},c(C)}},forkSession:()=>t.forkSession(),createWallet:async()=>{if(!a||!s)throw U(D,"createWallet","onError","must_be_authenticated"),new Error("User must be authenticated before creating a Privy wallet");return Na(s,15e3)},setWalletPassword:async()=>{if(!a||!s)throw U(D,"setWalletPassword","onError","must_be_authenticated"),new Error("User must be authenticated before adding password to Privy wallet");let d=Me(s);if(!d||!W)throw U(D,"setWalletPassword","onError","embedded_wallet_not_found"),new Error("Must have a Privy wallet to add a password");if(["google-drive","icloud"].includes(d.recoveryMethod))throw U(D,"setWalletPassword","onError","embedded_wallet_recovery_already_exists"),new Error("Cannot set password. Embedded wallet is set to recover using a cloud provider.");try{await Sp()}catch(p){throw U(D,"setWalletPassword","onError","missing_or_invalid_mfa"),p}return new Promise((p,m)=>{pe(!0);let C={onSuccess:G=>{U(D,"setWalletPassword","onSuccess",G),p(G)},onFailure:G=>{U(D,"setWalletPassword","onError","user_exited_set_password_flow"),m(G)},callAuthOnSuccessOnClose:!1},H={onCompleteNavigateTo:d.recoveryMethod==="user-passcode"?"EMBEDDED_WALLET_PASSWORD_UPDATE_SCREEN":"EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN",onFailure:G=>{U(D,"setWalletPassword","onError","unknown_connect_wallet_error"),m(G)}};X({setWalletPassword:C,createWallet:C,connectWallet:H}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")})},signMessage:(d,p,m)=>new Promise(async(C,E)=>{if(!a||!s){U(D,"signMessage","onError","must_be_authenticated"),E(new Error("User must be authenticated before signing with a Privy wallet"));return}let H=m?s?.linkedAccounts.find(fe=>fe.type==="wallet"&&fe.walletClientType==="privy"&&Ti(fe.address)===Ti(m)):Me(s);if(!H){U(D,"signMessage","onError","embedded_wallet_not_found"),E(new Error("Must have a Privy wallet before signing"));return}if(typeof d!="string"||d.length<1){U(D,"signMessage","onError","invalid_message"),E(new Error("Message must be a non-empty string"));return}pe(!0);let G=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let fe=await be();if(!W||!fe)throw new Error("Unable to connect to wallet");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_started",payload:{walletAddress:H.address}});let{response:mt}=await W.rpc({accessToken:fe,address:H.address,request:{method:"personal_sign",params:[d,H.address]}}),sr=mt.data;return t.createAnalyticsEvent({eventName:"embedded_wallet_sign_message_completed",payload:{walletAddress:H.address}}),sr};if(L.embeddedWallets.noPromptOnSignature){p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let fe=await G();U(D,"signMessage","onSuccess",fe),C(fe)}catch(fe){U(D,"signMessage","onError","unable_to_sign"),E(fe??new Be("Unable to sign message"))}}else{let mt={method:"personal_sign",data:d,confirmAndSign:G,onSuccess:Se=>{U(D,"signMessage","onSuccess",Se),C(Se)},onFailure:Se=>{U(D,"signMessage","onError","unable_to_sign"),E(Se)},uiOptions:p||{}},sr={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:Se=>{U(D,"signMessage","onError","unknown_connect_wallet_error"),E(Se)},address:H.address};X({signMessage:mt,connectWallet:sr}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),signTypedData:(d,p)=>new Promise(async(m,C)=>{if(!a||!s){U(D,"signTypedData","onError","must_be_authenticated"),C(new Error("User must be authenticated before signing with a Privy wallet"));return}let E=Me(s);if(!E){U(D,"signTypedData","onError","embedded_wallet_not_found"),C(new Error("Must have a Privy wallet before signing"));return}pe(!0);let H=Ja(d),G=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let fe=await be();if(!W||!fe)throw new Error("Unable to connect to wallet");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_started",payload:{walletAddress:E.address}});let{response:mt}=await W.rpc({accessToken:fe,address:E.address,request:{method:"eth_signTypedData_v4",params:[E.address,H]}}),sr=mt.data;return t.createAnalyticsEvent({eventName:"embedded_wallet_sign_typed_data_completed",payload:{walletAddress:E.address}}),sr};if(L.embeddedWallets.noPromptOnSignature||(L.legacyWalletUiConfig??!1)){p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let fe=await G();U(D,"signTypedData","onSuccess",fe),m(fe)}catch(fe){U(D,"signTypedData","onError","unable_to_sign"),C(fe??new Be("Unable to sign message"))}}else{let mt={method:"eth_signTypedData_v4",data:H,confirmAndSign:G,onSuccess:Se=>{U(D,"signTypedData","onSuccess",Se),m(Se)},onFailure:Se=>{U(D,"signTypedData","onError","unable_to_sign"),C(Se)},uiOptions:p||{}},sr={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:Se=>{U(D,"signMessage","onError","unknown_connect_wallet_error"),C(Se)}};X({signMessage:mt,connectWallet:sr}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),sendTransaction:async(d,p,m)=>{let E=await(await Pp(d,p,m)).wait();return ec(E)},exportWallet:()=>new Promise(async(d,p)=>{if(!a||!s){p(new Error("User must be authenticated before exporting their Privy wallet"));return}if(!Me(s)){p(new Error("Must have a Privy wallet before exporting"));return}pe(!0);let C={onCompleteNavigateTo:"EMBEDDED_WALLET_KEY_EXPORT_SCREEN",onFailure:p,shouldForceMFA:!0};if(X(we),!await be()||!W){p(new Error("Must have valid access token to enroll in MFA"));return}if(!W){p(new Error("Must have a Privy wallet before exporting"));return}let H={appId:e.appId,appClientId:e.clientId,origin:t.apiUrl,onSuccess:d,onFailure:p};X({keyExport:H,connectWallet:C}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}),promptMfa:Sp,async init(d){switch(d){case"sms":await t.initMfaSmsVerification();return;case"passkey":return await t.initMfaPasskeyVerification();case"totp":return;default:throw new Error(`Unsupported MFA method: ${d}`)}},async submit(d,p){switch(d){case"totp":case"sms":if(typeof p!="string")throw new T("Invalid MFA code");It.current?.resolve({mfaMethod:d,mfaCode:p,relyingParty:window.origin}),await new Promise((H,G)=>{Ge.current={resolve:H,reject:G}});break;case"passkey":if(typeof p=="string")throw new T("Invalid authenticator response");let C=await(await import("@simplewebauthn/browser")).startAuthentication(p),E=l2(C);It.current?.resolve({mfaMethod:d,mfaCode:E,relyingParty:window.origin}),await new Promise((H,G)=>{Ge.current={resolve:H,reject:G}});break;default:throw It.current?.reject(new T("Unsupported MFA method")),new T(`Unsupported MFA method: ${d}`)}},cancel(){It.current?.reject(new T("MFA canceled"))},async initEnrollmentWithSms(d){let p=await be();if(!p||!W)throw new Error("Must have valid access token to enroll in MFA");await W.initEnrollMfa({method:"sms",accessToken:p,phoneNumber:d.phoneNumber})},enrollInMfa(d){return new Promise((p,m)=>{if(!d){me.closePrivyModal(),p();return}L.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."),X({mfaEnrollmentFlow:{mfaMethods:L.mfa.methods,onSuccess:p,onFailure:m}}),ge("MFA_ENROLLMENT_FLOW_SCREEN")})},async initEnrollmentWithTotp(){let d=await be();if(!d||!W)throw new Error("Must have valid access token to enroll in MFA");let p=await W.initEnrollMfa({method:"totp",accessToken:d});return{secret:p.secret,authUrl:p.authUrl}},async submitEnrollmentWithSms(d){let p=await be();if(!p||!W)throw new Error("Must have valid access token to enroll in MFA");await W.submitEnrollMfa({method:"sms",accessToken:p,phoneNumber:d.phoneNumber,code:d.mfaCode});let m=await t.getAuthenticatedUser();c(m)},async submitEnrollmentWithTotp(d){let p=await be();if(!p||!W)throw new Error("Must have valid access token to enroll in MFA");await W.submitEnrollMfa({method:"totp",accessToken:p,code:d.mfaCode});let m=await t.getAuthenticatedUser();c(m)},async initEnrollmentWithPasskey(){},async submitEnrollmentWithPasskey({credentialIds:d}){let p=await be();if(!p||!W)throw new Error("Must have valid access token to enroll in MFA");await W.submitEnrollMfa({method:"passkey",accessToken:p,credentialIds:d});let m=await t.getAuthenticatedUser();c(m)},async unenroll(d){let p=await be();if(!p||!W)throw new Error("Must have valid access token to remove MFA");d==="passkey"?await W.submitEnrollMfa({method:"passkey",accessToken:p,credentialIds:[]}):await W.unenrollMfa({method:d,accessToken:p});let m=await t.getAuthenticatedUser();c(m)},requestFarcasterSignerFromWarpcast:async()=>{let d=await be(),p=s?.linkedAccounts.find(E=>E.type==="wallet"&&E.walletClientType==="privy");if(!d)throw new Error("Must have valid access token to connect with Farcaster");if(!W||!p)throw new Error("Must have an embedded wallet to use Farcaster signers");if(!s?.farcaster?.fid)throw new Error("Must have Farcaster account to use Farcaster signers");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");let C=await W.initFarcasterSigner({address:p.address,hdWalletIndex:null,accessToken:d,mfaCode:null,mfaMethod:null,relyingParty:window.origin});if(C.status==="approved"){let E=await t.getAuthenticatedUser();c(E||s||null)}X({farcasterSigner:C}),ge("AWAITING_FARCASTER_SIGNER")},getFarcasterSignerPublicKey:async()=>{let d=await be(),p=s?.linkedAccounts.find(E=>E.type==="wallet"&&E.walletClientType==="privy");if(!d)throw new Error("Must have valid access token to connect with Farcaster");if(!W||!p)throw new Error("Must have an embedded wallet to use Farcaster signers");if(!s?.farcaster?.fid)throw new Error("Must have Farcaster account to use Farcaster signers");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");if(!s.farcaster?.signerPublicKey)throw new Error("Must have a Farcaster signer public key to sign");return(E=>Uint8Array.from(E.match(/.{1,2}/g).map(H=>parseInt(H,16))))(s.farcaster.signerPublicKey.slice(2))},signFarcasterMessage:async d=>{let p=await be(),m=s?.linkedAccounts.find(G=>G.type==="wallet"&&G.walletClientType==="privy");if(!p)throw new Error("Must have valid access token to connect with Farcaster");if(!W||!m)throw new Error("Must have an embedded wallet to use Farcaster signers");if(!s?.farcaster?.fid)throw new Error("Must have Farcaster account to use Farcaster signers");if(!await me.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");if(!s.farcaster?.signerPublicKey)throw new Error("Must have a Farcaster signer public key to sign");let E=await import("@simplewebauthn/browser"),H=await W.signFarcasterMessage({address:m.address,hdWalletIndex:null,accessToken:p,mfaCode:null,mfaMethod:null,payload:{hash:E.bufferToBase64URLString(d)},fid:BigInt(s.farcaster.fid),relyingParty:window.origin});return new Uint8Array(E.base64URLStringToBuffer(H.signature))},isHeadlessOAuthLoading:S,loginWithCode(d){return me.loginWithCode(d)},initLoginWithEmail(d){return me.initLoginWithEmail(d)},initLoginWithSms(d){return me.initLoginWithSms(d)},otpState:N,fundWallet(d,p){return me.fundWallet(d,p)},initLoginWithHeadlessOAuth(d,p){return me.initLoginWithHeadlessOAuth(d,p)},loginWithHeadlessOAuth(d){return me.loginWithHeadlessOAuth(d)},isModalOpen:r,mfaMethods:L.mfa.methods};d2=Pn.signMessage,p2=Pn.signTypedData,u2=async(...d)=>{let p=await Pp(...d);return L.embeddedWallets.waitForTransactionConfirmation&&await p.wait(),p};let me=(()=>({isNewUserThisSession:y,linkingHint:K,pendingTransaction:null,walletConnectionStatus:_,mipdStore:R,connectors:t.connectors?.walletConnectors??[],rpcConfig:L.rpcConfig,chains:L.chains,appId:e.appId,showFiatPrices:L.embeddedWallets.priceDisplay.primary!=="native-token",clientAnalyticsId:t.clientAnalyticsId,nativeTokenSymbolForChainId:d=>L.chains.find(p=>p.id===Number(d))?.nativeCurrency.symbol,initializeWalletProxy:async d=>{if(W)return W;let p=new Promise(E=>{et(()=>H=>E(H))}),m=new Promise(E=>setTimeout(()=>E(null),d)),C=await Promise.race([p,m]);return et(null),C},getAuthFlow:()=>t.authFlow,getAuthMeta:()=>t.authFlow?.meta,closePrivyModal:(d={shouldCallAuthOnSuccess:!0,isSuccess:!1})=>{let p=n&&a&&s,m;p&&J.current&&(m=s?.linkedAccounts.filter(C=>C.latestVerifiedAt!==null&&!(C.type==="wallet"&&C.walletClientType==="privy")).sort((C,E)=>E.latestVerifiedAt.getTime()-C.latestVerifiedAt.getTime())[0]),ee.current==="login"&&J.current?d.shouldCallAuthOnSuccess&&p?(U(D,"login","onComplete",s,y,!1,J.current,m??null),e.onSuccess?.(s,y)):U(D,"login","onError","exited_auth_flow"):ee.current==="link"&&J.current&&m&&(d.isSuccess&&p?U(D,"linkAccount","onSuccess",s,J.current,m):U(D,"linkAccount","onError","exited_link_flow")),Y(null),ee.current=null,J.current=null,v(!1),o(!1),setTimeout(()=>{t.authFlow=void 0},200),t.createAnalyticsEvent({eventName:"modal_closed"})},openPrivyModal:ge,connectWallet:Tn,initLoginWithWallet:async(d,p)=>{J.current="siwe",Vo(d,p)},loginWithWallet:async()=>{if(!n)throw new Dr;if(!(t.authFlow instanceof Xo))throw new T("Must initialize SIWE flow first.");let d,p;if(a)try{({user:d}=await t.link()),J.current="siwe"}catch(m){throw U(D,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{({user:d,isNewUser:p}=await t.authenticate()),J.current="siwe"}catch(m){throw U(D,"login","onError",m.privyErrorCode||"generic_connect_wallet_error"),m}c(d||s||null),v(p||!1),l(!0)},initLoginWithFarcaster:async d=>{let p=new xi(d);t.startAuthFlow(p);try{J.current="farcaster",await p.initializeFarcasterConnect()}catch(m){throw ee.current==="login"?U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",m.privyErrorCode||"unknown_auth_error"),m}},loginWithFarcaster:async()=>{if(!n)throw new Dr;if(!(t.authFlow instanceof xi))throw new T("Must initialize Farcaster flow first.");let d,p;if(a)try{({user:d}=await t.link()),J.current="farcaster"}catch(m){throw U(D,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{({user:d,isNewUser:p}=await t.authenticate()),J.current="farcaster"}catch(m){throw U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"),m}c(d||null),v(p||!1),l(!0)},async initLoginWithOAuth(d,p){if(J.current=d,bc()){if(d==="google"&&fc(window.navigator.userAgent)){Ue("IN_APP_BROWSER_LOGIN_NOT_POSSIBLE");return}}else{Ue("IN_APP_BROWSER_LOGIN_NOT_POSSIBLE");return}Z.del(Yo);let m=new Ur({provider:d});p&&m.addCaptchaToken(p),t.startAuthFlow(m);let C=await t.authFlow.getAuthorizationUrl();C&&C.url&&(d==="twitter"&&nE&&(C.url=C.url.replace("x.com","twitter.com")),window.location.assign(C.url))},async initLoginWithTelegram(d){if(!n)throw new Dr;J.current="telegram";let p=new Oi(d);t.startAuthFlow(p),t.authFlow.meta.telegramAuthResult=await new Promise((m,C)=>{if(!L.loginConfig.telegramAuthConfiguration)return C("Telegram Auth configuration is not loaded");if(!window.Telegram)return C("Telegram was not initialized");window.Telegram.Login.auth({bot_id:L.loginConfig.telegramAuthConfiguration.botId,request_access:!0},E=>E?m(E):C("Telegram auth failed or was canceled by the client"))})},async loginWithTelegram(){if(!n)throw new Dr;if(!(t.authFlow instanceof Oi))throw new T("Must initialize Telegram flow before calling loginWithTelegram");let d,p;if(a)try{({user:d}=await t.link()),J.current="telegram"}catch(m){throw U(D,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{let m=await t.authenticate();d=m.user,p=m.isNewUser,J.current="telegram"}catch(m){throw ee.current==="login"?U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}c(d),v(p||!1),l(!0)},async recoveryOAuthFlow(d,p,m){let C,E;function H(G){if(!G)throw t.createAnalyticsEvent({eventName:"recovery_oauth_error",payload:{error:"Unable to open recovery OAuth popup",provider:d}}),new T("Recovery OAuth failed")}switch(d){case"google-drive":{let{url:G,codeVerifier:fe,stateCode:$e}=await md({api:ho.api,provider:d});H(G);let mt,sr;try{let Se=await Ep({url:G,popup:m,provider:d});if(mt=Se.stateCode,sr=Se.authorizationCode,mt!==$e)throw t.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:d,storedStateCode:$e??"",returnedStateCode:mt??""}}),new T("Unexpected auth flow. This may be a phishing attempt.")}catch(Se){throw t.createAnalyticsEvent({eventName:"recovery_oauth_error",payload:{error:Se.toString(),provider:d}}),new T("Recovery OAuth failed")}[C,E]=await Promise.all([be(),qf({api:ho.api,provider:d,codeVerifier:fe,stateCode:mt,authorizationCode:sr})]);break}case"icloud":{let{url:G}=await md({api:ho.api,provider:d});H(G);let{ckWebAuthToken:fe}=await Ep({url:G,popup:m,provider:d});E=fe,C=await be();break}}if(!W)throw new T("Cannot connect to wallet proxy");switch(p){case"recover":let G=we.recoverWallet?.privyWallet?.address;if(!G)throw new T("Recovery OAuth failed");t.createAnalyticsEvent({eventName:"embedded_wallet_recovery_started",payload:{walletAddress:G,recoveryMethod:d}}),await W.recover({address:G,accessToken:C,recoveryAccessToken:E,recoveryMethod:d}),t.createAnalyticsEvent({eventName:"embedded_wallet_recovery_completed",payload:{walletAddress:G,recoveryMethod:d}});break;case"create-wallet":t.createAnalyticsEvent({eventName:"embedded_wallet_creation_started"}),await W.create({accessToken:C,recoveryAccessToken:E,recoveryMethod:d});let fe=await me.refreshUser(),$e=Me(fe);if(!$e)throw U(D,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");t.createAnalyticsEvent({eventName:"embedded_wallet_creation_completed",payload:{walletAddress:$e.address}}),U(D,"createWallet","onSuccess",$e);break;default:throw new T("Unsupported recovery action")}},async loginWithOAuth(d){if(!(t.authFlow instanceof Ur))throw new T("Must initialize OAuth flow before calling loginWithOAuth");let p=Z.get(Ko),m=t.authFlow.meta.stateCode;if(p!==m)throw t.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:d,storedStateCode:p??"",returnedStateCode:m??""}}),new T("Unexpected auth flow. This may be a phishing attempt.");let C,E,H;if(a)try{let G=await t.link();C=G.user,H=G.oAuthProviderTokens,J.current=d}catch(G){throw U(D,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}else try{let G=await t.authenticate();C=G.user,E=G.isNewUser,H=G.oAuthProviderTokens,J.current=d}catch(G){throw ee.current==="login"?U(D,"login","onError",G.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}return c(C),v(E||!1),l(!0),H},async initLoginWithPasskey(d){let p=new Qo(d);t.startAuthFlow(p),ee.current="login";try{J.current="passkey",await p.initAuthenticationFlow()}catch(m){throw U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"),m}},async loginWithPasskey(){if(!n)throw new Dr;if(!(t.authFlow instanceof Qo))throw new T("Must initialize Passkey flow first.");if(J.current!=="passkey")throw new T("Must init login with Passkey flow first.");let d,p;try{J.current="passkey",{user:d,isNewUser:p}=await t.authenticate()}catch(m){throw U(D,"login","onError",m.privyErrorCode||"unknown_auth_error"),m}c(d),v(p||!1),l(!0)},async initLinkWithPasskey(d){let p=new Qo(d);t.startAuthFlow(p),ee.current="link",J.current="passkey";try{await p.initLinkFlow()}catch(m){throw U(D,"linkAccount","onError",m.privyErrorCode||"unknown_auth_error"),m}},async linkWithPasskey(){if(!n)throw new Dr;if(!(t.authFlow instanceof Qo))throw new T("Must initialize Passkey flow first.");if(J.current!=="passkey")throw new T("Must init login with Passkey flow first.");let d;try{J.current="passkey",{user:d}=await t.link()}catch(p){throw U(D,"linkAccount","onError",p.privyErrorCode||"failed_to_link_account"),p}return c(d||s||null),d},async initLoginWithHeadlessOAuth(d,p){if(bc()){if(d==="google"&&fc(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.")}else throw Error("It looks like you're using an in-app browser. To log in, please try again using an external browser.");let m=new Ur({provider:d,headless:!0});p&&m.addCaptchaToken(p);let C=await t.startAuthFlow(m).getAuthorizationUrl();C?.url&&window.location.assign(C.url)},async loginWithHeadlessOAuth(d){w(!0),t.startAuthFlow(new Ur(d));let p=Z.get(Ko),m=d.stateCode;if(p!==m)throw t.createAnalyticsEvent({eventName:"possible_phishing_attempt",payload:{provider:d.provider,storedStateCode:p??"",returnedStateCode:m??""}}),w(!1),new T("Unexpected auth flow. This may be a phishing attempt.");let C,E;if(a)try{({user:C}=await t.link()),J.current=d.provider}catch(H){throw U(D,"linkAccount","onError",H.privyErrorCode||"failed_to_link_account"),H}else try{({user:C,isNewUser:E}=await t.authenticate()),J.current=d.provider}catch(H){throw ee.current==="login"?U(D,"login","onError",H.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",H.privyErrorCode||"failed_to_link_account"),H}return c(C),v(E||!1),l(!0),w(!1),C??void 0},initLoginWithEmail:async(d,p)=>{let m=new go(d,p);t.startAuthFlow(m);try{J.current="email",await m.sendCodeEmail()}catch(C){throw ee.current==="login"?U(D,"login","onError",C.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",C.privyErrorCode||"failed_to_link_account"),C}},initUpdateEmail:async(d,p,m)=>{let C=new qa(d,p,m);t.startAuthFlow(C),await C.sendCodeEmail()},initLoginWithSms:async(d,p)=>{I({status:"sending-code"});let m=new en(d,p);t.startAuthFlow(m);try{J.current="sms",await m.sendSmsCode(),I({status:"awaiting-code-input"})}catch(C){throw I({status:"error",error:C}),ee.current==="login"?U(D,"login","onError",C.privyErrorCode||"unknown_auth_error"):ee.current==="link"&&U(D,"linkAccount","onError",C.privyErrorCode||"failed_to_link_account"),C}},resendEmailCode:async()=>{await t.authFlow?.sendCodeEmail()},resendSmsCode:async()=>{await t.authFlow?.sendSmsCode()},loginWithCode:async d=>{if(I({status:"submitting-code"}),!n){let E=new Dr;throw I({status:"error",error:E}),E}if(t.authFlow instanceof go)t.authFlow.meta.emailCode=d.trim();else if(t.authFlow instanceof en)t.authFlow.meta.smsCode=d.trim();else{let E=new T("Must initialize a passwordless code flow first");throw I({status:"error",error:E}),E}let p=await be(),m,C;if(p&&t.sessionHasActiveToken())try{({user:m}=await t.link())}catch(E){throw I({status:"error",error:E}),U(D,"linkAccount","onError",E.privyErrorCode||"failed_to_link_account"),E}else try{({user:m,isNewUser:C}=await t.authenticate())}catch(E){throw I({status:"error",error:E}),U(D,"login","onError",E.privyErrorCode||"unknown_auth_error"),E}c(m||s||null),v(C||!1),l(!0),I({status:"done"})},refreshUser:async()=>{let d=await t.getAuthenticatedUser();return c(d),d},walletProxy:W,createAnalyticsEvent:({eventName:d,payload:p,timestamp:m})=>t.createAnalyticsEvent({eventName:d,payload:p,timestamp:m}),acceptTerms:async()=>{let d=await t.acceptTerms();return c(d),d},getUsdTokenPrice:d=>t.getUsdTokenPrice(d),recoverEmbeddedWallet:async()=>new Promise(async(d,p)=>{let m=s?.linkedAccounts.find(E=>E.type==="wallet"&&E.walletClientType==="privy"),C=await be();if(!C||!W||!m){p(new Error("Must have valid access token and Privy wallet to recover wallet"));return}pe(!0);try{await W.connect({accessToken:C,address:m.address}),d(!0)}catch(E){if(Xn(E)&&m.recoveryMethod==="privy")t.createAnalyticsEvent({eventName:"embedded_wallet_pinless_recovery_started",payload:{walletAddress:m.address}}),(await W.recover({address:m.address,accessToken:C})).address||p(new Error("Unable to recover wallet")),t.createAnalyticsEvent({eventName:"embedded_wallet_recovery_completed",payload:{walletAddress:m.address}}),d(!0);else if(Xn(E)&&m.recoveryMethod!=="privy"){X({recoverWallet:{privyWallet:m,onFailure:p,onSuccess:()=>d(!0)},recoveryOAuthStatus:{provider:m.recoveryMethod,action:"recover"}});let H=pl(m.recoveryMethod);ge(H)}else p(E)}}),getFiatOnRampConfig:Cr,setReadyToTrue:d=>{i(!0),Et?.(d)},updateWallets:()=>zo(),fundWallet:async(d,p)=>{let{signedUrl:m,externalTransactionId:C}=await Cr(d,p);X({fiatOnRampPrompt:{signedUrl:m},fiatOnRampStatus:{externalTransactionId:C}}),ge("FIAT_ON_RAMP_PROMPT_SCREEN")},requestFarcasterSignerStatus:async d=>{let p=await be(),m=s?.linkedAccounts.find(E=>E.type==="wallet"&&E.walletClientType==="privy");if(!p)throw new Error("Must have valid access token to connect with Farcaster");if(!W||!m)throw new Error("Must have an embedded wallet to use Farcaster signers");if(!s?.farcaster?.fid)throw new Error("Must have Farcaster account to use Farcaster signers");let C=await t.requestFarcasterSignerStatus(d);if(C.status==="approved"){let E=await t.getAuthenticatedUser();c(E||s||null)}return C}}))();m2=me.recoverEmbeddedWallet;let v2=oE(()=>({wallets:u,ready:ir&&Go}),[u,ir,Go]);return vr(ve.Provider,{value:Pn,children:vr(zc.Provider,{value:D,children:vr(ap.Provider,{value:v2,children:vr(Hm,{...L,children:c2(Vc.Provider,{value:me,children:[c2(Lm,{data:we,setModalData:X,setInitialScreen:x,initialScreen:g,authenticated:a,open:r,children:[e.children,!L.headless&&L.captchaEnabled&&n&&!a&&vr(Gc,{delayedExecution:!1}),vr(Kg,{theme:{...L.appearance.palette||{}}}),!L.render.standalone&&vr(wp,{open:r})]}),de&&ae?vr(s2,{appId:e.appId,appClientId:e.clientId,clientAnalyticsId:t.clientAnalyticsId,origin:t.apiUrl,mfaMethods:s?.mfaMethods,mfaPromise:It,mfaSubmitPromise:Ge,onLoad:V,onLoadFailed:()=>null}):null,L.loginMethods.telegram&&L.loginConfig.telegramAuthConfiguration&&vr(_r,{if:!0,children:vr(n2,{scriptHost:e.apiUrl||ki,botUsername:L.loginConfig.telegramAuthConfiguration.botName})})]})})})})})};import{useContext as cE}from"react";function dE(e){let{login:t}=cE(ve);return He("login",e),{login:t}}import{useContext as pE}from"react";function uE(e){let{logout:t}=pE(ve);return He("logout",e),{logout:t}}import{useCallback as f2,useEffect as mE}from"react";function fE(){let e=he(),t=Fs(),{initLoginWithHeadlessOAuth:r,loginWithHeadlessOAuth:o,isHeadlessOAuthLoading:n,ready:i,user:a}=F(),l=f2(async c=>{if(e.enabled&&e.status!=="success")throw new Tr(e.error,null,"captcha_failure");return r(c.provider,e.token)},[r,e]),s=f2(async()=>{let c=Li();if(a)return console.warn("Cannot login with OAuth when already logged in"),a;if(!c.inProgress)throw new Error("Cannot login with OAuth because no OAuth flow is in progress");if(!c.popupFlow)try{return await o(c)}catch(u){throw u}finally{Jo()}},[o]);return mE(()=>{let c=Li();i&&t&&c.inProgress&&c.headless&&!c.popupFlow&&s()},[i,t]),{initOAuth:l,loginWithOAuth:s,loading:n}}import{useCallback as h2}from"react";var hE=()=>{let e=he(),{initLoginWithEmail:t,loginWithCode:r}=F(),o=h2(async({email:i})=>{if(!i)throw new Error("Email required to send OTP code");return t(i)},[t]),n=h2(async({code:i})=>{if(e.enabled&&e.status==="error")throw new Tr(e.error,null,"captcha_failure");return r(i)},[r,e.status]);return{sendCode:o,loginWithCode:n}};import{useCallback as y2}from"react";var yE=()=>{let e=he(),{initLoginWithSms:t,loginWithCode:r,otpState:o}=F(),n=y2(async({phoneNumber:a})=>{if(!a)throw new Error("SMS required to send OTP code");return t(a)},[t]),i=y2(async({code:a})=>{if(e.enabled&&e.status!=="success")throw new Tr(e.error,null,"captcha_failure");return r(a)},[r,e.status]);return{sendCode:n,loginWithCode:i,state:o}};import{useContext as gE}from"react";function vE(e){let{linkEmail:t,linkPhone:r,linkWallet:o,linkGoogle:n,linkApple:i,linkTwitter:a,linkDiscord:l,linkGithub:s,linkLinkedIn:c,linkTiktok:u,linkSpotify:h,linkInstagram:f,linkTelegram:y,linkFarcaster:v}=gE(ve);return He("linkAccount",e),{linkEmail:t,linkPhone:r,linkWallet:o,linkGoogle:n,linkApple:i,linkTwitter:a,linkDiscord:l,linkGithub:s,linkLinkedIn:c,linkTiktok:u,linkSpotify:h,linkInstagram:f,linkFarcaster:v,linkTelegram:y}}import{useContext as CE}from"react";function wE(e){let{connectWallet:t}=CE(ve);return He("connectWallet",e),{connectWallet:t}}import{useContext as bE}from"react";function EE(e){let{createWallet:t}=bE(ve);return He("createWallet",e),{createWallet:t}}var TE=()=>{let{fundWallet:e}=F();return{fundWallet:e}};import{useContext as PE}from"react";function SE(e){let{sendTransaction:t}=PE(ve);return He("sendTransaction",e),{sendTransaction:t}}import{useContext as _E}from"react";function xE(e){let{setWalletPassword:t}=_E(ve);return He("setWalletPassword",e),{setWalletPassword:t}}import{useContext as kE}from"react";function AE(e){let{signMessage:t}=kE(ve);return He("signMessage",e),{signMessage:t}}import{useContext as RE}from"react";function IE(e){let{signTypedData:t}=RE(ve);return He("signTypedData",e),{signTypedData:t}}import{useContext as ME}from"react";var WE=()=>{let{isModalOpen:e}=ME(ve);return{isOpen:e}};import{useContext as LE}from"react";function OE(e){let{getAccessToken:t}=LE(ve);return He("accessToken",e),{getAccessToken:t}}function NE(){let{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:r}=F();return{getFarcasterSignerPublicKey:e,signFarcasterMessage:t,requestFarcasterSignerFromWarpcast:r}}function DE(e,t){return{...e,rpcUrls:{...e.rpcUrls,privyWalletOverride:{http:[t]}}}}function UE(e){return e.find(r=>r.walletClientType==="privy"&&r.connectorType==="embedded"&&!r.imported)??null}export{Fr as AsExternalProvider,Gc as Captcha,Vi as ConnectorManager,wp as LoginModal,zi as PrivyClient,sE as PrivyProvider,Oe as PrivyProxyProvider,Hi as SUPPORTED_CHAINS,Pc as VERSION,Ot as WalletConnector,DE as addRpcUrlOverrideToChain,ud as errorIndicatesMaxMfaRetries,ln as errorIndicatesMfaTimeout,cn as errorIndicatesMfaVerificationFailed,be as getAccessToken,UE as getEmbeddedConnectedWallet,wE as useConnectWallet,EE as useCreateWallet,NE as useExperimentalFarcasterSigner,TE as useFundWallet,vE as useLinkAccount,dE as useLogin,hE as useLoginWithEmail,fE as useLoginWithOAuth,yE as useLoginWithSms,uE as useLogout,ga as useMfa,Wr as useMfaEnrollment,WE as useModalStatus,F as usePrivy,qc as useRegisterMfaListener,SE as useSendTransaction,xE as useSetWalletPassword,AE as useSignMessage,IE as useSignTypedData,OE as useToken,ka as useWallets};