@luno-kit/core 0.0.5 → 0.0.6

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/README.md ADDED
@@ -0,0 +1,8 @@
1
+ # @luno-kit/core
2
+
3
+ Core wallet connectors and utilities for LunoKit, enabling seamless integration with Polkadot ecosystem wallets.
4
+
5
+ ## Documentation
6
+
7
+ For comprehensive documentation, visit [docs.lunolab.xyz](https://docs.lunolab.xyz/)
8
+
@@ -7,7 +7,7 @@ interface Chain {
7
7
  decimals: number;
8
8
  };
9
9
  rpcUrls: {
10
- webSocket?: readonly string[];
10
+ webSocket: readonly string[];
11
11
  http?: readonly string[];
12
12
  };
13
13
  ss58Format: number;
@@ -21,8 +21,7 @@ interface Chain {
21
21
  url: string;
22
22
  } | undefined;
23
23
  };
24
- testnet?: boolean;
25
- meta?: Record<string, any>;
24
+ testnet: boolean;
26
25
  chainIconUrl: string;
27
26
  }
28
27
 
@@ -7,7 +7,7 @@ interface Chain {
7
7
  decimals: number;
8
8
  };
9
9
  rpcUrls: {
10
- webSocket?: readonly string[];
10
+ webSocket: readonly string[];
11
11
  http?: readonly string[];
12
12
  };
13
13
  ss58Format: number;
@@ -21,8 +21,7 @@ interface Chain {
21
21
  url: string;
22
22
  } | undefined;
23
23
  };
24
- testnet?: boolean;
25
- meta?: Record<string, any>;
24
+ testnet: boolean;
26
25
  chainIconUrl: string;
27
26
  }
28
27
 
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkB75MLGK5_cjs=require('../chunk-B75MLGK5.cjs');require('../chunk-MYEWIINX.cjs');Object.defineProperty(exports,"kusama",{enumerable:true,get:function(){return chunkB75MLGK5_cjs.b}});Object.defineProperty(exports,"paseo",{enumerable:true,get:function(){return chunkB75MLGK5_cjs.c}});Object.defineProperty(exports,"polkadot",{enumerable:true,get:function(){return chunkB75MLGK5_cjs.a}});Object.defineProperty(exports,"westend",{enumerable:true,get:function(){return chunkB75MLGK5_cjs.d}});//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var chunkMFLU4CFP_cjs=require('../chunk-MFLU4CFP.cjs');require('../chunk-MYEWIINX.cjs');Object.defineProperty(exports,"kusama",{enumerable:true,get:function(){return chunkMFLU4CFP_cjs.b}});Object.defineProperty(exports,"paseo",{enumerable:true,get:function(){return chunkMFLU4CFP_cjs.c}});Object.defineProperty(exports,"polkadot",{enumerable:true,get:function(){return chunkMFLU4CFP_cjs.a}});Object.defineProperty(exports,"westend",{enumerable:true,get:function(){return chunkMFLU4CFP_cjs.d}});//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1,4 +1,4 @@
1
- import { C as Chain } from '../chain-CCVvkcX7.cjs';
1
+ import { C as Chain } from '../chain-9vBVQoCB.cjs';
2
2
 
3
3
  declare const polkadot: Chain;
4
4
 
@@ -1,4 +1,4 @@
1
- import { C as Chain } from '../chain-CCVvkcX7.js';
1
+ import { C as Chain } from '../chain-9vBVQoCB.js';
2
2
 
3
3
  declare const polkadot: Chain;
4
4
 
