@privy-io/react-auth 1.13.0-beta.4 → 1.13.0-beta.5
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 +61 -61
- package/dist/index.js +74 -74
- package/package.json +1 -1
package/dist/esm/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{useEffect as Ut,useState as ne}from"react";import Ht from"axios";import Ci from"axios";var H=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}]`:""}`}},ke=class extends H{constructor(o,r,i,n){super(i,n);this.type=o;this.status=r}},u=class extends H{constructor(o,r){super(o,r);this.type="client_error"}};var G=class extends H{constructor(o,r){super(o,r);this.type="connector_error"}},T=t=>{if(t instanceof H)return t;if(!Ci.isAxiosError(t))return V(t);if(!t.response)return new ke("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new ke(e||"ApiError",t.response.status,o||r,t)},V=t=>t instanceof H?t:t instanceof Error?new u(t.message,t):new u(`Internal error: ${t}`);var vo="1.13.0-beta.4";var Co="https://api.privy.io/v0",xo=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",et="4df5e2316331463a9130964bd6078dfa",Lo=1e4,_e=1400,Bt=vo;var Pe="privy:token",tt="privy:refresh_token",Z="privy:active_wallet",ot="privy:wallet_type",Ao="walletconnect";var rt=class{constructor(e,o,r){this.appId=e,this.sdkVersion=Bt,this.client=o,this.defaults=r}async get(e,o){try{return await Ht.get(e,await this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw T(r)}}async post(e,o,r){try{return await Ht.post(e,o,await this.buildConfig(r))}catch(i){throw T(i)}}async delete(e,o){try{return await Ht.delete(e,await this.buildConfig(o))}catch(r){throw T(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 Eo from"jose";var Y=class{static parse(e){try{return new Y(e)}catch{return null}}constructor(e){this.value=e,this._decoded=Eo.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 se=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 zt=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]}},jt=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)}};function Li(){return typeof window<"u"&&window.localStorage?new jt:new zt}var E=Li();function ae(t){return new Date(t*1e3)}function Ai(t){return t.map(e=>{switch(e.type){case"wallet":return{address:e.address,type:e.type,verifiedAt:ae(e.verified_at),chainType:e.chain_type};case"email":return{address:e.address,type:e.type,verifiedAt:ae(e.verified_at)};case"phone":return{number:e.phoneNumber,type:e.type,verifiedAt:ae(e.verified_at)};case"google_oauth":return{subject:e.subject,email:e.email,name:e.name,type:e.type,verifiedAt:ae(e.verified_at)};case"twitter_oauth":return{subject:e.subject,username:e.username,name:e.name,type:e.type,verifiedAt:ae(e.verified_at)};case"discord_oauth":return{subject:e.subject,username:e.username,email:e.email,type:e.type,verifiedAt:ae(e.verified_at)};case"github_oauth":return{subject:e.subject,username:e.username,name:e.name,email:e.email,type:e.type,verifiedAt:ae(e.verified_at)};default:throw new u("Unrecognized account type")}})}function Ei(t,e){return e.find(o=>o.type==="wallet"&&o.address===t)}function le(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function Ge(t){let e=t.linkedAccounts.map(s=>s.type==="wallet"?s.address:null),r=E.get(Z);if(!r||!e.includes(r)){E.del(Z);let s=le(t.linkedAccounts,"wallet");s&&(r=s.address,E.put(Z,r))}let i=Ei(r,t.linkedAccounts),n=Object.assign({},t);return n.wallet=i&&{address:i.address,chainType:i.chainType,chainId:i.chainId,walletType:i.walletType},n}function Q(t){if(!t)return null;let e=Ai(t.linked_accounts),o=le(e,"wallet"),r=le(e,"email"),i=le(e,"phone"),n=le(e,"google_oauth"),s=le(e,"twitter_oauth"),c=le(e,"discord_oauth"),h=le(e,"github_oauth"),m={id:t.id,createdAt:ae(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:s&&{subject:s.subject,username:s.username,name:s.name},discord:c&&{subject:c.subject,username:c.username,email:c.email},github:h&&{subject:h.subject,username:h.username,name:h.name,email:h.email}};return Ge(m)}var ko=()=>"/api/v1/sessions",_o=()=>"/api/v1/sessions/logout",Po=()=>"/api/v1/sessions/fork",So=()=>"/api/v1/siwe/init",To=()=>"/api/v1/siwe/authenticate",Io=()=>"/api/v1/siwe/link",Ro=()=>"/api/v1/passwordless/init",Mo=()=>"/api/v1/passwordless/authenticate",Wo=()=>"/api/v1/passwordless/link",No=()=>"/api/v1/passwordless_sms/init",Oo=()=>"/api/v1/passwordless_sms/authenticate",Uo=()=>"/api/v1/passwordless_sms/link",Do=()=>"/api/v1/oauth/init",Fo=()=>"/api/v1/oauth/authenticate",Go=()=>"/api/v1/oauth/link",Vo=()=>"/api/v1/siwe/unlink",Bo=()=>"/api/v1/passwordless/unlink",Ho=()=>"/api/v1/passwordless_sms/unlink",zo=()=>"/api/v1/oauth/unlink";var ki=30,it=class{constructor(){this.authenticateOnce=new se(async e=>this._authenticate(e)),this.linkOnce=new se(async e=>this._link(e)),this.refreshOnce=new se(this._refresh.bind(this)),this.destroyOnce=new se(this._destroy.bind(this)),this.forkSessionOnce=new se(this._forkSession.bind(this))}get token(){try{let e=E.get(Pe);return typeof e=="string"?new Y(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=E.get(tt);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=Y.parse(this.token);return e!==null&&!e.isExpired(ki)}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:Q(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),V(o)}}async _link(e){try{let o=await e.link();return Q(o)}catch(o){throw console.warn("Error linking account"),V(o)}}async _refresh(){if(!this.api)throw new u("Session has no API instance");if(!this.client)throw new u("Session has no PrivyClient instance");let e=await this.client.getAccessToken({disableAutoRefresh:!0}),o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(ko(),{refresh_token:o},{headers:{authorization:`Bearer ${this.token}`}});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),Q(r.data.user)}catch(r){if(r instanceof ke&&r.status===400&&r.message==="Invalid auth token")return this.destroyLocalState(),null;throw V(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 u("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(Po(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw V(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),E.del(Z)}storeToken(e){typeof e=="string"?E.put(Pe,e):E.del(Pe)}storeRefreshToken(e){typeof e=="string"?E.put(tt,e):E.del(tt)}};import{getAddress as Ri}from"@ethersproject/address";import $o from"@walletconnect/web3-provider";import{ErrorCode as _i}from"@ethersproject/logger";var Se=class extends G{constructor(){super("Wallet timeout");this.type="wallet_error"}},nt=t=>{if(t instanceof G)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new Te(t);return t.code===_i.ACTION_REJECTED&&(e.details=ge.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new Te(t):new G("Unknown connector error",t)},$t=class extends H{constructor(o,r,i){super(o);this.type="provider_error";this.code=r,this.data=i}},Te=class extends $t{constructor(o){var n,s,c;let r=o;super(r.message,r.code,r.data);let i=Object.values(ge).find(h=>h.eipCode===r.code);this.details=i||ge.UNKNOWN_ERROR,r.code===-32002&&((n=r.message)!=null&&n.includes("already pending for origin")?(s=r.message)!=null&&s.includes("wallet_requestPermissions")?this.details=ge.E32002_CONNECTION_ALREADY_PENDING:this.details=ge.E32002_REQUEST_ALREADY_PENDING:(c=r.message)!=null&&c.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=ge.E32002_WALLET_LOCKED))}},Pi={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}},Si={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}},Ti={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}},ge={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Ti,...Si},st={...Pi,...ge};var Ii=12e4,Zt=(t=new Se,e=Ii)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),we=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})}request(e){if(!this.walletProvider)throw new G(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),Zt()]).catch(o=>{throw nt(o)})}},ye=class extends we{constructor(o){super(o)}},at=class extends we{constructor(e){super(e)}sendAsync(e,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};import{Web3Provider as Mi}from"@ethersproject/providers";var jo=["metamask","coinbase_wallet","wallet_connect"];import Wi from"@coinbase/wallet-sdk";var Ni=()=>{let t=`https://mainnet.infura.io/v3/${et}`,e=1;return new Wi({appName:"Privy",darkMode:!1,headlessMode:!1}).makeWeb3Provider(t,e)},Kt=()=>{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},lt=()=>{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},Ve=class{constructor(){this.walletType=null;this.getEthereumProvider=()=>this.ethProvider;this.createSiweMessage=(e,o,r,i,n,s,c)=>`${r} wants you to sign in with your Ethereum account:
|
|
1
|
+
import{useEffect as Ut,useState as ne}from"react";import Ht from"axios";import Ci from"axios";var H=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}]`:""}`}},ke=class extends H{constructor(o,r,i,n){super(i,n);this.type=o;this.status=r}},u=class extends H{constructor(o,r){super(o,r);this.type="client_error"}};var G=class extends H{constructor(o,r){super(o,r);this.type="connector_error"}},T=t=>{if(t instanceof H)return t;if(!Ci.isAxiosError(t))return V(t);if(!t.response)return new ke("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new ke(e||"ApiError",t.response.status,o||r,t)},V=t=>t instanceof H?t:t instanceof Error?new u(t.message,t):new u(`Internal error: ${t}`);var vo="1.13.0-beta.5";var Co="https://api.privy.io/v0",xo=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",et="4df5e2316331463a9130964bd6078dfa",Lo=1e4,_e=1400,Bt=vo;var Pe="privy:token",tt="privy:refresh_token",Z="privy:active_wallet",ot="privy:wallet_type",Ao="walletconnect";var rt=class{constructor(e,o,r){this.appId=e,this.sdkVersion=Bt,this.client=o,this.defaults=r}async get(e,o){try{return await Ht.get(e,await this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw T(r)}}async post(e,o,r){try{return await Ht.post(e,o,await this.buildConfig(r))}catch(i){throw T(i)}}async delete(e,o){try{return await Ht.delete(e,await this.buildConfig(o))}catch(r){throw T(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 Eo from"jose";var Y=class{static parse(e){try{return new Y(e)}catch{return null}}constructor(e){this.value=e,this._decoded=Eo.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 se=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 zt=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]}},jt=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)}};function Li(){return typeof window<"u"&&window.localStorage?new jt:new zt}var E=Li();function ae(t){return new Date(t*1e3)}function Ai(t){return t.map(e=>{switch(e.type){case"wallet":return{address:e.address,type:e.type,verifiedAt:ae(e.verified_at),chainType:e.chain_type};case"email":return{address:e.address,type:e.type,verifiedAt:ae(e.verified_at)};case"phone":return{number:e.phoneNumber,type:e.type,verifiedAt:ae(e.verified_at)};case"google_oauth":return{subject:e.subject,email:e.email,name:e.name,type:e.type,verifiedAt:ae(e.verified_at)};case"twitter_oauth":return{subject:e.subject,username:e.username,name:e.name,type:e.type,verifiedAt:ae(e.verified_at)};case"discord_oauth":return{subject:e.subject,username:e.username,email:e.email,type:e.type,verifiedAt:ae(e.verified_at)};case"github_oauth":return{subject:e.subject,username:e.username,name:e.name,email:e.email,type:e.type,verifiedAt:ae(e.verified_at)};default:throw new u("Unrecognized account type")}})}function Ei(t,e){return e.find(o=>o.type==="wallet"&&o.address===t)}function le(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function Ge(t){let e=t.linkedAccounts.map(s=>s.type==="wallet"?s.address:null),r=E.get(Z);if(!r||!e.includes(r)){E.del(Z);let s=le(t.linkedAccounts,"wallet");s&&(r=s.address,E.put(Z,r))}let i=Ei(r,t.linkedAccounts),n=Object.assign({},t);return n.wallet=i&&{address:i.address,chainType:i.chainType,chainId:i.chainId,walletType:i.walletType},n}function Q(t){if(!t)return null;let e=Ai(t.linked_accounts),o=le(e,"wallet"),r=le(e,"email"),i=le(e,"phone"),n=le(e,"google_oauth"),s=le(e,"twitter_oauth"),c=le(e,"discord_oauth"),h=le(e,"github_oauth"),m={id:t.id,createdAt:ae(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:s&&{subject:s.subject,username:s.username,name:s.name},discord:c&&{subject:c.subject,username:c.username,email:c.email},github:h&&{subject:h.subject,username:h.username,name:h.name,email:h.email}};return Ge(m)}var ko=()=>"/api/v1/sessions",_o=()=>"/api/v1/sessions/logout",Po=()=>"/api/v1/sessions/fork",So=()=>"/api/v1/siwe/init",To=()=>"/api/v1/siwe/authenticate",Io=()=>"/api/v1/siwe/link",Ro=()=>"/api/v1/passwordless/init",Mo=()=>"/api/v1/passwordless/authenticate",Wo=()=>"/api/v1/passwordless/link",No=()=>"/api/v1/passwordless_sms/init",Oo=()=>"/api/v1/passwordless_sms/authenticate",Uo=()=>"/api/v1/passwordless_sms/link",Do=()=>"/api/v1/oauth/init",Fo=()=>"/api/v1/oauth/authenticate",Go=()=>"/api/v1/oauth/link",Vo=()=>"/api/v1/siwe/unlink",Bo=()=>"/api/v1/passwordless/unlink",Ho=()=>"/api/v1/passwordless_sms/unlink",zo=()=>"/api/v1/oauth/unlink";var ki=30,it=class{constructor(){this.authenticateOnce=new se(async e=>this._authenticate(e)),this.linkOnce=new se(async e=>this._link(e)),this.refreshOnce=new se(this._refresh.bind(this)),this.destroyOnce=new se(this._destroy.bind(this)),this.forkSessionOnce=new se(this._forkSession.bind(this))}get token(){try{let e=E.get(Pe);return typeof e=="string"?new Y(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=E.get(tt);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=Y.parse(this.token);return e!==null&&!e.isExpired(ki)}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:Q(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),V(o)}}async _link(e){try{let o=await e.link();return Q(o)}catch(o){throw console.warn("Error linking account"),V(o)}}async _refresh(){if(!this.api)throw new u("Session has no API instance");if(!this.client)throw new u("Session has no PrivyClient instance");let e=await this.client.getAccessToken({disableAutoRefresh:!0}),o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(ko(),{refresh_token:o},{headers:{authorization:`Bearer ${this.token}`}});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),Q(r.data.user)}catch(r){if(r instanceof ke&&r.status===400&&r.message==="Invalid auth token")return this.destroyLocalState(),null;throw V(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 u("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(Po(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw V(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),E.del(Z)}storeToken(e){typeof e=="string"?E.put(Pe,e):E.del(Pe)}storeRefreshToken(e){typeof e=="string"?E.put(tt,e):E.del(tt)}};import{getAddress as Ri}from"@ethersproject/address";import $o from"@walletconnect/web3-provider";import{ErrorCode as _i}from"@ethersproject/logger";var Se=class extends G{constructor(){super("Wallet timeout");this.type="wallet_error"}},nt=t=>{if(t instanceof G)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new Te(t);return t.code===_i.ACTION_REJECTED&&(e.details=ge.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new Te(t):new G("Unknown connector error",t)},$t=class extends H{constructor(o,r,i){super(o);this.type="provider_error";this.code=r,this.data=i}},Te=class extends $t{constructor(o){var n,s,c;let r=o;super(r.message,r.code,r.data);let i=Object.values(ge).find(h=>h.eipCode===r.code);this.details=i||ge.UNKNOWN_ERROR,r.code===-32002&&((n=r.message)!=null&&n.includes("already pending for origin")?(s=r.message)!=null&&s.includes("wallet_requestPermissions")?this.details=ge.E32002_CONNECTION_ALREADY_PENDING:this.details=ge.E32002_REQUEST_ALREADY_PENDING:(c=r.message)!=null&&c.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=ge.E32002_WALLET_LOCKED))}},Pi={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}},Si={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}},Ti={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}},ge={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Ti,...Si},st={...Pi,...ge};var Ii=12e4,Zt=(t=new Se,e=Ii)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),we=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})}request(e){if(!this.walletProvider)throw new G(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),Zt()]).catch(o=>{throw nt(o)})}},ye=class extends we{constructor(o){super(o)}},at=class extends we{constructor(e){super(e)}sendAsync(e,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};import{Web3Provider as Mi}from"@ethersproject/providers";var jo=["metamask","coinbase_wallet","wallet_connect"];import Wi from"@coinbase/wallet-sdk";import{isMobile as Ni}from"react-device-detect";var Oi=()=>{let t=`https://mainnet.infura.io/v3/${et}`,e=1;return new Wi({appName:"Privy",darkMode:!1,headlessMode:!1}).makeWeb3Provider(t,e)},Kt=()=>{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},lt=()=>{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},Ve=class{constructor(){this.walletType=null;this.getEthereumProvider=()=>this.ethProvider;this.createSiweMessage=(e,o,r,i,n,s,c)=>`${r} wants you to sign in with your Ethereum account:
|
|
2
2
|
${o}
|
|
3
3
|
|
|
4
4
|
${c}
|
|
@@ -9,7 +9,7 @@ Chain ID: ${e}
|
|
|
9
9
|
Nonce: ${s}
|
|
10
10
|
Issued At: ${n}
|
|
11
11
|
Resources:
|
|
12
|
-
- https://privy.io`;this.ethProvider=new we}initialize(){let e=E.get(ot);jo.includes(e)&&(this.walletType=e,this.connect({showPrompt:!1}))}destroy(){this.walletType=null,E.del(ot),E.del(Ao)}async getConnectedWallet(){let e=this.walletType;if(!e||!await this.isConnected())return null;let o=await this.address(),r=await this.chainId();return{address:o,chainId:r,chainType:"ethereum",walletType:e}}async connect(e){var o;switch(this.walletType){case"metamask":this.ethProvider.setProvider(window.ethereum),(o=window.ethereum.providers)==null||o.forEach(async i=>{i.isMetaMask&&this.ethProvider.setProvider(i)});break;case"coinbase_wallet":this.ethProvider.setProvider(Ni());break;case"wallet_connect":let r=new $o({infuraId:et});this.ethProvider.setProvider(r);break;default:throw new G(`Unsupported wallet: ${this.walletType}`)}return(!await this.isConnected()||e.showPrompt)&&await this.promptConnection(this.walletType),this.getConnectedWallet()}async isConnected(){switch(this.walletType){case"metamask":return await this.address()!==null;case"coinbase_wallet":return await this.address()!==null;case"wallet_connect":return this.ethProvider.walletProvider.connected;default:throw new G(`Unsupported wallet: ${this.walletType}`)}}async promptConnection(e){try{switch(e){case"metamask":await this.ethProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]}),await this.ethProvider.request({method:"eth_requestAccounts"});break;case"coinbase_wallet":await this.ethProvider.request({method:"eth_requestAccounts"});break;case"wallet_connect":let o=new $o({infuraId:et});this.ethProvider.setProvider(o),await Promise.race([o.enable(),Zt()]);break;default:throw new G(`Unsupported wallet: ${this.walletType}`)}E.put(ot,e)}catch(o){throw nt(o)}}async sign(e){return new Mi(new ye(this.getEthereumProvider())).getSigner().signMessage(e)}prepareMessage(e,o,r){let i=window.location.host,n=window.location.origin,s="By signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.",c=new Date().toISOString();return this.createSiweMessage(e,o,i,n,c,r,s)}async chainId(){let e=await this.getEthereumProvider().request({method:"eth_chainId"}),o=Number(e);return String(o)}async address(){let e=await this.getEthereumProvider().request({method:"eth_accounts"});return Array.isArray(e)&&e.length>0?Ri(e[0]):null}};var qt,Be=class{constructor(e){let o=e.apiURL||Co,r=e.timeout||Lo;this.appId=e.appId,this.connector=new Ve,this.connector.initialize(),qt||(qt=new it),this.session=qt,this.api=new rt(e.appId,this,{baseURL:o,timeout:r}),this.session.api=this.api,this.session.client=this}authenticate(){if(!this.authFlow)throw new u("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new u("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.connector.destroy(),this.authFlow=void 0}startAuthFlow(e){e.api=this.api,this.authFlow=e}async unlinkEmail(e){try{let o=await this.api.post(Bo(),{address:e});return Q(o.data)}catch(o){throw V(o)}}async unlinkPhone(e){try{let o=await this.api.post(Ho(),{phoneNumber:e});return Q(o.data)}catch(o){throw V(o)}}async unlinkWallet(e){try{let o=await this.api.post(Vo(),{address:e});return Q(o.data)}catch(o){throw V(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(zo(),{provider:e,subject:o});return Q(r.data)}catch(r){throw V(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){var o;return this.session.hasActiveToken()?((o=Y.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,ctaText:e.data.allowlist_config.cta_text,ctaLink: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 V(e)}}setActiveWallet(e,o){if(!o.linkedAccounts.map(i=>i.type==="wallet"?i.address:null).includes(e))throw new u("Cannot set an unlinked address as active.");return E.put(Z,e),Ge(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as Ks}from"@ethersproject/providers";import{createContext as Oi,useContext as Ui}from"react";var f=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var Jt=Oi({ready:!1,authenticated:!1,user:null,walletConnector: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}),N=()=>Ui(Jt);var He=class{constructor(e){this.connector=e,this.meta={wallet:this.connector.walletType}}async authenticate(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.connector.walletType)throw new u("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(To(),{message:e,signature:o});return{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 T(e)}}async link(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.connector.walletType)throw new u("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api);return(await this.api.post(Io(),{message:e,signature:o})).data}catch(e){throw T(e)}}async promptConnectAndSign(e){let o=await this.connector.connect({showPrompt:!0}),r=o.address,i=o.chainId,n=await e.post(So(),{address:r}),s=this.connector.prepareMessage(i,r,n.data.nonce),c=await this.connector.sign(s);return{message:s,signature:c}}getEthereumProvider(){return this.connector.getEthereumProvider()}};var ze=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new u("Email and email code must be set prior to calling authenticate.");try{let e=Mo(),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 T(e)}}async link(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new u("Email and email code must be set prior to calling authenticate.");try{let e=Wo();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw T(e)}}async sendCodeEmail(e){if(!this.api)throw new u("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new u("Email must be set when initialzing authentication.");try{let o=Ro();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw T(o)}}};var je=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new u("phone number and sms code must be set prior to calling authenticate.");try{let e=Oo(),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 T(e)}}async link(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new u("phone number and sms code must be set prior to calling authenticate.");try{let e=Uo();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw T(e)}}async sendSmsCode(e){if(!this.api)throw new u("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new u("phone nNumber must be set when initialzing authentication.");try{let o=No();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw T(o)}}};var Ie=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 u("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new u("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new u("User denied confirmation during OAuth flow");try{let e=Fo(),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 T(e)}}async link(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new u("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new u("User denied confirmation during OAuth flow");try{let e=Go();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw T(e)}}async getAuthorizationUrl(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.provider)throw new u("Provider must be set when initialzing OAuth authentication.");try{let e=Do();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw T(e)}}};import"wicg-inert";import Bs from"react-dom";import wo from"styled-components";import{createContext as Fi,useContext as Gi,useEffect as Ko,useState as qo}from"react";import{jsx as Di}from"react/jsx-runtime";function Zo(t){return Di("link",{rel:"prefetch",href:t.src})}import{jsx as Vi,jsxs as Bi}from"react/jsx-runtime";var Jo=Fi({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}),Yo=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=qo("LANDING"),[s,c]=qo("LANDING");Ko(()=>{o||n("LANDING")},[o]),Ko(()=>{r||(c("LANDING"),n("LANDING"))},[r]);let h={ready:!!(e!=null&&e.id),app:e,options:t.options,currentScreen:i,lastScreen:s,navigate:m=>{c(i),n(m)},navigateBack:()=>{n(s)}};return Bi(Jo.Provider,{value:h,children:[e&&e.logoUrl&&Vi(Zo,{src:e.logoUrl}),t.children]})},g=()=>Gi(Jo);import{useEffect as Un,useState as Dn}from"react";import qe from"styled-components";import ji from"styled-components";import{jsx as Qo}from"react/jsx-runtime";var Xo=({style:t,...e})=>Qo("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:Qo("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});import{jsx as er}from"react/jsx-runtime";var tr=({style:t,...e})=>er("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:er("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as Hi,useContext as zi}from"react";var Yt=Hi({isLinking:!1,getAuthMeta:f,getAuthFlow:f,closePrivyModal:f,initLoginWithWallet:f,loginWithWallet:f,loginWithCode:f,initLoginWithEmail:f,initLoginWithSms:f,resendEmailCode:f,resendSmsCode:f,initLoginWithOAuth:f,loginWithOAuth:f,handleLoginError:f}),_=()=>zi(Yt);import{jsx as ee,jsxs as Ji}from"react/jsx-runtime";var $i=()=>ee("div",{}),Zi=({backFn:t})=>ee("div",{children:ee(tr,{onClick:t})}),Ki=t=>ee("div",{children:ee("div",{children:ee(Xo,{onClick:t.onClose})})});var L=({backFn:t,onClose:e})=>{let{closePrivyModal:o}=_();return Ji(qi,{children:[t?ee(Zi,{backFn:t}):ee($i,{}),ee(Ki,{onClose:e||o})]})},qi=ji.div`
|
|
12
|
+
- https://privy.io`;this.ethProvider=new we}initialize(){let e=E.get(ot);jo.includes(e)&&(this.walletType=e,this.connect({showPrompt:!1}))}destroy(){this.walletType=null,E.del(ot),E.del(Ao)}async getConnectedWallet(){let e=this.walletType;if(!e||!await this.isConnected())return null;let o=await this.address(),r=await this.chainId();return{address:o,chainId:r,chainType:"ethereum",walletType:e}}async connect(e){var o;switch(this.walletType){case"metamask":this.ethProvider.setProvider(window.ethereum),(o=window.ethereum.providers)==null||o.forEach(async i=>{i.isMetaMask&&this.ethProvider.setProvider(i)});break;case"coinbase_wallet":this.ethProvider.setProvider(Oi());break;case"wallet_connect":let r=new $o({infuraId:et});this.ethProvider.setProvider(r);break;default:throw new G(`Unsupported wallet: ${this.walletType}`)}return(!await this.isConnected()||e.showPrompt)&&await this.promptConnection(this.walletType),this.getConnectedWallet()}async isConnected(){switch(this.walletType){case"metamask":return await this.address()!==null;case"coinbase_wallet":return await this.address()!==null;case"wallet_connect":return this.ethProvider.walletProvider.connected;default:throw new G(`Unsupported wallet: ${this.walletType}`)}}async promptConnection(e){try{switch(e){case"metamask":Ni||await this.ethProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]}),await this.ethProvider.request({method:"eth_requestAccounts"});break;case"coinbase_wallet":await this.ethProvider.request({method:"eth_requestAccounts"});break;case"wallet_connect":let o=new $o({infuraId:et});this.ethProvider.setProvider(o),await Promise.race([o.enable(),Zt()]);break;default:throw new G(`Unsupported wallet: ${this.walletType}`)}E.put(ot,e)}catch(o){throw nt(o)}}async sign(e){return new Mi(new ye(this.getEthereumProvider())).getSigner().signMessage(e)}prepareMessage(e,o,r){let i=window.location.host,n=window.location.origin,s="By signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.",c=new Date().toISOString();return this.createSiweMessage(e,o,i,n,c,r,s)}async chainId(){let e=await this.getEthereumProvider().request({method:"eth_chainId"}),o=Number(e);return String(o)}async address(){let e=await this.getEthereumProvider().request({method:"eth_accounts"});return Array.isArray(e)&&e.length>0?Ri(e[0]):null}};var qt,Be=class{constructor(e){let o=e.apiURL||Co,r=e.timeout||Lo;this.appId=e.appId,this.connector=new Ve,this.connector.initialize(),qt||(qt=new it),this.session=qt,this.api=new rt(e.appId,this,{baseURL:o,timeout:r}),this.session.api=this.api,this.session.client=this}authenticate(){if(!this.authFlow)throw new u("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new u("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.connector.destroy(),this.authFlow=void 0}startAuthFlow(e){e.api=this.api,this.authFlow=e}async unlinkEmail(e){try{let o=await this.api.post(Bo(),{address:e});return Q(o.data)}catch(o){throw V(o)}}async unlinkPhone(e){try{let o=await this.api.post(Ho(),{phoneNumber:e});return Q(o.data)}catch(o){throw V(o)}}async unlinkWallet(e){try{let o=await this.api.post(Vo(),{address:e});return Q(o.data)}catch(o){throw V(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(zo(),{provider:e,subject:o});return Q(r.data)}catch(r){throw V(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){var o;return this.session.hasActiveToken()?((o=Y.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,ctaText:e.data.allowlist_config.cta_text,ctaLink: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 V(e)}}setActiveWallet(e,o){if(!o.linkedAccounts.map(i=>i.type==="wallet"?i.address:null).includes(e))throw new u("Cannot set an unlinked address as active.");return E.put(Z,e),Ge(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as qs}from"@ethersproject/providers";import{createContext as Ui,useContext as Di}from"react";var f=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var Jt=Ui({ready:!1,authenticated:!1,user:null,walletConnector: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}),N=()=>Di(Jt);var He=class{constructor(e){this.connector=e,this.meta={wallet:this.connector.walletType}}async authenticate(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.connector.walletType)throw new u("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(To(),{message:e,signature:o});return{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 T(e)}}async link(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.connector.walletType)throw new u("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api);return(await this.api.post(Io(),{message:e,signature:o})).data}catch(e){throw T(e)}}async promptConnectAndSign(e){let o=await this.connector.connect({showPrompt:!0}),r=o.address,i=o.chainId,n=await e.post(So(),{address:r}),s=this.connector.prepareMessage(i,r,n.data.nonce),c=await this.connector.sign(s);return{message:s,signature:c}}getEthereumProvider(){return this.connector.getEthereumProvider()}};var ze=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new u("Email and email code must be set prior to calling authenticate.");try{let e=Mo(),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 T(e)}}async link(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new u("Email and email code must be set prior to calling authenticate.");try{let e=Wo();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw T(e)}}async sendCodeEmail(e){if(!this.api)throw new u("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new u("Email must be set when initialzing authentication.");try{let o=Ro();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw T(o)}}};var je=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new u("phone number and sms code must be set prior to calling authenticate.");try{let e=Oo(),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 T(e)}}async link(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new u("phone number and sms code must be set prior to calling authenticate.");try{let e=Uo();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw T(e)}}async sendSmsCode(e){if(!this.api)throw new u("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new u("phone nNumber must be set when initialzing authentication.");try{let o=No();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw T(o)}}};var Ie=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 u("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new u("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new u("User denied confirmation during OAuth flow");try{let e=Fo(),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 T(e)}}async link(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new u("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new u("User denied confirmation during OAuth flow");try{let e=Go();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw T(e)}}async getAuthorizationUrl(){if(!this.api)throw new u("Auth flow has no API instance");if(!this.meta.provider)throw new u("Provider must be set when initialzing OAuth authentication.");try{let e=Do();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw T(e)}}};import"wicg-inert";import Hs from"react-dom";import wo from"styled-components";import{createContext as Gi,useContext as Vi,useEffect as Ko,useState as qo}from"react";import{jsx as Fi}from"react/jsx-runtime";function Zo(t){return Fi("link",{rel:"prefetch",href:t.src})}import{jsx as Bi,jsxs as Hi}from"react/jsx-runtime";var Jo=Gi({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}),Yo=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=qo("LANDING"),[s,c]=qo("LANDING");Ko(()=>{o||n("LANDING")},[o]),Ko(()=>{r||(c("LANDING"),n("LANDING"))},[r]);let h={ready:!!(e!=null&&e.id),app:e,options:t.options,currentScreen:i,lastScreen:s,navigate:m=>{c(i),n(m)},navigateBack:()=>{n(s)}};return Hi(Jo.Provider,{value:h,children:[e&&e.logoUrl&&Bi(Zo,{src:e.logoUrl}),t.children]})},g=()=>Vi(Jo);import{useEffect as Dn,useState as Fn}from"react";import qe from"styled-components";import $i from"styled-components";import{jsx as Qo}from"react/jsx-runtime";var Xo=({style:t,...e})=>Qo("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:Qo("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});import{jsx as er}from"react/jsx-runtime";var tr=({style:t,...e})=>er("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:er("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as zi,useContext as ji}from"react";var Yt=zi({isLinking:!1,getAuthMeta:f,getAuthFlow:f,closePrivyModal:f,initLoginWithWallet:f,loginWithWallet:f,loginWithCode:f,initLoginWithEmail:f,initLoginWithSms:f,resendEmailCode:f,resendSmsCode:f,initLoginWithOAuth:f,loginWithOAuth:f,handleLoginError:f}),_=()=>ji(Yt);import{jsx as ee,jsxs as Yi}from"react/jsx-runtime";var Zi=()=>ee("div",{}),Ki=({backFn:t})=>ee("div",{children:ee(tr,{onClick:t})}),qi=t=>ee("div",{children:ee("div",{children:ee(Xo,{onClick:t.onClose})})});var L=({backFn:t,onClose:e})=>{let{closePrivyModal:o}=_();return Yi(Ji,{children:[t?ee(Ki,{backFn:t}):ee(Zi,{}),ee(qi,{onClose:e||o})]})},Ji=$i.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 nr from"styled-components";import{jsx as U,jsxs as
|
|
69
|
+
`;import nr from"styled-components";import{jsx as U,jsxs as Qi}from"react/jsx-runtime";var be=({style:t,...e})=>Qi("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:[U("rect",{width:"28",height:"28",rx:"6",fill:"white"}),U("path",{d:"M23.0126 5L15.1958 10.7823L16.6533 7.37359L23.0126 5Z",fill:"#E17726",stroke:"#E17726",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("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"}),U("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"}),U("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"}),U("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"}),U("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"}),U("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"}),U("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"}),U("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"}),U("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"}),U("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"}),U("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 or,jsxs as Xi}from"react/jsx-runtime";var de=({style:t,...e})=>Xi("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:[or("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),or("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 Re,jsxs as en}from"react/jsx-runtime";var dt=({style:t,...e})=>en("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:[Re("rect",{width:"28",height:"28",rx:"6",fill:"#141414"}),Re("g",{clipPath:"url(#clip0_1765_9946)",children:Re("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"})}),Re("defs",{children:Re("clipPath",{id:"clip0_1765_9946",children:Re("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]});import{isMobile as ir}from"react-device-detect";import{isIOS as tn,isMobile as on}from"react-device-detect";var Qt=t=>{let e=new URL(window.location.href);if(!window.ethereum&&on){let o;switch(t){case"metamask":tn?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 rn from"styled-components";var rr=rn.span`
|
|
70
70
|
@media (max-width: 440px) {
|
|
71
71
|
display: none;
|
|
72
72
|
}
|
|
73
|
-
`;import{jsx as te,jsxs as $e}from"react/jsx-runtime";var ct=()=>{let{navigate:t}=g(),{initLoginWithWallet:e,closePrivyModal:o}=_();return $e(
|
|
73
|
+
`;import{jsx as te,jsxs as $e}from"react/jsx-runtime";var ct=()=>{let{navigate:t}=g(),{initLoginWithWallet:e,closePrivyModal:o}=_();return $e(nn,{children:[$e(Xt,{onClick:()=>{Kt()?(e("metamask"),t("AWAITING_CONNECTION")):ir?(Qt("metamask"),o()):t("INSTALL_METAMASK_SCREEN")},children:[te(be,{}),te("span",{children:"Metamask"}),te("span",{children:Kt()?"Connect":"Install"})]}),$e(Xt,{onClick:()=>{lt()?(e("coinbase_wallet"),t("AWAITING_CONNECTION")):ir?(Qt("coinbase_wallet"),o()):(e("coinbase_wallet"),t("AWAITING_CONNECTION"))},children:[te(de,{}),$e("span",{children:["Coinbase",te(rr,{children:" Wallet"})]}),te("span",{children:"Connect"})]}),$e(Xt,{onClick:()=>{e("wallet_connect"),t("AWAITING_CONNECTION")},children:[te(dt,{}),te("span",{children:"WalletConnect"}),te("span",{children:"Connect"})]})]})},nn=nr.div`
|
|
74
74
|
display: flex;
|
|
75
75
|
flex-direction: column;
|
|
76
76
|
align-items: flex-start;
|
|
@@ -147,7 +147,7 @@ Resources:
|
|
|
147
147
|
:hover > :last-child {
|
|
148
148
|
opacity: 1;
|
|
149
149
|
}
|
|
150
|
-
`;import
|
|
150
|
+
`;import sn from"styled-components";import{jsx as sr,jsxs as ln}from"react/jsx-runtime";var ut=()=>{let{navigate:t}=g();return ln(an,{children:[sr("span",{children:"Don\u2019t have a wallet? "}),sr("button",{onClick:()=>{t("WALLET_EDUCATION")},children:"Create one now."})]})},an=sn.div`
|
|
151
151
|
font-size: 13px;
|
|
152
152
|
color: var(--light-theme-fg-3);
|
|
153
153
|
|
|
@@ -158,7 +158,7 @@ Resources:
|
|
|
158
158
|
@media (max-width: 440px) {
|
|
159
159
|
margin-top: 4px;
|
|
160
160
|
}
|
|
161
|
-
`;import dr from"styled-components";import{jsx as ar}from"react/jsx-runtime";var lr=({style:t,...e})=>ar("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:ar("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
|
|
161
|
+
`;import dr from"styled-components";import{jsx as ar}from"react/jsx-runtime";var lr=({style:t,...e})=>ar("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:ar("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 cn,jsx as Me,jsxs as ur}from"react/jsx-runtime";var dn=dr.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 cr(t){let{privacyPolicyUrl:e,termsAndConditionsUrl:o}=t.app,r=!!e,i=!!o,n=r&&i;return!r&&!i?null:ur(
|
|
170
|
+
`;function cr(t){let{privacyPolicyUrl:e,termsAndConditionsUrl:o}=t.app,r=!!e,i=!!o,n=r&&i;return!r&&!i?null:ur(dn,{children:["By logging in I agree to the"," ",i&&Me("a",{href:o,target:"_blank",children:n?"Terms":"Terms of Service"}),n&&" & ",r&&Me("a",{href:e,target:"_blank",children:"Privacy Policy"})]})}var K=({protectedByPrivy:t})=>Me(oe,{hideOnMobile:t,children:t?ur(cn,{children:[Me(lr,{}),Me("span",{children:Me("a",{href:"https://www.privy.io/",target:"_blank",children:"Protected by Privy"})})]}):null}),oe=dr.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 Ke from"styled-components";import{jsx as mr}from"react/jsx-runtime";var pt=({style:t,logoFill:e,...o})=>mr("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:mr("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 Ze,jsxs as
|
|
207
|
+
`;import Ke from"styled-components";import{jsx as mr}from"react/jsx-runtime";var pt=({style:t,logoFill:e,...o})=>mr("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:mr("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 Ze,jsxs as un}from"react/jsx-runtime";var ht=({logoFill:t,style:e,...o})=>un("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:[Ze("g",{clipPath:"url(#clip0)",children:Ze("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"})}),Ze("defs",{children:Ze("clipPath",{id:"clip0",children:Ze("rect",{width:"71",height:"55",fill:"white"})})})]});import{jsx as fr}from"react/jsx-runtime";var mt=({logoFill:t,style:e,...o})=>fr("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:fr("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 ft,jsxs as pn}from"react/jsx-runtime";var gt=({style:t,...e})=>pn("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:[ft("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"}),ft("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"}),ft("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"}),ft("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 ue,jsxs as yn}from"react/jsx-runtime";var gr=({showGoogle:t,showTwitter:e,showDiscord:o,showGithub:r,stacked:i})=>{let{initLoginWithOAuth:n}=_();return yn(hn,{stacked:i,children:[t&&ue(wn,{onClick:()=>{n("google")},children:ue(gt,{})}),e&&ue(mn,{onClick:()=>{n("twitter")},children:ue(pt,{})}),o&&ue(fn,{onClick:()=>{n("discord")},children:ue(ht,{})}),r&&ue(gn,{onClick:()=>{n("github")},children:ue(mt,{})})]})},hn=Ke.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
|
-
`,
|
|
213
|
+
`,mn=Ke.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
|
-
`,
|
|
225
|
+
`,fn=Ke.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
|
-
`,
|
|
237
|
+
`,gn=Ke.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
|
-
`,
|
|
249
|
+
`,wn=Ke.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
|
|
262
|
+
`;import{useEffect as xn,useState as eo}from"react";import We from"styled-components";import{jsx as wr}from"react/jsx-runtime";var wt=({style:t,...e})=>wr("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:wr("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 bn from"styled-components";import{jsx as vn}from"react/jsx-runtime";var yt=({success:t,fail:e})=>vn(pe,{className:t?"success":e?"fail":""}),pe=bn.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{isPossiblePhoneNumber as
|
|
295
|
+
`;import{isPossiblePhoneNumber as Cn}from"libphonenumber-js/min";var yr=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,}))$/),br=t=>Cn(String(t),"US"),bt=t=>{var e=/^#?([a-f\d])([a-f\d])([a-f\d])$/i;t=t.replace(e,function(r,i,n,s){return i+i+n+n+s+s});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)}},vr=(t,e)=>{var o=t.slice(0);let r=[];for(;o.length;)r.push(o.splice(0,e));return r};import{Fragment as Sn,jsx as re,jsxs as to}from"react/jsx-runtime";var vt=t=>{let[e,o]=eo(""),[r,i]=eo(!1),[n,s]=eo(null),{authenticated:c}=N(),{initLoginWithEmail:h,handleLoginError:m}=_(),{navigate:x,options:R}=g(),v=R.wallet;xn(()=>{let l=document.querySelector("#email-input");l==null||l.focus()},[]);let A=yr(e),P=()=>{i(!0),h(e).then(()=>{x("AWAITING_PASSWORDLESS_CODE")}).catch(l=>{let y=(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?s(l.message):y?x("ALLOWLIST_REJECTION_SCREEN"):s("Issue submitting email"),i(!1),m(y)})};return to(Sn,{children:[to(Ln,{stacked:t.stacked,children:[to(kn,{standalone:t.stacked,children:[re(wt,{}),re("input",{id:"email-input",type:"email",placeholder:"your@email.com",onChange:l=>o(l.target.value),onKeyUp:l=>{l.key==="Enter"&&P()},value:e,autoComplete:"email"})]}),t.stacked?null:re(An,{disabled:r||!A,onClick:P,children:r?re(pe,{color:"var(--disabled-fg)",style:{height:"1rem",width:"1rem",borderWidth:"2px"}}):"Submit"})]}),n||c||!v?re(Pn,{fail:!!n,children:n||""}):null,!n&&!c&&v?re(_n,{children:re("span",{children:"Get started without a wallet."})}):null,t.stacked?re(En,{disabled:r||!A,onClick:P,children:r?re(pe,{color:"var(--disabled-fg)",style:{height:"1rem",width:"1rem",borderWidth:"2px"}}):"Submit"}):null]})},Ln=We.div`
|
|
296
296
|
display: flex;
|
|
297
297
|
border: 1px solid var(--border-color-1);
|
|
298
298
|
width: 100%;
|
|
@@ -306,7 +306,7 @@ Resources:
|
|
|
306
306
|
@media (max-width: 440px) {
|
|
307
307
|
margin-top: 20px;
|
|
308
308
|
}
|
|
309
|
-
`,
|
|
309
|
+
`,An=We.button`
|
|
310
310
|
display: flex;
|
|
311
311
|
flex-direction: row;
|
|
312
312
|
align-items: center;
|
|
@@ -331,7 +331,7 @@ Resources:
|
|
|
331
331
|
color: var(--disabled-fg);
|
|
332
332
|
cursor: not-allowed;
|
|
333
333
|
}
|
|
334
|
-
`,
|
|
334
|
+
`,En=We.button`
|
|
335
335
|
display: flex;
|
|
336
336
|
flex-direction: column;
|
|
337
337
|
align-items: center;
|
|
@@ -355,7 +355,7 @@ Resources:
|
|
|
355
355
|
color: var(--disabled-fg);
|
|
356
356
|
cursor: not-allowed;
|
|
357
357
|
}
|
|
358
|
-
`,
|
|
358
|
+
`,kn=We.label`
|
|
359
359
|
display: flex;
|
|
360
360
|
flex-direction: row;
|
|
361
361
|
align-items: center;
|
|
@@ -392,7 +392,7 @@ Resources:
|
|
|
392
392
|
line-height: 24px;
|
|
393
393
|
}
|
|
394
394
|
}
|
|
395
|
-
`,
|
|
395
|
+
`,_n=We.div`
|
|
396
396
|
font-size: 13px;
|
|
397
397
|
color: var(--light-theme-fg-3);
|
|
398
398
|
text-align: left;
|
|
@@ -400,7 +400,7 @@ Resources:
|
|
|
400
400
|
> button {
|
|
401
401
|
text-decoration: underline;
|
|
402
402
|
}
|
|
403
|
-
`,
|
|
403
|
+
`,Pn=We.div`
|
|
404
404
|
line-height: 20px;
|
|
405
405
|
height: 20px;
|
|
406
406
|
font-size: 13px;
|
|
@@ -412,7 +412,7 @@ Resources:
|
|
|
412
412
|
opacity: ${t=>t.success||t.fail?"1":"0"};
|
|
413
413
|
|
|
414
414
|
transition: ${t=>t.fail?"":"all 150ms ease-in-out"};
|
|
415
|
-
`;import{useEffect as
|
|
415
|
+
`;import{useEffect as Tn,useState as oo}from"react";import ve from"styled-components";import{jsx as Cr}from"react/jsx-runtime";var Ct=({style:t,...e})=>Cr("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:Cr("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 Un,jsx as ie,jsxs as ro}from"react/jsx-runtime";var xt=t=>{let[e,o]=oo(""),[r,i]=oo(!1),[n,s]=oo(null),{authenticated:c}=N(),{initLoginWithSms:h,handleLoginError:m}=_(),{navigate:x,options:R}=g(),v=R.wallet;Tn(()=>{let l=document.querySelector("#phone-number-input");l==null||l.focus()},[]);let A=br(e),P=()=>{i(!0),h(e).then(()=>{x("AWAITING_PASSWORDLESS_CODE")}).catch(l=>{let y=(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?s(l.message):y?x("ALLOWLIST_REJECTION_SCREEN"):s("Issue submitting phone number"),i(!1),m(y)})};return ro(Un,{children:[ro(In,{stacked:t.stacked,children:[ro(Wn,{standalone:t.stacked,children:[ie(Ct,{}),ie("input",{id:"phone-number-input",type:"tel",placeholder:"555 555 5555",onChange:l=>{o(l.target.value)},onKeyUp:l=>{l.key==="Enter"&&P()},value:e,autoComplete:"tel"})]}),t.stacked?null:ie(Rn,{disabled:r||!A,onClick:P,children:r?ie(xr,{color:"var(--disabled-fg)"}):"Submit"})]}),n||c||!v?ie(On,{fail:!!n,children:n||""}):null,!n&&!c&&v?ie(Nn,{children:ie("span",{children:"Don\u2019t have a wallet? Start exploring with your phone or socials."})}):null,t.stacked?ie(Mn,{disabled:r||!A,onClick:P,children:r?ie(xr,{color:"var(--disabled-fg)"}):"Submit"}):null]})},In=ve.div`
|
|
416
416
|
display: flex;
|
|
417
417
|
border: 1px solid var(--border-color-1);
|
|
418
418
|
width: 100%;
|
|
@@ -426,7 +426,7 @@ Resources:
|
|
|
426
426
|
@media (max-width: 440px) {
|
|
427
427
|
margin-top: 20px;
|
|
428
428
|
}
|
|
429
|
-
`,
|
|
429
|
+
`,Rn=ve.button`
|
|
430
430
|
display: flex;
|
|
431
431
|
flex-direction: row;
|
|
432
432
|
align-items: center;
|
|
@@ -451,7 +451,7 @@ Resources:
|
|
|
451
451
|
color: var(--disabled-fg);
|
|
452
452
|
cursor: not-allowed;
|
|
453
453
|
}
|
|
454
|
-
`,
|
|
454
|
+
`,Mn=ve.button`
|
|
455
455
|
display: flex;
|
|
456
456
|
flex-direction: column;
|
|
457
457
|
align-items: center;
|
|
@@ -475,7 +475,7 @@ Resources:
|
|
|
475
475
|
color: var(--disabled-fg);
|
|
476
476
|
cursor: not-allowed;
|
|
477
477
|
}
|
|
478
|
-
`,
|
|
478
|
+
`,Wn=ve.label`
|
|
479
479
|
display: flex;
|
|
480
480
|
flex-direction: row;
|
|
481
481
|
align-items: center;
|
|
@@ -512,14 +512,14 @@ Resources:
|
|
|
512
512
|
line-height: 24px;
|
|
513
513
|
}
|
|
514
514
|
}
|
|
515
|
-
`,
|
|
515
|
+
`,Nn=ve.div`
|
|
516
516
|
font-size: 13px;
|
|
517
517
|
color: var(--light-theme-fg-3);
|
|
518
518
|
|
|
519
519
|
> button {
|
|
520
520
|
text-decoration: underline;
|
|
521
521
|
}
|
|
522
|
-
`,
|
|
522
|
+
`,On=ve.div`
|
|
523
523
|
line-height: 20px;
|
|
524
524
|
height: 20px;
|
|
525
525
|
font-size: 13px;
|
|
@@ -537,7 +537,7 @@ Resources:
|
|
|
537
537
|
width: 1rem;
|
|
538
538
|
border-width: 2px;
|
|
539
539
|
}
|
|
540
|
-
`;import{jsx as Lr}from"react/jsx-runtime";var Ar=()=>{let{app:t}=g();return t!=null&&t.logoUrl?Lr("div",{children:Lr("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{isMobile as Er}from"react-device-detect";import{Fragment as Ce,jsx as C,jsxs as he}from"react/jsx-runtime";var _r=()=>{let{ready:t}=N(),{getAuthMeta:e,isLinking:o}=_(),{app:r,navigate:i,options:n}=g(),s=n.email,c=n.sms,h=n.wallet,m=n.google,x=n.twitter,R=n.discord,v=n.github,A=h&&(r==null?void 0:r.showWalletLoginFirst)?0:1,[P,l]=
|
|
540
|
+
`;import{jsx as Lr}from"react/jsx-runtime";var Ar=()=>{let{app:t}=g();return t!=null&&t.logoUrl?Lr("div",{children:Lr("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{isMobile as Er}from"react-device-detect";import{Fragment as Ce,jsx as C,jsxs as he}from"react/jsx-runtime";var _r=()=>{let{ready:t}=N(),{getAuthMeta:e,isLinking:o}=_(),{app:r,navigate:i,options:n}=g(),s=n.email,c=n.sms,h=n.wallet,m=n.google,x=n.twitter,R=n.discord,v=n.github,A=h&&(r==null?void 0:r.showWalletLoginFirst)?0:1,[P,l]=Fn(A),y=e(),F=(y==null?void 0:y.authorizationCode)&&(y==null?void 0:y.stateCode)&&(y==null?void 0:y.provider);Dn(()=>{F?i("AWAITING_OAUTH_SCREEN"):o&&s?i("LINK_EMAIL_SCREEN"):o&&c?i("LINK_PHONE_SCREEN"):o&&h&&i("LINK_WALLET_SCREEN")},[t]);let fe=P==0,W=P==1,J=()=>C(Ce,{children:h&&C(Gn,{active:fe,onClick:()=>l(0)})}),b=()=>C(Ce,{children:(s||c)&&C(Vn,{active:W,onClick:()=>l(1),email:s,sms:c,google:m,twitter:x,discord:R,github:v})});return he(Ce,{children:[C(L,{},"header"),C(zn,{walletOnly:!s&&!c&&!m&&!x&&!R&&!v,hasTerms:!!((r==null?void 0:r.privacyPolicyUrl)||(r==null?void 0:r.termsAndConditionsUrl)),children:C(Ar,{})}),C(ce,{children:r!=null&&r.showWalletLoginFirst?he(Ce,{children:[C(J,{}),C(b,{})]}):he(Ce,{children:[C(b,{}),C(J,{})]})}),r&&C(cr,{app:r}),C(K,{protectedByPrivy:!0})]})};function Gn(t){return he(Sr,{active:t.active,onClick:t.onClick,children:[C(Pr,{active:t.active,children:C("h4",{children:"Connect Wallet"})}),t.active&&he(Ce,{children:[C(ct,{}),C(ut,{})]})]})}function Vn(t){let e=t.google||t.discord||t.github||t.twitter&&!Er,o=t.email?"Email":"Phone";return he(Sr,{active:t.active,onClick:t.onClick,children:[C(Pr,{active:t.active,children:C("h4",{children:e?`${o} & Social`:o})}),t.active&&t.email&&C(vt,{}),t.active&&t.sms&&!t.email&&C(xt,{}),t.active&&e&&C(Bn,{google:t.google,twitter:t.twitter&&!Er,discord:t.discord,github:t.github})]})}function Bn(t){return he(Ce,{children:[he(Hn,{children:[C(kr,{}),C("p",{children:" Or "}),C(kr,{})]}),C(gr,{showGoogle:t.google,showDiscord:t.discord,showGithub:t.github,showTwitter:t.twitter})]})}var Pr=qe.div`
|
|
541
541
|
font-weight: ${t=>t.active?600:500};
|
|
542
542
|
color: ${t=>t.active?"inherit":"var(--light-theme-fg-3)"};
|
|
543
543
|
display: flex;
|
|
@@ -564,7 +564,7 @@ Resources:
|
|
|
564
564
|
}
|
|
565
565
|
|
|
566
566
|
cursor: ${t=>t.active?"inherit":"pointer"};
|
|
567
|
-
`,
|
|
567
|
+
`,Hn=qe.div`
|
|
568
568
|
display: flex;
|
|
569
569
|
justify-content: center;
|
|
570
570
|
align-items: center;
|
|
@@ -575,7 +575,7 @@ Resources:
|
|
|
575
575
|
border-top: 1px solid var(--border-color-1);
|
|
576
576
|
margin: 0px 8px;
|
|
577
577
|
}
|
|
578
|
-
`,
|
|
578
|
+
`,zn=qe.div`
|
|
579
579
|
display: flex;
|
|
580
580
|
flex-direction: column;
|
|
581
581
|
align-items: center;
|
|
@@ -597,7 +597,7 @@ Resources:
|
|
|
597
597
|
margin-bottom: ${t=>`${60+(t.walletOnly?31:0)-(t.hasTerms?18:0)}px`};
|
|
598
598
|
`;import{useEffect as Mr,useState as At}from"react";import Et from"styled-components";import Lt from"styled-components";import{jsx as Je,jsxs as Rr}from"react/jsx-runtime";var xe=({title:t,description:e,children:o,...r})=>Rr(Ir,{...r,children:[Je("h3",{children:t}),typeof e=="string"?Je("p",{children:e}):null,o]}),Tr=Lt(xe)`
|
|
599
599
|
margin-bottom: 24px;
|
|
600
|
-
`,Ne=({title:t,description:e,icon:o,children:r,...i})=>Rr(
|
|
600
|
+
`,Ne=({title:t,description:e,icon:o,children:r,...i})=>Rr(jn,{...i,children:[o?Je($n,{children:o}):null,Je("h3",{children:t}),typeof e=="string"?Je("p",{children:e}):null,r]}),Ir=Lt.div`
|
|
601
601
|
display: flex;
|
|
602
602
|
flex-direction: column;
|
|
603
603
|
justify-content: flex-start;
|
|
@@ -616,7 +616,7 @@ Resources:
|
|
|
616
616
|
color: var(--light-theme-fg-2);
|
|
617
617
|
font-size: 14px;
|
|
618
618
|
}
|
|
619
|
-
`,
|
|
619
|
+
`,jn=Lt(Ir)`
|
|
620
620
|
align-items: center;
|
|
621
621
|
text-align: center;
|
|
622
622
|
gap: 16px;
|
|
@@ -624,21 +624,21 @@ Resources:
|
|
|
624
624
|
h3 {
|
|
625
625
|
margin-bottom: 24px;
|
|
626
626
|
}
|
|
627
|
-
|
|
627
|
+
`,$n=Lt.div`
|
|
628
628
|
padding: 14px;
|
|
629
629
|
border-radius: 50%;
|
|
630
630
|
&& {
|
|
631
631
|
border-color: var(--light-theme-bg-3);
|
|
632
632
|
border-width: 1px;
|
|
633
633
|
}
|
|
634
|
-
`;import{Fragment as io,jsx as B,jsxs as Oe}from"react/jsx-runtime";var no=6,Wr=new Array(no).fill("")
|
|
634
|
+
`;import{Fragment as io,jsx as B,jsxs as Oe}from"react/jsx-runtime";var no=6,Wr=new Array(no).fill(""),Zn=1400;var Nr=()=>{var b,a,d;let{app:t}=g(),{closePrivyModal:e,resendEmailCode:o,resendSmsCode:r,getAuthMeta:i,loginWithCode:n}=_(),{authenticated:s,user:c}=N(),[h,m]=At(Wr),[x,R]=At(!1),[v,A]=At(null),[P,l]=At(null),y=(b=i())!=null&&b.email?0:1;Mr(()=>{if(s&&x){let k=setTimeout(e,_e);return()=>clearTimeout(k)}},[s,x,c]),Mr(()=>{if(v&&P===0){let k=setTimeout(()=>{m(Wr),A(null);let S=document.querySelector("input[name=code-0]");S==null||S.focus()},Zn);return()=>clearTimeout(k)}},[v]);let F=k=>{var bo;let S=k.currentTarget.value.replace(" ","");if(S==="")return;if(isNaN(Number(S))){A("Code should be numeric"),l(1);return}A(null),l(null);let j=Number((bo=k.currentTarget.name)==null?void 0:bo.charAt(5)),Ft=[...S||[""]].slice(0,no-j),Gt=[...h.slice(0,j),...Ft,...h.slice(j+Ft.length)];m(Gt);let vi=Ft.length,yo=Math.min(Math.max(j+vi,0),no-1);if(!isNaN(Number(k.currentTarget.value))){let $=document.querySelector(`input[name=code-${yo}]`);$==null||$.focus()}if(Gt.every($=>$&&!isNaN(+$))){let $=document.querySelector(`input[name=code-${yo}]`);$==null||$.blur(),n(Gt.join("")).then(()=>R(!0)).catch(Vt=>{(Vt==null?void 0:Vt.status)===422?A("Invalid or expired verification code"):A("Issue verifying code"),l(0)})}k.preventDefault()},fe=k=>{P===1&&(A(null),l(null));let S=[...h.slice(0,k),"",...h.slice(k+1)];if(m(S),k>0){let j=document.querySelector(`input[name=code-${k-1}]`);j==null||j.focus()}},W=`Verify your ${y==0?"email":"phone"}`,J=y==0?`Please check ${(a=i())==null?void 0:a.email} for an email from privy.io and enter your code below.`:`Please check ${(d=i())==null?void 0:d.phoneNumber} for a message from ${(t==null?void 0:t.name)||"privy.io"} and enter your code below.`;return Oe(io,{children:[B(L,{},"header"),Oe(Kn,{children:[B(xe,{title:W,description:J}),Oe(hr,{children:[Oe(qn,{children:[B(Jn,{fail:!!v,success:x,children:B("span",{children:v||(x?"Success!":"")})}),B("div",{children:h.map((k,S)=>B("input",{name:`code-${S}`,type:"text",value:h[S],onChange:F,onKeyUp:j=>{j.key==="Backspace"&&fe(S)},inputMode:"numeric",autoFocus:S===0,pattern:"[0-9]",className:`${x?"success":""} ${v?"fail":""}`,autoComplete:"one-time-code"},S))})]}),B(Yn,{children:y==0?Oe(io,{children:[B("span",{children:"Didn't get an email?"}),B("button",{onClick:o,children:"Resend Code"})]}):Oe(io,{children:[B("span",{children:"Didn't get a message?"}),B("button",{onClick:r,children:"Resend Code"})]})})]})]}),B(K,{protectedByPrivy:!0})]})},Kn=Et.div`
|
|
635
635
|
display: flex;
|
|
636
636
|
flex-direction: column;
|
|
637
637
|
align-items: flex-start;
|
|
638
638
|
justify-content: flex-end;
|
|
639
639
|
margin: auto;
|
|
640
640
|
gap: 16px;
|
|
641
|
-
`,
|
|
641
|
+
`,qn=Et.div`
|
|
642
642
|
display: flex;
|
|
643
643
|
flex-direction: column;
|
|
644
644
|
width: 100%;
|
|
@@ -706,7 +706,7 @@ Resources:
|
|
|
706
706
|
transform: translate(1px, 0px);
|
|
707
707
|
}
|
|
708
708
|
}
|
|
709
|
-
`,
|
|
709
|
+
`,Jn=Et.div`
|
|
710
710
|
line-height: 20px;
|
|
711
711
|
height: 20px;
|
|
712
712
|
font-size: 13px;
|
|
@@ -714,7 +714,7 @@ Resources:
|
|
|
714
714
|
display: flex;
|
|
715
715
|
justify-content: flex-end;
|
|
716
716
|
width: 100%;
|
|
717
|
-
`,
|
|
717
|
+
`,Yn=Et.div`
|
|
718
718
|
font-size: 13px;
|
|
719
719
|
color: var(--light-theme-fg-3);
|
|
720
720
|
display: flex;
|
|
@@ -728,7 +728,7 @@ Resources:
|
|
|
728
728
|
> button {
|
|
729
729
|
text-decoration: underline;
|
|
730
730
|
}
|
|
731
|
-
`;import Pt from"styled-components";import
|
|
731
|
+
`;import Pt from"styled-components";import Qn from"styled-components";var Or=Qn.span`
|
|
732
732
|
&& {
|
|
733
733
|
width: 82px;
|
|
734
734
|
height: 82px;
|
|
@@ -744,7 +744,7 @@ Resources:
|
|
|
744
744
|
border-color: var(--primary-color);
|
|
745
745
|
border-bottom-color: var(--primary-color);
|
|
746
746
|
}
|
|
747
|
-
`;import{jsx as Ur}from"react/jsx-runtime";var Dr=({style:t,...e})=>Ur("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:Ur("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 so,jsx as q,jsxs as _t}from"react/jsx-runtime";var Gr=()=>{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)||"Try with a different account?";return _t(so,{children:[q(L,{}),_t(
|
|
747
|
+
`;import{jsx as Ur}from"react/jsx-runtime";var Dr=({style:t,...e})=>Ur("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:Ur("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 so,jsx as q,jsxs as _t}from"react/jsx-runtime";var Gr=()=>{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)||"Try with a different account?";return _t(so,{children:[q(L,{}),_t(Xn,{children:[q(ts,{children:_t("div",{children:[q(Or,{}),q(Dr,{style:{width:"38px",height:"38px",strokeWidth:"1",stroke:"var(--primary-color)",fill:"var(--primary-color)"}})]})}),_t(es,{children:[typeof o=="string"?q("h3",{children:o}):q(so,{children:o}),typeof r=="string"?q("p",{children:r}):q(so,{children:r})]}),e!=null&&e.allowlistConfig.ctaLink?q(Fr,{onClick:()=>{typeof window<"u"&&(e==null?void 0:e.allowlistConfig.ctaLink)&&(window.location.href=e.allowlistConfig.ctaLink)},visible:!0,disabled:!1,children:e.allowlistConfig.ctaText}):q(Fr,{onClick:()=>{t("LANDING")},visible:!0,disabled:!1,children:"Okay"})]})]})},Xn=Pt.div`
|
|
748
748
|
display: flex;
|
|
749
749
|
flex-direction: column;
|
|
750
750
|
align-items: center;
|
|
@@ -752,11 +752,11 @@ Resources:
|
|
|
752
752
|
margin-left: 27px;
|
|
753
753
|
margin-right: 27px;
|
|
754
754
|
gap: 24px;
|
|
755
|
-
`,
|
|
755
|
+
`,es=Pt.div`
|
|
756
756
|
display: flex;
|
|
757
757
|
flex-direction: column;
|
|
758
758
|
gap: 8px;
|
|
759
|
-
`,
|
|
759
|
+
`,ts=Pt.div`
|
|
760
760
|
display: flex;
|
|
761
761
|
flex-direction: column;
|
|
762
762
|
justify-content: center;
|
|
@@ -791,7 +791,7 @@ Resources:
|
|
|
791
791
|
opacity: ${t=>t.visible?"1":"0"};
|
|
792
792
|
transition: opacity 200ms;
|
|
793
793
|
}
|
|
794
|
-
`;import{useState as
|
|
794
|
+
`;import{useState as fs}from"react";import z from"styled-components";import os from"qrcode";import rs from"styled-components";import{Fragment as Ue,jsx as O,jsxs as Hr}from"react/jsx-runtime";var D=7,ao=(t,e,o,r,i)=>{for(let n=e;n<e+r;n++)for(let s=o;s<o+i;s++){let c=t==null?void 0:t[s];c&&c[n]&&(c[n]=0)}return t},is=t=>{let e=os.create(t,{errorCorrectionLevel:"high"}).modules,o=vr(Array.from(e.data),e.size);return o=ao(o,0,0,D,D),o=ao(o,o.length-D,0,D,D),o=ao(o,0,o.length-D,D,D),o},ns=({x:t,y:e,cellSize:o,bgColor:r,fgColor:i})=>O(Ue,{children:[0,1,2].map(n=>O("circle",{r:o*(D-n*2)/2,cx:t+o*D/2,cy:e+o*D/2,fill:n%2!==0?r:i},`finder-${t}-${e}-${n}`))}),ss=({cellSize:t,matrixSize:e,bgColor:o,fgColor:r})=>{let i=[[0,0],[(e-D)*t,0],[0,(e-D)*t]];return O(Ue,{children:i.map(([n,s])=>O(ns,{x:n,y:s,cellSize:t,bgColor:o,fgColor:r}))})},as=({matrix:t,cellSize:e,color:o})=>O(Ue,{children:t.map((r,i)=>r.map((n,s)=>n?O("circle",{r:e/2.5,cx:i*e+e/2,cy:s*e+e/2,fill:o},`circle-${i}-${s}`):O(Ue,{})))}),Vr=(t,e)=>t-t%e,ls=({outputSize:t,cellSize:e,element:o,size:r,padding:i,bgColor:n})=>{if(!o)return O(Ue,{});let s=r||40,c=i||4,h=o,m=t/2-s/2-c;return Hr(Ue,{children:[O("rect",{x:Vr(m,e),y:Vr(m,e),width:s+c*2+(m%e?e+.5:.5),height:s+c*2+(m%e?e+.5:.5),fill:n}),O(h,{x:t/2-s/2,y:t/2-s/2,height:s,width:s})]})},ds=t=>{var i;let e=t.outputSize,o=is(t.url),r=e/o.length;return Hr("svg",{height:t.outputSize,width:t.outputSize,viewBox:`0 0 ${t.outputSize} ${t.outputSize}`,style:{height:"100%",width:"100%"},children:[O(as,{matrix:o,cellSize:r,color:t.fgColor}),O(ss,{cellSize:r,matrixSize:o.length,fgColor:t.fgColor,bgColor:t.bgColor}),O(ls,{outputSize:t.outputSize,cellSize:r,element:(i=t.logo)==null?void 0:i.element,bgColor:t.bgColor})]})},cs=rs.div`
|
|
795
795
|
display: flex;
|
|
796
796
|
justify-content: center;
|
|
797
797
|
align-items: center;
|
|
@@ -806,7 +806,7 @@ Resources:
|
|
|
806
806
|
border-color: ${t=>t.fgColor};
|
|
807
807
|
border-radius: 12px;
|
|
808
808
|
}
|
|
809
|
-
`,Br=t=>{let e=t.bgColor||"#FFFFFF",o=t.fgColor||"#000000",r=t.size||160;return O(
|
|
809
|
+
`,Br=t=>{let e=t.bgColor||"#FFFFFF",o=t.fgColor||"#000000",r=t.size||160;return O(cs,{size:r,bgColor:e,fgColor:o,children:O(ds,{url:t.url,logo:{element:t.squareLogoElement},outputSize:r,bgColor:e,fgColor:o})})};import{jsx as us}from"react/jsx-runtime";var zr=({size:t})=>us(Br,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:de,size:t,fgColor:"#1F1F1F"});import lo from"styled-components";import{jsx as jr}from"react/jsx-runtime";var $r=({style:t,...e})=>jr("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:jr("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 hs,jsxs as ms}from"react/jsx-runtime";var co=lo.div`
|
|
810
810
|
display: flex;
|
|
811
811
|
flex-direction: column;
|
|
812
812
|
justify-content: flex-start;
|
|
@@ -817,7 +817,7 @@ Resources:
|
|
|
817
817
|
border-left: 2px solid var(--border-color-2);
|
|
818
818
|
height: 12px;
|
|
819
819
|
}
|
|
820
|
-
`,Le=({children:t})=>
|
|
820
|
+
`,Le=({children:t})=>ms(ps,{children:[hs($r,{style:{width:"16px",height:"16px"}}),t]}),ps=lo.div`
|
|
821
821
|
display: flex;
|
|
822
822
|
justify-content: flex-start;
|
|
823
823
|
justify-items: center;
|
|
@@ -861,12 +861,12 @@ Resources:
|
|
|
861
861
|
background-color: var(--primary-color);
|
|
862
862
|
color: var(--light-theme-bg-1);
|
|
863
863
|
}
|
|
864
|
-
`,
|
|
864
|
+
`,Oc=uo(Kr)`
|
|
865
865
|
&& {
|
|
866
866
|
border: 1px solid var(--light-theme-bg-3);
|
|
867
867
|
color: var(--light-theme-fg-1);
|
|
868
868
|
}
|
|
869
|
-
`;import{Fragment as po,jsx as p,jsxs as M}from"react/jsx-runtime";var ho=()=>{let{navigate:t}=g(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return me.isFirefox&&(e="https://addons.mozilla.org/en-US/firefox/addon/ether-metamask/"),M(Xr,{children:[p(xe,{title:"Create a Metamask wallet",description:"Follow the instructions below to get started."}),p(ei,{children:p(be,{style:{width:"152px",height:"152px"}})}),M(co,{children:[p(Le,{children:M("div",{children:[p("span",{children:"Install the "}),p("a",{href:e,target:"_blank",children:"MetaMask browser extension"})]})}),p(Ye,{}),p(Le,{children:"Set up your first wallet"}),p(Ye,{}),p(Le,{children:"Store your recovery phrase in a safe place!"})]}),p(ti,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},mo=()=>{let{navigate:t}=g();return M(Xr,{children:[p(xe,{title:"Create a Coinbase wallet",description:"Follow the instructions below to get started."}),p(ei,{style:{marginTop:"-24px"},children:p(zr,{size:200})}),M(co,{children:[p(Le,{children:"Scan the QR code with your camera"}),p(Ye,{}),p(Le,{children:"Set up your first wallet"}),p(Ye,{}),p(Le,{children:"Store your seed phrase in a safe place!"})]}),p(ti,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},Qr=()=>{let[t,e]=
|
|
869
|
+
`;import{Fragment as po,jsx as p,jsxs as M}from"react/jsx-runtime";var ho=()=>{let{navigate:t}=g(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return me.isFirefox&&(e="https://addons.mozilla.org/en-US/firefox/addon/ether-metamask/"),M(Xr,{children:[p(xe,{title:"Create a Metamask wallet",description:"Follow the instructions below to get started."}),p(ei,{children:p(be,{style:{width:"152px",height:"152px"}})}),M(co,{children:[p(Le,{children:M("div",{children:[p("span",{children:"Install the "}),p("a",{href:e,target:"_blank",children:"MetaMask browser extension"})]})}),p(Ye,{}),p(Le,{children:"Set up your first wallet"}),p(Ye,{}),p(Le,{children:"Store your recovery phrase in a safe place!"})]}),p(ti,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},mo=()=>{let{navigate:t}=g();return M(Xr,{children:[p(xe,{title:"Create a Coinbase wallet",description:"Follow the instructions below to get started."}),p(ei,{style:{marginTop:"-24px"},children:p(zr,{size:200})}),M(co,{children:[p(Le,{children:"Scan the QR code with your camera"}),p(Ye,{}),p(Le,{children:"Set up your first wallet"}),p(Ye,{}),p(Le,{children:"Store your seed phrase in a safe place!"})]}),p(ti,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},Qr=()=>{let[t,e]=fs("WHAT_IS_A_WALLET"),{navigateBack:o}=g();return M(po,{children:[p(L,{backFn:t==="WHAT_IS_A_WALLET"?o:t==="PICK_A_NEW_WALLET"?()=>e("WHAT_IS_A_WALLET"):()=>e("PICK_A_NEW_WALLET")},"header"),M(gs,{children:[t==="WHAT_IS_A_WALLET"&&M(po,{children:[p(Cs,{children:p(Zr,{style:{width:"240px",height:"auto",borderRadius:"var(--border-radius-sm)",marginBottom:"32px"}})}),M(Ne,{title:"Get started with a new wallet",children:[p("p",{children:"Wallets help you store, send, and receive digital assets and collectibles. They are also a new\xA0way\xA0to\xA0log\xA0in."}),p("p",{children:"Instead of creating new accounts and passwords for every app, you just connect your wallet and bring your\xA0data\xA0with\xA0you."})]}),p(bs,{children:p(vs,{onClick:()=>{e("PICK_A_NEW_WALLET")},children:"Create a wallet"})})]}),t==="PICK_A_NEW_WALLET"&&p(po,{children:M(ws,{children:[p(xe,{title:"Create a new wallet",description:"Select one the wallet providers below to get started on your web3 adventure."}),M(ys,{children:[M(Jr,{onClick:()=>{me.isIOS?window.location.href="https://apps.apple.com/us/app/metamask-blockchain-wallet/id1438144202":me.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=io.metamask":e("CREATE_METAMASK_WALLET")},children:[p(be,{}),M(Yr,{children:[p("h4",{children:"MetaMask"}),p("p",{children:"Get a browser-based wallet"})]}),p("div",{children:p("span",{children:"Set up"})})]}),M(Jr,{onClick:()=>{me.isIOS?window.location.href="https://apps.apple.com/us/app/coinbase-wallet-nfts-crypto/id1278383455":me.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=org.toshi":e("CREATE_COINBASE_WALLET")},children:[p(de,{}),M(Yr,{children:[p("h4",{children:"Coinbase Wallet"}),p("p",{children:"Get a mobile app wallet"})]}),p("div",{children:p("span",{children:"Set up"})})]})]})]})}),t==="CREATE_COINBASE_WALLET"&&p(mo,{}),t==="CREATE_METAMASK_WALLET"&&p(ho,{})]}),M(oe,{children:[p("span",{children:"Still not sure? "}),p("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"}),"."]})]})},gs=z.div`
|
|
870
870
|
display: flex;
|
|
871
871
|
flex-direction: column;
|
|
872
872
|
height: 100%;
|
|
@@ -876,14 +876,14 @@ Resources:
|
|
|
876
876
|
display: none;
|
|
877
877
|
}
|
|
878
878
|
}
|
|
879
|
-
`,
|
|
879
|
+
`,ws=z.div`
|
|
880
880
|
display: flex;
|
|
881
881
|
flex-direction: column;
|
|
882
882
|
align-items: flex-start;
|
|
883
883
|
justify-content: flex-start;
|
|
884
884
|
text-align: left;
|
|
885
885
|
gap: 20px;
|
|
886
|
-
`,
|
|
886
|
+
`,ys=z.div`
|
|
887
887
|
display: flex;
|
|
888
888
|
flex-direction: column;
|
|
889
889
|
width: 100%;
|
|
@@ -952,13 +952,13 @@ Resources:
|
|
|
952
952
|
font-style: italic;
|
|
953
953
|
font-size: 12px;
|
|
954
954
|
}
|
|
955
|
-
`,
|
|
955
|
+
`,bs=z.div`
|
|
956
956
|
margin-top: auto;
|
|
957
957
|
display: flex;
|
|
958
958
|
align-items: flex-end;
|
|
959
959
|
flex-grow: 1;
|
|
960
960
|
width: 100%;
|
|
961
|
-
`,
|
|
961
|
+
`,vs=z(qr)`
|
|
962
962
|
&& {
|
|
963
963
|
margin-top: 14px;
|
|
964
964
|
}
|
|
@@ -988,10 +988,10 @@ Resources:
|
|
|
988
988
|
background-color: var(--primary-color-bg-1);
|
|
989
989
|
border-radius: var(--border-radius-sm);
|
|
990
990
|
}
|
|
991
|
-
`,
|
|
991
|
+
`,Cs=z.div`
|
|
992
992
|
display: flex;
|
|
993
993
|
justify-content: center;
|
|
994
|
-
`;import{useEffect as oi,useState as Tt}from"react";import Rt from"styled-components";import{Fragment as
|
|
994
|
+
`;import{useEffect as oi,useState as Tt}from"react";import Rt from"styled-components";import{Fragment as ks,jsx as Ae,jsxs as It}from"react/jsx-runtime";var fo=2,ri={metamask:{name:"MetaMask",component:be},coinbase_wallet:{name:"Coinbase Wallet",component:de},wallet_connect:{name:"WalletConnect",component:dt}},ii=()=>{var J;let[t,e]=Tt(!1),[o,r]=Tt(void 0),{navigate:i,navigateBack:n}=g(),{getAuthMeta:s,closePrivyModal:c,loginWithWallet:h,handleLoginError:m}=_(),[x,R]=Tt(0),{user:v}=N(),[A,P]=Tt((v==null?void 0:v.linkedAccounts.length)||0);oi(()=>{r(void 0),h().then(()=>e(!0)).catch(b=>{b instanceof H?console.error(b.cause):console.error(b);let a=(b==null?void 0:b.status)===401&&(b==null?void 0:b.message)==="User is not allowed to login to this app.";(b==null?void 0:b.status)===422?r(st.ERROR_USER_EXISTS):a?i("ALLOWLIST_REJECTION_SCREEN"):b instanceof Te&&!b.details.default?r(b.details):b instanceof Se?r(st.ERROR_TIMED_OUT):r(st.ERROR_WALLET_CONNECTION),m(a)})},[x]),oi(()=>{if(t){let b=setTimeout(c,_e);return()=>clearTimeout(b)}},[v]);let l=((J=s())==null?void 0:J.wallet)||"metamask",y=ri[l].name,F=ri[l].component,fe=t?`Successfully connected with ${y}`:o?o.message:`Waiting for ${y}`,W="";if(t){let b=(v==null?void 0:v.linkedAccounts.length)||0;A===b?W="Wallet was already linked.":W="You\u2019re good to go!"}else if(x>=fo&&o)W="Unable to connect wallet";else if(o)W=o.detail;else switch(W="Don\u2019t see your wallet modal? Check your other browser windows.",l){case"wallet_connect":W="Open your mobile wallet app to continue";break;case"coinbase_wallet":lt()||(W="Open the Coinbase app on your phone to continue.");break;default:W="Don\u2019t see your wallet modal? Check your other browser windows."}return It(ks,{children:[Ae(L,{backFn:n}),It(xs,{children:[Ae(As,{children:It("div",{children:[Ae(yt,{success:t,fail:!!o}),Ae(F,{style:{width:"38px",height:"38px"}})]})}),It(Ls,{children:[Ae("h3",{children:fe}),Ae("p",{children:W})]}),Ae(Es,{onClick:()=>{R(x+1),r(void 0)},visible:!t&&(o==null?void 0:o.retryable)&&x<fo,disabled:!t&&(!(o!=null&&o.retryable)||x>=fo),children:"Retry"})]})]})},xs=Rt.div`
|
|
995
995
|
display: flex;
|
|
996
996
|
flex-direction: column;
|
|
997
997
|
align-items: center;
|
|
@@ -999,11 +999,11 @@ Resources:
|
|
|
999
999
|
margin-left: 27px;
|
|
1000
1000
|
margin-right: 27px;
|
|
1001
1001
|
gap: 24px;
|
|
1002
|
-
`,
|
|
1002
|
+
`,Ls=Rt.div`
|
|
1003
1003
|
display: flex;
|
|
1004
1004
|
flex-direction: column;
|
|
1005
1005
|
gap: 8px;
|
|
1006
|
-
`,
|
|
1006
|
+
`,As=Rt.div`
|
|
1007
1007
|
display: flex;
|
|
1008
1008
|
flex-direction: column;
|
|
1009
1009
|
justify-content: center;
|
|
@@ -1026,7 +1026,7 @@ Resources:
|
|
|
1026
1026
|
left: -19px;
|
|
1027
1027
|
top: -19px;
|
|
1028
1028
|
}
|
|
1029
|
-
`,
|
|
1029
|
+
`,Es=Rt.button`
|
|
1030
1030
|
&& {
|
|
1031
1031
|
padding: 12px 16px;
|
|
1032
1032
|
font-weight: 500;
|
|
@@ -1038,7 +1038,7 @@ Resources:
|
|
|
1038
1038
|
opacity: ${t=>t.visible?"1":"0"};
|
|
1039
1039
|
transition: opacity 200ms;
|
|
1040
1040
|
}
|
|
1041
|
-
`;import{Fragment as
|
|
1041
|
+
`;import{Fragment as _s,jsx as Mt,jsxs as ni}from"react/jsx-runtime";var si=()=>{let{navigateBack:t}=g();return ni(_s,{children:[Mt(L,{backFn:t},"header"),Mt(ho,{}),ni(oe,{children:[Mt("span",{children:"Still not sure? "}),Mt("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"})]})]})};import{Fragment as Ps,jsx as Wt,jsxs as ai}from"react/jsx-runtime";var li=()=>{let{navigateBack:t}=g();return ai(Ps,{children:[Wt(L,{backFn:t},"header"),Wt(mo,{}),ai(oe,{children:[Wt("span",{children:"Still not sure? "}),Wt("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"})]})]})};import Ss from"styled-components";import{jsx as Is}from"react/jsx-runtime";var di=t=>{let e=t.accentColor||"#696ffd";return Is(Ts,{accentColor:e,children:t.children})},Ts=Ss.div`
|
|
1042
1042
|
/*! Modified from https://unpkg.com/tailwindcss@3.2.3/src/css/preflight.css */
|
|
1043
1043
|
|
|
1044
1044
|
*,
|
|
@@ -1349,7 +1349,7 @@ Resources:
|
|
|
1349
1349
|
display: none;
|
|
1350
1350
|
}
|
|
1351
1351
|
}
|
|
1352
|
-
`;import{useEffect as
|
|
1352
|
+
`;import{useEffect as zs}from"react";import{useEffect as ci,useState as ui}from"react";import Ot from"styled-components";import{Fragment as Us,jsx as Ee,jsxs as Nt}from"react/jsx-runtime";var pi={google:{name:"Google",component:gt},discord:{name:"Discord",component:ht},github:{name:"Github",component:mt},twitter:{name:"Twitter",component:pt}},Rs=t=>t.charAt(0).toUpperCase()+t.slice(1),go=()=>{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)},hi=()=>{var P;let[t,e]=ui(!1),[o,r]=ui(void 0),{getAuthMeta:i,initLoginWithOAuth:n,loginWithOAuth:s,closePrivyModal:c}=_(),{ready:h}=N(),m=((P=i())==null?void 0:P.provider)||"google",x=pi[m].name,R=pi[m].component;ci(()=>{!h||s().then(()=>{go(),e(!0)}).catch(l=>{let y={retryable:!1,message:"Authentication failed."};l.message.includes("Another user has already linked this")?y.detail="This account has already been linked to another user.":l.message==="Invalid code during oauth flow."?(y.retryable=!0,y.detail="Something went wrong. Try again."):l.message==="User denied confirmation during OAuth flow"&&(y.detail=`Retry and check ${Rs(m)} to finish connecting your account.`,y.retryable=!0),go(),r(y)})},[h]),ci(()=>{if(!t)return;let l=setTimeout(c,_e);return()=>clearTimeout(l)},[t]);let v=t?`Successfully connected with ${x}`:o?o.message:`Verifying connection to ${x}`,A="";return t?A="You\u2019re good to go!":o?A=o.detail:A="Just a few moments more",Nt(Us,{children:[Ee(L,{}),Nt(Ms,{children:[Ee(Ns,{children:Nt("div",{children:[Ee(yt,{success:t,fail:!!o}),Ee(R,{style:{width:"38px",height:"38px"},logoFill:"primary"})]})}),Nt(Ws,{children:[Ee("h3",{children:v}),Ee("p",{children:A})]}),Ee(Os,{onClick:()=>{go(),n(m),r(void 0)},visible:!t&&(o==null?void 0:o.retryable),disabled:!t&&!(o!=null&&o.retryable),children:"Retry"})]})]})},Ms=Ot.div`
|
|
1353
1353
|
display: flex;
|
|
1354
1354
|
flex-direction: column;
|
|
1355
1355
|
align-items: center;
|
|
@@ -1357,11 +1357,11 @@ Resources:
|
|
|
1357
1357
|
margin-left: 27px;
|
|
1358
1358
|
margin-right: 27px;
|
|
1359
1359
|
gap: 24px;
|
|
1360
|
-
`,
|
|
1360
|
+
`,Ws=Ot.div`
|
|
1361
1361
|
display: flex;
|
|
1362
1362
|
flex-direction: column;
|
|
1363
1363
|
gap: 8px;
|
|
1364
|
-
`,
|
|
1364
|
+
`,Ns=Ot.div`
|
|
1365
1365
|
display: flex;
|
|
1366
1366
|
flex-direction: column;
|
|
1367
1367
|
justify-content: center;
|
|
@@ -1384,7 +1384,7 @@ Resources:
|
|
|
1384
1384
|
left: -19px;
|
|
1385
1385
|
top: -19px;
|
|
1386
1386
|
}
|
|
1387
|
-
`,
|
|
1387
|
+
`,Os=Ot.button`
|
|
1388
1388
|
&& {
|
|
1389
1389
|
padding: 12px 16px;
|
|
1390
1390
|
font-weight: 500;
|
|
@@ -1396,7 +1396,7 @@ Resources:
|
|
|
1396
1396
|
opacity: ${t=>t.visible?"1":"0"};
|
|
1397
1397
|
transition: opacity 200ms;
|
|
1398
1398
|
}
|
|
1399
|
-
`;import{Fragment as
|
|
1399
|
+
`;import{Fragment as Ds,jsx as De,jsxs as Fs}from"react/jsx-runtime";var mi=()=>{let{app:t}=g();return Fs(Ds,{children:[De(L,{},"header"),De(Ne,{title:"Connect your email",description:`Add your email to your ${t==null?void 0:t.name} account`,icon:De(wt,{})}),De(ce,{children:De(vt,{stacked:!0})}),De(K,{protectedByPrivy:!0})]})};import{Fragment as Gs,jsx as Fe,jsxs as Vs}from"react/jsx-runtime";var fi=()=>{let{app:t}=g();return Vs(Gs,{children:[Fe(L,{},"header"),Fe(Ne,{title:"Connect your phone",description:`Add your number to your ${t==null?void 0:t.name} account`,icon:Fe(Ct,{})}),Fe(ce,{children:Fe(xt,{stacked:!0})}),Fe(K,{protectedByPrivy:!0})]})};import{Fragment as Bs,jsx as Qe,jsxs as gi}from"react/jsx-runtime";var wi=()=>{let{app:t}=g();return gi(Bs,{children:[Qe(L,{},"header"),Qe(Tr,{title:"Connect your wallet",description:`Link a wallet to your ${t==null?void 0:t.name} account`}),gi(ce,{children:[Qe(ct,{}),Qe(ut,{})]}),Qe(K,{protectedByPrivy:!0})]})};import{jsx as I,jsxs as yi}from"react/jsx-runtime";var js=()=>{let{ready:t}=N(),{isLinking:e}=_(),{ready:o,currentScreen:r}=g(),i;return["AWAITING_CONNECTION","AWAITING_OAUTH_SCREEN","ALLOWLIST_REJECTION_SCREEN"].includes(r)?i="compact":"WALLET_EDUCATION"===r?i="full":e?i="medium":i="full",!t||!o?yi(kt,{"data-height":i,children:[I(L,{}),I(Ks,{children:I(pe,{})}),I(oe,{})]}):yi(kt,{"data-height":i,children:[r==="LANDING"&&I(_r,{}),r==="AWAITING_PASSWORDLESS_CODE"&&I(Nr,{}),r==="WALLET_EDUCATION"&&I(Qr,{}),r==="AWAITING_CONNECTION"&&I(ii,{}),r==="AWAITING_OAUTH_SCREEN"&&I(hi,{}),r==="ALLOWLIST_REJECTION_SCREEN"&&I(Gr,{}),r==="INSTALL_METAMASK_SCREEN"&&I(si,{}),r==="INSTALL_COINBASE_WALLET_SCREEN"&&I(li,{}),r==="LINK_EMAIL_SCREEN"&&I(mi,{}),r==="LINK_PHONE_SCREEN"&&I(fi,{}),r==="LINK_WALLET_SCREEN"&&I(wi,{})]})},bi=()=>{let{app:t}=g();return Hs.createPortal(I(Zs,{id:"privy-dialog",children:I(di,{accentColor:t==null?void 0:t.accentColor,children:I(js,{})})}),document.body)},$s=({children:t,...e})=>(zs(()=>{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]),I("dialog",{open:!0,role:"dialog",...e,children:t})),Zs=wo($s)`
|
|
1400
1400
|
position: fixed;
|
|
1401
1401
|
top: 0;
|
|
1402
1402
|
left: 0;
|
|
@@ -1449,10 +1449,10 @@ Resources:
|
|
|
1449
1449
|
min-height: 0;
|
|
1450
1450
|
}
|
|
1451
1451
|
}
|
|
1452
|
-
`,
|
|
1452
|
+
`,Ks=wo.div`
|
|
1453
1453
|
display: flex;
|
|
1454
1454
|
flex-direction: column;
|
|
1455
1455
|
align-items: center;
|
|
1456
1456
|
justify-content: center;
|
|
1457
1457
|
height: 100%;
|
|
1458
|
-
`;import{Fragment as
|
|
1458
|
+
`;import{Fragment as ta,jsx as Xe,jsxs as oa}from"react/jsx-runtime";function Js(t){return typeof t=="string"&&t.length===25}var Dt;function Ys(){if(!Dt){let t=E.get(Pe);return Promise.resolve(t||null)}return Dt.getAccessToken()}var Qs=t=>{if(!Js(t.appId))throw new u("Cannot initialize the Privy provider with an invalid Privy app ID");let[e,o]=ne(null);return Ut(()=>{Dt=new Be({appId:t.appId,apiURL:xo}),o(Dt)},[]),e===null?Xe(ta,{}):Xe(ea,{...t,client:e})},Xs=(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)}},ea=t=>{let e=t.client,[o,r]=ne(!1),[i,n]=ne(!1),[s,c]=ne(!1),[h,m]=ne(null),[x,R]=ne(!1),[v,A]=ne({accentColor:"#696ffd",theme:"System",showWalletLoginFirst:!0,allowlistConfig:{errorTitle:null,errorDetail:null,ctaText:null,ctaLink:null},walletAuth:!0,emailAuth:!0,smsAuth:!1,googleOAuth:!1,twitterOAuth:!1,discordOAuth:!1,githubOAuth:!1,termsAndConditionsUrl:null,privacyPolicyUrl:null}),[P,l]=ne(null),[y,F]=ne(!1);Ut(()=>{async function a(){let d=await e.getAppSettings();A(d)}a()},[]);let fe=Xs(v,P),W=()=>{let a=new URLSearchParams(window.location.search),d=a.get("privy_oauth_code"),k=a.get("privy_oauth_state"),S=a.get("privy_oauth_provider");d&&k&&S&&(e.startAuthFlow(new Ie(S,d,k)),l(S),r(!0))};Ut(()=>{async function a(){W();let d=await e.getAuthenticatedUser();c(!!d),m(d),n(!0)}a()},[]),Ut(()=>{i&&s&&h===null&&e.getAuthenticatedUser().then(m)},[i,s,h]);let J={ready:i,authenticated:s,user:h,walletConnector:e.connector,linkWallet:()=>{l("wallet"),F(!0),r(!0)},linkEmail:()=>{l("email"),F(!0),r(!0)},linkPhone:()=>{l("sms"),F(!0),r(!0)},linkGoogle:async()=>{await b.initLoginWithOAuth("google")},linkTwitter:async()=>{await b.initLoginWithOAuth("twitter")},linkDiscord:async()=>{await b.initLoginWithOAuth("discord")},linkGithub:async()=>{await b.initLoginWithOAuth("github")},login:()=>{if(i&&s){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(),m(null),c(!1),l(null),F(!1),r(!1)},getAccessToken:()=>e.getAccessToken(),getEthereumProvider:()=>e.connector.getEthereumProvider(),getEthersProvider:()=>new qs(new ye(e.connector.getEthereumProvider())),getWeb3jsProvider:()=>new at(e.connector.getEthereumProvider()),unlinkWallet:async a=>{let d=await e.unlinkWallet(a);return m(d),d},unlinkEmail:async a=>{let d=await e.unlinkEmail(a);return m(d),d},unlinkPhone:async a=>{let d=await e.unlinkPhone(a);return m(d),d},unlinkGoogle:async a=>{let d=await e.unlinkOAuth("google",a);return m(d),d},unlinkTwitter:async a=>{let d=await e.unlinkOAuth("twitter",a);return m(d),d},unlinkDiscord:async a=>{let d=await e.unlinkOAuth("discord",a);return m(d),d},unlinkGithub:async a=>{let d=await e.unlinkOAuth("github",a);return m(d),d},setActiveWallet:a=>{if(!h)return;let d=e.setActiveWallet(a,h);m(d)},forkSession:()=>e.forkSession()},b={isLinking:y,getAuthFlow:()=>e.authFlow,getAuthMeta:()=>{var a;return(a=e.authFlow)==null?void 0:a.meta},closePrivyModal:()=>{var a;i&&s&&h&&((a=t.onSuccess)==null||a.call(t,h,x)),e.authFlow=void 0,l(null),F(!1),R(!1),r(!1)},handleLoginError:async a=>{var d;e.authFlow=void 0,l(null),F(!1),R(!1),(d=t.onError)==null||d.call(t,a)},initLoginWithWallet:a=>{a||(a="metamask"),e.connector.walletType=a,e.startAuthFlow(new He(e.connector))},loginWithWallet:async()=>{if(!(e.authFlow instanceof He))throw new u("Must initialize SIWE flow first.");let a,d;y?(a=await e.link(),a&&(E.del(Z),a=Ge(a))):{user:a,isNewUser:d}=await e.authenticate(),m(a||h||null),R(d||!1),c(!0)},initLoginWithOAuth:async a=>{e.startAuthFlow(new Ie(a));let d=await e.authFlow.getAuthorizationUrl();d&&d.url&&window.location.assign(d.url)},loginWithOAuth:async()=>{if(!(e.authFlow instanceof Ie))throw new u("Must initialize OAuth flow before calling loginWithOAuth");let a,d;i&&s?a=await e.link():{user:a,isNewUser:d}=await e.authenticate(),m(a),R(d||!1),c(!0)},initLoginWithEmail:async a=>{let d=new ze(a);e.startAuthFlow(d),await d.sendCodeEmail()},initLoginWithSms:async a=>{let d=new je(a);e.startAuthFlow(d),await d.sendSmsCode()},resendEmailCode:async()=>{var a;await((a=e.authFlow)==null?void 0:a.sendCodeEmail())},resendSmsCode:async()=>{var a;await((a=e.authFlow)==null?void 0:a.sendSmsCode())},loginWithCode:async a=>{if(e.authFlow instanceof ze)e.authFlow.meta.emailCode=a.trim();else if(e.authFlow instanceof je)e.authFlow.meta.smsCode=a.trim();else throw new u("Must initialize a passwordless code flow first");let d,k;y?d=await e.link():{user:d,isNewUser:k}=await e.authenticate(),m(d||h||null),R(k||!1),c(!0)}};return oa(Jt.Provider,{value:J,children:[t.children,Xe(Yt.Provider,{value:b,children:Xe(Yo,{appSettings:v,options:fe,visible:o,authenticated:s,children:o&&Xe(bi,{})})})]})};export{ye as AsExternalProvider,Be as PrivyClient,Ve as PrivyConnector,Qs as PrivyProvider,we as PrivyProxyProvider,Bt as VERSION,Ys as getAccessToken,N as usePrivy};
|