@privy-io/react-auth 1.12.0-beta.1 → 1.12.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +349 -5
- package/dist/{index.cjs.js → index.js} +56 -56
- package/dist/{index.esm.js → index.mjs} +29 -29
- package/package.json +6 -6
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{useEffect as Mt,useState as oe}from"react";import Ft from"axios";import mi from"axios";var B=class extends Error{constructor(o,r){super(o);r instanceof Error&&(this.cause=r)}toString(){return`${this.type}: ${this.message}${this.cause?` [cause: ${this.cause}]`:""}`}},Ye=class extends B{constructor(o,r,i,n){super(i,n);this.type=o;this.status=r}},p=class extends B{constructor(o,r){super(o,r);this.type="client_error"}};var V=class extends B{constructor(o,r){super(o,r);this.type="connector_error"}},T=t=>{if(t instanceof B)return t;if(!mi.isAxiosError(t))return G(t);if(!t.response)return new Ye("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new Ye(e||"ApiError",t.response.status,o||r,t)},G=t=>t instanceof B?t:t instanceof Error?new p(t.message,t):new p(`Internal error: ${t}`);var go="1.12.0-beta.1";var wo="https://api.privy.io/v0",yo=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",Je="4df5e2316331463a9130964bd6078dfa",Co=1e4,be=1400,vo=365*24*60*60,Dt=go,bo="ES256",xo="privy.io",xe="privy:token",Qe="privy:refresh_token",K="privy:active_wallet",Xe="privy:wallet_type",Lo="walletconnect";var et=class{constructor(e,o,r){this.appId=e,this.sdkVersion=Dt,this.session=o,this.defaults=r}async get(e,o){try{return await Ft.get(e,this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw T(r)}}async post(e,o,r){try{return await Ft.post(e,o,this.buildConfig(r))}catch(i){throw T(i)}}async delete(e,o){try{return await Ft.delete(e,this.buildConfig(o))}catch(r){throw T(r)}}buildConfig(e){return e=e||{},e.headers=e.headers||{},e.headers["privy-app-id"]=this.appId,e.headers["privy-client"]=`react-auth:${this.sdkVersion}`,this.session.token!==null&&(e.headers.authorization=`Bearer ${this.session.token}`),{...this.defaults,...e}}};import*as Le from"jose";var re=class{static parse(e){try{return new re(e)}catch{return null}}constructor(e){this.value=e,this._decoded=Le.decodeJwt(e)}get subject(){return this._decoded.sub}get expiration(){return this._decoded.exp}get issuer(){return this._decoded.iss}get audience(){return this._decoded.aud}isExpired(e=0){let o=Date.now(),r=(this.expiration-e)*1e3;return o>=r}async isValid(e,o,r=0){let i=await Le.importSPKI(e,bo);try{return await Le.jwtVerify(this.value,i,{issuer:xo,audience:o,clockTolerance:r}),!0}catch{return!1}}};var ie=class{constructor(e){this.promise=null;this.fn=e}execute(e){return this.promise===null&&(this.promise=(async()=>{try{return await this.fn(e)}finally{this.promise=null}})()),this.promise}};var Vt=class{constructor(){this._cache={}}get(e){return this._cache[e]}put(e,o){o!==void 0?this._cache[e]=o:this.del(e)}del(e){delete this._cache[e]}},Gt=class{get(e){let o=localStorage.getItem(e);return o===null?void 0:JSON.parse(o)}put(e,o){o!==void 0?localStorage.setItem(e,JSON.stringify(o)):this.del(e)}del(e){localStorage.removeItem(e)}};function gi(){return typeof window<"u"&&window.localStorage?new Gt:new Vt}var L=gi();function ce(t){return new Date(t*1e3)}function wi(t){return t.map(e=>{switch(e.type){case"wallet":return{address:e.address,type:e.type,verifiedAt:ce(e.verified_at),chainType:e.chain_type};case"email":return{address:e.address,type:e.type,verifiedAt:ce(e.verified_at)};case"phone":return{number:e.phoneNumber,type:e.type,verifiedAt:ce(e.verified_at)};case"google_oauth":return{subject:e.subject,email:e.email,name:e.name,type:e.type,verifiedAt:ce(e.verified_at)};case"twitter_oauth":return{subject:e.subject,username:e.username,name:e.name,type:e.type,verifiedAt:ce(e.verified_at)};case"discord_oauth":return{subject:e.subject,username:e.username,email:e.email,type:e.type,verifiedAt:ce(e.verified_at)};default:throw new p("Unrecognized account type")}})}function yi(t,e){return e.find(o=>o.type==="wallet"&&o.address===t)}function pe(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function De(t){let e=t.linkedAccounts.map(s=>s.type==="wallet"?s.address:null),r=L.get(K);if(!r||!e.includes(r)){L.del(K);let s=pe(t.linkedAccounts,"wallet");s&&(r=s.address,L.put(K,r))}let i=yi(r,t.linkedAccounts),n=Object.assign({},t);return n.wallet=i&&{address:i.address,chainType:i.chainType,chainId:i.chainId,walletType:i.walletType},n}function Y(t){if(!t)return null;let e=wi(t.linked_accounts),o=pe(e,"wallet"),r=pe(e,"email"),i=pe(e,"phone"),n=pe(e,"google_oauth"),s=pe(e,"twitter_oauth"),c=pe(e,"discord_oauth"),f={id:t.id,createdAt:ce(t.created_at),linkedAccounts:e,email:r&&{address:r==null?void 0:r.address},phone:i&&{number:i==null?void 0:i.number},wallet:o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletType:o.walletType},google:n&&{subject:n.subject,email:n.email,name:n.name},twitter:s&&{subject:s.subject,username:s.username,name:s.name},discord:c&&{subject:c.subject,username:c.username,email:c.email}};return De(f)}var Eo=()=>"/api/v1/sessions",Ao=()=>"/api/v1/sessions/logout",ko=()=>"/api/v1/sessions/fork",_o=()=>"/api/v1/siwe/init",Po=()=>"/api/v1/siwe/authenticate",So=()=>"/api/v1/siwe/link",To=()=>"/api/v1/passwordless/init",Io=()=>"/api/v1/passwordless/authenticate",Ro=()=>"/api/v1/passwordless/link",Mo=()=>"/api/v1/passwordless_sms/init",Wo=()=>"/api/v1/passwordless_sms/authenticate",No=()=>"/api/v1/passwordless_sms/link",Oo=()=>"/api/v1/oauth/init",Uo=()=>"/api/v1/oauth/authenticate",Do=()=>"/api/v1/oauth/link",Fo=()=>"/api/v1/siwe/unlink",Vo=()=>"/api/v1/passwordless/unlink",Go=()=>"/api/v1/passwordless_sms/unlink",Ho=()=>"/api/v1/oauth/unlink";var Ci=30,tt=class{constructor(){this.authenticateOnce=new ie(async e=>this._authenticate(e)),this.linkOnce=new ie(async e=>this._link(e)),this.refreshOnce=new ie(this._refresh.bind(this)),this.destroyOnce=new ie(this._destroy.bind(this)),this.forkSessionOnce=new ie(this._forkSession.bind(this))}get token(){try{let e=L.get(xe);return typeof e=="string"?new re(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=L.get(Qe);return typeof e=="string"?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}hasRefreshCredentials(){return typeof this.token=="string"&&typeof this.refreshToken=="string"}hasActiveToken(){let e=re.parse(this.token);return e!==null&&!e.isExpired(Ci)}async hasValidToken(e,o,r=0){let i=re.parse(this.token);return i!==null&&await i.isValid(e,o,r)}authenticate(e){return this.authenticateOnce.execute(e)}link(e){return this.linkOnce.execute(e)}refresh(){return this.refreshOnce.execute()}forkSession(){return this.forkSessionOnce.execute()}destroy(){return this.destroyOnce.execute()}async _authenticate(e){try{let{token:o,refresh_token:r,user:i,is_new_user:n}=await e.authenticate();return this.storeToken(o),this.storeRefreshToken(r),{user:Y(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),G(o)}}async _link(e){try{let o=await e.link();return Y(o)}catch(o){throw console.warn("Error linking account"),G(o)}}async _refresh(){if(!this.api)throw new p("Session has no API instance");let e=this.token,o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(Eo(),{refresh_token:o});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),Y(r.data.user)}catch(r){throw G(r)}}async _destroy(){var e;try{await((e=this.api)==null?void 0:e.post(Ao(),{refresh_token:this.refreshToken}))}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new p("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(ko(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw G(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),L.del(K)}storeToken(e){typeof e=="string"?L.put(xe,e):L.del(xe)}storeRefreshToken(e){typeof e=="string"?L.put(Qe,e):L.del(Qe)}};import{getAddress as Ai}from"@ethersproject/address";import zo from"@walletconnect/web3-provider";import{ErrorCode as vi}from"@ethersproject/logger";var Ee=class extends V{constructor(){super("Wallet timeout");this.type="wallet_error"}},ot=t=>{if(t instanceof V)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new Ae(t);return t.code===vi.ACTION_REJECTED&&(e.details=ue.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new Ae(t):new V("Unknown connector error",t)},Ht=class extends B{constructor(o,r,i){super(o);this.type="provider_error";this.code=r,this.data=i}},Ae=class extends Ht{constructor(o){var n,s,c;let r=o;super(r.message,r.code,r.data);let i=Object.values(ue).find(f=>f.eipCode===r.code);this.details=i||ue.UNKNOWN_ERROR,r.code===-32002&&((n=r.message)!=null&&n.includes("already pending for origin")?(s=r.message)!=null&&s.includes("wallet_requestPermissions")?this.details=ue.E32002_CONNECTION_ALREADY_PENDING:this.details=ue.E32002_REQUEST_ALREADY_PENDING:(c=r.message)!=null&&c.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=ue.E32002_WALLET_LOCKED))}},bi={ERROR_USER_EXISTS:{message:"User already exists for this address",detail:"Try another address!",retryable:!1},ERROR_TIMED_OUT:{message:"Wallet request timed out",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_CONNECTION:{message:"Could not log in with wallet",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_NOT_ALLOWED:{message:"You don\u2019t have access to this app",detail:"Try with a different address?",retryable:!0}},xi={E32002_CONNECTION_ALREADY_PENDING:{eipCode:-32002,message:"Connection request already pending",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E32002_REQUEST_ALREADY_PENDING:{eipCode:-32002,message:"Resource request already pending",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E32002_WALLET_LOCKED:{eipCode:-32002,message:"Wallet might be locked",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E4001_USER_REJECTED_REQUEST:{eipCode:4001,message:"Signature rejected",detail:"Please try signing again.",retryable:!0}},Li={E4001_DEFAULT_USER_REJECTED_REQUEST:{eipCode:4001,message:"User Rejected Request",detail:"The user rejected the request.",default:!0,retryable:!0},E4100_DEFAULT_UNAUTHORIZED:{eipCode:4100,message:"Unauthorized",detail:"The requested method and/or account has not been authorized by the user.",default:!0,retryable:!1},E4200_DEFAULT_UNSUPPORTED_METHOD:{eipCode:4200,message:"Unsupported Method",detail:"The Provider does not support the requested method.",default:!0,retryable:!1},E4900_DEFAULT_DISCONNECTED:{eipCode:4900,message:"Disconnected",detail:"The Provider is disconnected from all chains.",default:!0,retryable:!0},E4901_DEFAULT_CHAIN_DISCONNECTED:{eipCode:4901,message:"Chain Disconnected",detail:"The Provider is not connected to the requested chain.",default:!0,retryable:!0},E32700_DEFAULT_PARSE_ERROR:{eipCode:-32700,message:"Parse error",detail:"Invalid JSON",default:!0,retryable:!1},E32600_DEFAULT_INVALID_REQUEST:{eipCode:-32600,message:"Invalid request",detail:"JSON is not a valid request object",default:!0,retryable:!1},E32601_DEFAULT_METHOD_NOT_FOUND:{eipCode:-32601,message:"Method not found",detail:"Method does not exist",default:!0,retryable:!1},E32602_DEFAULT_INVALID_PARAMS:{eipCode:-32602,message:"Invalid params",detail:"Invalid method parameters",default:!0,retryable:!1},E32603_DEFAULT_INTERNAL_ERROR:{eipCode:-32603,message:"Internal error",detail:"Internal JSON-RPC error",default:!0,retryable:!0},E32000_DEFAULT_INVALID_INPUT:{eipCode:-32e3,message:"Invalid input",detail:"Missing or invalid parameters",default:!0,retryable:!1},E32001_DEFAULT_RESOURCE_NOT_FOUND:{eipCode:-32001,message:"Resource not found",detail:"Requested resource not found",default:!0,retryable:!1},E32002_DEFAULT_RESOURCE_UNAVAILABLE:{eipCode:-32002,message:"Resource unavailable",detail:"Requested resource not available",default:!0,retryable:!0},E32003_DEFAULT_TRANSACTION_REJECTED:{eipCode:-32003,message:"Transaction rejected",detail:"Transaction creation failed",default:!0,retryable:!0},E32004_DEFAULT_METHOD_NOT_SUPPORTED:{eipCode:-32004,message:"Method not supported",detail:"Method is not implemented",default:!0,retryable:!1},E32005_DEFAULT_LIMIT_EXCEEDED:{eipCode:-32005,message:"Limit exceeded",detail:"Request exceeds defined limit",default:!0,retryable:!1},E32006_DEFAULT_JSON_RPC_VERSION_NOT_SUPPORTED:{eipCode:-32006,message:"JSON-RPC version not supported",detail:"Version of JSON-RPC protocol is not supported",default:!0,retryable:!1}},ue={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Li,...xi},Fe={...bi,...ue};var Ei=12e4,Bt=(t=new Ee,e=Ei)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),ke=class{constructor(e){this.removeListener=(e,o)=>{if(this.walletProvider)return this.walletProvider.removeListener(e,o)};this.setProvider=e=>{this.walletProvider=e,this._subscriptions.forEach(o=>{var r;(r=this.walletProvider)==null||r.on(o.eventName,o.listener)})};this.walletProvider=e,this._subscriptions=[]}on(e,o){if(this.walletProvider)return this.walletProvider.on(e,o);this._subscriptions.push({eventName:e,listener:o})}request(e){if(!this.walletProvider)throw new V(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),Bt()]).catch(o=>{throw ot(o)})}},_e=class extends ke{constructor(o){super(o)}},rt=class extends ke{constructor(e){super(e)}sendAsync(e,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};import{Web3Provider as ki}from"@ethersproject/providers";var Bo=["metamask","coinbase_wallet","wallet_connect"];import _i from"@coinbase/wallet-sdk";var Pi=()=>{let t=`https://mainnet.infura.io/v3/${Je}`,e=1;return new _i({appName:"Privy",darkMode:!1,headlessMode:!1}).makeWeb3Provider(t,e)},zt=()=>{if(!window.ethereum)return!1;if(window.ethereum.isMetaMask)return!0;if(window.ethereum.providers){for(let t of window.ethereum.providers)if(t.isMetaMask)return!0}return!1},nt=()=>{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},it=class{constructor(){this.walletType=null;this.getEthereumProvider=()=>this.ethProvider;this.createSiweMessage=(e,o,r,i,n,s,c)=>`${r} wants you to sign in with your Ethereum account:
|
|
1
|
+
import{useEffect as Mt,useState as oe}from"react";import Ft from"axios";import mi from"axios";var B=class extends Error{constructor(o,r){super(o);r instanceof Error&&(this.cause=r)}toString(){return`${this.type}: ${this.message}${this.cause?` [cause: ${this.cause}]`:""}`}},Qe=class extends B{constructor(o,r,i,n){super(i,n);this.type=o;this.status=r}},p=class extends B{constructor(o,r){super(o,r);this.type="client_error"}};var V=class extends B{constructor(o,r){super(o,r);this.type="connector_error"}},T=t=>{if(t instanceof B)return t;if(!mi.isAxiosError(t))return G(t);if(!t.response)return new Qe("api_error",null,t.message,t);let{type:e,message:o,error:r}=t.response.data;return new Qe(e||"ApiError",t.response.status,o||r,t)},G=t=>t instanceof B?t:t instanceof Error?new p(t.message,t):new p(`Internal error: ${t}`);var go="1.12.0-beta.2";var wo="https://api.privy.io/v0",yo=process.env.NEXT_PUBLIC_PRIVY_AUTH_URL||"https://auth.privy.io",Xe="4df5e2316331463a9130964bd6078dfa",Co=1e4,Le=1400,vo=365*24*60*60,Dt=go,bo="ES256",xo="privy.io",Ee="privy:token",et="privy:refresh_token",K="privy:active_wallet",tt="privy:wallet_type",Lo="walletconnect";var ot=class{constructor(e,o,r){this.appId=e,this.sdkVersion=Dt,this.session=o,this.defaults=r}async get(e,o){try{return await Ft.get(e,this.buildConfig({headers:{"Cache-Control":"no-cache"},...o}))}catch(r){throw T(r)}}async post(e,o,r){try{return await Ft.post(e,o,this.buildConfig(r))}catch(i){throw T(i)}}async delete(e,o){try{return await Ft.delete(e,this.buildConfig(o))}catch(r){throw T(r)}}buildConfig(e){return e=e||{},e.headers=e.headers||{},e.headers["privy-app-id"]=this.appId,e.headers["privy-client"]=`react-auth:${this.sdkVersion}`,this.session.token!==null&&(e.headers.authorization=`Bearer ${this.session.token}`),{...this.defaults,...e}}};import*as Ae from"jose";var re=class{static parse(e){try{return new re(e)}catch{return null}}constructor(e){this.value=e,this._decoded=Ae.decodeJwt(e)}get subject(){return this._decoded.sub}get expiration(){return this._decoded.exp}get issuer(){return this._decoded.iss}get audience(){return this._decoded.aud}isExpired(e=0){let o=Date.now(),r=(this.expiration-e)*1e3;return o>=r}async isValid(e,o,r=0){let i=await Ae.importSPKI(e,bo);try{return await Ae.jwtVerify(this.value,i,{issuer:xo,audience:o,clockTolerance:r}),!0}catch{return!1}}};var ie=class{constructor(e){this.promise=null;this.fn=e}execute(e){return this.promise===null&&(this.promise=(async()=>{try{return await this.fn(e)}finally{this.promise=null}})()),this.promise}};var Vt=class{constructor(){this._cache={}}get(e){return this._cache[e]}put(e,o){o!==void 0?this._cache[e]=o:this.del(e)}del(e){delete this._cache[e]}},Gt=class{get(e){let o=localStorage.getItem(e);return o===null?void 0:JSON.parse(o)}put(e,o){o!==void 0?localStorage.setItem(e,JSON.stringify(o)):this.del(e)}del(e){localStorage.removeItem(e)}};function gi(){return typeof window<"u"&&window.localStorage?new Gt:new Vt}var L=gi();function ce(t){return new Date(t*1e3)}function wi(t){return t.map(e=>{switch(e.type){case"wallet":return{address:e.address,type:e.type,verifiedAt:ce(e.verified_at),chainType:e.chain_type};case"email":return{address:e.address,type:e.type,verifiedAt:ce(e.verified_at)};case"phone":return{number:e.phoneNumber,type:e.type,verifiedAt:ce(e.verified_at)};case"google_oauth":return{subject:e.subject,email:e.email,name:e.name,type:e.type,verifiedAt:ce(e.verified_at)};case"twitter_oauth":return{subject:e.subject,username:e.username,name:e.name,type:e.type,verifiedAt:ce(e.verified_at)};case"discord_oauth":return{subject:e.subject,username:e.username,email:e.email,type:e.type,verifiedAt:ce(e.verified_at)};default:throw new p("Unrecognized account type")}})}function yi(t,e){return e.find(o=>o.type==="wallet"&&o.address===t)}function pe(t,e){return t.sort((o,r)=>r.verifiedAt.getTime()-o.verifiedAt.getTime()),t.find(o=>o.type===e)}function De(t){let e=t.linkedAccounts.map(s=>s.type==="wallet"?s.address:null),r=L.get(K);if(!r||!e.includes(r)){L.del(K);let s=pe(t.linkedAccounts,"wallet");s&&(r=s.address,L.put(K,r))}let i=yi(r,t.linkedAccounts),n=Object.assign({},t);return n.wallet=i&&{address:i.address,chainType:i.chainType,chainId:i.chainId,walletType:i.walletType},n}function Y(t){if(!t)return null;let e=wi(t.linked_accounts),o=pe(e,"wallet"),r=pe(e,"email"),i=pe(e,"phone"),n=pe(e,"google_oauth"),s=pe(e,"twitter_oauth"),c=pe(e,"discord_oauth"),f={id:t.id,createdAt:ce(t.created_at),linkedAccounts:e,email:r&&{address:r==null?void 0:r.address},phone:i&&{number:i==null?void 0:i.number},wallet:o&&{address:o.address,chainType:o.chainType,chainId:o.chainId,walletType:o.walletType},google:n&&{subject:n.subject,email:n.email,name:n.name},twitter:s&&{subject:s.subject,username:s.username,name:s.name},discord:c&&{subject:c.subject,username:c.username,email:c.email}};return De(f)}var Eo=()=>"/api/v1/sessions",Ao=()=>"/api/v1/sessions/logout",ko=()=>"/api/v1/sessions/fork",_o=()=>"/api/v1/siwe/init",Po=()=>"/api/v1/siwe/authenticate",So=()=>"/api/v1/siwe/link",To=()=>"/api/v1/passwordless/init",Io=()=>"/api/v1/passwordless/authenticate",Ro=()=>"/api/v1/passwordless/link",Mo=()=>"/api/v1/passwordless_sms/init",Wo=()=>"/api/v1/passwordless_sms/authenticate",No=()=>"/api/v1/passwordless_sms/link",Oo=()=>"/api/v1/oauth/init",Uo=()=>"/api/v1/oauth/authenticate",Do=()=>"/api/v1/oauth/link",Fo=()=>"/api/v1/siwe/unlink",Vo=()=>"/api/v1/passwordless/unlink",Go=()=>"/api/v1/passwordless_sms/unlink",Ho=()=>"/api/v1/oauth/unlink";var Ci=30,rt=class{constructor(){this.authenticateOnce=new ie(async e=>this._authenticate(e)),this.linkOnce=new ie(async e=>this._link(e)),this.refreshOnce=new ie(this._refresh.bind(this)),this.destroyOnce=new ie(this._destroy.bind(this)),this.forkSessionOnce=new ie(this._forkSession.bind(this))}get token(){try{let e=L.get(Ee);return typeof e=="string"?new re(e).value:null}catch(e){return console.error(e),this.destroyLocalState(),null}}get refreshToken(){try{let e=L.get(et);return typeof e=="string"?e:null}catch(e){return console.error(e),this.destroyLocalState(),null}}hasRefreshCredentials(){return typeof this.token=="string"&&typeof this.refreshToken=="string"}hasActiveToken(){let e=re.parse(this.token);return e!==null&&!e.isExpired(Ci)}async hasValidToken(e,o,r=0){let i=re.parse(this.token);return i!==null&&await i.isValid(e,o,r)}authenticate(e){return this.authenticateOnce.execute(e)}link(e){return this.linkOnce.execute(e)}refresh(){return this.refreshOnce.execute()}forkSession(){return this.forkSessionOnce.execute()}destroy(){return this.destroyOnce.execute()}async _authenticate(e){try{let{token:o,refresh_token:r,user:i,is_new_user:n}=await e.authenticate();return this.storeToken(o),this.storeRefreshToken(r),{user:Y(i),isNewUser:n}}catch(o){throw console.warn("Error authenticating session"),G(o)}}async _link(e){try{let o=await e.link();return Y(o)}catch(o){throw console.warn("Error linking account"),G(o)}}async _refresh(){if(!this.api)throw new p("Session has no API instance");let e=this.token,o=this.refreshToken;if(!e||!o)return null;try{let r=await this.api.post(Eo(),{refresh_token:o});return this.storeToken(r.data.token),this.storeRefreshToken(r.data.refresh_token),Y(r.data.user)}catch(r){throw G(r)}}async _destroy(){var e;try{await((e=this.api)==null?void 0:e.post(Ao(),{refresh_token:this.refreshToken}))}catch{console.warn("Error destroying session")}this.destroyLocalState()}async _forkSession(){if(!this.api)throw new p("Session has no API instance");let e=this.refreshToken;try{let o=await this.api.post(ko(),{refresh_token:e});return this.storeToken(o.data.token),this.storeRefreshToken(o.data.refresh_token),o.data.new_session_refresh_token}catch(o){throw G(o)}}destroyLocalState(){this.storeToken(null),this.storeRefreshToken(null),L.del(K)}storeToken(e){typeof e=="string"?L.put(Ee,e):L.del(Ee)}storeRefreshToken(e){typeof e=="string"?L.put(et,e):L.del(et)}};import{getAddress as Ai}from"@ethersproject/address";import zo from"@walletconnect/web3-provider";import{ErrorCode as vi}from"@ethersproject/logger";var ke=class extends V{constructor(){super("Wallet timeout");this.type="wallet_error"}},it=t=>{if(t instanceof V)return t;if((t==null?void 0:t.code)&&(t==null?void 0:t.reason)){let e=new _e(t);return t.code===vi.ACTION_REJECTED&&(e.details=ue.E4001_USER_REJECTED_REQUEST),e}return t!=null&&t.code?new _e(t):new V("Unknown connector error",t)},Ht=class extends B{constructor(o,r,i){super(o);this.type="provider_error";this.code=r,this.data=i}},_e=class extends Ht{constructor(o){var n,s,c;let r=o;super(r.message,r.code,r.data);let i=Object.values(ue).find(f=>f.eipCode===r.code);this.details=i||ue.UNKNOWN_ERROR,r.code===-32002&&((n=r.message)!=null&&n.includes("already pending for origin")?(s=r.message)!=null&&s.includes("wallet_requestPermissions")?this.details=ue.E32002_CONNECTION_ALREADY_PENDING:this.details=ue.E32002_REQUEST_ALREADY_PENDING:(c=r.message)!=null&&c.includes("Already processing")&&r.message.includes("eth_requestAccounts")&&(this.details=ue.E32002_WALLET_LOCKED))}},bi={ERROR_USER_EXISTS:{message:"User already exists for this address",detail:"Try another address!",retryable:!1},ERROR_TIMED_OUT:{message:"Wallet request timed out",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_CONNECTION:{message:"Could not log in with wallet",detail:"Please try connecting again.",retryable:!0},ERROR_WALLET_NOT_ALLOWED:{message:"You don\u2019t have access to this app",detail:"Try with a different address?",retryable:!0}},xi={E32002_CONNECTION_ALREADY_PENDING:{eipCode:-32002,message:"Connection request already pending",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E32002_REQUEST_ALREADY_PENDING:{eipCode:-32002,message:"Resource request already pending",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E32002_WALLET_LOCKED:{eipCode:-32002,message:"Wallet might be locked",detail:"Don\u2019t see your wallet modal? Check your other browser windows.",retryable:!1},E4001_USER_REJECTED_REQUEST:{eipCode:4001,message:"Signature rejected",detail:"Please try signing again.",retryable:!0}},Li={E4001_DEFAULT_USER_REJECTED_REQUEST:{eipCode:4001,message:"User Rejected Request",detail:"The user rejected the request.",default:!0,retryable:!0},E4100_DEFAULT_UNAUTHORIZED:{eipCode:4100,message:"Unauthorized",detail:"The requested method and/or account has not been authorized by the user.",default:!0,retryable:!1},E4200_DEFAULT_UNSUPPORTED_METHOD:{eipCode:4200,message:"Unsupported Method",detail:"The Provider does not support the requested method.",default:!0,retryable:!1},E4900_DEFAULT_DISCONNECTED:{eipCode:4900,message:"Disconnected",detail:"The Provider is disconnected from all chains.",default:!0,retryable:!0},E4901_DEFAULT_CHAIN_DISCONNECTED:{eipCode:4901,message:"Chain Disconnected",detail:"The Provider is not connected to the requested chain.",default:!0,retryable:!0},E32700_DEFAULT_PARSE_ERROR:{eipCode:-32700,message:"Parse error",detail:"Invalid JSON",default:!0,retryable:!1},E32600_DEFAULT_INVALID_REQUEST:{eipCode:-32600,message:"Invalid request",detail:"JSON is not a valid request object",default:!0,retryable:!1},E32601_DEFAULT_METHOD_NOT_FOUND:{eipCode:-32601,message:"Method not found",detail:"Method does not exist",default:!0,retryable:!1},E32602_DEFAULT_INVALID_PARAMS:{eipCode:-32602,message:"Invalid params",detail:"Invalid method parameters",default:!0,retryable:!1},E32603_DEFAULT_INTERNAL_ERROR:{eipCode:-32603,message:"Internal error",detail:"Internal JSON-RPC error",default:!0,retryable:!0},E32000_DEFAULT_INVALID_INPUT:{eipCode:-32e3,message:"Invalid input",detail:"Missing or invalid parameters",default:!0,retryable:!1},E32001_DEFAULT_RESOURCE_NOT_FOUND:{eipCode:-32001,message:"Resource not found",detail:"Requested resource not found",default:!0,retryable:!1},E32002_DEFAULT_RESOURCE_UNAVAILABLE:{eipCode:-32002,message:"Resource unavailable",detail:"Requested resource not available",default:!0,retryable:!0},E32003_DEFAULT_TRANSACTION_REJECTED:{eipCode:-32003,message:"Transaction rejected",detail:"Transaction creation failed",default:!0,retryable:!0},E32004_DEFAULT_METHOD_NOT_SUPPORTED:{eipCode:-32004,message:"Method not supported",detail:"Method is not implemented",default:!0,retryable:!1},E32005_DEFAULT_LIMIT_EXCEEDED:{eipCode:-32005,message:"Limit exceeded",detail:"Request exceeds defined limit",default:!0,retryable:!1},E32006_DEFAULT_JSON_RPC_VERSION_NOT_SUPPORTED:{eipCode:-32006,message:"JSON-RPC version not supported",detail:"Version of JSON-RPC protocol is not supported",default:!0,retryable:!1}},ue={UNKNOWN_ERROR:{eipCode:0,message:"Unknown error",detail:"Unknown error",retryable:!0},...Li,...xi},Fe={...bi,...ue};var Ei=12e4,Bt=(t=new ke,e=Ei)=>new Promise((o,r)=>setTimeout(()=>{r(t)},e)),he=class{constructor(e){this.removeListener=(e,o)=>{if(this.walletProvider)return this.walletProvider.removeListener(e,o)};this.setProvider=e=>{this.walletProvider=e,this._subscriptions.forEach(o=>{var r;(r=this.walletProvider)==null||r.on(o.eventName,o.listener)})};this.walletProvider=e,this._subscriptions=[]}on(e,o){if(this.walletProvider)return this.walletProvider.on(e,o);this._subscriptions.push({eventName:e,listener:o})}request(e){if(!this.walletProvider)throw new V(`A wallet request of type ${e.method} was made before setting a wallet provider.`);return Promise.race([this.walletProvider.request(e),Bt()]).catch(o=>{throw it(o)})}},me=class extends he{constructor(o){super(o)}},nt=class extends he{constructor(e){super(e)}sendAsync(e,o){throw new Error("sendAsync is no longer supported by EIP-1193. Use the request method instead.")}};import{Web3Provider as ki}from"@ethersproject/providers";var Bo=["metamask","coinbase_wallet","wallet_connect"];import _i from"@coinbase/wallet-sdk";var Pi=()=>{let t=`https://mainnet.infura.io/v3/${Xe}`,e=1;return new _i({appName:"Privy",darkMode:!1,headlessMode:!1}).makeWeb3Provider(t,e)},zt=()=>{if(!window.ethereum)return!1;if(window.ethereum.isMetaMask)return!0;if(window.ethereum.providers){for(let t of window.ethereum.providers)if(t.isMetaMask)return!0}return!1},st=()=>{if(!window.ethereum)return!1;if(window.ethereum.isCoinbaseWallet)return!0;if(window.ethereum.providers){for(let t of window.ethereum.providers)if(t.isCoinbaseWallet)return!0}return!1},Ve=class{constructor(){this.walletType=null;this.getEthereumProvider=()=>this.ethProvider;this.createSiweMessage=(e,o,r,i,n,s,c)=>`${r} wants you to sign in with your Ethereum account:
|
|
2
2
|
${o}
|
|
3
3
|
|
|
4
4
|
${c}
|
|
@@ -9,7 +9,7 @@ Chain ID: ${e}
|
|
|
9
9
|
Nonce: ${s}
|
|
10
10
|
Issued At: ${n}
|
|
11
11
|
Resources:
|
|
12
|
-
- https://privy.io`;this.ethProvider=new ke}initialize(){let e=L.get(Xe);Bo.includes(e)&&(this.walletType=e,this.connect({showPrompt:!1}))}destroy(){this.walletType=null,L.del(Xe),L.del(Lo)}async getConnectedWallet(){let e=this.walletType;if(!e||!await this.isConnected())return null;let o=await this.address(),r=await this.chainId();return{address:o,chainId:r,chainType:"ethereum",walletType:e}}async connect(e){var o;switch(this.walletType){case"metamask":this.ethProvider.setProvider(window.ethereum),(o=window.ethereum.providers)==null||o.forEach(async i=>{i.isMetaMask&&this.ethProvider.setProvider(i)});break;case"coinbase_wallet":this.ethProvider.setProvider(Pi());break;case"wallet_connect":let r=new zo({infuraId:Je});this.ethProvider.setProvider(r);break;default:throw new V(`Unsupported wallet: ${this.walletType}`)}return(!await this.isConnected()||e.showPrompt)&&await this.promptConnection(this.walletType),this.getConnectedWallet()}async isConnected(){switch(this.walletType){case"metamask":return await this.address()!==null;case"coinbase_wallet":return await this.address()!==null;case"wallet_connect":return this.ethProvider.walletProvider.connected;default:throw new V(`Unsupported wallet: ${this.walletType}`)}}async promptConnection(e){try{switch(e){case"metamask":await this.ethProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]}),await this.ethProvider.request({method:"eth_requestAccounts"});break;case"coinbase_wallet":await this.ethProvider.request({method:"eth_requestAccounts"});break;case"wallet_connect":let o=new zo({infuraId:Je});this.ethProvider.setProvider(o),await Promise.race([o.enable(),Bt()]);break;default:throw new V(`Unsupported wallet: ${this.walletType}`)}L.put(Xe,e)}catch(o){throw ot(o)}}async sign(e){return new ki(new _e(this.getEthereumProvider())).getSigner().signMessage(e)}prepareMessage(e,o,r){let i=window.location.host,n=window.location.origin,s="By signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.",c=new Date().toISOString();return this.createSiweMessage(e,o,i,n,c,r,s)}async chainId(){let e=await this.getEthereumProvider().request({method:"eth_chainId"}),o=Number(e);return String(o)}async address(){let e=await this.getEthereumProvider().request({method:"eth_accounts"});return Array.isArray(e)&&e.length>0?Ai(e[0]):null}};var jt,st=class{constructor(e){let o=e.apiURL||wo,r=e.timeout||Co;this.appId=e.appId,this.connector=new it,this.connector.initialize(),jt||(jt=new tt),this.session=jt,this.api=new et(e.appId,this.session,{baseURL:o,timeout:r}),this.session.api=this.api}authenticate(){if(!this.authFlow)throw new p("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new p("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.connector.destroy(),this.authFlow=void 0}startAuthFlow(e){e.api=this.api,this.authFlow=e}async unlinkEmail(e){try{let o=await this.api.post(Vo(),{address:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkPhone(e){try{let o=await this.api.post(Go(),{phoneNumber:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkWallet(e){try{let o=await this.api.post(Fo(),{address:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(Ho(),{provider:e,subject:o});return Y(r.data)}catch(r){throw G(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(){if(this.session.hasActiveToken()){let{verificationKey:e,id:o}=await this.getAppSettings();return await this.session.hasValidToken(e,o,vo)?this.session.token:(await this.logout(),null)}else return this.session.hasRefreshCredentials()?(await this.session.refresh(),this.session.token):null}async getAppSettings(){try{let e=await this.api.get(`/api/v1/apps/${this.appId}`);return{id:e.data.id,name:e.data.name,verificationKey:e.data.verification_key,logoUrl:e.data.logo_url||void 0,theme:e.data.theme,accentColor:e.data.accent_color||void 0,walletAuth:e.data.wallet_auth,emailAuth:e.data.email_auth,smsAuth:e.data.sms_auth,googleOAuth:e.data.google_oauth,twitterOAuth:e.data.twitter_oauth,discordOAuth:e.data.discord_oauth,termsAndConditionsUrl:e.data.terms_and_conditions_url,privacyPolicyUrl:e.data.privacy_policy_url,createdAt:new Date(e.data.created_at*1e3),updatedAt:new Date(e.data.updated_at*1e3)}}catch(e){throw G(e)}}setActiveWallet(e,o){if(!o.linkedAccounts.map(i=>i.type==="wallet"?i.address:null).includes(e))throw new p("Cannot set an unlinked address as active.");return L.put(K,e),De(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as Ns}from"@ethersproject/providers";import{createContext as Si,useContext as Ti}from"react";var m=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var Zt=Si({ready:!1,authenticated:!1,user:null,login:m,linkEmail:m,linkPhone:m,linkWallet:m,linkGoogle:m,linkTwitter:m,linkDiscord:m,logout:m,getAccessToken:m,getEthereumProvider:m,getEthersProvider:m,getWeb3jsProvider:m,unlinkEmail:m,unlinkPhone:m,unlinkWallet:m,unlinkGoogle:m,unlinkTwitter:m,unlinkDiscord:m,setActiveWallet:m,forkSession:m}),N=()=>Ti(Zt);var Ve=class{constructor(e){this.connector=e,this.meta={wallet:this.connector.walletType}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.connector.walletType)throw new p("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Po(),{message:e,signature:o});return{user:r.data.user,token:r.data.token,refresh_token:r.data.refresh_token,is_new_user:r.data.is_new_user}}catch(e){throw T(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.connector.walletType)throw new p("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api);return(await this.api.post(So(),{message:e,signature:o})).data}catch(e){throw T(e)}}async promptConnectAndSign(e){let o=await this.connector.connect({showPrompt:!0}),r=o.address,i=o.chainId,n=await e.post(_o(),{address:r}),s=this.connector.prepareMessage(i,r,n.data.nonce),c=await this.connector.sign(s);return{message:s,signature:c}}getEthereumProvider(){return this.connector.getEthereumProvider()}};var Ge=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new p("Email and email code must be set prior to calling authenticate.");try{let e=Io(),o=await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw T(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new p("Email and email code must be set prior to calling authenticate.");try{let e=Ro();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw T(e)}}async sendCodeEmail(e){if(!this.api)throw new p("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new p("Email must be set when initialzing authentication.");try{let o=To();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw T(o)}}};var He=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new p("phone number and sms code must be set prior to calling authenticate.");try{let e=Wo(),o=await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw T(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new p("phone number and sms code must be set prior to calling authenticate.");try{let e=No();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw T(e)}}async sendSmsCode(e){if(!this.api)throw new p("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new p("phone nNumber must be set when initialzing authentication.");try{let o=Mo();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw T(o)}}};var Pe=class{constructor(e,o,r){this.meta={provider:e},this.meta.authorizationCode=o,this.meta.stateCode=r}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new p("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new p("User denied confirmation during OAuth flow");try{let e=Uo(),o=await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw T(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new p("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new p("User denied confirmation during OAuth flow");try{let e=Do();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw T(e)}}async getAuthorizationUrl(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.provider)throw new p("Provider must be set when initialzing OAuth authentication.");try{let e=Oo();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw T(e)}}};import"wicg-inert";import Ss from"react-dom";import ho from"styled-components";import{createContext as Ri,useContext as Mi,useEffect as Zo,useState as $o}from"react";import{jsx as Ii}from"react/jsx-runtime";function jo(t){return Ii("link",{rel:"prefetch",href:t.src})}import{jsx as Wi,jsxs as Ni}from"react/jsx-runtime";var Ko=Ri({ready:!1,app:null,options:{email:!0,sms:!1,wallet:!0,google:!1,twitter:!1,discord:!1},currentScreen:"LANDING",lastScreen:"LANDING",navigate:m,navigateBack:m}),qo=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=$o(null),[s,c]=$o(null);Zo(()=>{o||n(null)},[o]),Zo(()=>{r||(c("LANDING"),n("LANDING"))},[r]);let f={ready:!!(e!=null&&e.id),app:e,options:t.options,currentScreen:i||"LANDING",lastScreen:s||"LANDING",navigate:h=>{c(i),n(h)},navigateBack:()=>{n(s)}};return Ni(Ko.Provider,{value:f,children:[e&&e.logoUrl&&Wi(jo,{src:e.logoUrl}),t.children]})},w=()=>Mi(Ko);import{useEffect as Pn,useState as Sn}from"react";import je from"styled-components";import Di from"styled-components";import{jsx as Yo}from"react/jsx-runtime";var Jo=({style:t,...e})=>Yo("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Yo("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});import{jsx as Qo}from"react/jsx-runtime";var Xo=({style:t,...e})=>Qo("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Qo("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as Oi,useContext as Ui}from"react";var $t=Oi({isLinking:!1,getAuthMeta:m,getAuthFlow:m,closePrivyModal:m,initLoginWithWallet:m,loginWithWallet:m,loginWithCode:m,loginWithEmail:m,loginWithSms:m,resendEmailCode:m,resendSmsCode:m,initLoginWithOAuth:m,loginWithOAuth:m,handleLoginError:m}),_=()=>Ui($t);import{jsx as J,jsxs as Bi}from"react/jsx-runtime";var Fi=()=>J("div",{}),Vi=({backFn:t})=>J("div",{children:J(Xo,{onClick:t})}),Gi=()=>{let{closePrivyModal:t}=_();return J("div",{children:J("div",{children:J(Jo,{onClick:t})})})};var E=({backFn:t})=>Bi(Hi,{children:[t?J(Vi,{backFn:t}):J(Fi,{}),J(Gi,{})]}),Hi=Di.div`
|
|
12
|
+
- https://privy.io`;this.ethProvider=new he}initialize(){let e=L.get(tt);Bo.includes(e)&&(this.walletType=e,this.connect({showPrompt:!1}))}destroy(){this.walletType=null,L.del(tt),L.del(Lo)}async getConnectedWallet(){let e=this.walletType;if(!e||!await this.isConnected())return null;let o=await this.address(),r=await this.chainId();return{address:o,chainId:r,chainType:"ethereum",walletType:e}}async connect(e){var o;switch(this.walletType){case"metamask":this.ethProvider.setProvider(window.ethereum),(o=window.ethereum.providers)==null||o.forEach(async i=>{i.isMetaMask&&this.ethProvider.setProvider(i)});break;case"coinbase_wallet":this.ethProvider.setProvider(Pi());break;case"wallet_connect":let r=new zo({infuraId:Xe});this.ethProvider.setProvider(r);break;default:throw new V(`Unsupported wallet: ${this.walletType}`)}return(!await this.isConnected()||e.showPrompt)&&await this.promptConnection(this.walletType),this.getConnectedWallet()}async isConnected(){switch(this.walletType){case"metamask":return await this.address()!==null;case"coinbase_wallet":return await this.address()!==null;case"wallet_connect":return this.ethProvider.walletProvider.connected;default:throw new V(`Unsupported wallet: ${this.walletType}`)}}async promptConnection(e){try{switch(e){case"metamask":await this.ethProvider.request({method:"wallet_requestPermissions",params:[{eth_accounts:{}}]}),await this.ethProvider.request({method:"eth_requestAccounts"});break;case"coinbase_wallet":await this.ethProvider.request({method:"eth_requestAccounts"});break;case"wallet_connect":let o=new zo({infuraId:Xe});this.ethProvider.setProvider(o),await Promise.race([o.enable(),Bt()]);break;default:throw new V(`Unsupported wallet: ${this.walletType}`)}L.put(tt,e)}catch(o){throw it(o)}}async sign(e){return new ki(new me(this.getEthereumProvider())).getSigner().signMessage(e)}prepareMessage(e,o,r){let i=window.location.host,n=window.location.origin,s="By signing, you are proving you own this wallet and logging in. This does not initiate a transaction or cost any fees.",c=new Date().toISOString();return this.createSiweMessage(e,o,i,n,c,r,s)}async chainId(){let e=await this.getEthereumProvider().request({method:"eth_chainId"}),o=Number(e);return String(o)}async address(){let e=await this.getEthereumProvider().request({method:"eth_accounts"});return Array.isArray(e)&&e.length>0?Ai(e[0]):null}};var Zt,Ge=class{constructor(e){let o=e.apiURL||wo,r=e.timeout||Co;this.appId=e.appId,this.connector=new Ve,this.connector.initialize(),Zt||(Zt=new rt),this.session=Zt,this.api=new ot(e.appId,this.session,{baseURL:o,timeout:r}),this.session.api=this.api}authenticate(){if(!this.authFlow)throw new p("No auth flow in progress.");return this.session.authenticate(this.authFlow)}link(){if(!this.authFlow)throw new p("No auth flow in progress.");return this.session.link(this.authFlow)}async logout(){await this.session.destroy(),this.connector.destroy(),this.authFlow=void 0}startAuthFlow(e){e.api=this.api,this.authFlow=e}async unlinkEmail(e){try{let o=await this.api.post(Vo(),{address:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkPhone(e){try{let o=await this.api.post(Go(),{phoneNumber:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkWallet(e){try{let o=await this.api.post(Fo(),{address:e});return Y(o.data)}catch(o){throw G(o)}}async unlinkOAuth(e,o){try{let r=await this.api.post(Ho(),{provider:e,subject:o});return Y(r.data)}catch(r){throw G(r)}}async getAuthenticatedUser(){return this.session.hasRefreshCredentials()?this.session.refresh():null}async getAccessToken(){if(this.session.hasActiveToken()){let{verificationKey:e,id:o}=await this.getAppSettings();return await this.session.hasValidToken(e,o,vo)?this.session.token:(await this.logout(),null)}else return this.session.hasRefreshCredentials()?(await this.session.refresh(),this.session.token):null}async getAppSettings(){try{let e=await this.api.get(`/api/v1/apps/${this.appId}`);return{id:e.data.id,name:e.data.name,verificationKey:e.data.verification_key,logoUrl:e.data.logo_url||void 0,theme:e.data.theme,accentColor:e.data.accent_color||void 0,walletAuth:e.data.wallet_auth,emailAuth:e.data.email_auth,smsAuth:e.data.sms_auth,googleOAuth:e.data.google_oauth,twitterOAuth:e.data.twitter_oauth,discordOAuth:e.data.discord_oauth,termsAndConditionsUrl:e.data.terms_and_conditions_url,privacyPolicyUrl:e.data.privacy_policy_url,createdAt:new Date(e.data.created_at*1e3),updatedAt:new Date(e.data.updated_at*1e3)}}catch(e){throw G(e)}}setActiveWallet(e,o){if(!o.linkedAccounts.map(i=>i.type==="wallet"?i.address:null).includes(e))throw new p("Cannot set an unlinked address as active.");return L.put(K,e),De(o)}async forkSession(){return await this.session.forkSession()}};import{Web3Provider as Ns}from"@ethersproject/providers";import{createContext as Si,useContext as Ti}from"react";var m=()=>{throw new Error("You need to wrap your application with the <PrivyProvider> initialized with your app id.")};var jt=Si({ready:!1,authenticated:!1,user:null,walletConnector:null,login:m,linkEmail:m,linkPhone:m,linkWallet:m,linkGoogle:m,linkTwitter:m,linkDiscord:m,logout:m,getAccessToken:m,getEthereumProvider:m,getEthersProvider:m,getWeb3jsProvider:m,unlinkEmail:m,unlinkPhone:m,unlinkWallet:m,unlinkGoogle:m,unlinkTwitter:m,unlinkDiscord:m,setActiveWallet:m,forkSession:m}),N=()=>Ti(jt);var He=class{constructor(e){this.connector=e,this.meta={wallet:this.connector.walletType}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.connector.walletType)throw new p("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api),r=await this.api.post(Po(),{message:e,signature:o});return{user:r.data.user,token:r.data.token,refresh_token:r.data.refresh_token,is_new_user:r.data.is_new_user}}catch(e){throw T(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.connector.walletType)throw new p("Wallet must be specified");try{let{message:e,signature:o}=await this.promptConnectAndSign(this.api);return(await this.api.post(So(),{message:e,signature:o})).data}catch(e){throw T(e)}}async promptConnectAndSign(e){let o=await this.connector.connect({showPrompt:!0}),r=o.address,i=o.chainId,n=await e.post(_o(),{address:r}),s=this.connector.prepareMessage(i,r,n.data.nonce),c=await this.connector.sign(s);return{message:s,signature:c}}getEthereumProvider(){return this.connector.getEthereumProvider()}};var Be=class{constructor(e){this.meta={email:e}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new p("Email and email code must be set prior to calling authenticate.");try{let e=Io(),o=await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw T(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.email||!this.meta.emailCode)throw new p("Email and email code must be set prior to calling authenticate.");try{let e=Ro();return(await this.api.post(e,{email:this.meta.email,code:this.meta.emailCode})).data}catch(e){throw T(e)}}async sendCodeEmail(e){if(!this.api)throw new p("Auth flow has no API instance");if(e&&(this.meta.email=e),!this.meta.email)throw new p("Email must be set when initialzing authentication.");try{let o=To();return(await this.api.post(o,{email:this.meta.email})).data}catch(o){throw T(o)}}};var ze=class{constructor(e){this.meta={phoneNumber:e}}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new p("phone number and sms code must be set prior to calling authenticate.");try{let e=Wo(),o=await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw T(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.phoneNumber||!this.meta.smsCode)throw new p("phone number and sms code must be set prior to calling authenticate.");try{let e=No();return(await this.api.post(e,{phoneNumber:this.meta.phoneNumber,code:this.meta.smsCode})).data}catch(e){throw T(e)}}async sendSmsCode(e){if(!this.api)throw new p("Auth flow has no API instance");if(e&&(this.meta.phoneNumber=e),!this.meta.phoneNumber)throw new p("phone nNumber must be set when initialzing authentication.");try{let o=Mo();return(await this.api.post(o,{phoneNumber:this.meta.phoneNumber})).data}catch(o){throw T(o)}}};var Pe=class{constructor(e,o,r){this.meta={provider:e},this.meta.authorizationCode=o,this.meta.stateCode=r}isActive(){return!!(this.meta.authorizationCode&&this.meta.stateCode&&this.meta.provider)}async authenticate(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new p("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling authenticate.");if(this.meta.authorizationCode==="undefined")throw new p("User denied confirmation during OAuth flow");try{let e=Uo(),o=await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode});return{user:o.data.user,token:o.data.token,refresh_token:o.data.refresh_token,is_new_user:o.data.is_new_user}}catch(e){throw T(e)}}async link(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.authorizationCode||!this.meta.stateCode)throw new p("[OAuth AuthFlow] Authorization and state codes code must be set prior to calling link.");if(this.meta.authorizationCode==="undefined")throw new p("User denied confirmation during OAuth flow");try{let e=Do();return(await this.api.post(e,{authorization_code:this.meta.authorizationCode,state_code:this.meta.stateCode})).data}catch(e){throw T(e)}}async getAuthorizationUrl(){if(!this.api)throw new p("Auth flow has no API instance");if(!this.meta.provider)throw new p("Provider must be set when initialzing OAuth authentication.");try{let e=Oo();return(await this.api.post(e,{provider:this.meta.provider,redirect_to:window.location.href})).data}catch(e){throw T(e)}}};import"wicg-inert";import Ss from"react-dom";import ho from"styled-components";import{createContext as Ri,useContext as Mi,useEffect as jo,useState as $o}from"react";import{jsx as Ii}from"react/jsx-runtime";function Zo(t){return Ii("link",{rel:"prefetch",href:t.src})}import{jsx as Wi,jsxs as Ni}from"react/jsx-runtime";var Ko=Ri({ready:!1,app:null,options:{email:!0,sms:!1,wallet:!0,google:!1,twitter:!1,discord:!1},currentScreen:"LANDING",lastScreen:"LANDING",navigate:m,navigateBack:m}),qo=t=>{let e=t.appSettings,o=t.authenticated,r=t.visible,[i,n]=$o(null),[s,c]=$o(null);jo(()=>{o||n(null)},[o]),jo(()=>{r||(c("LANDING"),n("LANDING"))},[r]);let f={ready:!!(e!=null&&e.id),app:e,options:t.options,currentScreen:i||"LANDING",lastScreen:s||"LANDING",navigate:h=>{c(i),n(h)},navigateBack:()=>{n(s)}};return Ni(Ko.Provider,{value:f,children:[e&&e.logoUrl&&Wi(Zo,{src:e.logoUrl}),t.children]})},w=()=>Mi(Ko);import{useEffect as Pn,useState as Sn}from"react";import $e from"styled-components";import Di from"styled-components";import{jsx as Yo}from"react/jsx-runtime";var Jo=({style:t,...e})=>Yo("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Yo("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M6 18L18 6M6 6l12 12"})});import{jsx as Qo}from"react/jsx-runtime";var Xo=({style:t,...e})=>Qo("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",strokeWidth:"1.5",stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Qo("path",{strokeLinecap:"round",strokeLinejoin:"round",d:"M10.5 19.5L3 12m0 0l7.5-7.5M3 12h18"})});import{createContext as Oi,useContext as Ui}from"react";var $t=Oi({isLinking:!1,getAuthMeta:m,getAuthFlow:m,closePrivyModal:m,initLoginWithWallet:m,loginWithWallet:m,loginWithCode:m,loginWithEmail:m,loginWithSms:m,resendEmailCode:m,resendSmsCode:m,initLoginWithOAuth:m,loginWithOAuth:m,handleLoginError:m}),_=()=>Ui($t);import{jsx as J,jsxs as Bi}from"react/jsx-runtime";var Fi=()=>J("div",{}),Vi=({backFn:t})=>J("div",{children:J(Xo,{onClick:t})}),Gi=()=>{let{closePrivyModal:t}=_();return J("div",{children:J("div",{children:J(Jo,{onClick:t})})})};var E=({backFn:t})=>Bi(Hi,{children:[t?J(Vi,{backFn:t}):J(Fi,{}),J(Gi,{})]}),Hi=Di.div`
|
|
13
13
|
height: 30px;
|
|
14
14
|
display: flex;
|
|
15
15
|
align-items: center;
|
|
@@ -72,7 +72,7 @@ Resources:
|
|
|
72
72
|
@media (max-width: 440px) {
|
|
73
73
|
height: 30px;
|
|
74
74
|
}
|
|
75
|
-
`;import ir from"styled-components";import{jsx as U,jsxs as zi}from"react/jsx-runtime";var
|
|
75
|
+
`;import ir from"styled-components";import{jsx as U,jsxs as zi}from"react/jsx-runtime";var ge=({style:t,...e})=>zi("svg",{width:"28",height:"28",viewBox:"0 0 28 28",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...t},...e,children:[U("rect",{width:"28",height:"28",rx:"6",fill:"white"}),U("path",{d:"M23.0126 5L15.1958 10.7823L16.6533 7.37359L23.0126 5Z",fill:"#E17726",stroke:"#E17726",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M4.98753 5L12.7329 10.8299L11.3468 7.37954L4.98753 5ZM20.1987 18.4027L18.1166 21.5794L22.5723 22.8049L23.8454 18.4741L20.1987 18.4027ZM4.16064 18.4741L5.42775 22.8049L9.87153 21.5794L7.80133 18.4027L4.16064 18.4741Z",fill:"#E27625",stroke:"#E27625",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M9.6336 13.0369L8.39624 14.9049L12.7984 15.1071L12.6556 10.3659L9.6336 13.0429V13.0369ZM18.3665 13.0429L15.2969 10.3064L15.1958 15.1071L19.5979 14.9049L18.3665 13.0429ZM9.87155 21.5794L12.5426 20.2945L10.2463 18.5098L9.87155 21.5794ZM15.4635 20.2886L18.1166 21.5794L17.7597 18.5039L15.4635 20.2886Z",fill:"#E27625",stroke:"#E27625",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M18.1167 21.5794L15.4635 20.2944L15.6776 22.0196L15.6539 22.7513L18.1167 21.5794ZM9.87158 21.5794L12.3463 22.7513L12.3285 22.0196L12.5426 20.2944L9.87158 21.5794Z",fill:"#D5BFB2",stroke:"#D5BFB2",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M12.3878 17.3616L10.1868 16.7191L11.7454 16.0052L12.3938 17.3616H12.3878ZM15.6062 17.3616L16.2605 15.9993L17.8251 16.7131L15.6062 17.3675V17.3616Z",fill:"#233447",stroke:"#233447",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M9.87147 21.5794L10.2581 18.4027L7.80127 18.4741L9.87147 21.5794ZM17.7418 18.4027L18.1166 21.5794L20.1987 18.4741L17.7418 18.4027ZM19.6038 14.9048L15.2016 15.107L15.6061 17.3676L16.2605 15.9994L17.8251 16.7132L19.6038 14.9048ZM10.1868 16.7192L11.7454 16.0053L12.3938 17.3617L12.8042 15.1011L8.4021 14.9048L10.1868 16.7192Z",fill:"#CC6228",stroke:"#CC6228",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M8.4021 14.9048L10.2462 18.5038L10.1868 16.7192L8.4021 14.9048ZM17.8251 16.7192L17.7537 18.5038L19.5978 14.9048L17.8251 16.7192ZM12.8042 15.107L12.3878 17.3676L12.9113 20.0327L13.0303 16.5169L12.8042 15.107ZM15.1957 15.107L14.9815 16.511L15.0886 20.0327L15.6061 17.3617L15.1957 15.1011V15.107Z",fill:"#E27525",stroke:"#E27525",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M15.6062 17.3617L15.0887 20.0327L15.4635 20.2945L17.7538 18.5098L17.8252 16.7192L15.6062 17.3617ZM10.1869 16.7192L10.2463 18.5039L12.5426 20.2885L12.9114 20.0327L12.3939 17.3617L10.1809 16.7192H10.1869Z",fill:"#F5841F",stroke:"#F5841F",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M15.6598 22.7513L15.6776 22.0196L15.4754 21.853H12.5248L12.3285 22.0196L12.3463 22.7513L9.87158 21.5793L10.7401 22.2932L12.495 23.5008H15.4992L17.26 22.2873L18.1167 21.5793L15.6539 22.7513H15.6598Z",fill:"#C0AC9D",stroke:"#C0AC9D",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M15.4634 20.2885L15.0886 20.0327H12.9114L12.5425 20.2945L12.3284 22.0196L12.5247 21.8531H15.4753L15.6776 22.0196L15.4634 20.2945V20.2885Z",fill:"#161616",stroke:"#161616",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M23.3456 11.1571L24 7.97442L23.0125 5L15.4575 10.5919L18.3664 13.0369L22.4711 14.2326L23.3754 13.1797L22.9827 12.8941L23.6074 12.323L23.1315 11.9542L23.7561 11.4783L23.3397 11.1571H23.3456ZM4 7.96847L4.66627 11.1571L4.23795 11.4723L4.87448 11.9482L4.39857 12.323L5.01725 12.8941L4.62463 13.1797L5.52885 14.2326L9.63355 13.0428L12.5425 10.586L4.98751 5L4 7.96847Z",fill:"#763E1A",stroke:"#763E1A",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"}),U("path",{d:"M22.4712 14.2325L18.3665 13.0428L19.6038 14.9048L17.7597 18.5038L20.1987 18.4741H23.8454L22.4712 14.2325ZM9.63358 13.0368L5.52888 14.2325L4.16064 18.4741H7.80728L10.2463 18.5038L8.40217 14.9048L9.63953 13.0368H9.63358ZM15.1957 15.107L15.4634 10.5859L16.6532 7.37354H11.3468L12.5366 10.5859L12.8043 15.107L12.9054 16.5229V20.0327H15.0887L15.1006 16.5229L15.1957 15.107Z",fill:"#F5841F",stroke:"#F5841F",strokeWidth:"0.25",strokeLinecap:"round",strokeLinejoin:"round"})]});import{jsx as er,jsxs as Zi}from"react/jsx-runtime";var ne=({style:t,...e})=>Zi("svg",{width:"1024",height:"1024",viewBox:"0 0 1024 1024",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...t},...e,children:[er("rect",{width:"1024",height:"1024",fill:"#0052FF",rx:100,ry:100}),er("path",{fillRule:"evenodd",clipRule:"evenodd",d:"M152 512C152 710.823 313.177 872 512 872C710.823 872 872 710.823 872 512C872 313.177 710.823 152 512 152C313.177 152 152 313.177 152 512ZM420 396C406.745 396 396 406.745 396 420V604C396 617.255 406.745 628 420 628H604C617.255 628 628 617.255 628 604V420C628 406.745 617.255 396 604 396H420Z",fill:"white"})]});import{jsx as Se,jsxs as ji}from"react/jsx-runtime";var at=({style:t,...e})=>ji("svg",{width:"28",height:"28",viewBox:"0 0 28 28",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"28px",width:"28px",...t},...e,children:[Se("rect",{width:"28",height:"28",rx:"6",fill:"#141414"}),Se("g",{clipPath:"url(#clip0_1765_9946)",children:Se("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"})}),Se("defs",{children:Se("clipPath",{id:"clip0_1765_9946",children:Se("rect",{width:"20",height:"12.2531",fill:"white",transform:"translate(4 8)"})})})]});import{isMobile as rr}from"react-device-detect";import{isIOS as $i,isMobile as Ki}from"react-device-detect";var Kt=t=>{let e=new URL(window.location.href);if(!window.ethereum&&Ki){let o;switch(t){case"metamask":$i?o="dapp://"+e.hostname+e.pathname:o="https://metamask.app.link/dapp/"+e.hostname+e.pathname;break;case"coinbase_wallet":o="https://go.cb-w.com/dapp?cb_url="+encodeURIComponent(e.href.replace(/\/$/g,""));break;case"wallet_connect":break;default:break}o&&window.location.assign(o)}};import tr from"styled-components";var or=tr.span`
|
|
76
76
|
@media (max-width: 440px) {
|
|
77
77
|
display: none;
|
|
78
78
|
}
|
|
@@ -80,7 +80,7 @@ Resources:
|
|
|
80
80
|
@media (min-width: 441px) {
|
|
81
81
|
display: none;
|
|
82
82
|
}
|
|
83
|
-
`;import{jsx as Q,jsxs as
|
|
83
|
+
`;import{jsx as Q,jsxs as Ze}from"react/jsx-runtime";var lt=()=>{let{navigate:t}=w(),{initLoginWithWallet:e,closePrivyModal:o}=_();return Ze(qi,{children:[Ze(qt,{onClick:()=>{zt()?(e("metamask"),t("AWAITING_CONNECTION")):rr?(Kt("metamask"),o()):t("INSTALL_METAMASK_SCREEN")},children:[Q(ge,{}),Q("span",{children:"Metamask"}),Q("span",{children:zt()?"Connect":"Install"})]}),Ze(qt,{onClick:()=>{st()?(e("coinbase_wallet"),t("AWAITING_CONNECTION")):rr?(Kt("coinbase_wallet"),o()):(e("coinbase_wallet"),t("AWAITING_CONNECTION"))},children:[Q(ne,{}),Ze("span",{children:["Coinbase",Q(or,{children:" Wallet"})]}),Q("span",{children:"Connect"})]}),Ze(qt,{onClick:()=>{e("wallet_connect"),t("AWAITING_CONNECTION")},children:[Q(at,{}),Q("span",{children:"WalletConnect"}),Q("span",{children:"Connect"})]})]})},qi=ir.div`
|
|
84
84
|
display: flex;
|
|
85
85
|
flex-direction: column;
|
|
86
86
|
align-items: flex-start;
|
|
@@ -214,7 +214,7 @@ Resources:
|
|
|
214
214
|
justify-content: center;
|
|
215
215
|
height: 100%;
|
|
216
216
|
width: 100%;
|
|
217
|
-
`;import mt from"styled-components";import{jsx as hr}from"react/jsx-runtime";var ct=({style:t,logoFill:e,...o})=>hr("svg",{width:"24",height:"20",viewBox:"0 0 24 20",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"26px",width:"26px",...t},...o,children:hr("path",{d:"M7.54311 19.7551C16.5973 19.7551 21.5516 12.2467 21.5516 5.74656C21.5516 5.53533 21.5516 5.32409 21.542 5.11286C22.5021 4.42156 23.3375 3.54783 24 2.55888C23.1166 2.95254 22.1661 3.21178 21.1675 3.3366C22.1853 2.73171 22.963 1.76196 23.3375 0.609788C22.3869 1.17627 21.3308 1.57953 20.2074 1.80037C19.3049 0.840223 18.0279 0.244934 16.6165 0.244934C13.8993 0.244934 11.6909 2.45326 11.6909 5.17047C11.6909 5.55453 11.7389 5.92898 11.8157 6.29384C7.72554 6.09221 4.09619 4.12391 1.66703 1.14747C1.24457 1.87718 1.00453 2.72211 1.00453 3.62464C1.00453 5.3337 1.87826 6.84112 3.19366 7.72445C2.38714 7.69565 1.62862 7.47481 0.966125 7.10996C0.966125 7.12916 0.966125 7.14837 0.966125 7.17717C0.966125 9.55833 2.66558 11.5554 4.91232 12.0067C4.49945 12.1219 4.06739 12.1795 3.61612 12.1795C3.29927 12.1795 2.99203 12.1507 2.69438 12.0931C3.31848 14.0518 5.14275 15.4728 7.29347 15.5112C5.60362 16.8362 3.4817 17.6235 1.17736 17.6235C0.783698 17.6235 0.390039 17.6043 0.00598145 17.5563C2.17591 18.9389 4.76829 19.7551 7.54311 19.7551Z",fill:e==="primary"?"#1da1f2":"white"})});import{jsx as
|
|
217
|
+
`;import mt from"styled-components";import{jsx as hr}from"react/jsx-runtime";var ct=({style:t,logoFill:e,...o})=>hr("svg",{width:"24",height:"20",viewBox:"0 0 24 20",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"26px",width:"26px",...t},...o,children:hr("path",{d:"M7.54311 19.7551C16.5973 19.7551 21.5516 12.2467 21.5516 5.74656C21.5516 5.53533 21.5516 5.32409 21.542 5.11286C22.5021 4.42156 23.3375 3.54783 24 2.55888C23.1166 2.95254 22.1661 3.21178 21.1675 3.3366C22.1853 2.73171 22.963 1.76196 23.3375 0.609788C22.3869 1.17627 21.3308 1.57953 20.2074 1.80037C19.3049 0.840223 18.0279 0.244934 16.6165 0.244934C13.8993 0.244934 11.6909 2.45326 11.6909 5.17047C11.6909 5.55453 11.7389 5.92898 11.8157 6.29384C7.72554 6.09221 4.09619 4.12391 1.66703 1.14747C1.24457 1.87718 1.00453 2.72211 1.00453 3.62464C1.00453 5.3337 1.87826 6.84112 3.19366 7.72445C2.38714 7.69565 1.62862 7.47481 0.966125 7.10996C0.966125 7.12916 0.966125 7.14837 0.966125 7.17717C0.966125 9.55833 2.66558 11.5554 4.91232 12.0067C4.49945 12.1219 4.06739 12.1795 3.61612 12.1795C3.29927 12.1795 2.99203 12.1507 2.69438 12.0931C3.31848 14.0518 5.14275 15.4728 7.29347 15.5112C5.60362 16.8362 3.4817 17.6235 1.17736 17.6235C0.783698 17.6235 0.390039 17.6043 0.00598145 17.5563C2.17591 18.9389 4.76829 19.7551 7.54311 19.7551Z",fill:e==="primary"?"#1da1f2":"white"})});import{jsx as je,jsxs as tn}from"react/jsx-runtime";var pt=({logoFill:t,style:e,...o})=>tn("svg",{version:"1.1",xmlns:"http://www.w3.org/2000/svg",x:"0px",y:"0px",viewBox:"0 0 71 55",style:{height:"24px",...e},...o,children:[je("g",{clipPath:"url(#clip0)",children:je("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"})}),je("defs",{children:je("clipPath",{id:"clip0",children:je("rect",{width:"71",height:"55",fill:"white"})})})]});import{jsx as ut,jsxs as on}from"react/jsx-runtime";var ht=({style:t,...e})=>on("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",xmlns:"http://www.w3.org/2000/svg",style:{height:"26px",width:"26px",...t},...e,children:[ut("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"}),ut("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"}),ut("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"}),ut("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 Ie,jsxs as ln}from"react/jsx-runtime";var mr=({showGoogle:t,showTwitter:e,showDiscord:o,stacked:r})=>{let{initLoginWithOAuth:i}=_();return ln(rn,{stacked:r,children:[t&&Ie(an,{onClick:()=>{i("google")},children:Ie(ht,{})}),e&&Ie(nn,{onClick:()=>{i("twitter")},children:Ie(ct,{})}),o&&Ie(sn,{onClick:()=>{i("discord")},children:Ie(pt,{})})]})},rn=mt.div`
|
|
218
218
|
display: flex;
|
|
219
219
|
flex-direction: ${t=>t.stacked?"column":"row"};
|
|
220
220
|
justify-content: space-between;
|
|
@@ -410,7 +410,7 @@ Resources:
|
|
|
410
410
|
opacity: ${t=>t.success||t.fail?"1":"0"};
|
|
411
411
|
|
|
412
412
|
transition: ${t=>t.fail?"":"all 150ms ease-in-out"};
|
|
413
|
-
`;import{useEffect as vn,useState as Qt}from"react";import
|
|
413
|
+
`;import{useEffect as vn,useState as Qt}from"react";import we from"styled-components";import{jsx as Cr}from"react/jsx-runtime";var Ct=({style:t,...e})=>Cr("svg",{xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 20 20",strokeWidth:1.5,stroke:"currentColor",style:{height:"1.5rem",width:"1.5rem",...t},...e,children:Cr("path",{d:"M2.5 4.16667C2.5 3.72464 2.67559 3.30072 2.98816 2.98816C3.30072 2.67559 3.72464 2.5 4.16667 2.5H6.9C7.07483 2.50013 7.24519 2.55525 7.38696 2.65754C7.52874 2.75984 7.63475 2.90413 7.69 3.07L8.93833 6.81417C9.00158 7.00445 8.9941 7.21116 8.91726 7.39637C8.84042 7.58158 8.69938 7.73288 8.52 7.8225L6.63917 8.76417C7.5611 10.8046 9.19538 12.4389 11.2358 13.3608L12.1775 11.48C12.2671 11.3006 12.4184 11.1596 12.6036 11.0827C12.7888 11.0059 12.9956 10.9984 13.1858 11.0617L16.93 12.31C17.096 12.3653 17.2404 12.4714 17.3427 12.6134C17.445 12.7553 17.5 12.9259 17.5 13.1008V15.8333C17.5 16.2754 17.3244 16.6993 17.0118 17.0118C16.6993 17.3244 16.2754 17.5 15.8333 17.5H15C8.09667 17.5 2.5 11.9033 2.5 5V4.16667Z",strokeLinecap:"round",strokeLinejoin:"round"})});import{Fragment as _n,jsx as te,jsxs as Xt}from"react/jsx-runtime";var vt=t=>{let[e,o]=Qt(""),[r,i]=Qt(!1),[n,s]=Qt(null),{authenticated:c}=N(),{loginWithSms:f,handleLoginError:h}=_(),{navigate:P,options:C}=w(),A=C.wallet;vn(()=>{let a=document.querySelector("#phone-number-input");a==null||a.focus()},[]);let b=wr(e),x=()=>{i(!0),f(e).then(()=>{P("AWAITING_PASSWORDLESS_CODE")}).catch(a=>{let y=(a==null?void 0:a.status)===401&&(a==null?void 0:a.message)==="User is not allowed to login to this app.";(a==null?void 0:a.status)===422?s(a.message):s(y?"You don't have access to this app":"Issue submitting phone number"),i(!1),h(y)})};return Xt(_n,{children:[Xt(bn,{stacked:t.stacked,children:[Xt(En,{standalone:t.stacked,children:[te(Ct,{}),te("input",{id:"phone-number-input",type:"tel",placeholder:"555 555 5555",onChange:a=>{o(a.target.value)},onKeyUp:a=>{a.key==="Enter"&&x()},value:e,autoComplete:"tel"})]}),t.stacked?null:te(xn,{disabled:r||!b,onClick:x,children:r?te(vr,{color:"var(--disabled-fg)"}):"Submit"})]}),n||c||!A?te(kn,{fail:!!n,children:n||""}):null,!n&&!c&&A?te(An,{children:te("span",{children:"Don\u2019t have a wallet? Start exploring with your phone or socials."})}):null,t.stacked?te(Ln,{disabled:r||!b,onClick:x,children:r?te(vr,{color:"var(--disabled-fg)"}):"Submit"}):null]})},bn=we.div`
|
|
414
414
|
display: flex;
|
|
415
415
|
border: 1px solid #d1d5db;
|
|
416
416
|
width: 100%;
|
|
@@ -424,7 +424,7 @@ Resources:
|
|
|
424
424
|
@media (max-width: 440px) {
|
|
425
425
|
margin-top: 20px;
|
|
426
426
|
}
|
|
427
|
-
`,xn=
|
|
427
|
+
`,xn=we.button`
|
|
428
428
|
display: flex;
|
|
429
429
|
flex-direction: row;
|
|
430
430
|
align-items: center;
|
|
@@ -449,7 +449,7 @@ Resources:
|
|
|
449
449
|
color: var(--disabled-fg);
|
|
450
450
|
cursor: not-allowed;
|
|
451
451
|
}
|
|
452
|
-
`,Ln=
|
|
452
|
+
`,Ln=we.button`
|
|
453
453
|
display: flex;
|
|
454
454
|
flex-direction: column;
|
|
455
455
|
align-items: center;
|
|
@@ -473,7 +473,7 @@ Resources:
|
|
|
473
473
|
color: var(--disabled-fg);
|
|
474
474
|
cursor: not-allowed;
|
|
475
475
|
}
|
|
476
|
-
`,En=
|
|
476
|
+
`,En=we.label`
|
|
477
477
|
display: flex;
|
|
478
478
|
flex-direction: row;
|
|
479
479
|
align-items: center;
|
|
@@ -510,14 +510,14 @@ Resources:
|
|
|
510
510
|
line-height: 24px;
|
|
511
511
|
}
|
|
512
512
|
}
|
|
513
|
-
`,An=
|
|
513
|
+
`,An=we.div`
|
|
514
514
|
font-size: 13px;
|
|
515
515
|
color: #6b7280;
|
|
516
516
|
|
|
517
517
|
> button {
|
|
518
518
|
text-decoration: underline;
|
|
519
519
|
}
|
|
520
|
-
`,kn=
|
|
520
|
+
`,kn=we.div`
|
|
521
521
|
line-height: 20px;
|
|
522
522
|
height: 20px;
|
|
523
523
|
font-size: 13px;
|
|
@@ -529,19 +529,19 @@ Resources:
|
|
|
529
529
|
opacity: ${t=>t.success||t.fail?"1":"0"};
|
|
530
530
|
|
|
531
531
|
transition: ${t=>t.fail?"":"all 150ms ease-in-out"};
|
|
532
|
-
`,vr=
|
|
532
|
+
`,vr=we(ae)`
|
|
533
533
|
&& {
|
|
534
534
|
height: 1rem;
|
|
535
535
|
width: 1rem;
|
|
536
536
|
border-width: 2px;
|
|
537
537
|
}
|
|
538
|
-
`;import{jsx as br}from"react/jsx-runtime";var xr=()=>{let{app:t}=w();return t!=null&&t.logoUrl?br("div",{children:br("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{isMobile as Lr}from"react-device-detect";import{Fragment as eo,jsx as I,jsxs as le}from"react/jsx-runtime";var Ar=()=>{let{ready:t}=N(),{getAuthMeta:e,isLinking:o}=_(),{app:r,navigate:i,options:n}=w(),s=n.email,c=n.sms,f=n.wallet,h=n.google,P=n.twitter,C=n.discord,A=f?0:1,[b,x]=Sn(A),a=e(),y=(a==null?void 0:a.authorizationCode)&&(a==null?void 0:a.stateCode)&&(a==null?void 0:a.provider);Pn(()=>{y?i("AWAITING_OAUTH_SCREEN"):o&&s?i("LINK_EMAIL_SCREEN"):o&&c?i("LINK_PHONE_SCREEN"):o&&f&&i("LINK_WALLET_SCREEN")},[t]);let F=b==0,W=b==1;return le(eo,{children:[I(E,{},"header"),I(Wn,{walletOnly:!s&&!c&&!h&&!P&&!C,hasTerms:!!((r==null?void 0:r.privacyPolicyUrl)||(r==null?void 0:r.termsAndConditionsUrl)),children:I(xr,{})}),le(se,{children:[f&&I(Tn,{active:F,onClick:()=>x(0)}),(s||c)&&I(In,{active:W,onClick:()=>x(1),email:s,sms:c,google:h,twitter:P,discord:C})]}),r&&I(dr,{app:r}),I(q,{protectedByPrivy:!0})]})};function Tn(t){return le(_r,{active:t.active,onClick:t.onClick,children:[I(kr,{active:t.active,children:I("h4",{children:"Connect Wallet"})}),t.active&&le(eo,{children:[I(lt,{}),I(dt,{})]})]})}function In(t){let e=t.google||t.discord||t.twitter&&!Lr,o=t.email?"Email":"Phone";return le(_r,{active:t.active,onClick:t.onClick,children:[I(kr,{active:t.active,children:le("h4",{children:["Sign In with ",e?`${o} & Social`:o]})}),t.active&&t.email&&I(yt,{}),t.active&&t.sms&&!t.email&&I(vt,{}),t.active&&e&&I(Rn,{google:t.google,twitter:t.twitter&&!Lr,discord:t.discord})]})}function Rn(t){return le(eo,{children:[le(Mn,{children:[I(Er,{}),I("p",{children:" Or "}),I(Er,{})]}),I(mr,{showGoogle:t.google,showDiscord:t.discord,showTwitter:t.twitter})]})}var kr
|
|
538
|
+
`;import{jsx as br}from"react/jsx-runtime";var xr=()=>{let{app:t}=w();return t!=null&&t.logoUrl?br("div",{children:br("img",{src:t.logoUrl,alt:`${t==null?void 0:t.name} logo`,style:{objectFit:"contain",width:"200px",height:"80px"}})}):null};import{isMobile as Lr}from"react-device-detect";import{Fragment as eo,jsx as I,jsxs as le}from"react/jsx-runtime";var Ar=()=>{let{ready:t}=N(),{getAuthMeta:e,isLinking:o}=_(),{app:r,navigate:i,options:n}=w(),s=n.email,c=n.sms,f=n.wallet,h=n.google,P=n.twitter,C=n.discord,A=f?0:1,[b,x]=Sn(A),a=e(),y=(a==null?void 0:a.authorizationCode)&&(a==null?void 0:a.stateCode)&&(a==null?void 0:a.provider);Pn(()=>{y?i("AWAITING_OAUTH_SCREEN"):o&&s?i("LINK_EMAIL_SCREEN"):o&&c?i("LINK_PHONE_SCREEN"):o&&f&&i("LINK_WALLET_SCREEN")},[t]);let F=b==0,W=b==1;return le(eo,{children:[I(E,{},"header"),I(Wn,{walletOnly:!s&&!c&&!h&&!P&&!C,hasTerms:!!((r==null?void 0:r.privacyPolicyUrl)||(r==null?void 0:r.termsAndConditionsUrl)),children:I(xr,{})}),le(se,{children:[f&&I(Tn,{active:F,onClick:()=>x(0)}),(s||c)&&I(In,{active:W,onClick:()=>x(1),email:s,sms:c,google:h,twitter:P,discord:C})]}),r&&I(dr,{app:r}),I(q,{protectedByPrivy:!0})]})};function Tn(t){return le(_r,{active:t.active,onClick:t.onClick,children:[I(kr,{active:t.active,children:I("h4",{children:"Connect Wallet"})}),t.active&&le(eo,{children:[I(lt,{}),I(dt,{})]})]})}function In(t){let e=t.google||t.discord||t.twitter&&!Lr,o=t.email?"Email":"Phone";return le(_r,{active:t.active,onClick:t.onClick,children:[I(kr,{active:t.active,children:le("h4",{children:["Sign In with ",e?`${o} & Social`:o]})}),t.active&&t.email&&I(yt,{}),t.active&&t.sms&&!t.email&&I(vt,{}),t.active&&e&&I(Rn,{google:t.google,twitter:t.twitter&&!Lr,discord:t.discord})]})}function Rn(t){return le(eo,{children:[le(Mn,{children:[I(Er,{}),I("p",{children:" Or "}),I(Er,{})]}),I(mr,{showGoogle:t.google,showDiscord:t.discord,showTwitter:t.twitter})]})}var kr=$e.div`
|
|
539
539
|
font-weight: ${t=>t.active?600:500};
|
|
540
540
|
color: ${t=>t.active?"inherit":"#6b7280"};
|
|
541
541
|
display: flex;
|
|
542
542
|
justify-content: center;
|
|
543
543
|
align-items: center;
|
|
544
|
-
`,_r
|
|
544
|
+
`,_r=$e.div`
|
|
545
545
|
display: flex;
|
|
546
546
|
flex-direction: column;
|
|
547
547
|
align-items: flex-start;
|
|
@@ -562,18 +562,18 @@ Resources:
|
|
|
562
562
|
}
|
|
563
563
|
|
|
564
564
|
cursor: ${t=>t.active?"inherit":"pointer"};
|
|
565
|
-
`,Mn
|
|
565
|
+
`,Mn=$e.div`
|
|
566
566
|
display: flex;
|
|
567
567
|
justify-content: center;
|
|
568
568
|
align-items: center;
|
|
569
569
|
width: 100%;
|
|
570
|
-
`,Er
|
|
570
|
+
`,Er=$e.hr`
|
|
571
571
|
width: 50%;
|
|
572
572
|
&& {
|
|
573
573
|
border-top: 1px solid #d1d5db;
|
|
574
574
|
margin: 0px 8px;
|
|
575
575
|
}
|
|
576
|
-
`,Wn
|
|
576
|
+
`,Wn=$e.div`
|
|
577
577
|
display: flex;
|
|
578
578
|
flex-direction: column;
|
|
579
579
|
align-items: center;
|
|
@@ -593,9 +593,9 @@ Resources:
|
|
|
593
593
|
// the logo is close to the top (mobile or full wallet-open design)
|
|
594
594
|
margin-top: ${t=>`${28+(t.walletOnly?31:0)-(t.hasTerms?18:0)}px`};
|
|
595
595
|
margin-bottom: ${t=>`${60+(t.walletOnly?31:0)-(t.hasTerms?18:0)}px`};
|
|
596
|
-
`;import{useEffect as Ir,useState as xt}from"react";import Lt from"styled-components";import bt from"styled-components";import{jsx as
|
|
596
|
+
`;import{useEffect as Ir,useState as xt}from"react";import Lt from"styled-components";import bt from"styled-components";import{jsx as Ke,jsxs as Tr}from"react/jsx-runtime";var ye=({title:t,description:e,children:o,...r})=>Tr(Sr,{...r,children:[Ke("h3",{children:t}),typeof e=="string"?Ke("p",{children:e}):null,o]}),Pr=bt(ye)`
|
|
597
597
|
margin-bottom: 24px;
|
|
598
|
-
`,Me=({title:t,description:e,icon:o,children:r,...i})=>Tr(Nn,{...i,children:[o?
|
|
598
|
+
`,Me=({title:t,description:e,icon:o,children:r,...i})=>Tr(Nn,{...i,children:[o?Ke(On,{children:o}):null,Ke("h3",{children:t}),typeof e=="string"?Ke("p",{children:e}):null,r]}),Sr=bt.div`
|
|
599
599
|
display: flex;
|
|
600
600
|
flex-direction: column;
|
|
601
601
|
justify-content: flex-start;
|
|
@@ -629,7 +629,7 @@ Resources:
|
|
|
629
629
|
border-color: #e1e7ef;
|
|
630
630
|
border-width: 1px;
|
|
631
631
|
}
|
|
632
|
-
`;import{Fragment as to,jsx as H,jsxs as We}from"react/jsx-runtime";var oo=6,Rr=new Array(oo).fill(""),Un=1400;var Mr=()=>{var
|
|
632
|
+
`;import{Fragment as to,jsx as H,jsxs as We}from"react/jsx-runtime";var oo=6,Rr=new Array(oo).fill(""),Un=1400;var Mr=()=>{var Z,l,d;let{app:t}=w(),{closePrivyModal:e,resendEmailCode:o,resendSmsCode:r,getAuthMeta:i,loginWithCode:n}=_(),{authenticated:s,user:c}=N(),[f,h]=xt(Rr),[P,C]=xt(!1),[A,b]=xt(null),[x,a]=xt(null),y=(Z=i())!=null&&Z.email?0:1;Ir(()=>{if(s&&P){let k=setTimeout(e,Le);return()=>clearTimeout(k)}},[s,P,c]),Ir(()=>{if(A&&x===0){let k=setTimeout(()=>{h(Rr),b(null);let S=document.querySelector("input[name=code-0]");S==null||S.focus()},Un);return()=>clearTimeout(k)}},[A]);let F=k=>{var fo;let S=k.currentTarget.value.replace(" ","");if(S==="")return;if(isNaN(Number(S))){b("Code should be numeric"),a(1);return}b(null),a(null);let j=Number((fo=k.currentTarget.name)==null?void 0:fo.charAt(5)),Nt=[...S||[""]].slice(0,oo-j),Ot=[...f.slice(0,j),...Nt,...f.slice(j+Nt.length)];h(Ot);let hi=Nt.length,mo=Math.min(Math.max(j+hi,0),oo-1);if(!isNaN(Number(k.currentTarget.value))){let $=document.querySelector(`input[name=code-${mo}]`);$==null||$.focus()}if(Ot.every($=>$&&!isNaN(+$))){let $=document.querySelector(`input[name=code-${mo}]`);$==null||$.blur(),n(Ot.join("")).then(()=>C(!0)).catch(Ut=>{(Ut==null?void 0:Ut.status)===422?b("Invalid or expired verification code"):b("Issue verifying code"),a(0)})}k.preventDefault()},W=k=>{x===1&&(b(null),a(null));let S=[...f.slice(0,k),"",...f.slice(k+1)];if(h(S),k>0){let j=document.querySelector(`input[name=code-${k-1}]`);j==null||j.focus()}},xe=`Verify your ${y==0?"email":"phone"}`,v=y==0?`Please check ${(l=i())==null?void 0:l.email} for an email from privy.io and enter your code below.`:`Please check ${(d=i())==null?void 0:d.phoneNumber} for a message from ${(t==null?void 0:t.name)||"privy.io"} and enter your code below.`;return We(to,{children:[H(E,{},"header"),We(Dn,{children:[H(ye,{title:xe,description:v}),We(ur,{children:[We(Fn,{children:[H(Vn,{fail:!!A,success:P,children:H("span",{children:A||(P?"Success!":"")})}),H("div",{children:f.map((k,S)=>H("input",{name:`code-${S}`,type:"text",value:f[S],onChange:F,onKeyUp:j=>{j.key==="Backspace"&&W(S)},inputMode:"numeric",autoFocus:S===0,pattern:"[0-9]",className:`${P?"success":""} ${A?"fail":""}`,autoComplete:"one-time-code"},S))})]}),H(Gn,{children:y==0?We(to,{children:[H("span",{children:"Didn't get an email?"}),H("button",{onClick:o,children:"Resend Code"})]}):We(to,{children:[H("span",{children:"Didn't get a message?"}),H("button",{onClick:r,children:"Resend Code"})]})})]})]}),H(q,{protectedByPrivy:!0})]})},Dn=Lt.div`
|
|
633
633
|
display: flex;
|
|
634
634
|
flex-direction: column;
|
|
635
635
|
align-items: flex-start;
|
|
@@ -726,7 +726,7 @@ Resources:
|
|
|
726
726
|
> button {
|
|
727
727
|
text-decoration: underline;
|
|
728
728
|
}
|
|
729
|
-
`;import{useState as ts}from"react";import z from"styled-components";import Hn from"qrcode";import Bn from"styled-components";import{Fragment as Ne,jsx as O,jsxs as Or}from"react/jsx-runtime";var D=7,ro=(t,e,o,r,i)=>{for(let n=e;n<e+r;n++)for(let s=o;s<o+i;s++){let c=t==null?void 0:t[s];c&&c[n]&&(c[n]=0)}return t},zn=t=>{let e=Hn.create(t,{errorCorrectionLevel:"high"}).modules,o=yr(Array.from(e.data),e.size);return o=ro(o,0,0,D,D),o=ro(o,o.length-D,0,D,D),o=ro(o,0,o.length-D,D,D),o},
|
|
729
|
+
`;import{useState as ts}from"react";import z from"styled-components";import Hn from"qrcode";import Bn from"styled-components";import{Fragment as Ne,jsx as O,jsxs as Or}from"react/jsx-runtime";var D=7,ro=(t,e,o,r,i)=>{for(let n=e;n<e+r;n++)for(let s=o;s<o+i;s++){let c=t==null?void 0:t[s];c&&c[n]&&(c[n]=0)}return t},zn=t=>{let e=Hn.create(t,{errorCorrectionLevel:"high"}).modules,o=yr(Array.from(e.data),e.size);return o=ro(o,0,0,D,D),o=ro(o,o.length-D,0,D,D),o=ro(o,0,o.length-D,D,D),o},Zn=({x:t,y:e,cellSize:o,bgColor:r,fgColor:i})=>O(Ne,{children:[0,1,2].map(n=>O("circle",{r:o*(D-n*2)/2,cx:t+o*D/2,cy:e+o*D/2,fill:n%2!==0?r:i},`finder-${t}-${e}-${n}`))}),jn=({cellSize:t,matrixSize:e,bgColor:o,fgColor:r})=>{let i=[[0,0],[(e-D)*t,0],[0,(e-D)*t]];return O(Ne,{children:i.map(([n,s])=>O(Zn,{x:n,y:s,cellSize:t,bgColor:o,fgColor:r}))})},$n=({matrix:t,cellSize:e,color:o})=>O(Ne,{children:t.map((r,i)=>r.map((n,s)=>n?O("circle",{r:e/2.5,cx:i*e+e/2,cy:s*e+e/2,fill:o},`circle-${i}-${s}`):O(Ne,{})))}),Wr=(t,e)=>t-t%e,Kn=({outputSize:t,cellSize:e,element:o,size:r,padding:i,bgColor:n})=>{if(!o)return O(Ne,{});let s=r||40,c=i||4,f=o,h=t/2-s/2-c;return Or(Ne,{children:[O("rect",{x:Wr(h,e),y:Wr(h,e),width:s+c*2+(h%e?e+.5:.5),height:s+c*2+(h%e?e+.5:.5),fill:n}),O(f,{x:t/2-s/2,y:t/2-s/2,height:s,width:s})]})},qn=t=>{var i;let e=t.outputSize,o=zn(t.url),r=e/o.length;return Or("svg",{height:t.outputSize,width:t.outputSize,viewBox:`0 0 ${t.outputSize} ${t.outputSize}`,style:{height:"100%",width:"100%"},children:[O($n,{matrix:o,cellSize:r,color:t.fgColor}),O(jn,{cellSize:r,matrixSize:o.length,fgColor:t.fgColor,bgColor:t.bgColor}),O(Kn,{outputSize:t.outputSize,cellSize:r,element:(i=t.logo)==null?void 0:i.element,bgColor:t.bgColor})]})},Yn=Bn.div`
|
|
730
730
|
display: flex;
|
|
731
731
|
justify-content: center;
|
|
732
732
|
align-items: center;
|
|
@@ -746,13 +746,13 @@ Resources:
|
|
|
746
746
|
flex-direction: column;
|
|
747
747
|
justify-content: flex-start;
|
|
748
748
|
gap: 4px;
|
|
749
|
-
|
|
749
|
+
`,qe=io.div`
|
|
750
750
|
&&& {
|
|
751
751
|
margin-left: 7px; /* TODO: This is a total hack */
|
|
752
752
|
border-left: 2px solid #e5e7eb;
|
|
753
753
|
height: 12px;
|
|
754
754
|
}
|
|
755
|
-
`,
|
|
755
|
+
`,Ce=({children:t})=>es(Qn,{children:[Xn(Fr,{style:{width:"16px",height:"16px"}}),t]}),Qn=io.div`
|
|
756
756
|
display: flex;
|
|
757
757
|
justify-content: flex-start;
|
|
758
758
|
justify-items: center;
|
|
@@ -801,7 +801,7 @@ Resources:
|
|
|
801
801
|
border: 1px solid #e5e7eb;
|
|
802
802
|
color: var(--text-dark-blue);
|
|
803
803
|
}
|
|
804
|
-
`;import{Fragment as ao,jsx as u,jsxs as M}from"react/jsx-runtime";var lo=()=>{let{navigate:t}=w(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return de.isFirefox&&(e="https://addons.mozilla.org/en-US/firefox/addon/ether-metamask/"),M(
|
|
804
|
+
`;import{Fragment as ao,jsx as u,jsxs as M}from"react/jsx-runtime";var lo=()=>{let{navigate:t}=w(),e="https://chrome.google.com/webstore/detail/metamask/nkbihfbeogaeaoehlefnkodbefgpgknn?hl=en";return de.isFirefox&&(e="https://addons.mozilla.org/en-US/firefox/addon/ether-metamask/"),M(jr,{children:[u(ye,{title:"Create a Metamask wallet",description:"Follow the instructions below to get started."}),u($r,{children:u(ge,{style:{width:"152px",height:"152px"}})}),M(no,{children:[u(Ce,{children:M("div",{children:[u("span",{children:"Install the "}),u("a",{href:e,target:"_blank",children:"MetaMask browser extension"})]})}),u(qe,{}),u(Ce,{children:"Set up your first wallet"}),u(qe,{}),u(Ce,{children:"Store your recovery phrase in a safe place!"})]}),u(Kr,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},co=()=>{let{navigate:t}=w();return M(jr,{children:[u(ye,{title:"Create a Coinbase wallet",description:"Follow the instructions below to get started."}),u($r,{style:{marginTop:"-24px"},children:u(Ur,{size:200})}),M(no,{children:[u(Ce,{children:"Scan the QR code with your camera"}),u(qe,{}),u(Ce,{children:"Set up your first wallet"}),u(qe,{}),u(Ce,{children:"Store your seed phrase in a safe place!"})]}),u(Kr,{onClick:()=>t("LANDING"),children:"Done! I have my wallet"})]})},Zr=()=>{let[t,e]=ts("WHAT_IS_A_WALLET"),{navigateBack:o}=w();return M(ao,{children:[u(E,{backFn:t==="WHAT_IS_A_WALLET"?o:t==="PICK_A_NEW_WALLET"?()=>e("WHAT_IS_A_WALLET"):()=>e("PICK_A_NEW_WALLET")},"header"),M(os,{children:[t==="WHAT_IS_A_WALLET"&&M(ao,{children:[u(as,{children:u(Vr,{style:{width:"240px",height:"auto",borderRadius:"var(--border-radius-sm)",marginBottom:"32px"}})}),M(Me,{title:"Get started with a new wallet",children:[u("p",{children:"Wallets help you store, send, and receive digital assets and collectibles. They are also a new\xA0way\xA0to\xA0log\xA0in."}),u("p",{children:"Instead of creating new accounts and passwords for every app, you just connect your wallet and bring your\xA0data\xA0with\xA0you."})]}),u(ns,{children:u(ss,{onClick:()=>{e("PICK_A_NEW_WALLET")},children:"Create a wallet"})})]}),t==="PICK_A_NEW_WALLET"&&u(ao,{children:M(rs,{children:[u(ye,{title:"Create a new wallet",description:"Select one the wallet providers below to get started on your web3 adventure."}),M(is,{children:[M(Br,{onClick:()=>{de.isIOS?window.location.href="https://apps.apple.com/us/app/metamask-blockchain-wallet/id1438144202":de.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=io.metamask":e("CREATE_METAMASK_WALLET")},children:[u(ge,{}),M(zr,{children:[u("h4",{children:"MetaMask"}),u("p",{children:"Get a browser-based wallet"})]}),u("div",{children:u("span",{children:"Set up"})})]}),M(Br,{onClick:()=>{de.isIOS?window.location.href="https://apps.apple.com/us/app/coinbase-wallet-nfts-crypto/id1278383455":de.isAndroid?window.location.href="https://play.google.com/store/apps/details?id=org.toshi":e("CREATE_COINBASE_WALLET")},children:[u(ne,{}),M(zr,{children:[u("h4",{children:"Coinbase Wallet"}),u("p",{children:"Get a mobile app wallet"})]}),u("div",{children:u("span",{children:"Set up"})})]})]})]})}),t==="CREATE_COINBASE_WALLET"&&u(co,{}),t==="CREATE_METAMASK_WALLET"&&u(lo,{})]}),M(X,{children:[u("span",{children:"Still not sure? "}),u("a",{target:"_blank",href:"https://join.tell.ie/blog/explaining-web3-wallets",children:"Learn more"}),"."]})]})},os=z.div`
|
|
805
805
|
display: flex;
|
|
806
806
|
flex-direction: column;
|
|
807
807
|
height: 100%;
|
|
@@ -897,7 +897,7 @@ Resources:
|
|
|
897
897
|
&& {
|
|
898
898
|
margin-top: 14px;
|
|
899
899
|
}
|
|
900
|
-
`,
|
|
900
|
+
`,jr=z.div`
|
|
901
901
|
display: flex;
|
|
902
902
|
flex-direction: column;
|
|
903
903
|
align-items: center;
|
|
@@ -926,7 +926,7 @@ Resources:
|
|
|
926
926
|
`,as=z.div`
|
|
927
927
|
display: flex;
|
|
928
928
|
justify-content: center;
|
|
929
|
-
`;import{useEffect as qr,useState as kt}from"react";import Pt from"styled-components";import{Fragment as us,jsx as
|
|
929
|
+
`;import{useEffect as qr,useState as kt}from"react";import Pt from"styled-components";import{Fragment as us,jsx as ve,jsxs as _t}from"react/jsx-runtime";var po=2,Yr={metamask:{name:"MetaMask",component:ge},coinbase_wallet:{name:"Coinbase Wallet",component:ne},wallet_connect:{name:"WalletConnect",component:at}},Jr=()=>{var xe;let[t,e]=kt(!1),[o,r]=kt(void 0),{navigateBack:i}=w(),{getAuthMeta:n,closePrivyModal:s,loginWithWallet:c,handleLoginError:f}=_(),[h,P]=kt(0),{user:C}=N(),[A,b]=kt((C==null?void 0:C.linkedAccounts.length)||0);qr(()=>{r(void 0),c().then(()=>e(!0)).catch(v=>{v instanceof B?console.error(v.cause):console.error(v);let Z=(v==null?void 0:v.status)===401&&(v==null?void 0:v.message)==="User is not allowed to login to this app.";(v==null?void 0:v.status)===422?r(Fe.ERROR_USER_EXISTS):Z?r(Fe.ERROR_WALLET_NOT_ALLOWED):v instanceof _e&&!v.details.default?r(v.details):v instanceof ke?r(Fe.ERROR_TIMED_OUT):r(Fe.ERROR_WALLET_CONNECTION),f(Z)})},[h]),qr(()=>{if(t){let v=setTimeout(s,Le);return()=>clearTimeout(v)}},[C]);let x=((xe=n())==null?void 0:xe.wallet)||"metamask",a=Yr[x].name,y=Yr[x].component,F=t?`Successfully connected with ${a}`:o?o.message:`Waiting for ${a}`,W="";if(t){let v=(C==null?void 0:C.linkedAccounts.length)||0;A===v?W="Wallet was already linked.":W="You\u2019re good to go!"}else if(h>=po&&o)W="Unable to connect wallet";else if(o)W=o.detail;else switch(W="Don\u2019t see your wallet modal? Check your other browser windows.",x){case"wallet_connect":W="Open your mobile wallet app to continue";break;case"coinbase_wallet":st()||(W="Open the Coinbase app on your phone to continue.");break;default:W="Don\u2019t see your wallet modal? Check your other browser windows."}return _t(us,{children:[ve(E,{backFn:i}),_t(ls,{children:[ve(cs,{children:_t("div",{children:[ve(gt,{success:t,fail:!!o}),ve(y,{style:{width:"38px",height:"38px"}})]})}),_t(ds,{children:[ve("h3",{children:F}),ve("p",{children:W})]}),ve(ps,{onClick:()=>{P(h+1),r(void 0)},visible:!t&&(o==null?void 0:o.retryable)&&h<po,disabled:!t&&(!(o!=null&&o.retryable)||h>=po),children:"Retry"})]})]})},ls=Pt.div`
|
|
930
930
|
display: flex;
|
|
931
931
|
flex-direction: column;
|
|
932
932
|
align-items: center;
|
|
@@ -1271,7 +1271,7 @@ Resources:
|
|
|
1271
1271
|
display: none;
|
|
1272
1272
|
}
|
|
1273
1273
|
}
|
|
1274
|
-
`;import{useEffect as Ts}from"react";import{useEffect as ri,useState as ii}from"react";import Rt from"styled-components";import{Fragment as Ls,jsx as
|
|
1274
|
+
`;import{useEffect as Ts}from"react";import{useEffect as ri,useState as ii}from"react";import Rt from"styled-components";import{Fragment as Ls,jsx as be,jsxs as It}from"react/jsx-runtime";var ni={google:{name:"Google",component:ht},discord:{name:"Discord",component:pt},twitter:{name:"Twitter",component:ct}},ys=t=>t.charAt(0).toUpperCase()+t.slice(1),uo=()=>{let t=new URL(window.location.href);t.searchParams.delete("privy_oauth_code"),t.searchParams.delete("privy_oauth_provider"),t.searchParams.delete("privy_oauth_state"),window.history.pushState({},"",t)},si=()=>{var x;let[t,e]=ii(!1),[o,r]=ii(void 0),{getAuthMeta:i,initLoginWithOAuth:n,loginWithOAuth:s,closePrivyModal:c}=_(),{ready:f}=N(),h=((x=i())==null?void 0:x.provider)||"google",P=ni[h].name,C=ni[h].component;ri(()=>{!f||s().then(()=>{uo(),e(!0)}).catch(a=>{let y={retryable:!1,message:"Authentication failed."};a.message.includes("Another user has already linked this")?y.detail="This account has already been linked to another user.":a.message==="Invalid code during oauth flow."?(y.retryable=!0,y.detail="Something went wrong. Try again."):a.message==="User denied confirmation during OAuth flow"&&(y.detail=`Retry and check ${ys(h)} to finish connecting your account.`,y.retryable=!0),uo(),r(y)})},[f]),ri(()=>{if(!t)return;let a=setTimeout(c,Le);return()=>clearTimeout(a)},[t]);let A=t?`Successfully connected with ${P}`:o?o.message:`Verifying connection to ${P}`,b="";return t?b="You\u2019re good to go!":o?b=o.detail:b="Just a few moments more",It(Ls,{children:[be(E,{}),It(Cs,{children:[be(bs,{children:It("div",{children:[be(gt,{success:t,fail:!!o}),be(C,{style:{width:"38px",height:"38px"},logoFill:"primary"})]})}),It(vs,{children:[be("h3",{children:A}),be("p",{children:b})]}),be(xs,{onClick:()=>{uo(),n(h),r(void 0)},visible:!t&&(o==null?void 0:o.retryable),disabled:!t&&!(o!=null&&o.retryable),children:"Retry"})]})]})},Cs=Rt.div`
|
|
1275
1275
|
display: flex;
|
|
1276
1276
|
flex-direction: column;
|
|
1277
1277
|
align-items: center;
|
|
@@ -1318,7 +1318,7 @@ Resources:
|
|
|
1318
1318
|
opacity: ${t=>t.visible?"1":"0"};
|
|
1319
1319
|
transition: opacity 200ms;
|
|
1320
1320
|
}
|
|
1321
|
-
`;import{Fragment as Es,jsx as Oe,jsxs as As}from"react/jsx-runtime";var ai=()=>{let{app:t}=w();return As(Es,{children:[Oe(E,{},"header"),Oe(Me,{title:"Connect your email",description:`Add your email to your ${t==null?void 0:t.name} account`,icon:Oe(ft,{})}),Oe(se,{children:Oe(yt,{stacked:!0})}),Oe(q,{protectedByPrivy:!0})]})};import{Fragment as ks,jsx as Ue,jsxs as _s}from"react/jsx-runtime";var li=()=>{let{app:t}=w();return _s(ks,{children:[Ue(E,{},"header"),Ue(Me,{title:"Connect your phone",description:`Add your number to your ${t==null?void 0:t.name} account`,icon:Ue(Ct,{})}),Ue(se,{children:Ue(vt,{stacked:!0})}),Ue(q,{protectedByPrivy:!0})]})};import{Fragment as Ps,jsx as
|
|
1321
|
+
`;import{Fragment as Es,jsx as Oe,jsxs as As}from"react/jsx-runtime";var ai=()=>{let{app:t}=w();return As(Es,{children:[Oe(E,{},"header"),Oe(Me,{title:"Connect your email",description:`Add your email to your ${t==null?void 0:t.name} account`,icon:Oe(ft,{})}),Oe(se,{children:Oe(yt,{stacked:!0})}),Oe(q,{protectedByPrivy:!0})]})};import{Fragment as ks,jsx as Ue,jsxs as _s}from"react/jsx-runtime";var li=()=>{let{app:t}=w();return _s(ks,{children:[Ue(E,{},"header"),Ue(Me,{title:"Connect your phone",description:`Add your number to your ${t==null?void 0:t.name} account`,icon:Ue(Ct,{})}),Ue(se,{children:Ue(vt,{stacked:!0})}),Ue(q,{protectedByPrivy:!0})]})};import{Fragment as Ps,jsx as Ye,jsxs as di}from"react/jsx-runtime";var ci=()=>{let{app:t}=w();return di(Ps,{children:[Ye(E,{},"header"),Ye(Pr,{title:"Connect your wallet",description:`Link a wallet to your ${t==null?void 0:t.name} account`}),di(se,{children:[Ye(lt,{}),Ye(dt,{})]}),Ye(q,{protectedByPrivy:!0})]})};import{jsx as R,jsxs as pi}from"react/jsx-runtime";var Is=()=>{let{ready:t}=N(),{isLinking:e}=_(),{ready:o,currentScreen:r}=w(),i;return["AWAITING_CONNECTION","AWAITING_OAUTH_SCREEN"].includes(r)?i="compact":"WALLET_EDUCATION"===r?i="full":e?i="medium":i="full",!t||!o?pi(Et,{"data-height":i,children:[R(E,{}),R(Ws,{children:R(ae,{})}),R(X,{})]}):pi(Et,{"data-height":i,children:[r==="LANDING"&&R(Ar,{}),r==="AWAITING_PASSWORDLESS_CODE"&&R(Mr,{}),r==="WALLET_EDUCATION"&&R(Zr,{}),r==="AWAITING_CONNECTION"&&R(Jr,{}),r==="AWAITING_OAUTH_SCREEN"&&R(si,{}),r==="INSTALL_METAMASK_SCREEN"&&R(Xr,{}),r==="INSTALL_COINBASE_WALLET_SCREEN"&&R(ti,{}),r==="LINK_EMAIL_SCREEN"&&R(ai,{}),r==="LINK_PHONE_SCREEN"&&R(li,{}),r==="LINK_WALLET_SCREEN"&&R(ci,{})]})},ui=()=>{let{app:t}=w();return Ss.createPortal(R(Ms,{id:"privy-dialog",children:R(oi,{accentColor:t==null?void 0:t.accentColor,children:R(Is,{})})}),document.body)},Rs=({children:t,...e})=>(Ts(()=>{var r;(r=document==null?void 0:document.activeElement)==null||r.blur();let o=(document==null?void 0:document.getElementById("root"))||(document==null?void 0:document.getElementById("__next"));if(!!o)return o.setAttribute("inert","true"),()=>{let i=(document==null?void 0:document.getElementById("root"))||(document==null?void 0:document.getElementById("__next"));!i||i.removeAttribute("inert")}},[e.open,e.onClose]),R("dialog",{open:!0,role:"dialog",...e,children:t})),Ms=ho(Rs)`
|
|
1322
1322
|
position: fixed;
|
|
1323
1323
|
top: 0;
|
|
1324
1324
|
left: 0;
|
|
@@ -1376,4 +1376,4 @@ Resources:
|
|
|
1376
1376
|
align-items: center;
|
|
1377
1377
|
justify-content: center;
|
|
1378
1378
|
height: 100%;
|
|
1379
|
-
`;import{Fragment as Gs,jsx as
|
|
1379
|
+
`;import{Fragment as Gs,jsx as Je,jsxs as Hs}from"react/jsx-runtime";function Os(t){return typeof t=="string"&&t.length===25}var Wt;function Us(){if(!Wt){let t=L.get(Ee);return Promise.resolve(t||null)}return Wt.getAccessToken()}var Ds=t=>{if(!Os(t.appId))throw new p("Cannot initialize the Privy provider with an invalid Privy app ID");let[e,o]=oe(null);return Mt(()=>{Wt=new Ge({appId:t.appId,apiURL:yo}),o(Wt)},[]),e===null?Je(Gs,{}):Je(Vs,{...t,client:e})},Fs=(t,e)=>{if(e)return{email:!1,sms:!1,wallet:!1,google:!1,twitter:!1,discord:!1,[e]:!0};let o=!!(t!=null&&t.emailAuth),r=!!(t!=null&&t.smsAuth);return o&&r&&(console.warn("Enabling both email and SMS passwordless is not currently supported. Disabling SMS."),r=!1),{email:o,sms:r,wallet:!!(t!=null&&t.walletAuth),google:!!(t!=null&&t.googleOAuth),twitter:!!(t!=null&&t.twitterOAuth),discord:!!(t!=null&&t.discordOAuth)}},Vs=t=>{let e=t.client,[o,r]=oe(!1),[i,n]=oe(!1),[s,c]=oe(!1),[f,h]=oe(null),[P,C]=oe(!1),[A,b]=oe({accentColor:"#696ffd",theme:"System",emailAuth:!0,smsAuth:!1,walletAuth:!0,googleOAuth:!1,twitterOAuth:!1,discordOAuth:!1,termsAndConditionsUrl:null,privacyPolicyUrl:null}),[x,a]=oe(null),[y,F]=oe(!1);Mt(()=>{async function l(){let d=await e.getAppSettings();b(d)}l()},[]);let W=Fs(A,x),xe=()=>{let l=new URLSearchParams(window.location.search),d=l.get("privy_oauth_code"),k=l.get("privy_oauth_state"),S=l.get("privy_oauth_provider");d&&k&&S&&(e.startAuthFlow(new Pe(S,d,k)),a(S),r(!0))};Mt(()=>{async function l(){xe();let d=await e.getAuthenticatedUser();c(!!d),h(d),n(!0)}l()},[]),Mt(()=>{i&&s&&f===null&&e.getAuthenticatedUser().then(h)},[i,s,f]);let v={ready:i,authenticated:s,user:f,walletConnector:e.connector,linkWallet:()=>{a("wallet"),F(!0),r(!0)},linkEmail:()=>{a("email"),F(!0),r(!0)},linkPhone:()=>{a("sms"),F(!0),r(!0)},linkGoogle:async()=>{await Z.initLoginWithOAuth("google")},linkTwitter:async()=>{await Z.initLoginWithOAuth("twitter")},linkDiscord:async()=>{await Z.initLoginWithOAuth("discord")},login:()=>{if(i&&s){console.warn("Attempted to log in, but user is already logged in. Use a `link` helper instead.");return}r(!0)},logout:async()=>{await e.logout(),h(null),c(!1),a(null),F(!1),r(!1)},getAccessToken:()=>e.getAccessToken(),getEthereumProvider:()=>e.connector.getEthereumProvider(),getEthersProvider:()=>new Ns(new me(e.connector.getEthereumProvider())),getWeb3jsProvider:()=>new nt(e.connector.getEthereumProvider()),unlinkWallet:async l=>{let d=await e.unlinkWallet(l);return h(d),d},unlinkEmail:async l=>{let d=await e.unlinkEmail(l);return h(d),d},unlinkPhone:async l=>{let d=await e.unlinkPhone(l);return h(d),d},unlinkGoogle:async l=>{let d=await e.unlinkOAuth("google",l);return h(d),d},unlinkTwitter:async l=>{let d=await e.unlinkOAuth("twitter",l);return h(d),d},unlinkDiscord:async l=>{let d=await e.unlinkOAuth("discord",l);return h(d),d},setActiveWallet:l=>{if(!f)return;let d=e.setActiveWallet(l,f);h(d)},forkSession:()=>e.forkSession()},Z={isLinking:y,getAuthFlow:()=>e.authFlow,getAuthMeta:()=>{var l;return(l=e.authFlow)==null?void 0:l.meta},closePrivyModal:()=>{var l;i&&s&&f&&((l=t.onSuccess)==null||l.call(t,f,P)),e.authFlow=void 0,a(null),F(!1),C(!1),r(!1)},initLoginWithWallet:l=>{l||(l="metamask"),e.connector.walletType=l,e.startAuthFlow(new He(e.connector))},initLoginWithOAuth:async l=>{e.startAuthFlow(new Pe(l));let d=await e.authFlow.getAuthorizationUrl();d&&d.url&&window.location.assign(d.url)},loginWithOAuth:async()=>{if(!(e.authFlow instanceof Pe))throw new p("Must initialize OAuth flow before calling loginWithOAuth");let l,d;y?l=await e.link():{user:l,isNewUser:d}=await e.authenticate(),h(l),C(d||!1),c(!0)},loginWithWallet:async()=>{if(!(e.authFlow instanceof He))throw new p("Must initialize SIWE flow first.");let l,d;y?(l=await e.link(),l&&(L.del(K),l=De(l))):{user:l,isNewUser:d}=await e.authenticate(),h(l||f||null),C(d||!1),c(!0)},loginWithEmail:async l=>{let d=new Be(l);e.startAuthFlow(d),await d.sendCodeEmail()},loginWithSms:async l=>{let d=new ze(l);e.startAuthFlow(d),await d.sendSmsCode()},resendEmailCode:async()=>{var l;await((l=e.authFlow)==null?void 0:l.sendCodeEmail())},resendSmsCode:async()=>{var l;await((l=e.authFlow)==null?void 0:l.sendSmsCode())},loginWithCode:async l=>{if(e.authFlow instanceof Be)e.authFlow.meta.emailCode=l.trim();else if(e.authFlow instanceof ze)e.authFlow.meta.smsCode=l.trim();else throw new p("Must initialize a passwordless code flow first");let d,k;y?d=await e.link():{user:d,isNewUser:k}=await e.authenticate(),h(d||f||null),C(k||!1),c(!0)},handleLoginError:async l=>{var d;e.authFlow=void 0,a(null),F(!1),C(!1),(d=t.onError)==null||d.call(t,l)}};return Hs(jt.Provider,{value:v,children:[t.children,Je($t.Provider,{value:Z,children:Je(qo,{appSettings:A,options:W,visible:o,authenticated:s,children:o&&Je(ui,{})})})]})};export{me as AsExternalProvider,Ge as PrivyClient,Ve as PrivyConnector,Ds as PrivyProvider,he as PrivyProxyProvider,Dt as VERSION,Us as getAccessToken,N as usePrivy};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@privy-io/react-auth",
|
|
3
|
-
"version": "1.12.0-beta.
|
|
3
|
+
"version": "1.12.0-beta.2",
|
|
4
4
|
"description": "React client for the Privy Auth API",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"authentication",
|
|
@@ -17,14 +17,14 @@
|
|
|
17
17
|
"url": "git+https://github.com/privy-io/react-auth.git"
|
|
18
18
|
},
|
|
19
19
|
"license": "Apache-2.0",
|
|
20
|
-
"main": "./dist/index.
|
|
21
|
-
"module": "./dist/index.
|
|
20
|
+
"main": "./dist/index.js",
|
|
21
|
+
"module": "./dist/index.js",
|
|
22
22
|
"types": "./dist/index.d.ts",
|
|
23
23
|
"typings": "./dist/index",
|
|
24
24
|
"exports": {
|
|
25
25
|
".": {
|
|
26
|
-
"
|
|
27
|
-
"
|
|
26
|
+
"import": "./dist/index.js",
|
|
27
|
+
"require": "./dist/index.cjs",
|
|
28
28
|
"types": "./dist/index.d.ts"
|
|
29
29
|
}
|
|
30
30
|
},
|
|
@@ -77,7 +77,7 @@
|
|
|
77
77
|
"semantic-release": "^19.0.5",
|
|
78
78
|
"ts-jest": "^29.0.3",
|
|
79
79
|
"tsup": "^6.2.3",
|
|
80
|
-
"typescript": "^4.
|
|
80
|
+
"typescript": "^4.9.4"
|
|
81
81
|
},
|
|
82
82
|
"peerDependencies": {
|
|
83
83
|
"react": "^18",
|