@@ -1,2 +1,2 @@
1
- export{b as kusama,c as paseo,a as polkadot,d as westend}from'../chunk-TK2GOG2I.js';import'../chunk-LXQJABLC.js';//# sourceMappingURL=index.js.map
1
+ export{b as kusama,c as paseo,a as polkadot,d as westend}from'../chunk-GFMVMUPH.js';import'../chunk-LXQJABLC.js';//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -0,0 +1,3 @@
1
+ import {d,a,c,j}from'./chunk-LXQJABLC.js';var r={genesisHash:"0x91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3",name:"Polkadot",nativeCurrency:{name:"Polkadot",symbol:"DOT",decimals:10},rpcUrls:{webSocket:["wss://rpc.polkadot.io","wss://polkadot.api.onfinality.io/public-ws"],http:["https://rpc.polkadot.io"]},ss58Format:0,blockExplorers:{default:{name:"Subscan",url:"https://polkadot.subscan.io"}},chainIconUrl:d,testnet:false};var p={genesisHash:"0xb0a8d493285c2df73290dfb7e61f870f17b41801197a149ca93654499ea3dafe",name:"Kusama",nativeCurrency:{name:"Kusama",symbol:"KSM",decimals:12},rpcUrls:{webSocket:["wss://kusama-rpc.polkadot.io","wss://kusama.api.onfinality.io/public-ws"]},ss58Format:2,blockExplorers:{default:{name:"Subscan",url:"https://kusama.subscan.io"}},chainIconUrl:a,testnet:false};var l={genesisHash:"0x77afd6190f1554ad45fd0d31aee62aacc33c6db0ea801129acb813f913e0764f",name:"Paseo",nativeCurrency:{name:"Paseo",symbol:"PAS",decimals:10},rpcUrls:{webSocket:["wss://rpc.ibp.network/paseo","wss://paseo.rpc.amforc.com"]},ss58Format:0,blockExplorers:{default:{name:"Subscan",url:"https://paseo.subscan.io/"}},chainIconUrl:c,testnet:true};var b={genesisHash:"0xe143f23803ac50e8f6f8e62695d1ce9e4e1d68aa36c1cd2cfd15340213f3423e",name:"Westend",nativeCurrency:{name:"Westend",symbol:"WND",decimals:12},rpcUrls:{webSocket:["wss://westend-rpc.polkadot.io"]},ss58Format:42,blockExplorers:{default:{name:"Subscan",url:"https://westend.subscan.io"}},chainIconUrl:j,testnet:true};
2
+ export{r as a,p as b,l as c,b as d};//# sourceMappingURL=chunk-GFMVMUPH.js.map
3
+ //# sourceMappingURL=chunk-GFMVMUPH.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/chains/polkadot.ts","../src/chains/kusama.ts","../src/chains/paseo.ts","../src/chains/westend.ts"],"names":["polkadot","polkadotSVG","kusama","kusamaSVG","paseo","paseoSVG","westend","westendSVG"],"mappings":"0CAGO,IAAMA,EAAkB,CAC7B,WAAA,CAAa,oEAAA,CACb,IAAA,CAAM,WACN,cAAA,CAAgB,CAAE,IAAA,CAAM,UAAA,CAAY,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAChE,OAAA,CAAS,CACP,SAAA,CAAW,CAAC,uBAAA,CAAyB,4CAA4C,EACjF,IAAA,CAAM,CAAC,yBAAyB,CAClC,EACA,UAAA,CAAY,CAAA,CACZ,cAAA,CAAgB,CAAE,QAAS,CAAE,IAAA,CAAM,UAAW,GAAA,CAAK,6BAA8B,CAAE,CAAA,CACnF,YAAA,CAAcC,CAAAA,CACd,OAAA,CAAS,KACX,ECZO,IAAMC,CAAAA,CAAgB,CAC3B,YAAa,oEAAA,CACb,IAAA,CAAM,QAAA,CACN,cAAA,CAAgB,CAAE,IAAA,CAAM,QAAA,CAAU,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAC9D,OAAA,CAAS,CAAE,SAAA,CAAW,CAAC,8BAAA,CAAgC,0CAA0C,CAAE,CAAA,CACnG,WAAY,CAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,SAAA,CAAW,IAAK,2BAA4B,CAAE,EACjF,YAAA,CAAcC,CAAAA,CACd,OAAA,CAAS,KACX,ECTO,IAAMC,CAAAA,CAAe,CAC1B,WAAA,CAAa,qEACb,IAAA,CAAM,OAAA,CACN,cAAA,CAAgB,CAAE,KAAM,OAAA,CAAS,MAAA,CAAQ,MAAO,QAAA,CAAU,EAAG,EAC7D,OAAA,CAAS,CAAE,SAAA,CAAW,CAAC,8BAA+B,4BAA4B,CAAE,CAAA,CACpF,UAAA,CAAY,EACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,KAAM,SAAA,CAAW,GAAA,CAAK,2BAA4B,CAAE,CAAA,CACjF,aAAcC,CAAAA,CACd,OAAA,CAAS,IACX,MCTaC,CAAAA,CAAiB,CAC5B,WAAA,CAAa,oEAAA,CACb,KAAM,SAAA,CACN,cAAA,CAAgB,CAAE,IAAA,CAAM,UAAW,MAAA,CAAQ,KAAA,CAAO,SAAU,EAAG,CAAA,CAC/D,QAAS,CAAE,SAAA,CAAW,CAAC,+BAA+B,CAAE,CAAA,CACxD,UAAA,CAAY,EAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,SAAA,CAAW,IAAK,4BAA6B,CAAE,EAClF,YAAA,CAAcC,CAAAA,CACd,QAAS,IACX","file":"chunk-GFMVMUPH.js","sourcesContent":["import type { Chain } from '../types'\nimport { polkadotSVG } from '../config/logos/generated'\n\nexport const polkadot: Chain = {\n genesisHash: '0x91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3',\n name: 'Polkadot',\n nativeCurrency: { name: 'Polkadot', symbol: 'DOT', decimals: 10 },\n rpcUrls: {\n webSocket: ['wss://rpc.polkadot.io', 'wss://polkadot.api.onfinality.io/public-ws'],\n http: ['https://rpc.polkadot.io'],\n },\n ss58Format: 0,\n blockExplorers: { default: { name: 'Subscan', url: 'https://polkadot.subscan.io' } },\n chainIconUrl: polkadotSVG,\n testnet: false,\n};\n","import type { Chain } from '../types'\nimport { kusamaSVG } from '../config/logos/generated'\n\nexport const kusama: Chain = {\n genesisHash: '0xb0a8d493285c2df73290dfb7e61f870f17b41801197a149ca93654499ea3dafe',\n name: 'Kusama',\n nativeCurrency: { name: 'Kusama', symbol: 'KSM', decimals: 12 },\n rpcUrls: { webSocket: ['wss://kusama-rpc.polkadot.io', 'wss://kusama.api.onfinality.io/public-ws'] },\n ss58Format: 2,\n blockExplorers: { default: { name: 'Subscan', url: 'https://kusama.subscan.io' } },\n chainIconUrl: kusamaSVG,\n testnet: false,\n};\n","import type { Chain } from '../types'\nimport { paseoSVG } from '../config/logos/generated'\n\nexport const paseo: Chain = {\n genesisHash: '0x77afd6190f1554ad45fd0d31aee62aacc33c6db0ea801129acb813f913e0764f',\n name: 'Paseo',\n nativeCurrency: { name: 'Paseo', symbol: 'PAS', decimals: 10 },\n rpcUrls: { webSocket: ['wss://rpc.ibp.network/paseo', 'wss://paseo.rpc.amforc.com'] },\n ss58Format: 0,\n blockExplorers: { default: { name: 'Subscan', url: 'https://paseo.subscan.io/' } },\n chainIconUrl: paseoSVG,\n testnet: true\n};\n","import type { Chain } from '../types'\nimport { westendSVG } from '../config/logos/generated'\n\nexport const westend: Chain = {\n genesisHash: '0xe143f23803ac50e8f6f8e62695d1ce9e4e1d68aa36c1cd2cfd15340213f3423e',\n name: 'Westend',\n nativeCurrency: { name: 'Westend', symbol: 'WND', decimals: 12 },\n rpcUrls: { webSocket: ['wss://westend-rpc.polkadot.io'] },\n ss58Format: 42,\n blockExplorers: { default: { name: 'Subscan', url: 'https://westend.subscan.io' } },\n chainIconUrl: westendSVG,\n testnet: true,\n};\n"]}
@@ -1,3 +1,3 @@
1
- 'use strict';var chunkMYEWIINX_cjs=require('./chunk-MYEWIINX.cjs'),chunkWQPMFK4M_cjs=require('./chunk-WQPMFK4M.cjs'),eventemitter3=require('eventemitter3'),utils=require('dedot/utils');var a=class extends eventemitter3.EventEmitter{constructor(){super();this.links={};this.accounts=[];this.signer=void 0;this.connectionUri=void 0;}async getAccounts(){return [...this.accounts]}async getSigner(){return this.signer||console.warn(`Connector ${this.id}: Signer not available. Connection might be incomplete or failed.`),this.signer}hasConnectionUri(){return false}async getConnectionUri(){return this.connectionUri}async updateAccountsForChain(t){return [...this.accounts]}};var i=class extends a{constructor(t){super();this.unsubscribe=null;this.specificInjector=void 0;this.id=t.id,this.name=t.name,this.icon=t.icon,this.links=t.links,this.injectorId=t.injectorId||t.id;}isInstalled(){if(typeof window>"u")return false;let t=window.injectedWeb3;return typeof t=="object"&&typeof t[this.injectorId]<"u"}async isAvailable(){return this.isInstalled()}async connect(t){if(console.log(`Connector ${this.id}: Attempting to connect...`),this.signer)return console.log(`Connector ${this.id}: Already connected.`),[...this.accounts];if(!await this.isAvailable())throw new Error(`${this.name} extension not found or not enabled.`);try{if(this.specificInjector=await window.injectedWeb3[this.injectorId].enable(t),!this.specificInjector)throw new Error(`Failed to enable the '${this.id}' extension.`);if(this.signer=this.specificInjector.signer,!this.signer)throw new Error(`Could not get signer from ${this.name}.`);let n=await this.specificInjector.accounts.get();if(n.length===0)throw new Error(`No accounts found in ${this.name}. Make sure accounts are visible and access is granted.`);return this.accounts=chunkWQPMFK4M_cjs.h(n,this.id),console.log(`Connector ${this.id}: Initial accounts loaded`,this.accounts),await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}catch(n){throw console.error(`Connector ${this.id}: Connection failed:`,n),await this.cleanup(),n}}async disconnect(){console.log(`Connector ${this.id}: Disconnecting...`),await this.cleanup(),this.emit("disconnect");}async signMessage(t,n){if(!n||!t)return;let s=await this.getSigner();if(!s||!s?.signRaw)throw new Error("Signer is not available or does not support signRaw.");if(!(await this.getAccounts()).some(e=>e.address.toLowerCase()===n.toLowerCase()))throw new Error(`Address ${n} is not managed by ${this.name}.`);try{let e=utils.stringToHex(t);return (await s.signRaw({address:n,data:e,type:"bytes"})).signature}catch(e){throw new Error(`Connector ${this.id}: Failed to sign message: ${e.message}`)}}async startSubscription(){if(await this.cleanupSubscription(),!this.specificInjector)throw new Error(`Connector ${this.id}: Cannot subscribe, specificInjector not available.`);try{this.unsubscribe=this.specificInjector.accounts.subscribe(t=>{let n=chunkWQPMFK4M_cjs.h(t,this.id);JSON.stringify(this.accounts)!==JSON.stringify(n)&&(this.accounts=n,this.emit("accountsChanged",[...this.accounts]));}),console.log(`Connector ${this.id}: Subscribed to account changes.`);}catch(t){console.error(`Connector ${this.id}: Failed to subscribe to accounts:`,t),this.unsubscribe=null;}}async cleanupSubscription(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=null,console.log(`Connector ${this.id}: Unsubscribed from account changes.`));}async cleanup(){await this.cleanupSubscription(),this.accounts=[],this.signer=void 0,this.specificInjector=void 0;}};var P=()=>new i({id:"polkadot-js",name:"Polkadot{.js}",icon:chunkMYEWIINX_cjs.e,links:{browserExtension:"https://polkadot.js.org/extension"}});var x=()=>new i({id:"polkagate",name:"Polkagate",icon:chunkMYEWIINX_cjs.f,links:{browserExtension:"https://chromewebstore.google.com/detail/polkagate-the-gateway-to/ginchbkmljhldofnbjabmeophlhdldgp"}});var $=()=>new i({id:"subwallet-js",name:"SubWallet",icon:chunkMYEWIINX_cjs.g,links:{browserExtension:"https://chromewebstore.google.com/detail/subwallet-polkadot-wallet/onhogfjeacnfoofkfgppdlbmlmnplgbn",deepLink:"https://mobile.subwallet.app/browser"}});var E=()=>new i({id:"talisman",name:"Talisman",icon:chunkMYEWIINX_cjs.h,links:{browserExtension:"https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld"}});var u=class extends a{constructor(t){super();this.unsubscribe=null;this.id=t.id||"walletconnect",this.name=t.name||"WalletConnect",this.links=t.links||{},this.icon=t.icon||chunkMYEWIINX_cjs.i,this.projectId=t.projectId,this.relayUrl=t.relayUrl||"wss://relay.walletconnect.com",this.metadata=t.metadata;}isInstalled(){return false}async isAvailable(){return true}convertChainIdToCaipId(t){return t.map(n=>`polkadot:${n.genesisHash.replace("0x","").slice(0,32)}`)}async connect(t,n,s){if(!this.projectId)throw new Error(`${this.name} requires a projectId. Please visit https://cloud.walletconnect.com to get one.`);if(!n||n.length===0)throw new Error(`${this.name} requires chains configuration.`);this.connectedChains=n;let{UniversalProvider:c}=await import('@walletconnect/universal-provider');try{this.provider=await c.init({projectId:this.projectId,relayUrl:this.relayUrl,metadata:this.metadata||{name:t,description:"LunoKit DApp",url:typeof window<"u"?window.location.origin:"",icons:[this.icon]}});let e=s||n[0].genesisHash;if(this.provider.session){this.session=this.provider.session;let j=this.getAccountsFromSession(n,e);return this.accounts=j,await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}if(!this.provider?.client)throw new Error("Provider not initialized or not connected");let{uri:p,approval:o}=await this.provider.client.connect({requiredNamespaces:{polkadot:{methods:["polkadot_signMessage","polkadot_sendTransaction","polkadot_signTransaction","polkadot_requestAccounts"],chains:this.convertChainIdToCaipId(n),events:["accountsChanged","chainChanged","connect"]}},optionalNamespaces:{polkadot:{methods:["polkadot_signMessage","polkadot_sendTransaction","polkadot_signTransaction","polkadot_requestAccounts"],chains:this.convertChainIdToCaipId(n),events:["accountsChanged","chainChanged","connect"]}}});this.emit("get_uri",p);let l=await o();this.session=l,this.provider.session=l,this.connectionUri=void 0;let I=this.getAccountsFromSession(n,e);return this.accounts=I,await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}catch(e){throw this.connectionUri=void 0,e}}getAccountsFromSession(t,n){let s=t.filter(o=>o.genesisHash.toLowerCase()===n.toLowerCase()),c=this.convertChainIdToCaipId(s)[0],e=this.session?.namespaces.polkadot.accounts.flat().filter(o=>o.includes(c)).map(o=>o.replace(`${c}:`,""));if(e&&e.length===0){console.error("No accounts found for the specified chain, please connect to the correct chain");let o=this.convertChainIdToCaipId(t)[0];e=this.session?.namespaces.polkadot.accounts.flat().filter(l=>l.includes(o)).map(l=>l.replace(`${o}:`,""));}let p=e.map(o=>({address:o,name:`${this.name} Account`,meta:{source:this.id},publicKey:void 0}));return this.emit("accountsChanged",[...p]),p}async disconnect(){this.provider&&(console.log("this.provider",this.provider),console.log("this.sessionsession",this.session),await this.provider.disconnect()),await this.cleanup(),this.emit("disconnect");}async signMessage(t,n,s){if(!this.provider?.client||!this.session?.topic)throw new Error("Provider not initialized or not connected");let c=s?`polkadot:${s.replace("0x","").slice(0,32)}`:this.convertChainIdToCaipId(this.connectedChains)[0];try{return (await this.provider.client.request({topic:this.session.topic,chainId:c,request:{method:"polkadot_signMessage",params:{address:n,message:t,type:"bytes"}}}))?.signature}catch(e){throw console.error("Sign message error:",e),e}}hasConnectionUri(){return true}async getConnectionUri(){return this.connectionUri?this.connectionUri:new Promise(t=>{this.once("get_uri",n=>{this.connectionUri=n,t(n);});})}async updateAccountsForChain(t){if(!this.connectedChains)throw new Error("WalletConnect not connected");let n=this.getAccountsFromSession(this.connectedChains,t);return this.accounts=n,n}async getSigner(){if(!(!this.provider?.client||!this.session))return {signPayload:async t=>{try{return await this.provider?.client?.request({topic:this.session.topic,chainId:`polkadot:${t.genesisHash.replace("0x","").slice(0,32)}`,request:{method:"polkadot_signTransaction",params:{address:t.address,transactionPayload:t}}})}catch(n){throw new Error(`Transaction signing failed: ${JSON.stringify(n)}`)}}}}async startSubscription(){if(await this.cleanupSubscription(),!this.provider?.client||!this.session)throw new Error(`Connector ${this.id}: Cannot subscribe, provider or session not available.`);try{let t=async()=>{console.log(`Connector ${this.id}: Session deleted, disconnecting...`),await this.cleanup(),this.emit("disconnect");};this.provider.client.on("session_delete",t),this.unsubscribe=()=>{this.provider?.client?.off("session_delete",t);};}catch{this.unsubscribe=null;}}async cleanupSubscription(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=null,console.log(`Connector ${this.id}: Unsubscribed from events.`));}async cleanup(){await this.cleanupSubscription(),this.accounts=[],this.signer=void 0,this.provider=void 0,this.session=void 0;}},U=r=>new u(r);var b=class extends i{constructor(){super({id:"nova-mobile",name:"Nova Wallet",icon:chunkMYEWIINX_cjs.b,injectorId:"polkadot-js",links:{deepLink:"https://app.novawallet.io/open/dapp"}});}isInstalled(){if(typeof window>"u")return false;let d=window.injectedWeb3;return typeof d=="object"&&typeof d["polkadot-js"]<"u"&&window.walletExtension?.isNovaWallet===true}async isAvailable(){return this.isInstalled()}},f=()=>new b;var W=r=>{if(r.mobileOnly&&!chunkWQPMFK4M_cjs.l())throw new Error("Nova Wallet mobile connector cannot be used on desktop devices");if(r.mobileOnly)throw new Error("Nova Wallet is not installed. Please install Nova Wallet to continue.");return chunkWQPMFK4M_cjs.l()?f():new u({id:"nova",name:"Nova Wallet",icon:chunkMYEWIINX_cjs.b,links:{browserExtension:"https://novawallet.io"},...r})};
2
- exports.a=a;exports.b=P;exports.c=x;exports.d=$;exports.e=E;exports.f=U;exports.g=f;exports.h=W;//# sourceMappingURL=chunk-HQJ3DJ5D.cjs.map
3
- //# sourceMappingURL=chunk-HQJ3DJ5D.cjs.map
1
+ 'use strict';var chunkMYEWIINX_cjs=require('./chunk-MYEWIINX.cjs'),chunkWQPMFK4M_cjs=require('./chunk-WQPMFK4M.cjs'),eventemitter3=require('eventemitter3'),utils=require('dedot/utils');var a=class extends eventemitter3.EventEmitter{constructor(){super();this.links={};this.accounts=[];this.signer=void 0;this.connectionUri=void 0;}async getAccounts(){return [...this.accounts]}async getSigner(){return this.signer||console.warn(`Connector ${this.id}: Signer not available. Connection might be incomplete or failed.`),this.signer}hasConnectionUri(){return false}async getConnectionUri(){return this.connectionUri}async updateAccountsForChain(t){return [...this.accounts]}};var o=class extends a{constructor(t){super();this.unsubscribe=null;this.specificInjector=void 0;this.id=t.id,this.name=t.name,this.icon=t.icon,this.links=t.links,this.injectorId=t.injectorId||t.id;}isInstalled(){if(typeof window>"u")return false;let t=window.injectedWeb3;return typeof t=="object"&&typeof t[this.injectorId]<"u"}async isAvailable(){return this.isInstalled()}async connect(t){if(console.log(`Connector ${this.id}: Attempting to connect...`),this.signer)return console.log(`Connector ${this.id}: Already connected.`),[...this.accounts];if(!await this.isAvailable())throw new Error(`${this.name} extension not found or not enabled.`);try{if(this.specificInjector=await window.injectedWeb3[this.injectorId].enable(t),!this.specificInjector)throw new Error(`Failed to enable the '${this.id}' extension.`);if(this.signer=this.specificInjector.signer,!this.signer)throw new Error(`Could not get signer from ${this.name}.`);let n=await this.specificInjector.accounts.get();if(n.length===0)throw new Error(`No accounts found in ${this.name}. Make sure accounts are visible and access is granted.`);return this.accounts=chunkWQPMFK4M_cjs.h(n,this.id),console.log(`Connector ${this.id}: Initial accounts loaded`,this.accounts),await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}catch(n){throw console.error(`Connector ${this.id}: Connection failed:`,n),await this.cleanup(),n}}async disconnect(){console.log(`Connector ${this.id}: Disconnecting...`),await this.cleanup(),this.emit("disconnect");}async signMessage(t,n){if(!n||!t)return;let s=await this.getSigner();if(!s||!s?.signRaw)throw new Error("Signer is not available or does not support signRaw.");if(!(await this.getAccounts()).some(e=>e.address.toLowerCase()===n.toLowerCase()))throw new Error(`Address ${n} is not managed by ${this.name}.`);try{let e=utils.stringToHex(t);return (await s.signRaw({address:n,data:e,type:"bytes"})).signature}catch(e){throw new Error(`Connector ${this.id}: Failed to sign message: ${e.message}`)}}async startSubscription(){if(await this.cleanupSubscription(),!this.specificInjector)throw new Error(`Connector ${this.id}: Cannot subscribe, specificInjector not available.`);try{this.unsubscribe=this.specificInjector.accounts.subscribe(t=>{let n=chunkWQPMFK4M_cjs.h(t,this.id);JSON.stringify(this.accounts)!==JSON.stringify(n)&&(this.accounts=n,this.emit("accountsChanged",[...this.accounts]));}),console.log(`Connector ${this.id}: Subscribed to account changes.`);}catch(t){console.error(`Connector ${this.id}: Failed to subscribe to accounts:`,t),this.unsubscribe=null;}}async cleanupSubscription(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=null,console.log(`Connector ${this.id}: Unsubscribed from account changes.`));}async cleanup(){await this.cleanupSubscription(),this.accounts=[],this.signer=void 0,this.specificInjector=void 0;}};var P=()=>new o({id:"polkadot-js",name:"Polkadot{.js}",icon:chunkMYEWIINX_cjs.e,links:{browserExtension:"https://polkadot.js.org/extension"}});var x=()=>new o({id:"polkagate",name:"Polkagate",icon:chunkMYEWIINX_cjs.f,links:{browserExtension:"https://chromewebstore.google.com/detail/polkagate-the-gateway-to/ginchbkmljhldofnbjabmeophlhdldgp"}});var $=()=>new o({id:"subwallet-js",name:"SubWallet",icon:chunkMYEWIINX_cjs.g,links:{browserExtension:"https://chromewebstore.google.com/detail/subwallet-polkadot-wallet/onhogfjeacnfoofkfgppdlbmlmnplgbn",deepLink:"https://mobile.subwallet.app/browser"}});var E=()=>new o({id:"talisman",name:"Talisman",icon:chunkMYEWIINX_cjs.h,links:{browserExtension:"https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld"}});var u=class extends a{constructor(t){super();this.unsubscribe=null;this.id=t.id||"walletconnect",this.name=t.name||"WalletConnect",this.links=t.links||{},this.icon=t.icon||chunkMYEWIINX_cjs.i,this.projectId=t.projectId,this.relayUrl=t.relayUrl||"wss://relay.walletconnect.com",this.metadata=t.metadata;}isInstalled(){return false}async isAvailable(){return true}convertChainIdToCaipId(t){return t.map(n=>`polkadot:${n.genesisHash.replace("0x","").slice(0,32)}`)}async connect(t,n,s){if(!this.projectId)throw new Error(`${this.name} requires a projectId. Please visit https://cloud.walletconnect.com to get one.`);if(!n||n.length===0)throw new Error(`${this.name} requires chains configuration.`);this.connectedChains=n;let{UniversalProvider:c}=await import('@walletconnect/universal-provider');try{this.provider=await c.init({projectId:this.projectId,relayUrl:this.relayUrl,metadata:this.metadata||{name:t,description:"LunoKit DApp",url:typeof window<"u"?window.location.origin:"",icons:[this.icon]}});let e=s||n[0].genesisHash;if(this.provider.session){this.session=this.provider.session;let j=this.getAccountsFromSession(n,e);return this.accounts=j,await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}if(!this.provider?.client)throw new Error("Provider not initialized or not connected");let{uri:p,approval:i}=await this.provider.client.connect({requiredNamespaces:{polkadot:{methods:["polkadot_signMessage","polkadot_sendTransaction","polkadot_signTransaction","polkadot_requestAccounts"],chains:this.convertChainIdToCaipId(n),events:["accountsChanged","chainChanged","connect"]}},optionalNamespaces:{polkadot:{methods:["polkadot_signMessage","polkadot_sendTransaction","polkadot_signTransaction","polkadot_requestAccounts"],chains:this.convertChainIdToCaipId(n),events:["accountsChanged","chainChanged","connect"]}}});this.emit("get_uri",p);let l=await i();this.session=l,this.provider.session=l,this.connectionUri=void 0;let I=this.getAccountsFromSession(n,e);return this.accounts=I,await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}catch(e){throw this.connectionUri=void 0,e}}getAccountsFromSession(t,n){let s=t.filter(i=>i.genesisHash.toLowerCase()===n.toLowerCase()),c=this.convertChainIdToCaipId(s)[0],e=this.session?.namespaces.polkadot.accounts.flat().filter(i=>i.includes(c)).map(i=>i.replace(`${c}:`,""));if(e&&e.length===0){console.error("No accounts found for the specified chain, please connect to the correct chain");let i=this.convertChainIdToCaipId(t)[0];e=this.session?.namespaces.polkadot.accounts.flat().filter(l=>l.includes(i)).map(l=>l.replace(`${i}:`,""));}let p=e.map(i=>({address:i,name:`${this.name} Account`,meta:{source:this.id},publicKey:void 0}));return this.emit("accountsChanged",[...p]),p}async disconnect(){this.provider&&(console.log("this.provider",this.provider),console.log("this.sessionsession",this.session),await this.provider.disconnect()),await this.cleanup(),this.emit("disconnect");}async signMessage(t,n,s){if(!this.provider?.client||!this.session?.topic)throw new Error("Provider not initialized or not connected");let c=s?`polkadot:${s.replace("0x","").slice(0,32)}`:this.convertChainIdToCaipId(this.connectedChains)[0];try{return (await this.provider.client.request({topic:this.session.topic,chainId:c,request:{method:"polkadot_signMessage",params:{address:n,message:t,type:"bytes"}}}))?.signature}catch(e){throw console.error("Sign message error:",e),e}}hasConnectionUri(){return true}async getConnectionUri(){return this.connectionUri?this.connectionUri:new Promise(t=>{this.once("get_uri",n=>{this.connectionUri=n,t(n);});})}async updateAccountsForChain(t){if(!this.connectedChains)throw new Error("WalletConnect not connected");let n=this.getAccountsFromSession(this.connectedChains,t);return this.accounts=n,n}async getSigner(){if(!(!this.provider?.client||!this.session))return {signPayload:async t=>{try{return await this.provider?.client?.request({topic:this.session.topic,chainId:`polkadot:${t.genesisHash.replace("0x","").slice(0,32)}`,request:{method:"polkadot_signTransaction",params:{address:t.address,transactionPayload:t}}})}catch(n){throw new Error(`Transaction signing failed: ${JSON.stringify(n)}`)}}}}async startSubscription(){if(await this.cleanupSubscription(),!this.provider?.client||!this.session)throw new Error(`Connector ${this.id}: Cannot subscribe, provider or session not available.`);try{let t=async()=>{console.log(`Connector ${this.id}: Session deleted, disconnecting...`),await this.cleanup(),this.emit("disconnect");};this.provider.client.on("session_delete",t),this.unsubscribe=()=>{this.provider?.client?.off("session_delete",t);};}catch{this.unsubscribe=null;}}async cleanupSubscription(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=null,console.log(`Connector ${this.id}: Unsubscribed from events.`));}async cleanup(){await this.cleanupSubscription(),this.accounts=[],this.signer=void 0,this.provider=void 0,this.session=void 0;}},U=r=>new u(r);var b=class extends o{constructor(){super({id:"nova-mobile",name:"Nova Wallet",icon:chunkMYEWIINX_cjs.b,injectorId:"polkadot-js",links:{deepLink:"https://app.novawallet.io/open/dapp"}});}isInstalled(){if(typeof window>"u")return false;let d=window.injectedWeb3;return typeof d=="object"&&typeof d["polkadot-js"]<"u"&&window.walletExtension?.isNovaWallet===true}async isAvailable(){return this.isInstalled()}},f=()=>new b;var W=r=>{if(r.mobileOnly&&!chunkWQPMFK4M_cjs.l())throw new Error("Nova Wallet mobile connector cannot be used on desktop devices");if(r.mobileOnly)throw new Error("Nova Wallet is not installed. Please install Nova Wallet to continue.");return chunkWQPMFK4M_cjs.l()?f():new u({id:"nova",name:"Nova Wallet",icon:chunkMYEWIINX_cjs.b,links:{browserExtension:"https://novawallet.io"},...r})};
2
+ exports.a=a;exports.b=o;exports.c=P;exports.d=x;exports.e=$;exports.f=E;exports.g=U;exports.h=f;exports.i=W;//# sourceMappingURL=chunk-JOIV5HSZ.cjs.map
3
+ //# sourceMappingURL=chunk-JOIV5HSZ.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/connectors/base.ts","../src/connectors/common.ts","../src/connectors/polkadot-js.ts","../src/connectors/polkagate.ts","../src/connectors/subwallet.ts","../src/connectors/talisman.ts","../src/connectors/walletconnect.ts","../src/connectors/novaMobile.ts","../src/connectors/nova.ts"],"names":["BaseConnector","EventEmitter","chainId","CommonConnector","options","injectedWeb3","appName","rawAccounts","mapInjectedAccounts","error","message","address","signer","acc","dataHex","stringToHex","updatedRawAccounts","newAccounts","polkadotjsConnector","polkadotjsSVG","polkagateConnector","polkagateSVG","subwalletConnector","subwalletSVG","talismanConnector","talismanSVG","WalletConnectConnector","walletconnectSVG","chains","chain","targetChainId","UniversalProvider","chainIdToUse","accounts","uri","approval","session","targetChain","caipId","result","resolve","payload","sessionDeleteHandler","walletConnectConnector","NovaMobileConnector","novaSVG","novaMobileConnector","novaConnector","config","isMobileDevice"],"mappings":"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","file":"chunk-JOIV5HSZ.cjs","sourcesContent":["import type {Account, Chain, Signer} from '../types';\nimport { EventEmitter } from 'eventemitter3';\nimport { ConnectorLinks } from '../types'\n\n/**\n * base connector abstract class\n * defines the basic properties and methods that all wallet connectors should have.\n */\nexport abstract class BaseConnector extends EventEmitter {\n /**\n * the unique identifier of the connector (e.g., 'polkadot-js', 'subwallet-js')\n * subclasses must implement.\n */\n abstract readonly id: string;\n\n /**\n * user-friendly connector name (e.g., 'Polkadot{.js}', 'SubWallet')\n * subclasses must implement.\n */\n abstract readonly name: string;\n\n /**\n * connector icon URL (optional)\n * subclasses can implement.\n */\n abstract readonly icon?: string;\n\n readonly links: ConnectorLinks = {};\n /**\n * store the current connected accounts.\n * subclasses are responsible for maintaining this list when connecting and updating accounts.\n */\n protected accounts: Account[] = [];\n /**\n * store the signer.\n * subclasses are responsible for getting and storing it when connecting.\n */\n protected signer: Signer | undefined = undefined;\n\n protected connectionUri: string | undefined = undefined;\n\n constructor() {\n super();\n }\n\n public abstract isAvailable(): Promise<boolean>;\n\n public abstract isInstalled(): boolean;\n\n /**\n * connect to the wallet, get the initial accounts and signer, and set the necessary event listeners.\n * subclasses must implement:\n * 1. get the signer and assign it to this.signer.\n * 2. get the initial accounts list and assign it to this.accounts.\n * 3. set the account update mechanism of itself (e.g., use web3AccountsSubscribe or WalletConnect events).\n * 4. update this.accounts when the account list changes and trigger the 'accountsChanged' event.\n * 5. (optional) trigger the 'connect' event.\n * @returns the initial available accounts list\n */\n abstract connect(appName: string, chains?: Chain[], targetChainId?: string): Promise<Array<Account>>;\n /**\n * disconnect from the wallet.\n * subclasses must implement this method to perform specific cleanup logic\n * (e.g., unsubscribe, close session).\n * implementers should clear this.accounts and this.signer after cleanup and trigger the 'disconnect' event.\n */\n abstract disconnect(): Promise<void>;\n\n /**\n * get the current connected accounts list.\n * @returns the current available accounts list\n */\n public async getAccounts(): Promise<Array<Account>> {\n return [...this.accounts];\n }\n\n /**\n * get the cached signer object.\n * @returns the signer object, or undefined if the connection is not successful or cannot be obtained.\n */\n public async getSigner(): Promise<Signer | undefined> {\n if (!this.signer) {\n console.warn(`Connector ${this.id}: Signer not available. Connection might be incomplete or failed.`);\n }\n return this.signer;\n }\n\n /**\n * sign a message with the specified account.\n */\n abstract signMessage(message: string, address: string, chainId?: string): Promise<string | undefined>;\n\n public hasConnectionUri(): boolean {\n return false\n }\n\n public async getConnectionUri(): Promise<string | undefined >{\n return this.connectionUri;\n }\n\n public async updateAccountsForChain(chainId: string): Promise<Account[]> {\n return [...this.accounts];\n }\n}\n","import { BaseConnector } from './base';\nimport type { Account, Signer } from '../types';\nimport { mapInjectedAccounts } from '../utils'\nimport { Injected, InjectedAccount } from 'dedot/types'\nimport { stringToHex } from 'dedot/utils'\nimport { ConnectorLinks } from '../types'\n\nexport interface CommonConnectorOptions {\n id: string;\n name: string;\n icon: string;\n links: ConnectorLinks;\n injectorId?: string;\n}\n\nexport class CommonConnector extends BaseConnector {\n readonly id: string;\n readonly name: string;\n readonly icon: string;\n readonly links: ConnectorLinks;\n protected readonly injectorId: string;\n\n private unsubscribe: (() => void) | null = null;\n\n private specificInjector?: Injected = undefined\n\n constructor(options: CommonConnectorOptions) {\n super();\n this.id = options.id;\n this.name = options.name;\n this.icon = options.icon;\n this.links = options.links;\n this.injectorId = options.injectorId || options.id;\n }\n\n public isInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n const injectedWeb3 = window.injectedWeb3;\n return typeof injectedWeb3 === 'object' && typeof injectedWeb3[this.injectorId] !== 'undefined';\n }\n\n public async isAvailable(): Promise<boolean> {\n return this.isInstalled();\n }\n\n public async connect(appName: string): Promise<Array<Account>> {\n console.log(`Connector ${this.id}: Attempting to connect...`);\n if (this.signer) {\n console.log(`Connector ${this.id}: Already connected.`);\n return [...this.accounts];\n }\n if (!(await this.isAvailable())) {\n throw new Error(`${this.name} extension not found or not enabled.`);\n }\n\n try {\n this.specificInjector = await window.injectedWeb3![this.injectorId]!.enable(appName);\n\n if (!this.specificInjector) {\n throw new Error(`Failed to enable the '${this.id}' extension.`);\n }\n\n this.signer = this.specificInjector.signer as Signer;\n\n if (!this.signer) {\n throw new Error(`Could not get signer from ${this.name}.`);\n }\n\n const rawAccounts = await this.specificInjector.accounts.get();\n if (rawAccounts.length === 0) {\n throw new Error(`No accounts found in ${this.name}. Make sure accounts are visible and access is granted.`);\n }\n this.accounts = mapInjectedAccounts(rawAccounts, this.id);\n console.log(`Connector ${this.id}: Initial accounts loaded`, this.accounts);\n\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n\n return [...this.accounts];\n\n } catch (error) {\n console.error(`Connector ${this.id}: Connection failed:`, error);\n await this.cleanup();\n throw error;\n }\n }\n\n public async disconnect(): Promise<void> {\n console.log(`Connector ${this.id}: Disconnecting...`);\n await this.cleanup();\n this.emit('disconnect');\n }\n\n public async signMessage(message: string, address: string): Promise<string | undefined> {\n if (!address || !message) return undefined;\n const signer = await this.getSigner();\n if (!signer || !signer?.signRaw) {\n throw new Error('Signer is not available or does not support signRaw.');\n }\n const accounts = await this.getAccounts();\n if (!accounts.some(acc => acc.address.toLowerCase() === address.toLowerCase())) {\n throw new Error(`Address ${address} is not managed by ${this.name}.`);\n }\n\n try {\n const dataHex = stringToHex(message);\n const result = await signer.signRaw({ address, data: dataHex, type: 'bytes' });\n return result.signature;\n } catch (error: any) {\n throw new Error(`Connector ${this.id}: Failed to sign message: ${error.message}`);\n }\n }\n\n\n private async startSubscription(): Promise<void> {\n await this.cleanupSubscription();\n if (!this.specificInjector) {\n throw new Error(`Connector ${this.id}: Cannot subscribe, specificInjector not available.`);\n }\n\n try {\n this.unsubscribe = this.specificInjector.accounts.subscribe(\n (updatedRawAccounts: InjectedAccount[]) => {\n const newAccounts = mapInjectedAccounts(updatedRawAccounts, this.id);\n if (JSON.stringify(this.accounts) !== JSON.stringify(newAccounts)) {\n this.accounts = newAccounts;\n this.emit('accountsChanged', [...this.accounts]);\n }\n }\n );\n console.log(`Connector ${this.id}: Subscribed to account changes.`);\n } catch (error) {\n console.error(`Connector ${this.id}: Failed to subscribe to accounts:`, error);\n this.unsubscribe = null;\n }\n }\n\n private async cleanupSubscription(): Promise<void> {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n console.log(`Connector ${this.id}: Unsubscribed from account changes.`);\n }\n }\n\n\n private async cleanup(): Promise<void> {\n await this.cleanupSubscription();\n this.accounts = [];\n this.signer = undefined;\n this.specificInjector = undefined\n }\n}\n","import { CommonConnector } from './common'\nimport { polkadotjsSVG } from '../config/logos/generated'\n\nexport const polkadotjsConnector = () => {\n return new CommonConnector({\n id: 'polkadot-js',\n name: 'Polkadot{.js}',\n icon: polkadotjsSVG,\n links: {\n browserExtension: 'https://polkadot.js.org/extension'\n }\n });\n}\n","import { polkagateSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const polkagateConnector = () => {\n return new CommonConnector({\n id: 'polkagate',\n name: 'Polkagate',\n icon: polkagateSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/polkagate-the-gateway-to/ginchbkmljhldofnbjabmeophlhdldgp'\n }\n });\n}\n","import { subwalletSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const subwalletConnector = () => {\n return new CommonConnector({\n id: 'subwallet-js',\n name: 'SubWallet',\n icon: subwalletSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/subwallet-polkadot-wallet/onhogfjeacnfoofkfgppdlbmlmnplgbn',\n deepLink: 'https://mobile.subwallet.app/browser',\n }\n })\n};\n","import { talismanSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const talismanConnector = () => {\n return new CommonConnector({\n id: 'talisman',\n name: 'Talisman',\n icon: talismanSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld'\n }\n });\n}\n","import { BaseConnector } from './base';\nimport type { IUniversalProvider, Metadata } from '@walletconnect/universal-provider';\nimport { SessionTypes, SignClientTypes } from '@walletconnect/types'\nimport type { Account, Chain, Signer, WalletConnectConnectorOptions } from '../types';\nimport { walletconnectSVG } from '../config/logos/generated';\nimport { SignerResult, SignerPayloadJSON } from 'dedot/types'\nimport { ConnectorLinks } from '../types'\n\nexport class WalletConnectConnector extends BaseConnector {\n readonly id: string;\n readonly name: string;\n readonly icon: string;\n readonly links: ConnectorLinks;\n\n private provider?: IUniversalProvider;\n private projectId: string;\n private relayUrl: string;\n private metadata?: Metadata;\n\n private session?: SessionTypes.Struct;\n private connectedChains?: Chain[];\n\n private unsubscribe: (() => void) | null = null;\n\n constructor(options: WalletConnectConnectorOptions) {\n super();\n this.id = options.id || 'walletconnect';\n this.name = options.name || 'WalletConnect';\n this.links = options.links || {};\n\n this.icon = options.icon || walletconnectSVG;\n\n this.projectId = options.projectId;\n this.relayUrl = options.relayUrl || 'wss://relay.walletconnect.com';\n this.metadata = options.metadata;\n }\n\n public isInstalled(): boolean {\n return false;\n }\n\n public async isAvailable(): Promise<boolean> {\n return true;\n }\n\n private convertChainIdToCaipId(chains: Chain[]): string[] {\n return chains.map(chain => `polkadot:${chain.genesisHash.replace('0x', '').slice(0, 32)}`);\n }\n\n public async connect(appName: string, chains?: Chain[], targetChainId?: string): Promise<Array<Account>> {\n if (!this.projectId) {\n throw new Error(`${this.name} requires a projectId. Please visit https://cloud.walletconnect.com to get one.`);\n }\n\n if (!chains || chains.length === 0) {\n throw new Error(`${this.name} requires chains configuration.`);\n }\n\n this.connectedChains = chains;\n\n const { UniversalProvider } = await import(\"@walletconnect/universal-provider\");\n\n try {\n this.provider = await UniversalProvider.init({\n projectId: this.projectId,\n relayUrl: this.relayUrl,\n metadata: this.metadata || {\n name: appName,\n description: 'LunoKit DApp',\n url: typeof window !== 'undefined' ? window.location.origin : '',\n icons: [this.icon],\n },\n });\n\n const chainIdToUse = targetChainId || chains[0].genesisHash;\n\n if (this.provider.session) {\n this.session = this.provider.session;\n const accounts = this.getAccountsFromSession(chains, chainIdToUse);\n this.accounts = accounts;\n\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n return [...this.accounts];\n }\n\n if (!this.provider?.client) {\n throw new Error(\"Provider not initialized or not connected\");\n }\n\n const { uri, approval } = await this.provider.client.connect({\n requiredNamespaces: {\n polkadot: {\n methods: ['polkadot_signMessage', 'polkadot_sendTransaction', 'polkadot_signTransaction', 'polkadot_requestAccounts'],\n chains: this.convertChainIdToCaipId(chains),\n events: ['accountsChanged', 'chainChanged', 'connect'],\n },\n },\n optionalNamespaces: {\n polkadot: {\n methods: ['polkadot_signMessage', 'polkadot_sendTransaction', 'polkadot_signTransaction', 'polkadot_requestAccounts'],\n chains: this.convertChainIdToCaipId(chains),\n events: ['accountsChanged', 'chainChanged', 'connect'],\n },\n },\n });\n\n this.emit('get_uri', uri);\n\n const session = await approval();\n this.session = session;\n this.provider.session = session;\n\n this.connectionUri = undefined;\n\n const accounts = this.getAccountsFromSession(chains, chainIdToUse);\n this.accounts = accounts;\n\n // 启动订阅\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n return [...this.accounts];\n\n } catch (error) {\n this.connectionUri = undefined;\n throw error;\n }\n }\n\n private getAccountsFromSession(chains: Chain[], chainId: string): Account[] {\n const targetChain = chains.filter(chain => chain.genesisHash.toLowerCase() === chainId.toLowerCase())\n const caipId = this.convertChainIdToCaipId(targetChain)[0];\n\n let rawAccounts = this.session?.namespaces.polkadot.accounts\n .flat()\n .filter((address: string) => address.includes(caipId))\n .map((address: string) => address.replace(`${caipId}:`, \"\"))\n\n if (rawAccounts && rawAccounts.length === 0) {\n console.error(`No accounts found for the specified chain, please connect to the correct chain`);\n\n const caipId = this.convertChainIdToCaipId(chains)[0];\n\n rawAccounts = this.session?.namespaces.polkadot.accounts\n .flat()\n .filter((address: string) => address.includes(caipId))\n .map((address: string) => address.replace(`${caipId}:`, \"\"))\n }\n\n const result = rawAccounts!\n .map((address: string) => ({\n address,\n name: `${this.name} Account`,\n meta: {\n source: this.id,\n },\n publicKey: undefined,\n }));\n\n this.emit('accountsChanged', [...result]);\n\n return result!\n }\n\n public async disconnect(): Promise<void> {\n if (this.provider) {\n console.log('this.provider', this.provider)\n console.log('this.sessionsession', this.session)\n // await Promise.race([\n await this.provider.disconnect()\n // new Promise((_, reject) =>\n // setTimeout(() => reject(new Error('Disconnect timeout')), 5000)\n // )\n // ]);\n }\n await this.cleanup()\n this.emit('disconnect');\n }\n\n public async signMessage(message: string, address: string, chainId?: string): Promise<string | undefined> {\n if (!this.provider?.client || !this.session?.topic) {\n throw new Error(\"Provider not initialized or not connected\");\n }\n\n const targetChainId = chainId\n ? `polkadot:${chainId.replace('0x', '').slice(0, 32)}`\n : this.convertChainIdToCaipId(this.connectedChains!)[0]\n\n try {\n const result = await this.provider.client.request({\n topic: this.session.topic,\n chainId: targetChainId,\n request: {\n method: 'polkadot_signMessage',\n params: {\n address,\n message,\n type: 'bytes'\n },\n },\n });\n\n return (result as any)?.signature;\n } catch (error) {\n console.error('Sign message error:', error);\n throw error;\n }\n }\n\n public hasConnectionUri(): boolean {\n return true\n }\n\n public async getConnectionUri(): Promise<string> {\n if (this.connectionUri) {\n return this.connectionUri;\n }\n\n return new Promise<string>((resolve) => {\n this.once('get_uri', (uri: string) => {\n this.connectionUri = uri;\n resolve(uri);\n });\n });\n }\n\n public async updateAccountsForChain(chainId: string) {\n if (!this.connectedChains) {\n throw new Error('WalletConnect not connected');\n }\n\n const newAccounts = this.getAccountsFromSession(this.connectedChains, chainId);\n this.accounts = newAccounts;\n\n return newAccounts;\n }\n\n\n public async getSigner(): Promise<Signer | undefined> {\n if (!this.provider?.client || !this.session) return undefined;\n\n return {\n signPayload: async (payload: SignerPayloadJSON): Promise<SignerResult> => {\n try {\n const result = await this.provider?.client?.request<{ signature: string }>({\n topic: this.session!.topic,\n chainId: `polkadot:${payload.genesisHash.replace('0x', '').slice(0, 32)}`,\n request: {\n method: 'polkadot_signTransaction',\n params: {\n address: payload.address,\n transactionPayload: payload,\n },\n },\n });\n return result as SignerResult;\n } catch (error) {\n throw new Error(`Transaction signing failed: ${JSON.stringify(error)}`);\n }\n }\n };\n }\n\n private async startSubscription(): Promise<void> {\n await this.cleanupSubscription();\n\n if (!this.provider?.client || !this.session) {\n throw new Error(`Connector ${this.id}: Cannot subscribe, provider or session not available.`);\n }\n\n try {\n const sessionDeleteHandler = async () => {\n console.log(`Connector ${this.id}: Session deleted, disconnecting...`);\n await this.cleanup()\n this.emit('disconnect');\n }\n this.provider.client.on('session_delete', sessionDeleteHandler);\n\n this.unsubscribe = () => {\n this.provider?.client?.off('session_delete', sessionDeleteHandler)\n }\n\n } catch (error) {\n this.unsubscribe = null;\n }\n }\n\n private async cleanupSubscription(): Promise<void> {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n console.log(`Connector ${this.id}: Unsubscribed from events.`);\n }\n }\n\n private async cleanup(): Promise<void> {\n await this.cleanupSubscription();\n this.accounts = [];\n this.signer = undefined;\n this.provider = undefined;\n this.session = undefined;\n }\n}\n\nexport const walletConnectConnector = (options: WalletConnectConnectorOptions) =>\n new WalletConnectConnector(options);\n","import { novaSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport class NovaMobileConnector extends CommonConnector {\n constructor() {\n super({\n id: 'nova-mobile',\n name: 'Nova Wallet',\n icon: novaSVG,\n injectorId: 'polkadot-js',\n links: {\n deepLink: 'https://app.novawallet.io/open/dapp'\n }\n });\n }\n\n public isInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n const injectedWeb3 = window.injectedWeb3;\n return (\n typeof injectedWeb3 === 'object' &&\n typeof injectedWeb3['polkadot-js'] !== 'undefined' &&\n window.walletExtension?.isNovaWallet === true\n );\n }\n\n public async isAvailable(): Promise<boolean> {\n return this.isInstalled();\n }\n}\n\nexport const novaMobileConnector = () => new NovaMobileConnector()\n","import { novaSVG } from '../config/logos/generated'\nimport { WalletConnectConnector } from './walletconnect'\nimport type { Metadata } from '@walletconnect/universal-provider'\nimport { novaMobileConnector } from './novaMobile'\nimport { isMobileDevice } from '../utils'\n\ntype WalletConnectConfig = {\n projectId: string;\n relayUrl?: string;\n metadata?: Metadata;\n}\n\ntype MobileOnlyConfig = {\n mobileOnly: true;\n}\n\ntype NovaConnectorConfig = WalletConnectConfig | MobileOnlyConfig;\n\nexport const novaConnector = (config: NovaConnectorConfig) => {\n if ((config as MobileOnlyConfig).mobileOnly && !isMobileDevice()) {\n throw new Error('Nova Wallet mobile connector cannot be used on desktop devices');\n }\n\n if ((config as MobileOnlyConfig).mobileOnly) {\n throw new Error('Nova Wallet is not installed. Please install Nova Wallet to continue.');\n }\n\n if (isMobileDevice()) {\n return novaMobileConnector();\n }\n\n return new WalletConnectConnector({\n id: 'nova',\n name: 'Nova Wallet',\n icon: novaSVG,\n links: {\n browserExtension: 'https://novawallet.io',\n },\n ...config as WalletConnectConfig,\n });\n};\n"]}
@@ -0,0 +1,3 @@
1
+ 'use strict';var chunkMYEWIINX_cjs=require('./chunk-MYEWIINX.cjs');var r={genesisHash:"0x91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3",name:"Polkadot",nativeCurrency:{name:"Polkadot",symbol:"DOT",decimals:10},rpcUrls:{webSocket:["wss://rpc.polkadot.io","wss://polkadot.api.onfinality.io/public-ws"],http:["https://rpc.polkadot.io"]},ss58Format:0,blockExplorers:{default:{name:"Subscan",url:"https://polkadot.subscan.io"}},chainIconUrl:chunkMYEWIINX_cjs.d,testnet:false};var p={genesisHash:"0xb0a8d493285c2df73290dfb7e61f870f17b41801197a149ca93654499ea3dafe",name:"Kusama",nativeCurrency:{name:"Kusama",symbol:"KSM",decimals:12},rpcUrls:{webSocket:["wss://kusama-rpc.polkadot.io","wss://kusama.api.onfinality.io/public-ws"]},ss58Format:2,blockExplorers:{default:{name:"Subscan",url:"https://kusama.subscan.io"}},chainIconUrl:chunkMYEWIINX_cjs.a,testnet:false};var l={genesisHash:"0x77afd6190f1554ad45fd0d31aee62aacc33c6db0ea801129acb813f913e0764f",name:"Paseo",nativeCurrency:{name:"Paseo",symbol:"PAS",decimals:10},rpcUrls:{webSocket:["wss://rpc.ibp.network/paseo","wss://paseo.rpc.amforc.com"]},ss58Format:0,blockExplorers:{default:{name:"Subscan",url:"https://paseo.subscan.io/"}},chainIconUrl:chunkMYEWIINX_cjs.c,testnet:true};var b={genesisHash:"0xe143f23803ac50e8f6f8e62695d1ce9e4e1d68aa36c1cd2cfd15340213f3423e",name:"Westend",nativeCurrency:{name:"Westend",symbol:"WND",decimals:12},rpcUrls:{webSocket:["wss://westend-rpc.polkadot.io"]},ss58Format:42,blockExplorers:{default:{name:"Subscan",url:"https://westend.subscan.io"}},chainIconUrl:chunkMYEWIINX_cjs.j,testnet:true};
2
+ exports.a=r;exports.b=p;exports.c=l;exports.d=b;//# sourceMappingURL=chunk-MFLU4CFP.cjs.map
3
+ //# sourceMappingURL=chunk-MFLU4CFP.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/chains/polkadot.ts","../src/chains/kusama.ts","../src/chains/paseo.ts","../src/chains/westend.ts"],"names":["polkadot","polkadotSVG","kusama","kusamaSVG","paseo","paseoSVG","westend","westendSVG"],"mappings":"mEAGO,IAAMA,EAAkB,CAC7B,WAAA,CAAa,oEAAA,CACb,IAAA,CAAM,WACN,cAAA,CAAgB,CAAE,IAAA,CAAM,UAAA,CAAY,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAChE,OAAA,CAAS,CACP,SAAA,CAAW,CAAC,uBAAA,CAAyB,4CAA4C,EACjF,IAAA,CAAM,CAAC,yBAAyB,CAClC,EACA,UAAA,CAAY,CAAA,CACZ,cAAA,CAAgB,CAAE,QAAS,CAAE,IAAA,CAAM,UAAW,GAAA,CAAK,6BAA8B,CAAE,CAAA,CACnF,YAAA,CAAcC,mBAAAA,CACd,OAAA,CAAS,KACX,ECZO,IAAMC,CAAAA,CAAgB,CAC3B,YAAa,oEAAA,CACb,IAAA,CAAM,QAAA,CACN,cAAA,CAAgB,CAAE,IAAA,CAAM,QAAA,CAAU,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAC9D,OAAA,CAAS,CAAE,SAAA,CAAW,CAAC,8BAAA,CAAgC,0CAA0C,CAAE,CAAA,CACnG,WAAY,CAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,SAAA,CAAW,IAAK,2BAA4B,CAAE,EACjF,YAAA,CAAcC,mBAAAA,CACd,OAAA,CAAS,KACX,ECTO,IAAMC,CAAAA,CAAe,CAC1B,WAAA,CAAa,qEACb,IAAA,CAAM,OAAA,CACN,cAAA,CAAgB,CAAE,KAAM,OAAA,CAAS,MAAA,CAAQ,MAAO,QAAA,CAAU,EAAG,EAC7D,OAAA,CAAS,CAAE,SAAA,CAAW,CAAC,8BAA+B,4BAA4B,CAAE,CAAA,CACpF,UAAA,CAAY,EACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,KAAM,SAAA,CAAW,GAAA,CAAK,2BAA4B,CAAE,CAAA,CACjF,aAAcC,mBAAAA,CACd,OAAA,CAAS,IACX,MCTaC,CAAAA,CAAiB,CAC5B,WAAA,CAAa,oEAAA,CACb,KAAM,SAAA,CACN,cAAA,CAAgB,CAAE,IAAA,CAAM,UAAW,MAAA,CAAQ,KAAA,CAAO,SAAU,EAAG,CAAA,CAC/D,QAAS,CAAE,SAAA,CAAW,CAAC,+BAA+B,CAAE,CAAA,CACxD,UAAA,CAAY,EAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,SAAA,CAAW,IAAK,4BAA6B,CAAE,EAClF,YAAA,CAAcC,mBAAAA,CACd,QAAS,IACX","file":"chunk-MFLU4CFP.cjs","sourcesContent":["import type { Chain } from '../types'\nimport { polkadotSVG } from '../config/logos/generated'\n\nexport const polkadot: Chain = {\n genesisHash: '0x91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3',\n name: 'Polkadot',\n nativeCurrency: { name: 'Polkadot', symbol: 'DOT', decimals: 10 },\n rpcUrls: {\n webSocket: ['wss://rpc.polkadot.io', 'wss://polkadot.api.onfinality.io/public-ws'],\n http: ['https://rpc.polkadot.io'],\n },\n ss58Format: 0,\n blockExplorers: { default: { name: 'Subscan', url: 'https://polkadot.subscan.io' } },\n chainIconUrl: polkadotSVG,\n testnet: false,\n};\n","import type { Chain } from '../types'\nimport { kusamaSVG } from '../config/logos/generated'\n\nexport const kusama: Chain = {\n genesisHash: '0xb0a8d493285c2df73290dfb7e61f870f17b41801197a149ca93654499ea3dafe',\n name: 'Kusama',\n nativeCurrency: { name: 'Kusama', symbol: 'KSM', decimals: 12 },\n rpcUrls: { webSocket: ['wss://kusama-rpc.polkadot.io', 'wss://kusama.api.onfinality.io/public-ws'] },\n ss58Format: 2,\n blockExplorers: { default: { name: 'Subscan', url: 'https://kusama.subscan.io' } },\n chainIconUrl: kusamaSVG,\n testnet: false,\n};\n","import type { Chain } from '../types'\nimport { paseoSVG } from '../config/logos/generated'\n\nexport const paseo: Chain = {\n genesisHash: '0x77afd6190f1554ad45fd0d31aee62aacc33c6db0ea801129acb813f913e0764f',\n name: 'Paseo',\n nativeCurrency: { name: 'Paseo', symbol: 'PAS', decimals: 10 },\n rpcUrls: { webSocket: ['wss://rpc.ibp.network/paseo', 'wss://paseo.rpc.amforc.com'] },\n ss58Format: 0,\n blockExplorers: { default: { name: 'Subscan', url: 'https://paseo.subscan.io/' } },\n chainIconUrl: paseoSVG,\n testnet: true\n};\n","import type { Chain } from '../types'\nimport { westendSVG } from '../config/logos/generated'\n\nexport const westend: Chain = {\n genesisHash: '0xe143f23803ac50e8f6f8e62695d1ce9e4e1d68aa36c1cd2cfd15340213f3423e',\n name: 'Westend',\n nativeCurrency: { name: 'Westend', symbol: 'WND', decimals: 12 },\n rpcUrls: { webSocket: ['wss://westend-rpc.polkadot.io'] },\n ss58Format: 42,\n blockExplorers: { default: { name: 'Subscan', url: 'https://westend.subscan.io' } },\n chainIconUrl: westendSVG,\n testnet: true,\n};\n"]}
@@ -0,0 +1,3 @@
1
+ import {e,f as f$1,g,h as h$1,i,b as b$1}from'./chunk-LXQJABLC.js';import {h,l}from'./chunk-SYUDETGE.js';import {EventEmitter}from'eventemitter3';import {stringToHex}from'dedot/utils';var a=class extends EventEmitter{constructor(){super();this.links={};this.accounts=[];this.signer=void 0;this.connectionUri=void 0;}async getAccounts(){return [...this.accounts]}async getSigner(){return this.signer||console.warn(`Connector ${this.id}: Signer not available. Connection might be incomplete or failed.`),this.signer}hasConnectionUri(){return false}async getConnectionUri(){return this.connectionUri}async updateAccountsForChain(t){return [...this.accounts]}};var o=class extends a{constructor(t){super();this.unsubscribe=null;this.specificInjector=void 0;this.id=t.id,this.name=t.name,this.icon=t.icon,this.links=t.links,this.injectorId=t.injectorId||t.id;}isInstalled(){if(typeof window>"u")return false;let t=window.injectedWeb3;return typeof t=="object"&&typeof t[this.injectorId]<"u"}async isAvailable(){return this.isInstalled()}async connect(t){if(console.log(`Connector ${this.id}: Attempting to connect...`),this.signer)return console.log(`Connector ${this.id}: Already connected.`),[...this.accounts];if(!await this.isAvailable())throw new Error(`${this.name} extension not found or not enabled.`);try{if(this.specificInjector=await window.injectedWeb3[this.injectorId].enable(t),!this.specificInjector)throw new Error(`Failed to enable the '${this.id}' extension.`);if(this.signer=this.specificInjector.signer,!this.signer)throw new Error(`Could not get signer from ${this.name}.`);let n=await this.specificInjector.accounts.get();if(n.length===0)throw new Error(`No accounts found in ${this.name}. Make sure accounts are visible and access is granted.`);return this.accounts=h(n,this.id),console.log(`Connector ${this.id}: Initial accounts loaded`,this.accounts),await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}catch(n){throw console.error(`Connector ${this.id}: Connection failed:`,n),await this.cleanup(),n}}async disconnect(){console.log(`Connector ${this.id}: Disconnecting...`),await this.cleanup(),this.emit("disconnect");}async signMessage(t,n){if(!n||!t)return;let s=await this.getSigner();if(!s||!s?.signRaw)throw new Error("Signer is not available or does not support signRaw.");if(!(await this.getAccounts()).some(e=>e.address.toLowerCase()===n.toLowerCase()))throw new Error(`Address ${n} is not managed by ${this.name}.`);try{let e=stringToHex(t);return (await s.signRaw({address:n,data:e,type:"bytes"})).signature}catch(e){throw new Error(`Connector ${this.id}: Failed to sign message: ${e.message}`)}}async startSubscription(){if(await this.cleanupSubscription(),!this.specificInjector)throw new Error(`Connector ${this.id}: Cannot subscribe, specificInjector not available.`);try{this.unsubscribe=this.specificInjector.accounts.subscribe(t=>{let n=h(t,this.id);JSON.stringify(this.accounts)!==JSON.stringify(n)&&(this.accounts=n,this.emit("accountsChanged",[...this.accounts]));}),console.log(`Connector ${this.id}: Subscribed to account changes.`);}catch(t){console.error(`Connector ${this.id}: Failed to subscribe to accounts:`,t),this.unsubscribe=null;}}async cleanupSubscription(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=null,console.log(`Connector ${this.id}: Unsubscribed from account changes.`));}async cleanup(){await this.cleanupSubscription(),this.accounts=[],this.signer=void 0,this.specificInjector=void 0;}};var P=()=>new o({id:"polkadot-js",name:"Polkadot{.js}",icon:e,links:{browserExtension:"https://polkadot.js.org/extension"}});var x=()=>new o({id:"polkagate",name:"Polkagate",icon:f$1,links:{browserExtension:"https://chromewebstore.google.com/detail/polkagate-the-gateway-to/ginchbkmljhldofnbjabmeophlhdldgp"}});var $=()=>new o({id:"subwallet-js",name:"SubWallet",icon:g,links:{browserExtension:"https://chromewebstore.google.com/detail/subwallet-polkadot-wallet/onhogfjeacnfoofkfgppdlbmlmnplgbn",deepLink:"https://mobile.subwallet.app/browser"}});var E=()=>new o({id:"talisman",name:"Talisman",icon:h$1,links:{browserExtension:"https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld"}});var u=class extends a{constructor(t){super();this.unsubscribe=null;this.id=t.id||"walletconnect",this.name=t.name||"WalletConnect",this.links=t.links||{},this.icon=t.icon||i,this.projectId=t.projectId,this.relayUrl=t.relayUrl||"wss://relay.walletconnect.com",this.metadata=t.metadata;}isInstalled(){return false}async isAvailable(){return true}convertChainIdToCaipId(t){return t.map(n=>`polkadot:${n.genesisHash.replace("0x","").slice(0,32)}`)}async connect(t,n,s){if(!this.projectId)throw new Error(`${this.name} requires a projectId. Please visit https://cloud.walletconnect.com to get one.`);if(!n||n.length===0)throw new Error(`${this.name} requires chains configuration.`);this.connectedChains=n;let{UniversalProvider:c}=await import('@walletconnect/universal-provider');try{this.provider=await c.init({projectId:this.projectId,relayUrl:this.relayUrl,metadata:this.metadata||{name:t,description:"LunoKit DApp",url:typeof window<"u"?window.location.origin:"",icons:[this.icon]}});let e=s||n[0].genesisHash;if(this.provider.session){this.session=this.provider.session;let j=this.getAccountsFromSession(n,e);return this.accounts=j,await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}if(!this.provider?.client)throw new Error("Provider not initialized or not connected");let{uri:p,approval:i}=await this.provider.client.connect({requiredNamespaces:{polkadot:{methods:["polkadot_signMessage","polkadot_sendTransaction","polkadot_signTransaction","polkadot_requestAccounts"],chains:this.convertChainIdToCaipId(n),events:["accountsChanged","chainChanged","connect"]}},optionalNamespaces:{polkadot:{methods:["polkadot_signMessage","polkadot_sendTransaction","polkadot_signTransaction","polkadot_requestAccounts"],chains:this.convertChainIdToCaipId(n),events:["accountsChanged","chainChanged","connect"]}}});this.emit("get_uri",p);let l=await i();this.session=l,this.provider.session=l,this.connectionUri=void 0;let I=this.getAccountsFromSession(n,e);return this.accounts=I,await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}catch(e){throw this.connectionUri=void 0,e}}getAccountsFromSession(t,n){let s=t.filter(i=>i.genesisHash.toLowerCase()===n.toLowerCase()),c=this.convertChainIdToCaipId(s)[0],e=this.session?.namespaces.polkadot.accounts.flat().filter(i=>i.includes(c)).map(i=>i.replace(`${c}:`,""));if(e&&e.length===0){console.error("No accounts found for the specified chain, please connect to the correct chain");let i=this.convertChainIdToCaipId(t)[0];e=this.session?.namespaces.polkadot.accounts.flat().filter(l=>l.includes(i)).map(l=>l.replace(`${i}:`,""));}let p=e.map(i=>({address:i,name:`${this.name} Account`,meta:{source:this.id},publicKey:void 0}));return this.emit("accountsChanged",[...p]),p}async disconnect(){this.provider&&(console.log("this.provider",this.provider),console.log("this.sessionsession",this.session),await this.provider.disconnect()),await this.cleanup(),this.emit("disconnect");}async signMessage(t,n,s){if(!this.provider?.client||!this.session?.topic)throw new Error("Provider not initialized or not connected");let c=s?`polkadot:${s.replace("0x","").slice(0,32)}`:this.convertChainIdToCaipId(this.connectedChains)[0];try{return (await this.provider.client.request({topic:this.session.topic,chainId:c,request:{method:"polkadot_signMessage",params:{address:n,message:t,type:"bytes"}}}))?.signature}catch(e){throw console.error("Sign message error:",e),e}}hasConnectionUri(){return true}async getConnectionUri(){return this.connectionUri?this.connectionUri:new Promise(t=>{this.once("get_uri",n=>{this.connectionUri=n,t(n);});})}async updateAccountsForChain(t){if(!this.connectedChains)throw new Error("WalletConnect not connected");let n=this.getAccountsFromSession(this.connectedChains,t);return this.accounts=n,n}async getSigner(){if(!(!this.provider?.client||!this.session))return {signPayload:async t=>{try{return await this.provider?.client?.request({topic:this.session.topic,chainId:`polkadot:${t.genesisHash.replace("0x","").slice(0,32)}`,request:{method:"polkadot_signTransaction",params:{address:t.address,transactionPayload:t}}})}catch(n){throw new Error(`Transaction signing failed: ${JSON.stringify(n)}`)}}}}async startSubscription(){if(await this.cleanupSubscription(),!this.provider?.client||!this.session)throw new Error(`Connector ${this.id}: Cannot subscribe, provider or session not available.`);try{let t=async()=>{console.log(`Connector ${this.id}: Session deleted, disconnecting...`),await this.cleanup(),this.emit("disconnect");};this.provider.client.on("session_delete",t),this.unsubscribe=()=>{this.provider?.client?.off("session_delete",t);};}catch{this.unsubscribe=null;}}async cleanupSubscription(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=null,console.log(`Connector ${this.id}: Unsubscribed from events.`));}async cleanup(){await this.cleanupSubscription(),this.accounts=[],this.signer=void 0,this.provider=void 0,this.session=void 0;}},U=r=>new u(r);var b=class extends o{constructor(){super({id:"nova-mobile",name:"Nova Wallet",icon:b$1,injectorId:"polkadot-js",links:{deepLink:"https://app.novawallet.io/open/dapp"}});}isInstalled(){if(typeof window>"u")return false;let d=window.injectedWeb3;return typeof d=="object"&&typeof d["polkadot-js"]<"u"&&window.walletExtension?.isNovaWallet===true}async isAvailable(){return this.isInstalled()}},f=()=>new b;var W=r=>{if(r.mobileOnly&&!l())throw new Error("Nova Wallet mobile connector cannot be used on desktop devices");if(r.mobileOnly)throw new Error("Nova Wallet is not installed. Please install Nova Wallet to continue.");return l()?f():new u({id:"nova",name:"Nova Wallet",icon:b$1,links:{browserExtension:"https://novawallet.io"},...r})};
2
+ export{a,o as b,P as c,x as d,$ as e,E as f,U as g,f as h,W as i};//# sourceMappingURL=chunk-VGX4US5T.js.map
3
+ //# sourceMappingURL=chunk-VGX4US5T.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/connectors/base.ts","../src/connectors/common.ts","../src/connectors/polkadot-js.ts","../src/connectors/polkagate.ts","../src/connectors/subwallet.ts","../src/connectors/talisman.ts","../src/connectors/walletconnect.ts","../src/connectors/novaMobile.ts","../src/connectors/nova.ts"],"names":["BaseConnector","EventEmitter","chainId","CommonConnector","options","injectedWeb3","appName","rawAccounts","mapInjectedAccounts","error","message","address","signer","acc","dataHex","stringToHex","updatedRawAccounts","newAccounts","polkadotjsConnector","polkadotjsSVG","polkagateConnector","polkagateSVG","subwalletConnector","subwalletSVG","talismanConnector","talismanSVG","WalletConnectConnector","walletconnectSVG","chains","chain","targetChainId","UniversalProvider","chainIdToUse","accounts","uri","approval","session","targetChain","caipId","result","resolve","payload","sessionDeleteHandler","walletConnectConnector","NovaMobileConnector","novaSVG","novaMobileConnector","novaConnector","config","isMobileDevice"],"mappings":"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","file":"chunk-VGX4US5T.js","sourcesContent":["import type {Account, Chain, Signer} from '../types';\nimport { EventEmitter } from 'eventemitter3';\nimport { ConnectorLinks } from '../types'\n\n/**\n * base connector abstract class\n * defines the basic properties and methods that all wallet connectors should have.\n */\nexport abstract class BaseConnector extends EventEmitter {\n /**\n * the unique identifier of the connector (e.g., 'polkadot-js', 'subwallet-js')\n * subclasses must implement.\n */\n abstract readonly id: string;\n\n /**\n * user-friendly connector name (e.g., 'Polkadot{.js}', 'SubWallet')\n * subclasses must implement.\n */\n abstract readonly name: string;\n\n /**\n * connector icon URL (optional)\n * subclasses can implement.\n */\n abstract readonly icon?: string;\n\n readonly links: ConnectorLinks = {};\n /**\n * store the current connected accounts.\n * subclasses are responsible for maintaining this list when connecting and updating accounts.\n */\n protected accounts: Account[] = [];\n /**\n * store the signer.\n * subclasses are responsible for getting and storing it when connecting.\n */\n protected signer: Signer | undefined = undefined;\n\n protected connectionUri: string | undefined = undefined;\n\n constructor() {\n super();\n }\n\n public abstract isAvailable(): Promise<boolean>;\n\n public abstract isInstalled(): boolean;\n\n /**\n * connect to the wallet, get the initial accounts and signer, and set the necessary event listeners.\n * subclasses must implement:\n * 1. get the signer and assign it to this.signer.\n * 2. get the initial accounts list and assign it to this.accounts.\n * 3. set the account update mechanism of itself (e.g., use web3AccountsSubscribe or WalletConnect events).\n * 4. update this.accounts when the account list changes and trigger the 'accountsChanged' event.\n * 5. (optional) trigger the 'connect' event.\n * @returns the initial available accounts list\n */\n abstract connect(appName: string, chains?: Chain[], targetChainId?: string): Promise<Array<Account>>;\n /**\n * disconnect from the wallet.\n * subclasses must implement this method to perform specific cleanup logic\n * (e.g., unsubscribe, close session).\n * implementers should clear this.accounts and this.signer after cleanup and trigger the 'disconnect' event.\n */\n abstract disconnect(): Promise<void>;\n\n /**\n * get the current connected accounts list.\n * @returns the current available accounts list\n */\n public async getAccounts(): Promise<Array<Account>> {\n return [...this.accounts];\n }\n\n /**\n * get the cached signer object.\n * @returns the signer object, or undefined if the connection is not successful or cannot be obtained.\n */\n public async getSigner(): Promise<Signer | undefined> {\n if (!this.signer) {\n console.warn(`Connector ${this.id}: Signer not available. Connection might be incomplete or failed.`);\n }\n return this.signer;\n }\n\n /**\n * sign a message with the specified account.\n */\n abstract signMessage(message: string, address: string, chainId?: string): Promise<string | undefined>;\n\n public hasConnectionUri(): boolean {\n return false\n }\n\n public async getConnectionUri(): Promise<string | undefined >{\n return this.connectionUri;\n }\n\n public async updateAccountsForChain(chainId: string): Promise<Account[]> {\n return [...this.accounts];\n }\n}\n","import { BaseConnector } from './base';\nimport type { Account, Signer } from '../types';\nimport { mapInjectedAccounts } from '../utils'\nimport { Injected, InjectedAccount } from 'dedot/types'\nimport { stringToHex } from 'dedot/utils'\nimport { ConnectorLinks } from '../types'\n\nexport interface CommonConnectorOptions {\n id: string;\n name: string;\n icon: string;\n links: ConnectorLinks;\n injectorId?: string;\n}\n\nexport class CommonConnector extends BaseConnector {\n readonly id: string;\n readonly name: string;\n readonly icon: string;\n readonly links: ConnectorLinks;\n protected readonly injectorId: string;\n\n private unsubscribe: (() => void) | null = null;\n\n private specificInjector?: Injected = undefined\n\n constructor(options: CommonConnectorOptions) {\n super();\n this.id = options.id;\n this.name = options.name;\n this.icon = options.icon;\n this.links = options.links;\n this.injectorId = options.injectorId || options.id;\n }\n\n public isInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n const injectedWeb3 = window.injectedWeb3;\n return typeof injectedWeb3 === 'object' && typeof injectedWeb3[this.injectorId] !== 'undefined';\n }\n\n public async isAvailable(): Promise<boolean> {\n return this.isInstalled();\n }\n\n public async connect(appName: string): Promise<Array<Account>> {\n console.log(`Connector ${this.id}: Attempting to connect...`);\n if (this.signer) {\n console.log(`Connector ${this.id}: Already connected.`);\n return [...this.accounts];\n }\n if (!(await this.isAvailable())) {\n throw new Error(`${this.name} extension not found or not enabled.`);\n }\n\n try {\n this.specificInjector = await window.injectedWeb3![this.injectorId]!.enable(appName);\n\n if (!this.specificInjector) {\n throw new Error(`Failed to enable the '${this.id}' extension.`);\n }\n\n this.signer = this.specificInjector.signer as Signer;\n\n if (!this.signer) {\n throw new Error(`Could not get signer from ${this.name}.`);\n }\n\n const rawAccounts = await this.specificInjector.accounts.get();\n if (rawAccounts.length === 0) {\n throw new Error(`No accounts found in ${this.name}. Make sure accounts are visible and access is granted.`);\n }\n this.accounts = mapInjectedAccounts(rawAccounts, this.id);\n console.log(`Connector ${this.id}: Initial accounts loaded`, this.accounts);\n\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n\n return [...this.accounts];\n\n } catch (error) {\n console.error(`Connector ${this.id}: Connection failed:`, error);\n await this.cleanup();\n throw error;\n }\n }\n\n public async disconnect(): Promise<void> {\n console.log(`Connector ${this.id}: Disconnecting...`);\n await this.cleanup();\n this.emit('disconnect');\n }\n\n public async signMessage(message: string, address: string): Promise<string | undefined> {\n if (!address || !message) return undefined;\n const signer = await this.getSigner();\n if (!signer || !signer?.signRaw) {\n throw new Error('Signer is not available or does not support signRaw.');\n }\n const accounts = await this.getAccounts();\n if (!accounts.some(acc => acc.address.toLowerCase() === address.toLowerCase())) {\n throw new Error(`Address ${address} is not managed by ${this.name}.`);\n }\n\n try {\n const dataHex = stringToHex(message);\n const result = await signer.signRaw({ address, data: dataHex, type: 'bytes' });\n return result.signature;\n } catch (error: any) {\n throw new Error(`Connector ${this.id}: Failed to sign message: ${error.message}`);\n }\n }\n\n\n private async startSubscription(): Promise<void> {\n await this.cleanupSubscription();\n if (!this.specificInjector) {\n throw new Error(`Connector ${this.id}: Cannot subscribe, specificInjector not available.`);\n }\n\n try {\n this.unsubscribe = this.specificInjector.accounts.subscribe(\n (updatedRawAccounts: InjectedAccount[]) => {\n const newAccounts = mapInjectedAccounts(updatedRawAccounts, this.id);\n if (JSON.stringify(this.accounts) !== JSON.stringify(newAccounts)) {\n this.accounts = newAccounts;\n this.emit('accountsChanged', [...this.accounts]);\n }\n }\n );\n console.log(`Connector ${this.id}: Subscribed to account changes.`);\n } catch (error) {\n console.error(`Connector ${this.id}: Failed to subscribe to accounts:`, error);\n this.unsubscribe = null;\n }\n }\n\n private async cleanupSubscription(): Promise<void> {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n console.log(`Connector ${this.id}: Unsubscribed from account changes.`);\n }\n }\n\n\n private async cleanup(): Promise<void> {\n await this.cleanupSubscription();\n this.accounts = [];\n this.signer = undefined;\n this.specificInjector = undefined\n }\n}\n","import { CommonConnector } from './common'\nimport { polkadotjsSVG } from '../config/logos/generated'\n\nexport const polkadotjsConnector = () => {\n return new CommonConnector({\n id: 'polkadot-js',\n name: 'Polkadot{.js}',\n icon: polkadotjsSVG,\n links: {\n browserExtension: 'https://polkadot.js.org/extension'\n }\n });\n}\n","import { polkagateSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const polkagateConnector = () => {\n return new CommonConnector({\n id: 'polkagate',\n name: 'Polkagate',\n icon: polkagateSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/polkagate-the-gateway-to/ginchbkmljhldofnbjabmeophlhdldgp'\n }\n });\n}\n","import { subwalletSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const subwalletConnector = () => {\n return new CommonConnector({\n id: 'subwallet-js',\n name: 'SubWallet',\n icon: subwalletSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/subwallet-polkadot-wallet/onhogfjeacnfoofkfgppdlbmlmnplgbn',\n deepLink: 'https://mobile.subwallet.app/browser',\n }\n })\n};\n","import { talismanSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const talismanConnector = () => {\n return new CommonConnector({\n id: 'talisman',\n name: 'Talisman',\n icon: talismanSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld'\n }\n });\n}\n","import { BaseConnector } from './base';\nimport type { IUniversalProvider, Metadata } from '@walletconnect/universal-provider';\nimport { SessionTypes, SignClientTypes } from '@walletconnect/types'\nimport type { Account, Chain, Signer, WalletConnectConnectorOptions } from '../types';\nimport { walletconnectSVG } from '../config/logos/generated';\nimport { SignerResult, SignerPayloadJSON } from 'dedot/types'\nimport { ConnectorLinks } from '../types'\n\nexport class WalletConnectConnector extends BaseConnector {\n readonly id: string;\n readonly name: string;\n readonly icon: string;\n readonly links: ConnectorLinks;\n\n private provider?: IUniversalProvider;\n private projectId: string;\n private relayUrl: string;\n private metadata?: Metadata;\n\n private session?: SessionTypes.Struct;\n private connectedChains?: Chain[];\n\n private unsubscribe: (() => void) | null = null;\n\n constructor(options: WalletConnectConnectorOptions) {\n super();\n this.id = options.id || 'walletconnect';\n this.name = options.name || 'WalletConnect';\n this.links = options.links || {};\n\n this.icon = options.icon || walletconnectSVG;\n\n this.projectId = options.projectId;\n this.relayUrl = options.relayUrl || 'wss://relay.walletconnect.com';\n this.metadata = options.metadata;\n }\n\n public isInstalled(): boolean {\n return false;\n }\n\n public async isAvailable(): Promise<boolean> {\n return true;\n }\n\n private convertChainIdToCaipId(chains: Chain[]): string[] {\n return chains.map(chain => `polkadot:${chain.genesisHash.replace('0x', '').slice(0, 32)}`);\n }\n\n public async connect(appName: string, chains?: Chain[], targetChainId?: string): Promise<Array<Account>> {\n if (!this.projectId) {\n throw new Error(`${this.name} requires a projectId. Please visit https://cloud.walletconnect.com to get one.`);\n }\n\n if (!chains || chains.length === 0) {\n throw new Error(`${this.name} requires chains configuration.`);\n }\n\n this.connectedChains = chains;\n\n const { UniversalProvider } = await import(\"@walletconnect/universal-provider\");\n\n try {\n this.provider = await UniversalProvider.init({\n projectId: this.projectId,\n relayUrl: this.relayUrl,\n metadata: this.metadata || {\n name: appName,\n description: 'LunoKit DApp',\n url: typeof window !== 'undefined' ? window.location.origin : '',\n icons: [this.icon],\n },\n });\n\n const chainIdToUse = targetChainId || chains[0].genesisHash;\n\n if (this.provider.session) {\n this.session = this.provider.session;\n const accounts = this.getAccountsFromSession(chains, chainIdToUse);\n this.accounts = accounts;\n\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n return [...this.accounts];\n }\n\n if (!this.provider?.client) {\n throw new Error(\"Provider not initialized or not connected\");\n }\n\n const { uri, approval } = await this.provider.client.connect({\n requiredNamespaces: {\n polkadot: {\n methods: ['polkadot_signMessage', 'polkadot_sendTransaction', 'polkadot_signTransaction', 'polkadot_requestAccounts'],\n chains: this.convertChainIdToCaipId(chains),\n events: ['accountsChanged', 'chainChanged', 'connect'],\n },\n },\n optionalNamespaces: {\n polkadot: {\n methods: ['polkadot_signMessage', 'polkadot_sendTransaction', 'polkadot_signTransaction', 'polkadot_requestAccounts'],\n chains: this.convertChainIdToCaipId(chains),\n events: ['accountsChanged', 'chainChanged', 'connect'],\n },\n },\n });\n\n this.emit('get_uri', uri);\n\n const session = await approval();\n this.session = session;\n this.provider.session = session;\n\n this.connectionUri = undefined;\n\n const accounts = this.getAccountsFromSession(chains, chainIdToUse);\n this.accounts = accounts;\n\n // 启动订阅\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n return [...this.accounts];\n\n } catch (error) {\n this.connectionUri = undefined;\n throw error;\n }\n }\n\n private getAccountsFromSession(chains: Chain[], chainId: string): Account[] {\n const targetChain = chains.filter(chain => chain.genesisHash.toLowerCase() === chainId.toLowerCase())\n const caipId = this.convertChainIdToCaipId(targetChain)[0];\n\n let rawAccounts = this.session?.namespaces.polkadot.accounts\n .flat()\n .filter((address: string) => address.includes(caipId))\n .map((address: string) => address.replace(`${caipId}:`, \"\"))\n\n if (rawAccounts && rawAccounts.length === 0) {\n console.error(`No accounts found for the specified chain, please connect to the correct chain`);\n\n const caipId = this.convertChainIdToCaipId(chains)[0];\n\n rawAccounts = this.session?.namespaces.polkadot.accounts\n .flat()\n .filter((address: string) => address.includes(caipId))\n .map((address: string) => address.replace(`${caipId}:`, \"\"))\n }\n\n const result = rawAccounts!\n .map((address: string) => ({\n address,\n name: `${this.name} Account`,\n meta: {\n source: this.id,\n },\n publicKey: undefined,\n }));\n\n this.emit('accountsChanged', [...result]);\n\n return result!\n }\n\n public async disconnect(): Promise<void> {\n if (this.provider) {\n console.log('this.provider', this.provider)\n console.log('this.sessionsession', this.session)\n // await Promise.race([\n await this.provider.disconnect()\n // new Promise((_, reject) =>\n // setTimeout(() => reject(new Error('Disconnect timeout')), 5000)\n // )\n // ]);\n }\n await this.cleanup()\n this.emit('disconnect');\n }\n\n public async signMessage(message: string, address: string, chainId?: string): Promise<string | undefined> {\n if (!this.provider?.client || !this.session?.topic) {\n throw new Error(\"Provider not initialized or not connected\");\n }\n\n const targetChainId = chainId\n ? `polkadot:${chainId.replace('0x', '').slice(0, 32)}`\n : this.convertChainIdToCaipId(this.connectedChains!)[0]\n\n try {\n const result = await this.provider.client.request({\n topic: this.session.topic,\n chainId: targetChainId,\n request: {\n method: 'polkadot_signMessage',\n params: {\n address,\n message,\n type: 'bytes'\n },\n },\n });\n\n return (result as any)?.signature;\n } catch (error) {\n console.error('Sign message error:', error);\n throw error;\n }\n }\n\n public hasConnectionUri(): boolean {\n return true\n }\n\n public async getConnectionUri(): Promise<string> {\n if (this.connectionUri) {\n return this.connectionUri;\n }\n\n return new Promise<string>((resolve) => {\n this.once('get_uri', (uri: string) => {\n this.connectionUri = uri;\n resolve(uri);\n });\n });\n }\n\n public async updateAccountsForChain(chainId: string) {\n if (!this.connectedChains) {\n throw new Error('WalletConnect not connected');\n }\n\n const newAccounts = this.getAccountsFromSession(this.connectedChains, chainId);\n this.accounts = newAccounts;\n\n return newAccounts;\n }\n\n\n public async getSigner(): Promise<Signer | undefined> {\n if (!this.provider?.client || !this.session) return undefined;\n\n return {\n signPayload: async (payload: SignerPayloadJSON): Promise<SignerResult> => {\n try {\n const result = await this.provider?.client?.request<{ signature: string }>({\n topic: this.session!.topic,\n chainId: `polkadot:${payload.genesisHash.replace('0x', '').slice(0, 32)}`,\n request: {\n method: 'polkadot_signTransaction',\n params: {\n address: payload.address,\n transactionPayload: payload,\n },\n },\n });\n return result as SignerResult;\n } catch (error) {\n throw new Error(`Transaction signing failed: ${JSON.stringify(error)}`);\n }\n }\n };\n }\n\n private async startSubscription(): Promise<void> {\n await this.cleanupSubscription();\n\n if (!this.provider?.client || !this.session) {\n throw new Error(`Connector ${this.id}: Cannot subscribe, provider or session not available.`);\n }\n\n try {\n const sessionDeleteHandler = async () => {\n console.log(`Connector ${this.id}: Session deleted, disconnecting...`);\n await this.cleanup()\n this.emit('disconnect');\n }\n this.provider.client.on('session_delete', sessionDeleteHandler);\n\n this.unsubscribe = () => {\n this.provider?.client?.off('session_delete', sessionDeleteHandler)\n }\n\n } catch (error) {\n this.unsubscribe = null;\n }\n }\n\n private async cleanupSubscription(): Promise<void> {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n console.log(`Connector ${this.id}: Unsubscribed from events.`);\n }\n }\n\n private async cleanup(): Promise<void> {\n await this.cleanupSubscription();\n this.accounts = [];\n this.signer = undefined;\n this.provider = undefined;\n this.session = undefined;\n }\n}\n\nexport const walletConnectConnector = (options: WalletConnectConnectorOptions) =>\n new WalletConnectConnector(options);\n","import { novaSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport class NovaMobileConnector extends CommonConnector {\n constructor() {\n super({\n id: 'nova-mobile',\n name: 'Nova Wallet',\n icon: novaSVG,\n injectorId: 'polkadot-js',\n links: {\n deepLink: 'https://app.novawallet.io/open/dapp'\n }\n });\n }\n\n public isInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n const injectedWeb3 = window.injectedWeb3;\n return (\n typeof injectedWeb3 === 'object' &&\n typeof injectedWeb3['polkadot-js'] !== 'undefined' &&\n window.walletExtension?.isNovaWallet === true\n );\n }\n\n public async isAvailable(): Promise<boolean> {\n return this.isInstalled();\n }\n}\n\nexport const novaMobileConnector = () => new NovaMobileConnector()\n","import { novaSVG } from '../config/logos/generated'\nimport { WalletConnectConnector } from './walletconnect'\nimport type { Metadata } from '@walletconnect/universal-provider'\nimport { novaMobileConnector } from './novaMobile'\nimport { isMobileDevice } from '../utils'\n\ntype WalletConnectConfig = {\n projectId: string;\n relayUrl?: string;\n metadata?: Metadata;\n}\n\ntype MobileOnlyConfig = {\n mobileOnly: true;\n}\n\ntype NovaConnectorConfig = WalletConnectConfig | MobileOnlyConfig;\n\nexport const novaConnector = (config: NovaConnectorConfig) => {\n if ((config as MobileOnlyConfig).mobileOnly && !isMobileDevice()) {\n throw new Error('Nova Wallet mobile connector cannot be used on desktop devices');\n }\n\n if ((config as MobileOnlyConfig).mobileOnly) {\n throw new Error('Nova Wallet is not installed. Please install Nova Wallet to continue.');\n }\n\n if (isMobileDevice()) {\n return novaMobileConnector();\n }\n\n return new WalletConnectConnector({\n id: 'nova',\n name: 'Nova Wallet',\n icon: novaSVG,\n links: {\n browserExtension: 'https://novawallet.io',\n },\n ...config as WalletConnectConfig,\n });\n};\n"]}
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkHQJ3DJ5D_cjs=require('../chunk-HQJ3DJ5D.cjs');require('../chunk-MYEWIINX.cjs'),require('../chunk-WQPMFK4M.cjs');Object.defineProperty(exports,"BaseConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.a}});Object.defineProperty(exports,"novaConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.h}});Object.defineProperty(exports,"novaMobileConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.g}});Object.defineProperty(exports,"polkadotjsConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.b}});Object.defineProperty(exports,"polkagateConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.c}});Object.defineProperty(exports,"subwalletConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.d}});Object.defineProperty(exports,"talismanConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.e}});Object.defineProperty(exports,"walletConnectConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.f}});//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var chunkJOIV5HSZ_cjs=require('../chunk-JOIV5HSZ.cjs');require('../chunk-MYEWIINX.cjs'),require('../chunk-WQPMFK4M.cjs');Object.defineProperty(exports,"BaseConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.a}});Object.defineProperty(exports,"CommonConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.b}});Object.defineProperty(exports,"novaConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.i}});Object.defineProperty(exports,"novaMobileConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.h}});Object.defineProperty(exports,"polkadotjsConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.c}});Object.defineProperty(exports,"polkagateConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.d}});Object.defineProperty(exports,"subwalletConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.e}});Object.defineProperty(exports,"talismanConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.f}});Object.defineProperty(exports,"walletConnectConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.g}});//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1,5 +1,5 @@
1
- export { B as BaseConnector, n as novaConnector, c as novaMobileConnector, p as polkadotjsConnector, b as polkagateConnector, s as subwalletConnector, t as talismanConnector, w as walletConnectConnector } from '../index-wq9QCQkl.cjs';
2
- import '../chain-CCVvkcX7.cjs';
1
+ export { B as BaseConnector, b as CommonConnector, n as novaConnector, d as novaMobileConnector, p as polkadotjsConnector, c as polkagateConnector, s as subwalletConnector, t as talismanConnector, w as walletConnectConnector } from '../index-PqPDUdlJ.cjs';
2
+ import '../chain-9vBVQoCB.cjs';
3
3
  import '../account-DElDu01m.cjs';
