@nexus-cross/crossx-sdk-core 1.0.7 → 1.0.9
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/adapters/confirmation/BrowserConfirmationAdapter.d.ts +3 -0
- package/dist/adapters/confirmation/BrowserConfirmationAdapter.d.ts.map +1 -1
- package/dist/core/config/environments.d.ts +7 -5
- package/dist/core/config/environments.d.ts.map +1 -1
- package/dist/core/i18n/index.d.ts +14 -0
- package/dist/core/i18n/index.d.ts.map +1 -0
- package/dist/core/i18n/messages.en.d.ts +4 -0
- package/dist/core/i18n/messages.en.d.ts.map +1 -0
- package/dist/core/i18n/messages.ko.d.ts +4 -0
- package/dist/core/i18n/messages.ko.d.ts.map +1 -0
- package/dist/core/i18n/types.d.ts +31 -0
- package/dist/core/i18n/types.d.ts.map +1 -0
- package/dist/core/index.d.ts +1 -0
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/ports/ConfirmationPort.d.ts +6 -0
- package/dist/core/ports/ConfirmationPort.d.ts.map +1 -1
- package/dist/core/types/index.d.ts +8 -0
- package/dist/core/types/index.d.ts.map +1 -1
- package/dist/crossx.global +1228 -0
- package/dist/index.cjs +29 -29
- package/dist/index.js +517 -428
- package/dist/sdk/CROSSxSDK.d.ts +11 -0
- package/dist/sdk/CROSSxSDK.d.ts.map +1 -1
- package/package.json +5 -2
|
@@ -0,0 +1,1228 @@
|
|
|
1
|
+
var CROSSx=function(Z){"use strict";var ro=Object.defineProperty;var no=(Z,g,_)=>g in Z?ro(Z,g,{enumerable:!0,configurable:!0,writable:!0,value:_}):Z[g]=_;var v=(Z,g,_)=>no(Z,typeof g!="symbol"?g+"":g,_);var g=(r=>(r.AUTH_NOT_INITIALIZED="AUTH_NOT_INITIALIZED",r.AUTH_FAILED="AUTH_FAILED",r.AUTH_TOKEN_INVALID="AUTH_TOKEN_INVALID",r.AUTH_TOKEN_EXPIRED="AUTH_TOKEN_EXPIRED",r.AUTH_NOT_AUTHENTICATED="AUTH_NOT_AUTHENTICATED",r.WALLET_NOT_FOUND="WALLET_NOT_FOUND",r.WALLET_CREATION_FAILED="WALLET_CREATION_FAILED",r.SIGN_FAILED="SIGN_FAILED",r.SIGN_REJECTED="SIGN_REJECTED",r.TX_FAILED="TX_FAILED",r.TX_REJECTED="TX_REJECTED",r.USER_REJECTED="USER_REJECTED",r.TX_INVALID_PARAMS="TX_INVALID_PARAMS",r.NETWORK_ERROR="NETWORK_ERROR",r.NETWORK_NOT_CONFIGURED="NETWORK_NOT_CONFIGURED",r.INVALID_CHAIN="INVALID_CHAIN",r.CHAIN_NOT_SUPPORTED="CHAIN_NOT_SUPPORTED",r.CHAIN_ADAPTER_NOT_FOUND="CHAIN_ADAPTER_NOT_FOUND",r.NOT_IMPLEMENTED="NOT_IMPLEMENTED",r.SIGNATURE_FAILED="SIGNATURE_FAILED",r.TRANSACTION_FAILED="TRANSACTION_FAILED",r.PREPARE_FAILED="PREPARE_FAILED",r.PREPARE_EXPIRED="PREPARE_EXPIRED",r.PREPARE_MISMATCH="PREPARE_MISMATCH",r.MIGRATION_FAILED="MIGRATION_FAILED",r.MIGRATION_BACKUP_EXISTS="MIGRATION_BACKUP_EXISTS",r.GATEWAY_INTERNAL_ERROR="GATEWAY_INTERNAL_ERROR",r.GATEWAY_LOCK_CONFLICT="GATEWAY_LOCK_CONFLICT",r.PROJECT_ID_MISSING="PROJECT_ID_MISSING",r.ORIGIN_NOT_ALLOWED="ORIGIN_NOT_ALLOWED",r.APP_IDENTIFIER_MISSING="APP_IDENTIFIER_MISSING",r.INVALID_APP_TYPE="INVALID_APP_TYPE",r.PROJECT_NOT_REGISTERED="PROJECT_NOT_REGISTERED",r.SIGNATURE_SIGNER_MISMATCH="SIGNATURE_SIGNER_MISMATCH",r.GAS_ESTIMATION_FAILED="GAS_ESTIMATION_FAILED",r.TYPED_DATA_CHAIN_ID_MISMATCH="TYPED_DATA_CHAIN_ID_MISMATCH",r.INVALID_CONFIG="INVALID_CONFIG",r.UNKNOWN_ERROR="UNKNOWN_ERROR",r))(g||{});class _ extends Error{constructor(e,s,t){super(s),this.code=e,this.details=t,this.name="CROSSxError",Object.setPrototypeOf(this,_.prototype)}toJSON(){return{name:this.name,code:this.code,message:this.message,details:this.details}}}const De={CROSS_MAINNET:{caipId:"eip155:612055",chainId:612055,name:"CROSS Mainnet",nativeCurrency:{symbol:"CROSS",decimals:18},rpcUrl:"https://mainnet.crosstoken.io:22001"},CROSS_TESTNET:{caipId:"eip155:612044",chainId:612044,name:"CROSS Testnet",nativeCurrency:{symbol:"tCROSS",decimals:18},rpcUrl:"https://testnet.crosstoken.io:22001",testnet:!0},BSC_MAINNET:{caipId:"eip155:56",chainId:56,name:"BNB Smart Chain",nativeCurrency:{symbol:"BNB",decimals:18},rpcUrl:"https://bsc-mainnet.crosstoken.io/2272489872e4f1475ff25d57ce93b51989f933c7"},BSC_TESTNET:{caipId:"eip155:97",chainId:97,name:"BNB Smart Chain Testnet",nativeCurrency:{symbol:"BNB",decimals:18},rpcUrl:"https://bsc-testnet.crosstoken.io/110ea3628b77f244e5dbab16790d81bba874b962",testnet:!0},RONIN_MAINNET:{caipId:"eip155:2020",chainId:2020,name:"Ronin",nativeCurrency:{symbol:"RON",decimals:18},rpcUrl:"https://api.roninchain.com/rpc"},RONIN_SAIGON:{caipId:"eip155:202601",chainId:202601,name:"Ronin Saigon",nativeCurrency:{symbol:"RON",decimals:18},rpcUrl:"https://saigon-testnet.roninchain.com/rpc",testnet:!0}},Ns=Object.fromEntries(Object.entries(De).map(([r,e])=>[r,e.caipId])),ks=new Map(Object.values(De).map(r=>[r.caipId,r]));new Map(Object.values(De).map(r=>[r.chainId,r]));const Ps={symbol:"",decimals:18};function Xe(r){var e;return((e=ks.get(r))==null?void 0:e.nativeCurrency)??Ps}class yt{constructor(e,s){this.sdk=e,this.chainId=s,this._listeners=new Map}async request({method:e,params:s=[]}){switch(e){case"eth_accounts":case"eth_requestAccounts":{const t=await this.sdk.getAddress();return t?[t.address]:[]}case"eth_chainId":return this._caip2ToHex(this.chainId);case"net_version":return this.chainId.split(":")[1]??"1";case"eth_signTransaction":{const t=this._normalizeEIP1193Tx(s[0]);return(await this.sdk.signTransaction(this.chainId,t)).signedTx}case"eth_sendTransaction":{const t=this._normalizeEIP1193Tx(s[0]);return(await this.sdk.sendTransaction(this.chainId,t)).txHash}case"personal_sign":case"eth_sign":throw new _(g.NOT_IMPLEMENTED,`${e}은(는) 아직 지원되지 않습니다. sdk.signMessage()를 직접 사용하세요.`);case"eth_signTypedData":case"eth_signTypedData_v1":case"eth_signTypedData_v3":case"eth_signTypedData_v4":throw new _(g.NOT_IMPLEMENTED,`${e}은(는) 아직 지원되지 않습니다. sdk.signTypedData() 또는 sdk.signTypedDataOffchain()을 직접 사용하세요.`);default:return this.sdk.walletRpc(e,s,this.chainId)}}on(e,s){return this._listeners.has(e)||this._listeners.set(e,new Set),this._listeners.get(e).add(s),this}removeListener(e,s){var t;return(t=this._listeners.get(e))==null||t.delete(s),this}emit(e,...s){var t;(t=this._listeners.get(e))==null||t.forEach(n=>n(...s))}_caip2ToHex(e){const s=e.split(":");return`0x${parseInt(s[1]??"1",10).toString(16)}`}_normalizeEIP1193Tx(e){return{from:e.from,to:e.to,value:e.value,data:e.data,gasLimit:e.gasLimit??e.gas,gasPrice:e.gasPrice,maxFeePerGas:e.maxFeePerGas,maxPriorityFeePerGas:e.maxPriorityFeePerGas,nonce:e.nonce!==void 0?parseInt(String(e.nonce),16):void 0,chainId:parseInt(this.chainId.split(":")[1]??"1",10)}}}let ye=null;function oo(r){}function bt(r){ye=r}const p={log(...r){if(ye){ye.log(...r);return}},warn(...r){if(ye){ye.warn(...r);return}},error(...r){if(ye){ye.error(...r);return}}},Ls={confirm:"확인",cancel:"취소",close:"닫기",signMessage_title:"메시지 서명",signTypedData_title:"데이터 서명",signTransaction_title:"트랜잭션 서명",sendTransaction_title:"트랜잭션 전송",tx_pending:"트랜잭션 처리 중...",tx_success:"트랜잭션이 완료되었습니다",tx_failed:"트랜잭션이 실패했습니다",tx_timeout:"트랜잭션 확인 시간이 초과되었습니다",loginSelector_title:"로그인 방법 선택",loginSelector_google:"Google로 계속하기",loginSelector_apple:"Apple로 계속하기",migration_foundTitle:"기존 지갑 발견",migration_foundDescription:"기존 CROSSx 지갑이 발견되었습니다. 복구하시겠습니까?",migration_recoverButton:"복구하기",migration_skipButton:"건너뛰기",pinInput_title:"PIN 입력",pinInput_placeholder:"4자리 PIN을 입력하세요",pinInput_error:"PIN이 올바르지 않습니다. 다시 시도해 주세요.",walletSelector_title:"지갑 선택",walletSelector_addButton:"지갑 추가",walletSelector_selected:"선택됨"},vt={confirm:"Confirm",cancel:"Cancel",close:"Close",signMessage_title:"Sign Message",signTypedData_title:"Sign Data",signTransaction_title:"Sign Transaction",sendTransaction_title:"Send Transaction",tx_pending:"Processing transaction...",tx_success:"Transaction completed",tx_failed:"Transaction failed",tx_timeout:"Transaction confirmation timed out",loginSelector_title:"Choose a sign-in method",loginSelector_google:"Continue with Google",loginSelector_apple:"Continue with Apple",migration_foundTitle:"Existing Wallet Found",migration_foundDescription:"An existing CROSSx wallet was found. Would you like to recover it?",migration_recoverButton:"Recover",migration_skipButton:"Skip",pinInput_title:"Enter PIN",pinInput_placeholder:"Enter your 4-digit PIN",pinInput_error:"Incorrect PIN. Please try again.",walletSelector_title:"Select Wallet",walletSelector_addButton:"Add Wallet",walletSelector_selected:"Selected"},Ds={ko:Ls,en:vt};function St(r="en",e){return Ds[r]??vt}const Qe="crossx_access_token",Me="crossx_refresh_token",$e="crossx_user_info";class Ms{constructor(e,s,t,n,o,i,a){this.config=e,this.storage=s,this.crypto=t,this.oauth=n,this.transport=o,this.walletProvider=i,this.tokenStore=a,this._refreshPromise=null}get useCookieAuth(){return this.config.authMode==="cookie"}checkResponseError(e,s){if(e!=null&&e.code&&e.code!==200&&e.code>0)throw new _(g.AUTH_FAILED,`${s} 실패 (코드 ${e.code}): ${e.message}`);const t=e==null?void 0:e.data;if(typeof t=="object"&&t!==null&&"code"in t){const n=t;if(n.code&&n.code!==200&&n.code>0)throw new _(g.AUTH_FAILED,`${s} 실패 (코드 ${n.code}): ${n.message}`)}}async execute(e){var n,o,i,a;let s,t=!1;try{const c=e==null?void 0:e.provider;let l="/login";c==="google"?l="/google":c==="apple"&&(l="/apple");const{oauthServiceUrl:d,authApiUrl:f}=this.config,w=`${d}${l}`;p.log(`[CROSSx] OAuth 팝업 열기 (${c||"일반"} 로그인):`,w);const x=await this.oauth.openAuth({authUrl:w,expectedOrigin:new URL(d).origin});p.log("[CROSSx] OAuth Firebase 토큰 받음 (length:",x.length,")");const{accessToken:m,refreshToken:A}=await this.exchangeFirebaseToken(x,f);let y,I;try{const F=this.crypto.decodeJWT(x);I=(n=F.firebase)==null?void 0:n.sign_in_provider;const $=((o=F.firebase)==null?void 0:o.identities)??{};I==="google.com"?y=(i=$["google.com"])==null?void 0:i[0]:I==="apple.com"&&(y=(a=$["apple.com"])==null?void 0:a[0]),p.log("[CROSSx] OAuth provider sub 추출 — provider:",I,"hasProviderSub:",!!y)}catch{p.warn("[CROSSx] firebaseToken에서 providerSub 추출 실패")}if(m){const F=this.crypto.decodeJWT(m);p.log("[CROSSx] access_token 디코딩 — sub:",F.sub,"exp:",F.exp);const $=await this.crypto.verifyJWT(m);if(t=$.signatureVerified??!1,!$.valid)throw p.error("[CROSSx] access_token 검증 실패"),new Error("유효하지 않은 access token");const B=$.payload;s={id:B.sub,email:B.email,signInProvider:I,providerSub:y},this.tokenStore.set(m),this.useCookieAuth||(await this.storage.set(Qe,m),A&&await this.storage.set(Me,A))}else{const F=this.crypto.decodeJWT(x);s={id:F.sub,email:F.email,signInProvider:I,providerSub:y},p.log("[CROSSx] Cookie 모드 — Firebase 토큰에서 사용자 정보 추출 — id:",s.id)}p.log("[CROSSx] 사용자 정보 — id:",s.id);const L=this.useCookieAuth?{id:s.id,signInProvider:s.signInProvider,providerSub:s.providerSub}:s;await this.storage.set($e,L),p.log("[CROSSx] 사용자 정보 저장 완료 (authMode:",this.useCookieAuth?"cookie":"token",")")}catch(c){return p.error("[CROSSx] SignIn 에러 (OAuth/토큰 교환 단계):",c),{success:!1,error:c instanceof Error?c.message:"Sign in failed"}}return p.log("[CROSSx][Migration Phase 1] OAuth 로그인 완료, 지갑 로드 시작 — userId:",s.id),this.loadWallet(s,t)}async exchangeFirebaseToken(e,s){const t=this.useCookieAuth,n=t?`${s}/cross-auth/social/login/cookie`:`${s}/cross-auth/social/login`;p.log("[CROSSx] Firebase 토큰 교환 요청:",n);const o=await this.transport.request({url:n,method:"POST",headers:{"Content-Type":"application/json"},body:{auth_code:e,login_type:"firebase"},...t?{credentials:"include"}:{}});p.log("[CROSSx] 토큰 교환 응답 — status:",o.status);const i=o.data;this.checkResponseError(i,"Token exchange");const a=this.extractAccessToken(i);if(t&&!a)return p.log("[CROSSx] Cookie 모드 — 로그인 성공 (JWT는 HttpOnly 쿠키)"),{};if(!a)throw new _(g.AUTH_FAILED,"토큰 교환 응답에서 access_token을 찾을 수 없습니다");p.log("[CROSSx] access_token 교환 성공");let c;return t||(c=this.extractRefreshToken(i)),{accessToken:a,refreshToken:c}}extractAccessToken(e){const s=(e==null?void 0:e.data)??e;if(this.isJwtString(s))return s;if(typeof s=="object"&&s!==null){const t=s;if(this.isJwtString(t.data))return t.data;if(typeof t.data=="object"&&t.data!==null){const o=t.data,i=o.access_token??o.token;if(typeof i=="string")return i}const n=t.access_token??t.token;if(typeof n=="string")return n}}extractRefreshToken(e){const s=(e==null?void 0:e.data)??e;if(typeof s!="object"||s===null)return;const t=s;if(typeof t.data=="object"&&t.data!==null){const o=t.data,i=o.refresh_token??o.refresh;if(typeof i=="string")return i}const n=t.refresh_token??t.refresh;if(typeof n=="string")return n}isJwtString(e){return typeof e=="string"&&e.split(".").length===3}async restoreSession(){try{const e=this.tokenStore.get();if(e){const t=await this.crypto.verifyJWT(e);if(t.valid){const n=await this.storage.get($e);if(n)return p.log("[CROSSx] restoreSession — 메모리 토큰 유효, 세션 복원"),this.loadWallet(n,t.signatureVerified)}this.tokenStore.clear()}if(this.useCookieAuth){p.log("[CROSSx] restoreSession — 쿠키 기반 silentRefresh 시도");const t=await this.silentRefresh();t&&this.tokenStore.set(t)}else{const t=await this.storage.get(Qe),n=await this.storage.get(Me);if(p.log("[CROSSx] restoreSession — access_token:",t?"있음":"없음","refresh_token:",n?"있음":"없음"),!n)return p.log("[CROSSx] restoreSession — refresh_token 없음, 세션 복원 생략"),null;t&&this.tokenStore.set(t);const o=await this.silentRefresh(n);p.log("[CROSSx] restoreSession — silentRefresh 결과:",o?"토큰 발급 성공":"토큰 없음"),o&&this.tokenStore.set(o)}const s=await this.storage.get($e);if(p.log("[CROSSx] restoreSession — userInfo 조회:",s?`있음 (id: ${s.id})`:"없음"),!s)return null;p.log("[CROSSx] restoreSession — silentRefresh 성공, 세션 복원 — userId:",s.id);try{return await this.loadWallet(s,!1)}catch(t){return p.warn("[CROSSx] restoreSession — 지갑 로드 실패 (세션은 유지):",t),{success:!0,user:s,tokenSignatureVerified:!1}}}catch(e){return p.log("[CROSSx] restoreSession — 세션 복원 실패, 스토리지 정리:",e),this.tokenStore.clear(),this.useCookieAuth||await this.storage.remove(Me),await this.storage.remove($e),null}}silentRefresh(e){return this._refreshPromise?this._refreshPromise:(this._refreshPromise=this._doSilentRefresh(e).finally(()=>{this._refreshPromise=null}),this._refreshPromise)}async _doSilentRefresh(e){const{authApiUrl:s}=this.config,t=this.useCookieAuth,n=`${s}/cross-auth/social/refresh/simple`,o={};if(!t){const l=this.tokenStore.get()??"";l&&(o.access_token=l),e&&(o.refresh_token=e)}const i=await this.transport.request({url:n,method:"POST",headers:{"Content-Type":"application/json"},body:o,...t?{credentials:"include"}:{}});p.log("[CROSSx] silentRefresh 응답 — status:",i.status);const a=i.data;this.checkResponseError(a,"Silent refresh");const c=this.extractAccessToken(a);if(t&&!c){p.log("[CROSSx] silentRefresh 성공 (cookie 갱신)");return}if(!c)throw new _(g.AUTH_FAILED,"토큰 자동 갱신 실패: 응답에 토큰이 없습니다");if(this.tokenStore.set(c),!t){await this.storage.set(Qe,c);const l=this.extractRefreshToken(a);l&&await this.storage.set(Me,l)}return p.log("[CROSSx] silentRefresh 성공"),c}async loadWallet(e,s){let t,n=!1;try{p.log("[CROSSx][Migration Phase 2] POST /mnemonic/create 호출 — userId:",e.id),t=(await this.walletProvider.getOrCreateWallet(e.id)).address,p.log("[CROSSx][Migration Phase 2] 지갑 로드 완료 (기존 백업 없음) — address:",t)}catch(o){if(o instanceof _&&o.code===g.MIGRATION_BACKUP_EXISTS)p.log("[CROSSx][Migration Phase 2] Gateway -10012 감지 → needsMigration = true"),n=!0;else{if(o instanceof _&&(o.code===g.PROJECT_NOT_REGISTERED||o.code===g.PROJECT_ID_MISSING||o.code===g.ORIGIN_NOT_ALLOWED))throw p.error("[CROSSx][Migration Phase 2] 프로젝트 설정 에러:",o.message),o;p.warn("[CROSSx][Migration Phase 2] 지갑 로드 실패 (로그인은 유지):",o)}}return p.log("[CROSSx][Migration Phase 2] loadWallet 결과 — address:",t,"needsMigration:",n),{success:!0,address:t,user:e,needsMigration:n,tokenSignatureVerified:s}}}const $s="crossx_access_token",Bs="crossx_refresh_token",Fs="crossx_user_info";class Us{constructor(e,s,t){this.config=e,this.storage=s,this.tokenStore=t}async execute(){this.tokenStore.clear(),this.config.authMode!=="cookie"&&(await this.storage.remove($s),await this.storage.remove(Bs)),await this.storage.remove(Fs)}}class Hs{constructor(e,s){this.storage=e,this.walletProvider=s}async execute(e,s){if(!this.walletProvider.migrateWallet)throw new _(g.NOT_IMPLEMENTED,"현재 환경에서는 마이그레이션이 지원되지 않습니다");p.log("[CROSSx][Migration Phase 4] MigrateWalletUseCase.execute() — pin 길이:",e.length,"sub:",s);const t=await this.walletProvider.migrateWallet(e,s);return p.log("[CROSSx][Migration Phase 5] MigrateWalletUseCase 완료 — address:",t.address),{address:t.address}}}class Gs{constructor(e,s){this.chainRegistry=e,this.transport=s}async call(e,s,t){const n=await this.chainRegistry.getChain(t),o={jsonrpc:"2.0",method:e,params:s,id:Date.now()},a=(await this.transport.request({url:n.rpcUrl,method:"POST",headers:{"Content-Type":"application/json"},body:o})).data;if(a!=null&&a.error)throw new _(g.UNKNOWN_ERROR,`RPC 오류 [${e}] (${t}): ${a.error.message} (코드: ${a.error.code})`);return a==null?void 0:a.result}}class Ws{constructor(){this.listeners=new Map}on(e,s){return this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(s),()=>this.off(e,s)}off(e,s){var t;(t=this.listeners.get(e))==null||t.delete(s)}emit(e,s){var t;(t=this.listeners.get(e))==null||t.forEach(n=>n(s))}removeAllListeners(){this.listeners.clear()}}const Be={production:{oauthServiceUrl:"https://stg-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://stg-cross-auth.crosstoken.io",walletGatewayUrl:"https://stg-embedded-wallet-gateway.crosstoken.io/api/v1"},staging:{oauthServiceUrl:"https://stg-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://stg-cross-auth.crosstoken.io",walletGatewayUrl:"https://stg-embedded-wallet-gateway.crosstoken.io/api/v1"},development:{oauthServiceUrl:"https://dev-cross-wallet-oauth.crosstoken.io",authApiUrl:"https://dev-cross-auth.crosstoken.io",walletGatewayUrl:"https://dev-embedded-wallet-gateway.crosstoken.io/api/v1"}};function qs(r){const e=r.environment;return e&&e in Be?Be[e]:null}function Ks(){try{if(typeof window.__CROSSX_CONFIG__<"u"){const r=typeof window.__CROSSX_CONFIG__=="string"?JSON.parse(window.__CROSSX_CONFIG__):window.__CROSSX_CONFIG__,e=qs(r);if(e)return e}}catch{}return Be.production}const Vs=2e3,Et=6e4,js=1e3,Js=1e4,zs="0x77359400",It="0x3B9ACA00",Tt=130,At=6,Rt=18,Ys=0,Zs=30*1e3,Q=class Q extends Ws{constructor(e,s,t,n,o,i,a,c,l,d){super(),this.storage=t,this.crypto=n,this.transport=o,this.oauth=i,this.walletProvider=a,this.tokenStore=c,this.initialized=!1,this.authenticated=!1,this.userId=null,this.address=null,this.userEmail=null,this.loginType=null,this.providerSub=null,this.tokenSignatureVerified=!1,this._config=Object.freeze({...e}),this.internalConfig=e,this.adapterConfig=s,e.logger&&bt(e.logger),this.confirmation=l,this.chainRegistry=d,this.jsonRpc=new Gs(d,o),this.signInUseCase=new Ms(this.internalConfig,t,n,i,o,a,c),this.signOutUseCase=new Us(this.internalConfig,t,c),this.migrateWalletUseCase=new Hs(t,a)}get config(){return this._config}async initialize(){if(this.initialized)return this.authenticated?{success:!0,address:this.address??void 0}:null;console.log("[CROSSx SDK] v1.0.9 초기화 중..."),this.confirmation.setMessages(St(this._config.locale));try{const e=Ks();this.internalConfig.oauthServiceUrl=e.oauthServiceUrl,this.internalConfig.authApiUrl=e.authApiUrl,this.internalConfig.walletGatewayUrl=e.walletGatewayUrl,this.adapterConfig.gatewayUrl=e.walletGatewayUrl;const s=await this.signInUseCase.restoreSession();return s!=null&&s.success&&this.applyAuthResult(s),this.initialized=!0,this.emit("initialized",{restored:!!(s!=null&&s.success)}),s??null}catch(e){throw new _(g.AUTH_NOT_INITIALIZED,"SDK 초기화에 실패했습니다",e)}}async signIn(e){this.ensureInitialized();let s=e;if(!(e!=null&&e.provider)){const t=await this.confirmation.showLoginSelector();if(t===null)return{success:!1,error:"User cancelled login"};s={...e,provider:t}}try{const t=await this.signInUseCase.execute(s);return t.success&&this.applyAuthResult(t),t}catch(t){throw new _(g.AUTH_FAILED,"로그인에 실패했습니다",t)}}async signInWithCreate(e){const s=await this.signIn(e);if(!s.success)return{...s,addresses:[]};if(s.needsMigration||!s.address){const{address:o}=await this.createWallet(),i=await this.getAddresses(),a=await this.selectWalletIfMultiple(i);return{...s,address:(a==null?void 0:a.address)??o,needsMigration:!1,addresses:i}}const t=await this.getAddresses(),n=await this.selectWalletIfMultiple(t);return{...s,address:(n==null?void 0:n.address)??s.address,addresses:t}}async signOut(){this.ensureInitialized();try{await this.signOutUseCase.execute(),this.clearAuthState()}catch(e){throw new _(g.UNKNOWN_ERROR,"로그아웃에 실패했습니다",e)}}isAuthenticated(){return this.authenticated}get currentAddress(){return this.address}get currentUserId(){return this.userId}isLoggedIn(){return this.isAuthenticated()}async ensureLoggedIn(){if(!this.initialized)return!1;if(this.authenticated)return!0;try{const e=await this.signInUseCase.restoreSession();return e!=null&&e.success?(this.applyAuthResult(e),!0):!1}catch{return!1}}async getUserInfo(){return this.ensureAuthenticated(),{id:this.userId,email:this.userEmail??void 0,loginType:this.loginType??void 0,addresses:this.address?[this.address]:[],tokenSignatureVerified:this.tokenSignatureVerified}}async migrateWallet(e){if(this.ensureAuthenticated(),!this.userId)throw new _(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");try{const s=await this.migrateWalletUseCase.execute(e,this.userId);return this.address=s.address,this.emit("addressChanged",{address:s.address,index:0}),p.log("[CROSSx] migrateWallet 완료 — address:",s.address),s}catch(s){throw s instanceof _?s:new _(g.MIGRATION_FAILED,"지갑 마이그레이션에 실패했습니다",s)}}async getAddress(e){if(e!==void 0){if(this.ensureAuthenticated(),!this.userId)throw new _(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");return{address:(await this.walletProvider.getAddress(this.userId,e)).address,index:e}}return!this.authenticated||!this.address?null:{address:this.address,index:0}}async getAddresses(){return this.ensureAuthenticated(),this.userId?this.walletProvider.getAddresses(this.userId):[]}async selectWallet(e){if(this.ensureAuthenticated(),!this.userId)throw new _(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const s=await this.walletProvider.getAddresses(this.userId),t=await this.confirmation.showWalletSelector(s,async()=>{const n=s.length,i={address:(await this.walletProvider.getAddress(this.userId,n)).address,index:n};return s.push(i),i},e);return t&&(this.address=t.address,this.emit("addressChanged",{address:t.address,index:t.index})),t}async selectWalletIfMultiple(e){return e.length<2?null:this.selectWallet()}async getChains(){this.ensureInitialized();try{return await this.chainRegistry.getChains()}catch(e){throw e instanceof _?e:new _(g.UNKNOWN_ERROR,"체인 목록 조회에 실패했습니다",e)}}async getChain(e){this.ensureInitialized();try{return await this.chainRegistry.getChain(e)}catch(s){throw s instanceof _?s:new _(g.CHAIN_NOT_SUPPORTED,`체인 조회에 실패했습니다: ${e}`,s)}}applyTheme(e=this._config.theme??"light",s=this._config.themeTokens??{}){this._config=Object.freeze({...this._config,theme:e,themeTokens:s}),this.confirmation.setTheme(e,s)}applyLocale(e=this._config.locale??"en"){this._config=Object.freeze({...this._config,locale:e}),this.confirmation.setMessages(St(e))}async createWallet(){if(this.ensureAuthenticated(),!this.userId)throw new _(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");p.log("[CROSSx] 지갑 생성 시작");try{const e=await this.walletProvider.getOrCreateWallet(this.userId);return this.address=e.address,this.emit("addressChanged",{address:e.address,index:0}),p.log("[CROSSx] 지갑 생성 완료:",e.address),{address:e.address}}catch(e){if(e instanceof _&&e.code===g.MIGRATION_BACKUP_EXISTS){const s=this.providerSub??this.userId;p.log("[CROSSx][Migration Phase 3] createWallet() — Gateway -10012 감지, 마이그레이션 UI 시작 — migrationSub:",s);const t=await this.handleMigrationFlow(s);if(t)return this.address=t.address,this.emit("addressChanged",{address:t.address,index:0}),{address:t.address};throw new _(g.MIGRATION_FAILED,"사용자가 마이그레이션을 건너뛰었습니다")}throw e}}async signMessage(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new _(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=t==null?void 0:t.index,o=await this.walletProvider.getAddress(this.userId,n??0);let i;if(this.walletProvider.prepare&&(i=(await this.walletProvider.prepare("sign-message",{message:s,from:o.address})).uuid),!await this.confirmation.requestConfirmation({type:"sign-message",chainId:e,from:o.address,message:s,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new _(g.USER_REJECTED,"사용자가 메시지 서명을 거부했습니다");try{const c=await this.walletProvider.signMessage(this.userId,e,s,t==null?void 0:t.index,i,o.address);return this.verifySignatureSigner(s,c.signature,o.address),{chainId:e,signature:c.signature,message:s,address:o.address}}catch(c){throw c instanceof _?c:new _(g.SIGNATURE_FAILED,`메시지 서명에 실패했습니다 (${e})`,c)}}async signTypedData(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new _(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");if(!this.walletProvider.signTypedData)throw new _(g.NOT_IMPLEMENTED,"signTypedData가 구현되어 있지 않습니다");Q.validateTypedDataChainId(e,s);const n=await this.walletProvider.getAddress(this.userId,(t==null?void 0:t.index)??0);let o;if(this.walletProvider.prepare&&(o=(await this.walletProvider.prepare("sign-typed-data",{typedData:s,from:n.address})).uuid),!await this.confirmation.requestConfirmation({type:"sign-typed-data",chainId:e,from:n.address,typedData:s,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new _(g.USER_REJECTED,"사용자가 타입 데이터 서명을 거부했습니다");try{const a=await this.walletProvider.signTypedData(this.userId,e,s,t==null?void 0:t.index,o,n.address);return Q.validateSignatureFormat(a.signature),{chainId:e,signature:a.signature,address:n.address}}catch(a){throw a instanceof _?a:new _(g.SIGNATURE_FAILED,`타입 데이터 서명에 실패했습니다 (${e})`,a)}}async signTypedDataOffchain(e,s){return this.signTypedData(Q.OFFCHAIN_CHAIN_ID,e,s)}async signTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new _(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.withResolvedGasAndFee(s,e);let o;this.walletProvider.prepare&&(o=(await this.walletProvider.prepare("sign",{tx:n})).uuid);const i=Xe(e);if(!await this.confirmation.requestConfirmation({type:"sign",chainId:e,from:n.from,to:n.to,value:n.value,data:n.data,gasLimit:n.gasLimit,gasPrice:n.gasPrice,maxFeePerGas:n.maxFeePerGas,maxPriorityFeePerGas:n.maxPriorityFeePerGas,nativeSymbol:i.symbol,nativeDecimals:i.decimals,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new _(g.USER_REJECTED,"사용자가 트랜잭션 서명을 거부했습니다");try{const c=await this.walletProvider.signTransaction(this.userId,e,n,t==null?void 0:t.index,o);return Q.validateSignedTxFormat(c.signature),{chainId:e,signedTx:c.signature,txHash:c.txHash??""}}catch(c){if(c instanceof _)throw c;const l=c instanceof Error?c.message:String(c);throw new _(g.SIGNATURE_FAILED,`트랜잭션 서명에 실패했습니다 (${e}): ${l}`,c)}}async sendTransaction(e,s,t){if(this.ensureAuthenticated(),!this.userId)throw new _(g.AUTH_NOT_AUTHENTICATED,"사용자 ID를 찾을 수 없습니다");const n=await this.withResolvedGasAndFee(s,e);let o;this.walletProvider.prepare&&(o=(await this.walletProvider.prepare("send",{tx:n})).uuid);const i=Xe(e);if(!await this.confirmation.requestConfirmation({type:"send",chainId:e,from:n.from,to:n.to,value:n.value,data:n.data,gasLimit:n.gasLimit,gasPrice:n.gasPrice,maxFeePerGas:n.maxFeePerGas,maxPriorityFeePerGas:n.maxPriorityFeePerGas,nativeSymbol:i.symbol,nativeDecimals:i.decimals,dappName:t==null?void 0:t.dappName,accountName:t==null?void 0:t.accountName}))throw new _(g.USER_REJECTED,"사용자가 트랜잭션을 거부했습니다");try{let c;if(this.walletProvider.sendTransaction)c=(await this.walletProvider.sendTransaction(this.userId,e,n,o)).txHash;else{const l=await this.walletProvider.signTransaction(this.userId,e,n,t==null?void 0:t.index,o);c=l.txHash??l.signature}return{chainId:e,txHash:c,status:"pending"}}catch(c){const l=c instanceof Error?c.message:String(c);throw new _(g.TRANSACTION_FAILED,`트랜잭션 전송에 실패했습니다 (${e}): ${l}`,c)}}async getTransactionReceipt(e,s){try{return await this.jsonRpc.call("eth_getTransactionReceipt",[e],s)??null}catch{return null}}async waitForTxAndGetReceipt(e,s,t={}){const n=t.intervalMs??js,o=Js,i=t.timeoutMs??Et,a=Date.now()+i;let c=n;for(;Date.now()<a;){const l=await this.getTransactionReceipt(e,s);if(l)return l;await new Promise(d=>setTimeout(d,c)),c=Math.min(c*2,o)}throw new _(g.UNKNOWN_ERROR,`트랜잭션 영수증 조회 시간이 초과되었습니다 (${e})`)}async sendTransactionWithWaitForReceipt(e,s,t={}){var A,y;const{intervalMs:n,timeoutMs:o,...i}=t,{txHash:a}=await this.sendTransaction(e,s,i),c=n??((A=this._config.receiptPolling)==null?void 0:A.intervalMs)??Vs,l=o??((y=this._config.receiptPolling)==null?void 0:y.timeoutMs)??Et,d=Xe(e),f=s.from??"";let w,x;const m=this.waitForTxAndGetReceipt(a,e,{intervalMs:c,timeoutMs:l}).then(I=>{w=I;const L=BigInt(I.gasUsed)*BigInt(I.effectiveGasPrice),F=s.value?BigInt(s.value):0n,$=Q.formatTxAmount(s.value,d.symbol,d.decimals),B=Q.formatTxAmount("0x"+L.toString(16),d.symbol,d.decimals),se=Q.formatTxAmount("0x"+(F+L).toString(16),d.symbol,d.decimals);return{chainId:e,txHash:a,from:I.from,to:I.to??s.to,amount:$,fees:B,total:se,nativeSymbol:d.symbol,status:I.status==="0x1"?"success":"reverted"}}).catch(I=>(x=I instanceof Error?I:new Error(String(I)),{chainId:e,txHash:a,from:f,to:s.to,amount:Q.formatTxAmount(s.value,d.symbol,d.decimals),nativeSymbol:d.symbol,status:"timeout"}));if(await this.confirmation.showTransactionProgress({chainId:e,txHash:a,from:f,to:s.to},m),x)throw x;return{chainId:e,txHash:a,receipt:w}}async getGasPrice(e){this.ensureAuthenticated();try{return await this.walletRpc("eth_gasPrice",[],e)}catch(s){const t=s instanceof Error?s.message:String(s);throw new _(g.GAS_ESTIMATION_FAILED,`가스 가격 조회에 실패했습니다 (${e}): ${t}`,s)}}async estimateGas(e,s){this.ensureAuthenticated();const t={};e.from&&(t.from=e.from),e.to&&(t.to=e.to),e.value&&(t.value=e.value),e.data&&(t.data=e.data),e.gasPrice&&(t.gasPrice=e.gasPrice),e.maxFeePerGas&&(t.maxFeePerGas=e.maxFeePerGas),e.maxPriorityFeePerGas&&(t.maxPriorityFeePerGas=e.maxPriorityFeePerGas),e.nonce!==void 0&&(t.nonce="0x"+e.nonce.toString(16));try{return await this.walletRpc("eth_estimateGas",[t],s)}catch(n){const o=n instanceof Error?n.message:String(n);throw new _(g.GAS_ESTIMATION_FAILED,`가스 추정에 실패했습니다 (${s}): ${o}`,n)}}async getBaseFeePerGas(e){this.ensureAuthenticated();try{const s=await this.walletRpc("eth_getBlockByNumber",["latest",!1],e);return(s==null?void 0:s.baseFeePerGas)??null}catch(s){const t=s instanceof Error?s.message:String(s);throw new _(g.GAS_ESTIMATION_FAILED,`baseFeePerGas 조회에 실패했습니다 (${e}): ${t}`,s)}}async getMaxPriorityFeePerGas(e){this.ensureAuthenticated();try{return await this.walletRpc("eth_maxPriorityFeePerGas",[],e)}catch(s){const t=s instanceof Error?s.message:String(s);throw new _(g.GAS_ESTIMATION_FAILED,`maxPriorityFeePerGas 조회에 실패했습니다 (${e}): ${t}`,s)}}async getNonce(e){this.ensureAuthenticated();const s=this.address;if(!s)return 0;try{const t=await this.jsonRpc.call("eth_getTransactionCount",[s,"pending"],e);return parseInt(t??"0x0",16)}catch(t){if(t instanceof _)throw t;const n=t instanceof Error?t.message:String(t);throw new _(g.UNKNOWN_ERROR,`Nonce 조회에 실패했습니다: ${n}`,t)}}async getBalance(e){this.ensureAuthenticated();const s=this.address;if(!s)return{wei:"0x0",formatted:"0",chainId:e};try{const n=await this.jsonRpc.call("eth_getBalance",[s,"latest"],e)??"0x0";return{wei:n,formatted:Q.formatWei(n),chainId:e}}catch(t){if(t instanceof _)throw t;const n=t instanceof Error?t.message:String(t);throw new _(g.UNKNOWN_ERROR,`잔액 조회에 실패했습니다 (${e}): ${n}`,t)}}static formatWei(e){if(!e||e==="0x0"||e==="0x")return"0";try{const s=BigInt(e);if(s===0n)return"0";const t=10n**BigInt(Rt),n=s/t,i=(s%t).toString().padStart(Rt,"0").replace(/0+$/,"").slice(0,At);return i?`${n}.${i}`:`${n}`}catch{return"?"}}getProvider(e){return this.ensureAuthenticated(),new yt(this,e)}async walletRpc(e,s,t){this.ensureAuthenticated();try{return await this.jsonRpc.call(e,s,t)}catch(n){if(n instanceof _)throw n;const o=n instanceof Error?n.message:String(n);throw new _(g.UNKNOWN_ERROR,`walletRpc 호출에 실패했습니다 [${e}] (${t}): ${o}`,n)}}static formatTxAmount(e,s,t){if(!(!e||e==="0x"||e==="0x0"))try{const n=BigInt(e);if(n===0n)return;const o=10n**BigInt(t),i=n/o,c=(n%o).toString().padStart(t,"0").slice(0,At).replace(/0+$/,"");return`${c?`${i}.${c}`:`${i}`} ${s}`}catch{return}}async handleMigrationFlow(e){p.log('[CROSSx][Migration Phase 3] "Wallet Found" 팝업 표시');const s=await this.confirmation.showMigrationFoundPrompt();if(p.log("[CROSSx][Migration Phase 3] 사용자 선택:",s),s==="skip")return p.log("[CROSSx][Migration Phase 3] 사용자가 마이그레이션을 건너뜀 → 종료"),null;let t,n=0;for(;;){n++,p.log(`[CROSSx][Migration Phase 4] PIN 입력 팝업 표시 (시도 #${n})`,t?`— 이전 에러: ${t}`:"");const o=await this.confirmation.showPinInputPrompt(t);if(o===null)return p.log("[CROSSx][Migration Phase 4] 사용자가 PIN 입력을 취소함 → 종료"),null;p.log(`[CROSSx][Migration Phase 4] PIN 입력 완료 (${o.length}자리), Gateway 마이그레이션 API 호출`);try{const i=await this.migrateWalletUseCase.execute(o,e);return p.log("[CROSSx][Migration Phase 5] 마이그레이션 성공 — address:",i.address),i}catch(i){if(i instanceof _&&i.code===g.MIGRATION_FAILED){p.warn(`[CROSSx][Migration Phase 4] PIN 불일치 (시도 #${n}) — 재시도 요청`),t="PIN이 올바르지 않습니다. 다시 시도해 주세요.";continue}throw p.error("[CROSSx][Migration Phase 4] 마이그레이션 실패 (복구 불가):",i),i}}}async withResolvedGasAndFee(e,s){const t=l=>!(l!=null&&l.trim()),n=e.nonce===void 0||e.nonce===null,o=t(e.gasLimit),i=t(e.gasPrice)&&t(e.maxFeePerGas),a=!t(e.maxFeePerGas)&&t(e.maxPriorityFeePerGas);if(!n&&!o&&!i&&!a)return e;const c={...e};if(n){const l=c.from??this.address;if(l){p.log("[CROSSx] nonce 비어있음 → eth_getTransactionCount 호출 (from:",l,")");const d=await this.jsonRpc.call("eth_getTransactionCount",[l,"pending"],s);c.nonce=parseInt(d??"0x0",16),p.log("[CROSSx] nonce 결과:",c.nonce)}}if(o&&(p.log("[CROSSx] gasLimit 비어있음 → eth_estimateGas 호출"),c.gasLimit=await this.estimateGas(e,s),p.log("[CROSSx] estimateGas 결과:",c.gasLimit)),i){p.log("[CROSSx] gasPrice & maxFeePerGas 비어있음 → baseFee 조회로 Dynamic/Legacy 판별");const l=await this.getBaseFeePerGas(s);if(l){const d=It;c.maxFeePerGas="0x"+(BigInt(l)+BigInt(d)).toString(16),c.maxPriorityFeePerGas=d,p.log("[CROSSx] Dynamic 체인 감지 — baseFee:",l,"maxFeePerGas:",c.maxFeePerGas,"maxPriorityFeePerGas: 1 Gwei")}else c.gasPrice=zs,p.log("[CROSSx] Legacy 체인 감지 — gasPrice: 2 Gwei")}return!i&&a&&(c.maxPriorityFeePerGas=It,p.log("[CROSSx] maxPriorityFeePerGas 비어있음 → 1 Gwei 기본값 적용")),c}static validateTypedDataChainId(e,s){const t=Q.extractDomainChainId(s);if(e==="0"){if(t!==void 0&&t!==0)throw new _(g.TYPED_DATA_CHAIN_ID_MISMATCH,`오프체인 서명(chainId=0)에서는 typedData.domain.chainId가 없거나 0이어야 합니다. 현재 값: ${t}`);return}const n=e.match(/^eip155:(\d+)$/);if(n){const o=Number(n[1]);if(t===void 0)throw new _(g.TYPED_DATA_CHAIN_ID_MISMATCH,`온체인 서명(${e})에서는 typedData.domain.chainId가 반드시 있어야 합니다`);if(t!==o)throw new _(g.TYPED_DATA_CHAIN_ID_MISMATCH,`typedData.domain.chainId (${t})가 chainId (${e}, 예상값: ${o})와 일치하지 않습니다`)}}static extractDomainChainId(e){if(e==null||typeof e!="object")return;const s=e.domain;if(s==null||typeof s!="object")return;const t=s.chainId;if(t==null)return;const n=Number(t);return Number.isFinite(n)?n:void 0}static validateSignatureFormat(e){const s=e.startsWith("0x")?e.slice(2):e;if(!/^[0-9a-fA-F]+$/.test(s))throw new _(g.SIGNATURE_FAILED,"유효하지 않은 서명: 올바른 hex 문자열이 아닙니다");if(s.length!==Tt)throw new _(g.SIGNATURE_FAILED,`서명 길이가 유효하지 않습니다: ${Tt} hex 문자(65 바이트) 예상, 현재 ${s.length}`)}static validateSignedTxFormat(e){const s=e.startsWith("0x")?e.slice(2):e;if(!/^[0-9a-fA-F]+$/.test(s))throw new _(g.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 올바른 hex 문자열이 아닙니다");if(s.length<2)throw new _(g.SIGNATURE_FAILED,"유효하지 않은 서명된 트랜잭션: 너무 짧습니다")}verifySignatureSigner(e,s,t){if(this.crypto.recoverPersonalSignSigner)try{const n=this.crypto.recoverPersonalSignSigner(e,s);if(n.toLowerCase()!==t.toLowerCase())throw p.error("[CROSSx] 서명 검증 실패: 서명자 주소 불일치",{expected:t,recovered:n}),new _(g.SIGNATURE_SIGNER_MISMATCH,`서명자 주소가 일치하지 않습니다: 예상 ${t}, 복원된 주소 ${n}`);p.log("[CROSSx] 서명 ecrecover 검증 성공")}catch(n){if(n instanceof _)throw n;p.warn("[CROSSx] ecrecover 검증 중 예외 (무시):",n)}}applyAuthResult(e){var s,t,n,o;this.authenticated=e.success,this.userId=((s=e.user)==null?void 0:s.id)??null,this.address=e.address??null,this.userEmail=((t=e.user)==null?void 0:t.email)??null,this.providerSub=((n=e.user)==null?void 0:n.providerSub)??null,this.loginType=Q.normalizeLoginType((o=e.user)==null?void 0:o.signInProvider),this.tokenSignatureVerified=e.tokenSignatureVerified??!1,this.emit("authChanged",{isAuthenticated:this.authenticated,address:this.address,userId:this.userId})}clearAuthState(){this.authenticated=!1,this.userId=null,this.address=null,this.userEmail=null,this.providerSub=null,this.loginType=null,this.tokenSignatureVerified=!1,this.emit("authChanged",{isAuthenticated:!1,address:null,userId:null})}static normalizeLoginType(e){return e?e.includes("google")?"google":e.includes("apple")?"apple":e:null}ensureInitialized(){if(!this.initialized)throw new _(g.AUTH_NOT_INITIALIZED,"SDK가 초기화되지 않았습니다. initialize()를 먼저 호출하세요.")}ensureAuthenticated(){if(this.ensureInitialized(),!this.authenticated)throw new _(g.AUTH_NOT_AUTHENTICATED,"인증되지 않은 상태입니다. signIn()을 먼저 호출하세요.")}dispose(){this.clearAuthState(),this.tokenStore.clear(),this.initialized=!1,this.removeAllListeners(),bt(null)}};Q.OFFCHAIN_CHAIN_ID="0";let Fe=Q;class Xs{constructor(){this.prefix="crossx_"}async set(e,s){try{const t=JSON.stringify(s);localStorage.setItem(this.prefix+e,t)}catch(t){throw p.error("Storage set error:",t),t}}async get(e){try{const s=localStorage.getItem(this.prefix+e);return s?JSON.parse(s):null}catch(s){return p.error("Storage get error:",s),null}}async remove(e){try{localStorage.removeItem(this.prefix+e)}catch(s){throw p.error("Storage remove error:",s),s}}async clear(){try{Object.keys(localStorage).forEach(s=>{s.startsWith(this.prefix)&&localStorage.removeItem(s)})}catch(e){throw p.error("Storage clear error:",e),e}}}const Qs="crossx-sdk",er=1,Ie="data",Ue="keys",Ot="aes-primary",tr=12;class Ct{constructor(){this.db=null,this.cryptoKey=null,this.initPromise=null}async ensureReady(){this.db&&this.cryptoKey||(this.initPromise||(this.initPromise=this.init()),await this.initPromise)}openDB(){return new Promise((e,s)=>{const t=indexedDB.open(Qs,er);t.onupgradeneeded=()=>{const n=t.result;n.objectStoreNames.contains(Ie)||n.createObjectStore(Ie),n.objectStoreNames.contains(Ue)||n.createObjectStore(Ue)},t.onsuccess=()=>e(t.result),t.onerror=()=>s(t.error)})}idbGet(e,s){return new Promise((t,n)=>{const i=this.db.transaction(e,"readonly").objectStore(e).get(s);i.onsuccess=()=>t(i.result),i.onerror=()=>n(i.error)})}idbPut(e,s,t){return new Promise((n,o)=>{const a=this.db.transaction(e,"readwrite").objectStore(e).put(t,s);a.onsuccess=()=>n(),a.onerror=()=>o(a.error)})}idbDelete(e,s){return new Promise((t,n)=>{const i=this.db.transaction(e,"readwrite").objectStore(e).delete(s);i.onsuccess=()=>t(),i.onerror=()=>n(i.error)})}idbClear(e){return new Promise((s,t)=>{const o=this.db.transaction(e,"readwrite").objectStore(e).clear();o.onsuccess=()=>s(),o.onerror=()=>t(o.error)})}async init(){this.db=await this.openDB();const e=await this.idbGet(Ue,Ot);if(e){this.cryptoKey=e;return}this.cryptoKey=await crypto.subtle.generateKey({name:"AES-GCM",length:256},!1,["encrypt","decrypt"]),await this.idbPut(Ue,Ot,this.cryptoKey)}async encrypt(e){const s=new Uint8Array(tr);crypto.getRandomValues(s);const t=new TextEncoder().encode(e),n=await crypto.subtle.encrypt({name:"AES-GCM",iv:s},this.cryptoKey,t);return{iv:s,ciphertext:n}}async decrypt(e){const s=new Uint8Array(e.iv),t=await crypto.subtle.decrypt({name:"AES-GCM",iv:s},this.cryptoKey,e.ciphertext);return new TextDecoder().decode(t)}async set(e,s){try{await this.ensureReady();const t=JSON.stringify(s),n=await this.encrypt(t);await this.idbPut(Ie,e,n)}catch(t){throw p.error("[CROSSx] IndexedDB set error:",t),t}}async get(e){try{await this.ensureReady();const s=await this.idbGet(Ie,e);if(!s)return null;const t=await this.decrypt(s);return JSON.parse(t)}catch(s){return p.error("[CROSSx] IndexedDB get error:",s),null}}async remove(e){try{await this.ensureReady(),await this.idbDelete(Ie,e)}catch(s){throw p.error("[CROSSx] IndexedDB remove error:",s),s}}async clear(){try{await this.ensureReady(),await this.idbClear(Ie)}catch(e){throw p.error("[CROSSx] IndexedDB clear error:",e),e}}static isAvailable(){return typeof indexedDB<"u"&&typeof crypto<"u"&&typeof crypto.subtle<"u"}}new TextEncoder;const Nt=new TextDecoder,sr=r=>{const e=atob(r),s=new Uint8Array(e.length);for(let t=0;t<e.length;t++)s[t]=e.charCodeAt(t);return s},rr=r=>{let e=r;e instanceof Uint8Array&&(e=Nt.decode(e)),e=e.replace(/-/g,"+").replace(/_/g,"/").replace(/\s/g,"");try{return sr(e)}catch{throw new TypeError("The input to be decoded is not correctly encoded.")}};class V extends Error{constructor(e,s){var t;super(e,s),this.code="ERR_JOSE_GENERIC",this.name=this.constructor.name,(t=Error.captureStackTrace)==null||t.call(Error,this,this.constructor)}}V.code="ERR_JOSE_GENERIC";class nr extends V{constructor(e,s,t="unspecified",n="unspecified"){super(e,{cause:{claim:t,reason:n,payload:s}}),this.code="ERR_JWT_CLAIM_VALIDATION_FAILED",this.claim=t,this.reason=n,this.payload=s}}nr.code="ERR_JWT_CLAIM_VALIDATION_FAILED";class or extends V{constructor(e,s,t="unspecified",n="unspecified"){super(e,{cause:{claim:t,reason:n,payload:s}}),this.code="ERR_JWT_EXPIRED",this.claim=t,this.reason=n,this.payload=s}}or.code="ERR_JWT_EXPIRED";class ir extends V{constructor(){super(...arguments),this.code="ERR_JOSE_ALG_NOT_ALLOWED"}}ir.code="ERR_JOSE_ALG_NOT_ALLOWED";class ar extends V{constructor(){super(...arguments),this.code="ERR_JOSE_NOT_SUPPORTED"}}ar.code="ERR_JOSE_NOT_SUPPORTED";class cr extends V{constructor(e="decryption operation failed",s){super(e,s),this.code="ERR_JWE_DECRYPTION_FAILED"}}cr.code="ERR_JWE_DECRYPTION_FAILED";class lr extends V{constructor(){super(...arguments),this.code="ERR_JWE_INVALID"}}lr.code="ERR_JWE_INVALID";class dr extends V{constructor(){super(...arguments),this.code="ERR_JWS_INVALID"}}dr.code="ERR_JWS_INVALID";class pe extends V{constructor(){super(...arguments),this.code="ERR_JWT_INVALID"}}pe.code="ERR_JWT_INVALID";class ur extends V{constructor(){super(...arguments),this.code="ERR_JWK_INVALID"}}ur.code="ERR_JWK_INVALID";class hr extends V{constructor(){super(...arguments),this.code="ERR_JWKS_INVALID"}}hr.code="ERR_JWKS_INVALID";class fr extends V{constructor(e="no applicable key found in the JSON Web Key Set",s){super(e,s),this.code="ERR_JWKS_NO_MATCHING_KEY"}}fr.code="ERR_JWKS_NO_MATCHING_KEY";class pr extends V{constructor(e="multiple matching keys found in the JSON Web Key Set",s){super(e,s),this.code="ERR_JWKS_MULTIPLE_MATCHING_KEYS"}}pr.code="ERR_JWKS_MULTIPLE_MATCHING_KEYS";class gr extends V{constructor(e="request timed out",s){super(e,s),this.code="ERR_JWKS_TIMEOUT"}}gr.code="ERR_JWKS_TIMEOUT";class _r extends V{constructor(e="signature verification failed",s){super(e,s),this.code="ERR_JWS_SIGNATURE_VERIFICATION_FAILED"}}_r.code="ERR_JWS_SIGNATURE_VERIFICATION_FAILED";function xr(r){return typeof r=="object"&&r!==null}function mr(r){if(!xr(r)||Object.prototype.toString.call(r)!=="[object Object]")return!1;if(Object.getPrototypeOf(r)===null)return!0;let e=r;for(;Object.getPrototypeOf(e)!==null;)e=Object.getPrototypeOf(e);return Object.getPrototypeOf(r)===e}const wr=rr;function yr(r){if(typeof r!="string")throw new pe("JWTs must use Compact JWS serialization, JWT must be a string");const{1:e,length:s}=r.split(".");if(s===5)throw new pe("Only JWTs using Compact JWS serialization can be decoded");if(s!==3)throw new pe("Invalid JWT");if(!e)throw new pe("JWTs must contain a payload");let t;try{t=wr(e)}catch{throw new pe("Failed to base64url decode the payload")}let n;try{n=JSON.parse(Nt.decode(t))}catch{throw new pe("Failed to parse the decoded payload as JSON")}if(!mr(n))throw new pe("Invalid JWT Claims Set");return n}/*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) */function et(r){return r instanceof Uint8Array||ArrayBuffer.isView(r)&&r.constructor.name==="Uint8Array"}function de(r,e=""){if(!Number.isSafeInteger(r)||r<0){const s=e&&`"${e}" `;throw new Error(`${s}expected integer >= 0, got ${r}`)}}function H(r,e,s=""){const t=et(r),n=r==null?void 0:r.length,o=e!==void 0;if(!t||o&&n!==e){const i=s&&`"${s}" `,a=o?` of length ${e}`:"",c=t?`length=${n}`:`type=${typeof r}`;throw new Error(i+"expected Uint8Array"+a+", got "+c)}return r}function kt(r){if(typeof r!="function"||typeof r.create!="function")throw new Error("Hash must wrapped by utils.createHasher");de(r.outputLen),de(r.blockLen)}function Te(r,e=!0){if(r.destroyed)throw new Error("Hash instance has been destroyed");if(e&&r.finished)throw new Error("Hash#digest() has already been called")}function Pt(r,e){H(r,void 0,"digestInto() output");const s=e.outputLen;if(r.length<s)throw new Error('"digestInto() output" expected to be of length >='+s)}function br(r){return new Uint32Array(r.buffer,r.byteOffset,Math.floor(r.byteLength/4))}function Ae(...r){for(let e=0;e<r.length;e++)r[e].fill(0)}function tt(r){return new DataView(r.buffer,r.byteOffset,r.byteLength)}function ie(r,e){return r<<32-e|r>>>e}const vr=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Sr(r){return r<<24&4278190080|r<<8&16711680|r>>>8&65280|r>>>24&255}function Er(r){for(let e=0;e<r.length;e++)r[e]=Sr(r[e]);return r}const Lt=vr?r=>r:Er,Dt=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Ir=Array.from({length:256},(r,e)=>e.toString(16).padStart(2,"0"));function Ne(r){if(H(r),Dt)return r.toHex();let e="";for(let s=0;s<r.length;s++)e+=Ir[r[s]];return e}const ue={_0:48,_9:57,A:65,F:70,a:97,f:102};function Mt(r){if(r>=ue._0&&r<=ue._9)return r-ue._0;if(r>=ue.A&&r<=ue.F)return r-(ue.A-10);if(r>=ue.a&&r<=ue.f)return r-(ue.a-10)}function He(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);if(Dt)return Uint8Array.fromHex(r);const e=r.length,s=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);const t=new Uint8Array(s);for(let n=0,o=0;n<s;n++,o+=2){const i=Mt(r.charCodeAt(o)),a=Mt(r.charCodeAt(o+1));if(i===void 0||a===void 0){const c=r[o]+r[o+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+o)}t[n]=i*16+a}return t}function ge(...r){let e=0;for(let t=0;t<r.length;t++){const n=r[t];H(n),e+=n.length}const s=new Uint8Array(e);for(let t=0,n=0;t<r.length;t++){const o=r[t];s.set(o,n),n+=o.length}return s}function $t(r,e={}){const s=(n,o)=>r(o).update(n).digest(),t=r(void 0);return s.outputLen=t.outputLen,s.blockLen=t.blockLen,s.create=n=>r(n),Object.assign(s,e),Object.freeze(s)}function Bt(r=32){const e=typeof globalThis=="object"?globalThis.crypto:null;if(typeof(e==null?void 0:e.getRandomValues)!="function")throw new Error("crypto.getRandomValues must be defined");return e.getRandomValues(new Uint8Array(r))}const Tr=r=>({oid:Uint8Array.from([6,9,96,134,72,1,101,3,4,2,r])});function Ar(r,e,s){return r&e^~r&s}function Rr(r,e,s){return r&e^r&s^e&s}class Or{constructor(e,s,t,n){v(this,"blockLen");v(this,"outputLen");v(this,"padOffset");v(this,"isLE");v(this,"buffer");v(this,"view");v(this,"finished",!1);v(this,"length",0);v(this,"pos",0);v(this,"destroyed",!1);this.blockLen=e,this.outputLen=s,this.padOffset=t,this.isLE=n,this.buffer=new Uint8Array(e),this.view=tt(this.buffer)}update(e){Te(this),H(e);const{view:s,buffer:t,blockLen:n}=this,o=e.length;for(let i=0;i<o;){const a=Math.min(n-this.pos,o-i);if(a===n){const c=tt(e);for(;n<=o-i;i+=n)this.process(c,i);continue}t.set(e.subarray(i,i+a),this.pos),this.pos+=a,i+=a,this.pos===n&&(this.process(s,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){Te(this),Pt(e,this),this.finished=!0;const{buffer:s,view:t,blockLen:n,isLE:o}=this;let{pos:i}=this;s[i++]=128,Ae(this.buffer.subarray(i)),this.padOffset>n-i&&(this.process(t,0),i=0);for(let f=i;f<n;f++)s[f]=0;t.setBigUint64(n-8,BigInt(this.length*8),o),this.process(t,0);const a=tt(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen must be aligned to 32bit");const l=c/4,d=this.get();if(l>d.length)throw new Error("_sha2: outputLen bigger than state");for(let f=0;f<l;f++)a.setUint32(4*f,d[f],o)}digest(){const{buffer:e,outputLen:s}=this;this.digestInto(e);const t=e.slice(0,s);return this.destroy(),t}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:s,buffer:t,length:n,finished:o,destroyed:i,pos:a}=this;return e.destroyed=i,e.finished=o,e.length=n,e.pos=a,n%s&&e.buffer.set(t),e}clone(){return this._cloneInto()}}const _e=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),Ge=BigInt(2**32-1),Ft=BigInt(32);function Cr(r,e=!1){return e?{h:Number(r&Ge),l:Number(r>>Ft&Ge)}:{h:Number(r>>Ft&Ge)|0,l:Number(r&Ge)|0}}function Nr(r,e=!1){const s=r.length;let t=new Uint32Array(s),n=new Uint32Array(s);for(let o=0;o<s;o++){const{h:i,l:a}=Cr(r[o],e);[t[o],n[o]]=[i,a]}return[t,n]}const kr=(r,e,s)=>r<<s|e>>>32-s,Pr=(r,e,s)=>e<<s|r>>>32-s,Lr=(r,e,s)=>e<<s-32|r>>>64-s,Dr=(r,e,s)=>r<<s-32|e>>>64-s,Mr=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),xe=new Uint32Array(64);class $r extends Or{constructor(e){super(64,e,8,!1)}get(){const{A:e,B:s,C:t,D:n,E:o,F:i,G:a,H:c}=this;return[e,s,t,n,o,i,a,c]}set(e,s,t,n,o,i,a,c){this.A=e|0,this.B=s|0,this.C=t|0,this.D=n|0,this.E=o|0,this.F=i|0,this.G=a|0,this.H=c|0}process(e,s){for(let f=0;f<16;f++,s+=4)xe[f]=e.getUint32(s,!1);for(let f=16;f<64;f++){const w=xe[f-15],x=xe[f-2],m=ie(w,7)^ie(w,18)^w>>>3,A=ie(x,17)^ie(x,19)^x>>>10;xe[f]=A+xe[f-7]+m+xe[f-16]|0}let{A:t,B:n,C:o,D:i,E:a,F:c,G:l,H:d}=this;for(let f=0;f<64;f++){const w=ie(a,6)^ie(a,11)^ie(a,25),x=d+w+Ar(a,c,l)+Mr[f]+xe[f]|0,A=(ie(t,2)^ie(t,13)^ie(t,22))+Rr(t,n,o)|0;d=l,l=c,c=a,a=i+x|0,i=o,o=n,n=t,t=x+A|0}t=t+this.A|0,n=n+this.B|0,o=o+this.C|0,i=i+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,d=d+this.H|0,this.set(t,n,o,i,a,c,l,d)}roundClean(){Ae(xe)}destroy(){this.set(0,0,0,0,0,0,0,0),Ae(this.buffer)}}class Br extends $r{constructor(){super(32);v(this,"A",_e[0]|0);v(this,"B",_e[1]|0);v(this,"C",_e[2]|0);v(this,"D",_e[3]|0);v(this,"E",_e[4]|0);v(this,"F",_e[5]|0);v(this,"G",_e[6]|0);v(this,"H",_e[7]|0)}}const Fr=$t(()=>new Br,Tr(1));/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const st=BigInt(0),rt=BigInt(1);function We(r,e=""){if(typeof r!="boolean"){const s=e&&`"${e}" `;throw new Error(s+"expected boolean, got type="+typeof r)}return r}function Ut(r){if(typeof r=="bigint"){if(!Ve(r))throw new Error("positive bigint expected, got "+r)}else de(r);return r}function qe(r){const e=Ut(r).toString(16);return e.length&1?"0"+e:e}function Ht(r){if(typeof r!="string")throw new Error("hex string expected, got "+typeof r);return r===""?st:BigInt("0x"+r)}function Ke(r){return Ht(Ne(r))}function Gt(r){return Ht(Ne(Ur(H(r)).reverse()))}function nt(r,e){de(e),r=Ut(r);const s=He(r.toString(16).padStart(e*2,"0"));if(s.length!==e)throw new Error("number too large");return s}function Wt(r,e){return nt(r,e).reverse()}function Ur(r){return Uint8Array.from(r)}const Ve=r=>typeof r=="bigint"&&st<=r;function Hr(r,e,s){return Ve(r)&&Ve(e)&&Ve(s)&&e<=r&&r<s}function Gr(r,e,s,t){if(!Hr(e,s,t))throw new Error("expected valid "+r+": "+s+" <= n < "+t+", got "+e)}function Wr(r){let e;for(e=0;r>st;r>>=rt,e+=1);return e}const ot=r=>(rt<<BigInt(r))-rt;function qr(r,e,s){if(de(r,"hashLen"),de(e,"qByteLen"),typeof s!="function")throw new Error("hmacFn must be a function");const t=y=>new Uint8Array(y),n=Uint8Array.of(),o=Uint8Array.of(0),i=Uint8Array.of(1),a=1e3;let c=t(r),l=t(r),d=0;const f=()=>{c.fill(1),l.fill(0),d=0},w=(...y)=>s(l,ge(c,...y)),x=(y=n)=>{l=w(o,y),c=w(),y.length!==0&&(l=w(i,y),c=w())},m=()=>{if(d++>=a)throw new Error("drbg: tried max amount of iterations");let y=0;const I=[];for(;y<e;){c=w();const L=c.slice();I.push(L),y+=c.length}return ge(...I)};return(y,I)=>{f(),x(y);let L;for(;!(L=I(m()));)x();return f(),L}}function it(r,e={},s={}){if(!r||typeof r!="object")throw new Error("expected valid options object");function t(o,i,a){const c=r[o];if(a&&c===void 0)return;const l=typeof c;if(l!==i||c===null)throw new Error(`param "${o}" is invalid: expected ${i}, got ${l}`)}const n=(o,i)=>Object.entries(o).forEach(([a,c])=>t(a,c,i));n(e,!1),n(s,!0)}function qt(r){const e=new WeakMap;return(s,...t)=>{const n=e.get(s);if(n!==void 0)return n;const o=r(s,...t);return e.set(s,o),o}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const X=BigInt(0),j=BigInt(1),be=BigInt(2),Kt=BigInt(3),Vt=BigInt(4),jt=BigInt(5),Kr=BigInt(7),Jt=BigInt(8),Vr=BigInt(9),zt=BigInt(16);function oe(r,e){const s=r%e;return s>=X?s:e+s}function ne(r,e,s){let t=r;for(;e-- >X;)t*=t,t%=s;return t}function Yt(r,e){if(r===X)throw new Error("invert: expected non-zero number");if(e<=X)throw new Error("invert: expected positive modulus, got "+e);let s=oe(r,e),t=e,n=X,o=j;for(;s!==X;){const a=t/s,c=t%s,l=n-o*a;t=s,s=c,n=o,o=l}if(t!==j)throw new Error("invert: does not exist");return oe(n,e)}function at(r,e,s){if(!r.eql(r.sqr(e),s))throw new Error("Cannot find square root")}function Zt(r,e){const s=(r.ORDER+j)/Vt,t=r.pow(e,s);return at(r,t,e),t}function jr(r,e){const s=(r.ORDER-jt)/Jt,t=r.mul(e,be),n=r.pow(t,s),o=r.mul(e,n),i=r.mul(r.mul(o,be),n),a=r.mul(o,r.sub(i,r.ONE));return at(r,a,e),a}function Jr(r){const e=je(r),s=Xt(r),t=s(e,e.neg(e.ONE)),n=s(e,t),o=s(e,e.neg(t)),i=(r+Kr)/zt;return(a,c)=>{let l=a.pow(c,i),d=a.mul(l,t);const f=a.mul(l,n),w=a.mul(l,o),x=a.eql(a.sqr(d),c),m=a.eql(a.sqr(f),c);l=a.cmov(l,d,x),d=a.cmov(w,f,m);const A=a.eql(a.sqr(d),c),y=a.cmov(l,d,A);return at(a,y,c),y}}function Xt(r){if(r<Kt)throw new Error("sqrt is not defined for small field");let e=r-j,s=0;for(;e%be===X;)e/=be,s++;let t=be;const n=je(r);for(;es(n,t)===1;)if(t++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(s===1)return Zt;let o=n.pow(t,e);const i=(e+j)/be;return function(c,l){if(c.is0(l))return l;if(es(c,l)!==1)throw new Error("Cannot find square root");let d=s,f=c.mul(c.ONE,o),w=c.pow(l,e),x=c.pow(l,i);for(;!c.eql(w,c.ONE);){if(c.is0(w))return c.ZERO;let m=1,A=c.sqr(w);for(;!c.eql(A,c.ONE);)if(m++,A=c.sqr(A),m===d)throw new Error("Cannot find square root");const y=j<<BigInt(d-m-1),I=c.pow(f,y);d=m,f=c.sqr(I),w=c.mul(w,f),x=c.mul(x,I)}return x}}function zr(r){return r%Vt===Kt?Zt:r%Jt===jt?jr:r%zt===Vr?Jr(r):Xt(r)}const Yr=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Zr(r){const e={ORDER:"bigint",BYTES:"number",BITS:"number"},s=Yr.reduce((t,n)=>(t[n]="function",t),e);return it(r,s),r}function Xr(r,e,s){if(s<X)throw new Error("invalid exponent, negatives unsupported");if(s===X)return r.ONE;if(s===j)return e;let t=r.ONE,n=e;for(;s>X;)s&j&&(t=r.mul(t,n)),n=r.sqr(n),s>>=j;return t}function Qt(r,e,s=!1){const t=new Array(e.length).fill(s?r.ZERO:void 0),n=e.reduce((i,a,c)=>r.is0(a)?i:(t[c]=i,r.mul(i,a)),r.ONE),o=r.inv(n);return e.reduceRight((i,a,c)=>r.is0(a)?i:(t[c]=r.mul(i,t[c]),r.mul(i,a)),o),t}function es(r,e){const s=(r.ORDER-j)/be,t=r.pow(e,s),n=r.eql(t,r.ONE),o=r.eql(t,r.ZERO),i=r.eql(t,r.neg(r.ONE));if(!n&&!o&&!i)throw new Error("invalid Legendre symbol result");return n?1:o?0:-1}function Qr(r,e){e!==void 0&&de(e);const s=e!==void 0?e:r.toString(2).length,t=Math.ceil(s/8);return{nBitLength:s,nByteLength:t}}class en{constructor(e,s={}){v(this,"ORDER");v(this,"BITS");v(this,"BYTES");v(this,"isLE");v(this,"ZERO",X);v(this,"ONE",j);v(this,"_lengths");v(this,"_sqrt");v(this,"_mod");var i;if(e<=X)throw new Error("invalid field: expected ORDER > 0, got "+e);let t;this.isLE=!1,s!=null&&typeof s=="object"&&(typeof s.BITS=="number"&&(t=s.BITS),typeof s.sqrt=="function"&&(this.sqrt=s.sqrt),typeof s.isLE=="boolean"&&(this.isLE=s.isLE),s.allowedLengths&&(this._lengths=(i=s.allowedLengths)==null?void 0:i.slice()),typeof s.modFromBytes=="boolean"&&(this._mod=s.modFromBytes));const{nBitLength:n,nByteLength:o}=Qr(e,t);if(o>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");this.ORDER=e,this.BITS=n,this.BYTES=o,this._sqrt=void 0,Object.preventExtensions(this)}create(e){return oe(e,this.ORDER)}isValid(e){if(typeof e!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof e);return X<=e&&e<this.ORDER}is0(e){return e===X}isValidNot0(e){return!this.is0(e)&&this.isValid(e)}isOdd(e){return(e&j)===j}neg(e){return oe(-e,this.ORDER)}eql(e,s){return e===s}sqr(e){return oe(e*e,this.ORDER)}add(e,s){return oe(e+s,this.ORDER)}sub(e,s){return oe(e-s,this.ORDER)}mul(e,s){return oe(e*s,this.ORDER)}pow(e,s){return Xr(this,e,s)}div(e,s){return oe(e*Yt(s,this.ORDER),this.ORDER)}sqrN(e){return e*e}addN(e,s){return e+s}subN(e,s){return e-s}mulN(e,s){return e*s}inv(e){return Yt(e,this.ORDER)}sqrt(e){return this._sqrt||(this._sqrt=zr(this.ORDER)),this._sqrt(this,e)}toBytes(e){return this.isLE?Wt(e,this.BYTES):nt(e,this.BYTES)}fromBytes(e,s=!1){H(e);const{_lengths:t,BYTES:n,isLE:o,ORDER:i,_mod:a}=this;if(t){if(!t.includes(e.length)||e.length>n)throw new Error("Field.fromBytes: expected "+t+" bytes, got "+e.length);const l=new Uint8Array(n);l.set(e,o?0:l.length-e.length),e=l}if(e.length!==n)throw new Error("Field.fromBytes: expected "+n+" bytes, got "+e.length);let c=o?Gt(e):Ke(e);if(a&&(c=oe(c,i)),!s&&!this.isValid(c))throw new Error("invalid field element: outside of range 0..ORDER");return c}invertBatch(e){return Qt(this,e)}cmov(e,s,t){return t?s:e}}function je(r,e={}){return new en(r,e)}function ts(r){if(typeof r!="bigint")throw new Error("field order must be bigint");const e=r.toString(2).length;return Math.ceil(e/8)}function ss(r){const e=ts(r);return e+Math.ceil(e/2)}function tn(r,e,s=!1){H(r);const t=r.length,n=ts(e),o=ss(e);if(t<16||t<o||t>1024)throw new Error("expected "+o+"-1024 bytes of input, got "+t);const i=s?Gt(r):Ke(r),a=oe(i,e-j)+j;return s?Wt(a,n):nt(a,n)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Re=BigInt(0),ve=BigInt(1);function Je(r,e){const s=e.negate();return r?s:e}function rs(r,e){const s=Qt(r.Fp,e.map(t=>t.Z));return e.map((t,n)=>r.fromAffine(t.toAffine(s[n])))}function ns(r,e){if(!Number.isSafeInteger(r)||r<=0||r>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+r)}function ct(r,e){ns(r,e);const s=Math.ceil(e/r)+1,t=2**(r-1),n=2**r,o=ot(r),i=BigInt(r);return{windows:s,windowSize:t,mask:o,maxNumber:n,shiftBy:i}}function os(r,e,s){const{windowSize:t,mask:n,maxNumber:o,shiftBy:i}=s;let a=Number(r&n),c=r>>i;a>t&&(a-=o,c+=ve);const l=e*t,d=l+Math.abs(a)-1,f=a===0,w=a<0,x=e%2!==0;return{nextN:c,offset:d,isZero:f,isNeg:w,isNegF:x,offsetF:l}}const lt=new WeakMap,is=new WeakMap;function dt(r){return is.get(r)||1}function as(r){if(r!==Re)throw new Error("invalid wNAF")}class sn{constructor(e,s){v(this,"BASE");v(this,"ZERO");v(this,"Fn");v(this,"bits");this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=s}_unsafeLadder(e,s,t=this.ZERO){let n=e;for(;s>Re;)s&ve&&(t=t.add(n)),n=n.double(),s>>=ve;return t}precomputeWindow(e,s){const{windows:t,windowSize:n}=ct(s,this.bits),o=[];let i=e,a=i;for(let c=0;c<t;c++){a=i,o.push(a);for(let l=1;l<n;l++)a=a.add(i),o.push(a);i=a.double()}return o}wNAF(e,s,t){if(!this.Fn.isValid(t))throw new Error("invalid scalar");let n=this.ZERO,o=this.BASE;const i=ct(e,this.bits);for(let a=0;a<i.windows;a++){const{nextN:c,offset:l,isZero:d,isNeg:f,isNegF:w,offsetF:x}=os(t,a,i);t=c,d?o=o.add(Je(w,s[x])):n=n.add(Je(f,s[l]))}return as(t),{p:n,f:o}}wNAFUnsafe(e,s,t,n=this.ZERO){const o=ct(e,this.bits);for(let i=0;i<o.windows&&t!==Re;i++){const{nextN:a,offset:c,isZero:l,isNeg:d}=os(t,i,o);if(t=a,!l){const f=s[c];n=n.add(d?f.negate():f)}}return as(t),n}getPrecomputes(e,s,t){let n=lt.get(s);return n||(n=this.precomputeWindow(s,e),e!==1&&(typeof t=="function"&&(n=t(n)),lt.set(s,n))),n}cached(e,s,t){const n=dt(e);return this.wNAF(n,this.getPrecomputes(n,e,t),s)}unsafe(e,s,t,n){const o=dt(e);return o===1?this._unsafeLadder(e,s,n):this.wNAFUnsafe(o,this.getPrecomputes(o,e,t),s,n)}createCache(e,s){ns(s,this.bits),is.set(e,s),lt.delete(e)}hasCache(e){return dt(e)!==1}}function rn(r,e,s,t){let n=e,o=r.ZERO,i=r.ZERO;for(;s>Re||t>Re;)s&ve&&(o=o.add(n)),t&ve&&(i=i.add(n)),n=n.double(),s>>=ve,t>>=ve;return{p1:o,p2:i}}function cs(r,e,s){if(e){if(e.ORDER!==r)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Zr(e),e}else return je(r,{isLE:s})}function nn(r,e,s={},t){if(t===void 0&&(t=r==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${r} CURVE object`);for(const c of["p","n","h"]){const l=e[c];if(!(typeof l=="bigint"&&l>Re))throw new Error(`CURVE.${c} must be positive bigint`)}const n=cs(e.p,s.Fp,t),o=cs(e.n,s.Fn,t),a=["Gx","Gy","a","b"];for(const c of a)if(!n.isValid(e[c]))throw new Error(`CURVE.${c} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:n,Fn:o}}function on(r,e){return function(t){const n=r(t);return{secretKey:n,publicKey:e(n)}}}class ls{constructor(e,s){v(this,"oHash");v(this,"iHash");v(this,"blockLen");v(this,"outputLen");v(this,"finished",!1);v(this,"destroyed",!1);if(kt(e),H(s,void 0,"key"),this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;const t=this.blockLen,n=new Uint8Array(t);n.set(s.length>t?e.create().update(s).digest():s);for(let o=0;o<n.length;o++)n[o]^=54;this.iHash.update(n),this.oHash=e.create();for(let o=0;o<n.length;o++)n[o]^=106;this.oHash.update(n),Ae(n)}update(e){return Te(this),this.iHash.update(e),this}digestInto(e){Te(this),H(e,this.outputLen,"output"),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){const e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));const{oHash:s,iHash:t,finished:n,destroyed:o,blockLen:i,outputLen:a}=this;return e=e,e.finished=n,e.destroyed=o,e.blockLen=i,e.outputLen=a,e.oHash=s._cloneInto(e.oHash),e.iHash=t._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}}const ds=(r,e,s)=>new ls(r,e).update(s).digest();ds.create=(r,e)=>new ls(r,e);/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const us=(r,e)=>(r+(r>=0?e:-e)/hs)/e;function an(r,e,s){const[[t,n],[o,i]]=e,a=us(i*r,s),c=us(-n*r,s);let l=r-a*t-c*o,d=-a*n-c*i;const f=l<he,w=d<he;f&&(l=-l),w&&(d=-d);const x=ot(Math.ceil(Wr(s)/2))+Oe;if(l<he||l>=x||d<he||d>=x)throw new Error("splitScalar (endomorphism): failed, k="+r);return{k1neg:f,k1:l,k2neg:w,k2:d}}function ut(r){if(!["compact","recovered","der"].includes(r))throw new Error('Signature format must be "compact", "recovered", or "der"');return r}function ht(r,e){const s={};for(let t of Object.keys(e))s[t]=r[t]===void 0?e[t]:r[t];return We(s.lowS,"lowS"),We(s.prehash,"prehash"),s.format!==void 0&&ut(s.format),s}class cn extends Error{constructor(e=""){super(e)}}const me={Err:cn,_tlv:{encode:(r,e)=>{const{Err:s}=me;if(r<0||r>256)throw new s("tlv.encode: wrong tag");if(e.length&1)throw new s("tlv.encode: unpadded data");const t=e.length/2,n=qe(t);if(n.length/2&128)throw new s("tlv.encode: long form length too big");const o=t>127?qe(n.length/2|128):"";return qe(r)+o+n+e},decode(r,e){const{Err:s}=me;let t=0;if(r<0||r>256)throw new s("tlv.encode: wrong tag");if(e.length<2||e[t++]!==r)throw new s("tlv.decode: wrong tlv");const n=e[t++],o=!!(n&128);let i=0;if(!o)i=n;else{const c=n&127;if(!c)throw new s("tlv.decode(long): indefinite length not supported");if(c>4)throw new s("tlv.decode(long): byte length is too big");const l=e.subarray(t,t+c);if(l.length!==c)throw new s("tlv.decode: length bytes not complete");if(l[0]===0)throw new s("tlv.decode(long): zero leftmost byte");for(const d of l)i=i<<8|d;if(t+=c,i<128)throw new s("tlv.decode(long): not minimal encoding")}const a=e.subarray(t,t+i);if(a.length!==i)throw new s("tlv.decode: wrong value length");return{v:a,l:e.subarray(t+i)}}},_int:{encode(r){const{Err:e}=me;if(r<he)throw new e("integer: negative integers are not allowed");let s=qe(r);if(Number.parseInt(s[0],16)&8&&(s="00"+s),s.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return s},decode(r){const{Err:e}=me;if(r[0]&128)throw new e("invalid signature integer: negative");if(r[0]===0&&!(r[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return Ke(r)}},toSig(r){const{Err:e,_int:s,_tlv:t}=me,n=H(r,void 0,"signature"),{v:o,l:i}=t.decode(48,n);if(i.length)throw new e("invalid signature: left bytes after parsing");const{v:a,l:c}=t.decode(2,o),{v:l,l:d}=t.decode(2,c);if(d.length)throw new e("invalid signature: left bytes after parsing");return{r:s.decode(a),s:s.decode(l)}},hexFromSig(r){const{_tlv:e,_int:s}=me,t=e.encode(2,s.encode(r.r)),n=e.encode(2,s.encode(r.s)),o=t+n;return e.encode(48,o)}},he=BigInt(0),Oe=BigInt(1),hs=BigInt(2),ze=BigInt(3),ln=BigInt(4);function dn(r,e={}){const s=nn("weierstrass",r,e),{Fp:t,Fn:n}=s;let o=s.CURVE;const{h:i,n:a}=o;it(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object"});const{endo:c}=e;if(c&&(!t.is0(o.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');const l=ps(t,n);function d(){if(!t.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function f(P,u,h){const{x:b,y:E}=u.toAffine(),R=t.toBytes(b);if(We(h,"isCompressed"),h){d();const T=!t.isOdd(E);return ge(fs(T),R)}else return ge(Uint8Array.of(4),R,t.toBytes(E))}function w(P){H(P,void 0,"Point");const{publicKey:u,publicKeyUncompressed:h}=l,b=P.length,E=P[0],R=P.subarray(1);if(b===u&&(E===2||E===3)){const T=t.fromBytes(R);if(!t.isValid(T))throw new Error("bad point: is not on curve, wrong x");const O=A(T);let S;try{S=t.sqrt(O)}catch(q){const U=q instanceof Error?": "+q.message:"";throw new Error("bad point: is not on curve, sqrt error"+U)}d();const C=t.isOdd(S);return(E&1)===1!==C&&(S=t.neg(S)),{x:T,y:S}}else if(b===h&&E===4){const T=t.BYTES,O=t.fromBytes(R.subarray(0,T)),S=t.fromBytes(R.subarray(T,T*2));if(!y(O,S))throw new Error("bad point: is not on curve");return{x:O,y:S}}else throw new Error(`bad point: got length ${b}, expected compressed=${u} or uncompressed=${h}`)}const x=e.toBytes||f,m=e.fromBytes||w;function A(P){const u=t.sqr(P),h=t.mul(u,P);return t.add(t.add(h,t.mul(P,o.a)),o.b)}function y(P,u){const h=t.sqr(u),b=A(P);return t.eql(h,b)}if(!y(o.Gx,o.Gy))throw new Error("bad curve params: generator point");const I=t.mul(t.pow(o.a,ze),ln),L=t.mul(t.sqr(o.b),BigInt(27));if(t.is0(t.add(I,L)))throw new Error("bad curve params: a or b");function F(P,u,h=!1){if(!t.isValid(u)||h&&t.is0(u))throw new Error(`bad point coordinate ${P}`);return u}function $(P){if(!(P instanceof ee))throw new Error("Weierstrass Point expected")}function B(P){if(!c||!c.basises)throw new Error("no endo");return an(P,c.basises,n.ORDER)}const se=qt((P,u)=>{const{X:h,Y:b,Z:E}=P;if(t.eql(E,t.ONE))return{x:h,y:b};const R=P.is0();u==null&&(u=R?t.ONE:t.inv(E));const T=t.mul(h,u),O=t.mul(b,u),S=t.mul(E,u);if(R)return{x:t.ZERO,y:t.ZERO};if(!t.eql(S,t.ONE))throw new Error("invZ was invalid");return{x:T,y:O}}),Ce=qt(P=>{if(P.is0()){if(e.allowInfinityPoint&&!t.is0(P.Y))return;throw new Error("bad point: ZERO")}const{x:u,y:h}=P.toAffine();if(!t.isValid(u)||!t.isValid(h))throw new Error("bad point: x or y not field elements");if(!y(u,h))throw new Error("bad point: equation left != right");if(!P.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function we(P,u,h,b,E){return h=new ee(t.mul(h.X,P),h.Y,h.Z),u=Je(b,u),h=Je(E,h),u.add(h)}const D=class D{constructor(u,h,b){v(this,"X");v(this,"Y");v(this,"Z");this.X=F("x",u),this.Y=F("y",h,!0),this.Z=F("z",b),Object.freeze(this)}static CURVE(){return o}static fromAffine(u){const{x:h,y:b}=u||{};if(!u||!t.isValid(h)||!t.isValid(b))throw new Error("invalid affine point");if(u instanceof D)throw new Error("projective point not allowed");return t.is0(h)&&t.is0(b)?D.ZERO:new D(h,b,t.ONE)}static fromBytes(u){const h=D.fromAffine(m(H(u,void 0,"point")));return h.assertValidity(),h}static fromHex(u){return D.fromBytes(He(u))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(u=8,h=!0){return le.createCache(this,u),h||this.multiply(ze),this}assertValidity(){Ce(this)}hasEvenY(){const{y:u}=this.toAffine();if(!t.isOdd)throw new Error("Field doesn't support isOdd");return!t.isOdd(u)}equals(u){$(u);const{X:h,Y:b,Z:E}=this,{X:R,Y:T,Z:O}=u,S=t.eql(t.mul(h,O),t.mul(R,E)),C=t.eql(t.mul(b,O),t.mul(T,E));return S&&C}negate(){return new D(this.X,t.neg(this.Y),this.Z)}double(){const{a:u,b:h}=o,b=t.mul(h,ze),{X:E,Y:R,Z:T}=this;let O=t.ZERO,S=t.ZERO,C=t.ZERO,k=t.mul(E,E),q=t.mul(R,R),U=t.mul(T,T),N=t.mul(E,R);return N=t.add(N,N),C=t.mul(E,T),C=t.add(C,C),O=t.mul(u,C),S=t.mul(b,U),S=t.add(O,S),O=t.sub(q,S),S=t.add(q,S),S=t.mul(O,S),O=t.mul(N,O),C=t.mul(b,C),U=t.mul(u,U),N=t.sub(k,U),N=t.mul(u,N),N=t.add(N,C),C=t.add(k,k),k=t.add(C,k),k=t.add(k,U),k=t.mul(k,N),S=t.add(S,k),U=t.mul(R,T),U=t.add(U,U),k=t.mul(U,N),O=t.sub(O,k),C=t.mul(U,q),C=t.add(C,C),C=t.add(C,C),new D(O,S,C)}add(u){$(u);const{X:h,Y:b,Z:E}=this,{X:R,Y:T,Z:O}=u;let S=t.ZERO,C=t.ZERO,k=t.ZERO;const q=o.a,U=t.mul(o.b,ze);let N=t.mul(h,R),K=t.mul(b,T),z=t.mul(E,O),re=t.add(h,b),G=t.add(R,T);re=t.mul(re,G),G=t.add(N,K),re=t.sub(re,G),G=t.add(h,E);let Y=t.add(R,O);return G=t.mul(G,Y),Y=t.add(N,z),G=t.sub(G,Y),Y=t.add(b,E),S=t.add(T,O),Y=t.mul(Y,S),S=t.add(K,z),Y=t.sub(Y,S),k=t.mul(q,G),S=t.mul(U,z),k=t.add(S,k),S=t.sub(K,k),k=t.add(K,k),C=t.mul(S,k),K=t.add(N,N),K=t.add(K,N),z=t.mul(q,z),G=t.mul(U,G),K=t.add(K,z),z=t.sub(N,z),z=t.mul(q,z),G=t.add(G,z),N=t.mul(K,G),C=t.add(C,N),N=t.mul(Y,G),S=t.mul(re,S),S=t.sub(S,N),N=t.mul(re,K),k=t.mul(Y,k),k=t.add(k,N),new D(S,C,k)}subtract(u){return this.add(u.negate())}is0(){return this.equals(D.ZERO)}multiply(u){const{endo:h}=e;if(!n.isValidNot0(u))throw new Error("invalid scalar: out of range");let b,E;const R=T=>le.cached(this,T,O=>rs(D,O));if(h){const{k1neg:T,k1:O,k2neg:S,k2:C}=B(u),{p:k,f:q}=R(O),{p:U,f:N}=R(C);E=q.add(N),b=we(h.beta,k,U,T,S)}else{const{p:T,f:O}=R(u);b=T,E=O}return rs(D,[b,E])[0]}multiplyUnsafe(u){const{endo:h}=e,b=this;if(!n.isValid(u))throw new Error("invalid scalar: out of range");if(u===he||b.is0())return D.ZERO;if(u===Oe)return b;if(le.hasCache(this))return this.multiply(u);if(h){const{k1neg:E,k1:R,k2neg:T,k2:O}=B(u),{p1:S,p2:C}=rn(D,b,R,O);return we(h.beta,S,C,E,T)}else return le.unsafe(b,u)}toAffine(u){return se(this,u)}isTorsionFree(){const{isTorsionFree:u}=e;return i===Oe?!0:u?u(D,this):le.unsafe(this,a).is0()}clearCofactor(){const{clearCofactor:u}=e;return i===Oe?this:u?u(D,this):this.multiplyUnsafe(i)}isSmallOrder(){return this.multiplyUnsafe(i).is0()}toBytes(u=!0){return We(u,"isCompressed"),this.assertValidity(),x(D,this,u)}toHex(u=!0){return Ne(this.toBytes(u))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}};v(D,"BASE",new D(o.Gx,o.Gy,t.ONE)),v(D,"ZERO",new D(t.ZERO,t.ONE,t.ZERO)),v(D,"Fp",t),v(D,"Fn",n);let ee=D;const Ee=n.BITS,le=new sn(ee,e.endo?Math.ceil(Ee/2):Ee);return ee.BASE.precompute(8),ee}function fs(r){return Uint8Array.of(r?2:3)}function ps(r,e){return{secretKey:e.BYTES,publicKey:1+r.BYTES,publicKeyUncompressed:1+2*r.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function un(r,e={}){const{Fn:s}=r,t=e.randomBytes||Bt,n=Object.assign(ps(r.Fp,s),{seed:ss(s.ORDER)});function o(x){try{const m=s.fromBytes(x);return s.isValidNot0(m)}catch{return!1}}function i(x,m){const{publicKey:A,publicKeyUncompressed:y}=n;try{const I=x.length;return m===!0&&I!==A||m===!1&&I!==y?!1:!!r.fromBytes(x)}catch{return!1}}function a(x=t(n.seed)){return tn(H(x,n.seed,"seed"),s.ORDER)}function c(x,m=!0){return r.BASE.multiply(s.fromBytes(x)).toBytes(m)}function l(x){const{secretKey:m,publicKey:A,publicKeyUncompressed:y}=n;if(!et(x)||"_lengths"in s&&s._lengths||m===A)return;const I=H(x,void 0,"key").length;return I===A||I===y}function d(x,m,A=!0){if(l(x)===!0)throw new Error("first arg must be private key");if(l(m)===!1)throw new Error("second arg must be public key");const y=s.fromBytes(x);return r.fromBytes(m).multiply(y).toBytes(A)}const f={isValidSecretKey:o,isValidPublicKey:i,randomSecretKey:a},w=on(a,c);return Object.freeze({getPublicKey:c,getSharedSecret:d,keygen:w,Point:r,utils:f,lengths:n})}function hn(r,e,s={}){kt(e),it(s,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"}),s=Object.assign({},s);const t=s.randomBytes||Bt,n=s.hmac||((u,h)=>ds(e,u,h)),{Fp:o,Fn:i}=r,{ORDER:a,BITS:c}=i,{keygen:l,getPublicKey:d,getSharedSecret:f,utils:w,lengths:x}=un(r,s),m={prehash:!0,lowS:typeof s.lowS=="boolean"?s.lowS:!0,format:"compact",extraEntropy:!1},A=a*hs<o.ORDER;function y(u){const h=a>>Oe;return u>h}function I(u,h){if(!i.isValidNot0(h))throw new Error(`invalid signature ${u}: out of range 1..Point.Fn.ORDER`);return h}function L(){if(A)throw new Error('"recovered" sig type is not supported for cofactor >2 curves')}function F(u,h){ut(h);const b=x.signature,E=h==="compact"?b:h==="recovered"?b+1:void 0;return H(u,E)}class ${constructor(h,b,E){v(this,"r");v(this,"s");v(this,"recovery");if(this.r=I("r",h),this.s=I("s",b),E!=null){if(L(),![0,1,2,3].includes(E))throw new Error("invalid recovery id");this.recovery=E}Object.freeze(this)}static fromBytes(h,b=m.format){F(h,b);let E;if(b==="der"){const{r:S,s:C}=me.toSig(H(h));return new $(S,C)}b==="recovered"&&(E=h[0],b="compact",h=h.subarray(1));const R=x.signature/2,T=h.subarray(0,R),O=h.subarray(R,R*2);return new $(i.fromBytes(T),i.fromBytes(O),E)}static fromHex(h,b){return this.fromBytes(He(h),b)}assertRecovery(){const{recovery:h}=this;if(h==null)throw new Error("invalid recovery id: must be present");return h}addRecoveryBit(h){return new $(this.r,this.s,h)}recoverPublicKey(h){const{r:b,s:E}=this,R=this.assertRecovery(),T=R===2||R===3?b+a:b;if(!o.isValid(T))throw new Error("invalid recovery id: sig.r+curve.n != R.x");const O=o.toBytes(T),S=r.fromBytes(ge(fs((R&1)===0),O)),C=i.inv(T),k=se(H(h,void 0,"msgHash")),q=i.create(-k*C),U=i.create(E*C),N=r.BASE.multiplyUnsafe(q).add(S.multiplyUnsafe(U));if(N.is0())throw new Error("invalid recovery: point at infinify");return N.assertValidity(),N}hasHighS(){return y(this.s)}toBytes(h=m.format){if(ut(h),h==="der")return He(me.hexFromSig(this));const{r:b,s:E}=this,R=i.toBytes(b),T=i.toBytes(E);return h==="recovered"?(L(),ge(Uint8Array.of(this.assertRecovery()),R,T)):ge(R,T)}toHex(h){return Ne(this.toBytes(h))}}const B=s.bits2int||function(h){if(h.length>8192)throw new Error("input is too large");const b=Ke(h),E=h.length*8-c;return E>0?b>>BigInt(E):b},se=s.bits2int_modN||function(h){return i.create(B(h))},Ce=ot(c);function we(u){return Gr("num < 2^"+c,u,he,Ce),i.toBytes(u)}function ee(u,h){return H(u,void 0,"message"),h?H(e(u),void 0,"prehashed message"):u}function Ee(u,h,b){const{lowS:E,prehash:R,extraEntropy:T}=ht(b,m);u=ee(u,R);const O=se(u),S=i.fromBytes(h);if(!i.isValidNot0(S))throw new Error("invalid private key");const C=[we(S),we(O)];if(T!=null&&T!==!1){const N=T===!0?t(x.secretKey):T;C.push(H(N,void 0,"extraEntropy"))}const k=ge(...C),q=O;function U(N){const K=B(N);if(!i.isValidNot0(K))return;const z=i.inv(K),re=r.BASE.multiply(K).toAffine(),G=i.create(re.x);if(G===he)return;const Y=i.create(z*i.create(q+G*S));if(Y===he)return;let Os=(re.x===G?0:2)|Number(re.y&Oe),Cs=Y;return E&&y(Y)&&(Cs=i.neg(Y),Os^=1),new $(G,Cs,A?void 0:Os)}return{seed:k,k2sig:U}}function le(u,h,b={}){const{seed:E,k2sig:R}=Ee(u,h,b);return qr(e.outputLen,i.BYTES,n)(E,R).toBytes(b.format)}function D(u,h,b,E={}){const{lowS:R,prehash:T,format:O}=ht(E,m);if(b=H(b,void 0,"publicKey"),h=ee(h,T),!et(u)){const S=u instanceof $?", use sig.toBytes()":"";throw new Error("verify expects Uint8Array signature"+S)}F(u,O);try{const S=$.fromBytes(u,O),C=r.fromBytes(b);if(R&&S.hasHighS())return!1;const{r:k,s:q}=S,U=se(h),N=i.inv(q),K=i.create(U*N),z=i.create(k*N),re=r.BASE.multiplyUnsafe(K).add(C.multiplyUnsafe(z));return re.is0()?!1:i.create(re.x)===k}catch{return!1}}function P(u,h,b={}){const{prehash:E}=ht(b,m);return h=ee(h,E),$.fromBytes(u,"recovered").recoverPublicKey(h).toBytes()}return Object.freeze({keygen:l,getPublicKey:d,getSharedSecret:f,utils:w,lengths:x,Point:r,sign:le,verify:D,recoverPublicKey:P,Signature:$,hash:e})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const ft={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),n:BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),h:BigInt(1),a:BigInt(0),b:BigInt(7),Gx:BigInt("0x79be667ef9dcbbac55a06295ce870b07029bfcdb2dce28d959f2815b16f81798"),Gy:BigInt("0x483ada7726a3c4655da4fbfc0e1108a8fd17b448a68554199c47d08ffb10d4b8")},fn={beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),basises:[[BigInt("0x3086d221a7d46bcde86c90e49284eb15"),-BigInt("0xe4437ed6010e88286f547fa90abfe4c3")],[BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),BigInt("0x3086d221a7d46bcde86c90e49284eb15")]]},gs=BigInt(2);function pn(r){const e=ft.p,s=BigInt(3),t=BigInt(6),n=BigInt(11),o=BigInt(22),i=BigInt(23),a=BigInt(44),c=BigInt(88),l=r*r*r%e,d=l*l*r%e,f=ne(d,s,e)*d%e,w=ne(f,s,e)*d%e,x=ne(w,gs,e)*l%e,m=ne(x,n,e)*x%e,A=ne(m,o,e)*m%e,y=ne(A,a,e)*A%e,I=ne(y,c,e)*y%e,L=ne(I,a,e)*A%e,F=ne(L,s,e)*d%e,$=ne(F,i,e)*m%e,B=ne($,t,e)*l%e,se=ne(B,gs,e);if(!pt.eql(pt.sqr(se),r))throw new Error("Cannot find square root");return se}const pt=je(ft.p,{sqrt:pn}),gn=hn(dn(ft,{Fp:pt,endo:fn}),Fr),_n=BigInt(0),ke=BigInt(1),xn=BigInt(2),mn=BigInt(7),wn=BigInt(256),yn=BigInt(113),_s=[],xs=[],ms=[];for(let r=0,e=ke,s=1,t=0;r<24;r++){[s,t]=[t,(2*s+3*t)%5],_s.push(2*(5*t+s)),xs.push((r+1)*(r+2)/2%64);let n=_n;for(let o=0;o<7;o++)e=(e<<ke^(e>>mn)*yn)%wn,e&xn&&(n^=ke<<(ke<<BigInt(o))-ke);ms.push(n)}const ws=Nr(ms,!0),bn=ws[0],vn=ws[1],ys=(r,e,s)=>s>32?Lr(r,e,s):kr(r,e,s),bs=(r,e,s)=>s>32?Dr(r,e,s):Pr(r,e,s);function Sn(r,e=24){const s=new Uint32Array(10);for(let t=24-e;t<24;t++){for(let i=0;i<10;i++)s[i]=r[i]^r[i+10]^r[i+20]^r[i+30]^r[i+40];for(let i=0;i<10;i+=2){const a=(i+8)%10,c=(i+2)%10,l=s[c],d=s[c+1],f=ys(l,d,1)^s[a],w=bs(l,d,1)^s[a+1];for(let x=0;x<50;x+=10)r[i+x]^=f,r[i+x+1]^=w}let n=r[2],o=r[3];for(let i=0;i<24;i++){const a=xs[i],c=ys(n,o,a),l=bs(n,o,a),d=_s[i];n=r[d],o=r[d+1],r[d]=c,r[d+1]=l}for(let i=0;i<50;i+=10){for(let a=0;a<10;a++)s[a]=r[i+a];for(let a=0;a<10;a++)r[i+a]^=~s[(a+2)%10]&s[(a+4)%10]}r[0]^=bn[t],r[1]^=vn[t]}Ae(s)}class gt{constructor(e,s,t,n=!1,o=24){v(this,"state");v(this,"pos",0);v(this,"posOut",0);v(this,"finished",!1);v(this,"state32");v(this,"destroyed",!1);v(this,"blockLen");v(this,"suffix");v(this,"outputLen");v(this,"enableXOF",!1);v(this,"rounds");if(this.blockLen=e,this.suffix=s,this.outputLen=t,this.enableXOF=n,this.rounds=o,de(t,"outputLen"),!(0<e&&e<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=br(this.state)}clone(){return this._cloneInto()}keccak(){Lt(this.state32),Sn(this.state32,this.rounds),Lt(this.state32),this.posOut=0,this.pos=0}update(e){Te(this),H(e);const{blockLen:s,state:t}=this,n=e.length;for(let o=0;o<n;){const i=Math.min(s-this.pos,n-o);for(let a=0;a<i;a++)t[this.pos++]^=e[o++];this.pos===s&&this.keccak()}return this}finish(){if(this.finished)return;this.finished=!0;const{state:e,suffix:s,pos:t,blockLen:n}=this;e[t]^=s,s&128&&t===n-1&&this.keccak(),e[n-1]^=128,this.keccak()}writeInto(e){Te(this,!1),H(e),this.finish();const s=this.state,{blockLen:t}=this;for(let n=0,o=e.length;n<o;){this.posOut>=t&&this.keccak();const i=Math.min(t-this.posOut,o-n);e.set(s.subarray(this.posOut,this.posOut+i),n),this.posOut+=i,n+=i}return e}xofInto(e){if(!this.enableXOF)throw new Error("XOF is not possible for this instance");return this.writeInto(e)}xof(e){return de(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(Pt(e,this),this.finished)throw new Error("digest() was already called");return this.writeInto(e),this.destroy(),e}digest(){return this.digestInto(new Uint8Array(this.outputLen))}destroy(){this.destroyed=!0,Ae(this.state)}_cloneInto(e){const{blockLen:s,suffix:t,outputLen:n,rounds:o,enableXOF:i}=this;return e||(e=new gt(s,t,n,i,o)),e.state32.set(this.state32),e.pos=this.pos,e.posOut=this.posOut,e.finished=this.finished,e.rounds=o,e.suffix=t,e.outputLen=n,e.enableXOF=i,e.destroyed=this.destroyed,e}}const vs=((r,e,s,t={})=>$t(()=>new gt(e,r,s),t))(1,136,32);class En{async verifyJWT(e,s){try{const t=this.decodeJWT(e);p.log("[CROSSx] JWT 디코딩 성공:",{sub:t.sub,exp:t.exp,iat:t.iat,"현재 시간":Math.floor(Date.now()/1e3)});const n=Math.floor(Date.now()/1e3);return t.exp&&t.exp<n?(p.warn("[CROSSx] 토큰 만료:",{exp:t.exp,now:n,만료시간:new Date(t.exp*1e3).toISOString()}),{payload:t,valid:!1,signatureVerified:!1}):t.sub?(p.log("[CROSSx] JWT 검증 성공 (서명 미검증 — JWKS 미구현)"),{payload:t,valid:!0,signatureVerified:!1}):(p.warn("[CROSSx] JWT에 sub(사용자ID) 없음"),{payload:t,valid:!1,signatureVerified:!1})}catch(t){throw p.error("[CROSSx] JWT 검증 중 에러:",t),t}}decodeJWT(e){return yr(e)}recoverPersonalSignSigner(e,s){const t=new TextEncoder().encode(e),n=new TextEncoder().encode(`Ethereum Signed Message:
|
|
2
|
+
${t.length}`),o=new Uint8Array(n.length+t.length);o.set(n,0),o.set(t,n.length);const i=vs(o),a=s.startsWith("0x")?s.slice(2):s;if(a.length!==130)throw new Error(`서명 길이가 유효하지 않습니다: 130 hex 문자 예상, 현재 ${a.length}`);const c=In(a),l=c.slice(0,32),d=c.slice(32,64),f=c[64],w=f>=27?f-27:f,A=new gn.Signature(Ss(l),Ss(d)).addRecoveryBit(w).recoverPublicKey(i).toBytes(!1).slice(1),y=vs(A);return"0x"+Ne(y.slice(12))}}function In(r){const e=new Uint8Array(r.length/2);for(let s=0;s<e.length;s++)e[s]=parseInt(r.substring(s*2,s*2+2),16);return e}function Ss(r){let e="0x";for(const s of r)e+=s.toString(16).padStart(2,"0");return BigInt(e)}const Tn=3e4;class An{async request(e){const s=new AbortController,t=setTimeout(()=>s.abort(),e.timeoutMs??Tn);try{const n=await fetch(e.url,{method:e.method,headers:e.headers,body:e.body?JSON.stringify(e.body):void 0,signal:s.signal,credentials:e.credentials});let o;const i=await n.text();try{o=i?JSON.parse(i):null}catch{o={_raw:i}}return{status:n.status,data:o,headers:Object.fromEntries(n.headers.entries())}}finally{clearTimeout(t)}}}class _t{static generateState(){const e=new Uint8Array(16);return crypto.getRandomValues(e),Array.from(e,s=>s.toString(16).padStart(2,"0")).join("")}openAuth(e){return new Promise((s,t)=>{const n=Math.max(e.width??500,500),o=Math.max(e.height??700,700),i=window.screenX+(window.outerWidth-n)/2,a=window.screenY+(window.outerHeight-o)/2,c=_t.generateState(),l=e.authUrl.includes("?")?"&":"?",d=`${e.authUrl}${l}state=${c}`,f=window.open(d,"CROSSx OAuth",`width=${n},height=${o},left=${i},top=${a}`);if(!f){t(new Error("팝업 창을 열 수 없습니다. 팝업 차단을 해제해 주세요."));return}const w=setTimeout(()=>{p.warn("[CROSSx] OAuth 타임아웃 (5분) — postMessage를 수신하지 못했습니다"),F(),t(new Error("Authentication timeout"))},5*60*1e3),x=10,m=30;let A=0,y=null;const I=()=>{clearInterval(L),p.warn("[CROSSx] COOP 감지 — OAuth 서버 응답을 "+m+"초간 대기합니다"),y=setTimeout(()=>{F(),t(new Error("OAuth 서버로부터 응답을 받지 못했습니다. 브라우저 보안 정책(COOP)으로 인해 팝업 통신이 차단되었을 수 있습니다. 다시 시도해 주세요."))},m*1e3)},L=setInterval(()=>{A++;try{f.closed&&(A<=x?I():(F(),t(new Error("로그인이 취소되었습니다"))))}catch{I()}},1e3),F=()=>{clearTimeout(w),clearInterval(L),y&&clearTimeout(y),window.removeEventListener("message",$)},$=B=>{var Ce,we,ee,Ee,le,D,P;if(B.origin!==e.expectedOrigin)return;F(),p.log("[CROSSx] OAuth postMessage 수신 — status:",B.data.status);const se=B.data.state??((Ce=B.data.data)==null?void 0:Ce.state);if(!se||se!==c){t(new Error("OAuth state mismatch — possible CSRF attack"));return}if(B.data.status==="success"){const u=((we=B.data.data)==null?void 0:we.accessToken)||((ee=B.data.data)==null?void 0:ee.idToken);p.log("[CROSSx] OAuth 토큰 수신:",{hasAccessToken:!!((Ee=B.data.data)!=null&&Ee.accessToken),hasIdToken:!!((le=B.data.data)!=null&&le.idToken)}),u?s(u):(p.error("[CROSSx] 토큰을 찾을 수 없음:",B.data),t(new Error("Token not found in response")))}else p.error("[CROSSx] OAuth 실패:",(D=B.data.data)==null?void 0:D.error),t(new Error(((P=B.data.data)==null?void 0:P.error)||"Authentication failed"))};window.addEventListener("message",$)})}}const Pe="crossx_wallet_data";class Rn{constructor(e){this.storage=e}async getOrCreateWallet(e){try{const s=await this.storage.get(Pe);if(s)return s;const t={id:e,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};return await this.storage.set(Pe,t),t}catch(s){throw new _(g.WALLET_CREATION_FAILED,"지갑 생성에 실패했습니다",s)}}async getAddresses(e){const s=await this.storage.get(Pe);return s?[{address:s.address,index:0}]:[]}async getAddress(e,s){return{address:this.generateMockEvmAddress(),derivationPath:`m/44'/60'/0'/0/${s}`}}async prepare(e,s){const t="mock-"+crypto.randomUUID();return p.log(`[Mock] prepare action=${e} → uuid=${t}`),{uuid:t,expiresAt:new Date(Date.now()+3e5).toISOString()}}async signMessage(e,s,t,n=0,o,i){return p.log(`[Mock] signMessage chainId=${s} index=${n} uuid=${o} from=${i}: "${t}"`),{chainId:s,signature:this.generateMockSignature(),format:"hex"}}async signTypedData(e,s,t,n=0,o,i){return p.log(`[Mock] signTypedData chainId=${s} index=${n} uuid=${o} from=${i}`),{chainId:s,signature:this.generateMockSignature(),format:"hex"}}async signTransaction(e,s,t,n=0,o){p.log(`[Mock] signTransaction chainId=${s} index=${n} uuid=${o}:`,t);const i="0x"+Array(64).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("");return{chainId:s,signature:this.generateMockSignature(),txHash:i,format:"hex"}}async sendTransaction(e,s,t,n){return p.log(`[Mock] sendTransaction chainId=${s} uuid=${n}:`,t),{txHash:"0x"+Array(64).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}}async recoverWallet(e,s){p.log("[Mock] recoverWallet");const t={id:e,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};return await this.storage.set(Pe,t),t}async migrateWallet(e,s){p.log(`[Mock] migrateWallet pin=${e} sub=${s}`);const t={id:s,address:this.generateMockEvmAddress(),derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()};return await this.storage.set(Pe,t),t}generateMockEvmAddress(){return"0x"+Array(40).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}generateMockSignature(){return"0x"+Array(130).fill(0).map(()=>Math.floor(Math.random()*16).toString(16)).join("")}}class Ye{constructor(e,s,t,n){this.adapterConfig=e,this.projectId=e.projectId,this.storage=s,this.transport=t,this.tokenStore=n}get baseUrl(){return this.adapterConfig.gatewayUrl}getAuthToken(){const e=this.tokenStore.get();if(!e)throw new _(g.AUTH_NOT_AUTHENTICATED,"인증 토큰을 찾을 수 없습니다. 먼저 로그인해 주세요.");return e}async request(e,s,t){var a,c;const n=this.getAuthToken(),o=`${this.baseUrl}${s}`,i={Authorization:`Bearer ${n}`,"Content-Type":"application/json","X-Project-Id":this.projectId};try{const d=(await this.transport.request({url:o,method:e,headers:i,body:t??void 0})).data;if(d&&typeof d.code=="number"){if(d.code<0||d.code>=400){const f=d.message||d.data||"API 요청에 실패했습니다";p.error("[CROSSx] Wallet Gateway API 에러 (HTTP 200):",{code:d.code,message:f,url:o,method:e,fullResponse:d});const w=Ye.mapGatewayError(d.code),x=Ye.getGatewayErrorMessage(d.code,f),m=new _(w,x);throw m.gatewayCode=d.code,m.gatewayMessage=f,m}return p.log("[CROSSx] Wallet Gateway API 성공:",{code:d.code,url:o,method:e}),d.data??d}return d}catch(l){if(l instanceof _)throw l;if((a=l.response)!=null&&a.data){const d=l.response.data,f=d.message||d.data||"API 요청에 실패했습니다",w=d.code||"UNKNOWN";throw p.error("[CROSSx] Wallet Gateway API 에러 (HTTP 에러):",{code:w,message:f,url:o,method:e,status:(c=l.response)==null?void 0:c.status}),new _(g.UNKNOWN_ERROR,`Wallet Gateway 오류 (${w}): ${f}`)}throw l}}async getOrCreateWallet(e){var s;p.log("[CROSSx][Migration Phase 2] GET /mnemonic/addresses — 기존 지갑 조회");try{const t=await this.request("GET","/mnemonic/addresses");if(t.addresses&&t.addresses.length>0){const{address:n}=t.addresses[0];return p.log("[CROSSx][Migration Phase 2] 기존 지갑 발견 — address:",n),{id:e,address:n,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}}catch{p.log("[CROSSx][Migration Phase 2] 기존 지갑 없음, POST /mnemonic/create 진행")}p.log("[CROSSx][Migration Phase 2] POST /mnemonic/create — ignoreBackup: false");try{const t={ignoreBackup:!1},n=await this.request("POST","/mnemonic/create",t);return p.log("[CROSSx][Migration Phase 2] /mnemonic/create 성공 — address:",n.address),{id:e,address:n.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}catch(t){if((t==null?void 0:t.gatewayCode)===-10004||(s=t==null?void 0:t.message)!=null&&s.includes("-10004")){p.log("[CROSSx][Migration Phase 2] 지갑 이미 존재 (-10004), 주소 재조회");const n=await this.request("GET","/mnemonic/addresses");if(n.addresses&&n.addresses.length>0)return{id:e,address:n.addresses[0].address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}throw(t==null?void 0:t.gatewayCode)===-10012&&p.log("[CROSSx][Migration Phase 2] Gateway -10012 수신 → MIGRATION_BACKUP_EXISTS throw"),t}}async getAddresses(e){return((await this.request("GET","/mnemonic/addresses")).addresses??[]).map(t=>({address:t.address,index:t.index}))}async getAddress(e,s){try{return{address:(await this.request("GET",`/mnemonic/address?index=${s}`)).address,derivationPath:`m/44'/60'/0'/0/${s}`}}catch(t){if(t instanceof _&&this.isAddressNotFoundError(t))return p.log(`[CROSSx] index ${s} 주소 없음, 파생 중...`),{address:(await this.request("GET",`/mnemonic/address?index=${s}&derive=true`)).address,derivationPath:`m/44'/60'/0'/0/${s}`};throw t}}isAddressNotFoundError(e){const s=e.message.toLowerCase();return s.includes("404")||s.includes("not found")||s.includes("찾을 수 없")||s.includes("does not exist")||s.includes("no address")}async prepare(e,s){let t;switch(e){case"sign":case"send":if(!s.tx)throw new _(g.TX_INVALID_PARAMS,"prepare: tx가 필요합니다");t={unsignedTx:this.buildUnsignedTx(s.tx)};break;case"sign-message":if(!s.message)throw new _(g.TX_INVALID_PARAMS,"prepare: message가 필요합니다");t={message:s.message},s.from&&(t.from=s.from);break;case"sign-typed-data":if(!s.typedData)throw new _(g.TX_INVALID_PARAMS,"prepare: typedData가 필요합니다");t={typedData:s.typedData},s.from&&(t.from=s.from);break}const n={action:e,params:t},o=await this.request("POST","/mnemonic/prepare",n);return{uuid:o.uuid,expiresAt:o.expiresAt}}async signMessage(e,s,t,n,o,i){const a={message:t};o&&(a.uuid=o),i&&(a.from=i);const c=await this.request("POST","/mnemonic/sign-message",a);return{chainId:s,signature:c.signature,format:"hex"}}async signTypedData(e,s,t,n,o,i){const a={typedData:t};o&&(a.uuid=o),i&&(a.from=i);const c=await this.request("POST",`/mnemonic/sign-typed-data/${encodeURIComponent(s)}`,a);return{chainId:s,signature:c.signature,format:"hex"}}buildUnsignedTx(e){return{from:e.from,to:e.to,value:e.value,data:e.data,nonce:e.nonce!==void 0?`0x${e.nonce.toString(16)}`:void 0,gasLimit:e.gasLimit,gasPrice:e.gasPrice,maxFeePerGas:e.maxFeePerGas,maxPriorityFeePerGas:e.maxPriorityFeePerGas,chainId:e.chainId!==void 0?`0x${e.chainId.toString(16)}`:void 0}}async signTransaction(e,s,t,n,o){const i={unsignedTx:this.buildUnsignedTx(t)};o&&(i.uuid=o);const a=await this.request("POST",`/mnemonic/sign/${encodeURIComponent(s)}`,i);return{chainId:s,signature:a.signedTx,txHash:a.txHash,format:"hex"}}async sendTransaction(e,s,t,n){const o={unsignedTx:this.buildUnsignedTx(t)};return n&&(o.uuid=n),{txHash:(await this.request("POST",`/mnemonic/send/${encodeURIComponent(s)}`,o)).txHash}}async recoverWallet(e,s){const t={shareC:s},n=await this.request("POST","/mnemonic/recover",t);return{id:e,address:n.address,newShareC:n.newShareC,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}async migrateWallet(e,s){p.log("[CROSSx][Migration Phase 4] POST /mnemonic/migrate 호출 — sub:",s);const t={pin:e,sub:s},n=await this.request("POST","/mnemonic/migrate",t);return p.log("[CROSSx][Migration Phase 4] /mnemonic/migrate 완료 — address:",n.address),{id:s,address:n.address,derivationPath:"m/44'/60'/0'/0/0",createdAt:Date.now()}}static mapGatewayError(e){switch(e){case-10002:return g.AUTH_NOT_AUTHENTICATED;case-10001:case-10009:return g.UNKNOWN_ERROR;case-10006:return g.GATEWAY_INTERNAL_ERROR;case-10008:return g.GATEWAY_LOCK_CONFLICT;case-10010:return g.MIGRATION_FAILED;case-10012:return g.MIGRATION_BACKUP_EXISTS;case-10022:return g.PROJECT_NOT_REGISTERED;case-10023:return g.PROJECT_ID_MISSING;case-10024:return g.ORIGIN_NOT_ALLOWED;case-10026:return g.TYPED_DATA_CHAIN_ID_MISMATCH;case-10014:case-10015:case-10019:return g.PREPARE_FAILED;case-10016:return g.PREPARE_EXPIRED;case-10017:case-10018:return g.PREPARE_MISMATCH;default:return g.UNKNOWN_ERROR}}static getGatewayErrorMessage(e,s){switch(e){case-10002:return"Session expired. Please sign in again.";case-10006:return"Internal server error. Please try again later.";case-10008:return"Another operation is in progress. Please try again later.";case-10022:return"Project is not whitelisted. Verify your projectId and register the current origin in the management console.";case-10023:return"Project ID is required. Set the projectId field in SDKConfig.";case-10024:return"Origin is not in the allowed list. Register the current domain in the management console.";case-10026:return"Domain chainId mismatch: the chainId in typedData.domain does not match the request chainId.";default:return`Request failed (${e}): ${s}`}}}class Le{constructor(e,s){this.cache=new Map,this.loadedAt=0,this.usingFallback=!1,this.adapterConfig=e,this.projectId=e.projectId,this.transport=s}get baseUrl(){return this.adapterConfig.gatewayUrl}async getChains(){if(this.isCacheValid())return Array.from(this.cache.values());try{const e=await this.request("/chains");this.handleEnvelopeError(e);const s=e.data.chains;return this.populateCache(s,!1),s}catch{const e=Le.fallbackChains();return this.populateCache(e,!0),e}}async getChain(e){const t=(await this.getChains()).find(n=>n.chainId===e);return t||this.fallbackOrThrow(e)}invalidateCache(){this.cache.clear(),this.loadedAt=0,this.usingFallback=!1}isCacheValid(){if(this.loadedAt===0)return!1;const e=this.usingFallback?Zs:Ys;return e===0?!0:Date.now()-this.loadedAt<e}populateCache(e,s){this.cache.clear();for(const t of e)this.cache.set(t.chainId,t);this.loadedAt=Date.now(),this.usingFallback=s}async request(e){return(await this.transport.request({url:`${this.baseUrl}${e}`,method:"GET",headers:{"X-Project-Id":this.projectId}})).data}handleEnvelopeError(e){if(e.code<0){const s=typeof e.data=="string"?e.data:e.message??"체인 레지스트리 요청에 실패했습니다";throw new _(Le.mapErrorCode(e.code),s)}}fallbackOrThrow(e){const s=Le.fallbackChains().find(t=>t.chainId===e);if(s)return s;throw new _(g.CHAIN_NOT_SUPPORTED,`지원하지 않는 체인: ${e}`)}static fallbackChains(){return Object.values(De).map(e=>({chainId:e.caipId,rpcUrl:e.rpcUrl}))}static mapErrorCode(e){switch(e){case-10020:return g.CHAIN_NOT_SUPPORTED;case-10021:return g.INVALID_CHAIN;case-10022:return g.PROJECT_NOT_REGISTERED;case-10023:return g.PROJECT_ID_MISSING;case-10024:return g.APP_IDENTIFIER_MISSING;case-10025:return g.INVALID_APP_TYPE;default:return g.UNKNOWN_ERROR}}}const Es="__crossx-confirm-style",te="__crossx-confirm-overlay",On={light:{bg:"#FFFFFF",border:"rgba(18,18,18,0.05)",titleColor:"#121212",subtitleColor:"rgba(18,18,18,0.7)",labelColor:"rgba(18,18,18,0.5)",valueColor:"#121212",pillBg:"rgba(18,18,18,0.05)",pillFromColor:"rgba(18,18,18,0.5)",pillAmtColor:"#121212",divider:"rgba(18,18,18,0.1)",closeColor:"#121212",closeHoverBg:"rgba(18,18,18,0.05)",copyColor:"rgba(18,18,18,0.5)",inputBg:"#FFFFFF",inputBorder:"rgba(18,18,18,0.1)",hintColor:"rgba(18,18,18,0.5)",primary:"#019D92",primaryGlow:"rgba(1,157,146,0.15)",secondary:"#E70077",onPrimary:"#FFFFFF"},dark:{bg:"#121212",border:"rgba(255,255,255,0.05)",titleColor:"#FFFFFF",subtitleColor:"rgba(255,255,255,0.7)",labelColor:"rgba(255,255,255,0.5)",valueColor:"#FFFFFF",pillBg:"rgba(255,255,255,0.05)",pillFromColor:"rgba(255,255,255,0.5)",pillAmtColor:"#FFFFFF",divider:"rgba(255,255,255,0.1)",closeColor:"#FFFFFF",closeHoverBg:"rgba(255,255,255,0.05)",copyColor:"rgba(255,255,255,0.5)",inputBg:"#121212",inputBorder:"rgba(255,255,255,0.1)",hintColor:"rgba(255,255,255,0.5)",primary:"#019D92",primaryGlow:"rgba(1,157,146,0.15)",secondary:"#E70077",onPrimary:"#FFFFFF"}};function Is(r,e){const s=On[r],t=e==null?void 0:e[r];return t?{...s,...t.primary!==void 0&&{primary:t.primary},...t.secondary!==void 0&&{secondary:t.secondary},...t.onPrimary!==void 0&&{onPrimary:t.onPrimary},...t.borderDefault!==void 0&&{border:t.borderDefault},...t.borderSubtle!==void 0&&{divider:t.borderSubtle,inputBorder:t.borderSubtle},...t.textIconPrimary!==void 0&&{titleColor:t.textIconPrimary,valueColor:t.textIconPrimary,pillAmtColor:t.textIconPrimary,closeColor:t.textIconPrimary},...t.textIconSecondary!==void 0&&{subtitleColor:t.textIconSecondary},...t.textIconTertiary!==void 0&&{labelColor:t.textIconTertiary,pillFromColor:t.textIconTertiary,copyColor:t.textIconTertiary,hintColor:t.textIconTertiary},...t.surfaceDefault!==void 0&&{pillBg:t.surfaceDefault,closeHoverBg:t.surfaceDefault},...t.bg!==void 0&&{bg:t.bg,inputBg:t.bg}}:s}const Cn=`
|
|
3
|
+
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;600&display=swap');
|
|
4
|
+
|
|
5
|
+
#${te} {
|
|
6
|
+
position: fixed;
|
|
7
|
+
inset: 0;
|
|
8
|
+
z-index: 2147483647;
|
|
9
|
+
display: flex;
|
|
10
|
+
align-items: center;
|
|
11
|
+
justify-content: center;
|
|
12
|
+
background: rgba(0,0,0,0.55);
|
|
13
|
+
font-family: 'Sora', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
|
|
14
|
+
animation: __crossx-fade-in 0.15s ease;
|
|
15
|
+
}
|
|
16
|
+
@keyframes __crossx-fade-in {
|
|
17
|
+
from { opacity: 0; }
|
|
18
|
+
to { opacity: 1; }
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
.__crossx-card {
|
|
22
|
+
background: var(--cx-bg);
|
|
23
|
+
border: 4px solid var(--cx-border);
|
|
24
|
+
border-radius: 24px;
|
|
25
|
+
width: 383px;
|
|
26
|
+
max-width: calc(100vw - 32px);
|
|
27
|
+
overflow: hidden;
|
|
28
|
+
position: relative;
|
|
29
|
+
animation: __crossx-slide-up 0.18s ease;
|
|
30
|
+
}
|
|
31
|
+
@keyframes __crossx-slide-up {
|
|
32
|
+
from { transform: translateY(20px); opacity: 0; }
|
|
33
|
+
to { transform: translateY(0); opacity: 1; }
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
/* ── Header ─────────────────────────────────────────────────────── */
|
|
37
|
+
.__crossx-header {
|
|
38
|
+
padding: 24px 24px 20px;
|
|
39
|
+
position: relative;
|
|
40
|
+
}
|
|
41
|
+
.__crossx-title {
|
|
42
|
+
font-size: 22px;
|
|
43
|
+
font-weight: 600;
|
|
44
|
+
line-height: 1.3;
|
|
45
|
+
color: var(--cx-title);
|
|
46
|
+
margin: 0 0 4px 0;
|
|
47
|
+
padding-right: 36px;
|
|
48
|
+
}
|
|
49
|
+
.__crossx-subtitle {
|
|
50
|
+
font-size: 14px;
|
|
51
|
+
font-weight: 400;
|
|
52
|
+
line-height: 1.3;
|
|
53
|
+
color: var(--cx-subtitle);
|
|
54
|
+
margin: 0;
|
|
55
|
+
}
|
|
56
|
+
.__crossx-close {
|
|
57
|
+
position: absolute;
|
|
58
|
+
top: 12px;
|
|
59
|
+
right: 12px;
|
|
60
|
+
width: 32px;
|
|
61
|
+
height: 32px;
|
|
62
|
+
border: none;
|
|
63
|
+
background: none;
|
|
64
|
+
cursor: pointer;
|
|
65
|
+
color: var(--cx-close);
|
|
66
|
+
border-radius: 8px;
|
|
67
|
+
display: flex;
|
|
68
|
+
align-items: center;
|
|
69
|
+
justify-content: center;
|
|
70
|
+
padding: 0;
|
|
71
|
+
appearance: none;
|
|
72
|
+
-webkit-appearance: none;
|
|
73
|
+
box-shadow: none;
|
|
74
|
+
outline: none;
|
|
75
|
+
}
|
|
76
|
+
.__crossx-close:hover,
|
|
77
|
+
.__crossx-close:focus,
|
|
78
|
+
.__crossx-close:active {
|
|
79
|
+
background: none !important;
|
|
80
|
+
box-shadow: none !important;
|
|
81
|
+
outline: none !important;
|
|
82
|
+
filter: none !important;
|
|
83
|
+
transform: none !important;
|
|
84
|
+
opacity: 1 !important;
|
|
85
|
+
}
|
|
86
|
+
.__crossx-close svg { display: block; }
|
|
87
|
+
|
|
88
|
+
/* ── Divider ─────────────────────────────────────────────────────── */
|
|
89
|
+
.__crossx-divider {
|
|
90
|
+
border: none;
|
|
91
|
+
border-top: 1px solid var(--cx-divider);
|
|
92
|
+
margin: 0;
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/* ── Body ────────────────────────────────────────────────────────── */
|
|
96
|
+
.__crossx-body {
|
|
97
|
+
padding: 20px 24px 24px;
|
|
98
|
+
display: flex;
|
|
99
|
+
flex-direction: column;
|
|
100
|
+
gap: 16px;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
/* Info rows */
|
|
104
|
+
.__crossx-rows {
|
|
105
|
+
display: flex;
|
|
106
|
+
flex-direction: column;
|
|
107
|
+
gap: 4px;
|
|
108
|
+
}
|
|
109
|
+
.__crossx-row {
|
|
110
|
+
display: flex;
|
|
111
|
+
align-items: center;
|
|
112
|
+
height: 20px;
|
|
113
|
+
}
|
|
114
|
+
.__crossx-row-label {
|
|
115
|
+
font-size: 13px;
|
|
116
|
+
font-weight: 400;
|
|
117
|
+
line-height: 1.3;
|
|
118
|
+
color: var(--cx-label);
|
|
119
|
+
width: 100px;
|
|
120
|
+
flex-shrink: 0;
|
|
121
|
+
}
|
|
122
|
+
.__crossx-row-value {
|
|
123
|
+
font-size: 13px;
|
|
124
|
+
font-weight: 400;
|
|
125
|
+
line-height: 1.3;
|
|
126
|
+
color: var(--cx-value);
|
|
127
|
+
flex: 1;
|
|
128
|
+
text-align: right;
|
|
129
|
+
display: flex;
|
|
130
|
+
align-items: center;
|
|
131
|
+
justify-content: flex-end;
|
|
132
|
+
gap: 4px;
|
|
133
|
+
min-width: 0;
|
|
134
|
+
overflow: hidden;
|
|
135
|
+
}
|
|
136
|
+
.__crossx-addr-text {
|
|
137
|
+
white-space: nowrap;
|
|
138
|
+
overflow: hidden;
|
|
139
|
+
text-overflow: ellipsis;
|
|
140
|
+
}
|
|
141
|
+
.__crossx-copy-btn {
|
|
142
|
+
background: none;
|
|
143
|
+
border: none;
|
|
144
|
+
cursor: pointer;
|
|
145
|
+
color: var(--cx-copy);
|
|
146
|
+
padding: 0;
|
|
147
|
+
display: flex;
|
|
148
|
+
align-items: center;
|
|
149
|
+
flex-shrink: 0;
|
|
150
|
+
opacity: 0.7;
|
|
151
|
+
}
|
|
152
|
+
.__crossx-copy-btn:hover,
|
|
153
|
+
.__crossx-copy-btn:focus,
|
|
154
|
+
.__crossx-copy-btn:active {
|
|
155
|
+
opacity: 0.7 !important;
|
|
156
|
+
box-shadow: none !important;
|
|
157
|
+
outline: none !important;
|
|
158
|
+
filter: none !important;
|
|
159
|
+
transform: none !important;
|
|
160
|
+
background: none !important;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
/* Amount pill */
|
|
164
|
+
.__crossx-pill {
|
|
165
|
+
background: var(--cx-pill-bg);
|
|
166
|
+
border-radius: 12px;
|
|
167
|
+
padding: 16px;
|
|
168
|
+
display: flex;
|
|
169
|
+
align-items: center;
|
|
170
|
+
gap: 8px;
|
|
171
|
+
}
|
|
172
|
+
.__crossx-pill-from {
|
|
173
|
+
font-size: 16px;
|
|
174
|
+
font-weight: 600;
|
|
175
|
+
line-height: 1.3;
|
|
176
|
+
color: var(--cx-pill-from);
|
|
177
|
+
white-space: nowrap;
|
|
178
|
+
overflow: hidden;
|
|
179
|
+
text-overflow: ellipsis;
|
|
180
|
+
flex-shrink: 1;
|
|
181
|
+
min-width: 0;
|
|
182
|
+
}
|
|
183
|
+
.__crossx-pill-amount {
|
|
184
|
+
font-size: 16px;
|
|
185
|
+
font-weight: 600;
|
|
186
|
+
line-height: 1.3;
|
|
187
|
+
color: var(--cx-pill-amt);
|
|
188
|
+
text-align: right;
|
|
189
|
+
white-space: nowrap;
|
|
190
|
+
flex-shrink: 0;
|
|
191
|
+
margin-left: auto;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
/* Message box */
|
|
195
|
+
.__crossx-msg-box {
|
|
196
|
+
background: var(--cx-pill-bg);
|
|
197
|
+
border-radius: 12px;
|
|
198
|
+
padding: 16px;
|
|
199
|
+
max-height: 160px;
|
|
200
|
+
overflow-y: auto;
|
|
201
|
+
word-break: break-all;
|
|
202
|
+
font-size: 13px;
|
|
203
|
+
font-weight: 400;
|
|
204
|
+
line-height: 1.5;
|
|
205
|
+
color: var(--cx-value);
|
|
206
|
+
white-space: pre-wrap;
|
|
207
|
+
}
|
|
208
|
+
|
|
209
|
+
|
|
210
|
+
/* ── Migration Found Modal ─────────────────────────────────────── */
|
|
211
|
+
.__crossx-card--migration {
|
|
212
|
+
width: 560px;
|
|
213
|
+
}
|
|
214
|
+
.__crossx-subtitle--body {
|
|
215
|
+
font-size: 16px;
|
|
216
|
+
font-weight: 500;
|
|
217
|
+
line-height: 1.5;
|
|
218
|
+
color: var(--cx-subtitle);
|
|
219
|
+
margin: 0;
|
|
220
|
+
letter-spacing: -0.16px;
|
|
221
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
222
|
+
}
|
|
223
|
+
.__crossx-mig-info {
|
|
224
|
+
display: flex;
|
|
225
|
+
flex-direction: column;
|
|
226
|
+
gap: 4px;
|
|
227
|
+
}
|
|
228
|
+
.__crossx-mig-info-title {
|
|
229
|
+
font-size: 14px;
|
|
230
|
+
font-weight: 600;
|
|
231
|
+
line-height: 1.4;
|
|
232
|
+
color: var(--cx-value);
|
|
233
|
+
margin: 0;
|
|
234
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
235
|
+
}
|
|
236
|
+
.__crossx-mig-info-desc {
|
|
237
|
+
font-size: 14px;
|
|
238
|
+
font-weight: 400;
|
|
239
|
+
line-height: 1.4;
|
|
240
|
+
color: var(--cx-subtitle);
|
|
241
|
+
margin: 0;
|
|
242
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
243
|
+
}
|
|
244
|
+
.__crossx-recover-btn {
|
|
245
|
+
display: flex;
|
|
246
|
+
align-items: center;
|
|
247
|
+
gap: 16px;
|
|
248
|
+
width: 100%;
|
|
249
|
+
padding: 16px;
|
|
250
|
+
background: var(--cx-pill-bg);
|
|
251
|
+
border: 1px solid var(--cx-pill-bg);
|
|
252
|
+
border-radius: 20px;
|
|
253
|
+
cursor: pointer;
|
|
254
|
+
appearance: none;
|
|
255
|
+
-webkit-appearance: none;
|
|
256
|
+
-webkit-tap-highlight-color: transparent;
|
|
257
|
+
box-shadow: none;
|
|
258
|
+
outline: none;
|
|
259
|
+
}
|
|
260
|
+
.__crossx-recover-btn:hover,
|
|
261
|
+
.__crossx-recover-btn:focus,
|
|
262
|
+
.__crossx-recover-btn:active {
|
|
263
|
+
background: var(--cx-pill-bg) !important;
|
|
264
|
+
border-color: var(--cx-pill-bg) !important;
|
|
265
|
+
opacity: 1 !important;
|
|
266
|
+
box-shadow: none !important;
|
|
267
|
+
outline: none !important;
|
|
268
|
+
filter: none !important;
|
|
269
|
+
transform: none !important;
|
|
270
|
+
}
|
|
271
|
+
.__crossx-recover-label {
|
|
272
|
+
font-size: 18px;
|
|
273
|
+
font-weight: 700;
|
|
274
|
+
line-height: 1.3;
|
|
275
|
+
color: var(--cx-value);
|
|
276
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
277
|
+
}
|
|
278
|
+
.__crossx-skip-btn {
|
|
279
|
+
font-size: 16px;
|
|
280
|
+
font-weight: 400;
|
|
281
|
+
line-height: 1.3;
|
|
282
|
+
color: var(--cx-subtitle);
|
|
283
|
+
text-decoration: underline;
|
|
284
|
+
cursor: pointer;
|
|
285
|
+
text-align: center;
|
|
286
|
+
display: block;
|
|
287
|
+
background: none;
|
|
288
|
+
border: none;
|
|
289
|
+
width: 100%;
|
|
290
|
+
font-family: 'Sora', -apple-system, sans-serif;
|
|
291
|
+
padding: 0;
|
|
292
|
+
appearance: none;
|
|
293
|
+
-webkit-appearance: none;
|
|
294
|
+
-webkit-tap-highlight-color: transparent;
|
|
295
|
+
box-shadow: none;
|
|
296
|
+
outline: none;
|
|
297
|
+
}
|
|
298
|
+
.__crossx-skip-btn:hover,
|
|
299
|
+
.__crossx-skip-btn:focus,
|
|
300
|
+
.__crossx-skip-btn:active {
|
|
301
|
+
background: none !important;
|
|
302
|
+
color: var(--cx-subtitle) !important;
|
|
303
|
+
opacity: 1 !important;
|
|
304
|
+
box-shadow: none !important;
|
|
305
|
+
outline: none !important;
|
|
306
|
+
filter: none !important;
|
|
307
|
+
transform: none !important;
|
|
308
|
+
text-decoration: underline !important;
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
/* ── PIN Input Modal ───────────────────────────────────────────── */
|
|
312
|
+
.__crossx-pin-center {
|
|
313
|
+
display: flex;
|
|
314
|
+
flex-direction: column;
|
|
315
|
+
align-items: center;
|
|
316
|
+
justify-content: center;
|
|
317
|
+
height: 272px;
|
|
318
|
+
gap: 16px;
|
|
319
|
+
padding: 20px 64px 24px;
|
|
320
|
+
}
|
|
321
|
+
.__crossx-pin-inputs {
|
|
322
|
+
display: flex;
|
|
323
|
+
gap: 16px;
|
|
324
|
+
}
|
|
325
|
+
.__crossx-pin-input {
|
|
326
|
+
width: 72px;
|
|
327
|
+
height: 72px;
|
|
328
|
+
border: 1px solid var(--cx-input-border);
|
|
329
|
+
border-radius: 8px;
|
|
330
|
+
background: var(--cx-input-bg);
|
|
331
|
+
text-align: center;
|
|
332
|
+
font-size: 32px;
|
|
333
|
+
font-weight: 600;
|
|
334
|
+
font-family: 'Sora', sans-serif;
|
|
335
|
+
color: var(--cx-value);
|
|
336
|
+
outline: none;
|
|
337
|
+
transition: border-color 0.15s, box-shadow 0.15s;
|
|
338
|
+
-webkit-text-security: disc;
|
|
339
|
+
}
|
|
340
|
+
.__crossx-pin-input:focus {
|
|
341
|
+
border-color: var(--cx-primary);
|
|
342
|
+
box-shadow: 0 0 0 2px var(--cx-primary-glow);
|
|
343
|
+
}
|
|
344
|
+
.__crossx-pin-input.--error {
|
|
345
|
+
border-color: var(--cx-secondary);
|
|
346
|
+
}
|
|
347
|
+
.__crossx-pin-hint {
|
|
348
|
+
font-size: 16px;
|
|
349
|
+
font-weight: 500;
|
|
350
|
+
line-height: 1.5;
|
|
351
|
+
color: var(--cx-subtitle);
|
|
352
|
+
text-align: center;
|
|
353
|
+
font-family: 'Pretendard', -apple-system, sans-serif;
|
|
354
|
+
letter-spacing: -0.16px;
|
|
355
|
+
margin: 0;
|
|
356
|
+
}
|
|
357
|
+
.__crossx-pin-error-text {
|
|
358
|
+
font-size: 14px;
|
|
359
|
+
font-weight: 500;
|
|
360
|
+
line-height: 1.4;
|
|
361
|
+
color: var(--cx-secondary);
|
|
362
|
+
text-align: center;
|
|
363
|
+
margin: 0;
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
/* ── Signature Request modals (message & typed data) ───────── */
|
|
367
|
+
.__crossx-sig-subtitle {
|
|
368
|
+
font-size: 18px;
|
|
369
|
+
font-weight: 600;
|
|
370
|
+
line-height: 1.3;
|
|
371
|
+
color: var(--cx-title);
|
|
372
|
+
text-align: center;
|
|
373
|
+
margin: 0;
|
|
374
|
+
}
|
|
375
|
+
.__crossx-sig-origin { color: var(--cx-primary); }
|
|
376
|
+
.__crossx-addr-pill {
|
|
377
|
+
background: var(--cx-pill-bg);
|
|
378
|
+
border-radius: 12px;
|
|
379
|
+
padding: 16px;
|
|
380
|
+
display: flex;
|
|
381
|
+
align-items: center;
|
|
382
|
+
justify-content: center;
|
|
383
|
+
gap: 8px;
|
|
384
|
+
color: var(--cx-value);
|
|
385
|
+
}
|
|
386
|
+
.__crossx-addr-pill-text {
|
|
387
|
+
font-size: 18px;
|
|
388
|
+
font-weight: 600;
|
|
389
|
+
line-height: 1.3;
|
|
390
|
+
color: var(--cx-value);
|
|
391
|
+
}
|
|
392
|
+
.__crossx-warning {
|
|
393
|
+
font-size: 14px;
|
|
394
|
+
font-weight: 400;
|
|
395
|
+
line-height: 1.3;
|
|
396
|
+
color: var(--cx-subtitle);
|
|
397
|
+
text-align: center;
|
|
398
|
+
margin: 0;
|
|
399
|
+
}
|
|
400
|
+
.__crossx-msg-raw {
|
|
401
|
+
font-size: 14px;
|
|
402
|
+
font-weight: 400;
|
|
403
|
+
line-height: 1.3;
|
|
404
|
+
color: var(--cx-label);
|
|
405
|
+
white-space: pre-wrap;
|
|
406
|
+
word-break: break-all;
|
|
407
|
+
max-height: 200px;
|
|
408
|
+
overflow-y: auto;
|
|
409
|
+
margin: 0;
|
|
410
|
+
}
|
|
411
|
+
.__crossx-td-rows {
|
|
412
|
+
display: flex;
|
|
413
|
+
flex-direction: column;
|
|
414
|
+
gap: 4px;
|
|
415
|
+
}
|
|
416
|
+
.__crossx-td-row {
|
|
417
|
+
display: flex;
|
|
418
|
+
align-items: center;
|
|
419
|
+
justify-content: space-between;
|
|
420
|
+
min-height: 20px;
|
|
421
|
+
gap: 20px;
|
|
422
|
+
}
|
|
423
|
+
.__crossx-td-label {
|
|
424
|
+
font-size: 13px;
|
|
425
|
+
font-weight: 400;
|
|
426
|
+
line-height: 1.3;
|
|
427
|
+
color: var(--cx-label);
|
|
428
|
+
flex-shrink: 0;
|
|
429
|
+
}
|
|
430
|
+
.__crossx-td-value {
|
|
431
|
+
font-size: 13px;
|
|
432
|
+
font-weight: 400;
|
|
433
|
+
line-height: 1.3;
|
|
434
|
+
color: var(--cx-value);
|
|
435
|
+
text-align: right;
|
|
436
|
+
display: flex;
|
|
437
|
+
align-items: center;
|
|
438
|
+
justify-content: flex-end;
|
|
439
|
+
gap: 4px;
|
|
440
|
+
min-width: 0;
|
|
441
|
+
}
|
|
442
|
+
|
|
443
|
+
/* ── Transaction modals ────────────────────────────────────── */
|
|
444
|
+
.__crossx-tx-subtitle {
|
|
445
|
+
font-size: 14px;
|
|
446
|
+
font-weight: 400;
|
|
447
|
+
line-height: 1.3;
|
|
448
|
+
color: var(--cx-subtitle);
|
|
449
|
+
margin: 0;
|
|
450
|
+
}
|
|
451
|
+
.__crossx-raw-tx {
|
|
452
|
+
background: var(--cx-pill-bg);
|
|
453
|
+
border-radius: 12px;
|
|
454
|
+
padding: 16px;
|
|
455
|
+
font-size: 13px;
|
|
456
|
+
font-weight: 400;
|
|
457
|
+
line-height: 1.6;
|
|
458
|
+
color: var(--cx-label);
|
|
459
|
+
white-space: pre-wrap;
|
|
460
|
+
word-break: break-all;
|
|
461
|
+
max-height: 180px;
|
|
462
|
+
overflow-y: auto;
|
|
463
|
+
margin: 0;
|
|
464
|
+
width: 100%;
|
|
465
|
+
box-sizing: border-box;
|
|
466
|
+
}
|
|
467
|
+
.__crossx-approve-btn {
|
|
468
|
+
width: 100%;
|
|
469
|
+
padding: 16px;
|
|
470
|
+
border: 1px solid rgba(18,18,18,0.05);
|
|
471
|
+
border-radius: 12px;
|
|
472
|
+
background: var(--cx-primary);
|
|
473
|
+
color: var(--cx-on-primary);
|
|
474
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
475
|
+
font-size: 18px;
|
|
476
|
+
font-weight: 700;
|
|
477
|
+
line-height: 1.3;
|
|
478
|
+
cursor: pointer;
|
|
479
|
+
}
|
|
480
|
+
.__crossx-approve-btn:hover,
|
|
481
|
+
.__crossx-approve-btn:focus,
|
|
482
|
+
.__crossx-approve-btn:active {
|
|
483
|
+
opacity: 1 !important;
|
|
484
|
+
box-shadow: none !important;
|
|
485
|
+
outline: none !important;
|
|
486
|
+
filter: none !important;
|
|
487
|
+
transform: none !important;
|
|
488
|
+
background: var(--cx-primary) !important;
|
|
489
|
+
color: var(--cx-on-primary) !important;
|
|
490
|
+
}
|
|
491
|
+
.__crossx-btn-row {
|
|
492
|
+
display: flex;
|
|
493
|
+
gap: 8px;
|
|
494
|
+
width: 100%;
|
|
495
|
+
}
|
|
496
|
+
.__crossx-cancel-btn {
|
|
497
|
+
flex: 1;
|
|
498
|
+
padding: 16px;
|
|
499
|
+
border: 1px solid var(--cx-primary);
|
|
500
|
+
border-radius: 12px;
|
|
501
|
+
background: none;
|
|
502
|
+
color: var(--cx-primary);
|
|
503
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
504
|
+
font-size: 18px;
|
|
505
|
+
font-weight: 700;
|
|
506
|
+
line-height: 1.3;
|
|
507
|
+
cursor: pointer;
|
|
508
|
+
}
|
|
509
|
+
.__crossx-cancel-btn:hover,
|
|
510
|
+
.__crossx-cancel-btn:focus,
|
|
511
|
+
.__crossx-cancel-btn:active {
|
|
512
|
+
opacity: 1 !important;
|
|
513
|
+
box-shadow: none !important;
|
|
514
|
+
outline: none !important;
|
|
515
|
+
filter: none !important;
|
|
516
|
+
transform: none !important;
|
|
517
|
+
background: none !important;
|
|
518
|
+
color: var(--cx-primary) !important;
|
|
519
|
+
}
|
|
520
|
+
.__crossx-confirm-btn {
|
|
521
|
+
flex: 1;
|
|
522
|
+
padding: 16px;
|
|
523
|
+
border: 1px solid rgba(18,18,18,0.05);
|
|
524
|
+
border-radius: 12px;
|
|
525
|
+
background: var(--cx-primary);
|
|
526
|
+
color: var(--cx-on-primary);
|
|
527
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
528
|
+
font-size: 18px;
|
|
529
|
+
font-weight: 700;
|
|
530
|
+
line-height: 1.3;
|
|
531
|
+
cursor: pointer;
|
|
532
|
+
}
|
|
533
|
+
.__crossx-confirm-btn:hover,
|
|
534
|
+
.__crossx-confirm-btn:focus,
|
|
535
|
+
.__crossx-confirm-btn:active {
|
|
536
|
+
opacity: 1 !important;
|
|
537
|
+
box-shadow: none !important;
|
|
538
|
+
outline: none !important;
|
|
539
|
+
filter: none !important;
|
|
540
|
+
transform: none !important;
|
|
541
|
+
background: var(--cx-primary) !important;
|
|
542
|
+
color: var(--cx-on-primary) !important;
|
|
543
|
+
}
|
|
544
|
+
|
|
545
|
+
/* ── Transaction Progress / Complete Modal ─────────────────── */
|
|
546
|
+
@keyframes __crossx-spinner {
|
|
547
|
+
to { transform: rotate(360deg); }
|
|
548
|
+
}
|
|
549
|
+
.__crossx-progress-center {
|
|
550
|
+
display: flex;
|
|
551
|
+
flex-direction: column;
|
|
552
|
+
align-items: center;
|
|
553
|
+
justify-content: center;
|
|
554
|
+
gap: 16px;
|
|
555
|
+
padding: 24px 0;
|
|
556
|
+
min-height: 280px;
|
|
557
|
+
}
|
|
558
|
+
.__crossx-spinner {
|
|
559
|
+
width: 48px;
|
|
560
|
+
height: 48px;
|
|
561
|
+
border: 4px solid var(--cx-border);
|
|
562
|
+
border-top-color: var(--cx-primary);
|
|
563
|
+
border-radius: 50%;
|
|
564
|
+
animation: __crossx-spinner 0.8s linear infinite;
|
|
565
|
+
}
|
|
566
|
+
.__crossx-progress-text {
|
|
567
|
+
font-size: 14px;
|
|
568
|
+
font-weight: 400;
|
|
569
|
+
line-height: 1.4;
|
|
570
|
+
color: var(--cx-label);
|
|
571
|
+
text-align: center;
|
|
572
|
+
margin: 0;
|
|
573
|
+
}
|
|
574
|
+
.__crossx-total-pill {
|
|
575
|
+
background: var(--cx-pill-bg);
|
|
576
|
+
border-radius: 12px;
|
|
577
|
+
padding: 16px;
|
|
578
|
+
display: flex;
|
|
579
|
+
align-items: center;
|
|
580
|
+
justify-content: space-between;
|
|
581
|
+
gap: 8px;
|
|
582
|
+
}
|
|
583
|
+
.__crossx-total-label {
|
|
584
|
+
font-size: 14px;
|
|
585
|
+
font-weight: 600;
|
|
586
|
+
line-height: 1.4;
|
|
587
|
+
color: var(--cx-pill-from);
|
|
588
|
+
font-family: 'Sora', 'Pretendard', -apple-system, sans-serif;
|
|
589
|
+
}
|
|
590
|
+
.__crossx-total-amount {
|
|
591
|
+
font-size: 16px;
|
|
592
|
+
font-weight: 600;
|
|
593
|
+
line-height: 1.3;
|
|
594
|
+
color: var(--cx-pill-amt);
|
|
595
|
+
text-align: right;
|
|
596
|
+
white-space: nowrap;
|
|
597
|
+
flex-shrink: 0;
|
|
598
|
+
font-family: 'Sora', 'Pretendard', -apple-system, sans-serif;
|
|
599
|
+
}
|
|
600
|
+
|
|
601
|
+
/* ── Login Selector Modal ──────────────────────────────────── */
|
|
602
|
+
.__crossx-login-btn-row {
|
|
603
|
+
display: flex;
|
|
604
|
+
gap: 8px;
|
|
605
|
+
width: 100%;
|
|
606
|
+
}
|
|
607
|
+
.__crossx-login-btn {
|
|
608
|
+
flex: 1;
|
|
609
|
+
display: flex;
|
|
610
|
+
flex-direction: column;
|
|
611
|
+
gap: 16px;
|
|
612
|
+
padding: 16px;
|
|
613
|
+
background: var(--cx-pill-bg);
|
|
614
|
+
border: 1px solid var(--cx-border);
|
|
615
|
+
border-radius: 20px;
|
|
616
|
+
cursor: pointer;
|
|
617
|
+
align-items: flex-start;
|
|
618
|
+
justify-content: center;
|
|
619
|
+
appearance: none;
|
|
620
|
+
-webkit-appearance: none;
|
|
621
|
+
-webkit-tap-highlight-color: transparent;
|
|
622
|
+
box-shadow: none;
|
|
623
|
+
outline: none;
|
|
624
|
+
min-width: 0;
|
|
625
|
+
}
|
|
626
|
+
.__crossx-login-btn:hover,
|
|
627
|
+
.__crossx-login-btn:focus,
|
|
628
|
+
.__crossx-login-btn:active {
|
|
629
|
+
opacity: 1 !important;
|
|
630
|
+
box-shadow: none !important;
|
|
631
|
+
outline: none !important;
|
|
632
|
+
filter: none !important;
|
|
633
|
+
transform: none !important;
|
|
634
|
+
background: var(--cx-pill-bg) !important;
|
|
635
|
+
}
|
|
636
|
+
.__crossx-login-btn-label {
|
|
637
|
+
font-size: 18px;
|
|
638
|
+
font-weight: 700;
|
|
639
|
+
line-height: 1.3;
|
|
640
|
+
color: var(--cx-value);
|
|
641
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
642
|
+
text-align: left;
|
|
643
|
+
white-space: nowrap;
|
|
644
|
+
}
|
|
645
|
+
.__crossx-login-icon {
|
|
646
|
+
width: 40px;
|
|
647
|
+
height: 40px;
|
|
648
|
+
flex-shrink: 0;
|
|
649
|
+
display: flex;
|
|
650
|
+
align-items: center;
|
|
651
|
+
justify-content: center;
|
|
652
|
+
}
|
|
653
|
+
.__crossx-login-terms {
|
|
654
|
+
font-size: 12px;
|
|
655
|
+
font-weight: 400;
|
|
656
|
+
line-height: 1.3;
|
|
657
|
+
color: var(--cx-subtitle);
|
|
658
|
+
text-align: center;
|
|
659
|
+
font-family: 'Pretendard', 'Sora', -apple-system, sans-serif;
|
|
660
|
+
margin: 0;
|
|
661
|
+
width: 100%;
|
|
662
|
+
}
|
|
663
|
+
.__crossx-login-terms-link {
|
|
664
|
+
color: var(--cx-primary);
|
|
665
|
+
text-decoration: none;
|
|
666
|
+
}
|
|
667
|
+
.__crossx-login-terms-link:hover,
|
|
668
|
+
.__crossx-login-terms-link:focus,
|
|
669
|
+
.__crossx-login-terms-link:active {
|
|
670
|
+
color: var(--cx-primary) !important;
|
|
671
|
+
text-decoration: none !important;
|
|
672
|
+
opacity: 1 !important;
|
|
673
|
+
background: none !important;
|
|
674
|
+
box-shadow: none !important;
|
|
675
|
+
outline: none !important;
|
|
676
|
+
filter: none !important;
|
|
677
|
+
transform: none !important;
|
|
678
|
+
}
|
|
679
|
+
|
|
680
|
+
/* ── Wallet Selector Modal ─────────────────────────────────── */
|
|
681
|
+
.__crossx-wallet-list {
|
|
682
|
+
display: flex;
|
|
683
|
+
flex-direction: column;
|
|
684
|
+
gap: 8px;
|
|
685
|
+
max-height: 320px;
|
|
686
|
+
overflow-y: auto;
|
|
687
|
+
-webkit-overflow-scrolling: touch;
|
|
688
|
+
scrollbar-width: thin;
|
|
689
|
+
}
|
|
690
|
+
.__crossx-wallet-list::-webkit-scrollbar {
|
|
691
|
+
width: 4px;
|
|
692
|
+
}
|
|
693
|
+
.__crossx-wallet-list::-webkit-scrollbar-thumb {
|
|
694
|
+
background: var(--cx-divider);
|
|
695
|
+
border-radius: 2px;
|
|
696
|
+
}
|
|
697
|
+
.__crossx-wallet-item {
|
|
698
|
+
display: flex;
|
|
699
|
+
align-items: center;
|
|
700
|
+
gap: 8px;
|
|
701
|
+
padding: 16px;
|
|
702
|
+
background: var(--cx-pill-bg);
|
|
703
|
+
border: 1px solid var(--cx-border);
|
|
704
|
+
border-radius: 8px;
|
|
705
|
+
cursor: pointer;
|
|
706
|
+
appearance: none;
|
|
707
|
+
-webkit-appearance: none;
|
|
708
|
+
-webkit-tap-highlight-color: transparent;
|
|
709
|
+
box-shadow: none;
|
|
710
|
+
outline: none;
|
|
711
|
+
width: 100%;
|
|
712
|
+
font-family: 'Sora', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
|
|
713
|
+
}
|
|
714
|
+
.__crossx-wallet-item:hover,
|
|
715
|
+
.__crossx-wallet-item:focus,
|
|
716
|
+
.__crossx-wallet-item:active {
|
|
717
|
+
opacity: 1 !important;
|
|
718
|
+
box-shadow: none !important;
|
|
719
|
+
outline: none !important;
|
|
720
|
+
filter: none !important;
|
|
721
|
+
transform: none !important;
|
|
722
|
+
background: var(--cx-pill-bg) !important;
|
|
723
|
+
}
|
|
724
|
+
.__crossx-wallet-addr {
|
|
725
|
+
font-size: 16px;
|
|
726
|
+
font-weight: 600;
|
|
727
|
+
line-height: 1.3;
|
|
728
|
+
color: var(--cx-value);
|
|
729
|
+
white-space: nowrap;
|
|
730
|
+
}
|
|
731
|
+
.__crossx-wallet-selected {
|
|
732
|
+
font-size: 11px;
|
|
733
|
+
font-weight: 600;
|
|
734
|
+
line-height: 1;
|
|
735
|
+
color: var(--cx-primary);
|
|
736
|
+
border: 1.5px solid var(--cx-primary);
|
|
737
|
+
border-radius: 6px;
|
|
738
|
+
padding: 4px 8px;
|
|
739
|
+
margin-left: auto;
|
|
740
|
+
flex-shrink: 0;
|
|
741
|
+
white-space: nowrap;
|
|
742
|
+
}
|
|
743
|
+
.__crossx-wallet-add {
|
|
744
|
+
display: flex;
|
|
745
|
+
align-items: center;
|
|
746
|
+
justify-content: center;
|
|
747
|
+
gap: 8px;
|
|
748
|
+
padding: 16px;
|
|
749
|
+
border: 1px dashed var(--cx-divider);
|
|
750
|
+
border-radius: 8px;
|
|
751
|
+
cursor: pointer;
|
|
752
|
+
appearance: none;
|
|
753
|
+
-webkit-appearance: none;
|
|
754
|
+
-webkit-tap-highlight-color: transparent;
|
|
755
|
+
box-shadow: none;
|
|
756
|
+
outline: none;
|
|
757
|
+
background: none;
|
|
758
|
+
width: 100%;
|
|
759
|
+
flex-shrink: 0;
|
|
760
|
+
font-family: 'Sora', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
|
|
761
|
+
}
|
|
762
|
+
.__crossx-wallet-add:hover,
|
|
763
|
+
.__crossx-wallet-add:focus,
|
|
764
|
+
.__crossx-wallet-add:active {
|
|
765
|
+
opacity: 1 !important;
|
|
766
|
+
box-shadow: none !important;
|
|
767
|
+
outline: none !important;
|
|
768
|
+
filter: none !important;
|
|
769
|
+
transform: none !important;
|
|
770
|
+
background: none !important;
|
|
771
|
+
}
|
|
772
|
+
.__crossx-wallet-add:disabled { opacity: 0.5; cursor: not-allowed; }
|
|
773
|
+
.__crossx-wallet-add-icon {
|
|
774
|
+
width: 24px;
|
|
775
|
+
height: 24px;
|
|
776
|
+
color: var(--cx-subtitle);
|
|
777
|
+
}
|
|
778
|
+
.__crossx-wallet-add-label {
|
|
779
|
+
font-size: 16px;
|
|
780
|
+
font-weight: 600;
|
|
781
|
+
line-height: 1.3;
|
|
782
|
+
color: var(--cx-subtitle);
|
|
783
|
+
}
|
|
784
|
+
|
|
785
|
+
/* ── Mobile bottom sheet ───────────────────────────────────── */
|
|
786
|
+
@media (max-width: 480px) {
|
|
787
|
+
#${te} { align-items: flex-end; }
|
|
788
|
+
.__crossx-card {
|
|
789
|
+
width: 100%;
|
|
790
|
+
max-width: 100%;
|
|
791
|
+
border-radius: 24px 24px 0 0;
|
|
792
|
+
border-bottom: none;
|
|
793
|
+
max-height: 85vh;
|
|
794
|
+
overflow-y: auto;
|
|
795
|
+
animation: __crossx-slide-up-mobile 0.25s ease;
|
|
796
|
+
}
|
|
797
|
+
.__crossx-card--wallet-selector {
|
|
798
|
+
overflow: hidden !important;
|
|
799
|
+
}
|
|
800
|
+
.__crossx-card--wallet-selector .__crossx-wallet-list { max-height: 203px; }
|
|
801
|
+
.__crossx-login-btn-row {
|
|
802
|
+
flex-direction: column;
|
|
803
|
+
}
|
|
804
|
+
.__crossx-login-btn-label {
|
|
805
|
+
white-space: normal;
|
|
806
|
+
}
|
|
807
|
+
}
|
|
808
|
+
@keyframes __crossx-slide-up-mobile {
|
|
809
|
+
from { transform: translateY(100%); }
|
|
810
|
+
to { transform: translateY(0); }
|
|
811
|
+
}
|
|
812
|
+
|
|
813
|
+
/* ── 2-column wrapper (portrait: column, landscape: row) ── */
|
|
814
|
+
.__crossx-body-cols {
|
|
815
|
+
display: flex;
|
|
816
|
+
flex-direction: column;
|
|
817
|
+
gap: 16px;
|
|
818
|
+
width: 100%;
|
|
819
|
+
}
|
|
820
|
+
.__crossx-col-left {
|
|
821
|
+
display: flex;
|
|
822
|
+
flex-direction: column;
|
|
823
|
+
gap: 16px;
|
|
824
|
+
}
|
|
825
|
+
.__crossx-divider--cols { flex-shrink: 0; }
|
|
826
|
+
.__crossx-col-right-ws {
|
|
827
|
+
display: flex;
|
|
828
|
+
flex-direction: column;
|
|
829
|
+
gap: 8px;
|
|
830
|
+
}
|
|
831
|
+
|
|
832
|
+
/* ── Landscape for signing/transaction modals ──────────── */
|
|
833
|
+
@media (orientation: landscape) and (max-height: 500px) {
|
|
834
|
+
#${te} { align-items: center !important; overflow: hidden; }
|
|
835
|
+
.__crossx-card--send-tx,
|
|
836
|
+
.__crossx-card--sign-tx,
|
|
837
|
+
.__crossx-card--sign-msg,
|
|
838
|
+
.__crossx-card--sign-typed,
|
|
839
|
+
.__crossx-card--wallet-selector {
|
|
840
|
+
width: 600px;
|
|
841
|
+
max-width: calc(100vw - 32px);
|
|
842
|
+
border-radius: 24px;
|
|
843
|
+
border-bottom: 4px solid var(--cx-border);
|
|
844
|
+
max-height: calc(100vh - 32px);
|
|
845
|
+
overflow-y: auto;
|
|
846
|
+
animation: __crossx-slide-up 0.18s ease;
|
|
847
|
+
}
|
|
848
|
+
.__crossx-card--send-tx .__crossx-header,
|
|
849
|
+
.__crossx-card--sign-tx .__crossx-header,
|
|
850
|
+
.__crossx-card--sign-msg .__crossx-header,
|
|
851
|
+
.__crossx-card--sign-typed .__crossx-header,
|
|
852
|
+
.__crossx-card--wallet-selector .__crossx-header {
|
|
853
|
+
padding: 16px 24px 12px;
|
|
854
|
+
}
|
|
855
|
+
.__crossx-card--send-tx .__crossx-body,
|
|
856
|
+
.__crossx-card--sign-tx .__crossx-body,
|
|
857
|
+
.__crossx-card--sign-msg .__crossx-body,
|
|
858
|
+
.__crossx-card--sign-typed .__crossx-body,
|
|
859
|
+
.__crossx-card--wallet-selector .__crossx-body {
|
|
860
|
+
padding: 16px 24px 20px;
|
|
861
|
+
gap: 12px;
|
|
862
|
+
}
|
|
863
|
+
.__crossx-card--send-tx .__crossx-body-cols,
|
|
864
|
+
.__crossx-card--sign-tx .__crossx-body-cols,
|
|
865
|
+
.__crossx-card--sign-msg .__crossx-body-cols,
|
|
866
|
+
.__crossx-card--sign-typed .__crossx-body-cols,
|
|
867
|
+
.__crossx-card--wallet-selector .__crossx-body-cols {
|
|
868
|
+
flex-direction: row;
|
|
869
|
+
gap: 24px;
|
|
870
|
+
align-items: flex-start;
|
|
871
|
+
}
|
|
872
|
+
.__crossx-body-cols > * { flex: 1; min-width: 0; }
|
|
873
|
+
.__crossx-col-left { gap: 8px; }
|
|
874
|
+
.__crossx-divider--cols { display: none; }
|
|
875
|
+
.__crossx-card--send-tx .__crossx-pill {
|
|
876
|
+
flex-direction: column;
|
|
877
|
+
align-items: flex-end;
|
|
878
|
+
}
|
|
879
|
+
.__crossx-card--sign-tx .__crossx-raw-tx { max-height: 120px; }
|
|
880
|
+
.__crossx-card--sign-msg .__crossx-msg-raw,
|
|
881
|
+
.__crossx-card--sign-msg .__crossx-msg-box { max-height: 130px; }
|
|
882
|
+
.__crossx-card--sign-typed .__crossx-td-rows { max-height: 130px; overflow-y: auto; }
|
|
883
|
+
.__crossx-col-left > .__crossx-divider { display: none; }
|
|
884
|
+
.__crossx-card--wallet-selector {
|
|
885
|
+
overflow: hidden !important;
|
|
886
|
+
display: flex !important;
|
|
887
|
+
flex-direction: column !important;
|
|
888
|
+
}
|
|
889
|
+
.__crossx-card--wallet-selector .__crossx-header { flex-shrink: 0; }
|
|
890
|
+
.__crossx-card--wallet-selector > .__crossx-divider { flex-shrink: 0; }
|
|
891
|
+
.__crossx-card--wallet-selector .__crossx-body {
|
|
892
|
+
flex: 1;
|
|
893
|
+
min-height: 0;
|
|
894
|
+
overflow: hidden;
|
|
895
|
+
display: flex;
|
|
896
|
+
flex-direction: column;
|
|
897
|
+
}
|
|
898
|
+
.__crossx-card--wallet-selector .__crossx-body-cols {
|
|
899
|
+
flex: 1;
|
|
900
|
+
min-height: 0;
|
|
901
|
+
align-items: stretch !important;
|
|
902
|
+
}
|
|
903
|
+
.__crossx-card--wallet-selector .__crossx-col-right-ws {
|
|
904
|
+
display: flex;
|
|
905
|
+
flex-direction: column;
|
|
906
|
+
gap: 8px;
|
|
907
|
+
min-height: 0;
|
|
908
|
+
overflow: hidden;
|
|
909
|
+
}
|
|
910
|
+
.__crossx-card--wallet-selector .__crossx-wallet-list {
|
|
911
|
+
max-height: none;
|
|
912
|
+
flex: 1;
|
|
913
|
+
min-height: 0;
|
|
914
|
+
}
|
|
915
|
+
.__crossx-card--wallet-selector .__crossx-wallet-add { flex-shrink: 0; }
|
|
916
|
+
}
|
|
917
|
+
`;function Se(){let r=document.getElementById(Es);r||(r=document.createElement("style"),r.id=Es,document.head.appendChild(r)),r.textContent=Cn}function J(r){return r?r.length<=13?r:`${r.slice(0,6)}…${r.slice(-4)}`:"—"}function Nn(r,e="CROSS",s=18){if(!r||r==="0x"||r==="0x0")return null;try{const t=BigInt(r);if(t===0n)return null;const n=xt(t,s);return n==="0"?null:`${n} ${e}`}catch{return null}}const Ts={1:"Ethereum Mainnet",5:"Goerli Testnet",11155111:"Ethereum Sepolia",17e3:"Ethereum Holesky",10:"Optimism",420:"Optimism Goerli",42161:"Arbitrum One",421614:"Arbitrum Sepolia",8453:"Base",84532:"Base Sepolia",137:"Polygon",80002:"Polygon Amoy",56:"BNB Smart Chain",97:"BNB Testnet",43114:"Avalanche C-Chain",43113:"Avalanche Fuji",250:"Fantom Opera",2020:"Ronin",202601:"Ronin Saigon",612044:"CROSS Testnet",612055:"CROSS Mainnet"};function As(r){const e=parseInt(r.split(":")[1]??"",10);return!isNaN(e)&&Ts[e]?Ts[e]:r}function xt(r,e){if(r===0n)return"0";const s=10n**BigInt(e),t=r/s,i=(r%s).toString().padStart(e,"0").slice(0,6).replace(/0+$/,"");return i?`${t}.${i}`:`${t}`}function mt(r){try{const e=BigInt(r),s=e/1000000000n,n=(e%1000000000n).toString().padStart(9,"0").slice(0,2).replace(/0+$/,"");return n?`${s}.${n}`:`${s}`}catch{return r}}function kn(r){try{return BigInt(r).toLocaleString()}catch{return r}}function Pn(r){const{gasLimit:e,gasPrice:s,maxFeePerGas:t,maxPriorityFeePerGas:n,nativeSymbol:o="ETH",nativeDecimals:i=18}=r;if(!e)return null;try{const a=BigInt(e),c=kn(e);if(t){const l=a*BigInt(t);return{isDynamic:!0,estTxFee:`${xt(l,i)} ${o}`,maxFeeGwei:mt(t),maxPriorityFeeGwei:n?mt(n):void 0,gasLimitFormatted:c}}if(s){const l=a*BigInt(s);return{isDynamic:!1,estTxFee:`${xt(l,i)} ${o}`,gasPriceGwei:mt(s),gasLimitFormatted:c}}return{isDynamic:!1,estTxFee:`${a.toLocaleString()} gas`,gasLimitFormatted:c}}catch{return null}}function Rs(r){const e=Pn(r);if(!e)return W("Estimated fee","<span>—</span>");let s=W("Est. Tx Fee",`<span>${e.estTxFee}</span>`);return e.isDynamic?(e.maxPriorityFeeGwei!==void 0&&(s+=W("Max Priority Fee",`<span>${e.maxPriorityFeeGwei} Gwei</span>`)),e.maxFeeGwei!==void 0&&(s+=W("Max Gas Fee",`<span>${e.maxFeeGwei} Gwei</span>`))):e.gasPriceGwei!==void 0&&(s+=W("Gas Price",`<span>${e.gasPriceGwei} Gwei</span>`)),e.gasLimitFormatted&&(s+=W("Gas Limit",`<span>${e.gasLimitFormatted}</span>`)),s}const fe=`<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round">
|
|
918
|
+
<rect x="9" y="9" width="13" height="13" rx="2"/>
|
|
919
|
+
<path d="M5 15H4a2 2 0 0 1-2-2V4a2 2 0 0 1 2-2h9a2 2 0 0 1 2 2v1"/>
|
|
920
|
+
</svg>`,ae=`<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round">
|
|
921
|
+
<line x1="18" y1="6" x2="6" y2="18"/>
|
|
922
|
+
<line x1="6" y1="6" x2="18" y2="18"/>
|
|
923
|
+
</svg>`;function Ln(r){return`<svg width="28" height="28" viewBox="0 0 28 28" fill="none">
|
|
924
|
+
<circle cx="14" cy="14" r="14" fill="${r}"/>
|
|
925
|
+
<path d="M14 7.5L19.2 10.5V16.5L14 19.5L8.8 16.5V10.5L14 7.5Z" fill="white" opacity="0.9"/>
|
|
926
|
+
</svg>`}const wt=`<svg width="20" height="20" viewBox="0 0 20 20" fill="none">
|
|
927
|
+
<rect x="2" y="5" width="16" height="12" rx="2" stroke="currentColor" stroke-width="1.5"/>
|
|
928
|
+
<path d="M2 9h16" stroke="currentColor" stroke-width="1.5"/>
|
|
929
|
+
<rect x="12.5" y="11.5" width="3.5" height="2.5" rx="0.75" fill="currentColor"/>
|
|
930
|
+
</svg>`,Dn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
|
|
931
|
+
<path d="M12 0C18.6274 0 24 5.37258 24 12C23.9999 18.6273 18.6274 24 12 24C5.37264 24 9.89594e-05 18.6273 0 12C0 5.37258 5.37258 0 12 0ZM10.875 15.127V17.377H13.125V15.127H10.875ZM10.875 6.62207V13.627H13.125V6.62207H10.875Z" fill="var(--cx-secondary)"/>
|
|
932
|
+
</svg>`,Mn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none">
|
|
933
|
+
<circle cx="12" cy="12" r="12" fill="var(--cx-secondary)"/>
|
|
934
|
+
<circle cx="12" cy="12" r="5.5" stroke="white" stroke-width="1.5"/>
|
|
935
|
+
<path d="M12 9.5v3l2 1.5" stroke="white" stroke-width="1.5" stroke-linecap="round"/>
|
|
936
|
+
</svg>`;function ce(r){return[`--cx-bg:${r.bg}`,`--cx-border:${r.border}`,`--cx-title:${r.titleColor}`,`--cx-subtitle:${r.subtitleColor}`,`--cx-label:${r.labelColor}`,`--cx-value:${r.valueColor}`,`--cx-pill-bg:${r.pillBg}`,`--cx-pill-from:${r.pillFromColor}`,`--cx-pill-amt:${r.pillAmtColor}`,`--cx-divider:${r.divider}`,`--cx-close:${r.closeColor}`,`--cx-close-hover:${r.closeHoverBg}`,`--cx-copy:${r.copyColor}`,`--cx-input-bg:${r.inputBg}`,`--cx-input-border:${r.inputBorder}`,`--cx-hint:${r.hintColor}`,`--cx-primary:${r.primary}`,`--cx-primary-glow:${r.primaryGlow}`,`--cx-secondary:${r.secondary}`,`--cx-on-primary:${r.onPrimary}`].join(";")}function W(r,e){return`
|
|
937
|
+
<div class="__crossx-row">
|
|
938
|
+
<span class="__crossx-row-label">${r}</span>
|
|
939
|
+
<div class="__crossx-row-value">${e}</div>
|
|
940
|
+
</div>`}function $n(r,e){const s=e,t=Ze(),n=r.to?`<span class="__crossx-addr-text">${J(r.to)}</span>
|
|
941
|
+
<button class="__crossx-copy-btn" data-copy="${M(r.to)}" title="Copy address">${fe}</button>`:"<span>—</span>",o=Rs(r),i=r.data&&r.data!=="0x"?r.data:"0x",a=document.createElement("div");return a.id=te,a.innerHTML=`
|
|
942
|
+
<div class="__crossx-card __crossx-card--migration __crossx-card--sign-tx" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
943
|
+
<div class="__crossx-header">
|
|
944
|
+
<p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
|
|
945
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
946
|
+
</div>
|
|
947
|
+
<hr class="__crossx-divider">
|
|
948
|
+
<div class="__crossx-body">
|
|
949
|
+
<div class="__crossx-body-cols">
|
|
950
|
+
<div class="__crossx-col-left">
|
|
951
|
+
<p class="__crossx-sig-subtitle">
|
|
952
|
+
<span class="__crossx-sig-origin">${M(t)} </span>is requesting a Signature
|
|
953
|
+
</p>
|
|
954
|
+
<div class="__crossx-addr-pill">
|
|
955
|
+
${wt}
|
|
956
|
+
<span class="__crossx-addr-pill-text">${J(r.from)}</span>
|
|
957
|
+
</div>
|
|
958
|
+
<p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
|
|
959
|
+
<hr class="__crossx-divider">
|
|
960
|
+
<div class="__crossx-rows">
|
|
961
|
+
${W("To",n)}
|
|
962
|
+
${W("Network",`<span>${As(r.chainId)}</span>`)}
|
|
963
|
+
${o}
|
|
964
|
+
</div>
|
|
965
|
+
</div>
|
|
966
|
+
<pre class="__crossx-raw-tx">${M(i)}</pre>
|
|
967
|
+
</div>
|
|
968
|
+
<div class="__crossx-btn-row">
|
|
969
|
+
<button class="__crossx-cancel-btn" id="__crossx-cancel-btn">Cancel</button>
|
|
970
|
+
<button class="__crossx-confirm-btn" id="__crossx-confirm-btn">Sign</button>
|
|
971
|
+
</div>
|
|
972
|
+
</div>
|
|
973
|
+
</div>
|
|
974
|
+
`,a}function Bn(r,e){const s=e,t=r.nativeSymbol??"ETH",n=r.nativeDecimals??18,o=Ze(),i=r.to?`<span class="__crossx-addr-text">${J(r.to)}</span>
|
|
975
|
+
<button class="__crossx-copy-btn" data-copy="${M(r.to)}" title="Copy address">${fe}</button>`:"<span>—</span>",a=Rs(r),l=Nn(r.value,t,n)??"—",d=document.createElement("div");return d.id=te,d.innerHTML=`
|
|
976
|
+
<div class="__crossx-card __crossx-card--migration __crossx-card--send-tx" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
977
|
+
<div class="__crossx-header">
|
|
978
|
+
<p class="__crossx-title" id="__crossx-ttl">Approve transaction</p>
|
|
979
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
980
|
+
</div>
|
|
981
|
+
<hr class="__crossx-divider">
|
|
982
|
+
<div class="__crossx-body">
|
|
983
|
+
<p class="__crossx-tx-subtitle">
|
|
984
|
+
<span class="__crossx-sig-origin">${M(o)}</span> wants your permission to approve the following transaction.
|
|
985
|
+
</p>
|
|
986
|
+
<div class="__crossx-body-cols">
|
|
987
|
+
<div class="__crossx-rows">
|
|
988
|
+
${W("To",i)}
|
|
989
|
+
${W("Network",`<span>${As(r.chainId)}</span>`)}
|
|
990
|
+
${a}
|
|
991
|
+
</div>
|
|
992
|
+
<div class="__crossx-pill">
|
|
993
|
+
<span class="__crossx-pill-from">${J(r.from)}</span>
|
|
994
|
+
<span class="__crossx-pill-amount">${l}</span>
|
|
995
|
+
</div>
|
|
996
|
+
</div>
|
|
997
|
+
<button class="__crossx-approve-btn" id="__crossx-confirm-btn">Approve</button>
|
|
998
|
+
</div>
|
|
999
|
+
</div>
|
|
1000
|
+
`,d}function Ze(){var r;try{return((r=window.location)==null?void 0:r.hostname)||"This site"}catch{return"This site"}}function M(r){return r.replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""").replace(/'/g,"'")}function Fn(r){return typeof r=="string"&&/^0x[0-9a-fA-F]{40}$/i.test(r)}function Un(r){if(typeof r=="string")return M(r);if(typeof r=="number"||typeof r=="bigint"||typeof r=="boolean")return String(r);try{return M(JSON.stringify(r))}catch{return String(r)}}function Hn(r,e){const s=W("From",`<span class="__crossx-addr-text">${J(r.from)}</span>
|
|
1001
|
+
<button class="__crossx-copy-btn" data-copy="${M(r.from)}" title="Copy address">${fe}</button>`),t=r.to?W("To",`<span class="__crossx-addr-text">${J(r.to)}</span>
|
|
1002
|
+
<button class="__crossx-copy-btn" data-copy="${M(r.to)}" title="Copy address">${fe}</button>`):"",n=r.amount?W("Transfer",`<span>${M(r.amount)}</span>`):"",o=r.fees?W("Tx Fee",`<span>${M(r.fees)}</span>`):"",i=r.txHash?W("Tx Hash",`<span class="__crossx-addr-text">${J(r.txHash)}</span>
|
|
1003
|
+
<button class="__crossx-copy-btn" data-copy="${M(r.txHash)}" title="Copy hash">${fe}</button>`):"",a=r.total?`<div class="__crossx-total-pill">
|
|
1004
|
+
<span class="__crossx-total-label">Total<br>(including fees)</span>
|
|
1005
|
+
<span class="__crossx-total-amount">${M(r.total)}</span>
|
|
1006
|
+
</div>`:"",c=document.createElement("div");return c.id=te,c.innerHTML=`
|
|
1007
|
+
<div class="__crossx-card __crossx-card--migration" style="${ce(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
1008
|
+
<div class="__crossx-header">
|
|
1009
|
+
<p class="__crossx-title" id="__crossx-ttl">Transaction complete</p>
|
|
1010
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
1011
|
+
</div>
|
|
1012
|
+
<hr class="__crossx-divider">
|
|
1013
|
+
<div class="__crossx-body">
|
|
1014
|
+
<div class="__crossx-rows">
|
|
1015
|
+
${s}
|
|
1016
|
+
${t}
|
|
1017
|
+
${n}
|
|
1018
|
+
${o}
|
|
1019
|
+
${i}
|
|
1020
|
+
</div>
|
|
1021
|
+
${a}
|
|
1022
|
+
<button class="__crossx-approve-btn" id="__crossx-done-btn">All Done</button>
|
|
1023
|
+
</div>
|
|
1024
|
+
</div>
|
|
1025
|
+
`,c}function Gn(r,e){const s=document.createElement("div");return s.id=te,s.innerHTML=`
|
|
1026
|
+
<div class="__crossx-card __crossx-card--migration" style="${ce(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
1027
|
+
<div class="__crossx-header">
|
|
1028
|
+
<p class="__crossx-title" id="__crossx-ttl">Waiting for confirmation</p>
|
|
1029
|
+
</div>
|
|
1030
|
+
<hr class="__crossx-divider">
|
|
1031
|
+
<div class="__crossx-body" id="__crossx-progress-body">
|
|
1032
|
+
<div class="__crossx-progress-center">
|
|
1033
|
+
<div class="__crossx-spinner"></div>
|
|
1034
|
+
<p class="__crossx-progress-text">Waiting for transaction receipt...</p>
|
|
1035
|
+
</div>
|
|
1036
|
+
</div>
|
|
1037
|
+
</div>
|
|
1038
|
+
`,s}function Wn(r,e,s){const t=e.status!=="reverted"&&e.status!=="timeout",n=e.status==="timeout",o=r.querySelector("#__crossx-ttl"),i=r.querySelector(".__crossx-header");if(o){const m=n?Mn:t?"":Dn,A=n?"Transaction timeout":t?"Transaction complete":"Transaction failed";m?(o.style.display="flex",o.style.alignItems="center",o.style.gap="8px",o.innerHTML=`${m}<span>${A}</span>`):o.textContent=A}if(i&&!r.querySelector("#__crossx-close-btn")){const m=document.createElement("button");m.className="__crossx-close",m.id="__crossx-close-btn",m.setAttribute("aria-label","Close"),m.innerHTML=ae,i.appendChild(m)}const a=r.querySelector("#__crossx-progress-body");if(!a)return;const c=e.from?W("From",`<span class="__crossx-addr-text">${J(e.from)}</span>
|
|
1039
|
+
<button class="__crossx-copy-btn" data-copy="${M(e.from)}" title="Copy address">${fe}</button>`):"",l=e.to?W("To",`<span class="__crossx-addr-text">${J(e.to)}</span>
|
|
1040
|
+
<button class="__crossx-copy-btn" data-copy="${M(e.to)}" title="Copy address">${fe}</button>`):"",d=e.amount?W("Transfer",`<span>${M(e.amount)}</span>`):"",f=e.fees?W("Tx Fee",`<span>${M(e.fees)}</span>`):"",w=e.txHash?W("Tx Hash",`<span class="__crossx-addr-text">${J(e.txHash)}</span>
|
|
1041
|
+
<button class="__crossx-copy-btn" data-copy="${M(e.txHash)}" title="Copy hash">${fe}</button>`):"",x=e.total?`<div class="__crossx-total-pill">
|
|
1042
|
+
<span class="__crossx-total-label">Total<br>(including fees)</span>
|
|
1043
|
+
<span class="__crossx-total-amount">${M(e.total)}</span>
|
|
1044
|
+
</div>`:"";a.innerHTML=`
|
|
1045
|
+
<div class="__crossx-rows">
|
|
1046
|
+
${c}
|
|
1047
|
+
${l}
|
|
1048
|
+
${d}
|
|
1049
|
+
${f}
|
|
1050
|
+
${w}
|
|
1051
|
+
</div>
|
|
1052
|
+
${x}
|
|
1053
|
+
<button class="__crossx-approve-btn" id="__crossx-done-btn">${t?"All Done":"Done"}</button>
|
|
1054
|
+
`,a.querySelectorAll(".__crossx-copy-btn").forEach(m=>{m.addEventListener("click",A=>{var I;A.stopPropagation();const y=m.dataset.copy;y&&((I=navigator.clipboard)==null||I.writeText(y).catch(()=>{}))})})}function qn(r,e){const s=e,t=Ze(),n=M(r.message),o=document.createElement("div");return o.id=te,o.innerHTML=`
|
|
1055
|
+
<div class="__crossx-card __crossx-card--migration __crossx-card--sign-msg" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
1056
|
+
<div class="__crossx-header">
|
|
1057
|
+
<p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
|
|
1058
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
1059
|
+
</div>
|
|
1060
|
+
<hr class="__crossx-divider">
|
|
1061
|
+
<div class="__crossx-body">
|
|
1062
|
+
<div class="__crossx-body-cols">
|
|
1063
|
+
<div class="__crossx-col-left">
|
|
1064
|
+
<p class="__crossx-sig-subtitle">
|
|
1065
|
+
<span class="__crossx-sig-origin">${M(t)} </span>is requesting a Signature
|
|
1066
|
+
</p>
|
|
1067
|
+
<div class="__crossx-addr-pill">
|
|
1068
|
+
${wt}
|
|
1069
|
+
<span class="__crossx-addr-pill-text">${J(r.from)}</span>
|
|
1070
|
+
</div>
|
|
1071
|
+
<p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
|
|
1072
|
+
</div>
|
|
1073
|
+
<hr class="__crossx-divider __crossx-divider--cols">
|
|
1074
|
+
<div class="__crossx-msg-raw">${n}</div>
|
|
1075
|
+
</div>
|
|
1076
|
+
<div class="__crossx-btn-row">
|
|
1077
|
+
<button class="__crossx-cancel-btn" id="__crossx-cancel-btn">Cancel</button>
|
|
1078
|
+
<button class="__crossx-confirm-btn" id="__crossx-confirm-btn">Confirm</button>
|
|
1079
|
+
</div>
|
|
1080
|
+
</div>
|
|
1081
|
+
</div>
|
|
1082
|
+
`,o}function Kn(r,e){const s=e,t=Ze();let n={};if(typeof r.typedData=="string")try{n=JSON.parse(r.typedData)}catch{}else r.typedData&&typeof r.typedData=="object"&&(n=r.typedData);const o=n.primaryType??"—",i=n.message??{};let a=`
|
|
1083
|
+
<div class="__crossx-td-row">
|
|
1084
|
+
<span class="__crossx-td-label">Primary Type</span>
|
|
1085
|
+
<span class="__crossx-td-value">${M(o)}</span>
|
|
1086
|
+
</div>`;for(const[l,d]of Object.entries(i)){const f=Un(d),x=Fn(d)?`<span class="__crossx-addr-text">${J(d)}</span>
|
|
1087
|
+
<button class="__crossx-copy-btn" data-copy="${M(String(d))}" title="Copy">${fe}</button>`:`<span>${f}</span>`;a+=`
|
|
1088
|
+
<div class="__crossx-td-row">
|
|
1089
|
+
<span class="__crossx-td-label">${M(l)}</span>
|
|
1090
|
+
<div class="__crossx-td-value">${x}</div>
|
|
1091
|
+
</div>`}const c=document.createElement("div");return c.id=te,c.innerHTML=`
|
|
1092
|
+
<div class="__crossx-card __crossx-card--migration __crossx-card--sign-typed" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
1093
|
+
<div class="__crossx-header">
|
|
1094
|
+
<p class="__crossx-title" id="__crossx-ttl">Signature Request</p>
|
|
1095
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
1096
|
+
</div>
|
|
1097
|
+
<hr class="__crossx-divider">
|
|
1098
|
+
<div class="__crossx-body">
|
|
1099
|
+
<div class="__crossx-body-cols">
|
|
1100
|
+
<div class="__crossx-col-left">
|
|
1101
|
+
<p class="__crossx-sig-subtitle">
|
|
1102
|
+
<span class="__crossx-sig-origin">${M(t)} </span>is requesting a Signature
|
|
1103
|
+
</p>
|
|
1104
|
+
<div class="__crossx-addr-pill">
|
|
1105
|
+
${wt}
|
|
1106
|
+
<span class="__crossx-addr-pill-text">${J(r.from)}</span>
|
|
1107
|
+
</div>
|
|
1108
|
+
<p class="__crossx-warning">After you sign, changes or cancellations are not possible.</p>
|
|
1109
|
+
</div>
|
|
1110
|
+
<hr class="__crossx-divider __crossx-divider--cols">
|
|
1111
|
+
<div class="__crossx-td-rows">${a}</div>
|
|
1112
|
+
</div>
|
|
1113
|
+
<div class="__crossx-btn-row">
|
|
1114
|
+
<button class="__crossx-cancel-btn" id="__crossx-cancel-btn">Cancel</button>
|
|
1115
|
+
<button class="__crossx-confirm-btn" id="__crossx-confirm-btn">Confirm</button>
|
|
1116
|
+
</div>
|
|
1117
|
+
</div>
|
|
1118
|
+
</div>
|
|
1119
|
+
`,c}const Vn=`<svg width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round">
|
|
1120
|
+
<line x1="12" y1="5" x2="12" y2="19"/>
|
|
1121
|
+
<line x1="5" y1="12" x2="19" y2="12"/>
|
|
1122
|
+
</svg>`;function jn(r,e,s){const t=s==null?void 0:s.toLowerCase(),n=r.map(i=>{const a=t&&i.address.toLowerCase()===t;return`<button class="__crossx-wallet-item" data-wallet-index="${i.index}" data-wallet-address="${M(i.address)}">
|
|
1123
|
+
<span class="__crossx-wallet-addr">${J(i.address)}</span>${a?'<span class="__crossx-wallet-selected">selected</span>':""}
|
|
1124
|
+
</button>`}).join(""),o=document.createElement("div");return o.id=te,o.innerHTML=`
|
|
1125
|
+
<div class="__crossx-card __crossx-card--migration __crossx-card--wallet-selector" style="${ce(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
1126
|
+
<div class="__crossx-header">
|
|
1127
|
+
<div style="display:flex;flex-direction:column;gap:4px;padding-right:36px;">
|
|
1128
|
+
<p class="__crossx-title" id="__crossx-ttl" style="padding-right:0;">Select Connected Wallet</p>
|
|
1129
|
+
<p class="__crossx-subtitle--body">Please select the wallet you previously used for this game to continue.</p>
|
|
1130
|
+
</div>
|
|
1131
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
1132
|
+
</div>
|
|
1133
|
+
<hr class="__crossx-divider">
|
|
1134
|
+
<div class="__crossx-body">
|
|
1135
|
+
<div class="__crossx-body-cols">
|
|
1136
|
+
<div class="__crossx-col-left">
|
|
1137
|
+
<div class="__crossx-mig-info">
|
|
1138
|
+
<p class="__crossx-mig-info-title">Why do I need to select a wallet?</p>
|
|
1139
|
+
<p class="__crossx-mig-info-desc">Identifying your previously linked wallet ensures your game progress and assets are synced correctly.</p>
|
|
1140
|
+
</div>
|
|
1141
|
+
</div>
|
|
1142
|
+
<hr class="__crossx-divider __crossx-divider--cols">
|
|
1143
|
+
<div class="__crossx-col-right-ws">
|
|
1144
|
+
<div class="__crossx-wallet-list" id="__crossx-wallet-list">
|
|
1145
|
+
${n}
|
|
1146
|
+
</div>
|
|
1147
|
+
<button class="__crossx-wallet-add" id="__crossx-add-wallet-btn" type="button">
|
|
1148
|
+
<span class="__crossx-wallet-add-icon">${Vn}</span>
|
|
1149
|
+
<span class="__crossx-wallet-add-label">add a wallet</span>
|
|
1150
|
+
</button>
|
|
1151
|
+
</div>
|
|
1152
|
+
</div>
|
|
1153
|
+
</div>
|
|
1154
|
+
</div>
|
|
1155
|
+
`,o}const Jn=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
1156
|
+
<path d="M26.693 21.193c-.028-3.168 2.587-4.712 2.706-4.786-1.477-2.16-3.77-2.454-4.58-2.484-1.944-.197-3.804 1.148-4.793 1.148-.992 0-2.52-1.12-4.147-1.09-2.13.032-4.1 1.239-5.198 3.133-2.222 3.855-.569 9.562 1.593 12.69 1.061 1.535 2.318 3.258 3.975 3.196 1.6-.064 2.2-1.03 4.133-1.03 1.928 0 2.48 1.03 4.172.997 1.72-.03 2.806-1.56 3.862-3.1 1.211-1.779 1.713-3.495 1.74-3.583-.037-.017-3.427-1.316-3.463-5.09z" fill="currentColor"/>
|
|
1157
|
+
<path d="M23.527 11.876c.877-1.065 1.471-2.545 1.31-4.024-1.266.053-2.807.845-3.718 1.907-.813.946-1.53 2.468-1.34 3.915 1.41.107 2.852-.716 3.748-1.798z" fill="currentColor"/>
|
|
1158
|
+
</svg>`,zn=`<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
1159
|
+
<path d="M38.06 20.44c0-1.34-.12-2.63-.34-3.87H20.5v7.32h9.84c-.42 2.28-1.71 4.21-3.65 5.51v4.57h5.91c3.46-3.19 5.46-7.88 5.46-13.53z" fill="#4285F4"/>
|
|
1160
|
+
<path d="M20.5 38.5c4.94 0 9.09-1.64 12.12-4.44l-5.91-4.57c-1.64 1.1-3.73 1.75-6.21 1.75-4.77 0-8.82-3.22-10.26-7.55H4.16v4.72A18.49 18.49 0 0 0 20.5 38.5z" fill="#34A853"/>
|
|
1161
|
+
<path d="M10.24 23.69A11.16 11.16 0 0 1 9.66 20c0-1.28.22-2.52.58-3.69v-4.72H4.16A18.49 18.49 0 0 0 2 20c0 2.97.71 5.78 1.97 8.28l6.27-4.59z" fill="#FBBC05"/>
|
|
1162
|
+
<path d="M20.5 8.76c2.69 0 5.1.92 7 2.73l5.24-5.24C29.58 3.36 25.43 1.5 20.5 1.5A18.49 18.49 0 0 0 4.16 11.59l6.08 4.72C11.68 11.98 15.73 8.76 20.5 8.76z" fill="#EA4335"/>
|
|
1163
|
+
</svg>`;function Yn(r){const e=r,s=document.createElement("div");return s.id=te,s.innerHTML=`
|
|
1164
|
+
<div class="__crossx-card __crossx-card--migration" style="${ce(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
1165
|
+
<div class="__crossx-header">
|
|
1166
|
+
<div style="display:flex;flex-direction:column;gap:4px;padding-right:36px;">
|
|
1167
|
+
<p class="__crossx-title" id="__crossx-ttl" style="padding-right:0;">Welcome onboard</p>
|
|
1168
|
+
<p class="__crossx-subtitle">Creating CROSSx Embedded Wallet</p>
|
|
1169
|
+
</div>
|
|
1170
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
1171
|
+
</div>
|
|
1172
|
+
<hr class="__crossx-divider">
|
|
1173
|
+
<div class="__crossx-body">
|
|
1174
|
+
<div class="__crossx-login-btn-row">
|
|
1175
|
+
<button class="__crossx-login-btn" id="__crossx-apple-btn" type="button">
|
|
1176
|
+
<span class="__crossx-login-icon" style="color:var(--cx-value);">${Jn}</span>
|
|
1177
|
+
<span class="__crossx-login-btn-label">Sign in with Apple</span>
|
|
1178
|
+
</button>
|
|
1179
|
+
<button class="__crossx-login-btn" id="__crossx-google-btn" type="button">
|
|
1180
|
+
<span class="__crossx-login-icon">${zn}</span>
|
|
1181
|
+
<span class="__crossx-login-btn-label">Sign in with Google</span>
|
|
1182
|
+
</button>
|
|
1183
|
+
</div>
|
|
1184
|
+
<hr class="__crossx-divider">
|
|
1185
|
+
<p class="__crossx-login-terms">
|
|
1186
|
+
By continuing, you agree to NEXUS <a class="__crossx-login-terms-link" href="https://terms.crosstoken.io/docs/cross-terms-of-use" target="_blank" rel="noopener noreferrer">Terms of Service</a> and consent to its <a class="__crossx-login-terms-link" href="https://terms.crosstoken.io/docs/nexus-privacy-policy" target="_blank" rel="noopener noreferrer">Privacy Policy.</a>
|
|
1187
|
+
</p>
|
|
1188
|
+
</div>
|
|
1189
|
+
</div>
|
|
1190
|
+
`,s}function Zn(r){const e=r,s=document.createElement("div");return s.id=te,s.innerHTML=`
|
|
1191
|
+
<div class="__crossx-card __crossx-card--migration" style="${ce(e)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
1192
|
+
<div class="__crossx-header">
|
|
1193
|
+
<p class="__crossx-title" id="__crossx-ttl">Wallet Found on Social Account 🎉</p>
|
|
1194
|
+
<p class="__crossx-subtitle--body">We found a wallet linked to your social account. Enter your 4-digit PIN to restore your assets.</p>
|
|
1195
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
1196
|
+
</div>
|
|
1197
|
+
<hr class="__crossx-divider">
|
|
1198
|
+
<div class="__crossx-body">
|
|
1199
|
+
<div class="__crossx-mig-info">
|
|
1200
|
+
<p class="__crossx-mig-info-title">What is a Recovery Wallet?</p>
|
|
1201
|
+
<p class="__crossx-mig-info-desc">It safely restores and integrates all your previous assets. Simply verify your PIN to get started.</p>
|
|
1202
|
+
</div>
|
|
1203
|
+
<button class="__crossx-recover-btn" id="__crossx-recover-btn">
|
|
1204
|
+
<span>${Ln(e.primary)}</span>
|
|
1205
|
+
<span class="__crossx-recover-label">Recover My Wallet</span>
|
|
1206
|
+
</button>
|
|
1207
|
+
<button class="__crossx-skip-btn" id="__crossx-skip-btn">Skip for Now</button>
|
|
1208
|
+
</div>
|
|
1209
|
+
</div>
|
|
1210
|
+
`,s}function Xn(r,e){const s=r,t=e?`<p class="__crossx-pin-error-text">${e}</p>`:"",n=document.createElement("div");return n.id=te,n.innerHTML=`
|
|
1211
|
+
<div class="__crossx-card __crossx-card--migration" style="${ce(s)}" role="dialog" aria-modal="true" aria-labelledby="__crossx-ttl">
|
|
1212
|
+
<div class="__crossx-header">
|
|
1213
|
+
<p class="__crossx-title" id="__crossx-ttl">Recover My Wallet</p>
|
|
1214
|
+
<button class="__crossx-close" id="__crossx-close-btn" aria-label="Close">${ae}</button>
|
|
1215
|
+
</div>
|
|
1216
|
+
<hr class="__crossx-divider">
|
|
1217
|
+
<div class="__crossx-pin-center">
|
|
1218
|
+
<div class="__crossx-pin-inputs">
|
|
1219
|
+
<input class="__crossx-pin-input" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
|
|
1220
|
+
<input class="__crossx-pin-input" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
|
|
1221
|
+
<input class="__crossx-pin-input" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
|
|
1222
|
+
<input class="__crossx-pin-input" type="tel" maxlength="1" inputmode="numeric" pattern="[0-9]" autocomplete="off">
|
|
1223
|
+
</div>
|
|
1224
|
+
<p class="__crossx-pin-hint">Enter your 4-digit PIN to recover your wallet.</p>
|
|
1225
|
+
${t}
|
|
1226
|
+
</div>
|
|
1227
|
+
</div>
|
|
1228
|
+
`,n}function Qn(r,e,s){var n;const t=r.querySelectorAll(".__crossx-pin-input");t.forEach((o,i)=>{o.addEventListener("input",()=>{const a=o.value.replace(/\D/g,"");o.value=a?a[0]:"",a&&i<3&&t[i+1].focus();const c=Array.from(t).map(l=>l.value).join("");c.length===4&&setTimeout(()=>e(c),200)}),o.addEventListener("keydown",a=>{a.key==="Backspace"&&!o.value&&i>0&&(t[i-1].focus(),t[i-1].value=""),a.key==="Escape"&&s()}),o.addEventListener("keypress",a=>{/[0-9]/.test(a.key)||a.preventDefault()}),o.addEventListener("paste",a=>{var d;a.preventDefault();const c=(((d=a.clipboardData)==null?void 0:d.getData("text"))??"").replace(/\D/g,"").slice(0,4);if(!c)return;c.split("").forEach((f,w)=>{t[w]&&(t[w].value=f)});const l=Math.min(c.length,3);t[l].focus(),c.length===4&&setTimeout(()=>e(c),200)})}),(n=t[0])==null||n.focus()}class eo{constructor(e="light",s){this.theme=e,this.overrides=s,this.tokens=Is(e,s)}setTheme(e,s){this.theme=e,s!==void 0&&(this.overrides=s),this.tokens=Is(e,this.overrides)}setMessages(e){this.messages=e}getTheme(){return this.theme}showWalletSelector(e,s,t){return new Promise(n=>{var A;Se();const o=[...e],i=jn(o,this.tokens,t),a=document.body.style.overflow;document.body.style.overflow="hidden",document.body.appendChild(i);let c=!1;const l=()=>{c||(c=!0,i.remove(),document.body.style.overflow=a)},d=y=>{l(),n(y)},f=()=>{l(),n(null)};(()=>{i.querySelectorAll(".__crossx-wallet-item").forEach(y=>{y.addEventListener("click",()=>{const I=y.dataset.walletAddress??"",L=parseInt(y.dataset.walletIndex??"0",10);d({address:I,index:L})})})})();const x=i.querySelector("#__crossx-add-wallet-btn");x&&x.addEventListener("click",async()=>{x.disabled=!0;try{const y=await s();o.push(y);const I=i.querySelector("#__crossx-wallet-list");if(I){const L=document.createElement("button");L.className="__crossx-wallet-item",L.dataset.walletIndex=String(y.index),L.dataset.walletAddress=y.address,L.innerHTML=`<span class="__crossx-wallet-addr">${J(y.address)}</span>`,L.addEventListener("click",()=>d(y)),I.appendChild(L),L.scrollIntoView({behavior:"smooth",block:"nearest"})}}catch{}finally{x.disabled=!1}}),(A=i.querySelector("#__crossx-close-btn"))==null||A.addEventListener("click",f),i.addEventListener("click",y=>{y.target===i&&f()});const m=y=>{y.key==="Escape"&&(document.removeEventListener("keydown",m),f())};document.addEventListener("keydown",m)})}showLoginSelector(){return new Promise(e=>{var a,c,l;Se();const s=Yn(this.tokens);document.body.appendChild(s);const t=()=>s.remove(),n=d=>{t(),e(d)},o=()=>{t(),e(null)};(a=s.querySelector("#__crossx-apple-btn"))==null||a.addEventListener("click",()=>n("apple")),(c=s.querySelector("#__crossx-google-btn"))==null||c.addEventListener("click",()=>n("google")),(l=s.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",o),s.addEventListener("click",d=>{d.target===s&&o()}),s.querySelectorAll(".__crossx-login-terms-link").forEach(d=>{d.addEventListener("click",f=>f.stopPropagation())});const i=d=>{d.key==="Escape"&&(document.removeEventListener("keydown",i),o())};document.addEventListener("keydown",i)})}showMigrationFoundPrompt(){return new Promise(e=>{var a,c,l;Se();const s=Zn(this.tokens);document.body.appendChild(s);const t=()=>s.remove(),n=()=>{t(),e("recover")},o=()=>{t(),e("skip")};(a=s.querySelector("#__crossx-recover-btn"))==null||a.addEventListener("click",n),(c=s.querySelector("#__crossx-skip-btn"))==null||c.addEventListener("click",o),(l=s.querySelector("#__crossx-close-btn"))==null||l.addEventListener("click",o),s.addEventListener("click",d=>{d.target===s&&o()});const i=d=>{d.key==="Escape"&&(document.removeEventListener("keydown",i),o())};document.addEventListener("keydown",i)})}showPinInputPrompt(e){return new Promise(s=>{var a;Se();const t=Xn(this.tokens,e);document.body.appendChild(t);const n=()=>t.remove(),o=c=>{n(),s(c)},i=()=>{n(),s(null)};Qn(t,o,i),(a=t.querySelector("#__crossx-close-btn"))==null||a.addEventListener("click",i),t.addEventListener("click",c=>{c.target===t&&i()})})}showTransactionComplete(e){return new Promise(s=>{var a,c;Se();const t=Hn(e,this.tokens);document.body.appendChild(t);const n=()=>t.remove(),o=()=>{n(),s()};(a=t.querySelector("#__crossx-done-btn"))==null||a.addEventListener("click",o),(c=t.querySelector("#__crossx-close-btn"))==null||c.addEventListener("click",o),t.querySelectorAll(".__crossx-copy-btn").forEach(l=>{l.addEventListener("click",d=>{var w;d.stopPropagation();const f=l.dataset.copy;f&&((w=navigator.clipboard)==null||w.writeText(f).catch(()=>{}))})}),t.addEventListener("click",l=>{l.target===t&&o()});const i=l=>{l.key==="Escape"&&(document.removeEventListener("keydown",i),o())};document.addEventListener("keydown",i)})}showTransactionProgress(e,s){return new Promise(t=>{Se();const n=Gn(e,this.tokens);document.body.appendChild(n);const o=()=>n.remove();let i=!1;const a=()=>{i||(i=!0,o(),t())},c=()=>{var d,f;(d=n.querySelector("#__crossx-done-btn"))==null||d.addEventListener("click",a),(f=n.querySelector("#__crossx-close-btn"))==null||f.addEventListener("click",a),n.addEventListener("click",w=>{w.target===n&&a()});const l=w=>{w.key==="Escape"&&(document.removeEventListener("keydown",l),a())};document.addEventListener("keydown",l)};s.then(l=>{i||(Wn(n,l,this.tokens),c())})})}requestConfirmation(e){return new Promise(s=>{var c,l,d;Se();let t;e.type==="sign-message"?t=qn(e,this.tokens):e.type==="sign-typed-data"?t=Kn(e,this.tokens):e.type==="sign"?t=$n(e,this.tokens):t=Bn(e,this.tokens),document.body.appendChild(t);const n=()=>t.remove(),o=()=>{n(),s(!0)},i=()=>{n(),s(!1)};(c=t.querySelector("#__crossx-confirm-btn"))==null||c.addEventListener("click",o),(l=t.querySelector("#__crossx-cancel-btn"))==null||l.addEventListener("click",i),(d=t.querySelector("#__crossx-close-btn"))==null||d.addEventListener("click",i),t.querySelectorAll(".__crossx-copy-btn").forEach(f=>{f.addEventListener("click",w=>{var m;w.stopPropagation();const x=f.dataset.copy;x&&((m=navigator.clipboard)==null||m.writeText(x).catch(()=>{}))})}),t.addEventListener("click",f=>{f.target===t&&i()});const a=f=>{f.key==="Escape"&&(document.removeEventListener("keydown",a),i())};document.addEventListener("keydown",a)})}}class to{constructor(){this._accessToken=null}set(e){this._accessToken=e}get(){return this._accessToken}clear(){this._accessToken=null}has(){return this._accessToken!==null}}function so(r){r.debug;const e=Be.production,s={...r,oauthServiceUrl:e.oauthServiceUrl,authApiUrl:e.authApiUrl,walletGatewayUrl:e.walletGatewayUrl},t={gatewayUrl:e.walletGatewayUrl,projectId:r.projectId},o=s.authMode!=="cookie"&&Ct.isAvailable()?new Ct:new Xs,i=new En,a=new An,c=new _t,l=new to;let d;r.useMockWallet?(p.log("[CROSSx] Mock Wallet Provider 사용"),d=new Rn(o)):(p.log("[CROSSx] Remote Wallet Provider 사용"),d=new Ye(t,o,a,l));const f=new Le(t,a),w=new eo(r.theme??"light",r.themeTokens);return new Fe(s,t,o,i,a,c,d,l,w,f)}return Z.CROSSxError=_,Z.CROSSxEthereumProvider=yt,Z.CROSSxSDK=Fe,Z.ChainId=Ns,Z.ErrorCode=g,Z.createCROSSxSDK=so,Object.defineProperty(Z,Symbol.toStringTag,{value:"Module"}),Z}({});
|