@privy-io/react-auth 1.47.1 → 1.47.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/esm/index.js CHANGED
@@ -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 Qe(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 v("Auth flow has no API instance");try{let{message:t,signature:o}=await this.sign(),r=await this.api.post(ms(),{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 Y(t)}}async link(){if(!this.api)throw new v("Auth flow has no API instance");try{let{message:t,signature:o}=await this.sign();return await this.api.post(hs(),{message:t,signature:o,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(t){throw Y(t)}}async sign(){if(!this.api)throw new v("Auth flow has no API instance");if(await this.buildSiweMessage(),!this.preparedMessage)throw new v("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 v("Auth flow has no API instance");let t=this.wallet.address;return(await this.api.post(us(),{address:t})).nonce}async buildSiweMessage(){if(!this.api)throw new v("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.",l=new Date().toISOString();return this.createSiweMessage(t,o,n,i,l,r,a)}};var Ao=class{constructor(t,o){this.meta={phoneNumber:t,captchaToken:o}}async authenticate(){if(!this.api)throw new v("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new v("phone number and sms code must be set prior to calling authenticate.");try{let t=ws(),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 Y(t)}}async link(){if(!this.api)throw new v("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new v("phone number and sms code must be set prior to calling authenticate.");try{let t=Cs();return await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(t){throw Y(t)}}async sendSmsCode(t,o){if(!this.api)throw new v("Auth flow has no API instance");if(t&&(this.meta.phoneNumber=t),o&&(this.meta.captchaToken=o),!this.meta.phoneNumber)throw new v("phone nNumber must be set when initialzing authentication.");try{let r=vs();return await this.api.post(r,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken})}catch(r){throw Y(r)}}};import{v4 as lm}from"uuid";function He(e){return new Date(e*1e3)}function Eu(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:He(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:He(o.verified_at)};t.push(i);break;case"phone":let a={number:o.phoneNumber,type:o.type,verifiedAt:He(o.verified_at)};t.push(a);break;case"google_oauth":let l={subject:o.subject,email:o.email,name:o.name,type:o.type,verifiedAt:He(o.verified_at)};t.push(l);break;case"twitter_oauth":let s={subject:o.subject,username:o.username,name:o.name,type:o.type,verifiedAt:He(o.verified_at)};t.push(s);break;case"discord_oauth":let c={subject:o.subject,username:o.username,email:o.email,type:o.type,verifiedAt:He(o.verified_at)};t.push(c);break;case"github_oauth":let h={subject:o.subject,username:o.username,name:o.name,email:o.email,type:o.type,verifiedAt:He(o.verified_at)};t.push(h);break;case"tiktok_oauth":let m={subject:o.subject,username:o.username,type:o.type,verifiedAt:He(o.verified_at)};t.push(m);break;case"linkedin_oauth":let g={subject:o.subject,name:o.name,email:o.email,type:o.type,verifiedAt:He(o.verified_at)};t.push(g);break;case"apple_oauth":let f={subject:o.subject,email:o.email,type:o.type,verifiedAt:He(o.verified_at)};t.push(f);break;case"custom_auth":t.push({type:o.type,customUserId:o.custom_user_id,verifiedAt:He(o.verified_at)});break;default:console.warn(`Unrecognized account type: ${r}. Please consider upgrading the Privy SDK.`)}}return t}function ht(e,t){return e.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),e.find(o=>o.type===t)}var Q=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy")||null,xu=e=>e.linkedAccounts.filter(t=>t.type==="wallet"),Yt=(e,t)=>t==="all-users"&&!Q(e)||t==="users-without-wallets"&&!xu(e)?.length;function it(e){if(!e)return null;let t=Eu(e.linked_accounts),o=ht(t,"wallet"),r=ht(t,"email"),n=ht(t,"phone"),i=ht(t,"google_oauth"),a=ht(t,"twitter_oauth"),l=ht(t,"discord_oauth"),s=ht(t,"github_oauth"),c=ht(t,"tiktok_oauth"),h=ht(t,"linkedin_oauth"),m=ht(t,"apple_oauth"),g=e.mfa_methods.map(({type:C,verified_at:P})=>({type:C,verifiedAt:He(P)}));return{id:e.id,createdAt:He(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:l&&{subject:l.subject,username:l.username,email:l.email},github:s&&{subject:s.subject,username:s.username,name:s.name,email:s.email},tiktok:c&&{subject:c.subject,username:c.username},linkedin:h&&{subject:h.subject,name:h.name},apple:m&&{subject:m.subject,email:m.email},mfaMethods:g.map(C=>C.type)}}import{getAddress as yl}from"@ethersproject/address";import rm from"eventemitter3";var Ms="1.47.1";var fn="4df5e2316331463a9130964bd6078dfa",Ns="fe9c30fc-3bc5-4064-91e2-6ab5887f8f4d",Os="34357d3c125c2bcf2ce2bc3309d98715",yn="https://auth.privy.io",Ls=2e4,Ge=1400,Ds=2500,Fi=Ms;var qo="privy:token",Bi="privy-token",gn="privy:refresh_token",Hi="privy-refresh-token",Us="privy-session",Pr="privy:session_transfer_token",Tu="privy:wallet",Tr="privy:caid",vn=e=>`${Tu}:${e}`,Gi="privy:connectors",zi="privy:connections";var Sr=12e4,ft=1,$i="0x1",jo=3e4,Fs="https://api.moonpay.com/v1",Bs="https://api.moonpay.com/v1",Hs="pk_live_hirbpu0cVcLHrjktC9l7fbc9ctjv0SL",Gs="pk_test_fqWjXZMSFwloh7orvJsRfjiUHXJqFzI";var Vi=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)}},qi=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 Su(){return typeof window<"u"&&window.localStorage?new qi:new Vi}var z=Su();import{isPossiblePhoneNumber as _u}from"libphonenumber-js/min";var wn=()=>{let e=window;if(!e.ethereum)return!1;if(_r(window.ethereum,!0))return!0;if(e.ethereum.providers){for(let t of e.ethereum.providers)if(_r(t,!0))return!0}return!1},Ar=()=>{let e=window;if(!e.ethereum)return!1;if(_r(window.ethereum,!1))return!0;if(e.ethereum.providers){for(let t of e.ethereum.providers)if(_r(t,!1))return!0}return!!window.ethereum.isZerion},_r=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||e.isApexWallet||e.isAvalanche||e.isBitKeep||e.isBlockWallet||e.isKuCoinWallet||e.isMathWallet||e.isOkxWallet||e.isOKExWallet||e.isOneInchIOSWallet||e.isOneInchAndroidWallet||e.isOpera||e.isPhantom||e.isPortal||e.isRabby||e.isRainbow||e.isTokenPocket||e.isTokenary||e.isZerion)return!1;if(e.providers){for(let o of e.providers)if(!_r(o))return!1}return!0},Ze=()=>!!("phantom"in window&&window?.phantom?.ethereum?.isPhantom),Cn=()=>{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.isCoinbaseWallet)return!0}return!1};var zs=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,}))$/),$s=e=>_u(String(e),"US"),Vs=(e,t)=>{let o=e.slice(0),r=[];for(;o.length;)r.push(o.splice(0,t));return r},Jt=(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}`},ji=e=>new Promise(t=>setTimeout(t,e));function qs(e,{interval:t=100,timeout:o=5e3}={}){return new Promise((r,n)=>{let i=0,a,l=()=>{if(i>=o){n("Max attempts reached without result");return}if(a=e(),i+=t,a!=null){r(a);return}setTimeout(l,t)};l()})}var js=(e,t={})=>{let o=t.delayMs||150,r=t.maxAttempts||270;return new Promise(async(n,i)=>{let a=!1,l=0;for(;!a&&l<r;){if(t.abortSignal?.aborted)return;e().then(()=>{a=!0,n()},(...s)=>{a=!0,i(...s)}),l+=1,await ji(o)}a||i(new Error("Exceeded max attempts before resolving function"))})},bn=(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 Ki=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),ko=e=>typeof e=="string"?e:"0x"+e.toString(16);async function Ks(e=3e3){let t=!1,o=window;return new Promise(r=>{o.ethereum?n():(window.addEventListener("ethereum#initialized",n,{once:!0}),setTimeout(()=>{n()},e));function n(){if(t)return;t=!0,window.removeEventListener("ethereum#initialized",n);let i=[];wn()&&i.push("metamask"),Ze()&&i.push("phantom"),o.ethereum&&o.ethereum.isBraveWallet&&i.push("brave"),r(i)}})}function Ko(e){return`eip155:${String(Number(e))}`}var at=(e,t,o)=>{let r=Number(e),n=t.find(a=>a.id===r);if(!n)throw new B(`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]+"/"+fn:n.rpcUrls.blast?.http[0]?i=n.rpcUrls.blast.http[0]+"/"+Ns:i=n.rpcUrls.default?.http[0],!i)throw new B(`No RPC url found for ${e}`);return i},Ys=(e,t)=>{let o=Number(e),r=t.find(n=>n.id===o);if(!r)throw new B(`Unsupported chainId ${e}`,4901);return r.blockExplorers?.default.url};import Du from"@coinbase/wallet-sdk";import{jsx as Js,jsxs as Au}from"react/jsx-runtime";var Qt=({style:e,...t})=>Au("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:[Js("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),Js("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 wt}from"@ethersproject/address";import{Web3Provider as ol}from"@ethersproject/providers";import{default as Ou}from"eventemitter3";import{StaticJsonRpcProvider as Zs}from"@ethersproject/providers";import Nu from"eventemitter3";var ku=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4"],Qs=e=>ku.includes(e);import{ErrorCode as Ru}from"@ethersproject/logger";var Yo=class extends B{constructor(){super("Wallet timeout");this.type="wallet_error"}},Jo=class extends B{constructor(){super("User rejected connection");this.type="wallet_error"}},gt=e=>{if(e instanceof B)return e;if(e?.code&&e?.reason){let t=new Pe(e);return e.code===Ru.ACTION_REJECTED&&(t.details=Ne.E4001_USER_REJECTED_REQUEST),t}return e?.code?new Pe(e):new B("Unknown connector error",e)},yt=class extends Ue{constructor(o,r,n){super(o);this.type="provider_error";this.code=r,this.data=n}},Pe=class extends yt{constructor(o){let r=o;super(r.message,r.code,r.data);let n=Object.values(Ne).find(i=>i.eipCode===r.code);this.details=n||Ne.UNKNOWN_ERROR,r.code===-32002&&(r.message?.includes("already pending for origin")?r.message?.includes("wallet_requestPermissions")?this.details=Ne.E32002_CONNECTION_ALREADY_PENDING:this.details=Ne.E32002_REQUEST_ALREADY_PENDING:r.message?.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=Ne.E32002_WALLET_LOCKED))}},Iu={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}},Wu={E32002_CONNECTION_ALREADY_PENDING:{eipCode:-32002,message:"Connection request already pending",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E32002_REQUEST_ALREADY_PENDING:{eipCode:-32002,message:"Resource request already pending",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E32002_WALLET_LOCKED:{eipCode:-32002,message:"Wallet might be locked",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E4001_USER_REJECTED_REQUEST:{eipCode:4001,message:"Signature rejected",detail:"Please try signing again.",retryable:!0}},Mu={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}},Ne={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Mu,...Wu},Rt={...Iu,...Ne};var Z=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 Yo,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||Sr,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 B(`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 gt(o)})}},Zt=class extends Error{constructor(o,r,n){super(o);this.code=r,this.data=n}},En=class extends Nu{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 Zs(at(a,this.chains,n)),this.rpcTimeoutDuration=Qo(n,"privy")}async handleSendTransaction(o){if(!o.params||!Array.isArray(o.params))throw new Zt(`Invalid params for ${o.method}`,4200);let r=o.params[0];if(!await ze()||!this.address)throw new Zt("Disconnected",4900);return(await el(r)).hash}handleSwitchEthereumChain(o){if(!o.params||!Array.isArray(o.params))throw new Zt(`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 Zt(`Invalid params for ${o.method}`,4200);this.chainId=Number(r),this.provider=new Zs(at(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 Xs(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:ko(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 ko(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(Qs(o.method)){let r=await ze();if(await tl(),!r||!this.address)throw new Zt("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 Zt("Disconnected",4900)}}else return this.provider.send(o.method,o.params)}async connect(){let o=await ze();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}}},vt=class extends Z{constructor(o){super(o,o.rpcTimeoutDuration)}},Xt=class extends Z{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 Lu=(e,t)=>{switch(t){case"coinbase_wallet":return e.message.includes("addEthereumChain");default:return e.code===4902||e.message?.includes("4902")}},$e=class extends Ou{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=Ko(o),this.walletClientType==="privy"&&z.put(vn(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=Qo(i,o),this.connected=!1,this.initialized=!1}buildConnectedWallet(o,r){let n=async()=>!!this.wallets.find(i=>wt(i.address)===wt(o));return{address:wt(o),chainId:r,switchChain:async i=>{if(!n)throw new B("Wallet is not currently connected.");let a=this.wallets.find(m=>wt(m.address)===wt(o))?.chainId;if(!a)throw new B("Unable to determine current chainId.");let l,s;if(typeof i=="number"?(l=`0x${i.toString(16)}`,s=i):(l=i,s=Number(i)),a===Ko(l))return;let c=this.chains.find(m=>m.id===s);if(!c)throw new B(`Unsupported chainId: ${i}`);let h=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:l}]})};try{return await h()}catch(m){if(Lu(m,this.walletClientType))return await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:l,chainName:c.name,nativeCurrency:c.nativeCurrency,rpcUrls:[c.rpcUrls.public?.http[0]??""],blockExplorerUrls:[c.blockExplorers?.default.url??""]}]}),h();throw this.walletClientType==="rainbow"&&m.message?.includes("wallet_switchEthereumChain")?new B(`Rainbow does not support the chainId ${r}`):m}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:n,getEthereumProvider:async()=>{if(!await n())throw new B("Wallet is not currently connected.");return this.proxyProvider},getEthersProvider:async()=>{if(!await n())throw new B("Wallet is not currently connected.");return new ol(new vt(this.proxyProvider))},getWeb3jsProvider:async()=>{if(!await n())throw new B("Wallet is not currently connected.");return new Xt(this.proxyProvider)},sign:async i=>{if(!await n())throw new B("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=wt(n),a=[],l;if(this.walletClientType==="privy"){let c=z.get(vn(i));this.chains.find(h=>h.id===Number(c))||(z.del(vn(i)),c=null),l=c||`0x${this.defaultChain.id.toString(16)}`;try{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:l}]})}catch{console.warn(`Unable to switch embedded wallet to chain ID ${l} on initialization`)}}else try{let c=await this.proxyProvider.request({method:"eth_chainId"});if(typeof c=="string")l=c;else if(typeof c=="number")l=`0x${c.toString(16)}`;else throw new Error("Invalid chainId returned from provider")}catch(c){console.warn(`Failed to get chainId from provider, defaulting to ${$i}`,c),l=$i}let s=Ko(l);a.find(c=>wt(c.address)===i)||a.push(this.buildConnectedWallet(wt(n),s)),xn(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=>wt(n)===wt(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 ol(new vt(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 Uu=e=>{let t=`https://mainnet.infura.io/v3/${fn}`,o=1;return e.makeWeb3Provider(t,o)},Pn,Tn=class extends $e{constructor(o,r,n){super("coinbase_wallet",o,r,n);this.connectorType="coinbase_wallet";this.proxyProvider=new Z(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),Pn||(Pn=new Du({appName:"Privy",darkMode:!1,headlessMode:!1,enableMobileWalletLink:!0})),this.proxyProvider.setWalletProvider(Uu(Pn)),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(){Pn.disconnect()}get walletBranding(){return{name:"Coinbase Wallet",icon:Qt}}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new B("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([o[0]])}catch(o){throw gt(o)}}};import{jsx as rl}from"react/jsx-runtime";var Zo=({...e})=>rl("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:rl("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 Sn=class extends $e{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:[ko(o?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:Zo}}disconnect(){this.connected=!1}async promptConnection(){}};import{getAddress as CC}from"@ethersproject/address";import{Web3Provider as EC}from"@ethersproject/providers";import{isMobile as Bu}from"react-device-detect";import{jsx as Ve,jsxs as Fu}from"react/jsx-runtime";var qe=({style:e,...t})=>Fu("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:[Ve("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),Ve("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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 _n=class extends $e{constructor(o,r,n){super("metamask",o,r,n);this.connectorType="injected";this.proxyProvider=new Z(void 0,this.rpcTimeoutDuration),this.subscribeListeners();let i=window,a=i.ethereum,l=i.ethereum.providers||[];for(let s of l)if(s.isMetaMask){a=s;break}this.proxyProvider.setWalletProvider(a),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:"MetaMask",icon:qe}}disconnect(){console.warn("Metamask does not support programmatic disconnect.")}async promptConnection(){try{!Bu&&wn()&&await this.proxyProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]});let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new B("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw gt(o)}}};import{jsx as nl,jsxs as Hu}from"react/jsx-runtime";var Ct=({style:e,...t})=>Hu("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:[nl("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),nl("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 An=class extends $e{constructor(o,r,n){super("phantom",o,r,n);this.connectorType="injected";this.proxyProvider=new Z(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:Ct}}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 B("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw gt(o)}}};import{EthereumProvider as Zu,OPTIONAL_EVENTS as Xu,OPTIONAL_METHODS as em}from"@walletconnect/ethereum-provider";import Qi from"@walletconnect/qrcode-modal";import{isAndroid as tm,isMobile as om}from"react-device-detect";import{createContext as zu,useContext as $u,useEffect as Yi,useRef as Vu,useState as al}from"react";import{jsx as Gu}from"react/jsx-runtime";function il(e){return Gu("link",{rel:"prefetch",href:e.src})}var w=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};import{jsx as qu,jsxs as ju}from"react/jsx-runtime";var st="LANDING",sl=zu({ready:!1,app:null,currentScreen:st,lastScreen:st,navigate:w,navigateBack:w,resetNavigation:w,setModalData:w,onUserCloseViaDialogOrKeybindRef:void 0}),ll=e=>{let t=e.appConfig,o=e.authenticated,r=e.visible,[n,i]=al(e.initialScreen||st),[a,l]=al(e.initialScreen||st);Yi(()=>{o||i(st)},[o]),Yi(()=>{r||(l(st),i(st))},[r]),Yi(()=>{e.initialScreen&&n===st&&(i(e.initialScreen),l(e.initialScreen))},[e.initialScreen]);let s=e.initialScreen&&n===st?e.initialScreen:n,c=Vu(null),h={ready:!!t?.id,app:t,data:e.data,setModalData:e.setModalData,currentScreen:s,lastScreen:a,navigate:m=>{l(n),i(m)},navigateBack:()=>{i(a)},resetNavigation:()=>{e.setInitialScreen(null),l(st),i(st)},onUserCloseViaDialogOrKeybindRef:c};return ju(sl.Provider,{value:h,children:[(typeof t?.appearance?.logo=="string"||t?.appearance?.logo?.type==="img")&&qu(il,{src:typeof t.appearance.logo=="string"?t.appearance.logo:t.appearance.logo.props.src}),e.children]})},b=()=>$u(sl);import{jsx as Xo,jsxs as Ku}from"react/jsx-runtime";var er=({style:e,...t})=>{let{app:o}=b();return Ku("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:[Xo("rect",{width:"28",height:"28",rx:"3",fill:o?.appearance.palette.colorScheme==="dark"?"#3396ff":"#141414"}),Xo("g",{clipPath:"url(#clip0_1765_9946)",children:Xo("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"})}),Xo("defs",{children:Xo("clipPath",{id:"clip0_1765_9946",children:Xo("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})};import{isAndroid as dl,isDesktop as Yu,isMobileOnly as Ju}from"react-device-detect";var kn=e=>{let t;try{t=new URL(e).hostname}catch{return}for(let[o,r]of Object.entries(pl))if(t.includes(r.hostname))return{walletClientType:o,entry:r}};var pl={metamask:{id:"c57ca95b47569778a828d19178114f4db188b89b763c899ba0be274e97267d96",displayName:"MetaMask",hostname:"metamask.io",mobile:{native:"metamask:"}},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:{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:{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 Ji(e){return{name:e.displayName||"",universalLink:e.mobile.universal||"",deepLink:e.mobile.native||""}}function Qu(e){let t="mobile";return Object.values(e).filter(o=>!!o[t].universal||!!o[t].native).map(o=>Ji(o))}function ul(){return Qu(pl)}function ml(e,t){let o=encodeURIComponent(e);return t.universalLink?`${t.universalLink}/wc?uri=${o}`:t.deepLink?`${t.deepLink}${t.deepLink.endsWith(":")?"//":"/"}wc?uri=${e}`:""}function hl(e,t){return dl?e:ml(e,Ji(t))}var fl="WALLETCONNECT_DEEPLINK_CHOICE";function cl(e){let t=e.href.split("?")[0];z.put(fl,{...e,href:t})}var kr=(e,t)=>{if(!e||Yu){z.del(fl);return}if(dl){cl({name:"Unknown",href:t||"wc:"});return}else if(Ju){let o=ml(t||"wc:",Ji(e));cl({name:e?.displayName||"",href:o})}};var Rr=class extends $e{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 Z(void 0,this.rpcTimeoutDuration),this.createProvider().then(l=>{if(this.provider=l,this.proxyProvider.setWalletProvider(l),this.subscribeListeners(),l.session){if(this.walletProvider.session?.peer.metadata.url){let s=kn(this.walletProvider.session?.peer.metadata.url);this.walletEntry=s?.entry,this.walletClientType=s?.walletClientType||"unknown",kr(this.walletEntry)}this.connected=!0,this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}else this.emit("initialized"),this.initialized=!0})}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:qe}:{name:Ki(this.walletProvider.session?.peer.metadata.name||"")||"WalletConnect",icon:this.walletProvider.session?.peer.metadata.icons?.[0]||er}}resetConnection(){this.walletProvider&&this.walletProvider.connected&&(this.walletProvider.signer.session=void 0,this.walletEntry=void 0,kr(void 0),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise((o,r)=>{let n=()=>{r(new Jo)};this.onQrModalClosed=n,(async()=>{let a="",l=await Promise.race([this.walletProvider.enable(),this.proxyProvider.walletTimeout()]);if(l.length>0&&(a=l[0]),!a||a==="")throw new B("Unable to retrieve address");if(this.walletProvider.session?.peer.metadata.url){let s=kn(this.walletProvider.session?.peer.metadata.url);this.walletEntry=s?.entry,this.walletClientType=s?.walletClientType||"unknown",this.proxyProvider.rpcTimeoutDuration=Qo(this.rpcConfig,this.walletClientType)}this.connected=!0,await this.syncAccounts(l),o()})().catch(a=>{if(a){r(gt(a));return}r(new B("Unknown error during connection"))}).finally(()=>Qi.close())})}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=at(n.id,this.chains,this.rpcConfig);i&&(o[n.id]=i)}let r=await Zu.init({projectId:this.walletConnectCloudProjectId,chains:[this.defaultChain.id],optionalChains:this.chains.map(n=>n.id),optionalEvents:Xu,optionalMethods:em,rpcMap:o,showQrModal:!1});return r.on("display_uri",n=>{if(tm)window.open(n,"_self");else if(om&&this.walletEntry){kr(this.walletEntry,n);let a=hl(n,this.walletEntry);window.open(a,"_self","noopener,noreferrer")}else Qi.open(n,()=>{this.onQrModalClosed&&this.onQrModalClosed()},{mobileLinks:ul().map(i=>i.name)})}),r.on("connect",()=>{if(Qi.close(),r.session?.peer.metadata.url){let n=kn(r.session?.peer.metadata.url);this.walletEntry=n?.entry,this.walletClientType=n?.walletClientType||"unknown",kr(this.walletEntry)}}),r}async enableProvider(){return this.walletProvider.connected?Promise.resolve(this.walletProvider.accounts):await this.walletProvider.enable()}};var Zi=e=>{let t=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return t?!!e?.linkedAccounts.filter(r=>r.type=="wallet"&&r.address===yl(t)).length:!1},Qo=(e,t)=>e.rpcTimeouts?e.rpcTimeouts[t]||Sr:Sr,Ir=class extends rm{constructor(o,r,n,i){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 Z:r.proxyProvider};this.walletConnectCloudProjectId=o,this.rpcConfig=r,this.chains=n,this.defaultChain=i,this.walletConnectors=[],this.initialized=!1,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(Gi)&&(z.getKeys().forEach(o=>{o.startsWith("walletconnect")&&z.del(o)}),z.del(Gi)),Ks().then(o=>o.forEach(r=>{switch(r){case"metamask":this.createWalletConnector("injected","metamask");break;case"phantom":this.createWalletConnector("injected","phantom");break;case"unknown":default:break}})),(Cn()||z.getKeys().find(o=>o.startsWith("-walletlink")))&&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 En(o,r,this.rpcConfig,this.chains,n.id),l=new Sn(a,this.chains,n,this.rpcConfig);this.addWalletConnector(l)}}removeEmbeddedWalletConnector(){let o=this.findWalletConnector("embedded","privy");if(o){let r=this.walletConnectors.indexOf(o);this.walletConnectors.splice(r,1),this.saveConnectionHistory(),this.emit("walletsUpdated")}}async createWalletConnector(o,r){let n=this.findWalletConnector(o,r);if(n)return n instanceof Rr&&n.resetConnection(),n;let a=(()=>{switch(o){case"injected":switch(r){case"phantom":return Ze()?new An(this.chains,this.defaultChain,this.rpcConfig):null;case"metamask":default:return Ar()?new _n(this.chains,this.defaultChain,this.rpcConfig):null}case"coinbase_wallet":return new Tn(this.chains,this.defaultChain,this.rpcConfig);case"wallet_connect_v2":return new Rr(this.walletConnectCloudProjectId,this.rpcConfig,this.chains,this.defaultChain)}})();return a&&this.addWalletConnector(a),a||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(zi);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(zi,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=yl(o),this.emit("walletsUpdated")}};function xn(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 nm}from"ofetch";var im=[un(),hn(),mn()],am=e=>{let t=new AbortController;return setTimeout(()=>t.abort(),e),t.signal},Rn=class{constructor(t,o,r){this.appId=t,this.clientAnalyticsId=o.clientAnalyticsId,this.sdkVersion=Fi,this.client=o,this.defaults=r,this.fallbackApiUrl=o.fallbackApiUrl,this.baseFetch=nm.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 l=!im.includes(n.toString());if(!a.has("authorization")&&l){let s=await this.client.getAccessToken();s!==null&&a.set("authorization",`Bearer ${s}`)}i.headers=a,i.signal||(i.signal=am(this.defaults.timeout))},onRequestError:({error:n})=>{if(n instanceof DOMException&&n.name==="AbortError")throw new dn}})}async get(t,o){try{return await this.baseFetch(t,o)}catch(r){throw Y(r)}}async post(t,o,r){try{return await this.baseFetch(t,{method:"POST",...o?{body:o}:{},...r})}catch(n){throw Y(n)}}async delete(t,o){try{return await this.baseFetch(t,{method:"DELETE",...o})}catch(r){throw Y(r)}}};import Wr from"js-cookie";function gl(e){return e instanceof So?"email":e instanceof Ao?"sms":e instanceof _o?"siwe":e instanceof Vo?"custom_auth":e instanceof jt?e.meta.provider:null}import*as vl from"jose";var bt=class{static parse(t){try{return new bt(t)}catch{return null}}constructor(t){this.value=t,this._decoded=vl.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 sm=30,In=class{constructor(){this.authenticateOnce=new Qe(async t=>this._authenticate(t)),this.linkOnce=new Qe(async t=>this._link(t)),this.refreshOnce=new Qe(this._refresh.bind(this)),this.destroyOnce=new Qe(this._destroy.bind(this)),this.forkSessionOnce=new Qe(this._forkSession.bind(this))}get token(){try{let t=z.get(qo);return typeof t=="string"?new bt(t).value:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get refreshToken(){try{let t=z.get(gn);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get forkedToken(){try{let t=z.get(Pr);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get mightHaveServerCookies(){try{let t=Wr.get(Us);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=bt.parse(this.token);return t!==null&&!t.isExpired(sm)}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=gl(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:it(n),isNewUser:i}}catch(o){throw console.warn("Error authenticating session"),Be(o)}}async _link(t){try{let o=await t.link();return it(o)}catch(o){throw console.warn("Error linking account"),Be(o)}}async _refresh(){if(!this.api)throw new v("Session has no API instance");if(!this.client)throw new v("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(un(),a,{headers:i}),r&&this.clearForkedToken()}else if(r)n=await this.api.post(hn(),{refresh_token:r}),this.clearForkedToken();else return null;return this.storeToken(n.token),this.storeRefreshToken(n.refresh_token),it(n.user)}catch(n){if(n instanceof $o&&n.privyErrorCode==="missing_or_invalid_token")return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw Be(n)}}async _destroy(){try{await this.api?.post(mn(),{refresh_token:this.refreshToken})}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new v("Session has no API instance");let t=this.refreshToken;try{let o=await this.api.post(ps(),{refresh_token:t});return this.storeToken(o.token),this.storeRefreshToken(o.refresh_token),o.new_session_refresh_token}catch(o){throw Be(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),this.clearForkedToken()}storeToken(t){if(typeof t=="string"){if(z.put(qo,t),!this.client?.useServerCookies){let o=bt.parse(t)?.expiration;Wr.set(Bi,t,{sameSite:"Strict",secure:!0,expires:o?new Date(o*1e3):void 0})}}else z.del(qo),Wr.remove(Bi)}storeRefreshToken(t){typeof t=="string"?(z.put(gn,t),this.client?.useServerCookies||Wr.set(Hi,t,{sameSite:"Strict",secure:!0,expires:30})):(z.del(gn),Wr.remove(Hi))}clearForkedToken(){z.del(Pr)}};var Xi,Wn,wl,Mr=class{constructor(t){cs(this,Wn);this.apiUrl=t.apiUrl||yn,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=!1,this.timeout=t.timeout||Ls,this.appId=t.appId,this.clientAnalyticsId=ds(this,Wn,wl).call(this),Xi||(Xi=new In),this.session=Xi,this.api=this.generateApi(),this.session.client=this}initializeConnectorManager(t,o,r,n){this.connectors||(this.connectors=new Ir(t,o,r,n))}generateApi(){let t=new Rn(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 v("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new v("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(Ts(),{address:t});return it(o)}catch(o){throw Be(o)}}async unlinkPhone(t){try{let o=await this.api.post(Ss(),{phoneNumber:t});return it(o)}catch(o){throw Be(o)}}async unlinkWallet(t){try{let o=await this.api.post(Ps(),{address:t});return it(o)}catch(o){throw Be(o)}}async unlinkOAuth(t,o){try{let r=await this.api.post(_s(),{provider:t,subject:o});return it(r)}catch(r){throw Be(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(As(),{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(ks(),t)}catch(o){throw Be(o)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()||this.session.hasRecoveryCredentials()?this.session.refresh():null}async getAccessToken(t){return this.session.hasActiveToken()?bt.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)}}catch(t){throw Be(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()}};Wn=new WeakSet,wl=function(){if(typeof window>"u")return null;try{let o=z.get(Tr);if(typeof o=="string"&&o.length>0)return o}catch{}let t=lm();try{return z.put(Tr,t),t}catch{return t}};import"wicg-inert";import{disableBodyScroll as ow,clearAllBodyScrollLocks as rw}from"body-scroll-lock";import{useRef as nw,useCallback as iw}from"react";import{useEffect as Np}from"react";import aw from"react-dom";import es from"styled-components";import{createContext as cm,useContext as dm}from"react";var ea=cm({isNewUserThisSession:!1,isLinking:!1,linkingHint:null,walletConnectionStatus:null,rpcConfig:{rpcUrls:{}},showFiatPrices:!0,chains:[],clientAnalyticsId:null,nativeTokenSymbolForChainId:w,initializeWalletProxy:w,getAuthMeta:w,getAuthFlow:w,closePrivyModal:w,connectWallet:w,initLoginWithWallet:w,loginWithWallet:w,loginWithCode:w,initLoginWithEmail:w,initLoginWithSms:w,resendEmailCode:w,resendSmsCode:w,initLoginWithOAuth:w,loginWithOAuth:w,refreshUser:w,walletProxy:null,createAnalyticsEvent:w,getUsdTokenPrice:w,recoverEmbeddedWallet:w,getFiatOnRampConfig:w,updateWallets:w}),_=()=>dm(ea);import{createContext as pm,useContext as um}from"react";var Te=pm({ready:!1,authenticated:!1,user:null,walletConnectors:null,connectWallet:w,login:w,linkEmail:w,linkPhone:w,linkWallet:w,linkGoogle:w,linkTwitter:w,linkDiscord:w,linkGithub:w,linkTiktok:w,linkLinkedIn:w,linkApple:w,logout:w,getAccessToken:w,getEthereumProvider:w,getEthersProvider:w,getWeb3jsProvider:w,unlinkEmail:w,unlinkPhone:w,unlinkWallet:w,unlinkGoogle:w,unlinkTwitter:w,unlinkDiscord:w,unlinkGithub:w,unlinkTiktok:w,unlinkLinkedIn:w,unlinkApple:w,setActiveWallet:w,forkSession:w,createWallet:w,signMessage:w,initEnrollmentWithSms:w,initEnrollmentWithTotp:w,init:w,submitEnrollmentWithSms:w,submitEnrollmentWithTotp:w,submit:w,sendTransaction:w,exportWallet:w,setWalletPassword:w,initLoginWithEmail:w,loginWithCode:w}),G=()=>um(Te);import sa from"styled-components";import to,{css as na}from"styled-components";import oa from"styled-components";import{Fragment as hm,jsx as ta,jsxs as fm}from"react/jsx-runtime";var Mn=({success:e,fail:t})=>fm(hm,{children:[ta(Ro,{className:e?"success":t?"fail":""}),ta(ra,{className:e?"success":t?"fail":""})]}),Ro=oa.span`
12
+ - https://privy.io`;this.getNonceOnce=new Qe(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 v("Auth flow has no API instance");try{let{message:t,signature:o}=await this.sign(),r=await this.api.post(ms(),{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 Y(t)}}async link(){if(!this.api)throw new v("Auth flow has no API instance");try{let{message:t,signature:o}=await this.sign();return await this.api.post(hs(),{message:t,signature:o,chainId:this.wallet.chainId,walletClientType:this.wallet.walletClientType,connectorType:this.wallet.connectorType})}catch(t){throw Y(t)}}async sign(){if(!this.api)throw new v("Auth flow has no API instance");if(await this.buildSiweMessage(),!this.preparedMessage)throw new v("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 v("Auth flow has no API instance");let t=this.wallet.address;return(await this.api.post(us(),{address:t})).nonce}async buildSiweMessage(){if(!this.api)throw new v("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.",l=new Date().toISOString();return this.createSiweMessage(t,o,n,i,l,r,a)}};var Ao=class{constructor(t,o){this.meta={phoneNumber:t,captchaToken:o}}async authenticate(){if(!this.api)throw new v("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new v("phone number and sms code must be set prior to calling authenticate.");try{let t=ws(),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 Y(t)}}async link(){if(!this.api)throw new v("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new v("phone number and sms code must be set prior to calling authenticate.");try{let t=Cs();return await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})}catch(t){throw Y(t)}}async sendSmsCode(t,o){if(!this.api)throw new v("Auth flow has no API instance");if(t&&(this.meta.phoneNumber=t),o&&(this.meta.captchaToken=o),!this.meta.phoneNumber)throw new v("phone nNumber must be set when initialzing authentication.");try{let r=vs();return await this.api.post(r,{phoneNumber:this.meta.phoneNumber,token:this.meta.captchaToken})}catch(r){throw Y(r)}}};import{v4 as lm}from"uuid";function He(e){return new Date(e*1e3)}function Eu(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:He(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:He(o.verified_at)};t.push(i);break;case"phone":let a={number:o.phoneNumber,type:o.type,verifiedAt:He(o.verified_at)};t.push(a);break;case"google_oauth":let l={subject:o.subject,email:o.email,name:o.name,type:o.type,verifiedAt:He(o.verified_at)};t.push(l);break;case"twitter_oauth":let s={subject:o.subject,username:o.username,name:o.name,type:o.type,verifiedAt:He(o.verified_at)};t.push(s);break;case"discord_oauth":let c={subject:o.subject,username:o.username,email:o.email,type:o.type,verifiedAt:He(o.verified_at)};t.push(c);break;case"github_oauth":let h={subject:o.subject,username:o.username,name:o.name,email:o.email,type:o.type,verifiedAt:He(o.verified_at)};t.push(h);break;case"tiktok_oauth":let m={subject:o.subject,username:o.username,type:o.type,verifiedAt:He(o.verified_at)};t.push(m);break;case"linkedin_oauth":let g={subject:o.subject,name:o.name,email:o.email,type:o.type,verifiedAt:He(o.verified_at)};t.push(g);break;case"apple_oauth":let f={subject:o.subject,email:o.email,type:o.type,verifiedAt:He(o.verified_at)};t.push(f);break;case"custom_auth":t.push({type:o.type,customUserId:o.custom_user_id,verifiedAt:He(o.verified_at)});break;default:console.warn(`Unrecognized account type: ${r}. Please consider upgrading the Privy SDK.`)}}return t}function ht(e,t){return e.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),e.find(o=>o.type===t)}var Q=e=>e?.linkedAccounts.find(t=>t.type==="wallet"&&t.walletClientType==="privy")||null,xu=e=>e.linkedAccounts.filter(t=>t.type==="wallet"),Yt=(e,t)=>t==="all-users"&&!Q(e)||t==="users-without-wallets"&&!xu(e)?.length;function it(e){if(!e)return null;let t=Eu(e.linked_accounts),o=ht(t,"wallet"),r=ht(t,"email"),n=ht(t,"phone"),i=ht(t,"google_oauth"),a=ht(t,"twitter_oauth"),l=ht(t,"discord_oauth"),s=ht(t,"github_oauth"),c=ht(t,"tiktok_oauth"),h=ht(t,"linkedin_oauth"),m=ht(t,"apple_oauth"),g=e.mfa_methods.map(({type:C,verified_at:P})=>({type:C,verifiedAt:He(P)}));return{id:e.id,createdAt:He(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:l&&{subject:l.subject,username:l.username,email:l.email},github:s&&{subject:s.subject,username:s.username,name:s.name,email:s.email},tiktok:c&&{subject:c.subject,username:c.username},linkedin:h&&{subject:h.subject,name:h.name},apple:m&&{subject:m.subject,email:m.email},mfaMethods:g.map(C=>C.type)}}import{getAddress as yl}from"@ethersproject/address";import rm from"eventemitter3";var Ms="1.47.2";var fn="4df5e2316331463a9130964bd6078dfa",Ns="fe9c30fc-3bc5-4064-91e2-6ab5887f8f4d",Os="34357d3c125c2bcf2ce2bc3309d98715",yn="https://auth.privy.io",Ls=2e4,Ge=1400,Ds=2500,Fi=Ms;var qo="privy:token",Bi="privy-token",gn="privy:refresh_token",Hi="privy-refresh-token",Us="privy-session",Pr="privy:session_transfer_token",Tu="privy:wallet",Tr="privy:caid",vn=e=>`${Tu}:${e}`,Gi="privy:connectors",zi="privy:connections";var Sr=12e4,ft=1,$i="0x1",jo=3e4,Fs="https://api.moonpay.com/v1",Bs="https://api.moonpay.com/v1",Hs="pk_live_hirbpu0cVcLHrjktC9l7fbc9ctjv0SL",Gs="pk_test_fqWjXZMSFwloh7orvJsRfjiUHXJqFzI";var Vi=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)}},qi=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 Su(){return typeof window<"u"&&window.localStorage?new qi:new Vi}var z=Su();import{isPossiblePhoneNumber as _u}from"libphonenumber-js/min";var wn=()=>{let e=window;if(!e.ethereum)return!1;if(_r(window.ethereum,!0))return!0;if(e.ethereum.providers){for(let t of e.ethereum.providers)if(_r(t,!0))return!0}return!1},Ar=()=>{let e=window;if(!e.ethereum)return!1;if(_r(window.ethereum,!1))return!0;if(e.ethereum.providers){for(let t of e.ethereum.providers)if(_r(t,!1))return!0}return!!window.ethereum.isZerion},_r=(e,t)=>{if(!e.isMetaMask)return!1;if(e.isMetaMask&&!t)return!0;if(e.isBraveWallet&&!e._events&&!e._state||e.isApexWallet||e.isAvalanche||e.isBitKeep||e.isBlockWallet||e.isKuCoinWallet||e.isMathWallet||e.isOkxWallet||e.isOKExWallet||e.isOneInchIOSWallet||e.isOneInchAndroidWallet||e.isOpera||e.isPhantom||e.isPortal||e.isRabby||e.isRainbow||e.isTokenPocket||e.isTokenary||e.isZerion)return!1;if(e.providers){for(let o of e.providers)if(!_r(o))return!1}return!0},Ze=()=>!!("phantom"in window&&window?.phantom?.ethereum?.isPhantom),Cn=()=>{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.isCoinbaseWallet)return!0}return!1};var zs=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,}))$/),$s=e=>_u(String(e),"US"),Vs=(e,t)=>{let o=e.slice(0),r=[];for(;o.length;)r.push(o.splice(0,t));return r},Jt=(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}`},ji=e=>new Promise(t=>setTimeout(t,e));function qs(e,{interval:t=100,timeout:o=5e3}={}){return new Promise((r,n)=>{let i=0,a,l=()=>{if(i>=o){n("Max attempts reached without result");return}if(a=e(),i+=t,a!=null){r(a);return}setTimeout(l,t)};l()})}var js=(e,t={})=>{let o=t.delayMs||150,r=t.maxAttempts||270;return new Promise(async(n,i)=>{let a=!1,l=0;for(;!a&&l<r;){if(t.abortSignal?.aborted)return;e().then(()=>{a=!0,n()},(...s)=>{a=!0,i(...s)}),l+=1,await ji(o)}a||i(new Error("Exceeded max attempts before resolving function"))})},bn=(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 Ki=e=>e.replace(/([\u2700-\u27BF]|[\uE000-\uF8FF]|\uD83C[\uDC00-\uDFFF]|\uD83D[\uDC00-\uDFFF]|[\u2011-\u26FF]|\uD83E[\uDD10-\uDDFF])/g,""),ko=e=>typeof e=="string"?e:"0x"+e.toString(16);async function Ks(e=3e3){let t=!1,o=window;return new Promise(r=>{o.ethereum?n():(window.addEventListener("ethereum#initialized",n,{once:!0}),setTimeout(()=>{n()},e));function n(){if(t)return;t=!0,window.removeEventListener("ethereum#initialized",n);let i=[];wn()&&i.push("metamask"),Ze()&&i.push("phantom"),o.ethereum&&o.ethereum.isBraveWallet&&i.push("brave"),r(i)}})}function Ko(e){return`eip155:${String(Number(e))}`}var at=(e,t,o)=>{let r=Number(e),n=t.find(a=>a.id===r);if(!n)throw new B(`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]+"/"+fn:n.rpcUrls.blast?.http[0]?i=n.rpcUrls.blast.http[0]+"/"+Ns:i=n.rpcUrls.default?.http[0],!i)throw new B(`No RPC url found for ${e}`);return i},Ys=(e,t)=>{let o=Number(e),r=t.find(n=>n.id===o);if(!r)throw new B(`Unsupported chainId ${e}`,4901);return r.blockExplorers?.default.url};import Du from"@coinbase/wallet-sdk";import{jsx as Js,jsxs as Au}from"react/jsx-runtime";var Qt=({style:e,...t})=>Au("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:[Js("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),Js("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 wt}from"@ethersproject/address";import{Web3Provider as ol}from"@ethersproject/providers";import{default as Ou}from"eventemitter3";import{StaticJsonRpcProvider as Zs}from"@ethersproject/providers";import Nu from"eventemitter3";var ku=["eth_sign","eth_populateTransactionRequest","eth_signTransaction","personal_sign","eth_signTypedData_v4"],Qs=e=>ku.includes(e);import{ErrorCode as Ru}from"@ethersproject/logger";var Yo=class extends B{constructor(){super("Wallet timeout");this.type="wallet_error"}},Jo=class extends B{constructor(){super("User rejected connection");this.type="wallet_error"}},gt=e=>{if(e instanceof B)return e;if(e?.code&&e?.reason){let t=new Te(e);return e.code===Ru.ACTION_REJECTED&&(t.details=Ne.E4001_USER_REJECTED_REQUEST),t}return e?.code?new Te(e):new B("Unknown connector error",e)},yt=class extends Ue{constructor(o,r,n){super(o);this.type="provider_error";this.code=r,this.data=n}},Te=class extends yt{constructor(o){let r=o;super(r.message,r.code,r.data);let n=Object.values(Ne).find(i=>i.eipCode===r.code);this.details=n||Ne.UNKNOWN_ERROR,r.code===-32002&&(r.message?.includes("already pending for origin")?r.message?.includes("wallet_requestPermissions")?this.details=Ne.E32002_CONNECTION_ALREADY_PENDING:this.details=Ne.E32002_REQUEST_ALREADY_PENDING:r.message?.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=Ne.E32002_WALLET_LOCKED))}},Iu={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}},Wu={E32002_CONNECTION_ALREADY_PENDING:{eipCode:-32002,message:"Connection request already pending",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E32002_REQUEST_ALREADY_PENDING:{eipCode:-32002,message:"Resource request already pending",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E32002_WALLET_LOCKED:{eipCode:-32002,message:"Wallet might be locked",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E4001_USER_REJECTED_REQUEST:{eipCode:4001,message:"Signature rejected",detail:"Please try signing again.",retryable:!0}},Mu={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}},Ne={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Mu,...Wu},Rt={...Iu,...Ne};var Z=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 Yo,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||Sr,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 B(`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 gt(o)})}},Zt=class extends Error{constructor(o,r,n){super(o);this.code=r,this.data=n}},En=class extends Nu{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 Zs(at(a,this.chains,n)),this.rpcTimeoutDuration=Qo(n,"privy")}async handleSendTransaction(o){if(!o.params||!Array.isArray(o.params))throw new Zt(`Invalid params for ${o.method}`,4200);let r=o.params[0];if(!await ze()||!this.address)throw new Zt("Disconnected",4900);return(await el(r)).hash}handleSwitchEthereumChain(o){if(!o.params||!Array.isArray(o.params))throw new Zt(`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 Zt(`Invalid params for ${o.method}`,4200);this.chainId=Number(r),this.provider=new Zs(at(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 Xs(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:ko(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 ko(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(Qs(o.method)){let r=await ze();if(await tl(),!r||!this.address)throw new Zt("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 Zt("Disconnected",4900)}}else return this.provider.send(o.method,o.params)}async connect(){let o=await ze();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}}},vt=class extends Z{constructor(o){super(o,o.rpcTimeoutDuration)}},Xt=class extends Z{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 Lu=(e,t)=>{switch(t){case"coinbase_wallet":return e.message.includes("addEthereumChain");default:return e.code===4902||e.message?.includes("4902")}},$e=class extends Ou{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=Ko(o),this.walletClientType==="privy"&&z.put(vn(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=Qo(i,o),this.connected=!1,this.initialized=!1}buildConnectedWallet(o,r){let n=async()=>!!this.wallets.find(i=>wt(i.address)===wt(o));return{address:wt(o),chainId:r,switchChain:async i=>{if(!n)throw new B("Wallet is not currently connected.");let a=this.wallets.find(m=>wt(m.address)===wt(o))?.chainId;if(!a)throw new B("Unable to determine current chainId.");let l,s;if(typeof i=="number"?(l=`0x${i.toString(16)}`,s=i):(l=i,s=Number(i)),a===Ko(l))return;let c=this.chains.find(m=>m.id===s);if(!c)throw new B(`Unsupported chainId: ${i}`);let h=async()=>{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:l}]})};try{return await h()}catch(m){if(Lu(m,this.walletClientType))return await this.proxyProvider.request({method:"wallet_addEthereumChain",params:[{chainId:l,chainName:c.name,nativeCurrency:c.nativeCurrency,rpcUrls:[c.rpcUrls.public?.http[0]??""],blockExplorerUrls:[c.blockExplorers?.default.url??""]}]}),h();throw this.walletClientType==="rainbow"&&m.message?.includes("wallet_switchEthereumChain")?new B(`Rainbow does not support the chainId ${r}`):m}},connectedAt:Date.now(),walletClientType:this.walletClientType,connectorType:this.connectorType,isConnected:n,getEthereumProvider:async()=>{if(!await n())throw new B("Wallet is not currently connected.");return this.proxyProvider},getEthersProvider:async()=>{if(!await n())throw new B("Wallet is not currently connected.");return new ol(new vt(this.proxyProvider))},getWeb3jsProvider:async()=>{if(!await n())throw new B("Wallet is not currently connected.");return new Xt(this.proxyProvider)},sign:async i=>{if(!await n())throw new B("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=wt(n),a=[],l;if(this.walletClientType==="privy"){let c=z.get(vn(i));this.chains.find(h=>h.id===Number(c))||(z.del(vn(i)),c=null),l=c||`0x${this.defaultChain.id.toString(16)}`;try{await this.proxyProvider.request({method:"wallet_switchEthereumChain",params:[{chainId:l}]})}catch{console.warn(`Unable to switch embedded wallet to chain ID ${l} on initialization`)}}else try{let c=await this.proxyProvider.request({method:"eth_chainId"});if(typeof c=="string")l=c;else if(typeof c=="number")l=`0x${c.toString(16)}`;else throw new Error("Invalid chainId returned from provider")}catch(c){console.warn(`Failed to get chainId from provider, defaulting to ${$i}`,c),l=$i}let s=Ko(l);a.find(c=>wt(c.address)===i)||a.push(this.buildConnectedWallet(wt(n),s)),xn(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=>wt(n)===wt(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 ol(new vt(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 Uu=e=>{let t=`https://mainnet.infura.io/v3/${fn}`,o=1;return e.makeWeb3Provider(t,o)},Pn,Tn=class extends $e{constructor(o,r,n){super("coinbase_wallet",o,r,n);this.connectorType="coinbase_wallet";this.proxyProvider=new Z(void 0,this.rpcTimeoutDuration),this.subscribeListeners(),Pn||(Pn=new Du({appName:"Privy",darkMode:!1,headlessMode:!1,enableMobileWalletLink:!0})),this.proxyProvider.setWalletProvider(Uu(Pn)),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(){Pn.disconnect()}get walletBranding(){return{name:"Coinbase Wallet",icon:Qt}}async promptConnection(){try{let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new B("Unable to retrieve accounts");this.connected=!0,await this.syncAccounts([o[0]])}catch(o){throw gt(o)}}};import{jsx as rl}from"react/jsx-runtime";var Zo=({...e})=>rl("svg",{width:"15",height:"15",viewBox:"0 0 15 15",fill:"none",xmlns:"http://www.w3.org/2000/svg",...e,children:rl("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 Sn=class extends $e{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:[ko(o?.chainId||"0x1")]}),this.getConnectedWallet()):null}get walletBranding(){return{name:"Privy Wallet",icon:Zo}}disconnect(){this.connected=!1}async promptConnection(){}};import{getAddress as CC}from"@ethersproject/address";import{Web3Provider as EC}from"@ethersproject/providers";import{isMobile as Bu}from"react-device-detect";import{jsx as Ve,jsxs as Fu}from"react/jsx-runtime";var qe=({style:e,...t})=>Fu("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:[Ve("style",{children:".s1{stroke-linecap:round;stroke-linejoin:round}.s2{fill:#e4761b;stroke:#e4761b}.s3{fill:#f6851b;stroke:#f6851b}"}),Ve("path",{fill:"#e2761b",stroke:"#e2761b",className:"s1",d:"m274.1 35.5-99.5 73.9L193 65.8z"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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"}),Ve("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 _n=class extends $e{constructor(o,r,n){super("metamask",o,r,n);this.connectorType="injected";this.proxyProvider=new Z(void 0,this.rpcTimeoutDuration),this.subscribeListeners();let i=window,a=i.ethereum,l=i.ethereum.providers||[];for(let s of l)if(s.isMetaMask){a=s;break}this.proxyProvider.setWalletProvider(a),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:"MetaMask",icon:qe}}disconnect(){console.warn("Metamask does not support programmatic disconnect.")}async promptConnection(){try{!Bu&&wn()&&await this.proxyProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]});let o=await this.proxyProvider.request({method:"eth_requestAccounts"});if(!o||o.length===0||!o[0])throw new B("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw gt(o)}}};import{jsx as nl,jsxs as Hu}from"react/jsx-runtime";var Ct=({style:e,...t})=>Hu("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:[nl("rect",{width:"108",height:"108",rx:"23",fill:"#AB9FF2"}),nl("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 An=class extends $e{constructor(o,r,n){super("phantom",o,r,n);this.connectorType="injected";this.proxyProvider=new Z(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:Ct}}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 B("Unable to retrieve accounts");await this.syncAccounts([o[0]])}catch(o){throw gt(o)}}};import{EthereumProvider as Zu,OPTIONAL_EVENTS as Xu,OPTIONAL_METHODS as em}from"@walletconnect/ethereum-provider";import Qi from"@walletconnect/qrcode-modal";import{isAndroid as tm,isMobile as om}from"react-device-detect";import{createContext as zu,useContext as $u,useEffect as Yi,useRef as Vu,useState as al}from"react";import{jsx as Gu}from"react/jsx-runtime";function il(e){return Gu("link",{rel:"prefetch",href:e.src})}var w=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};import{jsx as qu,jsxs as ju}from"react/jsx-runtime";var st="LANDING",sl=zu({ready:!1,app:null,currentScreen:st,lastScreen:st,navigate:w,navigateBack:w,resetNavigation:w,setModalData:w,onUserCloseViaDialogOrKeybindRef:void 0}),ll=e=>{let t=e.appConfig,o=e.authenticated,r=e.visible,[n,i]=al(e.initialScreen||st),[a,l]=al(e.initialScreen||st);Yi(()=>{o||i(st)},[o]),Yi(()=>{r||(l(st),i(st))},[r]),Yi(()=>{e.initialScreen&&n===st&&(i(e.initialScreen),l(e.initialScreen))},[e.initialScreen]);let s=e.initialScreen&&n===st?e.initialScreen:n,c=Vu(null),h={ready:!!t?.id,app:t,data:e.data,setModalData:e.setModalData,currentScreen:s,lastScreen:a,navigate:m=>{l(n),i(m)},navigateBack:()=>{i(a)},resetNavigation:()=>{e.setInitialScreen(null),l(st),i(st)},onUserCloseViaDialogOrKeybindRef:c};return ju(sl.Provider,{value:h,children:[(typeof t?.appearance?.logo=="string"||t?.appearance?.logo?.type==="img")&&qu(il,{src:typeof t.appearance.logo=="string"?t.appearance.logo:t.appearance.logo.props.src}),e.children]})},b=()=>$u(sl);import{jsx as Xo,jsxs as Ku}from"react/jsx-runtime";var er=({style:e,...t})=>{let{app:o}=b();return Ku("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:[Xo("rect",{width:"28",height:"28",rx:"3",fill:o?.appearance.palette.colorScheme==="dark"?"#3396ff":"#141414"}),Xo("g",{clipPath:"url(#clip0_1765_9946)",children:Xo("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"})}),Xo("defs",{children:Xo("clipPath",{id:"clip0_1765_9946",children:Xo("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]})};import{isAndroid as dl,isDesktop as Yu,isMobileOnly as Ju}from"react-device-detect";var kn=e=>{let t;try{t=new URL(e).hostname}catch{return}for(let[o,r]of Object.entries(pl))if(t.includes(r.hostname))return{walletClientType:o,entry:r}};var pl={metamask:{id:"c57ca95b47569778a828d19178114f4db188b89b763c899ba0be274e97267d96",displayName:"MetaMask",hostname:"metamask.io",mobile:{native:"metamask:"}},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:{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:{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 Ji(e){return{name:e.displayName||"",universalLink:e.mobile.universal||"",deepLink:e.mobile.native||""}}function Qu(e){let t="mobile";return Object.values(e).filter(o=>!!o[t].universal||!!o[t].native).map(o=>Ji(o))}function ul(){return Qu(pl)}function ml(e,t){let o=encodeURIComponent(e);return t.universalLink?`${t.universalLink}/wc?uri=${o}`:t.deepLink?`${t.deepLink}${t.deepLink.endsWith(":")?"//":"/"}wc?uri=${e}`:""}function hl(e,t){return dl?e:ml(e,Ji(t))}var fl="WALLETCONNECT_DEEPLINK_CHOICE";function cl(e){let t=e.href.split("?")[0];z.put(fl,{...e,href:t})}var kr=(e,t)=>{if(!e||Yu){z.del(fl);return}if(dl){cl({name:"Unknown",href:t||"wc:"});return}else if(Ju){let o=ml(t||"wc:",Ji(e));cl({name:e?.displayName||"",href:o})}};var Rr=class extends $e{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 Z(void 0,this.rpcTimeoutDuration),this.createProvider().then(l=>{if(this.provider=l,this.proxyProvider.setWalletProvider(l),this.subscribeListeners(),l.session){if(this.walletProvider.session?.peer.metadata.url){let s=kn(this.walletProvider.session?.peer.metadata.url);this.walletEntry=s?.entry,this.walletClientType=s?.walletClientType||"unknown",kr(this.walletEntry)}this.connected=!0,this.syncAccounts().then(()=>{this.emit("initialized"),this.initialized=!0})}else this.emit("initialized"),this.initialized=!0})}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:qe}:{name:Ki(this.walletProvider.session?.peer.metadata.name||"")||"WalletConnect",icon:this.walletProvider.session?.peer.metadata.icons?.[0]||er}}resetConnection(){this.walletProvider&&this.walletProvider.connected&&(this.walletProvider.signer.session=void 0,this.walletEntry=void 0,kr(void 0),this.onDisconnect())}async promptConnection(){if(this.provider)return new Promise((o,r)=>{let n=()=>{r(new Jo)};this.onQrModalClosed=n,(async()=>{let a="",l=await Promise.race([this.walletProvider.enable(),this.proxyProvider.walletTimeout()]);if(l.length>0&&(a=l[0]),!a||a==="")throw new B("Unable to retrieve address");if(this.walletProvider.session?.peer.metadata.url){let s=kn(this.walletProvider.session?.peer.metadata.url);this.walletEntry=s?.entry,this.walletClientType=s?.walletClientType||"unknown",this.proxyProvider.rpcTimeoutDuration=Qo(this.rpcConfig,this.walletClientType)}this.connected=!0,await this.syncAccounts(l),o()})().catch(a=>{if(a){r(gt(a));return}r(new B("Unknown error during connection"))}).finally(()=>Qi.close())})}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=at(n.id,this.chains,this.rpcConfig);i&&(o[n.id]=i)}let r=await Zu.init({projectId:this.walletConnectCloudProjectId,chains:[this.defaultChain.id],optionalChains:this.chains.map(n=>n.id),optionalEvents:Xu,optionalMethods:em,rpcMap:o,showQrModal:!1});return r.on("display_uri",n=>{if(tm)window.open(n,"_self");else if(om&&this.walletEntry){kr(this.walletEntry,n);let a=hl(n,this.walletEntry);window.open(a,"_self","noopener,noreferrer")}else Qi.open(n,()=>{this.onQrModalClosed&&this.onQrModalClosed()},{mobileLinks:ul().map(i=>i.name)})}),r.on("connect",()=>{if(Qi.close(),r.session?.peer.metadata.url){let n=kn(r.session?.peer.metadata.url);this.walletEntry=n?.entry,this.walletClientType=n?.walletClientType||"unknown",kr(this.walletEntry)}}),r}async enableProvider(){return this.walletProvider.connected?Promise.resolve(this.walletProvider.accounts):await this.walletProvider.enable()}};var Zi=e=>{let t=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return t?!!e?.linkedAccounts.filter(r=>r.type=="wallet"&&r.address===yl(t)).length:!1},Qo=(e,t)=>e.rpcTimeouts?e.rpcTimeouts[t]||Sr:Sr,Ir=class extends rm{constructor(o,r,n,i){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 Z:r.proxyProvider};this.walletConnectCloudProjectId=o,this.rpcConfig=r,this.chains=n,this.defaultChain=i,this.walletConnectors=[],this.initialized=!1,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(Gi)&&(z.getKeys().forEach(o=>{o.startsWith("walletconnect")&&z.del(o)}),z.del(Gi)),Ks().then(o=>o.forEach(r=>{switch(r){case"metamask":this.createWalletConnector("injected","metamask");break;case"phantom":this.createWalletConnector("injected","phantom");break;case"unknown":default:break}})),(Cn()||z.getKeys().find(o=>o.startsWith("-walletlink")))&&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 En(o,r,this.rpcConfig,this.chains,n.id),l=new Sn(a,this.chains,n,this.rpcConfig);this.addWalletConnector(l)}}removeEmbeddedWalletConnector(){let o=this.findWalletConnector("embedded","privy");if(o){let r=this.walletConnectors.indexOf(o);this.walletConnectors.splice(r,1),this.saveConnectionHistory(),this.emit("walletsUpdated")}}async createWalletConnector(o,r){let n=this.findWalletConnector(o,r);if(n)return n instanceof Rr&&n.resetConnection(),n;let a=(()=>{switch(o){case"injected":switch(r){case"phantom":return Ze()?new An(this.chains,this.defaultChain,this.rpcConfig):null;case"metamask":default:return Ar()?new _n(this.chains,this.defaultChain,this.rpcConfig):null}case"coinbase_wallet":return new Tn(this.chains,this.defaultChain,this.rpcConfig);case"wallet_connect_v2":return new Rr(this.walletConnectCloudProjectId,this.rpcConfig,this.chains,this.defaultChain)}})();return a&&this.addWalletConnector(a),a||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(zi);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(zi,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=yl(o),this.emit("walletsUpdated")}};function xn(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 nm}from"ofetch";var im=[un(),hn(),mn()],am=e=>{let t=new AbortController;return setTimeout(()=>t.abort(),e),t.signal},Rn=class{constructor(t,o,r){this.appId=t,this.clientAnalyticsId=o.clientAnalyticsId,this.sdkVersion=Fi,this.client=o,this.defaults=r,this.fallbackApiUrl=o.fallbackApiUrl,this.baseFetch=nm.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 l=!im.includes(n.toString());if(!a.has("authorization")&&l){let s=await this.client.getAccessToken();s!==null&&a.set("authorization",`Bearer ${s}`)}i.headers=a,i.signal||(i.signal=am(this.defaults.timeout))},onRequestError:({error:n})=>{if(n instanceof DOMException&&n.name==="AbortError")throw new dn}})}async get(t,o){try{return await this.baseFetch(t,o)}catch(r){throw Y(r)}}async post(t,o,r){try{return await this.baseFetch(t,{method:"POST",...o?{body:o}:{},...r})}catch(n){throw Y(n)}}async delete(t,o){try{return await this.baseFetch(t,{method:"DELETE",...o})}catch(r){throw Y(r)}}};import Wr from"js-cookie";function gl(e){return e instanceof So?"email":e instanceof Ao?"sms":e instanceof _o?"siwe":e instanceof Vo?"custom_auth":e instanceof jt?e.meta.provider:null}import*as vl from"jose";var bt=class{static parse(t){try{return new bt(t)}catch{return null}}constructor(t){this.value=t,this._decoded=vl.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 sm=30,In=class{constructor(){this.authenticateOnce=new Qe(async t=>this._authenticate(t)),this.linkOnce=new Qe(async t=>this._link(t)),this.refreshOnce=new Qe(this._refresh.bind(this)),this.destroyOnce=new Qe(this._destroy.bind(this)),this.forkSessionOnce=new Qe(this._forkSession.bind(this))}get token(){try{let t=z.get(qo);return typeof t=="string"?new bt(t).value:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get refreshToken(){try{let t=z.get(gn);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get forkedToken(){try{let t=z.get(Pr);return typeof t=="string"?t:null}catch(t){return console.error(t),this.destroyLocalState(),null}}get mightHaveServerCookies(){try{let t=Wr.get(Us);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=bt.parse(this.token);return t!==null&&!t.isExpired(sm)}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=gl(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:it(n),isNewUser:i}}catch(o){throw console.warn("Error authenticating session"),Be(o)}}async _link(t){try{let o=await t.link();return it(o)}catch(o){throw console.warn("Error linking account"),Be(o)}}async _refresh(){if(!this.api)throw new v("Session has no API instance");if(!this.client)throw new v("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(un(),a,{headers:i}),r&&this.clearForkedToken()}else if(r)n=await this.api.post(hn(),{refresh_token:r}),this.clearForkedToken();else return null;return this.storeToken(n.token),this.storeRefreshToken(n.refresh_token),it(n.user)}catch(n){if(n instanceof $o&&n.privyErrorCode==="missing_or_invalid_token")return console.warn("Unable to refresh tokens - token is missing or no longer valid"),this.destroyLocalState(),null;throw Be(n)}}async _destroy(){try{await this.api?.post(mn(),{refresh_token:this.refreshToken})}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new v("Session has no API instance");let t=this.refreshToken;try{let o=await this.api.post(ps(),{refresh_token:t});return this.storeToken(o.token),this.storeRefreshToken(o.refresh_token),o.new_session_refresh_token}catch(o){throw Be(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),this.clearForkedToken()}storeToken(t){if(typeof t=="string"){if(z.put(qo,t),!this.client?.useServerCookies){let o=bt.parse(t)?.expiration;Wr.set(Bi,t,{sameSite:"Strict",secure:!0,expires:o?new Date(o*1e3):void 0})}}else z.del(qo),Wr.remove(Bi)}storeRefreshToken(t){typeof t=="string"?(z.put(gn,t),this.client?.useServerCookies||Wr.set(Hi,t,{sameSite:"Strict",secure:!0,expires:30})):(z.del(gn),Wr.remove(Hi))}clearForkedToken(){z.del(Pr)}};var Xi,Wn,wl,Mr=class{constructor(t){cs(this,Wn);this.apiUrl=t.apiUrl||yn,this.fallbackApiUrl=this.apiUrl,this.useServerCookies=!1,this.timeout=t.timeout||Ls,this.appId=t.appId,this.clientAnalyticsId=ds(this,Wn,wl).call(this),Xi||(Xi=new In),this.session=Xi,this.api=this.generateApi(),this.session.client=this}initializeConnectorManager(t,o,r,n){this.connectors||(this.connectors=new Ir(t,o,r,n))}generateApi(){let t=new Rn(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 v("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new v("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(Ts(),{address:t});return it(o)}catch(o){throw Be(o)}}async unlinkPhone(t){try{let o=await this.api.post(Ss(),{phoneNumber:t});return it(o)}catch(o){throw Be(o)}}async unlinkWallet(t){try{let o=await this.api.post(Ps(),{address:t});return it(o)}catch(o){throw Be(o)}}async unlinkOAuth(t,o){try{let r=await this.api.post(_s(),{provider:t,subject:o});return it(r)}catch(r){throw Be(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(As(),{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(ks(),t)}catch(o){throw Be(o)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()||this.session.hasRecoveryCredentials()?this.session.refresh():null}async getAccessToken(t){return this.session.hasActiveToken()?bt.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)}}catch(t){throw Be(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()}};Wn=new WeakSet,wl=function(){if(typeof window>"u")return null;try{let o=z.get(Tr);if(typeof o=="string"&&o.length>0)return o}catch{}let t=lm();try{return z.put(Tr,t),t}catch{return t}};import"wicg-inert";import{disableBodyScroll as ow,clearAllBodyScrollLocks as rw}from"body-scroll-lock";import{useRef as nw,useCallback as iw}from"react";import{useEffect as Np}from"react";import aw from"react-dom";import es from"styled-components";import{createContext as cm,useContext as dm}from"react";var ea=cm({isNewUserThisSession:!1,isLinking:!1,linkingHint:null,walletConnectionStatus:null,rpcConfig:{rpcUrls:{}},showFiatPrices:!0,chains:[],clientAnalyticsId:null,nativeTokenSymbolForChainId:w,initializeWalletProxy:w,getAuthMeta:w,getAuthFlow:w,closePrivyModal:w,connectWallet:w,initLoginWithWallet:w,loginWithWallet:w,loginWithCode:w,initLoginWithEmail:w,initLoginWithSms:w,resendEmailCode:w,resendSmsCode:w,initLoginWithOAuth:w,loginWithOAuth:w,refreshUser:w,walletProxy:null,createAnalyticsEvent:w,getUsdTokenPrice:w,recoverEmbeddedWallet:w,getFiatOnRampConfig:w,updateWallets:w}),_=()=>dm(ea);import{createContext as pm,useContext as um}from"react";var Se=pm({ready:!1,authenticated:!1,user:null,walletConnectors:null,connectWallet:w,login:w,linkEmail:w,linkPhone:w,linkWallet:w,linkGoogle:w,linkTwitter:w,linkDiscord:w,linkGithub:w,linkTiktok:w,linkLinkedIn:w,linkApple:w,logout:w,getAccessToken:w,getEthereumProvider:w,getEthersProvider:w,getWeb3jsProvider:w,unlinkEmail:w,unlinkPhone:w,unlinkWallet:w,unlinkGoogle:w,unlinkTwitter:w,unlinkDiscord:w,unlinkGithub:w,unlinkTiktok:w,unlinkLinkedIn:w,unlinkApple:w,setActiveWallet:w,forkSession:w,createWallet:w,signMessage:w,initEnrollmentWithSms:w,initEnrollmentWithTotp:w,init:w,submitEnrollmentWithSms:w,submitEnrollmentWithTotp:w,submit:w,cancel:w,sendTransaction:w,exportWallet:w,setWalletPassword:w,initLoginWithEmail:w,loginWithCode:w}),G=()=>um(Se);import sa from"styled-components";import to,{css as na}from"styled-components";import oa from"styled-components";import{Fragment as hm,jsx as ta,jsxs as fm}from"react/jsx-runtime";var Mn=({success:e,fail:t})=>fm(hm,{children:[ta(Ro,{className:e?"success":t?"fail":""}),ta(ra,{className:e?"success":t?"fail":""})]}),Ro=oa.span`
13
13
  && {
14
14
  width: 82px;
15
15
  height: 82px;
@@ -494,7 +494,7 @@ Resources:
494
494
  h3 {
495
495
  margin-bottom: 24px;
496
496
  }
497
- `;import{Fragment as ca,jsx as de,jsxs as no}from"react/jsx-runtime";var da=6,Ll=new Array(da).fill(""),Lm=1400;var Ul=()=>{let{app:e,navigate:t,setModalData:o}=b(),{closePrivyModal:r,resendEmailCode:n,resendSmsCode:i,getAuthMeta:a,loginWithCode:l,updateWallets:s}=_(),{authenticated:c,user:h}=G(),[m,g]=Gn(Ll),[f,C]=Gn(!1),[P,E]=Gn(null),[x,k]=Gn(null),N=a()?.email?0:1,I=e?.render.inDialog?Ge:0,R=e?.render.inDialog?I-500:0;Ol(()=>{if(c&&f&&h)if(Yt(h,e?.embeddedWallets?.createOnLogin)){let H=setTimeout(()=>{o({createWallet:{onSuccess:()=>{},onFailure:J=>console.error(J),callAuthOnSuccessOnClose:!0}}),t("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")},R);return()=>clearTimeout(H)}else{s();let H=setTimeout(r,I);return()=>clearTimeout(H)}},[c,f,h]),Ol(()=>{if(P&&x===0){let q=setTimeout(()=>{g(Ll),E(null),document.querySelector("input[name=code-0]")?.focus()},Lm);return()=>clearTimeout(q)}},[P]);let M=q=>{let H=q.currentTarget.value.replace(" ","");if(H==="")return;if(isNaN(Number(H))){E("Code should be numeric"),k(1);return}E(null),k(null);let J=Number(q.currentTarget.name?.charAt(5)),U=[...H||[""]].slice(0,da-J),Ie=[...m.slice(0,J),...U,...m.slice(J+U.length)];g(Ie);let re=U.length,V=Math.min(Math.max(J+re,0),da-1);isNaN(Number(q.currentTarget.value))||document.querySelector(`input[name=code-${V}]`)?.focus(),Ie.every(Ce=>Ce&&!isNaN(+Ce))&&(document.querySelector(`input[name=code-${V}]`)?.blur(),l(Ie.join("")).then(()=>C(!0)).catch(le=>{le?.status===422?E("Invalid or expired verification code"):E("Issue verifying code"),k(0)})),q.preventDefault()},A=q=>{x===1&&(E(null),k(null));let H=[...m.slice(0,q),"",...m.slice(q+1)];g(H),q>0&&document.querySelector(`input[name=code-${q-1}]`)?.focus()},te=N==0?de(Mm,{color:"var(--privy-color-accent)",strokeWidth:2,height:"48px",width:"48px"}):de(Nm,{color:"var(--privy-color-accent)",strokeWidth:2,height:"40px",width:"40px"}),O=N==0?no("p",{children:["Please check ",de(Dl,{children:a()?.email})," for an email from privy.io and enter your code below."]}):no("p",{children:["Please check ",de(Dl,{children:a()?.phoneNumber})," for a message from ",e?.name||"Privy"," and enter your code below."]});return no(ca,{children:[de(T,{},"header"),de(S,{}),no(Dm,{children:[de(he,{title:"Enter confirmation code",description:O,icon:te}),no(El,{children:[no(Um,{children:[de(Fm,{fail:!!P,success:f,children:de("span",{children:P||(f?"Success!":"")})}),de("div",{children:m.map((q,H)=>de("input",{name:`code-${H}`,type:"text",value:m[H],onChange:M,onKeyUp:J=>{J.key==="Backspace"&&A(H)},inputMode:"numeric",autoFocus:H===0,pattern:"[0-9]",className:`${f?"success":""} ${P?"fail":""}`,autoComplete:Om?"one-time-code":"off"},H))})]}),de(Bm,{children:N==0?no(ca,{children:[de("span",{children:"Didn't get an email?"}),de("button",{onClick:n,children:"Resend Code"})]}):no(ca,{children:[de("span",{children:"Didn't get a message?"}),de("button",{onClick:i,children:"Resend Code"})]})})]})]}),de(W,{}),de(F,{protectedByPrivy:!0})]})},Dm=Or.div`
497
+ `;import{Fragment as ca,jsx as de,jsxs as no}from"react/jsx-runtime";var da=6,Ll=new Array(da).fill(""),Lm=1400;var Ul=()=>{let{app:e,navigate:t,setModalData:o}=b(),{closePrivyModal:r,resendEmailCode:n,resendSmsCode:i,getAuthMeta:a,loginWithCode:l,updateWallets:s}=_(),{authenticated:c,user:h}=G(),[m,g]=Gn(Ll),[f,C]=Gn(!1),[P,E]=Gn(null),[x,k]=Gn(null),N=a()?.email?0:1,I=e?.render.inDialog?Ge:0,R=e?.render.inDialog?I-500:0;Ol(()=>{if(c&&f&&h)if(Yt(h,e?.embeddedWallets?.createOnLogin)){let H=setTimeout(()=>{o({createWallet:{onSuccess:()=>{},onFailure:J=>console.error(J),callAuthOnSuccessOnClose:!0}}),t("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")},R);return()=>clearTimeout(H)}else{s();let H=setTimeout(r,I);return()=>clearTimeout(H)}},[c,f,h]),Ol(()=>{if(P&&x===0){let q=setTimeout(()=>{g(Ll),E(null),document.querySelector("input[name=code-0]")?.focus()},Lm);return()=>clearTimeout(q)}},[P]);let M=q=>{let H=q.currentTarget.value.replace(" ","");if(H==="")return;if(isNaN(Number(H))){E("Code should be numeric"),k(1);return}E(null),k(null);let J=Number(q.currentTarget.name?.charAt(5)),U=[...H||[""]].slice(0,da-J),We=[...m.slice(0,J),...U,...m.slice(J+U.length)];g(We);let re=U.length,V=Math.min(Math.max(J+re,0),da-1);isNaN(Number(q.currentTarget.value))||document.querySelector(`input[name=code-${V}]`)?.focus(),We.every(Ce=>Ce&&!isNaN(+Ce))&&(document.querySelector(`input[name=code-${V}]`)?.blur(),l(We.join("")).then(()=>C(!0)).catch(le=>{le?.status===422?E("Invalid or expired verification code"):E("Issue verifying code"),k(0)})),q.preventDefault()},A=q=>{x===1&&(E(null),k(null));let H=[...m.slice(0,q),"",...m.slice(q+1)];g(H),q>0&&document.querySelector(`input[name=code-${q-1}]`)?.focus()},te=N==0?de(Mm,{color:"var(--privy-color-accent)",strokeWidth:2,height:"48px",width:"48px"}):de(Nm,{color:"var(--privy-color-accent)",strokeWidth:2,height:"40px",width:"40px"}),O=N==0?no("p",{children:["Please check ",de(Dl,{children:a()?.email})," for an email from privy.io and enter your code below."]}):no("p",{children:["Please check ",de(Dl,{children:a()?.phoneNumber})," for a message from ",e?.name||"Privy"," and enter your code below."]});return no(ca,{children:[de(T,{},"header"),de(S,{}),no(Dm,{children:[de(he,{title:"Enter confirmation code",description:O,icon:te}),no(El,{children:[no(Um,{children:[de(Fm,{fail:!!P,success:f,children:de("span",{children:P||(f?"Success!":"")})}),de("div",{children:m.map((q,H)=>de("input",{name:`code-${H}`,type:"text",value:m[H],onChange:M,onKeyUp:J=>{J.key==="Backspace"&&A(H)},inputMode:"numeric",autoFocus:H===0,pattern:"[0-9]",className:`${f?"success":""} ${P?"fail":""}`,autoComplete:Om?"one-time-code":"off"},H))})]}),de(Bm,{children:N==0?no(ca,{children:[de("span",{children:"Didn't get an email?"}),de("button",{onClick:n,children:"Resend Code"})]}):no(ca,{children:[de("span",{children:"Didn't get a message?"}),de("button",{onClick:i,children:"Resend Code"})]})})]})]}),de(W,{}),de(F,{protectedByPrivy:!0})]})},Dm=Or.div`
498
498
  display: flex;
499
499
  flex-direction: column;
500
500
  align-items: flex-start;
@@ -682,7 +682,7 @@ Resources:
682
682
  @media (max-width: 440px) {
683
683
  padding: 10px 10px 20px;
684
684
  }
685
- `;import{useEffect as Kl,useState as Yl}from"react";import Zm from"styled-components";import{useEffect as ma,useState as Lr}from"react";import{isMobile as ha}from"react-device-detect";import Vl from"styled-components";import{Fragment as jl,jsx as fe,jsxs as qn}from"react/jsx-runtime";var Vn=2,Dr={metamask:{name:"MetaMask",component:qe},phantom:{name:"Phantom",component:Ct},coinbase_wallet:{name:"Coinbase Wallet",component:Qt},wallet_connect:{name:"WalletConnect",component:er},embedded:{name:"Privy Wallet",component:Zo}},fa=e=>e?.privyErrorCode==="linked_to_another_user"?Rt.ERROR_USER_EXISTS:e instanceof Pe&&!e.details.default?e.details:e instanceof Yo?Rt.ERROR_TIMED_OUT:e instanceof Jo?Rt.ERROR_USER_REJECTED_CONNECTION:Rt.ERROR_WALLET_CONNECTION,ql=()=>{let[e,t]=Lr(!1),[o,r]=Lr(!1),[n,i]=Lr(void 0),{app:a,navigate:l,navigateBack:s,lastScreen:c,currentScreen:h,setModalData:m}=b(),{getAuthFlow:g,walletConnectionStatus:f,closePrivyModal:C,loginWithWallet:P,updateWallets:E}=_(),{walletConnectors:x}=G(),[k,N]=Lr(0),{user:I}=G(),[R]=Lr(I?.linkedAccounts.length||0),M=ha&&f?.connector?.connectorType==="wallet_connect_v2"||ha&&f?.connector?.connectorType==="coinbase_wallet"||ha&&f?.connector?.connectorType==="injected"&&f?.connector?.walletClientType==="phantom",A=f?.status==="connected",te=f?.status==="switching_to_supported_chain";ma(()=>{let D=g();if(D&&M&&A&&!D.preparedMessage){D.buildSiweMessage();return}!D||M||!A||(async()=>{r(!0),i(void 0);try{f?.connector?.connectorType==="wallet_connect_v2"&&f?.connector?.walletClientType==="metamask"&&await ji(2500),await q()}catch(Gt){console.warn("Auto-prompted signature failed",Gt)}finally{r(!1)}})()},[k,A]),ma(()=>{if(I&&e){let D;if(Yt(I,a?.embeddedWallets?.createOnLogin)){let Gt=a?.render.inDialog?Ge:0,zt=a?.render.inDialog?Gt-500:0;D=setTimeout(()=>{m({createWallet:{onSuccess:()=>{},onFailure:Po=>console.error(Po),callAuthOnSuccessOnClose:!0}}),l("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")},zt)}else E(),D=setTimeout(C,Ge);return()=>clearTimeout(D)}},[I,e]);let O=D=>{if(D?.privyErrorCode==="allowlist_rejected"){l("ALLOWLIST_REJECTION_SCREEN");return}i(fa(D))};async function q(){try{if(await P(),!a?.render.inDialog)return C();t(!0)}catch(D){O(D)}finally{r(!1)}}ma(()=>{f?.connectError&&O(f?.connectError)},[f]);let H=f?.connector?.connectorType||"metamask",J=f?.connector?.walletClientType||"metamask",U=f?.connector?.walletBranding.name||Dr[J]?.name||"MetaMask",Ie=f?.connector?.walletBranding.icon||Dr[J]?.component||(D=>fe(qe,{...D})),re;e?re=`Successfully connected with ${U}`:n?re=n.message:te?re="Switching networks":A?re=o&&M?"Signing":"Sign to verify":re=`Waiting for ${U}`;let V="Don\u2019t see your wallet modal? Check your other browser windows.";if(e){let D=I?.linkedAccounts.length||0;R===D?V="Wallet was already linked.":V="You\u2019re good to go!"}else k>=Vn&&n?V="Unable to connect wallet":n?V=n.detail:te?V="Switch your wallet to the requested network.":A&&M?V="Sign the message in your wallet to verify it belongs to you.":J==="metamask"?V="For the best experience, connect only one wallet at a time.":H==="wallet_connect"?V="Open your mobile wallet app to continue":H==="coinbase_wallet"&&(Cn()||(Zi(I)?V="Continue with the Coinbase app. Not the right wallet? Reset your connection below.":V="Open the Coinbase app on your phone to continue."));let Ce=x?.walletConnectors?.find(D=>D.walletClientType==="coinbase_wallet"),le=J==="coinbase_wallet"&&(Zi(I)||n===Rt.ERROR_USER_EXISTS);return qn(jl,{children:[fe(T,{backFn:h===c?void 0:s}),fe(S,{}),qn(Jm,{children:[fe(ya,{walletLogo:Ie,success:e,fail:!!n}),qn(oo,{children:[fe("h3",{children:re}),fe("p",{children:V})]}),fe(Un,{children:le?fe(ie,{onClick:()=>Ce&&Ce?.disconnect(),invisible:e,disabled:e,children:"Use a different wallet"}):n==Rt.ERROR_USER_EXISTS&&h!==c?fe(ie,{onClick:s,children:"Use a different wallet"}):A&&!e&&M?fe(ie,{onClick:()=>{r(!0),q()},disabled:o,children:o?"Signing":"Sign with your wallet"}):!e&&n?.retryable&&k<Vn?fe(ie,{onClick:()=>{N(k+1),i(void 0),A?(r(!0),q()):f?.connectRetry()},invisible:e||!n?.retryable||k>=Vn,disabled:!e&&(!n?.retryable||k>=Vn),children:"Retry"}):null})]}),fe(X,{})]})},Jm=Vl.div`
685
+ `;import{useEffect as Kl,useState as Yl}from"react";import Zm from"styled-components";import{useEffect as ma,useState as Lr}from"react";import{isMobile as ha}from"react-device-detect";import Vl from"styled-components";import{Fragment as jl,jsx as fe,jsxs as qn}from"react/jsx-runtime";var Vn=2,Dr={metamask:{name:"MetaMask",component:qe},phantom:{name:"Phantom",component:Ct},coinbase_wallet:{name:"Coinbase Wallet",component:Qt},wallet_connect:{name:"WalletConnect",component:er},embedded:{name:"Privy Wallet",component:Zo}},fa=e=>e?.privyErrorCode==="linked_to_another_user"?Rt.ERROR_USER_EXISTS:e instanceof Te&&!e.details.default?e.details:e instanceof Yo?Rt.ERROR_TIMED_OUT:e instanceof Jo?Rt.ERROR_USER_REJECTED_CONNECTION:Rt.ERROR_WALLET_CONNECTION,ql=()=>{let[e,t]=Lr(!1),[o,r]=Lr(!1),[n,i]=Lr(void 0),{app:a,navigate:l,navigateBack:s,lastScreen:c,currentScreen:h,setModalData:m}=b(),{getAuthFlow:g,walletConnectionStatus:f,closePrivyModal:C,loginWithWallet:P,updateWallets:E}=_(),{walletConnectors:x}=G(),[k,N]=Lr(0),{user:I}=G(),[R]=Lr(I?.linkedAccounts.length||0),M=ha&&f?.connector?.connectorType==="wallet_connect_v2"||ha&&f?.connector?.connectorType==="coinbase_wallet"||ha&&f?.connector?.connectorType==="injected"&&f?.connector?.walletClientType==="phantom",A=f?.status==="connected",te=f?.status==="switching_to_supported_chain";ma(()=>{let D=g();if(D&&M&&A&&!D.preparedMessage){D.buildSiweMessage();return}!D||M||!A||(async()=>{r(!0),i(void 0);try{f?.connector?.connectorType==="wallet_connect_v2"&&f?.connector?.walletClientType==="metamask"&&await ji(2500),await q()}catch(Gt){console.warn("Auto-prompted signature failed",Gt)}finally{r(!1)}})()},[k,A]),ma(()=>{if(I&&e){let D;if(Yt(I,a?.embeddedWallets?.createOnLogin)){let Gt=a?.render.inDialog?Ge:0,zt=a?.render.inDialog?Gt-500:0;D=setTimeout(()=>{m({createWallet:{onSuccess:()=>{},onFailure:Po=>console.error(Po),callAuthOnSuccessOnClose:!0}}),l("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")},zt)}else E(),D=setTimeout(C,Ge);return()=>clearTimeout(D)}},[I,e]);let O=D=>{if(D?.privyErrorCode==="allowlist_rejected"){l("ALLOWLIST_REJECTION_SCREEN");return}i(fa(D))};async function q(){try{if(await P(),!a?.render.inDialog)return C();t(!0)}catch(D){O(D)}finally{r(!1)}}ma(()=>{f?.connectError&&O(f?.connectError)},[f]);let H=f?.connector?.connectorType||"metamask",J=f?.connector?.walletClientType||"metamask",U=f?.connector?.walletBranding.name||Dr[J]?.name||"MetaMask",We=f?.connector?.walletBranding.icon||Dr[J]?.component||(D=>fe(qe,{...D})),re;e?re=`Successfully connected with ${U}`:n?re=n.message:te?re="Switching networks":A?re=o&&M?"Signing":"Sign to verify":re=`Waiting for ${U}`;let V="Don\u2019t see your wallet modal? Check your other browser windows.";if(e){let D=I?.linkedAccounts.length||0;R===D?V="Wallet was already linked.":V="You\u2019re good to go!"}else k>=Vn&&n?V="Unable to connect wallet":n?V=n.detail:te?V="Switch your wallet to the requested network.":A&&M?V="Sign the message in your wallet to verify it belongs to you.":J==="metamask"?V="For the best experience, connect only one wallet at a time.":H==="wallet_connect"?V="Open your mobile wallet app to continue":H==="coinbase_wallet"&&(Cn()||(Zi(I)?V="Continue with the Coinbase app. Not the right wallet? Reset your connection below.":V="Open the Coinbase app on your phone to continue."));let Ce=x?.walletConnectors?.find(D=>D.walletClientType==="coinbase_wallet"),le=J==="coinbase_wallet"&&(Zi(I)||n===Rt.ERROR_USER_EXISTS);return qn(jl,{children:[fe(T,{backFn:h===c?void 0:s}),fe(S,{}),qn(Jm,{children:[fe(ya,{walletLogo:We,success:e,fail:!!n}),qn(oo,{children:[fe("h3",{children:re}),fe("p",{children:V})]}),fe(Un,{children:le?fe(ie,{onClick:()=>Ce&&Ce?.disconnect(),invisible:e,disabled:e,children:"Use a different wallet"}):n==Rt.ERROR_USER_EXISTS&&h!==c?fe(ie,{onClick:s,children:"Use a different wallet"}):A&&!e&&M?fe(ie,{onClick:()=>{r(!0),q()},disabled:o,children:o?"Signing":"Sign with your wallet"}):!e&&n?.retryable&&k<Vn?fe(ie,{onClick:()=>{N(k+1),i(void 0),A?(r(!0),q()):f?.connectRetry()},invisible:e||!n?.retryable||k>=Vn,disabled:!e&&(!n?.retryable||k>=Vn),children:"Retry"}):null})]}),fe(X,{})]})},Jm=Vl.div`
686
686
  display: flex;
687
687
  flex-direction: column;
688
688
  align-items: center;
@@ -777,7 +777,7 @@ Resources:
777
777
  transform: rotate(360deg);
778
778
  }
779
779
  }
780
- `;var Ql=["error","invalid_request_arguments","wallet_not_on_device","invalid_recovery_pin","insufficient_funds","mfa_verification_failed","mfa_verification_max_attempts_reached","mfa_timeout"];var Se=class extends Error{constructor(o,r){super(r);this.type=o}};function nr(e){let t=e.type;return typeof t=="string"&&Ql.includes(t)}function ir(e){return nr(e)&&e.type==="wallet_not_on_device"}function Zl(e){return nr(e)&&(e.type==="invalid_recovery_pin"||e.type==="invalid_request_arguments")}function Xl(e){return!!(nr(e)&&e.type==="insufficient_funds"||e.code==="INSUFFICIENT_FUNDS")}function ah(e){return!!(nr(e)&&e.type==="mfa_timeout")}function sh(e){return!!(nr(e)&&e.type==="mfa_verification_failed")}function lh(e){return!!(nr(e)&&e.type==="mfa_verification_max_attempts_reached")}import{Fragment as tc,jsx as so,jsxs as wa}from"react/jsx-runtime";var ec=1,oc=()=>{let{authenticated:e,user:t,getAccessToken:o}=G(),{closePrivyModal:r,createAnalyticsEvent:n,walletProxy:i}=_(),{navigate:a,data:l,setModalData:s,onUserCloseViaDialogOrKeybindRef:c}=b(),h=ph(()=>Date.now(),[]),[m,g]=uh(!1),{onCompleteNavigateTo:f,onFailure:C}=l?.connectWallet,P=x=>{m||(g(!0),C(typeof x=="string"?new Error(x):x))};dh(()=>{let x=Q(t),k;return!e||!x?P("User must be authenticated and have a Privy wallet before it can be connected"):i?((async()=>{let I=await o();if(!I)return P("User must be authenticated and have a Privy wallet before it can be connected");try{await i.connect({accessToken:I,address:x.address});let R=(Date.now()-h)/1e3;f==="EMBEDDED_WALLET_KEY_EXPORT_SCREEN"&&R<ec?k=setTimeout(()=>{a(f)},(ec-R)*1e3):a(f)}catch(R){if(ir(R)&&x.recoveryMethod==="privy"){let M=await o();if(!M)return P("User must be authenticated and have a Privy wallet before it can be recovered");try{n("embedded_wallet_pinless_recovery_started",{walletAddress:x.address}),(await i?.recover({address:x.address,accessToken:M}))?.address||P(new Error("Unable to recover wallet")),f?a(f):r({shouldCallAuthOnSuccess:!1}),n("embedded_wallet_recovery_completed",{walletAddress:x.address}),a(f)}catch{P("An error has occurred, please try again.")}}else ir(R)?(s({...l,recoverWallet:{privyWallet:x,onCompleteNavigateTo:f,onFailure:C}}),a("EMBEDDED_WALLET_RECOVERY_SCREEN")):P(R)}})(),()=>clearTimeout(k)):void 0},[e,t,i]);let E=()=>{P("User exited before wallet could be connected"),r({shouldCallAuthOnSuccess:!1})};return c.current=E,wa(tc,{children:[so(T,{onClose:E}),so(S,{}),so(hh,{children:m?wa(tc,{children:[wa(lt,{children:[so(ch,{fill:"var(--privy-color-error)",stroke:"white",strokeWidth:".25px",width:"64px",height:"64px"}),so(he,{title:"Something went wrong",description:"We\u2019re on it. Please try again later."})]}),so(j,{onClick:()=>r({shouldCallAuthOnSuccess:!1}),children:"Close"})]}):so(rr,{})}),so(W,{})]})},hh=mh.div`
780
+ `;var Ql=["error","invalid_request_arguments","wallet_not_on_device","invalid_recovery_pin","insufficient_funds","mfa_verification_failed","mfa_verification_max_attempts_reached","mfa_timeout"];var _e=class extends Error{constructor(o,r){super(r);this.type=o}};function nr(e){let t=e.type;return typeof t=="string"&&Ql.includes(t)}function ir(e){return nr(e)&&e.type==="wallet_not_on_device"}function Zl(e){return nr(e)&&(e.type==="invalid_recovery_pin"||e.type==="invalid_request_arguments")}function Xl(e){return!!(nr(e)&&e.type==="insufficient_funds"||e.code==="INSUFFICIENT_FUNDS")}function ah(e){return!!(nr(e)&&e.type==="mfa_timeout")}function sh(e){return!!(nr(e)&&e.type==="mfa_verification_failed")}function lh(e){return!!(nr(e)&&e.type==="mfa_verification_max_attempts_reached")}import{Fragment as tc,jsx as so,jsxs as wa}from"react/jsx-runtime";var ec=1,oc=()=>{let{authenticated:e,user:t,getAccessToken:o}=G(),{closePrivyModal:r,createAnalyticsEvent:n,walletProxy:i}=_(),{navigate:a,data:l,setModalData:s,onUserCloseViaDialogOrKeybindRef:c}=b(),h=ph(()=>Date.now(),[]),[m,g]=uh(!1),{onCompleteNavigateTo:f,onFailure:C}=l?.connectWallet,P=x=>{m||(g(!0),C(typeof x=="string"?new Error(x):x))};dh(()=>{let x=Q(t),k;return!e||!x?P("User must be authenticated and have a Privy wallet before it can be connected"):i?((async()=>{let I=await o();if(!I)return P("User must be authenticated and have a Privy wallet before it can be connected");try{await i.connect({accessToken:I,address:x.address});let R=(Date.now()-h)/1e3;f==="EMBEDDED_WALLET_KEY_EXPORT_SCREEN"&&R<ec?k=setTimeout(()=>{a(f)},(ec-R)*1e3):a(f)}catch(R){if(ir(R)&&x.recoveryMethod==="privy"){let M=await o();if(!M)return P("User must be authenticated and have a Privy wallet before it can be recovered");try{n("embedded_wallet_pinless_recovery_started",{walletAddress:x.address}),(await i?.recover({address:x.address,accessToken:M}))?.address||P(new Error("Unable to recover wallet")),f?a(f):r({shouldCallAuthOnSuccess:!1}),n("embedded_wallet_recovery_completed",{walletAddress:x.address}),a(f)}catch{P("An error has occurred, please try again.")}}else ir(R)?(s({...l,recoverWallet:{privyWallet:x,onCompleteNavigateTo:f,onFailure:C}}),a("EMBEDDED_WALLET_RECOVERY_SCREEN")):P(R)}})(),()=>clearTimeout(k)):void 0},[e,t,i]);let E=()=>{P("User exited before wallet could be connected"),r({shouldCallAuthOnSuccess:!1})};return c.current=E,wa(tc,{children:[so(T,{onClose:E}),so(S,{}),so(hh,{children:m?wa(tc,{children:[wa(lt,{children:[so(ch,{fill:"var(--privy-color-error)",stroke:"white",strokeWidth:".25px",width:"64px",height:"64px"}),so(he,{title:"Something went wrong",description:"We\u2019re on it. Please try again later."})]}),so(j,{onClick:()=>r({shouldCallAuthOnSuccess:!1}),children:"Close"})]}):so(rr,{})}),so(W,{})]})},hh=mh.div`
781
781
  display: flex;
782
782
  height: 100%;
783
783
  flex-direction: column;
@@ -1091,7 +1091,7 @@ Resources:
1091
1091
 
1092
1092
  ${t}
1093
1093
 
1094
- You will need this password to access your ${e} wallet on a new device. Please keep it somewhere safe.`;import{CheckCircleIcon as vf,XCircleIcon as wf}from"@heroicons/react/24/outline";import{Fragment as Cf,jsx as Mt,jsxs as Sa}from"react/jsx-runtime";var Wc=({error:e,onClose:t})=>Sa(Cf,{children:[Mt(T,{closeable:!1}),Mt(S,{}),e?Sa(lt,{children:[Mt(wf,{stroke:"var(--privy-color-error)",width:"64px",height:"64px"}),Mt(he,{title:"Something went wrong",description:e})]}):Sa(lt,{children:[Mt(vf,{stroke:"var(--privy-color-success)",width:"64px",height:"64px"}),Mt(he,{title:"Success"})]}),Mt(j,{onClick:t,children:"Close"}),Mt(W,{}),Mt(F,{protectedByPrivy:!0})]});import{useReducer as bf}from"react";var Ef=(e,t)=>{switch(e){case"creating":return t==="back"?e:"saving";case"saving":return t==="back"?"creating":"confirming";case"confirming":return t==="back"?"saving":"finalizing";case"finalizing":return t==="back"?"confirming":"done";default:return e}},Mc=()=>{let[e,t]=bf(Ef,"creating");return{send:t,state:e}};import{jsx as Gr}from"react/jsx-runtime";var Xn=({onSubmit:e,...t})=>{let{send:o,state:r}=Mc(),n=Nc(async()=>{r==="finalizing"&&await e(),o("next")},[r,o,e]);xf(()=>{let a;return r==="done"&&t.config.initiatedBy==="automatic"&&(a=setTimeout(()=>t.onClose?.(),Ge)),()=>{a&&clearTimeout(a)}},[r,t.config.initiatedBy,t.onClose]);let i=Nc(()=>{o("back")},[o]);return r==="creating"?Gr(kc,{...t,onSubmit:n}):r==="saving"?Gr(Ic,{...t,onSubmit:n,onBack:i}):r==="confirming"?Gr(fc,{...t,onSubmit:n,onBack:i}):r==="finalizing"?Gr(wc,{...t,onSubmit:n,onBack:i}):r==="done"?Gr(Wc,{...t,onSubmit:n}):null};import{Fragment as _f,jsx as Nt,jsxs as Lc}from"react/jsx-runtime";var Sf=250,Dc=()=>{let{app:e,navigate:t,data:o,onUserCloseViaDialogOrKeybindRef:r}=b(),[n,i]=zr(""),[a,l]=zr(!1),[s,c]=zr(),[h,m]=zr(null),[g,f]=zr(null),C=Tf(!1),{authenticated:P,getAccessToken:E}=G(),{refreshUser:x,closePrivyModal:k,createAnalyticsEvent:N,isNewUserThisSession:I,initializeWalletProxy:R}=_(),{onSuccess:M,onFailure:A,callAuthOnSuccessOnClose:te}=o.createWallet,O=e?.embeddedWallets.requireUserPasswordOnCreate===!0,q=!!(!n||C.current)&&!O,H=new Qe(async()=>U());Oc(()=>{h||R(3e4).then(re=>m(re))},[h]),Oc(()=>{if(!P){t("LANDING"),A(new Error("User must be authenticated before creating a Privy wallet"));return}!O&&!a&&!C.current&&(l(!0),H.execute().finally(()=>l(!1)))},[O,P]);let J=()=>{O&&g&&g?.recoveryMethod!=="user-passcode"?A(new Fe("User created a wallet but failed to set a password for it")):g?M(g):A(new Fe("User wallet creation failed")),k({shouldCallAuthOnSuccess:te})};r.current=()=>null;let U=async function(){let re=await E();if(re)try{if(N("embedded_wallet_creation_started"),!await(await R(jo))?.create({accessToken:re,recoveryPassword:s}))throw N("embedded_wallet_creation_failed",{error:"walletProxy did not send a response."}),new Error("Unable to create wallet");let le=await x(),D=Q(le);if(!D)throw N("embedded_wallet_creation_failed",{error:"Updated user is missing embedded wallet."}),new Error("Unable to create wallet");f(D),N("embedded_wallet_creation_completed",{walletAddress:D.address}),i(""),C.current=!0,O?t("EMBEDDED_WALLET_CREATED_SCREEN"):I?t("EMBEDDED_WALLET_CREATED_SCREEN"):D&&(M(D),k({shouldCallAuthOnSuccess:te}))}catch(V){if(C.current)return;i("An error has occurred, please try again."),console.warn(V)}else i("An error has occured, please login again."),N("embedded_wallet_creation_failed",{error:"Missing access token for user."})},Ie=async()=>O?(l(!0),H.execute().then(()=>new Promise(re=>setTimeout(re,Sf))).finally(()=>l(!1))):k({shouldCallAuthOnSuccess:te});return!O&&n?Lc(_f,{children:[Nt(T,{closeable:!1}),Nt(S,{}),Lc(lt,{children:[Nt(Pf,{fill:"var(--privy-color-error)",stroke:"white",strokeWidth:".25px",width:"64px",height:"64px"}),Nt(he,{title:"Something went wrong",description:n})]}),Nt(j,{onClick:J,children:"Close"}),Nt(W,{})]}):q?Nt(uc,{children:Nt(rr,{})}):Nt(Xn,{config:{initiatedBy:"automatic"},appName:e?.name||"privy",loading:q||!h,buttonLoading:a,buttonHideAnimations:!g&&a,error:n,password:s||"",onClose:J,onPasswordChange:c,onPasswordGenerate:()=>c(Zn()),onSubmit:Ie})};import{useEffect as Af,useState as ei}from"react";import{jsx as kf}from"react/jsx-runtime";var Uc=()=>{let[e,t]=ei(null),[o,r]=ei(!1),[n,i]=ei(null),[a,l]=ei(""),{authenticated:s,getAccessToken:c,user:h}=G(),{walletProxy:m,refreshUser:g,closePrivyModal:f,createAnalyticsEvent:C}=_(),{app:P,navigate:E,data:x,onUserCloseViaDialogOrKeybindRef:k}=b(),{onSuccess:N,onFailure:I}=x.createWallet,R=Q(h),M=e?.recoveryMethod==="user-passcode";Af(()=>{s||(E("LANDING"),I(new pn("User must be authenticated before setting a password on a Privy wallet")))},[s]);let A=()=>{if(n){I(n),f({shouldCallAuthOnSuccess:!1});return}if(!M){I(new Fe("Exited before password was added to wallet")),f({shouldCallAuthOnSuccess:!1});return}N(e),f({shouldCallAuthOnSuccess:!1})};k.current=A;let te=async()=>{let q=await c();if(q&&R?.address&&a&&m)try{if(C("embedded_wallet_set_password_started",{walletAddress:R.address}),!(await m.setRecoveryPassword({accessToken:q,address:R.address,recoveryPassword:a})).address){i(new Fe("Error setting password on privy wallet")),C("embedded_wallet_set_password_failed",{walletAddress:R.address,reason:"error setting password"});return}let J=await g(),U=Q(J);if(!U){i(new Fe("Error setting password on privy wallet")),C("embedded_wallet_set_password_failed",{walletAddress:R.address,reason:"wallet disconnected"});return}t(U),C("embedded_wallet_set_password_completed",{walletAddress:R.address})}catch(H){console.warn(H),i(H instanceof Error?H:new Error("Error setting password on privy wallet")),C("embedded_wallet_set_password_failed",{walletAddress:R.address,reason:H})}},O=async()=>{M?(N(e),f({shouldCallAuthOnSuccess:!1})):(r(!0),i(null),await te(),r(!1))};return kf(Xn,{appName:P?.name||"privy",config:{initiatedBy:"user",onCancel:A},error:n?"An error has occurred, please try again.":void 0,buttonLoading:o,buttonHideAnimations:!1,password:a,onPasswordGenerate:()=>l(Zn()),onPasswordChange:l,onSubmit:O,onClose:A})};import{UserCircleIcon as Rf}from"@heroicons/react/24/outline";import{LockClosedIcon as If}from"@heroicons/react/24/solid";import{Fragment as Wf,jsx as Ot,jsxs as ti}from"react/jsx-runtime";var Fc=()=>{let{user:e}=G(),{closePrivyModal:t,createAnalyticsEvent:o}=_(),{data:r,setModalData:n,navigate:i,onUserCloseViaDialogOrKeybindRef:a}=b(),{onSuccess:l,onFailure:s}=r.setWalletPassword,c=()=>{s(new Fe("Exited before password was added to wallet")),t({shouldCallAuthOnSuccess:!1})};return a.current=c,ti(Wf,{children:[Ot(T,{onClose:c}),Ot(S,{}),ti(lt,{children:[ti(Pl,{children:[Ot(Rf,{stroke:"var(--privy-color-accent)",width:"64px",height:"64px"}),Ot(Tl,{style:{width:24,height:24,position:"absolute",bottom:0,right:0},children:Ot(If,{width:"12px",height:"12px",fill:"white"})})]}),ti(he,{title:"Secure Your Account",children:["Please set a password to secure your account.",Ot("p",{children:"Losing this password will make your account inaccessible on new devices. You will only be asked for it when you log on to a new device."})]})]}),Ot(j,{onClick:()=>{let m=Q(e);o("embedded_wallet_set_password_started",{walletAddress:m?.address}),n({createWallet:{onFailure:s,onSuccess:l,callAuthOnSuccessOnClose:!1,addPasswordToExistingWallet:!0}}),i("EMBEDDED_WALLET_PASSWORD_UPDATE_SCREEN")},children:"Add password"}),Ot(W,{}),Ot(F,{protectedByPrivy:!0})]})};import{ShieldCheckIcon as Mf}from"@heroicons/react/24/outline";import{useEffect as Nf,useState as oi}from"react";import ri,{css as Of}from"styled-components";import{Fragment as Bf,jsx as _e,jsxs as No}from"react/jsx-runtime";var Bc=()=>{let[e,t]=oi(!0),{authenticated:o,getAccessToken:r}=G(),{walletProxy:n,closePrivyModal:i,createAnalyticsEvent:a}=_(),{navigate:l,data:s,onUserCloseViaDialogOrKeybindRef:c}=b(),[h,m]=oi(void 0),[g,f]=oi(""),[C,P]=oi(!1),{privyWallet:E,onCompleteNavigateTo:x,onSuccess:k,onFailure:N}=s.recoverWallet,I=(A="User exited before their wallet could be recovered")=>{i({shouldCallAuthOnSuccess:!1}),N(typeof A=="string"?new Fe(A):A)};c.current=I,Nf(()=>{if(!o||!E)return I("User must be authenticated and have a Privy wallet before it can be recovered")},[o]);let R=A=>{A&&m(A)};return No(Bf,{children:[_e(T,{onClose:I}),_e(S,{}),No(Df,{children:[No(Lf,{children:[_e(Mf,{height:48,width:48,stroke:"var(--privy-color-accent)"}),_e("h3",{style:{color:"var(--privy-color-foreground)"},children:"Load your account"}),_e("p",{style:{color:"var(--privy-color-foreground-2)"},children:"Please provision your account on this new device. To continue, enter your recovery password."})]}),No("div",{children:[No(po,{children:[_e(Wo,{type:e?"password":"text",onChange:A=>R(A.target.value),disabled:C}),_e(sr,{style:{right:"0.75rem"},children:e?_e(lr,{onClick:()=>t(!1)}):_e(cr,{onClick:()=>t(!0)})})]}),!!g&&_e(Uf,{children:g})]}),No("div",{children:[No(xl,{children:[_e("h4",{children:"Why is this necessary?"}),_e("p",{children:"You previously set a password for this wallet. This helps ensure only you can access it"})]}),_e(Ff,{loading:C||!n,disabled:!h,onClick:async()=>{P(!0);let A=await r();if(A&&E&&h!==null)try{a("embedded_wallet_recovery_started",{walletAddress:E.address}),await n?.recover({address:E.address,accessToken:A,recoveryPin:h}),f(""),x?l(x):i({shouldCallAuthOnSuccess:!1}),k?.(E),a("embedded_wallet_recovery_completed",{walletAddress:E.address})}catch(te){Zl(te)?f("Invalid recovery password, please try again."):f("An error has occurred, please try again.")}finally{P(!1)}else return I("User must be authenticated and have a Privy wallet before it can be recovered")},warn:!1,hideAnimations:!E&&C,children:"Recover your account"})]})]}),_e(W,{}),_e(F,{protectedByPrivy:!0})]})},Lf=ri.div`
1094
+ You will need this password to access your ${e} wallet on a new device. Please keep it somewhere safe.`;import{CheckCircleIcon as vf,XCircleIcon as wf}from"@heroicons/react/24/outline";import{Fragment as Cf,jsx as Mt,jsxs as Sa}from"react/jsx-runtime";var Wc=({error:e,onClose:t})=>Sa(Cf,{children:[Mt(T,{closeable:!1}),Mt(S,{}),e?Sa(lt,{children:[Mt(wf,{stroke:"var(--privy-color-error)",width:"64px",height:"64px"}),Mt(he,{title:"Something went wrong",description:e})]}):Sa(lt,{children:[Mt(vf,{stroke:"var(--privy-color-success)",width:"64px",height:"64px"}),Mt(he,{title:"Success"})]}),Mt(j,{onClick:t,children:"Close"}),Mt(W,{}),Mt(F,{protectedByPrivy:!0})]});import{useReducer as bf}from"react";var Ef=(e,t)=>{switch(e){case"creating":return t==="back"?e:"saving";case"saving":return t==="back"?"creating":"confirming";case"confirming":return t==="back"?"saving":"finalizing";case"finalizing":return t==="back"?"confirming":"done";default:return e}},Mc=()=>{let[e,t]=bf(Ef,"creating");return{send:t,state:e}};import{jsx as Gr}from"react/jsx-runtime";var Xn=({onSubmit:e,...t})=>{let{send:o,state:r}=Mc(),n=Nc(async()=>{r==="finalizing"&&await e(),o("next")},[r,o,e]);xf(()=>{let a;return r==="done"&&t.config.initiatedBy==="automatic"&&(a=setTimeout(()=>t.onClose?.(),Ge)),()=>{a&&clearTimeout(a)}},[r,t.config.initiatedBy,t.onClose]);let i=Nc(()=>{o("back")},[o]);return r==="creating"?Gr(kc,{...t,onSubmit:n}):r==="saving"?Gr(Ic,{...t,onSubmit:n,onBack:i}):r==="confirming"?Gr(fc,{...t,onSubmit:n,onBack:i}):r==="finalizing"?Gr(wc,{...t,onSubmit:n,onBack:i}):r==="done"?Gr(Wc,{...t,onSubmit:n}):null};import{Fragment as _f,jsx as Nt,jsxs as Lc}from"react/jsx-runtime";var Sf=250,Dc=()=>{let{app:e,navigate:t,data:o,onUserCloseViaDialogOrKeybindRef:r}=b(),[n,i]=zr(""),[a,l]=zr(!1),[s,c]=zr(),[h,m]=zr(null),[g,f]=zr(null),C=Tf(!1),{authenticated:P,getAccessToken:E}=G(),{refreshUser:x,closePrivyModal:k,createAnalyticsEvent:N,isNewUserThisSession:I,initializeWalletProxy:R}=_(),{onSuccess:M,onFailure:A,callAuthOnSuccessOnClose:te}=o.createWallet,O=e?.embeddedWallets.requireUserPasswordOnCreate===!0,q=!!(!n||C.current)&&!O,H=new Qe(async()=>U());Oc(()=>{h||R(3e4).then(re=>m(re))},[h]),Oc(()=>{if(!P){t("LANDING"),A(new Error("User must be authenticated before creating a Privy wallet"));return}!O&&!a&&!C.current&&(l(!0),H.execute().finally(()=>l(!1)))},[O,P]);let J=()=>{O&&g&&g?.recoveryMethod!=="user-passcode"?A(new Fe("User created a wallet but failed to set a password for it")):g?M(g):A(new Fe("User wallet creation failed")),k({shouldCallAuthOnSuccess:te})};r.current=()=>null;let U=async function(){let re=await E();if(re)try{if(N("embedded_wallet_creation_started"),!await(await R(jo))?.create({accessToken:re,recoveryPassword:s}))throw N("embedded_wallet_creation_failed",{error:"walletProxy did not send a response."}),new Error("Unable to create wallet");let le=await x(),D=Q(le);if(!D)throw N("embedded_wallet_creation_failed",{error:"Updated user is missing embedded wallet."}),new Error("Unable to create wallet");f(D),N("embedded_wallet_creation_completed",{walletAddress:D.address}),i(""),C.current=!0,O?t("EMBEDDED_WALLET_CREATED_SCREEN"):I?t("EMBEDDED_WALLET_CREATED_SCREEN"):D&&(M(D),k({shouldCallAuthOnSuccess:te}))}catch(V){if(C.current)return;i("An error has occurred, please try again."),console.warn(V)}else i("An error has occured, please login again."),N("embedded_wallet_creation_failed",{error:"Missing access token for user."})},We=async()=>O?(l(!0),H.execute().then(()=>new Promise(re=>setTimeout(re,Sf))).finally(()=>l(!1))):k({shouldCallAuthOnSuccess:te});return!O&&n?Lc(_f,{children:[Nt(T,{closeable:!1}),Nt(S,{}),Lc(lt,{children:[Nt(Pf,{fill:"var(--privy-color-error)",stroke:"white",strokeWidth:".25px",width:"64px",height:"64px"}),Nt(he,{title:"Something went wrong",description:n})]}),Nt(j,{onClick:J,children:"Close"}),Nt(W,{})]}):q?Nt(uc,{children:Nt(rr,{})}):Nt(Xn,{config:{initiatedBy:"automatic"},appName:e?.name||"privy",loading:q||!h,buttonLoading:a,buttonHideAnimations:!g&&a,error:n,password:s||"",onClose:J,onPasswordChange:c,onPasswordGenerate:()=>c(Zn()),onSubmit:We})};import{useEffect as Af,useState as ei}from"react";import{jsx as kf}from"react/jsx-runtime";var Uc=()=>{let[e,t]=ei(null),[o,r]=ei(!1),[n,i]=ei(null),[a,l]=ei(""),{authenticated:s,getAccessToken:c,user:h}=G(),{walletProxy:m,refreshUser:g,closePrivyModal:f,createAnalyticsEvent:C}=_(),{app:P,navigate:E,data:x,onUserCloseViaDialogOrKeybindRef:k}=b(),{onSuccess:N,onFailure:I}=x.createWallet,R=Q(h),M=e?.recoveryMethod==="user-passcode";Af(()=>{s||(E("LANDING"),I(new pn("User must be authenticated before setting a password on a Privy wallet")))},[s]);let A=()=>{if(n){I(n),f({shouldCallAuthOnSuccess:!1});return}if(!M){I(new Fe("Exited before password was added to wallet")),f({shouldCallAuthOnSuccess:!1});return}N(e),f({shouldCallAuthOnSuccess:!1})};k.current=A;let te=async()=>{let q=await c();if(q&&R?.address&&a&&m)try{if(C("embedded_wallet_set_password_started",{walletAddress:R.address}),!(await m.setRecoveryPassword({accessToken:q,address:R.address,recoveryPassword:a})).address){i(new Fe("Error setting password on privy wallet")),C("embedded_wallet_set_password_failed",{walletAddress:R.address,reason:"error setting password"});return}let J=await g(),U=Q(J);if(!U){i(new Fe("Error setting password on privy wallet")),C("embedded_wallet_set_password_failed",{walletAddress:R.address,reason:"wallet disconnected"});return}t(U),C("embedded_wallet_set_password_completed",{walletAddress:R.address})}catch(H){console.warn(H),i(H instanceof Error?H:new Error("Error setting password on privy wallet")),C("embedded_wallet_set_password_failed",{walletAddress:R.address,reason:H})}},O=async()=>{M?(N(e),f({shouldCallAuthOnSuccess:!1})):(r(!0),i(null),await te(),r(!1))};return kf(Xn,{appName:P?.name||"privy",config:{initiatedBy:"user",onCancel:A},error:n?"An error has occurred, please try again.":void 0,buttonLoading:o,buttonHideAnimations:!1,password:a,onPasswordGenerate:()=>l(Zn()),onPasswordChange:l,onSubmit:O,onClose:A})};import{UserCircleIcon as Rf}from"@heroicons/react/24/outline";import{LockClosedIcon as If}from"@heroicons/react/24/solid";import{Fragment as Wf,jsx as Ot,jsxs as ti}from"react/jsx-runtime";var Fc=()=>{let{user:e}=G(),{closePrivyModal:t,createAnalyticsEvent:o}=_(),{data:r,setModalData:n,navigate:i,onUserCloseViaDialogOrKeybindRef:a}=b(),{onSuccess:l,onFailure:s}=r.setWalletPassword,c=()=>{s(new Fe("Exited before password was added to wallet")),t({shouldCallAuthOnSuccess:!1})};return a.current=c,ti(Wf,{children:[Ot(T,{onClose:c}),Ot(S,{}),ti(lt,{children:[ti(Pl,{children:[Ot(Rf,{stroke:"var(--privy-color-accent)",width:"64px",height:"64px"}),Ot(Tl,{style:{width:24,height:24,position:"absolute",bottom:0,right:0},children:Ot(If,{width:"12px",height:"12px",fill:"white"})})]}),ti(he,{title:"Secure Your Account",children:["Please set a password to secure your account.",Ot("p",{children:"Losing this password will make your account inaccessible on new devices. You will only be asked for it when you log on to a new device."})]})]}),Ot(j,{onClick:()=>{let m=Q(e);o("embedded_wallet_set_password_started",{walletAddress:m?.address}),n({createWallet:{onFailure:s,onSuccess:l,callAuthOnSuccessOnClose:!1,addPasswordToExistingWallet:!0}}),i("EMBEDDED_WALLET_PASSWORD_UPDATE_SCREEN")},children:"Add password"}),Ot(W,{}),Ot(F,{protectedByPrivy:!0})]})};import{ShieldCheckIcon as Mf}from"@heroicons/react/24/outline";import{useEffect as Nf,useState as oi}from"react";import ri,{css as Of}from"styled-components";import{Fragment as Bf,jsx as Ae,jsxs as No}from"react/jsx-runtime";var Bc=()=>{let[e,t]=oi(!0),{authenticated:o,getAccessToken:r}=G(),{walletProxy:n,closePrivyModal:i,createAnalyticsEvent:a}=_(),{navigate:l,data:s,onUserCloseViaDialogOrKeybindRef:c}=b(),[h,m]=oi(void 0),[g,f]=oi(""),[C,P]=oi(!1),{privyWallet:E,onCompleteNavigateTo:x,onSuccess:k,onFailure:N}=s.recoverWallet,I=(A="User exited before their wallet could be recovered")=>{i({shouldCallAuthOnSuccess:!1}),N(typeof A=="string"?new Fe(A):A)};c.current=I,Nf(()=>{if(!o||!E)return I("User must be authenticated and have a Privy wallet before it can be recovered")},[o]);let R=A=>{A&&m(A)};return No(Bf,{children:[Ae(T,{onClose:I}),Ae(S,{}),No(Df,{children:[No(Lf,{children:[Ae(Mf,{height:48,width:48,stroke:"var(--privy-color-accent)"}),Ae("h3",{style:{color:"var(--privy-color-foreground)"},children:"Load your account"}),Ae("p",{style:{color:"var(--privy-color-foreground-2)"},children:"Please provision your account on this new device. To continue, enter your recovery password."})]}),No("div",{children:[No(po,{children:[Ae(Wo,{type:e?"password":"text",onChange:A=>R(A.target.value),disabled:C}),Ae(sr,{style:{right:"0.75rem"},children:e?Ae(lr,{onClick:()=>t(!1)}):Ae(cr,{onClick:()=>t(!0)})})]}),!!g&&Ae(Uf,{children:g})]}),No("div",{children:[No(xl,{children:[Ae("h4",{children:"Why is this necessary?"}),Ae("p",{children:"You previously set a password for this wallet. This helps ensure only you can access it"})]}),Ae(Ff,{loading:C||!n,disabled:!h,onClick:async()=>{P(!0);let A=await r();if(A&&E&&h!==null)try{a("embedded_wallet_recovery_started",{walletAddress:E.address}),await n?.recover({address:E.address,accessToken:A,recoveryPin:h}),f(""),x?l(x):i({shouldCallAuthOnSuccess:!1}),k?.(E),a("embedded_wallet_recovery_completed",{walletAddress:E.address})}catch(te){Zl(te)?f("Invalid recovery password, please try again."):f("An error has occurred, please try again.")}finally{P(!1)}else return I("User must be authenticated and have a Privy wallet before it can be recovered")},warn:!1,hideAnimations:!E&&C,children:"Recover your account"})]})]}),Ae(W,{}),Ae(F,{protectedByPrivy:!0})]})},Lf=ri.div`
1095
1095
  display: flex;
1096
1096
  flex-direction: column;
1097
1097
  align-items: center;
@@ -1133,7 +1133,7 @@ You will need this password to access your ${e} wallet on a new device. Please k
1133
1133
  transition: none;
1134
1134
  }
1135
1135
  `}
1136
- `;import{EyeSlashIcon as Gf,LinkIcon as zf,ClockIcon as $f}from"@heroicons/react/24/outline";import Lt from"styled-components";import{jsx as _a,jsxs as Hf}from"react/jsx-runtime";var ni=({size:e=61,...t})=>_a("svg",{width:e,height:e,viewBox:"0 0 61 61",fill:"none",xmlns:"http://www.w3.org/2000/svg",...t,children:Hf("g",{id:"moonpay_symbol_wht 2",children:[_a("rect",{x:"1.3374",y:"1",width:"59",height:"59",rx:"11.5",fill:"#7715F5"}),_a("path",{id:"Vector",d:"M43.8884 23.3258C45.0203 23.3258 46.1268 22.9901 47.068 22.3613C48.0091 21.7324 48.7427 20.8386 49.1759 19.7928C49.6091 18.747 49.7224 17.5962 49.5016 16.4861C49.2807 15.3759 48.7357 14.3561 47.9353 13.5557C47.1349 12.7553 46.1151 12.2102 45.0049 11.9893C43.8947 11.7685 42.7439 11.8819 41.6982 12.3151C40.6524 12.7482 39.7585 13.4818 39.1297 14.423C38.5008 15.3641 38.1651 16.4707 38.1651 17.6026C38.165 18.3542 38.3131 19.0985 38.6007 19.7929C38.8883 20.4873 39.3098 21.1182 39.8413 21.6496C40.3728 22.1811 41.0037 22.6027 41.6981 22.8903C42.3925 23.1778 43.1367 23.3259 43.8884 23.3258ZM26.3395 49.1017C23.5804 49.1017 20.8832 48.2836 18.5891 46.7507C16.295 45.2178 14.5069 43.039 13.4511 40.49C12.3952 37.9409 12.1189 35.1359 12.6572 32.4298C13.1955 29.7237 14.5241 27.238 16.4751 25.287C18.4262 23.336 20.9118 22.0074 23.6179 21.4691C26.324 20.9308 29.129 21.2071 31.6781 22.2629C34.2272 23.3189 36.406 25.1069 37.9389 27.401C39.4717 29.6952 40.2899 32.3923 40.2899 35.1514C40.2899 36.9835 39.9291 38.7975 39.2281 40.49C38.527 42.1826 37.4994 43.7205 36.204 45.0159C34.9086 46.3113 33.3707 47.3389 31.6781 48.04C29.9856 48.741 28.1715 49.1018 26.3395 49.1017Z",fill:"white"})]})});import{Fragment as Hc,jsx as Ae,jsxs as Oo}from"react/jsx-runtime";var Aa=({title:e,desc:t,icon:o})=>Oo(Yf,{children:[Ae(Qf,{children:o}),Oo(Jf,{children:[Ae(jf,{children:e}),Ae(Kf,{children:t})]})]}),Gc=({app:e,signedUrl:t,onContinue:o})=>Oo(Hc,{children:[Oo(Vf,{children:[Ae(ni,{size:"3.75rem"}),Oo(qf,{children:[e?.name," uses ",Ae("span",{style:{fontWeight:"bold"},children:"Moonpay"})," to fund your account"]}),Oo(Zf,{children:[Ae(Aa,{icon:Ae(zf,{width:"1rem"}),title:"Purchase assets to fund your account",desc:Oo(Hc,{children:["Connect a payment method (",Ae("strong",{children:"debit card recommended"}),") to purchase digital assets."]})}),Ae(Aa,{icon:Ae($f,{width:"1rem"}),title:"Compliance takes time",desc:"Funding a new account may take a few hours. You'll be good to go thereafter."}),Ae(Aa,{icon:Ae(Gf,{width:"1rem"}),title:"Your data belongs to you",desc:"MoonPay does not sell your data and will only use it with your permission."})]}),Ae(Xf,{className:"mobile-only"})]}),Ae(ce,{children:Ae(Ln,{href:t,target:"_blank",rel:"noopener noreferrer",annotation:"By clicking continue, you will be taken to MoonPay in a new tab",onClick:o,children:"Continue to Moonpay"})})]}),Vf=Lt.div`
1136
+ `;import{EyeSlashIcon as Gf,LinkIcon as zf,ClockIcon as $f}from"@heroicons/react/24/outline";import Lt from"styled-components";import{jsx as _a,jsxs as Hf}from"react/jsx-runtime";var ni=({size:e=61,...t})=>_a("svg",{width:e,height:e,viewBox:"0 0 61 61",fill:"none",xmlns:"http://www.w3.org/2000/svg",...t,children:Hf("g",{id:"moonpay_symbol_wht 2",children:[_a("rect",{x:"1.3374",y:"1",width:"59",height:"59",rx:"11.5",fill:"#7715F5"}),_a("path",{id:"Vector",d:"M43.8884 23.3258C45.0203 23.3258 46.1268 22.9901 47.068 22.3613C48.0091 21.7324 48.7427 20.8386 49.1759 19.7928C49.6091 18.747 49.7224 17.5962 49.5016 16.4861C49.2807 15.3759 48.7357 14.3561 47.9353 13.5557C47.1349 12.7553 46.1151 12.2102 45.0049 11.9893C43.8947 11.7685 42.7439 11.8819 41.6982 12.3151C40.6524 12.7482 39.7585 13.4818 39.1297 14.423C38.5008 15.3641 38.1651 16.4707 38.1651 17.6026C38.165 18.3542 38.3131 19.0985 38.6007 19.7929C38.8883 20.4873 39.3098 21.1182 39.8413 21.6496C40.3728 22.1811 41.0037 22.6027 41.6981 22.8903C42.3925 23.1778 43.1367 23.3259 43.8884 23.3258ZM26.3395 49.1017C23.5804 49.1017 20.8832 48.2836 18.5891 46.7507C16.295 45.2178 14.5069 43.039 13.4511 40.49C12.3952 37.9409 12.1189 35.1359 12.6572 32.4298C13.1955 29.7237 14.5241 27.238 16.4751 25.287C18.4262 23.336 20.9118 22.0074 23.6179 21.4691C26.324 20.9308 29.129 21.2071 31.6781 22.2629C34.2272 23.3189 36.406 25.1069 37.9389 27.401C39.4717 29.6952 40.2899 32.3923 40.2899 35.1514C40.2899 36.9835 39.9291 38.7975 39.2281 40.49C38.527 42.1826 37.4994 43.7205 36.204 45.0159C34.9086 46.3113 33.3707 47.3389 31.6781 48.04C29.9856 48.741 28.1715 49.1018 26.3395 49.1017Z",fill:"white"})]})});import{Fragment as Hc,jsx as ke,jsxs as Oo}from"react/jsx-runtime";var Aa=({title:e,desc:t,icon:o})=>Oo(Yf,{children:[ke(Qf,{children:o}),Oo(Jf,{children:[ke(jf,{children:e}),ke(Kf,{children:t})]})]}),Gc=({app:e,signedUrl:t,onContinue:o})=>Oo(Hc,{children:[Oo(Vf,{children:[ke(ni,{size:"3.75rem"}),Oo(qf,{children:[e?.name," uses ",ke("span",{style:{fontWeight:"bold"},children:"Moonpay"})," to fund your account"]}),Oo(Zf,{children:[ke(Aa,{icon:ke(zf,{width:"1rem"}),title:"Purchase assets to fund your account",desc:Oo(Hc,{children:["Connect a payment method (",ke("strong",{children:"debit card recommended"}),") to purchase digital assets."]})}),ke(Aa,{icon:ke($f,{width:"1rem"}),title:"Compliance takes time",desc:"Funding a new account may take a few hours. You'll be good to go thereafter."}),ke(Aa,{icon:ke(Gf,{width:"1rem"}),title:"Your data belongs to you",desc:"MoonPay does not sell your data and will only use it with your permission."})]}),ke(Xf,{className:"mobile-only"})]}),ke(ce,{children:ke(Ln,{href:t,target:"_blank",rel:"noopener noreferrer",annotation:"By clicking continue, you will be taken to MoonPay in a new tab",onClick:o,children:"Continue to Moonpay"})})]}),Vf=Lt.div`
1137
1137
  display: flex;
1138
1138
  flex-direction: column;
1139
1139
  align-items: center;
@@ -1223,7 +1223,7 @@ You will need this password to access your ${e} wallet on a new device. Please k
1223
1223
  margin-bottom: auto;
1224
1224
  }
1225
1225
  }
1226
- `;import by from"qrcode";import Ey from"styled-components";import{Fragment as pr,jsx as ke,jsxs as Xc}from"react/jsx-runtime";var Ke=7,Ia=(e,t,o,r,n)=>{for(let i=t;i<t+r;i++)for(let a=o;a<o+n;a++){let l=e?.[a];l&&l[i]&&(l[i]=0)}return e},xy=e=>{let t=by.create(e,{errorCorrectionLevel:"high"}).modules,o=Vs(Array.from(t.data),t.size);return o=Ia(o,0,0,Ke,Ke),o=Ia(o,o.length-Ke,0,Ke,Ke),o=Ia(o,0,o.length-Ke,Ke,Ke),o},Py=({x:e,y:t,cellSize:o,bgColor:r,fgColor:n})=>ke(pr,{children:[0,1,2].map(i=>ke("circle",{r:o*(Ke-i*2)/2,cx:e+o*Ke/2,cy:t+o*Ke/2,fill:i%2!==0?r:n},`finder-${e}-${t}-${i}`))}),Ty=({cellSize:e,matrixSize:t,bgColor:o,fgColor:r})=>{let n=[[0,0],[(t-Ke)*e,0],[0,(t-Ke)*e]];return ke(pr,{children:n.map(([i,a])=>ke(Py,{x:i,y:a,cellSize:e,bgColor:o,fgColor:r}))})},Sy=({matrix:e,cellSize:t,color:o})=>ke(pr,{children:e.map((r,n)=>r.map((i,a)=>i?ke("circle",{r:t/2.5,cx:n*t+t/2,cy:a*t+t/2,fill:o},`circle-${n}-${a}`):ke(pr,{})))}),Qc=(e,t)=>e-e%t,_y=({outputSize:e,cellSize:t,element:o,size:r,padding:n,bgColor:i})=>{if(!o)return ke(pr,{});let a=r||40,l=n||4,s=o,c=e/2-a/2-l;return Xc(pr,{children:[ke("rect",{x:Qc(c,t),y:Qc(c,t),width:a+l*2+(c%t?t+.5:.5),height:a+l*2+(c%t?t+.5:.5),fill:i}),ke(s,{x:e/2-a/2,y:e/2-a/2,height:a,width:a})]})},Ay=e=>{let t=e.outputSize,o=xy(e.url),r=t/o.length;return Xc("svg",{height:e.outputSize,width:e.outputSize,viewBox:`0 0 ${e.outputSize} ${e.outputSize}`,style:{height:"100%",width:"100%"},children:[ke(Sy,{matrix:o,cellSize:r,color:e.fgColor}),ke(Ty,{cellSize:r,matrixSize:o.length,fgColor:e.fgColor,bgColor:e.bgColor}),ke(_y,{outputSize:e.outputSize,cellSize:r,element:e.logo?.element,bgColor:e.bgColor})]})},ky=Ey.div`
1226
+ `;import by from"qrcode";import Ey from"styled-components";import{Fragment as pr,jsx as Re,jsxs as Xc}from"react/jsx-runtime";var Ke=7,Ia=(e,t,o,r,n)=>{for(let i=t;i<t+r;i++)for(let a=o;a<o+n;a++){let l=e?.[a];l&&l[i]&&(l[i]=0)}return e},xy=e=>{let t=by.create(e,{errorCorrectionLevel:"high"}).modules,o=Vs(Array.from(t.data),t.size);return o=Ia(o,0,0,Ke,Ke),o=Ia(o,o.length-Ke,0,Ke,Ke),o=Ia(o,0,o.length-Ke,Ke,Ke),o},Py=({x:e,y:t,cellSize:o,bgColor:r,fgColor:n})=>Re(pr,{children:[0,1,2].map(i=>Re("circle",{r:o*(Ke-i*2)/2,cx:e+o*Ke/2,cy:t+o*Ke/2,fill:i%2!==0?r:n},`finder-${e}-${t}-${i}`))}),Ty=({cellSize:e,matrixSize:t,bgColor:o,fgColor:r})=>{let n=[[0,0],[(t-Ke)*e,0],[0,(t-Ke)*e]];return Re(pr,{children:n.map(([i,a])=>Re(Py,{x:i,y:a,cellSize:e,bgColor:o,fgColor:r}))})},Sy=({matrix:e,cellSize:t,color:o})=>Re(pr,{children:e.map((r,n)=>r.map((i,a)=>i?Re("circle",{r:t/2.5,cx:n*t+t/2,cy:a*t+t/2,fill:o},`circle-${n}-${a}`):Re(pr,{})))}),Qc=(e,t)=>e-e%t,_y=({outputSize:e,cellSize:t,element:o,size:r,padding:n,bgColor:i})=>{if(!o)return Re(pr,{});let a=r||40,l=n||4,s=o,c=e/2-a/2-l;return Xc(pr,{children:[Re("rect",{x:Qc(c,t),y:Qc(c,t),width:a+l*2+(c%t?t+.5:.5),height:a+l*2+(c%t?t+.5:.5),fill:i}),Re(s,{x:e/2-a/2,y:e/2-a/2,height:a,width:a})]})},Ay=e=>{let t=e.outputSize,o=xy(e.url),r=t/o.length;return Xc("svg",{height:e.outputSize,width:e.outputSize,viewBox:`0 0 ${e.outputSize} ${e.outputSize}`,style:{height:"100%",width:"100%"},children:[Re(Sy,{matrix:o,cellSize:r,color:e.fgColor}),Re(Ty,{cellSize:r,matrixSize:o.length,fgColor:e.fgColor,bgColor:e.bgColor}),Re(_y,{outputSize:e.outputSize,cellSize:r,element:e.logo?.element,bgColor:e.bgColor})]})},ky=Ey.div`
1227
1227
  display: flex;
1228
1228
  justify-content: center;
1229
1229
  align-items: center;
@@ -1238,7 +1238,7 @@ You will need this password to access your ${e} wallet on a new device. Please k
1238
1238
  border-color: ${e=>e.fgColor};
1239
1239
  border-radius: var(--privy-border-radius-md);
1240
1240
  }
1241
- `,Zc=e=>{let t=e.bgColor||"#FFFFFF",o=e.fgColor||"#000000",r=e.size||160;return ke(ky,{size:r,bgColor:t,fgColor:o,children:ke(Ay,{url:e.url,logo:{element:e.squareLogoElement},outputSize:r,bgColor:t,fgColor:o})})};import{jsx as Ry}from"react/jsx-runtime";var ed=({size:e})=>Ry(Zc,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:Qt,size:e,fgColor:"#1F1F1F"});import{Fragment as Ny,jsx as Re,jsxs as si}from"react/jsx-runtime";var Wy=()=>{let{navigate:e}=b();return si(My,{children:[Re(dt,{title:"Create a Coinbase wallet",description:"Follow the instructions below to get started."}),Re(et,{style:{marginTop:"-24px"},children:Re(ed,{size:200})}),si(dr,{children:[Re(rt,{children:"Scan the QR code with your camera"}),Re(Dt,{}),Re(rt,{children:"Set up your first wallet"}),Re(Dt,{}),Re(rt,{children:"Store your seed phrase in a safe place!"})]}),Re(ie,{onClick:()=>e("LANDING"),children:"Done! I have my wallet"})]})},td=()=>{let{navigateBack:e}=b();return si(Ny,{children:[Re(T,{backFn:e},"header"),Re(S,{}),Re(Wy,{}),Re(W,{}),si(X,{children:[Re("span",{children:"Still not sure? "}),Re("a",{target:"_blank",href:"https://ethereum.org/en/wallets/",children:"Learn more"})]})]})},My=Iy(et)`
1241
+ `,Zc=e=>{let t=e.bgColor||"#FFFFFF",o=e.fgColor||"#000000",r=e.size||160;return Re(ky,{size:r,bgColor:t,fgColor:o,children:Re(Ay,{url:e.url,logo:{element:e.squareLogoElement},outputSize:r,bgColor:t,fgColor:o})})};import{jsx as Ry}from"react/jsx-runtime";var ed=({size:e})=>Ry(Zc,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:Qt,size:e,fgColor:"#1F1F1F"});import{Fragment as Ny,jsx as Ie,jsxs as si}from"react/jsx-runtime";var Wy=()=>{let{navigate:e}=b();return si(My,{children:[Ie(dt,{title:"Create a Coinbase wallet",description:"Follow the instructions below to get started."}),Ie(et,{style:{marginTop:"-24px"},children:Ie(ed,{size:200})}),si(dr,{children:[Ie(rt,{children:"Scan the QR code with your camera"}),Ie(Dt,{}),Ie(rt,{children:"Set up your first wallet"}),Ie(Dt,{}),Ie(rt,{children:"Store your seed phrase in a safe place!"})]}),Ie(ie,{onClick:()=>e("LANDING"),children:"Done! I have my wallet"})]})},td=()=>{let{navigateBack:e}=b();return si(Ny,{children:[Ie(T,{backFn:e},"header"),Ie(S,{}),Ie(Wy,{}),Ie(W,{}),si(X,{children:[Ie("span",{children:"Still not sure? "}),Ie("a",{target:"_blank",href:"https://ethereum.org/en/wallets/",children:"Learn more"})]})]})},My=Iy(et)`
1242
1242
  gap: 30px;
1243
1243
 
1244
1244
  > :first-child > svg {
@@ -1740,7 +1740,7 @@ You will need this password to access your ${e} wallet on a new device. Please k
1740
1740
  margin-top: 24px;
1741
1741
  }
1742
1742
  transition: color 350ms ease, background-color 350ms ease;
1743
- `;import{Fragment as Xa,jsx as pe,jsxs as vr}from"react/jsx-runtime";var Dv=({txn:e,txnFamily:t,uiOptions:o,tokenSymbol:r,tokenPrice:n})=>{if(t==="CONTRACT_CALL"){if(o.transactionInfo?.contractInfo)return pe(Va,{contractInfo:o.transactionInfo.contractInfo,description:o.description});if(o.senderInfo)return pe(Va,{contractInfo:o.senderInfo,description:o.description||o.senderInfo.actionText})}return pe(Xa,{children:pe(yp,{description:o.description||o.transactionInfo?.description||"",txn:e,tokenSymbol:r,tokenPrice:n})})},Tp=()=>{let{authenticated:e,getAccessToken:t}=G(),{wallets:o}=Qa(),{walletProxy:r,closePrivyModal:n,getFiatOnRampConfig:i,rpcConfig:a,chains:l,nativeTokenSymbolForChainId:s}=_(),{app:c,navigate:h,data:m,onUserCloseViaDialogOrKeybindRef:g,setModalData:f}=b(),{transactionRequest:C,onSuccess:P,onFailure:E,uiOptions:x,fundWalletConfig:k}=m.sendTransaction,[N,I]=wo(null),[R,M]=wo(null),[A,te]=wo(""),[O,q]=wo(),[H,J]=wo(!1),U=()=>{te(""),q(void 0)},Ie=(Me,ne,mt)=>{te(Me),q(new Pe(new yt(ne??Me,mt??Ne.E32603_DEFAULT_INTERNAL_ERROR.eipCode)))},[re,V]=wo(!0),[Ce,le]=wo(!1),[D,Gt]=wo(C),{tokenPrice:zt,estimatedGas:Po,isTokenPriceLoading:an}=wp(D),To=s(C.chainId)||"ETH";xp(()=>{e||(h("LANDING"),E(new Error("User must be authenticated before transacting with a Privy wallet")))},[e]);let We=Ep(()=>o.find(Me=>Me.walletClientType==="privy"),[o]),sn=async()=>{if(!We)return console.warn("No privy wallet found, cannot fund wallet.");let{signedUrl:Me,externalTransactionId:ne}=await i(We.address,{config:k?.config||{}});f({fiatOnRampPrompt:{signedUrl:Me},fiatOnRampStatus:{externalTransactionId:ne}}),h("FIAT_ON_RAMP_PROMPT_SCREEN")},$=Ep(()=>new Lv(at(D.chainId,l,a)),[D.chainId,a]);xp(()=>{async function Me(){return!await t()||!r||!We?D:Si(We.address,D,$)}Me().then(ne=>{V(!1),Gt(ne)},async ne=>{V(!0);let mt="There was an error preparing your transaction. Please try again.";Xl(ne)&&(mt="Wallet has insufficient funds for this transaction.",c?.fiatOnRamp.enabled&&J(!0)),A!=="Wallet has insufficient funds for this transaction."&&Ie(mt,ne.reason)})},[r]);let ue=gp(D),zo=ue==="SEND"?`Send ${To}`:"Review transaction",Cr={modalTitle:x.header||x.modalTitle||zo,buttonText:x.buttonText||"Submit"},$t=()=>{Ce||(R?P(R):E(O||new Pe(new yt("The user rejected the request",Ne.E4001_USER_REJECTED_REQUEST.eipCode))),n({shouldCallAuthOnSuccess:!1}))};return g.current=$t,zt===void 0&&an?vr(Xa,{children:[pe(T,{title:Cr.modalTitle,onClose:$t}),pe(S,{}),pe(Pp,{children:pe(rr,{})}),pe(W,{})]}):N!==null?pe(bp,{txn:D,onClose:$t,receipt:N,transactionInfo:x.transactionInfo,tokenPrice:zt,tokenSymbol:To}):vr(Xa,{children:[pe(T,{title:Cr.modalTitle,onClose:$t}),vr(Pp,{children:[vr(Hv,{children:[pe(Dv,{txn:D,txnFamily:ue,uiOptions:x,tokenSymbol:To,tokenPrice:zt}),We?pe(Ti,{from:We.address,to:D.to,txn:D,transactionInfo:x.transactionInfo,gas:Po?yo(Po).toHexString():void 0,tokenPrice:zt,tokenSymbol:To}):null]}),vr(Gv,{children:[pe(Uv,{children:A}),We?pe(up,{txn:D,wallet:We,provider:$,onInsufficientFunds:()=>Ie("Wallet has insufficient funds for this transaction.")}):null,vr(Fv,{children:[H&&pe(j,{onClick:sn,children:"Add Funds"}),pe(Bv,{disabled:re||Ce,loading:!r||Ce,loadingText:Ce?"Submitting (may take a few minutes)...":"Loading...",onClick:async()=>{le(!0);let Me=await t();if(Me&&!Ce&&We)try{let ne=await _i(Me,We.address,r,D,$);M(ne);let mt=await ne.wait();I(Ai(mt)),U()}catch(ne){let mt="There was an error processing your transaction. Please contact support.";console.warn({transaction:D,error:ne}),Ie(mt,ne.reason)}finally{le(!1)}},children:Cr.buttonText})]})]})]}),pe(X,{})]})},Pp=wr.div`
1743
+ `;import{Fragment as Xa,jsx as pe,jsxs as vr}from"react/jsx-runtime";var Dv=({txn:e,txnFamily:t,uiOptions:o,tokenSymbol:r,tokenPrice:n})=>{if(t==="CONTRACT_CALL"){if(o.transactionInfo?.contractInfo)return pe(Va,{contractInfo:o.transactionInfo.contractInfo,description:o.description});if(o.senderInfo)return pe(Va,{contractInfo:o.senderInfo,description:o.description||o.senderInfo.actionText})}return pe(Xa,{children:pe(yp,{description:o.description||o.transactionInfo?.description||"",txn:e,tokenSymbol:r,tokenPrice:n})})},Tp=()=>{let{authenticated:e,getAccessToken:t}=G(),{wallets:o}=Qa(),{walletProxy:r,closePrivyModal:n,getFiatOnRampConfig:i,rpcConfig:a,chains:l,nativeTokenSymbolForChainId:s}=_(),{app:c,navigate:h,data:m,onUserCloseViaDialogOrKeybindRef:g,setModalData:f}=b(),{transactionRequest:C,onSuccess:P,onFailure:E,uiOptions:x,fundWalletConfig:k}=m.sendTransaction,[N,I]=wo(null),[R,M]=wo(null),[A,te]=wo(""),[O,q]=wo(),[H,J]=wo(!1),U=()=>{te(""),q(void 0)},We=(Me,ne,mt)=>{te(Me),q(new Te(new yt(ne??Me,mt??Ne.E32603_DEFAULT_INTERNAL_ERROR.eipCode)))},[re,V]=wo(!0),[Ce,le]=wo(!1),[D,Gt]=wo(C),{tokenPrice:zt,estimatedGas:Po,isTokenPriceLoading:an}=wp(D),To=s(C.chainId)||"ETH";xp(()=>{e||(h("LANDING"),E(new Error("User must be authenticated before transacting with a Privy wallet")))},[e]);let Ee=Ep(()=>o.find(Me=>Me.walletClientType==="privy"),[o]),sn=async()=>{if(!Ee)return console.warn("No privy wallet found, cannot fund wallet.");let{signedUrl:Me,externalTransactionId:ne}=await i(Ee.address,{config:k?.config||{}});f({fiatOnRampPrompt:{signedUrl:Me},fiatOnRampStatus:{externalTransactionId:ne}}),h("FIAT_ON_RAMP_PROMPT_SCREEN")},$=Ep(()=>new Lv(at(D.chainId,l,a)),[D.chainId,a]);xp(()=>{async function Me(){return!await t()||!r||!Ee?D:Si(Ee.address,D,$)}Me().then(ne=>{V(!1),Gt(ne)},async ne=>{V(!0);let mt="There was an error preparing your transaction. Please try again.";Xl(ne)&&(mt="Wallet has insufficient funds for this transaction.",c?.fiatOnRamp.enabled&&J(!0)),A!=="Wallet has insufficient funds for this transaction."&&We(mt,ne.reason)})},[r]);let ue=gp(D),zo=ue==="SEND"?`Send ${To}`:"Review transaction",Cr={modalTitle:x.header||x.modalTitle||zo,buttonText:x.buttonText||"Submit"},$t=()=>{Ce||(R?P(R):E(O||new Te(new yt("The user rejected the request",Ne.E4001_USER_REJECTED_REQUEST.eipCode))),n({shouldCallAuthOnSuccess:!1}))};return g.current=$t,zt===void 0&&an?vr(Xa,{children:[pe(T,{title:Cr.modalTitle,onClose:$t}),pe(S,{}),pe(Pp,{children:pe(rr,{})}),pe(W,{})]}):N!==null?pe(bp,{txn:D,onClose:$t,receipt:N,transactionInfo:x.transactionInfo,tokenPrice:zt,tokenSymbol:To}):vr(Xa,{children:[pe(T,{title:Cr.modalTitle,onClose:$t}),vr(Pp,{children:[vr(Hv,{children:[pe(Dv,{txn:D,txnFamily:ue,uiOptions:x,tokenSymbol:To,tokenPrice:zt}),Ee?pe(Ti,{from:Ee.address,to:D.to,txn:D,transactionInfo:x.transactionInfo,gas:Po?yo(Po).toHexString():void 0,tokenPrice:zt,tokenSymbol:To}):null]}),vr(Gv,{children:[pe(Uv,{children:A}),Ee?pe(up,{txn:D,wallet:Ee,provider:$,onInsufficientFunds:()=>We("Wallet has insufficient funds for this transaction.")}):null,vr(Fv,{children:[H&&pe(j,{onClick:sn,children:"Add Funds"}),pe(Bv,{disabled:re||Ce,loading:!r||Ce,loadingText:Ce?"Submitting (may take a few minutes)...":"Loading...",onClick:async()=>{le(!0);let Me=await t();if(Me&&!Ce&&Ee)try{let ne=await _i(Me,Ee.address,r,D,$);M(ne);let mt=await ne.wait();I(Ai(mt)),U()}catch(ne){let mt="There was an error processing your transaction. Please contact support.";console.warn({transaction:D,error:ne}),We(mt,ne.reason)}finally{le(!1)}},children:Cr.buttonText})]})]})]}),pe(X,{})]})},Pp=wr.div`
1744
1744
  display: flex;
1745
1745
  height: 100%;
1746
1746
  flex-direction: column;
@@ -1770,7 +1770,7 @@ You will need this password to access your ${e} wallet on a new device. Please k
1770
1770
  display: flex;
1771
1771
  flex-direction: column;
1772
1772
  gap: 8px;
1773
- `;import{isHexString as zv}from"@ethersproject/bytes";import{toUtf8String as $v}from"@ethersproject/strings";import{useEffect as Ap,useState as Ri}from"react";import on,{css as Vv}from"styled-components";import{jsx as Sp}from"react/jsx-runtime";var _p=({style:e,color:t,...o})=>Sp("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:t||"currentColor",style:{height:"1.5rem",width:"1.5rem",...e},...o,children:Sp("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M4.5 12.75l6 6 9-13.5"})});import{Fragment as Zv,jsx as _t,jsxs as Ii}from"react/jsx-runtime";var qv=e=>{if(!zv(e))return e;try{return $v(e)}catch{return e}},kp=()=>{let{authenticated:e}=G(),{initializeWalletProxy:t,closePrivyModal:o}=_(),{navigate:r,data:n,onUserCloseViaDialogOrKeybindRef:i}=b(),[a,l]=Ri(!0),[s,c]=Ri(""),[h,m]=Ri(),[g,f]=Ri(null),C=g!==null;Ap(()=>{e||r("LANDING")},[e]),Ap(()=>{t(jo).then(M=>{l(!1),M||(c("An error has occurred, please try again."),m(new Pe(new yt(s,Ne.E32603_DEFAULT_INTERNAL_ERROR.eipCode))))})},[]);let{message:P,confirmAndSignMessage:E,onSuccess:x,onFailure:k,uiOptions:N}=n.signMessage,I={title:N.title||"Sign message",description:N.description||"Signing this message will not cost you any fees.",buttonText:N.buttonText||"Sign and continue"},R=M=>{M?x(M):k(h||new Pe(new yt("The user rejected the request.",Ne.E4001_USER_REJECTED_REQUEST.eipCode))),o({shouldCallAuthOnSuccess:!1}),f(null),c(""),m(void 0)};return i.current=()=>{R(g)},Ii(Zv,{children:[_t(T,{onClose:()=>R(g)}),_t(S,{}),Ii(jv,{children:[Ii("div",{children:[_t(dt,{title:I.title,description:I.description}),_t(Kv,{children:qv(P)}),_t(Yv,{fail:!0,children:s})]}),_t(Qv,{success:C,loading:a,disabled:C,onClick:async()=>{try{let M=await E();f(M),c(""),setTimeout(()=>{R(M)},Ge)}catch{c("An error has occurred, please try again."),m(new Pe(new yt(s,Ne.E32603_DEFAULT_INTERNAL_ERROR.eipCode)))}},children:C?Ii(Jv,{children:[_t(_p,{style:{height:"0.9rem",width:"0.9rem"},strokeWidth:2})," ",_t("span",{children:"Success"})]}):I.buttonText})]}),_t(W,{}),_t(F,{protectedByPrivy:!0})]})},jv=on.div`
1773
+ `;import{isHexString as zv}from"@ethersproject/bytes";import{toUtf8String as $v}from"@ethersproject/strings";import{useEffect as Ap,useState as Ri}from"react";import on,{css as Vv}from"styled-components";import{jsx as Sp}from"react/jsx-runtime";var _p=({style:e,color:t,...o})=>Sp("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:t||"currentColor",style:{height:"1.5rem",width:"1.5rem",...e},...o,children:Sp("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M4.5 12.75l6 6 9-13.5"})});import{Fragment as Zv,jsx as _t,jsxs as Ii}from"react/jsx-runtime";var qv=e=>{if(!zv(e))return e;try{return $v(e)}catch{return e}},kp=()=>{let{authenticated:e}=G(),{initializeWalletProxy:t,closePrivyModal:o}=_(),{navigate:r,data:n,onUserCloseViaDialogOrKeybindRef:i}=b(),[a,l]=Ri(!0),[s,c]=Ri(""),[h,m]=Ri(),[g,f]=Ri(null),C=g!==null;Ap(()=>{e||r("LANDING")},[e]),Ap(()=>{t(jo).then(M=>{l(!1),M||(c("An error has occurred, please try again."),m(new Te(new yt(s,Ne.E32603_DEFAULT_INTERNAL_ERROR.eipCode))))})},[]);let{message:P,confirmAndSignMessage:E,onSuccess:x,onFailure:k,uiOptions:N}=n.signMessage,I={title:N.title||"Sign message",description:N.description||"Signing this message will not cost you any fees.",buttonText:N.buttonText||"Sign and continue"},R=M=>{M?x(M):k(h||new Te(new yt("The user rejected the request.",Ne.E4001_USER_REJECTED_REQUEST.eipCode))),o({shouldCallAuthOnSuccess:!1}),f(null),c(""),m(void 0)};return i.current=()=>{R(g)},Ii(Zv,{children:[_t(T,{onClose:()=>R(g)}),_t(S,{}),Ii(jv,{children:[Ii("div",{children:[_t(dt,{title:I.title,description:I.description}),_t(Kv,{children:qv(P)}),_t(Yv,{fail:!0,children:s})]}),_t(Qv,{success:C,loading:a,disabled:C,onClick:async()=>{try{let M=await E();f(M),c(""),setTimeout(()=>{R(M)},Ge)}catch{c("An error has occurred, please try again."),m(new Te(new yt(s,Ne.E32603_DEFAULT_INTERNAL_ERROR.eipCode)))}},children:C?Ii(Jv,{children:[_t(_p,{style:{height:"0.9rem",width:"0.9rem"},strokeWidth:2})," ",_t("span",{children:"Success"})]}):I.buttonText})]}),_t(W,{}),_t(F,{protectedByPrivy:!0})]})},jv=on.div`
1774
1774
  display: flex;
1775
1775
  height: 100%;
1776
1776
  flex-direction: column;
@@ -2195,4 +2195,4 @@ You will need this password to access your ${e} wallet on a new device. Please k
2195
2195
  align-items: center;
2196
2196
  justify-content: center;
2197
2197
  height: 100%;
2198
- `;var Lp={id:42161,name:"Arbitrum One",network:"arbitrum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{alchemy:{http:["https://arb-mainnet.g.alchemy.com/v2"],webSocket:["wss://arb-mainnet.g.alchemy.com/v2"]},infura:{http:["https://arbitrum-mainnet.infura.io/v3"],webSocket:["wss://arbitrum-mainnet.infura.io/ws/v3"]},default:{http:["https://arb1.arbitrum.io/rpc"]},public:{http:["https://arb1.arbitrum.io/rpc"]}},blockExplorers:{etherscan:{name:"Arbiscan",url:"https://arbiscan.io"},default:{name:"Arbiscan",url:"https://arbiscan.io"}}};var Dp={id:421613,name:"Arbitrum Goerli",network:"arbitrum-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"AGOR",decimals:18},rpcUrls:{alchemy:{http:["https://arb-goerli.g.alchemy.com/v2"],webSocket:["wss://arb-goerli.g.alchemy.com/v2"]},infura:{http:["https://arbitrum-goerli.infura.io/v3"],webSocket:["wss://arbitrum-goerli.infura.io/ws/v3"]},default:{http:["https://goerli-rollup.arbitrum.io/rpc"]},public:{http:["https://goerli-rollup.arbitrum.io/rpc"]}},blockExplorers:{etherscan:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"},default:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"}},testnet:!0};var Up={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 Fp={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 Bp={id:8453,network:"base",name:"Base",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{blast:{http:["https://base-mainnet.blastapi.io"],webSocket:["wss://base-mainnet.blastapi.io"]},default:{http:["https://mainnet.base.org"]},public:{http:["https://mainnet.base.org"]}},blockExplorers:{etherscan:{name:"Basescan",url:"https://basescan.org"},default:{name:"Basescan",url:"https://basescan.org"}},testnet:!0};var Hp={id:84531,network:"base-goerli",name:"Base Goerli Testnet",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{blast:{http:["https://base-goerli.blastapi.io"],webSocket:["wss://base-goerli.blastapi.io"]},default:{http:["https://goerli.base.org"]},public:{http:["https://goerli.base.org"]}},blockExplorers:{etherscan:{name:"Basescan",url:"https://goerli.basescan.org"},default:{name:"Basescan",url:"https://goerli.basescan.org"}},testnet:!0};var Gp={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 zp={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 $p={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 Vp={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 qp={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 jp={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 Kp={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 Wi={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 Yp={id:10,name:"OP Mainnet",network:"optimism",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{alchemy:{http:["https://opt-mainnet.g.alchemy.com/v2"],webSocket:["wss://opt-mainnet.g.alchemy.com/v2"]},infura:{http:["https://optimism-mainnet.infura.io/v3"],webSocket:["wss://optimism-mainnet.infura.io/ws/v3"]},default:{http:["https://mainnet.optimism.io"]},public:{http:["https://mainnet.optimism.io"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://optimistic.etherscan.io"},default:{name:"Optimism Explorer",url:"https://explorer.optimism.io"}}};var Jp={id:420,name:"Optimism Goerli Testnet",network:"optimism-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{alchemy:{http:["https://opt-goerli.g.alchemy.com/v2"],webSocket:["wss://opt-goerli.g.alchemy.com/v2"]},infura:{http:["https://optimism-goerli.infura.io/v3"],webSocket:["wss://optimism-goerli.infura.io/ws/v3"]},default:{http:["https://goerli.optimism.io"]},public:{http:["https://goerli.optimism.io"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"},default:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"}},testnet:!0};var Qp={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 Zp={id:7777777,name:"Zora",network:"zora",nativeCurrency:{decimals:18,name:"Ether",symbol:"ETH"},rpcUrls:{default:{http:["https://rpc.zora.energy"],webSocket:["wss://rpc.zora.energy"]},public:{http:["https://rpc.zora.energy"],webSocket:["wss://rpc.zora.energy"]}},blockExplorers:{default:{name:"Explorer",url:"https://explorer.zora.energy"}}};var Xp={id:999,name:"Zora Goerli Testnet",network:"zora-testnet",nativeCurrency:{decimals:18,name:"Zora Goerli",symbol:"ETH"},rpcUrls:{default:{http:["https://testnet.rpc.zora.energy"],webSocket:["wss://testnet.rpc.zora.energy"]},public:{http:["https://testnet.rpc.zora.energy"],webSocket:["wss://testnet.rpc.zora.energy"]}},blockExplorers:{default:{name:"Explorer",url:"https://testnet.explorer.zora.energy"}},testnet:!0};var rn=[Lp,Dp,qp,Qp,Wi,Yp,Jp,Xr,en,Gp,zp,$p,Vp,Bp,Hp,jp,Kp,Up,Fp,Zp,Xp],u8=new Set(rn.map(e=>e.id));import Go from"tinycolor2";var eu="#FFFFFF",fw="#000000",yw=eu,gw="#1E1E1D";function vw(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 Co(e,t){let o=Math.max(0,Math.min(1,e.toHsl().l+t));return Go({...e.toHsl(),l:o})}function tu({backgroundTheme:e,accentHex:t,successHex:o="#51BA81",warnHex:r="#FFB74D",errorHex:n="#EC6351",whiteHex:i=eu,blackHex:a=fw}){let l;switch(e){case"light":l=yw;break;case"dark":l=gw;break;default:l=e;break}let s=Go(l),c=Go(t),h=Go(o),m=Go(r),g=Go(n),f=vw(s.getLuminance()),C=Co(s,f==="light"?-.04:.11),P=Co(s,f==="light"?-.88:.87),E=Co(s,f==="light"?-.77:.75),x=Co(s,f==="light"?-.43:.45).desaturate(f==="light"?60:20),k=Co(s,f==="light"?-.08:.25).desaturate(f==="light"?60:20),N=Co(c,.15),I=Co(c,-.06),R=Go(c.getLuminance()>.5?a:i),M=Co(h,-.16);return{colorScheme:f,background:s.toHslString(),background2:C.toHslString(),foreground:P.toHslString(),foreground2:E.toHslString(),foreground3:x.toHslString(),foreground4:k.toHslString(),accent:c.toHslString(),accentLight:N.toHslString(),accentDark:I.toHslString(),foregroundAccent:R.toHslString(),success:h.toHslString(),successDark:M.toHslString(),error:g.toHslString(),warn:m.toHslString()}}var Bt={appearance:{theme:"light",accentColor:"#676FFF"},walletConnectCloudProjectId:Os,rpcConfig:{rpcUrls:{},rpcTimeouts:{}},captchaEnabled:!1,_render:{inDialog:!0,inParentNodeId:null},fiatOnRamp:{useSandbox:!1}};function Mi(e,t){let o=["google","twitter","discord","tiktok","linkedin","github","apple"],r=t?.loginMethods?.filter(I=>o.includes(I)),n=r?.slice(0,5),i,a,l,s,c,h,m,g,f,C;if(t?.loginMethods?(i=t.loginMethods.includes("email"),a=t.loginMethods.includes("sms"),l=t.loginMethods.includes("wallet"),s=n?.includes("google"),c=n?.includes("twitter"),h=n?.includes("discord"),m=n?.includes("tiktok"),f=n?.includes("github"),g=n?.includes("linkedin"),C=n?.includes("apple")):(i=e.emailAuth,a=e.smsAuth,l=e.walletAuth,s=e.googleOAuth,c=e.twitterOAuth,h=e.discordOAuth,f=e.githubOAuth,m=e.tiktokOAuth,g=e.linkedinOAuth,C=e.appleOAuth),i&&a&&(console.warn("Enabling both email and SMS passwordless is not currently supported. Disabling SMS."),a=!1),!i&&!a&&[s,c,h,f,m,g,C].some(I=>I))throw new Error("To enable social logins you must also enable either SMS or Email login");if(![i,a,l,s,c,h,f,m,g,C].some(I=>I))throw new Error("You must enable at least one login method");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{chains:P,defaultChain:E}=ww(t?.additionalChains,t?.supportedChains,t?.defaultChain),x=!!t?.defaultChain||!!t?.supportedChains;r&&r.length>5&&console.warn("Max number of social logins allowed is 5. Any more have been removed.");let k=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:tu({backgroundTheme:t?.appearance?.theme??Bt.appearance.theme,accentHex:t?.appearance?.accentColor??e.accentColor??Bt.appearance.accentColor}),showWalletLoginFirst:t?.appearance?.showWalletLoginFirst??e.showWalletLoginFirst},loginMethods:{wallet:l,email:i,sms:a,google:s,twitter:c,discord:h,github:f,tiktok:m,linkedin:g,apple:C},legal:{termsAndConditionsUrl:t?.legal?.termsAndConditionsUrl??e.termsAndConditionsUrl,privacyPolicyUrl:t?.legal?.privacyPolicyUrl??e.privacyPolicyUrl},walletConnectCloudProjectId:t?.walletConnectCloudProjectId??e.walletConnectCloudProjectId??Bt.walletConnectCloudProjectId,rpcConfig:{rpcUrls:t?.rpcConfig?.rpcUrls??Bt.rpcConfig.rpcUrls,rpcTimeouts:t?.rpcConfig?.rpcTimeouts??Bt.rpcConfig.rpcTimeouts},chains:P,defaultChain:E,shouldSwitchChainOnConnect:x,captchaEnabled:e.captchaEnabled??Bt.captchaEnabled,captchaSiteKey:e.captchaSiteKey,embeddedWallets:{...e.embeddedWalletConfig,...k?{createOnLogin:"all-users",requireUserPasswordOnCreate:!1,noPromptOnSignature:!0}:{},waitForTransactionConfirmation:!0,priceDisplay:{primary:"fiat-currency",secondary:"native-token"},...t?.embeddedWallets},customAuth:k?{enabled:!0,...t.customAuth}:void 0,fiatOnRamp:{enabled:e.fiatOnRampEnabled,useSandbox:t?.fiatOnRamp?.useSandbox??Bt.fiatOnRamp.useSandbox},loginConfig:{twitterOAuthOnMobileEnabled:e.twitterOAuthOnMobileEnabled??!1},render:{inDialog:t?._render?.inDialog??Bt._render.inDialog,inParentNodeId:t?._render?.inParentNodeId??Bt._render.inParentNodeId}}}function ou(e,t){if(!e)return{legacyCreateEmbeddedWalletFlag:t};let{appearance:o,additionalChains:r,supportedChains:n,...i}=e;return{...i,...r?{additionalChains:r.map(l=>l.id)}:void 0,...n?{supportedChains:n.map(l=>l.id)}:void 0,...o?{...o,...o.logo&&typeof o.logo?{logo:"component"}:void 0}:void 0,legacyCreateEmbeddedWalletFlag:t}}function ww(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=>rn.find(s=>s.id===a.id)??a)}else r=rn.concat(e??[]);let n=t?r[0]:Wi,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 xw,useEffect as Pw}from"react";import{createContext as Cw,useContext as bw,useEffect as Ew}from"react";var ru={login:{onComplete:[],onError:[]},logout:{onSuccess:[]},connectWallet:{onSuccess:[],onError:[]},createWallet:{onSuccess:[],onError:[]},configureMfa:{onMfaRequired:[],onError:[]}},ts=Cw(void 0),nu=()=>bw(ts);function At(e,t){if(!t)return;let r=nu().current[e];return Ew(()=>{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 K(e,t,o,...r){for(let n of e.current[t][o])n(...r)}function iu(){let e=nu();return(t,o,...r)=>K(e,t,o,...r)}var Ni=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:init-enrollment":return r;case"privy:mfa:submit-enrollment":return r;default:throw new Error(`invalid wallet event type ${t}`)}}};async function Oi(e,t,o,r,n,i=!1){let a=i,l=async h=>{if(a&&t&&t.length>0){h===(i?0:1)?n("configureMfa","onMfaRequired",t):r.current?.reject(new Se("mfa_verification_failed","MFA verification failed, retry."));let m=await new Promise((g,f)=>{o.current={resolve:g,reject:f};let C=1e3*60*5;setTimeout(()=>{let P=new Se("mfa_timeout","Timed out waiting for MFA code");r.current?.reject(P),f(P)},C)});return await e(m)}return await e()},s=4,c=null;for(let h=0;h<s;h++)try{c=await l(h),r.current?.resolve(void 0);break}catch(m){if(m.type==="mfa_verification_failed")a=!0;else throw r.current?.resolve(void 0),m}if(c===null){let h=new Se("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw r.current?.reject(h),h}return c}import{jsx as Rw}from"react/jsx-runtime";var Tw=function(e){return()=>`id-${e++}`}(0);function Sw(e){return typeof e.event=="string"&&/^privy:.+/.test(e.event)}function bo(e){return e.error!==void 0}var Ht=new Ni,os=new Map,_w=(e,t)=>typeof t=="bigint"?t.toString():t,Aw=(e,t)=>`${e}${JSON.stringify(t,_w)}`;function Eo(e,t,o){let r=o.contentWindow;if(!r)throw new Error("iframe not initialized");let n=Aw(e,t);if(e==="privy:wallet:create"){let a=os.get(n);if(a)return a}let i=new Promise((a,l)=>{let s=Tw();Ht.enqueue(s,{resolve:a,reject:l}),r.postMessage({id:s,event:e,data:t},"*")}).finally(()=>{os.delete(n)});return os.set(n,i),i}function kw(e){switch(e.event){case"privy:iframe:ready":let t=Ht.dequeue(e.event,e.id);return bo(e)?t.reject(new Se(e.error.type,e.error.message)):t.resolve(e.data);case"privy:wallet:create":let o=Ht.dequeue(e.event,e.id);return bo(e)?o.reject(new Se(e.error.type,e.error.message)):o.resolve(e.data);case"privy:wallet:connect":let r=Ht.dequeue(e.event,e.id);return bo(e)?r.reject(new Se(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallet:recover":let n=Ht.dequeue(e.event,e.id);return bo(e)?n.reject(new Se(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallet:rpc":let i=Ht.dequeue(e.event,e.id);return bo(e)?i.reject(new Se(e.error.type,e.error.message)):i.resolve(e.data);case"privy:wallet:set-recovery-password":let a=Ht.dequeue(e.event,e.id);return bo(e)?a.reject(new Se(e.error.type,e.error.message)):a.resolve(e.data);case"privy:mfa:init-enrollment":{let l=Ht.dequeue(e.event,e.id);return bo(e)?l.reject(new Se(e.error.type,e.error.message)):l.resolve(e.data)}case"privy:mfa:submit-enrollment":{let l=Ht.dequeue(e.event,e.id);return bo(e)?l.reject(new Se(e.error.type,e.error.message)):l.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}function au(e){let t=xw(null),o=iu();return Pw(()=>{let r=t.current;if(!r)return;function n(c){c&&c.origin===e.origin&&Sw(c.data)&&kw(c.data)}let i={create(c){return Eo("privy:wallet:create",c,r)},connect(c){return Eo("privy:wallet:connect",c,r)},recover(c){return Oi(h=>Eo("privy:wallet:recover",{...c,...h},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)},rpc(c){return Oi(h=>Eo("privy:wallet:rpc",{...c,...h},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o)},setRecoveryPassword(c){return Eo("privy:wallet:set-recovery-password",c,r)},initEnrollMfa(c){return Oi(h=>Eo("privy:mfa:init-enrollment",{...c,...h},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)},submitEnrollMfa(c){return Eo("privy:mfa:submit-enrollment",c,r)}};window.addEventListener("message",n);let a=()=>e.onLoad(i),l=(...c)=>{console.warn("Privy iframe failed to load: ",...c),e.onLoadFailed()},s=new AbortController;return js(()=>Eo("privy:iframe:ready",{},r),{abortSignal:s.signal}).then(a,l),()=>{window.removeEventListener("message",n),s.abort()}},[t.current,e.mfaMethods]),Rw("iframe",{ref:t,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},src:bn(e.origin,`/apps/${e.appId}/embedded-wallets`,{caid:e.clientAnalyticsId})})}var Li=class{constructor(t,o){this.meta={action:t,phoneNumber:o}}async init(){if(!this.meta.action)throw new v("action required");if(!this.api)throw new v("Auth flow has no API instance");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new v("phone number must be set when initialzing authentication.");try{let t=Is();await this.api.post(t,{action:this.meta.action,phoneNumber:this.meta.phoneNumber})}catch(t){throw Y(t)}}async authenticate(){if(!this.meta.action)throw new v("action required");if(!this.api)throw new v("Mfa flow has no API instance");if(!this.meta.smsCode)throw new v("sms code must be set prior to calling authenticate.");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new v("phone number must be set prior to calling authenticate.");try{let t=Ws(),o=await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return it(o)}catch(t){throw Y(t)}}};import{jsx as xo,jsxs as su}from"react/jsx-runtime";function Mw(e){return typeof e=="string"&&e.length===25}var nn;function ze(){if(!nn){let e=z.get(qo);return Promise.resolve(e||null)}return nn.getAccessToken()}var lu,Xs=(e,t)=>lu(e,t),cu,el=(e,t)=>cu(e,t),du,tl=()=>du(),Nw=()=>{let t=new URLSearchParams(window.location.search).get("privy_token");if(!t)return;z.put(Pr,t);let o=new URL(window.location.href);o.searchParams.delete("privy_token"),window.history.pushState({},"",o)},Ow=({config:e,...t})=>{if(!Mw(t.appId))throw new v("Cannot initialize the Privy provider with an invalid Privy app ID");nn||(nn=new Mr({appId:t.appId,apiUrl:t.apiUrl||yn}));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."),xo(Lw,{...t,config:o,client:nn})},Lw=e=>{let t=e.client,[o,r]=se(!1),[n,i]=se(!1),[a,l]=se(!1),[s,c]=se(null),[h,m]=se(!1),[g,f]=se([]),C=Ui(g),[P,E]=se(!1),[x,k]=se(null),[N,I]=se(!1),[R,M]=se({status:"disconnected",connectError:null,connector:null,connectRetry:w}),[A,te]=se(null),[O,q]=se(null),[H,J]=se({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:""}),[U,Ie]=se(()=>{let p=ou(e.config,e.createPrivyWalletOnLogin);return t.createAnalyticsEvent("sdk_initialize",p),Mi(H,e.config)}),[re,V]=se(!0),[Ce,le]=se({}),[D,Gt]=se(null),[zt,Po]=se(null),[an,To]=se(!1),We=Ui(null),sn=Ui(null),$=Ui(ru),ue=p=>{p&&k(p),r(!0),t.createAnalyticsEvent("modal_open",{initialScreen:p})},zo=p=>{U.embeddedWallets.createOnLogin!=="off"&&V(!0),ue(p)};kt(()=>{if(!O||!s){t.connectors?.removeEmbeddedWalletConnector();return}let p=s?.linkedAccounts.filter(d=>d.type==="wallet"&&d.walletClient==="privy");if(p&&p.length>0){let d=p[0].address;t.connectors?.addEmbeddedWalletConnector(O,d,U.defaultChain)}},[O,s]),kt(()=>{O&&zt?.(O)},[O]),kt(()=>{(async()=>{if(!U.customAuth?.enabled)return;V(!0);let{getCustomAccessToken:d,isLoading:u}=U.customAuth;if(!(!n||u))try{let y=await d();if(!y){await br.logout();return}if(a)return;t.startAuthFlow(new Vo(y));let{user:L,isNewUser:me}=await t.authenticate();L||await br.logout(),c(L||null),E(me||!1),l(!0),To(!0)}catch(y){console.warn(y),a&&await br.logout()}})()},[U.customAuth?.enabled,U.customAuth?.getCustomAccessToken,U.customAuth?.isLoading,n,a]),kt(()=>{an&&O&&s&&Yt(s,e.config?.embeddedWallets?.createOnLogin)&&(To(!1),as(s,jo).catch(console.error))},[an&&O&&s]),kt(()=>{async function p(){let d=await t.getServerConfig();J(d);let u=Mi(d,e.config);Ie(u),d.customApiUrl&&t.updateApiUrl(d.customApiUrl),t.initializeConnectorManager(u.walletConnectCloudProjectId,u.rpcConfig,u.chains,u.defaultChain),t.connectors?.initialize();let y=Cr();Nw();let L=await t.getAuthenticatedUser();e.config?.customAuth?.enabled||(l(!!L),L&&K($,"login","onComplete",L,!1,!0),c(L)),y||(i(!0),D?.()),y&&L&&m(!0),mt()}n||p()},[t,D,n]),kt(()=>{let p=Mi(H,e.config);Ie(p)},[e.config]);let Cr=()=>{let p=new URLSearchParams(window.location.search),d=p.get("privy_oauth_code"),u=p.get("privy_oauth_state"),y=p.get("privy_oauth_provider");return d&&u&&y?(t.startAuthFlow(new jt(y,d,u)),zo("AWAITING_OAUTH_SCREEN"),le({finishOauthFlow:{onComplete:()=>{i(!0),D?.()}}}),!0):!1},$t=async(p,d,u)=>{let y=await t.connectors?.createWalletConnector(p,d)||null;Me(y,u)};async function Me(p,d){if(!p)return M({status:"disconnected",connectError:new B("Unable to connect to wallet."),connector:null,connectRetry:w}),d?.(null);M({connector:p,status:"connecting",connectError:null,connectRetry:()=>Me(p,d)});try{let u=await p.connect({showPrompt:!0});if(U.shouldSwitchChainOnConnect&&!U.chains.find(y=>y.id===Number(u?.chainId))){M(y=>({...y,connector:p,status:"switching_to_supported_chain",connectError:null,connectRetry:w}));try{await u?.switchChain(U.defaultChain.id),u&&(u.chainId=Ko(ko(U.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${U.defaultChain.id}`)}}return M(y=>({...y,status:"connected",connectError:null,connectRetry:w})),u&&!N&&K($,"connectWallet","onSuccess",u),d?.(u)}catch(u){return u instanceof Ue?(console.warn(u.cause?u.cause:u.message),N||K($,"connectWallet","onError",u.privyErrorCode||"generic_connect_wallet_error")):(console.warn(u),N||K($,"connectWallet","onError","unknown_connect_wallet_error")),M(y=>({...y,status:"disconnected",connectError:u})),d?.(null)}}let ne=p=>{p!==null&&t.startAuthFlow(new _o(p))},mt=()=>{let p=new URLSearchParams(window.location.search),d=p.get("privy_connector"),u=p.get("privy_wallet_client");if(!d||!u)return;if(u==="phantom"&&!Ze()&&zo("LOGIN_FAILED_SCREEN"),!t.connectors)throw new v("Connector not initialized");ue("AWAITING_CONNECTION");let y=new URL(window.location.href);y.searchParams.delete("privy_connector"),y.searchParams.delete("privy_wallet_client"),window.history.pushState({},"",y),$t(d,u,ne)};kt(()=>{n&&a&&s===null&&t.getAuthenticatedUser().then(c)},[n,a,s,t]);let ns=()=>{m(!0),ue("LINK_WALLET_SCREEN")},uu=p=>{if(!a||!s)return!1;for(let d of s.linkedAccounts)if(d.type==="wallet"&&d.address===p.address)return!0;return!1},mu=async p=>{if(!t.connectors)throw new v("Connector not initialized");let d=t.connectors.findWalletConnector(p.connectorType,p.walletClientType)||null;M(u=>({...u,connector:d,status:"connected",connectError:null,connectRetry:w})),ne(p),zo("AWAITING_CONNECTION")},hu=async(p,d)=>{if(!t.connectors)throw new v("Connector not initialized");await $t(p,d,ne)},is=async(p,d)=>{if(!U.fiatOnRamp.enabled)throw new v("Fiat on-ramp is not enabled");if(!d||!d.provider||d.provider==="moonpay"){let{signedUrl:u,externalTransactionId:y}=await $c(t,p,d?.config??{},U.appearance.palette,U.fiatOnRamp.useSandbox);return{signedUrl:u,externalTransactionId:y}}else throw new v("Unsupported fund provider. Currently supported option is `moonpay`.")},ln=()=>{f(p=>{let d=t.connectors?.wallets.map(u=>({...u,linked:uu(u),loginOrLink:async()=>{if(!await u.isConnected())throw new v("Wallet is not connected");if(u.connectorType==="embedded"&&u.walletClientType==="privy")throw new v("Cannot link or login with embedded wallet");mu(u)},fund:async y=>{let{signedUrl:L,externalTransactionId:me}=await is(u.address,y);le({fiatOnRampPrompt:{signedUrl:L},fiatOnRampStatus:{externalTransactionId:me}}),ue("FIAT_ON_RAMP_PROMPT_SCREEN")},unlink:async()=>{if(!a)throw new v("User is not authenticated.");if(u.connectorType==="embedded"&&u.walletClientType==="privy")throw new v("Cannot unlink an embedded wallet");let y=await t.unlinkWallet(u.address);c(y)}}))||[];return xn(p,d)?p:d})};kt(()=>{ln()},[s?.linkedAccounts,a,n]),kt(()=>{if(n){if(!t.connectors)throw new v("Connector not initialized");ln(),t.connectors.on("walletsUpdated",ln)}},[n]);let fu=()=>{ue(a?"CONNECT_ONLY_AUTHENTICATED_SCREEN":"CONNECT_ONLY_LANDING_SCREEN")};kt(()=>{if(!g[0])return;let p=g[0],d=C.current.find(y=>y.address===p.address),u=s?.linkedAccounts.find(y=>y.type==="wallet"&&y.address===p.address);if(!d&&u){let y=Object.assign({},s);y.wallet=u&&{address:u.address,chainType:u.chainType,chainId:u.chainId,walletClient:u.walletClient,walletClientType:u.walletClientType,connectorType:u.connectorType},c(y)}C.current=g},[g]);let as=async(p,d)=>{if(Q(p))throw K($,"createWallet","onError","embedded_wallet_already_exists"),new Error("Only one Privy wallet per user is currently allowed");let[y,L]=await Promise.all([Ee.initializeWalletProxy(d),ze()]);if(!y&&e.config?.customAuth?.enabled)throw K($,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to connect to wallet proxy");if(!y||!L||e.config?.embeddedWallets?.requireUserPasswordOnCreate)return new Promise((me,xe)=>{V(!0),le({createWallet:{onSuccess:Je=>{K($,"createWallet","onSuccess",Je),me(Je)},onFailure:Je=>{K($,"createWallet","onError","unknown_embedded_wallet_error"),xe(Je)},callAuthOnSuccessOnClose:!1}}),ue("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")});{await y.create({accessToken:L});let me=await Ee.refreshUser(),xe=Q(me);if(!xe)throw K($,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");return K($,"createWallet","onSuccess",xe),xe}},yu=p=>{if(!U.chains.map(d=>d.id).includes(p))throw new B(`Chain ID ${p} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,"unsupported_chain_id")},ss=(p,d,u)=>new Promise(async(y,L)=>{if(!a||!s){L(new Error("User must be authenticated before signing with a Privy wallet"));return}let me=Q(s);if(!me){L(new Error("Must have a Privy wallet before signing"));return}V(!0);let xe=t.connectors?.findWalletConnector("embedded","privy")?.proxyProvider,Vt=p.chainId?Number(p.chainId):xe.chainId;yu(Vt);let Je=Object.assign({},p,{chainId:Vt}),Er=async()=>{let qt=await ze();if(!qt||!O){L(new Error("Must have valid access token and Privy wallet to send transaction"));return}try{if(!await Ee.recoverEmbeddedWallet()){L(new Error("Unable to connect to wallet"));return}let ls=new Iw(at(Je.chainId,U.chains,U.rpcConfig)),vu=await Si(me.address,Je,ls),wu=await _i(qt,me.address,O,vu,ls);y(wu)}catch(cn){L(cn)}};if(U.embeddedWallets.noPromptOnSignature)d&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config"),Er();else{let qt={transactionRequest:Je,onSuccess:y,onFailure:L,uiOptions:d||{},fundWalletConfig:u},cn={onCompleteNavigateTo:"EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN",onFailure:L};le({connectWallet:cn,sendTransaction:qt}),ue("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),br={ready:n,authenticated:a,user:s,walletConnectors:t.connectors||null,connectWallet:fu,linkWallet:ns,linkEmail:()=>{if(s?.email)throw new v("User already has an email linked to their account.");m(!0),ue("LINK_EMAIL_SCREEN")},linkPhone:()=>{if(s?.phone)throw new v("User already has a phone number linked to their account.");m(!0),ue("LINK_PHONE_SCREEN")},linkGoogle:async()=>{if(s?.google)throw new v("User already has a Google account linked to their account.");await Ee.initLoginWithOAuth("google")},linkTwitter:async()=>{if(s?.twitter)throw new v("User already has a Twitter account linked to their account.");await Ee.initLoginWithOAuth("twitter")},linkDiscord:async()=>{if(s?.discord)throw new v("User already has a Discord account linked to their account.");await Ee.initLoginWithOAuth("discord")},linkGithub:async()=>{if(s?.github)throw new v("User already has a Github account linked to their account.");await Ee.initLoginWithOAuth("github")},linkTiktok:async()=>{if(s?.tiktok)throw new v("User already has a Tiktok account linked to their account.");await Ee.initLoginWithOAuth("tiktok")},linkLinkedIn:async()=>{if(s?.linkedin)throw new v("User already has a LinkedIn account linked to their account.");await Ee.initLoginWithOAuth("linkedin")},linkApple:async()=>{await Ee.initLoginWithOAuth("apple")},login:async()=>{if(n||(await new Promise(p=>{Gt(()=>p)}),Gt(null)),a){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}I(!0),zo()},logout:async()=>{await t.logout(),c(null),l(!1),k(null),K($,"logout","onSuccess"),m(!1),r(!1),z.del(Tr)},getAccessToken:()=>t.getAccessToken(),getEthereumProvider:()=>{if(!s||!s.wallet)return new Z;let p=g.find(u=>s.wallet&&u.address===s.wallet.address),d=t.connectors?.walletConnectors.find(u=>u.wallets.find(y=>y.address===p?.address));return!p||!d?new Z:d.proxyProvider},getEthersProvider:()=>{if(!s||!s.wallet)return new rs(new vt(new Z));let p=g.find(u=>s.wallet&&u.address===s.wallet.address),d=t.connectors?.walletConnectors.find(u=>u.wallets.find(y=>y.address===p?.address));return!p||!d?new rs(new vt(new Z)):new rs(new vt(d.proxyProvider))},getWeb3jsProvider:()=>{if(!s||!s.wallet)return new Xt(new Z);let p=g.find(u=>s.wallet&&u.address===s.wallet.address),d=t.connectors?.walletConnectors.find(u=>u.wallets.find(y=>y.address===p?.address));return!p||!d?new Xt(new Z):new Xt(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=g.find(y=>Di(y.address)===Di(p)),u=s?.linkedAccounts.find(y=>y.type==="wallet"&&Di(y.address)===Di(p));if(!d||!await d.isConnected())te(p),ns();else if(!d.linked)d.loginOrLink();else{let y=Object.assign({},s);y.wallet=u&&{address:u.address,chainType:u.chainType,chainId:u.chainId,walletClient:u.walletClient,walletClientType:u.walletClientType,connectorType:u.connectorType},c(y)}},forkSession:()=>t.forkSession(),createWallet:async()=>{if(!a||!s)throw K($,"createWallet","onError","must_be_authenticated"),new Error("User must be authenticated before creating a Privy wallet");return as(s,15e3)},setWalletPassword:()=>new Promise((p,d)=>{if(!a||!s){d(new Error("User must be authenticated before adding password to Privy wallet"));return}let u=Q(s);if(!u||!O){d(new Error("Must have a Privy wallet to add a password"));return}if(u.recoveryMethod==="user-passcode"){d(new Error("Cannot set password. Embedded wallet already has a password."));return}V(!0);let y={onSuccess:p,onFailure:d,callAuthOnSuccessOnClose:!1},L={onCompleteNavigateTo:"EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN",onFailure:d};le({setWalletPassword:y,connectWallet:L}),ue("EMBEDDED_WALLET_CONNECTING_SCREEN")}),signMessage:(p,d)=>new Promise(async(u,y)=>{if(!a||!s){y(new Error("User must be authenticated before signing with a Privy wallet"));return}let L=Q(s);if(!L){y(new Error("Must have a Privy wallet before signing"));return}if(typeof p!="string"||p.length<1){y(new Error("Message must be a non-empty string"));return}V(!0);let me=async()=>{if(!a)return y(new Error("User must be authenticated before signing with a Privy wallet")),null;let xe=await ze();if(O&&xe)try{if(!await Ee.recoverEmbeddedWallet())return y(new Error("Unable to connect to wallet")),null;t.createAnalyticsEvent("embedded_wallet_sign_message_started",{walletAddress:L.address});let{response:Je}=await O.rpc({accessToken:xe,address:L.address,request:{method:"personal_sign",params:[p,L.address]}}),Er=Je.data;return t.createAnalyticsEvent("embedded_wallet_sign_message_completed",{walletAddress:L.address}),Er}catch(Vt){return y(Vt),null}else return null};if(U.embeddedWallets.noPromptOnSignature){d&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");let xe=await me();xe?u(xe):y(new Pe("Unable to sign message"))}else{let Je={message:p,confirmAndSignMessage:me,onSuccess:qt=>{u(qt)},onFailure:qt=>{y(qt)},uiOptions:d||{}},Er={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:y};le({signMessage:Je,connectWallet:Er}),ue("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),sendTransaction:async(p,d,u)=>{let L=await(await ss(p,d,u)).wait();return Ai(L)},exportWallet:()=>new Promise((p,d)=>{if(!a||!s){d(new Error("User must be authenticated before exporting their Privy wallet"));return}if(!Q(s)){d(new Error("Must have a Privy wallet before exporting"));return}V(!0);let y={onCompleteNavigateTo:"EMBEDDED_WALLET_KEY_EXPORT_SCREEN",onFailure:d},L={appId:e.appId,origin:t.apiUrl,onSuccess:p,onFailure:d};le({keyExport:L,connectWallet:y}),ue("EMBEDDED_WALLET_CONNECTING_SCREEN")}),async init(p){let d;switch(p){case"sms":d=new Li("verify");break;case"totp":return;default:throw K($,"configureMfa","onError","unknown_mfa_error"),new Error(`Unsupported MFA method: ${p}`)}t.startMfaFlow(d);try{await d.init()}catch(u){throw K($,"configureMfa","onError",u.privyErrorCode||"unknown_mfa_error"),u}},async submit(p,d){switch(p){case"totp":case"sms":We.current?.resolve({mfaMethod:p,mfaCode:d}),await new Promise((u,y)=>{sn.current={resolve:u,reject:y}});break;default:throw We.current?.reject(new v("Unsupported MFA method")),K($,"configureMfa","onError","unknown_mfa_error"),new v(`Unsupported MFA method: ${p}`)}},async initEnrollmentWithSms(p){let d=await ze();if(!d||!O)throw new Error("Must have valid access token to enroll in MFA");try{await O.initEnrollMfa({method:"sms",accessToken:d,phoneNumber:p.phoneNumber})}catch(u){throw K($,"configureMfa","onError",u.privyErrorCode||"unknown_mfa_error"),u}},async initEnrollmentWithTotp(){let p=await ze();if(!p||!O)throw new Error("Must have valid access token to enroll in MFA");try{let d=await O.initEnrollMfa({method:"totp",accessToken:p});return{secret:d.secret,authUrl:d.authUrl}}catch(d){throw K($,"configureMfa","onError",d.privyErrorCode||"unknown_mfa_error"),d}},async submitEnrollmentWithSms(p){let d=await ze();if(!d||!O)throw new Error("Must have valid access token to enroll in MFA");try{await O.submitEnrollMfa({method:"sms",accessToken:d,phoneNumber:p.phoneNumber,code:p.mfaCode});let u=await t.getAuthenticatedUser();c(u)}catch(u){throw K($,"configureMfa","onError",u.privyErrorCode||"unknown_mfa_error"),u}},async submitEnrollmentWithTotp(p){let d=await ze();if(!d||!O)throw new Error("Must have valid access token to enroll in MFA");try{await O.submitEnrollMfa({method:"totp",accessToken:d,code:p.mfaCode});let u=await t.getAuthenticatedUser();c(u)}catch(u){throw K($,"configureMfa","onError",u.privyErrorCode||"unknown_mfa_error"),u}},loginWithCode(p){return Ee.loginWithCode(p)},initLoginWithEmail(p,d){return Ee.initLoginWithEmail(p,d)}};lu=br.signMessage,cu=async(...p)=>{let d=await ss(...p);return U.embeddedWallets.waitForTransactionConfirmation&&await d.wait(),d};let Ee=(()=>({isNewUserThisSession:P,isLinking:h,linkingHint:A,walletConnectionStatus:R,rpcConfig:U.rpcConfig,chains:U.chains,showFiatPrices:U.embeddedWallets.priceDisplay.primary!=="native-token",clientAnalyticsId:t.clientAnalyticsId,nativeTokenSymbolForChainId:p=>U.chains.find(d=>d.id===Number(p))?.nativeCurrency.symbol,initializeWalletProxy:async p=>{if(O)return O;let d=new Promise(L=>{Po(()=>me=>L(me))}),u=new Promise(L=>setTimeout(()=>L(null),p)),y=await Promise.race([d,u]);return Po(null),y},getAuthFlow:()=>t.authFlow,getAuthMeta:()=>t.authFlow?.meta,closePrivyModal:(p={shouldCallAuthOnSuccess:!0})=>{let d=n&&a&&s;p.shouldCallAuthOnSuccess&&d?(K($,"login","onComplete",s,P,!1),e.onSuccess?.(s,P)):N&&K($,"login","onError","exited_auth_flow"),t.authFlow=void 0,te(null),k(null),I(!1),m(!1),E(!1),r(!1),t.createAnalyticsEvent("modal_closed")},connectWallet:$t,initLoginWithWallet:hu,loginWithWallet:async()=>{if(!n)throw new xr;if(!(t.authFlow instanceof _o))throw new v("Must initialize SIWE flow first.");let p,d;if(a)p=await t.link();else try{({user:p,isNewUser:d}=await t.authenticate())}catch(u){throw K($,"login","onError",u.privyErrorCode||"generic_connect_wallet_error"),u}c(p||s||null),E(d||!1),l(!0)},initLoginWithOAuth:async p=>{t.startAuthFlow(new jt(p));let d=await t.authFlow.getAuthorizationUrl();d&&d.url&&window.location.assign(d.url)},loginWithOAuth:async()=>{if(!(t.authFlow instanceof jt))throw new v("Must initialize OAuth flow before calling loginWithOAuth");let p,d;if(a)p=await t.link();else try{({user:p,isNewUser:d}=await t.authenticate())}catch(u){throw K($,"login","onError",u.privyErrorCode||"unknown_auth_error"),u}c(p),E(d||!1),l(!0)},initLoginWithEmail:async(p,d)=>{let u=new So(p,d);t.startAuthFlow(u);try{await u.sendCodeEmail()}catch(y){throw K($,"login","onError",y.privyErrorCode||"unknown_auth_error"),y}},initLoginWithSms:async(p,d)=>{let u=new Ao(p,d);t.startAuthFlow(u);try{await u.sendSmsCode()}catch(y){throw K($,"login","onError",y.privyErrorCode||"unknown_auth_error"),y}},resendEmailCode:async()=>{await t.authFlow?.sendCodeEmail()},resendSmsCode:async()=>{await t.authFlow?.sendSmsCode()},loginWithCode:async p=>{if(!n)throw new xr;if(t.authFlow instanceof So)t.authFlow.meta.emailCode=p.trim();else if(t.authFlow instanceof Ao)t.authFlow.meta.smsCode=p.trim();else throw new v("Must initialize a passwordless code flow first");let d,u;a?d=await t.link():{user:d,isNewUser:u}=await t.authenticate(),c(d||s||null),E(u||!1),l(!0)},refreshUser:async()=>{let p=await t.getAuthenticatedUser();return c(p),p},walletProxy:O,createAnalyticsEvent:(p,d,u)=>t.createAnalyticsEvent(p,d,u),getUsdTokenPrice:p=>t.getUsdTokenPrice(p),recoverEmbeddedWallet:async()=>new Promise(async(p,d)=>{let u=s?.linkedAccounts.find(L=>L.type==="wallet"&&L.walletClientType==="privy"),y=await ze();if(!y||!O||!u){d(new Error("Must have valid access token and Privy wallet to recover wallet"));return}V(!0);try{await O.connect({accessToken:y,address:u.address}),p(!0)}catch(L){ir(L)&&u.recoveryMethod==="privy"?(t.createAnalyticsEvent("embedded_wallet_pinless_recovery_started",{walletAddress:u.address}),(await O.recover({address:u.address,accessToken:y})).address||d(new Error("Unable to recover wallet")),t.createAnalyticsEvent("embedded_wallet_recovery_completed",{walletAddress:u.address}),p(!0)):ir(L)?(le({recoverWallet:{privyWallet:u,onFailure:d,onSuccess:()=>p(!0)}}),ue("EMBEDDED_WALLET_RECOVERY_SCREEN")):d(L)}}),getFiatOnRampConfig:is,updateWallets:()=>ln()}))();du=Ee.recoverEmbeddedWallet;let gu=Ww(()=>({wallets:g}),[g]);return xo(Te.Provider,{value:br,children:xo(ts.Provider,{value:$,children:xo(Ja.Provider,{value:gu,children:su(ld,{...U,children:[e.children,su(ea.Provider,{value:Ee,children:[xo(Ip,{theme:{...U.appearance.palette||{}}}),xo(ll,{appConfig:U,data:Ce,setModalData:le,setInitialScreen:k,initialScreen:x,visible:o,authenticated:a,children:o?xo(Op,{}):null}),re&&H.id?xo(au,{appId:e.appId,clientAnalyticsId:t.clientAnalyticsId,origin:t.apiUrl,mfaMethods:s?.mfaMethods,mfaPromise:We,mfaSubmitPromise:sn,onLoad:q,onLoadFailed:()=>null}):null]})]})})})})};import{useContext as Dw}from"react";function Uw(){let{init:e,submit:t}=Dw(Te);return{init:e,submit:t}}import{useContext as Fw}from"react";function Bw(){let{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,submitEnrollmentWithSms:o,submitEnrollmentWithTotp:r}=Fw(Te);return{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,submitEnrollmentWithSms:o,submitEnrollmentWithTotp:r}}import{useContext as Hw}from"react";function Gw(e){let{login:t}=Hw(Te);return At("login",e),{login:t}}import{useContext as zw}from"react";function $w(e){let{logout:t}=zw(Te);return At("logout",e),{logout:t}}import{useCallback as pu}from"react";var Vw=()=>{let e=Tt(),{initLoginWithEmail:t,loginWithCode:o}=G(),r=pu(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=pu(async({code:i})=>{if(e.enabled&&e.status!=="success")throw new qr(e.error,null,"captcha_failure");return o(i)},[o,e.status]);return{sendCode:r,loginWithCode:n}};function qw(e){At("configureMfa",e)}import{useContext as jw}from"react";function Kw(e){let{connectWallet:t}=jw(Te);return At("connectWallet",e),{connectWallet:t}}import{useContext as Yw}from"react";function Jw(e){let{createWallet:t}=Yw(Te);return At("createWallet",e),{createWallet:t}}export{vt as AsExternalProvider,jr as Captcha,Ir as ConnectorManager,Mr as PrivyClient,Ow as PrivyProvider,Z as PrivyProxyProvider,rn as SUPPORTED_CHAINS,Fi as VERSION,$e as WalletConnector,lh as errorIndicatesMaxMfaRetries,ah as errorIndicatesMfaTimeout,sh as errorIndicatesMfaVerificationFailed,ze as getAccessToken,Kw as useConnectWallet,Jw as useCreateWallet,Gw as useLogin,Vw as useLoginWithEmail,$w as useLogout,Uw as useMfa,Bw as useMfaEnrollment,G as usePrivy,qw as useRegisterMfaListener,Qa as useWallets};
2198
+ `;var Lp={id:42161,name:"Arbitrum One",network:"arbitrum",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{alchemy:{http:["https://arb-mainnet.g.alchemy.com/v2"],webSocket:["wss://arb-mainnet.g.alchemy.com/v2"]},infura:{http:["https://arbitrum-mainnet.infura.io/v3"],webSocket:["wss://arbitrum-mainnet.infura.io/ws/v3"]},default:{http:["https://arb1.arbitrum.io/rpc"]},public:{http:["https://arb1.arbitrum.io/rpc"]}},blockExplorers:{etherscan:{name:"Arbiscan",url:"https://arbiscan.io"},default:{name:"Arbiscan",url:"https://arbiscan.io"}}};var Dp={id:421613,name:"Arbitrum Goerli",network:"arbitrum-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"AGOR",decimals:18},rpcUrls:{alchemy:{http:["https://arb-goerli.g.alchemy.com/v2"],webSocket:["wss://arb-goerli.g.alchemy.com/v2"]},infura:{http:["https://arbitrum-goerli.infura.io/v3"],webSocket:["wss://arbitrum-goerli.infura.io/ws/v3"]},default:{http:["https://goerli-rollup.arbitrum.io/rpc"]},public:{http:["https://goerli-rollup.arbitrum.io/rpc"]}},blockExplorers:{etherscan:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"},default:{name:"Arbiscan",url:"https://goerli.arbiscan.io/"}},testnet:!0};var Up={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 Fp={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 Bp={id:8453,network:"base",name:"Base",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{blast:{http:["https://base-mainnet.blastapi.io"],webSocket:["wss://base-mainnet.blastapi.io"]},default:{http:["https://mainnet.base.org"]},public:{http:["https://mainnet.base.org"]}},blockExplorers:{etherscan:{name:"Basescan",url:"https://basescan.org"},default:{name:"Basescan",url:"https://basescan.org"}},testnet:!0};var Hp={id:84531,network:"base-goerli",name:"Base Goerli Testnet",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{blast:{http:["https://base-goerli.blastapi.io"],webSocket:["wss://base-goerli.blastapi.io"]},default:{http:["https://goerli.base.org"]},public:{http:["https://goerli.base.org"]}},blockExplorers:{etherscan:{name:"Basescan",url:"https://goerli.basescan.org"},default:{name:"Basescan",url:"https://goerli.basescan.org"}},testnet:!0};var Gp={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 zp={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 $p={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 Vp={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 qp={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 jp={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 Kp={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 Wi={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 Yp={id:10,name:"OP Mainnet",network:"optimism",nativeCurrency:{name:"Ether",symbol:"ETH",decimals:18},rpcUrls:{alchemy:{http:["https://opt-mainnet.g.alchemy.com/v2"],webSocket:["wss://opt-mainnet.g.alchemy.com/v2"]},infura:{http:["https://optimism-mainnet.infura.io/v3"],webSocket:["wss://optimism-mainnet.infura.io/ws/v3"]},default:{http:["https://mainnet.optimism.io"]},public:{http:["https://mainnet.optimism.io"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://optimistic.etherscan.io"},default:{name:"Optimism Explorer",url:"https://explorer.optimism.io"}}};var Jp={id:420,name:"Optimism Goerli Testnet",network:"optimism-goerli",nativeCurrency:{name:"Goerli Ether",symbol:"ETH",decimals:18},rpcUrls:{alchemy:{http:["https://opt-goerli.g.alchemy.com/v2"],webSocket:["wss://opt-goerli.g.alchemy.com/v2"]},infura:{http:["https://optimism-goerli.infura.io/v3"],webSocket:["wss://optimism-goerli.infura.io/ws/v3"]},default:{http:["https://goerli.optimism.io"]},public:{http:["https://goerli.optimism.io"]}},blockExplorers:{etherscan:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"},default:{name:"Etherscan",url:"https://goerli-optimism.etherscan.io"}},testnet:!0};var Qp={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 Zp={id:7777777,name:"Zora",network:"zora",nativeCurrency:{decimals:18,name:"Ether",symbol:"ETH"},rpcUrls:{default:{http:["https://rpc.zora.energy"],webSocket:["wss://rpc.zora.energy"]},public:{http:["https://rpc.zora.energy"],webSocket:["wss://rpc.zora.energy"]}},blockExplorers:{default:{name:"Explorer",url:"https://explorer.zora.energy"}}};var Xp={id:999,name:"Zora Goerli Testnet",network:"zora-testnet",nativeCurrency:{decimals:18,name:"Zora Goerli",symbol:"ETH"},rpcUrls:{default:{http:["https://testnet.rpc.zora.energy"],webSocket:["wss://testnet.rpc.zora.energy"]},public:{http:["https://testnet.rpc.zora.energy"],webSocket:["wss://testnet.rpc.zora.energy"]}},blockExplorers:{default:{name:"Explorer",url:"https://testnet.explorer.zora.energy"}},testnet:!0};var rn=[Lp,Dp,qp,Qp,Wi,Yp,Jp,Xr,en,Gp,zp,$p,Vp,Bp,Hp,jp,Kp,Up,Fp,Zp,Xp],u8=new Set(rn.map(e=>e.id));import Go from"tinycolor2";var eu="#FFFFFF",fw="#000000",yw=eu,gw="#1E1E1D";function vw(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 Co(e,t){let o=Math.max(0,Math.min(1,e.toHsl().l+t));return Go({...e.toHsl(),l:o})}function tu({backgroundTheme:e,accentHex:t,successHex:o="#51BA81",warnHex:r="#FFB74D",errorHex:n="#EC6351",whiteHex:i=eu,blackHex:a=fw}){let l;switch(e){case"light":l=yw;break;case"dark":l=gw;break;default:l=e;break}let s=Go(l),c=Go(t),h=Go(o),m=Go(r),g=Go(n),f=vw(s.getLuminance()),C=Co(s,f==="light"?-.04:.11),P=Co(s,f==="light"?-.88:.87),E=Co(s,f==="light"?-.77:.75),x=Co(s,f==="light"?-.43:.45).desaturate(f==="light"?60:20),k=Co(s,f==="light"?-.08:.25).desaturate(f==="light"?60:20),N=Co(c,.15),I=Co(c,-.06),R=Go(c.getLuminance()>.5?a:i),M=Co(h,-.16);return{colorScheme:f,background:s.toHslString(),background2:C.toHslString(),foreground:P.toHslString(),foreground2:E.toHslString(),foreground3:x.toHslString(),foreground4:k.toHslString(),accent:c.toHslString(),accentLight:N.toHslString(),accentDark:I.toHslString(),foregroundAccent:R.toHslString(),success:h.toHslString(),successDark:M.toHslString(),error:g.toHslString(),warn:m.toHslString()}}var Bt={appearance:{theme:"light",accentColor:"#676FFF"},walletConnectCloudProjectId:Os,rpcConfig:{rpcUrls:{},rpcTimeouts:{}},captchaEnabled:!1,_render:{inDialog:!0,inParentNodeId:null},fiatOnRamp:{useSandbox:!1}};function Mi(e,t){let o=["google","twitter","discord","tiktok","linkedin","github","apple"],r=t?.loginMethods?.filter(I=>o.includes(I)),n=r?.slice(0,5),i,a,l,s,c,h,m,g,f,C;if(t?.loginMethods?(i=t.loginMethods.includes("email"),a=t.loginMethods.includes("sms"),l=t.loginMethods.includes("wallet"),s=n?.includes("google"),c=n?.includes("twitter"),h=n?.includes("discord"),m=n?.includes("tiktok"),f=n?.includes("github"),g=n?.includes("linkedin"),C=n?.includes("apple")):(i=e.emailAuth,a=e.smsAuth,l=e.walletAuth,s=e.googleOAuth,c=e.twitterOAuth,h=e.discordOAuth,f=e.githubOAuth,m=e.tiktokOAuth,g=e.linkedinOAuth,C=e.appleOAuth),i&&a&&(console.warn("Enabling both email and SMS passwordless is not currently supported. Disabling SMS."),a=!1),!i&&!a&&[s,c,h,f,m,g,C].some(I=>I))throw new Error("To enable social logins you must also enable either SMS or Email login");if(![i,a,l,s,c,h,f,m,g,C].some(I=>I))throw new Error("You must enable at least one login method");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{chains:P,defaultChain:E}=ww(t?.additionalChains,t?.supportedChains,t?.defaultChain),x=!!t?.defaultChain||!!t?.supportedChains;r&&r.length>5&&console.warn("Max number of social logins allowed is 5. Any more have been removed.");let k=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:tu({backgroundTheme:t?.appearance?.theme??Bt.appearance.theme,accentHex:t?.appearance?.accentColor??e.accentColor??Bt.appearance.accentColor}),showWalletLoginFirst:t?.appearance?.showWalletLoginFirst??e.showWalletLoginFirst},loginMethods:{wallet:l,email:i,sms:a,google:s,twitter:c,discord:h,github:f,tiktok:m,linkedin:g,apple:C},legal:{termsAndConditionsUrl:t?.legal?.termsAndConditionsUrl??e.termsAndConditionsUrl,privacyPolicyUrl:t?.legal?.privacyPolicyUrl??e.privacyPolicyUrl},walletConnectCloudProjectId:t?.walletConnectCloudProjectId??e.walletConnectCloudProjectId??Bt.walletConnectCloudProjectId,rpcConfig:{rpcUrls:t?.rpcConfig?.rpcUrls??Bt.rpcConfig.rpcUrls,rpcTimeouts:t?.rpcConfig?.rpcTimeouts??Bt.rpcConfig.rpcTimeouts},chains:P,defaultChain:E,shouldSwitchChainOnConnect:x,captchaEnabled:e.captchaEnabled??Bt.captchaEnabled,captchaSiteKey:e.captchaSiteKey,embeddedWallets:{...e.embeddedWalletConfig,...k?{createOnLogin:"all-users",requireUserPasswordOnCreate:!1,noPromptOnSignature:!0}:{},waitForTransactionConfirmation:!0,priceDisplay:{primary:"fiat-currency",secondary:"native-token"},...t?.embeddedWallets},customAuth:k?{enabled:!0,...t.customAuth}:void 0,fiatOnRamp:{enabled:e.fiatOnRampEnabled,useSandbox:t?.fiatOnRamp?.useSandbox??Bt.fiatOnRamp.useSandbox},loginConfig:{twitterOAuthOnMobileEnabled:e.twitterOAuthOnMobileEnabled??!1},render:{inDialog:t?._render?.inDialog??Bt._render.inDialog,inParentNodeId:t?._render?.inParentNodeId??Bt._render.inParentNodeId}}}function ou(e,t){if(!e)return{legacyCreateEmbeddedWalletFlag:t};let{appearance:o,additionalChains:r,supportedChains:n,...i}=e;return{...i,...r?{additionalChains:r.map(l=>l.id)}:void 0,...n?{supportedChains:n.map(l=>l.id)}:void 0,...o?{...o,...o.logo&&typeof o.logo?{logo:"component"}:void 0}:void 0,legacyCreateEmbeddedWalletFlag:t}}function ww(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=>rn.find(s=>s.id===a.id)??a)}else r=rn.concat(e??[]);let n=t?r[0]:Wi,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 xw,useEffect as Pw}from"react";import{createContext as Cw,useContext as bw,useEffect as Ew}from"react";var ru={login:{onComplete:[],onError:[]},logout:{onSuccess:[]},connectWallet:{onSuccess:[],onError:[]},createWallet:{onSuccess:[],onError:[]},configureMfa:{onMfaRequired:[],onError:[]}},ts=Cw(void 0),nu=()=>bw(ts);function At(e,t){if(!t)return;let r=nu().current[e];return Ew(()=>{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 K(e,t,o,...r){for(let n of e.current[t][o])n(...r)}function iu(){let e=nu();return(t,o,...r)=>K(e,t,o,...r)}var Ni=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:init-enrollment":return r;case"privy:mfa:submit-enrollment":return r;default:throw new Error(`invalid wallet event type ${t}`)}}};async function Oi(e,t,o,r,n,i=!1){let a=i,l=async h=>{if(a&&t&&t.length>0){h===(i?0:1)?n("configureMfa","onMfaRequired",t):r.current?.reject(new _e("mfa_verification_failed","MFA verification failed, retry."));let m=await new Promise((g,f)=>{o.current={resolve:g,reject:f};let C=1e3*60*5;setTimeout(()=>{let P=new _e("mfa_timeout","Timed out waiting for MFA code");r.current?.reject(P),f(P)},C)});return await e(m)}return await e()},s=4,c=null;for(let h=0;h<s;h++)try{c=await l(h),r.current?.resolve(void 0);break}catch(m){if(m.type==="mfa_verification_failed")a=!0;else throw r.current?.resolve(void 0),m}if(c===null){let h=new _e("mfa_verification_max_attempts_reached","Max MFA verification attempts reached");throw r.current?.reject(h),h}return c}import{jsx as Rw}from"react/jsx-runtime";var Tw=function(e){return()=>`id-${e++}`}(0);function Sw(e){return typeof e.event=="string"&&/^privy:.+/.test(e.event)}function bo(e){return e.error!==void 0}var Ht=new Ni,os=new Map,_w=(e,t)=>typeof t=="bigint"?t.toString():t,Aw=(e,t)=>`${e}${JSON.stringify(t,_w)}`;function Eo(e,t,o){let r=o.contentWindow;if(!r)throw new Error("iframe not initialized");let n=Aw(e,t);if(e==="privy:wallet:create"){let a=os.get(n);if(a)return a}let i=new Promise((a,l)=>{let s=Tw();Ht.enqueue(s,{resolve:a,reject:l}),r.postMessage({id:s,event:e,data:t},"*")}).finally(()=>{os.delete(n)});return os.set(n,i),i}function kw(e){switch(e.event){case"privy:iframe:ready":let t=Ht.dequeue(e.event,e.id);return bo(e)?t.reject(new _e(e.error.type,e.error.message)):t.resolve(e.data);case"privy:wallet:create":let o=Ht.dequeue(e.event,e.id);return bo(e)?o.reject(new _e(e.error.type,e.error.message)):o.resolve(e.data);case"privy:wallet:connect":let r=Ht.dequeue(e.event,e.id);return bo(e)?r.reject(new _e(e.error.type,e.error.message)):r.resolve(e.data);case"privy:wallet:recover":let n=Ht.dequeue(e.event,e.id);return bo(e)?n.reject(new _e(e.error.type,e.error.message)):n.resolve(e.data);case"privy:wallet:rpc":let i=Ht.dequeue(e.event,e.id);return bo(e)?i.reject(new _e(e.error.type,e.error.message)):i.resolve(e.data);case"privy:wallet:set-recovery-password":let a=Ht.dequeue(e.event,e.id);return bo(e)?a.reject(new _e(e.error.type,e.error.message)):a.resolve(e.data);case"privy:mfa:init-enrollment":{let l=Ht.dequeue(e.event,e.id);return bo(e)?l.reject(new _e(e.error.type,e.error.message)):l.resolve(e.data)}case"privy:mfa:submit-enrollment":{let l=Ht.dequeue(e.event,e.id);return bo(e)?l.reject(new _e(e.error.type,e.error.message)):l.resolve(e.data)}default:console.warn("Unsupported wallet proxy method:",e)}}function au(e){let t=xw(null),o=iu();return Pw(()=>{let r=t.current;if(!r)return;function n(c){c&&c.origin===e.origin&&Sw(c.data)&&kw(c.data)}let i={create(c){return Eo("privy:wallet:create",c,r)},connect(c){return Eo("privy:wallet:connect",c,r)},recover(c){return Oi(h=>Eo("privy:wallet:recover",{...c,...h},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)},rpc(c){return Oi(h=>Eo("privy:wallet:rpc",{...c,...h},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o)},setRecoveryPassword(c){return Eo("privy:wallet:set-recovery-password",c,r)},initEnrollMfa(c){return Oi(h=>Eo("privy:mfa:init-enrollment",{...c,...h},r),e.mfaMethods,e.mfaPromise,e.mfaSubmitPromise,o,!0)},submitEnrollMfa(c){return Eo("privy:mfa:submit-enrollment",c,r)}};window.addEventListener("message",n);let a=()=>e.onLoad(i),l=(...c)=>{console.warn("Privy iframe failed to load: ",...c),e.onLoadFailed()},s=new AbortController;return js(()=>Eo("privy:iframe:ready",{},r),{abortSignal:s.signal}).then(a,l),()=>{window.removeEventListener("message",n),s.abort()}},[t.current,e.mfaMethods]),Rw("iframe",{ref:t,width:"0",height:"0",style:{display:"none",height:"0px",width:"0px"},src:bn(e.origin,`/apps/${e.appId}/embedded-wallets`,{caid:e.clientAnalyticsId})})}var Li=class{constructor(t,o){this.meta={action:t,phoneNumber:o}}async init(){if(!this.meta.action)throw new v("action required");if(!this.api)throw new v("Auth flow has no API instance");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new v("phone number must be set when initialzing authentication.");try{let t=Is();await this.api.post(t,{action:this.meta.action,phoneNumber:this.meta.phoneNumber})}catch(t){throw Y(t)}}async authenticate(){if(!this.meta.action)throw new v("action required");if(!this.api)throw new v("Mfa flow has no API instance");if(!this.meta.smsCode)throw new v("sms code must be set prior to calling authenticate.");if(this.meta.action==="enroll"&&!this.meta.phoneNumber)throw new v("phone number must be set prior to calling authenticate.");try{let t=Ws(),o=await this.api.post(t,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return it(o)}catch(t){throw Y(t)}}};import{jsx as xo,jsxs as su}from"react/jsx-runtime";function Mw(e){return typeof e=="string"&&e.length===25}var nn;function ze(){if(!nn){let e=z.get(qo);return Promise.resolve(e||null)}return nn.getAccessToken()}var lu,Xs=(e,t)=>lu(e,t),cu,el=(e,t)=>cu(e,t),du,tl=()=>du(),Nw=()=>{let t=new URLSearchParams(window.location.search).get("privy_token");if(!t)return;z.put(Pr,t);let o=new URL(window.location.href);o.searchParams.delete("privy_token"),window.history.pushState({},"",o)},Ow=({config:e,...t})=>{if(!Mw(t.appId))throw new v("Cannot initialize the Privy provider with an invalid Privy app ID");nn||(nn=new Mr({appId:t.appId,apiUrl:t.apiUrl||yn}));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."),xo(Lw,{...t,config:o,client:nn})},Lw=e=>{let t=e.client,[o,r]=se(!1),[n,i]=se(!1),[a,l]=se(!1),[s,c]=se(null),[h,m]=se(!1),[g,f]=se([]),C=Ui(g),[P,E]=se(!1),[x,k]=se(null),[N,I]=se(!1),[R,M]=se({status:"disconnected",connectError:null,connector:null,connectRetry:w}),[A,te]=se(null),[O,q]=se(null),[H,J]=se({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:""}),[U,We]=se(()=>{let p=ou(e.config,e.createPrivyWalletOnLogin);return t.createAnalyticsEvent("sdk_initialize",p),Mi(H,e.config)}),[re,V]=se(!0),[Ce,le]=se({}),[D,Gt]=se(null),[zt,Po]=se(null),[an,To]=se(!1),Ee=Ui(null),sn=Ui(null),$=Ui(ru),ue=p=>{p&&k(p),r(!0),t.createAnalyticsEvent("modal_open",{initialScreen:p})},zo=p=>{U.embeddedWallets.createOnLogin!=="off"&&V(!0),ue(p)};kt(()=>{if(!O||!s){t.connectors?.removeEmbeddedWalletConnector();return}let p=s?.linkedAccounts.filter(d=>d.type==="wallet"&&d.walletClient==="privy");if(p&&p.length>0){let d=p[0].address;t.connectors?.addEmbeddedWalletConnector(O,d,U.defaultChain)}},[O,s]),kt(()=>{O&&zt?.(O)},[O]),kt(()=>{(async()=>{if(!U.customAuth?.enabled)return;V(!0);let{getCustomAccessToken:d,isLoading:u}=U.customAuth;if(!(!n||u))try{let y=await d();if(!y){await br.logout();return}if(a)return;t.startAuthFlow(new Vo(y));let{user:L,isNewUser:me}=await t.authenticate();L||await br.logout(),c(L||null),E(me||!1),l(!0),To(!0)}catch(y){console.warn(y),a&&await br.logout()}})()},[U.customAuth?.enabled,U.customAuth?.getCustomAccessToken,U.customAuth?.isLoading,n,a]),kt(()=>{an&&O&&s&&Yt(s,e.config?.embeddedWallets?.createOnLogin)&&(To(!1),as(s,jo).catch(console.error))},[an&&O&&s]),kt(()=>{async function p(){let d=await t.getServerConfig();J(d);let u=Mi(d,e.config);We(u),d.customApiUrl&&t.updateApiUrl(d.customApiUrl),t.initializeConnectorManager(u.walletConnectCloudProjectId,u.rpcConfig,u.chains,u.defaultChain),t.connectors?.initialize();let y=Cr();Nw();let L=await t.getAuthenticatedUser();e.config?.customAuth?.enabled||(l(!!L),L&&K($,"login","onComplete",L,!1,!0),c(L)),y||(i(!0),D?.()),y&&L&&m(!0),mt()}n||p()},[t,D,n]),kt(()=>{let p=Mi(H,e.config);We(p)},[e.config]);let Cr=()=>{let p=new URLSearchParams(window.location.search),d=p.get("privy_oauth_code"),u=p.get("privy_oauth_state"),y=p.get("privy_oauth_provider");return d&&u&&y?(t.startAuthFlow(new jt(y,d,u)),zo("AWAITING_OAUTH_SCREEN"),le({finishOauthFlow:{onComplete:()=>{i(!0),D?.()}}}),!0):!1},$t=async(p,d,u)=>{let y=await t.connectors?.createWalletConnector(p,d)||null;Me(y,u)};async function Me(p,d){if(!p)return M({status:"disconnected",connectError:new B("Unable to connect to wallet."),connector:null,connectRetry:w}),d?.(null);M({connector:p,status:"connecting",connectError:null,connectRetry:()=>Me(p,d)});try{let u=await p.connect({showPrompt:!0});if(U.shouldSwitchChainOnConnect&&!U.chains.find(y=>y.id===Number(u?.chainId))){M(y=>({...y,connector:p,status:"switching_to_supported_chain",connectError:null,connectRetry:w}));try{await u?.switchChain(U.defaultChain.id),u&&(u.chainId=Ko(ko(U.defaultChain.id)))}catch{console.warn(`Unable to switch to default chain: ${U.defaultChain.id}`)}}return M(y=>({...y,status:"connected",connectError:null,connectRetry:w})),u&&!N&&K($,"connectWallet","onSuccess",u),d?.(u)}catch(u){return u instanceof Ue?(console.warn(u.cause?u.cause:u.message),N||K($,"connectWallet","onError",u.privyErrorCode||"generic_connect_wallet_error")):(console.warn(u),N||K($,"connectWallet","onError","unknown_connect_wallet_error")),M(y=>({...y,status:"disconnected",connectError:u})),d?.(null)}}let ne=p=>{p!==null&&t.startAuthFlow(new _o(p))},mt=()=>{let p=new URLSearchParams(window.location.search),d=p.get("privy_connector"),u=p.get("privy_wallet_client");if(!d||!u)return;if(u==="phantom"&&!Ze()&&zo("LOGIN_FAILED_SCREEN"),!t.connectors)throw new v("Connector not initialized");ue("AWAITING_CONNECTION");let y=new URL(window.location.href);y.searchParams.delete("privy_connector"),y.searchParams.delete("privy_wallet_client"),window.history.pushState({},"",y),$t(d,u,ne)};kt(()=>{n&&a&&s===null&&t.getAuthenticatedUser().then(c)},[n,a,s,t]);let ns=()=>{m(!0),ue("LINK_WALLET_SCREEN")},uu=p=>{if(!a||!s)return!1;for(let d of s.linkedAccounts)if(d.type==="wallet"&&d.address===p.address)return!0;return!1},mu=async p=>{if(!t.connectors)throw new v("Connector not initialized");let d=t.connectors.findWalletConnector(p.connectorType,p.walletClientType)||null;M(u=>({...u,connector:d,status:"connected",connectError:null,connectRetry:w})),ne(p),zo("AWAITING_CONNECTION")},hu=async(p,d)=>{if(!t.connectors)throw new v("Connector not initialized");await $t(p,d,ne)},is=async(p,d)=>{if(!U.fiatOnRamp.enabled)throw new v("Fiat on-ramp is not enabled");if(!d||!d.provider||d.provider==="moonpay"){let{signedUrl:u,externalTransactionId:y}=await $c(t,p,d?.config??{},U.appearance.palette,U.fiatOnRamp.useSandbox);return{signedUrl:u,externalTransactionId:y}}else throw new v("Unsupported fund provider. Currently supported option is `moonpay`.")},ln=()=>{f(p=>{let d=t.connectors?.wallets.map(u=>({...u,linked:uu(u),loginOrLink:async()=>{if(!await u.isConnected())throw new v("Wallet is not connected");if(u.connectorType==="embedded"&&u.walletClientType==="privy")throw new v("Cannot link or login with embedded wallet");mu(u)},fund:async y=>{let{signedUrl:L,externalTransactionId:me}=await is(u.address,y);le({fiatOnRampPrompt:{signedUrl:L},fiatOnRampStatus:{externalTransactionId:me}}),ue("FIAT_ON_RAMP_PROMPT_SCREEN")},unlink:async()=>{if(!a)throw new v("User is not authenticated.");if(u.connectorType==="embedded"&&u.walletClientType==="privy")throw new v("Cannot unlink an embedded wallet");let y=await t.unlinkWallet(u.address);c(y)}}))||[];return xn(p,d)?p:d})};kt(()=>{ln()},[s?.linkedAccounts,a,n]),kt(()=>{if(n){if(!t.connectors)throw new v("Connector not initialized");ln(),t.connectors.on("walletsUpdated",ln)}},[n]);let fu=()=>{ue(a?"CONNECT_ONLY_AUTHENTICATED_SCREEN":"CONNECT_ONLY_LANDING_SCREEN")};kt(()=>{if(!g[0])return;let p=g[0],d=C.current.find(y=>y.address===p.address),u=s?.linkedAccounts.find(y=>y.type==="wallet"&&y.address===p.address);if(!d&&u){let y=Object.assign({},s);y.wallet=u&&{address:u.address,chainType:u.chainType,chainId:u.chainId,walletClient:u.walletClient,walletClientType:u.walletClientType,connectorType:u.connectorType},c(y)}C.current=g},[g]);let as=async(p,d)=>{if(Q(p))throw K($,"createWallet","onError","embedded_wallet_already_exists"),new Error("Only one Privy wallet per user is currently allowed");let[y,L]=await Promise.all([xe.initializeWalletProxy(d),ze()]);if(!y&&e.config?.customAuth?.enabled)throw K($,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to connect to wallet proxy");if(!y||!L||e.config?.embeddedWallets?.requireUserPasswordOnCreate)return new Promise((me,Pe)=>{V(!0),le({createWallet:{onSuccess:Je=>{K($,"createWallet","onSuccess",Je),me(Je)},onFailure:Je=>{K($,"createWallet","onError","unknown_embedded_wallet_error"),Pe(Je)},callAuthOnSuccessOnClose:!1}}),ue("EMBEDDED_WALLET_ON_ACCOUNT_CREATE_SCREEN")});{await y.create({accessToken:L});let me=await xe.refreshUser(),Pe=Q(me);if(!Pe)throw K($,"createWallet","onError","unknown_embedded_wallet_error"),new Error("Failed to create wallet");return K($,"createWallet","onSuccess",Pe),Pe}},yu=p=>{if(!U.chains.map(d=>d.id).includes(p))throw new B(`Chain ID ${p} is not supported. It must be added to the config.supportedChains property of the PrivyProvider.`,"unsupported_chain_id")},ss=(p,d,u)=>new Promise(async(y,L)=>{if(!a||!s){L(new Error("User must be authenticated before signing with a Privy wallet"));return}let me=Q(s);if(!me){L(new Error("Must have a Privy wallet before signing"));return}V(!0);let Pe=t.connectors?.findWalletConnector("embedded","privy")?.proxyProvider,Vt=p.chainId?Number(p.chainId):Pe.chainId;yu(Vt);let Je=Object.assign({},p,{chainId:Vt}),Er=async()=>{let qt=await ze();if(!qt||!O){L(new Error("Must have valid access token and Privy wallet to send transaction"));return}try{if(!await xe.recoverEmbeddedWallet()){L(new Error("Unable to connect to wallet"));return}let ls=new Iw(at(Je.chainId,U.chains,U.rpcConfig)),vu=await Si(me.address,Je,ls),wu=await _i(qt,me.address,O,vu,ls);y(wu)}catch(cn){L(cn)}};if(U.embeddedWallets.noPromptOnSignature)d&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config"),Er();else{let qt={transactionRequest:Je,onSuccess:y,onFailure:L,uiOptions:d||{},fundWalletConfig:u},cn={onCompleteNavigateTo:"EMBEDDED_WALLET_SEND_TRANSACTION_SCREEN",onFailure:L};le({connectWallet:cn,sendTransaction:qt}),ue("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),br={ready:n,authenticated:a,user:s,walletConnectors:t.connectors||null,connectWallet:fu,linkWallet:ns,linkEmail:()=>{if(s?.email)throw new v("User already has an email linked to their account.");m(!0),ue("LINK_EMAIL_SCREEN")},linkPhone:()=>{if(s?.phone)throw new v("User already has a phone number linked to their account.");m(!0),ue("LINK_PHONE_SCREEN")},linkGoogle:async()=>{if(s?.google)throw new v("User already has a Google account linked to their account.");await xe.initLoginWithOAuth("google")},linkTwitter:async()=>{if(s?.twitter)throw new v("User already has a Twitter account linked to their account.");await xe.initLoginWithOAuth("twitter")},linkDiscord:async()=>{if(s?.discord)throw new v("User already has a Discord account linked to their account.");await xe.initLoginWithOAuth("discord")},linkGithub:async()=>{if(s?.github)throw new v("User already has a Github account linked to their account.");await xe.initLoginWithOAuth("github")},linkTiktok:async()=>{if(s?.tiktok)throw new v("User already has a Tiktok account linked to their account.");await xe.initLoginWithOAuth("tiktok")},linkLinkedIn:async()=>{if(s?.linkedin)throw new v("User already has a LinkedIn account linked to their account.");await xe.initLoginWithOAuth("linkedin")},linkApple:async()=>{await xe.initLoginWithOAuth("apple")},login:async()=>{if(n||(await new Promise(p=>{Gt(()=>p)}),Gt(null)),a){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}I(!0),zo()},logout:async()=>{await t.logout(),c(null),l(!1),k(null),K($,"logout","onSuccess"),m(!1),r(!1),z.del(Tr)},getAccessToken:()=>t.getAccessToken(),getEthereumProvider:()=>{if(!s||!s.wallet)return new Z;let p=g.find(u=>s.wallet&&u.address===s.wallet.address),d=t.connectors?.walletConnectors.find(u=>u.wallets.find(y=>y.address===p?.address));return!p||!d?new Z:d.proxyProvider},getEthersProvider:()=>{if(!s||!s.wallet)return new rs(new vt(new Z));let p=g.find(u=>s.wallet&&u.address===s.wallet.address),d=t.connectors?.walletConnectors.find(u=>u.wallets.find(y=>y.address===p?.address));return!p||!d?new rs(new vt(new Z)):new rs(new vt(d.proxyProvider))},getWeb3jsProvider:()=>{if(!s||!s.wallet)return new Xt(new Z);let p=g.find(u=>s.wallet&&u.address===s.wallet.address),d=t.connectors?.walletConnectors.find(u=>u.wallets.find(y=>y.address===p?.address));return!p||!d?new Xt(new Z):new Xt(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=g.find(y=>Di(y.address)===Di(p)),u=s?.linkedAccounts.find(y=>y.type==="wallet"&&Di(y.address)===Di(p));if(!d||!await d.isConnected())te(p),ns();else if(!d.linked)d.loginOrLink();else{let y=Object.assign({},s);y.wallet=u&&{address:u.address,chainType:u.chainType,chainId:u.chainId,walletClient:u.walletClient,walletClientType:u.walletClientType,connectorType:u.connectorType},c(y)}},forkSession:()=>t.forkSession(),createWallet:async()=>{if(!a||!s)throw K($,"createWallet","onError","must_be_authenticated"),new Error("User must be authenticated before creating a Privy wallet");return as(s,15e3)},setWalletPassword:()=>new Promise((p,d)=>{if(!a||!s){d(new Error("User must be authenticated before adding password to Privy wallet"));return}let u=Q(s);if(!u||!O){d(new Error("Must have a Privy wallet to add a password"));return}if(u.recoveryMethod==="user-passcode"){d(new Error("Cannot set password. Embedded wallet already has a password."));return}V(!0);let y={onSuccess:p,onFailure:d,callAuthOnSuccessOnClose:!1},L={onCompleteNavigateTo:"EMBEDDED_WALLET_PASSWORD_UPDATE_SPLASH_SCREEN",onFailure:d};le({setWalletPassword:y,connectWallet:L}),ue("EMBEDDED_WALLET_CONNECTING_SCREEN")}),signMessage:(p,d)=>new Promise(async(u,y)=>{if(!a||!s){y(new Error("User must be authenticated before signing with a Privy wallet"));return}let L=Q(s);if(!L){y(new Error("Must have a Privy wallet before signing"));return}if(typeof p!="string"||p.length<1){y(new Error("Message must be a non-empty string"));return}V(!0);let me=async()=>{if(!a)return y(new Error("User must be authenticated before signing with a Privy wallet")),null;let Pe=await ze();if(O&&Pe)try{if(!await xe.recoverEmbeddedWallet())return y(new Error("Unable to connect to wallet")),null;t.createAnalyticsEvent("embedded_wallet_sign_message_started",{walletAddress:L.address});let{response:Je}=await O.rpc({accessToken:Pe,address:L.address,request:{method:"personal_sign",params:[p,L.address]}}),Er=Je.data;return t.createAnalyticsEvent("embedded_wallet_sign_message_completed",{walletAddress:L.address}),Er}catch(Vt){return y(Vt),null}else return null};if(U.embeddedWallets.noPromptOnSignature){d&&console.warn("uiOptions defined with `noPromptOnSignature` set to true in app config");let Pe=await me();Pe?u(Pe):y(new Te("Unable to sign message"))}else{let Je={message:p,confirmAndSignMessage:me,onSuccess:qt=>{u(qt)},onFailure:qt=>{y(qt)},uiOptions:d||{}},Er={onCompleteNavigateTo:"EMBEDDED_WALLET_SIGN_REQUEST_SCREEN",onFailure:y};le({signMessage:Je,connectWallet:Er}),ue("EMBEDDED_WALLET_CONNECTING_SCREEN")}}),sendTransaction:async(p,d,u)=>{let L=await(await ss(p,d,u)).wait();return Ai(L)},exportWallet:()=>new Promise((p,d)=>{if(!a||!s){d(new Error("User must be authenticated before exporting their Privy wallet"));return}if(!Q(s)){d(new Error("Must have a Privy wallet before exporting"));return}V(!0);let y={onCompleteNavigateTo:"EMBEDDED_WALLET_KEY_EXPORT_SCREEN",onFailure:d},L={appId:e.appId,origin:t.apiUrl,onSuccess:p,onFailure:d};le({keyExport:L,connectWallet:y}),ue("EMBEDDED_WALLET_CONNECTING_SCREEN")}),async init(p){let d;switch(p){case"sms":d=new Li("verify");break;case"totp":return;default:throw K($,"configureMfa","onError","unknown_mfa_error"),new Error(`Unsupported MFA method: ${p}`)}t.startMfaFlow(d);try{await d.init()}catch(u){throw K($,"configureMfa","onError",u.privyErrorCode||"unknown_mfa_error"),u}},async submit(p,d){switch(p){case"totp":case"sms":Ee.current?.resolve({mfaMethod:p,mfaCode:d}),await new Promise((u,y)=>{sn.current={resolve:u,reject:y}});break;default:throw Ee.current?.reject(new v("Unsupported MFA method")),K($,"configureMfa","onError","unknown_mfa_error"),new v(`Unsupported MFA method: ${p}`)}},cancel(){Ee.current?.reject(new v("MFA canceled"))},async initEnrollmentWithSms(p){let d=await ze();if(!d||!O)throw new Error("Must have valid access token to enroll in MFA");try{await O.initEnrollMfa({method:"sms",accessToken:d,phoneNumber:p.phoneNumber})}catch(u){throw K($,"configureMfa","onError",u.privyErrorCode||"unknown_mfa_error"),u}},async initEnrollmentWithTotp(){let p=await ze();if(!p||!O)throw new Error("Must have valid access token to enroll in MFA");try{let d=await O.initEnrollMfa({method:"totp",accessToken:p});return{secret:d.secret,authUrl:d.authUrl}}catch(d){throw K($,"configureMfa","onError",d.privyErrorCode||"unknown_mfa_error"),d}},async submitEnrollmentWithSms(p){let d=await ze();if(!d||!O)throw new Error("Must have valid access token to enroll in MFA");try{await O.submitEnrollMfa({method:"sms",accessToken:d,phoneNumber:p.phoneNumber,code:p.mfaCode});let u=await t.getAuthenticatedUser();c(u)}catch(u){throw K($,"configureMfa","onError",u.privyErrorCode||"unknown_mfa_error"),u}},async submitEnrollmentWithTotp(p){let d=await ze();if(!d||!O)throw new Error("Must have valid access token to enroll in MFA");try{await O.submitEnrollMfa({method:"totp",accessToken:d,code:p.mfaCode});let u=await t.getAuthenticatedUser();c(u)}catch(u){throw K($,"configureMfa","onError",u.privyErrorCode||"unknown_mfa_error"),u}},loginWithCode(p){return xe.loginWithCode(p)},initLoginWithEmail(p,d){return xe.initLoginWithEmail(p,d)}};lu=br.signMessage,cu=async(...p)=>{let d=await ss(...p);return U.embeddedWallets.waitForTransactionConfirmation&&await d.wait(),d};let xe=(()=>({isNewUserThisSession:P,isLinking:h,linkingHint:A,walletConnectionStatus:R,rpcConfig:U.rpcConfig,chains:U.chains,showFiatPrices:U.embeddedWallets.priceDisplay.primary!=="native-token",clientAnalyticsId:t.clientAnalyticsId,nativeTokenSymbolForChainId:p=>U.chains.find(d=>d.id===Number(p))?.nativeCurrency.symbol,initializeWalletProxy:async p=>{if(O)return O;let d=new Promise(L=>{Po(()=>me=>L(me))}),u=new Promise(L=>setTimeout(()=>L(null),p)),y=await Promise.race([d,u]);return Po(null),y},getAuthFlow:()=>t.authFlow,getAuthMeta:()=>t.authFlow?.meta,closePrivyModal:(p={shouldCallAuthOnSuccess:!0})=>{let d=n&&a&&s;p.shouldCallAuthOnSuccess&&d?(K($,"login","onComplete",s,P,!1),e.onSuccess?.(s,P)):N&&K($,"login","onError","exited_auth_flow"),t.authFlow=void 0,te(null),k(null),I(!1),m(!1),E(!1),r(!1),t.createAnalyticsEvent("modal_closed")},connectWallet:$t,initLoginWithWallet:hu,loginWithWallet:async()=>{if(!n)throw new xr;if(!(t.authFlow instanceof _o))throw new v("Must initialize SIWE flow first.");let p,d;if(a)p=await t.link();else try{({user:p,isNewUser:d}=await t.authenticate())}catch(u){throw K($,"login","onError",u.privyErrorCode||"generic_connect_wallet_error"),u}c(p||s||null),E(d||!1),l(!0)},initLoginWithOAuth:async p=>{t.startAuthFlow(new jt(p));let d=await t.authFlow.getAuthorizationUrl();d&&d.url&&window.location.assign(d.url)},loginWithOAuth:async()=>{if(!(t.authFlow instanceof jt))throw new v("Must initialize OAuth flow before calling loginWithOAuth");let p,d;if(a)p=await t.link();else try{({user:p,isNewUser:d}=await t.authenticate())}catch(u){throw K($,"login","onError",u.privyErrorCode||"unknown_auth_error"),u}c(p),E(d||!1),l(!0)},initLoginWithEmail:async(p,d)=>{let u=new So(p,d);t.startAuthFlow(u);try{await u.sendCodeEmail()}catch(y){throw K($,"login","onError",y.privyErrorCode||"unknown_auth_error"),y}},initLoginWithSms:async(p,d)=>{let u=new Ao(p,d);t.startAuthFlow(u);try{await u.sendSmsCode()}catch(y){throw K($,"login","onError",y.privyErrorCode||"unknown_auth_error"),y}},resendEmailCode:async()=>{await t.authFlow?.sendCodeEmail()},resendSmsCode:async()=>{await t.authFlow?.sendSmsCode()},loginWithCode:async p=>{if(!n)throw new xr;if(t.authFlow instanceof So)t.authFlow.meta.emailCode=p.trim();else if(t.authFlow instanceof Ao)t.authFlow.meta.smsCode=p.trim();else throw new v("Must initialize a passwordless code flow first");let d,u;a?d=await t.link():{user:d,isNewUser:u}=await t.authenticate(),c(d||s||null),E(u||!1),l(!0)},refreshUser:async()=>{let p=await t.getAuthenticatedUser();return c(p),p},walletProxy:O,createAnalyticsEvent:(p,d,u)=>t.createAnalyticsEvent(p,d,u),getUsdTokenPrice:p=>t.getUsdTokenPrice(p),recoverEmbeddedWallet:async()=>new Promise(async(p,d)=>{let u=s?.linkedAccounts.find(L=>L.type==="wallet"&&L.walletClientType==="privy"),y=await ze();if(!y||!O||!u){d(new Error("Must have valid access token and Privy wallet to recover wallet"));return}V(!0);try{await O.connect({accessToken:y,address:u.address}),p(!0)}catch(L){ir(L)&&u.recoveryMethod==="privy"?(t.createAnalyticsEvent("embedded_wallet_pinless_recovery_started",{walletAddress:u.address}),(await O.recover({address:u.address,accessToken:y})).address||d(new Error("Unable to recover wallet")),t.createAnalyticsEvent("embedded_wallet_recovery_completed",{walletAddress:u.address}),p(!0)):ir(L)?(le({recoverWallet:{privyWallet:u,onFailure:d,onSuccess:()=>p(!0)}}),ue("EMBEDDED_WALLET_RECOVERY_SCREEN")):d(L)}}),getFiatOnRampConfig:is,updateWallets:()=>ln()}))();du=xe.recoverEmbeddedWallet;let gu=Ww(()=>({wallets:g}),[g]);return xo(Se.Provider,{value:br,children:xo(ts.Provider,{value:$,children:xo(Ja.Provider,{value:gu,children:su(ld,{...U,children:[e.children,su(ea.Provider,{value:xe,children:[xo(Ip,{theme:{...U.appearance.palette||{}}}),xo(ll,{appConfig:U,data:Ce,setModalData:le,setInitialScreen:k,initialScreen:x,visible:o,authenticated:a,children:o?xo(Op,{}):null}),re&&H.id?xo(au,{appId:e.appId,clientAnalyticsId:t.clientAnalyticsId,origin:t.apiUrl,mfaMethods:s?.mfaMethods,mfaPromise:Ee,mfaSubmitPromise:sn,onLoad:q,onLoadFailed:()=>null}):null]})]})})})})};import{useContext as Dw}from"react";function Uw(){let{init:e,submit:t,cancel:o}=Dw(Se);return{init:e,submit:t,cancel:o}}import{useContext as Fw}from"react";function Bw(){let{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,submitEnrollmentWithSms:o,submitEnrollmentWithTotp:r}=Fw(Se);return{initEnrollmentWithSms:e,initEnrollmentWithTotp:t,submitEnrollmentWithSms:o,submitEnrollmentWithTotp:r}}import{useContext as Hw}from"react";function Gw(e){let{login:t}=Hw(Se);return At("login",e),{login:t}}import{useContext as zw}from"react";function $w(e){let{logout:t}=zw(Se);return At("logout",e),{logout:t}}import{useCallback as pu}from"react";var Vw=()=>{let e=Tt(),{initLoginWithEmail:t,loginWithCode:o}=G(),r=pu(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=pu(async({code:i})=>{if(e.enabled&&e.status!=="success")throw new qr(e.error,null,"captcha_failure");return o(i)},[o,e.status]);return{sendCode:r,loginWithCode:n}};function qw(e){At("configureMfa",e)}import{useContext as jw}from"react";function Kw(e){let{connectWallet:t}=jw(Se);return At("connectWallet",e),{connectWallet:t}}import{useContext as Yw}from"react";function Jw(e){let{createWallet:t}=Yw(Se);return At("createWallet",e),{createWallet:t}}export{vt as AsExternalProvider,jr as Captcha,Ir as ConnectorManager,Mr as PrivyClient,Ow as PrivyProvider,Z as PrivyProxyProvider,rn as SUPPORTED_CHAINS,Fi as VERSION,$e as WalletConnector,lh as errorIndicatesMaxMfaRetries,ah as errorIndicatesMfaTimeout,sh as errorIndicatesMfaVerificationFailed,ze as getAccessToken,Kw as useConnectWallet,Jw as useCreateWallet,Gw as useLogin,Vw as useLoginWithEmail,$w as useLogout,Uw as useMfa,Bw as useMfaEnrollment,G as usePrivy,qw as useRegisterMfaListener,Qa as useWallets};