@privy-io/react-auth 1.12.0-beta.2 → 1.12.0-beta.4
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/index.d.ts +1 -0
- package/dist/index.js +37 -36
- package/dist/index.mjs +61 -60
- package/package.json +1 -1
package/dist/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{useEffect as Mt,useState as oe}from"react";import Ft from"axios";import mi from"axios";var B=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}]`:""}`}},Qe=class extends B{constructor(o,r,i,n){super(i,n);this.type=o;this.status=r}},p=class extends B{constructor(o,r){super(o,r);this.type="client_error"}};var V=class extends B{constructor(o,r){super(o,r);this.type="connector_error"}},T=t=>{if(t instanceof B)return t;if(!mi.isAxiosError(t))return G(t);if(!t.response)return new Qe("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new Qe(e||"ApiError",t.response.status,o||r,t)},G=t=>t instanceof B?t:t instanceof Error?new p(t.message,t):new p(`Internal error: ${t}`);var go="1.12.0-beta.2";var wo="https://api.privy.io/v0",yo=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",Xe="4df5e2316331463a9130964bd6078dfa",Co=1e4,Le=1400,vo=365*24*60*60,Dt=go,bo="ES256",xo="privy.io",Ee="privy:token",et="privy:refresh_token",K="privy:active_wallet",tt="privy:wallet_type",Lo="walletconnect";var ot=class{constructor(e,o,r){this.appId=e,this.sdkVersion=Dt,this.session=o,this.defaults=r}async get(e,o){try{return await Ft.get(e,this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw T(r)}}async post(e,o,r){try{return await Ft.post(e,o,this.buildConfig(r))}catch(i){throw T(i)}}async delete(e,o){try{return await Ft.delete(e,this.buildConfig(o))}catch(r){throw T(r)}}buildConfig(e){return e=e||{},e.headers=e.headers||{},e.headers["privy-app-id"]=this.appId,e.headers["privy-client"]=`react-auth:${this.sdkVersion}`,this.session.token!==null&&(e.headers.authorization=`Bearer ${this.session.token}`),{...this.defaults,...e}}};import*as Ae from"jose";var re=class{static parse(e){try{return new re(e)}catch{return null}}constructor(e){this.value=e,this._decoded=Ae.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}async isValid(e,o,r=0){let i=await Ae.importSPKI(e,bo);try{return await Ae.jwtVerify(this.value,i,{issuer:xo,audience:o,clockTolerance:r}),!0}catch{return!1}}};var ie=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 Vt=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]}},Gt=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 gi(){return typeof window<"u"&&window.localStorage?new Gt:new Vt}var L=gi();function ce(t){return new Date(t*1e3)}function wi(t){return t.map(e=>{switch(e.type){case"wallet":return{address:e.address,type:e.type,verifiedAt:ce(e.verified_at),chainType:e.chain_type};case"email":return{address:e.address,type:e.type,verifiedAt:ce(e.verified_at)};case"phone":return{number:e.phoneNumber,type:e.type,verifiedAt:ce(e.verified_at)};case"google_oauth":return{subject:e.subject,email:e.email,name:e.name,type:e.type,verifiedAt:ce(e.verified_at)};case"twitter_oauth":return{subject:e.subject,username:e.username,name:e.name,type:e.type,verifiedAt:ce(e.verified_at)};case"discord_oauth":return{subject:e.subject,username:e.username,email:e.email,type:e.type,verifiedAt:ce(e.verified_at)};default:throw new p("Unrecognized account type")}})}function yi(t,e){return e.find(o=>o.type==="wallet"&&o.address===t)}function pe(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function De(t){let e=t.linkedAccounts.map(s=>s.type==="wallet"?s.address:null),r=L.get(K);if(!r||!e.includes(r)){L.del(K);let s=pe(t.linkedAccounts,"wallet");s&&(r=s.address,L.put(K,r))}let i=yi(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 Y(t){if(!t)return null;let e=wi(t.linked_accounts),o=pe(e,"wallet"),r=pe(e,"email"),i=pe(e,"phone"),n=pe(e,"google_oauth"),s=pe(e,"twitter_oauth"),c=pe(e,"discord_oauth"),f={id:t.id,createdAt:ce(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}};return De(f)}var Eo=()=>"/api/v1/sessions",Ao=()=>"/api/v1/sessions/logout",ko=()=>"/api/v1/sessions/fork",_o=()=>"/api/v1/siwe/init",Po=()=>"/api/v1/siwe/authenticate",So=()=>"/api/v1/siwe/link",To=()=>"/api/v1/passwordless/init",Io=()=>"/api/v1/passwordless/authenticate",Ro=()=>"/api/v1/passwordless/link",Mo=()=>"/api/v1/passwordless_sms/init",Wo=()=>"/api/v1/passwordless_sms/authenticate",No=()=>"/api/v1/passwordless_sms/link",Oo=()=>"/api/v1/oauth/init",Uo=()=>"/api/v1/oauth/authenticate",Do=()=>"/api/v1/oauth/link",Fo=()=>"/api/v1/siwe/unlink",Vo=()=>"/api/v1/passwordless/unlink",Go=()=>"/api/v1/passwordless_sms/unlink",Ho=()=>"/api/v1/oauth/unlink";var Ci=30,rt=class{constructor(){this.authenticateOnce=new ie(async e=>this._authenticate(e)),this.linkOnce=new ie(async e=>this._link(e)),this.refreshOnce=new ie(this._refresh.bind(this)),this.destroyOnce=new ie(this._destroy.bind(this)),this.forkSessionOnce=new ie(this._forkSession.bind(this))}get token(){try{let e=L.get(Ee);return typeof e=="string"?new re(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=L.get(et);return typeof e=="string"?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}hasRefreshCredentials(){return typeof this.token=="string"&&typeof this.refreshToken=="string"}hasActiveToken(){let e=re.parse(this.token);return e!==null&&!e.isExpired(Ci)}async hasValidToken(e,o,r=0){let i=re.parse(this.token);return i!==null&&await i.isValid(e,o,r)}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:Y(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),G(o)}}async _link(e){try{let o=await e.link();return Y(o)}catch(o){throw console.warn("Error linking account"),G(o)}}async _refresh(){if(!this.api)throw new p("Session has no API instance");let e=this.token,o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(Eo(),{refresh_token:o});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),Y(r.data.user)}catch(r){throw G(r)}}async _destroy(){var e;try{await((e=this.api)==null?void 0:e.post(Ao(),{refresh_token:this.refreshToken}))}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new p("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(ko(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw G(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),L.del(K)}storeToken(e){typeof e=="string"?L.put(Ee,e):L.del(Ee)}storeRefreshToken(e){typeof e=="string"?L.put(et,e):L.del(et)}};import{getAddress as Ai}from"@ethersproject/address";import zo from"@walletconnect/web3-provider";import{ErrorCode as vi}from"@ethersproject/logger";var ke=class extends V{constructor(){super("Wallet timeout");this.type="wallet_error"}},it=t=>{if(t instanceof V)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new _e(t);return t.code===vi.ACTION_REJECTED&&(e.details=ue.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new _e(t):new V("Unknown connector error",t)},Ht=class extends B{constructor(o,r,i){super(o);this.type="provider_error";this.code=r,this.data=i}},_e=class extends Ht{constructor(o){var n,s,c;let r=o;super(r.message,r.code,r.data);let i=Object.values(ue).find(f=>f.eipCode===r.code);this.details=i||ue.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=ue.E32002_CONNECTION_ALREADY_PENDING:this.details=ue.E32002_REQUEST_ALREADY_PENDING:(c=r.message)!=null&&c.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=ue.E32002_WALLET_LOCKED))}},bi={ERROR_USER_EXISTS:{message:"User already exists for this address",detail:"Try another address!",retryable:!1},ERROR_TIMED_OUT:{message:"Wallet request timed out",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_CONNECTION:{message:"Could not log in with wallet",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_NOT_ALLOWED:{message:"You don\u2019t have access to this app",detail:"Try with a different address?",retryable:!0}},xi={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}},Li={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}},ue={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Li,...xi},Fe={...bi,...ue};var Ei=12e4,Bt=(t=new ke,e=Ei)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),he=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 V(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),Bt()]).catch(o=>{throw it(o)})}},me=class extends he{constructor(o){super(o)}},nt=class extends he{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 ki}from"@ethersproject/providers";var Bo=["metamask","coinbase_wallet","wallet_connect"];import _i from"@coinbase/wallet-sdk";var Pi=()=>{let t=`https://mainnet.infura.io/v3/${Xe}`,e=1;return new _i({appName:"Privy",darkMode:!1,headlessMode:!1}).makeWeb3Provider(t,e)},zt=()=>{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},st=()=>{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 Wt,useState as ie}from"react";import Vt from"axios";import mi from"axios";var B=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}]`:""}`}},Xe=class extends B{constructor(o,r,i,n){super(i,n);this.type=o;this.status=r}},p=class extends B{constructor(o,r){super(o,r);this.type="client_error"}};var V=class extends B{constructor(o,r){super(o,r);this.type="connector_error"}},I=t=>{if(t instanceof B)return t;if(!mi.isAxiosError(t))return G(t);if(!t.response)return new Xe("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new Xe(e||"ApiError",t.response.status,o||r,t)},G=t=>t instanceof B?t:t instanceof Error?new p(t.message,t):new p(`Internal error: ${t}`);var go="1.12.0-beta.4";var wo="https://api.privy.io/v0",yo=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",et="4df5e2316331463a9130964bd6078dfa",Co=1e4,Ee=1400,vo=365*24*60*60,Ft=go,bo="ES256",xo="privy.io",Ae="privy:token",tt="privy:refresh_token",K="privy:active_wallet",ot="privy:wallet_type",Lo="walletconnect";var rt=class{constructor(e,o,r){this.appId=e,this.sdkVersion=Ft,this.session=o,this.defaults=r}async get(e,o){try{return await Vt.get(e,this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw I(r)}}async post(e,o,r){try{return await Vt.post(e,o,this.buildConfig(r))}catch(i){throw I(i)}}async delete(e,o){try{return await Vt.delete(e,this.buildConfig(o))}catch(r){throw I(r)}}buildConfig(e){return e=e||{},e.headers=e.headers||{},e.headers["privy-app-id"]=this.appId,e.headers["privy-client"]=`react-auth:${this.sdkVersion}`,this.session.token!==null&&(e.headers.authorization=`Bearer ${this.session.token}`),{...this.defaults,...e}}};import*as ke from"jose";var ne=class{static parse(e){try{return new ne(e)}catch{return null}}constructor(e){this.value=e,this._decoded=ke.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}async isValid(e,o,r=0){let i=await ke.importSPKI(e,bo);try{return await ke.jwtVerify(this.value,i,{issuer:xo,audience:o,clockTolerance:r}),!0}catch{return!1}}};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 Gt=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]}},Ht=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 gi(){return typeof window<"u"&&window.localStorage?new Ht:new Gt}var E=gi();function pe(t){return new Date(t*1e3)}function wi(t){return t.map(e=>{switch(e.type){case"wallet":return{address:e.address,type:e.type,verifiedAt:pe(e.verified_at),chainType:e.chain_type};case"email":return{address:e.address,type:e.type,verifiedAt:pe(e.verified_at)};case"phone":return{number:e.phoneNumber,type:e.type,verifiedAt:pe(e.verified_at)};case"google_oauth":return{subject:e.subject,email:e.email,name:e.name,type:e.type,verifiedAt:pe(e.verified_at)};case"twitter_oauth":return{subject:e.subject,username:e.username,name:e.name,type:e.type,verifiedAt:pe(e.verified_at)};case"discord_oauth":return{subject:e.subject,username:e.username,email:e.email,type:e.type,verifiedAt:pe(e.verified_at)};default:throw new p("Unrecognized account type")}})}function yi(t,e){return e.find(o=>o.type==="wallet"&&o.address===t)}function ue(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function Fe(t){let e=t.linkedAccounts.map(s=>s.type==="wallet"?s.address:null),r=E.get(K);if(!r||!e.includes(r)){E.del(K);let s=ue(t.linkedAccounts,"wallet");s&&(r=s.address,E.put(K,r))}let i=yi(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 J(t){if(!t)return null;let e=wi(t.linked_accounts),o=ue(e,"wallet"),r=ue(e,"email"),i=ue(e,"phone"),n=ue(e,"google_oauth"),s=ue(e,"twitter_oauth"),c=ue(e,"discord_oauth"),f={id:t.id,createdAt:pe(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}};return Fe(f)}var Eo=()=>"/api/v1/sessions",Ao=()=>"/api/v1/sessions/logout",ko=()=>"/api/v1/sessions/fork",_o=()=>"/api/v1/siwe/init",Po=()=>"/api/v1/siwe/authenticate",So=()=>"/api/v1/siwe/link",To=()=>"/api/v1/passwordless/init",Io=()=>"/api/v1/passwordless/authenticate",Ro=()=>"/api/v1/passwordless/link",Mo=()=>"/api/v1/passwordless_sms/init",Wo=()=>"/api/v1/passwordless_sms/authenticate",No=()=>"/api/v1/passwordless_sms/link",Oo=()=>"/api/v1/oauth/init",Uo=()=>"/api/v1/oauth/authenticate",Do=()=>"/api/v1/oauth/link",Fo=()=>"/api/v1/siwe/unlink",Vo=()=>"/api/v1/passwordless/unlink",Go=()=>"/api/v1/passwordless_sms/unlink",Ho=()=>"/api/v1/oauth/unlink";var Ci=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(Ae);return typeof e=="string"?new ne(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=ne.parse(this.token);return e!==null&&!e.isExpired(Ci)}async hasValidToken(e,o,r=0){let i=ne.parse(this.token);return i!==null&&await i.isValid(e,o,r)}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:J(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),G(o)}}async _link(e){try{let o=await e.link();return J(o)}catch(o){throw console.warn("Error linking account"),G(o)}}async _refresh(){if(!this.api)throw new p("Session has no API instance");let e=this.token,o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(Eo(),{refresh_token:o});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),J(r.data.user)}catch(r){throw G(r)}}async _destroy(){var e;try{await((e=this.api)==null?void 0:e.post(Ao(),{refresh_token:this.refreshToken}))}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new p("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(ko(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw G(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),E.del(K)}storeToken(e){typeof e=="string"?E.put(Ae,e):E.del(Ae)}storeRefreshToken(e){typeof e=="string"?E.put(tt,e):E.del(tt)}};import{getAddress as Ai}from"@ethersproject/address";import zo from"@walletconnect/web3-provider";import{ErrorCode as vi}from"@ethersproject/logger";var _e=class extends V{constructor(){super("Wallet timeout");this.type="wallet_error"}},nt=t=>{if(t instanceof V)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new Pe(t);return t.code===vi.ACTION_REJECTED&&(e.details=he.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new Pe(t):new V("Unknown connector error",t)},Bt=class extends B{constructor(o,r,i){super(o);this.type="provider_error";this.code=r,this.data=i}},Pe=class extends Bt{constructor(o){var n,s,c;let r=o;super(r.message,r.code,r.data);let i=Object.values(he).find(f=>f.eipCode===r.code);this.details=i||he.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=he.E32002_CONNECTION_ALREADY_PENDING:this.details=he.E32002_REQUEST_ALREADY_PENDING:(c=r.message)!=null&&c.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=he.E32002_WALLET_LOCKED))}},bi={ERROR_USER_EXISTS:{message:"User already exists for this address",detail:"Try another address!",retryable:!1},ERROR_TIMED_OUT:{message:"Wallet request timed out",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_CONNECTION:{message:"Could not log in with wallet",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_NOT_ALLOWED:{message:"You don\u2019t have access to this app",detail:"Try with a different address?",retryable:!0}},xi={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}},Li={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}},he={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Li,...xi},Ve={...bi,...he};var Ei=12e4,zt=(t=new _e,e=Ei)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),me=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 V(`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)})}},fe=class extends me{constructor(o){super(o)}},st=class extends me{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 ki}from"@ethersproject/providers";var Bo=["metamask","coinbase_wallet","wallet_connect"];import _i from"@coinbase/wallet-sdk";var Pi=()=>{let t=`https://mainnet.infura.io/v3/${et}`,e=1;return new _i({appName:"Privy",darkMode:!1,headlessMode:!1}).makeWeb3Provider(t,e)},Zt=()=>{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},at=()=>{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},Ge=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 he}initialize(){let e=L.get(tt);Bo.includes(e)&&(this.walletType=e,this.connect({showPrompt:!1}))}destroy(){this.walletType=null,L.del(tt),L.del(Lo)}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(Pi());break;case"wallet_connect":let r=new zo({infuraId:Xe});this.ethProvider.setProvider(r);break;default:throw new V(`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 V(`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 zo({infuraId:Xe});this.ethProvider.setProvider(o),await Promise.race([o.enable(),Bt()]);break;default:throw new V(`Unsupported wallet: ${this.walletType}`)}L.put(tt,e)}catch(o){throw it(o)}}async sign(e){return new ki(new me(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?Ai(e[0]):null}};var Zt,Ge=class{constructor(e){let o=e.apiURL||wo,r=e.timeout||Co;this.appId=e.appId,this.connector=new Ve,this.connector.initialize(),Zt||(Zt=new rt),this.session=Zt,this.api=new ot(e.appId,this.session,{baseURL:o,timeout:r}),this.session.api=this.api}authenticate(){if(!this.authFlow)throw new p("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new p("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.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(Vo(),{address:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkPhone(e){try{let o=await this.api.post(Go(),{phoneNumber:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkWallet(e){try{let o=await this.api.post(Fo(),{address:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(Ho(),{provider:e,subject:o});return Y(r.data)}catch(r){throw G(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(){if(this.session.hasActiveToken()){let{verificationKey:e,id:o}=await this.getAppSettings();return await this.session.hasValidToken(e,o,vo)?this.session.token:(await this.logout(),null)}else return 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,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,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 G(e)}}setActiveWallet(e,o){if(!o.linkedAccounts.map(i=>i.type==="wallet"?i.address:null).includes(e))throw new p("Cannot set an unlinked address as active.");return L.put(K,e),De(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as Ns}from"@ethersproject/providers";import{createContext as Si,useContext as Ti}from"react";var m=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var jt=Si({ready:!1,authenticated:!1,user:null,walletConnector:null,login:m,linkEmail:m,linkPhone:m,linkWallet:m,linkGoogle:m,linkTwitter:m,linkDiscord:m,logout:m,getAccessToken:m,getEthereumProvider:m,getEthersProvider:m,getWeb3jsProvider:m,unlinkEmail:m,unlinkPhone:m,unlinkWallet:m,unlinkGoogle:m,unlinkTwitter:m,unlinkDiscord:m,setActiveWallet:m,forkSession:m}),N=()=>Ti(jt);var He=class{constructor(e){this.connector=e,this.meta={wallet:this.connector.walletType}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.connector.walletType)throw new p("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Po(),{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 p("Auth flow has no API instance");if(!this.connector.walletType)throw new p("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api);return(await this.api.post(So(),{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(_o(),{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 Be=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new p("Email and email code must be set prior to calling authenticate.");try{let e=Io(),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 p("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new p("Email and email code must be set prior to calling authenticate.");try{let e=Ro();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 p("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new p("Email must be set when initialzing authentication.");try{let o=To();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw T(o)}}};var ze=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new p("phone number and sms code must be set prior to calling authenticate.");try{let e=Wo(),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 p("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new p("phone number and sms code must be set prior to calling authenticate.");try{let e=No();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 p("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new p("phone nNumber must be set when initialzing authentication.");try{let o=Mo();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw T(o)}}};var Pe=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 p("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new p("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new p("User denied confirmation during OAuth flow");try{let e=Uo(),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 p("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new p("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new p("User denied confirmation during OAuth flow");try{let e=Do();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 p("Auth flow has no API instance");if(!this.meta.provider)throw new p("Provider must be set when initialzing OAuth authentication.");try{let e=Oo();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 Ss from"react-dom";import ho from"styled-components";import{createContext as Ri,useContext as Mi,useEffect as jo,useState as $o}from"react";import{jsx as Ii}from"react/jsx-runtime";function Zo(t){return Ii("link",{rel:"prefetch",href:t.src})}import{jsx as Wi,jsxs as Ni}from"react/jsx-runtime";var Ko=Ri({ready:!1,app:null,options:{email:!0,sms:!1,wallet:!0,google:!1,twitter:!1,discord:!1},currentScreen:"LANDING",lastScreen:"LANDING",navigate:m,navigateBack:m}),qo=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=$o(null),[s,c]=$o(null);jo(()=>{o||n(null)},[o]),jo(()=>{r||(c("LANDING"),n("LANDING"))},[r]);let f={ready:!!(e!=null&&e.id),app:e,options:t.options,currentScreen:i||"LANDING",lastScreen:s||"LANDING",navigate:h=>{c(i),n(h)},navigateBack:()=>{n(s)}};return Ni(Ko.Provider,{value:f,children:[e&&e.logoUrl&&Wi(Zo,{src:e.logoUrl}),t.children]})},w=()=>Mi(Ko);import{useEffect as Pn,useState as Sn}from"react";import $e from"styled-components";import Di from"styled-components";import{jsx as Yo}from"react/jsx-runtime";var Jo=({style:t,...e})=>Yo("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:Yo("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});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:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as Oi,useContext as Ui}from"react";var $t=Oi({isLinking:!1,getAuthMeta:m,getAuthFlow:m,closePrivyModal:m,initLoginWithWallet:m,loginWithWallet:m,loginWithCode:m,loginWithEmail:m,loginWithSms:m,resendEmailCode:m,resendSmsCode:m,initLoginWithOAuth:m,loginWithOAuth:m,handleLoginError:m}),_=()=>Ui($t);import{jsx as J,jsxs as Bi}from"react/jsx-runtime";var Fi=()=>J("div",{}),Vi=({backFn:t})=>J("div",{children:J(Xo,{onClick:t})}),Gi=()=>{let{closePrivyModal:t}=_();return J("div",{children:J("div",{children:J(Jo,{onClick:t})})})};var E=({backFn:t})=>Bi(Hi,{children:[t?J(Vi,{backFn:t}):J(Fi,{}),J(Gi,{})]}),Hi=Di.div`
|
|
12
|
+
- https://privy.io`;this.ethProvider=new me}initialize(){let e=E.get(ot);Bo.includes(e)&&(this.walletType=e,this.connect({showPrompt:!1}))}destroy(){this.walletType=null,E.del(ot),E.del(Lo)}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(Pi());break;case"wallet_connect":let r=new zo({infuraId:et});this.ethProvider.setProvider(r);break;default:throw new V(`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 V(`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 zo({infuraId:et});this.ethProvider.setProvider(o),await Promise.race([o.enable(),zt()]);break;default:throw new V(`Unsupported wallet: ${this.walletType}`)}E.put(ot,e)}catch(o){throw nt(o)}}async sign(e){return new ki(new fe(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?Ai(e[0]):null}};var jt,He=class{constructor(e){let o=e.apiURL||wo,r=e.timeout||Co;this.appId=e.appId,this.connector=new Ge,this.connector.initialize(),jt||(jt=new it),this.session=jt,this.api=new rt(e.appId,this.session,{baseURL:o,timeout:r}),this.session.api=this.api}authenticate(){if(!this.authFlow)throw new p("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new p("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.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(Vo(),{address:e});return J(o.data)}catch(o){throw G(o)}}async unlinkPhone(e){try{let o=await this.api.post(Go(),{phoneNumber:e});return J(o.data)}catch(o){throw G(o)}}async unlinkWallet(e){try{let o=await this.api.post(Fo(),{address:e});return J(o.data)}catch(o){throw G(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(Ho(),{provider:e,subject:o});return J(r.data)}catch(r){throw G(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(){if(this.session.hasActiveToken()){let{verificationKey:e,id:o}=await this.getAppSettings();return await this.session.hasValidToken(e,o,vo)?this.session.token:(await this.logout(),null)}else return 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,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,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 G(e)}}setActiveWallet(e,o){if(!o.linkedAccounts.map(i=>i.type==="wallet"?i.address:null).includes(e))throw new p("Cannot set an unlinked address as active.");return E.put(K,e),Fe(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as Ns}from"@ethersproject/providers";import{createContext as Si,useContext as Ti}from"react";var m=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var $t=Si({ready:!1,authenticated:!1,user:null,walletConnector:null,login:m,linkEmail:m,linkPhone:m,linkWallet:m,linkGoogle:m,linkTwitter:m,linkDiscord:m,logout:m,getAccessToken:m,getEthereumProvider:m,getEthersProvider:m,getWeb3jsProvider:m,unlinkEmail:m,unlinkPhone:m,unlinkWallet:m,unlinkGoogle:m,unlinkTwitter:m,unlinkDiscord:m,setActiveWallet:m,forkSession:m}),N=()=>Ti($t);var Be=class{constructor(e){this.connector=e,this.meta={wallet:this.connector.walletType}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.connector.walletType)throw new p("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Po(),{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 I(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.connector.walletType)throw new p("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api);return(await this.api.post(So(),{message:e,signature:o})).data}catch(e){throw I(e)}}async promptConnectAndSign(e){let o=await this.connector.connect({showPrompt:!0}),r=o.address,i=o.chainId,n=await e.post(_o(),{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 p("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new p("Email and email code must be set prior to calling authenticate.");try{let e=Io(),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 I(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new p("Email and email code must be set prior to calling authenticate.");try{let e=Ro();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw I(e)}}async sendCodeEmail(e){if(!this.api)throw new p("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new p("Email must be set when initialzing authentication.");try{let o=To();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw I(o)}}};var Ze=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new p("phone number and sms code must be set prior to calling authenticate.");try{let e=Wo(),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 I(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new p("phone number and sms code must be set prior to calling authenticate.");try{let e=No();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw I(e)}}async sendSmsCode(e){if(!this.api)throw new p("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new p("phone nNumber must be set when initialzing authentication.");try{let o=Mo();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw I(o)}}};var Se=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 p("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new p("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new p("User denied confirmation during OAuth flow");try{let e=Uo(),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 I(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new p("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new p("User denied confirmation during OAuth flow");try{let e=Do();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw I(e)}}async getAuthorizationUrl(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.provider)throw new p("Provider must be set when initialzing OAuth authentication.");try{let e=Oo();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw I(e)}}};import"wicg-inert";import Ss from"react-dom";import ho from"styled-components";import{createContext as Ri,useContext as Mi,useEffect as jo,useState as $o}from"react";import{jsx as Ii}from"react/jsx-runtime";function Zo(t){return Ii("link",{rel:"prefetch",href:t.src})}import{jsx as Wi,jsxs as Ni}from"react/jsx-runtime";var Ko=Ri({ready:!1,app:null,options:{email:!0,sms:!1,wallet:!0,google:!1,twitter:!1,discord:!1},currentScreen:"LANDING",lastScreen:"LANDING",navigate:m,navigateBack:m}),qo=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=$o(null),[s,c]=$o(null);jo(()=>{o||n(null)},[o]),jo(()=>{r||(c("LANDING"),n("LANDING"))},[r]);let f={ready:!!(e!=null&&e.id),app:e,options:t.options,currentScreen:i||"LANDING",lastScreen:s||"LANDING",navigate:h=>{c(i),n(h)},navigateBack:()=>{n(s)}};return Ni(Ko.Provider,{value:f,children:[e&&e.logoUrl&&Wi(Zo,{src:e.logoUrl}),t.children]})},w=()=>Mi(Ko);import{useEffect as Pn,useState as Sn}from"react";import Ke from"styled-components";import Di from"styled-components";import{jsx as Yo}from"react/jsx-runtime";var Jo=({style:t,...e})=>Yo("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:Yo("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});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:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as Oi,useContext as Ui}from"react";var Kt=Oi({isLinking:!1,getAuthMeta:m,getAuthFlow:m,closePrivyModal:m,initLoginWithWallet:m,loginWithWallet:m,loginWithCode:m,loginWithEmail:m,loginWithSms:m,resendEmailCode:m,resendSmsCode:m,initLoginWithOAuth:m,loginWithOAuth:m,handleLoginError:m}),P=()=>Ui(Kt);import{jsx as Q,jsxs as Bi}from"react/jsx-runtime";var Fi=()=>Q("div",{}),Vi=({backFn:t})=>Q("div",{children:Q(Xo,{onClick:t})}),Gi=()=>{let{closePrivyModal:t}=P();return Q("div",{children:Q("div",{children:Q(Jo,{onClick:t})})})};var A=({backFn:t})=>Bi(Hi,{children:[t?Q(Vi,{backFn:t}):Q(Fi,{}),Q(Gi,{})]}),Hi=Di.div`
|
|
13
13
|
height: 30px;
|
|
14
14
|
display: flex;
|
|
15
15
|
align-items: center;
|
|
@@ -72,7 +72,7 @@ Resources:
|
|
|
72
72
|
@media (max-width: 440px) {
|
|
73
73
|
height: 30px;
|
|
74
74
|
}
|
|
75
|
-
`;import ir from"styled-components";import{jsx as U,jsxs as zi}from"react/jsx-runtime";var
|
|
75
|
+
`;import ir from"styled-components";import{jsx as U,jsxs as zi}from"react/jsx-runtime";var we=({style:t,...e})=>zi("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 er,jsxs as Zi}from"react/jsx-runtime";var ae=({style:t,...e})=>Zi("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:[er("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),er("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 Te,jsxs as ji}from"react/jsx-runtime";var lt=({style:t,...e})=>ji("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:[Te("rect",{width:"28",height:"28",rx:"6",fill:"#141414"}),Te("g",{clipPath:"url(#clip0_1765_9946)",children:Te("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"})}),Te("defs",{children:Te("clipPath",{id:"clip0_1765_9946",children:Te("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]});import{isMobile as rr}from"react-device-detect";import{isIOS as $i,isMobile as Ki}from"react-device-detect";var qt=t=>{let e=new URL(window.location.href);if(!window.ethereum&&Ki){let o;switch(t){case"metamask":$i?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 tr from"styled-components";var or=tr.span`
|
|
76
76
|
@media (max-width: 440px) {
|
|
77
77
|
display: none;
|
|
78
78
|
}
|
|
@@ -80,7 +80,7 @@ Resources:
|
|
|
80
80
|
@media (min-width: 441px) {
|
|
81
81
|
display: none;
|
|
82
82
|
}
|
|
83
|
-
`;import{jsx as
|
|
83
|
+
`;import{jsx as X,jsxs as je}from"react/jsx-runtime";var dt=()=>{let{navigate:t}=w(),{initLoginWithWallet:e,closePrivyModal:o}=P();return je(qi,{children:[je(Yt,{onClick:()=>{Zt()?(e("metamask"),t("AWAITING_CONNECTION")):rr?(qt("metamask"),o()):t("INSTALL_METAMASK_SCREEN")},children:[X(we,{}),X("span",{children:"Metamask"}),X("span",{children:Zt()?"Connect":"Install"})]}),je(Yt,{onClick:()=>{at()?(e("coinbase_wallet"),t("AWAITING_CONNECTION")):rr?(qt("coinbase_wallet"),o()):(e("coinbase_wallet"),t("AWAITING_CONNECTION"))},children:[X(ae,{}),je("span",{children:["Coinbase",X(or,{children:" Wallet"})]}),X("span",{children:"Connect"})]}),je(Yt,{onClick:()=>{e("wallet_connect"),t("AWAITING_CONNECTION")},children:[X(lt,{}),X("span",{children:"WalletConnect"}),X("span",{children:"Connect"})]})]})},qi=ir.div`
|
|
84
84
|
display: flex;
|
|
85
85
|
flex-direction: column;
|
|
86
86
|
align-items: flex-start;
|
|
@@ -90,7 +90,7 @@ Resources:
|
|
|
90
90
|
@media (max-width: 440px) {
|
|
91
91
|
flex-direction: row;
|
|
92
92
|
}
|
|
93
|
-
`,
|
|
93
|
+
`,Yt=ir.button`
|
|
94
94
|
display: flex;
|
|
95
95
|
flex-direction: row;
|
|
96
96
|
align-items: center;
|
|
@@ -157,7 +157,7 @@ Resources:
|
|
|
157
157
|
:hover > :last-child {
|
|
158
158
|
opacity: 1;
|
|
159
159
|
}
|
|
160
|
-
`;import Yi from"styled-components";import{jsx as nr,jsxs as Qi}from"react/jsx-runtime";var
|
|
160
|
+
`;import Yi from"styled-components";import{jsx as nr,jsxs as Qi}from"react/jsx-runtime";var ct=()=>{let{navigate:t}=w();return Qi(Ji,{children:[nr("span",{children:"Don\u2019t have a wallet? "}),nr("button",{onClick:()=>{t("WALLET_EDUCATION")},children:"Create one now."})]})},Ji=Yi.div`
|
|
161
161
|
font-size: 13px;
|
|
162
162
|
color: #6b7280;
|
|
163
163
|
|
|
@@ -168,7 +168,7 @@ Resources:
|
|
|
168
168
|
@media (max-width: 440px) {
|
|
169
169
|
margin-top: 4px;
|
|
170
170
|
}
|
|
171
|
-
`;import lr from"styled-components";import{jsx as sr}from"react/jsx-runtime";var ar=({style:t,...e})=>sr("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:sr("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 en,jsx as
|
|
171
|
+
`;import lr from"styled-components";import{jsx as sr}from"react/jsx-runtime";var ar=({style:t,...e})=>sr("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:sr("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 en,jsx as Ie,jsxs as cr}from"react/jsx-runtime";var Xi=lr.div`
|
|
172
172
|
margin-top: 16px;
|
|
173
173
|
font-size: 12px;
|
|
174
174
|
text-align: left;
|
|
@@ -177,7 +177,7 @@ Resources:
|
|
|
177
177
|
&& > a {
|
|
178
178
|
color: var(--primary-color);
|
|
179
179
|
}
|
|
180
|
-
`;function dr(t){let{privacyPolicyUrl:e,termsAndConditionsUrl:o}=t.app,r=!!e,i=!!o,n=r&&i;return!r&&!i?null:cr(Xi,{children:["By logging in I agree to the"," ",i&&
|
|
180
|
+
`;function dr(t){let{privacyPolicyUrl:e,termsAndConditionsUrl:o}=t.app,r=!!e,i=!!o,n=r&&i;return!r&&!i?null:cr(Xi,{children:["By logging in I agree to the"," ",i&&Ie("a",{href:o,target:"_blank",children:n?"Terms":"Terms of Service"}),n&&" & ",r&&Ie("a",{href:e,target:"_blank",children:"Privacy Policy"})]})}var q=({protectedByPrivy:t})=>Ie(ee,{hideOnMobile:t,children:t?cr(en,{children:[Ie(ar,{}),Ie("span",{children:Ie("a",{href:"https://www.privy.io/",target:"_blank",children:"Protected by Privy"})})]}):null}),ee=lr.div`
|
|
181
181
|
height: 20px;
|
|
182
182
|
font-size: 12px;
|
|
183
183
|
display: flex;
|
|
@@ -199,7 +199,7 @@ Resources:
|
|
|
199
199
|
@media (max-width: 440px) {
|
|
200
200
|
display: ${t=>t.hideOnMobile?"none":"inherit"};
|
|
201
201
|
}
|
|
202
|
-
`;import pr from"styled-components";var
|
|
202
|
+
`;import pr from"styled-components";var le=pr.div`
|
|
203
203
|
display: flex;
|
|
204
204
|
flex-direction: column;
|
|
205
205
|
align-items: flex-start;
|
|
@@ -214,13 +214,13 @@ Resources:
|
|
|
214
214
|
justify-content: center;
|
|
215
215
|
height: 100%;
|
|
216
216
|
width: 100%;
|
|
217
|
-
`;import
|
|
217
|
+
`;import ft from"styled-components";import{jsx as hr}from"react/jsx-runtime";var pt=({style:t,logoFill:e,...o})=>hr("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:hr("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 $e,jsxs as tn}from"react/jsx-runtime";var ut=({logoFill:t,style:e,...o})=>tn("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"0px",y:"0px",viewBox:"0 0 71 55",style:{height:"24px",...e},...o,children:[$e("g",{clipPath:"url(#clip0)",children:$e("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"})}),$e("defs",{children:$e("clipPath",{id:"clip0",children:$e("rect",{width:"71",height:"55",fill:"white"})})})]});import{jsx as ht,jsxs as on}from"react/jsx-runtime";var mt=({style:t,...e})=>on("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:[ht("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"}),ht("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"}),ht("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"}),ht("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 Re,jsxs as ln}from"react/jsx-runtime";var mr=({showGoogle:t,showTwitter:e,showDiscord:o,stacked:r})=>{let{initLoginWithOAuth:i}=P();return ln(rn,{stacked:r,children:[t&&Re(an,{onClick:()=>{i("google")},children:Re(mt,{})}),e&&Re(nn,{onClick:()=>{i("twitter")},children:Re(pt,{})}),o&&Re(sn,{onClick:()=>{i("discord")},children:Re(ut,{})})]})},rn=ft.div`
|
|
218
218
|
display: flex;
|
|
219
219
|
flex-direction: ${t=>t.stacked?"column":"row"};
|
|
220
220
|
justify-content: space-between;
|
|
221
221
|
width: 100%;
|
|
222
222
|
gap: 4px;
|
|
223
|
-
`,nn=
|
|
223
|
+
`,nn=ft.button`
|
|
224
224
|
&& {
|
|
225
225
|
border-radius: var(--border-radius-sm);
|
|
226
226
|
cursor: pointer;
|
|
@@ -232,7 +232,7 @@ Resources:
|
|
|
232
232
|
justify-content: center;
|
|
233
233
|
align-items: center;
|
|
234
234
|
}
|
|
235
|
-
`,sn=
|
|
235
|
+
`,sn=ft.button`
|
|
236
236
|
&& {
|
|
237
237
|
border-radius: var(--border-radius-sm);
|
|
238
238
|
cursor: pointer;
|
|
@@ -244,7 +244,7 @@ Resources:
|
|
|
244
244
|
justify-content: center;
|
|
245
245
|
align-items: center;
|
|
246
246
|
}
|
|
247
|
-
`,an=
|
|
247
|
+
`,an=ft.button`
|
|
248
248
|
&& {
|
|
249
249
|
border-radius: var(--border-radius-sm);
|
|
250
250
|
cursor: pointer;
|
|
@@ -257,7 +257,7 @@ Resources:
|
|
|
257
257
|
align-items: center;
|
|
258
258
|
border: 1px solid #e5e7eb;
|
|
259
259
|
}
|
|
260
|
-
`;import{useEffect as un,useState as
|
|
260
|
+
`;import{useEffect as un,useState as Jt}from"react";import Me from"styled-components";import{jsx as fr}from"react/jsx-runtime";var gt=({style:t,...e})=>fr("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:fr("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 dn from"styled-components";import{jsx as cn}from"react/jsx-runtime";var wt=({success:t,fail:e})=>cn(de,{className:t?"success":e?"fail":""}),de=dn.span`
|
|
261
261
|
&& {
|
|
262
262
|
width: 82px;
|
|
263
263
|
height: 82px;
|
|
@@ -290,7 +290,7 @@ Resources:
|
|
|
290
290
|
border-color: var(--fail-light);
|
|
291
291
|
border-bottom-color: var(--fail-light);
|
|
292
292
|
}
|
|
293
|
-
`;import{isPossiblePhoneNumber as pn}from"libphonenumber-js/min";var gr=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,}))$/),wr=t=>pn(String(t),"US"),
|
|
293
|
+
`;import{isPossiblePhoneNumber as pn}from"libphonenumber-js/min";var gr=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,}))$/),wr=t=>pn(String(t),"US"),yt=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)}},yr=(t,e)=>{var o=t.slice(0);let r=[];for(;o.length;)r.push(o.splice(0,e));return r};import{Fragment as Cn,jsx as te,jsxs as Qt}from"react/jsx-runtime";var Ct=t=>{let[e,o]=Jt(""),[r,i]=Jt(!1),[n,s]=Jt(null),{authenticated:c}=N(),{loginWithEmail:f,handleLoginError:h}=P(),{navigate:S,options:b}=w(),k=b.wallet;un(()=>{let a=document.querySelector("#email-input");a==null||a.focus()},[]);let x=gr(e),L=()=>{i(!0),f(e).then(()=>{S("AWAITING_PASSWORDLESS_CODE")}).catch(a=>{let v=(a==null?void 0:a.status)===401&&(a==null?void 0:a.message)==="User is not allowed to login to this app.";(a==null?void 0:a.status)===422?s(a.message):s(v?"You don't have access to this app":"Issue submitting email"),i(!1),h(v)})};return Qt(Cn,{children:[Qt(hn,{stacked:t.stacked,children:[Qt(gn,{standalone:t.stacked,children:[te(gt,{}),te("input",{id:"email-input",type:"email",placeholder:"your@email.com",onChange:a=>o(a.target.value),onKeyUp:a=>{a.key==="Enter"&&L()},value:e,autoComplete:"email"})]}),t.stacked?null:te(mn,{disabled:r||!x,onClick:L,children:r?te(de,{color:"var(--disabled-fg)",style:{height:"1rem",width:"1rem",borderWidth:"2px"}}):"Submit"})]}),n||c||!k?te(yn,{fail:!!n,children:n||""}):null,!n&&!c&&k?te(wn,{children:te("span",{children:"Get started without a wallet."})}):null,t.stacked?te(fn,{disabled:r||!x,onClick:L,children:r?te(de,{color:"var(--disabled-fg)",style:{height:"1rem",width:"1rem",borderWidth:"2px"}}):"Submit"}):null]})},hn=Me.div`
|
|
294
294
|
display: flex;
|
|
295
295
|
border: 1px solid #d1d5db;
|
|
296
296
|
width: 100%;
|
|
@@ -304,7 +304,7 @@ Resources:
|
|
|
304
304
|
@media (max-width: 440px) {
|
|
305
305
|
margin-top: 20px;
|
|
306
306
|
}
|
|
307
|
-
`,mn=
|
|
307
|
+
`,mn=Me.button`
|
|
308
308
|
display: flex;
|
|
309
309
|
flex-direction: row;
|
|
310
310
|
align-items: center;
|
|
@@ -329,7 +329,7 @@ Resources:
|
|
|
329
329
|
color: var(--disabled-fg);
|
|
330
330
|
cursor: not-allowed;
|
|
331
331
|
}
|
|
332
|
-
`,fn=
|
|
332
|
+
`,fn=Me.button`
|
|
333
333
|
display: flex;
|
|
334
334
|
flex-direction: column;
|
|
335
335
|
align-items: center;
|
|
@@ -353,7 +353,7 @@ Resources:
|
|
|
353
353
|
color: var(--disabled-fg);
|
|
354
354
|
cursor: not-allowed;
|
|
355
355
|
}
|
|
356
|
-
`,gn=
|
|
356
|
+
`,gn=Me.label`
|
|
357
357
|
display: flex;
|
|
358
358
|
flex-direction: row;
|
|
359
359
|
align-items: center;
|
|
@@ -390,7 +390,7 @@ Resources:
|
|
|
390
390
|
line-height: 24px;
|
|
391
391
|
}
|
|
392
392
|
}
|
|
393
|
-
`,wn=
|
|
393
|
+
`,wn=Me.div`
|
|
394
394
|
font-size: 13px;
|
|
395
395
|
color: #6b7280;
|
|
396
396
|
text-align: left;
|
|
@@ -398,7 +398,7 @@ Resources:
|
|
|
398
398
|
> button {
|
|
399
399
|
text-decoration: underline;
|
|
400
400
|
}
|
|
401
|
-
`,yn=
|
|
401
|
+
`,yn=Me.div`
|
|
402
402
|
line-height: 20px;
|
|
403
403
|
height: 20px;
|
|
404
404
|
font-size: 13px;
|
|
@@ -410,7 +410,7 @@ Resources:
|
|
|
410
410
|
opacity: ${t=>t.success||t.fail?"1":"0"};
|
|
411
411
|
|
|
412
412
|
transition: ${t=>t.fail?"":"all 150ms ease-in-out"};
|
|
413
|
-
`;import{useEffect as vn,useState as
|
|
413
|
+
`;import{useEffect as vn,useState as Xt}from"react";import ye from"styled-components";import{jsx as Cr}from"react/jsx-runtime";var vt=({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 _n,jsx as oe,jsxs as eo}from"react/jsx-runtime";var bt=t=>{let[e,o]=Xt(""),[r,i]=Xt(!1),[n,s]=Xt(null),{authenticated:c}=N(),{loginWithSms:f,handleLoginError:h}=P(),{navigate:S,options:b}=w(),k=b.wallet;vn(()=>{let a=document.querySelector("#phone-number-input");a==null||a.focus()},[]);let x=wr(e),L=()=>{i(!0),f(e).then(()=>{S("AWAITING_PASSWORDLESS_CODE")}).catch(a=>{let v=(a==null?void 0:a.status)===401&&(a==null?void 0:a.message)==="User is not allowed to login to this app.";(a==null?void 0:a.status)===422?s(a.message):s(v?"You don't have access to this app":"Issue submitting phone number"),i(!1),h(v)})};return eo(_n,{children:[eo(bn,{stacked:t.stacked,children:[eo(En,{standalone:t.stacked,children:[oe(vt,{}),oe("input",{id:"phone-number-input",type:"tel",placeholder:"555 555 5555",onChange:a=>{o(a.target.value)},onKeyUp:a=>{a.key==="Enter"&&L()},value:e,autoComplete:"tel"})]}),t.stacked?null:oe(xn,{disabled:r||!x,onClick:L,children:r?oe(vr,{color:"var(--disabled-fg)"}):"Submit"})]}),n||c||!k?oe(kn,{fail:!!n,children:n||""}):null,!n&&!c&&k?oe(An,{children:oe("span",{children:"Don\u2019t have a wallet? Start exploring with your phone or socials."})}):null,t.stacked?oe(Ln,{disabled:r||!x,onClick:L,children:r?oe(vr,{color:"var(--disabled-fg)"}):"Submit"}):null]})},bn=ye.div`
|
|
414
414
|
display: flex;
|
|
415
415
|
border: 1px solid #d1d5db;
|
|
416
416
|
width: 100%;
|
|
@@ -424,7 +424,7 @@ Resources:
|
|
|
424
424
|
@media (max-width: 440px) {
|
|
425
425
|
margin-top: 20px;
|
|
426
426
|
}
|
|
427
|
-
`,xn=
|
|
427
|
+
`,xn=ye.button`
|
|
428
428
|
display: flex;
|
|
429
429
|
flex-direction: row;
|
|
430
430
|
align-items: center;
|
|
@@ -449,7 +449,7 @@ Resources:
|
|
|
449
449
|
color: var(--disabled-fg);
|
|
450
450
|
cursor: not-allowed;
|
|
451
451
|
}
|
|
452
|
-
`,Ln=
|
|
452
|
+
`,Ln=ye.button`
|
|
453
453
|
display: flex;
|
|
454
454
|
flex-direction: column;
|
|
455
455
|
align-items: center;
|
|
@@ -473,7 +473,7 @@ Resources:
|
|
|
473
473
|
color: var(--disabled-fg);
|
|
474
474
|
cursor: not-allowed;
|
|
475
475
|
}
|
|
476
|
-
`,En=
|
|
476
|
+
`,En=ye.label`
|
|
477
477
|
display: flex;
|
|
478
478
|
flex-direction: row;
|
|
479
479
|
align-items: center;
|
|
@@ -510,14 +510,14 @@ Resources:
|
|
|
510
510
|
line-height: 24px;
|
|
511
511
|
}
|
|
512
512
|
}
|
|
513
|
-
`,An=
|
|
513
|
+
`,An=ye.div`
|
|
514
514
|
font-size: 13px;
|
|
515
515
|
color: #6b7280;
|
|
516
516
|
|
|
517
517
|
> button {
|
|
518
518
|
text-decoration: underline;
|
|
519
519
|
}
|
|
520
|
-
`,kn=
|
|
520
|
+
`,kn=ye.div`
|
|
521
521
|
line-height: 20px;
|
|
522
522
|
height: 20px;
|
|
523
523
|
font-size: 13px;
|
|
@@ -529,19 +529,19 @@ Resources:
|
|
|
529
529
|
opacity: ${t=>t.success||t.fail?"1":"0"};
|
|
530
530
|
|
|
531
531
|
transition: ${t=>t.fail?"":"all 150ms ease-in-out"};
|
|
532
|
-
`,vr=
|
|
532
|
+
`,vr=ye(de)`
|
|
533
533
|
&& {
|
|
534
534
|
height: 1rem;
|
|
535
535
|
width: 1rem;
|
|
536
536
|
border-width: 2px;
|
|
537
537
|
}
|
|
538
|
-
`;import{jsx as br}from"react/jsx-runtime";var xr=()=>{let{app:t}=w();return t!=null&&t.logoUrl?br("div",{children:br("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{isMobile as Lr}from"react-device-detect";import{Fragment as
|
|
538
|
+
`;import{jsx as br}from"react/jsx-runtime";var xr=()=>{let{app:t}=w();return t!=null&&t.logoUrl?br("div",{children:br("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{isMobile as Lr}from"react-device-detect";import{Fragment as Ce,jsx as C,jsxs as re}from"react/jsx-runtime";var Ar=()=>{let{ready:t}=N(),{getAuthMeta:e,isLinking:o}=P(),{app:r,navigate:i,options:n}=w(),s=n.email,c=n.sms,f=n.wallet,h=n.google,S=n.twitter,b=n.discord,k=f&&(r==null?void 0:r.showWalletLoginFirst)?0:1,[x,L]=Sn(k),a=e(),v=(a==null?void 0:a.authorizationCode)&&(a==null?void 0:a.stateCode)&&(a==null?void 0:a.provider);Pn(()=>{v?i("AWAITING_OAUTH_SCREEN"):o&&s?i("LINK_EMAIL_SCREEN"):o&&c?i("LINK_PHONE_SCREEN"):o&&f&&i("LINK_WALLET_SCREEN")},[t]);let F=x==0,W=x==1,Y=()=>C(Ce,{children:f&&C(Tn,{active:F,onClick:()=>L(0)})}),y=()=>C(Ce,{children:(s||c)&&C(In,{active:W,onClick:()=>L(1),email:s,sms:c,google:h,twitter:S,discord:b})});return re(Ce,{children:[C(A,{},"header"),C(Wn,{walletOnly:!s&&!c&&!h&&!S&&!b,hasTerms:!!((r==null?void 0:r.privacyPolicyUrl)||(r==null?void 0:r.termsAndConditionsUrl)),children:C(xr,{})}),C(le,{children:r!=null&&r.showWalletLoginFirst?re(Ce,{children:[C(Y,{}),C(y,{})]}):re(Ce,{children:[C(y,{}),C(Y,{})]})}),r&&C(dr,{app:r}),C(q,{protectedByPrivy:!0})]})};function Tn(t){return re(_r,{active:t.active,onClick:t.onClick,children:[C(kr,{active:t.active,children:C("h4",{children:"Connect Wallet"})}),t.active&&re(Ce,{children:[C(dt,{}),C(ct,{})]})]})}function In(t){let e=t.google||t.discord||t.twitter&&!Lr,o=t.email?"Email":"Phone";return re(_r,{active:t.active,onClick:t.onClick,children:[C(kr,{active:t.active,children:re("h4",{children:["Sign In with ",e?`${o} & Social`:o]})}),t.active&&t.email&&C(Ct,{}),t.active&&t.sms&&!t.email&&C(bt,{}),t.active&&e&&C(Rn,{google:t.google,twitter:t.twitter&&!Lr,discord:t.discord})]})}function Rn(t){return re(Ce,{children:[re(Mn,{children:[C(Er,{}),C("p",{children:" Or "}),C(Er,{})]}),C(mr,{showGoogle:t.google,showDiscord:t.discord,showTwitter:t.twitter})]})}var kr=Ke.div`
|
|
539
539
|
font-weight: ${t=>t.active?600:500};
|
|
540
540
|
color: ${t=>t.active?"inherit":"#6b7280"};
|
|
541
541
|
display: flex;
|
|
542
542
|
justify-content: center;
|
|
543
543
|
align-items: center;
|
|
544
|
-
`,_r
|
|
544
|
+
`,_r=Ke.div`
|
|
545
545
|
display: flex;
|
|
546
546
|
flex-direction: column;
|
|
547
547
|
align-items: flex-start;
|
|
@@ -562,18 +562,18 @@ Resources:
|
|
|
562
562
|
}
|
|
563
563
|
|
|
564
564
|
cursor: ${t=>t.active?"inherit":"pointer"};
|
|
565
|
-
`,Mn
|
|
565
|
+
`,Mn=Ke.div`
|
|
566
566
|
display: flex;
|
|
567
567
|
justify-content: center;
|
|
568
568
|
align-items: center;
|
|
569
569
|
width: 100%;
|
|
570
|
-
`,Er
|
|
570
|
+
`,Er=Ke.hr`
|
|
571
571
|
width: 50%;
|
|
572
572
|
&& {
|
|
573
573
|
border-top: 1px solid #d1d5db;
|
|
574
574
|
margin: 0px 8px;
|
|
575
575
|
}
|
|
576
|
-
`,Wn
|
|
576
|
+
`,Wn=Ke.div`
|
|
577
577
|
display: flex;
|
|
578
578
|
flex-direction: column;
|
|
579
579
|
align-items: center;
|
|
@@ -593,9 +593,9 @@ Resources:
|
|
|
593
593
|
// the logo is close to the top (mobile or full wallet-open design)
|
|
594
594
|
margin-top: ${t=>`${28+(t.walletOnly?31:0)-(t.hasTerms?18:0)}px`};
|
|
595
595
|
margin-bottom: ${t=>`${60+(t.walletOnly?31:0)-(t.hasTerms?18:0)}px`};
|
|
596
|
-
`;import{useEffect as Ir,useState as
|
|
596
|
+
`;import{useEffect as Ir,useState as Lt}from"react";import Et from"styled-components";import xt from"styled-components";import{jsx as qe,jsxs as Tr}from"react/jsx-runtime";var ve=({title:t,description:e,children:o,...r})=>Tr(Sr,{...r,children:[qe("h3",{children:t}),typeof e=="string"?qe("p",{children:e}):null,o]}),Pr=xt(ve)`
|
|
597
597
|
margin-bottom: 24px;
|
|
598
|
-
`,
|
|
598
|
+
`,We=({title:t,description:e,icon:o,children:r,...i})=>Tr(Nn,{...i,children:[o?qe(On,{children:o}):null,qe("h3",{children:t}),typeof e=="string"?qe("p",{children:e}):null,r]}),Sr=xt.div`
|
|
599
599
|
display: flex;
|
|
600
600
|
flex-direction: column;
|
|
601
601
|
justify-content: flex-start;
|
|
@@ -614,7 +614,7 @@ Resources:
|
|
|
614
614
|
color: var(--text-dark-gray);
|
|
615
615
|
font-size: 14px;
|
|
616
616
|
}
|
|
617
|
-
`,Nn=
|
|
617
|
+
`,Nn=xt(Sr)`
|
|
618
618
|
align-items: center;
|
|
619
619
|
text-align: center;
|
|
620
620
|
gap: 16px;
|
|
@@ -622,21 +622,21 @@ Resources:
|
|
|
622
622
|
h3 {
|
|
623
623
|
margin-bottom: 24px;
|
|
624
624
|
}
|
|
625
|
-
`,On=
|
|
625
|
+
`,On=xt.div`
|
|
626
626
|
padding: 14px;
|
|
627
627
|
border-radius: 50%;
|
|
628
628
|
&& {
|
|
629
629
|
border-color: #e1e7ef;
|
|
630
630
|
border-width: 1px;
|
|
631
631
|
}
|
|
632
|
-
`;import{Fragment as to,jsx as H,jsxs as
|
|
632
|
+
`;import{Fragment as to,jsx as H,jsxs as Ne}from"react/jsx-runtime";var oo=6,Rr=new Array(oo).fill(""),Un=1400;var Mr=()=>{var Z,l,d;let{app:t}=w(),{closePrivyModal:e,resendEmailCode:o,resendSmsCode:r,getAuthMeta:i,loginWithCode:n}=P(),{authenticated:s,user:c}=N(),[f,h]=Lt(Rr),[S,b]=Lt(!1),[k,x]=Lt(null),[L,a]=Lt(null),v=(Z=i())!=null&&Z.email?0:1;Ir(()=>{if(s&&S){let _=setTimeout(e,Ee);return()=>clearTimeout(_)}},[s,S,c]),Ir(()=>{if(k&&L===0){let _=setTimeout(()=>{h(Rr),x(null);let T=document.querySelector("input[name=code-0]");T==null||T.focus()},Un);return()=>clearTimeout(_)}},[k]);let F=_=>{var fo;let T=_.currentTarget.value.replace(" ","");if(T==="")return;if(isNaN(Number(T))){x("Code should be numeric"),a(1);return}x(null),a(null);let j=Number((fo=_.currentTarget.name)==null?void 0:fo.charAt(5)),Ot=[...T||[""]].slice(0,oo-j),Ut=[...f.slice(0,j),...Ot,...f.slice(j+Ot.length)];h(Ut);let hi=Ot.length,mo=Math.min(Math.max(j+hi,0),oo-1);if(!isNaN(Number(_.currentTarget.value))){let $=document.querySelector(`input[name=code-${mo}]`);$==null||$.focus()}if(Ut.every($=>$&&!isNaN(+$))){let $=document.querySelector(`input[name=code-${mo}]`);$==null||$.blur(),n(Ut.join("")).then(()=>b(!0)).catch(Dt=>{(Dt==null?void 0:Dt.status)===422?x("Invalid or expired verification code"):x("Issue verifying code"),a(0)})}_.preventDefault()},W=_=>{L===1&&(x(null),a(null));let T=[...f.slice(0,_),"",...f.slice(_+1)];if(h(T),_>0){let j=document.querySelector(`input[name=code-${_-1}]`);j==null||j.focus()}},Y=`Verify your ${v==0?"email":"phone"}`,y=v==0?`Please check ${(l=i())==null?void 0:l.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 Ne(to,{children:[H(A,{},"header"),Ne(Dn,{children:[H(ve,{title:Y,description:y}),Ne(ur,{children:[Ne(Fn,{children:[H(Vn,{fail:!!k,success:S,children:H("span",{children:k||(S?"Success!":"")})}),H("div",{children:f.map((_,T)=>H("input",{name:`code-${T}`,type:"text",value:f[T],onChange:F,onKeyUp:j=>{j.key==="Backspace"&&W(T)},inputMode:"numeric",autoFocus:T===0,pattern:"[0-9]",className:`${S?"success":""} ${k?"fail":""}`,autoComplete:"one-time-code"},T))})]}),H(Gn,{children:v==0?Ne(to,{children:[H("span",{children:"Didn't get an email?"}),H("button",{onClick:o,children:"Resend Code"})]}):Ne(to,{children:[H("span",{children:"Didn't get a message?"}),H("button",{onClick:r,children:"Resend Code"})]})})]})]}),H(q,{protectedByPrivy:!0})]})},Dn=Et.div`
|
|
633
633
|
display: flex;
|
|
634
634
|
flex-direction: column;
|
|
635
635
|
align-items: flex-start;
|
|
636
636
|
justify-content: flex-end;
|
|
637
637
|
margin: auto;
|
|
638
638
|
gap: 16px;
|
|
639
|
-
`,Fn=
|
|
639
|
+
`,Fn=Et.div`
|
|
640
640
|
display: flex;
|
|
641
641
|
flex-direction: column;
|
|
642
642
|
width: 100%;
|
|
@@ -645,7 +645,7 @@ Resources:
|
|
|
645
645
|
// center just this element.
|
|
646
646
|
margin-top: 70px;
|
|
647
647
|
|
|
648
|
-
${
|
|
648
|
+
${At}[data-height='medium'] & {
|
|
649
649
|
/* Aligns this with the input field on the page before on shorter modals */
|
|
650
650
|
margin-top: 22px;
|
|
651
651
|
}
|
|
@@ -704,7 +704,7 @@ Resources:
|
|
|
704
704
|
transform: translate(1px, 0px);
|
|
705
705
|
}
|
|
706
706
|
}
|
|
707
|
-
`,Vn=
|
|
707
|
+
`,Vn=Et.div`
|
|
708
708
|
line-height: 20px;
|
|
709
709
|
height: 20px;
|
|
710
710
|
font-size: 13px;
|
|
@@ -712,7 +712,7 @@ Resources:
|
|
|
712
712
|
display: flex;
|
|
713
713
|
justify-content: flex-end;
|
|
714
714
|
width: 100%;
|
|
715
|
-
`,Gn=
|
|
715
|
+
`,Gn=Et.div`
|
|
716
716
|
font-size: 13px;
|
|
717
717
|
color: #6b7280;
|
|
718
718
|
display: flex;
|
|
@@ -726,7 +726,7 @@ Resources:
|
|
|
726
726
|
> button {
|
|
727
727
|
text-decoration: underline;
|
|
728
728
|
}
|
|
729
|
-
`;import{useState as ts}from"react";import z from"styled-components";import Hn from"qrcode";import Bn from"styled-components";import{Fragment as
|
|
729
|
+
`;import{useState as ts}from"react";import z from"styled-components";import Hn from"qrcode";import Bn from"styled-components";import{Fragment as Oe,jsx as O,jsxs as Or}from"react/jsx-runtime";var D=7,ro=(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},zn=t=>{let e=Hn.create(t,{errorCorrectionLevel:"high"}).modules,o=yr(Array.from(e.data),e.size);return o=ro(o,0,0,D,D),o=ro(o,o.length-D,0,D,D),o=ro(o,0,o.length-D,D,D),o},Zn=({x:t,y:e,cellSize:o,bgColor:r,fgColor:i})=>O(Oe,{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}`))}),jn=({cellSize:t,matrixSize:e,bgColor:o,fgColor:r})=>{let i=[[0,0],[(e-D)*t,0],[0,(e-D)*t]];return O(Oe,{children:i.map(([n,s])=>O(Zn,{x:n,y:s,cellSize:t,bgColor:o,fgColor:r}))})},$n=({matrix:t,cellSize:e,color:o})=>O(Oe,{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(Oe,{})))}),Wr=(t,e)=>t-t%e,Kn=({outputSize:t,cellSize:e,element:o,size:r,padding:i,bgColor:n})=>{if(!o)return O(Oe,{});let s=r||40,c=i||4,f=o,h=t/2-s/2-c;return Or(Oe,{children:[O("rect",{x:Wr(h,e),y:Wr(h,e),width:s+c*2+(h%e?e+.5:.5),height:s+c*2+(h%e?e+.5:.5),fill:n}),O(f,{x:t/2-s/2,y:t/2-s/2,height:s,width:s})]})},qn=t=>{var i;let e=t.outputSize,o=zn(t.url),r=e/o.length;return Or("svg",{height:t.outputSize,width:t.outputSize,viewBox:`0 0 ${t.outputSize} ${t.outputSize}`,style:{height:"100%",width:"100%"},children:[O($n,{matrix:o,cellSize:r,color:t.fgColor}),O(jn,{cellSize:r,matrixSize:o.length,fgColor:t.fgColor,bgColor:t.bgColor}),O(Kn,{outputSize:t.outputSize,cellSize:r,element:(i=t.logo)==null?void 0:i.element,bgColor:t.bgColor})]})},Yn=Bn.div`
|
|
730
730
|
display: flex;
|
|
731
731
|
justify-content: center;
|
|
732
732
|
align-items: center;
|
|
@@ -741,18 +741,18 @@ Resources:
|
|
|
741
741
|
border-color: ${t=>t.fgColor};
|
|
742
742
|
border-radius: 12px;
|
|
743
743
|
}
|
|
744
|
-
`,Nr=t=>{let e=t.bgColor||"#FFFFFF",o=t.fgColor||"#000000",r=t.size||160;return O(Yn,{size:r,bgColor:e,fgColor:o,children:O(qn,{url:t.url,logo:{element:t.squareLogoElement},outputSize:r,bgColor:e,fgColor:o})})};import{jsx as Jn}from"react/jsx-runtime";var Ur=({size:t})=>Jn(Nr,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:
|
|
744
|
+
`,Nr=t=>{let e=t.bgColor||"#FFFFFF",o=t.fgColor||"#000000",r=t.size||160;return O(Yn,{size:r,bgColor:e,fgColor:o,children:O(qn,{url:t.url,logo:{element:t.squareLogoElement},outputSize:r,bgColor:e,fgColor:o})})};import{jsx as Jn}from"react/jsx-runtime";var Ur=({size:t})=>Jn(Nr,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:ae,size:t,fgColor:"#1F1F1F"});import io from"styled-components";import{jsx as Dr}from"react/jsx-runtime";var Fr=({style:t,...e})=>Dr("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:Dr("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 Xn,jsxs as es}from"react/jsx-runtime";var no=io.div`
|
|
745
745
|
display: flex;
|
|
746
746
|
flex-direction: column;
|
|
747
747
|
justify-content: flex-start;
|
|
748
748
|
gap: 4px;
|
|
749
|
-
`,
|
|
749
|
+
`,Ye=io.div`
|
|
750
750
|
&&& {
|
|
751
751
|
margin-left: 7px; /* TODO: This is a total hack */
|
|
752
752
|
border-left: 2px solid #e5e7eb;
|
|
753
753
|
height: 12px;
|
|
754
754
|
}
|
|
755
|
-
`,
|
|
755
|
+
`,be=({children:t})=>es(Qn,{children:[Xn(Fr,{style:{width:"16px",height:"16px"}}),t]}),Qn=io.div`
|
|
756
756
|
display: flex;
|
|
757
757
|
justify-content: flex-start;
|
|
758
758
|
justify-items: center;
|
|
@@ -770,7 +770,7 @@ Resources:
|
|
|
770
770
|
margin-bottom: auto;
|
|
771
771
|
}
|
|
772
772
|
}
|
|
773
|
-
`;import{jsx as g,jsxs as At}from"react/jsx-runtime";var Vr=({style:t,...e})=>At("svg",{width:"286",height:"183",viewBox:"0 0 286 183",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"1.25rem",width:"1.25rem",...t},...e,children:[g("rect",{x:"198.5",y:"133",width:"50",height:"50",rx:"25",fill:"#E1E7EF"}),g("path",{d:"M236.373 144.791L225.206 153.052L227.289 148.181L236.373 144.791Z",fill:"#E17726",stroke:"#E17726",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M210.627 144.791L221.692 153.116L219.711 148.187L210.627 144.785V144.791ZM232.353 163.933L229.377 168.47L235.738 170.219L237.557 164.036L232.347 163.933H232.353ZM209.448 164.036L211.257 170.219L217.602 168.47L214.647 163.933L209.448 164.036Z",fill:"#E27625",stroke:"#E27625",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M217.262 156.27L215.497 158.939L221.783 159.23L221.579 152.46L217.262 156.281V156.27V156.27ZM229.737 156.281L225.351 152.374L225.206 159.23L231.492 158.939L229.732 156.281H229.737ZM217.602 168.475L221.417 166.64L218.14 164.089L217.607 168.475H217.602ZM225.588 166.63L229.377 168.475L228.865 164.084L225.588 166.635V166.63Z",fill:"#E27625",stroke:"#E27625",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M229.377 168.47L225.588 166.635L225.895 169.1L225.862 170.144L229.382 168.47H229.377ZM217.602 168.47L221.137 170.144L221.11 169.1L221.417 166.635L217.602 168.47V168.47Z",fill:"#D5BFB2",stroke:"#D5BFB2",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M221.197 162.448L218.054 161.533L220.282 160.516L221.207 162.453H221.197V162.448ZM225.793 162.448L226.729 160.505L228.962 161.522L225.793 162.459V162.448Z",fill:"#233447",stroke:"#233447",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M217.602 168.47L218.156 163.933L214.647 164.035L217.602 168.47V168.47ZM228.844 163.933L229.377 168.47L232.353 164.035L228.844 163.933V163.933ZM231.503 158.939L225.217 159.23L225.793 162.459L226.729 160.505L228.962 161.522L231.503 158.939V158.939ZM218.054 161.533L220.282 160.516L221.207 162.453L221.794 159.224L215.508 158.944L218.059 161.538L218.054 161.533Z",fill:"#CC6228",stroke:"#CC6228",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M215.503 158.939L218.134 164.078L218.048 161.528L215.497 158.934L215.503 158.939ZM228.962 161.533L228.86 164.084L231.492 158.944L228.957 161.538L228.962 161.533ZM221.794 159.23L221.196 162.459L221.945 166.263L222.117 161.242L221.794 159.23ZM225.211 159.23L224.904 161.237L225.055 166.269L225.792 162.453L225.206 159.224V159.235L225.211 159.23Z",fill:"#E27525",stroke:"#E27525",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M225.793 162.448L225.055 166.263L225.588 166.635L228.86 164.084L228.962 161.528L225.793 162.448V162.448ZM218.054 161.528L218.14 164.078L221.417 166.629L221.945 166.263L221.207 162.448L218.048 161.528H218.059H218.054Z",fill:"#F5841F",stroke:"#F5841F",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M225.868 170.144L225.895 169.1L225.604 168.863H221.39L221.11 169.1L221.137 170.144L217.602 168.47L218.845 169.487L221.353 171.215H225.642L228.155 169.482L229.377 168.47L225.857 170.144H225.868V170.144Z",fill:"#C0AC9D",stroke:"#C0AC9D",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M225.588 166.63L225.055 166.264H221.945L221.417 166.635L221.11 169.1L221.39 168.863H225.604L225.895 169.1L225.588 166.635V166.624V166.63Z",fill:"#161616",stroke:"#161616",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M236.846 153.585L237.783 149.037L236.373 144.791L225.583 152.777L229.737 156.27L235.598 157.976L236.889 156.475L236.33 156.066L237.223 155.248L236.545 154.72L237.438 154.042L236.846 153.585H236.857H236.846ZM209.217 149.032L210.17 153.585L209.556 154.037L210.466 154.715L209.787 155.248L210.67 156.066L210.11 156.475L211.402 157.976L217.263 156.275L221.417 152.767L210.627 144.791L209.217 149.032V149.032Z",fill:"#763E1A",stroke:"#763E1A",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M235.598 157.976L229.737 156.275L231.502 158.934L228.871 164.073L232.353 164.03H237.562L235.598 157.97V157.976ZM217.263 156.27L211.402 157.976L209.448 164.035H214.658L218.14 164.079L215.508 158.939L217.273 156.27H217.263V156.27ZM225.206 159.224L225.588 152.766L227.289 148.176H219.711L221.412 152.766L221.794 159.224L221.939 161.248V166.263H225.055L225.071 161.248L225.206 159.224V159.224Z",fill:"#F5841F",stroke:"#F5841F",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("rect",{x:"192",y:"30",width:"50",height:"50",rx:"25",fill:"#0C5BFF"}),g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M205 55C205 61.6274 210.373 67 217 67C223.627 67 229 61.6274 229 55C229 48.3726 223.627 43 217 43C210.373 43 205 48.3726 205 55ZM213.933 51.1333C213.491 51.1333 213.133 51.4915 213.133 51.9333V58.0667C213.133 58.5085 213.491 58.8667 213.933 58.8667H220.067C220.508 58.8667 220.867 58.5085 220.867 58.0667V51.9333C220.867 51.4915 220.508 51.1333 220.067 51.1333H213.933Z",fill:"white"}),g("rect",{x:"39.5",y:"18",width:"50",height:"50",rx:"25",fill:"url(#paint0_linear_428_81)"}),g("path",{d:"M77.3677 42.8335H74.102C74.102 36.2519 68.6881 30.9167 62.0091 30.9167C55.4129 30.9167 50.0501 36.1213 49.9189 42.5901C49.7831 49.2769 56.1492 55.0834 62.9357 55.0834H63.7893C69.7724 55.0834 77.7916 50.468 79.0445 44.8444C79.2758 43.8079 78.445 42.8335 77.3677 42.8335ZM57.1562 43.1267C57.1562 44.0068 56.4257 44.7267 55.5325 44.7267C54.6394 44.7267 53.9089 44.0065 53.9089 43.1267V40.5383C53.9089 39.6582 54.6394 38.9383 55.5325 38.9383C56.4257 38.9383 57.1562 39.6582 57.1562 40.5383V43.1267ZM62.794 43.1267C62.794 44.0068 62.0636 44.7267 61.1705 44.7267C60.2773 44.7267 59.5468 44.0065 59.5468 43.1267V40.5383C59.5468 39.6582 60.2776 38.9383 61.1705 38.9383C62.0636 38.9383 62.794 39.6582 62.794 40.5383V43.1267Z",fill:"url(#paint1_linear_428_81)"}),g("rect",{x:"46.5",y:"124",width:"50",height:"50",rx:"25",fill:"#141414"}),g("g",{clipPath:"url(#clip0_428_81)",children:g("path",{d:"M62.1497 143.578C67.3134 138.585 75.6867 138.585 80.8505 143.578L81.4722 144.179C81.5335 144.238 81.5822 144.308 81.6155 144.386C81.6488 144.463 81.666 144.547 81.666 144.631C81.666 144.715 81.6488 144.799 81.6155 144.876C81.5822 144.954 81.5335 145.024 81.4722 145.083L79.3462 147.139C79.2835 147.199 79.1996 147.232 79.1123 147.232C79.025 147.232 78.9411 147.199 78.8784 147.139L78.0232 146.311C74.421 142.829 68.58 142.829 64.977 146.311L64.0611 147.197C63.9984 147.257 63.9145 147.29 63.8272 147.29C63.7399 147.29 63.656 147.257 63.5933 147.197L61.4672 145.141C61.4059 145.083 61.3572 145.012 61.3239 144.935C61.2906 144.857 61.2735 144.774 61.2735 144.689C61.2735 144.605 61.2906 144.521 61.3239 144.444C61.3572 144.366 61.4059 144.296 61.4672 144.237L62.1497 143.578ZM85.248 147.829L87.1397 149.659C87.201 149.718 87.2497 149.788 87.283 149.865C87.3163 149.943 87.3334 150.027 87.3334 150.111C87.3334 150.195 87.3163 150.279 87.283 150.356C87.2497 150.434 87.201 150.504 87.1397 150.563L78.6081 158.812C78.4828 158.933 78.315 159 78.1403 159C77.9656 159 77.7978 158.933 77.6725 158.812L71.6177 152.957C71.5864 152.927 71.5443 152.91 71.5005 152.91C71.4567 152.91 71.4147 152.927 71.3833 152.957L65.3285 158.812C65.2032 158.933 65.0354 159 64.8607 159C64.686 159 64.5182 158.933 64.3929 158.812L55.8605 150.563C55.7992 150.504 55.7505 150.434 55.7172 150.356C55.6839 150.279 55.6667 150.195 55.6667 150.111C55.6667 150.027 55.6839 149.943 55.7172 149.865C55.7505 149.788 55.7992 149.718 55.8605 149.659L57.7531 147.829C57.8783 147.709 58.0459 147.642 58.2204 147.642C58.3949 147.642 58.5625 147.709 58.6878 147.829L64.7427 153.684C64.774 153.714 64.816 153.731 64.8598 153.731C64.9036 153.731 64.9457 153.714 64.977 153.684L71.0319 147.829C71.1572 147.709 71.325 147.641 71.4997 147.641C71.6743 147.641 71.8422 147.709 71.9675 147.829L78.0232 153.684C78.0545 153.714 78.0965 153.731 78.1403 153.731C78.1841 153.731 78.2262 153.714 78.2575 153.684L84.3124 147.829C84.4377 147.709 84.6055 147.641 84.7802 147.641C84.9549 147.641 85.1227 147.709 85.248 147.829Z",fill:"white"})}),g("rect",{x:"103.5",y:"58",width:"78",height:"78",rx:"39",fill:"white"}),g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M131.626 83.0058C128.674 83.3405 126.5 85.8652 126.5 88.8363V92.0779V103.277V105.099C126.5 108.098 128.713 110.636 131.695 110.952C134.982 111.301 139.216 111.667 142.5 111.667C147.147 111.667 153.695 110.934 156.773 110.555C157.765 110.433 158.5 109.588 158.5 108.589V92.0779C158.5 91.0782 157.765 90.2337 156.773 90.1115C153.705 89.7336 147.189 89.0046 142.545 88.9999L142.5 88.9999L142.46 88.9999C139.655 89.0025 136.165 89.2695 133.166 89.564C132.488 89.5642 131.907 89.0495 131.84 88.3608C131.768 87.6279 132.304 86.9755 133.037 86.9036C136.061 86.6067 139.621 86.3333 142.5 86.3333C145.707 86.3333 149.764 86.6728 152.989 87.007C154.039 87.1159 155.006 87.2247 155.833 87.3221V85.3898C155.833 84.3995 155.112 83.56 154.131 83.4288C151.262 83.0454 145.367 82.3333 141.167 82.3333C138.276 82.3333 134.583 82.6705 131.626 83.0058ZM153.833 102.333C154.938 102.333 155.833 101.438 155.833 100.333C155.833 99.2287 154.938 98.3333 153.833 98.3333C152.729 98.3333 151.833 99.2287 151.833 100.333C151.833 101.438 152.729 102.333 153.833 102.333Z",fill:"#696FFD"}),g("rect",{x:"103.5",y:"58",width:"78",height:"78",rx:"39",stroke:"#E1E7EF",strokeWidth:"2"}),g("path",{d:"M269.405 111C278.27 111 285.457 103.837 285.457 95C285.457 86.1634 278.27 79 269.405 79C260.54 79 253.354 86.1634 253.354 95C253.354 103.837 260.54 111 269.405 111Z",fill:"#B9BBFE"}),g("path",{d:"M133.971 24C140.62 24 146.01 18.6274 146.01 12C146.01 5.37258 140.62 0 133.971 0C127.322 0 121.932 5.37258 121.932 12C121.932 18.6274 127.322 24 133.971 24Z",fill:"#B9BBFE"}),g("path",{d:"M15.5917 112C20.5782 112 24.6206 107.971 24.6206 103C24.6206 98.0294 20.5782 94 15.5917 94C10.6051 94 6.56274 98.0294 6.56274 103C6.56274 107.971 10.6051 112 15.5917 112Z",fill:"#B9BBFE"}),g("path",{d:"M152.029 177C157.57 177 162.061 172.523 162.061 167C162.061 161.477 157.57 157 152.029 157C146.488 157 141.997 161.477 141.997 167C141.997 172.523 146.488 177 152.029 177Z",fill:"#E9E9FF"}),g("path",{d:"M263.386 21C267.818 21 271.412 17.4183 271.412 13C271.412 8.58172 267.818 5 263.386 5C258.953 5 255.36 8.58172 255.36 13C255.36 17.4183 258.953 21 263.386 21Z",fill:"#E9E9FF"}),g("path",{d:"M7.06436 36C10.6658 36 13.5853 33.0899 13.5853 29.5C13.5853 25.9101 10.6658 23 7.06436 23C3.46296 23 0.543457 25.9101 0.543457 29.5C0.543457 33.0899 3.46296 36 7.06436 36Z",fill:"#E9E9FF"}),At("defs",{children:[At("linearGradient",{id:"paint0_linear_428_81",x1:"64.5",y1:"18",x2:"64.5",y2:"68",gradientUnits:"userSpaceOnUse",children:[g("stop",{stopColor:"#534BB1"}),g("stop",{offset:"1",stopColor:"#551BF9"})]}),At("linearGradient",{id:"paint1_linear_428_81",x1:"64.5",y1:"30.9167",x2:"64.5",y2:"55.0834",gradientUnits:"userSpaceOnUse",children:[g("stop",{stopColor:"white"}),g("stop",{offset:"1",stopColor:"white",stopOpacity:"0.82"})]}),g("clipPath",{id:"clip0_428_81",children:g("rect",{width:"31.6667",height:"19.1667",fill:"white",transform:"translate(55.6667 139.833)"})})]})]});import*as de from"react-device-detect";import so from"styled-components";var Gr=so.button`
|
|
773
|
+
`;import{jsx as g,jsxs as kt}from"react/jsx-runtime";var Vr=({style:t,...e})=>kt("svg",{width:"286",height:"183",viewBox:"0 0 286 183",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"1.25rem",width:"1.25rem",...t},...e,children:[g("rect",{x:"198.5",y:"133",width:"50",height:"50",rx:"25",fill:"#E1E7EF"}),g("path",{d:"M236.373 144.791L225.206 153.052L227.289 148.181L236.373 144.791Z",fill:"#E17726",stroke:"#E17726",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M210.627 144.791L221.692 153.116L219.711 148.187L210.627 144.785V144.791ZM232.353 163.933L229.377 168.47L235.738 170.219L237.557 164.036L232.347 163.933H232.353ZM209.448 164.036L211.257 170.219L217.602 168.47L214.647 163.933L209.448 164.036Z",fill:"#E27625",stroke:"#E27625",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M217.262 156.27L215.497 158.939L221.783 159.23L221.579 152.46L217.262 156.281V156.27V156.27ZM229.737 156.281L225.351 152.374L225.206 159.23L231.492 158.939L229.732 156.281H229.737ZM217.602 168.475L221.417 166.64L218.14 164.089L217.607 168.475H217.602ZM225.588 166.63L229.377 168.475L228.865 164.084L225.588 166.635V166.63Z",fill:"#E27625",stroke:"#E27625",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M229.377 168.47L225.588 166.635L225.895 169.1L225.862 170.144L229.382 168.47H229.377ZM217.602 168.47L221.137 170.144L221.11 169.1L221.417 166.635L217.602 168.47V168.47Z",fill:"#D5BFB2",stroke:"#D5BFB2",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M221.197 162.448L218.054 161.533L220.282 160.516L221.207 162.453H221.197V162.448ZM225.793 162.448L226.729 160.505L228.962 161.522L225.793 162.459V162.448Z",fill:"#233447",stroke:"#233447",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M217.602 168.47L218.156 163.933L214.647 164.035L217.602 168.47V168.47ZM228.844 163.933L229.377 168.47L232.353 164.035L228.844 163.933V163.933ZM231.503 158.939L225.217 159.23L225.793 162.459L226.729 160.505L228.962 161.522L231.503 158.939V158.939ZM218.054 161.533L220.282 160.516L221.207 162.453L221.794 159.224L215.508 158.944L218.059 161.538L218.054 161.533Z",fill:"#CC6228",stroke:"#CC6228",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M215.503 158.939L218.134 164.078L218.048 161.528L215.497 158.934L215.503 158.939ZM228.962 161.533L228.86 164.084L231.492 158.944L228.957 161.538L228.962 161.533ZM221.794 159.23L221.196 162.459L221.945 166.263L222.117 161.242L221.794 159.23ZM225.211 159.23L224.904 161.237L225.055 166.269L225.792 162.453L225.206 159.224V159.235L225.211 159.23Z",fill:"#E27525",stroke:"#E27525",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M225.793 162.448L225.055 166.263L225.588 166.635L228.86 164.084L228.962 161.528L225.793 162.448V162.448ZM218.054 161.528L218.14 164.078L221.417 166.629L221.945 166.263L221.207 162.448L218.048 161.528H218.059H218.054Z",fill:"#F5841F",stroke:"#F5841F",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M225.868 170.144L225.895 169.1L225.604 168.863H221.39L221.11 169.1L221.137 170.144L217.602 168.47L218.845 169.487L221.353 171.215H225.642L228.155 169.482L229.377 168.47L225.857 170.144H225.868V170.144Z",fill:"#C0AC9D",stroke:"#C0AC9D",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M225.588 166.63L225.055 166.264H221.945L221.417 166.635L221.11 169.1L221.39 168.863H225.604L225.895 169.1L225.588 166.635V166.624V166.63Z",fill:"#161616",stroke:"#161616",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M236.846 153.585L237.783 149.037L236.373 144.791L225.583 152.777L229.737 156.27L235.598 157.976L236.889 156.475L236.33 156.066L237.223 155.248L236.545 154.72L237.438 154.042L236.846 153.585H236.857H236.846ZM209.217 149.032L210.17 153.585L209.556 154.037L210.466 154.715L209.787 155.248L210.67 156.066L210.11 156.475L211.402 157.976L217.263 156.275L221.417 152.767L210.627 144.791L209.217 149.032V149.032Z",fill:"#763E1A",stroke:"#763E1A",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("path",{d:"M235.598 157.976L229.737 156.275L231.502 158.934L228.871 164.073L232.353 164.03H237.562L235.598 157.97V157.976ZM217.263 156.27L211.402 157.976L209.448 164.035H214.658L218.14 164.079L215.508 158.939L217.273 156.27H217.263V156.27ZM225.206 159.224L225.588 152.766L227.289 148.176H219.711L221.412 152.766L221.794 159.224L221.939 161.248V166.263H225.055L225.071 161.248L225.206 159.224V159.224Z",fill:"#F5841F",stroke:"#F5841F",strokeWidth:"0.47",strokeLinecap:"round",strokeLinejoin:"round"}),g("rect",{x:"192",y:"30",width:"50",height:"50",rx:"25",fill:"#0C5BFF"}),g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M205 55C205 61.6274 210.373 67 217 67C223.627 67 229 61.6274 229 55C229 48.3726 223.627 43 217 43C210.373 43 205 48.3726 205 55ZM213.933 51.1333C213.491 51.1333 213.133 51.4915 213.133 51.9333V58.0667C213.133 58.5085 213.491 58.8667 213.933 58.8667H220.067C220.508 58.8667 220.867 58.5085 220.867 58.0667V51.9333C220.867 51.4915 220.508 51.1333 220.067 51.1333H213.933Z",fill:"white"}),g("rect",{x:"39.5",y:"18",width:"50",height:"50",rx:"25",fill:"url(#paint0_linear_428_81)"}),g("path",{d:"M77.3677 42.8335H74.102C74.102 36.2519 68.6881 30.9167 62.0091 30.9167C55.4129 30.9167 50.0501 36.1213 49.9189 42.5901C49.7831 49.2769 56.1492 55.0834 62.9357 55.0834H63.7893C69.7724 55.0834 77.7916 50.468 79.0445 44.8444C79.2758 43.8079 78.445 42.8335 77.3677 42.8335ZM57.1562 43.1267C57.1562 44.0068 56.4257 44.7267 55.5325 44.7267C54.6394 44.7267 53.9089 44.0065 53.9089 43.1267V40.5383C53.9089 39.6582 54.6394 38.9383 55.5325 38.9383C56.4257 38.9383 57.1562 39.6582 57.1562 40.5383V43.1267ZM62.794 43.1267C62.794 44.0068 62.0636 44.7267 61.1705 44.7267C60.2773 44.7267 59.5468 44.0065 59.5468 43.1267V40.5383C59.5468 39.6582 60.2776 38.9383 61.1705 38.9383C62.0636 38.9383 62.794 39.6582 62.794 40.5383V43.1267Z",fill:"url(#paint1_linear_428_81)"}),g("rect",{x:"46.5",y:"124",width:"50",height:"50",rx:"25",fill:"#141414"}),g("g",{clipPath:"url(#clip0_428_81)",children:g("path",{d:"M62.1497 143.578C67.3134 138.585 75.6867 138.585 80.8505 143.578L81.4722 144.179C81.5335 144.238 81.5822 144.308 81.6155 144.386C81.6488 144.463 81.666 144.547 81.666 144.631C81.666 144.715 81.6488 144.799 81.6155 144.876C81.5822 144.954 81.5335 145.024 81.4722 145.083L79.3462 147.139C79.2835 147.199 79.1996 147.232 79.1123 147.232C79.025 147.232 78.9411 147.199 78.8784 147.139L78.0232 146.311C74.421 142.829 68.58 142.829 64.977 146.311L64.0611 147.197C63.9984 147.257 63.9145 147.29 63.8272 147.29C63.7399 147.29 63.656 147.257 63.5933 147.197L61.4672 145.141C61.4059 145.083 61.3572 145.012 61.3239 144.935C61.2906 144.857 61.2735 144.774 61.2735 144.689C61.2735 144.605 61.2906 144.521 61.3239 144.444C61.3572 144.366 61.4059 144.296 61.4672 144.237L62.1497 143.578ZM85.248 147.829L87.1397 149.659C87.201 149.718 87.2497 149.788 87.283 149.865C87.3163 149.943 87.3334 150.027 87.3334 150.111C87.3334 150.195 87.3163 150.279 87.283 150.356C87.2497 150.434 87.201 150.504 87.1397 150.563L78.6081 158.812C78.4828 158.933 78.315 159 78.1403 159C77.9656 159 77.7978 158.933 77.6725 158.812L71.6177 152.957C71.5864 152.927 71.5443 152.91 71.5005 152.91C71.4567 152.91 71.4147 152.927 71.3833 152.957L65.3285 158.812C65.2032 158.933 65.0354 159 64.8607 159C64.686 159 64.5182 158.933 64.3929 158.812L55.8605 150.563C55.7992 150.504 55.7505 150.434 55.7172 150.356C55.6839 150.279 55.6667 150.195 55.6667 150.111C55.6667 150.027 55.6839 149.943 55.7172 149.865C55.7505 149.788 55.7992 149.718 55.8605 149.659L57.7531 147.829C57.8783 147.709 58.0459 147.642 58.2204 147.642C58.3949 147.642 58.5625 147.709 58.6878 147.829L64.7427 153.684C64.774 153.714 64.816 153.731 64.8598 153.731C64.9036 153.731 64.9457 153.714 64.977 153.684L71.0319 147.829C71.1572 147.709 71.325 147.641 71.4997 147.641C71.6743 147.641 71.8422 147.709 71.9675 147.829L78.0232 153.684C78.0545 153.714 78.0965 153.731 78.1403 153.731C78.1841 153.731 78.2262 153.714 78.2575 153.684L84.3124 147.829C84.4377 147.709 84.6055 147.641 84.7802 147.641C84.9549 147.641 85.1227 147.709 85.248 147.829Z",fill:"white"})}),g("rect",{x:"103.5",y:"58",width:"78",height:"78",rx:"39",fill:"white"}),g("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M131.626 83.0058C128.674 83.3405 126.5 85.8652 126.5 88.8363V92.0779V103.277V105.099C126.5 108.098 128.713 110.636 131.695 110.952C134.982 111.301 139.216 111.667 142.5 111.667C147.147 111.667 153.695 110.934 156.773 110.555C157.765 110.433 158.5 109.588 158.5 108.589V92.0779C158.5 91.0782 157.765 90.2337 156.773 90.1115C153.705 89.7336 147.189 89.0046 142.545 88.9999L142.5 88.9999L142.46 88.9999C139.655 89.0025 136.165 89.2695 133.166 89.564C132.488 89.5642 131.907 89.0495 131.84 88.3608C131.768 87.6279 132.304 86.9755 133.037 86.9036C136.061 86.6067 139.621 86.3333 142.5 86.3333C145.707 86.3333 149.764 86.6728 152.989 87.007C154.039 87.1159 155.006 87.2247 155.833 87.3221V85.3898C155.833 84.3995 155.112 83.56 154.131 83.4288C151.262 83.0454 145.367 82.3333 141.167 82.3333C138.276 82.3333 134.583 82.6705 131.626 83.0058ZM153.833 102.333C154.938 102.333 155.833 101.438 155.833 100.333C155.833 99.2287 154.938 98.3333 153.833 98.3333C152.729 98.3333 151.833 99.2287 151.833 100.333C151.833 101.438 152.729 102.333 153.833 102.333Z",fill:"#696FFD"}),g("rect",{x:"103.5",y:"58",width:"78",height:"78",rx:"39",stroke:"#E1E7EF",strokeWidth:"2"}),g("path",{d:"M269.405 111C278.27 111 285.457 103.837 285.457 95C285.457 86.1634 278.27 79 269.405 79C260.54 79 253.354 86.1634 253.354 95C253.354 103.837 260.54 111 269.405 111Z",fill:"#B9BBFE"}),g("path",{d:"M133.971 24C140.62 24 146.01 18.6274 146.01 12C146.01 5.37258 140.62 0 133.971 0C127.322 0 121.932 5.37258 121.932 12C121.932 18.6274 127.322 24 133.971 24Z",fill:"#B9BBFE"}),g("path",{d:"M15.5917 112C20.5782 112 24.6206 107.971 24.6206 103C24.6206 98.0294 20.5782 94 15.5917 94C10.6051 94 6.56274 98.0294 6.56274 103C6.56274 107.971 10.6051 112 15.5917 112Z",fill:"#B9BBFE"}),g("path",{d:"M152.029 177C157.57 177 162.061 172.523 162.061 167C162.061 161.477 157.57 157 152.029 157C146.488 157 141.997 161.477 141.997 167C141.997 172.523 146.488 177 152.029 177Z",fill:"#E9E9FF"}),g("path",{d:"M263.386 21C267.818 21 271.412 17.4183 271.412 13C271.412 8.58172 267.818 5 263.386 5C258.953 5 255.36 8.58172 255.36 13C255.36 17.4183 258.953 21 263.386 21Z",fill:"#E9E9FF"}),g("path",{d:"M7.06436 36C10.6658 36 13.5853 33.0899 13.5853 29.5C13.5853 25.9101 10.6658 23 7.06436 23C3.46296 23 0.543457 25.9101 0.543457 29.5C0.543457 33.0899 3.46296 36 7.06436 36Z",fill:"#E9E9FF"}),kt("defs",{children:[kt("linearGradient",{id:"paint0_linear_428_81",x1:"64.5",y1:"18",x2:"64.5",y2:"68",gradientUnits:"userSpaceOnUse",children:[g("stop",{stopColor:"#534BB1"}),g("stop",{offset:"1",stopColor:"#551BF9"})]}),kt("linearGradient",{id:"paint1_linear_428_81",x1:"64.5",y1:"30.9167",x2:"64.5",y2:"55.0834",gradientUnits:"userSpaceOnUse",children:[g("stop",{stopColor:"white"}),g("stop",{offset:"1",stopColor:"white",stopOpacity:"0.82"})]}),g("clipPath",{id:"clip0_428_81",children:g("rect",{width:"31.6667",height:"19.1667",fill:"white",transform:"translate(55.6667 139.833)"})})]})]});import*as ce from"react-device-detect";import so from"styled-components";var Gr=so.button`
|
|
774
774
|
display: flex;
|
|
775
775
|
flex-direction: row;
|
|
776
776
|
align-items: center;
|
|
@@ -801,7 +801,7 @@ Resources:
|
|
|
801
801
|
border: 1px solid #e5e7eb;
|
|
802
802
|
color: var(--text-dark-blue);
|
|
803
803
|
}
|
|
804
|
-
`;import{Fragment as ao,jsx as u,jsxs as M}from"react/jsx-runtime";var lo=()=>{let{navigate:t}=w(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return
|
|
804
|
+
`;import{Fragment as ao,jsx as u,jsxs as M}from"react/jsx-runtime";var lo=()=>{let{navigate:t}=w(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return ce.isFirefox&&(e="https://addons.mozilla.org/en-US/firefox/addon/ether-metamask/"),M(jr,{children:[u(ve,{title:"Create a Metamask wallet",description:"Follow the instructions below to get started."}),u($r,{children:u(we,{style:{width:"152px",height:"152px"}})}),M(no,{children:[u(be,{children:M("div",{children:[u("span",{children:"Install the "}),u("a",{href:e,target:"_blank",children:"MetaMask browser extension"})]})}),u(Ye,{}),u(be,{children:"Set up your first wallet"}),u(Ye,{}),u(be,{children:"Store your recovery phrase in a safe place!"})]}),u(Kr,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},co=()=>{let{navigate:t}=w();return M(jr,{children:[u(ve,{title:"Create a Coinbase wallet",description:"Follow the instructions below to get started."}),u($r,{style:{marginTop:"-24px"},children:u(Ur,{size:200})}),M(no,{children:[u(be,{children:"Scan the QR code with your camera"}),u(Ye,{}),u(be,{children:"Set up your first wallet"}),u(Ye,{}),u(be,{children:"Store your seed phrase in a safe place!"})]}),u(Kr,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},Zr=()=>{let[t,e]=ts("WHAT_IS_A_WALLET"),{navigateBack:o}=w();return M(ao,{children:[u(A,{backFn:t==="WHAT_IS_A_WALLET"?o:t==="PICK_A_NEW_WALLET"?()=>e("WHAT_IS_A_WALLET"):()=>e("PICK_A_NEW_WALLET")},"header"),M(os,{children:[t==="WHAT_IS_A_WALLET"&&M(ao,{children:[u(as,{children:u(Vr,{style:{width:"240px",height:"auto",borderRadius:"var(--border-radius-sm)",marginBottom:"32px"}})}),M(We,{title:"Get started with a new wallet",children:[u("p",{children:"Wallets help you store, send, and receive digital assets and collectibles. They are also a new\xA0way\xA0to\xA0log\xA0in."}),u("p",{children:"Instead of creating new accounts and passwords for every app, you just connect your wallet and bring your\xA0data\xA0with\xA0you."})]}),u(ns,{children:u(ss,{onClick:()=>{e("PICK_A_NEW_WALLET")},children:"Create a wallet"})})]}),t==="PICK_A_NEW_WALLET"&&u(ao,{children:M(rs,{children:[u(ve,{title:"Create a new wallet",description:"Select one the wallet providers below to get started on your web3 adventure."}),M(is,{children:[M(Br,{onClick:()=>{ce.isIOS?window.location.href="https://apps.apple.com/us/app/metamask-blockchain-wallet/id1438144202":ce.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=io.metamask":e("CREATE_METAMASK_WALLET")},children:[u(we,{}),M(zr,{children:[u("h4",{children:"MetaMask"}),u("p",{children:"Get a browser-based wallet"})]}),u("div",{children:u("span",{children:"Set up"})})]}),M(Br,{onClick:()=>{ce.isIOS?window.location.href="https://apps.apple.com/us/app/coinbase-wallet-nfts-crypto/id1278383455":ce.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=org.toshi":e("CREATE_COINBASE_WALLET")},children:[u(ae,{}),M(zr,{children:[u("h4",{children:"Coinbase Wallet"}),u("p",{children:"Get a mobile app wallet"})]}),u("div",{children:u("span",{children:"Set up"})})]})]})]})}),t==="CREATE_COINBASE_WALLET"&&u(co,{}),t==="CREATE_METAMASK_WALLET"&&u(lo,{})]}),M(ee,{children:[u("span",{children:"Still not sure? "}),u("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"}),"."]})]})},os=z.div`
|
|
805
805
|
display: flex;
|
|
806
806
|
flex-direction: column;
|
|
807
807
|
height: 100%;
|
|
@@ -926,7 +926,7 @@ Resources:
|
|
|
926
926
|
`,as=z.div`
|
|
927
927
|
display: flex;
|
|
928
928
|
justify-content: center;
|
|
929
|
-
`;import{useEffect as qr,useState as
|
|
929
|
+
`;import{useEffect as qr,useState as _t}from"react";import St from"styled-components";import{Fragment as us,jsx as xe,jsxs as Pt}from"react/jsx-runtime";var po=2,Yr={metamask:{name:"MetaMask",component:we},coinbase_wallet:{name:"Coinbase Wallet",component:ae},wallet_connect:{name:"WalletConnect",component:lt}},Jr=()=>{var Y;let[t,e]=_t(!1),[o,r]=_t(void 0),{navigateBack:i}=w(),{getAuthMeta:n,closePrivyModal:s,loginWithWallet:c,handleLoginError:f}=P(),[h,S]=_t(0),{user:b}=N(),[k,x]=_t((b==null?void 0:b.linkedAccounts.length)||0);qr(()=>{r(void 0),c().then(()=>e(!0)).catch(y=>{y instanceof B?console.error(y.cause):console.error(y);let Z=(y==null?void 0:y.status)===401&&(y==null?void 0:y.message)==="User is not allowed to login to this app.";(y==null?void 0:y.status)===422?r(Ve.ERROR_USER_EXISTS):Z?r(Ve.ERROR_WALLET_NOT_ALLOWED):y instanceof Pe&&!y.details.default?r(y.details):y instanceof _e?r(Ve.ERROR_TIMED_OUT):r(Ve.ERROR_WALLET_CONNECTION),f(Z)})},[h]),qr(()=>{if(t){let y=setTimeout(s,Ee);return()=>clearTimeout(y)}},[b]);let L=((Y=n())==null?void 0:Y.wallet)||"metamask",a=Yr[L].name,v=Yr[L].component,F=t?`Successfully connected with ${a}`:o?o.message:`Waiting for ${a}`,W="";if(t){let y=(b==null?void 0:b.linkedAccounts.length)||0;k===y?W="Wallet was already linked.":W="You\u2019re good to go!"}else if(h>=po&&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":at()||(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 Pt(us,{children:[xe(A,{backFn:i}),Pt(ls,{children:[xe(cs,{children:Pt("div",{children:[xe(wt,{success:t,fail:!!o}),xe(v,{style:{width:"38px",height:"38px"}})]})}),Pt(ds,{children:[xe("h3",{children:F}),xe("p",{children:W})]}),xe(ps,{onClick:()=>{S(h+1),r(void 0)},visible:!t&&(o==null?void 0:o.retryable)&&h<po,disabled:!t&&(!(o!=null&&o.retryable)||h>=po),children:"Retry"})]})]})},ls=St.div`
|
|
930
930
|
display: flex;
|
|
931
931
|
flex-direction: column;
|
|
932
932
|
align-items: center;
|
|
@@ -934,11 +934,11 @@ Resources:
|
|
|
934
934
|
margin-left: 27px;
|
|
935
935
|
margin-right: 27px;
|
|
936
936
|
gap: 24px;
|
|
937
|
-
`,ds=
|
|
937
|
+
`,ds=St.div`
|
|
938
938
|
display: flex;
|
|
939
939
|
flex-direction: column;
|
|
940
940
|
gap: 8px;
|
|
941
|
-
`,cs=
|
|
941
|
+
`,cs=St.div`
|
|
942
942
|
display: flex;
|
|
943
943
|
flex-direction: column;
|
|
944
944
|
justify-content: center;
|
|
@@ -961,7 +961,7 @@ Resources:
|
|
|
961
961
|
left: -19px;
|
|
962
962
|
top: -19px;
|
|
963
963
|
}
|
|
964
|
-
`,ps=
|
|
964
|
+
`,ps=St.button`
|
|
965
965
|
&& {
|
|
966
966
|
padding: 12px 16px;
|
|
967
967
|
font-weight: 500;
|
|
@@ -973,7 +973,7 @@ Resources:
|
|
|
973
973
|
opacity: ${t=>t.visible?"1":"0"};
|
|
974
974
|
transition: opacity 200ms;
|
|
975
975
|
}
|
|
976
|
-
`;import{Fragment as hs,jsx as
|
|
976
|
+
`;import{Fragment as hs,jsx as Tt,jsxs as Qr}from"react/jsx-runtime";var Xr=()=>{let{navigateBack:t}=w();return Qr(hs,{children:[Tt(A,{backFn:t},"header"),Tt(lo,{}),Qr(ee,{children:[Tt("span",{children:"Still not sure? "}),Tt("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"})]})]})};import{Fragment as ms,jsx as It,jsxs as ei}from"react/jsx-runtime";var ti=()=>{let{navigateBack:t}=w();return ei(ms,{children:[It(A,{backFn:t},"header"),It(co,{}),ei(ee,{children:[It("span",{children:"Still not sure? "}),It("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"})]})]})};import fs from"styled-components";import{jsx as ws}from"react/jsx-runtime";var oi=t=>{let e=t.accentColor||"#696ffd";return ws(gs,{accentColor:e,children:t.children})},gs=fs.div`
|
|
977
977
|
/*! Modified from https://unpkg.com/tailwindcss@3.2.3/src/css/preflight.css */
|
|
978
978
|
|
|
979
979
|
*,
|
|
@@ -1136,7 +1136,7 @@ Resources:
|
|
|
1136
1136
|
|
|
1137
1137
|
--primary-color: ${t=>t.accentColor};
|
|
1138
1138
|
/* Same as primary color, but can be used with rgba */
|
|
1139
|
-
--primary-color-rgb: ${t=>`${
|
|
1139
|
+
--primary-color-rgb: ${t=>`${yt(t.accentColor).r}, ${yt(t.accentColor).g}, ${yt(t.accentColor).b}`};
|
|
1140
1140
|
--success-light: #4bd089;
|
|
1141
1141
|
--success-dark: #22874f;
|
|
1142
1142
|
--fail-light: #ff1f01;
|
|
@@ -1271,7 +1271,7 @@ Resources:
|
|
|
1271
1271
|
display: none;
|
|
1272
1272
|
}
|
|
1273
1273
|
}
|
|
1274
|
-
`;import{useEffect as Ts}from"react";import{useEffect as ri,useState as ii}from"react";import
|
|
1274
|
+
`;import{useEffect as Ts}from"react";import{useEffect as ri,useState as ii}from"react";import Mt from"styled-components";import{Fragment as Ls,jsx as Le,jsxs as Rt}from"react/jsx-runtime";var ni={google:{name:"Google",component:mt},discord:{name:"Discord",component:ut},twitter:{name:"Twitter",component:pt}},ys=t=>t.charAt(0).toUpperCase()+t.slice(1),uo=()=>{let t=new URL(window.location.href);t.searchParams.delete("privy_oauth_code"),t.searchParams.delete("privy_oauth_provider"),t.searchParams.delete("privy_oauth_state"),window.history.pushState({},"",t)},si=()=>{var L;let[t,e]=ii(!1),[o,r]=ii(void 0),{getAuthMeta:i,initLoginWithOAuth:n,loginWithOAuth:s,closePrivyModal:c}=P(),{ready:f}=N(),h=((L=i())==null?void 0:L.provider)||"google",S=ni[h].name,b=ni[h].component;ri(()=>{!f||s().then(()=>{uo(),e(!0)}).catch(a=>{let v={retryable:!1,message:"Authentication failed."};a.message.includes("Another user has already linked this")?v.detail="This account has already been linked to another user.":a.message==="Invalid code during oauth flow."?(v.retryable=!0,v.detail="Something went wrong. Try again."):a.message==="User denied confirmation during OAuth flow"&&(v.detail=`Retry and check ${ys(h)} to finish connecting your account.`,v.retryable=!0),uo(),r(v)})},[f]),ri(()=>{if(!t)return;let a=setTimeout(c,Ee);return()=>clearTimeout(a)},[t]);let k=t?`Successfully connected with ${S}`:o?o.message:`Verifying connection to ${S}`,x="";return t?x="You\u2019re good to go!":o?x=o.detail:x="Just a few moments more",Rt(Ls,{children:[Le(A,{}),Rt(Cs,{children:[Le(bs,{children:Rt("div",{children:[Le(wt,{success:t,fail:!!o}),Le(b,{style:{width:"38px",height:"38px"},logoFill:"primary"})]})}),Rt(vs,{children:[Le("h3",{children:k}),Le("p",{children:x})]}),Le(xs,{onClick:()=>{uo(),n(h),r(void 0)},visible:!t&&(o==null?void 0:o.retryable),disabled:!t&&!(o!=null&&o.retryable),children:"Retry"})]})]})},Cs=Mt.div`
|
|
1275
1275
|
display: flex;
|
|
1276
1276
|
flex-direction: column;
|
|
1277
1277
|
align-items: center;
|
|
@@ -1279,11 +1279,11 @@ Resources:
|
|
|
1279
1279
|
margin-left: 27px;
|
|
1280
1280
|
margin-right: 27px;
|
|
1281
1281
|
gap: 24px;
|
|
1282
|
-
`,vs=
|
|
1282
|
+
`,vs=Mt.div`
|
|
1283
1283
|
display: flex;
|
|
1284
1284
|
flex-direction: column;
|
|
1285
1285
|
gap: 8px;
|
|
1286
|
-
`,bs=
|
|
1286
|
+
`,bs=Mt.div`
|
|
1287
1287
|
display: flex;
|
|
1288
1288
|
flex-direction: column;
|
|
1289
1289
|
justify-content: center;
|
|
@@ -1306,7 +1306,7 @@ Resources:
|
|
|
1306
1306
|
left: -19px;
|
|
1307
1307
|
top: -19px;
|
|
1308
1308
|
}
|
|
1309
|
-
`,xs=
|
|
1309
|
+
`,xs=Mt.button`
|
|
1310
1310
|
&& {
|
|
1311
1311
|
padding: 12px 16px;
|
|
1312
1312
|
font-weight: 500;
|
|
@@ -1318,7 +1318,7 @@ Resources:
|
|
|
1318
1318
|
opacity: ${t=>t.visible?"1":"0"};
|
|
1319
1319
|
transition: opacity 200ms;
|
|
1320
1320
|
}
|
|
1321
|
-
`;import{Fragment as Es,jsx as
|
|
1321
|
+
`;import{Fragment as Es,jsx as Ue,jsxs as As}from"react/jsx-runtime";var ai=()=>{let{app:t}=w();return As(Es,{children:[Ue(A,{},"header"),Ue(We,{title:"Connect your email",description:`Add your email to your ${t==null?void 0:t.name} account`,icon:Ue(gt,{})}),Ue(le,{children:Ue(Ct,{stacked:!0})}),Ue(q,{protectedByPrivy:!0})]})};import{Fragment as ks,jsx as De,jsxs as _s}from"react/jsx-runtime";var li=()=>{let{app:t}=w();return _s(ks,{children:[De(A,{},"header"),De(We,{title:"Connect your phone",description:`Add your number to your ${t==null?void 0:t.name} account`,icon:De(vt,{})}),De(le,{children:De(bt,{stacked:!0})}),De(q,{protectedByPrivy:!0})]})};import{Fragment as Ps,jsx as Je,jsxs as di}from"react/jsx-runtime";var ci=()=>{let{app:t}=w();return di(Ps,{children:[Je(A,{},"header"),Je(Pr,{title:"Connect your wallet",description:`Link a wallet to your ${t==null?void 0:t.name} account`}),di(le,{children:[Je(dt,{}),Je(ct,{})]}),Je(q,{protectedByPrivy:!0})]})};import{jsx as R,jsxs as pi}from"react/jsx-runtime";var Is=()=>{let{ready:t}=N(),{isLinking:e}=P(),{ready:o,currentScreen:r}=w(),i;return["AWAITING_CONNECTION","AWAITING_OAUTH_SCREEN"].includes(r)?i="compact":"WALLET_EDUCATION"===r?i="full":e?i="medium":i="full",!t||!o?pi(At,{"data-height":i,children:[R(A,{}),R(Ws,{children:R(de,{})}),R(ee,{})]}):pi(At,{"data-height":i,children:[r==="LANDING"&&R(Ar,{}),r==="AWAITING_PASSWORDLESS_CODE"&&R(Mr,{}),r==="WALLET_EDUCATION"&&R(Zr,{}),r==="AWAITING_CONNECTION"&&R(Jr,{}),r==="AWAITING_OAUTH_SCREEN"&&R(si,{}),r==="INSTALL_METAMASK_SCREEN"&&R(Xr,{}),r==="INSTALL_COINBASE_WALLET_SCREEN"&&R(ti,{}),r==="LINK_EMAIL_SCREEN"&&R(ai,{}),r==="LINK_PHONE_SCREEN"&&R(li,{}),r==="LINK_WALLET_SCREEN"&&R(ci,{})]})},ui=()=>{let{app:t}=w();return Ss.createPortal(R(Ms,{id:"privy-dialog",children:R(oi,{accentColor:t==null?void 0:t.accentColor,children:R(Is,{})})}),document.body)},Rs=({children:t,...e})=>(Ts(()=>{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]),R("dialog",{open:!0,role:"dialog",...e,children:t})),Ms=ho(Rs)`
|
|
1322
1322
|
position: fixed;
|
|
1323
1323
|
top: 0;
|
|
1324
1324
|
left: 0;
|
|
@@ -1329,10 +1329,11 @@ Resources:
|
|
|
1329
1329
|
align-items: center;
|
|
1330
1330
|
background: none;
|
|
1331
1331
|
padding: 0;
|
|
1332
|
+
border: 0;
|
|
1332
1333
|
z-index: 999999;
|
|
1333
1334
|
-webkit-backdrop-filter: blur(3px);
|
|
1334
1335
|
backdrop-filter: blur(3px);
|
|
1335
|
-
`,
|
|
1336
|
+
`,At=ho.div`
|
|
1336
1337
|
line-height: 20px;
|
|
1337
1338
|
width: 360px;
|
|
1338
1339
|
height: auto;
|
|
@@ -1376,4 +1377,4 @@ Resources:
|
|
|
1376
1377
|
align-items: center;
|
|
1377
1378
|
justify-content: center;
|
|
1378
1379
|
height: 100%;
|
|
1379
|
-
`;import{Fragment as Gs,jsx as
|
|
1380
|
+
`;import{Fragment as Gs,jsx as Qe,jsxs as Hs}from"react/jsx-runtime";function Os(t){return typeof t=="string"&&t.length===25}var Nt;function Us(){if(!Nt){let t=E.get(Ae);return Promise.resolve(t||null)}return Nt.getAccessToken()}var Ds=t=>{if(!Os(t.appId))throw new p("Cannot initialize the Privy provider with an invalid Privy app ID");let[e,o]=ie(null);return Wt(()=>{Nt=new He({appId:t.appId,apiURL:yo}),o(Nt)},[]),e===null?Qe(Gs,{}):Qe(Vs,{...t,client:e})},Fs=(t,e)=>{if(e)return{email:!1,sms:!1,wallet:!1,google:!1,twitter:!1,discord:!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)}},Vs=t=>{let e=t.client,[o,r]=ie(!1),[i,n]=ie(!1),[s,c]=ie(!1),[f,h]=ie(null),[S,b]=ie(!1),[k,x]=ie({accentColor:"#696ffd",theme:"System",showWalletLoginFirst:!0,emailAuth:!0,smsAuth:!1,walletAuth:!0,googleOAuth:!1,twitterOAuth:!1,discordOAuth:!1,termsAndConditionsUrl:null,privacyPolicyUrl:null}),[L,a]=ie(null),[v,F]=ie(!1);Wt(()=>{async function l(){let d=await e.getAppSettings();x(d)}l()},[]);let W=Fs(k,L),Y=()=>{let l=new URLSearchParams(window.location.search),d=l.get("privy_oauth_code"),_=l.get("privy_oauth_state"),T=l.get("privy_oauth_provider");d&&_&&T&&(e.startAuthFlow(new Se(T,d,_)),a(T),r(!0))};Wt(()=>{async function l(){Y();let d=await e.getAuthenticatedUser();c(!!d),h(d),n(!0)}l()},[]),Wt(()=>{i&&s&&f===null&&e.getAuthenticatedUser().then(h)},[i,s,f]);let y={ready:i,authenticated:s,user:f,walletConnector:e.connector,linkWallet:()=>{a("wallet"),F(!0),r(!0)},linkEmail:()=>{a("email"),F(!0),r(!0)},linkPhone:()=>{a("sms"),F(!0),r(!0)},linkGoogle:async()=>{await Z.initLoginWithOAuth("google")},linkTwitter:async()=>{await Z.initLoginWithOAuth("twitter")},linkDiscord:async()=>{await Z.initLoginWithOAuth("discord")},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(),h(null),c(!1),a(null),F(!1),r(!1)},getAccessToken:()=>e.getAccessToken(),getEthereumProvider:()=>e.connector.getEthereumProvider(),getEthersProvider:()=>new Ns(new fe(e.connector.getEthereumProvider())),getWeb3jsProvider:()=>new st(e.connector.getEthereumProvider()),unlinkWallet:async l=>{let d=await e.unlinkWallet(l);return h(d),d},unlinkEmail:async l=>{let d=await e.unlinkEmail(l);return h(d),d},unlinkPhone:async l=>{let d=await e.unlinkPhone(l);return h(d),d},unlinkGoogle:async l=>{let d=await e.unlinkOAuth("google",l);return h(d),d},unlinkTwitter:async l=>{let d=await e.unlinkOAuth("twitter",l);return h(d),d},unlinkDiscord:async l=>{let d=await e.unlinkOAuth("discord",l);return h(d),d},setActiveWallet:l=>{if(!f)return;let d=e.setActiveWallet(l,f);h(d)},forkSession:()=>e.forkSession()},Z={isLinking:v,getAuthFlow:()=>e.authFlow,getAuthMeta:()=>{var l;return(l=e.authFlow)==null?void 0:l.meta},closePrivyModal:()=>{var l;i&&s&&f&&((l=t.onSuccess)==null||l.call(t,f,S)),e.authFlow=void 0,a(null),F(!1),b(!1),r(!1)},initLoginWithWallet:l=>{l||(l="metamask"),e.connector.walletType=l,e.startAuthFlow(new Be(e.connector))},initLoginWithOAuth:async l=>{e.startAuthFlow(new Se(l));let d=await e.authFlow.getAuthorizationUrl();d&&d.url&&window.location.assign(d.url)},loginWithOAuth:async()=>{if(!(e.authFlow instanceof Se))throw new p("Must initialize OAuth flow before calling loginWithOAuth");let l,d;v?l=await e.link():{user:l,isNewUser:d}=await e.authenticate(),h(l),b(d||!1),c(!0)},loginWithWallet:async()=>{if(!(e.authFlow instanceof Be))throw new p("Must initialize SIWE flow first.");let l,d;v?(l=await e.link(),l&&(E.del(K),l=Fe(l))):{user:l,isNewUser:d}=await e.authenticate(),h(l||f||null),b(d||!1),c(!0)},loginWithEmail:async l=>{let d=new ze(l);e.startAuthFlow(d),await d.sendCodeEmail()},loginWithSms:async l=>{let d=new Ze(l);e.startAuthFlow(d),await d.sendSmsCode()},resendEmailCode:async()=>{var l;await((l=e.authFlow)==null?void 0:l.sendCodeEmail())},resendSmsCode:async()=>{var l;await((l=e.authFlow)==null?void 0:l.sendSmsCode())},loginWithCode:async l=>{if(e.authFlow instanceof ze)e.authFlow.meta.emailCode=l.trim();else if(e.authFlow instanceof Ze)e.authFlow.meta.smsCode=l.trim();else throw new p("Must initialize a passwordless code flow first");let d,_;v?d=await e.link():{user:d,isNewUser:_}=await e.authenticate(),h(d||f||null),b(_||!1),c(!0)},handleLoginError:async l=>{var d;e.authFlow=void 0,a(null),F(!1),b(!1),(d=t.onError)==null||d.call(t,l)}};return Hs($t.Provider,{value:y,children:[t.children,Qe(Kt.Provider,{value:Z,children:Qe(qo,{appSettings:k,options:W,visible:o,authenticated:s,children:o&&Qe(ui,{})})})]})};export{fe as AsExternalProvider,He as PrivyClient,Ge as PrivyConnector,Ds as PrivyProvider,me as PrivyProxyProvider,Ft as VERSION,Us as getAccessToken,N as usePrivy};
|