@privy-io/react-auth 1.52.2 → 1.52.3-beta-20240102190852
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 +2 -2
- package/dist/index.js +2 -2
- package/package.json +1 -1
package/dist/esm/index.js
CHANGED
|
@@ -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 dt(this._getNonceOnce.bind(this)),this.wallet=t}get meta(){return{connectorType:this.wallet.connectorType,walletClientType:this.wallet.walletClientType}}async authenticate(){if(!this.api)throw new C("Auth flow has no API instance");try{let{message:t,signature:o}=await this.sign(),r=await this.api.post(Ml(),{message:t,signature:o,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType});return{user:r.user,token:r.token,refresh_token:r.refresh_token,is_new_user:r.is_new_user}}catch(t){throw te(t)}}async link(){if(!this.api)throw new C("Auth flow has no API instance");try{let{message:t,signature:o}=await this.sign();return await this.api.post(Ll(),{message:t,signature:o,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(t){throw te(t)}}async sign(){if(!this.api)throw new C("Auth flow has no API instance");if(await this.buildSiweMessage(),!this.preparedMessage)throw new C("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 C("Auth flow has no API instance");let t=this.wallet.address;return(await this.api.post(Wl(),{address:t})).nonce}async buildSiweMessage(){if(!this.api)throw new C("Auth flow has no API instance");let t=this.wallet.address,o=this.wallet.chainId.replace("eip155:","");return this.nonce||(this.nonce=await this.getNonceOnce.execute()),this.preparedMessage=this.prepareMessage(o,t,this.nonce),this.preparedMessage}prepareMessage(t,o,r){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.",s=new Date().toISOString();return this.createSiweMessage(t,o,n,i,s,r,a)}};var zo=class{constructor(t,o){this.meta={phoneNumber:t,captchaToken:o}}async authenticate(){if(!this.api)throw new C("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new C("phone number and sms code must be set prior to calling authenticate.");try{let t=Fl(),o=await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return{user:o.user,token:o.token,refresh_token:o.refresh_token,is_new_user:o.is_new_user}}catch(t){throw te(t)}}async link(){if(!this.api)throw new C("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new C("phone number and sms code must be set prior to calling authenticate.");try{let t=Bl();return await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(t){throw te(t)}}async sendSmsCode(t,o){if(!this.api)throw new C("Auth flow has no API instance");if(t&&(this.meta.phoneNumber=t),o&&(this.meta.captchaToken=o),!this.meta.phoneNumber)throw new C("phone nNumber must be set when initialzing authentication.");try{let r=Ul();return await this.api.post(r,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken})}catch(r){throw te(r)}}};import{v4 as eh}from"uuid";function Ze(e){return new Date(e*1e3)}function hf(e){let t=[];for(let o of e){let r=o.type;switch(o.type){case"wallet":let n={address:o.address,type:o.type,verifiedAt:Ze(o.verified_at),chainType:"ethereum",chainId:o.chain_id,walletClient:o.wallet_client_type==="privy"?"privy":"unknown",walletClientType:o.wallet_client_type,connectorType:o.connector_type,recoveryMethod:o.recovery_method};t.push(n);break;case"email":let i={address:o.address,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(i);break;case"phone":let a={number:o.phoneNumber,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(a);break;case"google_oauth":let s={subject:o.subject,email:o.email,name:o.name,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(s);break;case"twitter_oauth":let l={subject:o.subject,username:o.username,name:o.name,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(l);break;case"discord_oauth":let c={subject:o.subject,username:o.username,email:o.email,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(c);break;case"github_oauth":let u={subject:o.subject,username:o.username,name:o.name,email:o.email,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(u);break;case"tiktok_oauth":let y={subject:o.subject,username:o.username,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(y);break;case"linkedin_oauth":let w={subject:o.subject,name:o.name,email:o.email,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(w);break;case"apple_oauth":let m={subject:o.subject,email:o.email,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(m);break;case"custom_auth":t.push({type:o.type,customUserId:o.custom_user_id,verifiedAt:Ze(o.verified_at)});break;default:console.warn(`Unrecognized account type: ${r}. Please consider upgrading the Privy SDK.`)}}return t}function St(e,t){return e.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),e.find(o=>o.type===t)}var ne=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy")||null,yf=e=>e.linkedAccounts.filter(t=>t.type==="wallet"),co=(e,t)=>t==="all-users"&&!ne(e)||t==="users-without-wallets"&&!yf(e)?.length;function gt(e){if(!e)return null;let t=hf(e.linked_accounts),o=St(t,"wallet"),r=St(t,"email"),n=St(t,"phone"),i=St(t,"google_oauth"),a=St(t,"twitter_oauth"),s=St(t,"discord_oauth"),l=St(t,"github_oauth"),c=St(t,"tiktok_oauth"),u=St(t,"linkedin_oauth"),y=St(t,"apple_oauth"),w=e.mfa_methods.map(({type:E,verified_at:b})=>({type:E,verifiedAt:Ze(b)}));return{id:e.id,createdAt:Ze(e.created_at),linkedAccounts:t,email:r&&{address:r?.address},phone:n&&{number:n?.number},wallet:o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletClient:o.walletClient,walletClientType:o.walletClientType,connectorType:o.connectorType,recoveryMethod:o.recoveryMethod},google:i&&{subject:i.subject,email:i.email,name:i.name},twitter:a&&{subject:a.subject,username:a.username,name:a.name},discord:s&&{subject:s.subject,username:s.username,email:s.email},github:l&&{subject:l.subject,username:l.username,name:l.name,email:l.email},tiktok:c&&{subject:c.subject,username:c.username},linkedin:u&&{subject:u.subject,name:u.name},apple:y&&{subject:y.subject,email:y.email},mfaMethods:w.map(E=>E.type)}}import{getAddress as Hc}from"@ethersproject/address";import Yf from"eventemitter3";var Xl="1.52.2";var oi="4df5e2316331463a9130964bd6078dfa",ec="fe9c30fc-3bc5-4064-91e2-6ab5887f8f4d",tc="34357d3c125c2bcf2ce2bc3309d98715",ri="https://auth.privy.io",oc=2e4,Xe=1400,rc=2500,za=Xl;var ar="privy:token",Va="privy-token",ni="privy:refresh_token",$a="privy-refresh-token",nc="privy-session",Qr="privy:session_transfer_token",vf="privy:wallet",Zr="privy:caid",ii=e=>`${vf}:${e}`,ja="privy:connectors",qa="privy:connections";var Xr=12e4,jt=1,Ka="0x1",sr=3e4,ic="https://api.moonpay.com/v1",ac="https://api.moonpay.com/v1",sc="pk_live_hirbpu0cVcLHrjktC9l7fbc9ctjv0SL",lc="pk_test_fqWjXZMSFwloh7orvJsRfjiUHXJqFzI",cc="0x420000000000000000000000000000000000000F",dc=["function getL1Fee(bytes memory _data) external view returns (uint256)"];var Ya=class{constructor(){this._cache={}}get(t){return this._cache[t]}put(t,o){o!==void 0?this._cache[t]=o:this.del(t)}del(t){delete this._cache[t]}getKeys(){return Object.keys(this._cache)}},Ja=class{get(t){let o=localStorage.getItem(t);return o===null?void 0:JSON.parse(o)}put(t,o){o!==void 0?localStorage.setItem(t,JSON.stringify(o)):this.del(t)}del(t){localStorage.removeItem(t)}getKeys(){return Object.entries(localStorage).map(([t])=>t)}};function wf(){return typeof window<"u"&&window.localStorage?new Ja:new Ya}var Z=wf();function pc(){let e=window,t=e.ethereum;if(!t)return[];let o=[];if(t.providers?.length)for(let r of t.providers)r&&o.push(r);return o.push(e.ethereum),o}var ai=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 Qa=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||ai(e)!=="MetaMask")return!1;if(e.providers){for(let o of e.providers)if(!Qa(o))return!1}return!0},_t=()=>!!("phantom"in window&&window?.phantom?.ethereum?.isPhantom),uc=()=>{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 mc=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,}))$/),fc=(e,t)=>{let o=e.slice(0),r=[];for(;o.length;)r.push(o.splice(0,t));return r},po=(e,t=3,o=4)=>{if(!e)return"";let r=2,n=3;if(t+o+r+n>=e.length)return e;let i=e.slice(0,r+t),a=e.slice(e.length-o,e.length);return`${i}...${a}`},Za=e=>new Promise(t=>setTimeout(t,e));function hc(e,{interval:t=100,timeout:o=5e3}={}){return new Promise((r,n)=>{let i=0,a,s=()=>{if(i>=o){n("Max attempts reached without result");return}if(a=e(),i+=t,a!=null){r(a);return}setTimeout(s,t)};s()})}var yc=(e,t={})=>{let o=t.delayMs||150,r=t.maxAttempts||270;return new Promise(async(n,i)=>{let a=!1,s=0;for(;!a&&s<r;){if(t.abortSignal?.aborted)return;e().then(()=>{a=!0,n()},(...l)=>{a=!0,i(...l)}),s+=1,await Za(o)}a||i(new Error("Exceeded max attempts before resolving function"))})},si=(e,t,o={})=>{let r=new URL(t,e);for(let[n,i]of Object.entries(o))r.searchParams.set(n,i);return r.href};var Xa=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),Vo=e=>typeof e=="string"?e:"0x"+e.toString(16);async function gc(e,t=3e3){let o=!1,r=window;return new Promise(n=>{r.ethereum?i():(window.addEventListener("ethereum#initialized",i,{once:!0}),setTimeout(()=>{i()},t));function i(){if(o)return;o=!0,window.removeEventListener("ethereum#initialized",i);let a=e.getProviders(),s=[];for(let l of a)l.info.rdns!=="com.coinbase.wallet"&&s.push({type:l.info.name.toLowerCase().replace(/\s/g,"_"),eip6963InjectedProvider:l});_t()&&s.push({type:"phantom"});for(let l of pc()){let c=ai(l);if(!a.some(u=>u.info.name===c)){if(Qa(l,!0)&&!s.find(u=>u.type==="metamask")){s.push({type:"metamask",legacyInjectedProvider:l});continue}s.find(u=>u.type==="unknown_browser_extension")||s.push({type:"unknown_browser_extension",legacyInjectedProvider:l})}}n(s)}})}function lr(e){return`eip155:${String(Number(e))}`}var vt=(e,t,o)=>{let r=Number(e),n=t.find(a=>a.id===r);if(!n)throw new H(`Unsupported chainId ${e}`,4901);let i;if(o.rpcUrls&&o.rpcUrls[r]?i=o.rpcUrls[r]:n.rpcUrls.infura?.http[0]?i=n.rpcUrls.infura.http[0]+"/"+oi:n.rpcUrls.blast?.http[0]?i=n.rpcUrls.blast.http[0]+"/"+ec:i=n.rpcUrls.default?.http[0],!i)throw new H(`No RPC url found for ${e}`);return i},vc=(e,t)=>{let o=Number(e),r=t.find(n=>n.id===o);if(!r)throw new H(`Unsupported chainId ${e}`,4901);return r.blockExplorers?.default.url};import Af from"@coinbase/wallet-sdk";import{jsx as wc,jsxs as Cf}from"react/jsx-runtime";var en=({style:e,...t})=>Cf("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:[wc("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),wc("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 Rt}from"@ethersproject/address";import{Web3Provider as Tc}from"@ethersproject/providers";import{default as _f}from"eventemitter3";import{StaticJsonRpcProvider as bc}from"@ethersproject/providers";import Sf from"eventemitter3";var bf=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4"],Cc=e=>bf.includes(e);import{ErrorCode as Ef}from"@ethersproject/logger";var cr=class extends H{constructor(){super("Wallet timeout");this.type="wallet_error"}},dr=class extends H{constructor(){super("User rejected connection");this.type="wallet_error"}},et=e=>{if(e instanceof H)return e;if(e?.code&&e?.reason){let t=new Oe(e);return e.code===Ef.ACTION_REJECTED&&(t.details=$e.E4001_USER_REJECTED_REQUEST),t}return e?.code?new Oe(e):new H("Unknown connector error",e)},kt=class extends Ye{constructor(o,r,n){super(o);this.type="provider_error";this.code=r,this.data=n}},Oe=class extends kt{constructor(o){let r=o;super(r.message,r.code,r.data);let n=Object.values($e).find(i=>i.eipCode===r.code);this.details=n||$e.UNKNOWN_ERROR,r.code===-32002&&(r.message?.includes("already pending for origin")?r.message?.includes("wallet_requestPermissions")?this.details=$e.E32002_CONNECTION_ALREADY_PENDING:this.details=$e.E32002_REQUEST_ALREADY_PENDING:r.message?.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=$e.E32002_WALLET_LOCKED))}},Pf={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}},xf={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}},Tf={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}},$e={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Tf,...xf},qt={...Pf,...$e};var oe=class{constructor(t,o){this.removeListener=(t,o)=>{if(this.walletProvider)try{return this.walletProvider.removeListener(t,o)}catch{console.warn("Unable to remove wallet provider listener")}};this.walletTimeout=(t=new cr,o=this.rpcTimeoutDuration)=>new Promise((r,n)=>setTimeout(()=>{n(t)},o));this.setWalletProvider=t=>{this.walletProvider&&this._subscriptions.forEach(o=>{this.removeListener(o.eventName,o.listener)}),this.walletProvider=t,this._subscriptions.forEach(o=>{this.walletProvider?.on(o.eventName,o.listener)})};this.walletProvider=t,this.rpcTimeoutDuration=o||Xr,this._subscriptions=[]}on(t,o){if(this.walletProvider)return this.walletProvider.on(t,o);this._subscriptions.push({eventName:t,listener:o})}async request(t){if(!this.walletProvider)throw new H(`A wallet request of type ${t.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(t),this.walletTimeout()]).catch(o=>{throw et(o)})}},uo=class extends Error{constructor(o,r,n){super(o);this.code=r,this.data=n}},li=class extends Sf{constructor(o,r,n,i,a=1){super();this.walletProxy=o,this.address=r,this.chainId=a,this.rpcConfig=n,this.chains=i,this.provider=new bc(vt(a,this.chains,n)),this.rpcTimeoutDuration=pr(n,"privy")}async handleSendTransaction(o){if(!o.params||!Array.isArray(o.params))throw new uo(`Invalid params for ${o.method}`,4200);let r=o.params[0];if(!await ke()||!this.address)throw new uo("Disconnected",4900);return(await Pc(r)).hash}handleSwitchEthereumChain(o){if(!o.params||!Array.isArray(o.params))throw new uo(`Invalid params for ${o.method}`,4200);let r;if(typeof o.params[0]=="string")r=o.params[0];else if("chainId"in o.params[0]&&typeof o.params[0].chainId=="string")r=o.params[0].chainId;else throw new uo(`Invalid params for ${o.method}`,4200);this.chainId=Number(r),this.provider=new bc(vt(this.chainId,this.chains,this.rpcConfig)),this.emit("chainChanged",r)}async handlePersonalSign(o){if(!o.params||!Array.isArray(o.params))throw new Error("Invalid params for eth_estimateGas");let r=o.params[0];return await Ec(r)}async handleEstimateGas(o){if(!o.params||!Array.isArray(o.params))throw new Error("Invalid params for eth_estimateGas");delete o.params[0].gasPrice,delete o.params[0].maxFeePerGas,delete o.params[0].maxPriorityFeePerGas;let r={...o.params[0],chainId:Vo(this.chainId)};try{return await this.provider.send("eth_estimateGas",[r])}catch{return delete r.from,await this.provider.send("eth_estimateGas",[r])}}async request(o){switch(console.debug("Embedded1193Provider.request() called with args",o),o.method){case"eth_accounts":case"eth_requestAccounts":return this.address?[this.address]:[];case"eth_chainId":return Vo(this.chainId);case"eth_estimateGas":return this.handleEstimateGas(o);case"eth_sendTransaction":return this.handleSendTransaction(o);case"wallet_switchEthereumChain":return this.handleSwitchEthereumChain(o);case"personal_sign":return this.handlePersonalSign(o);default:break}if(Cc(o.method)){let r=await ke();if(await xc(),!r||!this.address)throw new uo("Disconnected",4900);try{return(await this.walletProxy.rpc({address:this.address,accessToken:r,request:{method:o.method,params:o.params}})).response.data}catch(n){throw console.error(n),new uo("Disconnected",4900)}}else return this.provider.send(o.method,o.params)}async connect(){let o=await ke();if(!o||!this.address)return null;try{return(await this.walletProxy.connect({address:this.address,accessToken:o})).address}catch(r){return console.error(r),null}}},At=class extends oe{constructor(o){super(o,o.rpcTimeoutDuration)}},mo=class extends oe{constructor(t){super(t,t.rpcTimeoutDuration)}sendAsync(t,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};var kf=(e,t)=>{switch(t){case"coinbase_wallet":return e.message.includes("addEthereumChain");default:return e.code===4902||e.message?.includes("4902")}},je=class extends _f{constructor(o,r,n,i){super();this.onAccountsChanged=o=>{o.length===0?this.onDisconnect():this.syncAccounts(o)};this.onChainChanged=o=>{this.wallets.forEach(r=>{r.chainId=lr(o),this.walletClientType==="privy"&&Z.put(ii(r.address),o)}),this.emit("walletsUpdated")};this.onDisconnect=()=>{this.connected=!1,this.wallets=[],this.emit("walletsUpdated")};this.onConnect=()=>{this.connected=!0,this.syncAccounts()};this.wallets=[],this.walletClientType=o,this.chains=r,this.defaultChain=n,this.rpcConfig=i,this.rpcTimeoutDuration=pr(i,o),this.connected=!1,this.initialized=!1}buildConnectedWallet(o,r){let n=async()=>!!this.wallets.find(i=>Rt(i.address)===Rt(o));return{address:Rt(o),chainId:r,switchChain:async i=>{if(!n)throw new H("Wallet is not currently connected.");let a=this.wallets.find(y=>Rt(y.address)===Rt(o))?.chainId;if(!a)throw new H("Unable to determine current chainId.");let s,l;if(typeof i=="number"?(s=`0x${i.toString(16)}`,l=i):(s=i,l=Number(i)),a===lr(s))return;let c=this.chains.find(y=>y.id===l);if(!c)throw new H(`Unsupported chainId: ${i}`);let u=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:s}]})};try{return await u()}catch(y){if(kf(y,this.walletClientType))return await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:s,chainName:c.name,nativeCurrency:c.nativeCurrency,rpcUrls:[c.rpcUrls.public?.http[0]??""],blockExplorerUrls:[c.blockExplorers?.default.url??""]}]}),u();throw this.walletClientType==="rainbow"&&y.message?.includes("wallet_switchEthereumChain")?new H(`Rainbow does not support the chainId ${r}`):y}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:n,getEthereumProvider:async()=>{if(!await n())throw new H("Wallet is not currently connected.");return this.proxyProvider},getEthersProvider:async()=>{if(!await n())throw new H("Wallet is not currently connected.");return new Tc(new At(this.proxyProvider))},getWeb3jsProvider:async()=>{if(!await n())throw new H("Wallet is not currently connected.");return new mo(this.proxyProvider)},sign:async i=>{if(!await n())throw new H("Wallet is not currently connected.");return await this.sign(i)},disconnect:()=>{this.disconnect()}}}async syncAccounts(o){let r=o;if(r===void 0){let c=await this.proxyProvider.request({method:"eth_accounts"});Array.isArray(c)&&(r=c)}if(!r||!Array.isArray(r)||r.length<=0||!r[0])return;let n=r[0],i=Rt(n),a=[],s;if(this.walletClientType==="privy"){let c=Z.get(ii(i));this.chains.find(u=>u.id===Number(c))||(Z.del(ii(i)),c=null),s=c||`0x${this.defaultChain.id.toString(16)}`;try{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:s}]})}catch{console.warn(`Unable to switch embedded wallet to chain ID ${s} on initialization`)}}else try{let c=await this.proxyProvider.request({method:"eth_chainId"});if(typeof c=="string")s=c;else if(typeof c=="number")s=`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 ${Ka}`,c),s=Ka}let l=lr(s);a.find(c=>Rt(c.address)===i)||a.push(this.buildConnectedWallet(Rt(n),l)),ci(a,this.wallets)||(this.wallets=a,this.emit("walletsUpdated"))}async getConnectedWallet(){let o=await this.proxyProvider.request({method:"eth_accounts"});return this.wallets.sort((r,n)=>n.connectedAt-r.connectedAt).find(r=>o.find(n=>Rt(n)===Rt(r.address)))||null}async isConnected(){let o=await this.proxyProvider.request({method:"eth_accounts"});return Array.isArray(o)&&o.length>0}async sign(o){return await this.connect({showPrompt:!1}),new Tc(new At(this.proxyProvider)).getSigner().signMessage(o)}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 Rf=e=>{let t=`https://mainnet.infura.io/v3/${oi}`,o=1;return e.makeWeb3Provider(t,o)},di,pi=class extends je{constructor(o,r,n){super("coinbase_wallet",o,r,n);this.connectorType="coinbase_wallet";this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),di||(di=new Af({appName:"Privy",darkMode:!1,headlessMode:!1,enableMobileWalletLink:!0})),this.proxyProvider.setWalletProvider(Rf(di)),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}async connect(o){return o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){di.disconnect()}get walletBranding(){return{name:"Coinbase Wallet",icon:en}}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new H("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([o[0]])}catch(o){throw et(o)}}};import{jsx as Sc}from"react/jsx-runtime";var ui=({...e})=>Sc("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:Sc("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 mi=class extends je{constructor(o,r,n,i){super("privy",r,n,i);this.connectorType="embedded";this.proxyProvider=o,this.subscribeListeners(),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}async connect(o){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[Vo(o?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:ui}}disconnect(){this.connected=!1}async promptConnection(){}};import{jsx as _c}from"react/jsx-runtime";var ur=({style:e,...t})=>_c("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...t,children:_c("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 tt,jsxs as If}from"react/jsx-runtime";var mr=({style:e,...t})=>If("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:[tt("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),tt("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"})]});var fr=class extends je{constructor(o,r,n,i,a){super(a||"unknown",o,r,n);this.connectorType="injected";this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=i;let s=i.provider;this.proxyProvider.setWalletProvider(s),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}async connect(o){return o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return{name:this.providerDetail.info.name,icon:this.providerDetail.info.icon}}disconnect(){console.warn(`Programmatic disconnect with ${this.providerDetail.info.name} is not yet supported.`)}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new H("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw et(o)}}},on,tn=class extends je{constructor(o,r,n,i,a){super(a?"metamask":"unknown",o,r,n);this.connectorType="injected";Jn(this,on,void 0);this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(i),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0}),a&&Al(this,on,{name:"MetaMask",icon:mr})}async connect(o){return o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return kl(this,on)??{name:"Browser Extension",icon:ur}}disconnect(){console.warn("Programmatic disconnect with browser wallets is not yet supported.")}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new H("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw et(o)}}};on=new WeakMap;import{getAddress as z2}from"@ethersproject/address";import{Web3Provider as $2}from"@ethersproject/providers";import{isMobile as Wf}from"react-device-detect";var fi=class extends fr{disconnect(){console.warn("Metamask does not support programmatic disconnect.")}async promptConnection(){try{Wf||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 H("Unable to retrieve accounts");await this.syncAccounts([t[0]])}catch(t){throw et(t)}}};import{jsx as kc,jsxs as Mf}from"react/jsx-runtime";var fo=({style:e,...t})=>Mf("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:[kc("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),kc("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 hi=class extends je{constructor(o,r,n){super("phantom",o,r,n);this.connectorType="phantom";this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(window.phantom.ethereum),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}async connect(o){return o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return{name:"Phantom",icon:fo}}disconnect(){console.warn("Phantom does not support programmatic disconnect.")}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new H("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw et(o)}}};import{EthereumProvider as $f,OPTIONAL_EVENTS as jf,OPTIONAL_METHODS as qf}from"@walletconnect/ethereum-provider";import{isMobile as Kf}from"react-device-detect";import{createContext as Nf,useContext as Of,useEffect as Df,useRef as Uf,useState as Ff}from"react";import{jsx as Lf}from"react/jsx-runtime";function yi({src:e,...t}){return Lf("img",{src:e,...t,style:{display:"none"}})}var P=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};import{jsx as Hf,jsxs as Gf}from"react/jsx-runtime";var Bf="LANDING",Ac=Nf({ready:!1,app:null,currentScreen:null,lastScreen:null,navigate:P,navigateBack:P,resetNavigation:P,setModalData:P,onUserCloseViaDialogOrKeybindRef:void 0}),Rc=e=>{let t=e.appConfig,o=e.authenticated,[r,n]=Ff(e.initialScreen);Df(()=>{o||e.setInitialScreen(Bf)},[o]);let i=Uf(null),a={ready:!!t?.id,app:t,data:e.data,setModalData:e.setModalData,currentScreen:e.initialScreen,lastScreen:r,navigate:s=>{e.setInitialScreen(s),n(e.initialScreen)},navigateBack:()=>{e.setInitialScreen(r)},resetNavigation:()=>{e.setInitialScreen(null),n(null)},onUserCloseViaDialogOrKeybindRef:i};return Gf(Ac.Provider,{value:a,children:[(typeof t?.appearance?.logo=="string"||t?.appearance?.logo?.type==="img")&&Hf(yi,{src:typeof t.appearance.logo=="string"?t.appearance.logo:t.appearance.logo.props.src}),e.children]})},S=()=>Of(Ac);import{jsx as hr,jsxs as zf}from"react/jsx-runtime";var rn=({style:e,...t})=>{let{app:o}=S();return zf("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:[hr("rect",{width:"28",height:"28",rx:"3",fill:o?.appearance.palette.colorScheme==="dark"?"#3396ff":"#141414"}),hr("g",{clipPath:"url(#clip0_1765_9946)",children:hr("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"})}),hr("defs",{children:hr("clipPath",{id:"clip0_1765_9946",children:hr("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})};var gi=e=>{let t;try{t=new URL(e).hostname}catch{return}for(let[o,r]of Object.entries(yr))if(t.includes(r.hostname))return{walletClientType:o,entry:r}};var yr={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"}},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"}},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"}}};function Vf(e){return{name:e.displayName||"",universalLink:e.mobile.universal,deepLink:e.mobile.native}}var Ic=e=>e in yr,Wc=e=>{let t=yr[e].mobile;if("native"in t)return t.native};function Mc(e,t){let o=Vf(t);if(o.deepLink)return Uc(o.deepLink,e);if(o.universalLink)return Fc(o.universalLink,e);throw new C(`Unsupported wallet ${t.id}`)}var Lc="WALLETCONNECT_DEEPLINK_CHOICE";function Nc(){try{localStorage.removeItem(Lc)}catch{}}function Oc({href:e,name:t}){try{localStorage.setItem(Lc,JSON.stringify({href:e,name:t}))}catch{}}function Dc(e){return e.startsWith("http://")||e.startsWith("https://")}function Uc(e,t){if(Dc(e))return Fc(e,t);let o=e;o.includes("://")||(o=e.replaceAll("/","").replaceAll(":",""),o=`${o}://`),o.endsWith("/")||(o=`${o}/`);let r=encodeURIComponent(t);return{redirect:`${o}wc?uri=${r}`,href:o}}function Fc(e,t){if(!Dc(e))return Uc(e,t);let o=e;o.endsWith("/")||(o=`${o}/`);let r=encodeURIComponent(t);return{redirect:`${o}wc?uri=${r}`,href:o}}function Bc(e,t){window.open(e,t,"noreferrer noopener")}var It=class extends je{constructor(o,r,n,i,a){super(a||"unknown",n,i,r);this.connectorType="wallet_connect_v2";this.walletConnectCloudProjectId=o,this.rpcConfig=r,this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),a&&(this.walletEntry=yr[a],this.walletClientType=a),this.createProvider().then(s=>{if(this.provider=s,this.proxyProvider.setWalletProvider(s),this.subscribeListeners(),s.session){if(this.walletProvider?.session?.peer.metadata.url){let l=gi(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=l?.entry,this.walletClientType=l?.walletClientType||"unknown"}this.connected=!0,this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}else this.emit("initialized"),this.initialized=!0}),import("@walletconnect/modal").then(({WalletConnectModal:s})=>{this.modal=new s({projectId:this.walletConnectCloudProjectId,themeVariables:{"--wcm-z-index":"1000000"}}),this.modal.subscribeModal(l=>{!l.open&&!this.walletProvider?.session&&this.onQrModalClosed&&this.onQrModalClosed()})})}async connect(o){return o.showPrompt&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return!!this.walletProvider?.connected}get walletBranding(){return this.walletClientType==="metamask"?{name:"Metamask",icon:mr}:{name:Xa(this.walletProvider?.session?.peer.metadata.name||"")||"WalletConnect",icon:this.walletProvider?.session?.peer.metadata.icons?.[0]||rn}}resetConnection(o){this.walletProvider&&this.walletProvider.connected&&(this.walletProvider.signer.session=void 0,this.walletEntry=yr[o],this.walletClientType=o,this.redirectUri=void 0,Nc(),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise((o,r)=>{let n=()=>{r(new dr)};this.onQrModalClosed=n,(async()=>{let a="",s=await Promise.race([this.walletProvider?.enable(),this.proxyProvider.walletTimeout()]);if(s?.length&&(a=s[0]),!a||a==="")throw new H("Unable to retrieve address");if(this.walletProvider?.session?.peer.metadata.url){let l=gi(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=l?.entry,this.walletClientType=l?.walletClientType||"unknown",this.proxyProvider.rpcTimeoutDuration=pr(this.rpcConfig,this.walletClientType)}this.connected=!0,await this.syncAccounts(s),o()})().catch(a=>{if(a){r(et(a));return}r(new H("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(o){this.proxyProvider.setWalletProvider(o)}async createProvider(){let o={};for(let n of this.chains){let i=vt(n.id,this.chains,this.rpcConfig);i&&(o[n.id]=i)}let r=await $f.init({projectId:this.walletConnectCloudProjectId,chains:[this.defaultChain.id],optionalChains:this.chains.map(n=>n.id),optionalEvents:jf,optionalMethods:qf,rpcMap:o,showQrModal:!1});return r.on("display_uri",n=>{if(r.signer.abortPairingAttempt(),Kf&&this.walletEntry){let{redirect:i,href:a}=Mc(n,this.walletEntry);Oc({href:a,name:this.walletEntry.displayName}),this.redirectUri=i,Bc(i,"_self")}else this.modal?.openModal({uri:n,chains:[this.defaultChain.id]})}),r.on("connect",()=>{if(this.modal?.closeModal(),r.session?.peer.metadata.url){let n=gi(r.session?.peer.metadata.url);this.walletEntry=n?.entry,this.walletClientType=n?.walletClientType||"unknown"}}),r}async enableProvider(){return this.walletProvider?.connected?Promise.resolve(this.walletProvider.accounts):await this.walletProvider?.enable()}};var es=e=>{let t=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return t?!!e?.linkedAccounts.filter(r=>r.type=="wallet"&&r.address===Hc(t)).length:!1},pr=(e,t)=>e.rpcTimeouts?e.rpcTimeouts[t]||Xr:Xr,nn=class extends Yf{constructor(o,r,n,i,a){super();this.getEthereumProvider=()=>{let o=this.wallets[0],r=this.walletConnectors.find(n=>n.wallets.find(i=>i.address===o?.address));return!o||!r?new oe:r.proxyProvider};this.walletConnectCloudProjectId=o,this.rpcConfig=r,this.chains=n,this.defaultChain=i,this.walletConnectors=[],this.initialized=!1,this.store=a,this.storedConnections=this.loadConnectionHistory()}get wallets(){let o=new Set,r=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 o.has(a)?!1:(o.add(a),!0)}),n=r.findIndex(i=>i.address===(this.activeWallet?this.activeWallet:"unknown"));return n>=0&&r.unshift(r.splice(n,1)[0]),r}initialize(){this.initialized||(Z.get(ja)&&(Z.getKeys().forEach(o=>{o.startsWith("walletconnect")&&Z.del(o)}),Z.del(ja)),gc(this.store).then(o=>o.forEach(({type:r,eip6963InjectedProvider:n,legacyInjectedProvider:i})=>{this.createWalletConnector("injected",r,{eip6963InjectedProvider:n,legacyInjectedProvider:i})})),this.createWalletConnector("coinbase_wallet","coinbase_wallet"),this.createWalletConnector("wallet_connect_v2","unknown"),this.initialized=!0)}findWalletConnector(o,r){return o==="wallet_connect_v2"?this.walletConnectors.find(n=>n.connectorType===o)||null:this.walletConnectors.find(n=>n.connectorType===o&&n.walletClientType===r)||null}onInitialized(o){o.wallets.forEach(r=>{let n=this.storedConnections.find(i=>i.address===r.address&&i.connectorType===r.connectorType&&i.walletClientType===r.walletClientType);n&&(r.connectedAt=n.connectedAt)}),this.saveConnectionHistory(),this.emit("walletsUpdated")}onWalletsUpdated(o){o.initialized&&(this.saveConnectionHistory(),this.emit("walletsUpdated"))}addEmbeddedWalletConnector(o,r,n){let i=this.findWalletConnector("embedded","privy");if(i)i.proxyProvider.walletProxy=o;else{let a=new li(o,r,this.rpcConfig,this.chains,n.id),s=new mi(a,this.chains,n,this.rpcConfig);this.addWalletConnector(s)}}removeEmbeddedWalletConnector(){let o=this.findWalletConnector("embedded","privy");if(o){let r=this.walletConnectors.indexOf(o);this.walletConnectors.splice(r,1),this.saveConnectionHistory(),this.storedConnections=this.loadConnectionHistory(),this.emit("walletsUpdated")}}async createWalletConnector(o,r,n){let i=this.findWalletConnector(o,r);if(i)return i instanceof It&&i.resetConnection(r),i;let s=(()=>{if(o==="injected"){if(r==="metamask"&&n?.eip6963InjectedProvider)return new fi(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask");if(r==="metamask"&&n?.legacyInjectedProvider)return new tn(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,!0);if(r==="phantom"&&_t())return new hi(this.chains,this.defaultChain,this.rpcConfig);if(n?.legacyInjectedProvider&&r==="unknown_browser_extension")return new tn(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider);if(n?.eip6963InjectedProvider)return new fr(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,r)}else return o==="coinbase_wallet"?new pi(this.chains,this.defaultChain,this.rpcConfig):new It(this.walletConnectCloudProjectId,this.rpcConfig,this.chains,this.defaultChain,r)})();return s&&this.addWalletConnector(s),s||null}addWalletConnector(o){this.walletConnectors.push(o),o.on("initialized",()=>this.onInitialized(o)),o.on("walletsUpdated",()=>this.onWalletsUpdated(o))}loadConnectionHistory(){let o=a=>a&&typeof a.address=="string"&&typeof a.connectorType=="string"&&typeof a.walletClientType=="string"&&typeof a.connectedAt=="number",r=Z.get(qa);return r&&Array.isArray(r)&&r.map(a=>o(a)).every(Boolean)?r:[]}saveConnectionHistory(){let o=this.wallets.map(r=>({address:r.address,connectorType:r.connectorType,walletClientType:r.walletClientType,connectedAt:r.connectedAt}));Z.put(qa,o)}async activeWalletSign(o){let r=this.wallets,n=r.length>0?r[0]:null;return n?n.sign(o):null}setActiveWallet(o){this.activeWallet=Hc(o),this.emit("walletsUpdated")}};function ci(e,t){if(e.length!==t.length)return!1;for(let o=0;o<e.length;o++){let r=e[o],n=t[o];if(r?.address!==n?.address||r?.chainId!==n?.chainId||r?.connectorType!==n?.connectorType||r?.connectedAt!==n?.connectedAt||r?.walletClientType!==n?.walletClientType||r?.isConnected!==n?.isConnected||r?.linked!==n?.linked)return!1}return!0}import{ofetch as Jf}from"ofetch";var Qf=[Xn(),ti(),ei()],Zf=e=>{let t=new AbortController;return setTimeout(()=>t.abort(),e),t.signal},vi=class{constructor(t,o,r){this.appId=t,this.clientAnalyticsId=o.clientAnalyticsId,this.sdkVersion=za,this.client=o,this.defaults=r,this.fallbackApiUrl=o.fallbackApiUrl,this.baseFetch=Jf.create({baseURL:this.defaults.baseURL,retry:3,retryDelay:500,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 s=!Qf.includes(n.toString());if(!a.has("authorization")&&s){let l=await this.client.getAccessToken();l!==null&&a.set("authorization",`Bearer ${l}`)}i.headers=a,i.signal||(i.signal=Zf(this.defaults.timeout))},onRequestError:({error:n})=>{if(n instanceof DOMException&&n.name==="AbortError")throw new Qn}})}async get(t,o){try{return await this.baseFetch(t,o)}catch(r){throw te(r)}}async post(t,o,r){try{return await this.baseFetch(t,{method:"POST",...o?{body:o}:{},...r})}catch(n){throw te(n)}}async delete(t,o){try{return await this.baseFetch(t,{method:"DELETE",...o})}catch(r){throw te(r)}}};import an from"js-cookie";function Gc(e){return e instanceof Ho?"email":e instanceof zo?"sms":e instanceof Go?"siwe":e instanceof ir?"custom_auth":e instanceof lo?e.meta.provider:null}import*as zc from"jose";var Wt=class{static parse(t){try{return new Wt(t)}catch{return null}}constructor(t){this.value=t,this._decoded=zc.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 o=Date.now(),r=(this.expiration-t)*1e3;return o>=r}};var Xf=30,wi=class{constructor(){this.authenticateOnce=new dt(async t=>this._authenticate(t)),this.linkOnce=new dt(async t=>this._link(t)),this.refreshOnce=new dt(this._refresh.bind(this)),this.destroyOnce=new dt(this._destroy.bind(this)),this.forkSessionOnce=new dt(this._forkSession.bind(this))}get token(){try{let t=Z.get(ar);return typeof t=="string"?new Wt(t).value:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get refreshToken(){try{let t=Z.get(ni);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get forkedToken(){try{let t=Z.get(Qr);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get mightHaveServerCookies(){try{let t=an.get(nc);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=Wt.parse(this.token);return t!==null&&!t.isExpired(Xf)}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:o,refresh_token:r,user:n,is_new_user:i}=await t.authenticate();this.storeToken(o),this.storeRefreshToken(r);let a=Gc(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:gt(n),isNewUser:i}}catch(o){throw console.warn("Error authenticating session"),Qe(o)}}async _link(t){try{let o=await t.link();return gt(o)}catch(o){throw console.warn("Error linking account"),Qe(o)}}async _refresh(){if(!this.api)throw new C("Session has no API instance");if(!this.client)throw new C("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let t=this.token,o=this.refreshToken,r=this.forkedToken;try{let n;if(t&&o||this.mightHaveServerCookies){let i={};t&&(i.authorization=`Bearer ${t}`);let a=o?{refresh_token:o}:{};n=await this.api.post(Xn(),a,{headers:i}),r&&this.clearForkedToken()}else if(r)n=await this.api.post(ti(),{refresh_token:r}),this.clearForkedToken();else return null;return this.storeToken(n.token),this.storeRefreshToken(n.refresh_token),gt(n.user)}catch(n){if(n instanceof so&&n.privyErrorCode==="missing_or_invalid_token")return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw Qe(n)}}async _destroy(){try{await this.api?.post(ei(),{refresh_token:this.refreshToken})}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new C("Session has no API instance");let t=this.refreshToken;try{let o=await this.api.post(Il(),{refresh_token:t});return this.storeToken(o.token),this.storeRefreshToken(o.refresh_token),o.new_session_refresh_token}catch(o){throw Qe(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),this.clearForkedToken()}storeToken(t){if(typeof t=="string"){if(Z.put(ar,t),!this.client?.useServerCookies){let o=Wt.parse(t)?.expiration;an.set(Va,t,{sameSite:"Strict",secure:!0,expires:o?new Date(o*1e3):void 0})}}else Z.del(ar),an.remove(Va)}storeRefreshToken(t){typeof t=="string"?(Z.put(ni,t),this.client?.useServerCookies||an.set($a,t,{sameSite:"Strict",secure:!0,expires:30})):(Z.del(ni),an.remove($a))}clearForkedToken(){Z.del(Qr)}};var ts,Ci,Vc,sn=class{constructor(t){Jn(this,Ci);this.apiUrl=t.apiUrl||ri,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=!1,this.timeout=t.timeout||oc,this.appId=t.appId,this.clientAnalyticsId=Rl(this,Ci,Vc).call(this),ts||(ts=new wi),this.session=ts,this.api=this.generateApi(),this.session.client=this}initializeConnectorManager(t,o,r,n,i){this.connectors||(this.connectors=new nn(t,o,r,n,i))}generateApi(){let t=new vi(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 C("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new C("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.authFlow=void 0}startAuthFlow(t){t.api=this.api,this.authFlow=t}startMfaFlow(t){t.api=this.api,this.mfaFlow=t}async unlinkEmail(t){try{let o=await this.api.post($l(),{address:t});return gt(o)}catch(o){throw Qe(o)}}async unlinkPhone(t){try{let o=await this.api.post(jl(),{phoneNumber:t});return gt(o)}catch(o){throw Qe(o)}}async unlinkWallet(t){try{let o=await this.api.post(Vl(),{address:t});return gt(o)}catch(o){throw Qe(o)}}async unlinkOAuth(t,o){try{let r=await this.api.post(ql(),{provider:t,subject:o});return gt(r)}catch(r){throw Qe(r)}}async createAnalyticsEvent(t,o,r){if(!(typeof window>"u"))try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(Kl(),{event_name:t,client_id:this.clientAnalyticsId,payload:{...o||{},clientTimestamp:r?r.toISOString():new Date().toISOString()}})}catch{}}async signMoonpayOnRampUrl(t){try{return this.api.post(Yl(),t)}catch(o){throw Qe(o)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()||this.session.hasRecoveryCredentials()?this.session.refresh():null}async getAccessToken(t){return this.session.hasActiveToken()?Wt.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,tiktokOAuth:t.tiktok_oauth,linkedinOAuth:t.linkedin_oauth,appleOAuth:t.apple_oauth,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,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}}catch(t){throw Qe(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()}};Ci=new WeakSet,Vc=function(){if(typeof window>"u")return null;try{let o=Z.get(Zr);if(typeof o=="string"&&o.length>0)return o}catch{}let t=eh();try{return Z.put(Zr,t),t}catch{return t}};import"wicg-inert";import{useRef as P0,useState as Um}from"react";import{useEffect as x0}from"react";import T0 from"react-dom";import{createContext as th,useContext as oh}from"react";var we=th({ready:!1,authenticated:!1,user:null,walletConnectors:null,connectWallet:P,login:P,linkEmail:P,linkPhone:P,linkWallet:P,linkGoogle:P,linkTwitter:P,linkDiscord:P,linkGithub:P,linkTiktok:P,linkLinkedIn:P,linkApple:P,logout:P,getAccessToken:P,getEthereumProvider:P,getEthersProvider:P,getWeb3jsProvider:P,unlinkEmail:P,unlinkPhone:P,unlinkWallet:P,unlinkGoogle:P,unlinkTwitter:P,unlinkDiscord:P,unlinkGithub:P,unlinkTiktok:P,unlinkLinkedIn:P,unlinkApple:P,setActiveWallet:P,forkSession:P,createWallet:P,signMessage:P,enrollInMfa:P,initEnrollmentWithSms:P,initEnrollmentWithTotp:P,promptMfa:P,init:P,submitEnrollmentWithSms:P,submitEnrollmentWithTotp:P,unenroll:P,submit:P,cancel:P,sendTransaction:P,exportWallet:P,setWalletPassword:P,initLoginWithEmail:P,loginWithCode:P,isModalOpen:!1}),G=()=>oh(we);import{useEffect as rh,useState as nh}from"react";var $c=e=>{let[t,o]=nh("auto");return rh(()=>{let r=new ResizeObserver(n=>{o(n[0]?.contentRect.height??"auto")});return e.current&&r.observe(e.current),()=>{e.current&&r.unobserve(e.current)}},[e.current]),t};import{createContext as ih,useContext as ah,useEffect as sh}from"react";var jc={login:{onComplete:[],onError:[]},logout:{onSuccess:[]},connectWallet:{onSuccess:[],onError:[]},createWallet:{onSuccess:[],onError:[]},configureMfa:{onMfaRequired:[]}},os=ih(void 0),qc=()=>ah(os);function Mt(e,t){if(!t)return;let r=qc().current[e];return sh(()=>{for(let[n,i]of Object.entries(t))r.hasOwnProperty(n)||console.warn(`Invalid event type "${n}" for action "${e}"`),r[n]?.push(i);return()=>{for(let[n,i]of Object.entries(t))r.hasOwnProperty(n)||console.warn(`Invalid event type "${n}" for action "${e}"`),r[n]=r[n]?.filter(a=>a!==i)}},[t])}function de(e,t,o,...r){for(let n of e.current[t][o])n(...r)}function Kc(){let e=qc();return(t,o,...r)=>de(e,t,o,...r)}function rs(e){Mt("configureMfa",e)}import ps from"styled-components";import $o,{css as ss}from"styled-components";import is from"styled-components";import{Fragment as ch,jsx as ns,jsxs as dh}from"react/jsx-runtime";var bi=({success:e,fail:t})=>dh(ch,{children:[ns(Lt,{className:e?"success":t?"fail":""}),ns(as,{className:e?"success":t?"fail":""})]}),Lt=is.span`
|
|
12
|
+
- https://privy.io`;this.getNonceOnce=new dt(this._getNonceOnce.bind(this)),this.wallet=t}get meta(){return{connectorType:this.wallet.connectorType,walletClientType:this.wallet.walletClientType}}async authenticate(){if(!this.api)throw new C("Auth flow has no API instance");try{let{message:t,signature:o}=await this.sign(),r=await this.api.post(Ml(),{message:t,signature:o,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType});return{user:r.user,token:r.token,refresh_token:r.refresh_token,is_new_user:r.is_new_user}}catch(t){throw te(t)}}async link(){if(!this.api)throw new C("Auth flow has no API instance");try{let{message:t,signature:o}=await this.sign();return await this.api.post(Ll(),{message:t,signature:o,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(t){throw te(t)}}async sign(){if(!this.api)throw new C("Auth flow has no API instance");if(await this.buildSiweMessage(),!this.preparedMessage)throw new C("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 C("Auth flow has no API instance");let t=this.wallet.address;return(await this.api.post(Wl(),{address:t})).nonce}async buildSiweMessage(){if(!this.api)throw new C("Auth flow has no API instance");let t=this.wallet.address,o=this.wallet.chainId.replace("eip155:","");return this.nonce||(this.nonce=await this.getNonceOnce.execute()),this.preparedMessage=this.prepareMessage(o,t,this.nonce),this.preparedMessage}prepareMessage(t,o,r){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.",s=new Date().toISOString();return this.createSiweMessage(t,o,n,i,s,r,a)}};var zo=class{constructor(t,o){this.meta={phoneNumber:t,captchaToken:o}}async authenticate(){if(!this.api)throw new C("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new C("phone number and sms code must be set prior to calling authenticate.");try{let t=Fl(),o=await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return{user:o.user,token:o.token,refresh_token:o.refresh_token,is_new_user:o.is_new_user}}catch(t){throw te(t)}}async link(){if(!this.api)throw new C("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new C("phone number and sms code must be set prior to calling authenticate.");try{let t=Bl();return await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(t){throw te(t)}}async sendSmsCode(t,o){if(!this.api)throw new C("Auth flow has no API instance");if(t&&(this.meta.phoneNumber=t),o&&(this.meta.captchaToken=o),!this.meta.phoneNumber)throw new C("phone nNumber must be set when initialzing authentication.");try{let r=Ul();return await this.api.post(r,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken})}catch(r){throw te(r)}}};import{v4 as eh}from"uuid";function Ze(e){return new Date(e*1e3)}function hf(e){let t=[];for(let o of e){let r=o.type;switch(o.type){case"wallet":let n={address:o.address,type:o.type,verifiedAt:Ze(o.verified_at),chainType:"ethereum",chainId:o.chain_id,walletClient:o.wallet_client_type==="privy"?"privy":"unknown",walletClientType:o.wallet_client_type,connectorType:o.connector_type,recoveryMethod:o.recovery_method};t.push(n);break;case"email":let i={address:o.address,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(i);break;case"phone":let a={number:o.phoneNumber,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(a);break;case"google_oauth":let s={subject:o.subject,email:o.email,name:o.name,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(s);break;case"twitter_oauth":let l={subject:o.subject,username:o.username,name:o.name,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(l);break;case"discord_oauth":let c={subject:o.subject,username:o.username,email:o.email,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(c);break;case"github_oauth":let u={subject:o.subject,username:o.username,name:o.name,email:o.email,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(u);break;case"tiktok_oauth":let y={subject:o.subject,username:o.username,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(y);break;case"linkedin_oauth":let w={subject:o.subject,name:o.name,email:o.email,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(w);break;case"apple_oauth":let m={subject:o.subject,email:o.email,type:o.type,verifiedAt:Ze(o.verified_at)};t.push(m);break;case"custom_auth":t.push({type:o.type,customUserId:o.custom_user_id,verifiedAt:Ze(o.verified_at)});break;default:console.warn(`Unrecognized account type: ${r}. Please consider upgrading the Privy SDK.`)}}return t}function St(e,t){return e.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),e.find(o=>o.type===t)}var ne=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy")||null,yf=e=>e.linkedAccounts.filter(t=>t.type==="wallet"),co=(e,t)=>t==="all-users"&&!ne(e)||t==="users-without-wallets"&&!yf(e)?.length;function gt(e){if(!e)return null;let t=hf(e.linked_accounts),o=St(t,"wallet"),r=St(t,"email"),n=St(t,"phone"),i=St(t,"google_oauth"),a=St(t,"twitter_oauth"),s=St(t,"discord_oauth"),l=St(t,"github_oauth"),c=St(t,"tiktok_oauth"),u=St(t,"linkedin_oauth"),y=St(t,"apple_oauth"),w=e.mfa_methods.map(({type:E,verified_at:b})=>({type:E,verifiedAt:Ze(b)}));return{id:e.id,createdAt:Ze(e.created_at),linkedAccounts:t,email:r&&{address:r?.address},phone:n&&{number:n?.number},wallet:o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletClient:o.walletClient,walletClientType:o.walletClientType,connectorType:o.connectorType,recoveryMethod:o.recoveryMethod},google:i&&{subject:i.subject,email:i.email,name:i.name},twitter:a&&{subject:a.subject,username:a.username,name:a.name},discord:s&&{subject:s.subject,username:s.username,email:s.email},github:l&&{subject:l.subject,username:l.username,name:l.name,email:l.email},tiktok:c&&{subject:c.subject,username:c.username},linkedin:u&&{subject:u.subject,name:u.name},apple:y&&{subject:y.subject,email:y.email},mfaMethods:w.map(E=>E.type)}}import{getAddress as Hc}from"@ethersproject/address";import Yf from"eventemitter3";var Xl="1.52.2";var oi="4df5e2316331463a9130964bd6078dfa",ec="fe9c30fc-3bc5-4064-91e2-6ab5887f8f4d",tc="34357d3c125c2bcf2ce2bc3309d98715",ri="https://auth.privy.io",oc=2e4,Xe=1400,rc=2500,za=Xl;var ar="privy:token",Va="privy-token",ni="privy:refresh_token",$a="privy-refresh-token",nc="privy-session",Qr="privy:session_transfer_token",vf="privy:wallet",Zr="privy:caid",ii=e=>`${vf}:${e}`,ja="privy:connectors",qa="privy:connections";var Xr=12e4,jt=1,Ka="0x1",sr=3e4,ic="https://api.moonpay.com/v1",ac="https://api.moonpay.com/v1",sc="pk_live_hirbpu0cVcLHrjktC9l7fbc9ctjv0SL",lc="pk_test_fqWjXZMSFwloh7orvJsRfjiUHXJqFzI",cc="0x420000000000000000000000000000000000000F",dc=["function getL1Fee(bytes memory _data) external view returns (uint256)"];var Ya=class{constructor(){this._cache={}}get(t){return this._cache[t]}put(t,o){o!==void 0?this._cache[t]=o:this.del(t)}del(t){delete this._cache[t]}getKeys(){return Object.keys(this._cache)}},Ja=class{get(t){let o=localStorage.getItem(t);return o===null?void 0:JSON.parse(o)}put(t,o){o!==void 0?localStorage.setItem(t,JSON.stringify(o)):this.del(t)}del(t){localStorage.removeItem(t)}getKeys(){return Object.entries(localStorage).map(([t])=>t)}};function wf(){return typeof window<"u"&&window.localStorage?new Ja:new Ya}var Z=wf();function pc(){let e=window,t=e.ethereum;if(!t)return[];let o=[];if(t.providers?.length)for(let r of t.providers)r&&o.push(r);return o.push(e.ethereum),o}var ai=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 Qa=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||ai(e)!=="MetaMask")return!1;if(e.providers){for(let o of e.providers)if(!Qa(o))return!1}return!0},_t=()=>!!("phantom"in window&&window?.phantom?.ethereum?.isPhantom),uc=()=>{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 mc=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,}))$/),fc=(e,t)=>{let o=e.slice(0),r=[];for(;o.length;)r.push(o.splice(0,t));return r},po=(e,t=3,o=4)=>{if(!e)return"";let r=2,n=3;if(t+o+r+n>=e.length)return e;let i=e.slice(0,r+t),a=e.slice(e.length-o,e.length);return`${i}...${a}`},Za=e=>new Promise(t=>setTimeout(t,e));function hc(e,{interval:t=100,timeout:o=5e3}={}){return new Promise((r,n)=>{let i=0,a,s=()=>{if(i>=o){n("Max attempts reached without result");return}if(a=e(),i+=t,a!=null){r(a);return}setTimeout(s,t)};s()})}var yc=(e,t={})=>{let o=t.delayMs||150,r=t.maxAttempts||270;return new Promise(async(n,i)=>{let a=!1,s=0;for(;!a&&s<r;){if(t.abortSignal?.aborted)return;e().then(()=>{a=!0,n()},(...l)=>{a=!0,i(...l)}),s+=1,await Za(o)}a||i(new Error("Exceeded max attempts before resolving function"))})},si=(e,t,o={})=>{let r=new URL(t,e);for(let[n,i]of Object.entries(o))r.searchParams.set(n,i);return r.href};var Xa=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),Vo=e=>typeof e=="string"?e:"0x"+e.toString(16);async function gc(e,t=3e3){let o=!1,r=window;return new Promise(n=>{r.ethereum?i():(window.addEventListener("ethereum#initialized",i,{once:!0}),setTimeout(()=>{i()},t));function i(){if(o)return;o=!0,window.removeEventListener("ethereum#initialized",i);let a=e.getProviders(),s=[];for(let l of a)l.info.rdns!=="com.coinbase.wallet"&&s.push({type:l.info.name.toLowerCase().replace(/\s/g,"_"),eip6963InjectedProvider:l});_t()&&s.push({type:"phantom"});for(let l of pc()){let c=ai(l);if(!a.some(u=>u.info.name===c)){if(Qa(l,!0)&&!s.find(u=>u.type==="metamask")){s.push({type:"metamask",legacyInjectedProvider:l});continue}s.find(u=>u.type==="unknown_browser_extension")||s.push({type:"unknown_browser_extension",legacyInjectedProvider:l})}}n(s)}})}function lr(e){return`eip155:${String(Number(e))}`}var vt=(e,t,o)=>{let r=Number(e),n=t.find(a=>a.id===r);if(!n)throw new H(`Unsupported chainId ${e}`,4901);let i;if(o.rpcUrls&&o.rpcUrls[r]?i=o.rpcUrls[r]:n.rpcUrls.infura?.http[0]?i=n.rpcUrls.infura.http[0]+"/"+oi:n.rpcUrls.blast?.http[0]?i=n.rpcUrls.blast.http[0]+"/"+ec:i=n.rpcUrls.default?.http[0],!i)throw new H(`No RPC url found for ${e}`);return i},vc=(e,t)=>{let o=Number(e),r=t.find(n=>n.id===o);if(!r)throw new H(`Unsupported chainId ${e}`,4901);return r.blockExplorers?.default.url};import Af from"@coinbase/wallet-sdk";import{jsx as wc,jsxs as Cf}from"react/jsx-runtime";var en=({style:e,...t})=>Cf("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:[wc("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),wc("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 Rt}from"@ethersproject/address";import{Web3Provider as Tc}from"@ethersproject/providers";import{default as _f}from"eventemitter3";import{StaticJsonRpcProvider as bc}from"@ethersproject/providers";import Sf from"eventemitter3";var bf=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4"],Cc=e=>bf.includes(e);import{ErrorCode as Ef}from"@ethersproject/logger";var cr=class extends H{constructor(){super("Wallet timeout");this.type="wallet_error"}},dr=class extends H{constructor(){super("User rejected connection");this.type="wallet_error"}},et=e=>{if(e instanceof H)return e;if(e?.code&&e?.reason){let t=new Oe(e);return e.code===Ef.ACTION_REJECTED&&(t.details=$e.E4001_USER_REJECTED_REQUEST),t}return e?.code?new Oe(e):new H("Unknown connector error",e)},kt=class extends Ye{constructor(o,r,n){super(o);this.type="provider_error";this.code=r,this.data=n}},Oe=class extends kt{constructor(o){let r=o;super(r.message,r.code,r.data);let n=Object.values($e).find(i=>i.eipCode===r.code);this.details=n||$e.UNKNOWN_ERROR,r.code===-32002&&(r.message?.includes("already pending for origin")?r.message?.includes("wallet_requestPermissions")?this.details=$e.E32002_CONNECTION_ALREADY_PENDING:this.details=$e.E32002_REQUEST_ALREADY_PENDING:r.message?.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=$e.E32002_WALLET_LOCKED))}},Pf={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}},xf={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}},Tf={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}},$e={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Tf,...xf},qt={...Pf,...$e};var oe=class{constructor(t,o){this.removeListener=(t,o)=>{if(this.walletProvider)try{return this.walletProvider.removeListener(t,o)}catch{console.warn("Unable to remove wallet provider listener")}};this.walletTimeout=(t=new cr,o=this.rpcTimeoutDuration)=>new Promise((r,n)=>setTimeout(()=>{n(t)},o));this.setWalletProvider=t=>{this.walletProvider&&this._subscriptions.forEach(o=>{this.removeListener(o.eventName,o.listener)}),this.walletProvider=t,this._subscriptions.forEach(o=>{this.walletProvider?.on(o.eventName,o.listener)})};this.walletProvider=t,this.rpcTimeoutDuration=o||Xr,this._subscriptions=[]}on(t,o){if(this.walletProvider)return this.walletProvider.on(t,o);this._subscriptions.push({eventName:t,listener:o})}async request(t){if(!this.walletProvider)throw new H(`A wallet request of type ${t.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(t),this.walletTimeout()]).catch(o=>{throw et(o)})}},uo=class extends Error{constructor(o,r,n){super(o);this.code=r,this.data=n}},li=class extends Sf{constructor(o,r,n,i,a=1){super();this.walletProxy=o,this.address=r,this.chainId=a,this.rpcConfig=n,this.chains=i,this.provider=new bc(vt(a,this.chains,n)),this.rpcTimeoutDuration=pr(n,"privy")}async handleSendTransaction(o){if(!o.params||!Array.isArray(o.params))throw new uo(`Invalid params for ${o.method}`,4200);let r=o.params[0];if(!await ke()||!this.address)throw new uo("Disconnected",4900);return(await Pc(r)).hash}handleSwitchEthereumChain(o){if(!o.params||!Array.isArray(o.params))throw new uo(`Invalid params for ${o.method}`,4200);let r;if(typeof o.params[0]=="string")r=o.params[0];else if("chainId"in o.params[0]&&typeof o.params[0].chainId=="string")r=o.params[0].chainId;else throw new uo(`Invalid params for ${o.method}`,4200);this.chainId=Number(r),this.provider=new bc(vt(this.chainId,this.chains,this.rpcConfig)),this.emit("chainChanged",r)}async handlePersonalSign(o){if(!o.params||!Array.isArray(o.params))throw new Error("Invalid params for eth_estimateGas");let r=o.params[0];return await Ec(r)}async handleEstimateGas(o){if(!o.params||!Array.isArray(o.params))throw new Error("Invalid params for eth_estimateGas");delete o.params[0].gasPrice,delete o.params[0].maxFeePerGas,delete o.params[0].maxPriorityFeePerGas;let r={...o.params[0],chainId:Vo(this.chainId)};try{return await this.provider.send("eth_estimateGas",[r])}catch{return delete r.from,await this.provider.send("eth_estimateGas",[r])}}async request(o){switch(console.debug("Embedded1193Provider.request() called with args",o),o.method){case"eth_accounts":case"eth_requestAccounts":return this.address?[this.address]:[];case"eth_chainId":return Vo(this.chainId);case"eth_estimateGas":return this.handleEstimateGas(o);case"eth_sendTransaction":return this.handleSendTransaction(o);case"wallet_switchEthereumChain":return this.handleSwitchEthereumChain(o);case"personal_sign":return this.handlePersonalSign(o);default:break}if(Cc(o.method)){let r=await ke();if(await xc(),!r||!this.address)throw new uo("Disconnected",4900);try{return(await this.walletProxy.rpc({address:this.address,accessToken:r,request:{method:o.method,params:o.params}})).response.data}catch(n){throw console.error(n),new uo("Disconnected",4900)}}else return this.provider.send(o.method,o.params)}async connect(){let o=await ke();if(!o||!this.address)return null;try{return(await this.walletProxy.connect({address:this.address,accessToken:o})).address}catch(r){return console.error(r),null}}},At=class extends oe{constructor(o){super(o,o.rpcTimeoutDuration)}},mo=class extends oe{constructor(t){super(t,t.rpcTimeoutDuration)}sendAsync(t,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};var kf=(e,t)=>{switch(t){case"coinbase_wallet":return e.message.includes("addEthereumChain");default:return e.code===4902||e.message?.includes("4902")}},je=class extends _f{constructor(o,r,n,i){super();this.onAccountsChanged=o=>{o.length===0?this.onDisconnect():this.syncAccounts(o)};this.onChainChanged=o=>{this.wallets.forEach(r=>{r.chainId=lr(o),this.walletClientType==="privy"&&Z.put(ii(r.address),o)}),this.emit("walletsUpdated")};this.onDisconnect=()=>{this.connected=!1,this.wallets=[],this.emit("walletsUpdated")};this.onConnect=()=>{this.connected=!0,this.syncAccounts()};this.wallets=[],this.walletClientType=o,this.chains=r,this.defaultChain=n,this.rpcConfig=i,this.rpcTimeoutDuration=pr(i,o),this.connected=!1,this.initialized=!1}buildConnectedWallet(o,r){let n=async()=>!!this.wallets.find(i=>Rt(i.address)===Rt(o));return{address:Rt(o),chainId:r,switchChain:async i=>{if(!n)throw new H("Wallet is not currently connected.");let a=this.wallets.find(y=>Rt(y.address)===Rt(o))?.chainId;if(!a)throw new H("Unable to determine current chainId.");let s,l;if(typeof i=="number"?(s=`0x${i.toString(16)}`,l=i):(s=i,l=Number(i)),a===lr(s))return;let c=this.chains.find(y=>y.id===l);if(!c)throw new H(`Unsupported chainId: ${i}`);let u=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:s}]})};try{return await u()}catch(y){if(kf(y,this.walletClientType))return await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:s,chainName:c.name,nativeCurrency:c.nativeCurrency,rpcUrls:[c.rpcUrls.public?.http[0]??""],blockExplorerUrls:[c.blockExplorers?.default.url??""]}]}),u();throw this.walletClientType==="rainbow"&&y.message?.includes("wallet_switchEthereumChain")?new H(`Rainbow does not support the chainId ${r}`):y}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:n,getEthereumProvider:async()=>{if(!await n())throw new H("Wallet is not currently connected.");return this.proxyProvider},getEthersProvider:async()=>{if(!await n())throw new H("Wallet is not currently connected.");return new Tc(new At(this.proxyProvider))},getWeb3jsProvider:async()=>{if(!await n())throw new H("Wallet is not currently connected.");return new mo(this.proxyProvider)},sign:async i=>{if(!await n())throw new H("Wallet is not currently connected.");return await this.sign(i)},disconnect:()=>{this.disconnect()}}}async syncAccounts(o){let r=o;if(r===void 0){let c=await this.proxyProvider.request({method:"eth_accounts"});Array.isArray(c)&&(r=c)}if(!r||!Array.isArray(r)||r.length<=0||!r[0])return;let n=r[0],i=Rt(n),a=[],s;if(this.walletClientType==="privy"){let c=Z.get(ii(i));this.chains.find(u=>u.id===Number(c))||(Z.del(ii(i)),c=null),s=c||`0x${this.defaultChain.id.toString(16)}`;try{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:s}]})}catch{console.warn(`Unable to switch embedded wallet to chain ID ${s} on initialization`)}}else try{let c=await this.proxyProvider.request({method:"eth_chainId"});if(typeof c=="string")s=c;else if(typeof c=="number")s=`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 ${Ka}`,c),s=Ka}let l=lr(s);a.find(c=>Rt(c.address)===i)||a.push(this.buildConnectedWallet(Rt(n),l)),ci(a,this.wallets)||(this.wallets=a,this.emit("walletsUpdated"))}async getConnectedWallet(){let o=await this.proxyProvider.request({method:"eth_accounts"});return this.wallets.sort((r,n)=>n.connectedAt-r.connectedAt).find(r=>o.find(n=>Rt(n)===Rt(r.address)))||null}async isConnected(){let o=await this.proxyProvider.request({method:"eth_accounts"});return Array.isArray(o)&&o.length>0}async sign(o){return await this.connect({showPrompt:!1}),new Tc(new At(this.proxyProvider)).getSigner().signMessage(o)}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 Rf=e=>{let t=`https://mainnet.infura.io/v3/${oi}`,o=1;return e.makeWeb3Provider(t,o)},di,pi=class extends je{constructor(o,r,n){super("coinbase_wallet",o,r,n);this.connectorType="coinbase_wallet";this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),di||(di=new Af({appName:"Privy",darkMode:!1,headlessMode:!1,enableMobileWalletLink:!0})),this.proxyProvider.setWalletProvider(Rf(di)),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}async connect(o){return o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){di.disconnect()}get walletBranding(){return{name:"Coinbase Wallet",icon:en}}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new H("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([o[0]])}catch(o){throw et(o)}}};import{jsx as Sc}from"react/jsx-runtime";var ui=({...e})=>Sc("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:Sc("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 mi=class extends je{constructor(o,r,n,i){super("privy",r,n,i);this.connectorType="embedded";this.proxyProvider=o,this.subscribeListeners(),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}async connect(o){return await this.isConnected()?(await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[Vo(o?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:ui}}disconnect(){this.connected=!1}async promptConnection(){}};import{jsx as _c}from"react/jsx-runtime";var ur=({style:e,...t})=>_c("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",stroke:"currentColor",strokeWidth:1.5,viewBox:"0 0 24 24",style:{...e},...t,children:_c("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 tt,jsxs as If}from"react/jsx-runtime";var mr=({style:e,...t})=>If("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:[tt("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),tt("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"}),tt("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"})]});var fr=class extends je{constructor(o,r,n,i,a){super(a||"unknown",o,r,n);this.connectorType="injected";this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.providerDetail=i;let s=i.provider;this.proxyProvider.setWalletProvider(s),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}async connect(o){return o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return{name:this.providerDetail.info.name,icon:this.providerDetail.info.icon}}disconnect(){console.warn(`Programmatic disconnect with ${this.providerDetail.info.name} is not yet supported.`)}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new H("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw et(o)}}},on,tn=class extends je{constructor(o,r,n,i,a){super(a?"metamask":"unknown",o,r,n);this.connectorType="injected";Jn(this,on,void 0);this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(i),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0}),a&&Al(this,on,{name:"MetaMask",icon:mr})}async connect(o){return o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return kl(this,on)??{name:"Browser Extension",icon:ur}}disconnect(){console.warn("Programmatic disconnect with browser wallets is not yet supported.")}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new H("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw et(o)}}};on=new WeakMap;import{getAddress as z2}from"@ethersproject/address";import{Web3Provider as $2}from"@ethersproject/providers";import{isMobile as Wf}from"react-device-detect";var fi=class extends fr{disconnect(){console.warn("Metamask does not support programmatic disconnect.")}async promptConnection(){try{Wf||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 H("Unable to retrieve accounts");await this.syncAccounts([t[0]])}catch(t){throw et(t)}}};import{jsx as kc,jsxs as Mf}from"react/jsx-runtime";var fo=({style:e,...t})=>Mf("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:[kc("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),kc("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 hi=class extends je{constructor(o,r,n){super("phantom",o,r,n);this.connectorType="phantom";this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),this.proxyProvider.setWalletProvider(window.phantom.ethereum),this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}async connect(o){return o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}get walletBranding(){return{name:"Phantom",icon:fo}}disconnect(){console.warn("Phantom does not support programmatic disconnect.")}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new H("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw et(o)}}};import{EthereumProvider as $f,OPTIONAL_EVENTS as jf,OPTIONAL_METHODS as qf}from"@walletconnect/ethereum-provider";import{isMobile as Kf}from"react-device-detect";import{createContext as Nf,useContext as Of,useEffect as Df,useRef as Uf,useState as Ff}from"react";import{jsx as Lf}from"react/jsx-runtime";function yi({src:e,...t}){return Lf("img",{src:e,...t,style:{display:"none"}})}var P=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};import{jsx as Hf,jsxs as Gf}from"react/jsx-runtime";var Ac=Nf({ready:!1,app:null,currentScreen:null,lastScreen:null,navigate:P,navigateBack:P,resetNavigation:P,setModalData:P,onUserCloseViaDialogOrKeybindRef:void 0}),Bf=["LANDING","CONNECT_ONLY_LANDING_SCREEN",null],Rc=e=>{let t=e.appConfig,o=e.authenticated,[r,n]=Ff(e.initialScreen);Df(()=>{!o&&!Bf.includes(e.initialScreen)&&e.setInitialScreen(null)},[o]);let i=Uf(null),a={ready:!!t?.id,app:t,data:e.data,setModalData:e.setModalData,currentScreen:e.initialScreen,lastScreen:r,navigate:s=>{e.setInitialScreen(s),n(e.initialScreen)},navigateBack:()=>{e.setInitialScreen(r)},resetNavigation:()=>{e.setInitialScreen(null),n(null)},onUserCloseViaDialogOrKeybindRef:i};return Gf(Ac.Provider,{value:a,children:[(typeof t?.appearance?.logo=="string"||t?.appearance?.logo?.type==="img")&&Hf(yi,{src:typeof t.appearance.logo=="string"?t.appearance.logo:t.appearance.logo.props.src}),e.children]})},S=()=>Of(Ac);import{jsx as hr,jsxs as zf}from"react/jsx-runtime";var rn=({style:e,...t})=>{let{app:o}=S();return zf("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:[hr("rect",{width:"28",height:"28",rx:"3",fill:o?.appearance.palette.colorScheme==="dark"?"#3396ff":"#141414"}),hr("g",{clipPath:"url(#clip0_1765_9946)",children:hr("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"})}),hr("defs",{children:hr("clipPath",{id:"clip0_1765_9946",children:hr("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})};var gi=e=>{let t;try{t=new URL(e).hostname}catch{return}for(let[o,r]of Object.entries(yr))if(t.includes(r.hostname))return{walletClientType:o,entry:r}};var yr={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"}},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"}},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"}}};function Vf(e){return{name:e.displayName||"",universalLink:e.mobile.universal,deepLink:e.mobile.native}}var Ic=e=>e in yr,Wc=e=>{let t=yr[e].mobile;if("native"in t)return t.native};function Mc(e,t){let o=Vf(t);if(o.deepLink)return Uc(o.deepLink,e);if(o.universalLink)return Fc(o.universalLink,e);throw new C(`Unsupported wallet ${t.id}`)}var Lc="WALLETCONNECT_DEEPLINK_CHOICE";function Nc(){try{localStorage.removeItem(Lc)}catch{}}function Oc({href:e,name:t}){try{localStorage.setItem(Lc,JSON.stringify({href:e,name:t}))}catch{}}function Dc(e){return e.startsWith("http://")||e.startsWith("https://")}function Uc(e,t){if(Dc(e))return Fc(e,t);let o=e;o.includes("://")||(o=e.replaceAll("/","").replaceAll(":",""),o=`${o}://`),o.endsWith("/")||(o=`${o}/`);let r=encodeURIComponent(t);return{redirect:`${o}wc?uri=${r}`,href:o}}function Fc(e,t){if(!Dc(e))return Uc(e,t);let o=e;o.endsWith("/")||(o=`${o}/`);let r=encodeURIComponent(t);return{redirect:`${o}wc?uri=${r}`,href:o}}function Bc(e,t){window.open(e,t,"noreferrer noopener")}var It=class extends je{constructor(o,r,n,i,a){super(a||"unknown",n,i,r);this.connectorType="wallet_connect_v2";this.walletConnectCloudProjectId=o,this.rpcConfig=r,this.proxyProvider=new oe(void 0,this.rpcTimeoutDuration),a&&(this.walletEntry=yr[a],this.walletClientType=a),this.createProvider().then(s=>{if(this.provider=s,this.proxyProvider.setWalletProvider(s),this.subscribeListeners(),s.session){if(this.walletProvider?.session?.peer.metadata.url){let l=gi(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=l?.entry,this.walletClientType=l?.walletClientType||"unknown"}this.connected=!0,this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}else this.emit("initialized"),this.initialized=!0}),import("@walletconnect/modal").then(({WalletConnectModal:s})=>{this.modal=new s({projectId:this.walletConnectCloudProjectId,themeVariables:{"--wcm-z-index":"1000000"}}),this.modal.subscribeModal(l=>{!l.open&&!this.walletProvider?.session&&this.onQrModalClosed&&this.onQrModalClosed()})})}async connect(o){return o.showPrompt&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return!!this.walletProvider?.connected}get walletBranding(){return this.walletClientType==="metamask"?{name:"Metamask",icon:mr}:{name:Xa(this.walletProvider?.session?.peer.metadata.name||"")||"WalletConnect",icon:this.walletProvider?.session?.peer.metadata.icons?.[0]||rn}}resetConnection(o){this.walletProvider&&this.walletProvider.connected&&(this.walletProvider.signer.session=void 0,this.walletEntry=yr[o],this.walletClientType=o,this.redirectUri=void 0,Nc(),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise((o,r)=>{let n=()=>{r(new dr)};this.onQrModalClosed=n,(async()=>{let a="",s=await Promise.race([this.walletProvider?.enable(),this.proxyProvider.walletTimeout()]);if(s?.length&&(a=s[0]),!a||a==="")throw new H("Unable to retrieve address");if(this.walletProvider?.session?.peer.metadata.url){let l=gi(this.walletProvider?.session?.peer.metadata.url);this.walletEntry=l?.entry,this.walletClientType=l?.walletClientType||"unknown",this.proxyProvider.rpcTimeoutDuration=pr(this.rpcConfig,this.walletClientType)}this.connected=!0,await this.syncAccounts(s),o()})().catch(a=>{if(a){r(et(a));return}r(new H("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(o){this.proxyProvider.setWalletProvider(o)}async createProvider(){let o={};for(let n of this.chains){let i=vt(n.id,this.chains,this.rpcConfig);i&&(o[n.id]=i)}let r=await $f.init({projectId:this.walletConnectCloudProjectId,chains:[this.defaultChain.id],optionalChains:this.chains.map(n=>n.id),optionalEvents:jf,optionalMethods:qf,rpcMap:o,showQrModal:!1});return r.on("display_uri",n=>{if(r.signer.abortPairingAttempt(),Kf&&this.walletEntry){let{redirect:i,href:a}=Mc(n,this.walletEntry);Oc({href:a,name:this.walletEntry.displayName}),this.redirectUri=i,Bc(i,"_self")}else this.modal?.openModal({uri:n,chains:[this.defaultChain.id]})}),r.on("connect",()=>{if(this.modal?.closeModal(),r.session?.peer.metadata.url){let n=gi(r.session?.peer.metadata.url);this.walletEntry=n?.entry,this.walletClientType=n?.walletClientType||"unknown"}}),r}async enableProvider(){return this.walletProvider?.connected?Promise.resolve(this.walletProvider.accounts):await this.walletProvider?.enable()}};var es=e=>{let t=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return t?!!e?.linkedAccounts.filter(r=>r.type=="wallet"&&r.address===Hc(t)).length:!1},pr=(e,t)=>e.rpcTimeouts?e.rpcTimeouts[t]||Xr:Xr,nn=class extends Yf{constructor(o,r,n,i,a){super();this.getEthereumProvider=()=>{let o=this.wallets[0],r=this.walletConnectors.find(n=>n.wallets.find(i=>i.address===o?.address));return!o||!r?new oe:r.proxyProvider};this.walletConnectCloudProjectId=o,this.rpcConfig=r,this.chains=n,this.defaultChain=i,this.walletConnectors=[],this.initialized=!1,this.store=a,this.storedConnections=this.loadConnectionHistory()}get wallets(){let o=new Set,r=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 o.has(a)?!1:(o.add(a),!0)}),n=r.findIndex(i=>i.address===(this.activeWallet?this.activeWallet:"unknown"));return n>=0&&r.unshift(r.splice(n,1)[0]),r}initialize(){this.initialized||(Z.get(ja)&&(Z.getKeys().forEach(o=>{o.startsWith("walletconnect")&&Z.del(o)}),Z.del(ja)),gc(this.store).then(o=>o.forEach(({type:r,eip6963InjectedProvider:n,legacyInjectedProvider:i})=>{this.createWalletConnector("injected",r,{eip6963InjectedProvider:n,legacyInjectedProvider:i})})),this.createWalletConnector("coinbase_wallet","coinbase_wallet"),this.createWalletConnector("wallet_connect_v2","unknown"),this.initialized=!0)}findWalletConnector(o,r){return o==="wallet_connect_v2"?this.walletConnectors.find(n=>n.connectorType===o)||null:this.walletConnectors.find(n=>n.connectorType===o&&n.walletClientType===r)||null}onInitialized(o){o.wallets.forEach(r=>{let n=this.storedConnections.find(i=>i.address===r.address&&i.connectorType===r.connectorType&&i.walletClientType===r.walletClientType);n&&(r.connectedAt=n.connectedAt)}),this.saveConnectionHistory(),this.emit("walletsUpdated")}onWalletsUpdated(o){o.initialized&&(this.saveConnectionHistory(),this.emit("walletsUpdated"))}addEmbeddedWalletConnector(o,r,n){let i=this.findWalletConnector("embedded","privy");if(i)i.proxyProvider.walletProxy=o;else{let a=new li(o,r,this.rpcConfig,this.chains,n.id),s=new mi(a,this.chains,n,this.rpcConfig);this.addWalletConnector(s)}}removeEmbeddedWalletConnector(){let o=this.findWalletConnector("embedded","privy");if(o){let r=this.walletConnectors.indexOf(o);this.walletConnectors.splice(r,1),this.saveConnectionHistory(),this.storedConnections=this.loadConnectionHistory(),this.emit("walletsUpdated")}}async createWalletConnector(o,r,n){let i=this.findWalletConnector(o,r);if(i)return i instanceof It&&i.resetConnection(r),i;let s=(()=>{if(o==="injected"){if(r==="metamask"&&n?.eip6963InjectedProvider)return new fi(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,"metamask");if(r==="metamask"&&n?.legacyInjectedProvider)return new tn(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider,!0);if(r==="phantom"&&_t())return new hi(this.chains,this.defaultChain,this.rpcConfig);if(n?.legacyInjectedProvider&&r==="unknown_browser_extension")return new tn(this.chains,this.defaultChain,this.rpcConfig,n?.legacyInjectedProvider);if(n?.eip6963InjectedProvider)return new fr(this.chains,this.defaultChain,this.rpcConfig,n?.eip6963InjectedProvider,r)}else return o==="coinbase_wallet"?new pi(this.chains,this.defaultChain,this.rpcConfig):new It(this.walletConnectCloudProjectId,this.rpcConfig,this.chains,this.defaultChain,r)})();return s&&this.addWalletConnector(s),s||null}addWalletConnector(o){this.walletConnectors.push(o),o.on("initialized",()=>this.onInitialized(o)),o.on("walletsUpdated",()=>this.onWalletsUpdated(o))}loadConnectionHistory(){let o=a=>a&&typeof a.address=="string"&&typeof a.connectorType=="string"&&typeof a.walletClientType=="string"&&typeof a.connectedAt=="number",r=Z.get(qa);return r&&Array.isArray(r)&&r.map(a=>o(a)).every(Boolean)?r:[]}saveConnectionHistory(){let o=this.wallets.map(r=>({address:r.address,connectorType:r.connectorType,walletClientType:r.walletClientType,connectedAt:r.connectedAt}));Z.put(qa,o)}async activeWalletSign(o){let r=this.wallets,n=r.length>0?r[0]:null;return n?n.sign(o):null}setActiveWallet(o){this.activeWallet=Hc(o),this.emit("walletsUpdated")}};function ci(e,t){if(e.length!==t.length)return!1;for(let o=0;o<e.length;o++){let r=e[o],n=t[o];if(r?.address!==n?.address||r?.chainId!==n?.chainId||r?.connectorType!==n?.connectorType||r?.connectedAt!==n?.connectedAt||r?.walletClientType!==n?.walletClientType||r?.isConnected!==n?.isConnected||r?.linked!==n?.linked)return!1}return!0}import{ofetch as Jf}from"ofetch";var Qf=[Xn(),ti(),ei()],Zf=e=>{let t=new AbortController;return setTimeout(()=>t.abort(),e),t.signal},vi=class{constructor(t,o,r){this.appId=t,this.clientAnalyticsId=o.clientAnalyticsId,this.sdkVersion=za,this.client=o,this.defaults=r,this.fallbackApiUrl=o.fallbackApiUrl,this.baseFetch=Jf.create({baseURL:this.defaults.baseURL,retry:3,retryDelay:500,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 s=!Qf.includes(n.toString());if(!a.has("authorization")&&s){let l=await this.client.getAccessToken();l!==null&&a.set("authorization",`Bearer ${l}`)}i.headers=a,i.signal||(i.signal=Zf(this.defaults.timeout))},onRequestError:({error:n})=>{if(n instanceof DOMException&&n.name==="AbortError")throw new Qn}})}async get(t,o){try{return await this.baseFetch(t,o)}catch(r){throw te(r)}}async post(t,o,r){try{return await this.baseFetch(t,{method:"POST",...o?{body:o}:{},...r})}catch(n){throw te(n)}}async delete(t,o){try{return await this.baseFetch(t,{method:"DELETE",...o})}catch(r){throw te(r)}}};import an from"js-cookie";function Gc(e){return e instanceof Ho?"email":e instanceof zo?"sms":e instanceof Go?"siwe":e instanceof ir?"custom_auth":e instanceof lo?e.meta.provider:null}import*as zc from"jose";var Wt=class{static parse(t){try{return new Wt(t)}catch{return null}}constructor(t){this.value=t,this._decoded=zc.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 o=Date.now(),r=(this.expiration-t)*1e3;return o>=r}};var Xf=30,wi=class{constructor(){this.authenticateOnce=new dt(async t=>this._authenticate(t)),this.linkOnce=new dt(async t=>this._link(t)),this.refreshOnce=new dt(this._refresh.bind(this)),this.destroyOnce=new dt(this._destroy.bind(this)),this.forkSessionOnce=new dt(this._forkSession.bind(this))}get token(){try{let t=Z.get(ar);return typeof t=="string"?new Wt(t).value:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get refreshToken(){try{let t=Z.get(ni);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get forkedToken(){try{let t=Z.get(Qr);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get mightHaveServerCookies(){try{let t=an.get(nc);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=Wt.parse(this.token);return t!==null&&!t.isExpired(Xf)}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:o,refresh_token:r,user:n,is_new_user:i}=await t.authenticate();this.storeToken(o),this.storeRefreshToken(r);let a=Gc(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:gt(n),isNewUser:i}}catch(o){throw console.warn("Error authenticating session"),Qe(o)}}async _link(t){try{let o=await t.link();return gt(o)}catch(o){throw console.warn("Error linking account"),Qe(o)}}async _refresh(){if(!this.api)throw new C("Session has no API instance");if(!this.client)throw new C("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let t=this.token,o=this.refreshToken,r=this.forkedToken;try{let n;if(t&&o||this.mightHaveServerCookies){let i={};t&&(i.authorization=`Bearer ${t}`);let a=o?{refresh_token:o}:{};n=await this.api.post(Xn(),a,{headers:i}),r&&this.clearForkedToken()}else if(r)n=await this.api.post(ti(),{refresh_token:r}),this.clearForkedToken();else return null;return this.storeToken(n.token),this.storeRefreshToken(n.refresh_token),gt(n.user)}catch(n){if(n instanceof so&&n.privyErrorCode==="missing_or_invalid_token")return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw Qe(n)}}async _destroy(){try{await this.api?.post(ei(),{refresh_token:this.refreshToken})}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new C("Session has no API instance");let t=this.refreshToken;try{let o=await this.api.post(Il(),{refresh_token:t});return this.storeToken(o.token),this.storeRefreshToken(o.refresh_token),o.new_session_refresh_token}catch(o){throw Qe(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),this.clearForkedToken()}storeToken(t){if(typeof t=="string"){if(Z.put(ar,t),!this.client?.useServerCookies){let o=Wt.parse(t)?.expiration;an.set(Va,t,{sameSite:"Strict",secure:!0,expires:o?new Date(o*1e3):void 0})}}else Z.del(ar),an.remove(Va)}storeRefreshToken(t){typeof t=="string"?(Z.put(ni,t),this.client?.useServerCookies||an.set($a,t,{sameSite:"Strict",secure:!0,expires:30})):(Z.del(ni),an.remove($a))}clearForkedToken(){Z.del(Qr)}};var ts,Ci,Vc,sn=class{constructor(t){Jn(this,Ci);this.apiUrl=t.apiUrl||ri,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=!1,this.timeout=t.timeout||oc,this.appId=t.appId,this.clientAnalyticsId=Rl(this,Ci,Vc).call(this),ts||(ts=new wi),this.session=ts,this.api=this.generateApi(),this.session.client=this}initializeConnectorManager(t,o,r,n,i){this.connectors||(this.connectors=new nn(t,o,r,n,i))}generateApi(){let t=new vi(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 C("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new C("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.authFlow=void 0}startAuthFlow(t){t.api=this.api,this.authFlow=t}startMfaFlow(t){t.api=this.api,this.mfaFlow=t}async unlinkEmail(t){try{let o=await this.api.post($l(),{address:t});return gt(o)}catch(o){throw Qe(o)}}async unlinkPhone(t){try{let o=await this.api.post(jl(),{phoneNumber:t});return gt(o)}catch(o){throw Qe(o)}}async unlinkWallet(t){try{let o=await this.api.post(Vl(),{address:t});return gt(o)}catch(o){throw Qe(o)}}async unlinkOAuth(t,o){try{let r=await this.api.post(ql(),{provider:t,subject:o});return gt(r)}catch(r){throw Qe(r)}}async createAnalyticsEvent(t,o,r){if(!(typeof window>"u"))try{this.clientAnalyticsId||console.warn("No client analytics id set, refusing to send analytics event"),await this.api.post(Kl(),{event_name:t,client_id:this.clientAnalyticsId,payload:{...o||{},clientTimestamp:r?r.toISOString():new Date().toISOString()}})}catch{}}async signMoonpayOnRampUrl(t){try{return this.api.post(Yl(),t)}catch(o){throw Qe(o)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()||this.session.hasRecoveryCredentials()?this.session.refresh():null}async getAccessToken(t){return this.session.hasActiveToken()?Wt.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,tiktokOAuth:t.tiktok_oauth,linkedinOAuth:t.linkedin_oauth,appleOAuth:t.apple_oauth,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,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}}catch(t){throw Qe(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()}};Ci=new WeakSet,Vc=function(){if(typeof window>"u")return null;try{let o=Z.get(Zr);if(typeof o=="string"&&o.length>0)return o}catch{}let t=eh();try{return Z.put(Zr,t),t}catch{return t}};import"wicg-inert";import{useRef as P0,useState as Um}from"react";import{useEffect as x0}from"react";import T0 from"react-dom";import{createContext as th,useContext as oh}from"react";var we=th({ready:!1,authenticated:!1,user:null,walletConnectors:null,connectWallet:P,login:P,linkEmail:P,linkPhone:P,linkWallet:P,linkGoogle:P,linkTwitter:P,linkDiscord:P,linkGithub:P,linkTiktok:P,linkLinkedIn:P,linkApple:P,logout:P,getAccessToken:P,getEthereumProvider:P,getEthersProvider:P,getWeb3jsProvider:P,unlinkEmail:P,unlinkPhone:P,unlinkWallet:P,unlinkGoogle:P,unlinkTwitter:P,unlinkDiscord:P,unlinkGithub:P,unlinkTiktok:P,unlinkLinkedIn:P,unlinkApple:P,setActiveWallet:P,forkSession:P,createWallet:P,signMessage:P,enrollInMfa:P,initEnrollmentWithSms:P,initEnrollmentWithTotp:P,promptMfa:P,init:P,submitEnrollmentWithSms:P,submitEnrollmentWithTotp:P,unenroll:P,submit:P,cancel:P,sendTransaction:P,exportWallet:P,setWalletPassword:P,initLoginWithEmail:P,loginWithCode:P,isModalOpen:!1}),G=()=>oh(we);import{useEffect as rh,useState as nh}from"react";var $c=e=>{let[t,o]=nh("auto");return rh(()=>{let r=new ResizeObserver(n=>{o(n[0]?.contentRect.height??"auto")});return e.current&&r.observe(e.current),()=>{e.current&&r.unobserve(e.current)}},[e.current]),t};import{createContext as ih,useContext as ah,useEffect as sh}from"react";var jc={login:{onComplete:[],onError:[]},logout:{onSuccess:[]},connectWallet:{onSuccess:[],onError:[]},createWallet:{onSuccess:[],onError:[]},configureMfa:{onMfaRequired:[]}},os=ih(void 0),qc=()=>ah(os);function Mt(e,t){if(!t)return;let r=qc().current[e];return sh(()=>{for(let[n,i]of Object.entries(t))r.hasOwnProperty(n)||console.warn(`Invalid event type "${n}" for action "${e}"`),r[n]?.push(i);return()=>{for(let[n,i]of Object.entries(t))r.hasOwnProperty(n)||console.warn(`Invalid event type "${n}" for action "${e}"`),r[n]=r[n]?.filter(a=>a!==i)}},[t])}function de(e,t,o,...r){for(let n of e.current[t][o])n(...r)}function Kc(){let e=qc();return(t,o,...r)=>de(e,t,o,...r)}function rs(e){Mt("configureMfa",e)}import ps from"styled-components";import $o,{css as ss}from"styled-components";import is from"styled-components";import{Fragment as ch,jsx as ns,jsxs as dh}from"react/jsx-runtime";var bi=({success:e,fail:t})=>dh(ch,{children:[ns(Lt,{className:e?"success":t?"fail":""}),ns(as,{className:e?"success":t?"fail":""})]}),Lt=is.span`
|
|
13
13
|
&& {
|
|
14
14
|
width: 82px;
|
|
15
15
|
height: 82px;
|
|
@@ -2496,4 +2496,4 @@ You will need this password to access your ${e} wallet on a new device. Please k
|
|
|
2496
2496
|
opacity: 1;
|
|
2497
2497
|
}
|
|
2498
2498
|
}
|
|
2499
|
-
`;import{jsx as Ge,jsxs as Fm}from"react/jsx-runtime";var S0={["LANDING"]:tu,["AWAITING_PASSWORDLESS_CODE"]:fd,["AWAITING_CONNECTION"]:_d,["AWAITING_CONNECT_ONLY_CONNECTION"]:Id,["PHANTOM_INTERSTITIAL_SCREEN"]:Sm,["LOGIN_FAILED_SCREEN"]:lu,["AWAITING_OAUTH_SCREEN"]:Em,["ALLOWLIST_REJECTION_SCREEN"]:td,["INSTALL_PHANTOM_SCREEN"]:Mp,["LINK_EMAIL_SCREEN"]:ou,["LINK_PHONE_SCREEN"]:ru,["LINK_WALLET_SCREEN"]:nu,["CONNECT_ONLY_LANDING_SCREEN"]:xd,["CONNECT_ONLY_AUTHENTICATED_SCREEN"]:bd,["EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN"]:gp,["EMBEDDED_WALLET_CREATED_SCREEN"]:Fd,["EMBEDDED_WALLET_CONNECTING_SCREEN"]:Dd,["EMBEDDED_WALLET_RECOVERY_SCREEN"]:Cp,["EMBEDDED_WALLET_KEY_EXPORT_SCREEN"]:zd,["EMBEDDED_WALLET_SIGN_REQUEST_SCREEN"]:Lm,["EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN"]:Wm,["FIAT_ON_RAMP_PROMPT_SCREEN"]:Sp,["FIAT_ON_RAMP_STATUS_SCREEN"]:kp,["EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN"]:wp,["EMBEDDED_WALLET_PASSWORD_UPDATE_SCREEN"]:vp,["MFA_ENROLLMENT_FLOW_SCREEN"]:Nu},_0=({isMfaVerifying:e,onMfaVerificationComplete:t})=>{let{ready:o}=G(),{ready:r,currentScreen:n}=S(),i=P0(null),a=$c(i);if((!o||!r)&&n!=="AWAITING_OAUTH_SCREEN")return Fm(Or,{children:[Ge(T,{}),Ge(j,{}),Ge(gu,{children:Ge(Lt,{})}),Ge(K,{}),Ge(Y,{})]});if(!n)return null;let s=S0[n];return s?Ge(Or,{style:{height:a},children:Fm("div",{ref:i,children:[Ge(Jt,{if:!!e,children:Ge(s,{})}),Ge(Jt,{if:!e,children:Ge(gm,{open:e,onClose:t})})]})}):null},Bm=({open:e})=>{let{app:t}=S(),[o,r]=Um(!1),{gracefulClosePrivyModal:n,onEscape:i}=hu(),[a,s]=Um(!1);rs({onMfaRequired:()=>{t?.mfa.noPromptOnMfaRequired||s(!0)}}),x0(()=>{r(!0)},[]);let l=Ge(Dm,{children:Ge(_0,{isMfaVerifying:a,onMfaVerificationComplete:()=>s(!1)})}),c=e||a,u=t?.render.inDialog?Ge("div",{onKeyDown:i,children:Ge(yu,{open:c,id:"privy-dialog",onClick:()=>n(),children:l})}):l;if(o){let y=t?.render.inParentNodeId&&document.getElementById(t.render.inParentNodeId)||document.body;return T0.createPortal(u,y)}return null};var yt={appearance:{theme:"light",accentColor:"#676FFF",walletList:["detected_wallets","metamask","coinbase_wallet","rainbow","wallet_connect"]},walletConnectCloudProjectId:tc,rpcConfig:{rpcUrls:{},rpcTimeouts:{}},captchaEnabled:!1,_render:{inDialog:!0,inParentNodeId:null},fiatOnRamp:{useSandbox:!1}};var k0=new Set(["metamask","coinbase_wallet","rainbow","zerion","phantom","wallet_connect","detected_wallets"]),A0=e=>k0.has(e),R0=(e,t,o)=>o.indexOf(e)===t,Hm=({input:e})=>e?e.filter(A0).filter(R0):yt.appearance.walletList;var Gm={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 zm={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 Vm={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 $m={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 jm={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 qm={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 Km={id:5,network:"goerli",name:"Goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{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 Ym={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 Jm={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 Qm={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 Na={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 Zm={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 Xm={id:11155111,network:"sepolia",name:"Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"SEP",decimals:18},rpcUrls:{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 $n=[wa,Ca,ba,Km,Xm,Na,xa,Ta,Hn,Gn,Vm,$m,jm,qm,Ea,Pa,Jm,Qm,Gm,zm,Sa,_a,Ym,Zm],wL=new Set($n.map(e=>e.id));import tr from"tinycolor2";var ef="#FFFFFF",I0="#000000",W0=ef,M0="#1E1E1D";function L0(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 Mo(e,t){let o=Math.max(0,Math.min(1,e.toHsl().l+t));return tr({...e.toHsl(),l:o})}function tf({backgroundTheme:e,accentHex:t,successHex:o="#51BA81",warnHex:r="#FFB74D",errorHex:n="#EC6351",whiteHex:i=ef,blackHex:a=I0}){let s;switch(e){case"light":s=W0;break;case"dark":s=M0;break;default:s=e;break}let l=tr(s),c=tr(t),u=tr(o),y=tr(r),w=tr(n),m=L0(l.getLuminance()),E=Mo(l,m==="light"?-.04:.11),b=Mo(l,m==="light"?-.88:.87),x=Mo(l,m==="light"?-.77:.75),v=Mo(l,m==="light"?-.43:.45).desaturate(m==="light"?60:20),R=Mo(l,m==="light"?-.08:.25).desaturate(m==="light"?60:20),L=Mo(c,.15),M=Mo(c,-.06),W=tr(c.getLuminance()>.5?a:i),k=Mo(u,-.16);return{colorScheme:m,background:l.toHslString(),background2:E.toHslString(),foreground:b.toHslString(),foreground2:x.toHslString(),foreground3:v.toHslString(),foreground4:R.toHslString(),accent:c.toHslString(),accentLight:L.toHslString(),accentDark:M.toHslString(),foregroundAccent:W.toHslString(),success:u.toHslString(),successDark:k.toHslString(),error:w.toHslString(),warn:y.toHslString()}}function Oa(e,t){let o=["google","twitter","discord","tiktok","linkedin","github","apple"],r=t?.loginMethods?.filter(V=>o.includes(V)),n,i,a,s,l,c,u,y,w,m;t?.loginMethods?(n=t.loginMethods.includes("email"),i=t.loginMethods.includes("sms"),a=t.loginMethods.includes("wallet"),s=r?.includes("google"),l=r?.includes("twitter"),c=r?.includes("discord"),u=r?.includes("tiktok"),w=r?.includes("github"),y=r?.includes("linkedin"),m=r?.includes("apple")):(n=e.emailAuth,i=e.smsAuth,a=e.walletAuth,s=e.googleOAuth,l=e.twitterOAuth,c=e.discordOAuth,w=e.githubOAuth,u=e.tiktokOAuth,y=e.linkedinOAuth,m=e.appleOAuth);let E=[n,i].filter(Boolean),b=[s,l,c,w,u,y,m].filter(Boolean),x=[a].filter(Boolean);if(E.length+b.length+x.length===0)throw new Error("You must enable at least one login method");let v=t?.appearance?.showWalletLoginFirst!==void 0?t?.appearance?.showWalletLoginFirst:e.showWalletLoginFirst;v&&x.length===0?(console.warn("You should only enable `showWalletLoginFirst` when `wallet` logins are also enabled. `showWalletLoginFirst` has been set to false"),v=!1):!v&&b.length+E.length===0&&(console.warn("You should only disable `showWalletLoginFirst` when `email`, `sms`, or social logins are also enabled. `showWalletLoginFirst` has been set to true"),v=!0);let R=Hm({isWalletLoginEnabled:a,input:t?.appearance?.walletList});if(t?.embeddedWallets?.waitForTransactionConfirmation===!1&&t.embeddedWallets.noPromptOnSignature!==!0)throw new Error("Overriding `config.embeddedWallets.waitForTransactionConfirmation` requires that you also enable `config.embeddedWallets.noPromptOnSignature`");let L=t?.intl?.defaultCountry??"US",{chains:M,defaultChain:W}=N0(t?.additionalChains,t?.supportedChains,t?.defaultChain),k=!!t?.defaultChain||!!t?.supportedChains,I=t?.customAuth?.getCustomAccessToken&&t?.customAuth?.enabled!==!1;return{id:e.id,name:e.name,allowlistConfig:e.allowlistConfig,appearance:{logo:t?.appearance?.logo??e.logoUrl,palette:tf({backgroundTheme:t?.appearance?.theme??yt.appearance.theme,accentHex:t?.appearance?.accentColor??e.accentColor??yt.appearance.accentColor}),loginGroupPriority:v?"web3-first":"web2-first",hideDirectWeb2Inputs:!!t?.appearance?.hideDirectWeb2Inputs,walletList:R},loginMethods:{wallet:a,email:n,sms:i,google:s,twitter:l,discord:c,github:w,tiktok:u,linkedin:y,apple:m},legal:{termsAndConditionsUrl:t?.legal?.termsAndConditionsUrl??e.termsAndConditionsUrl,privacyPolicyUrl:t?.legal?.privacyPolicyUrl??e.privacyPolicyUrl},walletConnectCloudProjectId:t?.walletConnectCloudProjectId??e.walletConnectCloudProjectId??yt.walletConnectCloudProjectId,rpcConfig:{rpcUrls:t?.rpcConfig?.rpcUrls??yt.rpcConfig.rpcUrls,rpcTimeouts:t?.rpcConfig?.rpcTimeouts??yt.rpcConfig.rpcTimeouts},chains:M,defaultChain:W,intl:{defaultCountry:L},shouldSwitchChainOnConnect:k,captchaEnabled:e.captchaEnabled??yt.captchaEnabled,captchaSiteKey:e.captchaSiteKey,embeddedWallets:{...e.embeddedWalletConfig,...I?{createOnLogin:"all-users",requireUserPasswordOnCreate:!1,noPromptOnSignature:!0}:{},waitForTransactionConfirmation:!0,priceDisplay:{primary:"fiat-currency",secondary:"native-token"},...t?.embeddedWallets},mfa:{methods:e.mfaMethods??[],noPromptOnMfaRequired:t?.mfa?.noPromptOnMfaRequired??!1},customAuth:I?{enabled:!0,...t.customAuth}:void 0,fiatOnRamp:{enabled:e.fiatOnRampEnabled,useSandbox:t?.fiatOnRamp?.useSandbox??yt.fiatOnRamp.useSandbox},loginConfig:{twitterOAuthOnMobileEnabled:e.twitterOAuthOnMobileEnabled??!1},render:{inDialog:t?._render?.inDialog??yt._render.inDialog,inParentNodeId:t?._render?.inParentNodeId??yt._render.inParentNodeId}}}function of(e,t){if(!e)return{legacyCreateEmbeddedWalletFlag:t};let{appearance:o,additionalChains:r,supportedChains:n,defaultChain:i,...a}=e;return{...a,...r?{additionalChains:r.map(l=>l.id)}:void 0,...n?{supportedChains:n.map(l=>l.id)}:void 0,...i?{defaultChain:i.id}:void 0,...o?{...o,...o.logo&&typeof o.logo?{logo:"component"}:void 0}:void 0,legacyCreateEmbeddedWalletFlag:t}}function N0(e,t,o){let r;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");r=t.map(a=>$n.find(l=>l.id===a.id)??a)}else r=$n.concat(e??[]);let n=t?r[0]:Na,i=o??n;if(!r.find(a=>a.id===i.id))throw new Error("`defaultChain` must be included in `supportedChains`");return{chains:r,defaultChain:i}}import{useRef as O0,useEffect as D0}from"react";var Da=class{constructor(){this.callbacks={}}enqueue(t,o){this.callbacks[t]=o}dequeue(t,o){let r=this.callbacks[o];if(!r)throw new Error(`cannot dequeue ${t} event: no event found for id ${o}`);switch(delete this.callbacks[o],t){case"privy:iframe:ready":return r;case"privy:wallet:create":return r;case"privy:wallet:connect":return r;case"privy:wallet:recover":return r;case"privy:wallet:rpc":return r;case"privy:wallet:set-recovery-password":return r;case"privy:mfa:verify":return r;case"privy:mfa:init-enrollment":return r;case"privy:mfa:submit-enrollment":return r;case"privy:mfa:unenroll":return r;default:throw new Error(`invalid wallet event type ${t}`)}}};async function or(e,t,o,r,n,i=!1){let a=i,s=async u=>{if(a&&t&&t.length>0){u===(i?0:1)?n("configureMfa","onMfaRequired",t):r.current?.reject(new be("missing_or_invalid_mfa","MFA verification failed, retry."));let y=await new Promise((w,m)=>{o.current={resolve:w,reject:m};let E=1e3*60*5;setTimeout(()=>{let b=new be("mfa_timeout","Timed out waiting for MFA code");r.current?.reject(b),m(b)},E)});return await e(y)}return await e()},l=4,c=null;for(let u=0;u<l;u++)try{c=await s(u),r.current?.resolve(void 0);break}catch(y){if(y.type==="missing_or_invalid_mfa")a=!0;else throw r.current?.resolve(void 0),y}if(c===null){let u=new be("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw r.current?.reject(u),u}return c}import{jsx as z0}from"react/jsx-runtime";var U0=function(e){return()=>`id-${e++}`}(0);function F0(e){return typeof e.event=="string"&&/^privy:.+/.test(e.event)}function Ht(e){return e.error!==void 0}var Tt=new Da,El=new Map,B0=(e,t)=>typeof t=="bigint"?t.toString():t,H0=(e,t)=>`${e}${JSON.stringify(t,B0)}`;function Gt(e,t,o){let r=o.contentWindow;if(!r)throw new Error("iframe not initialized");let n=H0(e,t);if(e==="privy:wallet:create"){let a=El.get(n);if(a)return a}let i=new Promise((a,s)=>{let l=U0();Tt.enqueue(l,{resolve:a,reject:s}),r.postMessage({id:l,event:e,data:t},"*")}).finally(()=>{El.delete(n)});return El.set(n,i),i}function G0(e){switch(e.event){case"privy:iframe:ready":let t=Tt.dequeue(e.event,e.id);return Ht(e)?t.reject(new be(e.error.type,e.error.message)):t.resolve(e.data);case"privy:wallet:create":let o=Tt.dequeue(e.event,e.id);return Ht(e)?o.reject(new be(e.error.type,e.error.message)):o.resolve(e.data);case"privy:wallet:connect":let r=Tt.dequeue(e.event,e.id);return Ht(e)?r.reject(new be(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallet:recover":let n=Tt.dequeue(e.event,e.id);return Ht(e)?n.reject(new be(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallet:rpc":let i=Tt.dequeue(e.event,e.id);return Ht(e)?i.reject(new be(e.error.type,e.error.message)):i.resolve(e.data);case"privy:wallet:set-recovery-password":let a=Tt.dequeue(e.event,e.id);return Ht(e)?a.reject(new be(e.error.type,e.error.message)):a.resolve(e.data);case"privy:mfa:verify":let s=Tt.dequeue(e.event,e.id);return Ht(e)?s.reject(new be(e.error.type,e.error.message)):s.resolve(e.data);case"privy:mfa:init-enrollment":{let l=Tt.dequeue(e.event,e.id);return Ht(e)?l.reject(new be(e.error.type,e.error.message)):l.resolve(e.data)}case"privy:mfa:submit-enrollment":{let l=Tt.dequeue(e.event,e.id);return Ht(e)?l.reject(new be(e.error.type,e.error.message)):l.resolve(e.data)}case"privy:mfa:unenroll":{let l=Tt.dequeue(e.event,e.id);return Ht(e)?l.reject(new be(e.error.type,e.error.message)):l.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}function rf(e){let t=O0(null),o=Kc();return D0(()=>{let r=t.current;if(!r)return;function n(c){c&&c.origin===e.origin&&F0(c.data)&&G0(c.data)}let i={create(c){return Gt("privy:wallet:create",c,r)},connect(c){return Gt("privy:wallet:connect",c,r)},recover(c){return or(u=>Gt("privy:wallet:recover",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)},rpc(c){return or(u=>Gt("privy:wallet:rpc",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o)},setRecoveryPassword(c){return or(u=>Gt("privy:wallet:set-recovery-password",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o)},verifyMfa(c){return or(u=>Gt("privy:mfa:verify",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)},initEnrollMfa(c){return or(u=>Gt("privy:mfa:init-enrollment",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o)},submitEnrollMfa(c){return Gt("privy:mfa:submit-enrollment",c,r)},unenrollMfa(c){return or(u=>Gt("privy:mfa:unenroll",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)}};window.addEventListener("message",n);let a=()=>e.onLoad(i),s=(...c)=>{console.warn("Privy iframe failed to load: ",...c),e.onLoadFailed()},l=new AbortController;return yc(()=>Gt("privy:iframe:ready",{},r),{abortSignal:l.signal}).then(a,s),()=>{window.removeEventListener("message",n),l.abort()}},[t.current,e.mfaMethods]),z0("iframe",{ref:t,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},src:si(e.origin,`/apps/${e.appId}/embedded-wallets`,{caid:e.clientAnalyticsId})})}var Ua=class{constructor(t,o){this.meta={action:t,phoneNumber:o}}async init(){if(!this.meta.action)throw new C("action required");if(!this.api)throw new C("Auth flow has no API instance");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new C("phone number must be set when initialzing authentication.");try{let t=Ql();await this.api.post(t,{action:this.meta.action,phoneNumber:this.meta.phoneNumber})}catch(t){throw te(t)}}async authenticate(){if(!this.meta.action)throw new C("action required");if(!this.api)throw new C("Mfa flow has no API instance");if(!this.meta.smsCode)throw new C("sms code must be set prior to calling authenticate.");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new C("phone number must be set prior to calling authenticate.");try{let t=Zl(),o=await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return gt(o)}catch(t){throw te(t)}}};import{jsx as Lo,jsxs as nf}from"react/jsx-runtime";var qn;function q0(e){return typeof e=="string"&&e.length===25}function ke(){if(!qn){let e=Z.get(ar);return Promise.resolve(e||null)}return qn.getAccessToken()}var af,Ec=(e,t)=>af(e,t),sf,Pc=(e,t)=>sf(e,t),lf,xc=()=>lf(),K0=()=>{let t=new URLSearchParams(window.location.search).get("privy_token");if(!t)return;Z.put(Qr,t);let o=new URL(window.location.href);o.searchParams.delete("privy_token"),window.history.pushState({},"",o)},Y0=({config:e,...t})=>{if(!q0(t.appId))throw new C("Cannot initialize the Privy provider with an invalid Privy app ID");qn||(qn=new sn({appId:t.appId,apiUrl:t.apiUrl||ri}));let o=Object.assign({},e);return t.createPrivyWalletOnLogin!==void 0&&o.embeddedWallets?.createOnLogin===void 0&&(o.embeddedWallets||(o.embeddedWallets={}),o.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."),Lo(J0,{...t,config:o,client:qn})},J0=e=>{let t=e.client,[o,r]=ue(!1),[n,i]=ue(!1),[a,s]=ue(!1),[l,c]=ue(null),[u,y]=ue(!1),[w,m]=ue([]),E=jn(w),[b,x]=ue(!1),[v,R]=ue(null),[L,M]=ue(!1),[W,k]=ue({status:"disconnected",connectError:null,connector:null,connectRetry:P}),[I,O]=ue(null),[V,F]=ue(null),[_,Q]=ue(null),[re,me]=ue({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:""}),[N,Le]=ue(()=>{let p=of(e.config,e.createPrivyWalletOnLogin);return t.createAnalyticsEvent("sdk_initialize",p),Oa(re,e.config)}),[st,se]=ue(!0),[Se,ee]=ue({}),[le,rr]=ue(null),[J,io]=ue(null),[Vt,No]=ue(!1),Oo=jn(null),Kn=jn(null),ie=jn(jc),Do=jn(),ge=p=>{R(p),r(!0),t.createAnalyticsEvent("modal_open",{initialScreen:p})},Ne=p=>{N.embeddedWallets.createOnLogin!=="off"&&se(!0),ge(p)};zt(()=>{if(!_||!l){t.connectors?.removeEmbeddedWalletConnector();return}let p=l?.linkedAccounts.filter(d=>d.type==="wallet"&&d.walletClient==="privy");if(p&&p.length>0){let d=p[0].address;t.connectors?.addEmbeddedWalletConnector(_,d,N.defaultChain)}},[_,l]),zt(()=>{_&&J?.(_)},[_]),zt(()=>{(async()=>{if(!N.customAuth?.enabled)return;se(!0);let{getCustomAccessToken:d,isLoading:h}=N.customAuth;if(!(!n||h))try{let g=await d();if(!g){await Kr.logout();return}if(a)return;t.startAuthFlow(new ir(g));let{user:D,isNewUser:X}=await t.authenticate();D||await Kr.logout(),c(D||null),x(X||!1),s(!0),No(!0)}catch(g){console.warn(g),a&&await Kr.logout()}})()},[N.customAuth?.enabled,N.customAuth?.getCustomAccessToken,N.customAuth?.isLoading,n,a]),zt(()=>{Vt&&_&&l&&co(l,e.config?.embeddedWallets?.createOnLogin)&&(No(!1),xl(l,sr).catch(console.error))},[Vt&&_&&l]),zt(()=>{async function p(){let d=await t.getServerConfig();me(d);let h=Oa(d,e.config);Le(h),d.customApiUrl&&t.updateApiUrl(d.customApiUrl);let g=$0();O(g),t.initializeConnectorManager(h.walletConnectCloudProjectId,h.rpcConfig,h.chains,h.defaultChain,g),t.connectors?.initialize();let D=Ba();K0();let X=await t.getAuthenticatedUser();e.config?.customAuth?.enabled||(s(!!X),X&&de(ie,"login","onComplete",X,!1,!0,null),c(X)),D||ve.setReadyToTrue(),D&&X&&y(!0),jr()}n||p()},[t,le,n]),zt(()=>{let p=Oa(re,e.config);Le(p)},[e.config,re]);let Ba=()=>{let p=new URLSearchParams(window.location.search),d=p.get("privy_oauth_code"),h=p.get("privy_oauth_state"),g=p.get("privy_oauth_provider");return d&&h&&g?(t.startAuthFlow(new lo(g,d,h)),Ne("AWAITING_OAUTH_SCREEN"),!0):!1},Uo=async(p,d,h)=>{let g=await t.connectors?.createWalletConnector(p,d)||null;Fo(g,d,h)};async function Fo(p,d,h){if(!p)return k({status:"disconnected",connectError:new H("Unable to connect to wallet."),connector:null,connectRetry:P}),h?.(null);p instanceof It&&d&&p.resetConnection(d),k({connector:p,status:"connecting",connectError:null,connectRetry:()=>Fo(p,d,h)});try{let g=await p.connect({showPrompt:!0});if(N.shouldSwitchChainOnConnect&&!N.chains.find(D=>D.id===Number(g?.chainId))&&!(g?.connectorType==="wallet_connect_v2"&&g?.walletClientType==="metamask")){k(D=>({...D,connector:p,status:"switching_to_supported_chain",connectError:null,connectRetry:P}));try{await g?.switchChain(N.defaultChain.id),g&&(g.chainId=lr(Vo(N.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${N.defaultChain.id}`)}}return k(D=>({...D,status:"connected",connectError:null,connectRetry:P})),g&&!L&&de(ie,"connectWallet","onSuccess",g),h?.(g)}catch(g){return g instanceof Ye?(console.warn(g.cause?g.cause:g.message),L||de(ie,"connectWallet","onError",g.privyErrorCode||"generic_connect_wallet_error")):(console.warn(g),L||de(ie,"connectWallet","onError","unknown_connect_wallet_error")),k(D=>({...D,status:"disconnected",connectError:g})),h?.(null)}}let $r=p=>{p!==null&&t.startAuthFlow(new Go(p))},jr=()=>{let p=new URLSearchParams(window.location.search),d=p.get("privy_connector"),h=p.get("privy_wallet_client");if(!d||!h)return;if(h==="phantom"&&!_t()&&Ne("LOGIN_FAILED_SCREEN"),!t.connectors)throw new C("Connector not initialized");ge("AWAITING_CONNECTION");let g=new URL(window.location.href);g.searchParams.delete("privy_connector"),g.searchParams.delete("privy_wallet_client"),window.history.pushState({},"",g),Uo(d,h,$r)};zt(()=>{n&&a&&l===null&&t.getAuthenticatedUser().then(c)},[n,a,l,t]);let Bo=()=>{if(!a)throw new C("User must be authenticated before linking a wallet.");y(!0),ge("LINK_WALLET_SCREEN")},ze=p=>{if(!a||!l)return!1;for(let d of l.linkedAccounts)if(d.type==="wallet"&&d.address===p.address)return!0;return!1},Ke=async p=>{if(!t.connectors)throw new C("Connector not initialized");let d=t.connectors.findWalletConnector(p.connectorType,p.walletClientType)||null;k(h=>({...h,connector:d,status:"connected",connectError:null,connectRetry:P})),$r(p),Ne("AWAITING_CONNECTION")},lt=async(p,d)=>{Do.current="siwe",await Fo(p,d,$r)},Ha=async(p,d)=>{if(!N.fiatOnRamp.enabled)throw new C("Fiat on-ramp is not enabled");if(!d||!d.provider||d.provider==="moonpay"){let{signedUrl:h,externalTransactionId:g}=await xp(t,p,d?.config??{},N.appearance.palette,N.fiatOnRamp.useSandbox);return{signedUrl:h,externalTransactionId:g}}else throw new C("Unsupported fund provider. Currently supported option is `moonpay`.")},Ve=()=>{m(p=>{let d=t.connectors?.wallets.map(h=>({...h,linked:ze(h),loginOrLink:async()=>{if(!await h.isConnected())throw new C("Wallet is not connected");if(h.connectorType==="embedded"&&h.walletClientType==="privy")throw new C("Cannot link or login with embedded wallet");Ke(h)},fund:async g=>{let{signedUrl:D,externalTransactionId:X}=await Ha(h.address,g);ee({fiatOnRampPrompt:{signedUrl:D},fiatOnRampStatus:{externalTransactionId:X}}),ge("FIAT_ON_RAMP_PROMPT_SCREEN")},unlink:async()=>{if(!a)throw new C("User is not authenticated.");if(h.connectorType==="embedded"&&h.walletClientType==="privy")throw new C("Cannot unlink an embedded wallet");let g=await t.unlinkWallet(h.address);c(g)}}))||[];return ci(p,d)?p:d})};zt(()=>{Ve()},[l?.linkedAccounts,a,n]),zt(()=>{if(n){if(!t.connectors)throw new C("Connector not initialized");Ve(),t.connectors.on("walletsUpdated",Ve)}},[n]);let qr=()=>{ge(a?"CONNECT_ONLY_AUTHENTICATED_SCREEN":"CONNECT_ONLY_LANDING_SCREEN")};zt(()=>{if(!w[0])return;let p=w[0],d=E.current.find(g=>g.address===p.address),h=l?.linkedAccounts.find(g=>g.type==="wallet"&&g.address===p.address);if(!d&&h){let g=Object.assign({},l);g.wallet=h&&{address:h.address,chainType:h.chainType,chainId:h.chainId,walletClient:h.walletClient,walletClientType:h.walletClientType,connectorType:h.connectorType},c(g)}E.current=w},[w]);let xl=async(p,d)=>{if(ne(p))throw de(ie,"createWallet","onError","embedded_wallet_already_exists"),new Error("Only one Privy wallet per user is currently allowed");let[g,D]=await Promise.all([ve.initializeWalletProxy(d),ke()]);if(!g&&e.config?.customAuth?.enabled)throw de(ie,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to connect to wallet proxy");if(!g||!D||e.config?.embeddedWallets?.requireUserPasswordOnCreate)return new Promise((X,_e)=>{se(!0),ee({createWallet:{onSuccess:ct=>{de(ie,"createWallet","onSuccess",ct),X(ct)},onFailure:ct=>{de(ie,"createWallet","onError","unknown_embedded_wallet_error"),_e(ct)},callAuthOnSuccessOnClose:!1}}),ge("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")});{await g.create({accessToken:D});let X=await ve.refreshUser(),_e=ne(X);if(!_e)throw de(ie,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");return de(ie,"createWallet","onSuccess",_e),_e}},df=p=>{if(!N.chains.map(d=>d.id).includes(p))throw new H(`Chain ID ${p} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,"unsupported_chain_id")},Tl=(p,d,h)=>new Promise(async(g,D)=>{if(!a||!l){D(new Error("User must be authenticated before signing with a Privy wallet"));return}let X=ne(l);if(!X){D(new Error("Must have a Privy wallet before signing"));return}se(!0);let _e=t.connectors?.findWalletConnector("embedded","privy")?.proxyProvider,nr=p.chainId?Number(p.chainId):_e.chainId;df(nr);let ct=Object.assign({},p,{chainId:nr}),Yr=async()=>{let ao=await ke();if(!ao||!_){D(new Error("Must have valid access token and Privy wallet to send transaction"));return}try{if(!await ve.recoverEmbeddedWallet()){D(new Error("Unable to connect to wallet"));return}let _l=new V0(vt(ct.chainId,N.chains,N.rpcConfig)),uf=await Gr(X.address,ct,_l),mf=await ka(ao,X.address,_,uf,_l);g(mf)}catch(Yn){D(Yn)}};if(N.embeddedWallets.noPromptOnSignature)d&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config"),Yr();else{let ao={transactionRequest:ct,onSuccess:g,onFailure:D,uiOptions:d||{},fundWalletConfig:h},Yn={onCompleteNavigateTo:"EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN",onFailure:D};ee({connectWallet:Yn,sendTransaction:ao}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}});function Sl(){return new Promise(async(p,d)=>{let h=await ke();if(!h||!_)throw new Error("Must have valid access token to enroll in MFA");try{await _.verifyMfa({accessToken:h}),p()}catch(g){d(g)}})}let Kr={ready:n,authenticated:a,user:l,walletConnectors:t.connectors||null,connectWallet:qr,linkWallet:Bo,linkEmail:()=>{if(!a)throw new C("User must be authenticated before linking an email address.");if(l?.email)throw new C("User already has an email linked to their account.");y(!0),ge("LINK_EMAIL_SCREEN")},linkPhone:()=>{if(!a)throw new C("User must be authenticated before linking a phone number.");if(l?.phone)throw new C("User already has a phone number linked to their account.");y(!0),ge("LINK_PHONE_SCREEN")},linkGoogle:async()=>{if(!a)throw new C("User must be authenticated before linking a Google account.");if(l?.google)throw new C("User already has a Google account linked to their account.");await ve.initLoginWithOAuth("google")},linkTwitter:async()=>{if(!a)throw new C("User must be authenticated before linking a Twitter account.");if(l?.twitter)throw new C("User already has a Twitter account linked to their account.");await ve.initLoginWithOAuth("twitter")},linkDiscord:async()=>{if(!a)throw new C("User must be authenticated before linking a Discord account.");if(l?.discord)throw new C("User already has a Discord account linked to their account.");await ve.initLoginWithOAuth("discord")},linkGithub:async()=>{if(!a)throw new C("User must be authenticated before linking a GitHub account.");if(l?.github)throw new C("User already has a Github account linked to their account.");await ve.initLoginWithOAuth("github")},linkTiktok:async()=>{if(!a)throw new C("User must be authenticated before linking a TikTok account.");if(l?.tiktok)throw new C("User already has a Tiktok account linked to their account.");await ve.initLoginWithOAuth("tiktok")},linkLinkedIn:async()=>{if(!a)throw new C("User must be authenticated before linking a LinkedIn account.");if(l?.linkedin)throw new C("User already has a LinkedIn account linked to their account.");await ve.initLoginWithOAuth("linkedin")},linkApple:async()=>{if(!a)throw new C("User must be authenticated before linking an Apple account.");await ve.initLoginWithOAuth("apple")},login:async()=>{if(n||(await new Promise(p=>{rr(()=>p)}),rr(null)),a){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}M(!0),Ne("LANDING")},logout:async()=>{await t.logout(),c(null),s(!1),R(null),de(ie,"logout","onSuccess"),y(!1),r(!1),Z.del(Zr)},getAccessToken:()=>t.getAccessToken(),getEthereumProvider:()=>{if(!l||!l.wallet)return new oe;let p=w.find(h=>l.wallet&&h.address===l.wallet.address),d=t.connectors?.walletConnectors.find(h=>h.wallets.find(g=>g.address===p?.address));return!p||!d?new oe:d.proxyProvider},getEthersProvider:()=>{if(!l||!l.wallet)return new Pl(new At(new oe));let p=w.find(h=>l.wallet&&h.address===l.wallet.address),d=t.connectors?.walletConnectors.find(h=>h.wallets.find(g=>g.address===p?.address));return!p||!d?new Pl(new At(new oe)):new Pl(new At(d.proxyProvider))},getWeb3jsProvider:()=>{if(!l||!l.wallet)return new mo(new oe);let p=w.find(h=>l.wallet&&h.address===l.wallet.address),d=t.connectors?.walletConnectors.find(h=>h.wallets.find(g=>g.address===p?.address));return!p||!d?new mo(new oe):new mo(d.proxyProvider)},unlinkWallet:async p=>{let d=await t.unlinkWallet(p);return c(d),d},unlinkEmail:async p=>{let d=await t.unlinkEmail(p);return c(d),d},unlinkPhone:async p=>{let d=await t.unlinkPhone(p);return c(d),d},unlinkGoogle:async p=>{let d=await t.unlinkOAuth("google",p);return c(d),d},unlinkTwitter:async p=>{let d=await t.unlinkOAuth("twitter",p);return c(d),d},unlinkDiscord:async p=>{let d=await t.unlinkOAuth("discord",p);return c(d),d},unlinkGithub:async p=>{let d=await t.unlinkOAuth("github",p);return c(d),d},unlinkTiktok:async p=>{let d=await t.unlinkOAuth("tiktok",p);return c(d),d},unlinkLinkedIn:async p=>{let d=await t.unlinkOAuth("linkedin",p);return c(d),d},unlinkApple:async p=>{let d=await t.unlinkOAuth("apple",p);return c(d),d},setActiveWallet:async p=>{let d=w.find(g=>Fa(g.address)===Fa(p)),h=l?.linkedAccounts.find(g=>g.type==="wallet"&&Fa(g.address)===Fa(p));if(!d||!await d.isConnected())F(p),Bo();else if(!d.linked)d.loginOrLink();else{let g=Object.assign({},l);g.wallet=h&&{address:h.address,chainType:h.chainType,chainId:h.chainId,walletClient:h.walletClient,walletClientType:h.walletClientType,connectorType:h.connectorType},c(g)}},forkSession:()=>t.forkSession(),createWallet:async()=>{if(!a||!l)throw de(ie,"createWallet","onError","must_be_authenticated"),new Error("User must be authenticated before creating a Privy wallet");return xl(l,15e3)},setWalletPassword:()=>new Promise(async(p,d)=>{if(!a||!l){d(new Error("User must be authenticated before adding password to Privy wallet"));return}let h=ne(l);if(!h||!_){d(new Error("Must have a Privy wallet to add a password"));return}if(h.recoveryMethod==="user-passcode"){d(new Error("Cannot set password. Embedded wallet already has a password."));return}await Sl(),se(!0);let g={onSuccess:p,onFailure:d,callAuthOnSuccessOnClose:!1},D={onCompleteNavigateTo:"EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN",onFailure:d};ee({setWalletPassword:g,connectWallet:D}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}),signMessage:(p,d)=>new Promise(async(h,g)=>{if(!a||!l){g(new Error("User must be authenticated before signing with a Privy wallet"));return}let D=ne(l);if(!D){g(new Error("Must have a Privy wallet before signing"));return}if(typeof p!="string"||p.length<1){g(new Error("Message must be a non-empty string"));return}se(!0);let X=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let _e=await ke();if(!_||!_e)throw new Error("Unable to connect to wallet");if(!await ve.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent("embedded_wallet_sign_message_started",{walletAddress:D.address});let{response:ct}=await _.rpc({accessToken:_e,address:D.address,request:{method:"personal_sign",params:[p,D.address]}}),Yr=ct.data;return t.createAnalyticsEvent("embedded_wallet_sign_message_completed",{walletAddress:D.address}),Yr};if(N.embeddedWallets.noPromptOnSignature){d&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let _e=await X();h(_e)}catch(_e){g(_e??new Oe("Unable to sign message"))}}else{let ct={message:p,confirmAndSignMessage:X,onSuccess:ao=>{h(ao)},onFailure:ao=>{g(ao)},uiOptions:d||{}},Yr={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:g};ee({signMessage:ct,connectWallet:Yr}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),sendTransaction:async(p,d,h)=>{let D=await(await Tl(p,d,h)).wait();return Ra(D)},exportWallet:()=>new Promise(async(p,d)=>{if(!a||!l){d(new Error("User must be authenticated before exporting their Privy wallet"));return}if(!ne(l)){d(new Error("Must have a Privy wallet before exporting"));return}se(!0);let g={onCompleteNavigateTo:"EMBEDDED_WALLET_KEY_EXPORT_SCREEN",onFailure:d},D=await ke();if(!D||!_)throw new Error("Must have valid access token to enroll in MFA");if(!_){d(new Error("Must have a Privy wallet before exporting"));return}await _.verifyMfa({accessToken:D});let X={appId:e.appId,origin:t.apiUrl,onSuccess:p,onFailure:d};ee({keyExport:X,connectWallet:g}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}),promptMfa:Sl,async init(p){let d;switch(p){case"sms":d=new Ua("verify");break;case"totp":return;default:throw new Error(`Unsupported MFA method: ${p}`)}t.startMfaFlow(d),await d.init()},async submit(p,d){switch(p){case"totp":case"sms":Oo.current?.resolve({mfaMethod:p,mfaCode:d}),await new Promise((h,g)=>{Kn.current={resolve:h,reject:g}});break;default:throw Oo.current?.reject(new C("Unsupported MFA method")),new C(`Unsupported MFA method: ${p}`)}},cancel(){Oo.current?.reject(new C("MFA canceled"))},async initEnrollmentWithSms(p){let d=await ke();if(!d||!_)throw new Error("Must have valid access token to enroll in MFA");await _.initEnrollMfa({method:"sms",accessToken:d,phoneNumber:p.phoneNumber})},enrollInMfa(p){return new Promise((d,h)=>{if(!p){ve.closePrivyModal(),d();return}N.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."),ee({mfaEnrollmentFlow:{mfaMethods:N.mfa.methods,onSuccess:d,onFailure:h}}),ge("MFA_ENROLLMENT_FLOW_SCREEN")})},async initEnrollmentWithTotp(){let p=await ke();if(!p||!_)throw new Error("Must have valid access token to enroll in MFA");let d=await _.initEnrollMfa({method:"totp",accessToken:p});return{secret:d.secret,authUrl:d.authUrl}},async submitEnrollmentWithSms(p){let d=await ke();if(!d||!_)throw new Error("Must have valid access token to enroll in MFA");await _.submitEnrollMfa({method:"sms",accessToken:d,phoneNumber:p.phoneNumber,code:p.mfaCode});let h=await t.getAuthenticatedUser();c(h)},async submitEnrollmentWithTotp(p){let d=await ke();if(!d||!_)throw new Error("Must have valid access token to enroll in MFA");await _.submitEnrollMfa({method:"totp",accessToken:d,code:p.mfaCode});let h=await t.getAuthenticatedUser();c(h)},async unenroll(p){let d=await ke();if(!d||!_)throw new Error("Must have valid access token to remove MFA");await _.unenrollMfa({method:p,accessToken:d});let h=await t.getAuthenticatedUser();c(h)},loginWithCode(p){return ve.loginWithCode(p)},initLoginWithEmail(p,d){return ve.initLoginWithEmail(p,d)},isModalOpen:o};af=Kr.signMessage,sf=async(...p)=>{let d=await Tl(...p);return N.embeddedWallets.waitForTransactionConfirmation&&await d.wait(),d};let ve=(()=>({isNewUserThisSession:b,isLinking:u,linkingHint:V,pendingTransaction:null,walletConnectionStatus:W,mipdStore:I,connectors:t.connectors?.walletConnectors??[],rpcConfig:N.rpcConfig,chains:N.chains,showFiatPrices:N.embeddedWallets.priceDisplay.primary!=="native-token",clientAnalyticsId:t.clientAnalyticsId,nativeTokenSymbolForChainId:p=>N.chains.find(d=>d.id===Number(p))?.nativeCurrency.symbol,initializeWalletProxy:async p=>{if(_)return _;let d=new Promise(D=>{io(()=>X=>D(X))}),h=new Promise(D=>setTimeout(()=>D(null),p)),g=await Promise.race([d,h]);return io(null),g},getAuthFlow:()=>t.authFlow,getAuthMeta:()=>t.authFlow?.meta,closePrivyModal:(p={shouldCallAuthOnSuccess:!0})=>{let d=n&&a&&l;p.shouldCallAuthOnSuccess&&d?(de(ie,"login","onComplete",l,b,!1,Do.current??null),e.onSuccess?.(l,b)):L&&de(ie,"login","onError","exited_auth_flow"),F(null),M(!1),y(!1),x(!1),r(!1),setTimeout(()=>{t.authFlow=void 0},200),t.createAnalyticsEvent("modal_closed")},connectWallet:Fo,initLoginWithWallet:lt,loginWithWallet:async()=>{if(!n)throw new Jr;if(!(t.authFlow instanceof Go))throw new C("Must initialize SIWE flow first.");let p,d;if(a)p=await t.link();else try{({user:p,isNewUser:d}=await t.authenticate())}catch(h){throw de(ie,"login","onError",h.privyErrorCode||"generic_connect_wallet_error"),h}c(p||l||null),x(d||!1),s(!0)},initLoginWithOAuth:async p=>{t.startAuthFlow(new lo(p));let d=await t.authFlow.getAuthorizationUrl();d&&d.url&&window.location.assign(d.url)},loginWithOAuth:async p=>{if(!(t.authFlow instanceof lo))throw new C("Must initialize OAuth flow before calling loginWithOAuth");let d,h;if(a)d=await t.link();else try{({user:d,isNewUser:h}=await t.authenticate()),Do.current=p}catch(g){throw de(ie,"login","onError",g.privyErrorCode||"unknown_auth_error"),g}c(d),x(h||!1),s(!0)},initLoginWithEmail:async(p,d)=>{let h=new Ho(p,d);t.startAuthFlow(h);try{Do.current="email",await h.sendCodeEmail()}catch(g){throw de(ie,"login","onError",g.privyErrorCode||"unknown_auth_error"),g}},initLoginWithSms:async(p,d)=>{let h=new zo(p,d);t.startAuthFlow(h);try{Do.current="sms",await h.sendSmsCode()}catch(g){throw de(ie,"login","onError",g.privyErrorCode||"unknown_auth_error"),g}},resendEmailCode:async()=>{await t.authFlow?.sendCodeEmail()},resendSmsCode:async()=>{await t.authFlow?.sendSmsCode()},loginWithCode:async p=>{if(!n)throw new Jr;if(t.authFlow instanceof Ho)t.authFlow.meta.emailCode=p.trim();else if(t.authFlow instanceof zo)t.authFlow.meta.smsCode=p.trim();else throw new C("Must initialize a passwordless code flow first");let d,h;a?d=await t.link():{user:d,isNewUser:h}=await t.authenticate(),c(d||l||null),x(h||!1),s(!0)},refreshUser:async()=>{let p=await t.getAuthenticatedUser();return c(p),p},walletProxy:_,createAnalyticsEvent:(p,d,h)=>t.createAnalyticsEvent(p,d,h),getUsdTokenPrice:p=>t.getUsdTokenPrice(p),recoverEmbeddedWallet:async()=>new Promise(async(p,d)=>{let h=l?.linkedAccounts.find(D=>D.type==="wallet"&&D.walletClientType==="privy"),g=await ke();if(!g||!_||!h){d(new Error("Must have valid access token and Privy wallet to recover wallet"));return}se(!0);try{await _.connect({accessToken:g,address:h.address}),p(!0)}catch(D){Pr(D)&&h.recoveryMethod==="privy"?(t.createAnalyticsEvent("embedded_wallet_pinless_recovery_started",{walletAddress:h.address}),(await _.recover({address:h.address,accessToken:g})).address||d(new Error("Unable to recover wallet")),t.createAnalyticsEvent("embedded_wallet_recovery_completed",{walletAddress:h.address}),p(!0)):Pr(D)?(ee({recoverWallet:{privyWallet:h,onFailure:d,onSuccess:()=>p(!0)}}),ge("EMBEDDED_WALLET_RECOVERY_SCREEN")):d(D)}}),getFiatOnRampConfig:Ha,setReadyToTrue:()=>{i(!0),le?.()},updateWallets:()=>Ve()}))();lf=ve.recoverEmbeddedWallet;let pf=j0(()=>({wallets:w}),[w]);return Lo(we.Provider,{value:Kr,children:Lo(os.Provider,{value:ie,children:Lo(fl.Provider,{value:pf,children:nf(Up,{...N,children:[e.children,nf(ls.Provider,{value:ve,children:[Lo(Om,{theme:{...N.appearance.palette||{}}}),Lo(Rc,{appConfig:N,data:Se,setModalData:ee,setInitialScreen:R,initialScreen:v,visible:o,authenticated:a,children:Lo(Bm,{open:o})}),st&&re.id?Lo(rf,{appId:e.appId,clientAnalyticsId:t.clientAnalyticsId,origin:t.apiUrl,mfaMethods:l?.mfaMethods,mfaPromise:Oo,mfaSubmitPromise:Kn,onLoad:Q,onLoadFailed:()=>null}):null]})]})})})})};import{useContext as Q0}from"react";function Z0(e){let{login:t}=Q0(we);return Mt("login",e),{login:t}}import{useContext as X0}from"react";function eb(e){let{logout:t}=X0(we);return Mt("logout",e),{logout:t}}import{useCallback as cf}from"react";var tb=()=>{let e=Ut(),{initLoginWithEmail:t,loginWithCode:o}=G(),r=cf(async({email:i})=>{if(!i)throw new Error("Email required to send OTP code");if(e.status==="disabled")return t(i);let a=await e.waitForResult();return t(i,a)},[t,e]),n=cf(async({code:i})=>{if(e.enabled&&e.status!=="success")throw new Sn(e.error,null,"captcha_failure");return o(i)},[o,e.status]);return{sendCode:r,loginWithCode:n}};import{useContext as ob}from"react";function rb(e){let{connectWallet:t}=ob(we);return Mt("connectWallet",e),{connectWallet:t}}import{useContext as nb}from"react";function ib(e){let{createWallet:t}=nb(we);return Mt("createWallet",e),{createWallet:t}}import{useContext as ab}from"react";var sb=()=>{let{isModalOpen:e}=ab(we);return{isOpen:e}};export{At as AsExternalProvider,_n as Captcha,nn as ConnectorManager,sn as PrivyClient,Y0 as PrivyProvider,oe as PrivyProxyProvider,$n as SUPPORTED_CHAINS,za as VERSION,je as WalletConnector,Ps as errorIndicatesMaxMfaRetries,xr as errorIndicatesMfaTimeout,Tr as errorIndicatesMfaVerificationFailed,ke as getAccessToken,rb as useConnectWallet,ib as useCreateWallet,Z0 as useLogin,tb as useLoginWithEmail,eb as useLogout,Ur as useMfa,Ln as useMfaEnrollment,sb as useModalStatus,G as usePrivy,rs as useRegisterMfaListener,zn as useWallets};
|
|
2499
|
+
`;import{jsx as Ge,jsxs as Fm}from"react/jsx-runtime";var S0={["LANDING"]:tu,["AWAITING_PASSWORDLESS_CODE"]:fd,["AWAITING_CONNECTION"]:_d,["AWAITING_CONNECT_ONLY_CONNECTION"]:Id,["PHANTOM_INTERSTITIAL_SCREEN"]:Sm,["LOGIN_FAILED_SCREEN"]:lu,["AWAITING_OAUTH_SCREEN"]:Em,["ALLOWLIST_REJECTION_SCREEN"]:td,["INSTALL_PHANTOM_SCREEN"]:Mp,["LINK_EMAIL_SCREEN"]:ou,["LINK_PHONE_SCREEN"]:ru,["LINK_WALLET_SCREEN"]:nu,["CONNECT_ONLY_LANDING_SCREEN"]:xd,["CONNECT_ONLY_AUTHENTICATED_SCREEN"]:bd,["EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN"]:gp,["EMBEDDED_WALLET_CREATED_SCREEN"]:Fd,["EMBEDDED_WALLET_CONNECTING_SCREEN"]:Dd,["EMBEDDED_WALLET_RECOVERY_SCREEN"]:Cp,["EMBEDDED_WALLET_KEY_EXPORT_SCREEN"]:zd,["EMBEDDED_WALLET_SIGN_REQUEST_SCREEN"]:Lm,["EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN"]:Wm,["FIAT_ON_RAMP_PROMPT_SCREEN"]:Sp,["FIAT_ON_RAMP_STATUS_SCREEN"]:kp,["EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN"]:wp,["EMBEDDED_WALLET_PASSWORD_UPDATE_SCREEN"]:vp,["MFA_ENROLLMENT_FLOW_SCREEN"]:Nu},_0=({isMfaVerifying:e,onMfaVerificationComplete:t})=>{let{ready:o}=G(),{ready:r,currentScreen:n}=S(),i=P0(null),a=$c(i);if((!o||!r)&&n!=="AWAITING_OAUTH_SCREEN")return Fm(Or,{children:[Ge(T,{}),Ge(j,{}),Ge(gu,{children:Ge(Lt,{})}),Ge(K,{}),Ge(Y,{})]});if(!n)return null;let s=S0[n];return s?Ge(Or,{style:{height:a},children:Fm("div",{ref:i,children:[Ge(Jt,{if:!!e,children:Ge(s,{})}),Ge(Jt,{if:!e,children:Ge(gm,{open:e,onClose:t})})]})}):null},Bm=({open:e})=>{let{app:t}=S(),[o,r]=Um(!1),{gracefulClosePrivyModal:n,onEscape:i}=hu(),[a,s]=Um(!1);rs({onMfaRequired:()=>{t?.mfa.noPromptOnMfaRequired||s(!0)}}),x0(()=>{r(!0)},[]);let l=Ge(Dm,{children:Ge(_0,{isMfaVerifying:a,onMfaVerificationComplete:()=>s(!1)})}),c=e||a,u=t?.render.inDialog?Ge("div",{onKeyDown:i,children:Ge(yu,{open:c,id:"privy-dialog",onClick:()=>n(),children:l})}):l;if(o){let y=t?.render.inParentNodeId&&document.getElementById(t.render.inParentNodeId)||document.body;return T0.createPortal(u,y)}return null};var yt={appearance:{theme:"light",accentColor:"#676FFF",walletList:["detected_wallets","metamask","coinbase_wallet","rainbow","wallet_connect"]},walletConnectCloudProjectId:tc,rpcConfig:{rpcUrls:{},rpcTimeouts:{}},captchaEnabled:!1,_render:{inDialog:!0,inParentNodeId:null},fiatOnRamp:{useSandbox:!1}};var k0=new Set(["metamask","coinbase_wallet","rainbow","zerion","phantom","wallet_connect","detected_wallets"]),A0=e=>k0.has(e),R0=(e,t,o)=>o.indexOf(e)===t,Hm=({input:e})=>e?e.filter(A0).filter(R0):yt.appearance.walletList;var Gm={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 zm={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 Vm={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 $m={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 jm={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 qm={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 Km={id:5,network:"goerli",name:"Goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{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 Ym={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 Jm={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 Qm={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 Na={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 Zm={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 Xm={id:11155111,network:"sepolia",name:"Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"SEP",decimals:18},rpcUrls:{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 $n=[wa,Ca,ba,Km,Xm,Na,xa,Ta,Hn,Gn,Vm,$m,jm,qm,Ea,Pa,Jm,Qm,Gm,zm,Sa,_a,Ym,Zm],wL=new Set($n.map(e=>e.id));import tr from"tinycolor2";var ef="#FFFFFF",I0="#000000",W0=ef,M0="#1E1E1D";function L0(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 Mo(e,t){let o=Math.max(0,Math.min(1,e.toHsl().l+t));return tr({...e.toHsl(),l:o})}function tf({backgroundTheme:e,accentHex:t,successHex:o="#51BA81",warnHex:r="#FFB74D",errorHex:n="#EC6351",whiteHex:i=ef,blackHex:a=I0}){let s;switch(e){case"light":s=W0;break;case"dark":s=M0;break;default:s=e;break}let l=tr(s),c=tr(t),u=tr(o),y=tr(r),w=tr(n),m=L0(l.getLuminance()),E=Mo(l,m==="light"?-.04:.11),b=Mo(l,m==="light"?-.88:.87),x=Mo(l,m==="light"?-.77:.75),v=Mo(l,m==="light"?-.43:.45).desaturate(m==="light"?60:20),R=Mo(l,m==="light"?-.08:.25).desaturate(m==="light"?60:20),L=Mo(c,.15),M=Mo(c,-.06),W=tr(c.getLuminance()>.5?a:i),k=Mo(u,-.16);return{colorScheme:m,background:l.toHslString(),background2:E.toHslString(),foreground:b.toHslString(),foreground2:x.toHslString(),foreground3:v.toHslString(),foreground4:R.toHslString(),accent:c.toHslString(),accentLight:L.toHslString(),accentDark:M.toHslString(),foregroundAccent:W.toHslString(),success:u.toHslString(),successDark:k.toHslString(),error:w.toHslString(),warn:y.toHslString()}}function Oa(e,t){let o=["google","twitter","discord","tiktok","linkedin","github","apple"],r=t?.loginMethods?.filter(V=>o.includes(V)),n,i,a,s,l,c,u,y,w,m;t?.loginMethods?(n=t.loginMethods.includes("email"),i=t.loginMethods.includes("sms"),a=t.loginMethods.includes("wallet"),s=r?.includes("google"),l=r?.includes("twitter"),c=r?.includes("discord"),u=r?.includes("tiktok"),w=r?.includes("github"),y=r?.includes("linkedin"),m=r?.includes("apple")):(n=e.emailAuth,i=e.smsAuth,a=e.walletAuth,s=e.googleOAuth,l=e.twitterOAuth,c=e.discordOAuth,w=e.githubOAuth,u=e.tiktokOAuth,y=e.linkedinOAuth,m=e.appleOAuth);let E=[n,i].filter(Boolean),b=[s,l,c,w,u,y,m].filter(Boolean),x=[a].filter(Boolean);if(E.length+b.length+x.length===0)throw new Error("You must enable at least one login method");let v=t?.appearance?.showWalletLoginFirst!==void 0?t?.appearance?.showWalletLoginFirst:e.showWalletLoginFirst;v&&x.length===0?(console.warn("You should only enable `showWalletLoginFirst` when `wallet` logins are also enabled. `showWalletLoginFirst` has been set to false"),v=!1):!v&&b.length+E.length===0&&(console.warn("You should only disable `showWalletLoginFirst` when `email`, `sms`, or social logins are also enabled. `showWalletLoginFirst` has been set to true"),v=!0);let R=Hm({isWalletLoginEnabled:a,input:t?.appearance?.walletList});if(t?.embeddedWallets?.waitForTransactionConfirmation===!1&&t.embeddedWallets.noPromptOnSignature!==!0)throw new Error("Overriding `config.embeddedWallets.waitForTransactionConfirmation` requires that you also enable `config.embeddedWallets.noPromptOnSignature`");let L=t?.intl?.defaultCountry??"US",{chains:M,defaultChain:W}=N0(t?.additionalChains,t?.supportedChains,t?.defaultChain),k=!!t?.defaultChain||!!t?.supportedChains,I=t?.customAuth?.getCustomAccessToken&&t?.customAuth?.enabled!==!1;return{id:e.id,name:e.name,allowlistConfig:e.allowlistConfig,appearance:{logo:t?.appearance?.logo??e.logoUrl,palette:tf({backgroundTheme:t?.appearance?.theme??yt.appearance.theme,accentHex:t?.appearance?.accentColor??e.accentColor??yt.appearance.accentColor}),loginGroupPriority:v?"web3-first":"web2-first",hideDirectWeb2Inputs:!!t?.appearance?.hideDirectWeb2Inputs,walletList:R},loginMethods:{wallet:a,email:n,sms:i,google:s,twitter:l,discord:c,github:w,tiktok:u,linkedin:y,apple:m},legal:{termsAndConditionsUrl:t?.legal?.termsAndConditionsUrl??e.termsAndConditionsUrl,privacyPolicyUrl:t?.legal?.privacyPolicyUrl??e.privacyPolicyUrl},walletConnectCloudProjectId:t?.walletConnectCloudProjectId??e.walletConnectCloudProjectId??yt.walletConnectCloudProjectId,rpcConfig:{rpcUrls:t?.rpcConfig?.rpcUrls??yt.rpcConfig.rpcUrls,rpcTimeouts:t?.rpcConfig?.rpcTimeouts??yt.rpcConfig.rpcTimeouts},chains:M,defaultChain:W,intl:{defaultCountry:L},shouldSwitchChainOnConnect:k,captchaEnabled:e.captchaEnabled??yt.captchaEnabled,captchaSiteKey:e.captchaSiteKey,embeddedWallets:{...e.embeddedWalletConfig,...I?{createOnLogin:"all-users",requireUserPasswordOnCreate:!1,noPromptOnSignature:!0}:{},waitForTransactionConfirmation:!0,priceDisplay:{primary:"fiat-currency",secondary:"native-token"},...t?.embeddedWallets},mfa:{methods:e.mfaMethods??[],noPromptOnMfaRequired:t?.mfa?.noPromptOnMfaRequired??!1},customAuth:I?{enabled:!0,...t.customAuth}:void 0,fiatOnRamp:{enabled:e.fiatOnRampEnabled,useSandbox:t?.fiatOnRamp?.useSandbox??yt.fiatOnRamp.useSandbox},loginConfig:{twitterOAuthOnMobileEnabled:e.twitterOAuthOnMobileEnabled??!1},render:{inDialog:t?._render?.inDialog??yt._render.inDialog,inParentNodeId:t?._render?.inParentNodeId??yt._render.inParentNodeId}}}function of(e,t){if(!e)return{legacyCreateEmbeddedWalletFlag:t};let{appearance:o,additionalChains:r,supportedChains:n,defaultChain:i,...a}=e;return{...a,...r?{additionalChains:r.map(l=>l.id)}:void 0,...n?{supportedChains:n.map(l=>l.id)}:void 0,...i?{defaultChain:i.id}:void 0,...o?{...o,...o.logo&&typeof o.logo?{logo:"component"}:void 0}:void 0,legacyCreateEmbeddedWalletFlag:t}}function N0(e,t,o){let r;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");r=t.map(a=>$n.find(l=>l.id===a.id)??a)}else r=$n.concat(e??[]);let n=t?r[0]:Na,i=o??n;if(!r.find(a=>a.id===i.id))throw new Error("`defaultChain` must be included in `supportedChains`");return{chains:r,defaultChain:i}}import{useRef as O0,useEffect as D0}from"react";var Da=class{constructor(){this.callbacks={}}enqueue(t,o){this.callbacks[t]=o}dequeue(t,o){let r=this.callbacks[o];if(!r)throw new Error(`cannot dequeue ${t} event: no event found for id ${o}`);switch(delete this.callbacks[o],t){case"privy:iframe:ready":return r;case"privy:wallet:create":return r;case"privy:wallet:connect":return r;case"privy:wallet:recover":return r;case"privy:wallet:rpc":return r;case"privy:wallet:set-recovery-password":return r;case"privy:mfa:verify":return r;case"privy:mfa:init-enrollment":return r;case"privy:mfa:submit-enrollment":return r;case"privy:mfa:unenroll":return r;default:throw new Error(`invalid wallet event type ${t}`)}}};async function or(e,t,o,r,n,i=!1){let a=i,s=async u=>{if(a&&t&&t.length>0){u===(i?0:1)?n("configureMfa","onMfaRequired",t):r.current?.reject(new be("missing_or_invalid_mfa","MFA verification failed, retry."));let y=await new Promise((w,m)=>{o.current={resolve:w,reject:m};let E=1e3*60*5;setTimeout(()=>{let b=new be("mfa_timeout","Timed out waiting for MFA code");r.current?.reject(b),m(b)},E)});return await e(y)}return await e()},l=4,c=null;for(let u=0;u<l;u++)try{c=await s(u),r.current?.resolve(void 0);break}catch(y){if(y.type==="missing_or_invalid_mfa")a=!0;else throw r.current?.resolve(void 0),y}if(c===null){let u=new be("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw r.current?.reject(u),u}return c}import{jsx as z0}from"react/jsx-runtime";var U0=function(e){return()=>`id-${e++}`}(0);function F0(e){return typeof e.event=="string"&&/^privy:.+/.test(e.event)}function Ht(e){return e.error!==void 0}var Tt=new Da,El=new Map,B0=(e,t)=>typeof t=="bigint"?t.toString():t,H0=(e,t)=>`${e}${JSON.stringify(t,B0)}`;function Gt(e,t,o){let r=o.contentWindow;if(!r)throw new Error("iframe not initialized");let n=H0(e,t);if(e==="privy:wallet:create"){let a=El.get(n);if(a)return a}let i=new Promise((a,s)=>{let l=U0();Tt.enqueue(l,{resolve:a,reject:s}),r.postMessage({id:l,event:e,data:t},"*")}).finally(()=>{El.delete(n)});return El.set(n,i),i}function G0(e){switch(e.event){case"privy:iframe:ready":let t=Tt.dequeue(e.event,e.id);return Ht(e)?t.reject(new be(e.error.type,e.error.message)):t.resolve(e.data);case"privy:wallet:create":let o=Tt.dequeue(e.event,e.id);return Ht(e)?o.reject(new be(e.error.type,e.error.message)):o.resolve(e.data);case"privy:wallet:connect":let r=Tt.dequeue(e.event,e.id);return Ht(e)?r.reject(new be(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallet:recover":let n=Tt.dequeue(e.event,e.id);return Ht(e)?n.reject(new be(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallet:rpc":let i=Tt.dequeue(e.event,e.id);return Ht(e)?i.reject(new be(e.error.type,e.error.message)):i.resolve(e.data);case"privy:wallet:set-recovery-password":let a=Tt.dequeue(e.event,e.id);return Ht(e)?a.reject(new be(e.error.type,e.error.message)):a.resolve(e.data);case"privy:mfa:verify":let s=Tt.dequeue(e.event,e.id);return Ht(e)?s.reject(new be(e.error.type,e.error.message)):s.resolve(e.data);case"privy:mfa:init-enrollment":{let l=Tt.dequeue(e.event,e.id);return Ht(e)?l.reject(new be(e.error.type,e.error.message)):l.resolve(e.data)}case"privy:mfa:submit-enrollment":{let l=Tt.dequeue(e.event,e.id);return Ht(e)?l.reject(new be(e.error.type,e.error.message)):l.resolve(e.data)}case"privy:mfa:unenroll":{let l=Tt.dequeue(e.event,e.id);return Ht(e)?l.reject(new be(e.error.type,e.error.message)):l.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}function rf(e){let t=O0(null),o=Kc();return D0(()=>{let r=t.current;if(!r)return;function n(c){c&&c.origin===e.origin&&F0(c.data)&&G0(c.data)}let i={create(c){return Gt("privy:wallet:create",c,r)},connect(c){return Gt("privy:wallet:connect",c,r)},recover(c){return or(u=>Gt("privy:wallet:recover",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)},rpc(c){return or(u=>Gt("privy:wallet:rpc",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o)},setRecoveryPassword(c){return or(u=>Gt("privy:wallet:set-recovery-password",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o)},verifyMfa(c){return or(u=>Gt("privy:mfa:verify",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)},initEnrollMfa(c){return or(u=>Gt("privy:mfa:init-enrollment",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o)},submitEnrollMfa(c){return Gt("privy:mfa:submit-enrollment",c,r)},unenrollMfa(c){return or(u=>Gt("privy:mfa:unenroll",{...c,...u},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)}};window.addEventListener("message",n);let a=()=>e.onLoad(i),s=(...c)=>{console.warn("Privy iframe failed to load: ",...c),e.onLoadFailed()},l=new AbortController;return yc(()=>Gt("privy:iframe:ready",{},r),{abortSignal:l.signal}).then(a,s),()=>{window.removeEventListener("message",n),l.abort()}},[t.current,e.mfaMethods]),z0("iframe",{ref:t,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},src:si(e.origin,`/apps/${e.appId}/embedded-wallets`,{caid:e.clientAnalyticsId})})}var Ua=class{constructor(t,o){this.meta={action:t,phoneNumber:o}}async init(){if(!this.meta.action)throw new C("action required");if(!this.api)throw new C("Auth flow has no API instance");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new C("phone number must be set when initialzing authentication.");try{let t=Ql();await this.api.post(t,{action:this.meta.action,phoneNumber:this.meta.phoneNumber})}catch(t){throw te(t)}}async authenticate(){if(!this.meta.action)throw new C("action required");if(!this.api)throw new C("Mfa flow has no API instance");if(!this.meta.smsCode)throw new C("sms code must be set prior to calling authenticate.");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new C("phone number must be set prior to calling authenticate.");try{let t=Zl(),o=await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return gt(o)}catch(t){throw te(t)}}};import{jsx as Lo,jsxs as nf}from"react/jsx-runtime";var qn;function q0(e){return typeof e=="string"&&e.length===25}function ke(){if(!qn){let e=Z.get(ar);return Promise.resolve(e||null)}return qn.getAccessToken()}var af,Ec=(e,t)=>af(e,t),sf,Pc=(e,t)=>sf(e,t),lf,xc=()=>lf(),K0=()=>{let t=new URLSearchParams(window.location.search).get("privy_token");if(!t)return;Z.put(Qr,t);let o=new URL(window.location.href);o.searchParams.delete("privy_token"),window.history.pushState({},"",o)},Y0=({config:e,...t})=>{if(!q0(t.appId))throw new C("Cannot initialize the Privy provider with an invalid Privy app ID");qn||(qn=new sn({appId:t.appId,apiUrl:t.apiUrl||ri}));let o=Object.assign({},e);return t.createPrivyWalletOnLogin!==void 0&&o.embeddedWallets?.createOnLogin===void 0&&(o.embeddedWallets||(o.embeddedWallets={}),o.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."),Lo(J0,{...t,config:o,client:qn})},J0=e=>{let t=e.client,[o,r]=ue(!1),[n,i]=ue(!1),[a,s]=ue(!1),[l,c]=ue(null),[u,y]=ue(!1),[w,m]=ue([]),E=jn(w),[b,x]=ue(!1),[v,R]=ue(null),[L,M]=ue(!1),[W,k]=ue({status:"disconnected",connectError:null,connector:null,connectRetry:P}),[I,O]=ue(null),[V,F]=ue(null),[_,Q]=ue(null),[re,me]=ue({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:""}),[N,Le]=ue(()=>{let p=of(e.config,e.createPrivyWalletOnLogin);return t.createAnalyticsEvent("sdk_initialize",p),Oa(re,e.config)}),[st,se]=ue(!0),[Se,ee]=ue({}),[le,rr]=ue(null),[J,io]=ue(null),[Vt,No]=ue(!1),Oo=jn(null),Kn=jn(null),ie=jn(jc),Do=jn(),ge=p=>{R(p),setTimeout(()=>{r(!0)},15),t.createAnalyticsEvent("modal_open",{initialScreen:p})},Ne=p=>{N.embeddedWallets.createOnLogin!=="off"&&se(!0),ge(p)};zt(()=>{if(!_||!l){t.connectors?.removeEmbeddedWalletConnector();return}let p=l?.linkedAccounts.filter(d=>d.type==="wallet"&&d.walletClient==="privy");if(p&&p.length>0){let d=p[0].address;t.connectors?.addEmbeddedWalletConnector(_,d,N.defaultChain)}},[_,l]),zt(()=>{_&&J?.(_)},[_]),zt(()=>{(async()=>{if(!N.customAuth?.enabled)return;se(!0);let{getCustomAccessToken:d,isLoading:h}=N.customAuth;if(!(!n||h))try{let g=await d();if(!g){await Kr.logout();return}if(a)return;t.startAuthFlow(new ir(g));let{user:D,isNewUser:X}=await t.authenticate();D||await Kr.logout(),c(D||null),x(X||!1),s(!0),No(!0)}catch(g){console.warn(g),a&&await Kr.logout()}})()},[N.customAuth?.enabled,N.customAuth?.getCustomAccessToken,N.customAuth?.isLoading,n,a]),zt(()=>{Vt&&_&&l&&co(l,e.config?.embeddedWallets?.createOnLogin)&&(No(!1),xl(l,sr).catch(console.error))},[Vt&&_&&l]),zt(()=>{async function p(){let d=await t.getServerConfig();me(d);let h=Oa(d,e.config);Le(h),d.customApiUrl&&t.updateApiUrl(d.customApiUrl);let g=$0();O(g),t.initializeConnectorManager(h.walletConnectCloudProjectId,h.rpcConfig,h.chains,h.defaultChain,g),t.connectors?.initialize();let D=Ba();K0();let X=await t.getAuthenticatedUser();e.config?.customAuth?.enabled||(s(!!X),X&&de(ie,"login","onComplete",X,!1,!0,null),c(X)),D||ve.setReadyToTrue(),D&&X&&y(!0),jr()}n||p()},[t,le,n]),zt(()=>{let p=Oa(re,e.config);Le(p)},[e.config,re]);let Ba=()=>{let p=new URLSearchParams(window.location.search),d=p.get("privy_oauth_code"),h=p.get("privy_oauth_state"),g=p.get("privy_oauth_provider");return d&&h&&g?(t.startAuthFlow(new lo(g,d,h)),Ne("AWAITING_OAUTH_SCREEN"),!0):!1},Uo=async(p,d,h)=>{let g=await t.connectors?.createWalletConnector(p,d)||null;Fo(g,d,h)};async function Fo(p,d,h){if(!p)return k({status:"disconnected",connectError:new H("Unable to connect to wallet."),connector:null,connectRetry:P}),h?.(null);p instanceof It&&d&&p.resetConnection(d),k({connector:p,status:"connecting",connectError:null,connectRetry:()=>Fo(p,d,h)});try{let g=await p.connect({showPrompt:!0});if(N.shouldSwitchChainOnConnect&&!N.chains.find(D=>D.id===Number(g?.chainId))&&!(g?.connectorType==="wallet_connect_v2"&&g?.walletClientType==="metamask")){k(D=>({...D,connector:p,status:"switching_to_supported_chain",connectError:null,connectRetry:P}));try{await g?.switchChain(N.defaultChain.id),g&&(g.chainId=lr(Vo(N.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${N.defaultChain.id}`)}}return k(D=>({...D,status:"connected",connectError:null,connectRetry:P})),g&&!L&&de(ie,"connectWallet","onSuccess",g),h?.(g)}catch(g){return g instanceof Ye?(console.warn(g.cause?g.cause:g.message),L||de(ie,"connectWallet","onError",g.privyErrorCode||"generic_connect_wallet_error")):(console.warn(g),L||de(ie,"connectWallet","onError","unknown_connect_wallet_error")),k(D=>({...D,status:"disconnected",connectError:g})),h?.(null)}}let $r=p=>{p!==null&&t.startAuthFlow(new Go(p))},jr=()=>{let p=new URLSearchParams(window.location.search),d=p.get("privy_connector"),h=p.get("privy_wallet_client");if(!d||!h)return;if(h==="phantom"&&!_t()&&Ne("LOGIN_FAILED_SCREEN"),!t.connectors)throw new C("Connector not initialized");ge("AWAITING_CONNECTION");let g=new URL(window.location.href);g.searchParams.delete("privy_connector"),g.searchParams.delete("privy_wallet_client"),window.history.pushState({},"",g),Uo(d,h,$r)};zt(()=>{n&&a&&l===null&&t.getAuthenticatedUser().then(c)},[n,a,l,t]);let Bo=()=>{if(!a)throw new C("User must be authenticated before linking a wallet.");y(!0),ge("LINK_WALLET_SCREEN")},ze=p=>{if(!a||!l)return!1;for(let d of l.linkedAccounts)if(d.type==="wallet"&&d.address===p.address)return!0;return!1},Ke=async p=>{if(!t.connectors)throw new C("Connector not initialized");let d=t.connectors.findWalletConnector(p.connectorType,p.walletClientType)||null;k(h=>({...h,connector:d,status:"connected",connectError:null,connectRetry:P})),$r(p),Ne("AWAITING_CONNECTION")},lt=async(p,d)=>{Do.current="siwe",await Fo(p,d,$r)},Ha=async(p,d)=>{if(!N.fiatOnRamp.enabled)throw new C("Fiat on-ramp is not enabled");if(!d||!d.provider||d.provider==="moonpay"){let{signedUrl:h,externalTransactionId:g}=await xp(t,p,d?.config??{},N.appearance.palette,N.fiatOnRamp.useSandbox);return{signedUrl:h,externalTransactionId:g}}else throw new C("Unsupported fund provider. Currently supported option is `moonpay`.")},Ve=()=>{m(p=>{let d=t.connectors?.wallets.map(h=>({...h,linked:ze(h),loginOrLink:async()=>{if(!await h.isConnected())throw new C("Wallet is not connected");if(h.connectorType==="embedded"&&h.walletClientType==="privy")throw new C("Cannot link or login with embedded wallet");Ke(h)},fund:async g=>{let{signedUrl:D,externalTransactionId:X}=await Ha(h.address,g);ee({fiatOnRampPrompt:{signedUrl:D},fiatOnRampStatus:{externalTransactionId:X}}),ge("FIAT_ON_RAMP_PROMPT_SCREEN")},unlink:async()=>{if(!a)throw new C("User is not authenticated.");if(h.connectorType==="embedded"&&h.walletClientType==="privy")throw new C("Cannot unlink an embedded wallet");let g=await t.unlinkWallet(h.address);c(g)}}))||[];return ci(p,d)?p:d})};zt(()=>{Ve()},[l?.linkedAccounts,a,n]),zt(()=>{if(n){if(!t.connectors)throw new C("Connector not initialized");Ve(),t.connectors.on("walletsUpdated",Ve)}},[n]);let qr=()=>{ge(a?"CONNECT_ONLY_AUTHENTICATED_SCREEN":"CONNECT_ONLY_LANDING_SCREEN")};zt(()=>{if(!w[0])return;let p=w[0],d=E.current.find(g=>g.address===p.address),h=l?.linkedAccounts.find(g=>g.type==="wallet"&&g.address===p.address);if(!d&&h){let g=Object.assign({},l);g.wallet=h&&{address:h.address,chainType:h.chainType,chainId:h.chainId,walletClient:h.walletClient,walletClientType:h.walletClientType,connectorType:h.connectorType},c(g)}E.current=w},[w]);let xl=async(p,d)=>{if(ne(p))throw de(ie,"createWallet","onError","embedded_wallet_already_exists"),new Error("Only one Privy wallet per user is currently allowed");let[g,D]=await Promise.all([ve.initializeWalletProxy(d),ke()]);if(!g&&e.config?.customAuth?.enabled)throw de(ie,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to connect to wallet proxy");if(!g||!D||e.config?.embeddedWallets?.requireUserPasswordOnCreate)return new Promise((X,_e)=>{se(!0),ee({createWallet:{onSuccess:ct=>{de(ie,"createWallet","onSuccess",ct),X(ct)},onFailure:ct=>{de(ie,"createWallet","onError","unknown_embedded_wallet_error"),_e(ct)},callAuthOnSuccessOnClose:!1}}),ge("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")});{await g.create({accessToken:D});let X=await ve.refreshUser(),_e=ne(X);if(!_e)throw de(ie,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");return de(ie,"createWallet","onSuccess",_e),_e}},df=p=>{if(!N.chains.map(d=>d.id).includes(p))throw new H(`Chain ID ${p} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,"unsupported_chain_id")},Tl=(p,d,h)=>new Promise(async(g,D)=>{if(!a||!l){D(new Error("User must be authenticated before signing with a Privy wallet"));return}let X=ne(l);if(!X){D(new Error("Must have a Privy wallet before signing"));return}se(!0);let _e=t.connectors?.findWalletConnector("embedded","privy")?.proxyProvider,nr=p.chainId?Number(p.chainId):_e.chainId;df(nr);let ct=Object.assign({},p,{chainId:nr}),Yr=async()=>{let ao=await ke();if(!ao||!_){D(new Error("Must have valid access token and Privy wallet to send transaction"));return}try{if(!await ve.recoverEmbeddedWallet()){D(new Error("Unable to connect to wallet"));return}let _l=new V0(vt(ct.chainId,N.chains,N.rpcConfig)),uf=await Gr(X.address,ct,_l),mf=await ka(ao,X.address,_,uf,_l);g(mf)}catch(Yn){D(Yn)}};if(N.embeddedWallets.noPromptOnSignature)d&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config"),Yr();else{let ao={transactionRequest:ct,onSuccess:g,onFailure:D,uiOptions:d||{},fundWalletConfig:h},Yn={onCompleteNavigateTo:"EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN",onFailure:D};ee({connectWallet:Yn,sendTransaction:ao}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}});function Sl(){return new Promise(async(p,d)=>{let h=await ke();if(!h||!_)throw new Error("Must have valid access token to enroll in MFA");try{await _.verifyMfa({accessToken:h}),p()}catch(g){d(g)}})}let Kr={ready:n,authenticated:a,user:l,walletConnectors:t.connectors||null,connectWallet:qr,linkWallet:Bo,linkEmail:()=>{if(!a)throw new C("User must be authenticated before linking an email address.");if(l?.email)throw new C("User already has an email linked to their account.");y(!0),ge("LINK_EMAIL_SCREEN")},linkPhone:()=>{if(!a)throw new C("User must be authenticated before linking a phone number.");if(l?.phone)throw new C("User already has a phone number linked to their account.");y(!0),ge("LINK_PHONE_SCREEN")},linkGoogle:async()=>{if(!a)throw new C("User must be authenticated before linking a Google account.");if(l?.google)throw new C("User already has a Google account linked to their account.");await ve.initLoginWithOAuth("google")},linkTwitter:async()=>{if(!a)throw new C("User must be authenticated before linking a Twitter account.");if(l?.twitter)throw new C("User already has a Twitter account linked to their account.");await ve.initLoginWithOAuth("twitter")},linkDiscord:async()=>{if(!a)throw new C("User must be authenticated before linking a Discord account.");if(l?.discord)throw new C("User already has a Discord account linked to their account.");await ve.initLoginWithOAuth("discord")},linkGithub:async()=>{if(!a)throw new C("User must be authenticated before linking a GitHub account.");if(l?.github)throw new C("User already has a Github account linked to their account.");await ve.initLoginWithOAuth("github")},linkTiktok:async()=>{if(!a)throw new C("User must be authenticated before linking a TikTok account.");if(l?.tiktok)throw new C("User already has a Tiktok account linked to their account.");await ve.initLoginWithOAuth("tiktok")},linkLinkedIn:async()=>{if(!a)throw new C("User must be authenticated before linking a LinkedIn account.");if(l?.linkedin)throw new C("User already has a LinkedIn account linked to their account.");await ve.initLoginWithOAuth("linkedin")},linkApple:async()=>{if(!a)throw new C("User must be authenticated before linking an Apple account.");await ve.initLoginWithOAuth("apple")},login:async()=>{if(n||(await new Promise(p=>{rr(()=>p)}),rr(null)),a){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}M(!0),Ne("LANDING")},logout:async()=>{await t.logout(),c(null),s(!1),R(null),de(ie,"logout","onSuccess"),y(!1),r(!1),Z.del(Zr)},getAccessToken:()=>t.getAccessToken(),getEthereumProvider:()=>{if(!l||!l.wallet)return new oe;let p=w.find(h=>l.wallet&&h.address===l.wallet.address),d=t.connectors?.walletConnectors.find(h=>h.wallets.find(g=>g.address===p?.address));return!p||!d?new oe:d.proxyProvider},getEthersProvider:()=>{if(!l||!l.wallet)return new Pl(new At(new oe));let p=w.find(h=>l.wallet&&h.address===l.wallet.address),d=t.connectors?.walletConnectors.find(h=>h.wallets.find(g=>g.address===p?.address));return!p||!d?new Pl(new At(new oe)):new Pl(new At(d.proxyProvider))},getWeb3jsProvider:()=>{if(!l||!l.wallet)return new mo(new oe);let p=w.find(h=>l.wallet&&h.address===l.wallet.address),d=t.connectors?.walletConnectors.find(h=>h.wallets.find(g=>g.address===p?.address));return!p||!d?new mo(new oe):new mo(d.proxyProvider)},unlinkWallet:async p=>{let d=await t.unlinkWallet(p);return c(d),d},unlinkEmail:async p=>{let d=await t.unlinkEmail(p);return c(d),d},unlinkPhone:async p=>{let d=await t.unlinkPhone(p);return c(d),d},unlinkGoogle:async p=>{let d=await t.unlinkOAuth("google",p);return c(d),d},unlinkTwitter:async p=>{let d=await t.unlinkOAuth("twitter",p);return c(d),d},unlinkDiscord:async p=>{let d=await t.unlinkOAuth("discord",p);return c(d),d},unlinkGithub:async p=>{let d=await t.unlinkOAuth("github",p);return c(d),d},unlinkTiktok:async p=>{let d=await t.unlinkOAuth("tiktok",p);return c(d),d},unlinkLinkedIn:async p=>{let d=await t.unlinkOAuth("linkedin",p);return c(d),d},unlinkApple:async p=>{let d=await t.unlinkOAuth("apple",p);return c(d),d},setActiveWallet:async p=>{let d=w.find(g=>Fa(g.address)===Fa(p)),h=l?.linkedAccounts.find(g=>g.type==="wallet"&&Fa(g.address)===Fa(p));if(!d||!await d.isConnected())F(p),Bo();else if(!d.linked)d.loginOrLink();else{let g=Object.assign({},l);g.wallet=h&&{address:h.address,chainType:h.chainType,chainId:h.chainId,walletClient:h.walletClient,walletClientType:h.walletClientType,connectorType:h.connectorType},c(g)}},forkSession:()=>t.forkSession(),createWallet:async()=>{if(!a||!l)throw de(ie,"createWallet","onError","must_be_authenticated"),new Error("User must be authenticated before creating a Privy wallet");return xl(l,15e3)},setWalletPassword:()=>new Promise(async(p,d)=>{if(!a||!l){d(new Error("User must be authenticated before adding password to Privy wallet"));return}let h=ne(l);if(!h||!_){d(new Error("Must have a Privy wallet to add a password"));return}if(h.recoveryMethod==="user-passcode"){d(new Error("Cannot set password. Embedded wallet already has a password."));return}await Sl(),se(!0);let g={onSuccess:p,onFailure:d,callAuthOnSuccessOnClose:!1},D={onCompleteNavigateTo:"EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN",onFailure:d};ee({setWalletPassword:g,connectWallet:D}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}),signMessage:(p,d)=>new Promise(async(h,g)=>{if(!a||!l){g(new Error("User must be authenticated before signing with a Privy wallet"));return}let D=ne(l);if(!D){g(new Error("Must have a Privy wallet before signing"));return}if(typeof p!="string"||p.length<1){g(new Error("Message must be a non-empty string"));return}se(!0);let X=async()=>{if(!a)throw new Error("User must be authenticated before signing with a Privy wallet");let _e=await ke();if(!_||!_e)throw new Error("Unable to connect to wallet");if(!await ve.recoverEmbeddedWallet())throw new Error("Unable to connect to wallet");t.createAnalyticsEvent("embedded_wallet_sign_message_started",{walletAddress:D.address});let{response:ct}=await _.rpc({accessToken:_e,address:D.address,request:{method:"personal_sign",params:[p,D.address]}}),Yr=ct.data;return t.createAnalyticsEvent("embedded_wallet_sign_message_completed",{walletAddress:D.address}),Yr};if(N.embeddedWallets.noPromptOnSignature){d&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");try{let _e=await X();h(_e)}catch(_e){g(_e??new Oe("Unable to sign message"))}}else{let ct={message:p,confirmAndSignMessage:X,onSuccess:ao=>{h(ao)},onFailure:ao=>{g(ao)},uiOptions:d||{}},Yr={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:g};ee({signMessage:ct,connectWallet:Yr}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),sendTransaction:async(p,d,h)=>{let D=await(await Tl(p,d,h)).wait();return Ra(D)},exportWallet:()=>new Promise(async(p,d)=>{if(!a||!l){d(new Error("User must be authenticated before exporting their Privy wallet"));return}if(!ne(l)){d(new Error("Must have a Privy wallet before exporting"));return}se(!0);let g={onCompleteNavigateTo:"EMBEDDED_WALLET_KEY_EXPORT_SCREEN",onFailure:d},D=await ke();if(!D||!_)throw new Error("Must have valid access token to enroll in MFA");if(!_){d(new Error("Must have a Privy wallet before exporting"));return}await _.verifyMfa({accessToken:D});let X={appId:e.appId,origin:t.apiUrl,onSuccess:p,onFailure:d};ee({keyExport:X,connectWallet:g}),ge("EMBEDDED_WALLET_CONNECTING_SCREEN")}),promptMfa:Sl,async init(p){let d;switch(p){case"sms":d=new Ua("verify");break;case"totp":return;default:throw new Error(`Unsupported MFA method: ${p}`)}t.startMfaFlow(d),await d.init()},async submit(p,d){switch(p){case"totp":case"sms":Oo.current?.resolve({mfaMethod:p,mfaCode:d}),await new Promise((h,g)=>{Kn.current={resolve:h,reject:g}});break;default:throw Oo.current?.reject(new C("Unsupported MFA method")),new C(`Unsupported MFA method: ${p}`)}},cancel(){Oo.current?.reject(new C("MFA canceled"))},async initEnrollmentWithSms(p){let d=await ke();if(!d||!_)throw new Error("Must have valid access token to enroll in MFA");await _.initEnrollMfa({method:"sms",accessToken:d,phoneNumber:p.phoneNumber})},enrollInMfa(p){return new Promise((d,h)=>{if(!p){ve.closePrivyModal(),d();return}N.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."),ee({mfaEnrollmentFlow:{mfaMethods:N.mfa.methods,onSuccess:d,onFailure:h}}),ge("MFA_ENROLLMENT_FLOW_SCREEN")})},async initEnrollmentWithTotp(){let p=await ke();if(!p||!_)throw new Error("Must have valid access token to enroll in MFA");let d=await _.initEnrollMfa({method:"totp",accessToken:p});return{secret:d.secret,authUrl:d.authUrl}},async submitEnrollmentWithSms(p){let d=await ke();if(!d||!_)throw new Error("Must have valid access token to enroll in MFA");await _.submitEnrollMfa({method:"sms",accessToken:d,phoneNumber:p.phoneNumber,code:p.mfaCode});let h=await t.getAuthenticatedUser();c(h)},async submitEnrollmentWithTotp(p){let d=await ke();if(!d||!_)throw new Error("Must have valid access token to enroll in MFA");await _.submitEnrollMfa({method:"totp",accessToken:d,code:p.mfaCode});let h=await t.getAuthenticatedUser();c(h)},async unenroll(p){let d=await ke();if(!d||!_)throw new Error("Must have valid access token to remove MFA");await _.unenrollMfa({method:p,accessToken:d});let h=await t.getAuthenticatedUser();c(h)},loginWithCode(p){return ve.loginWithCode(p)},initLoginWithEmail(p,d){return ve.initLoginWithEmail(p,d)},isModalOpen:o};af=Kr.signMessage,sf=async(...p)=>{let d=await Tl(...p);return N.embeddedWallets.waitForTransactionConfirmation&&await d.wait(),d};let ve=(()=>({isNewUserThisSession:b,isLinking:u,linkingHint:V,pendingTransaction:null,walletConnectionStatus:W,mipdStore:I,connectors:t.connectors?.walletConnectors??[],rpcConfig:N.rpcConfig,chains:N.chains,showFiatPrices:N.embeddedWallets.priceDisplay.primary!=="native-token",clientAnalyticsId:t.clientAnalyticsId,nativeTokenSymbolForChainId:p=>N.chains.find(d=>d.id===Number(p))?.nativeCurrency.symbol,initializeWalletProxy:async p=>{if(_)return _;let d=new Promise(D=>{io(()=>X=>D(X))}),h=new Promise(D=>setTimeout(()=>D(null),p)),g=await Promise.race([d,h]);return io(null),g},getAuthFlow:()=>t.authFlow,getAuthMeta:()=>t.authFlow?.meta,closePrivyModal:(p={shouldCallAuthOnSuccess:!0})=>{let d=n&&a&&l;p.shouldCallAuthOnSuccess&&d?(de(ie,"login","onComplete",l,b,!1,Do.current??null),e.onSuccess?.(l,b)):L&&de(ie,"login","onError","exited_auth_flow"),F(null),M(!1),y(!1),x(!1),r(!1),setTimeout(()=>{t.authFlow=void 0},200),t.createAnalyticsEvent("modal_closed")},connectWallet:Fo,initLoginWithWallet:lt,loginWithWallet:async()=>{if(!n)throw new Jr;if(!(t.authFlow instanceof Go))throw new C("Must initialize SIWE flow first.");let p,d;if(a)p=await t.link();else try{({user:p,isNewUser:d}=await t.authenticate())}catch(h){throw de(ie,"login","onError",h.privyErrorCode||"generic_connect_wallet_error"),h}c(p||l||null),x(d||!1),s(!0)},initLoginWithOAuth:async p=>{t.startAuthFlow(new lo(p));let d=await t.authFlow.getAuthorizationUrl();d&&d.url&&window.location.assign(d.url)},loginWithOAuth:async p=>{if(!(t.authFlow instanceof lo))throw new C("Must initialize OAuth flow before calling loginWithOAuth");let d,h;if(a)d=await t.link();else try{({user:d,isNewUser:h}=await t.authenticate()),Do.current=p}catch(g){throw de(ie,"login","onError",g.privyErrorCode||"unknown_auth_error"),g}c(d),x(h||!1),s(!0)},initLoginWithEmail:async(p,d)=>{let h=new Ho(p,d);t.startAuthFlow(h);try{Do.current="email",await h.sendCodeEmail()}catch(g){throw de(ie,"login","onError",g.privyErrorCode||"unknown_auth_error"),g}},initLoginWithSms:async(p,d)=>{let h=new zo(p,d);t.startAuthFlow(h);try{Do.current="sms",await h.sendSmsCode()}catch(g){throw de(ie,"login","onError",g.privyErrorCode||"unknown_auth_error"),g}},resendEmailCode:async()=>{await t.authFlow?.sendCodeEmail()},resendSmsCode:async()=>{await t.authFlow?.sendSmsCode()},loginWithCode:async p=>{if(!n)throw new Jr;if(t.authFlow instanceof Ho)t.authFlow.meta.emailCode=p.trim();else if(t.authFlow instanceof zo)t.authFlow.meta.smsCode=p.trim();else throw new C("Must initialize a passwordless code flow first");let d,h;a?d=await t.link():{user:d,isNewUser:h}=await t.authenticate(),c(d||l||null),x(h||!1),s(!0)},refreshUser:async()=>{let p=await t.getAuthenticatedUser();return c(p),p},walletProxy:_,createAnalyticsEvent:(p,d,h)=>t.createAnalyticsEvent(p,d,h),getUsdTokenPrice:p=>t.getUsdTokenPrice(p),recoverEmbeddedWallet:async()=>new Promise(async(p,d)=>{let h=l?.linkedAccounts.find(D=>D.type==="wallet"&&D.walletClientType==="privy"),g=await ke();if(!g||!_||!h){d(new Error("Must have valid access token and Privy wallet to recover wallet"));return}se(!0);try{await _.connect({accessToken:g,address:h.address}),p(!0)}catch(D){Pr(D)&&h.recoveryMethod==="privy"?(t.createAnalyticsEvent("embedded_wallet_pinless_recovery_started",{walletAddress:h.address}),(await _.recover({address:h.address,accessToken:g})).address||d(new Error("Unable to recover wallet")),t.createAnalyticsEvent("embedded_wallet_recovery_completed",{walletAddress:h.address}),p(!0)):Pr(D)?(ee({recoverWallet:{privyWallet:h,onFailure:d,onSuccess:()=>p(!0)}}),ge("EMBEDDED_WALLET_RECOVERY_SCREEN")):d(D)}}),getFiatOnRampConfig:Ha,setReadyToTrue:()=>{i(!0),le?.()},updateWallets:()=>Ve()}))();lf=ve.recoverEmbeddedWallet;let pf=j0(()=>({wallets:w}),[w]);return Lo(we.Provider,{value:Kr,children:Lo(os.Provider,{value:ie,children:Lo(fl.Provider,{value:pf,children:nf(Up,{...N,children:[e.children,nf(ls.Provider,{value:ve,children:[Lo(Om,{theme:{...N.appearance.palette||{}}}),Lo(Rc,{appConfig:N,data:Se,setModalData:ee,setInitialScreen:R,initialScreen:v,authenticated:a,children:Lo(Bm,{open:o})}),st&&re.id?Lo(rf,{appId:e.appId,clientAnalyticsId:t.clientAnalyticsId,origin:t.apiUrl,mfaMethods:l?.mfaMethods,mfaPromise:Oo,mfaSubmitPromise:Kn,onLoad:Q,onLoadFailed:()=>null}):null]})]})})})})};import{useContext as Q0}from"react";function Z0(e){let{login:t}=Q0(we);return Mt("login",e),{login:t}}import{useContext as X0}from"react";function eb(e){let{logout:t}=X0(we);return Mt("logout",e),{logout:t}}import{useCallback as cf}from"react";var tb=()=>{let e=Ut(),{initLoginWithEmail:t,loginWithCode:o}=G(),r=cf(async({email:i})=>{if(!i)throw new Error("Email required to send OTP code");if(e.status==="disabled")return t(i);let a=await e.waitForResult();return t(i,a)},[t,e]),n=cf(async({code:i})=>{if(e.enabled&&e.status!=="success")throw new Sn(e.error,null,"captcha_failure");return o(i)},[o,e.status]);return{sendCode:r,loginWithCode:n}};import{useContext as ob}from"react";function rb(e){let{connectWallet:t}=ob(we);return Mt("connectWallet",e),{connectWallet:t}}import{useContext as nb}from"react";function ib(e){let{createWallet:t}=nb(we);return Mt("createWallet",e),{createWallet:t}}import{useContext as ab}from"react";var sb=()=>{let{isModalOpen:e}=ab(we);return{isOpen:e}};export{At as AsExternalProvider,_n as Captcha,nn as ConnectorManager,sn as PrivyClient,Y0 as PrivyProvider,oe as PrivyProxyProvider,$n as SUPPORTED_CHAINS,za as VERSION,je as WalletConnector,Ps as errorIndicatesMaxMfaRetries,xr as errorIndicatesMfaTimeout,Tr as errorIndicatesMfaVerificationFailed,ke as getAccessToken,rb as useConnectWallet,ib as useCreateWallet,Z0 as useLogin,tb as useLoginWithEmail,eb as useLogout,Ur as useMfa,Ln as useMfaEnrollment,sb as useModalStatus,G as usePrivy,rs as useRegisterMfaListener,zn as useWallets};
|