@privy-io/react-auth 1.59.5 → 1.59.6-beta-20240319171544
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 +3 -3
- package/dist/index.d.ts +12 -2
- package/dist/index.js +3 -3
- package/package.json +1 -1
package/dist/esm/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var Ys=(e,t,r)=>{if(!t.has(e))throw TypeError("Cannot "+r)};var Xc=(e,t,r)=>(Ys(e,t,"read from private field"),r?r.call(e):t.get(e)),Li=(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)},Js=(e,t,r,o)=>(Ys(e,t,"write to private field"),o?o.call(e,r):t.set(e,r),r);var ed=(e,t,r)=>(Ys(e,t,"access private method"),r);import{getAddress as $s}from"@ethersproject/address";import{Web3Provider as Kc}from"@ethersproject/providers";import{createStore as y4}from"mipd";import{useCallback as g4,useEffect as Wr,useMemo as v4,useRef as Ln,useState as ke}from"react";import{FetchError as Ly}from"ofetch";var He=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}]`:""}`}},Xt=class extends He{constructor(r,o,n,i,a){super(n,i,a);this.type=r;this.status=o}},P=class extends He{constructor(r,o,n){super(r,o,n);this.type="client_error"}},Oi=class extends P{constructor(){super("Request timed out",void 0,"client_request_timeout")}};var Y=class extends He{constructor(r,o,n){super(r,o,n);this.type="connector_error"}},le=e=>{if(e instanceof He)return e;if(!(e instanceof Ly))return Ze(e);if(!e.response)return new Xt("api_error",null,e.message,e);let{type:t,message:r,error:o,code:n}=e.data;return new Xt(t||"ApiError",e.response.status,r||o,e,n)},Ze=e=>e instanceof He?e:e instanceof Error?new P(e.message,e):new P(`Internal error: ${e}`);var Io=class extends P{constructor(){super("Method called before `ready`. Ensure you wait until `ready` is true before calling.")}},mt=class extends P{constructor(t="Embedded wallet error",r){super(t,r,"unknown_embedded_wallet_error")}},Ni=class extends P{constructor(t="User must be authenticated"){super(t,void 0,"must_be_authenticated")}};var Di="/api/v1/sessions",Ui="/api/v1/sessions/logout",td="/api/v1/sessions/fork",Fi="/api/v1/sessions/fork/recover",rd="/api/v1/siwe/init",od="/api/v1/siwe/authenticate",nd="/api/v1/siwe/link",id="/api/v1/siwe/unlink",ad="/api/v1/farcaster/init",sd="/api/v1/farcaster/authenticate",ld="/api/v1/farcaster/link",cd="/api/v1/farcaster/status",dd="/api/v1/farcaster/unlink",pd="/api/v1/passwordless/init",ud="/api/v1/passwordless/authenticate",md="/api/v1/passwordless/link",fd="/api/v1/passwordless/unlink",hd="/api/v1/passwordless/update",yd="/api/v1/passwordless_sms/init",gd="/api/v1/passwordless_sms/link",vd="/api/v1/passwordless_sms/unlink",wd="/api/v1/passwordless_sms/authenticate",Cd="/api/v1/oauth/init",bd="/api/v1/oauth/authenticate",Ed="/api/v1/oauth/link",Pd="/api/v1/oauth/unlink";var Td="/api/v1/mfa/passwordless_sms/init",xd="/api/v1/mfa/passwordless_sms/enroll";var Sd="/api/v1/users/me/accept_terms",_d="/api/v1/analytics_events",Ad="/api/v1/plugins/moonpay_on_ramp/sign",kd="/api/v1/custom_jwt_account/authenticate";var Mo=class{constructor(t){this.meta={token:t}}async authenticate(){if(!this.api)throw new P("Auth flow has no API instance");try{let t=await this.api.post(kd,{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 le(t)}}async link(){throw new Error("Unimplemented")}};var Nr=class{constructor(t,r){this.meta={email:t,captchaToken:r}}async authenticate(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new P("Email and email code must be set prior to calling authenticate.");try{let t=await this.api.post(ud,{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 le(t)}}async link(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new P("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(md,{email:this.meta.email,code:this.meta.emailCode})}catch(t){throw le(t)}}async sendCodeEmail(t,r){if(!this.api)throw new P("Auth flow has no API instance");if(t&&(this.meta.email=t),r&&(this.meta.captchaToken=r),!this.meta.email)throw new P("Email must be set when initialzing authentication.");try{return await this.api.post(pd,{email:this.meta.email,token:this.meta.captchaToken})}catch(o){throw le(o)}}},Bi=class extends Nr{constructor(r,o,n){super(o,n);this.meta={email:o,captchaToken:n,oldAddress:r}}async link(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode||!this.meta.oldAddress)throw new P("Email, email code, and an old email address must be set prior to calling update.");try{return await this.api.post(hd,{oldAddress:this.meta.oldAddress,newAddress:this.meta.email,code:this.meta.emailCode})}catch(r){throw le(r)}}};import{isMobile as By,isIOS as Hy}from"react-device-detect";var Hi=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)}},Zs=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)}},Qs=class{get(t){let r=sessionStorage.getItem(t);return r===null?void 0:JSON.parse(r)}put(t,r){r!==void 0?sessionStorage.setItem(t,JSON.stringify(r)):this.del(t)}del(t){sessionStorage.removeItem(t)}getKeys(){return Object.entries(sessionStorage).map(([t])=>t)}};function Xs(){try{let e="privy:__session_storage__test",t="blobby";return window.sessionStorage.setItem(e,t),window.sessionStorage.removeItem(e),!0}catch{return!1}}function Oy(){return typeof window<"u"&&window.localStorage?new Zs:new Hi}function Ny(){return typeof window<"u"&&window.sessionStorage?new Qs:new Hi}var Ge=Ny(),ce=Oy();import{StaticJsonRpcProvider as Oo}from"@ethersproject/providers";function Rd(){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 Gi=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 el=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||Gi(e)!=="MetaMask")return!1;if(e.providers){for(let r of e.providers)if(!el(r))return!1}return!0},Dr=()=>!!("phantom"in window&&window?.phantom?.ethereum?.isPhantom),Id=()=>{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 Md="1.59.5";var tl="4df5e2316331463a9130964bd6078dfa",rl="fe9c30fc-3bc5-4064-91e2-6ab5887f8f4d",Wd="34357d3c125c2bcf2ce2bc3309d98715",Vi="https://auth.privy.io",Ld=2e4,Qe=1400,Od=2500,ol=Md;var co="privy:token",nl="privy-token",zi="privy:refresh_token",il="privy-refresh-token",$i="privy-session",Dn="privy:session_transfer_token",Uy="privy:wallet",Un="privy:caid",po="privy:state_code",Wo="privy:code_verifier",Fn="privy:headless_oauth",qi=e=>`${Uy}:${e}`,al="privy:connectors",sl="privy:connections";var uo=12e4,Er=1,ll="0x1",Lo=3e4,Nd="https://api.moonpay.com/v1",Dd="https://api.moonpay.com/v1",Ud="pk_live_hirbpu0cVcLHrjktC9l7fbc9ctjv0SL",Fd="pk_test_fqWjXZMSFwloh7orvJsRfjiUHXJqFzI",Bd="0x420000000000000000000000000000000000000F",Hd=["function getL1Fee(bytes memory _data) external view returns (uint256)"];var Gd=(e,t)=>{let r=[],o=[];for(let[n,i]of e.entries())n<t?r.push(i):o.push(i);return[r,o]},ji=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,}))$/),Vd=(e,t)=>{let r=e.slice(0),o=[];for(;r.length;)o.push(r.splice(0,t));return o},Ur=(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}`},cl=e=>new Promise(t=>setTimeout(t,e));function zd(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 $d=(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(()=>{a=!0,n()},(...s)=>{a=!0,i(...s)}),l+=1,await cl(r)}a||i(new Error("Exceeded max attempts before resolving function"))})},Ki=(e,t,r={})=>{let o=new URL(t,e);for(let[n,i]of Object.entries(r))o.searchParams.set(n,i);return o.href};var qd=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),mo=e=>typeof e=="string"?e:"0x"+e.toString(16);async function jd(e,t,r=3e3){let o=!1,n=window;return new Promise(i=>{n.ethereum?a():(window.addEventListener("ethereum#initialized",a,{once:!0}),setTimeout(()=>{a()},r));function a(){if(o)return;o=!0,window.removeEventListener("ethereum#initialized",a);let l=e.getProviders(),s=[];for(let c of l)t.includes("coinbase_wallet")&&c.info.rdns==="com.coinbase.wallet"||s.push({type:c.info.name.toLowerCase().replace(/\s/g,"_"),eip6963InjectedProvider:c});for(let c of Rd()){let u=Gi(c);if(!l.some(h=>h.info.name===u)){if(el(c,!0)&&!s.find(h=>h.type==="metamask")){s.push({type:"metamask",legacyInjectedProvider:c});continue}if(u==="Phantom"&&!s.find(h=>h.type==="phantom")){s.push({type:"phantom",legacyInjectedProvider:c});continue}s.find(h=>h.type==="unknown_browser_extension")||s.push({type:"unknown_browser_extension",legacyInjectedProvider:c})}}i(s)}})}function No(e){return`eip155:${String(Number(e))}`}var Yi=(e,t,r,o)=>{let n=Number(e),i=t.find(l=>l.id===n);if(!i)throw new Y(`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.infura?.http[0]?a=i.rpcUrls.infura.http[0]+"/"+tl:i.rpcUrls.blast?.http[0]?a=i.rpcUrls.blast.http[0]+"/"+rl:a=i.rpcUrls.default?.http[0];if(!a)throw new Y(`No RPC url found for ${e}`);return a},Kd=(e,t)=>{let r=Number(e),o=t.find(n=>n.id===r);if(!o)throw new Y(`Unsupported chainId ${e}`,4901);return o.blockExplorers?.default.url},Pr=(e,t,r,o)=>{let n=Number(e),i=t.find(l=>l.id===n);if(!i)throw new Y(`Unsupported chainId ${e}`,4901);let a;if(i.rpcUrls.privyWalletOverride&&i.rpcUrls.privyWalletOverride.http[0]?a=new Oo(i.rpcUrls.privyWalletOverride.http[0]):r.rpcUrls&&r.rpcUrls[n]?a=new Oo(r.rpcUrls[n]):i.rpcUrls.privy?.http[0]?a=new Oo({url:i.rpcUrls.privy.http[0],headers:{"privy-app-id":o.appId}}):i.rpcUrls.infura?.http[0]?a=new Oo(i.rpcUrls.infura.http[0]+"/"+tl):i.rpcUrls.blast?.http[0]?a=new Oo(i.rpcUrls.blast.http[0]+"/"+rl):a=new Oo(i.rpcUrls.default?.http[0]),!a)throw new Y(`No RPC url found for ${e}`);return a},Ji=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 Zi=e=>{let t;try{t=new URL(e).hostname}catch{return}for(let[r,o]of Object.entries(Do))if(t.includes(o.hostname))return{walletClientType:r,entry:o}};var Do={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"}}};function Fy(e){return{name:e.displayName||"",universalLink:e.mobile.universal,deepLink:e.mobile.native}}var Yd=e=>e in Do,Jd=e=>{let t=Do[e].mobile;if("native"in t)return t.native};function Zd(e,t){let r=Fy(t);if(r.deepLink)return rp(r.deepLink,e);if(r.universalLink)return op(r.universalLink,e);throw new P(`Unsupported wallet ${t.id}`)}var Qd="WALLETCONNECT_DEEPLINK_CHOICE";function Xd(){try{localStorage.removeItem(Qd)}catch{}}function ep({href:e,name:t}){try{localStorage.setItem(Qd,JSON.stringify({href:e,name:t}))}catch{}}function tp(e){return e.startsWith("http://")||e.startsWith("https://")}function rp(e,t){if(tp(e))return op(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 op(e,t){if(!tp(e))return rp(e,t);let r=e;r.endsWith("/")||(r=`${r}/`);let o=encodeURIComponent(t);return{redirect:`${r}wc?uri=${o}`,href:r}}function Qi(e,t){window.open(e,t,"noreferrer noopener")}var Xe=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 Bn=class{constructor(t){this._meta={};this.captchaToken=t,this.startChannelOnce=new Xe(this._startChannelOnce.bind(this)),this.pollForReady=new Xe(this._pollForReady.bind(this))}get meta(){return this._meta}async authenticate(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.channelToken)throw new P("Auth flow must be initialized first");try{let t=await this.api.post(sd,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid});if(!t)throw new P("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 le(t)}}async link(){if(!this.api)throw new P("Auth flow has no API instance");try{return await this.api.post(ld,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid})}catch(t){throw le(t)}}async _startChannelOnce(){if(!this.api)throw new P("Auth flow has no API instance");let t=await this.api.post(ad,{token:this.captchaToken});By&&!Hy&&t.connect_uri&&Qi(t.connect_uri,"_blank"),this._meta={connectUri:t.connect_uri,channelToken:t.channel_token}}async initializeFarcasterConnect(){if(!this.api)throw new P("Auth flow has no API instance");await this.startChannelOnce.execute()}async _pollForReady(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.channelToken)throw new P("Auth flow must be initialized first");let t=await this.api.get(cd,{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}};import{base64url as ap}from"jose";async function np(e){let t=new TextEncoder().encode(e),r=await crypto.subtle.digest("SHA-256",t);return new Uint8Array(r)}function ip(e){return crypto.getRandomValues(new Uint8Array(e))}function Xi(){return!!Ge.get(Fn)}var Gy="S256",Vy="S256",er=class{constructor(t){let r=typeof t.headless=="boolean"?t.headless:Xi();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 P("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new P("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new P("User denied confirmation during OAuth flow");let t=Ge.get(Wo);if(!t)throw new P("Authentication error.");try{let r=await this.api.post(bd,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:t});return Ge.del(Wo),this.meta.headless&&Ge.del(Fn),{user:r.user,token:r.token,refresh_token:r.refresh_token,is_new_user:r.is_new_user}}catch(r){let o=le(r);throw o.privyErrorCode?new P(o.message||"Invalid code during OAuth flow.",void 0,o.privyErrorCode):o.message==="User denied confirmation during OAuth flow"?new P("Invalid code during oauth flow.",void 0,"oauth_user_denied"):new P("Invalid code during OAuth flow.",void 0,"unknown_auth_error")}}async link(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new P("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new P("User denied confirmation during OAuth flow");let t=Ge.get(Wo);if(!t)throw new P("Authentication error.");try{let r=await this.api.post(Ed,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:t});return Ge.del(Wo),r}catch(r){throw le(r)}}createCodeVerifier(){return ap.encode(ip(36))}createStateCode(){return this.createCodeVerifier()}async deriveCodeChallengeFromCodeVerifier(t,r=Gy){if(r==Vy){let o=await np(t);return ap.encode(o)}else return t}async getAuthorizationUrl(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.provider)throw new P("Provider must be set when initializing OAuth authentication.");let t=this.createCodeVerifier();Ge.put(Wo,t);let r=this.createStateCode();Ge.put(po,r);let o=await this.deriveCodeChallengeFromCodeVerifier(t);this.meta.headless&&Ge.put(Fn,!0);try{return await this.api.post(Cd,{provider:this.meta.provider,redirect_to:window.location.href,token:this.meta.captchaToken,code_challenge:o,state_code:r})}catch(n){throw le(n)}}};function dl(e){return e.charAt(0).toUpperCase()+e.slice(1)}function sp(e,t){let r={detail:"",retryable:!1},o=dl(t);return 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==="oauth_account_suspended"&&(r.detail=`Your ${o} account is suspended. Please try another login method.`),r}function Gn(){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:Xi()}}function Vn(){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"),Ge.del(po),window.history.replaceState({},"",e)}var fo=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 Ys=(e,t,r)=>{if(!t.has(e))throw TypeError("Cannot "+r)};var Xc=(e,t,r)=>(Ys(e,t,"read from private field"),r?r.call(e):t.get(e)),Li=(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)},Js=(e,t,r,o)=>(Ys(e,t,"write to private field"),o?o.call(e,r):t.set(e,r),r);var ed=(e,t,r)=>(Ys(e,t,"access private method"),r);import{getAddress as $s}from"@ethersproject/address";import{Web3Provider as Kc}from"@ethersproject/providers";import{createStore as y4}from"mipd";import{useCallback as g4,useEffect as Wr,useMemo as v4,useRef as Ln,useState as ke}from"react";import{FetchError as Ly}from"ofetch";var He=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}]`:""}`}},Xt=class extends He{constructor(r,o,n,i,a){super(n,i,a);this.type=r;this.status=o}},P=class extends He{constructor(r,o,n){super(r,o,n);this.type="client_error"}},Oi=class extends P{constructor(){super("Request timed out",void 0,"client_request_timeout")}};var Y=class extends He{constructor(r,o,n){super(r,o,n);this.type="connector_error"}},le=e=>{if(e instanceof He)return e;if(!(e instanceof Ly))return Ze(e);if(!e.response)return new Xt("api_error",null,e.message,e);let{type:t,message:r,error:o,code:n}=e.data;return new Xt(t||"ApiError",e.response.status,r||o,e,n)},Ze=e=>e instanceof He?e:e instanceof Error?new P(e.message,e):new P(`Internal error: ${e}`);var Io=class extends P{constructor(){super("Method called before `ready`. Ensure you wait until `ready` is true before calling.")}},mt=class extends P{constructor(t="Embedded wallet error",r){super(t,r,"unknown_embedded_wallet_error")}},Ni=class extends P{constructor(t="User must be authenticated"){super(t,void 0,"must_be_authenticated")}};var Di="/api/v1/sessions",Ui="/api/v1/sessions/logout",td="/api/v1/sessions/fork",Fi="/api/v1/sessions/fork/recover",rd="/api/v1/siwe/init",od="/api/v1/siwe/authenticate",nd="/api/v1/siwe/link",id="/api/v1/siwe/unlink",ad="/api/v1/farcaster/init",sd="/api/v1/farcaster/authenticate",ld="/api/v1/farcaster/link",cd="/api/v1/farcaster/status",dd="/api/v1/farcaster/unlink",pd="/api/v1/passwordless/init",ud="/api/v1/passwordless/authenticate",md="/api/v1/passwordless/link",fd="/api/v1/passwordless/unlink",hd="/api/v1/passwordless/update",yd="/api/v1/passwordless_sms/init",gd="/api/v1/passwordless_sms/link",vd="/api/v1/passwordless_sms/unlink",wd="/api/v1/passwordless_sms/authenticate",Cd="/api/v1/oauth/init",bd="/api/v1/oauth/authenticate",Ed="/api/v1/oauth/link",Pd="/api/v1/oauth/unlink";var Td="/api/v1/mfa/passwordless_sms/init",xd="/api/v1/mfa/passwordless_sms/enroll";var Sd="/api/v1/users/me/accept_terms",_d="/api/v1/analytics_events",Ad="/api/v1/plugins/moonpay_on_ramp/sign",kd="/api/v1/custom_jwt_account/authenticate";var Mo=class{constructor(t){this.meta={token:t}}async authenticate(){if(!this.api)throw new P("Auth flow has no API instance");try{let t=await this.api.post(kd,{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 le(t)}}async link(){throw new Error("Unimplemented")}};var Nr=class{constructor(t,r){this.meta={email:t,captchaToken:r}}async authenticate(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new P("Email and email code must be set prior to calling authenticate.");try{let t=await this.api.post(ud,{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 le(t)}}async link(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new P("Email and email code must be set prior to calling authenticate.");try{return await this.api.post(md,{email:this.meta.email,code:this.meta.emailCode})}catch(t){throw le(t)}}async sendCodeEmail(t,r){if(!this.api)throw new P("Auth flow has no API instance");if(t&&(this.meta.email=t),r&&(this.meta.captchaToken=r),!this.meta.email)throw new P("Email must be set when initialzing authentication.");try{return await this.api.post(pd,{email:this.meta.email,token:this.meta.captchaToken})}catch(o){throw le(o)}}},Bi=class extends Nr{constructor(r,o,n){super(o,n);this.meta={email:o,captchaToken:n,oldAddress:r}}async link(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode||!this.meta.oldAddress)throw new P("Email, email code, and an old email address must be set prior to calling update.");try{return await this.api.post(hd,{oldAddress:this.meta.oldAddress,newAddress:this.meta.email,code:this.meta.emailCode})}catch(r){throw le(r)}}};import{isMobile as By,isIOS as Hy}from"react-device-detect";var Hi=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)}},Zs=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)}},Qs=class{get(t){let r=sessionStorage.getItem(t);return r===null?void 0:JSON.parse(r)}put(t,r){r!==void 0?sessionStorage.setItem(t,JSON.stringify(r)):this.del(t)}del(t){sessionStorage.removeItem(t)}getKeys(){return Object.entries(sessionStorage).map(([t])=>t)}};function Xs(){try{let e="privy:__session_storage__test",t="blobby";return window.sessionStorage.setItem(e,t),window.sessionStorage.removeItem(e),!0}catch{return!1}}function Oy(){return typeof window<"u"&&window.localStorage?new Zs:new Hi}function Ny(){return typeof window<"u"&&window.sessionStorage?new Qs:new Hi}var Ge=Ny(),ce=Oy();import{StaticJsonRpcProvider as Oo}from"@ethersproject/providers";function Rd(){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 Gi=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 el=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||Gi(e)!=="MetaMask")return!1;if(e.providers){for(let r of e.providers)if(!el(r))return!1}return!0},Dr=()=>!!("phantom"in window&&window?.phantom?.ethereum?.isPhantom),Id=()=>{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 Md="1.59.6-beta-20240319171544";var tl="4df5e2316331463a9130964bd6078dfa",rl="fe9c30fc-3bc5-4064-91e2-6ab5887f8f4d",Wd="34357d3c125c2bcf2ce2bc3309d98715",Vi="https://auth.privy.io",Ld=2e4,Qe=1400,Od=2500,ol=Md;var co="privy:token",nl="privy-token",zi="privy:refresh_token",il="privy-refresh-token",$i="privy-session",Dn="privy:session_transfer_token",Uy="privy:wallet",Un="privy:caid",po="privy:state_code",Wo="privy:code_verifier",Fn="privy:headless_oauth",qi=e=>`${Uy}:${e}`,al="privy:connectors",sl="privy:connections";var uo=12e4,Er=1,ll="0x1",Lo=3e4,Nd="https://api.moonpay.com/v1",Dd="https://api.moonpay.com/v1",Ud="pk_live_hirbpu0cVcLHrjktC9l7fbc9ctjv0SL",Fd="pk_test_fqWjXZMSFwloh7orvJsRfjiUHXJqFzI",Bd="0x420000000000000000000000000000000000000F",Hd=["function getL1Fee(bytes memory _data) external view returns (uint256)"];var Gd=(e,t)=>{let r=[],o=[];for(let[n,i]of e.entries())n<t?r.push(i):o.push(i);return[r,o]},ji=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,}))$/),Vd=(e,t)=>{let r=e.slice(0),o=[];for(;r.length;)o.push(r.splice(0,t));return o},Ur=(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}`},cl=e=>new Promise(t=>setTimeout(t,e));function zd(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 $d=(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(()=>{a=!0,n()},(...s)=>{a=!0,i(...s)}),l+=1,await cl(r)}a||i(new Error("Exceeded max attempts before resolving function"))})},Ki=(e,t,r={})=>{let o=new URL(t,e);for(let[n,i]of Object.entries(r))o.searchParams.set(n,i);return o.href};var qd=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),mo=e=>typeof e=="string"?e:"0x"+e.toString(16);async function jd(e,t,r=3e3){let o=!1,n=window;return new Promise(i=>{n.ethereum?a():(window.addEventListener("ethereum#initialized",a,{once:!0}),setTimeout(()=>{a()},r));function a(){if(o)return;o=!0,window.removeEventListener("ethereum#initialized",a);let l=e.getProviders(),s=[];for(let c of l)t.includes("coinbase_wallet")&&c.info.rdns==="com.coinbase.wallet"||s.push({type:c.info.name.toLowerCase().replace(/\s/g,"_"),eip6963InjectedProvider:c});for(let c of Rd()){let u=Gi(c);if(!l.some(h=>h.info.name===u)){if(el(c,!0)&&!s.find(h=>h.type==="metamask")){s.push({type:"metamask",legacyInjectedProvider:c});continue}if(u==="Phantom"&&!s.find(h=>h.type==="phantom")){s.push({type:"phantom",legacyInjectedProvider:c});continue}s.find(h=>h.type==="unknown_browser_extension")||s.push({type:"unknown_browser_extension",legacyInjectedProvider:c})}}i(s)}})}function No(e){return`eip155:${String(Number(e))}`}var Yi=(e,t,r,o)=>{let n=Number(e),i=t.find(l=>l.id===n);if(!i)throw new Y(`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.infura?.http[0]?a=i.rpcUrls.infura.http[0]+"/"+tl:i.rpcUrls.blast?.http[0]?a=i.rpcUrls.blast.http[0]+"/"+rl:a=i.rpcUrls.default?.http[0];if(!a)throw new Y(`No RPC url found for ${e}`);return a},Kd=(e,t)=>{let r=Number(e),o=t.find(n=>n.id===r);if(!o)throw new Y(`Unsupported chainId ${e}`,4901);return o.blockExplorers?.default.url},Pr=(e,t,r,o)=>{let n=Number(e),i=t.find(l=>l.id===n);if(!i)throw new Y(`Unsupported chainId ${e}`,4901);let a;if(i.rpcUrls.privyWalletOverride&&i.rpcUrls.privyWalletOverride.http[0]?a=new Oo(i.rpcUrls.privyWalletOverride.http[0]):r.rpcUrls&&r.rpcUrls[n]?a=new Oo(r.rpcUrls[n]):i.rpcUrls.privy?.http[0]?a=new Oo({url:i.rpcUrls.privy.http[0],headers:{"privy-app-id":o.appId}}):i.rpcUrls.infura?.http[0]?a=new Oo(i.rpcUrls.infura.http[0]+"/"+tl):i.rpcUrls.blast?.http[0]?a=new Oo(i.rpcUrls.blast.http[0]+"/"+rl):a=new Oo(i.rpcUrls.default?.http[0]),!a)throw new Y(`No RPC url found for ${e}`);return a},Ji=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 Zi=e=>{let t;try{t=new URL(e).hostname}catch{return}for(let[r,o]of Object.entries(Do))if(t.includes(o.hostname))return{walletClientType:r,entry:o}};var Do={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"}}};function Fy(e){return{name:e.displayName||"",universalLink:e.mobile.universal,deepLink:e.mobile.native}}var Yd=e=>e in Do,Jd=e=>{let t=Do[e].mobile;if("native"in t)return t.native};function Zd(e,t){let r=Fy(t);if(r.deepLink)return rp(r.deepLink,e);if(r.universalLink)return op(r.universalLink,e);throw new P(`Unsupported wallet ${t.id}`)}var Qd="WALLETCONNECT_DEEPLINK_CHOICE";function Xd(){try{localStorage.removeItem(Qd)}catch{}}function ep({href:e,name:t}){try{localStorage.setItem(Qd,JSON.stringify({href:e,name:t}))}catch{}}function tp(e){return e.startsWith("http://")||e.startsWith("https://")}function rp(e,t){if(tp(e))return op(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 op(e,t){if(!tp(e))return rp(e,t);let r=e;r.endsWith("/")||(r=`${r}/`);let o=encodeURIComponent(t);return{redirect:`${r}wc?uri=${o}`,href:r}}function Qi(e,t){window.open(e,t,"noreferrer noopener")}var Xe=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 Bn=class{constructor(t){this._meta={};this.captchaToken=t,this.startChannelOnce=new Xe(this._startChannelOnce.bind(this)),this.pollForReady=new Xe(this._pollForReady.bind(this))}get meta(){return this._meta}async authenticate(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.channelToken)throw new P("Auth flow must be initialized first");try{let t=await this.api.post(sd,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid});if(!t)throw new P("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 le(t)}}async link(){if(!this.api)throw new P("Auth flow has no API instance");try{return await this.api.post(ld,{channel_token:this.meta.channelToken,message:this.message,signature:this.signature,fid:this.fid})}catch(t){throw le(t)}}async _startChannelOnce(){if(!this.api)throw new P("Auth flow has no API instance");let t=await this.api.post(ad,{token:this.captchaToken});By&&!Hy&&t.connect_uri&&Qi(t.connect_uri,"_blank"),this._meta={connectUri:t.connect_uri,channelToken:t.channel_token}}async initializeFarcasterConnect(){if(!this.api)throw new P("Auth flow has no API instance");await this.startChannelOnce.execute()}async _pollForReady(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.channelToken)throw new P("Auth flow must be initialized first");let t=await this.api.get(cd,{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}};import{base64url as ap}from"jose";async function np(e){let t=new TextEncoder().encode(e),r=await crypto.subtle.digest("SHA-256",t);return new Uint8Array(r)}function ip(e){return crypto.getRandomValues(new Uint8Array(e))}function Xi(){return!!Ge.get(Fn)}var Gy="S256",Vy="S256",er=class{constructor(t){let r=typeof t.headless=="boolean"?t.headless:Xi();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 P("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new P("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new P("User denied confirmation during OAuth flow");let t=Ge.get(Wo);if(!t)throw new P("Authentication error.");try{let r=await this.api.post(bd,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:t});return Ge.del(Wo),this.meta.headless&&Ge.del(Fn),{user:r.user,token:r.token,refresh_token:r.refresh_token,is_new_user:r.is_new_user}}catch(r){let o=le(r);throw o.privyErrorCode?new P(o.message||"Invalid code during OAuth flow.",void 0,o.privyErrorCode):o.message==="User denied confirmation during OAuth flow"?new P("Invalid code during oauth flow.",void 0,"oauth_user_denied"):new P("Invalid code during OAuth flow.",void 0,"unknown_auth_error")}}async link(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new P("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new P("User denied confirmation during OAuth flow");let t=Ge.get(Wo);if(!t)throw new P("Authentication error.");try{let r=await this.api.post(Ed,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode,code_verifier:t});return Ge.del(Wo),r}catch(r){throw le(r)}}createCodeVerifier(){return ap.encode(ip(36))}createStateCode(){return this.createCodeVerifier()}async deriveCodeChallengeFromCodeVerifier(t,r=Gy){if(r==Vy){let o=await np(t);return ap.encode(o)}else return t}async getAuthorizationUrl(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.provider)throw new P("Provider must be set when initializing OAuth authentication.");let t=this.createCodeVerifier();Ge.put(Wo,t);let r=this.createStateCode();Ge.put(po,r);let o=await this.deriveCodeChallengeFromCodeVerifier(t);this.meta.headless&&Ge.put(Fn,!0);try{return await this.api.post(Cd,{provider:this.meta.provider,redirect_to:window.location.href,token:this.meta.captchaToken,code_challenge:o,state_code:r})}catch(n){throw le(n)}}};function dl(e){return e.charAt(0).toUpperCase()+e.slice(1)}function sp(e,t){let r={detail:"",retryable:!1},o=dl(t);return 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==="oauth_account_suspended"&&(r.detail=`Your ${o} account is suspended. Please try another login method.`),r}function Gn(){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:Xi()}}function Vn(){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"),Ge.del(po),window.history.replaceState({},"",e)}var fo=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 Xe(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 P("Auth flow has no API instance");try{let{message:t,signature:r}=await this.sign(),o=await this.api.post(od,{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 le(t)}}async link(){if(!this.api)throw new P("Auth flow has no API instance");try{let{message:t,signature:r}=await this.sign();return await this.api.post(nd,{message:t,signature:r,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(t){throw le(t)}}async sign(){if(!this.api)throw new P("Auth flow has no API instance");if(await this.buildSiweMessage(),!this.preparedMessage)throw new P("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 P("Auth flow has no API instance");let t=this.wallet.address;return(await this.api.post(rd,{address:t,token:this.captchaToken})).nonce}async buildSiweMessage(){if(!this.api)throw new P("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 ho=class{constructor(t,r){this.meta={phoneNumber:t,captchaToken:r}}async authenticate(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new P("phone number and sms code must be set prior to calling authenticate.");try{let t=await this.api.post(wd,{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 le(t)}}async link(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new P("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(gd,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(t){throw le(t)}}async sendSmsCode(t,r){if(!this.api)throw new P("Auth flow has no API instance");if(t&&(this.meta.phoneNumber=t),r&&(this.meta.captchaToken=r),!this.meta.phoneNumber)throw new P("phone nNumber must be set when initialzing authentication.");try{return await this.api.post(yd,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken})}catch(o){throw le(o)}}};import{v4 as Wg}from"uuid";function et(e){return new Date(e*1e3)}function zy(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,verifiedAt:et(r.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:et(r.verified_at)};t.push(i);break;case"phone":let a={number:r.phoneNumber,type:r.type,verifiedAt:et(r.verified_at)};t.push(a);break;case"google_oauth":let l={subject:r.subject,email:r.email,name:r.name,type:r.type,verifiedAt:et(r.verified_at)};t.push(l);break;case"spotify_oauth":let s={subject:r.subject,email:r.email,name:r.name,type:r.type,verifiedAt:et(r.verified_at)};t.push(s);break;case"twitter_oauth":let c={subject:r.subject,username:r.username,name:r.name,type:r.type,profilePictureUrl:r.profile_picture_url,verifiedAt:et(r.verified_at)};t.push(c);break;case"discord_oauth":let u={subject:r.subject,username:r.username,email:r.email,type:r.type,verifiedAt:et(r.verified_at)};t.push(u);break;case"github_oauth":let h={subject:r.subject,username:r.username,name:r.name,email:r.email,type:r.type,verifiedAt:et(r.verified_at)};t.push(h);break;case"tiktok_oauth":let f={subject:r.subject,username:r.username,name:r.name,type:r.type,verifiedAt:et(r.verified_at)};t.push(f);break;case"linkedin_oauth":let y={subject:r.subject,name:r.name,email:r.email,type:r.type,verifiedAt:et(r.verified_at)};t.push(y);break;case"apple_oauth":let E={subject:r.subject,email:r.email,type:r.type,verifiedAt:et(r.verified_at)};t.push(E);break;case"custom_auth":t.push({type:r.type,customUserId:r.custom_user_id,verifiedAt:et(r.verified_at)});break;case"farcaster":let v={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:et(r.verified_at)};t.push(v);break;default:console.warn(`Unrecognized account type: ${o}. Please consider upgrading the Privy SDK.`)}}return t}function Et(e,t){return e.sort((r,o)=>o.verifiedAt.getTime()-r.verifiedAt.getTime()),e.find(r=>r.type===t)}var ye=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy")||null,$y=e=>e.linkedAccounts.filter(t=>t.type==="wallet"),Pt=(e,t)=>t==="all-users"&&!ye(e)||t==="users-without-wallets"&&!$y(e)?.length;function ft(e){if(!e)return null;let t=zy(e.linked_accounts),r=Et(t,"wallet"),o=Et(t,"email"),n=Et(t,"phone"),i=Et(t,"google_oauth"),a=Et(t,"twitter_oauth"),l=Et(t,"discord_oauth"),s=Et(t,"github_oauth"),c=Et(t,"spotify_oauth"),u=Et(t,"tiktok_oauth"),h=Et(t,"linkedin_oauth"),f=Et(t,"apple_oauth"),y=Et(t,"farcaster"),E=e.mfa_methods.map(({type:x,verified_at:C})=>({type:x,verifiedAt:et(C)}));return{id:e.id,createdAt:et(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},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},tiktok:u&&{subject:u.subject,username:u.username,name:u.name},linkedin:h&&{subject:h.subject,name:h.name,email:h.email},apple:f&&{subject:f.subject,email:f.email},farcaster:y&&{fid:y.fid,ownerAddress:y.ownerAddress,displayName:y.displayName,username:y.username,bio:y.bio,pfp:y.pfp,url:y.url},mfaMethods:E.map(x=>x.type),hasAcceptedTerms:e.has_accepted_terms??!1}}import{getAddress as Vp}from"@ethersproject/address";import kg from"eventemitter3";import tg from"@coinbase/wallet-sdk";import{jsx as lp,jsxs as qy}from"react/jsx-runtime";var ea=({style:e,...t})=>qy("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:[lp("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),lp("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 rr}from"@ethersproject/address";import{Web3Provider as fp}from"@ethersproject/providers";import{default as Xy}from"eventemitter3";import Qy from"eventemitter3";var jy=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4"],cp=e=>jy.includes(e);import{ErrorCode as Ky}from"@ethersproject/logger";var Uo=class extends Y{constructor(){super("Wallet timeout");this.type="wallet_error"}},Fo=class extends Y{constructor(){super("User rejected connection");this.type="wallet_error"}},Bt=e=>{if(e instanceof Y)return e;if(e?.code&&e?.reason){let t=new Ee(e);return e.code===Ky.ACTION_REJECTED&&(t.details=Ve.E4001_USER_REJECTED_REQUEST),t}return e?.code?new Ee(e):new Y("Unknown connector error",e)},Tt=class extends He{constructor(r,o,n){super(r);this.type="provider_error";this.code=o,this.data=n}},Ee=class extends Tt{constructor(r){let o=r;super(o.message,o.code,o.data);let n=Object.values(Ve).find(i=>i.eipCode===o.code);this.details=n||Ve.UNKNOWN_ERROR,o.code===-32002&&(o.message?.includes("already pending for origin")?o.message?.includes("wallet_requestPermissions")?this.details=Ve.E32002_CONNECTION_ALREADY_PENDING:this.details=Ve.E32002_REQUEST_ALREADY_PENDING:o.message?.includes("Already processing")&&o.message.includes("eth_requestAccounts")&&(this.details=Ve.E32002_WALLET_LOCKED))}},Yy={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}},Jy={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}},Zy={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}},Ve={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Zy,...Jy},Tr={...Yy,...Ve};var ge=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 Uo,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||uo,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 Y(`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 Bt(r)})}},Fr=class extends Error{constructor(r,o,n){super(r);this.code=o,this.data=n}},ta=class extends Qy{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=Pr(l,this.chains,n,{appId:a}),this.rpcTimeoutDuration=Bo(n,"privy"),this.appId=a}async handleSendTransaction(r){if(!r.params||!Array.isArray(r.params))throw new Fr(`Invalid params for ${r.method}`,4200);let o=r.params[0];if(!await Me()||!this.address)throw new Fr("Disconnected",4900);return(await up(o)).hash}handleSwitchEthereumChain(r){if(!r.params||!Array.isArray(r.params))throw new Fr(`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 Fr(`Invalid params for ${r.method}`,4200);this.chainId=Number(o),this.provider=Pr(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];return await dp(o)}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 pp(Ji(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:mo(this.chainId)};try{return await this.provider.send("eth_estimateGas",[o])}catch{return delete o.from,await this.provider.send("eth_estimateGas",[o])}}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 mo(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(cp(r.method)){let o=await Me();if(await mp(),!o||!this.address)throw new Fr("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 Fr("Disconnected",4900)}}else return this.provider.send(r.method,r.params)}async connect(){let r=await Me();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}}},tr=class extends ge{constructor(r){super(r,r.rpcTimeoutDuration)}},Br=class extends ge{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 eg=(e,t)=>{switch(t){case"coinbase_wallet":return e.message.includes("addEthereumChain");default:return e.code===4902||e.message?.includes("4902")}},lt=class extends Xy{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=No(r),this.walletClientType==="privy"&&ce.put(qi(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=Bo(i,r),this.connected=!1,this.initialized=!1}buildConnectedWallet(r,o,n){let i=async()=>!!this.wallets.find(a=>rr(a.address)===rr(r));return{address:rr(r),chainId:o,meta:n,switchChain:async a=>{if(!i)throw new Y("Wallet is not currently connected.");let l=this.wallets.find(f=>rr(f.address)===rr(r))?.chainId;if(!l)throw new Y("Unable to determine current chainId.");let s,c;if(typeof a=="number"?(s=`0x${a.toString(16)}`,c=a):(s=a,c=Number(a)),l===No(s))return;let u=this.chains.find(f=>f.id===c);if(!u)throw new Y(`Unsupported chainId: ${a}`);let h=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:s}]})};try{return await h()}catch(f){if(eg(f,this.walletClientType))return await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:s,chainName:u.name,nativeCurrency:u.nativeCurrency,rpcUrls:[u.rpcUrls.default?.http[0]??""],blockExplorerUrls:[u.blockExplorers?.default.url??""]}]}),h();throw this.walletClientType==="rainbow"&&f.message?.includes("wallet_switchEthereumChain")?new Y(`Rainbow does not support the chainId ${o}`):f}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:i,getEthereumProvider:async()=>{if(!await i())throw new Y("Wallet is not currently connected.");return this.proxyProvider},getEthersProvider:async()=>{if(!await i())throw new Y("Wallet is not currently connected.");return new fp(new tr(this.proxyProvider))},getWeb3jsProvider:async()=>{if(!await i())throw new Y("Wallet is not currently connected.");return new Br(this.proxyProvider)},sign:async a=>{if(!await i())throw new Y("Wallet is not currently connected.");return await this.sign(a)},disconnect:()=>{this.disconnect()}}}async syncAccounts(r){let o=r;try{if(o===void 0){let c=await this.proxyProvider.request({method:"eth_accounts"});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=rr(n),a=[],l;if(this.walletClientType==="privy"){let c=ce.get(qi(i));this.chains.find(u=>u.id===Number(c))||(ce.del(qi(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 this.proxyProvider.request({method:"eth_chainId"});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 ${ll}`,c),l=ll}let s=No(l);if(!a.find(c=>rr(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(rr(n),s,c))}ra(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=>rr(n)===rr(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 fp(new tr(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 Ho={id:1,network:"homestead",name:"Ethereum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{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 rg=(e,t)=>{let o=Yi(1,[Ho],{},t);return e.makeWeb3Provider(o,1)},oa,na=class extends lt{constructor(r,o,n,i){super("coinbase_wallet",r,o,n);this.connectorType="coinbase_wallet";this.proxyProvider=new ge(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),oa||(oa=new tg({appName:"Privy",darkMode:!1,headlessMode:!1,enableMobileWalletLink:!0})),this.proxyProvider.setWalletProvider(rg(oa,i))}async initialize(){await this.syncAccounts(),this.emit("initialized"),this.initialized=!0}async connect(r){return r.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){oa.disconnect(),this.onDisconnect()}get walletBranding(){return{name:"Coinbase Wallet",icon:ea,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 Y("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([r[0]])}catch(r){throw Bt(r)}}};import{jsx as hp}from"react/jsx-runtime";var ia=({...e})=>hp("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:hp("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 aa=class extends lt{constructor(r,o,n,i){super("privy",o,n,i);this.connectorType="embedded";this.proxyProvider=r,this.subscribeListeners()}async initialize(){await this.syncAccounts(),this.emit("initialized"),this.initialized=!0}async connect(r){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[mo(r?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:ia,id:"io.privy.wallet"}}disconnect(){this.connected=!1}async promptConnection(){}};import{jsx as yp}from"react/jsx-runtime";var Go=({style:e,...t})=>yp("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...t,children:yp("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 ht,jsxs as og}from"react/jsx-runtime";var Vo=({style:e,...t})=>og("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:[ht("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),ht("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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 gp,jsxs as ng}from"react/jsx-runtime";var or=({style:e,...t})=>ng("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:[gp("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),gp("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 $o=class extends lt{constructor(r,o,n,i,a){super(a||"unknown",r,o,n);this.connectorType="injected";this.proxyProvider=new ge(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=i;let l=i.provider;this.proxyProvider.setWalletProvider(l)}async initialize(){await this.syncAccounts(),this.emit("initialized"),this.initialized=!0}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 Y("Unable to retrieve accounts");await this.syncAccounts([r[0]])}catch(r){throw Bt(r)}}},zo,qo=class extends lt{constructor(r,o,n,i,a){super(a??"unknown",r,o,n);this.connectorType="injected";Li(this,zo,void 0);this.proxyProvider=new ge(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(i),a==="metamask"?Js(this,zo,{name:"MetaMask",icon:Vo,id:"io.metamask"}):a==="phantom"&&Js(this,zo,{name:"Phantom",icon:or,id:"phantom"})}async initialize(){await this.syncAccounts(),this.emit("initialized"),this.initialized=!0}async connect(r){return r.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return Xc(this,zo)??{name:"Browser Extension",icon:Go,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 Y("Unable to retrieve accounts");await this.syncAccounts([r[0]])}catch(r){throw Bt(r)}}};zo=new WeakMap;import{getAddress as l6}from"@ethersproject/address";import{Web3Provider as d6}from"@ethersproject/providers";import{isMobile as ig}from"react-device-detect";var sa=class extends $o{disconnect(){console.warn("MetaMask does not support programmatic disconnect.")}async promptConnection(){try{ig||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 Y("Unable to retrieve accounts");await this.syncAccounts([t[0]])}catch(t){throw Bt(t)}}};var la=class extends lt{constructor(r,o){super(r,[],o,{});this.connectorType="null";this.proxyProvider=new ge(void 0,uo);this.connectorType=r}get walletBranding(){return{name:"Wallet",id:""}}async initialize(){this.emit("initialized"),this.initialized=!0}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 ca=class extends la{constructor(t){super("phantom",t)}get walletBranding(){return{name:"Phantom",icon:or,id:"phantom"}}};import{EthereumProvider as xg,OPTIONAL_EVENTS as Sg,OPTIONAL_METHODS as _g}from"@walletconnect/ethereum-provider";import{isMobile as Ag}from"react-device-detect";import{createContext as gg,useContext as vg,useEffect as fl,useRef as wg,useState as Cg}from"react";import{jsx as ag}from"react/jsx-runtime";function da({src:e,...t}){return ag("img",{src:e,...t,style:{display:"none"}})}import{useContext as Up,useEffect as Dp,useMemo as mg,useState as fg}from"react";import{createContext as hg}from"react";var xt={appearance:{theme:"light",accentColor:"#676FFF",walletList:["detected_wallets","metamask","coinbase_wallet","rainbow","wallet_connect"]},walletConnectCloudProjectId:Wd,rpcConfig:{rpcUrls:{},rpcTimeouts:{}},captchaEnabled:!1,_render:{inDialog:!0,inParentNodeId:null},fiatOnRamp:{useSandbox:!1}};var vp=({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 sg=new Set(["coinbase_wallet","cryptocom","metamask","okx_wallet","phantom","rainbow","uniswap","zerion","wallet_connect","detected_wallets"]),wp=e=>sg.has(e),Cp=(e,t,r)=>r.indexOf(e)===t,bp=({input:e,overrides:t})=>t?t.primary.concat(t.overflow??[]).filter(wp).filter(Cp):e?e.filter(wp).filter(Cp):xt.appearance.walletList;var pa={id:42161,name:"Arbitrum One",network:"arbitrum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{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 ua={id:421613,name:"Arbitrum Goerli",network:"arbitrum-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"AGOR",decimals:18},rpcUrls:{alchemy:{http:["https://arb-goerli.g.alchemy.com/v2"],webSocket:["wss://arb-goerli.g.alchemy.com/v2"]},infura:{http:["https://arbitrum-goerli.infura.io/v3"],webSocket:["wss://arbitrum-goerli.infura.io/ws/v3"]},default:{http:["https://goerli-rollup.arbitrum.io/rpc"]},public:{http:["https://goerli-rollup.arbitrum.io/rpc"]}},blockExplorers:{etherscan:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"},default:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"}},testnet:!0};var ma={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 Ep={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 Pp={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 fa={id:8453,network:"base",name:"Base",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{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 ha={id:84531,network:"base-goerli",name:"Base Goerli Testnet",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{blast:{http:["https://base-goerli.blastapi.io"],webSocket:["wss://base-goerli.blastapi.io"]},default:{http:["https://goerli.base.org"]},public:{http:["https://goerli.base.org"]}},blockExplorers:{etherscan:{name:"Basescan",url:"https://goerli.basescan.org"},default:{name:"Basescan",url:"https://goerli.basescan.org"}},testnet:!0};var ya={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 Tp={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 xp={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 Sp={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 _p={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 Ap={id:5,network:"goerli",name:"Goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://goerli.rpc.privy.systems"]},alchemy:{http:["https://eth-goerli.g.alchemy.com/v2"],webSocket:["wss://eth-goerli.g.alchemy.com/v2"]},infura:{http:["https://goerli.infura.io/v3"],webSocket:["wss://goerli.infura.io/ws/v3"]},default:{http:["https://rpc.ankr.com/eth_goerli"]},public:{http:["https://rpc.ankr.com/eth_goerli"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://goerli.etherscan.io"},default:{name:"Etherscan",url:"https://goerli.etherscan.io"}},testnet:!0};var kp={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 Rp={id:59144,network:"linea-mainnet",name:"Linea Mainnet",nativeCurrency:{name:"Linea Ether",symbol:"ETH",decimals:18},rpcUrls:{infura:{http:["https://linea-mainnet.infura.io/v3"],webSocket:["wss://linea-mainnet.infura.io/ws/v3"]},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 Ip={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 ga={id:10,name:"OP Mainnet",network:"optimism",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{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 va={id:420,name:"Optimism Goerli Testnet",network:"optimism-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{alchemy:{http:["https://opt-goerli.g.alchemy.com/v2"],webSocket:["wss://opt-goerli.g.alchemy.com/v2"]},infura:{http:["https://optimism-goerli.infura.io/v3"],webSocket:["wss://optimism-goerli.infura.io/ws/v3"]},default:{http:["https://goerli.optimism.io"]},public:{http:["https://goerli.optimism.io"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"},default:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"}},testnet:!0};var wa={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 zn={id:137,name:"Polygon Mainnet",network:"matic",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{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 $n={id:80001,name:"Mumbai",network:"maticmum",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{privy:{http:["https://polygon-mumbai.rpc.privy.systems"]},alchemy:{http:["https://polygon-mumbai.g.alchemy.com/v2"],webSocket:["wss://polygon-mumbai.g.alchemy.com/v2"]},infura:{http:["https://polygon-mumbai.infura.io/v3"],webSocket:["wss://polygon-mumbai.infura.io/ws/v3"]},default:{http:["https://matic-mumbai.chainstacklabs.com"]},public:{http:["https://matic-mumbai.chainstacklabs.com"]}},blockExplorers:{etherscan:{name:"PolygonScan",url:"https://mumbai.polygonscan.com"},default:{name:"PolygonScan",url:"https://mumbai.polygonscan.com"}},testnet:!0};var Mp={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 Wp={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 Ca={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 ba={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 Ea={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 qn=[pa,ua,ma,Ap,Wp,Ho,ga,va,wa,zn,$n,Tp,xp,Sp,_p,fa,ha,ya,Rp,Ip,Ep,Pp,Ca,Ea,ba,kp,Mp],kP=new Set(qn.map(e=>e.id));import yo from"tinycolor2";var Lp="#FFFFFF",lg="#000000",cg=Lp,dg="#1E1E1D";function pg(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 Hr(e,t){let r=Math.max(0,Math.min(1,e.toHsl().l+t));return yo({...e.toHsl(),l:r})}function Op({backgroundTheme:e,accentHex:t,successHex:r="#51BA81",warnHex:o="#FFB74D",errorHex:n="#EC6351",whiteHex:i=Lp,blackHex:a=lg}){let l;switch(e){case"light":l=cg;break;case"dark":l=dg;break;default:l=e;break}let s=yo(l),c=yo(t),u=yo(r),h=yo(o),f=yo(n),y=pg(s.getLuminance()),E=Hr(s,y==="light"?-.04:.11),v=Hr(s,y==="light"?-.88:.87),x=Hr(s,y==="light"?-.77:.75),C=Hr(s,y==="light"?-.43:.45).desaturate(y==="light"?60:20),T=Hr(s,y==="light"?-.08:.25).desaturate(y==="light"?60:20),R=Hr(c,.15),I=Hr(c,-.06),_=yo(c.getLuminance()>.5?a:i),F=Hr(u,-.16);return{colorScheme:y,background:s.toHslString(),background2:E.toHslString(),foreground:v.toHslString(),foreground2:x.toHslString(),foreground3:C.toHslString(),foreground4:T.toHslString(),accent:c.toHslString(),accentLight:R.toHslString(),accentDark:I.toHslString(),foregroundAccent:_.toHslString(),success:u.toHslString(),successDark:F.toHslString(),error:f.toHslString(),warn:h.toHslString()}}function pl(e,t,r){let o=r?console.warn:()=>{},n=["google","twitter","discord","spotify","tiktok","linkedin","github","apple","farcaster"],i=t?.loginMethods?.filter($=>n.includes($)),a,l,s,c,u,h,f,y,E,v,x,C;t?.loginMethods?(a=t.loginMethods.includes("email"),l=t.loginMethods.includes("sms"),s=t.loginMethods.includes("wallet"),c=i?.includes("google"),u=i?.includes("twitter"),h=i?.includes("discord"),y=i?.includes("spotify"),f=i?.includes("tiktok"),v=i?.includes("github"),E=i?.includes("linkedin"),x=i?.includes("apple"),C=i?.includes("farcaster")):(a=e.emailAuth,l=e.smsAuth,s=e.walletAuth,c=e.googleOAuth,u=e.twitterOAuth,h=e.discordOAuth,v=e.githubOAuth,y=e.spotifyOAuth,f=e.tiktokOAuth,E=e.linkedinOAuth,x=e.appleOAuth,C=e.farcasterAuth);let T=[a,l].filter(Boolean),R=[c,u,h,v,y,f,E,x,C].filter(Boolean),I=[s].filter(Boolean);if(T.length+R.length+I.length===0)throw new Error("You must enable at least one login method");let _=t?.appearance?.showWalletLoginFirst!==void 0?t?.appearance?.showWalletLoginFirst:e.showWalletLoginFirst;_&&I.length===0?(o("You should only enable `showWalletLoginFirst` when `wallet` logins are also enabled. `showWalletLoginFirst` has been set to false"),_=!1):!_&&R.length+T.length===0&&(o("You should only disable `showWalletLoginFirst` when `email`, `sms`, or social logins are also enabled. `showWalletLoginFirst` has been set to true"),_=!0),t?.loginMethods&&t.loginMethodsAndOrder&&o("You should only configure one of `loginMethods` or `loginMethodsAndOrder`"),t?.appearance?.walletList&&t.loginMethodsAndOrder&&o("You should only configure one of `appearance.walletList` or `loginMethodsAndOrder`");let F=bp({input:t?.appearance?.walletList,overrides:t?.loginMethodsAndOrder}),U=vp({input:t?.loginMethodsAndOrder}),B=t?.intl?.defaultCountry??"US",{chains:k,defaultChain:z}=ug({additionalChains:t?.additionalChains,supportedChains:t?.supportedChains,defaultChainFromConfig:t?.defaultChain,hasRpcConfigDefined:Object.keys(t?.rpcConfig?.rpcUrls??{}).length>0}),L=!!t?.defaultChain||!!t?.supportedChains,j=t?.customAuth?.getCustomAccessToken&&t?.customAuth?.enabled!==!1,ie,ee=!(e.enforceWalletUis??!0);if(e.legacyWalletUiConfig??!0?j?ie=t?.embeddedWallets?.noPromptOnSignature??!0:ie=t?.embeddedWallets?.noPromptOnSignature??ee:ie=ee,t?.embeddedWallets?.waitForTransactionConfirmation===!1&&ie!==!0)throw new Error("Overriding `config.embeddedWallets.waitForTransactionConfirmation` requires that you disable wallet UIs in the dashboard.");return{id:e.id,name:e.name,allowlistConfig:e.allowlistConfig,legacyWalletUiConfig:e.legacyWalletUiConfig,appearance:{logo:t?.appearance?.logo??e.logoUrl,palette:Op({backgroundTheme:t?.appearance?.theme??xt.appearance.theme,accentHex:t?.appearance?.accentColor??e.accentColor??xt.appearance.accentColor}),loginGroupPriority:_?"web3-first":"web2-first",hideDirectWeb2Inputs:!!t?.appearance?.hideDirectWeb2Inputs,walletList:F},loginMethods:{wallet:s,email:a,sms:l,google:c,twitter:u,discord:h,github:v,spotify:y,tiktok:f,linkedin:E,apple:x,farcaster:C},loginMethodsAndOrder:U,legal:{termsAndConditionsUrl:t?.legal?.termsAndConditionsUrl??e.termsAndConditionsUrl,privacyPolicyUrl:t?.legal?.privacyPolicyUrl??e.privacyPolicyUrl,requireUsersAcceptTerms:e.requireUsersAcceptTerms??!1},walletConnectCloudProjectId:t?.walletConnectCloudProjectId??e.walletConnectCloudProjectId??xt.walletConnectCloudProjectId,rpcConfig:{rpcUrls:t?.rpcConfig?.rpcUrls??xt.rpcConfig.rpcUrls,rpcTimeouts:t?.rpcConfig?.rpcTimeouts??xt.rpcConfig.rpcTimeouts},chains:k,defaultChain:z,intl:{defaultCountry:B},shouldEnforceDefaultChainOnConnect:L,captchaEnabled:e.captchaEnabled??xt.captchaEnabled,captchaSiteKey:e.captchaSiteKey,embeddedWallets:{...e.embeddedWalletConfig,...j?{createOnLogin:"all-users",requireUserPasswordOnCreate:!1}:{},waitForTransactionConfirmation:!0,priceDisplay:{primary:"fiat-currency",secondary:"native-token"},...t?.embeddedWallets,noPromptOnSignature:ie},mfa:{methods:e.mfaMethods??[],noPromptOnMfaRequired:t?.mfa?.noPromptOnMfaRequired??!1},customAuth:j?{enabled:!0,...t.customAuth}:void 0,fiatOnRamp:{enabled:e.fiatOnRampEnabled,useSandbox:t?.fiatOnRamp?.useSandbox??xt.fiatOnRamp.useSandbox},loginConfig:{twitterOAuthOnMobileEnabled:e.twitterOAuthOnMobileEnabled??!1},render:{inDialog:t?._render?.inDialog??xt._render.inDialog,inParentNodeId:t?._render?.inParentNodeId??xt._render.inParentNodeId}}}function Np(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,...r?{...r,...r.logo&&typeof r.logo?{logo:"component"}:void 0}:void 0,legacyCreateEmbeddedWalletFlag:t}}function ug({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:qn.find(u=>u.id===s.id)??s)}else n=qn.concat(e??[]);let i=t?n[0]:Ho,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}}import{jsx as yg}from"react/jsx-runtime";var Fp={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",requireUserPasswordOnCreate:!1},fiatOnRampEnabled:!1,captchaEnabled:!1,captchaSiteKey:""},ul=pl(Fp,void 0,!1),ml=hg({appConfig:ul,isServerConfigLoaded:!1}),Bp=({children:e,legacyCreateEmbeddedWalletFlag:t,client:r,clientConfig:o})=>{let[n,i]=fg(null),a=mg(()=>pl(n??Fp,o,!!n),[n,o]);return Dp(()=>{let l=Np(o,t);r.createAnalyticsEvent("sdk_initialize",l)},[o,t]),Dp(()=>{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)}})()},[]),yg(ml.Provider,{value:{appConfig:a,isServerConfigLoaded:!!n},children:e})},Pa=()=>{let{appConfig:e}=Up(ml);return e},Ta=()=>{let{isServerConfigLoaded:e}=Up(ml);return e};var b=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};import{jsx as Eg,jsxs as Pg}from"react/jsx-runtime";var Hp=gg({ready:!1,app:ul,currentScreen:null,lastScreen:null,navigate:b,navigateBack:b,resetNavigation:b,setModalData:b,onUserCloseViaDialogOrKeybindRef:void 0}),bg=["LANDING","CONNECT_ONLY_LANDING_SCREEN",null],Gp=e=>{let t=Pa(),r=e.authenticated,[o,n]=Cg(e.initialScreen);fl(()=>{!r&&!bg.includes(e.initialScreen)&&e.setInitialScreen(null)},[r]);let i=wg(null);fl(()=>{e.open||(i.current=null)},[e.open]),fl(()=>{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 Pg(Hp.Provider,{value:a,children:[(typeof t.appearance.logo=="string"||t.appearance.logo?.type==="img")&&Eg(da,{src:typeof t.appearance.logo=="string"?t.appearance.logo:t.appearance.logo.props.src}),e.children]})},S=()=>vg(Hp);import{jsx as jo,jsxs as Tg}from"react/jsx-runtime";var jn=({style:e,...t})=>{let{app:r}=S();return Tg("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:[jo("rect",{width:"28",height:"28",rx:"3",fill:r?.appearance.palette.colorScheme==="dark"?"#3396ff":"#141414"}),jo("g",{clipPath:"url(#clip0_1765_9946)",children:jo("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"})}),jo("defs",{children:jo("clipPath",{id:"clip0_1765_9946",children:jo("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})};var nr=class extends lt{constructor(r,o,n,i,a,l,s){super(s||"unknown",n,i,o);this.connectorType="wallet_connect_v2";this.privyAppId=l,this.walletConnectCloudProjectId=r,this.rpcConfig=o,this.shouldEnforceDefaultChainOnConnect=a,this.proxyProvider=new ge(void 0,this.rpcTimeoutDuration),s&&(this.walletEntry=Do[s],this.walletClientType=s)}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=Zi(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=n?.entry,this.walletClientType=n?.walletClientType||"unknown"}this.connected=!0,await this.syncAccounts()}this.emit("initialized"),this.initialized=!0;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:Vo,id:"io.metamask"}:{name:qd(this.walletProvider?.session?.peer.metadata.name||"")||"WalletConnect",icon:this.walletProvider?.session?.peer.metadata.icons?.[0]||jn,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=Do[r],this.walletClientType=r,this.redirectUri=void 0,Xd(),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise((r,o)=>{let n=()=>{o(new Fo)};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 Y("Unable to retrieve address");if(this.walletProvider?.session?.peer.metadata.url){let s=Zi(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=s?.entry,this.walletClientType=s?.walletClientType||"unknown",this.proxyProvider.rpcTimeoutDuration=Bo(this.rpcConfig,this.walletClientType)}this.connected=!0,await this.syncAccounts(l),r()})().catch(a=>{if(a){o(Bt(a));return}o(new Y("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=Yi(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 xg.init({projectId:this.walletConnectCloudProjectId,chains:o,optionalChains:n,optionalEvents:Sg,optionalMethods:_g,rpcMap:r,showQrModal:!1});return i.on("display_uri",a=>{if(i.signer.abortPairingAttempt(),Ag&&this.walletEntry){let{redirect:l,href:s}=Zd(a,this.walletEntry);ep({href:s,name:this.walletEntry.displayName}),this.redirectUri=l,Qi(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=Zi(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 hl=e=>{let t=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return t?!!e?.linkedAccounts.filter(o=>o.type=="wallet"&&o.address===Vp(t)).length:!1},Bo=(e,t)=>e.rpcTimeouts?e.rpcTimeouts[t]||uo:uo,Kn=class extends kg{constructor(r,o,n,i,a,l,s,c){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 ge: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.initializedWalletConnectors=0,this.walletsReady=!1,this.storedConnections=this.loadConnectionHistory()}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;ce.get(al)&&(ce.getKeys().forEach(o=>{o.startsWith("walletconnect")&&ce.del(o)}),ce.del(al));let r=jd(this.store,this.walletList).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"),!Dr()&&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.initializedWalletConnectors++,this.walletsReady=this.initializedWalletConnectors===this.walletConnectors.length,this.emit("walletsUpdated")}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 ta(r,o,this.rpcConfig,this.chains,i,n.id),s=new aa(l,this.chains,n,this.rpcConfig);this.addWalletConnector(s)}}removeEmbeddedWalletConnector(){let r=this.findWalletConnector("embedded","privy");if(r){let o=this.walletConnectors.indexOf(r);this.walletConnectors.splice(o,1),this.saveConnectionHistory(),this.storedConnections=this.loadConnectionHistory(),this.emit("walletsUpdated")}}async createWalletConnector(r,o,n){let i=this.findWalletConnector(r,o);if(i)return i instanceof nr&&i.resetConnection(o),i;let l=(()=>{if(r==="injected"){if(o==="metamask"&&n?.eip6963InjectedProvider)return new sa(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask");if(o==="metamask"&&n?.legacyInjectedProvider)return new qo(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"metamask");if(o==="phantom"&&n?.legacyInjectedProvider)return new qo(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"phantom");if(n?.legacyInjectedProvider&&o==="unknown_browser_extension")return new qo(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider);if(n?.eip6963InjectedProvider)return new $o(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,o)}else return r==="coinbase_wallet"?new na(this.chains,this.defaultChain,this.rpcConfig,this.privyAppId):r==="phantom"?new ca(this.defaultChain):new nr(this.walletConnectCloudProjectId,this.rpcConfig,this.chains,this.defaultChain,this.shouldEnforceDefaultChainOnConnect,this.privyAppId,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()}loadConnectionHistory(){let r=a=>a&&typeof a.address=="string"&&typeof a.connectorType=="string"&&typeof a.walletClientType=="string"&&typeof a.connectedAt=="number",o=ce.get(sl);return o&&Array.isArray(o)&&o.map(a=>r(a)).every(Boolean)?o:[]}saveConnectionHistory(){let r=this.wallets.map(o=>({address:o.address,connectorType:o.connectorType,walletClientType:o.walletClientType,connectedAt:o.connectedAt}));ce.put(sl,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=Vp(r),this.emit("walletsUpdated")}};function ra(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}import{ofetch as Rg}from"ofetch";var Ig=[Di,Fi,Ui],xa=class{constructor(t,r,o){this.appId=t,this.clientAnalyticsId=r.clientAnalyticsId,this.sdkVersion=ol,this.client=r,this.defaults=o,this.fallbackApiUrl=r.fallbackApiUrl,this.baseFetch=Rg.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:n,options:i})=>{let a=new Headers(i.headers);a.set("privy-app-id",this.appId),a.set("privy-ca-id",this.clientAnalyticsId||""),a.set("privy-client",`react-auth:${this.sdkVersion}`);let l=!Ig.includes(n.toString());if(!a.has("authorization")&&l){let s=await this.client.getAccessToken();s!==null&&a.set("authorization",`Bearer ${s}`)}i.headers=a},onRequestError:({error:n})=>{if(n instanceof DOMException&&n.name==="AbortError")throw new Oi}})}async get(t,r){try{return await this.baseFetch(t,r)}catch(o){throw le(o)}}async post(t,r,o){try{return await this.baseFetch(t,{method:"POST",...r?{body:r}:{},...o})}catch(n){throw le(n)}}async delete(t,r){try{return await this.baseFetch(t,{method:"DELETE",...r})}catch(o){throw le(o)}}};import go from"js-cookie";function zp(e){return e instanceof Nr?"email":e instanceof ho?"sms":e instanceof fo?"siwe":e instanceof Mo?"custom_auth":e instanceof er?e.meta.provider:null}import*as $p from"jose";var ir=class{static parse(t){try{return new ir(t)}catch{return null}}constructor(t){this.value=t,this._decoded=$p.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 Mg=30,Sa=class{constructor(){this.authenticateOnce=new Xe(async t=>this._authenticate(t)),this.linkOnce=new Xe(async t=>this._link(t)),this.refreshOnce=new Xe(this._refresh.bind(this)),this.destroyOnce=new Xe(this._destroy.bind(this)),this.forkSessionOnce=new Xe(this._forkSession.bind(this))}get token(){try{let t=ce.get(co);return typeof t=="string"?new ir(t).value:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get refreshToken(){try{let t=ce.get(zi);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get forkedToken(){try{let t=ce.get(Dn);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get mightHaveServerCookies(){try{let t=go.get($i);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"}hasRecoveryCredentials(){return typeof this.forkedToken=="string"}hasActiveToken(){let t=ir.parse(this.token);return t!==null&&!t.isExpired(Mg)}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{token:r,refresh_token:o,user:n,is_new_user:i}=await t.authenticate();this.storeToken(r),this.storeRefreshToken(o);let a=zp(t);return a&&this.client&&this.client.createAnalyticsEvent("sdk_authenticate",{method:a,isNewUser:i}),a==="siwe"&&this.client&&this.client.createAnalyticsEvent("sdk_authenticate_siwe",{connectorType:t.meta.connectorType,walletClientType:t.meta.walletClientType}),{user:ft(n),isNewUser:i}}catch(r){throw console.warn("Error authenticating session"),Ze(r)}}async _link(t){try{let r=await t.link();return ft(r)}catch(r){throw console.warn("Error linking account"),Ze(r)}}async _refresh(){if(!this.api)throw new P("Session has no API instance");if(!this.client)throw new P("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(Di,a,{headers:i}),o&&this.clearForkedToken()}else if(o)n=await this.api.post(Fi,{refresh_token:o}),this.clearForkedToken();else return null;return n.session_update_action==="set"&&(this.storeToken(n.token),this.storeRefreshToken(n.refresh_token)),n.session_update_action==="clear"&&this.destroyLocalState(),n.session_update_action==="ignore"&&n.token&&this.storeToken(n.token),ft(n.user)}catch(n){if(n instanceof Xt&&n.privyErrorCode==="missing_or_invalid_token")return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw Ze(n)}}async _destroy(){try{await this.api?.post(Ui,{refresh_token:this.refreshToken})}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new P("Session has no API instance");let t=this.refreshToken;try{let r=await this.api.post(td,{refresh_token:t});return this.storeToken(r.token),this.storeRefreshToken(r.refresh_token),r.new_session_refresh_token}catch(r){throw Ze(r)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),this.clearForkedToken(),this.client?.onDeleteToken?.()}storeToken(t){if(typeof t=="string"){let r=ce.get(co);if(ce.put(co,t),r!==t&&this.client?.onStoreToken?.(t),!this.client?.useServerCookies){let o=ir.parse(t)?.expiration;go.set(nl,t,{sameSite:"Strict",secure:!0,expires:o?new Date(o*1e3):void 0})}}else ce.del(co),go.remove(nl)}storeRefreshToken(t){typeof t=="string"?(ce.put(zi,t),this.client?.useServerCookies||(go.set($i,"t",{sameSite:"Strict",secure:!0,expires:30}),go.set(il,t,{sameSite:"Strict",secure:!0,expires:30}))):(ce.del(zi),go.remove(il),go.remove($i))}clearForkedToken(){ce.del(Dn)}};var yl,_a,qp,Yn=class{constructor(t){Li(this,_a);this.apiUrl=t.apiUrl||Vi,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=!1,this.timeout=t.timeout||Ld,this.appId=t.appId,this.clientAnalyticsId=ed(this,_a,qp).call(this),yl||(yl=new Sa),this.session=yl,this.api=this.generateApi(),this.session.client=this}initializeConnectorManager(t,r,o,n,i,a,l){this.connectors||(this.connectors=new Kn(this.appId,t,r,o,n,i,a,l))}generateApi(){let t=new xa(this.appId,this,{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 P("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new P("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}startMfaFlow(t){t.api=this.api,this.mfaFlow=t}async unlinkEmail(t){try{let r=await this.api.post(fd,{address:t});return ft(r)}catch(r){throw Ze(r)}}async acceptTerms(){try{let t=await this.api.post(Sd,{});return ft(t)}catch(t){throw Ze(t)}}async unlinkPhone(t){try{let r=await this.api.post(vd,{phoneNumber:t});return ft(r)}catch(r){throw Ze(r)}}async unlinkWallet(t){try{let r=await this.api.post(id,{address:t});return ft(r)}catch(r){throw Ze(r)}}async unlinkOAuth(t,r){try{let o=await this.api.post(Pd,{provider:t,subject:r});return ft(o)}catch(o){throw Ze(o)}}async unlinkFarcaster(t){try{let r=await this.api.post(dd,{fid:t});return ft(r)}catch(r){throw Ze(r)}}async createAnalyticsEvent(t,r,o){if(!(typeof window>"u"))try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(_d,{event_name:t,client_id:this.clientAnalyticsId,payload:{...r||{},clientTimestamp:o?o.toISOString():new Date().toISOString()}})}catch{}}async signMoonpayOnRampUrl(t){try{return this.api.post(Ad,t)}catch(r){throw Ze(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()||this.session.hasRecoveryCredentials()?this.session.refresh():null}async getAccessToken(t){return this.session.hasActiveToken()?ir.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=await this.api.get(`/api/v1/apps/${this.appId}`,{baseURL:this.fallbackApiUrl});return{id:t.id,name:t.name,verificationKey:t.verification_key,logoUrl:t.logo_url||void 0,accentColor:t.accent_color||void 0,showWalletLoginFirst:t.show_wallet_login_first,allowlistConfig:{errorTitle:t.allowlist_config.error_title,errorDetail:t.allowlist_config.error_detail,errorCtaText:t.allowlist_config.cta_text,errorCtaLink:t.allowlist_config.cta_link},walletAuth:t.wallet_auth,emailAuth:t.email_auth,smsAuth:t.sms_auth,googleOAuth:t.google_oauth,twitterOAuth:t.twitter_oauth,discordOAuth:t.discord_oauth,githubOAuth:t.github_oauth,spotifyOAuth:t.spotify_oauth,tiktokOAuth:t.tiktok_oauth,linkedinOAuth:t.linkedin_oauth,appleOAuth:t.apple_oauth,farcasterAuth:t.farcaster_auth,termsAndConditionsUrl:t.terms_and_conditions_url,embeddedWalletConfig:{createOnLogin:t.embedded_wallet_config?.create_on_login,requireUserPasswordOnCreate:t.embedded_wallet_config?.require_user_password_on_create},privacyPolicyUrl:t.privacy_policy_url,requireUsersAcceptTerms:t.require_users_accept_terms,customApiUrl:t.custom_api_url,walletConnectCloudProjectId:t.wallet_connect_cloud_project_id,fiatOnRampEnabled:t.fiat_on_ramp_enabled,captchaEnabled:t.captcha_enabled,captchaSiteKey:t.captcha_site_key,twitterOAuthOnMobileEnabled:t.twitter_oauth_on_mobile_enabled,createdAt:new Date(t.created_at*1e3),updatedAt:new Date(t.updated_at*1e3),mfaMethods:t.mfa_methods,enforceWalletUis:t.enforce_wallet_uis,legacyWalletUiConfig:t.legacy_wallet_ui_config}}catch(t){throw Ze(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 forkSession(){return await this.session.forkSession()}};_a=new WeakSet,qp=function(){if(typeof window>"u")return null;try{let r=ce.get(Un);if(typeof r=="string"&&r.length>0)return r}catch{}let t=Wg();try{return ce.put(Un,t),t}catch{return t}};import{Turnstile as Fg}from"@marsidev/react-turnstile";import{useEffect as Bg,useMemo as Hg}from"react";import{useMemo as Lg,useRef as Og,useContext as Ng,useState as gl,createContext as Dg}from"react";import{jsx as Ug}from"react/jsx-runtime";var jp=Dg({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}),Ht=class extends He{constructor(r,o,n){super(r||"Captcha failed");this.type="Captcha";o instanceof Error&&(this.cause=o),this.privyErrorCode=n}},Kp=({children:e,id:t,captchaSiteKey:r,captchaEnabled:o})=>{let n=Og(null),[i,a]=gl(),[l,s]=gl(),[c,u]=gl(!1),h=Lg(()=>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 Ug(jp.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 zd(()=>n.current?.getResponse(),{interval:200,timeout:2e4})}catch{throw new Ht("Captcha failed",null,"captcha_timeout")}}},children:e})},de=()=>Ng(jp);import{jsx as Yp}from"react/jsx-runtime";var vl=e=>{let{enabled:t,siteKey:r,appId:o,setError:n,setToken:i,setExecuting:a,ref:l}=de(),[,s]=Hg(()=>r?.split("t:")||[],[r]);if(Bg(()=>l.current?.remove,[]),!t)return null;if(!s)throw new Error("Unsupported captcha site key");return Yp("div",{className:"hidden h-0 w-0",children:Yp(Fg,{...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 t4,useEffect as gy,useRef as r4,useState as o4}from"react";import n4 from"react-dom";import{createContext as Gg,useContext as Vg}from"react";var wl=Gg({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,loginWithOAuth:b,refreshUser:b,walletProxy:null,createAnalyticsEvent:b,acceptTerms:b,getUsdTokenPrice:b,recoverEmbeddedWallet:b,getFiatOnRampConfig:b,updateWallets:b,fundWallet:b,setReadyToTrue:b}),W=()=>Vg(wl);import{createContext as zg,useContext as $g}from"react";var ae=zg({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,linkTiktok:b,linkLinkedIn:b,linkApple: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,unlinkTiktok:b,unlinkLinkedIn:b,unlinkApple:b,unlinkFarcaster:b,setActiveWallet:b,forkSession:b,createWallet:b,signMessage:b,signTypedData:b,enrollInMfa:b,initEnrollmentWithSms:b,initEnrollmentWithTotp:b,promptMfa:b,init:b,submitEnrollmentWithSms:b,submitEnrollmentWithTotp:b,unenroll:b,submit:b,cancel:b,sendTransaction:b,exportWallet:b,setWalletPassword:b,initLoginWithEmail:b,initLoginWithSms:b,loginWithCode:b,fundWallet:b,initLoginWithHeadlessOAuth:b,loginWithHeadlessOAuth:b,isHeadlessOAuthLoading:!1,isModalOpen:!1}),H=()=>$g(ae);import{useEffect as qg,useState as jg}from"react";var Jp=e=>{let[t,r]=jg("auto");return qg(()=>{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 Kg,useContext as Yg,useEffect as Jg}from"react";var Zp={login:{onComplete:[],onError:[]},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:[]}},Cl=Kg(void 0),Qp=()=>Yg(Cl);function ve(e,t){if(!t)return;let o=Qp().current[e];return Jg(()=>{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 N(e,t,r,...o){for(let n of e.current[t][r])n(...o)}function Xp(){let e=Qp();return(t,r,...o)=>N(e,t,r,...o)}function bl(e){ve("configureMfa",e)}import lu from"@heroicons/react/24/outline/ArrowTopRightOnSquareIcon";import p1 from"@heroicons/react/24/solid/DocumentCheckIcon";import u1 from"styled-components";import wo,{css as xl}from"styled-components";import Pl from"styled-components";import{Fragment as Qg,jsx as El,jsxs as Xg}from"react/jsx-runtime";var xr=({success:e,fail:t})=>Xg(Qg,{children:[El(St,{className:e?"success":t?"fail":""}),El(Tl,{className:e?"success":t?"fail":""})]}),St=Pl.span`
|
|
12
|
+
- https://privy.io`;this.getNonceOnce=new Xe(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 P("Auth flow has no API instance");try{let{message:t,signature:r}=await this.sign(),o=await this.api.post(od,{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 le(t)}}async link(){if(!this.api)throw new P("Auth flow has no API instance");try{let{message:t,signature:r}=await this.sign();return await this.api.post(nd,{message:t,signature:r,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(t){throw le(t)}}async sign(){if(!this.api)throw new P("Auth flow has no API instance");if(await this.buildSiweMessage(),!this.preparedMessage)throw new P("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 P("Auth flow has no API instance");let t=this.wallet.address;return(await this.api.post(rd,{address:t,token:this.captchaToken})).nonce}async buildSiweMessage(){if(!this.api)throw new P("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 ho=class{constructor(t,r){this.meta={phoneNumber:t,captchaToken:r}}async authenticate(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new P("phone number and sms code must be set prior to calling authenticate.");try{let t=await this.api.post(wd,{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 le(t)}}async link(){if(!this.api)throw new P("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new P("phone number and sms code must be set prior to calling authenticate.");try{return await this.api.post(gd,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(t){throw le(t)}}async sendSmsCode(t,r){if(!this.api)throw new P("Auth flow has no API instance");if(t&&(this.meta.phoneNumber=t),r&&(this.meta.captchaToken=r),!this.meta.phoneNumber)throw new P("phone nNumber must be set when initialzing authentication.");try{return await this.api.post(yd,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken})}catch(o){throw le(o)}}};import{v4 as Wg}from"uuid";function et(e){return new Date(e*1e3)}function zy(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,verifiedAt:et(r.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:et(r.verified_at)};t.push(i);break;case"phone":let a={number:r.phoneNumber,type:r.type,verifiedAt:et(r.verified_at)};t.push(a);break;case"google_oauth":let l={subject:r.subject,email:r.email,name:r.name,type:r.type,verifiedAt:et(r.verified_at)};t.push(l);break;case"spotify_oauth":let s={subject:r.subject,email:r.email,name:r.name,type:r.type,verifiedAt:et(r.verified_at)};t.push(s);break;case"twitter_oauth":let c={subject:r.subject,username:r.username,name:r.name,type:r.type,profilePictureUrl:r.profile_picture_url,verifiedAt:et(r.verified_at)};t.push(c);break;case"discord_oauth":let u={subject:r.subject,username:r.username,email:r.email,type:r.type,verifiedAt:et(r.verified_at)};t.push(u);break;case"github_oauth":let h={subject:r.subject,username:r.username,name:r.name,email:r.email,type:r.type,verifiedAt:et(r.verified_at)};t.push(h);break;case"tiktok_oauth":let f={subject:r.subject,username:r.username,name:r.name,type:r.type,verifiedAt:et(r.verified_at)};t.push(f);break;case"linkedin_oauth":let y={subject:r.subject,name:r.name,email:r.email,type:r.type,verifiedAt:et(r.verified_at)};t.push(y);break;case"apple_oauth":let E={subject:r.subject,email:r.email,type:r.type,verifiedAt:et(r.verified_at)};t.push(E);break;case"custom_auth":t.push({type:r.type,customUserId:r.custom_user_id,verifiedAt:et(r.verified_at)});break;case"farcaster":let v={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:et(r.verified_at)};t.push(v);break;default:console.warn(`Unrecognized account type: ${o}. Please consider upgrading the Privy SDK.`)}}return t}function Et(e,t){return e.sort((r,o)=>o.verifiedAt.getTime()-r.verifiedAt.getTime()),e.find(r=>r.type===t)}var ye=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy")||null,$y=e=>e.linkedAccounts.filter(t=>t.type==="wallet"),Pt=(e,t)=>t==="all-users"&&!ye(e)||t==="users-without-wallets"&&!$y(e)?.length;function ft(e){if(!e)return null;let t=zy(e.linked_accounts),r=Et(t,"wallet"),o=Et(t,"email"),n=Et(t,"phone"),i=Et(t,"google_oauth"),a=Et(t,"twitter_oauth"),l=Et(t,"discord_oauth"),s=Et(t,"github_oauth"),c=Et(t,"spotify_oauth"),u=Et(t,"tiktok_oauth"),h=Et(t,"linkedin_oauth"),f=Et(t,"apple_oauth"),y=Et(t,"farcaster"),E=e.mfa_methods.map(({type:x,verified_at:C})=>({type:x,verifiedAt:et(C)}));return{id:e.id,createdAt:et(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},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},tiktok:u&&{subject:u.subject,username:u.username,name:u.name},linkedin:h&&{subject:h.subject,name:h.name,email:h.email},apple:f&&{subject:f.subject,email:f.email},farcaster:y&&{fid:y.fid,ownerAddress:y.ownerAddress,displayName:y.displayName,username:y.username,bio:y.bio,pfp:y.pfp,url:y.url},mfaMethods:E.map(x=>x.type),hasAcceptedTerms:e.has_accepted_terms??!1}}import{getAddress as Vp}from"@ethersproject/address";import kg from"eventemitter3";import tg from"@coinbase/wallet-sdk";import{jsx as lp,jsxs as qy}from"react/jsx-runtime";var ea=({style:e,...t})=>qy("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:[lp("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),lp("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 rr}from"@ethersproject/address";import{Web3Provider as fp}from"@ethersproject/providers";import{default as Xy}from"eventemitter3";import Qy from"eventemitter3";var jy=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4"],cp=e=>jy.includes(e);import{ErrorCode as Ky}from"@ethersproject/logger";var Uo=class extends Y{constructor(){super("Wallet timeout");this.type="wallet_error"}},Fo=class extends Y{constructor(){super("User rejected connection");this.type="wallet_error"}},Bt=e=>{if(e instanceof Y)return e;if(e?.code&&e?.reason){let t=new Ee(e);return e.code===Ky.ACTION_REJECTED&&(t.details=Ve.E4001_USER_REJECTED_REQUEST),t}return e?.code?new Ee(e):new Y("Unknown connector error",e)},Tt=class extends He{constructor(r,o,n){super(r);this.type="provider_error";this.code=o,this.data=n}},Ee=class extends Tt{constructor(r){let o=r;super(o.message,o.code,o.data);let n=Object.values(Ve).find(i=>i.eipCode===o.code);this.details=n||Ve.UNKNOWN_ERROR,o.code===-32002&&(o.message?.includes("already pending for origin")?o.message?.includes("wallet_requestPermissions")?this.details=Ve.E32002_CONNECTION_ALREADY_PENDING:this.details=Ve.E32002_REQUEST_ALREADY_PENDING:o.message?.includes("Already processing")&&o.message.includes("eth_requestAccounts")&&(this.details=Ve.E32002_WALLET_LOCKED))}},Yy={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}},Jy={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}},Zy={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}},Ve={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Zy,...Jy},Tr={...Yy,...Ve};var ge=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 Uo,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||uo,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 Y(`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 Bt(r)})}},Fr=class extends Error{constructor(r,o,n){super(r);this.code=o,this.data=n}},ta=class extends Qy{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=Pr(l,this.chains,n,{appId:a}),this.rpcTimeoutDuration=Bo(n,"privy"),this.appId=a}async handleSendTransaction(r){if(!r.params||!Array.isArray(r.params))throw new Fr(`Invalid params for ${r.method}`,4200);let o=r.params[0];if(!await Me()||!this.address)throw new Fr("Disconnected",4900);return(await up(o)).hash}handleSwitchEthereumChain(r){if(!r.params||!Array.isArray(r.params))throw new Fr(`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 Fr(`Invalid params for ${r.method}`,4200);this.chainId=Number(o),this.provider=Pr(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];return await dp(o)}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 pp(Ji(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:mo(this.chainId)};try{return await this.provider.send("eth_estimateGas",[o])}catch{return delete o.from,await this.provider.send("eth_estimateGas",[o])}}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 mo(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(cp(r.method)){let o=await Me();if(await mp(),!o||!this.address)throw new Fr("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 Fr("Disconnected",4900)}}else return this.provider.send(r.method,r.params)}async connect(){let r=await Me();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}}},tr=class extends ge{constructor(r){super(r,r.rpcTimeoutDuration)}},Br=class extends ge{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 eg=(e,t)=>{switch(t){case"coinbase_wallet":return e.message.includes("addEthereumChain");default:return e.code===4902||e.message?.includes("4902")}},lt=class extends Xy{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=No(r),this.walletClientType==="privy"&&ce.put(qi(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=Bo(i,r),this.connected=!1,this.initialized=!1}buildConnectedWallet(r,o,n){let i=async()=>!!this.wallets.find(a=>rr(a.address)===rr(r));return{address:rr(r),chainId:o,meta:n,switchChain:async a=>{if(!i)throw new Y("Wallet is not currently connected.");let l=this.wallets.find(f=>rr(f.address)===rr(r))?.chainId;if(!l)throw new Y("Unable to determine current chainId.");let s,c;if(typeof a=="number"?(s=`0x${a.toString(16)}`,c=a):(s=a,c=Number(a)),l===No(s))return;let u=this.chains.find(f=>f.id===c);if(!u)throw new Y(`Unsupported chainId: ${a}`);let h=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:s}]})};try{return await h()}catch(f){if(eg(f,this.walletClientType))return await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:s,chainName:u.name,nativeCurrency:u.nativeCurrency,rpcUrls:[u.rpcUrls.default?.http[0]??""],blockExplorerUrls:[u.blockExplorers?.default.url??""]}]}),h();throw this.walletClientType==="rainbow"&&f.message?.includes("wallet_switchEthereumChain")?new Y(`Rainbow does not support the chainId ${o}`):f}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:i,getEthereumProvider:async()=>{if(!await i())throw new Y("Wallet is not currently connected.");return this.proxyProvider},getEthersProvider:async()=>{if(!await i())throw new Y("Wallet is not currently connected.");return new fp(new tr(this.proxyProvider))},getWeb3jsProvider:async()=>{if(!await i())throw new Y("Wallet is not currently connected.");return new Br(this.proxyProvider)},sign:async a=>{if(!await i())throw new Y("Wallet is not currently connected.");return await this.sign(a)},disconnect:()=>{this.disconnect()}}}async syncAccounts(r){let o=r;try{if(o===void 0){let c=await this.proxyProvider.request({method:"eth_accounts"});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=rr(n),a=[],l;if(this.walletClientType==="privy"){let c=ce.get(qi(i));this.chains.find(u=>u.id===Number(c))||(ce.del(qi(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 this.proxyProvider.request({method:"eth_chainId"});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 ${ll}`,c),l=ll}let s=No(l);if(!a.find(c=>rr(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(rr(n),s,c))}ra(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=>rr(n)===rr(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 fp(new tr(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 Ho={id:1,network:"homestead",name:"Ethereum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{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 rg=(e,t)=>{let o=Yi(1,[Ho],{},t);return e.makeWeb3Provider(o,1)},oa,na=class extends lt{constructor(r,o,n,i,a){super("coinbase_wallet",r,o,n);this.connectorType="coinbase_wallet";this.proxyProvider=new ge(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),oa||(oa=new tg({appName:a,darkMode:!1,headlessMode:!1,enableMobileWalletLink:!0})),this.proxyProvider.setWalletProvider(rg(oa,i))}async initialize(){await this.syncAccounts(),this.emit("initialized"),this.initialized=!0}async connect(r){return r.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){oa.disconnect(),this.onDisconnect()}get walletBranding(){return{name:"Coinbase Wallet",icon:ea,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 Y("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([r[0]])}catch(r){throw Bt(r)}}};import{jsx as hp}from"react/jsx-runtime";var ia=({...e})=>hp("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:hp("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 aa=class extends lt{constructor(r,o,n,i){super("privy",o,n,i);this.connectorType="embedded";this.proxyProvider=r,this.subscribeListeners()}async initialize(){await this.syncAccounts(),this.emit("initialized"),this.initialized=!0}async connect(r){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[mo(r?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:ia,id:"io.privy.wallet"}}disconnect(){this.connected=!1}async promptConnection(){}};import{jsx as yp}from"react/jsx-runtime";var Go=({style:e,...t})=>yp("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...t,children:yp("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 ht,jsxs as og}from"react/jsx-runtime";var Vo=({style:e,...t})=>og("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:[ht("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),ht("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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"}),ht("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 gp,jsxs as ng}from"react/jsx-runtime";var or=({style:e,...t})=>ng("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:[gp("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),gp("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 $o=class extends lt{constructor(r,o,n,i,a){super(a||"unknown",r,o,n);this.connectorType="injected";this.proxyProvider=new ge(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=i;let l=i.provider;this.proxyProvider.setWalletProvider(l)}async initialize(){await this.syncAccounts(),this.emit("initialized"),this.initialized=!0}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 Y("Unable to retrieve accounts");await this.syncAccounts([r[0]])}catch(r){throw Bt(r)}}},zo,qo=class extends lt{constructor(r,o,n,i,a){super(a??"unknown",r,o,n);this.connectorType="injected";Li(this,zo,void 0);this.proxyProvider=new ge(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(i),a==="metamask"?Js(this,zo,{name:"MetaMask",icon:Vo,id:"io.metamask"}):a==="phantom"&&Js(this,zo,{name:"Phantom",icon:or,id:"phantom"})}async initialize(){await this.syncAccounts(),this.emit("initialized"),this.initialized=!0}async connect(r){return r.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return Xc(this,zo)??{name:"Browser Extension",icon:Go,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 Y("Unable to retrieve accounts");await this.syncAccounts([r[0]])}catch(r){throw Bt(r)}}};zo=new WeakMap;import{getAddress as l6}from"@ethersproject/address";import{Web3Provider as d6}from"@ethersproject/providers";import{isMobile as ig}from"react-device-detect";var sa=class extends $o{disconnect(){console.warn("MetaMask does not support programmatic disconnect.")}async promptConnection(){try{ig||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 Y("Unable to retrieve accounts");await this.syncAccounts([t[0]])}catch(t){throw Bt(t)}}};var la=class extends lt{constructor(r,o){super(r,[],o,{});this.connectorType="null";this.proxyProvider=new ge(void 0,uo);this.connectorType=r}get walletBranding(){return{name:"Wallet",id:""}}async initialize(){this.emit("initialized"),this.initialized=!0}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 ca=class extends la{constructor(t){super("phantom",t)}get walletBranding(){return{name:"Phantom",icon:or,id:"phantom"}}};import{EthereumProvider as xg,OPTIONAL_EVENTS as Sg,OPTIONAL_METHODS as _g}from"@walletconnect/ethereum-provider";import{isMobile as Ag}from"react-device-detect";import{createContext as gg,useContext as vg,useEffect as fl,useRef as wg,useState as Cg}from"react";import{jsx as ag}from"react/jsx-runtime";function da({src:e,...t}){return ag("img",{src:e,...t,style:{display:"none"}})}import{useContext as Up,useEffect as Dp,useMemo as mg,useState as fg}from"react";import{createContext as hg}from"react";var xt={appearance:{theme:"light",accentColor:"#676FFF",walletList:["detected_wallets","metamask","coinbase_wallet","rainbow","wallet_connect"]},walletConnectCloudProjectId:Wd,rpcConfig:{rpcUrls:{},rpcTimeouts:{}},captchaEnabled:!1,_render:{inDialog:!0,inParentNodeId:null},fiatOnRamp:{useSandbox:!1}};var vp=({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 sg=new Set(["coinbase_wallet","cryptocom","metamask","okx_wallet","phantom","rainbow","uniswap","zerion","wallet_connect","detected_wallets"]),wp=e=>sg.has(e),Cp=(e,t,r)=>r.indexOf(e)===t,bp=({input:e,overrides:t})=>t?t.primary.concat(t.overflow??[]).filter(wp).filter(Cp):e?e.filter(wp).filter(Cp):xt.appearance.walletList;var pa={id:42161,name:"Arbitrum One",network:"arbitrum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{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 ua={id:421613,name:"Arbitrum Goerli",network:"arbitrum-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"AGOR",decimals:18},rpcUrls:{alchemy:{http:["https://arb-goerli.g.alchemy.com/v2"],webSocket:["wss://arb-goerli.g.alchemy.com/v2"]},infura:{http:["https://arbitrum-goerli.infura.io/v3"],webSocket:["wss://arbitrum-goerli.infura.io/ws/v3"]},default:{http:["https://goerli-rollup.arbitrum.io/rpc"]},public:{http:["https://goerli-rollup.arbitrum.io/rpc"]}},blockExplorers:{etherscan:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"},default:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"}},testnet:!0};var ma={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 Ep={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 Pp={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 fa={id:8453,network:"base",name:"Base",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{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 ha={id:84531,network:"base-goerli",name:"Base Goerli Testnet",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{blast:{http:["https://base-goerli.blastapi.io"],webSocket:["wss://base-goerli.blastapi.io"]},default:{http:["https://goerli.base.org"]},public:{http:["https://goerli.base.org"]}},blockExplorers:{etherscan:{name:"Basescan",url:"https://goerli.basescan.org"},default:{name:"Basescan",url:"https://goerli.basescan.org"}},testnet:!0};var ya={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 Tp={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 xp={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 Sp={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 _p={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 Ap={id:5,network:"goerli",name:"Goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{privy:{http:["https://goerli.rpc.privy.systems"]},alchemy:{http:["https://eth-goerli.g.alchemy.com/v2"],webSocket:["wss://eth-goerli.g.alchemy.com/v2"]},infura:{http:["https://goerli.infura.io/v3"],webSocket:["wss://goerli.infura.io/ws/v3"]},default:{http:["https://rpc.ankr.com/eth_goerli"]},public:{http:["https://rpc.ankr.com/eth_goerli"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://goerli.etherscan.io"},default:{name:"Etherscan",url:"https://goerli.etherscan.io"}},testnet:!0};var kp={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 Rp={id:59144,network:"linea-mainnet",name:"Linea Mainnet",nativeCurrency:{name:"Linea Ether",symbol:"ETH",decimals:18},rpcUrls:{infura:{http:["https://linea-mainnet.infura.io/v3"],webSocket:["wss://linea-mainnet.infura.io/ws/v3"]},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 Ip={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 ga={id:10,name:"OP Mainnet",network:"optimism",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{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 va={id:420,name:"Optimism Goerli Testnet",network:"optimism-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{alchemy:{http:["https://opt-goerli.g.alchemy.com/v2"],webSocket:["wss://opt-goerli.g.alchemy.com/v2"]},infura:{http:["https://optimism-goerli.infura.io/v3"],webSocket:["wss://optimism-goerli.infura.io/ws/v3"]},default:{http:["https://goerli.optimism.io"]},public:{http:["https://goerli.optimism.io"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"},default:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"}},testnet:!0};var wa={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 zn={id:137,name:"Polygon Mainnet",network:"matic",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{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 $n={id:80001,name:"Mumbai",network:"maticmum",nativeCurrency:{name:"MATIC",symbol:"MATIC",decimals:18},rpcUrls:{privy:{http:["https://polygon-mumbai.rpc.privy.systems"]},alchemy:{http:["https://polygon-mumbai.g.alchemy.com/v2"],webSocket:["wss://polygon-mumbai.g.alchemy.com/v2"]},infura:{http:["https://polygon-mumbai.infura.io/v3"],webSocket:["wss://polygon-mumbai.infura.io/ws/v3"]},default:{http:["https://matic-mumbai.chainstacklabs.com"]},public:{http:["https://matic-mumbai.chainstacklabs.com"]}},blockExplorers:{etherscan:{name:"PolygonScan",url:"https://mumbai.polygonscan.com"},default:{name:"PolygonScan",url:"https://mumbai.polygonscan.com"}},testnet:!0};var Mp={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 Wp={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 Ca={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 ba={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 Ea={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 qn=[pa,ua,ma,Ap,Wp,Ho,ga,va,wa,zn,$n,Tp,xp,Sp,_p,fa,ha,ya,Rp,Ip,Ep,Pp,Ca,Ea,ba,kp,Mp],kP=new Set(qn.map(e=>e.id));import yo from"tinycolor2";var Lp="#FFFFFF",lg="#000000",cg=Lp,dg="#1E1E1D";function pg(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 Hr(e,t){let r=Math.max(0,Math.min(1,e.toHsl().l+t));return yo({...e.toHsl(),l:r})}function Op({backgroundTheme:e,accentHex:t,successHex:r="#51BA81",warnHex:o="#FFB74D",errorHex:n="#EC6351",whiteHex:i=Lp,blackHex:a=lg}){let l;switch(e){case"light":l=cg;break;case"dark":l=dg;break;default:l=e;break}let s=yo(l),c=yo(t),u=yo(r),h=yo(o),f=yo(n),y=pg(s.getLuminance()),E=Hr(s,y==="light"?-.04:.11),v=Hr(s,y==="light"?-.88:.87),x=Hr(s,y==="light"?-.77:.75),C=Hr(s,y==="light"?-.43:.45).desaturate(y==="light"?60:20),T=Hr(s,y==="light"?-.08:.25).desaturate(y==="light"?60:20),R=Hr(c,.15),I=Hr(c,-.06),_=yo(c.getLuminance()>.5?a:i),F=Hr(u,-.16);return{colorScheme:y,background:s.toHslString(),background2:E.toHslString(),foreground:v.toHslString(),foreground2:x.toHslString(),foreground3:C.toHslString(),foreground4:T.toHslString(),accent:c.toHslString(),accentLight:R.toHslString(),accentDark:I.toHslString(),foregroundAccent:_.toHslString(),success:u.toHslString(),successDark:F.toHslString(),error:f.toHslString(),warn:h.toHslString()}}function pl(e,t,r){let o=r?console.warn:()=>{},n=["google","twitter","discord","spotify","tiktok","linkedin","github","apple","farcaster"],i=t?.loginMethods?.filter($=>n.includes($)),a,l,s,c,u,h,f,y,E,v,x,C;t?.loginMethods?(a=t.loginMethods.includes("email"),l=t.loginMethods.includes("sms"),s=t.loginMethods.includes("wallet"),c=i?.includes("google"),u=i?.includes("twitter"),h=i?.includes("discord"),y=i?.includes("spotify"),f=i?.includes("tiktok"),v=i?.includes("github"),E=i?.includes("linkedin"),x=i?.includes("apple"),C=i?.includes("farcaster")):(a=e.emailAuth,l=e.smsAuth,s=e.walletAuth,c=e.googleOAuth,u=e.twitterOAuth,h=e.discordOAuth,v=e.githubOAuth,y=e.spotifyOAuth,f=e.tiktokOAuth,E=e.linkedinOAuth,x=e.appleOAuth,C=e.farcasterAuth);let T=[a,l].filter(Boolean),R=[c,u,h,v,y,f,E,x,C].filter(Boolean),I=[s].filter(Boolean);if(T.length+R.length+I.length===0)throw new Error("You must enable at least one login method");let _=t?.appearance?.showWalletLoginFirst!==void 0?t?.appearance?.showWalletLoginFirst:e.showWalletLoginFirst;_&&I.length===0?(o("You should only enable `showWalletLoginFirst` when `wallet` logins are also enabled. `showWalletLoginFirst` has been set to false"),_=!1):!_&&R.length+T.length===0&&(o("You should only disable `showWalletLoginFirst` when `email`, `sms`, or social logins are also enabled. `showWalletLoginFirst` has been set to true"),_=!0),t?.loginMethods&&t.loginMethodsAndOrder&&o("You should only configure one of `loginMethods` or `loginMethodsAndOrder`"),t?.appearance?.walletList&&t.loginMethodsAndOrder&&o("You should only configure one of `appearance.walletList` or `loginMethodsAndOrder`");let F=bp({input:t?.appearance?.walletList,overrides:t?.loginMethodsAndOrder}),U=vp({input:t?.loginMethodsAndOrder}),B=t?.intl?.defaultCountry??"US",{chains:k,defaultChain:z}=ug({additionalChains:t?.additionalChains,supportedChains:t?.supportedChains,defaultChainFromConfig:t?.defaultChain,hasRpcConfigDefined:Object.keys(t?.rpcConfig?.rpcUrls??{}).length>0}),L=!!t?.defaultChain||!!t?.supportedChains,j=t?.customAuth?.getCustomAccessToken&&t?.customAuth?.enabled!==!1,ie,ee=!(e.enforceWalletUis??!0);if(e.legacyWalletUiConfig??!0?j?ie=t?.embeddedWallets?.noPromptOnSignature??!0:ie=t?.embeddedWallets?.noPromptOnSignature??ee:ie=ee,t?.embeddedWallets?.waitForTransactionConfirmation===!1&&ie!==!0)throw new Error("Overriding `config.embeddedWallets.waitForTransactionConfirmation` requires that you disable wallet UIs in the dashboard.");return{id:e.id,name:e.name,allowlistConfig:e.allowlistConfig,legacyWalletUiConfig:e.legacyWalletUiConfig,appearance:{logo:t?.appearance?.logo??e.logoUrl,palette:Op({backgroundTheme:t?.appearance?.theme??xt.appearance.theme,accentHex:t?.appearance?.accentColor??e.accentColor??xt.appearance.accentColor}),loginGroupPriority:_?"web3-first":"web2-first",hideDirectWeb2Inputs:!!t?.appearance?.hideDirectWeb2Inputs,walletList:F},loginMethods:{wallet:s,email:a,sms:l,google:c,twitter:u,discord:h,github:v,spotify:y,tiktok:f,linkedin:E,apple:x,farcaster:C},loginMethodsAndOrder:U,legal:{termsAndConditionsUrl:t?.legal?.termsAndConditionsUrl??e.termsAndConditionsUrl,privacyPolicyUrl:t?.legal?.privacyPolicyUrl??e.privacyPolicyUrl,requireUsersAcceptTerms:e.requireUsersAcceptTerms??!1},walletConnectCloudProjectId:t?.walletConnectCloudProjectId??e.walletConnectCloudProjectId??xt.walletConnectCloudProjectId,rpcConfig:{rpcUrls:t?.rpcConfig?.rpcUrls??xt.rpcConfig.rpcUrls,rpcTimeouts:t?.rpcConfig?.rpcTimeouts??xt.rpcConfig.rpcTimeouts},chains:k,defaultChain:z,intl:{defaultCountry:B},shouldEnforceDefaultChainOnConnect:L,captchaEnabled:e.captchaEnabled??xt.captchaEnabled,captchaSiteKey:e.captchaSiteKey,embeddedWallets:{...e.embeddedWalletConfig,...j?{createOnLogin:"all-users",requireUserPasswordOnCreate:!1}:{},waitForTransactionConfirmation:!0,priceDisplay:{primary:"fiat-currency",secondary:"native-token"},...t?.embeddedWallets,noPromptOnSignature:ie},mfa:{methods:e.mfaMethods??[],noPromptOnMfaRequired:t?.mfa?.noPromptOnMfaRequired??!1},customAuth:j?{enabled:!0,...t.customAuth}:void 0,fiatOnRamp:{enabled:e.fiatOnRampEnabled,useSandbox:t?.fiatOnRamp?.useSandbox??xt.fiatOnRamp.useSandbox},loginConfig:{twitterOAuthOnMobileEnabled:e.twitterOAuthOnMobileEnabled??!1},render:{inDialog:t?._render?.inDialog??xt._render.inDialog,inParentNodeId:t?._render?.inParentNodeId??xt._render.inParentNodeId}}}function Np(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,...r?{...r,...r.logo&&typeof r.logo?{logo:"component"}:void 0}:void 0,legacyCreateEmbeddedWalletFlag:t}}function ug({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:qn.find(u=>u.id===s.id)??s)}else n=qn.concat(e??[]);let i=t?n[0]:Ho,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}}import{jsx as yg}from"react/jsx-runtime";var Fp={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",requireUserPasswordOnCreate:!1},fiatOnRampEnabled:!1,captchaEnabled:!1,captchaSiteKey:""},ul=pl(Fp,void 0,!1),ml=hg({appConfig:ul,isServerConfigLoaded:!1}),Bp=({children:e,legacyCreateEmbeddedWalletFlag:t,client:r,clientConfig:o})=>{let[n,i]=fg(null),a=mg(()=>pl(n??Fp,o,!!n),[n,o]);return Dp(()=>{let l=Np(o,t);r.createAnalyticsEvent("sdk_initialize",l)},[o,t]),Dp(()=>{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)}})()},[]),yg(ml.Provider,{value:{appConfig:a,isServerConfigLoaded:!!n},children:e})},Pa=()=>{let{appConfig:e}=Up(ml);return e},Ta=()=>{let{isServerConfigLoaded:e}=Up(ml);return e};var b=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};import{jsx as Eg,jsxs as Pg}from"react/jsx-runtime";var Hp=gg({ready:!1,app:ul,currentScreen:null,lastScreen:null,navigate:b,navigateBack:b,resetNavigation:b,setModalData:b,onUserCloseViaDialogOrKeybindRef:void 0}),bg=["LANDING","CONNECT_ONLY_LANDING_SCREEN",null],Gp=e=>{let t=Pa(),r=e.authenticated,[o,n]=Cg(e.initialScreen);fl(()=>{!r&&!bg.includes(e.initialScreen)&&e.setInitialScreen(null)},[r]);let i=wg(null);fl(()=>{e.open||(i.current=null)},[e.open]),fl(()=>{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 Pg(Hp.Provider,{value:a,children:[(typeof t.appearance.logo=="string"||t.appearance.logo?.type==="img")&&Eg(da,{src:typeof t.appearance.logo=="string"?t.appearance.logo:t.appearance.logo.props.src}),e.children]})},S=()=>vg(Hp);import{jsx as jo,jsxs as Tg}from"react/jsx-runtime";var jn=({style:e,...t})=>{let{app:r}=S();return Tg("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:[jo("rect",{width:"28",height:"28",rx:"3",fill:r?.appearance.palette.colorScheme==="dark"?"#3396ff":"#141414"}),jo("g",{clipPath:"url(#clip0_1765_9946)",children:jo("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"})}),jo("defs",{children:jo("clipPath",{id:"clip0_1765_9946",children:jo("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})};var nr=class extends lt{constructor(r,o,n,i,a,l,s){super(s||"unknown",n,i,o);this.connectorType="wallet_connect_v2";this.privyAppId=l,this.walletConnectCloudProjectId=r,this.rpcConfig=o,this.shouldEnforceDefaultChainOnConnect=a,this.proxyProvider=new ge(void 0,this.rpcTimeoutDuration),s&&(this.walletEntry=Do[s],this.walletClientType=s)}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=Zi(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=n?.entry,this.walletClientType=n?.walletClientType||"unknown"}this.connected=!0,await this.syncAccounts()}this.emit("initialized"),this.initialized=!0;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:Vo,id:"io.metamask"}:{name:qd(this.walletProvider?.session?.peer.metadata.name||"")||"WalletConnect",icon:this.walletProvider?.session?.peer.metadata.icons?.[0]||jn,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=Do[r],this.walletClientType=r,this.redirectUri=void 0,Xd(),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise((r,o)=>{let n=()=>{o(new Fo)};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 Y("Unable to retrieve address");if(this.walletProvider?.session?.peer.metadata.url){let s=Zi(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=s?.entry,this.walletClientType=s?.walletClientType||"unknown",this.proxyProvider.rpcTimeoutDuration=Bo(this.rpcConfig,this.walletClientType)}this.connected=!0,await this.syncAccounts(l),r()})().catch(a=>{if(a){o(Bt(a));return}o(new Y("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=Yi(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 xg.init({projectId:this.walletConnectCloudProjectId,chains:o,optionalChains:n,optionalEvents:Sg,optionalMethods:_g,rpcMap:r,showQrModal:!1});return i.on("display_uri",a=>{if(i.signer.abortPairingAttempt(),Ag&&this.walletEntry){let{redirect:l,href:s}=Zd(a,this.walletEntry);ep({href:s,name:this.walletEntry.displayName}),this.redirectUri=l,Qi(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=Zi(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 hl=e=>{let t=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return t?!!e?.linkedAccounts.filter(o=>o.type=="wallet"&&o.address===Vp(t)).length:!1},Bo=(e,t)=>e.rpcTimeouts?e.rpcTimeouts[t]||uo:uo,Kn=class extends kg{constructor(r,o,n,i,a,l,s,c,u){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 ge: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.privyAppName=u,this.initializedWalletConnectors=0,this.walletsReady=!1,this.storedConnections=this.loadConnectionHistory()}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;ce.get(al)&&(ce.getKeys().forEach(o=>{o.startsWith("walletconnect")&&ce.del(o)}),ce.del(al));let r=jd(this.store,this.walletList).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"),!Dr()&&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.initializedWalletConnectors++,this.walletsReady=this.initializedWalletConnectors===this.walletConnectors.length,this.emit("walletsUpdated")}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 ta(r,o,this.rpcConfig,this.chains,i,n.id),s=new aa(l,this.chains,n,this.rpcConfig);this.addWalletConnector(s)}}removeEmbeddedWalletConnector(){let r=this.findWalletConnector("embedded","privy");if(r){let o=this.walletConnectors.indexOf(r);this.walletConnectors.splice(o,1),this.saveConnectionHistory(),this.storedConnections=this.loadConnectionHistory(),this.emit("walletsUpdated")}}async createWalletConnector(r,o,n){let i=this.findWalletConnector(r,o);if(i)return i instanceof nr&&i.resetConnection(o),i;let l=(()=>{if(r==="injected"){if(o==="metamask"&&n?.eip6963InjectedProvider)return new sa(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask");if(o==="metamask"&&n?.legacyInjectedProvider)return new qo(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"metamask");if(o==="phantom"&&n?.legacyInjectedProvider)return new qo(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,"phantom");if(n?.legacyInjectedProvider&&o==="unknown_browser_extension")return new qo(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider);if(n?.eip6963InjectedProvider)return new $o(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,o)}else return r==="coinbase_wallet"?new na(this.chains,this.defaultChain,this.rpcConfig,this.privyAppId,this.privyAppName):r==="phantom"?new ca(this.defaultChain):new nr(this.walletConnectCloudProjectId,this.rpcConfig,this.chains,this.defaultChain,this.shouldEnforceDefaultChainOnConnect,this.privyAppId,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()}loadConnectionHistory(){let r=a=>a&&typeof a.address=="string"&&typeof a.connectorType=="string"&&typeof a.walletClientType=="string"&&typeof a.connectedAt=="number",o=ce.get(sl);return o&&Array.isArray(o)&&o.map(a=>r(a)).every(Boolean)?o:[]}saveConnectionHistory(){let r=this.wallets.map(o=>({address:o.address,connectorType:o.connectorType,walletClientType:o.walletClientType,connectedAt:o.connectedAt}));ce.put(sl,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=Vp(r),this.emit("walletsUpdated")}};function ra(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}import{ofetch as Rg}from"ofetch";var Ig=[Di,Fi,Ui],xa=class{constructor(t,r,o){this.appId=t,this.clientAnalyticsId=r.clientAnalyticsId,this.sdkVersion=ol,this.client=r,this.defaults=o,this.fallbackApiUrl=r.fallbackApiUrl,this.baseFetch=Rg.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:n,options:i})=>{let a=new Headers(i.headers);a.set("privy-app-id",this.appId),a.set("privy-ca-id",this.clientAnalyticsId||""),a.set("privy-client",`react-auth:${this.sdkVersion}`);let l=!Ig.includes(n.toString());if(!a.has("authorization")&&l){let s=await this.client.getAccessToken();s!==null&&a.set("authorization",`Bearer ${s}`)}i.headers=a},onRequestError:({error:n})=>{if(n instanceof DOMException&&n.name==="AbortError")throw new Oi}})}async get(t,r){try{return await this.baseFetch(t,r)}catch(o){throw le(o)}}async post(t,r,o){try{return await this.baseFetch(t,{method:"POST",...r?{body:r}:{},...o})}catch(n){throw le(n)}}async delete(t,r){try{return await this.baseFetch(t,{method:"DELETE",...r})}catch(o){throw le(o)}}};import go from"js-cookie";function zp(e){return e instanceof Nr?"email":e instanceof ho?"sms":e instanceof fo?"siwe":e instanceof Mo?"custom_auth":e instanceof er?e.meta.provider:null}import*as $p from"jose";var ir=class{static parse(t){try{return new ir(t)}catch{return null}}constructor(t){this.value=t,this._decoded=$p.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 Mg=30,Sa=class{constructor(){this.authenticateOnce=new Xe(async t=>this._authenticate(t)),this.linkOnce=new Xe(async t=>this._link(t)),this.refreshOnce=new Xe(this._refresh.bind(this)),this.destroyOnce=new Xe(this._destroy.bind(this)),this.forkSessionOnce=new Xe(this._forkSession.bind(this))}get token(){try{let t=ce.get(co);return typeof t=="string"?new ir(t).value:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get refreshToken(){try{let t=ce.get(zi);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get forkedToken(){try{let t=ce.get(Dn);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get mightHaveServerCookies(){try{let t=go.get($i);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"}hasRecoveryCredentials(){return typeof this.forkedToken=="string"}hasActiveToken(){let t=ir.parse(this.token);return t!==null&&!t.isExpired(Mg)}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{token:r,refresh_token:o,user:n,is_new_user:i}=await t.authenticate();this.storeToken(r),this.storeRefreshToken(o);let a=zp(t);return a&&this.client&&this.client.createAnalyticsEvent("sdk_authenticate",{method:a,isNewUser:i}),a==="siwe"&&this.client&&this.client.createAnalyticsEvent("sdk_authenticate_siwe",{connectorType:t.meta.connectorType,walletClientType:t.meta.walletClientType}),{user:ft(n),isNewUser:i}}catch(r){throw console.warn("Error authenticating session"),Ze(r)}}async _link(t){try{let r=await t.link();return ft(r)}catch(r){throw console.warn("Error linking account"),Ze(r)}}async _refresh(){if(!this.api)throw new P("Session has no API instance");if(!this.client)throw new P("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(Di,a,{headers:i}),o&&this.clearForkedToken()}else if(o)n=await this.api.post(Fi,{refresh_token:o}),this.clearForkedToken();else return null;return n.session_update_action==="set"&&(this.storeToken(n.token),this.storeRefreshToken(n.refresh_token)),n.session_update_action==="clear"&&this.destroyLocalState(),n.session_update_action==="ignore"&&n.token&&this.storeToken(n.token),ft(n.user)}catch(n){if(n instanceof Xt&&n.privyErrorCode==="missing_or_invalid_token")return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw Ze(n)}}async _destroy(){try{await this.api?.post(Ui,{refresh_token:this.refreshToken})}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new P("Session has no API instance");let t=this.refreshToken;try{let r=await this.api.post(td,{refresh_token:t});return this.storeToken(r.token),this.storeRefreshToken(r.refresh_token),r.new_session_refresh_token}catch(r){throw Ze(r)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),this.clearForkedToken(),this.client?.onDeleteToken?.()}storeToken(t){if(typeof t=="string"){let r=ce.get(co);if(ce.put(co,t),r!==t&&this.client?.onStoreToken?.(t),!this.client?.useServerCookies){let o=ir.parse(t)?.expiration;go.set(nl,t,{sameSite:"Strict",secure:!0,expires:o?new Date(o*1e3):void 0})}}else ce.del(co),go.remove(nl)}storeRefreshToken(t){typeof t=="string"?(ce.put(zi,t),this.client?.useServerCookies||(go.set($i,"t",{sameSite:"Strict",secure:!0,expires:30}),go.set(il,t,{sameSite:"Strict",secure:!0,expires:30}))):(ce.del(zi),go.remove(il),go.remove($i))}clearForkedToken(){ce.del(Dn)}};var yl,_a,qp,Yn=class{constructor(t){Li(this,_a);this.apiUrl=t.apiUrl||Vi,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=!1,this.timeout=t.timeout||Ld,this.appId=t.appId,this.clientAnalyticsId=ed(this,_a,qp).call(this),yl||(yl=new Sa),this.session=yl,this.api=this.generateApi(),this.session.client=this}initializeConnectorManager({walletConnectCloudProjectId:t,rpcConfig:r,chains:o,defaultChain:n,store:i,walletList:a,shouldEnforceDefaultChainOnConnect:l,appName:s}){this.connectors||(this.connectors=new Kn(this.appId,t,r,o,n,i,a,l,s))}generateApi(){let t=new xa(this.appId,this,{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 P("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new P("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}startMfaFlow(t){t.api=this.api,this.mfaFlow=t}async unlinkEmail(t){try{let r=await this.api.post(fd,{address:t});return ft(r)}catch(r){throw Ze(r)}}async acceptTerms(){try{let t=await this.api.post(Sd,{});return ft(t)}catch(t){throw Ze(t)}}async unlinkPhone(t){try{let r=await this.api.post(vd,{phoneNumber:t});return ft(r)}catch(r){throw Ze(r)}}async unlinkWallet(t){try{let r=await this.api.post(id,{address:t});return ft(r)}catch(r){throw Ze(r)}}async unlinkOAuth(t,r){try{let o=await this.api.post(Pd,{provider:t,subject:r});return ft(o)}catch(o){throw Ze(o)}}async unlinkFarcaster(t){try{let r=await this.api.post(dd,{fid:t});return ft(r)}catch(r){throw Ze(r)}}async createAnalyticsEvent(t,r,o){if(!(typeof window>"u"))try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(_d,{event_name:t,client_id:this.clientAnalyticsId,payload:{...r||{},clientTimestamp:o?o.toISOString():new Date().toISOString()}})}catch{}}async signMoonpayOnRampUrl(t){try{return this.api.post(Ad,t)}catch(r){throw Ze(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()||this.session.hasRecoveryCredentials()?this.session.refresh():null}async getAccessToken(t){return this.session.hasActiveToken()?ir.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=await this.api.get(`/api/v1/apps/${this.appId}`,{baseURL:this.fallbackApiUrl});return{id:t.id,name:t.name,verificationKey:t.verification_key,logoUrl:t.logo_url||void 0,accentColor:t.accent_color||void 0,showWalletLoginFirst:t.show_wallet_login_first,allowlistConfig:{errorTitle:t.allowlist_config.error_title,errorDetail:t.allowlist_config.error_detail,errorCtaText:t.allowlist_config.cta_text,errorCtaLink:t.allowlist_config.cta_link},walletAuth:t.wallet_auth,emailAuth:t.email_auth,smsAuth:t.sms_auth,googleOAuth:t.google_oauth,twitterOAuth:t.twitter_oauth,discordOAuth:t.discord_oauth,githubOAuth:t.github_oauth,spotifyOAuth:t.spotify_oauth,tiktokOAuth:t.tiktok_oauth,linkedinOAuth:t.linkedin_oauth,appleOAuth:t.apple_oauth,farcasterAuth:t.farcaster_auth,termsAndConditionsUrl:t.terms_and_conditions_url,embeddedWalletConfig:{createOnLogin:t.embedded_wallet_config?.create_on_login,requireUserPasswordOnCreate:t.embedded_wallet_config?.require_user_password_on_create},privacyPolicyUrl:t.privacy_policy_url,requireUsersAcceptTerms:t.require_users_accept_terms,customApiUrl:t.custom_api_url,walletConnectCloudProjectId:t.wallet_connect_cloud_project_id,fiatOnRampEnabled:t.fiat_on_ramp_enabled,captchaEnabled:t.captcha_enabled,captchaSiteKey:t.captcha_site_key,twitterOAuthOnMobileEnabled:t.twitter_oauth_on_mobile_enabled,createdAt:new Date(t.created_at*1e3),updatedAt:new Date(t.updated_at*1e3),mfaMethods:t.mfa_methods,enforceWalletUis:t.enforce_wallet_uis,legacyWalletUiConfig:t.legacy_wallet_ui_config}}catch(t){throw Ze(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 forkSession(){return await this.session.forkSession()}};_a=new WeakSet,qp=function(){if(typeof window>"u")return null;try{let r=ce.get(Un);if(typeof r=="string"&&r.length>0)return r}catch{}let t=Wg();try{return ce.put(Un,t),t}catch{return t}};import{Turnstile as Fg}from"@marsidev/react-turnstile";import{useEffect as Bg,useMemo as Hg}from"react";import{useMemo as Lg,useRef as Og,useContext as Ng,useState as gl,createContext as Dg}from"react";import{jsx as Ug}from"react/jsx-runtime";var jp=Dg({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}),Ht=class extends He{constructor(r,o,n){super(r||"Captcha failed");this.type="Captcha";o instanceof Error&&(this.cause=o),this.privyErrorCode=n}},Kp=({children:e,id:t,captchaSiteKey:r,captchaEnabled:o})=>{let n=Og(null),[i,a]=gl(),[l,s]=gl(),[c,u]=gl(!1),h=Lg(()=>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 Ug(jp.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 zd(()=>n.current?.getResponse(),{interval:200,timeout:2e4})}catch{throw new Ht("Captcha failed",null,"captcha_timeout")}}},children:e})},de=()=>Ng(jp);import{jsx as Yp}from"react/jsx-runtime";var vl=e=>{let{enabled:t,siteKey:r,appId:o,setError:n,setToken:i,setExecuting:a,ref:l}=de(),[,s]=Hg(()=>r?.split("t:")||[],[r]);if(Bg(()=>l.current?.remove,[]),!t)return null;if(!s)throw new Error("Unsupported captcha site key");return Yp("div",{className:"hidden h-0 w-0",children:Yp(Fg,{...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 t4,useEffect as gy,useRef as r4,useState as o4}from"react";import n4 from"react-dom";import{createContext as Gg,useContext as Vg}from"react";var wl=Gg({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,loginWithOAuth:b,refreshUser:b,walletProxy:null,createAnalyticsEvent:b,acceptTerms:b,getUsdTokenPrice:b,recoverEmbeddedWallet:b,getFiatOnRampConfig:b,updateWallets:b,fundWallet:b,setReadyToTrue:b}),W=()=>Vg(wl);import{createContext as zg,useContext as $g}from"react";var ae=zg({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,linkTiktok:b,linkLinkedIn:b,linkApple: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,unlinkTiktok:b,unlinkLinkedIn:b,unlinkApple:b,unlinkFarcaster:b,setActiveWallet:b,forkSession:b,createWallet:b,signMessage:b,signTypedData:b,enrollInMfa:b,initEnrollmentWithSms:b,initEnrollmentWithTotp:b,promptMfa:b,init:b,submitEnrollmentWithSms:b,submitEnrollmentWithTotp:b,unenroll:b,submit:b,cancel:b,sendTransaction:b,exportWallet:b,setWalletPassword:b,initLoginWithEmail:b,initLoginWithSms:b,loginWithCode:b,fundWallet:b,initLoginWithHeadlessOAuth:b,loginWithHeadlessOAuth:b,isHeadlessOAuthLoading:!1,isModalOpen:!1}),H=()=>$g(ae);import{useEffect as qg,useState as jg}from"react";var Jp=e=>{let[t,r]=jg("auto");return qg(()=>{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 Kg,useContext as Yg,useEffect as Jg}from"react";var Zp={login:{onComplete:[],onError:[]},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:[]}},Cl=Kg(void 0),Qp=()=>Yg(Cl);function ve(e,t){if(!t)return;let o=Qp().current[e];return Jg(()=>{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 N(e,t,r,...o){for(let n of e.current[t][r])n(...o)}function Xp(){let e=Qp();return(t,r,...o)=>N(e,t,r,...o)}function bl(e){ve("configureMfa",e)}import lu from"@heroicons/react/24/outline/ArrowTopRightOnSquareIcon";import p1 from"@heroicons/react/24/solid/DocumentCheckIcon";import u1 from"styled-components";import wo,{css as xl}from"styled-components";import Pl from"styled-components";import{Fragment as Qg,jsx as El,jsxs as Xg}from"react/jsx-runtime";var xr=({success:e,fail:t})=>Xg(Qg,{children:[El(St,{className:e?"success":t?"fail":""}),El(Tl,{className:e?"success":t?"fail":""})]}),St=Pl.span`
|
|
13
13
|
&& {
|
|
14
14
|
width: 82px;
|
|
15
15
|
height: 82px;
|
|
@@ -2711,4 +2711,4 @@ You will need this password to access your ${e} wallet on a new device. Please k
|
|
|
2711
2711
|
opacity: 1;
|
|
2712
2712
|
}
|
|
2713
2713
|
}
|
|
2714
|
-
`;import{jsx as Fe,jsxs as vy}from"react/jsx-runtime";var i4={["LANDING"]:Lf,["CONNECT_OR_CREATE"]:Mf,["AWAITING_PASSWORDLESS_CODE"]:bu,["AWAITING_CONNECTION"]:Bu,["AWAITING_CONNECT_ONLY_CONNECTION"]:zu,["AWAITING_FARCASTER_CONNECTION"]:Km,["PHANTOM_INTERSTITIAL_SCREEN"]:Zh,["LOGIN_FAILED_SCREEN"]:Hf,["AWAITING_OAUTH_SCREEN"]:jh,["ALLOWLIST_REJECTION_SCREEN"]:pu,["INSTALL_PHANTOM_SCREEN"]:cf,["LINK_EMAIL_SCREEN"]:Of,["LINK_PHONE_SCREEN"]:Nf,["LINK_WALLET_SCREEN"]:Df,["UPDATE_EMAIL_SCREEN"]:my,["CONNECT_ONLY_LANDING_SCREEN"]:Du,["CONNECT_ONLY_AUTHENTICATED_SCREEN"]:Lu,["EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN"]:km,["EMBEDDED_WALLET_CREATED_SCREEN"]:Zu,["EMBEDDED_WALLET_CONNECTING_SCREEN"]:Yu,["EMBEDDED_WALLET_RECOVERY_SCREEN"]:Mm,["EMBEDDED_WALLET_KEY_EXPORT_SCREEN"]:tm,["EMBEDDED_WALLET_SIGN_REQUEST_SCREEN"]:ay,["EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN"]:ny,["FIAT_ON_RAMP_PROMPT_SCREEN"]:ef,["FIAT_ON_RAMP_STATUS_SCREEN"]:rf,["EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN"]:Im,["EMBEDDED_WALLET_PASSWORD_UPDATE_SCREEN"]:Rm,["MFA_ENROLLMENT_FLOW_SCREEN"]:th,["CAPTCHA_SCREEN"]:xu,["ERROR_SCREEN"]:Wm,["IN_APP_BROWSER_LOGIN_NOT_POSSIBLE"]:of,["AFFIRMATIVE_CONSENT_SCREEN"]:cu},a4=["LANDING","AWAITING_CONNECTION"],s4=({isMfaVerifying:e,onMfaVerificationComplete:t})=>{let{ready:r,isModalOpen:o}=H(),{headless:n}=W(),{ready:i,currentScreen:a}=S(),{status:l,execute:s,reset:c,enabled:u}=de(),h=r4(null),f=Jp(h),y=o&&a&&a4.includes(a)&&!n&&l==="ready";if(gy(()=>{y&&s()},[y]),gy(()=>{!o&&u&&c()},[o,u]),(!r||!i)&&a!=="AWAITING_OAUTH_SCREEN")return vy(En,{children:[Fe(A,{}),Fe(X,{}),Fe(zf,{children:Fe(St,{})}),Fe(te,{}),Fe(oe,{})]});if(!a&&e)return Fe(En,{style:{height:f},children:Fe("div",{ref:h,children:Fe(zc,{open:e,onClose:t})})});if(!a)return null;let E=i4[a];return Fe(En,{style:{height:f},children:vy("div",{ref:h,children:[Fe(Sr,{if:!!e,children:Fe(E,{})}),Fe(Sr,{if:!e,children:Fe(zc,{open:e,onClose:t})})]})})},l4=()=>{let{closePrivyModal:e}=W(),{onUserCloseViaDialogOrKeybindRef:t}=S();return{gracefulClosePrivyModal:t4(()=>{if(t?.current)t.current();else return e({shouldCallAuthOnSuccess:!1})},[e])}},wy=({open:e})=>{let{app:t}=S(),{gracefulClosePrivyModal:r}=l4(),[o,n]=o4(!1);bl({onMfaRequired:()=>{t?.mfa.noPromptOnMfaRequired||n(!0)}});let i=Fe(yy,{children:Fe(s4,{isMfaVerifying:o,onMfaVerificationComplete:()=>n(!1)})}),a=e||o,l=t?.render.inDialog?Fe(Vf,{open:a,id:"privy-dialog","aria-label":"log in or sign up","aria-labelledby":"privy-dialog-title",onClick:()=>r(),children:i}):i;if(typeof window<"u"&&t?.render.inParentNodeId){let s=document.getElementById(t.render.inParentNodeId);if(s)return n4.createPortal(l,s)}return l};import{useState as c4}from"react";import{useEffect as Cy,useRef as by}from"react";var Gs=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: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;default:throw new Error(`invalid wallet event type ${t}`)}}};async function ko(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 Se("missing_or_invalid_mfa","MFA verification failed, retry."));let h=await new Promise((f,y)=>{r.current={resolve:f,reject:y};let E=1e3*60*5;setTimeout(()=>{let v=new Se("mfa_timeout","Timed out waiting for MFA code");o.current?.reject(v),y(v)},E)});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 Se("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw o.current?.reject(u),u}return c}import{jsx as h4}from"react/jsx-runtime";var d4=function(e){return()=>`id-${e++}`}(0);function p4(e){return typeof e.event=="string"&&/^privy:.+/.test(e.event)}function yr(e){return e.error!==void 0}var Jt=new Gs,jc=new Map,u4=(e,t)=>typeof t=="bigint"?t.toString():t,m4=(e,t)=>`${e}${JSON.stringify(t,u4)}`;function gr(e,t,r,o){let n=r.contentWindow;if(!n)throw new Error("iframe not initialized");let i=m4(e,t);if(e==="privy:wallet:create"){let l=jc.get(i);if(l)return l}let a=new Promise((l,s)=>{let c=d4();Jt.enqueue(c,{resolve:l,reject:s}),n.postMessage({id:c,event:e,data:t},o)}).finally(()=>{jc.delete(i)});return jc.set(i,a),a}function f4(e){switch(e.event){case"privy:iframe:ready":let t=Jt.dequeue(e.event,e.id);return yr(e)?t.reject(new Se(e.error.type,e.error.message)):t.resolve(e.data);case"privy:wallet:create":let r=Jt.dequeue(e.event,e.id);return yr(e)?r.reject(new Se(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallet:connect":let o=Jt.dequeue(e.event,e.id);return yr(e)?o.reject(new Se(e.error.type,e.error.message)):o.resolve(e.data);case"privy:wallet:recover":let n=Jt.dequeue(e.event,e.id);return yr(e)?n.reject(new Se(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallet:rpc":let i=Jt.dequeue(e.event,e.id);return yr(e)?i.reject(new Se(e.error.type,e.error.message)):i.resolve(e.data);case"privy:wallet:set-recovery-password":let a=Jt.dequeue(e.event,e.id);return yr(e)?a.reject(new Se(e.error.type,e.error.message)):a.resolve(e.data);case"privy:mfa:verify":let l=Jt.dequeue(e.event,e.id);return yr(e)?l.reject(new Se(e.error.type,e.error.message)):l.resolve(e.data);case"privy:mfa:init-enrollment":{let s=Jt.dequeue(e.event,e.id);return yr(e)?s.reject(new Se(e.error.type,e.error.message)):s.resolve(e.data)}case"privy:mfa:submit-enrollment":{let s=Jt.dequeue(e.event,e.id);return yr(e)?s.reject(new Se(e.error.type,e.error.message)):s.resolve(e.data)}case"privy:mfa:unenroll":{let s=Jt.dequeue(e.event,e.id);return yr(e)?s.reject(new Se(e.error.type,e.error.message)):s.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}function Ey(e){let t=by(null),r=by(e.mfaMethods),o=Xp(),[n,i]=c4(!1);return Cy(()=>{r.current=e.mfaMethods},[e.mfaMethods]),Cy(()=>{if(!n)return;let a=t.current;if(!a)return;function l(f){f&&f.origin===e.origin&&p4(f.data)&&f4(f.data)}let s={create(f){return gr("privy:wallet:create",f,a,e.origin)},connect(f){return gr("privy:wallet:connect",f,a,e.origin)},recover(f){return ko(y=>gr("privy:wallet:recover",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},rpc(f){return ko(y=>gr("privy:wallet:rpc",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},setRecoveryPassword(f){return ko(y=>gr("privy:wallet:set-recovery-password",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},verifyMfa(f){return ko(y=>gr("privy:mfa:verify",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},initEnrollMfa(f){return ko(y=>gr("privy:mfa:init-enrollment",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},submitEnrollMfa(f){return gr("privy:mfa:submit-enrollment",f,a,e.origin)},unenrollMfa(f){return ko(y=>gr("privy:mfa:unenroll",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)}};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 $d(()=>gr("privy:iframe:ready",{},a,e.origin),{abortSignal:h.signal}).then(c,u),()=>{window.removeEventListener("message",l),h.abort()}},[n]),h4("iframe",{ref:t,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},onLoad:()=>i(!0),src:Ki(e.origin,`/apps/${e.appId}/embedded-wallets`,{caid:e.clientAnalyticsId})})}function Vs(e){let t=e.toLowerCase();return["fbav","fban","instagram","snapchat"].some(o=>t.includes(o))}var zs=class{constructor(t,r){this.meta={action:t,phoneNumber:r}}async init(){if(!this.meta.action)throw new P("action required");if(!this.api)throw new P("Auth flow has no API instance");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new P("phone number must be set when initialzing authentication.");try{await this.api.post(Td,{action:this.meta.action,phoneNumber:this.meta.phoneNumber})}catch(t){throw le(t)}}async authenticate(){if(!this.meta.action)throw new P("action required");if(!this.api)throw new P("Mfa flow has no API instance");if(!this.meta.smsCode)throw new P("sms code must be set prior to calling authenticate.");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new P("phone number must be set prior to calling authenticate.");try{let t=await this.api.post(xd,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return ft(t)}catch(t){throw le(t)}}};import{jsx as vr,jsxs as Py}from"react/jsx-runtime";var On;function w4(e){return typeof e=="string"&&e.length===25}function Me(){if(!On){let e=ce.get(co);return Promise.resolve(e||null)}return On.getAccessToken()}var Ty,dp=(e,t)=>Ty(e,t),xy,pp=(e,t)=>xy(e,t),Sy,up=(e,t)=>Sy(e,t),_y,mp=()=>_y(),C4=()=>{let t=new URLSearchParams(window.location.search).get("privy_token");if(!t)return;ce.put(Dn,t);let r=new URL(window.location.href);r.searchParams.delete("privy_token"),window.history.pushState({},"",r)},b4=({config:e,...t})=>{if(!w4(t.appId))throw new P("Cannot initialize the Privy provider with an invalid Privy app ID");On||(On=new Yn({appId:t.appId,apiUrl:t.apiUrl||Vi}));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(Bp,{client:On,clientConfig:r,legacyCreateEmbeddedWalletFlag:t.createPrivyWalletOnLogin,children:vr(E4,{...t,config:r,client:On})})},E4=e=>{let t=e.client,[r,o]=ke(!1),[n,i]=ke(!1),[a,l]=ke(!1),[s,c]=ke(null),[u,h]=ke([]),f=Ln(u),[y,E]=ke(!1),[v,x]=ke(null),[C,T]=ke(!1),[R,I]=ke({status:"disconnected",connectedWallet:null,connectError:null,connector:null,connectRetry:b}),[_,F]=ke(null),[U,B]=ke(null),[k,z]=ke(null),L=Pa(),j=Ta(),[ie,ee]=ke(!0),[Q,$]=ke({}),[be,he]=ke(null),[wr,dt]=ke(null),[xe,pe]=ke(!1),[pt,Ot]=ke(!1),Lr=Ln(null),Zt=Ln(null),M=Ln(Zp);t.onStoreToken=d=>{d&&N(M,"accessToken","onAccessTokenGranted",d)},t.onDeleteToken=()=>{N(M,"accessToken","onAccessTokenRemoved")};let K=Ln(null),J=Ln(null),Nn=g4(d=>{let p=t.connectors?.walletsReady||!1;return a&&s?.linkedAccounts?.some(g=>g.type==="wallet"&&g.walletClientType==="privy")?p&&d?.some(g=>g?.walletClientType==="privy"):p},[a,s?.linkedAccounts,t?.connectors?.walletsReady]),q=d=>{x(d),setTimeout(()=>{o(!0)},15),t.createAnalyticsEvent("modal_open",{initialScreen:d})},Re=d=>{L.embeddedWallets.createOnLogin!=="off"&&ee(!0),q(d)};Wr(()=>{if(!k||!s){t.connectors?.removeEmbeddedWalletConnector();return}let d=s?.linkedAccounts.filter(p=>p.type==="wallet"&&p.walletClientType==="privy");if(d&&d.length>0){let p=d[0].address;t.connectors?.addEmbeddedWalletConnector(k,p,L.defaultChain,e.appId)}},[k,s]),Wr(()=>{k&&wr?.(k)},[k]),Wr(()=>{(async()=>{if(!L.customAuth?.enabled)return;ee(!0);let{getCustomAccessToken:p,isLoading:m}=L.customAuth;if(!(!n||m))try{let g=await p();if(!g){await Ro.logout();return}if(a)return;t.startAuthFlow(new Mo(g));let{user:O,isNewUser:G}=await t.authenticate();O||await Ro.logout(),c(O||null),E(G||!1),l(!0),Ot(!0)}catch(g){console.warn(g),a&&await Ro.logout()}})()},[L.customAuth?.enabled,L.customAuth?.getCustomAccessToken,L.customAuth?.isLoading,n,a]),Wr(()=>{pt&&k&&s&&Pt(s,e.config?.embeddedWallets?.createOnLogin)&&(Ot(!1),Cr(s,Lo).catch(console.error))},[pt&&k&&s]),Wr(()=>{async function d(){let p=at();C4();let m=y4();F(m),t.initializeConnectorManager(L.walletConnectCloudProjectId,L.rpcConfig,L.chains,L.defaultChain,m,L.appearance.walletList,L.shouldEnforceDefaultChainOnConnect),t.connectors?.initialize().then(()=>{qs()});let g=await t.getAuthenticatedUser();e.config?.customAuth?.enabled||(l(!!g),g&&N(M,"login","onComplete",g,!1,!0,null),c(g)),p||ue.setReadyToTrue(),p&&(g?J.current="link":J.current="login")}!n&&j&&d()},[t,be,n,j]);let at=()=>{let d=Gn();return!d.inProgress||d.headless?!1:(t.startAuthFlow(new er(d)),Re("AWAITING_OAUTH_SCREEN"),!0)},ao=async(d,p,m,g)=>{let O=await t.connectors?.createWalletConnector(d,p)||null;Nt(O,p,m,g)};async function Nt(d,p,m,g){if(d)I({status:"disconnected",connectedWallet:null,connectError:null,connector:d,connectRetry:b});else return I({status:"disconnected",connectedWallet:null,connectError:new Y("Unable to connect to wallet."),connector:null,connectRetry:b}),g?.(null,m);d instanceof nr&&p&&await d.resetConnection(p),I({connector:d,status:"connecting",connectedWallet:null,connectError:null,connectRetry:()=>Nt(d,p,m,g)});try{let O=await d.connect({showPrompt:!0});if(L.shouldEnforceDefaultChainOnConnect&&!L.chains.find(G=>G.id===Number(O?.chainId))&&!(O?.connectorType==="wallet_connect_v2"&&O?.walletClientType==="metamask")){I(G=>({...G,connector:d,status:"switching_to_supported_chain",connectedWallet:null,connectError:null,connectRetry:b}));try{await O?.switchChain(L.defaultChain.id),O&&(O.chainId=No(mo(L.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${L.defaultChain.id}`)}}return I(G=>({...G,status:"connected",connectedWallet:O,connectError:null,connectRetry:b})),O&&!J.current&&N(M,"connectWallet","onSuccess",O),g?.(O,m)}catch(O){return O instanceof He?(console.warn(O.cause?O.cause:O.message),J.current||N(M,"connectWallet","onError",O.privyErrorCode||"generic_connect_wallet_error")):(console.warn(O),J.current||N(M,"connectWallet","onError","unknown_connect_wallet_error")),I(G=>({...G,status:"disconnected",connectedWallet:null,connectError:O})),g?.(null,m)}}let so=async(d,p)=>{if(d===null)return;let m=new fo(d,p);t.startAuthFlow(m)},qs=()=>{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"&&!Dr()&&Re("LOGIN_FAILED_SCREEN"),!t.connectors)throw new P("Connector not initialized");q("AWAITING_CONNECTION");let g=new URL(window.location.href);g.searchParams.delete("privy_connector"),g.searchParams.delete("privy_wallet_client"),window.history.pushState({},"",g),ao(p,m,void 0,so)};Wr(()=>{n&&a&&s===null&&t.getAuthenticatedUser().then(c)},[n,a,s,t]);let Ie=()=>{if(!a)throw N(M,"linkAccount","onError","must_be_authenticated"),new P("User must be authenticated before linking an account.")},lo=()=>{Ie(),K.current="siwe",J.current="link",q("LINK_WALLET_SCREEN")},ut=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},Be=async d=>{if(!t.connectors)throw new P("Connector not initialized");let p=t.connectors.findWalletConnector(d.connectorType,d.walletClientType)||null;if(I(m=>({...m,connector:p,status:"connected",connectedWallet:d,connectError:null,connectRetry:b})),L.captchaEnabled&&!a){let m={callback:g=>so(d,g),userIntentRequired:!1,onSuccessNavigateTo:"AWAITING_CONNECTION",onErrorNavigateTo:"ERROR_SCREEN"};$({captchaModalData:m}),Re("CAPTCHA_SCREEN")}else await so(d),Re("AWAITING_CONNECTION")},Qt=async(d,p)=>{if(!L.fiatOnRamp.enabled)throw new P("Fiat on-ramp is not enabled");if(!p||!p.provider||p.provider==="moonpay"){let{signedUrl:m,externalTransactionId:g}=await Qm(t,d,p?.config??{},L.appearance.palette,L.fiatOnRamp.useSandbox);return{signedUrl:m,externalTransactionId:g}}else throw new P("Unsupported fund provider. Currently supported option is `moonpay`.")},Or=()=>{h(d=>{let p=t.connectors?.wallets.map(m=>({...m,linked:ut(m),loginOrLink:async()=>{if(!await m.isConnected())throw new P("Wallet is not connected");if(m.connectorType==="embedded"&&m.walletClientType==="privy")throw new P("Cannot link or login with embedded wallet");Be(m)},fund:async g=>{let{signedUrl:O,externalTransactionId:G}=await Qt(m.address,g);$({fiatOnRampPrompt:{signedUrl:O},fiatOnRampStatus:{externalTransactionId:G}}),q("FIAT_ON_RAMP_PROMPT_SCREEN")},unlink:async()=>{if(!a)throw new P("User is not authenticated.");if(m.connectorType==="embedded"&&m.walletClientType==="privy")throw new P("Cannot unlink an embedded wallet");let g=await t.unlinkWallet(m.address);c(g)}}))||[];return pe(Nn(p)),ra(d,p)?d:p})};Wr(()=>{Or()},[s?.linkedAccounts,a,n]),Wr(()=>{if(n){if(!t.connectors)throw new P("Connector not initialized");Or(),t.connectors.on("walletsUpdated",Or)}},[n]);let Wi=()=>{q(a?"CONNECT_ONLY_AUTHENTICATED_SCREEN":"CONNECT_ONLY_LANDING_SCREEN")};Wr(()=>{if(!u[0])return;let d=u[0],p=f.current.find(g=>g.address===d.address),m;if(d.walletClientType==="privy"?m=s?.linkedAccounts.find(g=>g.type==="wallet"&&g.address===d.address&&g.walletClientType==="privy"):m=s?.linkedAccounts.find(g=>g.type==="wallet"&&g.address===d.address&&g.walletClientType!=="privy"),!p&&m){let g=Object.assign({},s);g.wallet=m&&{address:m.address,chainType:m.chainType,chainId:m.chainId,walletClient:m.walletClient,walletClientType:m.walletClientType,connectorType:m.connectorType},c(g)}f.current=u},[u]);let Cr=async(d,p)=>{if(ye(d))throw N(M,"createWallet","onError","embedded_wallet_already_exists"),new Error("Only one Privy wallet per user is currently allowed");let[g,O]=await Promise.all([ue.initializeWalletProxy(p),Me()]);if(!g&&e.config?.customAuth?.enabled)throw N(M,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to connect to wallet proxy");if(!g||!O||e.config?.embeddedWallets?.requireUserPasswordOnCreate)return new Promise((G,me)=>{ee(!0),$({createWallet:{onSuccess:st=>{N(M,"createWallet","onSuccess",st),G(st)},onFailure:st=>{N(M,"createWallet","onError","unknown_embedded_wallet_error"),me(st)},callAuthOnSuccessOnClose:!1}}),q("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")});{await g.create({accessToken:O});let G=await ue.refreshUser(),me=ye(G);if(!me)throw N(M,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");return N(M,"createWallet","onSuccess",me),me}},js=d=>{if(!L.chains.map(p=>p.id).includes(d))throw new Y(`Chain ID ${d} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,"unsupported_chain_id")},Yc=(d,p,m)=>new Promise(async(g,O)=>{if(!a||!s){N(M,"sendTransaction","onError","must_be_authenticated"),O(new Error("User must be authenticated before signing with a Privy wallet"));return}let G=ye(s);if(!G){N(M,"sendTransaction","onError","embedded_wallet_not_found"),O(new Error("Must have a Privy wallet before signing"));return}ee(!0);let me=t.connectors?.findWalletConnector("embedded","privy")?.proxyProvider,Ye=d.chainId?Number(d.chainId):me.chainId;js(Ye);let st=Object.assign({},d,{chainId:Ye}),br=async()=>{let Je=await Me();if(!Je||!k){N(M,"sendTransaction","onError","embedded_wallet_not_found"),O(new Error("Must have valid access token and Privy wallet to send transaction"));return}try{if(!await ue.recoverEmbeddedWallet()){N(M,"sendTransaction","onError","unknown_connect_wallet_error"),O(new Error("Unable to connect to wallet"));return}let Ft=Pr(st.chainId,L.chains,L.rpcConfig,{appId:e.appId}),Ks=await Rn(G.address,st,Ft);if(L.embeddedWallets.noPromptOnSignature){let{totalGasEstimate:My}=await kn(Ks,Ft),{hasSufficientFunds:Wy}=await Ds(G.address,Ks,My,Ft);if(!Wy)throw new Ee(new Tt("Wallet has insufficient funds for this transaction.",Ve.E32603_DEFAULT_INTERNAL_ERROR.eipCode))}let Qc=await Ns(Je,G.address,k,Ks,Ft);N(M,"sendTransaction","onSuccess",Qc),g(Qc)}catch(Ut){N(M,"sendTransaction","onError","transaction_failure"),O(Ut)}};if(L.embeddedWallets.noPromptOnSignature)p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config"),br();else{let Je={transactionRequest:st,onSuccess:Ft=>{N(M,"sendTransaction","onSuccess",Ft),g(Ft)},onFailure:Ft=>{N(M,"sendTransaction","onError","transaction_failure"),O(Ft)},uiOptions:p||{},fundWalletConfig:m},Ut={onCompleteNavigateTo:"EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN",onFailure:Ft=>{N(M,"sendTransaction","onError","unknown_connect_wallet_error"),O(Ft)}};$({connectWallet:Ut,sendTransaction:Je}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")}});function Jc(){return new Promise(async(d,p)=>{let m=await Me();if(!m||!k)throw new Error("Must have valid access token to enroll in MFA");try{await k.verifyMfa({accessToken:m}),d()}catch(g){p(g)}})}let Dt=d=>{if(s?.[d])throw N(M,"linkAccount","onError","cannot_link_more_of_type"),new P(`User already has an account of type ${d} linked.`)},Ro={ready:n,authenticated:a,user:s,walletConnectors:t.connectors||null,connectWallet:Wi,linkWallet:lo,linkEmail:()=>{Ie(),Dt("email"),K.current="email",J.current="link",q("LINK_EMAIL_SCREEN")},linkPhone:()=>{Ie(),Dt("phone"),K.current="sms",J.current="link",q("LINK_PHONE_SCREEN")},linkGoogle:async()=>{Ie(),Dt("google"),J.current="link",await ue.initLoginWithOAuth("google")},linkTwitter:async()=>{Ie(),Dt("twitter"),J.current="link",await ue.initLoginWithOAuth("twitter")},linkDiscord:async()=>{Ie(),Dt("discord"),J.current="link",await ue.initLoginWithOAuth("discord")},linkGithub:async()=>{Ie(),Dt("github"),J.current="link",await ue.initLoginWithOAuth("github")},linkSpotify:async()=>{Ie(),Dt("spotify"),J.current="link",await ue.initLoginWithOAuth("spotify")},linkTiktok:async()=>{Ie(),Dt("tiktok"),J.current="link",await ue.initLoginWithOAuth("tiktok")},linkLinkedIn:async()=>{Ie(),Dt("linkedin"),J.current="link",await ue.initLoginWithOAuth("linkedin")},linkApple:async()=>{Ie(),Dt("apple"),J.current="link",await ue.initLoginWithOAuth("apple")},linkFarcaster:async()=>{Ie(),Dt("farcaster"),await ue.initLoginWithFarcaster(),J.current="link",K.current="farcaster",q("AWAITING_FARCASTER_CONNECTION")},updateEmail:()=>{if(Ie(),!s?.email)throw new P("User does not have an email linked to their account.");J.current="link",K.current="email",q("UPDATE_EMAIL_SCREEN")},login:async()=>{if(n||(await new Promise(d=>{he(()=>d)}),he(null)),a){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}J.current="login",Re("LANDING")},connectOrCreateWallet:async()=>{if(n||(await new Promise(d=>{he(()=>d)}),he(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}Re("CONNECT_OR_CREATE")},logout:async()=>{await t.logout(),c(null),l(!1),x(null),N(M,"logout","onSuccess"),J.current=null,K.current=null,o(!1),ce.del(Un)},getAccessToken:()=>t.getAccessToken(),getEthereumProvider:()=>{if(!s||!s.wallet)return new ge;let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(g=>g.address===d?.address));return!d||!p?new ge:p.proxyProvider},getEthersProvider:()=>{if(!s||!s.wallet)return new Kc(new tr(new ge));let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(g=>g.address===d?.address));return!d||!p?new Kc(new tr(new ge)):new Kc(new tr(p.proxyProvider))},getWeb3jsProvider:()=>{if(!s||!s.wallet)return new Br(new ge);let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(g=>g.address===d?.address));return!d||!p?new Br(new ge):new Br(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},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},setActiveWallet:async d=>{let p=u.find(g=>$s(g.address)===$s(d)),m=s?.linkedAccounts.find(g=>g.type==="wallet"&&$s(g.address)===$s(d));if(!p||!await p.isConnected())B(d),lo();else if(!p.linked)p.loginOrLink();else{let g=Object.assign({},s);g.wallet=m&&{address:m.address,chainType:m.chainType,chainId:m.chainId,walletClient:m.walletClient,walletClientType:m.walletClientType,connectorType:m.connectorType},c(g)}},forkSession:()=>t.forkSession(),createWallet:async()=>{if(!a||!s)throw N(M,"createWallet","onError","must_be_authenticated"),new Error("User must be authenticated before creating a Privy wallet");return Cr(s,15e3)},setWalletPassword:async()=>{if(!a||!s)throw N(M,"setWalletPassword","onError","must_be_authenticated"),new Error("User must be authenticated before adding password to Privy wallet");let d=ye(s);if(!d||!k)throw N(M,"setWalletPassword","onError","embedded_wallet_not_found"),new Error("Must have a Privy wallet to add a password");if(d.recoveryMethod==="user-passcode")throw N(M,"setWalletPassword","onError","embedded_wallet_password_already_exists"),new Error("Cannot set password. Embedded wallet already has a password.");try{await Jc()}catch(p){throw N(M,"setWalletPassword","onError","missing_mfa_credentials"),p}return new Promise((p,m)=>{ee(!0);let g={onSuccess:G=>{N(M,"setWalletPassword","onSuccess",G),p(G)},onFailure:G=>{N(M,"setWalletPassword","onError","user_exited_set_password_flow"),m(G)},callAuthOnSuccessOnClose:!1},O={onCompleteNavigateTo:"EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN",onFailure:G=>{N(M,"setWalletPassword","onError","unknown_connect_wallet_error"),m(G)}};$({setWalletPassword:g,connectWallet:O}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")})},signMessage:(d,p)=>new Promise(async(m,g)=>{if(!a||!s){N(M,"signMessage","onError","must_be_authenticated"),g(new Error("User must be authenticated before signing with a Privy wallet"));return}let O=ye(s);if(!O){N(M,"signMessage","onError","embedded_wallet_not_found"),g(new Error("Must have a Privy wallet before signing"));return}if(typeof d!="string"||d.length<1){N(M,"signMessage","onError","invalid_message"),g(new Error("Message must be a non-empty string"));return}ee(!0);let G=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let me=await Me();if(!k||!me)throw new Error("Unable to connect to wallet");if(!await ue.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent("embedded_wallet_sign_message_started",{walletAddress:O.address});let{response:st}=await k.rpc({accessToken:me,address:O.address,request:{method:"personal_sign",params:[d,O.address]}}),br=st.data;return t.createAnalyticsEvent("embedded_wallet_sign_message_completed",{walletAddress:O.address}),br};if(L.embeddedWallets.noPromptOnSignature){p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let me=await G();N(M,"signMessage","onSuccess",me),m(me)}catch(me){N(M,"signMessage","onError","unable_to_sign"),g(me??new Ee("Unable to sign message"))}}else{let st={method:"personal_sign",data:d,confirmAndSign:G,onSuccess:Je=>{N(M,"signMessage","onSuccess",Je),m(Je)},onFailure:Je=>{N(M,"signMessage","onError","unable_to_sign"),g(Je)},uiOptions:p||{}},br={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:Je=>{N(M,"signMessage","onError","unknown_connect_wallet_error"),g(Je)}};$({signMessage:st,connectWallet:br}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),signTypedData:(d,p)=>new Promise(async(m,g)=>{if(!a||!s){N(M,"signTypedData","onError","must_be_authenticated"),g(new Error("User must be authenticated before signing with a Privy wallet"));return}let O=ye(s);if(!O){N(M,"signTypedData","onError","embedded_wallet_not_found"),g(new Error("Must have a Privy wallet before signing"));return}ee(!0);let G=Ji(d),me=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let Ye=await Me();if(!k||!Ye)throw new Error("Unable to connect to wallet");if(!await ue.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent("embedded_wallet_sign_typed_data_started",{walletAddress:O.address});let{response:br}=await k.rpc({accessToken:Ye,address:O.address,request:{method:"eth_signTypedData_v4",params:[O.address,G]}}),Je=br.data;return t.createAnalyticsEvent("embedded_wallet_sign_typed_data_completed",{walletAddress:O.address}),Je};if(L.embeddedWallets.noPromptOnSignature||(L.legacyWalletUiConfig??!1)){p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let Ye=await me();N(M,"signTypedData","onSuccess",Ye),m(Ye)}catch(Ye){N(M,"signTypedData","onError","unable_to_sign"),g(Ye??new Ee("Unable to sign message"))}}else{let br={method:"eth_signTypedData_v4",data:G,confirmAndSign:me,onSuccess:Ut=>{N(M,"signTypedData","onSuccess",Ut),m(Ut)},onFailure:Ut=>{N(M,"signTypedData","onError","unable_to_sign"),g(Ut)},uiOptions:p||{}},Je={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:Ut=>{N(M,"signMessage","onError","unknown_connect_wallet_error"),g(Ut)}};$({signMessage:br,connectWallet:Je}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),sendTransaction:async(d,p,m)=>{let O=await(await Yc(d,p,m)).wait();return Us(O)},exportWallet:()=>new Promise(async(d,p)=>{if(!a||!s){p(new Error("User must be authenticated before exporting their Privy wallet"));return}let m=ye(s);if(!m){p(new Error("Must have a Privy wallet before exporting"));return}ee(!0);let g={onCompleteNavigateTo:"EMBEDDED_WALLET_KEY_EXPORT_SCREEN",onFailure:p},O=await Me();if(!O||!k){p(new Error("Must have valid access token to enroll in MFA"));return}if(!k){p(new Error("Must have a Privy wallet before exporting"));return}try{try{await k.connect({accessToken:O,address:m.address}),await k.verifyMfa({accessToken:O})}catch(me){if(Eo(me))await ue.recoverEmbeddedWallet();else throw me}}catch(me){p(me);return}let G={appId:e.appId,origin:t.apiUrl,onSuccess:d,onFailure:p};$({keyExport:G,connectWallet:g}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")}),promptMfa:Jc,async init(d){let p;switch(d){case"sms":p=new zs("verify");break;case"totp":return;default:throw new Error(`Unsupported MFA method: ${d}`)}t.startMfaFlow(p),await p.init()},async submit(d,p){switch(d){case"totp":case"sms":Lr.current?.resolve({mfaMethod:d,mfaCode:p}),await new Promise((m,g)=>{Zt.current={resolve:m,reject:g}});break;default:throw Lr.current?.reject(new P("Unsupported MFA method")),new P(`Unsupported MFA method: ${d}`)}},cancel(){Lr.current?.reject(new P("MFA canceled"))},async initEnrollmentWithSms(d){let p=await Me();if(!p||!k)throw new Error("Must have valid access token to enroll in MFA");await k.initEnrollMfa({method:"sms",accessToken:p,phoneNumber:d.phoneNumber})},enrollInMfa(d){return new Promise((p,m)=>{if(!d){ue.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."),$({mfaEnrollmentFlow:{mfaMethods:L.mfa.methods,onSuccess:p,onFailure:m}}),q("MFA_ENROLLMENT_FLOW_SCREEN")})},async initEnrollmentWithTotp(){let d=await Me();if(!d||!k)throw new Error("Must have valid access token to enroll in MFA");let p=await k.initEnrollMfa({method:"totp",accessToken:d});return{secret:p.secret,authUrl:p.authUrl}},async submitEnrollmentWithSms(d){let p=await Me();if(!p||!k)throw new Error("Must have valid access token to enroll in MFA");await k.submitEnrollMfa({method:"sms",accessToken:p,phoneNumber:d.phoneNumber,code:d.mfaCode});let m=await t.getAuthenticatedUser();c(m)},async submitEnrollmentWithTotp(d){let p=await Me();if(!p||!k)throw new Error("Must have valid access token to enroll in MFA");await k.submitEnrollMfa({method:"totp",accessToken:p,code:d.mfaCode});let m=await t.getAuthenticatedUser();c(m)},async unenroll(d){let p=await Me();if(!p||!k)throw new Error("Must have valid access token to remove MFA");await k.unenrollMfa({method:d,accessToken:p});let m=await t.getAuthenticatedUser();c(m)},isHeadlessOAuthLoading:C,loginWithCode(d){return ue.loginWithCode(d)},initLoginWithEmail(d){return ue.initLoginWithEmail(d)},initLoginWithSms(d){return ue.initLoginWithSms(d)},fundWallet(d,p){return ue.fundWallet(d,p)},initLoginWithHeadlessOAuth(d,p){return ue.initLoginWithHeadlessOAuth(d,p)},loginWithHeadlessOAuth(d){return ue.loginWithHeadlessOAuth(d)},isModalOpen:r};Ty=Ro.signMessage,xy=Ro.signTypedData,Sy=async(...d)=>{let p=await Yc(...d);return L.embeddedWallets.waitForTransactionConfirmation&&await p.wait(),p};let Zc=!!e.config?.headless,ue=(()=>({headless:Zc,isNewUserThisSession:y,linkingHint:U,pendingTransaction:null,walletConnectionStatus:R,mipdStore:_,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(k)return k;let p=new Promise(O=>{dt(()=>G=>O(G))}),m=new Promise(O=>setTimeout(()=>O(null),d)),g=await Promise.race([p,m]);return dt(null),g},getAuthFlow:()=>t.authFlow,getAuthMeta:()=>t.authFlow?.meta,closePrivyModal:(d={shouldCallAuthOnSuccess:!0,isSuccess:!1})=>{let p=n&&a&&s;J.current==="login"?d.shouldCallAuthOnSuccess&&p?(N(M,"login","onComplete",s,y,!1,K.current??null),e.onSuccess?.(s,y)):N(M,"login","onError","exited_auth_flow"):J.current==="link"&&K.current&&(d.isSuccess&&p?N(M,"linkAccount","onSuccess",s,K.current):N(M,"linkAccount","onError","exited_link_flow")),B(null),J.current=null,K.current=null,E(!1),o(!1),setTimeout(()=>{t.authFlow=void 0},200),t.createAnalyticsEvent("modal_closed")},openPrivyModal:q,connectWallet:Nt,initLoginWithWallet:async(d,p)=>{K.current="siwe",so(d,p)},loginWithWallet:async()=>{if(!n)throw new Io;if(!(t.authFlow instanceof fo))throw new P("Must initialize SIWE flow first.");let d,p;if(a)try{d=await t.link(),K.current="siwe"}catch(m){throw N(M,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{({user:d,isNewUser:p}=await t.authenticate()),K.current="siwe"}catch(m){throw N(M,"login","onError",m.privyErrorCode||"generic_connect_wallet_error"),m}c(d||s||null),E(p||!1),l(!0)},initLoginWithFarcaster:async d=>{let p=new Bn(d);t.startAuthFlow(p);try{K.current="farcaster",await p.initializeFarcasterConnect()}catch(m){throw J.current==="login"?N(M,"login","onError",m.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",m.privyErrorCode||"unknown_auth_error"),m}},loginWithFarcaster:async()=>{if(!n)throw new Io;if(!(t.authFlow instanceof Bn))throw new P("Must initialize Farcaster flow first.");let d,p;if(a)try{d=await t.link(),K.current="farcaster"}catch(m){throw N(M,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{({user:d,isNewUser:p}=await t.authenticate()),K.current="farcaster"}catch(m){throw N(M,"login","onError",m.privyErrorCode||"unknown_auth_error"),m}c(d||null),E(p||!1),l(!0)},async initLoginWithOAuth(d,p){if(K.current=d,Xs()){if(d==="google"&&Vs(window.navigator.userAgent)){Re("IN_APP_BROWSER_LOGIN_NOT_POSSIBLE");return}}else{Re("IN_APP_BROWSER_LOGIN_NOT_POSSIBLE");return}let m=new er({provider:d});p&&m.addCaptchaToken(p),t.startAuthFlow(m);let g=await t.authFlow.getAuthorizationUrl();g&&g.url&&window.location.assign(g.url)},async loginWithOAuth(d){if(!(t.authFlow instanceof er))throw new P("Must initialize OAuth flow before calling loginWithOAuth");let p=Ge.get(po),m=t.authFlow.meta.stateCode;if(p!==m)throw t.createAnalyticsEvent("possible_phishing_attempt",{provider:d,storedStateCode:p??"",returnedStateCode:m??""}),new P("Unexpected auth flow. This may be a phishing attempt.");let g,O;if(a)try{g=await t.link(),K.current=d}catch(G){throw N(M,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}else try{({user:g,isNewUser:O}=await t.authenticate()),K.current=d}catch(G){throw J.current==="login"?N(M,"login","onError",G.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}c(g),E(O||!1),l(!0)},async initLoginWithHeadlessOAuth(d,p){if(Xs()){if(d==="google"&&Vs(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 er({provider:d,headless:!0});p&&m.addCaptchaToken(p);let g=await t.startAuthFlow(m).getAuthorizationUrl();g?.url&&window.location.assign(g.url)},async loginWithHeadlessOAuth(d){T(!0),t.startAuthFlow(new er(d));let p=Ge.get(po),m=d.stateCode;if(p!==m)throw t.createAnalyticsEvent("possible_phishing_attempt",{provider:d.provider,storedStateCode:p??"",returnedStateCode:m??""}),T(!1),new P("Unexpected auth flow. This may be a phishing attempt.");let g,O;if(a)try{g=await t.link(),K.current=d.provider}catch(G){throw N(M,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}else try{({user:g,isNewUser:O}=await t.authenticate()),K.current=d.provider}catch(G){throw J.current==="login"?N(M,"login","onError",G.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}return c(g),E(O||!1),l(!0),T(!1),g??void 0},initLoginWithEmail:async(d,p)=>{let m=new Nr(d,p);t.startAuthFlow(m);try{K.current="email",await m.sendCodeEmail()}catch(g){throw J.current==="login"?N(M,"login","onError",g.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",g.privyErrorCode||"failed_to_link_account"),g}},initUpdateEmail:async(d,p,m)=>{let g=new Bi(d,p,m);t.startAuthFlow(g),await g.sendCodeEmail()},initLoginWithSms:async(d,p)=>{let m=new ho(d,p);t.startAuthFlow(m);try{K.current="sms",await m.sendSmsCode()}catch(g){throw J.current==="login"?N(M,"login","onError",g.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",g.privyErrorCode||"failed_to_link_account"),g}},resendEmailCode:async()=>{await t.authFlow?.sendCodeEmail()},resendSmsCode:async()=>{await t.authFlow?.sendSmsCode()},loginWithCode:async d=>{if(!n)throw new Io;if(t.authFlow instanceof Nr)t.authFlow.meta.emailCode=d.trim();else if(t.authFlow instanceof ho)t.authFlow.meta.smsCode=d.trim();else throw new P("Must initialize a passwordless code flow first");let p,m;if(a)try{p=await t.link()}catch(g){throw N(M,"linkAccount","onError",g.privyErrorCode||"failed_to_link_account"),g}else try{({user:p,isNewUser:m}=await t.authenticate())}catch(g){throw N(M,"login","onError",g.privyErrorCode||"unknown_auth_error"),g}c(p||s||null),E(m||!1),l(!0)},refreshUser:async()=>{let d=await t.getAuthenticatedUser();return c(d),d},walletProxy:k,createAnalyticsEvent:(d,p,m)=>t.createAnalyticsEvent(d,p,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(O=>O.type==="wallet"&&O.walletClientType==="privy"),g=await Me();if(!g||!k||!m){p(new Error("Must have valid access token and Privy wallet to recover wallet"));return}ee(!0);try{await k.connect({accessToken:g,address:m.address}),d(!0)}catch(O){Eo(O)&&m.recoveryMethod==="privy"?(t.createAnalyticsEvent("embedded_wallet_pinless_recovery_started",{walletAddress:m.address}),(await k.recover({address:m.address,accessToken:g})).address||p(new Error("Unable to recover wallet")),t.createAnalyticsEvent("embedded_wallet_recovery_completed",{walletAddress:m.address}),d(!0)):Eo(O)?($({recoverWallet:{privyWallet:m,onFailure:p,onSuccess:()=>d(!0)}}),q("EMBEDDED_WALLET_RECOVERY_SCREEN")):p(O)}}),getFiatOnRampConfig:Qt,setReadyToTrue:()=>{i(!0),be?.()},updateWallets:()=>Or(),fundWallet:async(d,p)=>{let{signedUrl:m,externalTransactionId:g}=await Qt(d,p);$({fiatOnRampPrompt:{signedUrl:m},fiatOnRampStatus:{externalTransactionId:g}}),q("FIAT_ON_RAMP_PROMPT_SCREEN")}}))();_y=ue.recoverEmbeddedWallet;let Iy=v4(()=>({wallets:u,ready:xe}),[u,xe]);return vr(ae.Provider,{value:Ro,children:vr(Cl.Provider,{value:M,children:vr(Bc.Provider,{value:Iy,children:Py(Kp,{...L,children:[e.children,Py(wl.Provider,{value:ue,children:[!Zc&&L.captchaEnabled&&n&&!a&&vr(vl,{delayedExecution:!1}),vr(hy,{theme:{...L.appearance.palette||{}}}),vr(Gp,{data:Q,setModalData:$,setInitialScreen:x,initialScreen:v,authenticated:a,open:r,children:vr(wy,{open:r})}),ie&&j?vr(Ey,{appId:e.appId,clientAnalyticsId:t.clientAnalyticsId,origin:t.apiUrl,mfaMethods:s?.mfaMethods,mfaPromise:Lr,mfaSubmitPromise:Zt,onLoad:z,onLoadFailed:()=>null}):null]})]})})})})};import{useContext as P4}from"react";function T4(e){let{login:t}=P4(ae);return ve("login",e),{login:t}}import{useContext as x4}from"react";function S4(e){let{logout:t}=x4(ae);return ve("logout",e),{logout:t}}import{useCallback as Ay,useEffect as _4}from"react";function A4(){let e=de(),t=Ta(),{initLoginWithHeadlessOAuth:r,loginWithHeadlessOAuth:o,isHeadlessOAuthLoading:n,ready:i,user:a}=H(),l=Ay(async c=>{if(e.enabled&&e.status!=="success")throw new Ht(e.error,null,"captcha_failure");return r(c.provider,e.token)},[r,e]),s=Ay(async()=>{let c=Gn();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");try{return await o(c)}catch(u){throw u}finally{Vn()}},[o]);return _4(()=>{let c=Gn();i&&t&&c.inProgress&&c.headless&&s()},[i,t]),{initOAuth:l,loginWithOAuth:s,loading:n}}import{useCallback as ky}from"react";var k4=()=>{let e=de(),{initLoginWithEmail:t,loginWithCode:r}=H(),o=ky(async({email:i})=>{if(!i)throw new Error("Email required to send OTP code");return t(i)},[t]),n=ky(async({code:i})=>{if(e.enabled&&e.status==="error")throw new Ht(e.error,null,"captcha_failure");return r(i)},[r,e.status]);return{sendCode:o,loginWithCode:n}};import{useCallback as Ry}from"react";var R4=()=>{let e=de(),{initLoginWithSms:t,loginWithCode:r}=H(),o=Ry(async({phoneNumber:i})=>{if(!i)throw new Error("SMS required to send OTP code");return t(i)},[t]),n=Ry(async({code:i})=>{if(e.enabled&&e.status!=="success")throw new Ht(e.error,null,"captcha_failure");return r(i)},[r,e.status]);return{sendCode:o,loginWithCode:n}};import{useContext as I4}from"react";function M4(e){let{linkEmail:t,linkPhone:r,linkWallet:o,linkGoogle:n,linkApple:i,linkTwitter:a,linkDiscord:l,linkGithub:s,linkLinkedIn:c,linkTiktok:u,linkSpotify:h,linkFarcaster:f}=I4(ae);return ve("linkAccount",e),{linkEmail:t,linkPhone:r,linkWallet:o,linkGoogle:n,linkApple:i,linkTwitter:a,linkDiscord:l,linkGithub:s,linkLinkedIn:c,linkTiktok:u,linkSpotify:h,linkFarcaster:f}}import{useContext as W4}from"react";function L4(e){let{connectWallet:t}=W4(ae);return ve("connectWallet",e),{connectWallet:t}}import{useContext as O4}from"react";function N4(e){let{createWallet:t}=O4(ae);return ve("createWallet",e),{createWallet:t}}var D4=()=>{let{fundWallet:e}=H();return{fundWallet:e}};import{useContext as U4}from"react";function F4(e){let{sendTransaction:t}=U4(ae);return ve("sendTransaction",e),{sendTransaction:t}}import{useContext as B4}from"react";function H4(e){let{setWalletPassword:t}=B4(ae);return ve("setWalletPassword",e),{setWalletPassword:t}}import{useContext as G4}from"react";function V4(e){let{signMessage:t}=G4(ae);return ve("signMessage",e),{signMessage:t}}import{useContext as z4}from"react";function $4(e){let{signTypedData:t}=z4(ae);return ve("signTypedData",e),{signTypedData:t}}import{useContext as q4}from"react";var j4=()=>{let{isModalOpen:e}=q4(ae);return{isOpen:e}};import{useContext as K4}from"react";function Y4(e){let{getAccessToken:t}=K4(ae);return ve("accessToken",e),{getAccessToken:t}}function J4(e,t){return{...e,rpcUrls:{...e.rpcUrls,privyWalletOverride:{http:[t]}}}}export{tr as AsExternalProvider,vl as Captcha,Kn as ConnectorManager,Yn as PrivyClient,b4 as PrivyProvider,ge as PrivyProxyProvider,qn as SUPPORTED_CHAINS,ol as VERSION,lt as WalletConnector,J4 as addRpcUrlOverrideToChain,jl as errorIndicatesMaxMfaRetries,ln as errorIndicatesMfaTimeout,cn as errorIndicatesMfaVerificationFailed,Me as getAccessToken,L4 as useConnectWallet,N4 as useCreateWallet,D4 as useFundWallet,M4 as useLinkAccount,T4 as useLogin,k4 as useLoginWithEmail,A4 as useLoginWithOAuth,R4 as useLoginWithSms,S4 as useLogout,Tn as useMfa,Pi as useMfaEnrollment,j4 as useModalStatus,H as usePrivy,bl as useRegisterMfaListener,F4 as useSendTransaction,H4 as useSetWalletPassword,V4 as useSignMessage,$4 as useSignTypedData,Y4 as useToken,Ri as useWallets};
|
|
2714
|
+
`;import{jsx as Fe,jsxs as vy}from"react/jsx-runtime";var i4={["LANDING"]:Lf,["CONNECT_OR_CREATE"]:Mf,["AWAITING_PASSWORDLESS_CODE"]:bu,["AWAITING_CONNECTION"]:Bu,["AWAITING_CONNECT_ONLY_CONNECTION"]:zu,["AWAITING_FARCASTER_CONNECTION"]:Km,["PHANTOM_INTERSTITIAL_SCREEN"]:Zh,["LOGIN_FAILED_SCREEN"]:Hf,["AWAITING_OAUTH_SCREEN"]:jh,["ALLOWLIST_REJECTION_SCREEN"]:pu,["INSTALL_PHANTOM_SCREEN"]:cf,["LINK_EMAIL_SCREEN"]:Of,["LINK_PHONE_SCREEN"]:Nf,["LINK_WALLET_SCREEN"]:Df,["UPDATE_EMAIL_SCREEN"]:my,["CONNECT_ONLY_LANDING_SCREEN"]:Du,["CONNECT_ONLY_AUTHENTICATED_SCREEN"]:Lu,["EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN"]:km,["EMBEDDED_WALLET_CREATED_SCREEN"]:Zu,["EMBEDDED_WALLET_CONNECTING_SCREEN"]:Yu,["EMBEDDED_WALLET_RECOVERY_SCREEN"]:Mm,["EMBEDDED_WALLET_KEY_EXPORT_SCREEN"]:tm,["EMBEDDED_WALLET_SIGN_REQUEST_SCREEN"]:ay,["EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN"]:ny,["FIAT_ON_RAMP_PROMPT_SCREEN"]:ef,["FIAT_ON_RAMP_STATUS_SCREEN"]:rf,["EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN"]:Im,["EMBEDDED_WALLET_PASSWORD_UPDATE_SCREEN"]:Rm,["MFA_ENROLLMENT_FLOW_SCREEN"]:th,["CAPTCHA_SCREEN"]:xu,["ERROR_SCREEN"]:Wm,["IN_APP_BROWSER_LOGIN_NOT_POSSIBLE"]:of,["AFFIRMATIVE_CONSENT_SCREEN"]:cu},a4=["LANDING","AWAITING_CONNECTION"],s4=({isMfaVerifying:e,onMfaVerificationComplete:t})=>{let{ready:r,isModalOpen:o}=H(),{headless:n}=W(),{ready:i,currentScreen:a}=S(),{status:l,execute:s,reset:c,enabled:u}=de(),h=r4(null),f=Jp(h),y=o&&a&&a4.includes(a)&&!n&&l==="ready";if(gy(()=>{y&&s()},[y]),gy(()=>{!o&&u&&c()},[o,u]),(!r||!i)&&a!=="AWAITING_OAUTH_SCREEN")return vy(En,{children:[Fe(A,{}),Fe(X,{}),Fe(zf,{children:Fe(St,{})}),Fe(te,{}),Fe(oe,{})]});if(!a&&e)return Fe(En,{style:{height:f},children:Fe("div",{ref:h,children:Fe(zc,{open:e,onClose:t})})});if(!a)return null;let E=i4[a];return Fe(En,{style:{height:f},children:vy("div",{ref:h,children:[Fe(Sr,{if:!!e,children:Fe(E,{})}),Fe(Sr,{if:!e,children:Fe(zc,{open:e,onClose:t})})]})})},l4=()=>{let{closePrivyModal:e}=W(),{onUserCloseViaDialogOrKeybindRef:t}=S();return{gracefulClosePrivyModal:t4(()=>{if(t?.current)t.current();else return e({shouldCallAuthOnSuccess:!1})},[e])}},wy=({open:e})=>{let{app:t}=S(),{gracefulClosePrivyModal:r}=l4(),[o,n]=o4(!1);bl({onMfaRequired:()=>{t?.mfa.noPromptOnMfaRequired||n(!0)}});let i=Fe(yy,{children:Fe(s4,{isMfaVerifying:o,onMfaVerificationComplete:()=>n(!1)})}),a=e||o,l=t?.render.inDialog?Fe(Vf,{open:a,id:"privy-dialog","aria-label":"log in or sign up","aria-labelledby":"privy-dialog-title",onClick:()=>r(),children:i}):i;if(typeof window<"u"&&t?.render.inParentNodeId){let s=document.getElementById(t.render.inParentNodeId);if(s)return n4.createPortal(l,s)}return l};import{useState as c4}from"react";import{useEffect as Cy,useRef as by}from"react";var Gs=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: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;default:throw new Error(`invalid wallet event type ${t}`)}}};async function ko(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 Se("missing_or_invalid_mfa","MFA verification failed, retry."));let h=await new Promise((f,y)=>{r.current={resolve:f,reject:y};let E=1e3*60*5;setTimeout(()=>{let v=new Se("mfa_timeout","Timed out waiting for MFA code");o.current?.reject(v),y(v)},E)});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 Se("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw o.current?.reject(u),u}return c}import{jsx as h4}from"react/jsx-runtime";var d4=function(e){return()=>`id-${e++}`}(0);function p4(e){return typeof e.event=="string"&&/^privy:.+/.test(e.event)}function yr(e){return e.error!==void 0}var Jt=new Gs,jc=new Map,u4=(e,t)=>typeof t=="bigint"?t.toString():t,m4=(e,t)=>`${e}${JSON.stringify(t,u4)}`;function gr(e,t,r,o){let n=r.contentWindow;if(!n)throw new Error("iframe not initialized");let i=m4(e,t);if(e==="privy:wallet:create"){let l=jc.get(i);if(l)return l}let a=new Promise((l,s)=>{let c=d4();Jt.enqueue(c,{resolve:l,reject:s}),n.postMessage({id:c,event:e,data:t},o)}).finally(()=>{jc.delete(i)});return jc.set(i,a),a}function f4(e){switch(e.event){case"privy:iframe:ready":let t=Jt.dequeue(e.event,e.id);return yr(e)?t.reject(new Se(e.error.type,e.error.message)):t.resolve(e.data);case"privy:wallet:create":let r=Jt.dequeue(e.event,e.id);return yr(e)?r.reject(new Se(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallet:connect":let o=Jt.dequeue(e.event,e.id);return yr(e)?o.reject(new Se(e.error.type,e.error.message)):o.resolve(e.data);case"privy:wallet:recover":let n=Jt.dequeue(e.event,e.id);return yr(e)?n.reject(new Se(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallet:rpc":let i=Jt.dequeue(e.event,e.id);return yr(e)?i.reject(new Se(e.error.type,e.error.message)):i.resolve(e.data);case"privy:wallet:set-recovery-password":let a=Jt.dequeue(e.event,e.id);return yr(e)?a.reject(new Se(e.error.type,e.error.message)):a.resolve(e.data);case"privy:mfa:verify":let l=Jt.dequeue(e.event,e.id);return yr(e)?l.reject(new Se(e.error.type,e.error.message)):l.resolve(e.data);case"privy:mfa:init-enrollment":{let s=Jt.dequeue(e.event,e.id);return yr(e)?s.reject(new Se(e.error.type,e.error.message)):s.resolve(e.data)}case"privy:mfa:submit-enrollment":{let s=Jt.dequeue(e.event,e.id);return yr(e)?s.reject(new Se(e.error.type,e.error.message)):s.resolve(e.data)}case"privy:mfa:unenroll":{let s=Jt.dequeue(e.event,e.id);return yr(e)?s.reject(new Se(e.error.type,e.error.message)):s.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}function Ey(e){let t=by(null),r=by(e.mfaMethods),o=Xp(),[n,i]=c4(!1);return Cy(()=>{r.current=e.mfaMethods},[e.mfaMethods]),Cy(()=>{if(!n)return;let a=t.current;if(!a)return;function l(f){f&&f.origin===e.origin&&p4(f.data)&&f4(f.data)}let s={create(f){return gr("privy:wallet:create",f,a,e.origin)},connect(f){return gr("privy:wallet:connect",f,a,e.origin)},recover(f){return ko(y=>gr("privy:wallet:recover",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},rpc(f){return ko(y=>gr("privy:wallet:rpc",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},setRecoveryPassword(f){return ko(y=>gr("privy:wallet:set-recovery-password",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},verifyMfa(f){return ko(y=>gr("privy:mfa:verify",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)},initEnrollMfa(f){return ko(y=>gr("privy:mfa:init-enrollment",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o)},submitEnrollMfa(f){return gr("privy:mfa:submit-enrollment",f,a,e.origin)},unenrollMfa(f){return ko(y=>gr("privy:mfa:unenroll",{...f,...y},a,e.origin),r.current,e.mfaPromise,e.mfaSubmitPromise,o,!0)}};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 $d(()=>gr("privy:iframe:ready",{},a,e.origin),{abortSignal:h.signal}).then(c,u),()=>{window.removeEventListener("message",l),h.abort()}},[n]),h4("iframe",{ref:t,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},onLoad:()=>i(!0),src:Ki(e.origin,`/apps/${e.appId}/embedded-wallets`,{caid:e.clientAnalyticsId})})}function Vs(e){let t=e.toLowerCase();return["fbav","fban","instagram","snapchat"].some(o=>t.includes(o))}var zs=class{constructor(t,r){this.meta={action:t,phoneNumber:r}}async init(){if(!this.meta.action)throw new P("action required");if(!this.api)throw new P("Auth flow has no API instance");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new P("phone number must be set when initialzing authentication.");try{await this.api.post(Td,{action:this.meta.action,phoneNumber:this.meta.phoneNumber})}catch(t){throw le(t)}}async authenticate(){if(!this.meta.action)throw new P("action required");if(!this.api)throw new P("Mfa flow has no API instance");if(!this.meta.smsCode)throw new P("sms code must be set prior to calling authenticate.");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new P("phone number must be set prior to calling authenticate.");try{let t=await this.api.post(xd,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return ft(t)}catch(t){throw le(t)}}};import{jsx as vr,jsxs as Py}from"react/jsx-runtime";var On;function w4(e){return typeof e=="string"&&e.length===25}function Me(){if(!On){let e=ce.get(co);return Promise.resolve(e||null)}return On.getAccessToken()}var Ty,dp=(e,t)=>Ty(e,t),xy,pp=(e,t)=>xy(e,t),Sy,up=(e,t)=>Sy(e,t),_y,mp=()=>_y(),C4=()=>{let t=new URLSearchParams(window.location.search).get("privy_token");if(!t)return;ce.put(Dn,t);let r=new URL(window.location.href);r.searchParams.delete("privy_token"),window.history.pushState({},"",r)},b4=({config:e,...t})=>{if(!w4(t.appId))throw new P("Cannot initialize the Privy provider with an invalid Privy app ID");On||(On=new Yn({appId:t.appId,apiUrl:t.apiUrl||Vi}));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(Bp,{client:On,clientConfig:r,legacyCreateEmbeddedWalletFlag:t.createPrivyWalletOnLogin,children:vr(E4,{...t,config:r,client:On})})},E4=e=>{let t=e.client,[r,o]=ke(!1),[n,i]=ke(!1),[a,l]=ke(!1),[s,c]=ke(null),[u,h]=ke([]),f=Ln(u),[y,E]=ke(!1),[v,x]=ke(null),[C,T]=ke(!1),[R,I]=ke({status:"disconnected",connectedWallet:null,connectError:null,connector:null,connectRetry:b}),[_,F]=ke(null),[U,B]=ke(null),[k,z]=ke(null),L=Pa(),j=Ta(),[ie,ee]=ke(!0),[Q,$]=ke({}),[be,he]=ke(null),[wr,dt]=ke(null),[xe,pe]=ke(!1),[pt,Ot]=ke(!1),Lr=Ln(null),Zt=Ln(null),M=Ln(Zp);t.onStoreToken=d=>{d&&N(M,"accessToken","onAccessTokenGranted",d)},t.onDeleteToken=()=>{N(M,"accessToken","onAccessTokenRemoved")};let K=Ln(null),J=Ln(null),Nn=g4(d=>{let p=t.connectors?.walletsReady||!1;return a&&s?.linkedAccounts?.some(g=>g.type==="wallet"&&g.walletClientType==="privy")?p&&d?.some(g=>g?.walletClientType==="privy"):p},[a,s?.linkedAccounts,t?.connectors?.walletsReady]),q=d=>{x(d),setTimeout(()=>{o(!0)},15),t.createAnalyticsEvent("modal_open",{initialScreen:d})},Re=d=>{L.embeddedWallets.createOnLogin!=="off"&&ee(!0),q(d)};Wr(()=>{if(!k||!s){t.connectors?.removeEmbeddedWalletConnector();return}let d=s?.linkedAccounts.filter(p=>p.type==="wallet"&&p.walletClientType==="privy");if(d&&d.length>0){let p=d[0].address;t.connectors?.addEmbeddedWalletConnector(k,p,L.defaultChain,e.appId)}},[k,s]),Wr(()=>{k&&wr?.(k)},[k]),Wr(()=>{(async()=>{if(!L.customAuth?.enabled)return;ee(!0);let{getCustomAccessToken:p,isLoading:m}=L.customAuth;if(!(!n||m))try{let g=await p();if(!g){await Ro.logout();return}if(a)return;t.startAuthFlow(new Mo(g));let{user:O,isNewUser:G}=await t.authenticate();O||await Ro.logout(),c(O||null),E(G||!1),l(!0),Ot(!0)}catch(g){console.warn(g),a&&await Ro.logout()}})()},[L.customAuth?.enabled,L.customAuth?.getCustomAccessToken,L.customAuth?.isLoading,n,a]),Wr(()=>{pt&&k&&s&&Pt(s,e.config?.embeddedWallets?.createOnLogin)&&(Ot(!1),Cr(s,Lo).catch(console.error))},[pt&&k&&s]),Wr(()=>{async function d(){let p=at();C4();let m=y4();F(m),t.initializeConnectorManager({walletConnectCloudProjectId:L.walletConnectCloudProjectId,rpcConfig:L.rpcConfig,chains:L.chains,defaultChain:L.defaultChain,store:m,walletList:L.appearance.walletList,shouldEnforceDefaultChainOnConnect:L.shouldEnforceDefaultChainOnConnect,appName:L.name??"Privy"}),t.connectors?.initialize().then(()=>{qs()});let g=await t.getAuthenticatedUser();e.config?.customAuth?.enabled||(l(!!g),g&&N(M,"login","onComplete",g,!1,!0,null),c(g)),p||ue.setReadyToTrue(),p&&(g?J.current="link":J.current="login")}!n&&j&&d()},[t,be,n,j]);let at=()=>{let d=Gn();return!d.inProgress||d.headless?!1:(t.startAuthFlow(new er(d)),Re("AWAITING_OAUTH_SCREEN"),!0)},ao=async(d,p,m,g)=>{let O=await t.connectors?.createWalletConnector(d,p)||null;Nt(O,p,m,g)};async function Nt(d,p,m,g){if(d)I({status:"disconnected",connectedWallet:null,connectError:null,connector:d,connectRetry:b});else return I({status:"disconnected",connectedWallet:null,connectError:new Y("Unable to connect to wallet."),connector:null,connectRetry:b}),g?.(null,m);d instanceof nr&&p&&await d.resetConnection(p),I({connector:d,status:"connecting",connectedWallet:null,connectError:null,connectRetry:()=>Nt(d,p,m,g)});try{let O=await d.connect({showPrompt:!0});if(L.shouldEnforceDefaultChainOnConnect&&!L.chains.find(G=>G.id===Number(O?.chainId))&&!(O?.connectorType==="wallet_connect_v2"&&O?.walletClientType==="metamask")){I(G=>({...G,connector:d,status:"switching_to_supported_chain",connectedWallet:null,connectError:null,connectRetry:b}));try{await O?.switchChain(L.defaultChain.id),O&&(O.chainId=No(mo(L.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${L.defaultChain.id}`)}}return I(G=>({...G,status:"connected",connectedWallet:O,connectError:null,connectRetry:b})),O&&!J.current&&N(M,"connectWallet","onSuccess",O),g?.(O,m)}catch(O){return O instanceof He?(console.warn(O.cause?O.cause:O.message),J.current||N(M,"connectWallet","onError",O.privyErrorCode||"generic_connect_wallet_error")):(console.warn(O),J.current||N(M,"connectWallet","onError","unknown_connect_wallet_error")),I(G=>({...G,status:"disconnected",connectedWallet:null,connectError:O})),g?.(null,m)}}let so=async(d,p)=>{if(d===null)return;let m=new fo(d,p);t.startAuthFlow(m)},qs=()=>{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"&&!Dr()&&Re("LOGIN_FAILED_SCREEN"),!t.connectors)throw new P("Connector not initialized");q("AWAITING_CONNECTION");let g=new URL(window.location.href);g.searchParams.delete("privy_connector"),g.searchParams.delete("privy_wallet_client"),window.history.pushState({},"",g),ao(p,m,void 0,so)};Wr(()=>{n&&a&&s===null&&t.getAuthenticatedUser().then(c)},[n,a,s,t]);let Ie=()=>{if(!a)throw N(M,"linkAccount","onError","must_be_authenticated"),new P("User must be authenticated before linking an account.")},lo=()=>{Ie(),K.current="siwe",J.current="link",q("LINK_WALLET_SCREEN")},ut=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},Be=async d=>{if(!t.connectors)throw new P("Connector not initialized");let p=t.connectors.findWalletConnector(d.connectorType,d.walletClientType)||null;if(I(m=>({...m,connector:p,status:"connected",connectedWallet:d,connectError:null,connectRetry:b})),L.captchaEnabled&&!a){let m={callback:g=>so(d,g),userIntentRequired:!1,onSuccessNavigateTo:"AWAITING_CONNECTION",onErrorNavigateTo:"ERROR_SCREEN"};$({captchaModalData:m}),Re("CAPTCHA_SCREEN")}else await so(d),Re("AWAITING_CONNECTION")},Qt=async(d,p)=>{if(!L.fiatOnRamp.enabled)throw new P("Fiat on-ramp is not enabled");if(!p||!p.provider||p.provider==="moonpay"){let{signedUrl:m,externalTransactionId:g}=await Qm(t,d,p?.config??{},L.appearance.palette,L.fiatOnRamp.useSandbox);return{signedUrl:m,externalTransactionId:g}}else throw new P("Unsupported fund provider. Currently supported option is `moonpay`.")},Or=()=>{h(d=>{let p=t.connectors?.wallets.map(m=>({...m,linked:ut(m),loginOrLink:async()=>{if(!await m.isConnected())throw new P("Wallet is not connected");if(m.connectorType==="embedded"&&m.walletClientType==="privy")throw new P("Cannot link or login with embedded wallet");Be(m)},fund:async g=>{let{signedUrl:O,externalTransactionId:G}=await Qt(m.address,g);$({fiatOnRampPrompt:{signedUrl:O},fiatOnRampStatus:{externalTransactionId:G}}),q("FIAT_ON_RAMP_PROMPT_SCREEN")},unlink:async()=>{if(!a)throw new P("User is not authenticated.");if(m.connectorType==="embedded"&&m.walletClientType==="privy")throw new P("Cannot unlink an embedded wallet");let g=await t.unlinkWallet(m.address);c(g)}}))||[];return pe(Nn(p)),ra(d,p)?d:p})};Wr(()=>{Or()},[s?.linkedAccounts,a,n]),Wr(()=>{if(n){if(!t.connectors)throw new P("Connector not initialized");Or(),t.connectors.on("walletsUpdated",Or)}},[n]);let Wi=()=>{q(a?"CONNECT_ONLY_AUTHENTICATED_SCREEN":"CONNECT_ONLY_LANDING_SCREEN")};Wr(()=>{if(!u[0])return;let d=u[0],p=f.current.find(g=>g.address===d.address),m;if(d.walletClientType==="privy"?m=s?.linkedAccounts.find(g=>g.type==="wallet"&&g.address===d.address&&g.walletClientType==="privy"):m=s?.linkedAccounts.find(g=>g.type==="wallet"&&g.address===d.address&&g.walletClientType!=="privy"),!p&&m){let g=Object.assign({},s);g.wallet=m&&{address:m.address,chainType:m.chainType,chainId:m.chainId,walletClient:m.walletClient,walletClientType:m.walletClientType,connectorType:m.connectorType},c(g)}f.current=u},[u]);let Cr=async(d,p)=>{if(ye(d))throw N(M,"createWallet","onError","embedded_wallet_already_exists"),new Error("Only one Privy wallet per user is currently allowed");let[g,O]=await Promise.all([ue.initializeWalletProxy(p),Me()]);if(!g&&e.config?.customAuth?.enabled)throw N(M,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to connect to wallet proxy");if(!g||!O||e.config?.embeddedWallets?.requireUserPasswordOnCreate)return new Promise((G,me)=>{ee(!0),$({createWallet:{onSuccess:st=>{N(M,"createWallet","onSuccess",st),G(st)},onFailure:st=>{N(M,"createWallet","onError","unknown_embedded_wallet_error"),me(st)},callAuthOnSuccessOnClose:!1}}),q("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")});{await g.create({accessToken:O});let G=await ue.refreshUser(),me=ye(G);if(!me)throw N(M,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");return N(M,"createWallet","onSuccess",me),me}},js=d=>{if(!L.chains.map(p=>p.id).includes(d))throw new Y(`Chain ID ${d} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,"unsupported_chain_id")},Yc=(d,p,m)=>new Promise(async(g,O)=>{if(!a||!s){N(M,"sendTransaction","onError","must_be_authenticated"),O(new Error("User must be authenticated before signing with a Privy wallet"));return}let G=ye(s);if(!G){N(M,"sendTransaction","onError","embedded_wallet_not_found"),O(new Error("Must have a Privy wallet before signing"));return}ee(!0);let me=t.connectors?.findWalletConnector("embedded","privy")?.proxyProvider,Ye=d.chainId?Number(d.chainId):me.chainId;js(Ye);let st=Object.assign({},d,{chainId:Ye}),br=async()=>{let Je=await Me();if(!Je||!k){N(M,"sendTransaction","onError","embedded_wallet_not_found"),O(new Error("Must have valid access token and Privy wallet to send transaction"));return}try{if(!await ue.recoverEmbeddedWallet()){N(M,"sendTransaction","onError","unknown_connect_wallet_error"),O(new Error("Unable to connect to wallet"));return}let Ft=Pr(st.chainId,L.chains,L.rpcConfig,{appId:e.appId}),Ks=await Rn(G.address,st,Ft);if(L.embeddedWallets.noPromptOnSignature){let{totalGasEstimate:My}=await kn(Ks,Ft),{hasSufficientFunds:Wy}=await Ds(G.address,Ks,My,Ft);if(!Wy)throw new Ee(new Tt("Wallet has insufficient funds for this transaction.",Ve.E32603_DEFAULT_INTERNAL_ERROR.eipCode))}let Qc=await Ns(Je,G.address,k,Ks,Ft);N(M,"sendTransaction","onSuccess",Qc),g(Qc)}catch(Ut){N(M,"sendTransaction","onError","transaction_failure"),O(Ut)}};if(L.embeddedWallets.noPromptOnSignature)p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config"),br();else{let Je={transactionRequest:st,onSuccess:Ft=>{N(M,"sendTransaction","onSuccess",Ft),g(Ft)},onFailure:Ft=>{N(M,"sendTransaction","onError","transaction_failure"),O(Ft)},uiOptions:p||{},fundWalletConfig:m},Ut={onCompleteNavigateTo:"EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN",onFailure:Ft=>{N(M,"sendTransaction","onError","unknown_connect_wallet_error"),O(Ft)}};$({connectWallet:Ut,sendTransaction:Je}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")}});function Jc(){return new Promise(async(d,p)=>{let m=await Me();if(!m||!k)throw new Error("Must have valid access token to enroll in MFA");try{await k.verifyMfa({accessToken:m}),d()}catch(g){p(g)}})}let Dt=d=>{if(s?.[d])throw N(M,"linkAccount","onError","cannot_link_more_of_type"),new P(`User already has an account of type ${d} linked.`)},Ro={ready:n,authenticated:a,user:s,walletConnectors:t.connectors||null,connectWallet:Wi,linkWallet:lo,linkEmail:()=>{Ie(),Dt("email"),K.current="email",J.current="link",q("LINK_EMAIL_SCREEN")},linkPhone:()=>{Ie(),Dt("phone"),K.current="sms",J.current="link",q("LINK_PHONE_SCREEN")},linkGoogle:async()=>{Ie(),Dt("google"),J.current="link",await ue.initLoginWithOAuth("google")},linkTwitter:async()=>{Ie(),Dt("twitter"),J.current="link",await ue.initLoginWithOAuth("twitter")},linkDiscord:async()=>{Ie(),Dt("discord"),J.current="link",await ue.initLoginWithOAuth("discord")},linkGithub:async()=>{Ie(),Dt("github"),J.current="link",await ue.initLoginWithOAuth("github")},linkSpotify:async()=>{Ie(),Dt("spotify"),J.current="link",await ue.initLoginWithOAuth("spotify")},linkTiktok:async()=>{Ie(),Dt("tiktok"),J.current="link",await ue.initLoginWithOAuth("tiktok")},linkLinkedIn:async()=>{Ie(),Dt("linkedin"),J.current="link",await ue.initLoginWithOAuth("linkedin")},linkApple:async()=>{Ie(),Dt("apple"),J.current="link",await ue.initLoginWithOAuth("apple")},linkFarcaster:async()=>{Ie(),Dt("farcaster"),await ue.initLoginWithFarcaster(),J.current="link",K.current="farcaster",q("AWAITING_FARCASTER_CONNECTION")},updateEmail:()=>{if(Ie(),!s?.email)throw new P("User does not have an email linked to their account.");J.current="link",K.current="email",q("UPDATE_EMAIL_SCREEN")},login:async()=>{if(n||(await new Promise(d=>{he(()=>d)}),he(null)),a){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}J.current="login",Re("LANDING")},connectOrCreateWallet:async()=>{if(n||(await new Promise(d=>{he(()=>d)}),he(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}Re("CONNECT_OR_CREATE")},logout:async()=>{await t.logout(),c(null),l(!1),x(null),N(M,"logout","onSuccess"),J.current=null,K.current=null,o(!1),ce.del(Un)},getAccessToken:()=>t.getAccessToken(),getEthereumProvider:()=>{if(!s||!s.wallet)return new ge;let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(g=>g.address===d?.address));return!d||!p?new ge:p.proxyProvider},getEthersProvider:()=>{if(!s||!s.wallet)return new Kc(new tr(new ge));let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(g=>g.address===d?.address));return!d||!p?new Kc(new tr(new ge)):new Kc(new tr(p.proxyProvider))},getWeb3jsProvider:()=>{if(!s||!s.wallet)return new Br(new ge);let d=u.find(m=>s.wallet&&m.address===s.wallet.address),p=t.connectors?.walletConnectors.find(m=>m.wallets.find(g=>g.address===d?.address));return!d||!p?new Br(new ge):new Br(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},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},setActiveWallet:async d=>{let p=u.find(g=>$s(g.address)===$s(d)),m=s?.linkedAccounts.find(g=>g.type==="wallet"&&$s(g.address)===$s(d));if(!p||!await p.isConnected())B(d),lo();else if(!p.linked)p.loginOrLink();else{let g=Object.assign({},s);g.wallet=m&&{address:m.address,chainType:m.chainType,chainId:m.chainId,walletClient:m.walletClient,walletClientType:m.walletClientType,connectorType:m.connectorType},c(g)}},forkSession:()=>t.forkSession(),createWallet:async()=>{if(!a||!s)throw N(M,"createWallet","onError","must_be_authenticated"),new Error("User must be authenticated before creating a Privy wallet");return Cr(s,15e3)},setWalletPassword:async()=>{if(!a||!s)throw N(M,"setWalletPassword","onError","must_be_authenticated"),new Error("User must be authenticated before adding password to Privy wallet");let d=ye(s);if(!d||!k)throw N(M,"setWalletPassword","onError","embedded_wallet_not_found"),new Error("Must have a Privy wallet to add a password");if(d.recoveryMethod==="user-passcode")throw N(M,"setWalletPassword","onError","embedded_wallet_password_already_exists"),new Error("Cannot set password. Embedded wallet already has a password.");try{await Jc()}catch(p){throw N(M,"setWalletPassword","onError","missing_mfa_credentials"),p}return new Promise((p,m)=>{ee(!0);let g={onSuccess:G=>{N(M,"setWalletPassword","onSuccess",G),p(G)},onFailure:G=>{N(M,"setWalletPassword","onError","user_exited_set_password_flow"),m(G)},callAuthOnSuccessOnClose:!1},O={onCompleteNavigateTo:"EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN",onFailure:G=>{N(M,"setWalletPassword","onError","unknown_connect_wallet_error"),m(G)}};$({setWalletPassword:g,connectWallet:O}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")})},signMessage:(d,p)=>new Promise(async(m,g)=>{if(!a||!s){N(M,"signMessage","onError","must_be_authenticated"),g(new Error("User must be authenticated before signing with a Privy wallet"));return}let O=ye(s);if(!O){N(M,"signMessage","onError","embedded_wallet_not_found"),g(new Error("Must have a Privy wallet before signing"));return}if(typeof d!="string"||d.length<1){N(M,"signMessage","onError","invalid_message"),g(new Error("Message must be a non-empty string"));return}ee(!0);let G=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let me=await Me();if(!k||!me)throw new Error("Unable to connect to wallet");if(!await ue.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent("embedded_wallet_sign_message_started",{walletAddress:O.address});let{response:st}=await k.rpc({accessToken:me,address:O.address,request:{method:"personal_sign",params:[d,O.address]}}),br=st.data;return t.createAnalyticsEvent("embedded_wallet_sign_message_completed",{walletAddress:O.address}),br};if(L.embeddedWallets.noPromptOnSignature){p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let me=await G();N(M,"signMessage","onSuccess",me),m(me)}catch(me){N(M,"signMessage","onError","unable_to_sign"),g(me??new Ee("Unable to sign message"))}}else{let st={method:"personal_sign",data:d,confirmAndSign:G,onSuccess:Je=>{N(M,"signMessage","onSuccess",Je),m(Je)},onFailure:Je=>{N(M,"signMessage","onError","unable_to_sign"),g(Je)},uiOptions:p||{}},br={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:Je=>{N(M,"signMessage","onError","unknown_connect_wallet_error"),g(Je)}};$({signMessage:st,connectWallet:br}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),signTypedData:(d,p)=>new Promise(async(m,g)=>{if(!a||!s){N(M,"signTypedData","onError","must_be_authenticated"),g(new Error("User must be authenticated before signing with a Privy wallet"));return}let O=ye(s);if(!O){N(M,"signTypedData","onError","embedded_wallet_not_found"),g(new Error("Must have a Privy wallet before signing"));return}ee(!0);let G=Ji(d),me=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let Ye=await Me();if(!k||!Ye)throw new Error("Unable to connect to wallet");if(!await ue.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent("embedded_wallet_sign_typed_data_started",{walletAddress:O.address});let{response:br}=await k.rpc({accessToken:Ye,address:O.address,request:{method:"eth_signTypedData_v4",params:[O.address,G]}}),Je=br.data;return t.createAnalyticsEvent("embedded_wallet_sign_typed_data_completed",{walletAddress:O.address}),Je};if(L.embeddedWallets.noPromptOnSignature||(L.legacyWalletUiConfig??!1)){p&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let Ye=await me();N(M,"signTypedData","onSuccess",Ye),m(Ye)}catch(Ye){N(M,"signTypedData","onError","unable_to_sign"),g(Ye??new Ee("Unable to sign message"))}}else{let br={method:"eth_signTypedData_v4",data:G,confirmAndSign:me,onSuccess:Ut=>{N(M,"signTypedData","onSuccess",Ut),m(Ut)},onFailure:Ut=>{N(M,"signTypedData","onError","unable_to_sign"),g(Ut)},uiOptions:p||{}},Je={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:Ut=>{N(M,"signMessage","onError","unknown_connect_wallet_error"),g(Ut)}};$({signMessage:br,connectWallet:Je}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),sendTransaction:async(d,p,m)=>{let O=await(await Yc(d,p,m)).wait();return Us(O)},exportWallet:()=>new Promise(async(d,p)=>{if(!a||!s){p(new Error("User must be authenticated before exporting their Privy wallet"));return}let m=ye(s);if(!m){p(new Error("Must have a Privy wallet before exporting"));return}ee(!0);let g={onCompleteNavigateTo:"EMBEDDED_WALLET_KEY_EXPORT_SCREEN",onFailure:p},O=await Me();if(!O||!k){p(new Error("Must have valid access token to enroll in MFA"));return}if(!k){p(new Error("Must have a Privy wallet before exporting"));return}try{try{await k.connect({accessToken:O,address:m.address}),await k.verifyMfa({accessToken:O})}catch(me){if(Eo(me))await ue.recoverEmbeddedWallet();else throw me}}catch(me){p(me);return}let G={appId:e.appId,origin:t.apiUrl,onSuccess:d,onFailure:p};$({keyExport:G,connectWallet:g}),q("EMBEDDED_WALLET_CONNECTING_SCREEN")}),promptMfa:Jc,async init(d){let p;switch(d){case"sms":p=new zs("verify");break;case"totp":return;default:throw new Error(`Unsupported MFA method: ${d}`)}t.startMfaFlow(p),await p.init()},async submit(d,p){switch(d){case"totp":case"sms":Lr.current?.resolve({mfaMethod:d,mfaCode:p}),await new Promise((m,g)=>{Zt.current={resolve:m,reject:g}});break;default:throw Lr.current?.reject(new P("Unsupported MFA method")),new P(`Unsupported MFA method: ${d}`)}},cancel(){Lr.current?.reject(new P("MFA canceled"))},async initEnrollmentWithSms(d){let p=await Me();if(!p||!k)throw new Error("Must have valid access token to enroll in MFA");await k.initEnrollMfa({method:"sms",accessToken:p,phoneNumber:d.phoneNumber})},enrollInMfa(d){return new Promise((p,m)=>{if(!d){ue.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."),$({mfaEnrollmentFlow:{mfaMethods:L.mfa.methods,onSuccess:p,onFailure:m}}),q("MFA_ENROLLMENT_FLOW_SCREEN")})},async initEnrollmentWithTotp(){let d=await Me();if(!d||!k)throw new Error("Must have valid access token to enroll in MFA");let p=await k.initEnrollMfa({method:"totp",accessToken:d});return{secret:p.secret,authUrl:p.authUrl}},async submitEnrollmentWithSms(d){let p=await Me();if(!p||!k)throw new Error("Must have valid access token to enroll in MFA");await k.submitEnrollMfa({method:"sms",accessToken:p,phoneNumber:d.phoneNumber,code:d.mfaCode});let m=await t.getAuthenticatedUser();c(m)},async submitEnrollmentWithTotp(d){let p=await Me();if(!p||!k)throw new Error("Must have valid access token to enroll in MFA");await k.submitEnrollMfa({method:"totp",accessToken:p,code:d.mfaCode});let m=await t.getAuthenticatedUser();c(m)},async unenroll(d){let p=await Me();if(!p||!k)throw new Error("Must have valid access token to remove MFA");await k.unenrollMfa({method:d,accessToken:p});let m=await t.getAuthenticatedUser();c(m)},isHeadlessOAuthLoading:C,loginWithCode(d){return ue.loginWithCode(d)},initLoginWithEmail(d){return ue.initLoginWithEmail(d)},initLoginWithSms(d){return ue.initLoginWithSms(d)},fundWallet(d,p){return ue.fundWallet(d,p)},initLoginWithHeadlessOAuth(d,p){return ue.initLoginWithHeadlessOAuth(d,p)},loginWithHeadlessOAuth(d){return ue.loginWithHeadlessOAuth(d)},isModalOpen:r};Ty=Ro.signMessage,xy=Ro.signTypedData,Sy=async(...d)=>{let p=await Yc(...d);return L.embeddedWallets.waitForTransactionConfirmation&&await p.wait(),p};let Zc=!!e.config?.headless,ue=(()=>({headless:Zc,isNewUserThisSession:y,linkingHint:U,pendingTransaction:null,walletConnectionStatus:R,mipdStore:_,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(k)return k;let p=new Promise(O=>{dt(()=>G=>O(G))}),m=new Promise(O=>setTimeout(()=>O(null),d)),g=await Promise.race([p,m]);return dt(null),g},getAuthFlow:()=>t.authFlow,getAuthMeta:()=>t.authFlow?.meta,closePrivyModal:(d={shouldCallAuthOnSuccess:!0,isSuccess:!1})=>{let p=n&&a&&s;J.current==="login"?d.shouldCallAuthOnSuccess&&p?(N(M,"login","onComplete",s,y,!1,K.current??null),e.onSuccess?.(s,y)):N(M,"login","onError","exited_auth_flow"):J.current==="link"&&K.current&&(d.isSuccess&&p?N(M,"linkAccount","onSuccess",s,K.current):N(M,"linkAccount","onError","exited_link_flow")),B(null),J.current=null,K.current=null,E(!1),o(!1),setTimeout(()=>{t.authFlow=void 0},200),t.createAnalyticsEvent("modal_closed")},openPrivyModal:q,connectWallet:Nt,initLoginWithWallet:async(d,p)=>{K.current="siwe",so(d,p)},loginWithWallet:async()=>{if(!n)throw new Io;if(!(t.authFlow instanceof fo))throw new P("Must initialize SIWE flow first.");let d,p;if(a)try{d=await t.link(),K.current="siwe"}catch(m){throw N(M,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{({user:d,isNewUser:p}=await t.authenticate()),K.current="siwe"}catch(m){throw N(M,"login","onError",m.privyErrorCode||"generic_connect_wallet_error"),m}c(d||s||null),E(p||!1),l(!0)},initLoginWithFarcaster:async d=>{let p=new Bn(d);t.startAuthFlow(p);try{K.current="farcaster",await p.initializeFarcasterConnect()}catch(m){throw J.current==="login"?N(M,"login","onError",m.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",m.privyErrorCode||"unknown_auth_error"),m}},loginWithFarcaster:async()=>{if(!n)throw new Io;if(!(t.authFlow instanceof Bn))throw new P("Must initialize Farcaster flow first.");let d,p;if(a)try{d=await t.link(),K.current="farcaster"}catch(m){throw N(M,"linkAccount","onError",m.privyErrorCode||"failed_to_link_account"),m}else try{({user:d,isNewUser:p}=await t.authenticate()),K.current="farcaster"}catch(m){throw N(M,"login","onError",m.privyErrorCode||"unknown_auth_error"),m}c(d||null),E(p||!1),l(!0)},async initLoginWithOAuth(d,p){if(K.current=d,Xs()){if(d==="google"&&Vs(window.navigator.userAgent)){Re("IN_APP_BROWSER_LOGIN_NOT_POSSIBLE");return}}else{Re("IN_APP_BROWSER_LOGIN_NOT_POSSIBLE");return}let m=new er({provider:d});p&&m.addCaptchaToken(p),t.startAuthFlow(m);let g=await t.authFlow.getAuthorizationUrl();g&&g.url&&window.location.assign(g.url)},async loginWithOAuth(d){if(!(t.authFlow instanceof er))throw new P("Must initialize OAuth flow before calling loginWithOAuth");let p=Ge.get(po),m=t.authFlow.meta.stateCode;if(p!==m)throw t.createAnalyticsEvent("possible_phishing_attempt",{provider:d,storedStateCode:p??"",returnedStateCode:m??""}),new P("Unexpected auth flow. This may be a phishing attempt.");let g,O;if(a)try{g=await t.link(),K.current=d}catch(G){throw N(M,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}else try{({user:g,isNewUser:O}=await t.authenticate()),K.current=d}catch(G){throw J.current==="login"?N(M,"login","onError",G.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}c(g),E(O||!1),l(!0)},async initLoginWithHeadlessOAuth(d,p){if(Xs()){if(d==="google"&&Vs(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 er({provider:d,headless:!0});p&&m.addCaptchaToken(p);let g=await t.startAuthFlow(m).getAuthorizationUrl();g?.url&&window.location.assign(g.url)},async loginWithHeadlessOAuth(d){T(!0),t.startAuthFlow(new er(d));let p=Ge.get(po),m=d.stateCode;if(p!==m)throw t.createAnalyticsEvent("possible_phishing_attempt",{provider:d.provider,storedStateCode:p??"",returnedStateCode:m??""}),T(!1),new P("Unexpected auth flow. This may be a phishing attempt.");let g,O;if(a)try{g=await t.link(),K.current=d.provider}catch(G){throw N(M,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}else try{({user:g,isNewUser:O}=await t.authenticate()),K.current=d.provider}catch(G){throw J.current==="login"?N(M,"login","onError",G.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",G.privyErrorCode||"failed_to_link_account"),G}return c(g),E(O||!1),l(!0),T(!1),g??void 0},initLoginWithEmail:async(d,p)=>{let m=new Nr(d,p);t.startAuthFlow(m);try{K.current="email",await m.sendCodeEmail()}catch(g){throw J.current==="login"?N(M,"login","onError",g.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",g.privyErrorCode||"failed_to_link_account"),g}},initUpdateEmail:async(d,p,m)=>{let g=new Bi(d,p,m);t.startAuthFlow(g),await g.sendCodeEmail()},initLoginWithSms:async(d,p)=>{let m=new ho(d,p);t.startAuthFlow(m);try{K.current="sms",await m.sendSmsCode()}catch(g){throw J.current==="login"?N(M,"login","onError",g.privyErrorCode||"unknown_auth_error"):J.current==="link"&&N(M,"linkAccount","onError",g.privyErrorCode||"failed_to_link_account"),g}},resendEmailCode:async()=>{await t.authFlow?.sendCodeEmail()},resendSmsCode:async()=>{await t.authFlow?.sendSmsCode()},loginWithCode:async d=>{if(!n)throw new Io;if(t.authFlow instanceof Nr)t.authFlow.meta.emailCode=d.trim();else if(t.authFlow instanceof ho)t.authFlow.meta.smsCode=d.trim();else throw new P("Must initialize a passwordless code flow first");let p,m;if(a)try{p=await t.link()}catch(g){throw N(M,"linkAccount","onError",g.privyErrorCode||"failed_to_link_account"),g}else try{({user:p,isNewUser:m}=await t.authenticate())}catch(g){throw N(M,"login","onError",g.privyErrorCode||"unknown_auth_error"),g}c(p||s||null),E(m||!1),l(!0)},refreshUser:async()=>{let d=await t.getAuthenticatedUser();return c(d),d},walletProxy:k,createAnalyticsEvent:(d,p,m)=>t.createAnalyticsEvent(d,p,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(O=>O.type==="wallet"&&O.walletClientType==="privy"),g=await Me();if(!g||!k||!m){p(new Error("Must have valid access token and Privy wallet to recover wallet"));return}ee(!0);try{await k.connect({accessToken:g,address:m.address}),d(!0)}catch(O){Eo(O)&&m.recoveryMethod==="privy"?(t.createAnalyticsEvent("embedded_wallet_pinless_recovery_started",{walletAddress:m.address}),(await k.recover({address:m.address,accessToken:g})).address||p(new Error("Unable to recover wallet")),t.createAnalyticsEvent("embedded_wallet_recovery_completed",{walletAddress:m.address}),d(!0)):Eo(O)?($({recoverWallet:{privyWallet:m,onFailure:p,onSuccess:()=>d(!0)}}),q("EMBEDDED_WALLET_RECOVERY_SCREEN")):p(O)}}),getFiatOnRampConfig:Qt,setReadyToTrue:()=>{i(!0),be?.()},updateWallets:()=>Or(),fundWallet:async(d,p)=>{let{signedUrl:m,externalTransactionId:g}=await Qt(d,p);$({fiatOnRampPrompt:{signedUrl:m},fiatOnRampStatus:{externalTransactionId:g}}),q("FIAT_ON_RAMP_PROMPT_SCREEN")}}))();_y=ue.recoverEmbeddedWallet;let Iy=v4(()=>({wallets:u,ready:xe}),[u,xe]);return vr(ae.Provider,{value:Ro,children:vr(Cl.Provider,{value:M,children:vr(Bc.Provider,{value:Iy,children:Py(Kp,{...L,children:[e.children,Py(wl.Provider,{value:ue,children:[!Zc&&L.captchaEnabled&&n&&!a&&vr(vl,{delayedExecution:!1}),vr(hy,{theme:{...L.appearance.palette||{}}}),vr(Gp,{data:Q,setModalData:$,setInitialScreen:x,initialScreen:v,authenticated:a,open:r,children:vr(wy,{open:r})}),ie&&j?vr(Ey,{appId:e.appId,clientAnalyticsId:t.clientAnalyticsId,origin:t.apiUrl,mfaMethods:s?.mfaMethods,mfaPromise:Lr,mfaSubmitPromise:Zt,onLoad:z,onLoadFailed:()=>null}):null]})]})})})})};import{useContext as P4}from"react";function T4(e){let{login:t}=P4(ae);return ve("login",e),{login:t}}import{useContext as x4}from"react";function S4(e){let{logout:t}=x4(ae);return ve("logout",e),{logout:t}}import{useCallback as Ay,useEffect as _4}from"react";function A4(){let e=de(),t=Ta(),{initLoginWithHeadlessOAuth:r,loginWithHeadlessOAuth:o,isHeadlessOAuthLoading:n,ready:i,user:a}=H(),l=Ay(async c=>{if(e.enabled&&e.status!=="success")throw new Ht(e.error,null,"captcha_failure");return r(c.provider,e.token)},[r,e]),s=Ay(async()=>{let c=Gn();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");try{return await o(c)}catch(u){throw u}finally{Vn()}},[o]);return _4(()=>{let c=Gn();i&&t&&c.inProgress&&c.headless&&s()},[i,t]),{initOAuth:l,loginWithOAuth:s,loading:n}}import{useCallback as ky}from"react";var k4=()=>{let e=de(),{initLoginWithEmail:t,loginWithCode:r}=H(),o=ky(async({email:i})=>{if(!i)throw new Error("Email required to send OTP code");return t(i)},[t]),n=ky(async({code:i})=>{if(e.enabled&&e.status==="error")throw new Ht(e.error,null,"captcha_failure");return r(i)},[r,e.status]);return{sendCode:o,loginWithCode:n}};import{useCallback as Ry}from"react";var R4=()=>{let e=de(),{initLoginWithSms:t,loginWithCode:r}=H(),o=Ry(async({phoneNumber:i})=>{if(!i)throw new Error("SMS required to send OTP code");return t(i)},[t]),n=Ry(async({code:i})=>{if(e.enabled&&e.status!=="success")throw new Ht(e.error,null,"captcha_failure");return r(i)},[r,e.status]);return{sendCode:o,loginWithCode:n}};import{useContext as I4}from"react";function M4(e){let{linkEmail:t,linkPhone:r,linkWallet:o,linkGoogle:n,linkApple:i,linkTwitter:a,linkDiscord:l,linkGithub:s,linkLinkedIn:c,linkTiktok:u,linkSpotify:h,linkFarcaster:f}=I4(ae);return ve("linkAccount",e),{linkEmail:t,linkPhone:r,linkWallet:o,linkGoogle:n,linkApple:i,linkTwitter:a,linkDiscord:l,linkGithub:s,linkLinkedIn:c,linkTiktok:u,linkSpotify:h,linkFarcaster:f}}import{useContext as W4}from"react";function L4(e){let{connectWallet:t}=W4(ae);return ve("connectWallet",e),{connectWallet:t}}import{useContext as O4}from"react";function N4(e){let{createWallet:t}=O4(ae);return ve("createWallet",e),{createWallet:t}}var D4=()=>{let{fundWallet:e}=H();return{fundWallet:e}};import{useContext as U4}from"react";function F4(e){let{sendTransaction:t}=U4(ae);return ve("sendTransaction",e),{sendTransaction:t}}import{useContext as B4}from"react";function H4(e){let{setWalletPassword:t}=B4(ae);return ve("setWalletPassword",e),{setWalletPassword:t}}import{useContext as G4}from"react";function V4(e){let{signMessage:t}=G4(ae);return ve("signMessage",e),{signMessage:t}}import{useContext as z4}from"react";function $4(e){let{signTypedData:t}=z4(ae);return ve("signTypedData",e),{signTypedData:t}}import{useContext as q4}from"react";var j4=()=>{let{isModalOpen:e}=q4(ae);return{isOpen:e}};import{useContext as K4}from"react";function Y4(e){let{getAccessToken:t}=K4(ae);return ve("accessToken",e),{getAccessToken:t}}function J4(e,t){return{...e,rpcUrls:{...e.rpcUrls,privyWalletOverride:{http:[t]}}}}export{tr as AsExternalProvider,vl as Captcha,Kn as ConnectorManager,Yn as PrivyClient,b4 as PrivyProvider,ge as PrivyProxyProvider,qn as SUPPORTED_CHAINS,ol as VERSION,lt as WalletConnector,J4 as addRpcUrlOverrideToChain,jl as errorIndicatesMaxMfaRetries,ln as errorIndicatesMfaTimeout,cn as errorIndicatesMfaVerificationFailed,Me as getAccessToken,L4 as useConnectWallet,N4 as useCreateWallet,D4 as useFundWallet,M4 as useLinkAccount,T4 as useLogin,k4 as useLoginWithEmail,A4 as useLoginWithOAuth,R4 as useLoginWithSms,S4 as useLogout,Tn as useMfa,Pi as useMfaEnrollment,j4 as useModalStatus,H as usePrivy,bl as useRegisterMfaListener,F4 as useSendTransaction,H4 as useSetWalletPassword,V4 as useSignMessage,$4 as useSignTypedData,Y4 as useToken,Ri as useWallets};
|