4
4
  import 'dedot/utils';
5
5
  import 'dedot/types';
@@ -1,5 +1,5 @@
1
- export { B as BaseConnector, n as novaConnector, c as novaMobileConnector, p as polkadotjsConnector, b as polkagateConnector, s as subwalletConnector, t as talismanConnector, w as walletConnectConnector } from '../index-CAhh4QRi.js';
2
- import '../chain-CCVvkcX7.js';
1
+ export { B as BaseConnector, b as CommonConnector, n as novaConnector, d as novaMobileConnector, p as polkadotjsConnector, c as polkagateConnector, s as subwalletConnector, t as talismanConnector, w as walletConnectConnector } from '../index-Cxsn9zGL.js';
2
+ import '../chain-9vBVQoCB.js';
3
3
  import '../account-DElDu01m.js';
4
4
  import 'dedot/utils';
5
5
  import 'dedot/types';
@@ -1,2 +1,2 @@
1
- export{a as BaseConnector,h as novaConnector,g as novaMobileConnector,b as polkadotjsConnector,c as polkagateConnector,d as subwalletConnector,e as talismanConnector,f as walletConnectConnector}from'../chunk-2ZADE6DA.js';import'../chunk-LXQJABLC.js';import'../chunk-SYUDETGE.js';//# sourceMappingURL=index.js.map
1
+ export{a as BaseConnector,b as CommonConnector,i as novaConnector,h as novaMobileConnector,c as polkadotjsConnector,d as polkagateConnector,e as subwalletConnector,f as talismanConnector,g as walletConnectConnector}from'../chunk-VGX4US5T.js';import'../chunk-LXQJABLC.js';import'../chunk-SYUDETGE.js';//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
@@ -1,4 +1,4 @@
1
- import { C as Chain } from './chain-CCVvkcX7.js';
1
+ import { C as Chain } from './chain-9vBVQoCB.js';
2
2
  import { A as Account } from './account-DElDu01m.js';
