@privy-io/react-auth 1.17.0-beta.1 → 1.17.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/index.js +944 -944
- package/dist/index.d.ts +25 -21
- package/dist/index.js +944 -944
- package/package.json +9 -4
package/dist/esm/index.js
CHANGED
|
@@ -1,15 +1,31 @@
|
|
|
1
|
-
import{useEffect as Ni,useState as te}from"react";import To from"axios";import Ui from"axios";var ie=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}]`:""}`}},je=class extends ie{constructor(o,r,n,i){super(n,i);this.type=o;this.status=r}},y=class extends ie{constructor(o,r){super(o,r);this.type="client_error"}};var B=class extends ie{constructor(o,r){super(o,r);this.type="connector_error"}},U=t=>{if(t instanceof ie)return t;if(!Ui.isAxiosError(t))return re(t);if(!t.response)return new je("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new je(e||"ApiError",t.response.status,o||r,t)},re=t=>t instanceof ie?t:t instanceof Error?new y(t.message,t):new y(`Internal error: ${t}`);var vr="1.17.0-beta.1";var Cr="https://api.privy.io/v0",So=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",ft="4df5e2316331463a9130964bd6078dfa",br=1e4,ne=1400,Po=vr;var Ze="privy:token",Ut="privy:refresh_token",Dt="privy:connectors",xr="walletconnect",ko=3e4;var Ft=class{constructor(e,o,r){this.appId=e,this.sdkVersion=Po,this.client=o,this.defaults=r}async get(e,o){try{return await To.get(e,await this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw U(r)}}async post(e,o,r){try{return await To.post(e,o,await this.buildConfig(r))}catch(n){throw U(n)}}async delete(e,o){try{return await To.delete(e,await this.buildConfig(o))}catch(r){throw U(r)}}async buildConfig(e){if(e=e||{},e.headers=e.headers||{},e.headers["privy-app-id"]=this.appId,e.headers["privy-client"]=`react-auth:${this.sdkVersion}`,!e.headers.authorization){let o=await this.client.getAccessToken();o!==null&&(e.headers.authorization=`Bearer ${o}`)}return{...this.defaults,...e}}};import*as Er from"jose";var ge=class{static parse(e){try{return new ge(e)}catch{return null}}constructor(e){this.value=e,this._decoded=Er.decodeJwt(e)}get subject(){return this._decoded.sub}get expiration(){return this._decoded.exp}get issuer(){return this._decoded.iss}get audience(){return this._decoded.aud}isExpired(e=0){let o=Date.now(),r=(this.expiration-e)*1e3;return o>=r}};var _e=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 Wo=class{constructor(){this._cache={}}get(e){return this._cache[e]}put(e,o){o!==void 0?this._cache[e]=o:this.del(e)}del(e){delete this._cache[e]}getKeys(){return Object.keys(this._cache)}},Io=class{get(e){let o=localStorage.getItem(e);return o===null?void 0:JSON.parse(o)}put(e,o){o!==void 0?localStorage.setItem(e,JSON.stringify(o)):this.del(e)}del(e){localStorage.removeItem(e)}getKeys(){return Object.entries(localStorage).map(([e])=>e)}};function Fi(){return typeof window<"u"&&window.localStorage?new Io:new Wo}var q=Fi();import{ErrorCode as Gi}from"@ethersproject/logger";var qe=class extends B{constructor(){super("Wallet timeout");this.type="wallet_error"}},Se=t=>{if(t instanceof B)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new Ke(t);return t.code===Gi.ACTION_REJECTED&&(e.details=Oe.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new Ke(t):new B("Unknown connector error",t)},Ro=class extends ie{constructor(o,r,n){super(o);this.type="provider_error";this.code=r,this.data=n}},Ke=class extends Ro{constructor(o){var i,s,a;let r=o;super(r.message,r.code,r.data);let n=Object.values(Oe).find(p=>p.eipCode===r.code);this.details=n||Oe.UNKNOWN_ERROR,r.code===-32002&&((i=r.message)!=null&&i.includes("already pending for origin")?(s=r.message)!=null&&s.includes("wallet_requestPermissions")?this.details=Oe.E32002_CONNECTION_ALREADY_PENDING:this.details=Oe.E32002_REQUEST_ALREADY_PENDING:(a=r.message)!=null&&a.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=Oe.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}},Vi={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}},Hi={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}},Oe={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Hi,...Vi},Je={...Bi,...Oe};var zi=12e4,Mo=(t=new qe,e=zi)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),pe=class{constructor(e){this.removeListener=(e,o)=>{if(this.walletProvider)return this.walletProvider.removeListener(e,o)};this.setProvider=e=>{this.walletProvider=e,this._subscriptions.forEach(o=>{var r;(r=this.walletProvider)==null||r.on(o.eventName,o.listener)})};this.walletProvider=e,this._subscriptions=[]}on(e,o){if(this.walletProvider)return this.walletProvider.on(e,o);this._subscriptions.push({eventName:e,listener:o})}async request(e){if(!this.walletProvider)throw new B(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),Mo()]).catch(o=>{throw Se(o)})}},Ue=class extends pe{constructor(o){super(o)}},Gt=class extends pe{constructor(e){super(e)}sendAsync(e,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};import{getAddress as kr}from"@ethersproject/address";import{Web3Provider as qi}from"@ethersproject/providers";import{getAddress as $i}from"@ethersproject/address";import{Web3Provider as ji}from"@ethersproject/providers";var ye=class{constructor(e,o,r){this.createSiweMessage=(e,o,r,n,i,s,a)=>`${r} wants you to sign in with your Ethereum account:
|
|
1
|
+
import{Web3Provider as u1}from"@ethersproject/providers";import{useEffect as Nn,useState as te}from"react";import Un from"axios";var ne=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}]`:""}`}},je=class extends ne{constructor(o,r,i,n){super(i,n);this.type=o;this.status=r}},y=class extends ne{constructor(o,r){super(o,r);this.type="client_error"}};var B=class extends ne{constructor(o,r){super(o,r);this.type="connector_error"}},U=t=>{if(t instanceof ne)return t;if(!Un.isAxiosError(t))return oe(t);if(!t.response)return new je("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new je(e||"ApiError",t.response.status,o||r,t)},oe=t=>t instanceof ne?t:t instanceof Error?new y(t.message,t):new y(`Internal error: ${t}`);var vr=()=>"/api/v1/sessions",Cr=()=>"/api/v1/sessions/logout",br=()=>"/api/v1/sessions/fork",xr=()=>"/api/v1/siwe/init",Er=()=>"/api/v1/siwe/authenticate",Lr=()=>"/api/v1/siwe/link",Ar=()=>"/api/v1/passwordless/init",_r=()=>"/api/v1/passwordless/authenticate",Pr=()=>"/api/v1/passwordless/link",Sr=()=>"/api/v1/passwordless_sms/init",kr=()=>"/api/v1/passwordless_sms/authenticate",Tr=()=>"/api/v1/passwordless_sms/link",Wr=()=>"/api/v1/oauth/init",Ir=()=>"/api/v1/oauth/authenticate",Rr=()=>"/api/v1/oauth/link",Mr=()=>"/api/v1/siwe/unlink",Nr=()=>"/api/v1/passwordless/unlink",Or=()=>"/api/v1/passwordless_sms/unlink",Ur=()=>"/api/v1/oauth/unlink";var ft=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new y("Email and email code must be set prior to calling authenticate.");try{let e=_r(),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 U(e)}}async link(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new y("Email and email code must be set prior to calling authenticate.");try{let e=Pr();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw U(e)}}async sendCodeEmail(e){if(!this.api)throw new y("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new y("Email must be set when initialzing authentication.");try{let o=Ar();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw U(o)}}};var Ze=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 y("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new y("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new y("User denied confirmation during OAuth flow");try{let e=Ir(),o=await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw U(e)}}async link(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new y("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new y("User denied confirmation during OAuth flow");try{let e=Rr();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw U(e)}}async getAuthorizationUrl(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.provider)throw new y("Provider must be set when initialzing OAuth authentication.");try{let e=Wr();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw U(e)}}};var gt=class{constructor(e,o){this.meta={walletType:o},this.connectors=e,this.walletConnector=this.connectors.createWalletConnector(o,null)}async authenticate(){if(!this.api)throw new y("Auth flow has no API instance");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Er(),{message:e,signature:o});return this.connectors.addWalletConnector(this.walletConnector),await this.connectors.setActiveWallet(this.walletConnector.address)||console.warn("Failed to set active wallet"),{user:r.data.user,token:r.data.token,refresh_token:r.data.refresh_token,is_new_user:r.data.is_new_user}}catch(e){throw U(e)}}async link(){if(!this.api)throw new y("Auth flow has no API instance");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Lr(),{message:e,signature:o});return this.connectors.addWalletConnector(this.walletConnector),await this.connectors.setActiveWallet(this.walletConnector.address)||console.warn("Failed to set active wallet"),r.data}catch(e){throw U(e)}}async promptConnectAndSign(e){let o=await this.walletConnector.connect({showPrompt:!0}),r=o.address,i=o.chainId,n=await e.post(xr(),{address:r}),s=this.walletConnector.prepareMessage(i,r,n.data.nonce),a=await this.walletConnector.sign(s);return{message:s,signature:a}}};var yt=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new y("phone number and sms code must be set prior to calling authenticate.");try{let e=kr(),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 U(e)}}async link(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new y("phone number and sms code must be set prior to calling authenticate.");try{let e=Tr();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw U(e)}}async sendSmsCode(e){if(!this.api)throw new y("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new y("phone nNumber must be set when initialzing authentication.");try{let o=Sr();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw U(o)}}};import{getAddress as es}from"@ethersproject/address";var Dr="1.17.0";var Fr="https://api.privy.io/v0",Po=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",wt="4df5e2316331463a9130964bd6078dfa",Gr=1e4,re=1400,So=Dr;var qe="privy:token",Ut="privy:refresh_token",Dt="privy:connectors",Br="walletconnect",ko=3e4;var To=class{constructor(){this._cache={}}get(e){return this._cache[e]}put(e,o){o!==void 0?this._cache[e]=o:this.del(e)}del(e){delete this._cache[e]}getKeys(){return Object.keys(this._cache)}},Wo=class{get(e){let o=localStorage.getItem(e);return o===null?void 0:JSON.parse(o)}put(e,o){o!==void 0?localStorage.setItem(e,JSON.stringify(o)):this.del(e)}del(e){localStorage.removeItem(e)}getKeys(){return Object.entries(localStorage).map(([e])=>e)}};function Fn(){return typeof window<"u"&&window.localStorage?new Wo:new To}var Z=Fn();import Zn from"@coinbase/wallet-sdk";import{getAddress as qn}from"@ethersproject/address";import{getAddress as $n}from"@ethersproject/address";import{Web3Provider as jn}from"@ethersproject/providers";import{ErrorCode as Gn}from"@ethersproject/logger";var Ke=class extends B{constructor(){super("Wallet timeout");this.type="wallet_error"}},Pe=t=>{if(t instanceof B)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new Je(t);return t.code===Gn.ACTION_REJECTED&&(e.details=Ue.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new Je(t):new B("Unknown connector error",t)},Io=class extends ne{constructor(o,r,i){super(o);this.type="provider_error";this.code=r,this.data=i}},Je=class extends Io{constructor(o){var n,s,a;let r=o;super(r.message,r.code,r.data);let i=Object.values(Ue).find(p=>p.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:(a=r.message)!=null&&a.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=Ue.E32002_WALLET_LOCKED))}},Bn={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}},Vn={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}},Hn={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},...Hn,...Vn},Ye={...Bn,...Ue};var zn=12e4,Ro=(t=new Ke,e=zn)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),de=class{constructor(e){this.removeListener=(e,o)=>{if(this.walletProvider)return this.walletProvider.removeListener(e,o)};this.setProvider=e=>{this.walletProvider=e,this._subscriptions.forEach(o=>{var r;(r=this.walletProvider)==null||r.on(o.eventName,o.listener)})};this.walletProvider=e,this._subscriptions=[]}on(e,o){if(this.walletProvider)return this.walletProvider.on(e,o);this._subscriptions.push({eventName:e,listener:o})}async request(e){if(!this.walletProvider)throw new B(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),Ro()]).catch(o=>{throw Pe(o)})}},fe=class extends de{constructor(o){super(o)}},Ft=class extends de{constructor(e){super(e)}sendAsync(e,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};var ge=class{constructor(e,o,r){this.createSiweMessage=(e,o,r,i,n,s,a)=>`${r} wants you to sign in with your Ethereum account:
|
|
2
2
|
${o}
|
|
3
3
|
|
|
4
4
|
${a}
|
|
5
5
|
|
|
6
|
-
URI: ${
|
|
6
|
+
URI: ${i}
|
|
7
7
|
Version: 1
|
|
8
8
|
Chain ID: ${e}
|
|
9
9
|
Nonce: ${s}
|
|
10
|
-
Issued At: ${
|
|
10
|
+
Issued At: ${n}
|
|
11
11
|
Resources:
|
|
12
|
-
- https://privy.io`;this.provider=o,this.walletType=e,this.address=r,this.chain=null,this.connected=!1}async fetchAddress(){if(!this.address){let e=await this.provider.request({method:"eth_accounts"});Array.isArray(e)&&e.length>0&&(this.address=$i(e[0]))}return this.address}async fetchChainId(){if(!this.chain){let e=await this.provider.request({method:"eth_chainId"}),o=Number(e);this.chain=String(o)}return this.chain}async getConnectedWallet(){if(!this.walletType||!await this.isConnected())return null;let o=await this.fetchAddress(),r=await this.fetchChainId();return{address:o,chainId:r,chainType:"ethereum",walletClient:"unknown"}}async setActive(){return!0}async sign(e){return new ji(new Ue(this.provider)).getSigner().signMessage(e)}prepareMessage(e,o,r){let n=window.location.host,i=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.",a=new Date().toISOString();return this.createSiweMessage(e,o,n,i,a,r,s)}};import{isPossiblePhoneNumber as Zi}from"libphonenumber-js/min";var Lr=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,}))$/),Ar=t=>Zi(String(t),"US"),Bt=t=>{var e=/^#?([a-f\d])([a-f\d])([a-f\d])$/i;t=t.replace(e,function(r,n,i,s){return n+n+i+i+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)}},_r=(t,e)=>{var o=t.slice(0);let r=[];for(;o.length;)r.push(o.splice(0,e));return r},De=(t,e=3,o=4)=>{if(!t)return"";let r=2,n=3;if(e+o+r+n>=t.length)return t;let i=t.slice(0,r+e),s=t.slice(t.length-o,t.length);return`${i}...${s}`},No=t=>new Promise(e=>setTimeout(e,t)),Sr=(t,e={})=>{let o=e.delayMs||40,r=e.maxAttempts||1e3;return new Promise(async(n,i)=>{let s=!1,a=0;for(;!s&&a<r;)t().then(()=>{s=!0,n()},(...p)=>{s=!0,i(...p)}),a+=1,await No(o);s||i(new Error("Exceeded max attempts before resolving function"))})},Pr=(...t)=>{let o=t.length-1;return t.map((n,i)=>(i===0&&(n.startsWith("//")||n.endsWith("://"))?n=n.replace(new RegExp("/$"),""):i!==o&&(n=n.replace(new RegExp("/+$"),"")),i!==0&&(n=n.replace(new RegExp("^/+"),"")),n)).join("/")};import{isMobile as Ki}from"react-device-detect";var Vt=class extends ye{constructor(e,o){var r;super("metamask",e,o),this.provider.setProvider(window.ethereum),(r=window.ethereum.providers)==null||r.forEach(async n=>{n.isMetaMask&&this.provider.setProvider(n)}),this.subscribeListeners()}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}async isConnected(){let e=await this.connectedMetamaskAddress();return this.address===e}async connectedMetamaskAddress(){let o=await new qi(this.provider).listAccounts();return o.length===0?null:kr(o[0])}disconnect(){console.warn("Metamask does not support programmetic disconnect.")}async promptConnection(){try{let e="";if(!Ki&&(await this.provider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]}),this.address&&await this.isConnected()))throw new B("Selected the wrong wallet in MetaMask");let o=await this.provider.request({method:"eth_requestAccounts"});if(o.length>0&&(e=kr(o[0])),!e||e==="")throw new B("Unable to retrieve address");this.connected=!0,this.address=e}catch(e){throw Se(e)}}async setActive(){if(await this.connectedMetamaskAddress()===this.address)return this.connected=!0,!0;for(;!this.connected;)await No(200);return!0}subscribeListeners(){this.provider.on("accountsChanged",e=>{var o;if(e.length>0){let r=e[0];this.connected=((o=this.address)==null?void 0:o.toLowerCase())===(r==null?void 0:r.toLowerCase())}}),this.provider.on("disconnect",()=>{this.connected=!1})}};import{getAddress as Ji}from"@ethersproject/address";import Yi from"@coinbase/wallet-sdk";var Xi=t=>{let e=`https://mainnet.infura.io/v3/${ft}`,o=1;return t.makeWeb3Provider(e,o)},Ht,zt=class extends ye{constructor(e,o){super("coinbase_wallet",e,o),Ht||(Ht=new Yi({appName:"Privy",darkMode:!1,headlessMode:!1}))}async connect(e){return this.provider.setProvider(Xi(Ht)),e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){Ht.disconnect()}async isConnected(){return await this.fetchAddress()!==null}async promptConnection(){try{let e="",o=await this.provider.request({method:"eth_requestAccounts"});if(o.length>0&&(e=Ji(o[0])),!e||e==="")throw new B("Unable to retrieve address");this.connected=!0}catch(e){throw Se(e)}}};import Tr from"@walletconnect/web3-provider";var Oo=class extends ye{constructor(o,r,n){super("wallet_connect",r,n);this._connectionManager=o,this._provider=this._connectionManager.getProviderForAddress(n)}async connect(o){return this.provider.setProvider(this._provider),o.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}async isConnected(){return this.provider.walletProvider.connected}async promptConnection(){try{let o="";this.provider.setProvider(this._provider);let r=await Promise.race([this._provider.enable(),Mo()]);if(r.length>0&&(o=r[0]),this._connectionManager.indexProvider(this._provider),!o||o==="")throw new B("Unable to retrieve address");this.connected=!0}catch(o){throw Se(o)}}disconnect(){}},$t=class{constructor(){this._storageIdToProvider={},this._addressToStorageId={},q.getKeys().forEach(e=>{if(e.startsWith("walletconnect")){let o=new Tr({infuraId:ft,storageId:e,pollingInterval:ko});this._storageIdToProvider[e]=o;for(let r of o.accounts)this._addressToStorageId[r]=e}})}createConnector(e,o){return new Oo(this,e,o)}async disconnect(){Object.values(this._storageIdToProvider).forEach(async e=>{await e.disconnect()})}getProviderForAddress(e){let o=xr,r=()=>`walletconnect:${Math.random().toString(36).slice(2)}`;e===null?o=r():o=this._addressToStorageId[e]||r();let n=new Tr({infuraId:ft,storageId:o,pollingInterval:ko});return this._storageIdToProvider[o]=n,n}indexProvider(e){this._storageIdToProvider[e.storageId]=e;for(let o of e.accounts)this._addressToStorageId[o]=e.storageId}};import{getAddress as Qi}from"@ethersproject/address";var Uo=()=>{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},jt=()=>{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},Do=t=>{let e=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return e?!!(t==null?void 0:t.linkedAccounts.filter(r=>r.type=="wallet"&&r.address===Qi(e)).length):!1},Wr=()=>{var e;let t=q.get(Dt);return t?(e=t.find(o=>o.active))==null?void 0:e.address:null},gt=class{constructor(){this.getEthereumProvider=()=>{var e;return((e=this.activeWalletConnector)==null?void 0:e.provider)||new pe};this.walletConnectors=[],this.wcConnectionManager=new $t,this.initialized=!1}initialize(){this.initialized||(this.load(),this.activeWalletConnector&&this.activeWalletConnector.connect({showPrompt:!1}),this.initialized=!0)}initializeLinkedWallets(e){e.linkedAccounts.forEach(()=>{})}load(){(q.get(Dt)||[]).forEach(o=>{let r=this.createWalletConnector(o.walletType,o.address);this.addWalletConnector(r),o.active&&(this.activeWalletConnector=r)})}save(){let e=this.walletConnectors.map(o=>{var r;return{address:o.address,walletType:o.walletType,active:o.address===((r=this.activeWalletConnector)==null?void 0:r.address)}});q.put(Dt,e)}addWalletConnector(e){this.walletConnectors.find(r=>r.address===e.address&&r.walletType===e.walletType)||this.walletConnectors.push(e)}getConnectorByAddress(e){return this.walletConnectors.find(o=>{var r;return((r=o.address)==null?void 0:r.toLowerCase())===e.toLowerCase()})}async removeWallet(e){var r;if(this.walletConnectors=this.walletConnectors.filter(n=>n.address!==e),e===((r=this.activeWalletConnector)==null?void 0:r.address))if(this.walletConnectors.length>0){let n=this.walletConnectors[this.walletConnectors.length-1];await this.setActiveWallet(n.address)}else this.activeWalletConnector=void 0;this.save()}async activeWalletSign(e){if(!this.activeWalletConnector)throw new B("Cannot sign, no wallet is active. Is a wallet connected?");if(!await this.activeWalletConnector.connect({showPrompt:!1}))throw new B("Cannot sign - unable to connect to wallet.");return this.activeWalletConnector.sign(e)}async setActiveWallet(e){let o=this.walletConnectors.find(r=>r.address===e);return o?(await o.setActive(),this.activeWalletConnector=o,this.save(),!0):!1}createWalletConnector(e,o){switch(e){case"metamask":return new Vt(new pe,o);case"coinbase_wallet":return new zt(new pe,o);case"wallet_connect":return this.wcConnectionManager.createConnector(new pe,o)}}};function Pe(t){return new Date(t*1e3)}function es(t){let e=[];for(let o of t){let r=o.type;switch(o.type){case"wallet":let n={address:o.address,type:o.type,verifiedAt:Pe(o.verified_at),chainType:o.chain_type,walletClient:o.wallet_client};e.push(n);break;case"email":let i={address:o.address,type:o.type,verifiedAt:Pe(o.verified_at)};e.push(i);break;case"phone":let s={number:o.phoneNumber,type:o.type,verifiedAt:Pe(o.verified_at)};e.push(s);break;case"google_oauth":let a={subject:o.subject,email:o.email,name:o.name,type:o.type,verifiedAt:Pe(o.verified_at)};e.push(a);break;case"twitter_oauth":let p={subject:o.subject,username:o.username,name:o.name,type:o.type,verifiedAt:Pe(o.verified_at)};e.push(p);break;case"discord_oauth":let u={subject:o.subject,username:o.username,email:o.email,type:o.type,verifiedAt:Pe(o.verified_at)};e.push(u);break;case"github_oauth":let b={subject:o.subject,username:o.username,name:o.name,email:o.email,type:o.type,verifiedAt:Pe(o.verified_at)};e.push(b);break;default:console.warn(`Unrecognized account type: ${r}. Please consider upgrading the Privy SDK.`)}}return e}function Fe(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function yt(t){let e=Wr();if(!e)return t.wallet&&console.warn("[Privy] User has linked wallets but no active wallet"),t;let o=t.linkedAccounts.find(n=>n.type==="wallet"&&n.address===e);if(!o)return t;let r=Object.assign({},t);return r.wallet=o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletClient:o.walletClient},r}var we=t=>t==null?void 0:t.linkedAccounts.find(e=>e.type==="wallet"&&e.walletClient==="privy");function ve(t){if(!t)return null;let e=es(t.linked_accounts),o=Fe(e,"wallet"),r=Fe(e,"email"),n=Fe(e,"phone"),i=Fe(e,"google_oauth"),s=Fe(e,"twitter_oauth"),a=Fe(e,"discord_oauth"),p=Fe(e,"github_oauth"),u={id:t.id,createdAt:Pe(t.created_at),linkedAccounts:e,email:r&&{address:r==null?void 0:r.address},phone:n&&{number:n==null?void 0:n.number},wallet:o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletClient:o.walletClient},google:i&&{subject:i.subject,email:i.email,name:i.name},twitter:s&&{subject:s.subject,username:s.username,name:s.name},discord:a&&{subject:a.subject,username:a.username,email:a.email},github:p&&{subject:p.subject,username:p.username,name:p.name,email:p.email}};return yt(u)}var Ir=()=>"/api/v1/sessions",Rr=()=>"/api/v1/sessions/logout",Mr=()=>"/api/v1/sessions/fork",Nr=()=>"/api/v1/siwe/init",Or=()=>"/api/v1/siwe/authenticate",Ur=()=>"/api/v1/siwe/link",Dr=()=>"/api/v1/passwordless/init",Fr=()=>"/api/v1/passwordless/authenticate",Gr=()=>"/api/v1/passwordless/link",Br=()=>"/api/v1/passwordless_sms/init",Vr=()=>"/api/v1/passwordless_sms/authenticate",Hr=()=>"/api/v1/passwordless_sms/link",zr=()=>"/api/v1/oauth/init",$r=()=>"/api/v1/oauth/authenticate",jr=()=>"/api/v1/oauth/link",Zr=()=>"/api/v1/siwe/unlink",qr=()=>"/api/v1/passwordless/unlink",Kr=()=>"/api/v1/passwordless_sms/unlink",Jr=()=>"/api/v1/oauth/unlink";var ts=30,Zt=class{constructor(){this.authenticateOnce=new _e(async e=>this._authenticate(e)),this.linkOnce=new _e(async e=>this._link(e)),this.refreshOnce=new _e(this._refresh.bind(this)),this.destroyOnce=new _e(this._destroy.bind(this)),this.forkSessionOnce=new _e(this._forkSession.bind(this))}get token(){try{let e=q.get(Ze);return typeof e=="string"?new ge(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=q.get(Ut);return typeof e=="string"?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}hasRefreshCredentials(){return typeof this.token=="string"&&typeof this.refreshToken=="string"}hasActiveToken(){let e=ge.parse(this.token);return e!==null&&!e.isExpired(ts)}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:n,is_new_user:i}=await e.authenticate();return this.storeToken(o),this.storeRefreshToken(r),{user:ve(n),isNewUser:i}}catch(o){throw console.warn("Error authenticating session"),re(o)}}async _link(e){try{let o=await e.link();return ve(o)}catch(o){throw console.warn("Error linking account"),re(o)}}async _refresh(){if(!this.api)throw new y("Session has no API instance");if(!this.client)throw new y("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let e=this.token,o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(Ir(),{refresh_token:o},{headers:{authorization:`Bearer ${e}`}});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),ve(r.data.user)}catch(r){if(r instanceof je&&r.status===400&&r.message==="Invalid auth token")return this.destroyLocalState(),null;throw re(r)}}async _destroy(){var e;try{await((e=this.api)==null?void 0:e.post(Rr(),{refresh_token:this.refreshToken}))}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new y("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(Mr(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw re(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null)}storeToken(e){typeof e=="string"?q.put(Ze,e):q.del(Ze)}storeRefreshToken(e){typeof e=="string"?q.put(Ut,e):q.del(Ut)}};var Fo,wt=class{constructor(e){let o=e.apiURL||Cr,r=e.timeout||br;this.appId=e.appId,this.connectors=new gt,Fo||(Fo=new Zt),this.session=Fo,this.api=new Ft(e.appId,this,{baseURL:o,timeout:r}),this.session.api=this.api,this.session.client=this}authenticate(){if(!this.authFlow)throw new y("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new y("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.authFlow=void 0}startAuthFlow(e){e.api=this.api,this.authFlow=e}async unlinkEmail(e){try{let o=await this.api.post(qr(),{address:e});return ve(o.data)}catch(o){throw re(o)}}async unlinkPhone(e){try{let o=await this.api.post(Kr(),{phoneNumber:e});return ve(o.data)}catch(o){throw re(o)}}async unlinkWallet(e){try{let o=await this.api.post(Zr(),{address:e});return this.connectors.removeWallet(e),ve(o.data)}catch(o){throw re(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(Jr(),{provider:e,subject:o});return ve(r.data)}catch(r){throw re(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){var o;return this.session.hasActiveToken()?((o=ge.parse(this.session.token))==null?void 0:o.audience)!==this.appId?(await this.logout(),null):this.session.token:!(e!=null&&e.disableAutoRefresh)&&this.session.hasRefreshCredentials()?(await this.session.refresh(),this.session.token):null}async getAppSettings(){try{let e=await this.api.get(`/api/v1/apps/${this.appId}`);return{id:e.data.id,name:e.data.name,verificationKey:e.data.verification_key,logoUrl:e.data.logo_url||void 0,theme:e.data.theme,accentColor:e.data.accent_color||void 0,showWalletLoginFirst:e.data.show_wallet_login_first,allowlistConfig:{errorTitle:e.data.allowlist_config.error_title,errorDetail:e.data.allowlist_config.error_detail,errorCtaText:e.data.allowlist_config.cta_text,errorCtaLink:e.data.allowlist_config.cta_link},walletAuth:e.data.wallet_auth,emailAuth:e.data.email_auth,smsAuth:e.data.sms_auth,googleOAuth:e.data.google_oauth,twitterOAuth:e.data.twitter_oauth,discordOAuth:e.data.discord_oauth,githubOAuth:e.data.github_oauth,termsAndConditionsUrl:e.data.terms_and_conditions_url,privacyPolicyUrl:e.data.privacy_policy_url,createdAt:new Date(e.data.created_at*1e3),updatedAt:new Date(e.data.updated_at*1e3)}}catch(e){throw re(e)}}async setActiveWallet(e,o){if(!o.linkedAccounts.map(i=>i.type==="wallet"?i.address:null).includes(e))throw new y("Cannot set an unlinked address as active.");if(!await this.connectors.setActiveWallet(e))throw new y("Error setting the active wallet.");return yt(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as p1}from"@ethersproject/providers";import{createContext as os,useContext as rs}from"react";var w=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var Go=os({ready:!1,authenticated:!1,user:null,walletConnectors:null,login:w,linkEmail:w,linkPhone:w,linkWallet:w,linkGoogle:w,linkTwitter:w,linkDiscord:w,linkGithub:w,logout:w,getAccessToken:w,getEthereumProvider:w,getEthersProvider:w,getWeb3jsProvider:w,unlinkEmail:w,unlinkPhone:w,unlinkWallet:w,unlinkGoogle:w,unlinkTwitter:w,unlinkDiscord:w,unlinkGithub:w,setActiveWallet:w,forkSession:w,createWallet:w,signMessage:w}),$=()=>rs(Go);var vt=class{constructor(e,o){this.meta={walletType:o},this.connectors=e,this.walletConnector=this.connectors.createWalletConnector(o,null)}async authenticate(){if(!this.api)throw new y("Auth flow has no API instance");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Or(),{message:e,signature:o});return this.connectors.addWalletConnector(this.walletConnector),await this.connectors.setActiveWallet(this.walletConnector.address)||console.warn("Failed to set active wallet"),{user:r.data.user,token:r.data.token,refresh_token:r.data.refresh_token,is_new_user:r.data.is_new_user}}catch(e){throw U(e)}}async link(){if(!this.api)throw new y("Auth flow has no API instance");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Ur(),{message:e,signature:o});return this.connectors.addWalletConnector(this.walletConnector),await this.connectors.setActiveWallet(this.walletConnector.address)||console.warn("Failed to set active wallet"),r.data}catch(e){throw U(e)}}async promptConnectAndSign(e){let o=await this.walletConnector.connect({showPrompt:!0}),r=o.address,n=o.chainId,i=await e.post(Nr(),{address:r}),s=this.walletConnector.prepareMessage(n,r,i.data.nonce),a=await this.walletConnector.sign(s);return{message:s,signature:a}}};var Ct=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new y("Email and email code must be set prior to calling authenticate.");try{let e=Fr(),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 U(e)}}async link(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new y("Email and email code must be set prior to calling authenticate.");try{let e=Gr();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw U(e)}}async sendCodeEmail(e){if(!this.api)throw new y("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new y("Email must be set when initialzing authentication.");try{let o=Dr();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw U(o)}}};var bt=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new y("phone number and sms code must be set prior to calling authenticate.");try{let e=Vr(),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 U(e)}}async link(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new y("phone number and sms code must be set prior to calling authenticate.");try{let e=Hr();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw U(e)}}async sendSmsCode(e){if(!this.api)throw new y("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new y("phone nNumber must be set when initialzing authentication.");try{let o=Br();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw U(o)}}};var Ye=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 y("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new y("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new y("User denied confirmation during OAuth flow");try{let e=$r(),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 U(e)}}async link(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new y("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new y("User denied confirmation during OAuth flow");try{let e=jr();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw U(e)}}async getAuthorizationUrl(){if(!this.api)throw new y("Auth flow has no API instance");if(!this.meta.provider)throw new y("Provider must be set when initialzing OAuth authentication.");try{let e=zr();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw U(e)}}};import{useRef as ns,useEffect as is}from"react";var qt=class{constructor(){this.callbacks={}}enqueue(e,o){this.callbacks[e]=o}dequeue(e,o){let r=this.callbacks[o];if(!r)throw new Error(`cannot dequeue ${e} event: no event found for id ${o}`);switch(delete this.callbacks[o],e){case"privy:iframe:ready":return r;case"privy:wallet:create":return r;case"privy:wallet:sign":return r;case"privy:wallet:recover":return r;default:throw new Error(`invalid wallet event type ${e}`)}}};import{jsx as cs}from"react/jsx-runtime";var ss=function(t){return()=>`id-${t++}`}(0);function as(t){return typeof t.event=="string"&&/^privy:.+/.test(t.event)}function Kt(t){return t.error!==void 0}var xt=new qt;function Jt(t,e,o){let r=o.contentWindow;if(!r)throw new Error("iframe not initialized");return new Promise((n,i)=>{let s=ss();xt.enqueue(s,{resolve:n,reject:i}),r.postMessage({id:s,event:t,data:e},"*")})}function ls(t){switch(t.event){case"privy:iframe:ready":let e=xt.dequeue(t.event,t.id);return Kt(t)?e.reject(new Error(t.error.message)):e.resolve(t.data);case"privy:wallet:create":let o=xt.dequeue(t.event,t.id);return Kt(t)?o.reject(new Error(t.error.message)):o.resolve(t.data);case"privy:wallet:sign":let r=xt.dequeue(t.event,t.id);return Kt(t)?r.reject(new Error(t.error.message)):r.resolve(t.data);case"privy:wallet:recover":let n=xt.dequeue(t.event,t.id);return Kt(t)?n.reject(new Error(t.error.message)):n.resolve(t.data)}}function Yr(t){let e=ns(null);return is(()=>{let o=e.current;if(!o)return;function r(a){a&&a.origin===t.origin&&as(a.data)&&ls(a.data)}let n={create(a){return Jt("privy:wallet:create",a,o)},sign(a){return Jt("privy:wallet:sign",a,o)},recover(a){return Jt("privy:wallet:recover",a,o)}};window.addEventListener("message",r);let i=()=>t.onLoad(n),s=(...a)=>{console.error("privy iframe failed to load: ",...a),t.onLoadFailed()};return Sr(()=>Jt("privy:iframe:ready",{},o)).then(i,s),()=>window.removeEventListener("message",r)},[e.current]),cs("iframe",{ref:e,width:"0",height:"0",style:{visibility:"hidden"},src:Pr(t.origin,`/apps/${t.appId}/embedded-wallets`)})}import"wicg-inert";import{useRef as o1}from"react";import r1 from"react-dom";import wr from"styled-components";import{createContext as ps,useContext as us,useEffect as Bo,useState as Qr}from"react";import{jsx as ds}from"react/jsx-runtime";function Xr(t){return ds("link",{rel:"prefetch",href:t.src})}import{jsx as hs,jsxs as ms}from"react/jsx-runtime";var Ce="LANDING",en=ps({ready:!1,app:null,options:{email:!0,sms:!1,wallet:!0,google:!1,twitter:!1,discord:!1,github:!1},currentScreen:Ce,lastScreen:Ce,navigate:w,navigateBack:w,setModalData:w}),tn=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[n,i]=Qr(t.initialScreen||Ce),[s,a]=Qr(t.initialScreen||Ce);Bo(()=>{o||i(Ce)},[o]),Bo(()=>{r||(a(Ce),i(Ce))},[r]),Bo(()=>{t.initialScreen&&n===Ce&&(i(t.initialScreen),a(t.initialScreen))},[t.initialScreen]);let p=t.initialScreen&&n===Ce?t.initialScreen:n,u={ready:!!(e!=null&&e.id),app:e,options:t.options,data:t.data,setModalData:t.setModalData,currentScreen:p,lastScreen:s,navigate:b=>{a(n),i(b)},navigateBack:()=>{i(s)}};return ms(en.Provider,{value:u,children:[e&&e.logoUrl&&hs(Xr,{src:e.logoUrl}),t.children]})},v=()=>us(en);import{useState as aa}from"react";import ot from"styled-components";import ys from"styled-components";import{jsx as on}from"react/jsx-runtime";var rn=({style:t,...e})=>on("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:on("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});import{jsx as nn}from"react/jsx-runtime";var sn=({style:t,...e})=>nn("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:nn("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as fs,useContext as gs}from"react";var Vo=fs({isLinking:!1,linkingHint:null,activeStatus:null,getAuthMeta:w,getAuthFlow:w,closePrivyModal:w,initLoginWithWallet:w,loginWithWallet:w,loginWithCode:w,initLoginWithEmail:w,initLoginWithSms:w,resendEmailCode:w,resendSmsCode:w,initLoginWithOAuth:w,loginWithOAuth:w,refreshUser:w,walletProxy:null}),S=()=>gs(Vo);import{jsx as be,jsxs as xs}from"react/jsx-runtime";var ws=()=>be("div",{}),vs=({backFn:t})=>be("div",{children:be(sn,{onClick:t})}),Cs=t=>be("div",{children:be("div",{children:be(rn,{onClick:t.onClose})})});var L=({backFn:t,onClose:e})=>{let{closePrivyModal:o}=S();return xs(bs,{children:[t?be(vs,{backFn:t}):be(ws,{}),be(Cs,{onClose:e||(()=>o())})]})},bs=ys.div`
|
|
12
|
+
- https://privy.io`;this.provider=o,this.walletType=e,this.address=r,this.chain=null,this.connected=!1}async fetchAddress(){if(!this.address){let e=await this.provider.request({method:"eth_accounts"});Array.isArray(e)&&e.length>0&&(this.address=$n(e[0]))}return this.address}async fetchChainId(){if(!this.chain){let e=await this.provider.request({method:"eth_chainId"}),o=Number(e);this.chain=String(o)}return this.chain}async getConnectedWallet(){if(!this.walletType||!await this.isConnected())return null;let o=await this.fetchAddress(),r=await this.fetchChainId();return{address:o,chainId:r,chainType:"ethereum",walletClient:"unknown"}}async setActive(){return!0}async sign(e){return await this.connect({showPrompt:!1}),new jn(new fe(this.provider)).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.",a=new Date().toISOString();return this.createSiweMessage(e,o,i,n,a,r,s)}};var Kn=t=>{let e=`https://mainnet.infura.io/v3/${wt}`,o=1;return t.makeWeb3Provider(e,o)},Gt,Bt=class extends ge{constructor(e,o){super("coinbase_wallet",e,o),Gt||(Gt=new Zn({appName:"Privy",darkMode:!1,headlessMode:!1}))}async connect(e){return this.provider.setProvider(Kn(Gt)),e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}disconnect(){Gt.disconnect()}async isConnected(){return await this.fetchAddress()!==null}async promptConnection(){try{let e="",o=await this.provider.request({method:"eth_requestAccounts"});if(o.length>0&&(e=qn(o[0])),!e||e==="")throw new B("Unable to retrieve address");this.connected=!0}catch(e){throw Pe(e)}}};import{getAddress as Zr}from"@ethersproject/address";import{Web3Provider as Yn}from"@ethersproject/providers";import{isMobile as Xn}from"react-device-detect";import{isPossiblePhoneNumber as Jn}from"libphonenumber-js/min";var Vr=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,}))$/),Hr=t=>Jn(String(t),"US"),Vt=t=>{let 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});let 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)}},zr=(t,e)=>{let o=t.slice(0),r=[];for(;o.length;)r.push(o.splice(0,e));return r},De=(t,e=3,o=4)=>{if(!t)return"";let r=2,i=3;if(e+o+r+i>=t.length)return t;let n=t.slice(0,r+e),s=t.slice(t.length-o,t.length);return`${n}...${s}`},Mo=t=>new Promise(e=>setTimeout(e,t)),$r=(t,e={})=>{let o=e.delayMs||40,r=e.maxAttempts||1e3;return new Promise(async(i,n)=>{let s=!1,a=0;for(;!s&&a<r;)t().then(()=>{s=!0,i()},(...p)=>{s=!0,n(...p)}),a+=1,await Mo(o);s||n(new Error("Exceeded max attempts before resolving function"))})},jr=(...t)=>{let o=t.length-1;return t.map((i,n)=>(n===0&&(i.startsWith("//")||i.endsWith("://"))?i=i.replace(new RegExp("/$"),""):n!==o&&(i=i.replace(new RegExp("/+$"),"")),n!==0&&(i=i.replace(new RegExp("^/+"),"")),i)).join("/")};var Ht=class extends ge{constructor(e,o){var r;super("metamask",e,o),this.provider.setProvider(window.ethereum),(r=window.ethereum.providers)==null||r.forEach(async i=>{i.isMetaMask&&this.provider.setProvider(i)}),this.subscribeListeners()}async connect(e){return e.showPrompt&&await this.promptConnection(),await this.isConnected()?this.getConnectedWallet():null}async isConnected(){let e=await this.connectedMetamaskAddress();return this.address===e}async connectedMetamaskAddress(){let o=await new Yn(this.provider).listAccounts();return o.length===0?null:Zr(o[0])}disconnect(){console.warn("Metamask does not support programmetic disconnect.")}async promptConnection(){try{let e="";if(!Xn&&(await this.provider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]}),this.address&&await this.isConnected()))throw new B("Selected the wrong wallet in MetaMask");let o=await this.provider.request({method:"eth_requestAccounts"});if(o.length>0&&(e=Zr(o[0])),!e||e==="")throw new B("Unable to retrieve address");this.connected=!0,this.address=e}catch(e){throw Pe(e)}}async setActive(){if(await this.connectedMetamaskAddress()===this.address)return this.connected=!0,!0;for(;!this.connected;)await Mo(200);return!0}subscribeListeners(){this.provider.on("accountsChanged",e=>{var o;if(e.length>0){let r=e[0];this.connected=((o=this.address)==null?void 0:o.toLowerCase())===(r==null?void 0:r.toLowerCase())}}),this.provider.on("disconnect",()=>{this.connected=!1})}};import{Web3Provider as Qn}from"@ethersproject/providers";import qr from"@walletconnect/web3-provider";var No=class extends ge{constructor(o,r,i){super("wallet_connect",r,i);this._connectionManager=o,this._provider=this._connectionManager.getProviderForAddress(i)}async connect(o){return this.provider.setProvider(this._provider),o.showPrompt&&await this.promptConnection(),this.getConnectedWallet()}async isConnected(){return this.provider.walletProvider.connected}async promptConnection(){try{let o="";this.provider.setProvider(this._provider);let r=await Promise.race([this._provider.enable(),Ro()]);if(r.length>0&&(o=r[0]),this._connectionManager.indexProvider(this._provider),!o||o==="")throw new B("Unable to retrieve address");this.connected=!0}catch(o){throw Pe(o)}}async sign(o){return await this._provider.enable(),new Qn(new fe(this.provider)).getSigner().signMessage(o)}disconnect(){}},zt=class{constructor(){this._storageIdToProvider={},this._addressToStorageId={},Z.getKeys().forEach(e=>{if(e.startsWith("walletconnect")){let o=new qr({infuraId:wt,storageId:e,pollingInterval:ko});o.enable(),this._storageIdToProvider[e]=o;for(let r of o.accounts)this._addressToStorageId[r]=e}})}createConnector(e,o){return new No(this,e,o)}async disconnect(){Object.values(this._storageIdToProvider).forEach(async e=>{await e.disconnect()})}getProviderForAddress(e){let o=Br,r=()=>`walletconnect:${Math.random().toString(36).slice(2)}`;e===null?o=r():o=this._addressToStorageId[e]||r();let i=new qr({infuraId:wt,storageId:o,pollingInterval:ko});return this._storageIdToProvider[o]=i,i}indexProvider(e){this._storageIdToProvider[e.storageId]=e;for(let o of e.accounts)this._addressToStorageId[o]=e.storageId}};var Oo=()=>{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},$t=()=>{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},Uo=t=>{let e=localStorage.getItem("-walletlink:https://www.walletlink.org:Addresses");return e?!!(t==null?void 0:t.linkedAccounts.filter(r=>r.type=="wallet"&&r.address===es(e)).length):!1},Kr=()=>{var e;let t=Z.get(Dt);return t?(e=t.find(o=>o.active))==null?void 0:e.address:null},vt=class{constructor(){this.getEthereumProvider=()=>{var e;return((e=this.activeWalletConnector)==null?void 0:e.provider)||new de};this.walletConnectors=[],this.wcConnectionManager=new zt,this.initialized=!1}initialize(){this.initialized||(this.load(),this.activeWalletConnector&&this.activeWalletConnector.connect({showPrompt:!1}),this.initialized=!0)}initializeLinkedWallets(e){e.linkedAccounts.forEach(()=>null)}load(){(Z.get(Dt)||[]).forEach(o=>{let r=this.createWalletConnector(o.walletType,o.address);this.addWalletConnector(r),o.active&&(this.activeWalletConnector=r)})}save(){let e=this.walletConnectors.map(o=>{var r;return{address:o.address,walletType:o.walletType,active:o.address===((r=this.activeWalletConnector)==null?void 0:r.address)}});Z.put(Dt,e)}addWalletConnector(e){this.walletConnectors.find(r=>r.address===e.address&&r.walletType===e.walletType)||this.walletConnectors.push(e)}getConnectorByAddress(e){return this.walletConnectors.find(o=>{var r;return((r=o.address)==null?void 0:r.toLowerCase())===e.toLowerCase()})}async removeWallet(e){var r;if(this.walletConnectors=this.walletConnectors.filter(i=>i.address!==e),e===((r=this.activeWalletConnector)==null?void 0:r.address))if(this.walletConnectors.length>0){let i=this.walletConnectors[this.walletConnectors.length-1];await this.setActiveWallet(i.address)}else this.activeWalletConnector=void 0;this.save()}async activeWalletSign(e){if(!this.activeWalletConnector)throw new B("Cannot sign, no wallet is active. Is a wallet connected?");return this.activeWalletConnector.sign(e)}async setActiveWallet(e){let o=this.walletConnectors.find(r=>r.address===e);return o?(await o.setActive(),this.activeWalletConnector=o,this.save(),!0):!1}createWalletConnector(e,o){switch(e){case"metamask":return new Ht(new de,o);case"coinbase_wallet":return new Bt(new de,o);case"wallet_connect":return this.wcConnectionManager.createConnector(new de,o)}}};function Se(t){return new Date(t*1e3)}function ts(t){let e=[];for(let o of t){let r=o.type;switch(o.type){case"wallet":let i={address:o.address,type:o.type,verifiedAt:Se(o.verified_at),chainType:o.chain_type,walletClient:o.wallet_client};e.push(i);break;case"email":let n={address:o.address,type:o.type,verifiedAt:Se(o.verified_at)};e.push(n);break;case"phone":let s={number:o.phoneNumber,type:o.type,verifiedAt:Se(o.verified_at)};e.push(s);break;case"google_oauth":let a={subject:o.subject,email:o.email,name:o.name,type:o.type,verifiedAt:Se(o.verified_at)};e.push(a);break;case"twitter_oauth":let p={subject:o.subject,username:o.username,name:o.name,type:o.type,verifiedAt:Se(o.verified_at)};e.push(p);break;case"discord_oauth":let u={subject:o.subject,username:o.username,email:o.email,type:o.type,verifiedAt:Se(o.verified_at)};e.push(u);break;case"github_oauth":let x={subject:o.subject,username:o.username,name:o.name,email:o.email,type:o.type,verifiedAt:Se(o.verified_at)};e.push(x);break;default:console.warn(`Unrecognized account type: ${r}. Please consider upgrading the Privy SDK.`)}}return e}function Fe(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function Ct(t){let e=Kr();if(!e)return t.wallet&&console.warn("[Privy] User has linked wallets but no active wallet"),t;let o=t.linkedAccounts.find(i=>i.type==="wallet"&&i.address===e);if(!o)return t;let r=Object.assign({},t);return r.wallet=o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletClient:o.walletClient},r}var ye=t=>t==null?void 0:t.linkedAccounts.find(e=>e.type==="wallet"&&e.walletClient==="privy");function we(t){if(!t)return null;let e=ts(t.linked_accounts),o=Fe(e,"wallet"),r=Fe(e,"email"),i=Fe(e,"phone"),n=Fe(e,"google_oauth"),s=Fe(e,"twitter_oauth"),a=Fe(e,"discord_oauth"),p=Fe(e,"github_oauth"),u={id:t.id,createdAt:Se(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,walletClient:o.walletClient},google:n&&{subject:n.subject,email:n.email,name:n.name},twitter:s&&{subject:s.subject,username:s.username,name:s.name},discord:a&&{subject:a.subject,username:a.username,email:a.email},github:p&&{subject:p.subject,username:p.username,name:p.name,email:p.email}};return Ct(u)}import Do from"axios";var jt=class{constructor(e,o,r){this.appId=e,this.sdkVersion=So,this.client=o,this.defaults=r}async get(e,o){try{return await Do.get(e,await this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw U(r)}}async post(e,o,r){try{return await Do.post(e,o,await this.buildConfig(r))}catch(i){throw U(i)}}async delete(e,o){try{return await Do.delete(e,await this.buildConfig(o))}catch(r){throw U(r)}}async buildConfig(e){if(e=e||{},e.headers=e.headers||{},e.headers["privy-app-id"]=this.appId,e.headers["privy-client"]=`react-auth:${this.sdkVersion}`,!e.headers.authorization){let o=await this.client.getAccessToken();o!==null&&(e.headers.authorization=`Bearer ${o}`)}return{...this.defaults,...e}}};var ke=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}};import*as Jr from"jose";var ve=class{static parse(e){try{return new ve(e)}catch{return null}}constructor(e){this.value=e,this._decoded=Jr.decodeJwt(e)}get subject(){return this._decoded.sub}get expiration(){return this._decoded.exp}get issuer(){return this._decoded.iss}get audience(){return this._decoded.aud}isExpired(e=0){let o=Date.now(),r=(this.expiration-e)*1e3;return o>=r}};var os=30,Zt=class{constructor(){this.authenticateOnce=new ke(async e=>this._authenticate(e)),this.linkOnce=new ke(async e=>this._link(e)),this.refreshOnce=new ke(this._refresh.bind(this)),this.destroyOnce=new ke(this._destroy.bind(this)),this.forkSessionOnce=new ke(this._forkSession.bind(this))}get token(){try{let e=Z.get(qe);return typeof e=="string"?new ve(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=Z.get(Ut);return typeof e=="string"?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}hasRefreshCredentials(){return typeof this.token=="string"&&typeof this.refreshToken=="string"}hasActiveToken(){let e=ve.parse(this.token);return e!==null&&!e.isExpired(os)}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:we(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),oe(o)}}async _link(e){try{let o=await e.link();return we(o)}catch(o){throw console.warn("Error linking account"),oe(o)}}async _refresh(){if(!this.api)throw new y("Session has no API instance");if(!this.client)throw new y("Session has no PrivyClient instance");await this.client.getAccessToken({disableAutoRefresh:!0});let e=this.token,o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(vr(),{refresh_token:o},{headers:{authorization:`Bearer ${e}`}});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),we(r.data.user)}catch(r){if(r instanceof je&&r.status===400&&r.message==="Invalid auth token")return this.destroyLocalState(),null;throw oe(r)}}async _destroy(){var e;try{await((e=this.api)==null?void 0:e.post(Cr(),{refresh_token:this.refreshToken}))}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new y("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(br(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw oe(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null)}storeToken(e){typeof e=="string"?Z.put(qe,e):Z.del(qe)}storeRefreshToken(e){typeof e=="string"?Z.put(Ut,e):Z.del(Ut)}};var Fo,bt=class{constructor(e){let o=e.apiURL||Fr,r=e.timeout||Gr;this.appId=e.appId,this.connectors=new vt,Fo||(Fo=new Zt),this.session=Fo,this.api=new jt(e.appId,this,{baseURL:o,timeout:r}),this.session.api=this.api,this.session.client=this}authenticate(){if(!this.authFlow)throw new y("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new y("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.authFlow=void 0}startAuthFlow(e){e.api=this.api,this.authFlow=e}async unlinkEmail(e){try{let o=await this.api.post(Nr(),{address:e});return we(o.data)}catch(o){throw oe(o)}}async unlinkPhone(e){try{let o=await this.api.post(Or(),{phoneNumber:e});return we(o.data)}catch(o){throw oe(o)}}async unlinkWallet(e){try{let o=await this.api.post(Mr(),{address:e});return this.connectors.removeWallet(e),we(o.data)}catch(o){throw oe(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(Ur(),{provider:e,subject:o});return we(r.data)}catch(r){throw oe(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(e){var o;return this.session.hasActiveToken()?((o=ve.parse(this.session.token))==null?void 0:o.audience)!==this.appId?(await this.logout(),null):this.session.token:!(e!=null&&e.disableAutoRefresh)&&this.session.hasRefreshCredentials()?(await this.session.refresh(),this.session.token):null}async getAppSettings(){try{let e=await this.api.get(`/api/v1/apps/${this.appId}`);return{id:e.data.id,name:e.data.name,verificationKey:e.data.verification_key,logoUrl:e.data.logo_url||void 0,theme:e.data.theme,accentColor:e.data.accent_color||void 0,showWalletLoginFirst:e.data.show_wallet_login_first,allowlistConfig:{errorTitle:e.data.allowlist_config.error_title,errorDetail:e.data.allowlist_config.error_detail,errorCtaText:e.data.allowlist_config.cta_text,errorCtaLink:e.data.allowlist_config.cta_link},walletAuth:e.data.wallet_auth,emailAuth:e.data.email_auth,smsAuth:e.data.sms_auth,googleOAuth:e.data.google_oauth,twitterOAuth:e.data.twitter_oauth,discordOAuth:e.data.discord_oauth,githubOAuth:e.data.github_oauth,termsAndConditionsUrl:e.data.terms_and_conditions_url,privacyPolicyUrl:e.data.privacy_policy_url,createdAt:new Date(e.data.created_at*1e3),updatedAt:new Date(e.data.updated_at*1e3)}}catch(e){throw oe(e)}}async setActiveWallet(e,o){if(!o.linkedAccounts.map(n=>n.type==="wallet"?n.address:null).includes(e))throw new y("Cannot set an unlinked address as active.");if(!await this.connectors.setActiveWallet(e))throw new y("Error setting the active wallet.");return Ct(o)}async forkSession(){return await this.session.forkSession()}};import"wicg-inert";import{disableBodyScroll as Yl,clearAllBodyScrollLocks as Xl}from"body-scroll-lock";import{useRef as Ql}from"react";import{useEffect as e1}from"react";import t1 from"react-dom";import wr from"styled-components";import{createContext as rs,useContext as is}from"react";var w=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var Go=rs({isLinking:!1,linkingHint:null,activeStatus:null,getAuthMeta:w,getAuthFlow:w,closePrivyModal:w,initLoginWithWallet:w,loginWithWallet:w,loginWithCode:w,initLoginWithEmail:w,initLoginWithSms:w,resendEmailCode:w,resendSmsCode:w,initLoginWithOAuth:w,loginWithOAuth:w,refreshUser:w,walletProxy:null}),_=()=>is(Go);import{createContext as ss,useContext as as,useEffect as Bo,useState as Xr}from"react";import{jsx as ns}from"react/jsx-runtime";function Yr(t){return ns("link",{rel:"prefetch",href:t.src})}import{jsx as ls,jsxs as cs}from"react/jsx-runtime";var Ce="LANDING",Qr=ss({ready:!1,app:null,options:{email:!0,sms:!1,wallet:!0,google:!1,twitter:!1,discord:!1,github:!1},currentScreen:Ce,lastScreen:Ce,navigate:w,navigateBack:w,setModalData:w}),ei=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=Xr(t.initialScreen||Ce),[s,a]=Xr(t.initialScreen||Ce);Bo(()=>{o||n(Ce)},[o]),Bo(()=>{r||(a(Ce),n(Ce))},[r]),Bo(()=>{t.initialScreen&&i===Ce&&(n(t.initialScreen),a(t.initialScreen))},[t.initialScreen]);let p=t.initialScreen&&i===Ce?t.initialScreen:i,u={ready:!!(e!=null&&e.id),app:e,options:t.options,data:t.data,setModalData:t.setModalData,currentScreen:p,lastScreen:s,navigate:x=>{a(i),n(x)},navigateBack:()=>{n(s)}};return cs(Qr.Provider,{value:u,children:[e&&e.logoUrl&&ls(Yr,{src:e.logoUrl}),t.children]})},v=()=>as(Qr);import{createContext as ds,useContext as ps}from"react";var Vo=ds({ready:!1,authenticated:!1,user:null,walletConnectors:null,login:w,linkEmail:w,linkPhone:w,linkWallet:w,linkGoogle:w,linkTwitter:w,linkDiscord:w,linkGithub:w,logout:w,getAccessToken:w,getEthereumProvider:w,getEthersProvider:w,getWeb3jsProvider:w,unlinkEmail:w,unlinkPhone:w,unlinkWallet:w,unlinkGoogle:w,unlinkTwitter:w,unlinkDiscord:w,unlinkGithub:w,setActiveWallet:w,forkSession:w,createWallet:w,signMessage:w}),z=()=>ps(Vo);import Kt from"styled-components";import us from"styled-components";var ti=us.span`
|
|
13
|
+
&& {
|
|
14
|
+
width: 82px;
|
|
15
|
+
height: 82px;
|
|
16
|
+
border-width: 4px;
|
|
17
|
+
border-style: solid;
|
|
18
|
+
border-color: ${t=>t.color??"var(--primary-color)"};
|
|
19
|
+
border-bottom-color: transparent;
|
|
20
|
+
border-radius: 50%;
|
|
21
|
+
display: inline-block;
|
|
22
|
+
box-sizing: border-box;
|
|
23
|
+
animation: rotation 1.2s linear infinite;
|
|
24
|
+
transition: border-color 800ms;
|
|
25
|
+
border-color: var(--primary-color);
|
|
26
|
+
border-bottom-color: var(--primary-color);
|
|
27
|
+
}
|
|
28
|
+
`;import hs from"styled-components";import{jsx as oi}from"react/jsx-runtime";var ri=({style:t,...e})=>oi("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:oi("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{jsx as ii}from"react/jsx-runtime";var ni=({style:t,...e})=>ii("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:ii("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});import{jsx as be,jsxs as ws}from"react/jsx-runtime";var ms=()=>be("div",{}),fs=({backFn:t})=>be("div",{children:be(ri,{onClick:t})}),gs=t=>be("div",{children:be("div",{children:be(ni,{onClick:t.onClose})})});var A=({backFn:t,onClose:e})=>{let{closePrivyModal:o}=_();return ws(ys,{children:[t?be(fs,{backFn:t}):be(ms,{}),be(gs,{onClose:e||(()=>o())})]})},ys=hs.div`
|
|
13
29
|
height: 30px;
|
|
14
30
|
display: flex;
|
|
15
31
|
align-items: center;
|
|
@@ -66,99 +82,73 @@ Resources:
|
|
|
66
82
|
@media (max-width: 440px) {
|
|
67
83
|
height: 30px;
|
|
68
84
|
}
|
|
69
|
-
`;import
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
85
|
+
`;import{jsx as si}from"react/jsx-runtime";var ai=({style:t,...e})=>si("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:si("path",{fillRule:"evenodd",d:"M12 1.5a5.25 5.25 0 00-5.25 5.25v3a3 3 0 00-3 3v6.75a3 3 0 003 3h10.5a3 3 0 003-3v-6.75a3 3 0 00-3-3v-3c0-2.9-2.35-5.25-5.25-5.25zm3.75 8.25v-3a3.75 3.75 0 10-7.5 0v3h7.5z",clipRule:"evenodd"})});import{Fragment as Ho,jsx as pe,jsxs as qt}from"react/jsx-runtime";var ci=()=>{let{navigate:t,app:e}=v(),o=(e==null?void 0:e.allowlistConfig.errorTitle)||"You don't have access to this app",r=(e==null?void 0:e.allowlistConfig.errorDetail)||"Have you been invited?",i=(e==null?void 0:e.allowlistConfig.errorCtaText)||"Try another account";return qt(Ho,{children:[pe(A,{}),qt(vs,{children:[pe(bs,{children:qt("div",{children:[pe(ti,{}),pe(ai,{style:{width:"38px",height:"38px",strokeWidth:"1",stroke:"var(--primary-color)",fill:"var(--primary-color)"}})]})}),qt(Cs,{children:[typeof o=="string"?pe("h3",{children:o}):pe(Ho,{children:o}),typeof r=="string"?pe("p",{children:r}):pe(Ho,{children:r})]}),e!=null&&e.allowlistConfig.errorCtaLink?pe(li,{as:"a",href:e.allowlistConfig.errorCtaLink,visible:!0,children:i}):pe(li,{onClick:()=>{t("LANDING")},visible:!0,children:i})]})]})},vs=Kt.div`
|
|
86
|
+
display: flex;
|
|
87
|
+
flex-direction: column;
|
|
88
|
+
align-items: center;
|
|
89
|
+
justify-content: center;
|
|
90
|
+
margin-left: 27px;
|
|
91
|
+
margin-right: 27px;
|
|
92
|
+
gap: 24px;
|
|
93
|
+
`,Cs=Kt.div`
|
|
74
94
|
display: flex;
|
|
75
95
|
flex-direction: column;
|
|
76
|
-
align-items: flex-start;
|
|
77
96
|
gap: 8px;
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
@media (max-width: 440px) {
|
|
81
|
-
flex-direction: row;
|
|
82
|
-
}
|
|
83
|
-
`,zo=dn.button`
|
|
97
|
+
`,bs=Kt.div`
|
|
84
98
|
display: flex;
|
|
85
|
-
flex-direction:
|
|
99
|
+
flex-direction: column;
|
|
100
|
+
justify-content: center;
|
|
86
101
|
align-items: center;
|
|
87
|
-
gap: 12px;
|
|
88
102
|
width: 100%;
|
|
89
|
-
height:
|
|
90
|
-
|
|
91
|
-
-webkit-user-select: none;
|
|
92
|
-
-ms-user-select: none;
|
|
93
|
-
user-select: none;
|
|
103
|
+
height: 82px;
|
|
94
104
|
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
padding: 7px 11px;
|
|
98
|
-
border: 1px solid var(--border-color-2);
|
|
99
|
-
border-radius: var(--border-radius-sm);
|
|
105
|
+
> div {
|
|
106
|
+
position: relative;
|
|
100
107
|
}
|
|
101
108
|
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
&& {
|
|
108
|
-
font-weight: 500;
|
|
109
|
-
padding: 11px 7px;
|
|
110
|
-
font-size: 11px;
|
|
111
|
-
line-height: 16px;
|
|
112
|
-
flex-grow: 1;
|
|
113
|
-
flex-basis: 0;
|
|
114
|
-
}
|
|
109
|
+
> div > span {
|
|
110
|
+
position: absolute;
|
|
111
|
+
left: -41px;
|
|
112
|
+
top: -41px;
|
|
115
113
|
}
|
|
116
114
|
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
> svg {
|
|
123
|
-
border-radius: var(--border-radius-sm);
|
|
124
|
-
|
|
125
|
-
@media (max-width: 440px) {
|
|
126
|
-
height: 50px !important;
|
|
127
|
-
width: 50px !important;
|
|
128
|
-
}
|
|
115
|
+
> div > svg {
|
|
116
|
+
position: absolute;
|
|
117
|
+
left: -19px;
|
|
118
|
+
top: -19px;
|
|
129
119
|
}
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
120
|
+
`,li=Kt.button`
|
|
121
|
+
&& {
|
|
122
|
+
padding: 12px 16px;
|
|
133
123
|
font-weight: 500;
|
|
134
|
-
text-align:
|
|
135
|
-
flex: none;
|
|
136
|
-
order: 2;
|
|
137
|
-
flex-grow: 1;
|
|
124
|
+
text-align: center;
|
|
138
125
|
color: var(--primary-color);
|
|
139
|
-
|
|
140
|
-
|
|
126
|
+
background-color: var(--primary-color-bg-1);
|
|
127
|
+
border-radius: var(--border-radius-sm);
|
|
128
|
+
min-width: 144px;
|
|
129
|
+
opacity: ${t=>t.visible?"0.95":"0"};
|
|
130
|
+
transition: opacity 200ms, background-color 200ms;
|
|
141
131
|
|
|
142
|
-
|
|
143
|
-
|
|
132
|
+
:hover {
|
|
133
|
+
background-color: var(--primary-color-bg-2);
|
|
144
134
|
}
|
|
145
135
|
}
|
|
146
|
-
|
|
147
|
-
:
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
`;import
|
|
136
|
+
`;import{useEffect as vi,useState as Xt}from"react";import{isMobile as Ps}from"react-device-detect";import xt from"styled-components";import di from"styled-components";var Te=di.div`
|
|
137
|
+
display: flex;
|
|
138
|
+
flex-direction: column;
|
|
139
|
+
align-items: flex-start;
|
|
140
|
+
justify-content: flex-end;
|
|
141
|
+
margin-top: auto;
|
|
142
|
+
gap: 16px;
|
|
143
|
+
flex-grow: 100;
|
|
144
|
+
`,pi=di.div`
|
|
145
|
+
display: flex;
|
|
146
|
+
flex-direction: column;
|
|
147
|
+
align-items: center;
|
|
148
|
+
justify-content: center;
|
|
149
|
+
height: 100%;
|
|
150
|
+
width: 100%;
|
|
151
|
+
`;import hi from"styled-components";import{jsx as ui}from"react/jsx-runtime";var Jt=({style:t,...e})=>ui("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:ui("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:e.color||"var(--primary-color)"})});import{Fragment as Es,jsx as Xe,jsxs as fi}from"react/jsx-runtime";var xs=hi.div`
|
|
162
152
|
margin-top: 16px;
|
|
163
153
|
font-size: 12px;
|
|
164
154
|
text-align: left;
|
|
@@ -167,7 +157,7 @@ Resources:
|
|
|
167
157
|
&& > a {
|
|
168
158
|
color: var(--primary-color);
|
|
169
159
|
}
|
|
170
|
-
`;function
|
|
160
|
+
`;function mi(t){let{privacyPolicyUrl:e,termsAndConditionsUrl:o}=t.app,r=!!e,i=!!o,n=r&&i;return!r&&!i?null:fi(xs,{children:["By logging in I agree to the"," ",i&&Xe("a",{href:o,target:"_blank",children:n?"Terms":"Terms of Service"}),n&&" & ",r&&Xe("a",{href:e,target:"_blank",children:"Privacy Policy"})]})}var $=({protectedByPrivy:t})=>Xe(se,{hideOnMobile:t,children:t?fi(Es,{children:[Xe(Jt,{}),Xe("span",{children:Xe("a",{href:"https://www.privy.io/",target:"_blank",children:"Protected by Privy"})})]}):null}),se=hi.div`
|
|
171
161
|
height: 20px;
|
|
172
162
|
font-size: 12px;
|
|
173
163
|
display: flex;
|
|
@@ -189,267 +179,252 @@ Resources:
|
|
|
189
179
|
@media (max-width: 440px) {
|
|
190
180
|
display: ${t=>t.hideOnMobile?"none":"inherit"};
|
|
191
181
|
}
|
|
192
|
-
`;import
|
|
182
|
+
`;import Yt from"styled-components";import{Fragment as _s,jsx as Qe,jsxs as wi}from"react/jsx-runtime";var Y=({title:t,description:e,children:o,...r})=>Qe(yi,{...r,children:wi(_s,{children:[Qe("h3",{children:t}),typeof e=="string"?Qe("p",{children:e}):e,o]})}),gi=Yt(Y)`
|
|
183
|
+
margin-bottom: 24px;
|
|
184
|
+
`,et=({title:t,description:e,icon:o,children:r,...i})=>wi(Ls,{...i,children:[o?Qe(As,{children:o}):null,Qe("h3",{children:t}),typeof e=="string"?Qe("p",{children:e}):null,r]}),yi=Yt.div`
|
|
193
185
|
display: flex;
|
|
194
186
|
flex-direction: column;
|
|
187
|
+
justify-content: flex-start;
|
|
195
188
|
align-items: flex-start;
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
gap: 16px;
|
|
199
|
-
flex-grow: 100;
|
|
200
|
-
`,yn=gn.div`
|
|
201
|
-
display: flex;
|
|
202
|
-
flex-direction: column;
|
|
203
|
-
align-items: center;
|
|
204
|
-
justify-content: center;
|
|
205
|
-
height: 100%;
|
|
206
|
-
width: 100%;
|
|
207
|
-
`;import At from"styled-components";import{jsx as wn}from"react/jsx-runtime";var eo=({style:t,logoFill:e,...o})=>wn("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:wn("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 Lt,jsxs as Ns}from"react/jsx-runtime";var to=({logoFill:t,style:e,...o})=>Ns("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:[Lt("g",{clipPath:"url(#clip0)",children:Lt("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"})}),Lt("defs",{children:Lt("clipPath",{id:"clip0",children:Lt("rect",{width:"71",height:"55",fill:"white"})})})]});import{jsx as vn}from"react/jsx-runtime";var oo=({logoFill:t,style:e,...o})=>vn("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"24",y:"24",viewBox:"0 0 98 96",style:{height:"24px",...e},...o,children:vn("path",{d:"M48.854 0C21.839 0 0 22 0 49.217c0 21.756 13.993 40.172 33.405 46.69 2.427.49 3.316-1.059 3.316-2.362 0-1.141-.08-5.052-.08-9.127-13.59 2.934-16.42-5.867-16.42-5.867-2.184-5.704-5.42-7.17-5.42-7.17-4.448-3.015.324-3.015.324-3.015 4.934.326 7.523 5.052 7.523 5.052 4.367 7.496 11.404 5.378 14.235 4.074.404-3.178 1.699-5.378 3.074-6.6-10.839-1.141-22.243-5.378-22.243-24.283 0-5.378 1.94-9.778 5.014-13.2-.485-1.222-2.184-6.275.486-13.038 0 0 4.125-1.304 13.426 5.052a46.97 46.97 0 0 1 12.214-1.63c4.125 0 8.33.571 12.213 1.63 9.302-6.356 13.427-5.052 13.427-5.052 2.67 6.763.97 11.816.485 13.038 3.155 3.422 5.015 7.822 5.015 13.2 0 18.905-11.404 23.06-22.324 24.283 1.78 1.548 3.316 4.481 3.316 9.126 0 6.6-.08 11.897-.08 13.526 0 1.304.89 2.853 3.316 2.364 19.412-6.52 33.405-24.935 33.405-46.691C97.707 22 75.788 0 48.854 0z",fill:t==="primary"?"#2D333B":"white"})});import{jsx as ro,jsxs as Os}from"react/jsx-runtime";var no=({style:t,...e})=>Os("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:[ro("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"}),ro("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"}),ro("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"}),ro("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 Te,jsxs as Vs}from"react/jsx-runtime";var Cn=({showGoogle:t,showTwitter:e,showDiscord:o,showGithub:r,stacked:n})=>{let{initLoginWithOAuth:i}=S();return Vs(Us,{stacked:n,children:[t&&Te(Bs,{onClick:()=>{i("google")},children:Te(no,{})}),e&&Te(Ds,{onClick:()=>{i("twitter")},children:Te(eo,{})}),o&&Te(Fs,{onClick:()=>{i("discord")},children:Te(to,{})}),r&&Te(Gs,{onClick:()=>{i("github")},children:Te(oo,{})})]})},Us=At.div`
|
|
208
|
-
display: flex;
|
|
209
|
-
flex-direction: ${t=>t.stacked?"column":"row"};
|
|
210
|
-
justify-content: space-between;
|
|
189
|
+
text-align: left;
|
|
190
|
+
gap: 8px;
|
|
211
191
|
width: 100%;
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
&& {
|
|
215
|
-
|
|
216
|
-
cursor: pointer;
|
|
217
|
-
height: 44px;
|
|
218
|
-
flex: 1;
|
|
219
|
-
background-color: #1da1f2;
|
|
220
|
-
display: flex;
|
|
221
|
-
flex-direction: column;
|
|
222
|
-
justify-content: center;
|
|
223
|
-
align-items: center;
|
|
224
|
-
}
|
|
225
|
-
`,Fs=At.button`
|
|
226
|
-
&& {
|
|
227
|
-
border-radius: var(--border-radius-sm);
|
|
228
|
-
cursor: pointer;
|
|
229
|
-
height: 44px;
|
|
230
|
-
flex: 1;
|
|
231
|
-
background-color: #5865f2;
|
|
232
|
-
display: flex;
|
|
233
|
-
flex-direction: column;
|
|
234
|
-
justify-content: center;
|
|
235
|
-
align-items: center;
|
|
192
|
+
margin-bottom: 24px;
|
|
193
|
+
|
|
194
|
+
&& h3 {
|
|
195
|
+
font-size: 17px;
|
|
236
196
|
}
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
flex: 1;
|
|
243
|
-
background-color: #2d333b;
|
|
244
|
-
display: flex;
|
|
245
|
-
flex-direction: column;
|
|
246
|
-
justify-content: center;
|
|
247
|
-
align-items: center;
|
|
197
|
+
|
|
198
|
+
/* Sugar assuming children are paragraphs. Otherwise, handling styling on your own */
|
|
199
|
+
&& p {
|
|
200
|
+
color: var(--light-theme-fg-2);
|
|
201
|
+
font-size: 14px;
|
|
248
202
|
}
|
|
249
|
-
`,
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
display: flex;
|
|
257
|
-
flex-direction: column;
|
|
258
|
-
justify-content: center;
|
|
259
|
-
align-items: center;
|
|
260
|
-
border: 1px solid var(--border-color-2);
|
|
203
|
+
`,Ls=Yt(yi)`
|
|
204
|
+
align-items: center;
|
|
205
|
+
text-align: center;
|
|
206
|
+
gap: 16px;
|
|
207
|
+
|
|
208
|
+
h3 {
|
|
209
|
+
margin-bottom: 24px;
|
|
261
210
|
}
|
|
262
|
-
|
|
211
|
+
`,As=Yt.div`
|
|
212
|
+
padding: 14px;
|
|
213
|
+
border-radius: 50%;
|
|
263
214
|
&& {
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
border-width: 4px;
|
|
267
|
-
border-style: solid;
|
|
268
|
-
border-color: ${t=>t.color??"var(--primary-color)"};
|
|
269
|
-
border-bottom-color: transparent;
|
|
270
|
-
border-radius: 50%;
|
|
271
|
-
display: inline-block;
|
|
272
|
-
box-sizing: border-box;
|
|
273
|
-
animation: rotation 1.2s linear infinite;
|
|
274
|
-
transition: border-color 800ms;
|
|
215
|
+
border-color: var(--light-theme-bg-3);
|
|
216
|
+
border-width: 1px;
|
|
275
217
|
}
|
|
218
|
+
`;import{Fragment as zo,jsx as X,jsxs as Ge}from"react/jsx-runtime";var $o=6,Ci=new Array($o).fill(""),Ss=1400;var bi=()=>{var P,ie,Ae;let{app:t,data:e,navigate:o,setModalData:r}=v(),{closePrivyModal:i,resendEmailCode:n,resendSmsCode:s,getAuthMeta:a,loginWithCode:p}=_(),{authenticated:u,user:x}=z(),[L,m]=Xt(Ci),[g,f]=Xt(!1),[c,S]=Xt(null),[M,k]=Xt(null),b=(P=a())!=null&&P.email?0:1;vi(()=>{var R;if(!(u&&g&&x))return;if(((R=e==null?void 0:e.login)==null?void 0:R.promptCreatePrivyWalletFlow)&&!x.wallet){let ce=setTimeout(()=>{r({createWallet:{onSuccess:()=>i({shouldCallAuthOnSuccess:!0}),onFailure:Oe=>console.error(Oe)}}),o("EMBEDDED_WALLET_SCREEN")},re-500);return()=>clearTimeout(ce)}else{let ce=setTimeout(i,re);return()=>clearTimeout(ce)}},[u,g,x]),vi(()=>{if(c&&M===0){let D=setTimeout(()=>{m(Ci),S(null);let F=document.querySelector("input[name=code-0]");F==null||F.focus()},Ss);return()=>clearTimeout(D)}},[c]);let W=D=>{var _o;let F=D.currentTarget.value.replace(" ","");if(F==="")return;if(isNaN(Number(F))){S("Code should be numeric"),k(1);return}S(null),k(null);let R=Number((_o=D.currentTarget.name)==null?void 0:_o.charAt(5)),ce=[...F||[""]].slice(0,$o-R),Oe=[...L.slice(0,R),...ce,...L.slice(R+ce.length)];m(Oe);let mt=ce.length,Ot=Math.min(Math.max(R+mt,0),$o-1);if(!isNaN(Number(D.currentTarget.value))){let H=document.querySelector(`input[name=code-${Ot}]`);H==null||H.focus()}if(Oe.every(H=>H&&!isNaN(+H))){let H=document.querySelector(`input[name=code-${Ot}]`);H==null||H.blur(),p(Oe.join("")).then(()=>f(!0)).catch(l=>{(l==null?void 0:l.status)===422?S("Invalid or expired verification code"):S("Issue verifying code"),k(0)})}D.preventDefault()},G=D=>{M===1&&(S(null),k(null));let F=[...L.slice(0,D),"",...L.slice(D+1)];if(m(F),D>0){let R=document.querySelector(`input[name=code-${D-1}]`);R==null||R.focus()}},K=`Verify your ${b==0?"email":"phone"}`,I=b==0?Ge("p",{children:["Please check ",X(Rs,{children:(ie=a())==null?void 0:ie.email})," for an email from privy.io and enter your code below."]}):`Please check ${(Ae=a())==null?void 0:Ae.phoneNumber} for a message from ${(t==null?void 0:t.name)||"privy.io"} and enter your code below.`;return Ge(zo,{children:[X(A,{},"header"),Ge(ks,{children:[X(Y,{title:K,description:I}),Ge(pi,{children:[Ge(Ts,{children:[X(Ws,{fail:!!c,success:g,children:X("span",{children:c||(g?"Success!":"")})}),X("div",{children:L.map((D,F)=>X("input",{name:`code-${F}`,type:"text",value:L[F],onChange:W,onKeyUp:R=>{R.key==="Backspace"&&G(F)},inputMode:"numeric",autoFocus:F===0,pattern:"[0-9]",className:`${g?"success":""} ${c?"fail":""}`,autoComplete:Ps?"one-time-code":"off"},F))})]}),X(Is,{children:b==0?Ge(zo,{children:[X("span",{children:"Didn't get an email?"}),X("button",{onClick:n,children:"Resend Code"})]}):Ge(zo,{children:[X("span",{children:"Didn't get a message?"}),X("button",{onClick:s,children:"Resend Code"})]})})]})]}),X($,{protectedByPrivy:!0})]})},ks=xt.div`
|
|
219
|
+
display: flex;
|
|
220
|
+
flex-direction: column;
|
|
221
|
+
align-items: flex-start;
|
|
222
|
+
justify-content: flex-end;
|
|
223
|
+
margin: auto;
|
|
224
|
+
gap: 16px;
|
|
225
|
+
`,Ts=xt.div`
|
|
226
|
+
display: flex;
|
|
227
|
+
flex-direction: column;
|
|
228
|
+
width: 100%;
|
|
229
|
+
gap: 8px;
|
|
230
|
+
// This may seem goofy, but it's actually cleaner than trying to globally
|
|
231
|
+
// center just this element.
|
|
232
|
+
margin-top: 70px;
|
|
276
233
|
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
}
|
|
281
|
-
100% {
|
|
282
|
-
transform: rotate(360deg);
|
|
283
|
-
}
|
|
234
|
+
${tt}[data-height='medium'] & {
|
|
235
|
+
/* Aligns this with the input field on the page before on shorter modals */
|
|
236
|
+
margin-top: 22px;
|
|
284
237
|
}
|
|
285
238
|
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
border-bottom-color: var(--success-light);
|
|
239
|
+
@media (max-width: 440px) {
|
|
240
|
+
margin-top: 20px;
|
|
289
241
|
}
|
|
290
242
|
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
&& {
|
|
297
|
-
border-bottom-color: ${t=>t.color??"var(--primary-color)"};
|
|
298
|
-
animation: none;
|
|
299
|
-
opacity: 0.5;
|
|
300
|
-
}
|
|
301
|
-
`,We=t=>$o(zs,{color:t.color||"var(--disabled-fg)"}),zs=jo(_t)`
|
|
302
|
-
&& {
|
|
303
|
-
height: 0.9rem;
|
|
304
|
-
width: 0.9rem;
|
|
305
|
-
border-width: 1.5px;
|
|
243
|
+
> div:last-child {
|
|
244
|
+
display: flex;
|
|
245
|
+
justify-content: space-between;
|
|
246
|
+
width: 100%;
|
|
247
|
+
border-radius: 6px;
|
|
306
248
|
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
249
|
+
> input {
|
|
250
|
+
border: 1px solid var(--border-color-1);
|
|
251
|
+
background: var(--light-theme-bg-1);
|
|
252
|
+
border-radius: 6px;
|
|
253
|
+
padding: 8px 10px;
|
|
254
|
+
height: 58px;
|
|
255
|
+
width: 46px;
|
|
256
|
+
text-align: center;
|
|
257
|
+
font-size: 18px;
|
|
258
|
+
}
|
|
313
259
|
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
flex-grow: 1;
|
|
260
|
+
> input:focus {
|
|
261
|
+
border: 1px solid var(--primary-color);
|
|
262
|
+
}
|
|
318
263
|
|
|
319
|
-
|
|
320
|
-
|
|
264
|
+
> input:invalid {
|
|
265
|
+
border: 1px solid var(--fail-dark);
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
> input.success {
|
|
269
|
+
border: 1px solid var(--success-dark);
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
> input.fail {
|
|
273
|
+
border: 1px solid var(--fail-dark);
|
|
274
|
+
animation: shake 180ms;
|
|
275
|
+
animation-iteration-count: 2;
|
|
276
|
+
}
|
|
321
277
|
}
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
278
|
+
|
|
279
|
+
@keyframes shake {
|
|
280
|
+
0% {
|
|
281
|
+
transform: translate(1px, 0px);
|
|
282
|
+
}
|
|
283
|
+
33% {
|
|
284
|
+
transform: translate(-1px, 0px);
|
|
285
|
+
}
|
|
286
|
+
67% {
|
|
287
|
+
transform: translate(-1px, 0px);
|
|
288
|
+
}
|
|
289
|
+
100% {
|
|
290
|
+
transform: translate(1px, 0px);
|
|
291
|
+
}
|
|
333
292
|
}
|
|
293
|
+
`,Ws=xt.div`
|
|
294
|
+
line-height: 20px;
|
|
295
|
+
height: 20px;
|
|
296
|
+
font-size: 13px;
|
|
297
|
+
color: ${t=>t.success?"var(--success-dark)":t.fail?"var(--fail-dark)":"var(--light-theme-fg-3)"};
|
|
298
|
+
display: flex;
|
|
299
|
+
justify-content: flex-end;
|
|
300
|
+
width: 100%;
|
|
301
|
+
`,Is=xt.div`
|
|
302
|
+
font-size: 13px;
|
|
303
|
+
color: var(--light-theme-fg-3);
|
|
304
|
+
display: flex;
|
|
305
|
+
justify-content: space-between;
|
|
306
|
+
width: 100%;
|
|
307
|
+
margin-top: 16px;
|
|
308
|
+
// Equal opposing size buffer to account for auto margining when the
|
|
309
|
+
// success/fail text does not show up
|
|
310
|
+
padding-bottom: 32px;
|
|
334
311
|
|
|
312
|
+
> button {
|
|
313
|
+
text-decoration: underline;
|
|
314
|
+
}
|
|
315
|
+
`,Rs=xt.span`
|
|
316
|
+
word-break: break-all;
|
|
317
|
+
`;import{useEffect as Ei,useState as Lt}from"react";import eo from"styled-components";import Zo from"styled-components";import{Fragment as Os,jsx as jo,jsxs as Us}from"react/jsx-runtime";var ot=({success:t,fail:e})=>Us(Os,{children:[jo(Et,{className:t?"success":e?"fail":""}),jo(Ms,{className:t?"success":e?"fail":""})]}),Et=Zo.span`
|
|
335
318
|
&& {
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
319
|
+
width: 82px;
|
|
320
|
+
height: 82px;
|
|
321
|
+
border-width: 4px;
|
|
322
|
+
border-style: solid;
|
|
323
|
+
border-color: ${t=>t.color??"var(--primary-color)"};
|
|
324
|
+
border-bottom-color: transparent;
|
|
325
|
+
border-radius: 50%;
|
|
326
|
+
display: inline-block;
|
|
327
|
+
box-sizing: border-box;
|
|
328
|
+
animation: rotation 1.2s linear infinite;
|
|
329
|
+
transition: border-color 800ms;
|
|
340
330
|
}
|
|
341
331
|
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
332
|
+
@keyframes rotation {
|
|
333
|
+
0% {
|
|
334
|
+
transform: rotate(0deg);
|
|
335
|
+
}
|
|
336
|
+
100% {
|
|
337
|
+
transform: rotate(360deg);
|
|
338
|
+
}
|
|
346
339
|
}
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
justify-content: center;
|
|
352
|
-
& {
|
|
353
|
-
height: 44px;
|
|
354
|
-
width: 100%;
|
|
355
|
-
cursor: pointer;
|
|
356
|
-
font-size: 14px;
|
|
357
|
-
font-weight: 600;
|
|
358
|
-
border-radius: var(--border-radius-sm);
|
|
340
|
+
|
|
341
|
+
&&&.success {
|
|
342
|
+
border-color: var(--success-light);
|
|
343
|
+
border-bottom-color: var(--success-light);
|
|
359
344
|
}
|
|
360
345
|
|
|
346
|
+
&&&.fail {
|
|
347
|
+
border-color: var(--fail-light);
|
|
348
|
+
border-bottom-color: var(--fail-light);
|
|
349
|
+
}
|
|
350
|
+
`,Ms=Zo(Et)`
|
|
361
351
|
&& {
|
|
362
|
-
|
|
363
|
-
|
|
352
|
+
border-bottom-color: ${t=>t.color??"var(--primary-color)"};
|
|
353
|
+
animation: none;
|
|
354
|
+
opacity: 0.5;
|
|
364
355
|
}
|
|
356
|
+
`,We=t=>jo(Ns,{color:t.color||"var(--disabled-fg)"}),Ns=Zo(Et)`
|
|
357
|
+
&& {
|
|
358
|
+
height: 0.9rem;
|
|
359
|
+
width: 0.9rem;
|
|
360
|
+
border-width: 1.5px;
|
|
365
361
|
|
|
366
|
-
|
|
367
|
-
background-color: var(--disabled-bg);
|
|
368
|
-
color: var(--disabled-fg);
|
|
369
|
-
cursor: not-allowed;
|
|
362
|
+
transition: border-color 350ms ease;
|
|
370
363
|
}
|
|
371
|
-
`,Ys=St.label`
|
|
364
|
+
`;import{jsx as xi,jsxs as Ds}from"react/jsx-runtime";var ue=({style:t,...e})=>Ds("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:[xi("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),xi("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 Q,jsxs as Fs}from"react/jsx-runtime";var he=({style:t,...e})=>Fs("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:[Q("rect",{width:"28",height:"28",rx:"6",fill:"white"}),Q("path",{d:"M23.0126 5L15.1958 10.7823L16.6533 7.37359L23.0126 5Z",fill:"#E17726",stroke:"#E17726",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),Q("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"}),Q("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"}),Q("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"}),Q("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"}),Q("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"}),Q("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"}),Q("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"}),Q("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"}),Q("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"}),Q("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"}),Q("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 rt,jsxs as Gs}from"react/jsx-runtime";var it=({style:t,...e})=>Gs("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:[rt("rect",{width:"28",height:"28",rx:"6",fill:"#141414"}),rt("g",{clipPath:"url(#clip0_1765_9946)",children:rt("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"})}),rt("defs",{children:rt("clipPath",{id:"clip0_1765_9946",children:rt("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]});import{Fragment as zs,jsx as xe,jsxs as Qt}from"react/jsx-runtime";var qo=2,Li={metamask:{name:"MetaMask",component:he},coinbase_wallet:{name:"Coinbase Wallet",component:ue},wallet_connect:{name:"WalletConnect",component:it}},Ai=()=>{var K;let[t,e]=Lt(!1),[o,r]=Lt("metamask"),[i,n]=Lt(void 0),{navigate:s,navigateBack:a}=v(),{getAuthMeta:p,closePrivyModal:u,loginWithWallet:x}=_(),{walletConnectors:L}=z(),[m,g]=Lt(0),{user:f}=z(),[c]=Lt((f==null?void 0:f.linkedAccounts.length)||0);Ei(()=>{var I;r(((I=p())==null?void 0:I.walletType)||"metamask"),n(void 0),x().then(()=>e(!0)).catch(P=>{P instanceof ne?console.error(P.cause):console.error(P);let ie=(P==null?void 0:P.status)===401&&(P==null?void 0:P.message)==="User is not allowed to login to this app.";(P==null?void 0:P.status)===422?n(Ye.ERROR_USER_EXISTS):ie?s("ALLOWLIST_REJECTION_SCREEN"):P instanceof Je&&!P.details.default?n(P.details):P instanceof Ke?n(Ye.ERROR_TIMED_OUT):n(Ye.ERROR_WALLET_CONNECTION)})},[m]),Ei(()=>{if(t){let I=setTimeout(u,re);return()=>clearTimeout(I)}},[f]);let S=Li[o].name,M=Li[o].component,k=t?`Successfully connected with ${S}`:i?i.message:`Waiting for ${S}`,b="";if(t){let I=(f==null?void 0:f.linkedAccounts.length)||0;c===I?b="Wallet was already linked.":b="You\u2019re good to go!"}else if(m>=qo&&i)b="Unable to connect wallet";else if(i)b=i.detail;else switch(b="Don\u2019t see your wallet modal? Check your other browser windows.",o){case"metamask":b="For the best experience, connect only one wallet at a time.";break;case"wallet_connect":b="Open your mobile wallet app to continue";break;case"coinbase_wallet":$t()||(Uo(f)?b="Continue with the Coinbase app. Not the right wallet? Reset your connection below.":b="Open the Coinbase app on your phone to continue.");break}let W=(K=L==null?void 0:L.walletConnectors)==null?void 0:K.find(I=>I.walletType==="coinbase_wallet"),G=o==="coinbase_wallet"&&(Uo(f)||i===Ye.ERROR_USER_EXISTS);return Qt(zs,{children:[xe(A,{backFn:a}),Qt(Bs,{children:[xe(Hs,{children:Qt("div",{children:[xe(ot,{success:t,fail:!!i}),xe(M,{style:{width:"38px",height:"38px"}})]})}),Qt(Vs,{children:[xe("h3",{children:k}),xe("p",{children:b})]}),G?xe(Ko,{onClick:()=>W&&(W==null?void 0:W.disconnect()),visible:!t,disabled:t,children:"Use a different wallet"}):i==Ye.ERROR_USER_EXISTS?xe(Ko,{onClick:a,visible:!0,children:"Use a different wallet"}):xe(Ko,{onClick:()=>{g(m+1),n(void 0)},visible:!t&&(i==null?void 0:i.retryable)&&m<qo,disabled:!t&&(!(i!=null&&i.retryable)||m>=qo),children:"Retry"})]})]})},Bs=eo.div`
|
|
372
365
|
display: flex;
|
|
373
|
-
flex-direction:
|
|
366
|
+
flex-direction: column;
|
|
367
|
+
align-items: center;
|
|
368
|
+
justify-content: center;
|
|
369
|
+
margin-left: 27px;
|
|
370
|
+
margin-right: 27px;
|
|
371
|
+
gap: 24px;
|
|
372
|
+
`,Vs=eo.div`
|
|
373
|
+
display: flex;
|
|
374
|
+
flex-direction: column;
|
|
375
|
+
gap: 8px;
|
|
376
|
+
/* Very specifically chosen to be the height if 2 lines h3 and 1 line p.
|
|
377
|
+
If we then switch to 1 line h3 and 2 lines p, we don't resize. */
|
|
378
|
+
min-height: 76px;
|
|
379
|
+
`,Hs=eo.div`
|
|
380
|
+
display: flex;
|
|
381
|
+
flex-direction: column;
|
|
382
|
+
justify-content: center;
|
|
374
383
|
align-items: center;
|
|
375
|
-
position: relative;
|
|
376
384
|
width: 100%;
|
|
377
|
-
height:
|
|
378
|
-
background: var(--light-theme-bg-1);
|
|
385
|
+
height: 82px;
|
|
379
386
|
|
|
380
|
-
>
|
|
381
|
-
|
|
382
|
-
margin-left: 8px;
|
|
383
|
-
height: 20px !important;
|
|
384
|
-
width: 20px !important;
|
|
385
|
-
color: var(--light-theme-fg-3);
|
|
387
|
+
> div {
|
|
388
|
+
position: relative;
|
|
386
389
|
}
|
|
387
390
|
|
|
388
|
-
|
|
391
|
+
> div > span {
|
|
389
392
|
position: absolute;
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
/* Mirror parent to handle embedded logo on left */
|
|
394
|
-
border-radius: ${t=>t.standalone?"var(--border-radius-sm)":"var(--border-radius-sm) 0px 0px var(--border-radius-sm)"};
|
|
395
|
-
height: 100%;
|
|
396
|
-
width: 100%;
|
|
397
|
-
border: 1px solid var(--border-color-1);
|
|
398
|
-
background: var(--light-theme-bg-1);
|
|
399
|
-
}
|
|
400
|
-
|
|
401
|
-
/* Mobile */
|
|
402
|
-
@media (max-width: 440px) {
|
|
403
|
-
&& > input {
|
|
404
|
-
font-size: 16px;
|
|
405
|
-
line-height: 24px;
|
|
406
|
-
}
|
|
393
|
+
left: -41px;
|
|
394
|
+
top: -41px;
|
|
407
395
|
}
|
|
408
|
-
`,Xs=St.div`
|
|
409
|
-
line-height: 20px;
|
|
410
|
-
height: 20px;
|
|
411
|
-
font-size: 13px;
|
|
412
|
-
color: ${t=>t.success?"var(--success-dark)":t.fail?"var(--fail-dark)":"var(--light-theme-fg-3)"};
|
|
413
|
-
display: flex;
|
|
414
|
-
justify-content: space-between;
|
|
415
|
-
width: 100%;
|
|
416
396
|
|
|
417
|
-
>
|
|
418
|
-
|
|
419
|
-
|
|
397
|
+
> div > svg {
|
|
398
|
+
position: absolute;
|
|
399
|
+
left: -19px;
|
|
400
|
+
top: -19px;
|
|
420
401
|
}
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
@media (max-width: 440px) {
|
|
433
|
-
margin-top: 20px;
|
|
402
|
+
`,Ko=eo.button`
|
|
403
|
+
&& {
|
|
404
|
+
padding: 12px 16px;
|
|
405
|
+
font-weight: 500;
|
|
406
|
+
text-align: center;
|
|
407
|
+
color: var(--primary-color);
|
|
408
|
+
background-color: var(--primary-color-bg-1);
|
|
409
|
+
border-radius: var(--border-radius-sm);
|
|
410
|
+
min-width: 144px;
|
|
411
|
+
opacity: ${t=>t.visible?"1":"0"};
|
|
412
|
+
transition: opacity 200ms;
|
|
434
413
|
}
|
|
435
|
-
|
|
414
|
+
`;import at from"styled-components";import Yo from"styled-components";import{jsx as Jo,jsxs as js}from"react/jsx-runtime";var _i=Yo.button`
|
|
436
415
|
display: flex;
|
|
437
416
|
flex-direction: row;
|
|
438
417
|
align-items: center;
|
|
439
418
|
justify-content: center;
|
|
440
419
|
& {
|
|
441
420
|
height: 44px;
|
|
421
|
+
width: 100%;
|
|
422
|
+
/* Off by one because of internal border in designs and otherwise looks off */
|
|
423
|
+
padding: 7px 11px;
|
|
442
424
|
cursor: pointer;
|
|
443
425
|
font-size: 14px;
|
|
444
426
|
font-weight: 600;
|
|
445
|
-
border-radius:
|
|
446
|
-
}
|
|
447
|
-
|
|
448
|
-
&& {
|
|
449
|
-
padding-left: 15px;
|
|
450
|
-
padding-right: 15px;
|
|
451
|
-
background-color: var(--primary-color);
|
|
452
|
-
color: var(--light-theme-bg-1);
|
|
427
|
+
border-radius: var(--border-radius-md);
|
|
453
428
|
}
|
|
454
429
|
|
|
455
430
|
&&:disabled {
|
|
@@ -457,205 +432,116 @@ Resources:
|
|
|
457
432
|
color: var(--disabled-fg);
|
|
458
433
|
cursor: not-allowed;
|
|
459
434
|
}
|
|
460
|
-
`,
|
|
461
|
-
display: flex;
|
|
462
|
-
flex-direction: column;
|
|
463
|
-
align-items: center;
|
|
464
|
-
justify-content: center;
|
|
465
|
-
& {
|
|
466
|
-
height: 44px;
|
|
467
|
-
width: 100%;
|
|
468
|
-
cursor: pointer;
|
|
469
|
-
font-size: 14px;
|
|
470
|
-
font-weight: 600;
|
|
471
|
-
border-radius: var(--border-radius-sm);
|
|
472
|
-
}
|
|
473
|
-
|
|
435
|
+
`,Ie=({children:t,loading:e,disabled:o,warn:r,...i})=>Jo($s,{disabled:o||e,warn:r,...i,children:e?js("span",{children:[Jo(We,{})," ",Jo("span",{children:"Loading..."})]}):t}),$s=Yo(_i)`
|
|
474
436
|
&& {
|
|
475
|
-
background-color: var(--primary-color);
|
|
437
|
+
background-color: ${t=>t.warn?"var(--fail-dark)":"var(--primary-color)"};
|
|
476
438
|
color: var(--light-theme-bg-1);
|
|
477
439
|
}
|
|
478
440
|
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
441
|
+
> span {
|
|
442
|
+
display: flex;
|
|
443
|
+
align-items: center;
|
|
444
|
+
gap: 8px;
|
|
445
|
+
}
|
|
446
|
+
`,Vp=Yo(_i)`
|
|
447
|
+
&& {
|
|
448
|
+
border: 1px solid var(--light-theme-bg-3);
|
|
449
|
+
color: var(--light-theme-fg-1);
|
|
483
450
|
}
|
|
484
|
-
|
|
451
|
+
`;import{useState as Zs}from"react";import qs from"styled-components";import{jsx as Pi}from"react/jsx-runtime";var nt=({style:t,color:e,...o})=>Pi("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:e||"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...o,children:Pi("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M4.5 12.75l6 6 9-13.5"})});import{jsx as Xo}from"react/jsx-runtime";var Si=({color:t,...e})=>Xo("svg",{version:"1.1",id:"Layer_1",xmlns:"http://www.w3.org/2000/svg",xmlnsXlink:"http://www.w3.org/1999/xlink",x:"0px",y:"0px",viewBox:"0 0 115.77 122.88",xmlSpace:"preserve",...e,children:Xo("g",{children:Xo("path",{fill:t||"currentColor",className:"st0",d:"M89.62,13.96v7.73h12.19h0.01v0.02c3.85,0.01,7.34,1.57,9.86,4.1c2.5,2.51,4.06,5.98,4.07,9.82h0.02v0.02 v73.27v0.01h-0.02c-0.01,3.84-1.57,7.33-4.1,9.86c-2.51,2.5-5.98,4.06-9.82,4.07v0.02h-0.02h-61.7H40.1v-0.02 c-3.84-0.01-7.34-1.57-9.86-4.1c-2.5-2.51-4.06-5.98-4.07-9.82h-0.02v-0.02V92.51H13.96h-0.01v-0.02c-3.84-0.01-7.34-1.57-9.86-4.1 c-2.5-2.51-4.06-5.98-4.07-9.82H0v-0.02V13.96v-0.01h0.02c0.01-3.85,1.58-7.34,4.1-9.86c2.51-2.5,5.98-4.06,9.82-4.07V0h0.02h61.7 h0.01v0.02c3.85,0.01,7.34,1.57,9.86,4.1c2.5,2.51,4.06,5.98,4.07,9.82h0.02V13.96L89.62,13.96z M79.04,21.69v-7.73v-0.02h0.02 c0-0.91-0.39-1.75-1.01-2.37c-0.61-0.61-1.46-1-2.37-1v0.02h-0.01h-61.7h-0.02v-0.02c-0.91,0-1.75,0.39-2.37,1.01 c-0.61,0.61-1,1.46-1,2.37h0.02v0.01v64.59v0.02h-0.02c0,0.91,0.39,1.75,1.01,2.37c0.61,0.61,1.46,1,2.37,1v-0.02h0.01h12.19V35.65 v-0.01h0.02c0.01-3.85,1.58-7.34,4.1-9.86c2.51-2.5,5.98-4.06,9.82-4.07v-0.02h0.02H79.04L79.04,21.69z M105.18,108.92V35.65v-0.02 h0.02c0-0.91-0.39-1.75-1.01-2.37c-0.61-0.61-1.46-1-2.37-1v0.02h-0.01h-61.7h-0.02v-0.02c-0.91,0-1.75,0.39-2.37,1.01 c-0.61,0.61-1,1.46-1,2.37h0.02v0.01v73.27v0.02h-0.02c0,0.91,0.39,1.75,1.01,2.37c0.61,0.61,1.46,1,2.37,1v-0.02h0.01h61.7h0.02 v0.02c0.91,0,1.75-0.39,2.37-1.01c0.61-0.61,1-1.46,1-2.37h-0.02V108.92L105.18,108.92z"})})});import{jsx as ki,jsxs as Js}from"react/jsx-runtime";var to=t=>{let[e,o]=Zs(!1);return Js(Ks,{onClick:()=>{o(!0),navigator.clipboard.writeText(t.text),setTimeout(()=>o(!1),1500)},justCopied:e,children:[e?ki(nt,{style:{height:"14px",width:"14px"},strokeWidth:"2"}):ki(Si,{style:{height:"14px",width:"14px"}}),e?"Copied":"Copy"," ",t.itemName?t.itemName:"to Clipboard"]})},Ks=qs.button`
|
|
485
452
|
display: flex;
|
|
486
|
-
flex-direction: row;
|
|
487
453
|
align-items: center;
|
|
488
|
-
|
|
489
|
-
width: 100%;
|
|
490
|
-
height: ${t=>t.standalone?"64px":"44px"};
|
|
491
|
-
background: var(--light-theme-bg-1);
|
|
454
|
+
gap: 6px;
|
|
492
455
|
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
}
|
|
456
|
+
&& {
|
|
457
|
+
margin: 8px 2px;
|
|
458
|
+
font-size: 14px;
|
|
459
|
+
color: ${t=>t.justCopied?"var(--light-theme-fg-1)":"var(--light-theme-fg-3)"};
|
|
460
|
+
font-weight: ${t=>t.justCopied?"medium":"normal"};
|
|
461
|
+
transition: color 350ms ease;
|
|
500
462
|
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
463
|
+
:focus,
|
|
464
|
+
:active {
|
|
465
|
+
background-color: transparent;
|
|
466
|
+
border: none;
|
|
467
|
+
outline: none;
|
|
468
|
+
box-shadow: none;
|
|
469
|
+
}
|
|
505
470
|
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
width: 100%;
|
|
510
|
-
border: 1px solid var(--border-color-1);
|
|
511
|
-
background: var(--light-theme-bg-1);
|
|
512
|
-
}
|
|
471
|
+
:hover {
|
|
472
|
+
color: ${t=>t.justCopied?"var(--light-theme-fg-1)":"var(--light-theme-fg-2)"};
|
|
473
|
+
}
|
|
513
474
|
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
475
|
+
:active {
|
|
476
|
+
color: var(--light-theme-fg-1);
|
|
477
|
+
font-weight: medium;
|
|
478
|
+
}
|
|
479
|
+
|
|
480
|
+
@media (max-width: 440px) {
|
|
481
|
+
margin: 12px 2px;
|
|
519
482
|
}
|
|
520
483
|
}
|
|
521
|
-
`,ia=Pt.div`
|
|
522
|
-
line-height: 20px;
|
|
523
|
-
height: 20px;
|
|
524
|
-
font-size: 13px;
|
|
525
|
-
color: ${t=>t.success?"var(--success-dark)":t.fail?"var(--fail-dark)":"var(--light-theme-fg-3)"};
|
|
526
|
-
display: flex;
|
|
527
|
-
justify-content: space-between;
|
|
528
|
-
width: 100%;
|
|
529
484
|
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
485
|
+
svg {
|
|
486
|
+
width: 14px;
|
|
487
|
+
height: 14px;
|
|
533
488
|
}
|
|
534
|
-
`;import{jsx as
|
|
535
|
-
font-weight: ${t=>t.active?600:500};
|
|
536
|
-
color: ${t=>t.active?"inherit":"var(--light-theme-fg-3)"};
|
|
537
|
-
display: flex;
|
|
538
|
-
justify-content: center;
|
|
539
|
-
align-items: center;
|
|
540
|
-
`,kn=ot.div`
|
|
489
|
+
`;import{jsx as h,jsxs as V}from"react/jsx-runtime";var Ti=()=>V("svg",{width:"332",height:"128",viewBox:"0 0 332 128",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[V("g",{clipPath:"url(#clip0_39_1593)",children:[h("g",{clipPath:"url(#clip1_39_1593)",children:V("g",{filter:"url(#filter0_b_39_1593)",children:[V("linearGradient",{id:"background-gradient",children:[h("stop",{offset:"0%",stopColor:"#fed8f4",children:h("animate",{attributeName:"stop-color",values:"#fed8f4; #ffe5d0; #fed8f4;",dur:"4.97s",repeatCount:"indefinite"})}),h("stop",{offset:"33%",stopColor:"#ffe5d0",children:h("animate",{attributeName:"stop-color",values:"#ffe5d0; #ffcdf3; #ffe5d0;",dur:"5.11s",repeatCount:"indefinite"})}),h("stop",{offset:"67%",stopColor:"#ffcdf3",children:h("animate",{attributeName:"stop-color",values:"#ffcdf3; #d0fcf5; #ffcdf3;",dur:"4.95s",repeatCount:"indefinite"})}),h("stop",{offset:"100%",stopColor:"#d0fcf5",children:h("animate",{attributeName:"stop-color",values:"#d0fcf5; #fed8f4; #d0fcf5;",dur:"5.03s",repeatCount:"indefinite"})})]}),h("rect",{width:301,height:112,transform:"translate(16 16)",fill:"url(#background-gradient)"})]})}),h("path",{d:"M183.83 53.8229L203.497 101.003C203.617 101.287 203.707 101.571 203.781 101.87C203.856 102.169 203.901 102.483 203.916 102.797C203.931 103.111 203.916 103.44 203.886 103.769C203.856 104.098 203.781 104.426 203.692 104.755C203.453 105.592 203.034 106.34 202.511 106.983C201.988 107.626 201.315 108.179 200.583 108.582C199.851 108.986 199.044 109.255 198.207 109.375C197.37 109.494 196.533 109.434 195.711 109.195C195.427 109.121 195.158 109.016 194.904 108.896C194.65 108.777 194.411 108.642 194.172 108.493C193.933 108.343 193.723 108.179 193.529 107.999C193.335 107.82 193.141 107.641 192.976 107.431L159.963 68.3985C160.187 68.6526 160.441 68.8918 160.725 69.1011C161.009 69.3104 161.353 69.4898 161.726 69.6542C162.1 69.8187 162.518 69.9383 162.967 70.028C163.415 70.1177 163.908 70.1775 164.446 70.2074C166.001 70.2821 167.719 70.028 169.483 69.5047C171.246 68.9815 173.099 68.1892 174.833 67.1726C176.567 66.1561 178.196 64.9751 179.6 63.6446C181.005 62.3141 182.141 60.9238 182.948 59.4737C183.262 58.9057 183.516 58.3525 183.71 57.8143C183.905 57.2762 184.024 56.7828 184.084 56.3045C184.144 55.8261 184.159 55.3776 184.114 54.959C184.069 54.5404 183.964 54.1518 183.815 53.793L183.83 53.8229Z",fill:"url(#paint0_linear_39_1593)"}),h("path",{d:"M161.158 60.2668C162.04 59.0559 163.116 57.9198 164.326 56.8733C165.537 55.8269 166.852 54.9 168.227 54.0927C169.602 53.2855 171.066 52.5978 172.531 52.0746C173.995 51.5514 175.505 51.1926 176.94 51.058C178.374 50.9235 179.689 51.0132 180.736 51.3122C181.782 51.6111 182.678 52.1643 183.261 52.8818C183.844 53.5994 184.173 54.5711 184.143 55.6624C184.113 56.7537 183.74 58.0992 182.947 59.5044C182.155 60.9097 180.99 62.3597 179.6 63.6753C178.21 64.9908 176.566 66.2017 174.832 67.2033C173.099 68.2049 171.275 68.9973 169.482 69.5354C167.689 70.0736 166 70.2978 164.446 70.238C162.891 70.1783 161.726 69.8045 160.844 69.2065C159.962 68.6086 159.424 67.8461 159.185 66.9043C158.946 65.9625 158.991 64.946 159.335 63.8098C159.678 62.6737 160.276 61.5076 161.173 60.2818L161.158 60.2668Z",fill:"url(#paint1_linear_39_1593)"}),h("path",{d:"M326.717 118.136L252.77 127.539L235.18 119.003L310.771 102.693L326.717 118.136Z",fill:"url(#paint2_linear_39_1593)"}),h("path",{d:"M310.771 102.694L235.18 119.003L242.069 98.9263L313.117 73.333L310.771 102.694Z",fill:"url(#paint3_linear_39_1593)"}),h("path",{d:"M327.241 91.1526L326.718 118.136L310.771 102.694L313.118 73.333L327.241 91.1526Z",fill:"url(#paint4_linear_39_1593)"}),h("path",{d:"M99.4197 23.8945L122.45 47.9331L64.1199 132.801L36.0684 110.093L99.4346 23.8945H99.4197Z",fill:"url(#paint5_linear_39_1593)"}),h("path",{d:"M36.0685 110.077L64.1201 132.785L27.789 117.612L6.0293 100.465L36.0834 110.062L36.0685 110.077Z",fill:"url(#paint6_linear_39_1593)"}),h("path",{d:"M55.7664 36.3772L99.4204 23.8945L36.0542 110.093L6 100.495L55.7515 36.3772H55.7664Z",fill:"url(#paint7_linear_39_1593)"}),h("path",{d:"M106.012 124.249C109.046 126.133 127.189 132.74 135.737 135.805C137.859 136.567 139.623 134.983 139.1 132.8C136.992 123.965 132.449 105.204 130.91 101.975C131.672 104.172 127.473 110.182 121.016 115.952C114.545 121.738 108.119 125.251 106.012 124.249V124.249Z",fill:"url(#paint8_linear_39_1593)"}),h("path",{d:"M105.638 123.981C105.638 123.981 105.698 124.041 105.743 124.071C105.788 124.101 105.833 124.146 105.877 124.175C105.922 124.205 105.967 124.235 106.027 124.265C108.134 125.267 114.56 121.769 121.032 115.968C127.488 110.183 131.687 104.188 130.925 101.991C130.91 101.931 130.88 101.871 130.85 101.841C130.82 101.796 130.791 101.736 130.761 101.692C130.731 101.647 130.716 101.617 130.686 101.587C129.117 99.8229 122.227 103.411 115.308 109.6C108.388 115.789 104.069 122.247 105.638 123.996V123.981Z",fill:"url(#paint9_linear_39_1593)"}),h("path",{d:"M290.057 16.9137C289.713 21.3537 287.89 25.5844 284.886 29.1573C277.817 37.6335 264.187 42.4323 248.167 37.7083C218.695 29.0227 200.313 19.799 183.963 17.138C179.779 16.4653 178.613 10.919 182.14 8.55705C200.238 -3.59678 237.466 -23.9578 268.013 -10.6529C284.527 -3.46224 290.789 7.22655 290.057 16.9137Z",fill:"url(#paint10_linear_39_1593)"})]}),V("defs",{children:[V("filter",{id:"filter0_b_39_1593",x:"-76",y:"-76",width:"485",height:"296",filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[h("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),h("feGaussianBlur",{in:"BackgroundImageFix",stdDeviation:"46"}),h("feComposite",{in2:"SourceAlpha",operator:"in",result:"effect1_backgroundBlur_39_1593"}),h("feBlend",{mode:"normal",in:"SourceGraphic",in2:"effect1_backgroundBlur_39_1593",result:"shape"})]}),V("linearGradient",{id:"paint0_linear_39_1593",x1:"187.753",y1:"56.8365",x2:"173.389",y2:"118.39",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#2D2068"}),h("stop",{offset:"1",stopColor:"#4F3D9A"})]}),V("linearGradient",{id:"paint1_linear_39_1593",x1:"162.8",y1:"69.9911",x2:"171.997",y2:"54.1167",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint2_linear_39_1593",x1:"248.905",y1:"127.208",x2:"254.292",y2:"100.947",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint3_linear_39_1593",x1:"246.866",y1:"118.395",x2:"265.49",y2:"76.3396",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint4_linear_39_1593",x1:"321.183",y1:"75.7837",x2:"300.239",y2:"117.543",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#2D2068"}),h("stop",{offset:"1",stopColor:"#4F3D9A"})]}),V("linearGradient",{id:"paint5_linear_39_1593",x1:"90.6771",y1:"29.8515",x2:"62.6626",y2:"150.379",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#2D2068"}),h("stop",{offset:"1",stopColor:"#4F3D9A"})]}),V("linearGradient",{id:"paint6_linear_39_1593",x1:"14.7397",y1:"132.355",x2:"27.4593",y2:"102.104",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint7_linear_39_1593",x1:"20.0079",y1:"108.945",x2:"64.5521",y2:"45.0635",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint8_linear_39_1593",x1:"126.988",y1:"103.836",x2:"119.744",y2:"142.156",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#2D2068"}),h("stop",{offset:"1",stopColor:"#4F3D9A"})]}),V("linearGradient",{id:"paint9_linear_39_1593",x1:"109.17",y1:"124.125",x2:"121.135",y2:"106.662",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint10_linear_39_1593",x1:"196.556",y1:"38.8404",x2:"216.303",y2:"-13.8631",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),h("clipPath",{id:"clip0_39_1593",children:h("rect",{width:"332",height:"128",fill:"white"})}),h("clipPath",{id:"clip1_39_1593",children:h("rect",{x:"16",y:"16",width:"301",height:"112",rx:"8",fill:"white"})})]})]});import{Fragment as ra,jsx as me,jsxs as st}from"react/jsx-runtime";var Wi=()=>{var x;let{user:t}=z(),{closePrivyModal:e}=_(),{data:o}=v(),r=ye(t),{onSuccess:i,onFailure:n}=o.createWallet,s=()=>{r?(i(r),e({shouldCallAuthOnSuccess:!1})):n(new Error("Failed to create wallet"))},a="Your digital wallet",p="You\u2019re all set! This wallet is all yours and can only ever be accessed by you.",u=De(r.address);return st(ra,{children:[me(A,{onClose:s}),st(Ys,{children:[st("div",{children:[me(Y,{title:a,description:p}),st(Xs,{children:[me(Ti,{}),st(Qs,{children:[me("p",{children:((x=t==null?void 0:t.email)==null?void 0:x.address)||""}),st(ea,{children:[me(ta,{children:u})," ",me(Jt,{color:"var(--light-theme-bg-1)"})]})]})]}),me(oa,{children:me(to,{text:r.address,itemName:"Address"})})]}),me(Ie,{onClick:s,children:"I\u2019m all set"})]}),me($,{protectedByPrivy:!0})]})},Ys=at.div`
|
|
541
490
|
display: flex;
|
|
491
|
+
height: 100%;
|
|
542
492
|
flex-direction: column;
|
|
543
|
-
|
|
544
|
-
/* 1px helps with the input ring getting hidden by padding, despite it being
|
|
545
|
-
* annoying that it's not perfectly lined up
|
|
546
|
-
*/
|
|
547
|
-
padding: ${t=>t.isOnlySection?"1px":"12px"};
|
|
548
|
-
gap: 12px;
|
|
549
|
-
width: 100%;
|
|
550
|
-
max-height: ${t=>t.active?"400px":"52px"};
|
|
551
|
-
|
|
552
|
-
transition-property: border-color, max-height;
|
|
553
|
-
transition-duration: 0.25s;
|
|
554
|
-
transition-timing-function: ease-in;
|
|
555
|
-
overflow: hidden;
|
|
556
|
-
|
|
557
|
-
&& {
|
|
558
|
-
background: var(--light-theme-bg-1);
|
|
493
|
+
justify-content: space-between;
|
|
559
494
|
|
|
560
|
-
|
|
561
|
-
|
|
495
|
+
@media (max-width: 440px) {
|
|
496
|
+
gap: 24px;
|
|
562
497
|
}
|
|
563
|
-
|
|
564
|
-
cursor: ${t=>t.active?"inherit":"pointer"};
|
|
565
|
-
`,pa=ot.div`
|
|
566
|
-
display: flex;
|
|
567
|
-
justify-content: center;
|
|
568
|
-
align-items: center;
|
|
498
|
+
`,Xs=at.div`
|
|
569
499
|
width: 100%;
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
500
|
+
background-color: #160b45;
|
|
501
|
+
border-radius: 8px;
|
|
502
|
+
margin-bottom: 8px;
|
|
503
|
+
svg {
|
|
504
|
+
width: 100%;
|
|
505
|
+
height: auto;
|
|
575
506
|
}
|
|
576
|
-
`,
|
|
577
|
-
display: flex;
|
|
578
|
-
flex-direction: column;
|
|
579
|
-
align-items: center;
|
|
580
|
-
|
|
581
|
-
// This is a temp hack until we use a real accordion and JS to calculate
|
|
582
|
-
// heights - real-life CSS height math is hard to do properly.
|
|
583
|
-
|
|
584
|
-
// - Logo is 80px tall
|
|
585
|
-
// - Top margin from cancel button is 24px and needs to be counteracted
|
|
586
|
-
// - Some don't have social/email/sms. That adds 46px+16px gap
|
|
587
|
-
// So...
|
|
588
|
-
// - Wallet + other => 114px padding for logo, -24px on the top
|
|
589
|
-
// - Only one section => Condensed, so just need a healthy amount of space
|
|
590
|
-
// - Terms => 36px
|
|
591
|
-
// Lastly, apply a 10px cheat upwards, which helps in particular for when
|
|
592
|
-
// the logo is close to the top (mobile or full wallet-open design)
|
|
593
|
-
margin-top: ${t=>`${28+(t.hasOnlyOneSection?31:0)-(t.hasTerms?18:0)}px`};
|
|
594
|
-
margin-bottom: ${t=>`${60+(t.hasOnlyOneSection?31:0)-(t.hasTerms?18:0)}px`};
|
|
595
|
-
`,ha=ot(ke)`
|
|
596
|
-
flex-direction: ${t=>t.reverse?"column-reverse":"column"};
|
|
597
|
-
`;import{useEffect as Rn,useState as po}from"react";import kt from"styled-components";import co from"styled-components";import{Fragment as ga,jsx as rt,jsxs as In}from"react/jsx-runtime";var X=({title:t,description:e,children:o,...r})=>rt(Wn,{...r,children:In(ga,{children:[rt("h3",{children:t}),typeof e=="string"?rt("p",{children:e}):e,o]})}),Tn=co(X)`
|
|
598
|
-
margin-bottom: 24px;
|
|
599
|
-
`,nt=({title:t,description:e,icon:o,children:r,...n})=>In(ma,{...n,children:[o?rt(fa,{children:o}):null,rt("h3",{children:t}),typeof e=="string"?rt("p",{children:e}):null,r]}),Wn=co.div`
|
|
507
|
+
`,Qs=at.div`
|
|
600
508
|
display: flex;
|
|
601
|
-
flex-direction: column;
|
|
602
|
-
justify-content: flex-start;
|
|
603
|
-
align-items: flex-start;
|
|
604
509
|
text-align: left;
|
|
605
|
-
|
|
510
|
+
flex-direction: column;
|
|
511
|
+
padding: 22px 16px 16px 16px;
|
|
606
512
|
width: 100%;
|
|
607
|
-
margin-bottom: 24px;
|
|
608
|
-
|
|
609
|
-
&& h3 {
|
|
610
|
-
font-size: 17px;
|
|
611
|
-
}
|
|
612
513
|
|
|
613
|
-
|
|
614
|
-
&& p {
|
|
615
|
-
color: var(--light-theme-fg-2);
|
|
514
|
+
> p {
|
|
616
515
|
font-size: 14px;
|
|
516
|
+
color: var(--light-theme-bg-1);
|
|
517
|
+
opacity: 0.65;
|
|
617
518
|
}
|
|
618
|
-
`,
|
|
619
|
-
align-items: center;
|
|
620
|
-
text-align: center;
|
|
621
|
-
gap: 16px;
|
|
622
|
-
|
|
623
|
-
h3 {
|
|
624
|
-
margin-bottom: 24px;
|
|
625
|
-
}
|
|
626
|
-
`,fa=co.div`
|
|
627
|
-
padding: 14px;
|
|
628
|
-
border-radius: 50%;
|
|
629
|
-
&& {
|
|
630
|
-
border-color: var(--light-theme-bg-3);
|
|
631
|
-
border-width: 1px;
|
|
632
|
-
}
|
|
633
|
-
`;import{isMobile as ya}from"react-device-detect";import{Fragment as Xo,jsx as Q,jsxs as He}from"react/jsx-runtime";var Qo=6,Mn=new Array(Qo).fill(""),wa=1400;var Nn=()=>{var D,P,ce;let{app:t,data:e,navigate:o,setModalData:r}=v(),{closePrivyModal:n,resendEmailCode:i,resendSmsCode:s,getAuthMeta:a,loginWithCode:p}=S(),{authenticated:u,user:b}=$(),[E,m]=po(Mn),[g,f]=po(!1),[c,k]=po(null),[I,T]=po(null),A=(D=a())!=null&&D.email?0:1;Rn(()=>{var R;if(!(u&&g&&b))return;if(((R=e==null?void 0:e.login)==null?void 0:R.promptCreatePrivyWalletFlow)&&!b.wallet){let de=setTimeout(()=>{r({createWallet:{onSuccess:()=>n({shouldCallAuthOnSuccess:!0}),onFailure:Ne=>console.error(Ne)}}),o("EMBEDDED_WALLET_SCREEN")},ne-500);return()=>clearTimeout(de)}else{let de=setTimeout(n,ne);return()=>clearTimeout(de)}},[u,g,b]),Rn(()=>{if(c&&I===0){let F=setTimeout(()=>{m(Mn),k(null);let G=document.querySelector("input[name=code-0]");G==null||G.focus()},wa);return()=>clearTimeout(F)}},[c]);let _=F=>{var _o;let G=F.currentTarget.value.replace(" ","");if(G==="")return;if(isNaN(Number(G))){k("Code should be numeric"),T(1);return}k(null),T(null);let R=Number((_o=F.currentTarget.name)==null?void 0:_o.charAt(5)),de=[...G||[""]].slice(0,Qo-R),Ne=[...E.slice(0,R),...de,...E.slice(R+de.length)];m(Ne);let mt=de.length,Ot=Math.min(Math.max(R+mt,0),Qo-1);if(!isNaN(Number(F.currentTarget.value))){let z=document.querySelector(`input[name=code-${Ot}]`);z==null||z.focus()}if(Ne.every(z=>z&&!isNaN(+z))){let z=document.querySelector(`input[name=code-${Ot}]`);z==null||z.blur(),p(Ne.join("")).then(()=>f(!0)).catch(l=>{(l==null?void 0:l.status)===422?k("Invalid or expired verification code"):k("Issue verifying code"),T(0)})}F.preventDefault()},M=F=>{I===1&&(k(null),T(null));let G=[...E.slice(0,F),"",...E.slice(F+1)];if(m(G),F>0){let R=document.querySelector(`input[name=code-${F-1}]`);R==null||R.focus()}},oe=`Verify your ${A==0?"email":"phone"}`,H=A==0?He("p",{children:["Please check ",Q(Ea,{children:(P=a())==null?void 0:P.email})," for an email from privy.io and enter your code below."]}):`Please check ${(ce=a())==null?void 0:ce.phoneNumber} for a message from ${(t==null?void 0:t.name)||"privy.io"} and enter your code below.`;return He(Xo,{children:[Q(L,{},"header"),He(va,{children:[Q(X,{title:oe,description:H}),He(yn,{children:[He(Ca,{children:[Q(ba,{fail:!!c,success:g,children:Q("span",{children:c||(g?"Success!":"")})}),Q("div",{children:E.map((F,G)=>Q("input",{name:`code-${G}`,type:"text",value:E[G],onChange:_,onKeyUp:R=>{R.key==="Backspace"&&M(G)},inputMode:"numeric",autoFocus:G===0,pattern:"[0-9]",className:`${g?"success":""} ${c?"fail":""}`,autoComplete:ya?"one-time-code":"off"},G))})]}),Q(xa,{children:A==0?He(Xo,{children:[Q("span",{children:"Didn't get an email?"}),Q("button",{onClick:i,children:"Resend Code"})]}):He(Xo,{children:[Q("span",{children:"Didn't get a message?"}),Q("button",{onClick:s,children:"Resend Code"})]})})]})]}),Q(j,{protectedByPrivy:!0})]})},va=kt.div`
|
|
519
|
+
`,ea=at.div`
|
|
634
520
|
display: flex;
|
|
635
|
-
|
|
636
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
`,
|
|
521
|
+
justify-content: space-between;
|
|
522
|
+
width: 100%;
|
|
523
|
+
`,ta=at.span`
|
|
524
|
+
font-size: 17px;
|
|
525
|
+
color: #fff;
|
|
526
|
+
`,oa=at.div`
|
|
527
|
+
display: flex;
|
|
528
|
+
justify-content: center;
|
|
529
|
+
`;import{useEffect as ya,useState as or}from"react";import Oi from"styled-components";import{useEffect as ia,useState as At}from"react";import tr from"styled-components";import{jsx as Ii}from"react/jsx-runtime";var Ri=({style:t,...e})=>Ii("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:Ii("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M16.023 9.348h4.992v-.001M2.985 19.644v-4.992m0 0h4.992m-4.993 0l3.181 3.183a8.25 8.25 0 0013.803-3.7M4.031 9.865a8.25 8.25 0 0113.803-3.7l3.181 3.182m0-4.991v4.99"})});import{Fragment as ga,jsx as lt,jsxs as er}from"react/jsx-runtime";var ct=6,na=new Array(ct).fill("");function sa(t){return t.replace(/\s+/g,"")}function Qo(t){return/^[a-zA-Z0-9]{1}$/.test(t)}function aa(t){return/^[a-zA-Z]{1}$/.test(t)}function la(t){return/^[a-z]{1}$/.test(t)}function Mi(t){return t.length===ct&&t.every(Qo)}function ca(t,e){return t.reduce((o,r)=>o+Number(e(r)),0)}function da(){return crypto.getRandomValues(new Uint8Array(1))[0]}function pa(){let t="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789",e=[];for(;e.length<ct;){let o=da();o>247||e.push(t.charAt(o%62))}return e.join("")}var Ni=({onChange:t,disabled:e,readOnly:o,errorReasonOverride:r})=>{let[i,n]=At(na),[s,a]=At(null),[p,u]=At(null),x=m=>{var ie;let g=sa(m.currentTarget.value);if(g==="")return;let f=ca(i,Qo),c=g.split(""),S=!c.every(Qo),M=c.length+f>ct;if(S){a("PIN can only be letters and numbers"),u(1);return}if(M){a("PIN must be exactly 6 letters and numbers"),u(1);return}a(null),u(null);let k=Number((ie=m.currentTarget.name)==null?void 0:ie.charAt(4)),b=[...g||[""]].slice(0,ct-k),W=[...i.slice(0,k),...b,...i.slice(k+b.length)];n(W);let G=b.length,K=Math.min(Math.max(k+G,0),ct-1),I=document.querySelector(`input[name=pin-${K}]`),P=b[b.length-1]||"";if(aa(P)&&(la(P)?I.autocapitalize="none":I.autocapitalize="on"),I==null||I.focus(),Mi(W)){let Ae=document.querySelector(`input[name=pin-${K}]`);Ae==null||Ae.blur(),t(W.join(""))}else t(null);m.preventDefault()},L=m=>{p===1&&(a(null),u(null));let g=[...i.slice(0,m),"",...i.slice(m+1)];if(n(g),m>0){let f=document.querySelector(`input[name=pin-${m-1}]`);f==null||f.focus()}Mi(g)?t(g.join("")):t(null)};return er(ga,{children:[er(ua,{children:[lt(ha,{fail:!!r||!!s,children:r||s||"PIN can be letters and numbers"}),lt("div",{children:i.map((m,g)=>lt("input",{name:`pin-${g}`,type:"text",value:i[g],onChange:x,onKeyUp:f=>{f.key==="Backspace"&&L(g)},inputMode:"text",autoFocus:g===0,pattern:"[a-zA-Z0-9]",className:s?"fail":"",autoComplete:"off",disabled:e||o,autoCapitalize:"none"},g))})]}),!o&<(ma,{disabled:e,onClick:()=>{let m=pa();n([...m]),t(m)}})]})},ua=tr.div`
|
|
641
530
|
display: flex;
|
|
642
531
|
flex-direction: column;
|
|
643
532
|
width: 100%;
|
|
644
533
|
gap: 8px;
|
|
645
|
-
// This may seem goofy, but it's actually cleaner than trying to globally
|
|
646
|
-
// center just this element.
|
|
647
|
-
margin-top: 70px;
|
|
648
534
|
|
|
649
|
-
${
|
|
650
|
-
/* Aligns this with the input field on the page before on shorter modals */
|
|
535
|
+
${tt}[data-height='medium'] & {
|
|
651
536
|
margin-top: 22px;
|
|
652
537
|
}
|
|
653
538
|
|
|
654
539
|
@media (max-width: 440px) {
|
|
655
|
-
margin-top:
|
|
540
|
+
margin-top: 8px;
|
|
541
|
+
margin-bottom: 8px;
|
|
656
542
|
}
|
|
657
543
|
|
|
658
|
-
> div:
|
|
544
|
+
> div:nth-child(2) {
|
|
659
545
|
display: flex;
|
|
660
546
|
justify-content: space-between;
|
|
661
547
|
width: 100%;
|
|
@@ -672,6 +558,12 @@ Resources:
|
|
|
672
558
|
font-size: 18px;
|
|
673
559
|
}
|
|
674
560
|
|
|
561
|
+
> input:disabled {
|
|
562
|
+
/* Use --light-theme-bg-2 instead of disabled-bg for consistency with
|
|
563
|
+
the callout bubble */
|
|
564
|
+
background: var(--light-theme-bg-2);
|
|
565
|
+
}
|
|
566
|
+
|
|
675
567
|
> input:focus {
|
|
676
568
|
border: 1px solid var(--primary-color);
|
|
677
569
|
}
|
|
@@ -680,10 +572,6 @@ Resources:
|
|
|
680
572
|
border: 1px solid var(--fail-dark);
|
|
681
573
|
}
|
|
682
574
|
|
|
683
|
-
> input.success {
|
|
684
|
-
border: 1px solid var(--success-dark);
|
|
685
|
-
}
|
|
686
|
-
|
|
687
575
|
> input.fail {
|
|
688
576
|
border: 1px solid var(--fail-dark);
|
|
689
577
|
animation: shake 180ms;
|
|
@@ -705,98 +593,112 @@ Resources:
|
|
|
705
593
|
transform: translate(1px, 0px);
|
|
706
594
|
}
|
|
707
595
|
}
|
|
708
|
-
`,
|
|
596
|
+
`,ha=tr.div`
|
|
709
597
|
line-height: 20px;
|
|
710
598
|
height: 20px;
|
|
711
599
|
font-size: 13px;
|
|
712
|
-
color: ${t=>t.
|
|
600
|
+
color: ${t=>t.fail?"var(--fail-dark)":"var(--light-theme-fg-3)"};
|
|
713
601
|
display: flex;
|
|
714
602
|
justify-content: flex-end;
|
|
715
603
|
width: 100%;
|
|
716
|
-
`,
|
|
717
|
-
font-size: 13px;
|
|
718
|
-
color: var(--light-theme-fg-3);
|
|
604
|
+
`,ma=({onClick:t,disabled:e,...o})=>{let[r,i]=At(!1),[n,s]=At();return ia(()=>{e&&n&&clearTimeout(n),s(void 0)},[e]),er(fa,{onClick:a=>{n&&clearTimeout(n),i(!0),t==null||t(a),s(setTimeout(()=>i(!1),1e3))},justGenerated:r,disabled:e,...o,children:[r?lt(nt,{style:{height:"14px",width:"14px"},strokeWidth:"2"}):lt(Ri,{style:{height:"14px",width:"14px"}}),r?"Generated":"Generate"," PIN"]})},fa=tr.button`
|
|
719
605
|
display: flex;
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
margin-top: 16px;
|
|
723
|
-
// Equal opposing size buffer to account for auto margining when the
|
|
724
|
-
// success/fail text does not show up
|
|
725
|
-
padding-bottom: 32px;
|
|
606
|
+
align-items: center;
|
|
607
|
+
gap: 6px;
|
|
726
608
|
|
|
727
|
-
> button {
|
|
728
|
-
text-decoration: underline;
|
|
729
|
-
}
|
|
730
|
-
`,Ea=kt.span`
|
|
731
|
-
word-break: break-all;
|
|
732
|
-
`;import ho from"styled-components";import La from"styled-components";var On=La.span`
|
|
733
609
|
&& {
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
border-bottom-color: transparent;
|
|
740
|
-
border-radius: 50%;
|
|
741
|
-
display: inline-block;
|
|
742
|
-
box-sizing: border-box;
|
|
743
|
-
animation: rotation 1.2s linear infinite;
|
|
744
|
-
transition: border-color 800ms;
|
|
745
|
-
border-color: var(--primary-color);
|
|
746
|
-
border-bottom-color: var(--primary-color);
|
|
747
|
-
}
|
|
748
|
-
`;import{jsx as Un}from"react/jsx-runtime";var Dn=({style:t,...e})=>Un("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:Un("path",{fillRule:"evenodd",d:"M12 1.5a5.25 5.25 0 00-5.25 5.25v3a3 3 0 00-3 3v6.75a3 3 0 003 3h10.5a3 3 0 003-3v-6.75a3 3 0 00-3-3v-3c0-2.9-2.35-5.25-5.25-5.25zm3.75 8.25v-3a3.75 3.75 0 10-7.5 0v3h7.5z",clipRule:"evenodd"})});import{Fragment as er,jsx as me,jsxs as uo}from"react/jsx-runtime";var Gn=()=>{let{navigate:t,app:e}=v(),o=(e==null?void 0:e.allowlistConfig.errorTitle)||"You don't have access to this app",r=(e==null?void 0:e.allowlistConfig.errorDetail)||"Have you been invited?",n=(e==null?void 0:e.allowlistConfig.errorCtaText)||"Try another account";return uo(er,{children:[me(L,{}),uo(Aa,{children:[me(Sa,{children:uo("div",{children:[me(On,{}),me(Dn,{style:{width:"38px",height:"38px",strokeWidth:"1",stroke:"var(--primary-color)",fill:"var(--primary-color)"}})]})}),uo(_a,{children:[typeof o=="string"?me("h3",{children:o}):me(er,{children:o}),typeof r=="string"?me("p",{children:r}):me(er,{children:r})]}),e!=null&&e.allowlistConfig.errorCtaLink?me(Fn,{as:"a",href:e.allowlistConfig.errorCtaLink,visible:!0,children:n}):me(Fn,{onClick:()=>{t("LANDING")},visible:!0,children:n})]})]})},Aa=ho.div`
|
|
749
|
-
display: flex;
|
|
750
|
-
flex-direction: column;
|
|
751
|
-
align-items: center;
|
|
752
|
-
justify-content: center;
|
|
753
|
-
margin-left: 27px;
|
|
754
|
-
margin-right: 27px;
|
|
755
|
-
gap: 24px;
|
|
756
|
-
`,_a=ho.div`
|
|
757
|
-
display: flex;
|
|
758
|
-
flex-direction: column;
|
|
759
|
-
gap: 8px;
|
|
760
|
-
`,Sa=ho.div`
|
|
761
|
-
display: flex;
|
|
762
|
-
flex-direction: column;
|
|
763
|
-
justify-content: center;
|
|
764
|
-
align-items: center;
|
|
765
|
-
width: 100%;
|
|
766
|
-
height: 82px;
|
|
610
|
+
margin: 8px 2px;
|
|
611
|
+
font-size: 14px;
|
|
612
|
+
color: ${t=>t.justGenerated?"var(--light-theme-fg-1)":"var(--light-theme-fg-3)"};
|
|
613
|
+
font-weight: ${t=>t.justGenerated?"medium":"normal"};
|
|
614
|
+
transition: color 350ms ease;
|
|
767
615
|
|
|
768
|
-
|
|
769
|
-
|
|
616
|
+
:focus,
|
|
617
|
+
:active {
|
|
618
|
+
background-color: transparent;
|
|
619
|
+
border: none;
|
|
620
|
+
outline: none;
|
|
621
|
+
box-shadow: none;
|
|
622
|
+
}
|
|
623
|
+
|
|
624
|
+
:hover {
|
|
625
|
+
color: ${t=>t.justGenerated?"var(--light-theme-fg-1)":"var(--light-theme-fg-2)"};
|
|
626
|
+
}
|
|
627
|
+
|
|
628
|
+
:active {
|
|
629
|
+
color: var(--light-theme-fg-1);
|
|
630
|
+
font-weight: medium;
|
|
631
|
+
}
|
|
632
|
+
|
|
633
|
+
@media (max-width: 440px) {
|
|
634
|
+
margin: 12px 2px;
|
|
635
|
+
}
|
|
770
636
|
}
|
|
771
637
|
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
top: -41px;
|
|
638
|
+
svg {
|
|
639
|
+
width: 14px;
|
|
640
|
+
height: 14px;
|
|
776
641
|
}
|
|
642
|
+
`;import{Fragment as Ca,jsx as Ee,jsxs as oo}from"react/jsx-runtime";var Ui=()=>{let{authenticated:t,getAccessToken:e,user:o}=z(),{walletProxy:r,refreshUser:i,closePrivyModal:n}=_(),{navigate:s,data:a}=v(),[p,u]=or(null),[x,L]=or(""),[m,g]=or(!1),{onFailure:f}=a.createWallet;ya(()=>{t||(s("LANDING"),f(new Error("User must be authenticated before creating a Privy wallet")))},[t]);let c=()=>{f(new Error("User exited before creating a wallet")),n({shouldCallAuthOnSuccess:!1})},S=W=>{u(W)},M=ye(o),k=M?()=>{g(!0),setTimeout(()=>{g(!1),s("EMBEDDED_WALLET_CREATED_SCREEN")},350)}:async()=>{g(!0);let W=await e();if(W&&p!==null)try{await(r==null?void 0:r.create({accessToken:W,recoveryPin:p})),L(""),await i()}catch(G){L("An error has occurred, please try again."),console.error(G)}finally{g(!1)}},b=!!M;return oo(Ca,{children:[Ee(A,{onClose:c}),oo(wa,{children:[oo("div",{children:[Ee(Y,{title:b?"Secure your PIN":"Set your PIN",description:b?"Don\u2019t lose this PIN. You\u2019ll need it to access your wallet across devices.":"To finish setting up your account, please set up a PIN."}),Ee(Ni,{onChange:S,disabled:m,readOnly:b,errorReasonOverride:x}),b?Ee(to,{text:p||""}):null]}),oo(va,{children:[Ee("h4",{children:"Why am I doing this?"}),b?Ee("p",{children:"This PIN allows you to access your wallet across devices. If you lose it, there is no way to recover your wallet."}):Ee("p",{children:"A digital wallet is being created on this device for your account. This PIN allows you to access it across devices."})]}),Ee(Ie,{loading:m||!r,disabled:!p,onClick:k,warn:b,children:b?"I have saved my PIN":"Create your wallet"})]}),Ee($,{protectedByPrivy:!0})]})},wa=Oi.div`
|
|
643
|
+
display: flex;
|
|
644
|
+
height: 100%;
|
|
645
|
+
flex-direction: column;
|
|
646
|
+
justify-content: space-between;
|
|
647
|
+
`,va=Oi.div`
|
|
648
|
+
display: flex;
|
|
649
|
+
flex-direction: column;
|
|
650
|
+
justify-content: flex-start;
|
|
651
|
+
align-items: flex-start;
|
|
652
|
+
text-align: left;
|
|
653
|
+
gap: 8px;
|
|
654
|
+
padding: 16px;
|
|
655
|
+
margin-top: 16px;
|
|
656
|
+
margin-bottom: 16px;
|
|
657
|
+
width: 100%;
|
|
658
|
+
background: var(--light-theme-bg-2);
|
|
659
|
+
border-radius: var(--border-radius-md);
|
|
777
660
|
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
661
|
+
&& h4 {
|
|
662
|
+
color: var(--light-theme-fg-3);
|
|
663
|
+
font-size: 14px;
|
|
664
|
+
text-decoration: underline;
|
|
665
|
+
font-weight: medium;
|
|
666
|
+
}
|
|
667
|
+
|
|
668
|
+
&& p {
|
|
669
|
+
color: var(--light-theme-fg-3);
|
|
670
|
+
font-size: 14px;
|
|
782
671
|
}
|
|
783
|
-
|
|
672
|
+
`;import{useState as Ma}from"react";import*as Re from"react-device-detect";import ae from"styled-components";import rr from"styled-components";import{jsx as Di}from"react/jsx-runtime";var Fi=({style:t,...e})=>Di("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:Di("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 xa,jsxs as Ea}from"react/jsx-runtime";var ir=rr.div`
|
|
673
|
+
display: flex;
|
|
674
|
+
flex-direction: column;
|
|
675
|
+
justify-content: flex-start;
|
|
676
|
+
gap: 4px;
|
|
677
|
+
`,_t=rr.div`
|
|
678
|
+
&&& {
|
|
679
|
+
margin-left: 7px; /* TODO: This is a total hack */
|
|
680
|
+
border-left: 2px solid var(--border-color-2);
|
|
681
|
+
height: 12px;
|
|
682
|
+
}
|
|
683
|
+
`,Be=({children:t})=>Ea(ba,{children:[xa(Fi,{style:{width:"16px",height:"16px"}}),t]}),ba=rr.div`
|
|
684
|
+
display: flex;
|
|
685
|
+
justify-content: flex-start;
|
|
686
|
+
justify-items: center;
|
|
687
|
+
text-align: left;
|
|
688
|
+
gap: 8px;
|
|
689
|
+
|
|
784
690
|
&& {
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
|
|
789
|
-
background-color: var(--primary-color-bg-1);
|
|
790
|
-
border-radius: var(--border-radius-sm);
|
|
791
|
-
min-width: 144px;
|
|
792
|
-
opacity: ${t=>t.visible?"0.95":"0"};
|
|
793
|
-
transition: opacity 200ms, background-color 200ms;
|
|
691
|
+
a {
|
|
692
|
+
text-decoration: underline;
|
|
693
|
+
color: var(--primary-color);
|
|
694
|
+
}
|
|
794
695
|
|
|
795
|
-
|
|
796
|
-
|
|
696
|
+
svg {
|
|
697
|
+
margin-top: auto;
|
|
698
|
+
margin-bottom: auto;
|
|
797
699
|
}
|
|
798
700
|
}
|
|
799
|
-
`;import
|
|
701
|
+
`;import La from"qrcode";import Aa from"styled-components";import{Fragment as dt,jsx as q,jsxs as Vi}from"react/jsx-runtime";var ee=7,nr=(t,e,o,r,i)=>{for(let n=e;n<e+r;n++)for(let s=o;s<o+i;s++){let a=t==null?void 0:t[s];a&&a[n]&&(a[n]=0)}return t},_a=t=>{let e=La.create(t,{errorCorrectionLevel:"high"}).modules,o=zr(Array.from(e.data),e.size);return o=nr(o,0,0,ee,ee),o=nr(o,o.length-ee,0,ee,ee),o=nr(o,0,o.length-ee,ee,ee),o},Pa=({x:t,y:e,cellSize:o,bgColor:r,fgColor:i})=>q(dt,{children:[0,1,2].map(n=>q("circle",{r:o*(ee-n*2)/2,cx:t+o*ee/2,cy:e+o*ee/2,fill:n%2!==0?r:i},`finder-${t}-${e}-${n}`))}),Sa=({cellSize:t,matrixSize:e,bgColor:o,fgColor:r})=>{let i=[[0,0],[(e-ee)*t,0],[0,(e-ee)*t]];return q(dt,{children:i.map(([n,s])=>q(Pa,{x:n,y:s,cellSize:t,bgColor:o,fgColor:r}))})},ka=({matrix:t,cellSize:e,color:o})=>q(dt,{children:t.map((r,i)=>r.map((n,s)=>n?q("circle",{r:e/2.5,cx:i*e+e/2,cy:s*e+e/2,fill:o},`circle-${i}-${s}`):q(dt,{})))}),Gi=(t,e)=>t-t%e,Ta=({outputSize:t,cellSize:e,element:o,size:r,padding:i,bgColor:n})=>{if(!o)return q(dt,{});let s=r||40,a=i||4,p=o,u=t/2-s/2-a;return Vi(dt,{children:[q("rect",{x:Gi(u,e),y:Gi(u,e),width:s+a*2+(u%e?e+.5:.5),height:s+a*2+(u%e?e+.5:.5),fill:n}),q(p,{x:t/2-s/2,y:t/2-s/2,height:s,width:s})]})},Wa=t=>{var i;let e=t.outputSize,o=_a(t.url),r=e/o.length;return Vi("svg",{height:t.outputSize,width:t.outputSize,viewBox:`0 0 ${t.outputSize} ${t.outputSize}`,style:{height:"100%",width:"100%"},children:[q(ka,{matrix:o,cellSize:r,color:t.fgColor}),q(Sa,{cellSize:r,matrixSize:o.length,fgColor:t.fgColor,bgColor:t.bgColor}),q(Ta,{outputSize:t.outputSize,cellSize:r,element:(i=t.logo)==null?void 0:i.element,bgColor:t.bgColor})]})},Ia=Aa.div`
|
|
800
702
|
display: flex;
|
|
801
703
|
justify-content: center;
|
|
802
704
|
align-items: center;
|
|
@@ -811,198 +713,567 @@ Resources:
|
|
|
811
713
|
border-color: ${t=>t.fgColor};
|
|
812
714
|
border-radius: 12px;
|
|
813
715
|
}
|
|
814
|
-
`,Vn=t=>{let e=t.bgColor||"#FFFFFF",o=t.fgColor||"#000000",r=t.size||160;return K(Oa,{size:r,bgColor:e,fgColor:o,children:K(Na,{url:t.url,logo:{element:t.squareLogoElement},outputSize:r,bgColor:e,fgColor:o})})};import{jsx as Ua}from"react/jsx-runtime";var zn=({size:t})=>Ua(Vn,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:he,size:t,fgColor:"#1F1F1F"});import or from"styled-components";import{jsx as $n}from"react/jsx-runtime";var jn=({style:t,...e})=>$n("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:$n("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 Fa,jsxs as Ga}from"react/jsx-runtime";var rr=or.div`
|
|
716
|
+
`,Bi=t=>{let e=t.bgColor||"#FFFFFF",o=t.fgColor||"#000000",r=t.size||160;return q(Ia,{size:r,bgColor:e,fgColor:o,children:q(Wa,{url:t.url,logo:{element:t.squareLogoElement},outputSize:r,bgColor:e,fgColor:o})})};import{jsx as Ra}from"react/jsx-runtime";var Hi=({size:t})=>Ra(Bi,{url:"https://coinbase-wallet.onelink.me/q5Sx/fdb9b250",squareLogoElement:ue,size:t,fgColor:"#1F1F1F"});import{jsx as E,jsxs as ro}from"react/jsx-runtime";var zi=({style:t,...e})=>ro("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:[E("rect",{x:"198.5",y:"133",width:"50",height:"50",rx:"25",fill:"#E1E7EF"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("rect",{x:"192",y:"30",width:"50",height:"50",rx:"25",fill:"#0C5BFF"}),E("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"}),E("rect",{x:"39.5",y:"18",width:"50",height:"50",rx:"25",fill:"url(#paint0_linear_428_81)"}),E("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)"}),E("rect",{x:"46.5",y:"124",width:"50",height:"50",rx:"25",fill:"#141414"}),E("g",{clipPath:"url(#clip0_428_81)",children:E("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"})}),E("rect",{x:"103.5",y:"58",width:"78",height:"78",rx:"39",fill:"white"}),E("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"}),E("rect",{x:"103.5",y:"58",width:"78",height:"78",rx:"39",stroke:"#E1E7EF",strokeWidth:"2"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),E("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"}),ro("defs",{children:[ro("linearGradient",{id:"paint0_linear_428_81",x1:"64.5",y1:"18",x2:"64.5",y2:"68",gradientUnits:"userSpaceOnUse",children:[E("stop",{stopColor:"#534BB1"}),E("stop",{offset:"1",stopColor:"#551BF9"})]}),ro("linearGradient",{id:"paint1_linear_428_81",x1:"64.5",y1:"30.9167",x2:"64.5",y2:"55.0834",gradientUnits:"userSpaceOnUse",children:[E("stop",{stopColor:"white"}),E("stop",{offset:"1",stopColor:"white",stopOpacity:"0.82"})]}),E("clipPath",{id:"clip0_428_81",children:E("rect",{width:"31.6667",height:"19.1667",fill:"white",transform:"translate(55.6667 139.833)"})})]})]});import{Fragment as sr,jsx as C,jsxs as j}from"react/jsx-runtime";var ar=()=>{let{navigate:t}=v(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return Re.isFirefox&&(e="https://addons.mozilla.org/en-US/firefox/addon/ether-metamask/"),j(qi,{children:[C(Y,{title:"Create a Metamask wallet",description:"Follow the instructions below to get started."}),C(Ki,{children:C(he,{style:{width:"152px",height:"152px"}})}),j(ir,{children:[C(Be,{children:j("div",{children:[C("span",{children:"Install the "}),C("a",{href:e,target:"_blank",children:"MetaMask browser extension"})]})}),C(_t,{}),C(Be,{children:"Set up your first wallet"}),C(_t,{}),C(Be,{children:"Store your recovery phrase in a safe place!"})]}),C(Ji,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},lr=()=>{let{navigate:t}=v();return j(qi,{children:[C(Y,{title:"Create a Coinbase wallet",description:"Follow the instructions below to get started."}),C(Ki,{style:{marginTop:"-24px"},children:C(Hi,{size:200})}),j(ir,{children:[C(Be,{children:"Scan the QR code with your camera"}),C(_t,{}),C(Be,{children:"Set up your first wallet"}),C(_t,{}),C(Be,{children:"Store your seed phrase in a safe place!"})]}),C(Ji,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},Zi=()=>{let[t,e]=Ma("WHAT_IS_A_WALLET"),{navigateBack:o}=v();return j(sr,{children:[C(A,{backFn:t==="WHAT_IS_A_WALLET"?o:t==="PICK_A_NEW_WALLET"?()=>e("WHAT_IS_A_WALLET"):()=>e("PICK_A_NEW_WALLET")},"header"),j(Na,{children:[t==="WHAT_IS_A_WALLET"&&j(sr,{children:[C(Ga,{children:C(zi,{style:{width:"240px",height:"auto",borderRadius:"var(--border-radius-sm)",marginBottom:"32px"}})}),j(et,{title:"Get started with a new wallet",children:[C("p",{children:"Wallets help you store, send, and receive digital assets and collectibles. They are also a new\xA0way\xA0to\xA0log\xA0in."}),C("p",{children:"Instead of creating new accounts and passwords for every app, you just connect your wallet and bring your\xA0data\xA0with\xA0you."})]}),C(Da,{children:C(Fa,{onClick:()=>{e("PICK_A_NEW_WALLET")},children:"Create a wallet"})})]}),t==="PICK_A_NEW_WALLET"&&C(sr,{children:j(Oa,{children:[C(Y,{title:"Create a new wallet",description:"Select one the wallet providers below to get started on your web3 adventure."}),j(Ua,{children:[j($i,{onClick:()=>{Re.isIOS?window.location.href="https://apps.apple.com/us/app/metamask-blockchain-wallet/id1438144202":Re.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=io.metamask":e("CREATE_METAMASK_WALLET")},children:[C(he,{}),j(ji,{children:[C("h4",{children:"MetaMask"}),C("p",{children:"Get a browser-based wallet"})]}),C("div",{children:C("span",{children:"Set up"})})]}),j($i,{onClick:()=>{Re.isIOS?window.location.href="https://apps.apple.com/us/app/coinbase-wallet-nfts-crypto/id1278383455":Re.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=org.toshi":e("CREATE_COINBASE_WALLET")},children:[C(ue,{}),j(ji,{children:[C("h4",{children:"Coinbase Wallet"}),C("p",{children:"Get a mobile app wallet"})]}),C("div",{children:C("span",{children:"Set up"})})]})]})]})}),t==="CREATE_COINBASE_WALLET"&&C(lr,{}),t==="CREATE_METAMASK_WALLET"&&C(ar,{})]}),j(se,{children:[C("span",{children:"Still not sure? "}),C("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"}),"."]})]})},Na=ae.div`
|
|
717
|
+
display: flex;
|
|
718
|
+
flex-direction: column;
|
|
719
|
+
height: 100%;
|
|
720
|
+
|
|
721
|
+
> svg {
|
|
722
|
+
@media (max-width: 440px) {
|
|
723
|
+
display: none;
|
|
724
|
+
}
|
|
725
|
+
}
|
|
726
|
+
`,Oa=ae.div`
|
|
815
727
|
display: flex;
|
|
816
728
|
flex-direction: column;
|
|
729
|
+
align-items: flex-start;
|
|
817
730
|
justify-content: flex-start;
|
|
818
|
-
|
|
819
|
-
|
|
820
|
-
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
731
|
+
text-align: left;
|
|
732
|
+
gap: 20px;
|
|
733
|
+
`,Ua=ae.div`
|
|
734
|
+
display: flex;
|
|
735
|
+
flex-direction: column;
|
|
736
|
+
width: 100%;
|
|
737
|
+
gap: 8px;
|
|
738
|
+
`,$i=ae.button`
|
|
739
|
+
display: flex;
|
|
740
|
+
flex-direction: row;
|
|
741
|
+
align-items: center;
|
|
742
|
+
gap: 12px;
|
|
743
|
+
cursor: pointer;
|
|
744
|
+
|
|
745
|
+
width: 100%;
|
|
746
|
+
|
|
747
|
+
&& {
|
|
748
|
+
padding: 12px 16px;
|
|
749
|
+
|
|
750
|
+
border: 1px solid var(--border-color-2);
|
|
751
|
+
border-radius: var(--border-radius-sm);
|
|
752
|
+
transition: all 200ms ease-in-out;
|
|
753
|
+
}
|
|
754
|
+
|
|
755
|
+
> svg {
|
|
756
|
+
border-radius: var(--border-radius-sm);
|
|
757
|
+
}
|
|
758
|
+
|
|
759
|
+
-webkit-user-select: none;
|
|
760
|
+
-ms-user-select: none;
|
|
761
|
+
user-select: none;
|
|
762
|
+
|
|
763
|
+
flex: none;
|
|
764
|
+
order: 0;
|
|
765
|
+
align-self: stretch;
|
|
766
|
+
flex-grow: 0;
|
|
767
|
+
|
|
768
|
+
> :last-child {
|
|
769
|
+
margin-left: auto;
|
|
770
|
+
flex: none;
|
|
771
|
+
order: 2;
|
|
772
|
+
flex-grow: 1;
|
|
773
|
+
display: flex;
|
|
774
|
+
justify-content: flex-end;
|
|
775
|
+
|
|
776
|
+
> span {
|
|
777
|
+
padding: 6px 8px;
|
|
778
|
+
font-weight: 500;
|
|
779
|
+
text-align: center;
|
|
780
|
+
color: var(--primary-color);
|
|
781
|
+
background-color: var(--primary-color-bg-1);
|
|
782
|
+
border-radius: var(--border-radius-sm);
|
|
783
|
+
}
|
|
784
|
+
}
|
|
785
|
+
|
|
786
|
+
:hover {
|
|
787
|
+
border: 1px solid var(--primary-color);
|
|
788
|
+
}
|
|
789
|
+
|
|
790
|
+
@media (max-width: 440px) {
|
|
791
|
+
:hover {
|
|
792
|
+
border: 1px solid var(--border-color-2);
|
|
793
|
+
}
|
|
794
|
+
}
|
|
795
|
+
`,ji=ae.div`
|
|
796
|
+
text-align: left;
|
|
797
|
+
|
|
798
|
+
p {
|
|
799
|
+
font-style: italic;
|
|
800
|
+
font-size: 12px;
|
|
801
|
+
}
|
|
802
|
+
`,Da=ae.div`
|
|
803
|
+
margin-top: auto;
|
|
804
|
+
display: flex;
|
|
805
|
+
align-items: flex-end;
|
|
806
|
+
flex-grow: 1;
|
|
807
|
+
width: 100%;
|
|
808
|
+
`,Fa=ae(Ie)`
|
|
809
|
+
&& {
|
|
810
|
+
margin-top: 14px;
|
|
811
|
+
}
|
|
812
|
+
`,qi=ae.div`
|
|
813
|
+
display: flex;
|
|
814
|
+
flex-direction: column;
|
|
815
|
+
align-items: center;
|
|
816
|
+
justify-content: center;
|
|
817
|
+
width: 100%;
|
|
818
|
+
gap: 30px;
|
|
819
|
+
|
|
820
|
+
> :first-child > svg {
|
|
821
|
+
margin-top: 20px;
|
|
822
|
+
}
|
|
823
|
+
`,Ki=ae.div`
|
|
824
|
+
display: flex;
|
|
825
|
+
flex-direction: column;
|
|
826
|
+
align-items: center;
|
|
827
|
+
justify-content: center;
|
|
828
|
+
width: 100%;
|
|
829
|
+
`,Ji=ae.button`
|
|
830
|
+
&& {
|
|
831
|
+
padding: 12px 16px;
|
|
832
|
+
font-weight: 500;
|
|
833
|
+
text-align: center;
|
|
834
|
+
color: var(--primary-color);
|
|
835
|
+
background-color: var(--primary-color-bg-1);
|
|
836
|
+
border-radius: var(--border-radius-sm);
|
|
837
|
+
}
|
|
838
|
+
`,Ga=ae.div`
|
|
839
|
+
display: flex;
|
|
840
|
+
justify-content: center;
|
|
841
|
+
`;import{Fragment as Ba,jsx as io,jsxs as Yi}from"react/jsx-runtime";var Xi=()=>{let{navigateBack:t}=v();return Yi(Ba,{children:[io(A,{backFn:t},"header"),io(lr,{}),Yi(se,{children:[io("span",{children:"Still not sure? "}),io("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"})]})]})};import{Fragment as Va,jsx as no,jsxs as Qi}from"react/jsx-runtime";var en=()=>{let{navigateBack:t}=v();return Qi(Va,{children:[no(A,{backFn:t},"header"),no(ar,{}),Qi(se,{children:[no("span",{children:"Still not sure? "}),no("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"})]})]})};import{useState as wl}from"react";import{isMobile as hn}from"react-device-detect";import pt from"styled-components";import{jsx as tn}from"react/jsx-runtime";var on=()=>{let{app:t}=v();return t!=null&&t.logoUrl?tn("div",{children:tn("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{useEffect as Ha,useState as cr}from"react";import Pt from"styled-components";import{jsx as rn}from"react/jsx-runtime";var so=({style:t,...e})=>rn("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:rn("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{Fragment as Ka,jsx as Ve,jsxs as dr}from"react/jsx-runtime";var ao=t=>{let[e,o]=cr(""),[r,i]=cr(!1),[n,s]=cr(null),{isLinking:a,initLoginWithEmail:p}=_(),{navigate:u,options:x}=v(),L=x.wallet;Ha(()=>{let c=document.querySelector("#email-input");c==null||c.focus()},[]);let m=Vr(e),g=()=>{i(!0),p(e).then(()=>{u("AWAITING_PASSWORDLESS_CODE")}).catch(c=>{let S=(c==null?void 0:c.status)===401&&(c==null?void 0:c.message)==="User is not allowed to login to this app.";(c==null?void 0:c.status)===422?s(c.message):S?u("ALLOWLIST_REJECTION_SCREEN"):s("Issue submitting email"),i(!1)})},f="Get started without a wallet.";return n?f=n:a?f="Easily connect an email":L||(f="Get started quickly with email"),dr(Ka,{children:[dr(za,{stacked:t.stacked,children:[dr(Za,{standalone:t.stacked,children:[Ve(so,{}),Ve("input",{id:"email-input",type:"email",placeholder:"your@email.com",onChange:c=>o(c.target.value),onKeyUp:c=>{c.key==="Enter"&&g()},value:e,autoComplete:"email"})]}),t.stacked?null:Ve($a,{disabled:r||!m,onClick:g,children:r?Ve(We,{}):"Submit"})]}),Ve(qa,{fail:!!n,children:f}),t.stacked?Ve(ja,{disabled:r||!m,onClick:g,children:r?Ve(We,{}):"Submit"}):null]})},za=Pt.div`
|
|
842
|
+
border: 1px solid var(--border-color-1);
|
|
843
|
+
width: 100%;
|
|
844
|
+
height: ${t=>t.stacked?"100%":"auto"};
|
|
845
|
+
|
|
846
|
+
display: flex;
|
|
847
|
+
align-content: center;
|
|
848
|
+
align-items: center;
|
|
849
|
+
flex-grow: 1;
|
|
850
|
+
|
|
851
|
+
@media (max-width: 440px) {
|
|
852
|
+
margin-top: 20px;
|
|
853
|
+
}
|
|
854
|
+
`,$a=Pt.button`
|
|
855
|
+
display: flex;
|
|
856
|
+
flex-direction: row;
|
|
857
|
+
align-items: center;
|
|
858
|
+
justify-content: center;
|
|
859
|
+
& {
|
|
860
|
+
height: 44px;
|
|
861
|
+
cursor: pointer;
|
|
862
|
+
font-size: 14px;
|
|
863
|
+
font-weight: 600;
|
|
864
|
+
border-radius: 0px var(--border-radius-sm) var(--border-radius-sm) 0px;
|
|
865
|
+
}
|
|
866
|
+
|
|
867
|
+
&& {
|
|
868
|
+
padding-left: 15px;
|
|
869
|
+
padding-right: 15px;
|
|
870
|
+
background-color: var(--primary-color);
|
|
871
|
+
color: var(--light-theme-bg-1);
|
|
872
|
+
}
|
|
873
|
+
|
|
874
|
+
&&:disabled {
|
|
875
|
+
background-color: var(--disabled-bg);
|
|
876
|
+
color: var(--disabled-fg);
|
|
877
|
+
cursor: not-allowed;
|
|
878
|
+
}
|
|
879
|
+
`,ja=Pt.button`
|
|
880
|
+
display: flex;
|
|
881
|
+
flex-direction: column;
|
|
882
|
+
align-items: center;
|
|
883
|
+
justify-content: center;
|
|
884
|
+
& {
|
|
885
|
+
height: 44px;
|
|
886
|
+
width: 100%;
|
|
887
|
+
cursor: pointer;
|
|
888
|
+
font-size: 14px;
|
|
889
|
+
font-weight: 600;
|
|
890
|
+
border-radius: var(--border-radius-sm);
|
|
891
|
+
}
|
|
892
|
+
|
|
893
|
+
&& {
|
|
894
|
+
background-color: var(--primary-color);
|
|
895
|
+
color: var(--light-theme-bg-1);
|
|
896
|
+
}
|
|
897
|
+
|
|
898
|
+
&&:disabled {
|
|
899
|
+
background-color: var(--disabled-bg);
|
|
900
|
+
color: var(--disabled-fg);
|
|
901
|
+
cursor: not-allowed;
|
|
902
|
+
}
|
|
903
|
+
`,Za=Pt.label`
|
|
904
|
+
display: flex;
|
|
905
|
+
flex-direction: row;
|
|
906
|
+
align-items: center;
|
|
907
|
+
position: relative;
|
|
908
|
+
width: 100%;
|
|
909
|
+
height: ${t=>t.standalone?"64px":"44px"};
|
|
910
|
+
background: var(--light-theme-bg-1);
|
|
911
|
+
|
|
912
|
+
> svg {
|
|
913
|
+
z-index: 2;
|
|
914
|
+
margin-left: 8px;
|
|
915
|
+
height: 20px !important;
|
|
916
|
+
width: 20px !important;
|
|
917
|
+
color: var(--light-theme-fg-3);
|
|
918
|
+
}
|
|
919
|
+
|
|
920
|
+
&& > input {
|
|
921
|
+
position: absolute;
|
|
922
|
+
padding-left: 40px;
|
|
923
|
+
line-height: 20px;
|
|
924
|
+
|
|
925
|
+
/* Mirror parent to handle embedded logo on left */
|
|
926
|
+
border-radius: ${t=>t.standalone?"var(--border-radius-sm)":"var(--border-radius-sm) 0px 0px var(--border-radius-sm)"};
|
|
927
|
+
height: 100%;
|
|
928
|
+
width: 100%;
|
|
929
|
+
border: 1px solid var(--border-color-1);
|
|
930
|
+
background: var(--light-theme-bg-1);
|
|
931
|
+
}
|
|
932
|
+
|
|
933
|
+
/* Mobile */
|
|
934
|
+
@media (max-width: 440px) {
|
|
935
|
+
&& > input {
|
|
936
|
+
font-size: 16px;
|
|
937
|
+
line-height: 24px;
|
|
938
|
+
}
|
|
939
|
+
}
|
|
940
|
+
`,qa=Pt.div`
|
|
941
|
+
line-height: 20px;
|
|
942
|
+
height: 20px;
|
|
943
|
+
font-size: 13px;
|
|
944
|
+
color: ${t=>t.success?"var(--success-dark)":t.fail?"var(--fail-dark)":"var(--light-theme-fg-3)"};
|
|
945
|
+
display: flex;
|
|
946
|
+
justify-content: space-between;
|
|
947
|
+
width: 100%;
|
|
948
|
+
|
|
949
|
+
> button,
|
|
950
|
+
> a {
|
|
951
|
+
text-decoration: underline;
|
|
952
|
+
}
|
|
953
|
+
`;import{useEffect as Ja,useState as pr}from"react";import St from"styled-components";import{jsx as nn}from"react/jsx-runtime";var lo=({style:t,...e})=>nn("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:nn("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 ol,jsx as He,jsxs as ur}from"react/jsx-runtime";var co=t=>{let[e,o]=pr(""),[r,i]=pr(!1),[n,s]=pr(null),{isLinking:a,initLoginWithSms:p}=_(),{navigate:u,options:x}=v(),L=x.wallet;Ja(()=>{let c=document.querySelector("#phone-number-input");c==null||c.focus()},[]);let m=Hr(e),g=()=>{i(!0),p(e).then(()=>{u("AWAITING_PASSWORDLESS_CODE")}).catch(c=>{let S=(c==null?void 0:c.status)===401&&(c==null?void 0:c.message)==="User is not allowed to login to this app.";(c==null?void 0:c.status)===422?s(c.message):S?u("ALLOWLIST_REJECTION_SCREEN"):s("Issue submitting phone number"),i(!1)})},f="Get started without a wallet.";return n?f=n:a?f="Easily connect a phone number":L||(f="Get started quickly with your phone"),ur(ol,{children:[ur(Ya,{stacked:t.stacked,children:[ur(el,{standalone:t.stacked,children:[He(lo,{}),He("input",{id:"phone-number-input",type:"tel",placeholder:"555 555 5555",onChange:c=>{o(c.target.value)},onKeyUp:c=>{c.key==="Enter"&&g()},value:e,autoComplete:"tel"})]}),t.stacked?null:He(Xa,{disabled:r||!m,onClick:g,children:r?He(We,{}):"Submit"})]}),He(tl,{fail:!!n,children:f}),t.stacked?He(Qa,{disabled:r||!m,onClick:g,children:r?He(We,{}):"Submit"}):null]})},Ya=St.div`
|
|
954
|
+
display: flex;
|
|
955
|
+
border: 1px solid var(--border-color-1);
|
|
956
|
+
width: 100%;
|
|
957
|
+
|
|
958
|
+
height: ${t=>t.stacked?"100%":"auto"};
|
|
959
|
+
display: flex;
|
|
960
|
+
align-content: center;
|
|
961
|
+
align-items: center;
|
|
962
|
+
flex-grow: 1;
|
|
963
|
+
|
|
964
|
+
@media (max-width: 440px) {
|
|
965
|
+
margin-top: 20px;
|
|
966
|
+
}
|
|
967
|
+
`,Xa=St.button`
|
|
968
|
+
display: flex;
|
|
969
|
+
flex-direction: row;
|
|
970
|
+
align-items: center;
|
|
971
|
+
justify-content: center;
|
|
972
|
+
& {
|
|
973
|
+
height: 44px;
|
|
974
|
+
cursor: pointer;
|
|
975
|
+
font-size: 14px;
|
|
976
|
+
font-weight: 600;
|
|
977
|
+
border-radius: 0px var(--border-radius-sm) var(--border-radius-sm) 0px;
|
|
978
|
+
}
|
|
979
|
+
|
|
980
|
+
&& {
|
|
981
|
+
padding-left: 15px;
|
|
982
|
+
padding-right: 15px;
|
|
983
|
+
background-color: var(--primary-color);
|
|
984
|
+
color: var(--light-theme-bg-1);
|
|
985
|
+
}
|
|
986
|
+
|
|
987
|
+
&&:disabled {
|
|
988
|
+
background-color: var(--disabled-bg);
|
|
989
|
+
color: var(--disabled-fg);
|
|
990
|
+
cursor: not-allowed;
|
|
991
|
+
}
|
|
992
|
+
`,Qa=St.button`
|
|
993
|
+
display: flex;
|
|
994
|
+
flex-direction: column;
|
|
995
|
+
align-items: center;
|
|
996
|
+
justify-content: center;
|
|
997
|
+
& {
|
|
998
|
+
height: 44px;
|
|
999
|
+
width: 100%;
|
|
1000
|
+
cursor: pointer;
|
|
1001
|
+
font-size: 14px;
|
|
1002
|
+
font-weight: 600;
|
|
1003
|
+
border-radius: var(--border-radius-sm);
|
|
1004
|
+
}
|
|
1005
|
+
|
|
1006
|
+
&& {
|
|
1007
|
+
background-color: var(--primary-color);
|
|
1008
|
+
color: var(--light-theme-bg-1);
|
|
1009
|
+
}
|
|
1010
|
+
|
|
1011
|
+
&&:disabled {
|
|
1012
|
+
background-color: var(--disabled-bg);
|
|
1013
|
+
color: var(--disabled-fg);
|
|
1014
|
+
cursor: not-allowed;
|
|
1015
|
+
}
|
|
1016
|
+
`,el=St.label`
|
|
1017
|
+
display: flex;
|
|
1018
|
+
flex-direction: row;
|
|
1019
|
+
align-items: center;
|
|
1020
|
+
position: relative;
|
|
1021
|
+
width: 100%;
|
|
1022
|
+
height: ${t=>t.standalone?"64px":"44px"};
|
|
1023
|
+
background: var(--light-theme-bg-1);
|
|
1024
|
+
|
|
1025
|
+
> svg {
|
|
1026
|
+
z-index: 2;
|
|
1027
|
+
margin-left: 8px;
|
|
1028
|
+
height: 20px !important;
|
|
1029
|
+
width: 20px !important;
|
|
1030
|
+
color: var(--light-theme-fg-3);
|
|
1031
|
+
}
|
|
1032
|
+
|
|
1033
|
+
&& > input {
|
|
1034
|
+
position: absolute;
|
|
1035
|
+
padding-left: 40px;
|
|
1036
|
+
line-height: 20px;
|
|
1037
|
+
|
|
1038
|
+
/* Mirror parent to handle embedded logo on left */
|
|
1039
|
+
border-radius: ${t=>t.standalone?"var(--border-radius-sm)":"var(--border-radius-sm) 0px 0px var(--border-radius-sm)"};
|
|
1040
|
+
height: 100%;
|
|
1041
|
+
width: 100%;
|
|
1042
|
+
border: 1px solid var(--border-color-1);
|
|
1043
|
+
background: var(--light-theme-bg-1);
|
|
824
1044
|
}
|
|
825
|
-
`,ze=({children:t})=>Ga(Da,{children:[Fa(jn,{style:{width:"16px",height:"16px"}}),t]}),Da=or.div`
|
|
826
|
-
display: flex;
|
|
827
|
-
justify-content: flex-start;
|
|
828
|
-
justify-items: center;
|
|
829
|
-
text-align: left;
|
|
830
|
-
gap: 8px;
|
|
831
1045
|
|
|
832
|
-
|
|
833
|
-
|
|
834
|
-
|
|
835
|
-
|
|
1046
|
+
/* Mobile */
|
|
1047
|
+
@media (max-width: 440px) {
|
|
1048
|
+
&& > input {
|
|
1049
|
+
font-size: 16px;
|
|
1050
|
+
line-height: 24px;
|
|
836
1051
|
}
|
|
1052
|
+
}
|
|
1053
|
+
`,tl=St.div`
|
|
1054
|
+
line-height: 20px;
|
|
1055
|
+
height: 20px;
|
|
1056
|
+
font-size: 13px;
|
|
1057
|
+
color: ${t=>t.success?"var(--success-dark)":t.fail?"var(--fail-dark)":"var(--light-theme-fg-3)"};
|
|
1058
|
+
display: flex;
|
|
1059
|
+
justify-content: space-between;
|
|
1060
|
+
width: 100%;
|
|
837
1061
|
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
}
|
|
1062
|
+
> button,
|
|
1063
|
+
> a {
|
|
1064
|
+
text-decoration: underline;
|
|
842
1065
|
}
|
|
843
|
-
`;import{jsx as x,jsxs as mo}from"react/jsx-runtime";var Zn=({style:t,...e})=>mo("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:[x("rect",{x:"198.5",y:"133",width:"50",height:"50",rx:"25",fill:"#E1E7EF"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("rect",{x:"192",y:"30",width:"50",height:"50",rx:"25",fill:"#0C5BFF"}),x("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"}),x("rect",{x:"39.5",y:"18",width:"50",height:"50",rx:"25",fill:"url(#paint0_linear_428_81)"}),x("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)"}),x("rect",{x:"46.5",y:"124",width:"50",height:"50",rx:"25",fill:"#141414"}),x("g",{clipPath:"url(#clip0_428_81)",children:x("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"})}),x("rect",{x:"103.5",y:"58",width:"78",height:"78",rx:"39",fill:"white"}),x("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"}),x("rect",{x:"103.5",y:"58",width:"78",height:"78",rx:"39",stroke:"#E1E7EF",strokeWidth:"2"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),x("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"}),mo("defs",{children:[mo("linearGradient",{id:"paint0_linear_428_81",x1:"64.5",y1:"18",x2:"64.5",y2:"68",gradientUnits:"userSpaceOnUse",children:[x("stop",{stopColor:"#534BB1"}),x("stop",{offset:"1",stopColor:"#551BF9"})]}),mo("linearGradient",{id:"paint1_linear_428_81",x1:"64.5",y1:"30.9167",x2:"64.5",y2:"55.0834",gradientUnits:"userSpaceOnUse",children:[x("stop",{stopColor:"white"}),x("stop",{offset:"1",stopColor:"white",stopOpacity:"0.82"})]}),x("clipPath",{id:"clip0_428_81",children:x("rect",{width:"31.6667",height:"19.1667",fill:"white",transform:"translate(55.6667 139.833)"})})]})]});import*as Re from"react-device-detect";import ir from"styled-components";import{jsx as nr,jsxs as Va}from"react/jsx-runtime";var qn=ir.button`
|
|
1066
|
+
`;import Tt from"styled-components";import{jsx as kt,jsxs as rl}from"react/jsx-runtime";var po=({logoFill:t,style:e,...o})=>rl("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:[kt("g",{clipPath:"url(#clip0)",children:kt("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"})}),kt("defs",{children:kt("clipPath",{id:"clip0",children:kt("rect",{width:"71",height:"55",fill:"white"})})})]});import{jsx as sn}from"react/jsx-runtime";var uo=({logoFill:t,style:e,...o})=>sn("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"24",y:"24",viewBox:"0 0 98 96",style:{height:"24px",...e},...o,children:sn("path",{d:"M48.854 0C21.839 0 0 22 0 49.217c0 21.756 13.993 40.172 33.405 46.69 2.427.49 3.316-1.059 3.316-2.362 0-1.141-.08-5.052-.08-9.127-13.59 2.934-16.42-5.867-16.42-5.867-2.184-5.704-5.42-7.17-5.42-7.17-4.448-3.015.324-3.015.324-3.015 4.934.326 7.523 5.052 7.523 5.052 4.367 7.496 11.404 5.378 14.235 4.074.404-3.178 1.699-5.378 3.074-6.6-10.839-1.141-22.243-5.378-22.243-24.283 0-5.378 1.94-9.778 5.014-13.2-.485-1.222-2.184-6.275.486-13.038 0 0 4.125-1.304 13.426 5.052a46.97 46.97 0 0 1 12.214-1.63c4.125 0 8.33.571 12.213 1.63 9.302-6.356 13.427-5.052 13.427-5.052 2.67 6.763.97 11.816.485 13.038 3.155 3.422 5.015 7.822 5.015 13.2 0 18.905-11.404 23.06-22.324 24.283 1.78 1.548 3.316 4.481 3.316 9.126 0 6.6-.08 11.897-.08 13.526 0 1.304.89 2.853 3.316 2.364 19.412-6.52 33.405-24.935 33.405-46.691C97.707 22 75.788 0 48.854 0z",fill:t==="primary"?"#2D333B":"white"})});import{jsx as ho,jsxs as il}from"react/jsx-runtime";var mo=({style:t,...e})=>il("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:[ho("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"}),ho("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"}),ho("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"}),ho("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 an}from"react/jsx-runtime";var fo=({style:t,logoFill:e,...o})=>an("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:an("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 Me,jsxs as dl}from"react/jsx-runtime";var ln=({showGoogle:t,showTwitter:e,showDiscord:o,showGithub:r,stacked:i})=>{let{initLoginWithOAuth:n}=_();return dl(nl,{stacked:i,children:[t&&Me(cl,{onClick:()=>{n("google")},children:Me(mo,{})}),e&&Me(sl,{onClick:()=>{n("twitter")},children:Me(fo,{})}),o&&Me(al,{onClick:()=>{n("discord")},children:Me(po,{})}),r&&Me(ll,{onClick:()=>{n("github")},children:Me(uo,{})})]})},nl=Tt.div`
|
|
844
1067
|
display: flex;
|
|
845
|
-
flex-direction: row;
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
padding: 7px 11px;
|
|
1068
|
+
flex-direction: ${t=>t.stacked?"column":"row"};
|
|
1069
|
+
justify-content: space-between;
|
|
1070
|
+
width: 100%;
|
|
1071
|
+
gap: 4px;
|
|
1072
|
+
`,sl=Tt.button`
|
|
1073
|
+
&& {
|
|
1074
|
+
border-radius: var(--border-radius-sm);
|
|
853
1075
|
cursor: pointer;
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
color: var(--disabled-fg);
|
|
862
|
-
cursor: not-allowed;
|
|
1076
|
+
height: 44px;
|
|
1077
|
+
flex: 1;
|
|
1078
|
+
background-color: #1da1f2;
|
|
1079
|
+
display: flex;
|
|
1080
|
+
flex-direction: column;
|
|
1081
|
+
justify-content: center;
|
|
1082
|
+
align-items: center;
|
|
863
1083
|
}
|
|
864
|
-
`,
|
|
1084
|
+
`,al=Tt.button`
|
|
865
1085
|
&& {
|
|
866
|
-
|
|
867
|
-
|
|
1086
|
+
border-radius: var(--border-radius-sm);
|
|
1087
|
+
cursor: pointer;
|
|
1088
|
+
height: 44px;
|
|
1089
|
+
flex: 1;
|
|
1090
|
+
background-color: #5865f2;
|
|
1091
|
+
display: flex;
|
|
1092
|
+
flex-direction: column;
|
|
1093
|
+
justify-content: center;
|
|
1094
|
+
align-items: center;
|
|
868
1095
|
}
|
|
869
|
-
|
|
870
|
-
|
|
1096
|
+
`,ll=Tt.button`
|
|
1097
|
+
&& {
|
|
1098
|
+
border-radius: var(--border-radius-sm);
|
|
1099
|
+
cursor: pointer;
|
|
1100
|
+
height: 44px;
|
|
1101
|
+
flex: 1;
|
|
1102
|
+
background-color: #2d333b;
|
|
871
1103
|
display: flex;
|
|
1104
|
+
flex-direction: column;
|
|
1105
|
+
justify-content: center;
|
|
872
1106
|
align-items: center;
|
|
873
|
-
gap: 8px;
|
|
874
1107
|
}
|
|
875
|
-
`,
|
|
1108
|
+
`,cl=Tt.button`
|
|
876
1109
|
&& {
|
|
877
|
-
border:
|
|
878
|
-
|
|
1110
|
+
border-radius: var(--border-radius-sm);
|
|
1111
|
+
cursor: pointer;
|
|
1112
|
+
height: 44px;
|
|
1113
|
+
background-color: var(--light-theme-bg-1);
|
|
1114
|
+
flex: 1;
|
|
1115
|
+
display: flex;
|
|
1116
|
+
flex-direction: column;
|
|
1117
|
+
justify-content: center;
|
|
1118
|
+
align-items: center;
|
|
1119
|
+
border: 1px solid var(--border-color-2);
|
|
879
1120
|
}
|
|
880
|
-
`;import{
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
height: 100%;
|
|
884
|
-
|
|
885
|
-
> svg {
|
|
886
|
-
@media (max-width: 440px) {
|
|
887
|
-
display: none;
|
|
888
|
-
}
|
|
1121
|
+
`;import{isMobile as dn}from"react-device-detect";import pn from"styled-components";import{isIOS as pl,isMobile as ul}from"react-device-detect";var hr=t=>{let e=new URL(window.location.href);if(!window.ethereum&&ul){let o;switch(t){case"metamask":pl?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 hl from"styled-components";var cn=hl.span`
|
|
1122
|
+
@media (max-width: 440px) {
|
|
1123
|
+
display: none;
|
|
889
1124
|
}
|
|
890
|
-
|
|
1125
|
+
`;import{jsx as Le,jsxs as Wt}from"react/jsx-runtime";var go=()=>{let{navigate:t}=v(),{initLoginWithWallet:e,closePrivyModal:o}=_();return Wt(ml,{children:[Wt(mr,{onClick:()=>{Oo()?(e("metamask"),t("AWAITING_CONNECTION")):dn?(hr("metamask"),o()):t("INSTALL_METAMASK_SCREEN")},children:[Le(he,{}),Le("span",{children:"Metamask"}),Le("span",{children:Oo()?"Connect":"Install"})]}),Wt(mr,{onClick:()=>{$t()?(e("coinbase_wallet"),t("AWAITING_CONNECTION")):dn?(hr("coinbase_wallet"),o()):(e("coinbase_wallet"),t("AWAITING_CONNECTION"))},children:[Le(ue,{}),Wt("span",{children:["Coinbase",Le(cn,{children:" Wallet"})]}),Le("span",{children:"Connect"})]}),Wt(mr,{onClick:()=>{e("wallet_connect"),t("AWAITING_CONNECTION")},children:[Le(it,{}),Le("span",{children:"WalletConnect"}),Le("span",{children:"Connect"})]})]})},ml=pn.div`
|
|
891
1126
|
display: flex;
|
|
892
1127
|
flex-direction: column;
|
|
893
1128
|
align-items: flex-start;
|
|
894
|
-
justify-content: flex-start;
|
|
895
|
-
text-align: left;
|
|
896
|
-
gap: 20px;
|
|
897
|
-
`,ja=ae.div`
|
|
898
|
-
display: flex;
|
|
899
|
-
flex-direction: column;
|
|
900
|
-
width: 100%;
|
|
901
1129
|
gap: 8px;
|
|
902
|
-
|
|
1130
|
+
width: 100%;
|
|
1131
|
+
|
|
1132
|
+
@media (max-width: 440px) {
|
|
1133
|
+
flex-direction: row;
|
|
1134
|
+
}
|
|
1135
|
+
`,mr=pn.button`
|
|
903
1136
|
display: flex;
|
|
904
1137
|
flex-direction: row;
|
|
905
1138
|
align-items: center;
|
|
906
1139
|
gap: 12px;
|
|
907
|
-
cursor: pointer;
|
|
908
|
-
|
|
909
1140
|
width: 100%;
|
|
1141
|
+
height: 44px;
|
|
910
1142
|
|
|
911
|
-
|
|
912
|
-
|
|
1143
|
+
-webkit-user-select: none;
|
|
1144
|
+
-ms-user-select: none;
|
|
1145
|
+
user-select: none;
|
|
913
1146
|
|
|
1147
|
+
&& {
|
|
1148
|
+
font-weight: 600;
|
|
1149
|
+
padding: 7px 11px;
|
|
914
1150
|
border: 1px solid var(--border-color-2);
|
|
915
1151
|
border-radius: var(--border-radius-sm);
|
|
916
|
-
transition: all 200ms ease-in-out;
|
|
917
1152
|
}
|
|
918
1153
|
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
1154
|
+
@media (max-width: 440px) {
|
|
1155
|
+
width: auto;
|
|
1156
|
+
flex-direction: column;
|
|
1157
|
+
height: auto;
|
|
922
1158
|
|
|
923
|
-
|
|
924
|
-
|
|
925
|
-
|
|
1159
|
+
&& {
|
|
1160
|
+
font-weight: 500;
|
|
1161
|
+
padding: 11px 7px;
|
|
1162
|
+
font-size: 11px;
|
|
1163
|
+
line-height: 16px;
|
|
1164
|
+
flex-grow: 1;
|
|
1165
|
+
flex-basis: 0;
|
|
1166
|
+
}
|
|
1167
|
+
}
|
|
926
1168
|
|
|
927
1169
|
flex: none;
|
|
928
1170
|
order: 0;
|
|
929
1171
|
align-self: stretch;
|
|
930
1172
|
flex-grow: 0;
|
|
931
1173
|
|
|
1174
|
+
> svg {
|
|
1175
|
+
border-radius: var(--border-radius-sm);
|
|
1176
|
+
|
|
1177
|
+
@media (max-width: 440px) {
|
|
1178
|
+
height: 50px !important;
|
|
1179
|
+
width: 50px !important;
|
|
1180
|
+
}
|
|
1181
|
+
}
|
|
1182
|
+
|
|
1183
|
+
/* Show "Connect" on hover */
|
|
932
1184
|
> :last-child {
|
|
933
|
-
|
|
1185
|
+
font-weight: 500;
|
|
1186
|
+
text-align: right;
|
|
934
1187
|
flex: none;
|
|
935
1188
|
order: 2;
|
|
936
1189
|
flex-grow: 1;
|
|
937
|
-
|
|
938
|
-
|
|
1190
|
+
color: var(--primary-color);
|
|
1191
|
+
opacity: 0;
|
|
1192
|
+
transition: opacity 0.1s ease-out;
|
|
939
1193
|
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
font-weight: 500;
|
|
943
|
-
text-align: center;
|
|
944
|
-
color: var(--primary-color);
|
|
945
|
-
background-color: var(--primary-color-bg-1);
|
|
946
|
-
border-radius: var(--border-radius-sm);
|
|
1194
|
+
@media (max-width: 440px) {
|
|
1195
|
+
display: none;
|
|
947
1196
|
}
|
|
948
1197
|
}
|
|
949
1198
|
|
|
950
|
-
:hover {
|
|
951
|
-
|
|
1199
|
+
:hover > :last-child {
|
|
1200
|
+
opacity: 1;
|
|
952
1201
|
}
|
|
1202
|
+
`;import fl from"styled-components";import{jsx as un,jsxs as yl}from"react/jsx-runtime";var yo=()=>{let{navigate:t}=v();return yl(gl,{children:[un("span",{children:"Don\u2019t have a wallet? "}),un("button",{onClick:()=>{t("WALLET_EDUCATION")},children:"Create one now."})]})},gl=fl.div`
|
|
1203
|
+
font-size: 13px;
|
|
1204
|
+
color: var(--light-theme-fg-3);
|
|
953
1205
|
|
|
954
|
-
|
|
955
|
-
:
|
|
956
|
-
border: 1px solid var(--border-color-2);
|
|
957
|
-
}
|
|
1206
|
+
> button {
|
|
1207
|
+
text-decoration: underline;
|
|
958
1208
|
}
|
|
959
|
-
`,Jn=ae.div`
|
|
960
|
-
text-align: left;
|
|
961
1209
|
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
font-size: 12px;
|
|
1210
|
+
@media (max-width: 440px) {
|
|
1211
|
+
margin-top: 4px;
|
|
965
1212
|
}
|
|
966
|
-
|
|
967
|
-
|
|
1213
|
+
`;import{Fragment as fr,jsx as O,jsxs as ze}from"react/jsx-runtime";var fn=()=>{let{app:t,options:e}=v(),o=e.email,r=e.sms,i=e.wallet,n=e.google,s=e.twitter,a=e.discord,p=e.github,u=i&&(t==null?void 0:t.showWalletLoginFirst)?0:1,[x,L]=wl(u),m=x==0,g=x==1,f=i,c=o||r;return ze(fr,{children:[O(A,{},"header"),O(El,{hasOnlyOneSection:f!==c,hasTerms:!!((t==null?void 0:t.privacyPolicyUrl)||(t==null?void 0:t.termsAndConditionsUrl)),children:O(on,{})}),ze(Ll,{reverse:!(t!=null&&t.showWalletLoginFirst),children:[f&&O(vl,{active:m,onClick:()=>L(0),isOnlySection:!c}),c&&O(Cl,{active:g,onClick:()=>L(1),email:o,sms:r,google:n,twitter:s,discord:a,github:p,isOnlySection:!f})]}),t&&O(mi,{app:t}),O($,{protectedByPrivy:!0})]})};function vl(t){return ze(yn,{active:t.active,onClick:t.onClick,isOnlySection:t.isOnlySection,children:[O(gn,{active:t.active,children:O("h4",{children:"Connect Wallet"})}),t.active&&ze(fr,{children:[O(go,{}),O(yo,{})]})]})}function Cl(t){let e=t.google||t.discord||t.github||t.twitter&&!hn,o=t.email?"Email":"Phone";return ze(yn,{active:t.active,onClick:t.onClick,isOnlySection:t.isOnlySection,children:[t.isOnlySection?null:O(gn,{active:t.active,children:O("h4",{children:e?`${o} & Social`:o})}),t.active&&t.email&&O(ao,{}),t.active&&t.sms&&!t.email&&O(co,{}),t.active&&e&&O(bl,{google:t.google,twitter:t.twitter&&!hn,discord:t.discord,github:t.github})]})}function bl(t){return ze(fr,{children:[ze(xl,{children:[O(mn,{}),O("p",{children:" Or "}),O(mn,{})]}),O(ln,{showGoogle:t.google,showDiscord:t.discord,showGithub:t.github,showTwitter:t.twitter})]})}var gn=pt.div`
|
|
1214
|
+
font-weight: ${t=>t.active?600:500};
|
|
1215
|
+
color: ${t=>t.active?"inherit":"var(--light-theme-fg-3)"};
|
|
968
1216
|
display: flex;
|
|
969
|
-
|
|
970
|
-
|
|
971
|
-
|
|
972
|
-
`,qa=ae(Ie)`
|
|
973
|
-
&& {
|
|
974
|
-
margin-top: 14px;
|
|
975
|
-
}
|
|
976
|
-
`,Xn=ae.div`
|
|
1217
|
+
justify-content: center;
|
|
1218
|
+
align-items: center;
|
|
1219
|
+
`,yn=pt.div`
|
|
977
1220
|
display: flex;
|
|
978
1221
|
flex-direction: column;
|
|
979
|
-
align-items:
|
|
980
|
-
|
|
1222
|
+
align-items: flex-start;
|
|
1223
|
+
/* 1px helps with the input ring getting hidden by padding, despite it being
|
|
1224
|
+
* annoying that it's not perfectly lined up
|
|
1225
|
+
*/
|
|
1226
|
+
padding: ${t=>t.isOnlySection?"1px":"12px"};
|
|
1227
|
+
gap: 12px;
|
|
981
1228
|
width: 100%;
|
|
982
|
-
|
|
1229
|
+
max-height: ${t=>t.active?"400px":"52px"};
|
|
983
1230
|
|
|
984
|
-
|
|
985
|
-
|
|
1231
|
+
transition-property: border-color, max-height;
|
|
1232
|
+
transition-duration: 0.25s;
|
|
1233
|
+
transition-timing-function: ease-in;
|
|
1234
|
+
overflow: hidden;
|
|
1235
|
+
|
|
1236
|
+
&& {
|
|
1237
|
+
background: var(--light-theme-bg-1);
|
|
1238
|
+
|
|
1239
|
+
border: ${t=>t.isOnlySection?"none":t.active?"1px solid var(--border-color-active);":"1px solid var(--border-color-2);"};
|
|
1240
|
+
border-radius: ${t=>t.isOnlySection?"0":"10px"};
|
|
986
1241
|
}
|
|
987
|
-
|
|
1242
|
+
|
|
1243
|
+
cursor: ${t=>t.active?"inherit":"pointer"};
|
|
1244
|
+
`,xl=pt.div`
|
|
988
1245
|
display: flex;
|
|
989
|
-
flex-direction: column;
|
|
990
|
-
align-items: center;
|
|
991
1246
|
justify-content: center;
|
|
1247
|
+
align-items: center;
|
|
992
1248
|
width: 100%;
|
|
993
|
-
`,
|
|
1249
|
+
`,mn=pt.hr`
|
|
1250
|
+
width: 50%;
|
|
994
1251
|
&& {
|
|
995
|
-
|
|
996
|
-
|
|
997
|
-
text-align: center;
|
|
998
|
-
color: var(--primary-color);
|
|
999
|
-
background-color: var(--primary-color-bg-1);
|
|
1000
|
-
border-radius: var(--border-radius-sm);
|
|
1252
|
+
border-top: 1px solid var(--border-color-1);
|
|
1253
|
+
margin: 0px 8px;
|
|
1001
1254
|
}
|
|
1002
|
-
`,
|
|
1255
|
+
`,El=pt.div`
|
|
1003
1256
|
display: flex;
|
|
1004
|
-
|
|
1005
|
-
|
|
1257
|
+
flex-direction: column;
|
|
1258
|
+
align-items: center;
|
|
1259
|
+
|
|
1260
|
+
// This is a temp hack until we use a real accordion and JS to calculate
|
|
1261
|
+
// heights - real-life CSS height math is hard to do properly.
|
|
1262
|
+
|
|
1263
|
+
// - Logo is 80px tall
|
|
1264
|
+
// - Top margin from cancel button is 24px and needs to be counteracted
|
|
1265
|
+
// - Some don't have social/email/sms. That adds 46px+16px gap
|
|
1266
|
+
// So...
|
|
1267
|
+
// - Wallet + other => 114px padding for logo, -24px on the top
|
|
1268
|
+
// - Only one section => Condensed, so just need a healthy amount of space
|
|
1269
|
+
// - Terms => 36px
|
|
1270
|
+
// Lastly, apply a 10px cheat upwards, which helps in particular for when
|
|
1271
|
+
// the logo is close to the top (mobile or full wallet-open design)
|
|
1272
|
+
margin-top: ${t=>`${28+(t.hasOnlyOneSection?31:0)-(t.hasTerms?18:0)}px`};
|
|
1273
|
+
margin-bottom: ${t=>`${60+(t.hasOnlyOneSection?31:0)-(t.hasTerms?18:0)}px`};
|
|
1274
|
+
`,Ll=pt(Te)`
|
|
1275
|
+
flex-direction: ${t=>t.reverse?"column-reverse":"column"};
|
|
1276
|
+
`;import{Fragment as Al,jsx as ut,jsxs as _l}from"react/jsx-runtime";var wn=()=>{let{app:t}=v();return _l(Al,{children:[ut(A,{},"header"),ut(et,{title:"Connect your email",description:`Add your email to your ${t==null?void 0:t.name} account`,icon:ut(so,{})}),ut(Te,{children:ut(ao,{stacked:!0})}),ut($,{protectedByPrivy:!0})]})};import{Fragment as Pl,jsx as ht,jsxs as Sl}from"react/jsx-runtime";var vn=()=>{let{app:t}=v();return Sl(Pl,{children:[ht(A,{},"header"),ht(et,{title:"Connect your phone",description:`Add your number to your ${t==null?void 0:t.name} account`,icon:ht(lo,{})}),ht(Te,{children:ht(co,{stacked:!0})}),ht($,{protectedByPrivy:!0})]})};import{Fragment as kl,jsx as It,jsxs as Cn}from"react/jsx-runtime";var bn=()=>{let{linkingHint:t}=_(),{app:e}=v(),o=t?`Select the wallet with ${De(t)} and follow the instructions to reconnect your wallet${e!=null&&e.name?` to ${e.name}.`:"."}`:`Link a wallet to your ${e==null?void 0:e.name} account`;return Cn(kl,{children:[It(A,{},"header"),It(gi,{title:`${t?"Reconnect":"Connect"} your wallet`,description:o}),Cn(Te,{children:[It(go,{}),It(yo,{})]}),It($,{protectedByPrivy:!0})]})};import{useEffect as xn,useState as En}from"react";import vo from"styled-components";import{Fragment as Nl,jsx as $e,jsxs as wo}from"react/jsx-runtime";var Ln={google:{name:"Google",component:mo},discord:{name:"Discord",component:po},github:{name:"Github",component:uo},twitter:{name:"Twitter",component:fo}},Tl=t=>t.charAt(0).toUpperCase()+t.slice(1),gr=()=>{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)},An=()=>{var b;let{ready:t,user:e,authenticated:o}=z(),{data:r,setModalData:i,navigate:n}=v(),{getAuthMeta:s,initLoginWithOAuth:a,loginWithOAuth:p,closePrivyModal:u}=_(),[x,L]=En(!1),[m,g]=En(void 0),f=((b=s())==null?void 0:b.provider)||"google",c=Ln[f].name,S=Ln[f].component;xn(()=>{!t||p().then(()=>{gr(),L(!0)}).catch(W=>{let G={retryable:!1,message:"Authentication failed."};W.message.includes("Another user has already linked this")?G.detail="This account has already been linked to another user.":W.message==="Invalid code during oauth flow."?(G.retryable=!0,G.detail="Something went wrong. Try again."):W.message==="User denied confirmation during OAuth flow"&&(G.detail=`Retry and check ${Tl(f)} to finish connecting your account.`,G.retryable=!0),gr(),g(G)})},[t]),xn(()=>{var K;if(!(o&&x&&e))return;if(((K=r==null?void 0:r.login)==null?void 0:K.promptCreatePrivyWalletFlow)&&!e.wallet){let I=setTimeout(()=>{i({createWallet:{onSuccess:()=>u({shouldCallAuthOnSuccess:!0}),onFailure:P=>console.error(P)}}),n("EMBEDDED_WALLET_SCREEN")},re-500);return()=>clearTimeout(I)}else{let I=setTimeout(u,re);return()=>clearTimeout(I)}},[x]);let M=x?`Successfully connected with ${c}`:m?m.message:`Verifying connection to ${c}`,k="";return x?k="You\u2019re good to go!":m?k=m.detail:k="Just a few moments more",wo(Nl,{children:[$e(A,{}),wo(Wl,{children:[$e(Rl,{children:wo("div",{children:[$e(ot,{success:x,fail:!!m}),$e(S,{style:{width:"38px",height:"38px"},logoFill:"primary"})]})}),wo(Il,{children:[$e("h3",{children:M}),$e("p",{children:k})]}),$e(Ml,{onClick:()=>{gr(),a(f),g(void 0)},visible:!x&&(m==null?void 0:m.retryable),disabled:!x&&!(m!=null&&m.retryable),children:"Retry"})]})]})},Wl=vo.div`
|
|
1006
1277
|
display: flex;
|
|
1007
1278
|
flex-direction: column;
|
|
1008
1279
|
align-items: center;
|
|
@@ -1010,14 +1281,11 @@ Resources:
|
|
|
1010
1281
|
margin-left: 27px;
|
|
1011
1282
|
margin-right: 27px;
|
|
1012
1283
|
gap: 24px;
|
|
1013
|
-
`,
|
|
1284
|
+
`,Il=vo.div`
|
|
1014
1285
|
display: flex;
|
|
1015
1286
|
flex-direction: column;
|
|
1016
1287
|
gap: 8px;
|
|
1017
|
-
|
|
1018
|
-
If we then switch to 1 line h3 and 2 lines p, we don't resize. */
|
|
1019
|
-
min-height: 76px;
|
|
1020
|
-
`,Xa=go.div`
|
|
1288
|
+
`,Rl=vo.div`
|
|
1021
1289
|
display: flex;
|
|
1022
1290
|
flex-direction: column;
|
|
1023
1291
|
justify-content: center;
|
|
@@ -1040,7 +1308,7 @@ Resources:
|
|
|
1040
1308
|
left: -19px;
|
|
1041
1309
|
top: -19px;
|
|
1042
1310
|
}
|
|
1043
|
-
`,
|
|
1311
|
+
`,Ml=vo.button`
|
|
1044
1312
|
&& {
|
|
1045
1313
|
padding: 12px 16px;
|
|
1046
1314
|
font-weight: 500;
|
|
@@ -1052,7 +1320,7 @@ Resources:
|
|
|
1052
1320
|
opacity: ${t=>t.visible?"1":"0"};
|
|
1053
1321
|
transition: opacity 200ms;
|
|
1054
1322
|
}
|
|
1055
|
-
`;import{
|
|
1323
|
+
`;import{useEffect as _n,useState as Pn}from"react";import yr from"styled-components";import{Fragment as Fl,jsx as le,jsxs as Co}from"react/jsx-runtime";var Sn=()=>{let[t,e]=Pn(!1),[o,r]=Pn(""),{activeStatus:i,closePrivyModal:n}=_();_n(()=>{!i||(i.error?r(i.error):i.success&&e(!0))},[i]),_n(()=>{if(t){let u=setTimeout(n,re);return()=>clearTimeout(u)}},[t]);let s=i!=null&&i.address?`Please connect and select the wallet ${De(i.address)} in MetaMask.`:"Please connect and select the right wallet in MetaMask.",a=t?`${De(i==null?void 0:i.address)} is now active.`:s;return Co(Fl,{children:[le(A,{},"header"),Co(Ol,{children:[le(Dl,{children:Co("div",{children:[le(ot,{success:t,fail:!!o}),(u=>{switch(u){case"metamask":return le(he,{style:{width:"38px",height:"38px"}});case"wallet_connect":return le(it,{style:{width:"38px",height:"38px"}});case"coinbase_wallet":return le(ue,{style:{width:"38px",height:"38px"}});default:return le(he,{style:{width:"38px",height:"38px"}})}})((i==null?void 0:i.walletType)||"metamask")]})}),Co(Ul,{children:[le("h3",{children:t?"Wallet updated successfully":"Update your active wallet"}),le("p",{children:a}),o&&le("p",{children:o})]}),le(se,{})]})]})},Ol=yr.div`
|
|
1056
1324
|
display: flex;
|
|
1057
1325
|
flex-direction: column;
|
|
1058
1326
|
align-items: center;
|
|
@@ -1060,11 +1328,11 @@ Resources:
|
|
|
1060
1328
|
margin-left: 27px;
|
|
1061
1329
|
margin-right: 27px;
|
|
1062
1330
|
gap: 24px;
|
|
1063
|
-
`,
|
|
1331
|
+
`,Ul=yr.div`
|
|
1064
1332
|
display: flex;
|
|
1065
1333
|
flex-direction: column;
|
|
1066
1334
|
gap: 8px;
|
|
1067
|
-
`,
|
|
1335
|
+
`,Dl=yr.div`
|
|
1068
1336
|
display: flex;
|
|
1069
1337
|
flex-direction: column;
|
|
1070
1338
|
justify-content: center;
|
|
@@ -1087,19 +1355,19 @@ Resources:
|
|
|
1087
1355
|
left: -19px;
|
|
1088
1356
|
top: -19px;
|
|
1089
1357
|
}
|
|
1090
|
-
`;import{
|
|
1358
|
+
`;import{useEffect as Gl,useState as kn}from"react";import Rt,{css as Bl}from"styled-components";import{Fragment as Zl,jsx as Ne,jsxs as bo}from"react/jsx-runtime";var Tn=()=>{let{authenticated:t,getAccessToken:e,user:o}=z(),{walletProxy:r,closePrivyModal:i}=_(),{navigate:n,data:s}=v(),[a,p]=kn(!1),[u,x]=kn("");Gl(()=>{t||(n("LANDING"),g(new Error("User must be authenticated before signing with a Privy wallet")))},[t]);let{message:L,onSuccess:m,onFailure:g,uiOptions:f}=s.signMessage,c=ye(o),S=!r,M={title:f.title||"Sign message",description:f.description||"Signing this message will not cost you any fees.",buttonText:f.buttonText||"Sign and continue"};return bo(Zl,{children:[Ne(A,{onClose:()=>i({shouldCallAuthOnSuccess:!1})}),bo(Vl,{children:[bo("div",{children:[Ne(Y,{title:M.title,description:M.description}),Ne(Hl,{children:L}),Ne(zl,{fail:!0,children:u})]}),Ne(jl,{success:a,loading:S,disabled:a,onClick:async()=>{let k=await e();if(k&&!S&&c)try{let{signature:b}=await r.sign({accessToken:k,address:c==null?void 0:c.address,message:L});x(""),m(b),p(!0),setTimeout(()=>{i({shouldCallAuthOnSuccess:!1})},re)}catch(b){x("An error has occurred, please try again."),g(b)}},children:a?bo($l,{children:[Ne(nt,{style:{height:"0.9rem",width:"0.9rem"},strokeWidth:2})," ",Ne("span",{children:"Success"})]}):M.buttonText})]}),Ne($,{protectedByPrivy:!0})]})},Vl=Rt.div`
|
|
1091
1359
|
display: flex;
|
|
1092
1360
|
height: 100%;
|
|
1093
1361
|
flex-direction: column;
|
|
1094
1362
|
justify-content: space-between;
|
|
1095
|
-
`,
|
|
1363
|
+
`,Hl=Rt.div`
|
|
1096
1364
|
background-color: var(--light-theme-bg-2);
|
|
1097
1365
|
border-radius: 8px;
|
|
1098
1366
|
padding: 12px;
|
|
1099
1367
|
text-align: left;
|
|
1100
1368
|
max-height: 310px;
|
|
1101
1369
|
overflow: scroll;
|
|
1102
|
-
`,
|
|
1370
|
+
`,zl=Rt.div`
|
|
1103
1371
|
line-height: 20px;
|
|
1104
1372
|
height: 20px;
|
|
1105
1373
|
font-size: 13px;
|
|
@@ -1108,201 +1376,20 @@ Resources:
|
|
|
1108
1376
|
justify-content: flex-start;
|
|
1109
1377
|
width: 100%;
|
|
1110
1378
|
margin-top: 4px;
|
|
1111
|
-
|
|
1379
|
+
`,$l=Rt.span`
|
|
1112
1380
|
display: flex;
|
|
1113
1381
|
align-items: center;
|
|
1114
1382
|
gap: 8px;
|
|
1115
|
-
`,
|
|
1383
|
+
`,jl=Rt(Ie)`
|
|
1116
1384
|
transition: color 350ms ease, background-color 350ms ease;
|
|
1117
1385
|
|
|
1118
|
-
${t=>t.success&&
|
|
1386
|
+
${t=>t.success&&Bl`
|
|
1119
1387
|
&&&& {
|
|
1120
1388
|
background-color: var(--success-light);
|
|
1121
1389
|
color: var(--light-theme-bg-1);
|
|
1122
1390
|
}
|
|
1123
1391
|
`}
|
|
1124
|
-
`;import
|
|
1125
|
-
display: flex;
|
|
1126
|
-
flex-direction: column;
|
|
1127
|
-
width: 100%;
|
|
1128
|
-
gap: 8px;
|
|
1129
|
-
|
|
1130
|
-
${it}[data-height='medium'] & {
|
|
1131
|
-
margin-top: 22px;
|
|
1132
|
-
}
|
|
1133
|
-
|
|
1134
|
-
@media (max-width: 440px) {
|
|
1135
|
-
margin-top: 8px;
|
|
1136
|
-
margin-bottom: 8px;
|
|
1137
|
-
}
|
|
1138
|
-
|
|
1139
|
-
> div:nth-child(2) {
|
|
1140
|
-
display: flex;
|
|
1141
|
-
justify-content: space-between;
|
|
1142
|
-
width: 100%;
|
|
1143
|
-
border-radius: 6px;
|
|
1144
|
-
|
|
1145
|
-
> input {
|
|
1146
|
-
border: 1px solid var(--border-color-1);
|
|
1147
|
-
background: var(--light-theme-bg-1);
|
|
1148
|
-
border-radius: 6px;
|
|
1149
|
-
padding: 8px 10px;
|
|
1150
|
-
height: 58px;
|
|
1151
|
-
width: 46px;
|
|
1152
|
-
text-align: center;
|
|
1153
|
-
font-size: 18px;
|
|
1154
|
-
}
|
|
1155
|
-
|
|
1156
|
-
> input:disabled {
|
|
1157
|
-
/* Use --light-theme-bg-2 instead of disabled-bg for consistency with
|
|
1158
|
-
the callout bubble */
|
|
1159
|
-
background: var(--light-theme-bg-2);
|
|
1160
|
-
}
|
|
1161
|
-
|
|
1162
|
-
> input:focus {
|
|
1163
|
-
border: 1px solid var(--primary-color);
|
|
1164
|
-
}
|
|
1165
|
-
|
|
1166
|
-
> input:invalid {
|
|
1167
|
-
border: 1px solid var(--fail-dark);
|
|
1168
|
-
}
|
|
1169
|
-
|
|
1170
|
-
> input.fail {
|
|
1171
|
-
border: 1px solid var(--fail-dark);
|
|
1172
|
-
animation: shake 180ms;
|
|
1173
|
-
animation-iteration-count: 2;
|
|
1174
|
-
}
|
|
1175
|
-
}
|
|
1176
|
-
|
|
1177
|
-
@keyframes shake {
|
|
1178
|
-
0% {
|
|
1179
|
-
transform: translate(1px, 0px);
|
|
1180
|
-
}
|
|
1181
|
-
33% {
|
|
1182
|
-
transform: translate(-1px, 0px);
|
|
1183
|
-
}
|
|
1184
|
-
67% {
|
|
1185
|
-
transform: translate(-1px, 0px);
|
|
1186
|
-
}
|
|
1187
|
-
100% {
|
|
1188
|
-
transform: translate(1px, 0px);
|
|
1189
|
-
}
|
|
1190
|
-
}
|
|
1191
|
-
`,El=mr.div`
|
|
1192
|
-
line-height: 20px;
|
|
1193
|
-
height: 20px;
|
|
1194
|
-
font-size: 13px;
|
|
1195
|
-
color: ${t=>t.fail?"var(--fail-dark)":"var(--light-theme-fg-3)"};
|
|
1196
|
-
display: flex;
|
|
1197
|
-
justify-content: flex-end;
|
|
1198
|
-
width: 100%;
|
|
1199
|
-
`,Ll=({onClick:t,disabled:e,...o})=>{let[r,n]=Rt(!1),[i,s]=Rt();return ml(()=>{e&&i&&clearTimeout(i),s(void 0)},[e]),hr(Al,{onClick:a=>{i&&clearTimeout(i),n(!0),t==null||t(a),s(setTimeout(()=>n(!1),1e3))},justGenerated:r,disabled:e,...o,children:[r?lt(at,{style:{height:"14px",width:"14px"},strokeWidth:"2"}):lt(fi,{style:{height:"14px",width:"14px"}}),r?"Generated":"Generate"," PIN"]})},Al=mr.button`
|
|
1200
|
-
display: flex;
|
|
1201
|
-
align-items: center;
|
|
1202
|
-
gap: 6px;
|
|
1203
|
-
|
|
1204
|
-
&& {
|
|
1205
|
-
margin: 8px 2px;
|
|
1206
|
-
font-size: 14px;
|
|
1207
|
-
color: ${t=>t.justGenerated?"var(--light-theme-fg-1)":"var(--light-theme-fg-3)"};
|
|
1208
|
-
font-weight: ${t=>t.justGenerated?"medium":"normal"};
|
|
1209
|
-
transition: color 350ms ease;
|
|
1210
|
-
|
|
1211
|
-
:focus,
|
|
1212
|
-
:active {
|
|
1213
|
-
background-color: transparent;
|
|
1214
|
-
border: none;
|
|
1215
|
-
outline: none;
|
|
1216
|
-
box-shadow: none;
|
|
1217
|
-
}
|
|
1218
|
-
|
|
1219
|
-
:hover {
|
|
1220
|
-
color: ${t=>t.justGenerated?"var(--light-theme-fg-1)":"var(--light-theme-fg-2)"};
|
|
1221
|
-
}
|
|
1222
|
-
|
|
1223
|
-
:active {
|
|
1224
|
-
color: var(--light-theme-fg-1);
|
|
1225
|
-
font-weight: medium;
|
|
1226
|
-
}
|
|
1227
|
-
|
|
1228
|
-
@media (max-width: 440px) {
|
|
1229
|
-
margin: 12px 2px;
|
|
1230
|
-
}
|
|
1231
|
-
}
|
|
1232
|
-
|
|
1233
|
-
svg {
|
|
1234
|
-
width: 14px;
|
|
1235
|
-
height: 14px;
|
|
1236
|
-
}
|
|
1237
|
-
`;import{useEffect as Wl,useState as gr}from"react";import Ci from"styled-components";import{useState as Sl}from"react";import Pl from"styled-components";import{jsx as fr}from"react/jsx-runtime";var wi=({color:t,...e})=>fr("svg",{version:"1.1",id:"Layer_1",xmlns:"http://www.w3.org/2000/svg",xmlnsXlink:"http://www.w3.org/1999/xlink",x:"0px",y:"0px",viewBox:"0 0 115.77 122.88",xmlSpace:"preserve",...e,children:fr("g",{children:fr("path",{fill:t||"currentColor",className:"st0",d:"M89.62,13.96v7.73h12.19h0.01v0.02c3.85,0.01,7.34,1.57,9.86,4.1c2.5,2.51,4.06,5.98,4.07,9.82h0.02v0.02 v73.27v0.01h-0.02c-0.01,3.84-1.57,7.33-4.1,9.86c-2.51,2.5-5.98,4.06-9.82,4.07v0.02h-0.02h-61.7H40.1v-0.02 c-3.84-0.01-7.34-1.57-9.86-4.1c-2.5-2.51-4.06-5.98-4.07-9.82h-0.02v-0.02V92.51H13.96h-0.01v-0.02c-3.84-0.01-7.34-1.57-9.86-4.1 c-2.5-2.51-4.06-5.98-4.07-9.82H0v-0.02V13.96v-0.01h0.02c0.01-3.85,1.58-7.34,4.1-9.86c2.51-2.5,5.98-4.06,9.82-4.07V0h0.02h61.7 h0.01v0.02c3.85,0.01,7.34,1.57,9.86,4.1c2.5,2.51,4.06,5.98,4.07,9.82h0.02V13.96L89.62,13.96z M79.04,21.69v-7.73v-0.02h0.02 c0-0.91-0.39-1.75-1.01-2.37c-0.61-0.61-1.46-1-2.37-1v0.02h-0.01h-61.7h-0.02v-0.02c-0.91,0-1.75,0.39-2.37,1.01 c-0.61,0.61-1,1.46-1,2.37h0.02v0.01v64.59v0.02h-0.02c0,0.91,0.39,1.75,1.01,2.37c0.61,0.61,1.46,1,2.37,1v-0.02h0.01h12.19V35.65 v-0.01h0.02c0.01-3.85,1.58-7.34,4.1-9.86c2.51-2.5,5.98-4.06,9.82-4.07v-0.02h0.02H79.04L79.04,21.69z M105.18,108.92V35.65v-0.02 h0.02c0-0.91-0.39-1.75-1.01-2.37c-0.61-0.61-1.46-1-2.37-1v0.02h-0.01h-61.7h-0.02v-0.02c-0.91,0-1.75,0.39-2.37,1.01 c-0.61,0.61-1,1.46-1,2.37h0.02v0.01v73.27v0.02h-0.02c0,0.91,0.39,1.75,1.01,2.37c0.61,0.61,1.46,1,2.37,1v-0.02h0.01h61.7h0.02 v0.02c0.91,0,1.75-0.39,2.37-1.01c0.61-0.61,1-1.46,1-2.37h-0.02V108.92L105.18,108.92z"})})});import{jsx as vi,jsxs as Tl}from"react/jsx-runtime";var bo=t=>{let[e,o]=Sl(!1);return Tl(kl,{onClick:()=>{o(!0),navigator.clipboard.writeText(t.text),setTimeout(()=>o(!1),1500)},justCopied:e,children:[e?vi(at,{style:{height:"14px",width:"14px"},strokeWidth:"2"}):vi(wi,{style:{height:"14px",width:"14px"}}),e?"Copied":"Copy"," ",t.itemName?t.itemName:"to Clipboard"]})},kl=Pl.button`
|
|
1238
|
-
display: flex;
|
|
1239
|
-
align-items: center;
|
|
1240
|
-
gap: 6px;
|
|
1241
|
-
|
|
1242
|
-
&& {
|
|
1243
|
-
margin: 8px 2px;
|
|
1244
|
-
font-size: 14px;
|
|
1245
|
-
color: ${t=>t.justCopied?"var(--light-theme-fg-1)":"var(--light-theme-fg-3)"};
|
|
1246
|
-
font-weight: ${t=>t.justCopied?"medium":"normal"};
|
|
1247
|
-
transition: color 350ms ease;
|
|
1248
|
-
|
|
1249
|
-
:focus,
|
|
1250
|
-
:active {
|
|
1251
|
-
background-color: transparent;
|
|
1252
|
-
border: none;
|
|
1253
|
-
outline: none;
|
|
1254
|
-
box-shadow: none;
|
|
1255
|
-
}
|
|
1256
|
-
|
|
1257
|
-
:hover {
|
|
1258
|
-
color: ${t=>t.justCopied?"var(--light-theme-fg-1)":"var(--light-theme-fg-2)"};
|
|
1259
|
-
}
|
|
1260
|
-
|
|
1261
|
-
:active {
|
|
1262
|
-
color: var(--light-theme-fg-1);
|
|
1263
|
-
font-weight: medium;
|
|
1264
|
-
}
|
|
1265
|
-
|
|
1266
|
-
@media (max-width: 440px) {
|
|
1267
|
-
margin: 12px 2px;
|
|
1268
|
-
}
|
|
1269
|
-
}
|
|
1270
|
-
|
|
1271
|
-
svg {
|
|
1272
|
-
width: 14px;
|
|
1273
|
-
height: 14px;
|
|
1274
|
-
}
|
|
1275
|
-
`;import{Fragment as Ml,jsx as Le,jsxs as xo}from"react/jsx-runtime";var bi=()=>{let{authenticated:t,getAccessToken:e,user:o}=$(),{walletProxy:r,refreshUser:n,closePrivyModal:i}=S(),{navigate:s,data:a}=v(),[p,u]=gr(null),[b,E]=gr(""),[m,g]=gr(!1),{onFailure:f}=a.createWallet;Wl(()=>{t||(s("LANDING"),f(new Error("User must be authenticated before creating a Privy wallet")))},[t]);let c=()=>{f(new Error("User exited before creating a wallet")),i({shouldCallAuthOnSuccess:!1})},k=_=>{u(_)},I=we(o),T=I?()=>{g(!0),setTimeout(()=>{g(!1),s("EMBEDDED_WALLET_CREATED_SCREEN")},350)}:async()=>{g(!0);let _=await e();if(_&&p!==null)try{await(r==null?void 0:r.create({accessToken:_,recoveryPin:p})),E(""),await n()}catch(M){E("An error has occurred, please try again."),console.error(M)}finally{g(!1)}},A=!!I;return xo(Ml,{children:[Le(L,{onClose:c}),xo(Il,{children:[xo("div",{children:[Le(X,{title:A?"Secure your PIN":"Set your PIN",description:A?"Don\u2019t lose this PIN. You\u2019ll need it to access your wallet across devices.":"To finish setting up your account, please set up a PIN."}),Le(yi,{onChange:k,disabled:m,readOnly:A,errorReasonOverride:b}),A?Le(bo,{text:p||""}):null]}),xo(Rl,{children:[Le("h4",{children:"Why am I doing this?"}),A?Le("p",{children:"This PIN allows you to access your wallet across devices. If you lose it, there is no way to recover your wallet."}):Le("p",{children:"A digital wallet is being created on this device for your account. This PIN allows you to access it across devices."})]}),Le(Ie,{loading:m||!r,disabled:!p,onClick:T,warn:A,children:A?"I have saved my PIN":"Create your wallet"})]}),Le(j,{protectedByPrivy:!0})]})},Il=Ci.div`
|
|
1276
|
-
display: flex;
|
|
1277
|
-
height: 100%;
|
|
1278
|
-
flex-direction: column;
|
|
1279
|
-
justify-content: space-between;
|
|
1280
|
-
`,Rl=Ci.div`
|
|
1281
|
-
display: flex;
|
|
1282
|
-
flex-direction: column;
|
|
1283
|
-
justify-content: flex-start;
|
|
1284
|
-
align-items: flex-start;
|
|
1285
|
-
text-align: left;
|
|
1286
|
-
gap: 8px;
|
|
1287
|
-
padding: 16px;
|
|
1288
|
-
margin-top: 16px;
|
|
1289
|
-
margin-bottom: 16px;
|
|
1290
|
-
width: 100%;
|
|
1291
|
-
background: var(--light-theme-bg-2);
|
|
1292
|
-
border-radius: var(--border-radius-md);
|
|
1293
|
-
|
|
1294
|
-
&& h4 {
|
|
1295
|
-
color: var(--light-theme-fg-3);
|
|
1296
|
-
font-size: 14px;
|
|
1297
|
-
text-decoration: underline;
|
|
1298
|
-
font-weight: medium;
|
|
1299
|
-
}
|
|
1300
|
-
|
|
1301
|
-
&& p {
|
|
1302
|
-
color: var(--light-theme-fg-3);
|
|
1303
|
-
font-size: 14px;
|
|
1304
|
-
}
|
|
1305
|
-
`;import Nl from"styled-components";import{jsx as Ul}from"react/jsx-runtime";var xi=t=>{let e=t.accentColor||"#696ffd";return Ul(Ol,{accentColor:e,children:t.children})},Ol=Nl.div`
|
|
1392
|
+
`;import ql from"styled-components";import{jsx as Jl}from"react/jsx-runtime";var Wn=t=>{let e=t.accentColor||"#696ffd";return Jl(Kl,{accentColor:e,children:t.children})},Kl=ql.div`
|
|
1306
1393
|
/*! Modified from https://unpkg.com/tailwindcss@3.2.3/src/css/preflight.css */
|
|
1307
1394
|
|
|
1308
1395
|
*,
|
|
@@ -1543,7 +1630,7 @@ Resources:
|
|
|
1543
1630
|
|
|
1544
1631
|
--primary-color: ${t=>t.accentColor};
|
|
1545
1632
|
/* Same as primary color, but can be used with rgba */
|
|
1546
|
-
--primary-color-rgb: ${t=>`${
|
|
1633
|
+
--primary-color-rgb: ${t=>`${Vt(t.accentColor).r}, ${Vt(t.accentColor).g}, ${Vt(t.accentColor).b}`};
|
|
1547
1634
|
--primary-color-bg-1: rgba(var(--primary-color-rgb), 0.15);
|
|
1548
1635
|
--primary-color-bg-2: rgba(var(--primary-color-rgb), 0.2);
|
|
1549
1636
|
|
|
@@ -1614,94 +1701,7 @@ Resources:
|
|
|
1614
1701
|
display: none;
|
|
1615
1702
|
}
|
|
1616
1703
|
}
|
|
1617
|
-
`;import{
|
|
1618
|
-
display: flex;
|
|
1619
|
-
flex-direction: column;
|
|
1620
|
-
align-items: center;
|
|
1621
|
-
justify-content: center;
|
|
1622
|
-
margin-left: 27px;
|
|
1623
|
-
margin-right: 27px;
|
|
1624
|
-
gap: 24px;
|
|
1625
|
-
`,Gl=Lo.div`
|
|
1626
|
-
display: flex;
|
|
1627
|
-
flex-direction: column;
|
|
1628
|
-
gap: 8px;
|
|
1629
|
-
`,Bl=Lo.div`
|
|
1630
|
-
display: flex;
|
|
1631
|
-
flex-direction: column;
|
|
1632
|
-
justify-content: center;
|
|
1633
|
-
align-items: center;
|
|
1634
|
-
width: 100%;
|
|
1635
|
-
height: 82px;
|
|
1636
|
-
|
|
1637
|
-
> div {
|
|
1638
|
-
position: relative;
|
|
1639
|
-
}
|
|
1640
|
-
|
|
1641
|
-
> div > span {
|
|
1642
|
-
position: absolute;
|
|
1643
|
-
left: -41px;
|
|
1644
|
-
top: -41px;
|
|
1645
|
-
}
|
|
1646
|
-
|
|
1647
|
-
> div > svg {
|
|
1648
|
-
position: absolute;
|
|
1649
|
-
left: -19px;
|
|
1650
|
-
top: -19px;
|
|
1651
|
-
}
|
|
1652
|
-
`,Vl=Lo.button`
|
|
1653
|
-
&& {
|
|
1654
|
-
padding: 12px 16px;
|
|
1655
|
-
font-weight: 500;
|
|
1656
|
-
text-align: center;
|
|
1657
|
-
color: var(--primary-color);
|
|
1658
|
-
background-color: var(--primary-color-bg-1);
|
|
1659
|
-
border-radius: var(--border-radius-sm);
|
|
1660
|
-
min-width: 144px;
|
|
1661
|
-
opacity: ${t=>t.visible?"1":"0"};
|
|
1662
|
-
transition: opacity 200ms;
|
|
1663
|
-
}
|
|
1664
|
-
`;import{Fragment as zl,jsx as dt,jsxs as $l}from"react/jsx-runtime";var Si=()=>{let{app:t}=v();return $l(zl,{children:[dt(L,{},"header"),dt(nt,{title:"Connect your email",description:`Add your email to your ${t==null?void 0:t.name} account`,icon:dt(io,{})}),dt(ke,{children:dt(so,{stacked:!0})}),dt(j,{protectedByPrivy:!0})]})};import{Fragment as jl,jsx as pt,jsxs as Zl}from"react/jsx-runtime";var Pi=()=>{let{app:t}=v();return Zl(jl,{children:[pt(L,{},"header"),pt(nt,{title:"Connect your phone",description:`Add your number to your ${t==null?void 0:t.name} account`,icon:pt(ao,{})}),pt(ke,{children:pt(lo,{stacked:!0})}),pt(j,{protectedByPrivy:!0})]})};import{Fragment as ql,jsx as Mt,jsxs as ki}from"react/jsx-runtime";var Ti=()=>{let{linkingHint:t}=S(),{app:e}=v(),o=t?`Select the wallet with ${De(t)} and follow the instructions to reconnect your wallet${e!=null&&e.name?` to ${e.name}.`:"."}`:`Link a wallet to your ${e==null?void 0:e.name} account`;return ki(ql,{children:[Mt(L,{},"header"),Mt(Tn,{title:`${t?"Reconnect":"Connect"} your wallet`,description:o}),ki(ke,{children:[Mt(Yt,{}),Mt(Xt,{})]}),Mt(j,{protectedByPrivy:!0})]})};import ht from"styled-components";import{jsx as h,jsxs as V}from"react/jsx-runtime";var Wi=()=>V("svg",{width:"332",height:"128",viewBox:"0 0 332 128",fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[V("g",{clipPath:"url(#clip0_39_1593)",children:[h("g",{clipPath:"url(#clip1_39_1593)",children:V("g",{filter:"url(#filter0_b_39_1593)",children:[V("linearGradient",{id:"background-gradient",children:[h("stop",{offset:"0%",stopColor:"#fed8f4",children:h("animate",{attributeName:"stop-color",values:"#fed8f4; #ffe5d0; #fed8f4;",dur:"4.97s",repeatCount:"indefinite"})}),h("stop",{offset:"33%",stopColor:"#ffe5d0",children:h("animate",{attributeName:"stop-color",values:"#ffe5d0; #ffcdf3; #ffe5d0;",dur:"5.11s",repeatCount:"indefinite"})}),h("stop",{offset:"67%",stopColor:"#ffcdf3",children:h("animate",{attributeName:"stop-color",values:"#ffcdf3; #d0fcf5; #ffcdf3;",dur:"4.95s",repeatCount:"indefinite"})}),h("stop",{offset:"100%",stopColor:"#d0fcf5",children:h("animate",{attributeName:"stop-color",values:"#d0fcf5; #fed8f4; #d0fcf5;",dur:"5.03s",repeatCount:"indefinite"})})]}),h("rect",{width:301,height:112,transform:"translate(16 16)",fill:"url(#background-gradient)"})]})}),h("path",{d:"M183.83 53.8229L203.497 101.003C203.617 101.287 203.707 101.571 203.781 101.87C203.856 102.169 203.901 102.483 203.916 102.797C203.931 103.111 203.916 103.44 203.886 103.769C203.856 104.098 203.781 104.426 203.692 104.755C203.453 105.592 203.034 106.34 202.511 106.983C201.988 107.626 201.315 108.179 200.583 108.582C199.851 108.986 199.044 109.255 198.207 109.375C197.37 109.494 196.533 109.434 195.711 109.195C195.427 109.121 195.158 109.016 194.904 108.896C194.65 108.777 194.411 108.642 194.172 108.493C193.933 108.343 193.723 108.179 193.529 107.999C193.335 107.82 193.141 107.641 192.976 107.431L159.963 68.3985C160.187 68.6526 160.441 68.8918 160.725 69.1011C161.009 69.3104 161.353 69.4898 161.726 69.6542C162.1 69.8187 162.518 69.9383 162.967 70.028C163.415 70.1177 163.908 70.1775 164.446 70.2074C166.001 70.2821 167.719 70.028 169.483 69.5047C171.246 68.9815 173.099 68.1892 174.833 67.1726C176.567 66.1561 178.196 64.9751 179.6 63.6446C181.005 62.3141 182.141 60.9238 182.948 59.4737C183.262 58.9057 183.516 58.3525 183.71 57.8143C183.905 57.2762 184.024 56.7828 184.084 56.3045C184.144 55.8261 184.159 55.3776 184.114 54.959C184.069 54.5404 183.964 54.1518 183.815 53.793L183.83 53.8229Z",fill:"url(#paint0_linear_39_1593)"}),h("path",{d:"M161.158 60.2668C162.04 59.0559 163.116 57.9198 164.326 56.8733C165.537 55.8269 166.852 54.9 168.227 54.0927C169.602 53.2855 171.066 52.5978 172.531 52.0746C173.995 51.5514 175.505 51.1926 176.94 51.058C178.374 50.9235 179.689 51.0132 180.736 51.3122C181.782 51.6111 182.678 52.1643 183.261 52.8818C183.844 53.5994 184.173 54.5711 184.143 55.6624C184.113 56.7537 183.74 58.0992 182.947 59.5044C182.155 60.9097 180.99 62.3597 179.6 63.6753C178.21 64.9908 176.566 66.2017 174.832 67.2033C173.099 68.2049 171.275 68.9973 169.482 69.5354C167.689 70.0736 166 70.2978 164.446 70.238C162.891 70.1783 161.726 69.8045 160.844 69.2065C159.962 68.6086 159.424 67.8461 159.185 66.9043C158.946 65.9625 158.991 64.946 159.335 63.8098C159.678 62.6737 160.276 61.5076 161.173 60.2818L161.158 60.2668Z",fill:"url(#paint1_linear_39_1593)"}),h("path",{d:"M326.717 118.136L252.77 127.539L235.18 119.003L310.771 102.693L326.717 118.136Z",fill:"url(#paint2_linear_39_1593)"}),h("path",{d:"M310.771 102.694L235.18 119.003L242.069 98.9263L313.117 73.333L310.771 102.694Z",fill:"url(#paint3_linear_39_1593)"}),h("path",{d:"M327.241 91.1526L326.718 118.136L310.771 102.694L313.118 73.333L327.241 91.1526Z",fill:"url(#paint4_linear_39_1593)"}),h("path",{d:"M99.4197 23.8945L122.45 47.9331L64.1199 132.801L36.0684 110.093L99.4346 23.8945H99.4197Z",fill:"url(#paint5_linear_39_1593)"}),h("path",{d:"M36.0685 110.077L64.1201 132.785L27.789 117.612L6.0293 100.465L36.0834 110.062L36.0685 110.077Z",fill:"url(#paint6_linear_39_1593)"}),h("path",{d:"M55.7664 36.3772L99.4204 23.8945L36.0542 110.093L6 100.495L55.7515 36.3772H55.7664Z",fill:"url(#paint7_linear_39_1593)"}),h("path",{d:"M106.012 124.249C109.046 126.133 127.189 132.74 135.737 135.805C137.859 136.567 139.623 134.983 139.1 132.8C136.992 123.965 132.449 105.204 130.91 101.975C131.672 104.172 127.473 110.182 121.016 115.952C114.545 121.738 108.119 125.251 106.012 124.249V124.249Z",fill:"url(#paint8_linear_39_1593)"}),h("path",{d:"M105.638 123.981C105.638 123.981 105.698 124.041 105.743 124.071C105.788 124.101 105.833 124.146 105.877 124.175C105.922 124.205 105.967 124.235 106.027 124.265C108.134 125.267 114.56 121.769 121.032 115.968C127.488 110.183 131.687 104.188 130.925 101.991C130.91 101.931 130.88 101.871 130.85 101.841C130.82 101.796 130.791 101.736 130.761 101.692C130.731 101.647 130.716 101.617 130.686 101.587C129.117 99.8229 122.227 103.411 115.308 109.6C108.388 115.789 104.069 122.247 105.638 123.996V123.981Z",fill:"url(#paint9_linear_39_1593)"}),h("path",{d:"M290.057 16.9137C289.713 21.3537 287.89 25.5844 284.886 29.1573C277.817 37.6335 264.187 42.4323 248.167 37.7083C218.695 29.0227 200.313 19.799 183.963 17.138C179.779 16.4653 178.613 10.919 182.14 8.55705C200.238 -3.59678 237.466 -23.9578 268.013 -10.6529C284.527 -3.46224 290.789 7.22655 290.057 16.9137Z",fill:"url(#paint10_linear_39_1593)"})]}),V("defs",{children:[V("filter",{id:"filter0_b_39_1593",x:"-76",y:"-76",width:"485",height:"296",filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[h("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),h("feGaussianBlur",{in:"BackgroundImageFix",stdDeviation:"46"}),h("feComposite",{in2:"SourceAlpha",operator:"in",result:"effect1_backgroundBlur_39_1593"}),h("feBlend",{mode:"normal",in:"SourceGraphic",in2:"effect1_backgroundBlur_39_1593",result:"shape"})]}),V("linearGradient",{id:"paint0_linear_39_1593",x1:"187.753",y1:"56.8365",x2:"173.389",y2:"118.39",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#2D2068"}),h("stop",{offset:"1",stopColor:"#4F3D9A"})]}),V("linearGradient",{id:"paint1_linear_39_1593",x1:"162.8",y1:"69.9911",x2:"171.997",y2:"54.1167",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint2_linear_39_1593",x1:"248.905",y1:"127.208",x2:"254.292",y2:"100.947",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint3_linear_39_1593",x1:"246.866",y1:"118.395",x2:"265.49",y2:"76.3396",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint4_linear_39_1593",x1:"321.183",y1:"75.7837",x2:"300.239",y2:"117.543",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#2D2068"}),h("stop",{offset:"1",stopColor:"#4F3D9A"})]}),V("linearGradient",{id:"paint5_linear_39_1593",x1:"90.6771",y1:"29.8515",x2:"62.6626",y2:"150.379",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#2D2068"}),h("stop",{offset:"1",stopColor:"#4F3D9A"})]}),V("linearGradient",{id:"paint6_linear_39_1593",x1:"14.7397",y1:"132.355",x2:"27.4593",y2:"102.104",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint7_linear_39_1593",x1:"20.0079",y1:"108.945",x2:"64.5521",y2:"45.0635",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint8_linear_39_1593",x1:"126.988",y1:"103.836",x2:"119.744",y2:"142.156",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#2D2068"}),h("stop",{offset:"1",stopColor:"#4F3D9A"})]}),V("linearGradient",{id:"paint9_linear_39_1593",x1:"109.17",y1:"124.125",x2:"121.135",y2:"106.662",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),V("linearGradient",{id:"paint10_linear_39_1593",x1:"196.556",y1:"38.8404",x2:"216.303",y2:"-13.8631",gradientUnits:"userSpaceOnUse",children:[h("stop",{stopColor:"#4F3D9A"}),h("stop",{offset:"1",stopColor:"#160B45"})]}),h("clipPath",{id:"clip0_39_1593",children:h("rect",{width:"332",height:"128",fill:"white"})}),h("clipPath",{id:"clip1_39_1593",children:h("rect",{x:"16",y:"16",width:"301",height:"112",rx:"8",fill:"white"})})]})]});import{Fragment as t1,jsx as fe,jsxs as ut}from"react/jsx-runtime";var Ii=()=>{var b;let{user:t}=$(),{closePrivyModal:e}=S(),{data:o}=v(),r=we(t),{onSuccess:n,onFailure:i}=o.createWallet,s=()=>{r?(n(r),e({shouldCallAuthOnSuccess:!1})):i(new Error("Failed to create wallet"))},a="Your digital wallet",p="You\u2019re all set! This wallet is all yours and can only ever be accessed by you.",u=De(r.address);return ut(t1,{children:[fe(L,{onClose:s}),ut(Kl,{children:[ut("div",{children:[fe(X,{title:a,description:p}),ut(Jl,{children:[fe(Wi,{}),ut(Yl,{children:[fe("p",{children:((b=t==null?void 0:t.email)==null?void 0:b.address)||""}),ut(Xl,{children:[fe(Ql,{children:u})," ",fe(Qt,{color:"var(--light-theme-bg-1)"})]})]})]}),fe(e1,{children:fe(bo,{text:r.address,itemName:"Address"})})]}),fe(Ie,{onClick:s,children:"I\u2019m all set"})]}),fe(j,{protectedByPrivy:!0})]})},Kl=ht.div`
|
|
1665
|
-
display: flex;
|
|
1666
|
-
height: 100%;
|
|
1667
|
-
flex-direction: column;
|
|
1668
|
-
justify-content: space-between;
|
|
1669
|
-
|
|
1670
|
-
@media (max-width: 440px) {
|
|
1671
|
-
gap: 24px;
|
|
1672
|
-
}
|
|
1673
|
-
`,Jl=ht.div`
|
|
1674
|
-
width: 100%;
|
|
1675
|
-
background-color: #160b45;
|
|
1676
|
-
border-radius: 8px;
|
|
1677
|
-
margin-bottom: 8px;
|
|
1678
|
-
svg {
|
|
1679
|
-
width: 100%;
|
|
1680
|
-
height: auto;
|
|
1681
|
-
}
|
|
1682
|
-
`,Yl=ht.div`
|
|
1683
|
-
display: flex;
|
|
1684
|
-
text-align: left;
|
|
1685
|
-
flex-direction: column;
|
|
1686
|
-
padding: 22px 16px 16px 16px;
|
|
1687
|
-
width: 100%;
|
|
1688
|
-
|
|
1689
|
-
> p {
|
|
1690
|
-
font-size: 14px;
|
|
1691
|
-
color: var(--light-theme-bg-1);
|
|
1692
|
-
opacity: 0.65;
|
|
1693
|
-
}
|
|
1694
|
-
`,Xl=ht.div`
|
|
1695
|
-
display: flex;
|
|
1696
|
-
justify-content: space-between;
|
|
1697
|
-
width: 100%;
|
|
1698
|
-
`,Ql=ht.span`
|
|
1699
|
-
font-size: 17px;
|
|
1700
|
-
color: #fff;
|
|
1701
|
-
`,e1=ht.div`
|
|
1702
|
-
display: flex;
|
|
1703
|
-
justify-content: center;
|
|
1704
|
-
`;import{disableBodyScroll as i1,clearAllBodyScrollLocks as s1}from"body-scroll-lock";import{jsx as W,jsxs as Ri}from"react/jsx-runtime";var a1=()=>{let{ready:t}=$(),{isLinking:e}=S(),{ready:o,currentScreen:r,app:n}=v(),i=!!(n!=null&&n.walletAuth),s=!!((n==null?void 0:n.emailAuth)||(n==null?void 0:n.smsAuth)),a=i!==s,p;return["AWAITING_CONNECTION","AWAITING_OAUTH_SCREEN","ALLOWLIST_REJECTION_SCREEN","SETTING_ACTIVE_WALLET"].includes(r)||a&&r==="LANDING"?p="compact":"WALLET_EDUCATION"===r?p="full":e?p="medium":p="full",!t||!o?Ri(it,{"data-height":p,children:[W(L,{}),W(d1,{children:W(_t,{})}),W(se,{})]}):Ri(it,{"data-height":p,children:[r==="LANDING"&&W(Sn,{}),r==="AWAITING_PASSWORDLESS_CODE"&&W(Nn,{}),r==="SETTING_ACTIVE_WALLET"&&W(li,{}),r==="WALLET_EDUCATION"&&W(Yn,{}),r==="AWAITING_CONNECTION"&&W(ri,{}),r==="AWAITING_OAUTH_SCREEN"&&W(_i,{}),r==="ALLOWLIST_REJECTION_SCREEN"&&W(Gn,{}),r==="INSTALL_METAMASK_SCREEN"&&W(ii,{}),r==="INSTALL_COINBASE_WALLET_SCREEN"&&W(di,{}),r==="LINK_EMAIL_SCREEN"&&W(Si,{}),r==="LINK_PHONE_SCREEN"&&W(Pi,{}),r==="LINK_WALLET_SCREEN"&&W(Ti,{}),r==="EMBEDDED_WALLET_SCREEN"&&W(bi,{}),r==="EMBEDDED_WALLET_CREATED_SCREEN"&&W(Ii,{}),r==="SIGN_REQUEST_SCREEN"&&W(hi,{})]})},Mi=()=>{let{app:t}=v();return r1.createPortal(W(c1,{id:"privy-dialog",children:W(xi,{accentColor:t==null?void 0:t.accentColor,children:W(a1,{})})}),document.body)},l1=({children:t,...e})=>{let o=o1(null);return n1(()=>{var n;(n=document==null?void 0:document.activeElement)==null||n.blur();let r=(document==null?void 0:document.getElementById("root"))||(document==null?void 0:document.getElementById("__next"));if(!!r)return r.setAttribute("inert","true"),i1(o==null?void 0:o.current),()=>{let i=(document==null?void 0:document.getElementById("root"))||(document==null?void 0:document.getElementById("__next"));!i||(i.removeAttribute("inert"),s1())}},[e.open,e.onClose]),W("dialog",{open:!0,role:"dialog",...e,ref:o,children:t})},c1=wr(l1)`
|
|
1704
|
+
`;import{jsx as T,jsxs as In}from"react/jsx-runtime";var o1=()=>{let{ready:t}=z(),{isLinking:e}=_(),{ready:o,currentScreen:r,app:i}=v(),n=!!(i!=null&&i.walletAuth),s=!!((i==null?void 0:i.emailAuth)||(i==null?void 0:i.smsAuth)),a=n!==s,p;return["AWAITING_CONNECTION","AWAITING_OAUTH_SCREEN","ALLOWLIST_REJECTION_SCREEN","SETTING_ACTIVE_WALLET"].includes(r)||a&&r==="LANDING"?p="compact":"WALLET_EDUCATION"===r?p="full":e?p="medium":p="full",!t||!o?In(tt,{"data-height":p,children:[T(A,{}),T(n1,{children:T(Et,{})}),T(se,{})]}):In(tt,{"data-height":p,children:[r==="LANDING"&&T(fn,{}),r==="AWAITING_PASSWORDLESS_CODE"&&T(bi,{}),r==="SETTING_ACTIVE_WALLET"&&T(Sn,{}),r==="WALLET_EDUCATION"&&T(Zi,{}),r==="AWAITING_CONNECTION"&&T(Ai,{}),r==="AWAITING_OAUTH_SCREEN"&&T(An,{}),r==="ALLOWLIST_REJECTION_SCREEN"&&T(ci,{}),r==="INSTALL_METAMASK_SCREEN"&&T(en,{}),r==="INSTALL_COINBASE_WALLET_SCREEN"&&T(Xi,{}),r==="LINK_EMAIL_SCREEN"&&T(wn,{}),r==="LINK_PHONE_SCREEN"&&T(vn,{}),r==="LINK_WALLET_SCREEN"&&T(bn,{}),r==="EMBEDDED_WALLET_SCREEN"&&T(Ui,{}),r==="EMBEDDED_WALLET_CREATED_SCREEN"&&T(Wi,{}),r==="SIGN_REQUEST_SCREEN"&&T(Tn,{})]})},Rn=()=>{let{app:t}=v();return t1.createPortal(T(i1,{id:"privy-dialog",children:T(Wn,{accentColor:t==null?void 0:t.accentColor,children:T(o1,{})})}),document.body)},r1=({children:t,...e})=>{let o=Ql(null);return e1(()=>{var i;(i=document==null?void 0:document.activeElement)==null||i.blur();let r=(document==null?void 0:document.getElementById("root"))||(document==null?void 0:document.getElementById("__next"));if(!!r)return r.setAttribute("inert","true"),Yl(o==null?void 0:o.current),()=>{let n=(document==null?void 0:document.getElementById("root"))||(document==null?void 0:document.getElementById("__next"));!n||(n.removeAttribute("inert"),Xl())}},[e.open,e.onClose]),T("dialog",{open:!0,role:"dialog",...e,ref:o,children:t})},i1=wr(r1)`
|
|
1705
1705
|
position: fixed;
|
|
1706
1706
|
top: 0;
|
|
1707
1707
|
left: 0;
|
|
@@ -1716,7 +1716,7 @@ Resources:
|
|
|
1716
1716
|
z-index: 999999;
|
|
1717
1717
|
-webkit-backdrop-filter: blur(3px);
|
|
1718
1718
|
backdrop-filter: blur(3px);
|
|
1719
|
-
`,
|
|
1719
|
+
`,tt=wr.div`
|
|
1720
1720
|
display: flex;
|
|
1721
1721
|
flex-direction: column;
|
|
1722
1722
|
text-align: center;
|
|
@@ -1753,10 +1753,10 @@ Resources:
|
|
|
1753
1753
|
min-height: 0;
|
|
1754
1754
|
}
|
|
1755
1755
|
}
|
|
1756
|
-
`,
|
|
1756
|
+
`,n1=wr.div`
|
|
1757
1757
|
display: flex;
|
|
1758
1758
|
flex-direction: column;
|
|
1759
1759
|
align-items: center;
|
|
1760
1760
|
justify-content: center;
|
|
1761
1761
|
height: 100%;
|
|
1762
|
-
`;import{jsx as Ao,jsxs as
|
|
1762
|
+
`;import{useRef as s1,useEffect as a1}from"react";var xo=class{constructor(){this.callbacks={}}enqueue(e,o){this.callbacks[e]=o}dequeue(e,o){let r=this.callbacks[o];if(!r)throw new Error(`cannot dequeue ${e} event: no event found for id ${o}`);switch(delete this.callbacks[o],e){case"privy:iframe:ready":return r;case"privy:wallet:create":return r;case"privy:wallet:sign":return r;case"privy:wallet:recover":return r;default:throw new Error(`invalid wallet event type ${e}`)}}};import{jsx as p1}from"react/jsx-runtime";var l1=function(t){return()=>`id-${t++}`}(0);function c1(t){return typeof t.event=="string"&&/^privy:.+/.test(t.event)}function Eo(t){return t.error!==void 0}var Mt=new xo;function Lo(t,e,o){let r=o.contentWindow;if(!r)throw new Error("iframe not initialized");return new Promise((i,n)=>{let s=l1();Mt.enqueue(s,{resolve:i,reject:n}),r.postMessage({id:s,event:t,data:e},"*")})}function d1(t){switch(t.event){case"privy:iframe:ready":let e=Mt.dequeue(t.event,t.id);return Eo(t)?e.reject(new Error(t.error.message)):e.resolve(t.data);case"privy:wallet:create":let o=Mt.dequeue(t.event,t.id);return Eo(t)?o.reject(new Error(t.error.message)):o.resolve(t.data);case"privy:wallet:sign":let r=Mt.dequeue(t.event,t.id);return Eo(t)?r.reject(new Error(t.error.message)):r.resolve(t.data);case"privy:wallet:recover":let i=Mt.dequeue(t.event,t.id);return Eo(t)?i.reject(new Error(t.error.message)):i.resolve(t.data)}}function Mn(t){let e=s1(null);return a1(()=>{let o=e.current;if(!o)return;function r(a){a&&a.origin===t.origin&&c1(a.data)&&d1(a.data)}let i={create(a){return Lo("privy:wallet:create",a,o)},sign(a){return Lo("privy:wallet:sign",a,o)},recover(a){return Lo("privy:wallet:recover",a,o)}};window.addEventListener("message",r);let n=()=>t.onLoad(i),s=(...a)=>{console.error("privy iframe failed to load: ",...a),t.onLoadFailed()};return $r(()=>Lo("privy:iframe:ready",{},o)).then(n,s),()=>window.removeEventListener("message",r)},[e.current]),p1("iframe",{ref:e,width:"0",height:"0",style:{visibility:"hidden"},src:jr(t.origin,`/apps/${t.appId}/embedded-wallets`)})}import{jsx as Ao,jsxs as On}from"react/jsx-runtime";function h1(t){return typeof t=="string"&&t.length===25}var Nt;function m1(){if(!Nt){let t=Z.get(qe);return Promise.resolve(t||null)}return Nt.getAccessToken()}var f1=t=>{if(!h1(t.appId))throw new y("Cannot initialize the Privy provider with an invalid Privy app ID");return Nt||(Nt=new bt({appId:t.appId,apiURL:Po})),Ao(y1,{...t,client:Nt})},g1=t=>{let e=!!(t!=null&&t.emailAuth),o=!!(t!=null&&t.smsAuth);return e&&o&&(console.warn("Enabling both email and SMS passwordless is not currently supported. Disabling SMS."),o=!1),{email:e,sms:o,wallet:!!(t!=null&&t.walletAuth),google:!!(t!=null&&t.googleOAuth),twitter:!!(t!=null&&t.twitterOAuth),discord:!!(t!=null&&t.discordOAuth),github:!!(t!=null&&t.githubOAuth)}},y1=t=>{let e=t.client,[o,r]=te(!1),[i,n]=te(!1),[s,a]=te(!1),[p,u]=te(null),[x,L]=te(!1),[m,g]=te(null),[f,c]=te(!1),[S,M]=te(null),[k,b]=te(null),[W,G]=te(null),[K,I]=te({accentColor:"#696ffd",theme:"System",showWalletLoginFirst:!0,allowlistConfig:{errorTitle:null,errorDetail:null,errorCtaText:null,errorCtaLink:null},walletAuth:!0,emailAuth:!0,smsAuth:!1,googleOAuth:!1,twitterOAuth:!1,discordOAuth:!1,githubOAuth:!1,termsAndConditionsUrl:null,privacyPolicyUrl:null}),[P,ie]=te(!1),[Ae,D]=te({}),F=g1(K),R=l=>{l&&g(l),r(!0)},ce=l=>{let d=t.createPrivyWalletOnLogin===!0;D({login:{promptCreatePrivyWalletFlow:d}}),d&&ie(!0),R(l)};Nn(()=>{async function l(){let d=await e.getAppSettings();I(d),e.connectors.initialize(),Oe();let N=await e.getAuthenticatedUser();a(!!N),u(N),n(!0)}l()},[e]);let Oe=()=>{let l=new URLSearchParams(window.location.search),d=l.get("privy_oauth_code"),N=l.get("privy_oauth_state"),_e=l.get("privy_oauth_provider");d&&N&&_e&&(e.startAuthFlow(new Ze(_e,d,N)),ce("AWAITING_OAUTH_SCREEN"))};Nn(()=>{i&&s&&p===null&&e.getAuthenticatedUser().then(u)},[i,s,p,e]);let mt=()=>{c(!0),R("LINK_WALLET_SCREEN")},Ot={ready:i,authenticated:s,user:p,walletConnectors:e.connectors,linkWallet:mt,linkEmail:()=>{c(!0),R("LINK_EMAIL_SCREEN")},linkPhone:()=>{c(!0),R("LINK_PHONE_SCREEN")},linkGoogle:async()=>{await H.initLoginWithOAuth("google")},linkTwitter:async()=>{await H.initLoginWithOAuth("twitter")},linkDiscord:async()=>{await H.initLoginWithOAuth("discord")},linkGithub:async()=>{await H.initLoginWithOAuth("github")},login:()=>{if(i&&s){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}ce()},logout:async()=>{await e.logout(),u(null),a(!1),g(null),c(!1),r(!1)},getAccessToken:()=>e.getAccessToken(),getEthereumProvider:()=>e.connectors.getEthereumProvider(),getEthersProvider:()=>new u1(new fe(e.connectors.getEthereumProvider())),getWeb3jsProvider:()=>new Ft(e.connectors.getEthereumProvider()),unlinkWallet:async l=>{let d=await e.unlinkWallet(l);return u(d),d},unlinkEmail:async l=>{let d=await e.unlinkEmail(l);return u(d),d},unlinkPhone:async l=>{let d=await e.unlinkPhone(l);return u(d),d},unlinkGoogle:async l=>{let d=await e.unlinkOAuth("google",l);return u(d),d},unlinkTwitter:async l=>{let d=await e.unlinkOAuth("twitter",l);return u(d),d},unlinkDiscord:async l=>{let d=await e.unlinkOAuth("discord",l);return u(d),d},unlinkGithub:async l=>{let d=await e.unlinkOAuth("github",l);return u(d),d},setActiveWallet:async l=>{if(!p)return;let d=e.connectors.getConnectorByAddress(l);if(!d){b(l),mt();return}M({address:l,walletType:d.walletType,success:!1}),R("SETTING_ACTIVE_WALLET"),e.setActiveWallet(l,p).then(N=>{u(N),M({address:l,walletType:d.walletType,success:!0})}).catch(N=>{N instanceof y&&N.message==="Error setting the active wallet."&&(b(l),mt()),M({address:l,walletType:d.walletType,success:!1,error:N.message})})},forkSession:()=>e.forkSession(),createWallet:()=>new Promise((l,d)=>{if(!s||!p){d(new Error("User must be authenticated before creating a Privy wallet"));return}if(ye(p)){d(new Error("Only one Privy wallet per user is currently allowed"));return}ie(!0),D({createWallet:{onSuccess:l,onFailure:d}}),R("EMBEDDED_WALLET_SCREEN")}),signMessage:(l,d)=>new Promise((N,_e)=>{if(!s||!p){_e(new Error("User must be authenticated before signing with a Privy wallet"));return}if(!ye(p)){_e(new Error("Must have a Privy wallet before signing"));return}if(typeof l!="string"||l.length<1){_e(new Error("Message must be a non-empty string"));return}ie(!0),D({signMessage:{message:l,onSuccess:N,onFailure:_e,uiOptions:d||{}}}),R("SIGN_REQUEST_SCREEN")})},H=(()=>({isLinking:f,linkingHint:k,activeStatus:S,getAuthFlow:()=>e.authFlow,getAuthMeta:()=>{var l;return(l=e.authFlow)==null?void 0:l.meta},closePrivyModal:(l={shouldCallAuthOnSuccess:!0})=>{var N;let d=i&&s&&p;l.shouldCallAuthOnSuccess&&d&&((N=t.onSuccess)==null||N.call(t,p,x)),e.authFlow=void 0,b(null),g(null),c(!1),M(null),L(!1),r(!1)},initLoginWithWallet:l=>{if(!e.connectors)throw new y("Connector not initialized");l||(l="metamask"),e.startAuthFlow(new gt(e.connectors,l))},loginWithWallet:async()=>{if(!(e.authFlow instanceof gt))throw new y("Must initialize SIWE flow first.");let l,d;f?(l=await e.link(),l&&(l=Ct(l))):{user:l,isNewUser:d}=await e.authenticate(),u(l||p||null),L(d||!1),a(!0)},initLoginWithOAuth:async l=>{e.startAuthFlow(new Ze(l));let d=await e.authFlow.getAuthorizationUrl();d&&d.url&&window.location.assign(d.url)},loginWithOAuth:async()=>{if(!(e.authFlow instanceof Ze))throw new y("Must initialize OAuth flow before calling loginWithOAuth");let l,d;i&&s?l=await e.link():{user:l,isNewUser:d}=await e.authenticate(),u(l),L(d||!1),a(!0)},initLoginWithEmail:async l=>{let d=new ft(l);e.startAuthFlow(d),await d.sendCodeEmail()},initLoginWithSms:async l=>{let d=new yt(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 ft)e.authFlow.meta.emailCode=l.trim();else if(e.authFlow instanceof yt)e.authFlow.meta.smsCode=l.trim();else throw new y("Must initialize a passwordless code flow first");let d,N;f?d=await e.link():{user:d,isNewUser:N}=await e.authenticate(),u(d||p||null),L(N||!1),a(!0)},refreshUser:async()=>{let l=await e.getAuthenticatedUser();return u(l),l},walletProxy:W}))();return On(Vo.Provider,{value:Ot,children:[t.children,On(Go.Provider,{value:H,children:[Ao(ei,{appSettings:K,options:F,data:Ae,setModalData:D,initialScreen:m,visible:o,authenticated:s,children:o&&Ao(Rn,{})}),P&&Ao(Mn,{appId:t.appId,origin:Po,onLoad:G,onLoadFailed:()=>null})]})]})};export{fe as AsExternalProvider,vt as ConnectorManager,bt as PrivyClient,f1 as PrivyProvider,de as PrivyProxyProvider,So as VERSION,ge as WalletConnector,m1 as getAccessToken,z as usePrivy};
|