@privy-io/react-auth 1.15.0-beta.2 → 1.15.0-beta.3
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 +43 -43
- package/dist/index.js +48 -48
- package/package.json +1 -1
package/dist/esm/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{useEffect as Oi,useState as
|
|
1
|
+
import{useEffect as Oi,useState as oe}from"react";import Yt from"axios";import Ui from"axios";var j=class extends Error{constructor(o,r){super(o);r instanceof Error&&(this.cause=r)}toString(){return`${this.type}: ${this.message}${this.cause?` [cause: ${this.cause}]`:""}`}},Ie=class extends j{constructor(o,r,i,n){super(i,n);this.type=o;this.status=r}},h=class extends j{constructor(o,r){super(o,r);this.type="client_error"}};var I=class extends j{constructor(o,r){super(o,r);this.type="connector_error"}},S=t=>{if(t instanceof j)return t;if(!Ui.isAxiosError(t))return H(t);if(!t.response)return new Ie("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new Ie(e||"ApiError",t.response.status,o||r,t)},H=t=>t instanceof j?t:t instanceof Error?new h(t.message,t):new h(`Internal error: ${t}`);var Io="1.15.0-beta.3";var Ro="https://api.privy.io/v0",Mo=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",qe="4df5e2316331463a9130964bd6078dfa",No=1e4,ue=1400,Jt=Io;var Re="privy:token",pt="privy:refresh_token",ht="privy:connectors",Oo="walletconnect";var mt=class{constructor(e,o,r){this.appId=e,this.sdkVersion=Jt,this.client=o,this.defaults=r}async get(e,o){try{return await Yt.get(e,await this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw S(r)}}async post(e,o,r){try{return await Yt.post(e,o,await this.buildConfig(r))}catch(i){throw S(i)}}async delete(e,o){try{return await Yt.delete(e,await this.buildConfig(o))}catch(r){throw S(r)}}async buildConfig(e){if(e=e||{},e.headers=e.headers||{},e.headers["privy-app-id"]=this.appId,e.headers["privy-client"]=`react-auth:${this.sdkVersion}`,!e.headers.authorization){let o=await this.client.getAccessToken();o!==null&&(e.headers.authorization=`Bearer ${o}`)}return{...this.defaults,...e}}};import*as Uo from"jose";var ne=class{static parse(e){try{return new ne(e)}catch{return null}}constructor(e){this.value=e,this._decoded=Uo.decodeJwt(e)}get subject(){return this._decoded.sub}get expiration(){return this._decoded.exp}get issuer(){return this._decoded.iss}get audience(){return this._decoded.aud}isExpired(e=0){let o=Date.now(),r=(this.expiration-e)*1e3;return o>=r}};var pe=class{constructor(e){this.promise=null;this.fn=e}execute(e){return this.promise===null&&(this.promise=(async()=>{try{return await this.fn(e)}finally{this.promise=null}})()),this.promise}};var Qt=class{constructor(){this._cache={}}get(e){return this._cache[e]}put(e,o){o!==void 0?this._cache[e]=o:this.del(e)}del(e){delete this._cache[e]}getKeys(){return Object.keys(this._cache)}},Xt=class{get(e){let o=localStorage.getItem(e);return o===null?void 0:JSON.parse(o)}put(e,o){o!==void 0?localStorage.setItem(e,JSON.stringify(o)):this.del(e)}del(e){localStorage.removeItem(e)}getKeys(){return Object.entries(localStorage).map(([e])=>e)}};function Di(){return typeof window<"u"&&window.localStorage?new Xt:new Qt}var O=Di();import{ErrorCode as Gi}from"@ethersproject/logger";var Me=class extends I{constructor(){super("Wallet timeout");this.type="wallet_error"}},he=t=>{if(t instanceof I)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new Ne(t);return t.code===Gi.ACTION_REJECTED&&(e.details=xe.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new Ne(t):new I("Unknown connector error",t)},eo=class extends j{constructor(o,r,i){super(o);this.type="provider_error";this.code=r,this.data=i}},Ne=class extends eo{constructor(o){var n,a,d;let r=o;super(r.message,r.code,r.data);let i=Object.values(xe).find(u=>u.eipCode===r.code);this.details=i||xe.UNKNOWN_ERROR,r.code===-32002&&((n=r.message)!=null&&n.includes("already pending for origin")?(a=r.message)!=null&&a.includes("wallet_requestPermissions")?this.details=xe.E32002_CONNECTION_ALREADY_PENDING:this.details=xe.E32002_REQUEST_ALREADY_PENDING:(d=r.message)!=null&&d.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=xe.E32002_WALLET_LOCKED))}},Vi={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}},Hi={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}},Bi={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}},xe={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Bi,...Hi},Oe={...Vi,...xe};var zi=12e4,to=(t=new Me,e=zi)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),J=class{constructor(e){this.removeListener=(e,o)=>{if(this.walletProvider)return this.walletProvider.removeListener(e,o)};this.setProvider=e=>{this.walletProvider=e,this._subscriptions.forEach(o=>{var r;(r=this.walletProvider)==null||r.on(o.eventName,o.listener)})};this.walletProvider=e,this._subscriptions=[]}on(e,o){if(this.walletProvider)return this.walletProvider.on(e,o);this._subscriptions.push({eventName:e,listener:o})}async request(e){if(!this.walletProvider)throw new I(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),to()]).catch(o=>{throw he(o)})}},Le=class extends J{constructor(o){super(o)}},ft=class extends J{constructor(e){super(e)}sendAsync(e,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};import{getAddress as Ho}from"@ethersproject/address";import{Web3Provider as Ki}from"@ethersproject/providers";import{getAddress as ji}from"@ethersproject/address";import{Web3Provider as $i}from"@ethersproject/providers";var se=class{constructor(e,o,r){this.createSiweMessage=(e,o,r,i,n,a,d)=>`${r} wants you to sign in with your Ethereum account:
|
|
2
2
|
${o}
|
|
3
3
|
|
|
4
4
|
${d}
|
|
@@ -9,7 +9,7 @@ Chain ID: ${e}
|
|
|
9
9
|
Nonce: ${a}
|
|
10
10
|
Issued At: ${n}
|
|
11
11
|
Resources:
|
|
12
|
-
- https://privy.io`;this.provider=o,this.walletType=e,this.address=r,this.chain=null,this.connected=!1}async fetchAddress(){if(!this.address){let e=await this.provider.request({method:"eth_accounts"});Array.isArray(e)&&e.length>0&&(this.address=ji(e[0]))}return this.address}async fetchChainId(){if(!this.chain){let e=await this.provider.request({method:"eth_chainId"}),o=Number(e);this.chain=String(o)}return this.chain}async getConnectedWallet(){let e=this.walletType;if(!e||!await this.isConnected())return null;let o=await this.fetchAddress(),r=await this.fetchChainId();return{address:o,chainId:r,chainType:"ethereum",walletType:e}}async setActive(){return!0}async sign(e){return new $i(new Le(this.provider)).getSigner().signMessage(e)}prepareMessage(e,o,r){let i=window.location.host,n=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.",d=new Date().toISOString();return this.createSiweMessage(e,o,i,n,d,r,a)}};import{isPossiblePhoneNumber as Zi}from"libphonenumber-js/min";var Fo=t=>!!String(t).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,}))$/),Do=t=>Zi(String(t),"US"),ft=t=>{var e=/^#?([a-f\d])([a-f\d])([a-f\d])$/i;t=t.replace(e,function(r,i,n,a){return i+i+n+n+a+a});var o=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(t);return{r:parseInt((o==null?void 0:o[1])||"00",16),g:parseInt((o==null?void 0:o[2])||"00",16),b:parseInt((o==null?void 0:o[3])||"00",16)}},Go=(t,e)=>{var o=t.slice(0);let r=[];for(;o.length;)r.push(o.splice(0,e));return r},qe=t=>{if(!t)return"";let e=t.slice(0,5),o=t.slice(t.length-4,t.length);return`${e}...${o}`},Vo=t=>new Promise(e=>setTimeout(e,t));import{isMobile as qi}from"react-device-detect";var gt=class extends ie{constructor(e,o){var r;super("metamask",e,o),this.provider.setProvider(window.ethereum),(r=window.ethereum.providers)==null||r.forEach(async i=>{i.isMetaMask&&this.provider.setProvider(i)}),this.subscribeListeners()}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}async isConnected(){let e=await this.connectedMetamaskAddress();return this.address===e}async connectedMetamaskAddress(){let o=await new Ki(this.provider).listAccounts();return o.length===0?null:Ho(o[0])}disconnect(){console.warn("Metamask does not support programmetic disconnect.")}async promptConnection(){try{let e="";if(!qi&&(await this.provider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]}),this.address&&await this.isConnected()))throw new I("Selected the wrong wallet in MetaMask");let o=await this.provider.request({method:"eth_requestAccounts"});if(o.length>0&&(e=Ho(o[0])),!e||e==="")throw new I("Unable to retrieve address");this.connected=!0,this.address=e}catch(e){throw pe(e)}}async setActive(){for(;!this.connected;)await Vo(200);return!0}subscribeListeners(){this.provider.on("accountsChanged",e=>{var o;if(e.length>0){let r=e[0];this.connected=((o=this.address)==null?void 0:o.toLowerCase())===(r==null?void 0:r.toLowerCase())}}),this.provider.on("disconnect",()=>{this.connected=!1})}};import{getAddress as Ji}from"@ethersproject/address";import Yi from"@coinbase/wallet-sdk";var Qi=t=>{let e=`https://mainnet.infura.io/v3/${Ke}`,o=1;return t.makeWeb3Provider(e,o)},wt,yt=class extends ie{constructor(e,o){super("coinbase_wallet",e,o),wt||(wt=new Yi({appName:"Privy",darkMode:!1,headlessMode:!1}))}async connect(e){return this.provider.setProvider(Qi(wt)),(!await this.isConnected()||e.showPrompt)&&await this.promptConnection(),this.getConnectedWallet()}disconnect(){wt.disconnect()}async isConnected(){return await this.fetchAddress()!==null}async promptConnection(){try{let e="",o=await this.provider.request({method:"eth_requestAccounts"});if(o.length>0&&(e=Ji(o[0])),!e||e==="")throw new I("Unable to retrieve address");this.connected=!0}catch(e){throw pe(e)}}};import Bo from"@walletconnect/web3-provider";var oo=class extends ie{constructor(o,r,i){super("wallet_connect",r,i);this._globalConnector=o,this._provider=this._globalConnector.getProviderForAddress(i)}async connect(o){return this.provider.setProvider(this._provider),(!await this.isConnected()||o.showPrompt)&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return this.provider.walletProvider.connected}async promptConnection(){try{let o="";this.provider.setProvider(this._provider);let r=await Promise.race([this._provider.enable(),to()]);if(r.length>0&&(o=r[0]),this._globalConnector.indexProvider(this._provider),!o||o==="")throw new I("Unable to retrieve address");this.connected=!0}catch(o){throw pe(o)}}disconnect(){}},vt=class{constructor(){this._storageIdToProvider={},this._addressToStorageId={},O.getKeys().forEach(e=>{if(e.startsWith("walletconnect")){let o=new Bo({infuraId:Ke,storageId:e});o.enable(),this._storageIdToProvider[e]=o;for(let r of o.accounts)this._addressToStorageId[r]=e}})}build(e,o){return new oo(this,e,o)}async disconnect(){Object.values(this._storageIdToProvider).forEach(async e=>{await e.disconnect()})}getProviderForAddress(e){let o=Oo,r=()=>`walletconnect:${Math.random().toString(36).slice(2)}`;e===null?o=r():o=this._addressToStorageId[e]||r();let i=new Bo({infuraId:Ke,storageId:o});return this._storageIdToProvider[o]=i,i}indexProvider(e){this._storageIdToProvider[e.storageId]=e;for(let o of e.accounts)this._addressToStorageId[o]=e.storageId}};import{getAddress as Xi}from"@ethersproject/address";var ro=()=>{if(!window.ethereum)return!1;if(window.ethereum.isMetaMask)return!0;if(window.ethereum.providers){for(let t of window.ethereum.providers)if(t.isMetaMask)return!0}return!1},Ct=()=>{if(!window.ethereum)return!1;if(window.ethereum.isCoinbaseWallet)return!0;if(window.ethereum.providers){for(let t of window.ethereum.providers)if(t.isCoinbaseWallet)return!0}return!1},io=t=>{let e=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return e?!!(t==null?void 0:t.linkedAccounts.filter(r=>r.type=="wallet"&&r.address===Xi(e)).length):!1},zo=()=>{var e;let t=O.get(pt);return t?(e=t.find(o=>o.active))==null?void 0:e.address:null},Je=class{constructor(){this.getEthereumProvider=()=>{var e;return((e=this.activeWalletConnector)==null?void 0:e.provider)||new q};this.walletConnectors=[],this.walletConnectGlobalWalletConnector=new vt,this.initialized=!1}initialize(){this.initialized||(this.load(),this.activeWalletConnector&&this.activeWalletConnector.connect({showPrompt:!1}),this.initialized=!0)}initializeLinkedWallets(e){e.linkedAccounts.forEach(()=>{})}load(){(O.get(pt)||[]).forEach(o=>{let r=this.createWalletConnector(o.walletType,o.address);this.addWalletConnector(r),o.active&&(this.activeWalletConnector=r)})}save(){let e=this.walletConnectors.map(o=>{var r;return{address:o.address,walletType:o.walletType,active:o.address===((r=this.activeWalletConnector)==null?void 0:r.address)}});O.put(pt,e)}addWalletConnector(e){this.walletConnectors.find(r=>r.address===e.address&&r.walletType===e.walletType)||this.walletConnectors.push(e)}getConnectorByAddress(e){return this.walletConnectors.find(o=>{var r;return((r=o.address)==null?void 0:r.toLowerCase())===e.toLowerCase()})}async removeWallet(e){var r;if(this.walletConnectors=this.walletConnectors.filter(i=>i.address!==e),e===((r=this.activeWalletConnector)==null?void 0:r.address))if(this.walletConnectors.length>0){let i=this.walletConnectors[this.walletConnectors.length-1];await this.setActiveWallet(i.address)}else this.activeWalletConnector=void 0;this.save()}async activeWalletSign(e){if(!this.activeWalletConnector)throw new I("Cannot sign, no wallet is active. Is a wallet connected?");if(!await this.activeWalletConnector.connect({showPrompt:!1}))throw new I("Cannot sign - unable to connect to wallet.");return this.activeWalletConnector.sign(e)}async setActiveWallet(e){let o=this.walletConnectors.find(r=>r.address===e);return o?(await o.setActive(),this.activeWalletConnector=o,this.save(),!0):!1}createWalletConnector(e,o){switch(e){case"metamask":return new gt(new q,o);case"coinbase_wallet":return new yt(new q,o);case"wallet_connect":return this.walletConnectGlobalWalletConnector.build(new q,o)}}};function he(t){return new Date(t*1e3)}function en(t){let e=[];for(let o of t){let r=o.type;switch(o.type){case"wallet":e.push({address:o.address,type:o.type,verifiedAt:he(o.verified_at),chainType:o.chain_type});break;case"email":e.push({address:o.address,type:o.type,verifiedAt:he(o.verified_at)});break;case"phone":e.push({number:o.phoneNumber,type:o.type,verifiedAt:he(o.verified_at)});break;case"google_oauth":e.push({subject:o.subject,email:o.email,name:o.name,type:o.type,verifiedAt:he(o.verified_at)});break;case"twitter_oauth":e.push({subject:o.subject,username:o.username,name:o.name,type:o.type,verifiedAt:he(o.verified_at)});break;case"discord_oauth":e.push({subject:o.subject,username:o.username,email:o.email,type:o.type,verifiedAt:he(o.verified_at)});break;case"github_oauth":e.push({subject:o.subject,username:o.username,name:o.name,email:o.email,type:o.type,verifiedAt:he(o.verified_at)});break;default:console.warn(`Unrecognized account type: ${r}. Please consider upgrading the Privy SDK.`)}}return e}function Ae(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function Ye(t){let e=zo();if(!e)return t.wallet&&console.warn("[Privy] User has linked wallets but no active wallet"),t;let o=t.linkedAccounts.find(i=>i.type==="wallet"&&i.address===e),r=Object.assign({},t);return r.wallet=o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletType:o.walletType},r}function ne(t){if(!t)return null;let e=en(t.linked_accounts),o=Ae(e,"wallet"),r=Ae(e,"email"),i=Ae(e,"phone"),n=Ae(e,"google_oauth"),a=Ae(e,"twitter_oauth"),d=Ae(e,"discord_oauth"),u=Ae(e,"github_oauth"),p={id:t.id,createdAt:he(t.created_at),linkedAccounts:e,email:r&&{address:r==null?void 0:r.address},phone:i&&{number:i==null?void 0:i.number},wallet:o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletType:o.walletType},google:n&&{subject:n.subject,email:n.email,name:n.name},twitter:a&&{subject:a.subject,username:a.username,name:a.name},discord:d&&{subject:d.subject,username:d.username,email:d.email},github:u&&{subject:u.subject,username:u.username,name:u.name,email:u.email}};return Ye(p)}var jo=()=>"/api/v1/sessions",$o=()=>"/api/v1/sessions/logout",Zo=()=>"/api/v1/sessions/fork",Ko=()=>"/api/v1/siwe/init",qo=()=>"/api/v1/siwe/authenticate",Jo=()=>"/api/v1/siwe/link",Yo=()=>"/api/v1/passwordless/init",Qo=()=>"/api/v1/passwordless/authenticate",Xo=()=>"/api/v1/passwordless/link",er=()=>"/api/v1/passwordless_sms/init",tr=()=>"/api/v1/passwordless_sms/authenticate",or=()=>"/api/v1/passwordless_sms/link",rr=()=>"/api/v1/oauth/init",ir=()=>"/api/v1/oauth/authenticate",nr=()=>"/api/v1/oauth/link",sr=()=>"/api/v1/siwe/unlink",ar=()=>"/api/v1/passwordless/unlink",lr=()=>"/api/v1/passwordless_sms/unlink",cr=()=>"/api/v1/oauth/unlink";var tn=30,bt=class{constructor(){this.authenticateOnce=new ue(async e=>this._authenticate(e)),this.linkOnce=new ue(async e=>this._link(e)),this.refreshOnce=new ue(this._refresh.bind(this)),this.destroyOnce=new ue(this._destroy.bind(this)),this.forkSessionOnce=new ue(this._forkSession.bind(this))}get token(){try{let e=O.get(Re);return typeof e=="string"?new re(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=O.get(ut);return typeof e=="string"?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}hasRefreshCredentials(){return typeof this.token=="string"&&typeof this.refreshToken=="string"}hasActiveToken(){let e=re.parse(this.token);return e!==null&&!e.isExpired(tn)}authenticate(e){return this.authenticateOnce.execute(e)}link(e){return this.linkOnce.execute(e)}refresh(){return this.refreshOnce.execute()}forkSession(){return this.forkSessionOnce.execute()}destroy(){return this.destroyOnce.execute()}async _authenticate(e){try{let{token:o,refresh_token:r,user:i,is_new_user:n}=await e.authenticate();return this.storeToken(o),this.storeRefreshToken(r),{user:ne(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),H(o)}}async _link(e){try{let o=await e.link();return ne(o)}catch(o){throw console.warn("Error linking account"),H(o)}}async _refresh(){if(!this.api)throw new h("Session has no API instance");if(!this.client)throw new h("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let e=this.token,o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(jo(),{refresh_token:o},{headers:{authorization:`Bearer ${e}`}});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),ne(r.data.user)}catch(r){if(r instanceof Ie&&r.status===400&&r.message==="Invalid auth token")return this.destroyLocalState(),null;throw H(r)}}async _destroy(){var e;try{await((e=this.api)==null?void 0:e.post($o(),{refresh_token:this.refreshToken}))}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new h("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(Zo(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw H(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null)}storeToken(e){typeof e=="string"?O.put(Re,e):O.del(Re)}storeRefreshToken(e){typeof e=="string"?O.put(ut,e):O.del(ut)}};var no,Qe=class{constructor(e){let o=e.apiURL||Ro,r=e.timeout||No;this.appId=e.appId,this.connectors=new Je,no||(no=new bt),this.session=no,this.api=new ht(e.appId,this,{baseURL:o,timeout:r}),this.session.api=this.api,this.session.client=this}authenticate(){if(!this.authFlow)throw new h("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new h("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.authFlow=void 0}startAuthFlow(e){e.api=this.api,this.authFlow=e}async unlinkEmail(e){try{let o=await this.api.post(ar(),{address:e});return ne(o.data)}catch(o){throw H(o)}}async unlinkPhone(e){try{let o=await this.api.post(lr(),{phoneNumber:e});return ne(o.data)}catch(o){throw H(o)}}async unlinkWallet(e){try{let o=await this.api.post(sr(),{address:e});return this.connectors.removeWallet(e),ne(o.data)}catch(o){throw H(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(cr(),{provider:e,subject:o});return ne(r.data)}catch(r){throw H(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){var o;return this.session.hasActiveToken()?((o=re.parse(this.session.token))==null?void 0:o.audience)!==this.appId?(await this.logout(),null):this.session.token:!(e!=null&&e.disableAutoRefresh)&&this.session.hasRefreshCredentials()?(await this.session.refresh(),this.session.token):null}async getAppSettings(){try{let e=await this.api.get(`/api/v1/apps/${this.appId}`);return{id:e.data.id,name:e.data.name,verificationKey:e.data.verification_key,logoUrl:e.data.logo_url||void 0,theme:e.data.theme,accentColor:e.data.accent_color||void 0,showWalletLoginFirst:e.data.show_wallet_login_first,allowlistConfig:{errorTitle:e.data.allowlist_config.error_title,errorDetail:e.data.allowlist_config.error_detail,errorCtaText:e.data.allowlist_config.cta_text,errorCtaLink:e.data.allowlist_config.cta_link},walletAuth:e.data.wallet_auth,emailAuth:e.data.email_auth,smsAuth:e.data.sms_auth,googleOAuth:e.data.google_oauth,twitterOAuth:e.data.twitter_oauth,discordOAuth:e.data.discord_oauth,githubOAuth:e.data.github_oauth,termsAndConditionsUrl:e.data.terms_and_conditions_url,privacyPolicyUrl:e.data.privacy_policy_url,createdAt:new Date(e.data.created_at*1e3),updatedAt:new Date(e.data.updated_at*1e3)}}catch(e){throw H(e)}}async setActiveWallet(e,o){if(!o.linkedAccounts.map(n=>n.type==="wallet"?n.address:null).includes(e))throw new h("Cannot set an unlinked address as active.");if(!await this.connectors.setActiveWallet(e))throw new h("Error setting the active wallet.");return Ye(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as ga}from"@ethersproject/providers";import{createContext as on,useContext as rn}from"react";var f=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var so=on({ready:!1,authenticated:!1,user:null,walletConnectors:null,login:f,linkEmail:f,linkPhone:f,linkWallet:f,linkGoogle:f,linkTwitter:f,linkDiscord:f,linkGithub:f,logout:f,getAccessToken:f,getEthereumProvider:f,getEthersProvider:f,getWeb3jsProvider:f,unlinkEmail:f,unlinkPhone:f,unlinkWallet:f,unlinkGoogle:f,unlinkTwitter:f,unlinkDiscord:f,unlinkGithub:f,setActiveWallet:f,forkSession:f}),M=()=>rn(so);var Xe=class{constructor(e,o){this.meta={walletType:o},this.connectors=e,this.walletConnector=this.connectors.createWalletConnector(o,null)}async authenticate(){if(!this.api)throw new h("Auth flow has no API instance");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(qo(),{message:e,signature:o});return this.connectors.addWalletConnector(this.walletConnector),await this.connectors.setActiveWallet(this.walletConnector.address)||console.warn("Failed to set active wallet"),{user:r.data.user,token:r.data.token,refresh_token:r.data.refresh_token,is_new_user:r.data.is_new_user}}catch(e){throw S(e)}}async link(){if(!this.api)throw new h("Auth flow has no API instance");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Jo(),{message:e,signature:o});return this.connectors.addWalletConnector(this.walletConnector),await this.connectors.setActiveWallet(this.walletConnector.address)||console.warn("Failed to set active wallet"),r.data}catch(e){throw S(e)}}async promptConnectAndSign(e){let o=await this.walletConnector.connect({showPrompt:!0}),r=o.address,i=o.chainId,n=await e.post(Ko(),{address:r}),a=this.walletConnector.prepareMessage(i,r,n.data.nonce),d=await this.walletConnector.sign(a);return{message:a,signature:d}}};var et=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new h("Email and email code must be set prior to calling authenticate.");try{let e=Qo(),o=await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw S(e)}}async link(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new h("Email and email code must be set prior to calling authenticate.");try{let e=Xo();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw S(e)}}async sendCodeEmail(e){if(!this.api)throw new h("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new h("Email must be set when initialzing authentication.");try{let o=Yo();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw S(o)}}};var tt=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new h("phone number and sms code must be set prior to calling authenticate.");try{let e=tr(),o=await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw S(e)}}async link(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new h("phone number and sms code must be set prior to calling authenticate.");try{let e=or();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw S(e)}}async sendSmsCode(e){if(!this.api)throw new h("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new h("phone nNumber must be set when initialzing authentication.");try{let o=er();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw S(o)}}};var Ue=class{constructor(e,o,r){this.meta={provider:e},this.meta.authorizationCode=o,this.meta.stateCode=r}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new h("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new h("User denied confirmation during OAuth flow");try{let e=ir(),o=await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw S(e)}}async link(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new h("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new h("User denied confirmation during OAuth flow");try{let e=nr();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw S(e)}}async getAuthorizationUrl(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.provider)throw new h("Provider must be set when initialzing OAuth authentication.");try{let e=rr();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw S(e)}}};import"wicg-inert";import da from"react-dom";import Wo from"styled-components";import{createContext as sn,useContext as an,useEffect as ao,useState as ur}from"react";import{jsx as nn}from"react/jsx-runtime";function dr(t){return nn("link",{rel:"prefetch",href:t.src})}import{jsx as ln,jsxs as cn}from"react/jsx-runtime";var pr=sn({ready:!1,app:null,options:{email:!0,sms:!1,wallet:!0,google:!1,twitter:!1,discord:!1,github:!1},currentScreen:"LANDING",lastScreen:"LANDING",navigate:f,navigateBack:f}),hr=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=ur(t.screen||"LANDING"),[a,d]=ur(t.screen||"LANDING");ao(()=>{o||n("LANDING")},[o]),ao(()=>{r||(d("LANDING"),n("LANDING"))},[r]),ao(()=>{t.screen&&t.screen!==i&&(n(t.screen),d(t.screen))},[t.screen]);let u={ready:!!(e!=null&&e.id),app:e,options:t.options,currentScreen:i,lastScreen:a,navigate:p=>{d(i),n(p)},navigateBack:()=>{n(a)}};return cn(pr.Provider,{value:u,children:[e&&e.logoUrl&&ln(dr,{src:e.logoUrl}),t.children]})},g=()=>an(pr);import{useEffect as es,useState as ts}from"react";import He from"styled-components";import pn from"styled-components";import{jsx as mr}from"react/jsx-runtime";var fr=({style:t,...e})=>mr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:mr("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});import{jsx as gr}from"react/jsx-runtime";var wr=({style:t,...e})=>gr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:gr("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as dn,useContext as un}from"react";var lo=dn({isLinking:!1,linkingHint:null,activeStatus:null,getAuthMeta:f,getAuthFlow:f,closePrivyModal:f,initLoginWithWallet:f,loginWithWallet:f,loginWithCode:f,initLoginWithEmail:f,initLoginWithSms:f,resendEmailCode:f,resendSmsCode:f,initLoginWithOAuth:f,loginWithOAuth:f}),E=()=>un(lo);import{jsx as se,jsxs as wn}from"react/jsx-runtime";var hn=()=>se("div",{}),mn=({backFn:t})=>se("div",{children:se(wr,{onClick:t})}),fn=t=>se("div",{children:se("div",{children:se(fr,{onClick:t.onClose})})});var L=({backFn:t,onClose:e})=>{let{closePrivyModal:o}=E();return wn(gn,{children:[t?se(mn,{backFn:t}):se(hn,{}),se(fn,{onClose:e||o})]})},gn=pn.div`
|
|
12
|
+
- https://privy.io`;this.provider=o,this.walletType=e,this.address=r,this.chain=null,this.connected=!1}async fetchAddress(){if(!this.address){let e=await this.provider.request({method:"eth_accounts"});Array.isArray(e)&&e.length>0&&(this.address=ji(e[0]))}return this.address}async fetchChainId(){if(!this.chain){let e=await this.provider.request({method:"eth_chainId"}),o=Number(e);this.chain=String(o)}return this.chain}async getConnectedWallet(){let e=this.walletType;if(!e||!await this.isConnected())return null;let o=await this.fetchAddress(),r=await this.fetchChainId();return{address:o,chainId:r,chainType:"ethereum",walletType:e}}async setActive(){return!0}async sign(e){return new $i(new Le(this.provider)).getSigner().signMessage(e)}prepareMessage(e,o,r){let i=window.location.host,n=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.",d=new Date().toISOString();return this.createSiweMessage(e,o,i,n,d,r,a)}};import{isPossiblePhoneNumber as Zi}from"libphonenumber-js/min";var Fo=t=>!!String(t).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,}))$/),Do=t=>Zi(String(t),"US"),gt=t=>{var e=/^#?([a-f\d])([a-f\d])([a-f\d])$/i;t=t.replace(e,function(r,i,n,a){return i+i+n+n+a+a});var o=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(t);return{r:parseInt((o==null?void 0:o[1])||"00",16),g:parseInt((o==null?void 0:o[2])||"00",16),b:parseInt((o==null?void 0:o[3])||"00",16)}},Go=(t,e)=>{var o=t.slice(0);let r=[];for(;o.length;)r.push(o.splice(0,e));return r},Je=t=>{if(!t)return"";let e=t.slice(0,5),o=t.slice(t.length-4,t.length);return`${e}...${o}`},Vo=t=>new Promise(e=>setTimeout(e,t));import{isMobile as qi}from"react-device-detect";var wt=class extends se{constructor(e,o){var r;super("metamask",e,o),this.provider.setProvider(window.ethereum),(r=window.ethereum.providers)==null||r.forEach(async i=>{i.isMetaMask&&this.provider.setProvider(i)}),this.subscribeListeners()}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}async isConnected(){let e=await this.connectedMetamaskAddress();return this.address===e}async connectedMetamaskAddress(){let o=await new Ki(this.provider).listAccounts();return o.length===0?null:Ho(o[0])}disconnect(){console.warn("Metamask does not support programmetic disconnect.")}async promptConnection(){try{let e="";if(!qi&&(await this.provider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]}),this.address&&await this.isConnected()))throw new I("Selected the wrong wallet in MetaMask");let o=await this.provider.request({method:"eth_requestAccounts"});if(o.length>0&&(e=Ho(o[0])),!e||e==="")throw new I("Unable to retrieve address");this.connected=!0,this.address=e}catch(e){throw he(e)}}async setActive(){if(await this.connectedMetamaskAddress()===this.address)return this.connected=!0,!0;for(;!this.connected;)await Vo(200);return!0}subscribeListeners(){this.provider.on("accountsChanged",e=>{var o;if(e.length>0){let r=e[0];this.connected=((o=this.address)==null?void 0:o.toLowerCase())===(r==null?void 0:r.toLowerCase())}}),this.provider.on("disconnect",()=>{this.connected=!1})}};import{getAddress as Ji}from"@ethersproject/address";import Yi from"@coinbase/wallet-sdk";var Qi=t=>{let e=`https://mainnet.infura.io/v3/${qe}`,o=1;return t.makeWeb3Provider(e,o)},yt,vt=class extends se{constructor(e,o){super("coinbase_wallet",e,o),yt||(yt=new Yi({appName:"Privy",darkMode:!1,headlessMode:!1}))}async connect(e){return this.provider.setProvider(Qi(yt)),(!await this.isConnected()||e.showPrompt)&&await this.promptConnection(),this.getConnectedWallet()}disconnect(){yt.disconnect()}async isConnected(){return await this.fetchAddress()!==null}async promptConnection(){try{let e="",o=await this.provider.request({method:"eth_requestAccounts"});if(o.length>0&&(e=Ji(o[0])),!e||e==="")throw new I("Unable to retrieve address");this.connected=!0}catch(e){throw he(e)}}};import Bo from"@walletconnect/web3-provider";var oo=class extends se{constructor(o,r,i){super("wallet_connect",r,i);this._globalConnector=o,this._provider=this._globalConnector.getProviderForAddress(i)}async connect(o){return this.provider.setProvider(this._provider),(!await this.isConnected()||o.showPrompt)&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return this.provider.walletProvider.connected}async promptConnection(){try{let o="";this.provider.setProvider(this._provider);let r=await Promise.race([this._provider.enable(),to()]);if(r.length>0&&(o=r[0]),this._globalConnector.indexProvider(this._provider),!o||o==="")throw new I("Unable to retrieve address");this.connected=!0}catch(o){throw he(o)}}disconnect(){}},Ct=class{constructor(){this._storageIdToProvider={},this._addressToStorageId={},O.getKeys().forEach(e=>{if(e.startsWith("walletconnect")){let o=new Bo({infuraId:qe,storageId:e});o.enable(),this._storageIdToProvider[e]=o;for(let r of o.accounts)this._addressToStorageId[r]=e}})}build(e,o){return new oo(this,e,o)}async disconnect(){Object.values(this._storageIdToProvider).forEach(async e=>{await e.disconnect()})}getProviderForAddress(e){let o=Oo,r=()=>`walletconnect:${Math.random().toString(36).slice(2)}`;e===null?o=r():o=this._addressToStorageId[e]||r();let i=new Bo({infuraId:qe,storageId:o});return this._storageIdToProvider[o]=i,i}indexProvider(e){this._storageIdToProvider[e.storageId]=e;for(let o of e.accounts)this._addressToStorageId[o]=e.storageId}};import{getAddress as Xi}from"@ethersproject/address";var ro=()=>{if(!window.ethereum)return!1;if(window.ethereum.isMetaMask)return!0;if(window.ethereum.providers){for(let t of window.ethereum.providers)if(t.isMetaMask)return!0}return!1},bt=()=>{if(!window.ethereum)return!1;if(window.ethereum.isCoinbaseWallet)return!0;if(window.ethereum.providers){for(let t of window.ethereum.providers)if(t.isCoinbaseWallet)return!0}return!1},io=t=>{let e=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return e?!!(t==null?void 0:t.linkedAccounts.filter(r=>r.type=="wallet"&&r.address===Xi(e)).length):!1},zo=()=>{var e;let t=O.get(ht);return t?(e=t.find(o=>o.active))==null?void 0:e.address:null},Ye=class{constructor(){this.getEthereumProvider=()=>{var e;return((e=this.activeWalletConnector)==null?void 0:e.provider)||new J};this.walletConnectors=[],this.walletConnectGlobalWalletConnector=new Ct,this.initialized=!1}initialize(){this.initialized||(this.load(),this.activeWalletConnector&&this.activeWalletConnector.connect({showPrompt:!1}),this.initialized=!0)}initializeLinkedWallets(e){e.linkedAccounts.forEach(()=>{})}load(){(O.get(ht)||[]).forEach(o=>{let r=this.createWalletConnector(o.walletType,o.address);this.addWalletConnector(r),o.active&&(this.activeWalletConnector=r)})}save(){let e=this.walletConnectors.map(o=>{var r;return{address:o.address,walletType:o.walletType,active:o.address===((r=this.activeWalletConnector)==null?void 0:r.address)}});O.put(ht,e)}addWalletConnector(e){this.walletConnectors.find(r=>r.address===e.address&&r.walletType===e.walletType)||this.walletConnectors.push(e)}getConnectorByAddress(e){return this.walletConnectors.find(o=>{var r;return((r=o.address)==null?void 0:r.toLowerCase())===e.toLowerCase()})}async removeWallet(e){var r;if(this.walletConnectors=this.walletConnectors.filter(i=>i.address!==e),e===((r=this.activeWalletConnector)==null?void 0:r.address))if(this.walletConnectors.length>0){let i=this.walletConnectors[this.walletConnectors.length-1];await this.setActiveWallet(i.address)}else this.activeWalletConnector=void 0;this.save()}async activeWalletSign(e){if(!this.activeWalletConnector)throw new I("Cannot sign, no wallet is active. Is a wallet connected?");if(!await this.activeWalletConnector.connect({showPrompt:!1}))throw new I("Cannot sign - unable to connect to wallet.");return this.activeWalletConnector.sign(e)}async setActiveWallet(e){let o=this.walletConnectors.find(r=>r.address===e);return o?(await o.setActive(),this.activeWalletConnector=o,this.save(),!0):!1}createWalletConnector(e,o){switch(e){case"metamask":return new wt(new J,o);case"coinbase_wallet":return new vt(new J,o);case"wallet_connect":return this.walletConnectGlobalWalletConnector.build(new J,o)}}};function me(t){return new Date(t*1e3)}function en(t){let e=[];for(let o of t){let r=o.type;switch(o.type){case"wallet":e.push({address:o.address,type:o.type,verifiedAt:me(o.verified_at),chainType:o.chain_type});break;case"email":e.push({address:o.address,type:o.type,verifiedAt:me(o.verified_at)});break;case"phone":e.push({number:o.phoneNumber,type:o.type,verifiedAt:me(o.verified_at)});break;case"google_oauth":e.push({subject:o.subject,email:o.email,name:o.name,type:o.type,verifiedAt:me(o.verified_at)});break;case"twitter_oauth":e.push({subject:o.subject,username:o.username,name:o.name,type:o.type,verifiedAt:me(o.verified_at)});break;case"discord_oauth":e.push({subject:o.subject,username:o.username,email:o.email,type:o.type,verifiedAt:me(o.verified_at)});break;case"github_oauth":e.push({subject:o.subject,username:o.username,name:o.name,email:o.email,type:o.type,verifiedAt:me(o.verified_at)});break;default:console.warn(`Unrecognized account type: ${r}. Please consider upgrading the Privy SDK.`)}}return e}function Ae(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function Qe(t){let e=zo();if(!e)return t.wallet&&console.warn("[Privy] User has linked wallets but no active wallet"),t;let o=t.linkedAccounts.find(i=>i.type==="wallet"&&i.address===e),r=Object.assign({},t);return r.wallet=o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletType:o.walletType},r}function ae(t){if(!t)return null;let e=en(t.linked_accounts),o=Ae(e,"wallet"),r=Ae(e,"email"),i=Ae(e,"phone"),n=Ae(e,"google_oauth"),a=Ae(e,"twitter_oauth"),d=Ae(e,"discord_oauth"),u=Ae(e,"github_oauth"),p={id:t.id,createdAt:me(t.created_at),linkedAccounts:e,email:r&&{address:r==null?void 0:r.address},phone:i&&{number:i==null?void 0:i.number},wallet:o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletType:o.walletType},google:n&&{subject:n.subject,email:n.email,name:n.name},twitter:a&&{subject:a.subject,username:a.username,name:a.name},discord:d&&{subject:d.subject,username:d.username,email:d.email},github:u&&{subject:u.subject,username:u.username,name:u.name,email:u.email}};return Qe(p)}var jo=()=>"/api/v1/sessions",$o=()=>"/api/v1/sessions/logout",Zo=()=>"/api/v1/sessions/fork",Ko=()=>"/api/v1/siwe/init",qo=()=>"/api/v1/siwe/authenticate",Jo=()=>"/api/v1/siwe/link",Yo=()=>"/api/v1/passwordless/init",Qo=()=>"/api/v1/passwordless/authenticate",Xo=()=>"/api/v1/passwordless/link",er=()=>"/api/v1/passwordless_sms/init",tr=()=>"/api/v1/passwordless_sms/authenticate",or=()=>"/api/v1/passwordless_sms/link",rr=()=>"/api/v1/oauth/init",ir=()=>"/api/v1/oauth/authenticate",nr=()=>"/api/v1/oauth/link",sr=()=>"/api/v1/siwe/unlink",ar=()=>"/api/v1/passwordless/unlink",lr=()=>"/api/v1/passwordless_sms/unlink",cr=()=>"/api/v1/oauth/unlink";var tn=30,xt=class{constructor(){this.authenticateOnce=new pe(async e=>this._authenticate(e)),this.linkOnce=new pe(async e=>this._link(e)),this.refreshOnce=new pe(this._refresh.bind(this)),this.destroyOnce=new pe(this._destroy.bind(this)),this.forkSessionOnce=new pe(this._forkSession.bind(this))}get token(){try{let e=O.get(Re);return typeof e=="string"?new ne(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=O.get(pt);return typeof e=="string"?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}hasRefreshCredentials(){return typeof this.token=="string"&&typeof this.refreshToken=="string"}hasActiveToken(){let e=ne.parse(this.token);return e!==null&&!e.isExpired(tn)}authenticate(e){return this.authenticateOnce.execute(e)}link(e){return this.linkOnce.execute(e)}refresh(){return this.refreshOnce.execute()}forkSession(){return this.forkSessionOnce.execute()}destroy(){return this.destroyOnce.execute()}async _authenticate(e){try{let{token:o,refresh_token:r,user:i,is_new_user:n}=await e.authenticate();return this.storeToken(o),this.storeRefreshToken(r),{user:ae(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),H(o)}}async _link(e){try{let o=await e.link();return ae(o)}catch(o){throw console.warn("Error linking account"),H(o)}}async _refresh(){if(!this.api)throw new h("Session has no API instance");if(!this.client)throw new h("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let e=this.token,o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(jo(),{refresh_token:o},{headers:{authorization:`Bearer ${e}`}});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),ae(r.data.user)}catch(r){if(r instanceof Ie&&r.status===400&&r.message==="Invalid auth token")return this.destroyLocalState(),null;throw H(r)}}async _destroy(){var e;try{await((e=this.api)==null?void 0:e.post($o(),{refresh_token:this.refreshToken}))}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new h("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(Zo(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw H(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null)}storeToken(e){typeof e=="string"?O.put(Re,e):O.del(Re)}storeRefreshToken(e){typeof e=="string"?O.put(pt,e):O.del(pt)}};var no,Xe=class{constructor(e){let o=e.apiURL||Ro,r=e.timeout||No;this.appId=e.appId,this.connectors=new Ye,no||(no=new xt),this.session=no,this.api=new mt(e.appId,this,{baseURL:o,timeout:r}),this.session.api=this.api,this.session.client=this}authenticate(){if(!this.authFlow)throw new h("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new h("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.authFlow=void 0}startAuthFlow(e){e.api=this.api,this.authFlow=e}async unlinkEmail(e){try{let o=await this.api.post(ar(),{address:e});return ae(o.data)}catch(o){throw H(o)}}async unlinkPhone(e){try{let o=await this.api.post(lr(),{phoneNumber:e});return ae(o.data)}catch(o){throw H(o)}}async unlinkWallet(e){try{let o=await this.api.post(sr(),{address:e});return this.connectors.removeWallet(e),ae(o.data)}catch(o){throw H(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(cr(),{provider:e,subject:o});return ae(r.data)}catch(r){throw H(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){var o;return this.session.hasActiveToken()?((o=ne.parse(this.session.token))==null?void 0:o.audience)!==this.appId?(await this.logout(),null):this.session.token:!(e!=null&&e.disableAutoRefresh)&&this.session.hasRefreshCredentials()?(await this.session.refresh(),this.session.token):null}async getAppSettings(){try{let e=await this.api.get(`/api/v1/apps/${this.appId}`);return{id:e.data.id,name:e.data.name,verificationKey:e.data.verification_key,logoUrl:e.data.logo_url||void 0,theme:e.data.theme,accentColor:e.data.accent_color||void 0,showWalletLoginFirst:e.data.show_wallet_login_first,allowlistConfig:{errorTitle:e.data.allowlist_config.error_title,errorDetail:e.data.allowlist_config.error_detail,errorCtaText:e.data.allowlist_config.cta_text,errorCtaLink:e.data.allowlist_config.cta_link},walletAuth:e.data.wallet_auth,emailAuth:e.data.email_auth,smsAuth:e.data.sms_auth,googleOAuth:e.data.google_oauth,twitterOAuth:e.data.twitter_oauth,discordOAuth:e.data.discord_oauth,githubOAuth:e.data.github_oauth,termsAndConditionsUrl:e.data.terms_and_conditions_url,privacyPolicyUrl:e.data.privacy_policy_url,createdAt:new Date(e.data.created_at*1e3),updatedAt:new Date(e.data.updated_at*1e3)}}catch(e){throw H(e)}}async setActiveWallet(e,o){if(!o.linkedAccounts.map(n=>n.type==="wallet"?n.address:null).includes(e))throw new h("Cannot set an unlinked address as active.");if(!await this.connectors.setActiveWallet(e))throw new h("Error setting the active wallet.");return Qe(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as ga}from"@ethersproject/providers";import{createContext as on,useContext as rn}from"react";var f=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var so=on({ready:!1,authenticated:!1,user:null,walletConnectors:null,login:f,linkEmail:f,linkPhone:f,linkWallet:f,linkGoogle:f,linkTwitter:f,linkDiscord:f,linkGithub:f,logout:f,getAccessToken:f,getEthereumProvider:f,getEthersProvider:f,getWeb3jsProvider:f,unlinkEmail:f,unlinkPhone:f,unlinkWallet:f,unlinkGoogle:f,unlinkTwitter:f,unlinkDiscord:f,unlinkGithub:f,setActiveWallet:f,forkSession:f}),M=()=>rn(so);var et=class{constructor(e,o){this.meta={walletType:o},this.connectors=e,this.walletConnector=this.connectors.createWalletConnector(o,null)}async authenticate(){if(!this.api)throw new h("Auth flow has no API instance");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(qo(),{message:e,signature:o});return this.connectors.addWalletConnector(this.walletConnector),await this.connectors.setActiveWallet(this.walletConnector.address)||console.warn("Failed to set active wallet"),{user:r.data.user,token:r.data.token,refresh_token:r.data.refresh_token,is_new_user:r.data.is_new_user}}catch(e){throw S(e)}}async link(){if(!this.api)throw new h("Auth flow has no API instance");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Jo(),{message:e,signature:o});return this.connectors.addWalletConnector(this.walletConnector),await this.connectors.setActiveWallet(this.walletConnector.address)||console.warn("Failed to set active wallet"),r.data}catch(e){throw S(e)}}async promptConnectAndSign(e){let o=await this.walletConnector.connect({showPrompt:!0}),r=o.address,i=o.chainId,n=await e.post(Ko(),{address:r}),a=this.walletConnector.prepareMessage(i,r,n.data.nonce),d=await this.walletConnector.sign(a);return{message:a,signature:d}}};var tt=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new h("Email and email code must be set prior to calling authenticate.");try{let e=Qo(),o=await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw S(e)}}async link(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new h("Email and email code must be set prior to calling authenticate.");try{let e=Xo();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw S(e)}}async sendCodeEmail(e){if(!this.api)throw new h("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new h("Email must be set when initialzing authentication.");try{let o=Yo();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw S(o)}}};var ot=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new h("phone number and sms code must be set prior to calling authenticate.");try{let e=tr(),o=await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw S(e)}}async link(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new h("phone number and sms code must be set prior to calling authenticate.");try{let e=or();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw S(e)}}async sendSmsCode(e){if(!this.api)throw new h("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new h("phone nNumber must be set when initialzing authentication.");try{let o=er();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw S(o)}}};var Ue=class{constructor(e,o,r){this.meta={provider:e},this.meta.authorizationCode=o,this.meta.stateCode=r}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new h("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new h("User denied confirmation during OAuth flow");try{let e=ir(),o=await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw S(e)}}async link(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new h("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new h("User denied confirmation during OAuth flow");try{let e=nr();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw S(e)}}async getAuthorizationUrl(){if(!this.api)throw new h("Auth flow has no API instance");if(!this.meta.provider)throw new h("Provider must be set when initialzing OAuth authentication.");try{let e=rr();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw S(e)}}};import"wicg-inert";import da from"react-dom";import Wo from"styled-components";import{createContext as sn,useContext as an,useEffect as ao,useState as ur}from"react";import{jsx as nn}from"react/jsx-runtime";function dr(t){return nn("link",{rel:"prefetch",href:t.src})}import{jsx as ln,jsxs as cn}from"react/jsx-runtime";var pr=sn({ready:!1,app:null,options:{email:!0,sms:!1,wallet:!0,google:!1,twitter:!1,discord:!1,github:!1},currentScreen:"LANDING",lastScreen:"LANDING",navigate:f,navigateBack:f}),hr=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=ur(t.screen||"LANDING"),[a,d]=ur(t.screen||"LANDING");ao(()=>{o||n("LANDING")},[o]),ao(()=>{r||(d("LANDING"),n("LANDING"))},[r]),ao(()=>{t.screen&&t.screen!==i&&(n(t.screen),d(t.screen))},[t.screen]);let u={ready:!!(e!=null&&e.id),app:e,options:t.options,currentScreen:i,lastScreen:a,navigate:p=>{d(i),n(p)},navigateBack:()=>{n(a)}};return cn(pr.Provider,{value:u,children:[e&&e.logoUrl&&ln(dr,{src:e.logoUrl}),t.children]})},g=()=>an(pr);import{useEffect as es,useState as ts}from"react";import Be from"styled-components";import pn from"styled-components";import{jsx as mr}from"react/jsx-runtime";var fr=({style:t,...e})=>mr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:mr("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});import{jsx as gr}from"react/jsx-runtime";var wr=({style:t,...e})=>gr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:gr("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as dn,useContext as un}from"react";var lo=dn({isLinking:!1,linkingHint:null,activeStatus:null,getAuthMeta:f,getAuthFlow:f,closePrivyModal:f,initLoginWithWallet:f,loginWithWallet:f,loginWithCode:f,initLoginWithEmail:f,initLoginWithSms:f,resendEmailCode:f,resendSmsCode:f,initLoginWithOAuth:f,loginWithOAuth:f}),E=()=>un(lo);import{jsx as le,jsxs as wn}from"react/jsx-runtime";var hn=()=>le("div",{}),mn=({backFn:t})=>le("div",{children:le(wr,{onClick:t})}),fn=t=>le("div",{children:le("div",{children:le(fr,{onClick:t.onClose})})});var L=({backFn:t,onClose:e})=>{let{closePrivyModal:o}=E();return wn(gn,{children:[t?le(mn,{backFn:t}):le(hn,{}),le(fn,{onClose:e||o})]})},gn=pn.div`
|
|
13
13
|
height: 30px;
|
|
14
14
|
display: flex;
|
|
15
15
|
align-items: center;
|
|
@@ -66,11 +66,11 @@ Resources:
|
|
|
66
66
|
@media (max-width: 440px) {
|
|
67
67
|
height: 30px;
|
|
68
68
|
}
|
|
69
|
-
`;import br from"styled-components";import{jsx as G,jsxs as yn}from"react/jsx-runtime";var
|
|
69
|
+
`;import br from"styled-components";import{jsx as G,jsxs as yn}from"react/jsx-runtime";var Q=({style:t,...e})=>yn("svg",{width:"28",height:"28",viewBox:"0 0 28 28",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...t},...e,children:[G("rect",{width:"28",height:"28",rx:"6",fill:"white"}),G("path",{d:"M23.0126 5L15.1958 10.7823L16.6533 7.37359L23.0126 5Z",fill:"#E17726",stroke:"#E17726",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M4.98753 5L12.7329 10.8299L11.3468 7.37954L4.98753 5ZM20.1987 18.4027L18.1166 21.5794L22.5723 22.8049L23.8454 18.4741L20.1987 18.4027ZM4.16064 18.4741L5.42775 22.8049L9.87153 21.5794L7.80133 18.4027L4.16064 18.4741Z",fill:"#E27625",stroke:"#E27625",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M9.6336 13.0369L8.39624 14.9049L12.7984 15.1071L12.6556 10.3659L9.6336 13.0429V13.0369ZM18.3665 13.0429L15.2969 10.3064L15.1958 15.1071L19.5979 14.9049L18.3665 13.0429ZM9.87155 21.5794L12.5426 20.2945L10.2463 18.5098L9.87155 21.5794ZM15.4635 20.2886L18.1166 21.5794L17.7597 18.5039L15.4635 20.2886Z",fill:"#E27625",stroke:"#E27625",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M18.1167 21.5794L15.4635 20.2944L15.6776 22.0196L15.6539 22.7513L18.1167 21.5794ZM9.87158 21.5794L12.3463 22.7513L12.3285 22.0196L12.5426 20.2944L9.87158 21.5794Z",fill:"#D5BFB2",stroke:"#D5BFB2",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M12.3878 17.3616L10.1868 16.7191L11.7454 16.0052L12.3938 17.3616H12.3878ZM15.6062 17.3616L16.2605 15.9993L17.8251 16.7131L15.6062 17.3675V17.3616Z",fill:"#233447",stroke:"#233447",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M9.87147 21.5794L10.2581 18.4027L7.80127 18.4741L9.87147 21.5794ZM17.7418 18.4027L18.1166 21.5794L20.1987 18.4741L17.7418 18.4027ZM19.6038 14.9048L15.2016 15.107L15.6061 17.3676L16.2605 15.9994L17.8251 16.7132L19.6038 14.9048ZM10.1868 16.7192L11.7454 16.0053L12.3938 17.3617L12.8042 15.1011L8.4021 14.9048L10.1868 16.7192Z",fill:"#CC6228",stroke:"#CC6228",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M8.4021 14.9048L10.2462 18.5038L10.1868 16.7192L8.4021 14.9048ZM17.8251 16.7192L17.7537 18.5038L19.5978 14.9048L17.8251 16.7192ZM12.8042 15.107L12.3878 17.3676L12.9113 20.0327L13.0303 16.5169L12.8042 15.107ZM15.1957 15.107L14.9815 16.511L15.0886 20.0327L15.6061 17.3617L15.1957 15.1011V15.107Z",fill:"#E27525",stroke:"#E27525",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M15.6062 17.3617L15.0887 20.0327L15.4635 20.2945L17.7538 18.5098L17.8252 16.7192L15.6062 17.3617ZM10.1869 16.7192L10.2463 18.5039L12.5426 20.2885L12.9114 20.0327L12.3939 17.3617L10.1809 16.7192H10.1869Z",fill:"#F5841F",stroke:"#F5841F",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M15.6598 22.7513L15.6776 22.0196L15.4754 21.853H12.5248L12.3285 22.0196L12.3463 22.7513L9.87158 21.5793L10.7401 22.2932L12.495 23.5008H15.4992L17.26 22.2873L18.1167 21.5793L15.6539 22.7513H15.6598Z",fill:"#C0AC9D",stroke:"#C0AC9D",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M15.4634 20.2885L15.0886 20.0327H12.9114L12.5425 20.2945L12.3284 22.0196L12.5247 21.8531H15.4753L15.6776 22.0196L15.4634 20.2945V20.2885Z",fill:"#161616",stroke:"#161616",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M23.3456 11.1571L24 7.97442L23.0125 5L15.4575 10.5919L18.3664 13.0369L22.4711 14.2326L23.3754 13.1797L22.9827 12.8941L23.6074 12.323L23.1315 11.9542L23.7561 11.4783L23.3397 11.1571H23.3456ZM4 7.96847L4.66627 11.1571L4.23795 11.4723L4.87448 11.9482L4.39857 12.323L5.01725 12.8941L4.62463 13.1797L5.52885 14.2326L9.63355 13.0428L12.5425 10.586L4.98751 5L4 7.96847Z",fill:"#763E1A",stroke:"#763E1A",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),G("path",{d:"M22.4712 14.2325L18.3665 13.0428L19.6038 14.9048L17.7597 18.5038L20.1987 18.4741H23.8454L22.4712 14.2325ZM9.63358 13.0368L5.52888 14.2325L4.16064 18.4741H7.80728L10.2463 18.5038L8.40217 14.9048L9.63953 13.0368H9.63358ZM15.1957 15.107L15.4634 10.5859L16.6532 7.37354H11.3468L12.5366 10.5859L12.8043 15.107L12.9054 16.5229V20.0327H15.0887L15.1006 16.5229L15.1957 15.107Z",fill:"#F5841F",stroke:"#F5841F",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"})]});import{jsx as yr,jsxs as vn}from"react/jsx-runtime";var X=({style:t,...e})=>vn("svg",{width:"1024",height:"1024",viewBox:"0 0 1024 1024",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...t},...e,children:[yr("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),yr("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{jsx as Fe,jsxs as Cn}from"react/jsx-runtime";var De=({style:t,...e})=>Cn("svg",{width:"28",height:"28",viewBox:"0 0 28 28",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...t},...e,children:[Fe("rect",{width:"28",height:"28",rx:"6",fill:"#141414"}),Fe("g",{clipPath:"url(#clip0_1765_9946)",children:Fe("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"})}),Fe("defs",{children:Fe("clipPath",{id:"clip0_1765_9946",children:Fe("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]});import{isMobile as Cr}from"react-device-detect";import{isIOS as bn,isMobile as xn}from"react-device-detect";var co=t=>{let e=new URL(window.location.href);if(!window.ethereum&&xn){let o;switch(t){case"metamask":bn?o="dapp://"+e.hostname+e.pathname:o="https://metamask.app.link/dapp/"+e.hostname+e.pathname;break;case"coinbase_wallet":o="https://go.cb-w.com/dapp?cb_url="+encodeURIComponent(e.href.replace(/\/$/g,""));break;case"wallet_connect":break;default:break}o&&window.location.assign(o)}};import Ln from"styled-components";var vr=Ln.span`
|
|
70
70
|
@media (max-width: 440px) {
|
|
71
71
|
display: none;
|
|
72
72
|
}
|
|
73
|
-
`;import{jsx as
|
|
73
|
+
`;import{jsx as ce,jsxs as rt}from"react/jsx-runtime";var Lt=()=>{let{navigate:t}=g(),{initLoginWithWallet:e,closePrivyModal:o}=E();return rt(An,{children:[rt(uo,{onClick:()=>{ro()?(e("metamask"),t("AWAITING_CONNECTION")):Cr?(co("metamask"),o()):t("INSTALL_METAMASK_SCREEN")},children:[ce(Q,{}),ce("span",{children:"Metamask"}),ce("span",{children:ro()?"Connect":"Install"})]}),rt(uo,{onClick:()=>{bt()?(e("coinbase_wallet"),t("AWAITING_CONNECTION")):Cr?(co("coinbase_wallet"),o()):(e("coinbase_wallet"),t("AWAITING_CONNECTION"))},children:[ce(X,{}),rt("span",{children:["Coinbase",ce(vr,{children:" Wallet"})]}),ce("span",{children:"Connect"})]}),rt(uo,{onClick:()=>{e("wallet_connect"),t("AWAITING_CONNECTION")},children:[ce(De,{}),ce("span",{children:"WalletConnect"}),ce("span",{children:"Connect"})]})]})},An=br.div`
|
|
74
74
|
display: flex;
|
|
75
75
|
flex-direction: column;
|
|
76
76
|
align-items: flex-start;
|
|
@@ -158,7 +158,7 @@ Resources:
|
|
|
158
158
|
@media (max-width: 440px) {
|
|
159
159
|
margin-top: 4px;
|
|
160
160
|
}
|
|
161
|
-
`;import Er from"styled-components";import{jsx as Lr}from"react/jsx-runtime";var Ar=({style:t,...e})=>Lr("svg",{width:"16",height:"17",viewBox:"0 0 16 17",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"1.25rem",width:"1.25rem",...t},...e,children:Lr("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M7.99555 0.929932C-1.12055 1.31799 -0.499722 9.15734 2.17445 8.76915C0.0807959 10.5544 -0.960455 16.6416 6.01654 16.0265C10.6356 15.9489 15.5635 12.2232 15.5635 8.1095C15.5635 2.63748 10.7516 0.929932 7.99555 0.929932ZM9.47052 7.53055C9.47052 8.49933 8.81856 9.28468 8.01433 9.28468C7.2101 9.28468 6.55814 8.49933 6.55814 7.53055C6.55814 6.56176 7.2101 5.77641 8.01433 5.77641C8.81856 5.77641 9.47052 6.56176 9.47052 7.53055ZM12.3171 9.28468C13.1213 9.28468 13.7733 8.49933 13.7733 7.53055C13.7733 6.56176 13.1213 5.77641 12.3171 5.77641C11.5129 5.77641 10.8609 6.56176 10.8609 7.53055C10.8609 8.49933 11.5129 9.28468 12.3171 9.28468Z",fill:"var(--primary-color)"})});import{Fragment as Sn,jsx as
|
|
161
|
+
`;import Er from"styled-components";import{jsx as Lr}from"react/jsx-runtime";var Ar=({style:t,...e})=>Lr("svg",{width:"16",height:"17",viewBox:"0 0 16 17",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"1.25rem",width:"1.25rem",...t},...e,children:Lr("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M7.99555 0.929932C-1.12055 1.31799 -0.499722 9.15734 2.17445 8.76915C0.0807959 10.5544 -0.960455 16.6416 6.01654 16.0265C10.6356 15.9489 15.5635 12.2232 15.5635 8.1095C15.5635 2.63748 10.7516 0.929932 7.99555 0.929932ZM9.47052 7.53055C9.47052 8.49933 8.81856 9.28468 8.01433 9.28468C7.2101 9.28468 6.55814 8.49933 6.55814 7.53055C6.55814 6.56176 7.2101 5.77641 8.01433 5.77641C8.81856 5.77641 9.47052 6.56176 9.47052 7.53055ZM12.3171 9.28468C13.1213 9.28468 13.7733 8.49933 13.7733 7.53055C13.7733 6.56176 13.1213 5.77641 12.3171 5.77641C11.5129 5.77641 10.8609 6.56176 10.8609 7.53055C10.8609 8.49933 11.5129 9.28468 12.3171 9.28468Z",fill:"var(--primary-color)"})});import{Fragment as Sn,jsx as Ge,jsxs as _r}from"react/jsx-runtime";var Pn=Er.div`
|
|
162
162
|
margin-top: 16px;
|
|
163
163
|
font-size: 12px;
|
|
164
164
|
text-align: left;
|
|
@@ -167,7 +167,7 @@ Resources:
|
|
|
167
167
|
&& > a {
|
|
168
168
|
color: var(--primary-color);
|
|
169
169
|
}
|
|
170
|
-
`;function kr(t){let{privacyPolicyUrl:e,termsAndConditionsUrl:o}=t.app,r=!!e,i=!!o,n=r&&i;return!r&&!i?null:_r(Pn,{children:["By logging in I agree to the"," ",i&&
|
|
170
|
+
`;function kr(t){let{privacyPolicyUrl:e,termsAndConditionsUrl:o}=t.app,r=!!e,i=!!o,n=r&&i;return!r&&!i?null:_r(Pn,{children:["By logging in I agree to the"," ",i&&Ge("a",{href:o,target:"_blank",children:n?"Terms":"Terms of Service"}),n&&" & ",r&&Ge("a",{href:e,target:"_blank",children:"Privacy Policy"})]})}var ee=({protectedByPrivy:t})=>Ge($,{hideOnMobile:t,children:t?_r(Sn,{children:[Ge(Ar,{}),Ge("span",{children:Ge("a",{href:"https://www.privy.io/",target:"_blank",children:"Protected by Privy"})})]}):null}),$=Er.div`
|
|
171
171
|
height: 20px;
|
|
172
172
|
font-size: 12px;
|
|
173
173
|
display: flex;
|
|
@@ -204,13 +204,13 @@ Resources:
|
|
|
204
204
|
justify-content: center;
|
|
205
205
|
height: 100%;
|
|
206
206
|
width: 100%;
|
|
207
|
-
`;import
|
|
207
|
+
`;import nt from"styled-components";import{jsx as Tr}from"react/jsx-runtime";var Et=({style:t,logoFill:e,...o})=>Tr("svg",{width:"24",height:"20",viewBox:"0 0 24 20",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"26px",width:"26px",...t},...o,children:Tr("path",{d:"M7.54311 19.7551C16.5973 19.7551 21.5516 12.2467 21.5516 5.74656C21.5516 5.53533 21.5516 5.32409 21.542 5.11286C22.5021 4.42156 23.3375 3.54783 24 2.55888C23.1166 2.95254 22.1661 3.21178 21.1675 3.3366C22.1853 2.73171 22.963 1.76196 23.3375 0.609788C22.3869 1.17627 21.3308 1.57953 20.2074 1.80037C19.3049 0.840223 18.0279 0.244934 16.6165 0.244934C13.8993 0.244934 11.6909 2.45326 11.6909 5.17047C11.6909 5.55453 11.7389 5.92898 11.8157 6.29384C7.72554 6.09221 4.09619 4.12391 1.66703 1.14747C1.24457 1.87718 1.00453 2.72211 1.00453 3.62464C1.00453 5.3337 1.87826 6.84112 3.19366 7.72445C2.38714 7.69565 1.62862 7.47481 0.966125 7.10996C0.966125 7.12916 0.966125 7.14837 0.966125 7.17717C0.966125 9.55833 2.66558 11.5554 4.91232 12.0067C4.49945 12.1219 4.06739 12.1795 3.61612 12.1795C3.29927 12.1795 2.99203 12.1507 2.69438 12.0931C3.31848 14.0518 5.14275 15.4728 7.29347 15.5112C5.60362 16.8362 3.4817 17.6235 1.17736 17.6235C0.783698 17.6235 0.390039 17.6043 0.00598145 17.5563C2.17591 18.9389 4.76829 19.7551 7.54311 19.7551Z",fill:e==="primary"?"#1da1f2":"white"})});import{jsx as it,jsxs as Tn}from"react/jsx-runtime";var kt=({logoFill:t,style:e,...o})=>Tn("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"0px",y:"0px",viewBox:"0 0 71 55",style:{height:"24px",...e},...o,children:[it("g",{clipPath:"url(#clip0)",children:it("path",{d:"M60.1045 4.8978C55.5792 2.8214 50.7265 1.2916 45.6527 0.41542C45.5603 0.39851 45.468 0.440769 45.4204 0.525289C44.7963 1.6353 44.105 3.0834 43.6209 4.2216C38.1637 3.4046 32.7345 3.4046 27.3892 4.2216C26.905 3.0581 26.1886 1.6353 25.5617 0.525289C25.5141 0.443589 25.4218 0.40133 25.3294 0.41542C20.2584 1.2888 15.4057 2.8186 10.8776 4.8978C10.8384 4.9147 10.8048 4.9429 10.7825 4.9795C1.57795 18.7309 -0.943561 32.1443 0.293408 45.3914C0.299005 45.4562 0.335386 45.5182 0.385761 45.5576C6.45866 50.0174 12.3413 52.7249 18.1147 54.5195C18.2071 54.5477 18.305 54.5139 18.3638 54.4378C19.7295 52.5728 20.9469 50.6063 21.9907 48.5383C22.0523 48.4172 21.9935 48.2735 21.8676 48.2256C19.9366 47.4931 18.0979 46.6 16.3292 45.5858C16.1893 45.5041 16.1781 45.304 16.3068 45.2082C16.679 44.9293 17.0513 44.6391 17.4067 44.3461C17.471 44.2926 17.5606 44.2813 17.6362 44.3151C29.2558 49.6202 41.8354 49.6202 53.3179 44.3151C53.3935 44.2785 53.4831 44.2898 53.5502 44.3433C53.9057 44.6363 54.2779 44.9293 54.6529 45.2082C54.7816 45.304 54.7732 45.5041 54.6333 45.5858C52.8646 46.6197 51.0259 47.4931 49.0921 48.2228C48.9662 48.2707 48.9102 48.4172 48.9718 48.5383C50.038 50.6034 51.2554 52.5699 52.5959 54.435C52.6519 54.5139 52.7526 54.5477 52.845 54.5195C58.6464 52.7249 64.529 50.0174 70.6019 45.5576C70.6551 45.5182 70.6887 45.459 70.6943 45.3942C72.1747 30.0791 68.2147 16.7757 60.1968 4.9823C60.1772 4.9429 60.1437 4.9147 60.1045 4.8978ZM23.7259 37.3253C20.2276 37.3253 17.3451 34.1136 17.3451 30.1693C17.3451 26.225 20.1717 23.0133 23.7259 23.0133C27.308 23.0133 30.1626 26.2532 30.1066 30.1693C30.1066 34.1136 27.28 37.3253 23.7259 37.3253ZM47.3178 37.3253C43.8196 37.3253 40.9371 34.1136 40.9371 30.1693C40.9371 26.225 43.7636 23.0133 47.3178 23.0133C50.9 23.0133 53.7545 26.2532 53.6986 30.1693C53.6986 34.1136 50.9 37.3253 47.3178 37.3253Z",fill:t==="primary"?"#5865f2":"white"})}),it("defs",{children:it("clipPath",{id:"clip0",children:it("rect",{width:"71",height:"55",fill:"white"})})})]});import{jsx as Wr}from"react/jsx-runtime";var _t=({logoFill:t,style:e,...o})=>Wr("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"24",y:"24",viewBox:"0 0 98 96",style:{height:"24px",...e},...o,children:Wr("path",{d:"M48.854 0C21.839 0 0 22 0 49.217c0 21.756 13.993 40.172 33.405 46.69 2.427.49 3.316-1.059 3.316-2.362 0-1.141-.08-5.052-.08-9.127-13.59 2.934-16.42-5.867-16.42-5.867-2.184-5.704-5.42-7.17-5.42-7.17-4.448-3.015.324-3.015.324-3.015 4.934.326 7.523 5.052 7.523 5.052 4.367 7.496 11.404 5.378 14.235 4.074.404-3.178 1.699-5.378 3.074-6.6-10.839-1.141-22.243-5.378-22.243-24.283 0-5.378 1.94-9.778 5.014-13.2-.485-1.222-2.184-6.275.486-13.038 0 0 4.125-1.304 13.426 5.052a46.97 46.97 0 0 1 12.214-1.63c4.125 0 8.33.571 12.213 1.63 9.302-6.356 13.427-5.052 13.427-5.052 2.67 6.763.97 11.816.485 13.038 3.155 3.422 5.015 7.822 5.015 13.2 0 18.905-11.404 23.06-22.324 24.283 1.78 1.548 3.316 4.481 3.316 9.126 0 6.6-.08 11.897-.08 13.526 0 1.304.89 2.853 3.316 2.364 19.412-6.52 33.405-24.935 33.405-46.691C97.707 22 75.788 0 48.854 0z",fill:t==="primary"?"#2D333B":"white"})});import{jsx as Pt,jsxs as Wn}from"react/jsx-runtime";var St=({style:t,...e})=>Wn("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"26px",width:"26px",...t},...e,children:[Pt("path",{d:"M22.56 12.25C22.56 11.47 22.49 10.72 22.36 10H12V14.255H17.92C17.665 15.63 16.89 16.795 15.725 17.575V20.335H19.28C21.36 18.42 22.56 15.6 22.56 12.25Z",fill:"#4285F4"}),Pt("path",{d:"M12 23C14.97 23 17.46 22.015 19.28 20.335L15.725 17.575C14.74 18.235 13.48 18.625 12 18.625C9.13504 18.625 6.71004 16.69 5.84504 14.09H2.17004V16.94C3.98004 20.535 7.70004 23 12 23Z",fill:"#34A853"}),Pt("path",{d:"M5.845 14.09C5.625 13.43 5.5 12.725 5.5 12C5.5 11.275 5.625 10.57 5.845 9.91V7.06H2.17C1.4 8.59286 0.999321 10.2846 1 12C1 13.775 1.425 15.455 2.17 16.94L5.845 14.09Z",fill:"#FBBC05"}),Pt("path",{d:"M12 5.375C13.615 5.375 15.065 5.93 16.205 7.02L19.36 3.865C17.455 2.09 14.965 1 12 1C7.70004 1 3.98004 3.465 2.17004 7.06L5.84504 9.91C6.71004 7.31 9.13504 5.375 12 5.375Z",fill:"#EA4335"})]});import{jsx as ge,jsxs as Un}from"react/jsx-runtime";var Ir=({showGoogle:t,showTwitter:e,showDiscord:o,showGithub:r,stacked:i})=>{let{initLoginWithOAuth:n}=E();return Un(In,{stacked:i,children:[t&&ge(On,{onClick:()=>{n("google")},children:ge(St,{})}),e&&ge(Rn,{onClick:()=>{n("twitter")},children:ge(Et,{})}),o&&ge(Mn,{onClick:()=>{n("discord")},children:ge(kt,{})}),r&&ge(Nn,{onClick:()=>{n("github")},children:ge(_t,{})})]})},In=nt.div`
|
|
208
208
|
display: flex;
|
|
209
209
|
flex-direction: ${t=>t.stacked?"column":"row"};
|
|
210
210
|
justify-content: space-between;
|
|
211
211
|
width: 100%;
|
|
212
212
|
gap: 4px;
|
|
213
|
-
`,Rn=
|
|
213
|
+
`,Rn=nt.button`
|
|
214
214
|
&& {
|
|
215
215
|
border-radius: var(--border-radius-sm);
|
|
216
216
|
cursor: pointer;
|
|
@@ -222,7 +222,7 @@ Resources:
|
|
|
222
222
|
justify-content: center;
|
|
223
223
|
align-items: center;
|
|
224
224
|
}
|
|
225
|
-
`,Mn=
|
|
225
|
+
`,Mn=nt.button`
|
|
226
226
|
&& {
|
|
227
227
|
border-radius: var(--border-radius-sm);
|
|
228
228
|
cursor: pointer;
|
|
@@ -234,7 +234,7 @@ Resources:
|
|
|
234
234
|
justify-content: center;
|
|
235
235
|
align-items: center;
|
|
236
236
|
}
|
|
237
|
-
`,Nn=
|
|
237
|
+
`,Nn=nt.button`
|
|
238
238
|
&& {
|
|
239
239
|
border-radius: var(--border-radius-sm);
|
|
240
240
|
cursor: pointer;
|
|
@@ -246,7 +246,7 @@ Resources:
|
|
|
246
246
|
justify-content: center;
|
|
247
247
|
align-items: center;
|
|
248
248
|
}
|
|
249
|
-
`,On=
|
|
249
|
+
`,On=nt.button`
|
|
250
250
|
&& {
|
|
251
251
|
border-radius: var(--border-radius-sm);
|
|
252
252
|
cursor: pointer;
|
|
@@ -259,7 +259,7 @@ Resources:
|
|
|
259
259
|
align-items: center;
|
|
260
260
|
border: 1px solid var(--border-color-2);
|
|
261
261
|
}
|
|
262
|
-
`;import{useEffect as Gn,useState as po}from"react";import
|
|
262
|
+
`;import{useEffect as Gn,useState as po}from"react";import st from"styled-components";import{jsx as Rr}from"react/jsx-runtime";var Tt=({style:t,...e})=>Rr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Rr("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M21.75 6.75v10.5a2.25 2.25 0 01-2.25 2.25h-15a2.25 2.25 0 01-2.25-2.25V6.75m19.5 0A2.25 2.25 0 0019.5 4.5h-15a2.25 2.25 0 00-2.25 2.25m19.5 0v.243a2.25 2.25 0 01-1.07 1.916l-7.5 4.615a2.25 2.25 0 01-2.36 0L3.32 8.91a2.25 2.25 0 01-1.07-1.916V6.75"})});import Fn from"styled-components";import{jsx as Dn}from"react/jsx-runtime";var Ve=({success:t,fail:e})=>Dn(we,{className:t?"success":e?"fail":""}),we=Fn.span`
|
|
263
263
|
&& {
|
|
264
264
|
width: 82px;
|
|
265
265
|
height: 82px;
|
|
@@ -292,7 +292,7 @@ Resources:
|
|
|
292
292
|
border-color: var(--fail-light);
|
|
293
293
|
border-bottom-color: var(--fail-light);
|
|
294
294
|
}
|
|
295
|
-
`;import{Fragment as $n,jsx as Ee,jsxs as ho}from"react/jsx-runtime";var Wt=t=>{let[e,o]=po(""),[r,i]=po(!1),[n,a]=po(null),{authenticated:d}=M(),{initLoginWithEmail:u}=E(),{navigate:p,options:T}=g(),W=T.wallet;Gn(()=>{let l=document.querySelector("#email-input");l==null||l.focus()},[]);let A=Fo(e),v=()=>{i(!0),u(e).then(()=>{p("AWAITING_PASSWORDLESS_CODE")}).catch(l=>{let C=(l==null?void 0:l.status)===401&&(l==null?void 0:l.message)==="User is not allowed to login to this app.";(l==null?void 0:l.status)===422?a(l.message):C?p("ALLOWLIST_REJECTION_SCREEN"):a("Issue submitting email"),i(!1)})},x=n||(d||!W?"Get started quickly with email":"Get started without a wallet.");return ho($n,{children:[ho(Vn,{stacked:t.stacked,children:[ho(zn,{standalone:t.stacked,children:[Ee(Tt,{}),Ee("input",{id:"email-input",type:"email",placeholder:"your@email.com",onChange:l=>o(l.target.value),onKeyUp:l=>{l.key==="Enter"&&v()},value:e,autoComplete:"email"})]}),t.stacked?null:Ee(Hn,{disabled:r||!A,onClick:v,children:r?Ee(we,{color:"var(--disabled-fg)",style:{height:"1rem",width:"1rem",borderWidth:"2px"}}):"Submit"})]}),Ee(jn,{fail:!!n,children:x}),t.stacked?Ee(Bn,{disabled:r||!A,onClick:v,children:r?Ee(we,{color:"var(--disabled-fg)",style:{height:"1rem",width:"1rem",borderWidth:"2px"}}):"Submit"}):null]})},Vn=
|
|
295
|
+
`;import{Fragment as $n,jsx as Ee,jsxs as ho}from"react/jsx-runtime";var Wt=t=>{let[e,o]=po(""),[r,i]=po(!1),[n,a]=po(null),{authenticated:d}=M(),{initLoginWithEmail:u}=E(),{navigate:p,options:T}=g(),W=T.wallet;Gn(()=>{let l=document.querySelector("#email-input");l==null||l.focus()},[]);let A=Fo(e),v=()=>{i(!0),u(e).then(()=>{p("AWAITING_PASSWORDLESS_CODE")}).catch(l=>{let C=(l==null?void 0:l.status)===401&&(l==null?void 0:l.message)==="User is not allowed to login to this app.";(l==null?void 0:l.status)===422?a(l.message):C?p("ALLOWLIST_REJECTION_SCREEN"):a("Issue submitting email"),i(!1)})},x=n||(d||!W?"Get started quickly with email":"Get started without a wallet.");return ho($n,{children:[ho(Vn,{stacked:t.stacked,children:[ho(zn,{standalone:t.stacked,children:[Ee(Tt,{}),Ee("input",{id:"email-input",type:"email",placeholder:"your@email.com",onChange:l=>o(l.target.value),onKeyUp:l=>{l.key==="Enter"&&v()},value:e,autoComplete:"email"})]}),t.stacked?null:Ee(Hn,{disabled:r||!A,onClick:v,children:r?Ee(we,{color:"var(--disabled-fg)",style:{height:"1rem",width:"1rem",borderWidth:"2px"}}):"Submit"})]}),Ee(jn,{fail:!!n,children:x}),t.stacked?Ee(Bn,{disabled:r||!A,onClick:v,children:r?Ee(we,{color:"var(--disabled-fg)",style:{height:"1rem",width:"1rem",borderWidth:"2px"}}):"Submit"}):null]})},Vn=st.div`
|
|
296
296
|
border: 1px solid var(--border-color-1);
|
|
297
297
|
width: 100%;
|
|
298
298
|
height: ${t=>t.stacked?"100%":"auto"};
|
|
@@ -305,7 +305,7 @@ Resources:
|
|
|
305
305
|
@media (max-width: 440px) {
|
|
306
306
|
margin-top: 20px;
|
|
307
307
|
}
|
|
308
|
-
`,Hn=
|
|
308
|
+
`,Hn=st.button`
|
|
309
309
|
display: flex;
|
|
310
310
|
flex-direction: row;
|
|
311
311
|
align-items: center;
|
|
@@ -330,7 +330,7 @@ Resources:
|
|
|
330
330
|
color: var(--disabled-fg);
|
|
331
331
|
cursor: not-allowed;
|
|
332
332
|
}
|
|
333
|
-
`,Bn=
|
|
333
|
+
`,Bn=st.button`
|
|
334
334
|
display: flex;
|
|
335
335
|
flex-direction: column;
|
|
336
336
|
align-items: center;
|
|
@@ -354,7 +354,7 @@ Resources:
|
|
|
354
354
|
color: var(--disabled-fg);
|
|
355
355
|
cursor: not-allowed;
|
|
356
356
|
}
|
|
357
|
-
`,zn=
|
|
357
|
+
`,zn=st.label`
|
|
358
358
|
display: flex;
|
|
359
359
|
flex-direction: row;
|
|
360
360
|
align-items: center;
|
|
@@ -391,7 +391,7 @@ Resources:
|
|
|
391
391
|
line-height: 24px;
|
|
392
392
|
}
|
|
393
393
|
}
|
|
394
|
-
`,jn=
|
|
394
|
+
`,jn=st.div`
|
|
395
395
|
line-height: 20px;
|
|
396
396
|
height: 20px;
|
|
397
397
|
font-size: 13px;
|
|
@@ -404,7 +404,7 @@ Resources:
|
|
|
404
404
|
> a {
|
|
405
405
|
text-decoration: underline;
|
|
406
406
|
}
|
|
407
|
-
`;import{useEffect as Zn,useState as mo}from"react";import
|
|
407
|
+
`;import{useEffect as Zn,useState as mo}from"react";import He from"styled-components";import{jsx as Mr}from"react/jsx-runtime";var It=({style:t,...e})=>Mr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 20 20",strokeWidth:1.5,stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Mr("path",{d:"M2.5 4.16667C2.5 3.72464 2.67559 3.30072 2.98816 2.98816C3.30072 2.67559 3.72464 2.5 4.16667 2.5H6.9C7.07483 2.50013 7.24519 2.55525 7.38696 2.65754C7.52874 2.75984 7.63475 2.90413 7.69 3.07L8.93833 6.81417C9.00158 7.00445 8.9941 7.21116 8.91726 7.39637C8.84042 7.58158 8.69938 7.73288 8.52 7.8225L6.63917 8.76417C7.5611 10.8046 9.19538 12.4389 11.2358 13.3608L12.1775 11.48C12.2671 11.3006 12.4184 11.1596 12.6036 11.0827C12.7888 11.0059 12.9956 10.9984 13.1858 11.0617L16.93 12.31C17.096 12.3653 17.2404 12.4714 17.3427 12.6134C17.445 12.7553 17.5 12.9259 17.5 13.1008V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H15C8.09667 17.5 2.5 11.9033 2.5 5V4.16667Z",strokeLinecap:"round",strokeLinejoin:"round"})});import{Fragment as Xn,jsx as ke,jsxs as fo}from"react/jsx-runtime";var Rt=t=>{let[e,o]=mo(""),[r,i]=mo(!1),[n,a]=mo(null),{authenticated:d}=M(),{initLoginWithSms:u}=E(),{navigate:p,options:T}=g(),W=T.wallet;Zn(()=>{let l=document.querySelector("#phone-number-input");l==null||l.focus()},[]);let A=Do(e),v=()=>{i(!0),u(e).then(()=>{p("AWAITING_PASSWORDLESS_CODE")}).catch(l=>{let C=(l==null?void 0:l.status)===401&&(l==null?void 0:l.message)==="User is not allowed to login to this app.";(l==null?void 0:l.status)===422?a(l.message):C?p("ALLOWLIST_REJECTION_SCREEN"):a("Issue submitting phone number"),i(!1)})},x=n||(d||!W?"Get started quickly with your phone":"Get started without a wallet.");return fo(Xn,{children:[fo(Kn,{stacked:t.stacked,children:[fo(Yn,{standalone:t.stacked,children:[ke(It,{}),ke("input",{id:"phone-number-input",type:"tel",placeholder:"555 555 5555",onChange:l=>{o(l.target.value)},onKeyUp:l=>{l.key==="Enter"&&v()},value:e,autoComplete:"tel"})]}),t.stacked?null:ke(qn,{disabled:r||!A,onClick:v,children:r?ke(Nr,{color:"var(--disabled-fg)"}):"Submit"})]}),ke(Qn,{fail:!!n,children:x}),t.stacked?ke(Jn,{disabled:r||!A,onClick:v,children:r?ke(Nr,{color:"var(--disabled-fg)"}):"Submit"}):null]})},Kn=He.div`
|
|
408
408
|
display: flex;
|
|
409
409
|
border: 1px solid var(--border-color-1);
|
|
410
410
|
width: 100%;
|
|
@@ -418,7 +418,7 @@ Resources:
|
|
|
418
418
|
@media (max-width: 440px) {
|
|
419
419
|
margin-top: 20px;
|
|
420
420
|
}
|
|
421
|
-
`,qn=
|
|
421
|
+
`,qn=He.button`
|
|
422
422
|
display: flex;
|
|
423
423
|
flex-direction: row;
|
|
424
424
|
align-items: center;
|
|
@@ -443,7 +443,7 @@ Resources:
|
|
|
443
443
|
color: var(--disabled-fg);
|
|
444
444
|
cursor: not-allowed;
|
|
445
445
|
}
|
|
446
|
-
`,Jn=
|
|
446
|
+
`,Jn=He.button`
|
|
447
447
|
display: flex;
|
|
448
448
|
flex-direction: column;
|
|
449
449
|
align-items: center;
|
|
@@ -467,7 +467,7 @@ Resources:
|
|
|
467
467
|
color: var(--disabled-fg);
|
|
468
468
|
cursor: not-allowed;
|
|
469
469
|
}
|
|
470
|
-
`,Yn=
|
|
470
|
+
`,Yn=He.label`
|
|
471
471
|
display: flex;
|
|
472
472
|
flex-direction: row;
|
|
473
473
|
align-items: center;
|
|
@@ -504,7 +504,7 @@ Resources:
|
|
|
504
504
|
line-height: 24px;
|
|
505
505
|
}
|
|
506
506
|
}
|
|
507
|
-
`,Qn=
|
|
507
|
+
`,Qn=He.div`
|
|
508
508
|
line-height: 20px;
|
|
509
509
|
height: 20px;
|
|
510
510
|
font-size: 13px;
|
|
@@ -517,19 +517,19 @@ Resources:
|
|
|
517
517
|
> a {
|
|
518
518
|
text-decoration: underline;
|
|
519
519
|
}
|
|
520
|
-
`,Nr=
|
|
520
|
+
`,Nr=He(we)`
|
|
521
521
|
&& {
|
|
522
522
|
height: 1rem;
|
|
523
523
|
width: 1rem;
|
|
524
524
|
border-width: 2px;
|
|
525
525
|
}
|
|
526
|
-
`;import{jsx as Or}from"react/jsx-runtime";var Ur=()=>{let{app:t}=g();return t!=null&&t.logoUrl?Or("div",{children:Or("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{isMobile as Fr}from"react-device-detect";import{Fragment as go,jsx as k,jsxs as _e}from"react/jsx-runtime";var Gr=()=>{let{ready:t}=M(),{getAuthMeta:e,isLinking:o}=E(),{app:r,navigate:i,options:n}=g(),a=n.email,d=n.sms,u=n.wallet,p=n.google,T=n.twitter,W=n.discord,A=n.github,v=u&&(r==null?void 0:r.showWalletLoginFirst)?0:1,[x,l]=ts(v),C=e(),z=(C==null?void 0:C.authorizationCode)&&(C==null?void 0:C.stateCode)&&(C==null?void 0:C.provider);es(()=>{z?i("AWAITING_OAUTH_SCREEN"):o&&a?i("LINK_EMAIL_SCREEN"):o&&d?i("LINK_PHONE_SCREEN"):o&&u&&i("LINK_WALLET_SCREEN")},[t]);let ve=x==0,
|
|
526
|
+
`;import{jsx as Or}from"react/jsx-runtime";var Ur=()=>{let{app:t}=g();return t!=null&&t.logoUrl?Or("div",{children:Or("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{isMobile as Fr}from"react-device-detect";import{Fragment as go,jsx as k,jsxs as _e}from"react/jsx-runtime";var Gr=()=>{let{ready:t}=M(),{getAuthMeta:e,isLinking:o}=E(),{app:r,navigate:i,options:n}=g(),a=n.email,d=n.sms,u=n.wallet,p=n.google,T=n.twitter,W=n.discord,A=n.github,v=u&&(r==null?void 0:r.showWalletLoginFirst)?0:1,[x,l]=ts(v),C=e(),z=(C==null?void 0:C.authorizationCode)&&(C==null?void 0:C.stateCode)&&(C==null?void 0:C.provider);es(()=>{z?i("AWAITING_OAUTH_SCREEN"):o&&a?i("LINK_EMAIL_SCREEN"):o&&d?i("LINK_PHONE_SCREEN"):o&&u&&i("LINK_WALLET_SCREEN")},[t]);let ve=x==0,re=x==1,P=u,F=a||d;return _e(go,{children:[k(L,{},"header"),k(ss,{hasOnlyOneSection:P!==F,hasTerms:!!((r==null?void 0:r.privacyPolicyUrl)||(r==null?void 0:r.termsAndConditionsUrl)),children:k(Ur,{})}),_e(as,{reverse:!(r!=null&&r.showWalletLoginFirst),children:[P&&k(os,{active:ve,onClick:()=>l(0),isOnlySection:!F}),F&&k(rs,{active:re,onClick:()=>l(1),email:a,sms:d,google:p,twitter:T,discord:W,github:A,isOnlySection:!P})]}),r&&k(kr,{app:r}),k(ee,{protectedByPrivy:!0})]})};function os(t){return _e(Hr,{active:t.active,onClick:t.onClick,isOnlySection:t.isOnlySection,children:[k(Vr,{active:t.active,children:k("h4",{children:"Connect Wallet"})}),t.active&&_e(go,{children:[k(Lt,{}),k(At,{})]})]})}function rs(t){let e=t.google||t.discord||t.github||t.twitter&&!Fr,o=t.email?"Email":"Phone";return _e(Hr,{active:t.active,onClick:t.onClick,isOnlySection:t.isOnlySection,children:[t.isOnlySection?null:k(Vr,{active:t.active,children:k("h4",{children:e?`${o} & Social`:o})}),t.active&&t.email&&k(Wt,{}),t.active&&t.sms&&!t.email&&k(Rt,{}),t.active&&e&&k(is,{google:t.google,twitter:t.twitter&&!Fr,discord:t.discord,github:t.github})]})}function is(t){return _e(go,{children:[_e(ns,{children:[k(Dr,{}),k("p",{children:" Or "}),k(Dr,{})]}),k(Ir,{showGoogle:t.google,showDiscord:t.discord,showGithub:t.github,showTwitter:t.twitter})]})}var Vr=Be.div`
|
|
527
527
|
font-weight: ${t=>t.active?600:500};
|
|
528
528
|
color: ${t=>t.active?"inherit":"var(--light-theme-fg-3)"};
|
|
529
529
|
display: flex;
|
|
530
530
|
justify-content: center;
|
|
531
531
|
align-items: center;
|
|
532
|
-
`,Hr=
|
|
532
|
+
`,Hr=Be.div`
|
|
533
533
|
display: flex;
|
|
534
534
|
flex-direction: column;
|
|
535
535
|
align-items: flex-start;
|
|
@@ -554,18 +554,18 @@ Resources:
|
|
|
554
554
|
}
|
|
555
555
|
|
|
556
556
|
cursor: ${t=>t.active?"inherit":"pointer"};
|
|
557
|
-
`,ns=
|
|
557
|
+
`,ns=Be.div`
|
|
558
558
|
display: flex;
|
|
559
559
|
justify-content: center;
|
|
560
560
|
align-items: center;
|
|
561
561
|
width: 100%;
|
|
562
|
-
`,Dr=
|
|
562
|
+
`,Dr=Be.hr`
|
|
563
563
|
width: 50%;
|
|
564
564
|
&& {
|
|
565
565
|
border-top: 1px solid var(--border-color-1);
|
|
566
566
|
margin: 0px 8px;
|
|
567
567
|
}
|
|
568
|
-
`,ss=
|
|
568
|
+
`,ss=Be.div`
|
|
569
569
|
display: flex;
|
|
570
570
|
flex-direction: column;
|
|
571
571
|
align-items: center;
|
|
@@ -584,11 +584,11 @@ Resources:
|
|
|
584
584
|
// the logo is close to the top (mobile or full wallet-open design)
|
|
585
585
|
margin-top: ${t=>`${28+(t.hasOnlyOneSection?31:0)-(t.hasTerms?18:0)}px`};
|
|
586
586
|
margin-bottom: ${t=>`${60+(t.hasOnlyOneSection?31:0)-(t.hasTerms?18:0)}px`};
|
|
587
|
-
`,as=
|
|
587
|
+
`,as=Be(fe)`
|
|
588
588
|
flex-direction: ${t=>t.reverse?"column-reverse":"column"};
|
|
589
|
-
`;import{useEffect as $r,useState as Nt}from"react";import Ot from"styled-components";import Mt from"styled-components";import{jsx as
|
|
589
|
+
`;import{useEffect as $r,useState as Nt}from"react";import Ot from"styled-components";import Mt from"styled-components";import{jsx as at,jsxs as jr}from"react/jsx-runtime";var Pe=({title:t,description:e,children:o,...r})=>jr(zr,{...r,children:[at("h3",{children:t}),typeof e=="string"?at("p",{children:e}):null,o]}),Br=Mt(Pe)`
|
|
590
590
|
margin-bottom: 24px;
|
|
591
|
-
`,
|
|
591
|
+
`,ze=({title:t,description:e,icon:o,children:r,...i})=>jr(ls,{...i,children:[o?at(cs,{children:o}):null,at("h3",{children:t}),typeof e=="string"?at("p",{children:e}):null,r]}),zr=Mt.div`
|
|
592
592
|
display: flex;
|
|
593
593
|
flex-direction: column;
|
|
594
594
|
justify-content: flex-start;
|
|
@@ -622,7 +622,7 @@ Resources:
|
|
|
622
622
|
border-color: var(--light-theme-bg-3);
|
|
623
623
|
border-width: 1px;
|
|
624
624
|
}
|
|
625
|
-
`;import{isMobile as ds}from"react-device-detect";import{Fragment as wo,jsx as B,jsxs as
|
|
625
|
+
`;import{isMobile as ds}from"react-device-detect";import{Fragment as wo,jsx as B,jsxs as je}from"react/jsx-runtime";var yo=6,Zr=new Array(yo).fill(""),us=1400;var Kr=()=>{var F,Ce,be;let{app:t}=g(),{closePrivyModal:e,resendEmailCode:o,resendSmsCode:r,getAuthMeta:i,loginWithCode:n}=E(),{authenticated:a,user:d}=M(),[u,p]=Nt(Zr),[T,W]=Nt(!1),[A,v]=Nt(null),[x,l]=Nt(null),C=(F=i())!=null&&F.email?0:1;$r(()=>{if(a&&T){let b=setTimeout(e,ue);return()=>clearTimeout(b)}},[a,T,d]),$r(()=>{if(A&&x===0){let b=setTimeout(()=>{p(Zr),v(null);let y=document.querySelector("input[name=code-0]");y==null||y.focus()},us);return()=>clearTimeout(b)}},[A]);let z=b=>{var We;let y=b.currentTarget.value.replace(" ","");if(y==="")return;if(isNaN(Number(y))){v("Code should be numeric"),l(1);return}v(null),l(null);let D=Number((We=b.currentTarget.name)==null?void 0:We.charAt(5)),ie=[...y||[""]].slice(0,yo-D),s=[...u.slice(0,D),...ie,...u.slice(D+ie.length)];p(s);let c=ie.length,R=Math.min(Math.max(D+c,0),yo-1);if(!isNaN(Number(b.currentTarget.value))){let q=document.querySelector(`input[name=code-${R}]`);q==null||q.focus()}if(s.every(q=>q&&!isNaN(+q))){let q=document.querySelector(`input[name=code-${R}]`);q==null||q.blur(),n(s.join("")).then(()=>W(!0)).catch(qt=>{(qt==null?void 0:qt.status)===422?v("Invalid or expired verification code"):v("Issue verifying code"),l(0)})}b.preventDefault()},ve=b=>{x===1&&(v(null),l(null));let y=[...u.slice(0,b),"",...u.slice(b+1)];if(p(y),b>0){let D=document.querySelector(`input[name=code-${b-1}]`);D==null||D.focus()}},re=`Verify your ${C==0?"email":"phone"}`,P=C==0?`Please check ${(Ce=i())==null?void 0:Ce.email} for an email from privy.io and enter your code below.`:`Please check ${(be=i())==null?void 0:be.phoneNumber} for a message from ${(t==null?void 0:t.name)||"privy.io"} and enter your code below.`;return je(wo,{children:[B(L,{},"header"),je(ps,{children:[B(Pe,{title:re,description:P}),je(Sr,{children:[je(hs,{children:[B(ms,{fail:!!A,success:T,children:B("span",{children:A||(T?"Success!":"")})}),B("div",{children:u.map((b,y)=>B("input",{name:`code-${y}`,type:"text",value:u[y],onChange:z,onKeyUp:D=>{D.key==="Backspace"&&ve(y)},inputMode:"numeric",autoFocus:y===0,pattern:"[0-9]",className:`${T?"success":""} ${A?"fail":""}`,autoComplete:ds?"one-time-code":"off"},y))})]}),B(fs,{children:C==0?je(wo,{children:[B("span",{children:"Didn't get an email?"}),B("button",{onClick:o,children:"Resend Code"})]}):je(wo,{children:[B("span",{children:"Didn't get a message?"}),B("button",{onClick:r,children:"Resend Code"})]})})]})]}),B(ee,{protectedByPrivy:!0})]})},ps=Ot.div`
|
|
626
626
|
display: flex;
|
|
627
627
|
flex-direction: column;
|
|
628
628
|
align-items: flex-start;
|
|
@@ -735,7 +735,7 @@ Resources:
|
|
|
735
735
|
border-color: var(--primary-color);
|
|
736
736
|
border-bottom-color: var(--primary-color);
|
|
737
737
|
}
|
|
738
|
-
`;import{jsx as Jr}from"react/jsx-runtime";var Yr=({style:t,...e})=>Jr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Jr("path",{"fill-rule":"evenodd",d:"M12 1.5a5.25 5.25 0 00-5.25 5.25v3a3 3 0 00-3 3v6.75a3 3 0 003 3h10.5a3 3 0 003-3v-6.75a3 3 0 00-3-3v-3c0-2.9-2.35-5.25-5.25-5.25zm3.75 8.25v-3a3.75 3.75 0 10-7.5 0v3h7.5z","clip-rule":"evenodd"})});import{Fragment as vo,jsx as
|
|
738
|
+
`;import{jsx as Jr}from"react/jsx-runtime";var Yr=({style:t,...e})=>Jr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Jr("path",{"fill-rule":"evenodd",d:"M12 1.5a5.25 5.25 0 00-5.25 5.25v3a3 3 0 00-3 3v6.75a3 3 0 003 3h10.5a3 3 0 003-3v-6.75a3 3 0 00-3-3v-3c0-2.9-2.35-5.25-5.25-5.25zm3.75 8.25v-3a3.75 3.75 0 10-7.5 0v3h7.5z","clip-rule":"evenodd"})});import{Fragment as vo,jsx as te,jsxs as Ft}from"react/jsx-runtime";var Xr=()=>{let{navigate:t,app:e}=g(),o=(e==null?void 0:e.allowlistConfig.errorTitle)||"You don't have access to this app",r=(e==null?void 0:e.allowlistConfig.errorDetail)||"Have you been invited?",i=(e==null?void 0:e.allowlistConfig.errorCtaText)||"Try another account";return Ft(vo,{children:[te(L,{}),Ft(ws,{children:[te(vs,{children:Ft("div",{children:[te(qr,{}),te(Yr,{style:{width:"38px",height:"38px",strokeWidth:"1",stroke:"var(--primary-color)",fill:"var(--primary-color)"}})]})}),Ft(ys,{children:[typeof o=="string"?te("h3",{children:o}):te(vo,{children:o}),typeof r=="string"?te("p",{children:r}):te(vo,{children:r})]}),e!=null&&e.allowlistConfig.errorCtaLink?te(Qr,{as:"a",href:e.allowlistConfig.errorCtaLink,visible:!0,children:i}):te(Qr,{onClick:()=>{t("LANDING")},visible:!0,children:i})]})]})},ws=Dt.div`
|
|
739
739
|
display: flex;
|
|
740
740
|
flex-direction: column;
|
|
741
741
|
align-items: center;
|
|
@@ -786,7 +786,7 @@ Resources:
|
|
|
786
786
|
background-color: var(--primary-color-bg-2);
|
|
787
787
|
}
|
|
788
788
|
}
|
|
789
|
-
`;import{useState as Rs}from"react";import Z from"styled-components";import Cs from"qrcode";import bs from"styled-components";import{Fragment as
|
|
789
|
+
`;import{useState as Rs}from"react";import Z from"styled-components";import Cs from"qrcode";import bs from"styled-components";import{Fragment as $e,jsx as U,jsxs as oi}from"react/jsx-runtime";var V=7,Co=(t,e,o,r,i)=>{for(let n=e;n<e+r;n++)for(let a=o;a<o+i;a++){let d=t==null?void 0:t[a];d&&d[n]&&(d[n]=0)}return t},xs=t=>{let e=Cs.create(t,{errorCorrectionLevel:"high"}).modules,o=Go(Array.from(e.data),e.size);return o=Co(o,0,0,V,V),o=Co(o,o.length-V,0,V,V),o=Co(o,0,o.length-V,V,V),o},Ls=({x:t,y:e,cellSize:o,bgColor:r,fgColor:i})=>U($e,{children:[0,1,2].map(n=>U("circle",{r:o*(V-n*2)/2,cx:t+o*V/2,cy:e+o*V/2,fill:n%2!==0?r:i},`finder-${t}-${e}-${n}`))}),As=({cellSize:t,matrixSize:e,bgColor:o,fgColor:r})=>{let i=[[0,0],[(e-V)*t,0],[0,(e-V)*t]];return U($e,{children:i.map(([n,a])=>U(Ls,{x:n,y:a,cellSize:t,bgColor:o,fgColor:r}))})},Es=({matrix:t,cellSize:e,color:o})=>U($e,{children:t.map((r,i)=>r.map((n,a)=>n?U("circle",{r:e/2.5,cx:i*e+e/2,cy:a*e+e/2,fill:o},`circle-${i}-${a}`):U($e,{})))}),ei=(t,e)=>t-t%e,ks=({outputSize:t,cellSize:e,element:o,size:r,padding:i,bgColor:n})=>{if(!o)return U($e,{});let a=r||40,d=i||4,u=o,p=t/2-a/2-d;return oi($e,{children:[U("rect",{x:ei(p,e),y:ei(p,e),width:a+d*2+(p%e?e+.5:.5),height:a+d*2+(p%e?e+.5:.5),fill:n}),U(u,{x:t/2-a/2,y:t/2-a/2,height:a,width:a})]})},_s=t=>{var i;let e=t.outputSize,o=xs(t.url),r=e/o.length;return oi("svg",{height:t.outputSize,width:t.outputSize,viewBox:`0 0 ${t.outputSize} ${t.outputSize}`,style:{height:"100%",width:"100%"},children:[U(Es,{matrix:o,cellSize:r,color:t.fgColor}),U(As,{cellSize:r,matrixSize:o.length,fgColor:t.fgColor,bgColor:t.bgColor}),U(ks,{outputSize:t.outputSize,cellSize:r,element:(i=t.logo)==null?void 0:i.element,bgColor:t.bgColor})]})},Ps=bs.div`
|
|
790
790
|
display: flex;
|
|
791
791
|
justify-content: center;
|
|
792
792
|
align-items: center;
|
|
@@ -801,12 +801,12 @@ Resources:
|
|
|
801
801
|
border-color: ${t=>t.fgColor};
|
|
802
802
|
border-radius: 12px;
|
|
803
803
|
}
|
|
804
|
-
`,ti=t=>{let e=t.bgColor||"#FFFFFF",o=t.fgColor||"#000000",r=t.size||160;return U(Ps,{size:r,bgColor:e,fgColor:o,children:U(_s,{url:t.url,logo:{element:t.squareLogoElement},outputSize:r,bgColor:e,fgColor:o})})};import{jsx as Ss}from"react/jsx-runtime";var ri=({size:t})=>Ss(ti,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:
|
|
804
|
+
`,ti=t=>{let e=t.bgColor||"#FFFFFF",o=t.fgColor||"#000000",r=t.size||160;return U(Ps,{size:r,bgColor:e,fgColor:o,children:U(_s,{url:t.url,logo:{element:t.squareLogoElement},outputSize:r,bgColor:e,fgColor:o})})};import{jsx as Ss}from"react/jsx-runtime";var ri=({size:t})=>Ss(ti,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:X,size:t,fgColor:"#1F1F1F"});import bo from"styled-components";import{jsx as ii}from"react/jsx-runtime";var ni=({style:t,...e})=>ii("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",width:"17",height:"17",viewBox:"0 0 17 17",style:{height:"1.25rem",width:"1.25rem",...t},...e,children:ii("path",{strokeLinecap:"round",strokeLinejoin:"round",fillRule:"evenodd",clipRule:"evenodd",d:"M16.5 8.67993C16.5 9.82986 15.853 10.8287 14.9032 11.3322C15.2188 12.3599 14.97 13.5237 14.1569 14.3368C13.3437 15.1499 12.18 15.3987 11.1523 15.0831C10.6488 16.0329 9.64993 16.6799 8.5 16.6799C7.35007 16.6799 6.35126 16.0329 5.84771 15.0831C4.82003 15.3987 3.65627 15.1499 2.84314 14.3368C2.03001 13.5237 1.78124 12.3599 2.09681 11.3322C1.14699 10.8287 0.5 9.82986 0.5 8.67993C0.5 7.53 1.14699 6.53119 2.0968 6.02764C1.78125 4.99996 2.03003 3.83621 2.84315 3.02309C3.65627 2.20997 4.82002 1.96119 5.8477 2.27675C6.35125 1.32692 7.35007 0.679932 8.5 0.679932C9.64992 0.679932 10.6487 1.32691 11.1523 2.27672C12.18 1.96115 13.3437 2.20993 14.1569 3.02305C14.97 3.83618 15.2188 4.99996 14.9032 6.02764C15.853 6.53119 16.5 7.53 16.5 8.67993ZM12.2659 6.68856C12.5654 6.40238 12.5761 5.92763 12.29 5.62818C12.0038 5.32873 11.529 5.31797 11.2296 5.60416C9.73022 7.03711 8.40877 8.65489 7.3018 10.4211L5.78033 8.89963C5.48744 8.60673 5.01256 8.60673 4.71967 8.89963C4.42678 9.19252 4.42678 9.66739 4.71967 9.96029L6.92031 12.1609C7.08544 12.3261 7.31807 12.4048 7.54957 12.374C7.78106 12.3432 7.98499 12.2064 8.1012 12.0038C9.23027 10.0356 10.6362 8.24613 12.2659 6.68856Z",fill:"var(--primary-color)"})});import{jsx as Ws,jsxs as Is}from"react/jsx-runtime";var xo=bo.div`
|
|
805
805
|
display: flex;
|
|
806
806
|
flex-direction: column;
|
|
807
807
|
justify-content: flex-start;
|
|
808
808
|
gap: 4px;
|
|
809
|
-
`,
|
|
809
|
+
`,lt=bo.div`
|
|
810
810
|
&&& {
|
|
811
811
|
margin-left: 7px; /* TODO: This is a total hack */
|
|
812
812
|
border-left: 2px solid var(--border-color-2);
|
|
@@ -861,7 +861,7 @@ Resources:
|
|
|
861
861
|
border: 1px solid var(--light-theme-bg-3);
|
|
862
862
|
color: var(--light-theme-fg-1);
|
|
863
863
|
}
|
|
864
|
-
`;import{Fragment as Ao,jsx as m,jsxs as N}from"react/jsx-runtime";var Eo=()=>{let{navigate:t}=g(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return ye.isFirefox&&(e="https://addons.mozilla.org/en-US/firefox/addon/ether-metamask/"),N(pi,{children:[m(Pe,{title:"Create a Metamask wallet",description:"Follow the instructions below to get started."}),m(hi,{children:m(
|
|
864
|
+
`;import{Fragment as Ao,jsx as m,jsxs as N}from"react/jsx-runtime";var Eo=()=>{let{navigate:t}=g(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return ye.isFirefox&&(e="https://addons.mozilla.org/en-US/firefox/addon/ether-metamask/"),N(pi,{children:[m(Pe,{title:"Create a Metamask wallet",description:"Follow the instructions below to get started."}),m(hi,{children:m(Q,{style:{width:"152px",height:"152px"}})}),N(xo,{children:[m(Se,{children:N("div",{children:[m("span",{children:"Install the "}),m("a",{href:e,target:"_blank",children:"MetaMask browser extension"})]})}),m(lt,{}),m(Se,{children:"Set up your first wallet"}),m(lt,{}),m(Se,{children:"Store your recovery phrase in a safe place!"})]}),m(mi,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},ko=()=>{let{navigate:t}=g();return N(pi,{children:[m(Pe,{title:"Create a Coinbase wallet",description:"Follow the instructions below to get started."}),m(hi,{style:{marginTop:"-24px"},children:m(ri,{size:200})}),N(xo,{children:[m(Se,{children:"Scan the QR code with your camera"}),m(lt,{}),m(Se,{children:"Set up your first wallet"}),m(lt,{}),m(Se,{children:"Store your seed phrase in a safe place!"})]}),m(mi,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},ui=()=>{let[t,e]=Rs("WHAT_IS_A_WALLET"),{navigateBack:o}=g();return N(Ao,{children:[m(L,{backFn:t==="WHAT_IS_A_WALLET"?o:t==="PICK_A_NEW_WALLET"?()=>e("WHAT_IS_A_WALLET"):()=>e("PICK_A_NEW_WALLET")},"header"),N(Ms,{children:[t==="WHAT_IS_A_WALLET"&&N(Ao,{children:[m(Ds,{children:m(si,{style:{width:"240px",height:"auto",borderRadius:"var(--border-radius-sm)",marginBottom:"32px"}})}),N(ze,{title:"Get started with a new wallet",children:[m("p",{children:"Wallets help you store, send, and receive digital assets and collectibles. They are also a new\xA0way\xA0to\xA0log\xA0in."}),m("p",{children:"Instead of creating new accounts and passwords for every app, you just connect your wallet and bring your\xA0data\xA0with\xA0you."})]}),m(Us,{children:m(Fs,{onClick:()=>{e("PICK_A_NEW_WALLET")},children:"Create a wallet"})})]}),t==="PICK_A_NEW_WALLET"&&m(Ao,{children:N(Ns,{children:[m(Pe,{title:"Create a new wallet",description:"Select one the wallet providers below to get started on your web3 adventure."}),N(Os,{children:[N(ci,{onClick:()=>{ye.isIOS?window.location.href="https://apps.apple.com/us/app/metamask-blockchain-wallet/id1438144202":ye.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=io.metamask":e("CREATE_METAMASK_WALLET")},children:[m(Q,{}),N(di,{children:[m("h4",{children:"MetaMask"}),m("p",{children:"Get a browser-based wallet"})]}),m("div",{children:m("span",{children:"Set up"})})]}),N(ci,{onClick:()=>{ye.isIOS?window.location.href="https://apps.apple.com/us/app/coinbase-wallet-nfts-crypto/id1278383455":ye.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=org.toshi":e("CREATE_COINBASE_WALLET")},children:[m(X,{}),N(di,{children:[m("h4",{children:"Coinbase Wallet"}),m("p",{children:"Get a mobile app wallet"})]}),m("div",{children:m("span",{children:"Set up"})})]})]})]})}),t==="CREATE_COINBASE_WALLET"&&m(ko,{}),t==="CREATE_METAMASK_WALLET"&&m(Eo,{})]}),N($,{children:[m("span",{children:"Still not sure? "}),m("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"}),"."]})]})},Ms=Z.div`
|
|
865
865
|
display: flex;
|
|
866
866
|
flex-direction: column;
|
|
867
867
|
height: 100%;
|
|
@@ -986,7 +986,7 @@ Resources:
|
|
|
986
986
|
`,Ds=Z.div`
|
|
987
987
|
display: flex;
|
|
988
988
|
justify-content: center;
|
|
989
|
-
`;import{useEffect as fi,useState as
|
|
989
|
+
`;import{useEffect as fi,useState as ct}from"react";import Ht from"styled-components";import{Fragment as Bs,jsx as de,jsxs as Vt}from"react/jsx-runtime";var _o=2,gi={metamask:{name:"MetaMask",component:Q},coinbase_wallet:{name:"Coinbase Wallet",component:X},wallet_connect:{name:"WalletConnect",component:De}},wi=()=>{var be;let[t,e]=ct(!1),[o,r]=ct("metamask"),[i,n]=ct(void 0),{navigate:a,navigateBack:d}=g(),{getAuthMeta:u,closePrivyModal:p,loginWithWallet:T}=E(),{walletConnectors:W}=M(),[A,v]=ct(0),{user:x}=M(),[l,C]=ct((x==null?void 0:x.linkedAccounts.length)||0);fi(()=>{var b;r(((b=u())==null?void 0:b.walletType)||"metamask"),n(void 0),T().then(()=>e(!0)).catch(y=>{y instanceof j?console.error(y.cause):console.error(y);let D=(y==null?void 0:y.status)===401&&(y==null?void 0:y.message)==="User is not allowed to login to this app.";(y==null?void 0:y.status)===422?n(Oe.ERROR_USER_EXISTS):D?a("ALLOWLIST_REJECTION_SCREEN"):y instanceof Ne&&!y.details.default?n(y.details):y instanceof Me?n(Oe.ERROR_TIMED_OUT):n(Oe.ERROR_WALLET_CONNECTION)})},[A]),fi(()=>{if(t){let b=setTimeout(p,ue);return()=>clearTimeout(b)}},[x]);let z=gi[o].name,ve=gi[o].component,re=t?`Successfully connected with ${z}`:i?i.message:`Waiting for ${z}`,P="";if(t){let b=(x==null?void 0:x.linkedAccounts.length)||0;l===b?P="Wallet was already linked.":P="You\u2019re good to go!"}else if(A>=_o&&i)P="Unable to connect wallet";else if(i)P=i.detail;else switch(P="Don\u2019t see your wallet modal? Check your other browser windows.",o){case"metamask":P="For the best experience, connect only one wallet at a time.";break;case"wallet_connect":P="Open your mobile wallet app to continue";break;case"coinbase_wallet":bt()||(io(x)?P="Continue with the Coinbase app. Not the right wallet? Reset your connection below.":P="Open the Coinbase app on your phone to continue.");break}let F=(be=W==null?void 0:W.walletConnectors)==null?void 0:be.find(b=>b.walletType==="coinbase_wallet"),Ce=o==="coinbase_wallet"&&(io(x)||i===Oe.ERROR_USER_EXISTS);return Vt(Bs,{children:[de(L,{backFn:d}),Vt(Gs,{children:[de(Hs,{children:Vt("div",{children:[de(Ve,{success:t,fail:!!i}),de(ve,{style:{width:"38px",height:"38px"}})]})}),Vt(Vs,{children:[de("h3",{children:re}),de("p",{children:P})]}),Ce?de(Po,{onClick:()=>F&&(F==null?void 0:F.disconnect()),visible:!t,disabled:t,children:"Use a different wallet"}):i==Oe.ERROR_USER_EXISTS?de(Po,{onClick:d,visible:!0,children:"Use a different wallet"}):de(Po,{onClick:()=>{v(A+1),n(void 0)},visible:!t&&(i==null?void 0:i.retryable)&&A<_o,disabled:!t&&(!(i!=null&&i.retryable)||A>=_o),children:"Retry"})]})]})},Gs=Ht.div`
|
|
990
990
|
display: flex;
|
|
991
991
|
flex-direction: column;
|
|
992
992
|
align-items: center;
|
|
@@ -1033,7 +1033,7 @@ Resources:
|
|
|
1033
1033
|
opacity: ${t=>t.visible?"1":"0"};
|
|
1034
1034
|
transition: opacity 200ms;
|
|
1035
1035
|
}
|
|
1036
|
-
`;import{Fragment as zs,jsx as Bt,jsxs as yi}from"react/jsx-runtime";var vi=()=>{let{navigateBack:t}=g();return yi(zs,{children:[Bt(L,{backFn:t},"header"),Bt(Eo,{}),yi($,{children:[Bt("span",{children:"Still not sure? "}),Bt("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"})]})]})};import So from"styled-components";import{useEffect as Ci,useState as bi}from"react";import{Fragment as Ks,jsx as
|
|
1036
|
+
`;import{Fragment as zs,jsx as Bt,jsxs as yi}from"react/jsx-runtime";var vi=()=>{let{navigateBack:t}=g();return yi(zs,{children:[Bt(L,{backFn:t},"header"),Bt(Eo,{}),yi($,{children:[Bt("span",{children:"Still not sure? "}),Bt("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"})]})]})};import So from"styled-components";import{useEffect as Ci,useState as bi}from"react";import{Fragment as Ks,jsx as K,jsxs as zt}from"react/jsx-runtime";var xi=()=>{let[t,e]=bi(!1),[o,r]=bi(""),{activeStatus:i,closePrivyModal:n}=E();Ci(()=>{!i||(i.error?r(i.error):i.success&&e(!0))},[i]),Ci(()=>{if(t){let p=setTimeout(n,ue);return()=>clearTimeout(p)}},[t]);let a=i!=null&&i.address?`Please connect and select the wallet ${Je(i.address)} in MetaMask.`:"Please connect and select the right wallet in MetaMask.",d=t?`${Je(i==null?void 0:i.address)} is now active.`:a;return zt(Ks,{children:[K(L,{},"header"),zt(js,{children:[K(Zs,{children:zt("div",{children:[K(Ve,{success:t,fail:!!o}),(p=>{switch(p){case"metamask":return K(Q,{style:{width:"38px",height:"38px"}});case"wallet_connect":return K(De,{style:{width:"38px",height:"38px"}});case"coinbase_wallet":return K(X,{style:{width:"38px",height:"38px"}});default:return K(Q,{style:{width:"38px",height:"38px"}})}})((i==null?void 0:i.walletType)||"metamask")]})}),zt($s,{children:[K("h3",{children:t?"Wallet updated successfully":"Update your active wallet"}),K("p",{children:d}),o&&K("p",{children:o})]}),K($,{})]})]})},js=So.div`
|
|
1037
1037
|
display: flex;
|
|
1038
1038
|
flex-direction: column;
|
|
1039
1039
|
align-items: center;
|
|
@@ -1309,7 +1309,7 @@ Resources:
|
|
|
1309
1309
|
|
|
1310
1310
|
--primary-color: ${t=>t.accentColor};
|
|
1311
1311
|
/* Same as primary color, but can be used with rgba */
|
|
1312
|
-
--primary-color-rgb: ${t=>`${
|
|
1312
|
+
--primary-color-rgb: ${t=>`${gt(t.accentColor).r}, ${gt(t.accentColor).g}, ${gt(t.accentColor).b}`};
|
|
1313
1313
|
--primary-color-bg-1: rgba(var(--primary-color-rgb), 0.15);
|
|
1314
1314
|
--primary-color-bg-2: rgba(var(--primary-color-rgb), 0.2);
|
|
1315
1315
|
|
|
@@ -1380,7 +1380,7 @@ Resources:
|
|
|
1380
1380
|
display: none;
|
|
1381
1381
|
}
|
|
1382
1382
|
}
|
|
1383
|
-
`;import{useEffect as ua}from"react";import{useEffect as ki,useState as _i}from"react";import Zt from"styled-components";import{Fragment as ia,jsx as Te,jsxs as $t}from"react/jsx-runtime";var Pi={google:{name:"Google",component:St},discord:{name:"Discord",component:kt},github:{name:"Github",component:_t},twitter:{name:"Twitter",component:Et}},Xs=t=>t.charAt(0).toUpperCase()+t.slice(1),To=()=>{let t=new URL(window.location.href);t.searchParams.delete("privy_oauth_code"),t.searchParams.delete("privy_oauth_provider"),t.searchParams.delete("privy_oauth_state"),window.history.pushState({},"",t)},Si=()=>{var x;let[t,e]=_i(!1),[o,r]=_i(void 0),{getAuthMeta:i,initLoginWithOAuth:n,loginWithOAuth:a,closePrivyModal:d}=E(),{ready:u}=M(),p=((x=i())==null?void 0:x.provider)||"google",T=Pi[p].name,W=Pi[p].component;ki(()=>{!u||a().then(()=>{To(),e(!0)}).catch(l=>{let C={retryable:!1,message:"Authentication failed."};l.message.includes("Another user has already linked this")?C.detail="This account has already been linked to another user.":l.message==="Invalid code during oauth flow."?(C.retryable=!0,C.detail="Something went wrong. Try again."):l.message==="User denied confirmation during OAuth flow"&&(C.detail=`Retry and check ${Xs(p)} to finish connecting your account.`,C.retryable=!0),To(),r(C)})},[u]),ki(()=>{if(!t)return;let l=setTimeout(d,
|
|
1383
|
+
`;import{useEffect as ua}from"react";import{useEffect as ki,useState as _i}from"react";import Zt from"styled-components";import{Fragment as ia,jsx as Te,jsxs as $t}from"react/jsx-runtime";var Pi={google:{name:"Google",component:St},discord:{name:"Discord",component:kt},github:{name:"Github",component:_t},twitter:{name:"Twitter",component:Et}},Xs=t=>t.charAt(0).toUpperCase()+t.slice(1),To=()=>{let t=new URL(window.location.href);t.searchParams.delete("privy_oauth_code"),t.searchParams.delete("privy_oauth_provider"),t.searchParams.delete("privy_oauth_state"),window.history.pushState({},"",t)},Si=()=>{var x;let[t,e]=_i(!1),[o,r]=_i(void 0),{getAuthMeta:i,initLoginWithOAuth:n,loginWithOAuth:a,closePrivyModal:d}=E(),{ready:u}=M(),p=((x=i())==null?void 0:x.provider)||"google",T=Pi[p].name,W=Pi[p].component;ki(()=>{!u||a().then(()=>{To(),e(!0)}).catch(l=>{let C={retryable:!1,message:"Authentication failed."};l.message.includes("Another user has already linked this")?C.detail="This account has already been linked to another user.":l.message==="Invalid code during oauth flow."?(C.retryable=!0,C.detail="Something went wrong. Try again."):l.message==="User denied confirmation during OAuth flow"&&(C.detail=`Retry and check ${Xs(p)} to finish connecting your account.`,C.retryable=!0),To(),r(C)})},[u]),ki(()=>{if(!t)return;let l=setTimeout(d,ue);return()=>clearTimeout(l)},[t]);let A=t?`Successfully connected with ${T}`:o?o.message:`Verifying connection to ${T}`,v="";return t?v="You\u2019re good to go!":o?v=o.detail:v="Just a few moments more",$t(ia,{children:[Te(L,{}),$t(ea,{children:[Te(oa,{children:$t("div",{children:[Te(Ve,{success:t,fail:!!o}),Te(W,{style:{width:"38px",height:"38px"},logoFill:"primary"})]})}),$t(ta,{children:[Te("h3",{children:A}),Te("p",{children:v})]}),Te(ra,{onClick:()=>{To(),n(p),r(void 0)},visible:!t&&(o==null?void 0:o.retryable),disabled:!t&&!(o!=null&&o.retryable),children:"Retry"})]})]})},ea=Zt.div`
|
|
1384
1384
|
display: flex;
|
|
1385
1385
|
flex-direction: column;
|
|
1386
1386
|
align-items: center;
|
|
@@ -1427,7 +1427,7 @@ Resources:
|
|
|
1427
1427
|
opacity: ${t=>t.visible?"1":"0"};
|
|
1428
1428
|
transition: opacity 200ms;
|
|
1429
1429
|
}
|
|
1430
|
-
`;import{Fragment as na,jsx as
|
|
1430
|
+
`;import{Fragment as na,jsx as Ze,jsxs as sa}from"react/jsx-runtime";var Ti=()=>{let{app:t}=g();return sa(na,{children:[Ze(L,{},"header"),Ze(ze,{title:"Connect your email",description:`Add your email to your ${t==null?void 0:t.name} account`,icon:Ze(Tt,{})}),Ze(fe,{children:Ze(Wt,{stacked:!0})}),Ze(ee,{protectedByPrivy:!0})]})};import{Fragment as aa,jsx as Ke,jsxs as la}from"react/jsx-runtime";var Wi=()=>{let{app:t}=g();return la(aa,{children:[Ke(L,{},"header"),Ke(ze,{title:"Connect your phone",description:`Add your number to your ${t==null?void 0:t.name} account`,icon:Ke(It,{})}),Ke(fe,{children:Ke(Rt,{stacked:!0})}),Ke(ee,{protectedByPrivy:!0})]})};import{Fragment as ca,jsx as dt,jsxs as Ii}from"react/jsx-runtime";var Ri=()=>{let{linkingHint:t}=E(),{app:e}=g(),o=t?`Select the wallet with ${Je(t)} and follow the instructions to reconnect your wallet${e!=null&&e.name?` to ${e.name}.`:"."}`:`Link a wallet to your ${e==null?void 0:e.name} account`;return Ii(ca,{children:[dt(L,{},"header"),dt(Br,{title:`${t?"Reconnect":"Connect"} your wallet`,description:o}),Ii(fe,{children:[dt(Lt,{}),dt(At,{})]}),dt(ee,{protectedByPrivy:!0})]})};import{jsx as _,jsxs as Mi}from"react/jsx-runtime";var pa=()=>{let{ready:t}=M(),{isLinking:e}=E(),{ready:o,currentScreen:r,app:i}=g(),n=!!(i!=null&&i.walletAuth),a=!!((i==null?void 0:i.emailAuth)||(i==null?void 0:i.smsAuth)),d=n!==a,u;return["AWAITING_CONNECTION","AWAITING_OAUTH_SCREEN","ALLOWLIST_REJECTION_SCREEN","SETTING_ACTIVE_WALLET"].includes(r)||d&&r==="LANDING"?u="compact":"WALLET_EDUCATION"===r?u="full":e?u="medium":u="full",!t||!o?Mi(Ut,{"data-height":u,children:[_(L,{}),_(fa,{children:_(we,{})}),_($,{})]}):Mi(Ut,{"data-height":u,children:[r==="LANDING"&&_(Gr,{}),r==="AWAITING_PASSWORDLESS_CODE"&&_(Kr,{}),r==="SETTING_ACTIVE_WALLET"&&_(xi,{}),r==="WALLET_EDUCATION"&&_(ui,{}),r==="AWAITING_CONNECTION"&&_(wi,{}),r==="AWAITING_OAUTH_SCREEN"&&_(Si,{}),r==="ALLOWLIST_REJECTION_SCREEN"&&_(Xr,{}),r==="INSTALL_METAMASK_SCREEN"&&_(vi,{}),r==="INSTALL_COINBASE_WALLET_SCREEN"&&_(Ai,{}),r==="LINK_EMAIL_SCREEN"&&_(Ti,{}),r==="LINK_PHONE_SCREEN"&&_(Wi,{}),r==="LINK_WALLET_SCREEN"&&_(Ri,{})]})},Ni=()=>{let{app:t}=g();return da.createPortal(_(ma,{id:"privy-dialog",children:_(Ei,{accentColor:t==null?void 0:t.accentColor,children:_(pa,{})})}),document.body)},ha=({children:t,...e})=>(ua(()=>{var r;(r=document==null?void 0:document.activeElement)==null||r.blur();let o=(document==null?void 0:document.getElementById("root"))||(document==null?void 0:document.getElementById("__next"));if(!!o)return o.setAttribute("inert","true"),()=>{let i=(document==null?void 0:document.getElementById("root"))||(document==null?void 0:document.getElementById("__next"));!i||i.removeAttribute("inert")}},[e.open,e.onClose]),_("dialog",{open:!0,role:"dialog",...e,children:t})),ma=Wo(ha)`
|
|
1431
1431
|
position: fixed;
|
|
1432
1432
|
top: 0;
|
|
1433
1433
|
left: 0;
|
|
@@ -1485,4 +1485,4 @@ Resources:
|
|
|
1485
1485
|
align-items: center;
|
|
1486
1486
|
justify-content: center;
|
|
1487
1487
|
height: 100%;
|
|
1488
|
-
`;import{jsx as Kt,jsxs as xa}from"react/jsx-runtime";function wa(t){return typeof t=="string"&&t.length===25}var
|
|
1488
|
+
`;import{jsx as Kt,jsxs as xa}from"react/jsx-runtime";function wa(t){return typeof t=="string"&&t.length===25}var ut;function ya(){if(!ut){let t=O.get(Re);return Promise.resolve(t||null)}return ut.getAccessToken()}var va=t=>{if(!wa(t.appId))throw new h("Cannot initialize the Privy provider with an invalid Privy app ID");return ut||(ut=new Xe({appId:t.appId,apiURL:Mo})),Kt(ba,{...t,client:ut})},Ca=(t,e)=>{if(e)return{email:!1,sms:!1,wallet:!1,google:!1,twitter:!1,discord:!1,github:!1,[e]:!0};let o=!!(t!=null&&t.emailAuth),r=!!(t!=null&&t.smsAuth);return o&&r&&(console.warn("Enabling both email and SMS passwordless is not currently supported. Disabling SMS."),r=!1),{email:o,sms:r,wallet:!!(t!=null&&t.walletAuth),google:!!(t!=null&&t.googleOAuth),twitter:!!(t!=null&&t.twitterOAuth),discord:!!(t!=null&&t.discordOAuth),github:!!(t!=null&&t.githubOAuth)}},ba=t=>{let e=t.client,[o,r]=oe(!1),[i,n]=oe(!1),[a,d]=oe(!1),[u,p]=oe(null),[T,W]=oe(!1),[A,v]=oe(null),[x,l]=oe(!1),[C,z]=oe(null),[ve,re]=oe(null),[P,F]=oe({accentColor:"#696ffd",theme:"System",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,termsAndConditionsUrl:null,privacyPolicyUrl:null}),Ce=Ca(P,A);Oi(()=>{async function s(){let c=await e.getAppSettings();F(c),e.connectors.initialize(),be();let R=await e.getAuthenticatedUser();d(!!R),p(R),n(!0)}s()},[e]);let be=()=>{let s=new URLSearchParams(window.location.search),c=s.get("privy_oauth_code"),R=s.get("privy_oauth_state"),We=s.get("privy_oauth_provider");c&&R&&We&&(e.startAuthFlow(new Ue(We,c,R)),v(We),r(!0))};Oi(()=>{i&&a&&u===null&&e.getAuthenticatedUser().then(p)},[i,a,u,e]);let b=()=>{v("wallet"),l(!0),r(!0)},y={ready:i,authenticated:a,user:u,walletConnectors:e.connectors,linkWallet:b,linkEmail:()=>{v("email"),l(!0),r(!0)},linkPhone:()=>{v("sms"),l(!0),r(!0)},linkGoogle:async()=>{await ie.initLoginWithOAuth("google")},linkTwitter:async()=>{await ie.initLoginWithOAuth("twitter")},linkDiscord:async()=>{await ie.initLoginWithOAuth("discord")},linkGithub:async()=>{await ie.initLoginWithOAuth("github")},login:()=>{if(i&&a){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}r(!0)},logout:async()=>{await e.logout(),p(null),d(!1),v(null),l(!1),r(!1)},getAccessToken:()=>e.getAccessToken(),getEthereumProvider:()=>e.connectors.getEthereumProvider(),getEthersProvider:()=>new ga(new Le(e.connectors.getEthereumProvider())),getWeb3jsProvider:()=>new ft(e.connectors.getEthereumProvider()),unlinkWallet:async s=>{let c=await e.unlinkWallet(s);return p(c),c},unlinkEmail:async s=>{let c=await e.unlinkEmail(s);return p(c),c},unlinkPhone:async s=>{let c=await e.unlinkPhone(s);return p(c),c},unlinkGoogle:async s=>{let c=await e.unlinkOAuth("google",s);return p(c),c},unlinkTwitter:async s=>{let c=await e.unlinkOAuth("twitter",s);return p(c),c},unlinkDiscord:async s=>{let c=await e.unlinkOAuth("discord",s);return p(c),c},unlinkGithub:async s=>{let c=await e.unlinkOAuth("github",s);return p(c),c},setActiveWallet:async s=>{if(!u)return;let c=e.connectors.getConnectorByAddress(s);if(!c){re(s),b();return}z({address:s,walletType:c.walletType,success:!1}),r(!0),e.setActiveWallet(s,u).then(R=>{p(R),z({address:s,walletType:c.walletType,success:!0})}).catch(R=>{R instanceof h&&R.message==="Error setting the active wallet."&&(re(s),b()),z({address:s,walletType:c.walletType,success:!1,error:R.message})})},forkSession:()=>e.forkSession()},ie=(()=>({isLinking:x,linkingHint:ve,activeStatus:C,getAuthFlow:()=>e.authFlow,getAuthMeta:()=>{var s;return(s=e.authFlow)==null?void 0:s.meta},closePrivyModal:()=>{var s;i&&a&&u&&((s=t.onSuccess)==null||s.call(t,u,T)),e.authFlow=void 0,v(null),re(null),l(!1),z(null),W(!1),r(!1)},initLoginWithWallet:s=>{if(!e.connectors)throw new h("Connector not initialized");s||(s="metamask"),e.startAuthFlow(new et(e.connectors,s))},loginWithWallet:async()=>{if(!(e.authFlow instanceof et))throw new h("Must initialize SIWE flow first.");let s,c;x?(s=await e.link(),s&&(s=Qe(s))):{user:s,isNewUser:c}=await e.authenticate(),p(s||u||null),W(c||!1),d(!0)},initLoginWithOAuth:async s=>{e.startAuthFlow(new Ue(s));let c=await e.authFlow.getAuthorizationUrl();c&&c.url&&window.location.assign(c.url)},loginWithOAuth:async()=>{if(!(e.authFlow instanceof Ue))throw new h("Must initialize OAuth flow before calling loginWithOAuth");let s,c;i&&a?s=await e.link():{user:s,isNewUser:c}=await e.authenticate(),p(s),W(c||!1),d(!0)},initLoginWithEmail:async s=>{let c=new tt(s);e.startAuthFlow(c),await c.sendCodeEmail()},initLoginWithSms:async s=>{let c=new ot(s);e.startAuthFlow(c),await c.sendSmsCode()},resendEmailCode:async()=>{var s;await((s=e.authFlow)==null?void 0:s.sendCodeEmail())},resendSmsCode:async()=>{var s;await((s=e.authFlow)==null?void 0:s.sendSmsCode())},loginWithCode:async s=>{if(e.authFlow instanceof tt)e.authFlow.meta.emailCode=s.trim();else if(e.authFlow instanceof ot)e.authFlow.meta.smsCode=s.trim();else throw new h("Must initialize a passwordless code flow first");let c,R;x?c=await e.link():{user:c,isNewUser:R}=await e.authenticate(),p(c||u||null),W(R||!1),d(!0)}}))();return xa(so.Provider,{value:y,children:[t.children,Kt(lo.Provider,{value:ie,children:Kt(hr,{appSettings:P,options:Ce,screen:C?"SETTING_ACTIVE_WALLET":null,visible:o,authenticated:a,children:o&&Kt(Ni,{})})})]})};export{Le as AsExternalProvider,Ye as ConnectorManager,Xe as PrivyClient,va as PrivyProvider,J as PrivyProxyProvider,Jt as VERSION,se as WalletConnector,ya as getAccessToken,M as usePrivy};
|