3
3
  import { EventEmitter } from 'eventemitter3';
4
4
  import { InjectedSigner } from 'dedot/types';
@@ -199,4 +199,4 @@ type MobileOnlyConfig = {
199
199
  type NovaConnectorConfig = WalletConnectConfig | MobileOnlyConfig;
200
200
  declare const novaConnector: (config: NovaConnectorConfig) => WalletConnectConnector | NovaMobileConnector;
201
201
 
202
- export { BaseConnector as B, type Connector as C, type Signer as S, type WalletConnectConnectorOptions as W, type ConnectorLinks as a, polkagateConnector as b, novaMobileConnector as c, novaConnector as n, polkadotjsConnector as p, subwalletConnector as s, talismanConnector as t, walletConnectConnector as w };
202
+ export { BaseConnector as B, type Connector as C, type Signer as S, type WalletConnectConnectorOptions as W, type ConnectorLinks as a, CommonConnector as b, polkagateConnector as c, novaMobileConnector as d, novaConnector as n, polkadotjsConnector as p, subwalletConnector as s, talismanConnector as t, walletConnectConnector as w };
@@ -1,4 +1,4 @@
1
- import { C as Chain } from './chain-CCVvkcX7.cjs';
1
+ import { C as Chain } from './chain-9vBVQoCB.cjs';
2
2
  import { A as Account } from './account-DElDu01m.cjs';
3
3
  import { EventEmitter } from 'eventemitter3';
4
4
  import { InjectedSigner } from 'dedot/types';
@@ -199,4 +199,4 @@ type MobileOnlyConfig = {
199
199
  type NovaConnectorConfig = WalletConnectConfig | MobileOnlyConfig;
200
200
  declare const novaConnector: (config: NovaConnectorConfig) => WalletConnectConnector | NovaMobileConnector;
201
201
 
202
- export { BaseConnector as B, type Connector as C, type Signer as S, type WalletConnectConnectorOptions as W, type ConnectorLinks as a, polkagateConnector as b, novaMobileConnector as c, novaConnector as n, polkadotjsConnector as p, subwalletConnector as s, talismanConnector as t, walletConnectConnector as w };
202
+ export { BaseConnector as B, type Connector as C, type Signer as S, type WalletConnectConnectorOptions as W, type ConnectorLinks as a, CommonConnector as b, polkagateConnector as c, novaMobileConnector as d, novaConnector as n, polkadotjsConnector as p, subwalletConnector as s, talismanConnector as t, walletConnectConnector as w };
package/dist/index.cjs CHANGED
@@ -1,2 +1,2 @@
1
- 'use strict';var chunkB75MLGK5_cjs=require('./chunk-B75MLGK5.cjs'),chunkHQJ3DJ5D_cjs=require('./chunk-HQJ3DJ5D.cjs');require('./chunk-MYEWIINX.cjs');var chunkWQPMFK4M_cjs=require('./chunk-WQPMFK4M.cjs'),dedot=require('dedot');var h=(t=>(t.NORMAL="normal",t.MULTISIG="multisig",t.PROXY="proxy",t.CONTRACT="contract",t))(h||{});function rr(o){return new dedot.WsProvider(o)}function p({storage:o,keyPrefix:a="luno."}){let e=r=>`${a}${r}`;return {async getItem(r){try{let t=e(r),n=await o.getItem(t);return n==null?null:String(n)}catch(t){return console.error(`[LunoStorage] Error getting item "${r}" (full key: "${e(r)}"):`,t),null}},async setItem(r,t){try{let n=e(r);await o.setItem(n,t);}catch(n){console.error(`[LunoStorage] Error setting item "${r}" (full key: "${e(r)}"):`,n);}},async removeItem(r){try{let t=e(r);await o.removeItem(t);}catch(t){console.error(`[LunoStorage] Error removing item "${r}" (full key: "${e(r)}"):`,t);}}}}var x={getItem:async o=>null,setItem:async(o,a)=>{},removeItem:async o=>{}},b=p({storage:typeof window<"u"&&window.localStorage?window.localStorage:x,keyPrefix:"luno."});function S(o){let a={};for(let e of o){let r=e.rpcUrls.webSocket?.[0];r?a[e.genesisHash]=r:console.warn(`No WebSocket URL found for chain "${e.name}" (${e.genesisHash}). Skipping transport generation.`);}return a}function nr(o){let{appName:a="My Luno App",chains:e,connectors:r,transports:t,storage:n=b,autoConnect:l=true,cacheMetadata:m,metadata:f,scaledResponses:u,customTypes:y,customRpc:d}=o;if(!e||e.length===0)throw new Error("At least one chain must be provided in the `chains` array.");if(!r||r.length===0)throw new Error("No connectors provided. Wallet connection features will be unavailable.");let c=S(e),s=t?{...c,...t}:c;if(!s||Object.keys(s).length===0)throw new Error("Transports must be provided for chains.");for(let i of e)if(!s[i.genesisHash])throw new Error(`Missing transport for chain "${i.name}" (genesisHash: ${i.genesisHash}). Please provide a valid WebSocket URL in the chain configuration or explicit transport.`);let g={customRpc:d,customTypes:y,cacheMetadata:m,metadata:f,scaledResponses:u,appName:a,chains:Object.freeze([...e]),connectors:Object.freeze([...r]),transports:Object.freeze({...s}),storage:n,autoConnect:l};return console.log("[createConfig]: Luno Core Config created:",g),g}Object.defineProperty(exports,"kusama",{enumerable:true,get:function(){return chunkB75MLGK5_cjs.b}});Object.defineProperty(exports,"paseo",{enumerable:true,get:function(){return chunkB75MLGK5_cjs.c}});Object.defineProperty(exports,"polkadot",{enumerable:true,get:function(){return chunkB75MLGK5_cjs.a}});Object.defineProperty(exports,"westend",{enumerable:true,get:function(){return chunkB75MLGK5_cjs.d}});Object.defineProperty(exports,"BaseConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.a}});Object.defineProperty(exports,"novaConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.h}});Object.defineProperty(exports,"novaMobileConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.g}});Object.defineProperty(exports,"polkadotjsConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.b}});Object.defineProperty(exports,"polkagateConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.c}});Object.defineProperty(exports,"subwalletConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.d}});Object.defineProperty(exports,"talismanConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.e}});Object.defineProperty(exports,"walletConnectConnector",{enumerable:true,get:function(){return chunkHQJ3DJ5D_cjs.f}});Object.defineProperty(exports,"convertAddress",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.e}});Object.defineProperty(exports,"defineChain",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.i}});Object.defineProperty(exports,"formatAddress",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.b}});Object.defineProperty(exports,"formatBalance",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.a}});Object.defineProperty(exports,"formatBalanceWithUnit",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.c}});Object.defineProperty(exports,"getChainToken",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.j}});Object.defineProperty(exports,"getExplorerUrl",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.k}});Object.defineProperty(exports,"getPublicKey",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.g}});Object.defineProperty(exports,"isMobileDevice",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.l}});Object.defineProperty(exports,"isSameAddress",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.f}});Object.defineProperty(exports,"isValidAddress",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.d}});Object.defineProperty(exports,"mapInjectedAccounts",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.h}});exports.ACCOUNT_TYPE=h;exports.createConfig=nr;exports.createStorage=p;exports.wsProvider=rr;//# sourceMappingURL=index.cjs.map
1
+ 'use strict';var chunkMFLU4CFP_cjs=require('./chunk-MFLU4CFP.cjs'),chunkJOIV5HSZ_cjs=require('./chunk-JOIV5HSZ.cjs');require('./chunk-MYEWIINX.cjs');var chunkWQPMFK4M_cjs=require('./chunk-WQPMFK4M.cjs'),dedot=require('dedot');var h=(t=>(t.NORMAL="normal",t.MULTISIG="multisig",t.PROXY="proxy",t.CONTRACT="contract",t))(h||{});function er(o){return new dedot.WsProvider(o)}function p({storage:o,keyPrefix:a="luno."}){let e=r=>`${a}${r}`;return {async getItem(r){try{let t=e(r),n=await o.getItem(t);return n==null?null:String(n)}catch(t){return console.error(`[LunoStorage] Error getting item "${r}" (full key: "${e(r)}"):`,t),null}},async setItem(r,t){try{let n=e(r);await o.setItem(n,t);}catch(n){console.error(`[LunoStorage] Error setting item "${r}" (full key: "${e(r)}"):`,n);}},async removeItem(r){try{let t=e(r);await o.removeItem(t);}catch(t){console.error(`[LunoStorage] Error removing item "${r}" (full key: "${e(r)}"):`,t);}}}}var x={getItem:async o=>null,setItem:async(o,a)=>{},removeItem:async o=>{}},b=p({storage:typeof window<"u"&&window.localStorage?window.localStorage:x,keyPrefix:"luno."});function S(o){let a={};for(let e of o){let r=e.rpcUrls.webSocket?.[0];r?a[e.genesisHash]=r:console.warn(`No WebSocket URL found for chain "${e.name}" (${e.genesisHash}). Skipping transport generation.`);}return a}function ar(o){let{appName:a="My Luno App",chains:e,connectors:r,transports:t,storage:n=b,autoConnect:l=true,cacheMetadata:m,metadata:f,scaledResponses:u,customTypes:y,customRpc:d}=o;if(!e||e.length===0)throw new Error("At least one chain must be provided in the `chains` array.");if(!r||r.length===0)throw new Error("No connectors provided. Wallet connection features will be unavailable.");let c=S(e),s=t?{...c,...t}:c;if(!s||Object.keys(s).length===0)throw new Error("Transports must be provided for chains.");for(let i of e)if(!s[i.genesisHash])throw new Error(`Missing transport for chain "${i.name}" (genesisHash: ${i.genesisHash}). Please provide a valid WebSocket URL in the chain configuration or explicit transport.`);let g={customRpc:d,customTypes:y,cacheMetadata:m,metadata:f,scaledResponses:u,appName:a,chains:Object.freeze([...e]),connectors:Object.freeze([...r]),transports:Object.freeze({...s}),storage:n,autoConnect:l};return console.log("[createConfig]: Luno Core Config created:",g),g}Object.defineProperty(exports,"kusama",{enumerable:true,get:function(){return chunkMFLU4CFP_cjs.b}});Object.defineProperty(exports,"paseo",{enumerable:true,get:function(){return chunkMFLU4CFP_cjs.c}});Object.defineProperty(exports,"polkadot",{enumerable:true,get:function(){return chunkMFLU4CFP_cjs.a}});Object.defineProperty(exports,"westend",{enumerable:true,get:function(){return chunkMFLU4CFP_cjs.d}});Object.defineProperty(exports,"BaseConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.a}});Object.defineProperty(exports,"CommonConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.b}});Object.defineProperty(exports,"novaConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.i}});Object.defineProperty(exports,"novaMobileConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.h}});Object.defineProperty(exports,"polkadotjsConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.c}});Object.defineProperty(exports,"polkagateConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.d}});Object.defineProperty(exports,"subwalletConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.e}});Object.defineProperty(exports,"talismanConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.f}});Object.defineProperty(exports,"walletConnectConnector",{enumerable:true,get:function(){return chunkJOIV5HSZ_cjs.g}});Object.defineProperty(exports,"convertAddress",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.e}});Object.defineProperty(exports,"defineChain",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.i}});Object.defineProperty(exports,"formatAddress",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.b}});Object.defineProperty(exports,"formatBalance",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.a}});Object.defineProperty(exports,"formatBalanceWithUnit",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.c}});Object.defineProperty(exports,"getChainToken",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.j}});Object.defineProperty(exports,"getExplorerUrl",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.k}});Object.defineProperty(exports,"getPublicKey",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.g}});Object.defineProperty(exports,"isMobileDevice",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.l}});Object.defineProperty(exports,"isSameAddress",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.f}});Object.defineProperty(exports,"isValidAddress",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.d}});Object.defineProperty(exports,"mapInjectedAccounts",{enumerable:true,get:function(){return chunkWQPMFK4M_cjs.h}});exports.ACCOUNT_TYPE=h;exports.createConfig=ar;exports.createStorage=p;exports.wsProvider=er;//# sourceMappingURL=index.cjs.map
2
2
  //# sourceMappingURL=index.cjs.map
package/dist/index.d.cts CHANGED
@@ -1,7 +1,7 @@
1
- import { C as Chain } from './chain-CCVvkcX7.cjs';
1
+ import { C as Chain } from './chain-9vBVQoCB.cjs';
2
2
  export { b as ACCOUNT_TYPE, A as Account, a as AccountBalance } from './account-DElDu01m.cjs';
3
- import { C as Connector } from './index-wq9QCQkl.cjs';
4
- export { B as BaseConnector, a as ConnectorLinks, S as Signer, W as WalletConnectConnectorOptions, n as novaConnector, c as novaMobileConnector, p as polkadotjsConnector, b as polkagateConnector, s as subwalletConnector, t as talismanConnector, w as walletConnectConnector } from './index-wq9QCQkl.cjs';
3
+ import { C as Connector } from './index-PqPDUdlJ.cjs';
4
+ export { B as BaseConnector, b as CommonConnector, a as ConnectorLinks, S as Signer, W as WalletConnectConnectorOptions, n as novaConnector, d as novaMobileConnector, p as polkadotjsConnector, c as polkagateConnector, s as subwalletConnector, t as talismanConnector, w as walletConnectConnector } from './index-PqPDUdlJ.cjs';
5
5
  import { ApiOptions, WsProvider } from 'dedot';
6
6
  import { AnyShape } from 'dedot/shape';
7
7
  export { kusama, paseo, polkadot, westend } from './chains/index.cjs';
package/dist/index.d.ts CHANGED
@@ -1,7 +1,7 @@
1
- import { C as Chain } from './chain-CCVvkcX7.js';
1
+ import { C as Chain } from './chain-9vBVQoCB.js';
2
2
  export { b as ACCOUNT_TYPE, A as Account, a as AccountBalance } from './account-DElDu01m.js';
3
- import { C as Connector } from './index-CAhh4QRi.js';
4
- export { B as BaseConnector, a as ConnectorLinks, S as Signer, W as WalletConnectConnectorOptions, n as novaConnector, c as novaMobileConnector, p as polkadotjsConnector, b as polkagateConnector, s as subwalletConnector, t as talismanConnector, w as walletConnectConnector } from './index-CAhh4QRi.js';
3
+ import { C as Connector } from './index-Cxsn9zGL.js';
4
+ export { B as BaseConnector, b as CommonConnector, a as ConnectorLinks, S as Signer, W as WalletConnectConnectorOptions, n as novaConnector, d as novaMobileConnector, p as polkadotjsConnector, c as polkagateConnector, s as subwalletConnector, t as talismanConnector, w as walletConnectConnector } from './index-Cxsn9zGL.js';
5
5
  import { ApiOptions, WsProvider } from 'dedot';
6
6
  import { AnyShape } from 'dedot/shape';
7
7
  export { kusama, paseo, polkadot, westend } from './chains/index.js';
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- export{b as kusama,c as paseo,a as polkadot,d as westend}from'./chunk-TK2GOG2I.js';export{a as BaseConnector,h as novaConnector,g as novaMobileConnector,b as polkadotjsConnector,c as polkagateConnector,d as subwalletConnector,e as talismanConnector,f as walletConnectConnector}from'./chunk-2ZADE6DA.js';import'./chunk-LXQJABLC.js';export{e as convertAddress,i as defineChain,b as formatAddress,a as formatBalance,c as formatBalanceWithUnit,j as getChainToken,k as getExplorerUrl,g as getPublicKey,l as isMobileDevice,f as isSameAddress,d as isValidAddress,h as mapInjectedAccounts}from'./chunk-SYUDETGE.js';import {WsProvider}from'dedot';var h=(t=>(t.NORMAL="normal",t.MULTISIG="multisig",t.PROXY="proxy",t.CONTRACT="contract",t))(h||{});function rr(o){return new WsProvider(o)}function p({storage:o,keyPrefix:a="luno."}){let e=r=>`${a}${r}`;return {async getItem(r){try{let t=e(r),n=await o.getItem(t);return n==null?null:String(n)}catch(t){return console.error(`[LunoStorage] Error getting item "${r}" (full key: "${e(r)}"):`,t),null}},async setItem(r,t){try{let n=e(r);await o.setItem(n,t);}catch(n){console.error(`[LunoStorage] Error setting item "${r}" (full key: "${e(r)}"):`,n);}},async removeItem(r){try{let t=e(r);await o.removeItem(t);}catch(t){console.error(`[LunoStorage] Error removing item "${r}" (full key: "${e(r)}"):`,t);}}}}var x={getItem:async o=>null,setItem:async(o,a)=>{},removeItem:async o=>{}},b=p({storage:typeof window<"u"&&window.localStorage?window.localStorage:x,keyPrefix:"luno."});function S(o){let a={};for(let e of o){let r=e.rpcUrls.webSocket?.[0];r?a[e.genesisHash]=r:console.warn(`No WebSocket URL found for chain "${e.name}" (${e.genesisHash}). Skipping transport generation.`);}return a}function nr(o){let{appName:a="My Luno App",chains:e,connectors:r,transports:t,storage:n=b,autoConnect:l=true,cacheMetadata:m,metadata:f,scaledResponses:u,customTypes:y,customRpc:d}=o;if(!e||e.length===0)throw new Error("At least one chain must be provided in the `chains` array.");if(!r||r.length===0)throw new Error("No connectors provided. Wallet connection features will be unavailable.");let c=S(e),s=t?{...c,...t}:c;if(!s||Object.keys(s).length===0)throw new Error("Transports must be provided for chains.");for(let i of e)if(!s[i.genesisHash])throw new Error(`Missing transport for chain "${i.name}" (genesisHash: ${i.genesisHash}). Please provide a valid WebSocket URL in the chain configuration or explicit transport.`);let g={customRpc:d,customTypes:y,cacheMetadata:m,metadata:f,scaledResponses:u,appName:a,chains:Object.freeze([...e]),connectors:Object.freeze([...r]),transports:Object.freeze({...s}),storage:n,autoConnect:l};return console.log("[createConfig]: Luno Core Config created:",g),g}export{h as ACCOUNT_TYPE,nr as createConfig,p as createStorage,rr as wsProvider};//# sourceMappingURL=index.js.map
1
+ export{b as kusama,c as paseo,a as polkadot,d as westend}from'./chunk-GFMVMUPH.js';export{a as BaseConnector,b as CommonConnector,i as novaConnector,h as novaMobileConnector,c as polkadotjsConnector,d as polkagateConnector,e as subwalletConnector,f as talismanConnector,g as walletConnectConnector}from'./chunk-VGX4US5T.js';import'./chunk-LXQJABLC.js';export{e as convertAddress,i as defineChain,b as formatAddress,a as formatBalance,c as formatBalanceWithUnit,j as getChainToken,k as getExplorerUrl,g as getPublicKey,l as isMobileDevice,f as isSameAddress,d as isValidAddress,h as mapInjectedAccounts}from'./chunk-SYUDETGE.js';import {WsProvider}from'dedot';var h=(t=>(t.NORMAL="normal",t.MULTISIG="multisig",t.PROXY="proxy",t.CONTRACT="contract",t))(h||{});function er(o){return new WsProvider(o)}function p({storage:o,keyPrefix:a="luno."}){let e=r=>`${a}${r}`;return {async getItem(r){try{let t=e(r),n=await o.getItem(t);return n==null?null:String(n)}catch(t){return console.error(`[LunoStorage] Error getting item "${r}" (full key: "${e(r)}"):`,t),null}},async setItem(r,t){try{let n=e(r);await o.setItem(n,t);}catch(n){console.error(`[LunoStorage] Error setting item "${r}" (full key: "${e(r)}"):`,n);}},async removeItem(r){try{let t=e(r);await o.removeItem(t);}catch(t){console.error(`[LunoStorage] Error removing item "${r}" (full key: "${e(r)}"):`,t);}}}}var x={getItem:async o=>null,setItem:async(o,a)=>{},removeItem:async o=>{}},b=p({storage:typeof window<"u"&&window.localStorage?window.localStorage:x,keyPrefix:"luno."});function S(o){let a={};for(let e of o){let r=e.rpcUrls.webSocket?.[0];r?a[e.genesisHash]=r:console.warn(`No WebSocket URL found for chain "${e.name}" (${e.genesisHash}). Skipping transport generation.`);}return a}function ar(o){let{appName:a="My Luno App",chains:e,connectors:r,transports:t,storage:n=b,autoConnect:l=true,cacheMetadata:m,metadata:f,scaledResponses:u,customTypes:y,customRpc:d}=o;if(!e||e.length===0)throw new Error("At least one chain must be provided in the `chains` array.");if(!r||r.length===0)throw new Error("No connectors provided. Wallet connection features will be unavailable.");let c=S(e),s=t?{...c,...t}:c;if(!s||Object.keys(s).length===0)throw new Error("Transports must be provided for chains.");for(let i of e)if(!s[i.genesisHash])throw new Error(`Missing transport for chain "${i.name}" (genesisHash: ${i.genesisHash}). Please provide a valid WebSocket URL in the chain configuration or explicit transport.`);let g={customRpc:d,customTypes:y,cacheMetadata:m,metadata:f,scaledResponses:u,appName:a,chains:Object.freeze([...e]),connectors:Object.freeze([...r]),transports:Object.freeze({...s}),storage:n,autoConnect:l};return console.log("[createConfig]: Luno Core Config created:",g),g}export{h as ACCOUNT_TYPE,ar as createConfig,p as createStorage,er as wsProvider};//# sourceMappingURL=index.js.map
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types/account.ts","../src/config/providers.ts","../src/config/createStorage.ts","../src/config/createConfig.ts"],"names":["ACCOUNT_TYPE","wsProvider","url","WsProvider","createStorage","storage","keyPrefix","getKey","suffix","keySuffix","fullKey","value","error","noopStorage","_key","_value","defaultLunoStorage","generateTransportsFromChains","chains","transports","chain","wsUrl","createConfig","parameters","appName","connectors","autoConnect","cacheMetadata","metadata","scaledResponses","customTypes","customRpc","transportsFromChains","finalTransports","config"],"mappings":"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","file":"index.js","sourcesContent":["import type { HexString } from 'dedot/utils'\nimport type { KeypairType } from 'dedot/types'\n\n/**\n * Polkadot account interface\n * Represents a chain account\n */\nexport interface Account {\n /**\n * account address (original format from wallet)\n * specific SS58 formatting should be done in the React layer based on the chain.\n */\n address: string;\n\n /** account name (if any) */\n name?: string;\n\n /**\n * account public key (hex format, without 0x prefix)\n * used for cross-chain address conversion and verification\n */\n publicKey?: HexString;\n\n /**\n * other metadata\n * including account source, control method, etc.\n */\n meta?: {\n /** account source (e.g. 'polkadot-js', 'subwallet-js', 'talisman' etc.) */\n source?: string;\n\n /** genesis hash (if the wallet provides a specific chain account) */\n genesisHash?: string | null;\n\n /** other custom metadata */\n [key: string]: any;\n };\n type?: KeypairType\n}\n\n/**\n * account balance information\n */\nexport interface AccountBalance {\n /** available balance (in smallest unit) */\n free: bigint;\n\n /** total balance (in smallest unit) */\n total: bigint;\n\n /** reserved balance (in smallest unit) */\n reserved: bigint;\n\n /**\n * transferable balance (in smallest unit)\n * free minus various locked amounts\n */\n transferable: bigint;\n\n /** formatted available balance (with unit, for display) */\n formattedTransferable: string;\n\n /** formatted total balance (with unit, for display) */\n formattedTotal: string;\n\n /** lock details (if any) */\n locks?: Array<{\n id: string;\n amount: bigint;\n reason: string;\n lockHuman: string;\n }>;\n}\n\n/**\n * account type enum\n */\nexport enum ACCOUNT_TYPE {\n /** normal account */\n NORMAL = 'normal',\n\n /** multisig account */\n MULTISIG = 'multisig',\n\n /** proxy account */\n PROXY = 'proxy',\n\n /** smart contract account */\n CONTRACT = 'contract',\n}\n","import { WsProvider } from 'dedot';\nimport type { Transport } from '../types';\n\n/**\n * create a WebSocket Transport (WsProvider) instance.\n * @param url - WebSocket RPC URL or URL array (for fallback).\n * @returns WsProvider instance.\n */\nexport function wsProvider(\n url: string | string[],\n): WsProvider {\n return new WsProvider(url);\n}\n\nexport type { Transport };\n","import type { LunoStorage, RawStorage } from '../types'\n\n// Defines the parameters for the createStorage function.\nexport interface CreateStorageParameters {\n storage: RawStorage;\n keyPrefix?: string; // Optional key prefix, e.g., \"luno.\"\n}\n\n/**\n * Creates a LunoStorage object that wraps a raw storage mechanism (like localStorage)\n * to provide a consistent async API with key prefixing and error handling.\n *\n * @param storage The raw storage mechanism (e.g., window.localStorage).\n * @param keyPrefix An optional prefix for all storage keys to avoid collisions.\n * @returns A LunoStorage object.\n */\nexport function createStorage({\n storage,\n keyPrefix = 'luno.', // Default key prefix\n}: CreateStorageParameters): LunoStorage {\n const getKey = (suffix: string): string => `${keyPrefix}${suffix}`;\n\n return {\n async getItem(keySuffix: string): Promise<string | null> {\n try {\n const fullKey = getKey(keySuffix);\n // Await to handle both sync and async RawStorage getItem methods consistently\n const value = await storage.getItem(fullKey);\n // Normalize undefined or null to null\n return value == null ? null : String(value);\n } catch (error) {\n console.error(`[LunoStorage] Error getting item \"${keySuffix}\" (full key: \"${getKey(keySuffix)}\"):`, error);\n return null; // Return null on error to indicate failure\n }\n },\n\n async setItem(keySuffix: string, value: string): Promise<void> {\n try {\n const fullKey = getKey(keySuffix);\n // Await to handle both sync and async RawStorage setItem methods consistently\n await storage.setItem(fullKey, value);\n } catch (error) {\n console.error(`[LunoStorage] Error setting item \"${keySuffix}\" (full key: \"${getKey(keySuffix)}\"):`, error);\n // Errors during setItem are logged but don't typically need to be propagated further in the same way getItem might.\n }\n },\n\n async removeItem(keySuffix: string): Promise<void> {\n try {\n const fullKey = getKey(keySuffix);\n // Await to handle both sync and async RawStorage removeItem methods consistently\n await storage.removeItem(fullKey);\n } catch (error) {\n console.error(`[LunoStorage] Error removing item \"${keySuffix}\" (full key: \"${getKey(keySuffix)}\"):`, error);\n }\n },\n };\n}\n","import type {\n CreateConfigParameters,\n Config,\n Chain,\n Connector,\n Transport,\n RawStorage,\n} from '../types';\nimport { createStorage } from './createStorage'\n\nconst noopStorage: RawStorage = {\n getItem: async (_key: string) => null,\n setItem: async (_key: string, _value: string) => {},\n removeItem: async (_key: string) => {},\n};\n\nconst defaultLunoStorage = createStorage({\n storage: typeof window !== 'undefined' && window.localStorage\n ? window.localStorage\n : noopStorage,\n keyPrefix: 'luno.',\n});\n\nfunction generateTransportsFromChains(chains: readonly Chain[]): Record<string, Transport> {\n const transports: Record<string, Transport> = {};\n\n for (const chain of chains) {\n const wsUrl = chain.rpcUrls.webSocket?.[0];\n if (wsUrl) {\n transports[chain.genesisHash] = wsUrl;\n } else {\n console.warn(`No WebSocket URL found for chain \"${chain.name}\" (${chain.genesisHash}). Skipping transport generation.`);\n }\n }\n\n return transports;\n}\n\nexport function createConfig(parameters: CreateConfigParameters): Config {\n const {\n appName = 'My Luno App',\n chains,\n connectors,\n transports,\n storage = defaultLunoStorage,\n autoConnect = true,\n cacheMetadata,\n metadata,\n scaledResponses,\n customTypes,\n customRpc,\n } = parameters;\n\n if (!chains || chains.length === 0) {\n throw new Error('At least one chain must be provided in the `chains` array.');\n }\n if (!connectors || connectors.length === 0) {\n throw new Error('No connectors provided. Wallet connection features will be unavailable.');\n }\n\n const transportsFromChains = generateTransportsFromChains(chains);\n\n const finalTransports = transports\n ? { ...transportsFromChains, ...transports }\n : transportsFromChains;\n\n if (!finalTransports || Object.keys(finalTransports).length === 0) {\n throw new Error('Transports must be provided for chains.');\n }\n\n for (const chain of chains) {\n if (!finalTransports[chain.genesisHash]) {\n throw new Error(`Missing transport for chain \"${chain.name}\" (genesisHash: ${chain.genesisHash}). Please provide a valid WebSocket URL in the chain configuration or explicit transport.`);\n }\n }\n\n const config = {\n customRpc,\n customTypes,\n cacheMetadata,\n metadata,\n scaledResponses,\n\n appName,\n chains: Object.freeze([...chains]) as readonly Chain[],\n connectors: Object.freeze([...connectors]) as readonly Connector[],\n transports: Object.freeze({ ...finalTransports }) as Readonly<Record<string, Transport>>,\n storage,\n autoConnect,\n };\n\n console.log('[createConfig]: Luno Core Config created:', config);\n\n return config;\n}\n"]}
1
+ {"version":3,"sources":["../src/types/account.ts","../src/config/providers.ts","../src/config/createStorage.ts","../src/config/createConfig.ts"],"names":["ACCOUNT_TYPE","wsProvider","url","WsProvider","createStorage","storage","keyPrefix","getKey","suffix","keySuffix","fullKey","value","error","noopStorage","_key","_value","defaultLunoStorage","generateTransportsFromChains","chains","transports","chain","wsUrl","createConfig","parameters","appName","connectors","autoConnect","cacheMetadata","metadata","scaledResponses","customTypes","customRpc","transportsFromChains","finalTransports","config"],"mappings":"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","file":"index.js","sourcesContent":["import type { HexString } from 'dedot/utils'\nimport type { KeypairType } from 'dedot/types'\n\n/**\n * Polkadot account interface\n * Represents a chain account\n */\nexport interface Account {\n /**\n * account address (original format from wallet)\n * specific SS58 formatting should be done in the React layer based on the chain.\n */\n address: string;\n\n /** account name (if any) */\n name?: string;\n\n /**\n * account public key (hex format, without 0x prefix)\n * used for cross-chain address conversion and verification\n */\n publicKey?: HexString;\n\n /**\n * other metadata\n * including account source, control method, etc.\n */\n meta?: {\n /** account source (e.g. 'polkadot-js', 'subwallet-js', 'talisman' etc.) */\n source?: string;\n\n /** genesis hash (if the wallet provides a specific chain account) */\n genesisHash?: string | null;\n\n /** other custom metadata */\n [key: string]: any;\n };\n type?: KeypairType\n}\n\n/**\n * account balance information\n */\nexport interface AccountBalance {\n /** available balance (in smallest unit) */\n free: bigint;\n\n /** total balance (in smallest unit) */\n total: bigint;\n\n /** reserved balance (in smallest unit) */\n reserved: bigint;\n\n /**\n * transferable balance (in smallest unit)\n * free minus various locked amounts\n */\n transferable: bigint;\n\n /** formatted available balance (with unit, for display) */\n formattedTransferable: string;\n\n /** formatted total balance (with unit, for display) */\n formattedTotal: string;\n\n /** lock details (if any) */\n locks?: Array<{\n id: string;\n amount: bigint;\n reason: string;\n lockHuman: string;\n }>;\n}\n\n/**\n * account type enum\n */\nexport enum ACCOUNT_TYPE {\n /** normal account */\n NORMAL = 'normal',\n\n /** multisig account */\n MULTISIG = 'multisig',\n\n /** proxy account */\n PROXY = 'proxy',\n\n /** smart contract account */\n CONTRACT = 'contract',\n}\n","import { WsProvider } from 'dedot';\nimport type { Transport } from '../types';\n\n/**\n * create a WebSocket Transport (WsProvider) instance.\n * @param url - WebSocket RPC URL or URL array (for fallback).\n * @returns WsProvider instance.\n */\nexport function wsProvider(\n url: string | string[],\n): WsProvider {\n return new WsProvider(url);\n}\n\nexport type { Transport };\n","import type { LunoStorage, RawStorage } from '../types'\n\n// Defines the parameters for the createStorage function.\nexport interface CreateStorageParameters {\n storage: RawStorage;\n keyPrefix?: string; // Optional key prefix, e.g., \"luno.\"\n}\n\n/**\n * Creates a LunoStorage object that wraps a raw storage mechanism (like localStorage)\n * to provide a consistent async API with key prefixing and error handling.\n *\n * @param storage The raw storage mechanism (e.g., window.localStorage).\n * @param keyPrefix An optional prefix for all storage keys to avoid collisions.\n * @returns A LunoStorage object.\n */\nexport function createStorage({\n storage,\n keyPrefix = 'luno.', // Default key prefix\n}: CreateStorageParameters): LunoStorage {\n const getKey = (suffix: string): string => `${keyPrefix}${suffix}`;\n\n return {\n async getItem(keySuffix: string): Promise<string | null> {\n try {\n const fullKey = getKey(keySuffix);\n // Await to handle both sync and async RawStorage getItem methods consistently\n const value = await storage.getItem(fullKey);\n // Normalize undefined or null to null\n return value == null ? null : String(value);\n } catch (error) {\n console.error(`[LunoStorage] Error getting item \"${keySuffix}\" (full key: \"${getKey(keySuffix)}\"):`, error);\n return null; // Return null on error to indicate failure\n }\n },\n\n async setItem(keySuffix: string, value: string): Promise<void> {\n try {\n const fullKey = getKey(keySuffix);\n // Await to handle both sync and async RawStorage setItem methods consistently\n await storage.setItem(fullKey, value);\n } catch (error) {\n console.error(`[LunoStorage] Error setting item \"${keySuffix}\" (full key: \"${getKey(keySuffix)}\"):`, error);\n // Errors during setItem are logged but don't typically need to be propagated further in the same way getItem might.\n }\n },\n\n async removeItem(keySuffix: string): Promise<void> {\n try {\n const fullKey = getKey(keySuffix);\n // Await to handle both sync and async RawStorage removeItem methods consistently\n await storage.removeItem(fullKey);\n } catch (error) {\n console.error(`[LunoStorage] Error removing item \"${keySuffix}\" (full key: \"${getKey(keySuffix)}\"):`, error);\n }\n },\n };\n}\n","import type {\n CreateConfigParameters,\n Config,\n Chain,\n Connector,\n Transport,\n RawStorage,\n} from '../types';\nimport { createStorage } from './createStorage'\n\nconst noopStorage: RawStorage = {\n getItem: async (_key: string) => null,\n setItem: async (_key: string, _value: string) => {},\n removeItem: async (_key: string) => {},\n};\n\nconst defaultLunoStorage = createStorage({\n storage: typeof window !== 'undefined' && window.localStorage\n ? window.localStorage\n : noopStorage,\n keyPrefix: 'luno.',\n});\n\nfunction generateTransportsFromChains(chains: readonly Chain[]): Record<string, Transport> {\n const transports: Record<string, Transport> = {};\n\n for (const chain of chains) {\n const wsUrl = chain.rpcUrls.webSocket?.[0];\n if (wsUrl) {\n transports[chain.genesisHash] = wsUrl;\n } else {\n console.warn(`No WebSocket URL found for chain \"${chain.name}\" (${chain.genesisHash}). Skipping transport generation.`);\n }\n }\n\n return transports;\n}\n\nexport function createConfig(parameters: CreateConfigParameters): Config {\n const {\n appName = 'My Luno App',\n chains,\n connectors,\n transports,\n storage = defaultLunoStorage,\n autoConnect = true,\n cacheMetadata,\n metadata,\n scaledResponses,\n customTypes,\n customRpc,\n } = parameters;\n\n if (!chains || chains.length === 0) {\n throw new Error('At least one chain must be provided in the `chains` array.');\n }\n if (!connectors || connectors.length === 0) {\n throw new Error('No connectors provided. Wallet connection features will be unavailable.');\n }\n\n const transportsFromChains = generateTransportsFromChains(chains);\n\n const finalTransports = transports\n ? { ...transportsFromChains, ...transports }\n : transportsFromChains;\n\n if (!finalTransports || Object.keys(finalTransports).length === 0) {\n throw new Error('Transports must be provided for chains.');\n }\n\n for (const chain of chains) {\n if (!finalTransports[chain.genesisHash]) {\n throw new Error(`Missing transport for chain \"${chain.name}\" (genesisHash: ${chain.genesisHash}). Please provide a valid WebSocket URL in the chain configuration or explicit transport.`);\n }\n }\n\n const config = {\n customRpc,\n customTypes,\n cacheMetadata,\n metadata,\n scaledResponses,\n\n appName,\n chains: Object.freeze([...chains]) as readonly Chain[],\n connectors: Object.freeze([...connectors]) as readonly Connector[],\n transports: Object.freeze({ ...finalTransports }) as Readonly<Record<string, Transport>>,\n storage,\n autoConnect,\n };\n\n console.log('[createConfig]: Luno Core Config created:', config);\n\n return config;\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { A as Account } from '../account-DElDu01m.cjs';
2
2
  import { InjectedAccount } from 'dedot/types';
3
- import { C as Chain } from '../chain-CCVvkcX7.cjs';
3
+ import { C as Chain } from '../chain-9vBVQoCB.cjs';
4
4
  export { formatBalance as formatBalanceWithUnit } from 'dedot/utils';
5
5
 
6
6
  /**
@@ -1,6 +1,6 @@
1
1
  import { A as Account } from '../account-DElDu01m.js';
2
2
  import { InjectedAccount } from 'dedot/types';
3
- import { C as Chain } from '../chain-CCVvkcX7.js';
3
+ import { C as Chain } from '../chain-9vBVQoCB.js';
4
4
  export { formatBalance as formatBalanceWithUnit } from 'dedot/utils';
5
5
 
6
6
  /**
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@luno-kit/core",
3
3
  "description": "Core module for Luno, providing foundational utilities, types, configuration, and connectors for Polkadot wallet interactions.",
4
- "version": "0.0.5",
4
+ "version": "0.0.6",
5
5
  "type": "module",
6
6
  "keywords": [
7
7
  "polkadot",
@@ -1,3 +0,0 @@
1
- import {e,f as f$1,g,h as h$1,i as i$1,b as b$1}from'./chunk-LXQJABLC.js';import {h,l}from'./chunk-SYUDETGE.js';import {EventEmitter}from'eventemitter3';import {stringToHex}from'dedot/utils';var a=class extends EventEmitter{constructor(){super();this.links={};this.accounts=[];this.signer=void 0;this.connectionUri=void 0;}async getAccounts(){return [...this.accounts]}async getSigner(){return this.signer||console.warn(`Connector ${this.id}: Signer not available. Connection might be incomplete or failed.`),this.signer}hasConnectionUri(){return false}async getConnectionUri(){return this.connectionUri}async updateAccountsForChain(t){return [...this.accounts]}};var i=class extends a{constructor(t){super();this.unsubscribe=null;this.specificInjector=void 0;this.id=t.id,this.name=t.name,this.icon=t.icon,this.links=t.links,this.injectorId=t.injectorId||t.id;}isInstalled(){if(typeof window>"u")return false;let t=window.injectedWeb3;return typeof t=="object"&&typeof t[this.injectorId]<"u"}async isAvailable(){return this.isInstalled()}async connect(t){if(console.log(`Connector ${this.id}: Attempting to connect...`),this.signer)return console.log(`Connector ${this.id}: Already connected.`),[...this.accounts];if(!await this.isAvailable())throw new Error(`${this.name} extension not found or not enabled.`);try{if(this.specificInjector=await window.injectedWeb3[this.injectorId].enable(t),!this.specificInjector)throw new Error(`Failed to enable the '${this.id}' extension.`);if(this.signer=this.specificInjector.signer,!this.signer)throw new Error(`Could not get signer from ${this.name}.`);let n=await this.specificInjector.accounts.get();if(n.length===0)throw new Error(`No accounts found in ${this.name}. Make sure accounts are visible and access is granted.`);return this.accounts=h(n,this.id),console.log(`Connector ${this.id}: Initial accounts loaded`,this.accounts),await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}catch(n){throw console.error(`Connector ${this.id}: Connection failed:`,n),await this.cleanup(),n}}async disconnect(){console.log(`Connector ${this.id}: Disconnecting...`),await this.cleanup(),this.emit("disconnect");}async signMessage(t,n){if(!n||!t)return;let s=await this.getSigner();if(!s||!s?.signRaw)throw new Error("Signer is not available or does not support signRaw.");if(!(await this.getAccounts()).some(e=>e.address.toLowerCase()===n.toLowerCase()))throw new Error(`Address ${n} is not managed by ${this.name}.`);try{let e=stringToHex(t);return (await s.signRaw({address:n,data:e,type:"bytes"})).signature}catch(e){throw new Error(`Connector ${this.id}: Failed to sign message: ${e.message}`)}}async startSubscription(){if(await this.cleanupSubscription(),!this.specificInjector)throw new Error(`Connector ${this.id}: Cannot subscribe, specificInjector not available.`);try{this.unsubscribe=this.specificInjector.accounts.subscribe(t=>{let n=h(t,this.id);JSON.stringify(this.accounts)!==JSON.stringify(n)&&(this.accounts=n,this.emit("accountsChanged",[...this.accounts]));}),console.log(`Connector ${this.id}: Subscribed to account changes.`);}catch(t){console.error(`Connector ${this.id}: Failed to subscribe to accounts:`,t),this.unsubscribe=null;}}async cleanupSubscription(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=null,console.log(`Connector ${this.id}: Unsubscribed from account changes.`));}async cleanup(){await this.cleanupSubscription(),this.accounts=[],this.signer=void 0,this.specificInjector=void 0;}};var P=()=>new i({id:"polkadot-js",name:"Polkadot{.js}",icon:e,links:{browserExtension:"https://polkadot.js.org/extension"}});var x=()=>new i({id:"polkagate",name:"Polkagate",icon:f$1,links:{browserExtension:"https://chromewebstore.google.com/detail/polkagate-the-gateway-to/ginchbkmljhldofnbjabmeophlhdldgp"}});var $=()=>new i({id:"subwallet-js",name:"SubWallet",icon:g,links:{browserExtension:"https://chromewebstore.google.com/detail/subwallet-polkadot-wallet/onhogfjeacnfoofkfgppdlbmlmnplgbn",deepLink:"https://mobile.subwallet.app/browser"}});var E=()=>new i({id:"talisman",name:"Talisman",icon:h$1,links:{browserExtension:"https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld"}});var u=class extends a{constructor(t){super();this.unsubscribe=null;this.id=t.id||"walletconnect",this.name=t.name||"WalletConnect",this.links=t.links||{},this.icon=t.icon||i$1,this.projectId=t.projectId,this.relayUrl=t.relayUrl||"wss://relay.walletconnect.com",this.metadata=t.metadata;}isInstalled(){return false}async isAvailable(){return true}convertChainIdToCaipId(t){return t.map(n=>`polkadot:${n.genesisHash.replace("0x","").slice(0,32)}`)}async connect(t,n,s){if(!this.projectId)throw new Error(`${this.name} requires a projectId. Please visit https://cloud.walletconnect.com to get one.`);if(!n||n.length===0)throw new Error(`${this.name} requires chains configuration.`);this.connectedChains=n;let{UniversalProvider:c}=await import('@walletconnect/universal-provider');try{this.provider=await c.init({projectId:this.projectId,relayUrl:this.relayUrl,metadata:this.metadata||{name:t,description:"LunoKit DApp",url:typeof window<"u"?window.location.origin:"",icons:[this.icon]}});let e=s||n[0].genesisHash;if(this.provider.session){this.session=this.provider.session;let j=this.getAccountsFromSession(n,e);return this.accounts=j,await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}if(!this.provider?.client)throw new Error("Provider not initialized or not connected");let{uri:p,approval:o}=await this.provider.client.connect({requiredNamespaces:{polkadot:{methods:["polkadot_signMessage","polkadot_sendTransaction","polkadot_signTransaction","polkadot_requestAccounts"],chains:this.convertChainIdToCaipId(n),events:["accountsChanged","chainChanged","connect"]}},optionalNamespaces:{polkadot:{methods:["polkadot_signMessage","polkadot_sendTransaction","polkadot_signTransaction","polkadot_requestAccounts"],chains:this.convertChainIdToCaipId(n),events:["accountsChanged","chainChanged","connect"]}}});this.emit("get_uri",p);let l=await o();this.session=l,this.provider.session=l,this.connectionUri=void 0;let I=this.getAccountsFromSession(n,e);return this.accounts=I,await this.startSubscription(),this.emit("connect",[...this.accounts]),[...this.accounts]}catch(e){throw this.connectionUri=void 0,e}}getAccountsFromSession(t,n){let s=t.filter(o=>o.genesisHash.toLowerCase()===n.toLowerCase()),c=this.convertChainIdToCaipId(s)[0],e=this.session?.namespaces.polkadot.accounts.flat().filter(o=>o.includes(c)).map(o=>o.replace(`${c}:`,""));if(e&&e.length===0){console.error("No accounts found for the specified chain, please connect to the correct chain");let o=this.convertChainIdToCaipId(t)[0];e=this.session?.namespaces.polkadot.accounts.flat().filter(l=>l.includes(o)).map(l=>l.replace(`${o}:`,""));}let p=e.map(o=>({address:o,name:`${this.name} Account`,meta:{source:this.id},publicKey:void 0}));return this.emit("accountsChanged",[...p]),p}async disconnect(){this.provider&&(console.log("this.provider",this.provider),console.log("this.sessionsession",this.session),await this.provider.disconnect()),await this.cleanup(),this.emit("disconnect");}async signMessage(t,n,s){if(!this.provider?.client||!this.session?.topic)throw new Error("Provider not initialized or not connected");let c=s?`polkadot:${s.replace("0x","").slice(0,32)}`:this.convertChainIdToCaipId(this.connectedChains)[0];try{return (await this.provider.client.request({topic:this.session.topic,chainId:c,request:{method:"polkadot_signMessage",params:{address:n,message:t,type:"bytes"}}}))?.signature}catch(e){throw console.error("Sign message error:",e),e}}hasConnectionUri(){return true}async getConnectionUri(){return this.connectionUri?this.connectionUri:new Promise(t=>{this.once("get_uri",n=>{this.connectionUri=n,t(n);});})}async updateAccountsForChain(t){if(!this.connectedChains)throw new Error("WalletConnect not connected");let n=this.getAccountsFromSession(this.connectedChains,t);return this.accounts=n,n}async getSigner(){if(!(!this.provider?.client||!this.session))return {signPayload:async t=>{try{return await this.provider?.client?.request({topic:this.session.topic,chainId:`polkadot:${t.genesisHash.replace("0x","").slice(0,32)}`,request:{method:"polkadot_signTransaction",params:{address:t.address,transactionPayload:t}}})}catch(n){throw new Error(`Transaction signing failed: ${JSON.stringify(n)}`)}}}}async startSubscription(){if(await this.cleanupSubscription(),!this.provider?.client||!this.session)throw new Error(`Connector ${this.id}: Cannot subscribe, provider or session not available.`);try{let t=async()=>{console.log(`Connector ${this.id}: Session deleted, disconnecting...`),await this.cleanup(),this.emit("disconnect");};this.provider.client.on("session_delete",t),this.unsubscribe=()=>{this.provider?.client?.off("session_delete",t);};}catch{this.unsubscribe=null;}}async cleanupSubscription(){this.unsubscribe&&(this.unsubscribe(),this.unsubscribe=null,console.log(`Connector ${this.id}: Unsubscribed from events.`));}async cleanup(){await this.cleanupSubscription(),this.accounts=[],this.signer=void 0,this.provider=void 0,this.session=void 0;}},U=r=>new u(r);var b=class extends i{constructor(){super({id:"nova-mobile",name:"Nova Wallet",icon:b$1,injectorId:"polkadot-js",links:{deepLink:"https://app.novawallet.io/open/dapp"}});}isInstalled(){if(typeof window>"u")return false;let d=window.injectedWeb3;return typeof d=="object"&&typeof d["polkadot-js"]<"u"&&window.walletExtension?.isNovaWallet===true}async isAvailable(){return this.isInstalled()}},f=()=>new b;var W=r=>{if(r.mobileOnly&&!l())throw new Error("Nova Wallet mobile connector cannot be used on desktop devices");if(r.mobileOnly)throw new Error("Nova Wallet is not installed. Please install Nova Wallet to continue.");return l()?f():new u({id:"nova",name:"Nova Wallet",icon:b$1,links:{browserExtension:"https://novawallet.io"},...r})};
2
- export{a,P as b,x as c,$ as d,E as e,U as f,f as g,W as h};//# sourceMappingURL=chunk-2ZADE6DA.js.map
3
- //# sourceMappingURL=chunk-2ZADE6DA.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/connectors/base.ts","../src/connectors/common.ts","../src/connectors/polkadot-js.ts","../src/connectors/polkagate.ts","../src/connectors/subwallet.ts","../src/connectors/talisman.ts","../src/connectors/walletconnect.ts","../src/connectors/novaMobile.ts","../src/connectors/nova.ts"],"names":["BaseConnector","EventEmitter","chainId","CommonConnector","options","injectedWeb3","appName","rawAccounts","mapInjectedAccounts","error","message","address","signer","acc","dataHex","stringToHex","updatedRawAccounts","newAccounts","polkadotjsConnector","polkadotjsSVG","polkagateConnector","polkagateSVG","subwalletConnector","subwalletSVG","talismanConnector","talismanSVG","WalletConnectConnector","walletconnectSVG","chains","chain","targetChainId","UniversalProvider","chainIdToUse","accounts","uri","approval","session","targetChain","caipId","result","resolve","payload","sessionDeleteHandler","walletConnectConnector","NovaMobileConnector","novaSVG","novaMobileConnector","novaConnector","config","isMobileDevice"],"mappings":"+LAQO,IAAeA,EAAf,cAAqCC,YAAa,CAiCvD,WAAA,EAAc,CACZ,OAAM,CAfR,IAAA,CAAS,MAAwB,EAAC,CAKlC,KAAU,QAAA,CAAsB,GAKhC,IAAA,CAAU,MAAA,CAA6B,OAEvC,IAAA,CAAU,aAAA,CAAoC,OAI9C,CA6BA,MAAa,aAAuC,CAClD,OAAO,CAAC,GAAG,IAAA,CAAK,QAAQ,CAC1B,CAMA,MAAa,SAAA,EAAyC,CACpD,OAAK,IAAA,CAAK,MAAA,EACR,QAAQ,IAAA,CAAK,CAAA,UAAA,EAAa,KAAK,EAAE,CAAA,iEAAA,CAAmE,EAE/F,IAAA,CAAK,MACd,CAOO,gBAAA,EAA4B,CACjC,OAAO,MACT,CAEA,MAAa,gBAAA,EAAgD,CAC3D,OAAO,IAAA,CAAK,aACd,CAEA,MAAa,sBAAA,CAAuBC,EAAqC,CACvE,OAAO,CAAC,GAAG,IAAA,CAAK,QAAQ,CAC1B,CACF,ECxFO,IAAMC,EAAN,cAA8BH,CAAc,CAWjD,WAAA,CAAYI,CAAAA,CAAiC,CAC3C,KAAA,EAAM,CALR,IAAA,CAAQ,WAAA,CAAmC,IAAA,CAE3C,IAAA,CAAQ,iBAA8B,MAAA,CAIpC,IAAA,CAAK,GAAKA,CAAAA,CAAQ,EAAA,CAClB,KAAK,IAAA,CAAOA,CAAAA,CAAQ,KACpB,IAAA,CAAK,IAAA,CAAOA,EAAQ,IAAA,CACpB,IAAA,CAAK,MAAQA,CAAAA,CAAQ,KAAA,CACrB,KAAK,UAAA,CAAaA,CAAAA,CAAQ,YAAcA,CAAAA,CAAQ,GAClD,CAEO,WAAA,EAAuB,CAC5B,GAAI,OAAO,MAAA,CAAW,IAAa,OAAO,MAAA,CAC1C,IAAMC,CAAAA,CAAe,MAAA,CAAO,aAC5B,OAAO,OAAOA,GAAiB,QAAA,EAAY,OAAOA,EAAa,IAAA,CAAK,UAAU,EAAM,GACtF,CAEA,MAAa,WAAA,EAAgC,CAC3C,OAAO,IAAA,CAAK,WAAA,EACd,CAEA,MAAa,QAAQC,CAAAA,CAA0C,CAE7D,GADA,OAAA,CAAQ,GAAA,CAAI,aAAa,IAAA,CAAK,EAAE,4BAA4B,CAAA,CACxD,IAAA,CAAK,OACP,OAAA,OAAA,CAAQ,GAAA,CAAI,aAAa,IAAA,CAAK,EAAE,sBAAsB,CAAA,CAC/C,CAAC,GAAG,IAAA,CAAK,QAAQ,EAE1B,GAAI,CAAE,MAAM,IAAA,CAAK,WAAA,GACf,MAAM,IAAI,MAAM,CAAA,EAAG,IAAA,CAAK,IAAI,CAAA,oCAAA,CAAsC,CAAA,CAGpE,GAAI,CAGF,GAFA,IAAA,CAAK,iBAAmB,MAAM,MAAA,CAAO,aAAc,IAAA,CAAK,UAAU,EAAG,MAAA,CAAOA,CAAO,EAE/E,CAAC,IAAA,CAAK,iBACR,MAAM,IAAI,MAAM,CAAA,sBAAA,EAAyB,IAAA,CAAK,EAAE,CAAA,YAAA,CAAc,CAAA,CAKhE,GAFA,IAAA,CAAK,MAAA,CAAS,KAAK,gBAAA,CAAiB,MAAA,CAEhC,CAAC,IAAA,CAAK,MAAA,CACR,MAAM,IAAI,KAAA,CAAM,6BAA6B,IAAA,CAAK,IAAI,GAAG,CAAA,CAG3D,IAAMC,EAAc,MAAM,IAAA,CAAK,iBAAiB,QAAA,CAAS,GAAA,GACzD,GAAIA,CAAAA,CAAY,SAAW,CAAA,CACzB,MAAM,IAAI,KAAA,CAAM,CAAA,qBAAA,EAAwB,KAAK,IAAI,CAAA,uDAAA,CAAyD,EAE5G,OAAA,IAAA,CAAK,QAAA,CAAWC,EAAoBD,CAAAA,CAAa,IAAA,CAAK,EAAE,CAAA,CACxD,OAAA,CAAQ,IAAI,CAAA,UAAA,EAAa,IAAA,CAAK,EAAE,CAAA,yBAAA,CAAA,CAA6B,IAAA,CAAK,QAAQ,CAAA,CAE1E,MAAM,KAAK,iBAAA,EAAkB,CAE7B,KAAK,IAAA,CAAK,SAAA,CAAW,CAAC,GAAG,IAAA,CAAK,QAAQ,CAAC,CAAA,CAEhC,CAAC,GAAG,IAAA,CAAK,QAAQ,CAE1B,CAAA,MAASE,CAAAA,CAAO,CACd,MAAA,OAAA,CAAQ,KAAA,CAAM,aAAa,IAAA,CAAK,EAAE,uBAAwBA,CAAK,CAAA,CAC/D,MAAM,IAAA,CAAK,OAAA,GACLA,CACR,CACF,CAEA,MAAa,UAAA,EAA4B,CACvC,OAAA,CAAQ,GAAA,CAAI,aAAa,IAAA,CAAK,EAAE,oBAAoB,CAAA,CACpD,MAAM,KAAK,OAAA,EAAQ,CACnB,KAAK,IAAA,CAAK,YAAY,EACxB,CAEA,MAAa,YAAYC,CAAAA,CAAiBC,CAAAA,CAA8C,CACtF,GAAI,CAACA,GAAW,CAACD,CAAAA,CAAS,OAC1B,IAAME,CAAAA,CAAS,MAAM,KAAK,SAAA,EAAU,CACpC,GAAI,CAACA,CAAAA,EAAU,CAACA,CAAAA,EAAQ,OAAA,CACtB,MAAM,IAAI,KAAA,CAAM,sDAAsD,CAAA,CAGxE,GAAI,EADa,MAAM,IAAA,CAAK,aAAY,EAC1B,IAAA,CAAKC,GAAOA,CAAAA,CAAI,OAAA,CAAQ,aAAY,GAAMF,CAAAA,CAAQ,aAAa,CAAA,CAC3E,MAAM,IAAI,KAAA,CAAM,WAAWA,CAAO,CAAA,mBAAA,EAAsB,KAAK,IAAI,CAAA,CAAA,CAAG,EAGtE,GAAI,CACF,IAAMG,CAAAA,CAAUC,WAAAA,CAAYL,CAAO,CAAA,CAEnC,OAAA,CADe,MAAME,EAAO,OAAA,CAAQ,CAAE,QAAAD,CAAAA,CAAS,IAAA,CAAMG,EAAS,IAAA,CAAM,OAAQ,CAAC,CAAA,EAC/D,SAChB,OAASL,CAAAA,CAAY,CACnB,MAAM,IAAI,KAAA,CAAM,aAAa,IAAA,CAAK,EAAE,6BAA6BA,CAAAA,CAAM,OAAO,EAAE,CAClF,CACF,CAGA,MAAc,iBAAA,EAAmC,CAE/C,GADA,MAAM,KAAK,mBAAA,EAAoB,CAC3B,CAAC,IAAA,CAAK,gBAAA,CACR,MAAM,IAAI,KAAA,CAAM,aAAa,IAAA,CAAK,EAAE,qDAAqD,CAAA,CAG3F,GAAI,CACF,IAAA,CAAK,WAAA,CAAc,KAAK,gBAAA,CAAiB,QAAA,CAAS,UAC/CO,CAAAA,EAA0C,CACzC,IAAMC,CAAAA,CAAcT,CAAAA,CAAoBQ,EAAoB,IAAA,CAAK,EAAE,EAC/D,IAAA,CAAK,SAAA,CAAU,KAAK,QAAQ,CAAA,GAAM,KAAK,SAAA,CAAUC,CAAW,IAC9D,IAAA,CAAK,QAAA,CAAWA,EAChB,IAAA,CAAK,IAAA,CAAK,kBAAmB,CAAC,GAAG,KAAK,QAAQ,CAAC,GAEnD,CACF,CAAA,CACA,QAAQ,GAAA,CAAI,CAAA,UAAA,EAAa,KAAK,EAAE,CAAA,gCAAA,CAAkC,EACpE,CAAA,MAASR,CAAAA,CAAO,CACd,QAAQ,KAAA,CAAM,CAAA,UAAA,EAAa,KAAK,EAAE,CAAA,kCAAA,CAAA,CAAsCA,CAAK,CAAA,CAC7E,IAAA,CAAK,YAAc,KACrB,CACF,CAEA,MAAc,mBAAA,EAAqC,CAC7C,IAAA,CAAK,WAAA,GACP,KAAK,WAAA,EAAY,CACjB,KAAK,WAAA,CAAc,IAAA,CACnB,QAAQ,GAAA,CAAI,CAAA,UAAA,EAAa,KAAK,EAAE,CAAA,oCAAA,CAAsC,GAE1E,CAGA,MAAc,SAAyB,CACrC,MAAM,KAAK,mBAAA,EAAoB,CAC/B,KAAK,QAAA,CAAW,GAChB,IAAA,CAAK,MAAA,CAAS,OACd,IAAA,CAAK,gBAAA,CAAmB,OAC1B,CACF,CAAA,KCtJaS,CAAAA,CAAsB,IAC1B,IAAIf,CAAAA,CAAgB,CACzB,GAAI,aAAA,CACJ,IAAA,CAAM,gBACN,IAAA,CAAMgB,CAAAA,CACN,MAAO,CACL,gBAAA,CAAkB,mCACpB,CACF,CAAC,ECRI,IAAMC,CAAAA,CAAqB,IACzB,IAAIjB,CAAAA,CAAgB,CACzB,EAAA,CAAI,WAAA,CACJ,KAAM,WAAA,CACN,IAAA,CAAMkB,IACN,KAAA,CAAO,CACL,iBAAkB,oGACpB,CACF,CAAC,ECRI,IAAMC,EAAqB,IACzB,IAAInB,CAAAA,CAAgB,CACzB,EAAA,CAAI,cAAA,CACJ,KAAM,WAAA,CACN,IAAA,CAAMoB,EACN,KAAA,CAAO,CACL,iBAAkB,qGAAA,CAClB,QAAA,CAAU,sCACZ,CACF,CAAC,ECTI,IAAMC,CAAAA,CAAoB,IACxB,IAAIrB,CAAAA,CAAgB,CACzB,EAAA,CAAI,UAAA,CACJ,KAAM,UAAA,CACN,IAAA,CAAMsB,IACN,KAAA,CAAO,CACL,iBAAkB,2FACpB,CACF,CAAC,ECHI,IAAMC,EAAN,cAAqC1B,CAAc,CAgBxD,WAAA,CAAYI,CAAAA,CAAwC,CAClD,KAAA,EAAM,CAHR,KAAQ,WAAA,CAAmC,IAAA,CAIzC,KAAK,EAAA,CAAKA,CAAAA,CAAQ,IAAM,eAAA,CACxB,IAAA,CAAK,KAAOA,CAAAA,CAAQ,IAAA,EAAQ,gBAC5B,IAAA,CAAK,KAAA,CAAQA,EAAQ,KAAA,EAAS,GAE9B,IAAA,CAAK,IAAA,CAAOA,EAAQ,IAAA,EAAQuB,GAAAA,CAE5B,KAAK,SAAA,CAAYvB,CAAAA,CAAQ,UACzB,IAAA,CAAK,QAAA,CAAWA,EAAQ,QAAA,EAAY,+BAAA,CACpC,KAAK,QAAA,CAAWA,CAAAA,CAAQ,SAC1B,CAEO,WAAA,EAAuB,CAC5B,OAAO,MACT,CAEA,MAAa,WAAA,EAAgC,CAC3C,OAAO,KACT,CAEQ,sBAAA,CAAuBwB,CAAAA,CAA2B,CACxD,OAAOA,CAAAA,CAAO,GAAA,CAAIC,GAAS,CAAA,SAAA,EAAYA,CAAAA,CAAM,YAAY,OAAA,CAAQ,IAAA,CAAM,EAAE,CAAA,CAAE,KAAA,CAAM,EAAG,EAAE,CAAC,EAAE,CAC3F,CAEA,MAAa,OAAA,CAAQvB,CAAAA,CAAiBsB,EAAkBE,CAAAA,CAAiD,CACvG,GAAI,CAAC,IAAA,CAAK,UACR,MAAM,IAAI,MAAM,CAAA,EAAG,IAAA,CAAK,IAAI,CAAA,+EAAA,CAAiF,CAAA,CAG/G,GAAI,CAACF,CAAAA,EAAUA,EAAO,MAAA,GAAW,CAAA,CAC/B,MAAM,IAAI,KAAA,CAAM,GAAG,IAAA,CAAK,IAAI,CAAA,+BAAA,CAAiC,CAAA,CAG/D,IAAA,CAAK,eAAA,CAAkBA,EAEvB,GAAM,CAAE,kBAAAG,CAAkB,CAAA,CAAI,MAAM,OAAO,mCAAmC,EAE9E,GAAI,CACF,KAAK,QAAA,CAAW,MAAMA,EAAkB,IAAA,CAAK,CAC3C,UAAW,IAAA,CAAK,SAAA,CAChB,SAAU,IAAA,CAAK,QAAA,CACf,SAAU,IAAA,CAAK,QAAA,EAAY,CACzB,IAAA,CAAMzB,CAAAA,CACN,YAAa,cAAA,CACb,GAAA,CAAK,OAAO,MAAA,CAAW,GAAA,CAAc,OAAO,QAAA,CAAS,MAAA,CAAS,GAC9D,KAAA,CAAO,CAAC,KAAK,IAAI,CACnB,CACF,CAAC,CAAA,CAED,IAAM0B,EAAeF,CAAAA,EAAiBF,CAAAA,CAAO,CAAC,CAAA,CAAE,WAAA,CAEhD,GAAI,IAAA,CAAK,QAAA,CAAS,QAAS,CACzB,IAAA,CAAK,QAAU,IAAA,CAAK,QAAA,CAAS,QAC7B,IAAMK,CAAAA,CAAW,KAAK,sBAAA,CAAuBL,CAAAA,CAAQI,CAAY,CAAA,CACjE,OAAA,IAAA,CAAK,SAAWC,CAAAA,CAEhB,MAAM,KAAK,iBAAA,EAAkB,CAE7B,KAAK,IAAA,CAAK,SAAA,CAAW,CAAC,GAAG,IAAA,CAAK,QAAQ,CAAC,CAAA,CAChC,CAAC,GAAG,IAAA,CAAK,QAAQ,CAC1B,CAEA,GAAI,CAAC,IAAA,CAAK,UAAU,MAAA,CAClB,MAAM,IAAI,KAAA,CAAM,2CAA2C,EAG7D,GAAM,CAAE,IAAAC,CAAAA,CAAK,QAAA,CAAAC,CAAS,CAAA,CAAI,MAAM,KAAK,QAAA,CAAS,MAAA,CAAO,QAAQ,CAC3D,kBAAA,CAAoB,CAClB,QAAA,CAAU,CACR,QAAS,CAAC,sBAAA,CAAwB,2BAA4B,0BAAA,CAA4B,0BAA0B,EACpH,MAAA,CAAQ,IAAA,CAAK,uBAAuBP,CAAM,CAAA,CAC1C,OAAQ,CAAC,iBAAA,CAAmB,eAAgB,SAAS,CACvD,CACF,CAAA,CACA,kBAAA,CAAoB,CAClB,QAAA,CAAU,CACR,OAAA,CAAS,CAAC,sBAAA,CAAwB,0BAAA,CAA4B,2BAA4B,0BAA0B,CAAA,CACpH,OAAQ,IAAA,CAAK,sBAAA,CAAuBA,CAAM,CAAA,CAC1C,MAAA,CAAQ,CAAC,iBAAA,CAAmB,cAAA,CAAgB,SAAS,CACvD,CACF,CACF,CAAC,CAAA,CAED,KAAK,IAAA,CAAK,SAAA,CAAWM,CAAG,CAAA,CAExB,IAAME,EAAU,MAAMD,CAAAA,GACtB,IAAA,CAAK,OAAA,CAAUC,EACf,IAAA,CAAK,QAAA,CAAS,QAAUA,CAAAA,CAExB,IAAA,CAAK,cAAgB,KAAA,CAAA,CAErB,IAAMH,EAAW,IAAA,CAAK,sBAAA,CAAuBL,EAAQI,CAAY,CAAA,CACjE,YAAK,QAAA,CAAWC,CAAAA,CAGhB,MAAM,IAAA,CAAK,iBAAA,GAEX,IAAA,CAAK,IAAA,CAAK,UAAW,CAAC,GAAG,KAAK,QAAQ,CAAC,EAChC,CAAC,GAAG,KAAK,QAAQ,CAE1B,OAASxB,CAAAA,CAAO,CACd,WAAK,aAAA,CAAgB,MAAA,CACfA,CACR,CACF,CAEQ,uBAAuBmB,CAAAA,CAAiB1B,CAAAA,CAA4B,CAC1E,IAAMmC,CAAAA,CAAcT,EAAO,MAAA,CAAOC,CAAAA,EAASA,EAAM,WAAA,CAAY,WAAA,KAAkB3B,CAAAA,CAAQ,WAAA,EAAa,CAAA,CAC9FoC,CAAAA,CAAS,IAAA,CAAK,uBAAuBD,CAAW,CAAA,CAAE,CAAC,CAAA,CAErD9B,CAAAA,CAAc,KAAK,OAAA,EAAS,UAAA,CAAW,SAAS,QAAA,CACjD,IAAA,GACA,MAAA,CAAQI,CAAAA,EAAoBA,EAAQ,QAAA,CAAS2B,CAAM,CAAC,CAAA,CACpD,GAAA,CAAK3B,GAAoBA,CAAAA,CAAQ,OAAA,CAAQ,GAAG2B,CAAM,CAAA,CAAA,CAAA,CAAK,EAAE,CAAC,CAAA,CAE7D,GAAI/B,CAAAA,EAAeA,CAAAA,CAAY,SAAW,CAAA,CAAG,CAC3C,QAAQ,KAAA,CAAM,gFAAgF,EAE9F,IAAM+B,CAAAA,CAAS,KAAK,sBAAA,CAAuBV,CAAM,EAAE,CAAC,CAAA,CAEpDrB,EAAc,IAAA,CAAK,OAAA,EAAS,WAAW,QAAA,CAAS,QAAA,CAC7C,MAAK,CACL,MAAA,CAAQI,GAAoBA,CAAAA,CAAQ,QAAA,CAAS2B,CAAM,CAAC,CAAA,CACpD,IAAK3B,CAAAA,EAAoBA,CAAAA,CAAQ,QAAQ,CAAA,EAAG2B,CAAM,IAAK,EAAE,CAAC,EAC/D,CAEA,IAAMC,EAAShC,CAAAA,CACZ,GAAA,CAAKI,IAAqB,CACzB,OAAA,CAAAA,EACA,IAAA,CAAM,CAAA,EAAG,KAAK,IAAI,CAAA,QAAA,CAAA,CAClB,KAAM,CACJ,MAAA,CAAQ,KAAK,EACf,CAAA,CACA,SAAA,CAAW,MACb,CAAA,CAAE,CAAA,CAEJ,YAAK,IAAA,CAAK,iBAAA,CAAmB,CAAC,GAAG4B,CAAM,CAAC,CAAA,CAEjCA,CACT,CAEA,MAAa,UAAA,EAA4B,CACnC,IAAA,CAAK,QAAA,GACP,QAAQ,GAAA,CAAI,eAAA,CAAiB,KAAK,QAAQ,CAAA,CAC1C,QAAQ,GAAA,CAAI,qBAAA,CAAuB,KAAK,OAAO,CAAA,CAE7C,MAAM,IAAA,CAAK,QAAA,CAAS,YAAW,CAAA,CAMnC,MAAM,KAAK,OAAA,EAAQ,CACnB,KAAK,IAAA,CAAK,YAAY,EACxB,CAEA,MAAa,YAAY7B,CAAAA,CAAiBC,CAAAA,CAAiBT,CAAAA,CAA+C,CACxG,GAAI,CAAC,KAAK,QAAA,EAAU,MAAA,EAAU,CAAC,IAAA,CAAK,OAAA,EAAS,MAC3C,MAAM,IAAI,MAAM,2CAA2C,CAAA,CAG7D,IAAM4B,CAAAA,CAAgB5B,CAAAA,CAClB,YAAYA,CAAAA,CAAQ,OAAA,CAAQ,KAAM,EAAE,CAAA,CAAE,MAAM,CAAA,CAAG,EAAE,CAAC,CAAA,CAAA,CAClD,IAAA,CAAK,uBAAuB,IAAA,CAAK,eAAgB,EAAE,CAAC,CAAA,CAExD,GAAI,CAcF,OAAA,CAbe,MAAM,IAAA,CAAK,QAAA,CAAS,OAAO,OAAA,CAAQ,CAChD,MAAO,IAAA,CAAK,OAAA,CAAQ,KAAA,CACpB,OAAA,CAAS4B,CAAAA,CACT,OAAA,CAAS,CACP,MAAA,CAAQ,sBAAA,CACR,OAAQ,CACN,OAAA,CAAAnB,EACA,OAAA,CAAAD,CAAAA,CACA,KAAM,OACR,CACF,CACF,CAAC,CAAA,GAEuB,SAC1B,CAAA,MAASD,CAAAA,CAAO,CACd,MAAA,OAAA,CAAQ,KAAA,CAAM,sBAAuBA,CAAK,CAAA,CACpCA,CACR,CACF,CAEO,kBAA4B,CACjC,OAAO,KACT,CAEA,MAAa,kBAAoC,CAC/C,OAAI,KAAK,aAAA,CACA,IAAA,CAAK,cAGP,IAAI,OAAA,CAAiB+B,GAAY,CACtC,IAAA,CAAK,KAAK,SAAA,CAAYN,CAAAA,EAAgB,CACpC,IAAA,CAAK,aAAA,CAAgBA,EACrBM,CAAAA,CAAQN,CAAG,EACb,CAAC,EACH,CAAC,CACH,CAEA,MAAa,sBAAA,CAAuBhC,CAAAA,CAAiB,CACnD,GAAI,CAAC,KAAK,eAAA,CACR,MAAM,IAAI,KAAA,CAAM,6BAA6B,EAG/C,IAAMe,CAAAA,CAAc,KAAK,sBAAA,CAAuB,IAAA,CAAK,gBAAiBf,CAAO,CAAA,CAC7E,YAAK,QAAA,CAAWe,CAAAA,CAETA,CACT,CAGA,MAAa,WAAyC,CACpD,GAAI,GAAC,IAAA,CAAK,QAAA,EAAU,MAAA,EAAU,CAAC,IAAA,CAAK,OAAA,CAAA,CAEpC,OAAO,CACL,WAAA,CAAa,MAAOwB,CAAAA,EAAsD,CACxE,GAAI,CAYF,OAXe,MAAM,IAAA,CAAK,QAAA,EAAU,QAAQ,OAAA,CAA+B,CACzE,MAAO,IAAA,CAAK,OAAA,CAAS,MACrB,OAAA,CAAS,CAAA,SAAA,EAAYA,EAAQ,WAAA,CAAY,OAAA,CAAQ,KAAM,EAAE,CAAA,CAAE,MAAM,CAAA,CAAG,EAAE,CAAC,CAAA,CAAA,CACvE,OAAA,CAAS,CACP,MAAA,CAAQ,0BAAA,CACR,OAAQ,CACN,OAAA,CAASA,EAAQ,OAAA,CACjB,kBAAA,CAAoBA,CACtB,CACF,CACF,CAAC,CAEH,CAAA,MAAShC,CAAAA,CAAO,CACd,MAAM,IAAI,MAAM,CAAA,4BAAA,EAA+B,IAAA,CAAK,UAAUA,CAAK,CAAC,EAAE,CACxE,CACF,CACF,CACF,CAEA,MAAc,iBAAA,EAAmC,CAG/C,GAFA,MAAM,IAAA,CAAK,qBAAoB,CAE3B,CAAC,KAAK,QAAA,EAAU,MAAA,EAAU,CAAC,IAAA,CAAK,OAAA,CAClC,MAAM,IAAI,KAAA,CAAM,aAAa,IAAA,CAAK,EAAE,wDAAwD,CAAA,CAG9F,GAAI,CACF,IAAMiC,CAAAA,CAAuB,SAAY,CACvC,OAAA,CAAQ,GAAA,CAAI,CAAA,UAAA,EAAa,IAAA,CAAK,EAAE,qCAAqC,CAAA,CACrE,MAAM,KAAK,OAAA,EAAQ,CACnB,KAAK,IAAA,CAAK,YAAY,EACxB,CAAA,CACA,IAAA,CAAK,SAAS,MAAA,CAAO,EAAA,CAAG,iBAAkBA,CAAoB,CAAA,CAE9D,KAAK,WAAA,CAAc,IAAM,CACvB,IAAA,CAAK,QAAA,EAAU,QAAQ,GAAA,CAAI,gBAAA,CAAkBA,CAAoB,EACnE,EAEF,MAAgB,CACd,IAAA,CAAK,YAAc,KACrB,CACF,CAEA,MAAc,mBAAA,EAAqC,CAC7C,IAAA,CAAK,WAAA,GACP,KAAK,WAAA,EAAY,CACjB,KAAK,WAAA,CAAc,IAAA,CACnB,QAAQ,GAAA,CAAI,CAAA,UAAA,EAAa,KAAK,EAAE,CAAA,2BAAA,CAA6B,GAEjE,CAEA,MAAc,SAAyB,CACrC,MAAM,KAAK,mBAAA,EAAoB,CAC/B,KAAK,QAAA,CAAW,GAChB,IAAA,CAAK,MAAA,CAAS,OACd,IAAA,CAAK,QAAA,CAAW,OAChB,IAAA,CAAK,OAAA,CAAU,OACjB,CACF,CAAA,CAEaC,EAA0BvC,CAAAA,EACrC,IAAIsB,EAAuBtB,CAAO,MChTvBwC,CAAAA,CAAN,cAAkCzC,CAAgB,CACvD,WAAA,EAAc,CACZ,KAAA,CAAM,CACJ,EAAA,CAAI,aAAA,CACJ,IAAA,CAAM,aAAA,CACN,KAAM0C,GAAAA,CACN,UAAA,CAAY,cACZ,KAAA,CAAO,CACL,SAAU,qCACZ,CACF,CAAC,EACH,CAEO,aAAuB,CAC5B,GAAI,OAAO,MAAA,CAAW,GAAA,CAAa,OAAO,MAAA,CAC1C,IAAMxC,EAAe,MAAA,CAAO,YAAA,CAC5B,OACE,OAAOA,CAAAA,EAAiB,UACxB,OAAOA,CAAAA,CAAa,aAAa,CAAA,CAAM,GAAA,EACvC,OAAO,eAAA,EAAiB,YAAA,GAAiB,IAE7C,CAEA,MAAa,aAAgC,CAC3C,OAAO,KAAK,WAAA,EACd,CACF,CAAA,CAEayC,CAAAA,CAAsB,IAAM,IAAIF,ECbtC,IAAMG,EAAiBC,CAAAA,EAAgC,CAC5D,GAAKA,CAAAA,CAA4B,UAAA,EAAc,CAACC,CAAAA,EAAe,CAC7D,MAAM,IAAI,KAAA,CAAM,gEAAgE,CAAA,CAGlF,GAAKD,EAA4B,UAAA,CAC/B,MAAM,IAAI,KAAA,CAAM,uEAAuE,EAGzF,OAAIC,CAAAA,GACKH,CAAAA,EAAoB,CAGtB,IAAIpB,CAAAA,CAAuB,CAChC,GAAI,MAAA,CACJ,IAAA,CAAM,cACN,IAAA,CAAMmB,GAAAA,CACN,MAAO,CACL,gBAAA,CAAkB,uBACpB,CAAA,CACA,GAAGG,CACL,CAAC,CACH","file":"chunk-2ZADE6DA.js","sourcesContent":["import type {Account, Chain, Signer} from '../types';\nimport { EventEmitter } from 'eventemitter3';\nimport { ConnectorLinks } from '../types'\n\n/**\n * base connector abstract class\n * defines the basic properties and methods that all wallet connectors should have.\n */\nexport abstract class BaseConnector extends EventEmitter {\n /**\n * the unique identifier of the connector (e.g., 'polkadot-js', 'subwallet-js')\n * subclasses must implement.\n */\n abstract readonly id: string;\n\n /**\n * user-friendly connector name (e.g., 'Polkadot{.js}', 'SubWallet')\n * subclasses must implement.\n */\n abstract readonly name: string;\n\n /**\n * connector icon URL (optional)\n * subclasses can implement.\n */\n abstract readonly icon?: string;\n\n readonly links: ConnectorLinks = {};\n /**\n * store the current connected accounts.\n * subclasses are responsible for maintaining this list when connecting and updating accounts.\n */\n protected accounts: Account[] = [];\n /**\n * store the signer.\n * subclasses are responsible for getting and storing it when connecting.\n */\n protected signer: Signer | undefined = undefined;\n\n protected connectionUri: string | undefined = undefined;\n\n constructor() {\n super();\n }\n\n public abstract isAvailable(): Promise<boolean>;\n\n public abstract isInstalled(): boolean;\n\n /**\n * connect to the wallet, get the initial accounts and signer, and set the necessary event listeners.\n * subclasses must implement:\n * 1. get the signer and assign it to this.signer.\n * 2. get the initial accounts list and assign it to this.accounts.\n * 3. set the account update mechanism of itself (e.g., use web3AccountsSubscribe or WalletConnect events).\n * 4. update this.accounts when the account list changes and trigger the 'accountsChanged' event.\n * 5. (optional) trigger the 'connect' event.\n * @returns the initial available accounts list\n */\n abstract connect(appName: string, chains?: Chain[], targetChainId?: string): Promise<Array<Account>>;\n /**\n * disconnect from the wallet.\n * subclasses must implement this method to perform specific cleanup logic\n * (e.g., unsubscribe, close session).\n * implementers should clear this.accounts and this.signer after cleanup and trigger the 'disconnect' event.\n */\n abstract disconnect(): Promise<void>;\n\n /**\n * get the current connected accounts list.\n * @returns the current available accounts list\n */\n public async getAccounts(): Promise<Array<Account>> {\n return [...this.accounts];\n }\n\n /**\n * get the cached signer object.\n * @returns the signer object, or undefined if the connection is not successful or cannot be obtained.\n */\n public async getSigner(): Promise<Signer | undefined> {\n if (!this.signer) {\n console.warn(`Connector ${this.id}: Signer not available. Connection might be incomplete or failed.`);\n }\n return this.signer;\n }\n\n /**\n * sign a message with the specified account.\n */\n abstract signMessage(message: string, address: string, chainId?: string): Promise<string | undefined>;\n\n public hasConnectionUri(): boolean {\n return false\n }\n\n public async getConnectionUri(): Promise<string | undefined >{\n return this.connectionUri;\n }\n\n public async updateAccountsForChain(chainId: string): Promise<Account[]> {\n return [...this.accounts];\n }\n}\n","import { BaseConnector } from './base';\nimport type { Account, Signer } from '../types';\nimport { mapInjectedAccounts } from '../utils'\nimport { Injected, InjectedAccount } from 'dedot/types'\nimport { stringToHex } from 'dedot/utils'\nimport { ConnectorLinks } from '../types'\n\nexport interface CommonConnectorOptions {\n id: string;\n name: string;\n icon: string;\n links: ConnectorLinks;\n injectorId?: string;\n}\n\nexport class CommonConnector extends BaseConnector {\n readonly id: string;\n readonly name: string;\n readonly icon: string;\n readonly links: ConnectorLinks;\n protected readonly injectorId: string;\n\n private unsubscribe: (() => void) | null = null;\n\n private specificInjector?: Injected = undefined\n\n constructor(options: CommonConnectorOptions) {\n super();\n this.id = options.id;\n this.name = options.name;\n this.icon = options.icon;\n this.links = options.links;\n this.injectorId = options.injectorId || options.id;\n }\n\n public isInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n const injectedWeb3 = window.injectedWeb3;\n return typeof injectedWeb3 === 'object' && typeof injectedWeb3[this.injectorId] !== 'undefined';\n }\n\n public async isAvailable(): Promise<boolean> {\n return this.isInstalled();\n }\n\n public async connect(appName: string): Promise<Array<Account>> {\n console.log(`Connector ${this.id}: Attempting to connect...`);\n if (this.signer) {\n console.log(`Connector ${this.id}: Already connected.`);\n return [...this.accounts];\n }\n if (!(await this.isAvailable())) {\n throw new Error(`${this.name} extension not found or not enabled.`);\n }\n\n try {\n this.specificInjector = await window.injectedWeb3![this.injectorId]!.enable(appName);\n\n if (!this.specificInjector) {\n throw new Error(`Failed to enable the '${this.id}' extension.`);\n }\n\n this.signer = this.specificInjector.signer as Signer;\n\n if (!this.signer) {\n throw new Error(`Could not get signer from ${this.name}.`);\n }\n\n const rawAccounts = await this.specificInjector.accounts.get();\n if (rawAccounts.length === 0) {\n throw new Error(`No accounts found in ${this.name}. Make sure accounts are visible and access is granted.`);\n }\n this.accounts = mapInjectedAccounts(rawAccounts, this.id);\n console.log(`Connector ${this.id}: Initial accounts loaded`, this.accounts);\n\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n\n return [...this.accounts];\n\n } catch (error) {\n console.error(`Connector ${this.id}: Connection failed:`, error);\n await this.cleanup();\n throw error;\n }\n }\n\n public async disconnect(): Promise<void> {\n console.log(`Connector ${this.id}: Disconnecting...`);\n await this.cleanup();\n this.emit('disconnect');\n }\n\n public async signMessage(message: string, address: string): Promise<string | undefined> {\n if (!address || !message) return undefined;\n const signer = await this.getSigner();\n if (!signer || !signer?.signRaw) {\n throw new Error('Signer is not available or does not support signRaw.');\n }\n const accounts = await this.getAccounts();\n if (!accounts.some(acc => acc.address.toLowerCase() === address.toLowerCase())) {\n throw new Error(`Address ${address} is not managed by ${this.name}.`);\n }\n\n try {\n const dataHex = stringToHex(message);\n const result = await signer.signRaw({ address, data: dataHex, type: 'bytes' });\n return result.signature;\n } catch (error: any) {\n throw new Error(`Connector ${this.id}: Failed to sign message: ${error.message}`);\n }\n }\n\n\n private async startSubscription(): Promise<void> {\n await this.cleanupSubscription();\n if (!this.specificInjector) {\n throw new Error(`Connector ${this.id}: Cannot subscribe, specificInjector not available.`);\n }\n\n try {\n this.unsubscribe = this.specificInjector.accounts.subscribe(\n (updatedRawAccounts: InjectedAccount[]) => {\n const newAccounts = mapInjectedAccounts(updatedRawAccounts, this.id);\n if (JSON.stringify(this.accounts) !== JSON.stringify(newAccounts)) {\n this.accounts = newAccounts;\n this.emit('accountsChanged', [...this.accounts]);\n }\n }\n );\n console.log(`Connector ${this.id}: Subscribed to account changes.`);\n } catch (error) {\n console.error(`Connector ${this.id}: Failed to subscribe to accounts:`, error);\n this.unsubscribe = null;\n }\n }\n\n private async cleanupSubscription(): Promise<void> {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n console.log(`Connector ${this.id}: Unsubscribed from account changes.`);\n }\n }\n\n\n private async cleanup(): Promise<void> {\n await this.cleanupSubscription();\n this.accounts = [];\n this.signer = undefined;\n this.specificInjector = undefined\n }\n}\n","import { CommonConnector } from './common'\nimport { polkadotjsSVG } from '../config/logos/generated'\n\nexport const polkadotjsConnector = () => {\n return new CommonConnector({\n id: 'polkadot-js',\n name: 'Polkadot{.js}',\n icon: polkadotjsSVG,\n links: {\n browserExtension: 'https://polkadot.js.org/extension'\n }\n });\n}\n","import { polkagateSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const polkagateConnector = () => {\n return new CommonConnector({\n id: 'polkagate',\n name: 'Polkagate',\n icon: polkagateSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/polkagate-the-gateway-to/ginchbkmljhldofnbjabmeophlhdldgp'\n }\n });\n}\n","import { subwalletSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const subwalletConnector = () => {\n return new CommonConnector({\n id: 'subwallet-js',\n name: 'SubWallet',\n icon: subwalletSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/subwallet-polkadot-wallet/onhogfjeacnfoofkfgppdlbmlmnplgbn',\n deepLink: 'https://mobile.subwallet.app/browser',\n }\n })\n};\n","import { talismanSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const talismanConnector = () => {\n return new CommonConnector({\n id: 'talisman',\n name: 'Talisman',\n icon: talismanSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld'\n }\n });\n}\n","import { BaseConnector } from './base';\nimport type { IUniversalProvider, Metadata } from '@walletconnect/universal-provider';\nimport { SessionTypes, SignClientTypes } from '@walletconnect/types'\nimport type { Account, Chain, Signer, WalletConnectConnectorOptions } from '../types';\nimport { walletconnectSVG } from '../config/logos/generated';\nimport { SignerResult, SignerPayloadJSON } from 'dedot/types'\nimport { ConnectorLinks } from '../types'\n\nexport class WalletConnectConnector extends BaseConnector {\n readonly id: string;\n readonly name: string;\n readonly icon: string;\n readonly links: ConnectorLinks;\n\n private provider?: IUniversalProvider;\n private projectId: string;\n private relayUrl: string;\n private metadata?: Metadata;\n\n private session?: SessionTypes.Struct;\n private connectedChains?: Chain[];\n\n private unsubscribe: (() => void) | null = null;\n\n constructor(options: WalletConnectConnectorOptions) {\n super();\n this.id = options.id || 'walletconnect';\n this.name = options.name || 'WalletConnect';\n this.links = options.links || {};\n\n this.icon = options.icon || walletconnectSVG;\n\n this.projectId = options.projectId;\n this.relayUrl = options.relayUrl || 'wss://relay.walletconnect.com';\n this.metadata = options.metadata;\n }\n\n public isInstalled(): boolean {\n return false;\n }\n\n public async isAvailable(): Promise<boolean> {\n return true;\n }\n\n private convertChainIdToCaipId(chains: Chain[]): string[] {\n return chains.map(chain => `polkadot:${chain.genesisHash.replace('0x', '').slice(0, 32)}`);\n }\n\n public async connect(appName: string, chains?: Chain[], targetChainId?: string): Promise<Array<Account>> {\n if (!this.projectId) {\n throw new Error(`${this.name} requires a projectId. Please visit https://cloud.walletconnect.com to get one.`);\n }\n\n if (!chains || chains.length === 0) {\n throw new Error(`${this.name} requires chains configuration.`);\n }\n\n this.connectedChains = chains;\n\n const { UniversalProvider } = await import(\"@walletconnect/universal-provider\");\n\n try {\n this.provider = await UniversalProvider.init({\n projectId: this.projectId,\n relayUrl: this.relayUrl,\n metadata: this.metadata || {\n name: appName,\n description: 'LunoKit DApp',\n url: typeof window !== 'undefined' ? window.location.origin : '',\n icons: [this.icon],\n },\n });\n\n const chainIdToUse = targetChainId || chains[0].genesisHash;\n\n if (this.provider.session) {\n this.session = this.provider.session;\n const accounts = this.getAccountsFromSession(chains, chainIdToUse);\n this.accounts = accounts;\n\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n return [...this.accounts];\n }\n\n if (!this.provider?.client) {\n throw new Error(\"Provider not initialized or not connected\");\n }\n\n const { uri, approval } = await this.provider.client.connect({\n requiredNamespaces: {\n polkadot: {\n methods: ['polkadot_signMessage', 'polkadot_sendTransaction', 'polkadot_signTransaction', 'polkadot_requestAccounts'],\n chains: this.convertChainIdToCaipId(chains),\n events: ['accountsChanged', 'chainChanged', 'connect'],\n },\n },\n optionalNamespaces: {\n polkadot: {\n methods: ['polkadot_signMessage', 'polkadot_sendTransaction', 'polkadot_signTransaction', 'polkadot_requestAccounts'],\n chains: this.convertChainIdToCaipId(chains),\n events: ['accountsChanged', 'chainChanged', 'connect'],\n },\n },\n });\n\n this.emit('get_uri', uri);\n\n const session = await approval();\n this.session = session;\n this.provider.session = session;\n\n this.connectionUri = undefined;\n\n const accounts = this.getAccountsFromSession(chains, chainIdToUse);\n this.accounts = accounts;\n\n // 启动订阅\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n return [...this.accounts];\n\n } catch (error) {\n this.connectionUri = undefined;\n throw error;\n }\n }\n\n private getAccountsFromSession(chains: Chain[], chainId: string): Account[] {\n const targetChain = chains.filter(chain => chain.genesisHash.toLowerCase() === chainId.toLowerCase())\n const caipId = this.convertChainIdToCaipId(targetChain)[0];\n\n let rawAccounts = this.session?.namespaces.polkadot.accounts\n .flat()\n .filter((address: string) => address.includes(caipId))\n .map((address: string) => address.replace(`${caipId}:`, \"\"))\n\n if (rawAccounts && rawAccounts.length === 0) {\n console.error(`No accounts found for the specified chain, please connect to the correct chain`);\n\n const caipId = this.convertChainIdToCaipId(chains)[0];\n\n rawAccounts = this.session?.namespaces.polkadot.accounts\n .flat()\n .filter((address: string) => address.includes(caipId))\n .map((address: string) => address.replace(`${caipId}:`, \"\"))\n }\n\n const result = rawAccounts!\n .map((address: string) => ({\n address,\n name: `${this.name} Account`,\n meta: {\n source: this.id,\n },\n publicKey: undefined,\n }));\n\n this.emit('accountsChanged', [...result]);\n\n return result!\n }\n\n public async disconnect(): Promise<void> {\n if (this.provider) {\n console.log('this.provider', this.provider)\n console.log('this.sessionsession', this.session)\n // await Promise.race([\n await this.provider.disconnect()\n // new Promise((_, reject) =>\n // setTimeout(() => reject(new Error('Disconnect timeout')), 5000)\n // )\n // ]);\n }\n await this.cleanup()\n this.emit('disconnect');\n }\n\n public async signMessage(message: string, address: string, chainId?: string): Promise<string | undefined> {\n if (!this.provider?.client || !this.session?.topic) {\n throw new Error(\"Provider not initialized or not connected\");\n }\n\n const targetChainId = chainId\n ? `polkadot:${chainId.replace('0x', '').slice(0, 32)}`\n : this.convertChainIdToCaipId(this.connectedChains!)[0]\n\n try {\n const result = await this.provider.client.request({\n topic: this.session.topic,\n chainId: targetChainId,\n request: {\n method: 'polkadot_signMessage',\n params: {\n address,\n message,\n type: 'bytes'\n },\n },\n });\n\n return (result as any)?.signature;\n } catch (error) {\n console.error('Sign message error:', error);\n throw error;\n }\n }\n\n public hasConnectionUri(): boolean {\n return true\n }\n\n public async getConnectionUri(): Promise<string> {\n if (this.connectionUri) {\n return this.connectionUri;\n }\n\n return new Promise<string>((resolve) => {\n this.once('get_uri', (uri: string) => {\n this.connectionUri = uri;\n resolve(uri);\n });\n });\n }\n\n public async updateAccountsForChain(chainId: string) {\n if (!this.connectedChains) {\n throw new Error('WalletConnect not connected');\n }\n\n const newAccounts = this.getAccountsFromSession(this.connectedChains, chainId);\n this.accounts = newAccounts;\n\n return newAccounts;\n }\n\n\n public async getSigner(): Promise<Signer | undefined> {\n if (!this.provider?.client || !this.session) return undefined;\n\n return {\n signPayload: async (payload: SignerPayloadJSON): Promise<SignerResult> => {\n try {\n const result = await this.provider?.client?.request<{ signature: string }>({\n topic: this.session!.topic,\n chainId: `polkadot:${payload.genesisHash.replace('0x', '').slice(0, 32)}`,\n request: {\n method: 'polkadot_signTransaction',\n params: {\n address: payload.address,\n transactionPayload: payload,\n },\n },\n });\n return result as SignerResult;\n } catch (error) {\n throw new Error(`Transaction signing failed: ${JSON.stringify(error)}`);\n }\n }\n };\n }\n\n private async startSubscription(): Promise<void> {\n await this.cleanupSubscription();\n\n if (!this.provider?.client || !this.session) {\n throw new Error(`Connector ${this.id}: Cannot subscribe, provider or session not available.`);\n }\n\n try {\n const sessionDeleteHandler = async () => {\n console.log(`Connector ${this.id}: Session deleted, disconnecting...`);\n await this.cleanup()\n this.emit('disconnect');\n }\n this.provider.client.on('session_delete', sessionDeleteHandler);\n\n this.unsubscribe = () => {\n this.provider?.client?.off('session_delete', sessionDeleteHandler)\n }\n\n } catch (error) {\n this.unsubscribe = null;\n }\n }\n\n private async cleanupSubscription(): Promise<void> {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n console.log(`Connector ${this.id}: Unsubscribed from events.`);\n }\n }\n\n private async cleanup(): Promise<void> {\n await this.cleanupSubscription();\n this.accounts = [];\n this.signer = undefined;\n this.provider = undefined;\n this.session = undefined;\n }\n}\n\nexport const walletConnectConnector = (options: WalletConnectConnectorOptions) =>\n new WalletConnectConnector(options);\n","import { novaSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport class NovaMobileConnector extends CommonConnector {\n constructor() {\n super({\n id: 'nova-mobile',\n name: 'Nova Wallet',\n icon: novaSVG,\n injectorId: 'polkadot-js',\n links: {\n deepLink: 'https://app.novawallet.io/open/dapp'\n }\n });\n }\n\n public isInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n const injectedWeb3 = window.injectedWeb3;\n return (\n typeof injectedWeb3 === 'object' &&\n typeof injectedWeb3['polkadot-js'] !== 'undefined' &&\n window.walletExtension?.isNovaWallet === true\n );\n }\n\n public async isAvailable(): Promise<boolean> {\n return this.isInstalled();\n }\n}\n\nexport const novaMobileConnector = () => new NovaMobileConnector()\n","import { novaSVG } from '../config/logos/generated'\nimport { WalletConnectConnector } from './walletconnect'\nimport type { Metadata } from '@walletconnect/universal-provider'\nimport { novaMobileConnector } from './novaMobile'\nimport { isMobileDevice } from '../utils'\n\ntype WalletConnectConfig = {\n projectId: string;\n relayUrl?: string;\n metadata?: Metadata;\n}\n\ntype MobileOnlyConfig = {\n mobileOnly: true;\n}\n\ntype NovaConnectorConfig = WalletConnectConfig | MobileOnlyConfig;\n\nexport const novaConnector = (config: NovaConnectorConfig) => {\n if ((config as MobileOnlyConfig).mobileOnly && !isMobileDevice()) {\n throw new Error('Nova Wallet mobile connector cannot be used on desktop devices');\n }\n\n if ((config as MobileOnlyConfig).mobileOnly) {\n throw new Error('Nova Wallet is not installed. Please install Nova Wallet to continue.');\n }\n\n if (isMobileDevice()) {\n return novaMobileConnector();\n }\n\n return new WalletConnectConnector({\n id: 'nova',\n name: 'Nova Wallet',\n icon: novaSVG,\n links: {\n browserExtension: 'https://novawallet.io',\n },\n ...config as WalletConnectConfig,\n });\n};\n"]}
@@ -1,3 +0,0 @@
1
- 'use strict';var chunkMYEWIINX_cjs=require('./chunk-MYEWIINX.cjs');var r={genesisHash:"0x91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3",name:"Polkadot",nativeCurrency:{name:"Polkadot",symbol:"DOT",decimals:10},rpcUrls:{webSocket:["wss://rpc.polkadot.io","wss://polkadot.api.onfinality.io/public-ws"],http:["https://rpc.polkadot.io"]},ss58Format:0,blockExplorers:{default:{name:"Subscan",url:"https://polkadot.subscan.io"}},chainIconUrl:chunkMYEWIINX_cjs.d};var p={genesisHash:"0xb0a8d493285c2df73290dfb7e61f870f17b41801197a149ca93654499ea3dafe",name:"Kusama",nativeCurrency:{name:"Kusama",symbol:"KSM",decimals:12},rpcUrls:{webSocket:["wss://kusama-rpc.polkadot.io","wss://kusama.api.onfinality.io/public-ws"]},ss58Format:2,blockExplorers:{default:{name:"Subscan",url:"https://kusama.subscan.io"}},chainIconUrl:chunkMYEWIINX_cjs.a};var l={genesisHash:"0x77afd6190f1554ad45fd0d31aee62aacc33c6db0ea801129acb813f913e0764f",name:"Paseo",nativeCurrency:{name:"Paseo",symbol:"PAS",decimals:10},rpcUrls:{webSocket:["wss://rpc.ibp.network/paseo","wss://paseo.rpc.amforc.com"]},ss58Format:0,blockExplorers:{default:{name:"Subscan",url:"https://paseo.subscan.io/"}},chainIconUrl:chunkMYEWIINX_cjs.c,testnet:true};var b={genesisHash:"0xe143f23803ac50e8f6f8e62695d1ce9e4e1d68aa36c1cd2cfd15340213f3423e",name:"Westend",nativeCurrency:{name:"Westend",symbol:"WND",decimals:12},rpcUrls:{webSocket:["wss://westend-rpc.polkadot.io"]},ss58Format:42,blockExplorers:{default:{name:"Subscan",url:"https://westend.subscan.io"}},chainIconUrl:chunkMYEWIINX_cjs.j,testnet:true};
2
- exports.a=r;exports.b=p;exports.c=l;exports.d=b;//# sourceMappingURL=chunk-B75MLGK5.cjs.map
3
- //# sourceMappingURL=chunk-B75MLGK5.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/chains/polkadot.ts","../src/chains/kusama.ts","../src/chains/paseo.ts","../src/chains/westend.ts"],"names":["polkadot","polkadotSVG","kusama","kusamaSVG","paseo","paseoSVG","westend","westendSVG"],"mappings":"mEAGO,IAAMA,EAAkB,CAC7B,WAAA,CAAa,oEAAA,CACb,IAAA,CAAM,WACN,cAAA,CAAgB,CAAE,IAAA,CAAM,UAAA,CAAY,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAChE,QAAS,CACP,SAAA,CAAW,CAAC,uBAAA,CAAyB,4CAA4C,CAAA,CACjF,IAAA,CAAM,CAAC,yBAAyB,CAClC,CAAA,CACA,UAAA,CAAY,CAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,KAAM,SAAA,CAAW,GAAA,CAAK,6BAA8B,CAAE,CAAA,CACnF,YAAA,CAAcC,mBAChB,ECXO,IAAMC,CAAAA,CAAgB,CAC3B,WAAA,CAAa,qEACb,IAAA,CAAM,QAAA,CACN,cAAA,CAAgB,CAAE,KAAM,QAAA,CAAU,MAAA,CAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAC9D,OAAA,CAAS,CAAE,SAAA,CAAW,CAAC,8BAAA,CAAgC,0CAA0C,CAAE,CAAA,CACnG,WAAY,CAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,SAAA,CAAW,IAAK,2BAA4B,CAAE,EACjF,YAAA,CAAcC,mBAChB,ECRO,IAAMC,EAAe,CAC1B,WAAA,CAAa,oEAAA,CACb,IAAA,CAAM,QACN,cAAA,CAAgB,CAAE,IAAA,CAAM,OAAA,CAAS,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAC7D,QAAS,CAAE,SAAA,CAAW,CAAC,6BAAA,CAA+B,4BAA4B,CAAE,CAAA,CACpF,UAAA,CAAY,CAAA,CACZ,eAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,UAAW,GAAA,CAAK,2BAA4B,CAAE,CAAA,CACjF,YAAA,CAAcC,oBACd,OAAA,CAAS,IACX,ECTO,IAAMC,EAAiB,CAC5B,WAAA,CAAa,oEAAA,CACb,IAAA,CAAM,UACN,cAAA,CAAgB,CAAE,IAAA,CAAM,SAAA,CAAW,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAC/D,QAAS,CAAE,SAAA,CAAW,CAAC,+BAA+B,CAAE,CAAA,CACxD,UAAA,CAAY,EAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,SAAA,CAAW,IAAK,4BAA6B,CAAE,EAClF,YAAA,CAAcC,mBAAAA,CACd,QAAS,IACX","file":"chunk-B75MLGK5.cjs","sourcesContent":["import type { Chain } from '../types'\nimport { polkadotSVG } from '../config/logos/generated'\n\nexport const polkadot: Chain = {\n genesisHash: '0x91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3',\n name: 'Polkadot',\n nativeCurrency: { name: 'Polkadot', symbol: 'DOT', decimals: 10 },\n rpcUrls: {\n webSocket: ['wss://rpc.polkadot.io', 'wss://polkadot.api.onfinality.io/public-ws'],\n http: ['https://rpc.polkadot.io'],\n },\n ss58Format: 0,\n blockExplorers: { default: { name: 'Subscan', url: 'https://polkadot.subscan.io' } },\n chainIconUrl: polkadotSVG\n};\n","import type { Chain } from '../types'\nimport { kusamaSVG } from '../config/logos/generated'\n\nexport const kusama: Chain = {\n genesisHash: '0xb0a8d493285c2df73290dfb7e61f870f17b41801197a149ca93654499ea3dafe',\n name: 'Kusama',\n nativeCurrency: { name: 'Kusama', symbol: 'KSM', decimals: 12 },\n rpcUrls: { webSocket: ['wss://kusama-rpc.polkadot.io', 'wss://kusama.api.onfinality.io/public-ws'] },\n ss58Format: 2,\n blockExplorers: { default: { name: 'Subscan', url: 'https://kusama.subscan.io' } },\n chainIconUrl: kusamaSVG\n};\n","import type { Chain } from '../types'\nimport { paseoSVG } from '../config/logos/generated'\n\nexport const paseo: Chain = {\n genesisHash: '0x77afd6190f1554ad45fd0d31aee62aacc33c6db0ea801129acb813f913e0764f',\n name: 'Paseo',\n nativeCurrency: { name: 'Paseo', symbol: 'PAS', decimals: 10 },\n rpcUrls: { webSocket: ['wss://rpc.ibp.network/paseo', 'wss://paseo.rpc.amforc.com'] },\n ss58Format: 0,\n blockExplorers: { default: { name: 'Subscan', url: 'https://paseo.subscan.io/' } },\n chainIconUrl: paseoSVG,\n testnet: true\n};\n","import type { Chain } from '../types'\nimport { westendSVG } from '../config/logos/generated'\n\nexport const westend: Chain = {\n genesisHash: '0xe143f23803ac50e8f6f8e62695d1ce9e4e1d68aa36c1cd2cfd15340213f3423e',\n name: 'Westend',\n nativeCurrency: { name: 'Westend', symbol: 'WND', decimals: 12 },\n rpcUrls: { webSocket: ['wss://westend-rpc.polkadot.io'] },\n ss58Format: 42,\n blockExplorers: { default: { name: 'Subscan', url: 'https://westend.subscan.io' } },\n chainIconUrl: westendSVG,\n testnet: true,\n};\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/connectors/base.ts","../src/connectors/common.ts","../src/connectors/polkadot-js.ts","../src/connectors/polkagate.ts","../src/connectors/subwallet.ts","../src/connectors/talisman.ts","../src/connectors/walletconnect.ts","../src/connectors/novaMobile.ts","../src/connectors/nova.ts"],"names":["BaseConnector","EventEmitter","chainId","CommonConnector","options","injectedWeb3","appName","rawAccounts","mapInjectedAccounts","error","message","address","signer","acc","dataHex","stringToHex","updatedRawAccounts","newAccounts","polkadotjsConnector","polkadotjsSVG","polkagateConnector","polkagateSVG","subwalletConnector","subwalletSVG","talismanConnector","talismanSVG","WalletConnectConnector","walletconnectSVG","chains","chain","targetChainId","UniversalProvider","chainIdToUse","accounts","uri","approval","session","targetChain","caipId","result","resolve","payload","sessionDeleteHandler","walletConnectConnector","NovaMobileConnector","novaSVG","novaMobileConnector","novaConnector","config","isMobileDevice"],"mappings":"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","file":"chunk-HQJ3DJ5D.cjs","sourcesContent":["import type {Account, Chain, Signer} from '../types';\nimport { EventEmitter } from 'eventemitter3';\nimport { ConnectorLinks } from '../types'\n\n/**\n * base connector abstract class\n * defines the basic properties and methods that all wallet connectors should have.\n */\nexport abstract class BaseConnector extends EventEmitter {\n /**\n * the unique identifier of the connector (e.g., 'polkadot-js', 'subwallet-js')\n * subclasses must implement.\n */\n abstract readonly id: string;\n\n /**\n * user-friendly connector name (e.g., 'Polkadot{.js}', 'SubWallet')\n * subclasses must implement.\n */\n abstract readonly name: string;\n\n /**\n * connector icon URL (optional)\n * subclasses can implement.\n */\n abstract readonly icon?: string;\n\n readonly links: ConnectorLinks = {};\n /**\n * store the current connected accounts.\n * subclasses are responsible for maintaining this list when connecting and updating accounts.\n */\n protected accounts: Account[] = [];\n /**\n * store the signer.\n * subclasses are responsible for getting and storing it when connecting.\n */\n protected signer: Signer | undefined = undefined;\n\n protected connectionUri: string | undefined = undefined;\n\n constructor() {\n super();\n }\n\n public abstract isAvailable(): Promise<boolean>;\n\n public abstract isInstalled(): boolean;\n\n /**\n * connect to the wallet, get the initial accounts and signer, and set the necessary event listeners.\n * subclasses must implement:\n * 1. get the signer and assign it to this.signer.\n * 2. get the initial accounts list and assign it to this.accounts.\n * 3. set the account update mechanism of itself (e.g., use web3AccountsSubscribe or WalletConnect events).\n * 4. update this.accounts when the account list changes and trigger the 'accountsChanged' event.\n * 5. (optional) trigger the 'connect' event.\n * @returns the initial available accounts list\n */\n abstract connect(appName: string, chains?: Chain[], targetChainId?: string): Promise<Array<Account>>;\n /**\n * disconnect from the wallet.\n * subclasses must implement this method to perform specific cleanup logic\n * (e.g., unsubscribe, close session).\n * implementers should clear this.accounts and this.signer after cleanup and trigger the 'disconnect' event.\n */\n abstract disconnect(): Promise<void>;\n\n /**\n * get the current connected accounts list.\n * @returns the current available accounts list\n */\n public async getAccounts(): Promise<Array<Account>> {\n return [...this.accounts];\n }\n\n /**\n * get the cached signer object.\n * @returns the signer object, or undefined if the connection is not successful or cannot be obtained.\n */\n public async getSigner(): Promise<Signer | undefined> {\n if (!this.signer) {\n console.warn(`Connector ${this.id}: Signer not available. Connection might be incomplete or failed.`);\n }\n return this.signer;\n }\n\n /**\n * sign a message with the specified account.\n */\n abstract signMessage(message: string, address: string, chainId?: string): Promise<string | undefined>;\n\n public hasConnectionUri(): boolean {\n return false\n }\n\n public async getConnectionUri(): Promise<string | undefined >{\n return this.connectionUri;\n }\n\n public async updateAccountsForChain(chainId: string): Promise<Account[]> {\n return [...this.accounts];\n }\n}\n","import { BaseConnector } from './base';\nimport type { Account, Signer } from '../types';\nimport { mapInjectedAccounts } from '../utils'\nimport { Injected, InjectedAccount } from 'dedot/types'\nimport { stringToHex } from 'dedot/utils'\nimport { ConnectorLinks } from '../types'\n\nexport interface CommonConnectorOptions {\n id: string;\n name: string;\n icon: string;\n links: ConnectorLinks;\n injectorId?: string;\n}\n\nexport class CommonConnector extends BaseConnector {\n readonly id: string;\n readonly name: string;\n readonly icon: string;\n readonly links: ConnectorLinks;\n protected readonly injectorId: string;\n\n private unsubscribe: (() => void) | null = null;\n\n private specificInjector?: Injected = undefined\n\n constructor(options: CommonConnectorOptions) {\n super();\n this.id = options.id;\n this.name = options.name;\n this.icon = options.icon;\n this.links = options.links;\n this.injectorId = options.injectorId || options.id;\n }\n\n public isInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n const injectedWeb3 = window.injectedWeb3;\n return typeof injectedWeb3 === 'object' && typeof injectedWeb3[this.injectorId] !== 'undefined';\n }\n\n public async isAvailable(): Promise<boolean> {\n return this.isInstalled();\n }\n\n public async connect(appName: string): Promise<Array<Account>> {\n console.log(`Connector ${this.id}: Attempting to connect...`);\n if (this.signer) {\n console.log(`Connector ${this.id}: Already connected.`);\n return [...this.accounts];\n }\n if (!(await this.isAvailable())) {\n throw new Error(`${this.name} extension not found or not enabled.`);\n }\n\n try {\n this.specificInjector = await window.injectedWeb3![this.injectorId]!.enable(appName);\n\n if (!this.specificInjector) {\n throw new Error(`Failed to enable the '${this.id}' extension.`);\n }\n\n this.signer = this.specificInjector.signer as Signer;\n\n if (!this.signer) {\n throw new Error(`Could not get signer from ${this.name}.`);\n }\n\n const rawAccounts = await this.specificInjector.accounts.get();\n if (rawAccounts.length === 0) {\n throw new Error(`No accounts found in ${this.name}. Make sure accounts are visible and access is granted.`);\n }\n this.accounts = mapInjectedAccounts(rawAccounts, this.id);\n console.log(`Connector ${this.id}: Initial accounts loaded`, this.accounts);\n\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n\n return [...this.accounts];\n\n } catch (error) {\n console.error(`Connector ${this.id}: Connection failed:`, error);\n await this.cleanup();\n throw error;\n }\n }\n\n public async disconnect(): Promise<void> {\n console.log(`Connector ${this.id}: Disconnecting...`);\n await this.cleanup();\n this.emit('disconnect');\n }\n\n public async signMessage(message: string, address: string): Promise<string | undefined> {\n if (!address || !message) return undefined;\n const signer = await this.getSigner();\n if (!signer || !signer?.signRaw) {\n throw new Error('Signer is not available or does not support signRaw.');\n }\n const accounts = await this.getAccounts();\n if (!accounts.some(acc => acc.address.toLowerCase() === address.toLowerCase())) {\n throw new Error(`Address ${address} is not managed by ${this.name}.`);\n }\n\n try {\n const dataHex = stringToHex(message);\n const result = await signer.signRaw({ address, data: dataHex, type: 'bytes' });\n return result.signature;\n } catch (error: any) {\n throw new Error(`Connector ${this.id}: Failed to sign message: ${error.message}`);\n }\n }\n\n\n private async startSubscription(): Promise<void> {\n await this.cleanupSubscription();\n if (!this.specificInjector) {\n throw new Error(`Connector ${this.id}: Cannot subscribe, specificInjector not available.`);\n }\n\n try {\n this.unsubscribe = this.specificInjector.accounts.subscribe(\n (updatedRawAccounts: InjectedAccount[]) => {\n const newAccounts = mapInjectedAccounts(updatedRawAccounts, this.id);\n if (JSON.stringify(this.accounts) !== JSON.stringify(newAccounts)) {\n this.accounts = newAccounts;\n this.emit('accountsChanged', [...this.accounts]);\n }\n }\n );\n console.log(`Connector ${this.id}: Subscribed to account changes.`);\n } catch (error) {\n console.error(`Connector ${this.id}: Failed to subscribe to accounts:`, error);\n this.unsubscribe = null;\n }\n }\n\n private async cleanupSubscription(): Promise<void> {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n console.log(`Connector ${this.id}: Unsubscribed from account changes.`);\n }\n }\n\n\n private async cleanup(): Promise<void> {\n await this.cleanupSubscription();\n this.accounts = [];\n this.signer = undefined;\n this.specificInjector = undefined\n }\n}\n","import { CommonConnector } from './common'\nimport { polkadotjsSVG } from '../config/logos/generated'\n\nexport const polkadotjsConnector = () => {\n return new CommonConnector({\n id: 'polkadot-js',\n name: 'Polkadot{.js}',\n icon: polkadotjsSVG,\n links: {\n browserExtension: 'https://polkadot.js.org/extension'\n }\n });\n}\n","import { polkagateSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const polkagateConnector = () => {\n return new CommonConnector({\n id: 'polkagate',\n name: 'Polkagate',\n icon: polkagateSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/polkagate-the-gateway-to/ginchbkmljhldofnbjabmeophlhdldgp'\n }\n });\n}\n","import { subwalletSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const subwalletConnector = () => {\n return new CommonConnector({\n id: 'subwallet-js',\n name: 'SubWallet',\n icon: subwalletSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/subwallet-polkadot-wallet/onhogfjeacnfoofkfgppdlbmlmnplgbn',\n deepLink: 'https://mobile.subwallet.app/browser',\n }\n })\n};\n","import { talismanSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport const talismanConnector = () => {\n return new CommonConnector({\n id: 'talisman',\n name: 'Talisman',\n icon: talismanSVG,\n links: {\n browserExtension: 'https://chromewebstore.google.com/detail/talisman-wallet/fijngjgcjhjmmpcmkeiomlglpeiijkld'\n }\n });\n}\n","import { BaseConnector } from './base';\nimport type { IUniversalProvider, Metadata } from '@walletconnect/universal-provider';\nimport { SessionTypes, SignClientTypes } from '@walletconnect/types'\nimport type { Account, Chain, Signer, WalletConnectConnectorOptions } from '../types';\nimport { walletconnectSVG } from '../config/logos/generated';\nimport { SignerResult, SignerPayloadJSON } from 'dedot/types'\nimport { ConnectorLinks } from '../types'\n\nexport class WalletConnectConnector extends BaseConnector {\n readonly id: string;\n readonly name: string;\n readonly icon: string;\n readonly links: ConnectorLinks;\n\n private provider?: IUniversalProvider;\n private projectId: string;\n private relayUrl: string;\n private metadata?: Metadata;\n\n private session?: SessionTypes.Struct;\n private connectedChains?: Chain[];\n\n private unsubscribe: (() => void) | null = null;\n\n constructor(options: WalletConnectConnectorOptions) {\n super();\n this.id = options.id || 'walletconnect';\n this.name = options.name || 'WalletConnect';\n this.links = options.links || {};\n\n this.icon = options.icon || walletconnectSVG;\n\n this.projectId = options.projectId;\n this.relayUrl = options.relayUrl || 'wss://relay.walletconnect.com';\n this.metadata = options.metadata;\n }\n\n public isInstalled(): boolean {\n return false;\n }\n\n public async isAvailable(): Promise<boolean> {\n return true;\n }\n\n private convertChainIdToCaipId(chains: Chain[]): string[] {\n return chains.map(chain => `polkadot:${chain.genesisHash.replace('0x', '').slice(0, 32)}`);\n }\n\n public async connect(appName: string, chains?: Chain[], targetChainId?: string): Promise<Array<Account>> {\n if (!this.projectId) {\n throw new Error(`${this.name} requires a projectId. Please visit https://cloud.walletconnect.com to get one.`);\n }\n\n if (!chains || chains.length === 0) {\n throw new Error(`${this.name} requires chains configuration.`);\n }\n\n this.connectedChains = chains;\n\n const { UniversalProvider } = await import(\"@walletconnect/universal-provider\");\n\n try {\n this.provider = await UniversalProvider.init({\n projectId: this.projectId,\n relayUrl: this.relayUrl,\n metadata: this.metadata || {\n name: appName,\n description: 'LunoKit DApp',\n url: typeof window !== 'undefined' ? window.location.origin : '',\n icons: [this.icon],\n },\n });\n\n const chainIdToUse = targetChainId || chains[0].genesisHash;\n\n if (this.provider.session) {\n this.session = this.provider.session;\n const accounts = this.getAccountsFromSession(chains, chainIdToUse);\n this.accounts = accounts;\n\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n return [...this.accounts];\n }\n\n if (!this.provider?.client) {\n throw new Error(\"Provider not initialized or not connected\");\n }\n\n const { uri, approval } = await this.provider.client.connect({\n requiredNamespaces: {\n polkadot: {\n methods: ['polkadot_signMessage', 'polkadot_sendTransaction', 'polkadot_signTransaction', 'polkadot_requestAccounts'],\n chains: this.convertChainIdToCaipId(chains),\n events: ['accountsChanged', 'chainChanged', 'connect'],\n },\n },\n optionalNamespaces: {\n polkadot: {\n methods: ['polkadot_signMessage', 'polkadot_sendTransaction', 'polkadot_signTransaction', 'polkadot_requestAccounts'],\n chains: this.convertChainIdToCaipId(chains),\n events: ['accountsChanged', 'chainChanged', 'connect'],\n },\n },\n });\n\n this.emit('get_uri', uri);\n\n const session = await approval();\n this.session = session;\n this.provider.session = session;\n\n this.connectionUri = undefined;\n\n const accounts = this.getAccountsFromSession(chains, chainIdToUse);\n this.accounts = accounts;\n\n // 启动订阅\n await this.startSubscription();\n\n this.emit('connect', [...this.accounts]);\n return [...this.accounts];\n\n } catch (error) {\n this.connectionUri = undefined;\n throw error;\n }\n }\n\n private getAccountsFromSession(chains: Chain[], chainId: string): Account[] {\n const targetChain = chains.filter(chain => chain.genesisHash.toLowerCase() === chainId.toLowerCase())\n const caipId = this.convertChainIdToCaipId(targetChain)[0];\n\n let rawAccounts = this.session?.namespaces.polkadot.accounts\n .flat()\n .filter((address: string) => address.includes(caipId))\n .map((address: string) => address.replace(`${caipId}:`, \"\"))\n\n if (rawAccounts && rawAccounts.length === 0) {\n console.error(`No accounts found for the specified chain, please connect to the correct chain`);\n\n const caipId = this.convertChainIdToCaipId(chains)[0];\n\n rawAccounts = this.session?.namespaces.polkadot.accounts\n .flat()\n .filter((address: string) => address.includes(caipId))\n .map((address: string) => address.replace(`${caipId}:`, \"\"))\n }\n\n const result = rawAccounts!\n .map((address: string) => ({\n address,\n name: `${this.name} Account`,\n meta: {\n source: this.id,\n },\n publicKey: undefined,\n }));\n\n this.emit('accountsChanged', [...result]);\n\n return result!\n }\n\n public async disconnect(): Promise<void> {\n if (this.provider) {\n console.log('this.provider', this.provider)\n console.log('this.sessionsession', this.session)\n // await Promise.race([\n await this.provider.disconnect()\n // new Promise((_, reject) =>\n // setTimeout(() => reject(new Error('Disconnect timeout')), 5000)\n // )\n // ]);\n }\n await this.cleanup()\n this.emit('disconnect');\n }\n\n public async signMessage(message: string, address: string, chainId?: string): Promise<string | undefined> {\n if (!this.provider?.client || !this.session?.topic) {\n throw new Error(\"Provider not initialized or not connected\");\n }\n\n const targetChainId = chainId\n ? `polkadot:${chainId.replace('0x', '').slice(0, 32)}`\n : this.convertChainIdToCaipId(this.connectedChains!)[0]\n\n try {\n const result = await this.provider.client.request({\n topic: this.session.topic,\n chainId: targetChainId,\n request: {\n method: 'polkadot_signMessage',\n params: {\n address,\n message,\n type: 'bytes'\n },\n },\n });\n\n return (result as any)?.signature;\n } catch (error) {\n console.error('Sign message error:', error);\n throw error;\n }\n }\n\n public hasConnectionUri(): boolean {\n return true\n }\n\n public async getConnectionUri(): Promise<string> {\n if (this.connectionUri) {\n return this.connectionUri;\n }\n\n return new Promise<string>((resolve) => {\n this.once('get_uri', (uri: string) => {\n this.connectionUri = uri;\n resolve(uri);\n });\n });\n }\n\n public async updateAccountsForChain(chainId: string) {\n if (!this.connectedChains) {\n throw new Error('WalletConnect not connected');\n }\n\n const newAccounts = this.getAccountsFromSession(this.connectedChains, chainId);\n this.accounts = newAccounts;\n\n return newAccounts;\n }\n\n\n public async getSigner(): Promise<Signer | undefined> {\n if (!this.provider?.client || !this.session) return undefined;\n\n return {\n signPayload: async (payload: SignerPayloadJSON): Promise<SignerResult> => {\n try {\n const result = await this.provider?.client?.request<{ signature: string }>({\n topic: this.session!.topic,\n chainId: `polkadot:${payload.genesisHash.replace('0x', '').slice(0, 32)}`,\n request: {\n method: 'polkadot_signTransaction',\n params: {\n address: payload.address,\n transactionPayload: payload,\n },\n },\n });\n return result as SignerResult;\n } catch (error) {\n throw new Error(`Transaction signing failed: ${JSON.stringify(error)}`);\n }\n }\n };\n }\n\n private async startSubscription(): Promise<void> {\n await this.cleanupSubscription();\n\n if (!this.provider?.client || !this.session) {\n throw new Error(`Connector ${this.id}: Cannot subscribe, provider or session not available.`);\n }\n\n try {\n const sessionDeleteHandler = async () => {\n console.log(`Connector ${this.id}: Session deleted, disconnecting...`);\n await this.cleanup()\n this.emit('disconnect');\n }\n this.provider.client.on('session_delete', sessionDeleteHandler);\n\n this.unsubscribe = () => {\n this.provider?.client?.off('session_delete', sessionDeleteHandler)\n }\n\n } catch (error) {\n this.unsubscribe = null;\n }\n }\n\n private async cleanupSubscription(): Promise<void> {\n if (this.unsubscribe) {\n this.unsubscribe();\n this.unsubscribe = null;\n console.log(`Connector ${this.id}: Unsubscribed from events.`);\n }\n }\n\n private async cleanup(): Promise<void> {\n await this.cleanupSubscription();\n this.accounts = [];\n this.signer = undefined;\n this.provider = undefined;\n this.session = undefined;\n }\n}\n\nexport const walletConnectConnector = (options: WalletConnectConnectorOptions) =>\n new WalletConnectConnector(options);\n","import { novaSVG } from '../config/logos/generated'\nimport { CommonConnector } from './common'\n\nexport class NovaMobileConnector extends CommonConnector {\n constructor() {\n super({\n id: 'nova-mobile',\n name: 'Nova Wallet',\n icon: novaSVG,\n injectorId: 'polkadot-js',\n links: {\n deepLink: 'https://app.novawallet.io/open/dapp'\n }\n });\n }\n\n public isInstalled(): boolean {\n if (typeof window === 'undefined') return false;\n const injectedWeb3 = window.injectedWeb3;\n return (\n typeof injectedWeb3 === 'object' &&\n typeof injectedWeb3['polkadot-js'] !== 'undefined' &&\n window.walletExtension?.isNovaWallet === true\n );\n }\n\n public async isAvailable(): Promise<boolean> {\n return this.isInstalled();\n }\n}\n\nexport const novaMobileConnector = () => new NovaMobileConnector()\n","import { novaSVG } from '../config/logos/generated'\nimport { WalletConnectConnector } from './walletconnect'\nimport type { Metadata } from '@walletconnect/universal-provider'\nimport { novaMobileConnector } from './novaMobile'\nimport { isMobileDevice } from '../utils'\n\ntype WalletConnectConfig = {\n projectId: string;\n relayUrl?: string;\n metadata?: Metadata;\n}\n\ntype MobileOnlyConfig = {\n mobileOnly: true;\n}\n\ntype NovaConnectorConfig = WalletConnectConfig | MobileOnlyConfig;\n\nexport const novaConnector = (config: NovaConnectorConfig) => {\n if ((config as MobileOnlyConfig).mobileOnly && !isMobileDevice()) {\n throw new Error('Nova Wallet mobile connector cannot be used on desktop devices');\n }\n\n if ((config as MobileOnlyConfig).mobileOnly) {\n throw new Error('Nova Wallet is not installed. Please install Nova Wallet to continue.');\n }\n\n if (isMobileDevice()) {\n return novaMobileConnector();\n }\n\n return new WalletConnectConnector({\n id: 'nova',\n name: 'Nova Wallet',\n icon: novaSVG,\n links: {\n browserExtension: 'https://novawallet.io',\n },\n ...config as WalletConnectConfig,\n });\n};\n"]}
@@ -1,3 +0,0 @@
1
- import {d,a,c,j}from'./chunk-LXQJABLC.js';var r={genesisHash:"0x91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3",name:"Polkadot",nativeCurrency:{name:"Polkadot",symbol:"DOT",decimals:10},rpcUrls:{webSocket:["wss://rpc.polkadot.io","wss://polkadot.api.onfinality.io/public-ws"],http:["https://rpc.polkadot.io"]},ss58Format:0,blockExplorers:{default:{name:"Subscan",url:"https://polkadot.subscan.io"}},chainIconUrl:d};var p={genesisHash:"0xb0a8d493285c2df73290dfb7e61f870f17b41801197a149ca93654499ea3dafe",name:"Kusama",nativeCurrency:{name:"Kusama",symbol:"KSM",decimals:12},rpcUrls:{webSocket:["wss://kusama-rpc.polkadot.io","wss://kusama.api.onfinality.io/public-ws"]},ss58Format:2,blockExplorers:{default:{name:"Subscan",url:"https://kusama.subscan.io"}},chainIconUrl:a};var l={genesisHash:"0x77afd6190f1554ad45fd0d31aee62aacc33c6db0ea801129acb813f913e0764f",name:"Paseo",nativeCurrency:{name:"Paseo",symbol:"PAS",decimals:10},rpcUrls:{webSocket:["wss://rpc.ibp.network/paseo","wss://paseo.rpc.amforc.com"]},ss58Format:0,blockExplorers:{default:{name:"Subscan",url:"https://paseo.subscan.io/"}},chainIconUrl:c,testnet:true};var b={genesisHash:"0xe143f23803ac50e8f6f8e62695d1ce9e4e1d68aa36c1cd2cfd15340213f3423e",name:"Westend",nativeCurrency:{name:"Westend",symbol:"WND",decimals:12},rpcUrls:{webSocket:["wss://westend-rpc.polkadot.io"]},ss58Format:42,blockExplorers:{default:{name:"Subscan",url:"https://westend.subscan.io"}},chainIconUrl:j,testnet:true};
2
- export{r as a,p as b,l as c,b as d};//# sourceMappingURL=chunk-TK2GOG2I.js.map
3
- //# sourceMappingURL=chunk-TK2GOG2I.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/chains/polkadot.ts","../src/chains/kusama.ts","../src/chains/paseo.ts","../src/chains/westend.ts"],"names":["polkadot","polkadotSVG","kusama","kusamaSVG","paseo","paseoSVG","westend","westendSVG"],"mappings":"0CAGO,IAAMA,EAAkB,CAC7B,WAAA,CAAa,oEAAA,CACb,IAAA,CAAM,WACN,cAAA,CAAgB,CAAE,IAAA,CAAM,UAAA,CAAY,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAChE,QAAS,CACP,SAAA,CAAW,CAAC,uBAAA,CAAyB,4CAA4C,CAAA,CACjF,IAAA,CAAM,CAAC,yBAAyB,CAClC,CAAA,CACA,UAAA,CAAY,CAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,KAAM,SAAA,CAAW,GAAA,CAAK,6BAA8B,CAAE,CAAA,CACnF,YAAA,CAAcC,CAChB,ECXO,IAAMC,CAAAA,CAAgB,CAC3B,WAAA,CAAa,qEACb,IAAA,CAAM,QAAA,CACN,cAAA,CAAgB,CAAE,KAAM,QAAA,CAAU,MAAA,CAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAC9D,OAAA,CAAS,CAAE,SAAA,CAAW,CAAC,8BAAA,CAAgC,0CAA0C,CAAE,CAAA,CACnG,WAAY,CAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,SAAA,CAAW,IAAK,2BAA4B,CAAE,EACjF,YAAA,CAAcC,CAChB,ECRO,IAAMC,EAAe,CAC1B,WAAA,CAAa,oEAAA,CACb,IAAA,CAAM,QACN,cAAA,CAAgB,CAAE,IAAA,CAAM,OAAA,CAAS,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAC7D,QAAS,CAAE,SAAA,CAAW,CAAC,6BAAA,CAA+B,4BAA4B,CAAE,CAAA,CACpF,UAAA,CAAY,CAAA,CACZ,eAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,UAAW,GAAA,CAAK,2BAA4B,CAAE,CAAA,CACjF,YAAA,CAAcC,EACd,OAAA,CAAS,IACX,ECTO,IAAMC,EAAiB,CAC5B,WAAA,CAAa,oEAAA,CACb,IAAA,CAAM,UACN,cAAA,CAAgB,CAAE,IAAA,CAAM,SAAA,CAAW,OAAQ,KAAA,CAAO,QAAA,CAAU,EAAG,CAAA,CAC/D,QAAS,CAAE,SAAA,CAAW,CAAC,+BAA+B,CAAE,CAAA,CACxD,UAAA,CAAY,EAAA,CACZ,cAAA,CAAgB,CAAE,OAAA,CAAS,CAAE,IAAA,CAAM,SAAA,CAAW,IAAK,4BAA6B,CAAE,EAClF,YAAA,CAAcC,CAAAA,CACd,QAAS,IACX","file":"chunk-TK2GOG2I.js","sourcesContent":["import type { Chain } from '../types'\nimport { polkadotSVG } from '../config/logos/generated'\n\nexport const polkadot: Chain = {\n genesisHash: '0x91b171bb158e2d3848fa23a9f1c25182fb8e20313b2c1eb49219da7a70ce90c3',\n name: 'Polkadot',\n nativeCurrency: { name: 'Polkadot', symbol: 'DOT', decimals: 10 },\n rpcUrls: {\n webSocket: ['wss://rpc.polkadot.io', 'wss://polkadot.api.onfinality.io/public-ws'],\n http: ['https://rpc.polkadot.io'],\n },\n ss58Format: 0,\n blockExplorers: { default: { name: 'Subscan', url: 'https://polkadot.subscan.io' } },\n chainIconUrl: polkadotSVG\n};\n","import type { Chain } from '../types'\nimport { kusamaSVG } from '../config/logos/generated'\n\nexport const kusama: Chain = {\n genesisHash: '0xb0a8d493285c2df73290dfb7e61f870f17b41801197a149ca93654499ea3dafe',\n name: 'Kusama',\n nativeCurrency: { name: 'Kusama', symbol: 'KSM', decimals: 12 },\n rpcUrls: { webSocket: ['wss://kusama-rpc.polkadot.io', 'wss://kusama.api.onfinality.io/public-ws'] },\n ss58Format: 2,\n blockExplorers: { default: { name: 'Subscan', url: 'https://kusama.subscan.io' } },\n chainIconUrl: kusamaSVG\n};\n","import type { Chain } from '../types'\nimport { paseoSVG } from '../config/logos/generated'\n\nexport const paseo: Chain = {\n genesisHash: '0x77afd6190f1554ad45fd0d31aee62aacc33c6db0ea801129acb813f913e0764f',\n name: 'Paseo',\n nativeCurrency: { name: 'Paseo', symbol: 'PAS', decimals: 10 },\n rpcUrls: { webSocket: ['wss://rpc.ibp.network/paseo', 'wss://paseo.rpc.amforc.com'] },\n ss58Format: 0,\n blockExplorers: { default: { name: 'Subscan', url: 'https://paseo.subscan.io/' } },\n chainIconUrl: paseoSVG,\n testnet: true\n};\n","import type { Chain } from '../types'\nimport { westendSVG } from '../config/logos/generated'\n\nexport const westend: Chain = {\n genesisHash: '0xe143f23803ac50e8f6f8e62695d1ce9e4e1d68aa36c1cd2cfd15340213f3423e',\n name: 'Westend',\n nativeCurrency: { name: 'Westend', symbol: 'WND', decimals: 12 },\n rpcUrls: { webSocket: ['wss://westend-rpc.polkadot.io'] },\n ss58Format: 42,\n blockExplorers: { default: { name: 'Subscan', url: 'https://westend.subscan.io' } },\n chainIconUrl: westendSVG,\n testnet: true,\n};\n"]}