@xyo-network/metamask-connector 2.109.0 → 2.110.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/index.cjs +0 -2
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.d.cts +1 -1
- package/dist/browser/index.d.cts.map +1 -1
- package/dist/browser/index.d.mts +1 -1
- package/dist/browser/index.d.mts.map +1 -1
- package/dist/browser/index.d.ts +1 -1
- package/dist/browser/index.d.ts.map +1 -1
- package/dist/browser/index.js +0 -2
- package/dist/browser/index.js.map +1 -1
- package/dist/neutral/index.cjs +0 -2
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.d.cts +1 -1
- package/dist/neutral/index.d.cts.map +1 -1
- package/dist/neutral/index.d.mts +1 -1
- package/dist/neutral/index.d.mts.map +1 -1
- package/dist/neutral/index.d.ts +1 -1
- package/dist/neutral/index.d.ts.map +1 -1
- package/dist/neutral/index.js +0 -2
- package/dist/neutral/index.js.map +1 -1
- package/dist/node/index.cjs +0 -4
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.d.cts +1 -1
- package/dist/node/index.d.cts.map +1 -1
- package/dist/node/index.d.mts +1 -1
- package/dist/node/index.d.mts.map +1 -1
- package/dist/node/index.d.ts +1 -1
- package/dist/node/index.d.ts.map +1 -1
- package/dist/node/index.js +0 -4
- package/dist/node/index.js.map +1 -1
- package/package.json +2 -2
- package/src/MetaMaskConnector.ts +2 -2
- package/src/index.ts +1 -1
package/dist/browser/index.cjs
CHANGED
|
@@ -108,11 +108,9 @@ var MetaMaskConnector = class {
|
|
|
108
108
|
]);
|
|
109
109
|
}
|
|
110
110
|
providerRemoveListener(event, listener) {
|
|
111
|
-
this.ethereum?.removeListener(event, listener);
|
|
112
111
|
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
113
112
|
}
|
|
114
113
|
providerRemoveListeners() {
|
|
115
|
-
for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener);
|
|
116
114
|
}
|
|
117
115
|
async requestAccounts() {
|
|
118
116
|
if (!this.provider) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACCA,oBAAuB;AACvB,oBAA0C;AAEnC,IAAMA,oBAAN,MAAMA;EAHb,OAGaA;;;EACHC,UAAU;EACVC,WAAWC,OAAOD;EAElBE,YAAwB,CAAA;EACxBC;EACAC,oBAA2D,CAAA;EAEnEC,YAAYF,UAA4B;AACtC,QAAIA,UAAU;AACZ,WAAKA,WAAWA;IAClB,WAAW,KAAKH,UAAU;AACxB,WAAKG,WAAW,IAAIG,8BAAgBL,OAAOD,QAAQ;IACrD;EACF;EAEA,IAAIO,UAAU;AACZ,WAAO,KAAKP,UAAUQ;EACxB;EAEA,IAAIC,iBAAiB;AACnB,WAAO,KAAKT,UAAUU;EACxB;EAEA,MAAMC,gBAAgB;AACpB,QAAI,CAAC,KAAKR,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMC,WAAW,MAAM,KAAKV,SAASW,KAAK,uBAAuB,CAAA,CAAE;AAEnE,QAAID,SAASE,SAAS,GAAG;AACvB,WAAKhB,UAAUc,SAAS,CAAA;AACxBG,cAAQC,IAAI,cAAc,KAAKlB,OAAO;IACxC,OAAO;AACLiB,cAAQC,IAAI,8BAAA;IACd;EACF;EAEAC,sBAAsB;AACpB,WAAO,KAAKlB,YAAY,KAAKA,SAASmB;EACxC;EAEAC,sBAAsB,6BAAA;AACpB,QAAI,KAAKX,gBAAgB;AACvBO,cAAQC,IAAI,gCAAgC,KAAKjB,UAAUU,eAAAA;AAC3D,aAAO;IACT;AACA,WAAO;EACT,GANsB;;;;;;;EActBW,0BAA0BC,UAAoB;AAC5C,SAAKtB,UAAUuB,GAAG,mBAAmBD,QAAAA;AACrC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAmBF;KAAS;EAC3D;EAEAG,uBAAuBH,UAAoB;AACzC,SAAKtB,UAAUuB,GAAG,gBAAgBD,QAAAA;AAClC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAgBF;KAAS;EACxD;EAEAI,kBAAkBJ,UAAoB;AACpC,SAAKtB,UAAUuB,GAAG,WAAWD,QAAAA;AAC7B,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAWF;KAAS;EACnD;EAEAK,qBAAqBL,UAAoB;AACvC,SAAKtB,UAAUuB,GAAG,cAAcD,QAAAA;AAChC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAcF;KAAS;EACtD;EAEAM,uBAAuBC,OAAeP,UAAoB;
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector.js'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n //this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n //for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":"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","names":["MetaMaskConnector","account","ethereum","window","listeners","provider","providerListeners","constructor","BrowserProvider","chainId","networkVersion","currentAccount","selectedAddress","connectWallet","logProviderMissing","accounts","send","length","console","log","isMetaMaskInstalled","isMetaMask","isWalletIsConnected","providerOnAccountsChanged","listener","on","push","providerOnChainChanged","providerOnConnect","providerOnDisconnect","providerRemoveListener","event","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","forget","web3ProviderRemoveListener","removeListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
|
package/dist/browser/index.d.cts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/browser/index.d.mts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/browser/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/browser/index.js
CHANGED
|
@@ -84,11 +84,9 @@ var MetaMaskConnector = class {
|
|
|
84
84
|
]);
|
|
85
85
|
}
|
|
86
86
|
providerRemoveListener(event, listener) {
|
|
87
|
-
this.ethereum?.removeListener(event, listener);
|
|
88
87
|
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
89
88
|
}
|
|
90
89
|
providerRemoveListeners() {
|
|
91
|
-
for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener);
|
|
92
90
|
}
|
|
93
91
|
async requestAccounts() {
|
|
94
92
|
if (!this.provider) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";;;;AACA,SAASA,cAAc;AACvB,SAASC,uBAAiC;AAEnC,IAAMC,oBAAN,MAAMA;EAHb,OAGaA;;;EACHC,UAAU;EACVC,WAAWC,OAAOD;EAElBE,YAAwB,CAAA;EACxBC;EACAC,oBAA2D,CAAA;EAEnEC,YAAYF,UAA4B;AACtC,QAAIA,UAAU;AACZ,WAAKA,WAAWA;IAClB,WAAW,KAAKH,UAAU;AACxB,WAAKG,WAAW,IAAIG,gBAAgBL,OAAOD,QAAQ;IACrD;EACF;EAEA,IAAIO,UAAU;AACZ,WAAO,KAAKP,UAAUQ;EACxB;EAEA,IAAIC,iBAAiB;AACnB,WAAO,KAAKT,UAAUU;EACxB;EAEA,MAAMC,gBAAgB;AACpB,QAAI,CAAC,KAAKR,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMC,WAAW,MAAM,KAAKV,SAASW,KAAK,uBAAuB,CAAA,CAAE;AAEnE,QAAID,SAASE,SAAS,GAAG;AACvB,WAAKhB,UAAUc,SAAS,CAAA;AACxBG,cAAQC,IAAI,cAAc,KAAKlB,OAAO;IACxC,OAAO;AACLiB,cAAQC,IAAI,8BAAA;IACd;EACF;EAEAC,sBAAsB;AACpB,WAAO,KAAKlB,YAAY,KAAKA,SAASmB;EACxC;EAEAC,sBAAsB,6BAAA;AACpB,QAAI,KAAKX,gBAAgB;AACvBO,cAAQC,IAAI,gCAAgC,KAAKjB,UAAUU,eAAAA;AAC3D,aAAO;IACT;AACA,WAAO;EACT,GANsB;;;;;;;EActBW,0BAA0BC,UAAoB;AAC5C,SAAKtB,UAAUuB,GAAG,mBAAmBD,QAAAA;AACrC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAmBF;KAAS;EAC3D;EAEAG,uBAAuBH,UAAoB;AACzC,SAAKtB,UAAUuB,GAAG,gBAAgBD,QAAAA;AAClC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAgBF;KAAS;EACxD;EAEAI,kBAAkBJ,UAAoB;AACpC,SAAKtB,UAAUuB,GAAG,WAAWD,QAAAA;AAC7B,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAWF;KAAS;EACnD;EAEAK,qBAAqBL,UAAoB;AACvC,SAAKtB,UAAUuB,GAAG,cAAcD,QAAAA;AAChC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAcF;KAAS;EACtD;EAEAM,uBAAuBC,OAAeP,UAAoB;
|
|
1
|
+
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n //this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n //for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";;;;AACA,SAASA,cAAc;AACvB,SAASC,uBAAiC;AAEnC,IAAMC,oBAAN,MAAMA;EAHb,OAGaA;;;EACHC,UAAU;EACVC,WAAWC,OAAOD;EAElBE,YAAwB,CAAA;EACxBC;EACAC,oBAA2D,CAAA;EAEnEC,YAAYF,UAA4B;AACtC,QAAIA,UAAU;AACZ,WAAKA,WAAWA;IAClB,WAAW,KAAKH,UAAU;AACxB,WAAKG,WAAW,IAAIG,gBAAgBL,OAAOD,QAAQ;IACrD;EACF;EAEA,IAAIO,UAAU;AACZ,WAAO,KAAKP,UAAUQ;EACxB;EAEA,IAAIC,iBAAiB;AACnB,WAAO,KAAKT,UAAUU;EACxB;EAEA,MAAMC,gBAAgB;AACpB,QAAI,CAAC,KAAKR,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMC,WAAW,MAAM,KAAKV,SAASW,KAAK,uBAAuB,CAAA,CAAE;AAEnE,QAAID,SAASE,SAAS,GAAG;AACvB,WAAKhB,UAAUc,SAAS,CAAA;AACxBG,cAAQC,IAAI,cAAc,KAAKlB,OAAO;IACxC,OAAO;AACLiB,cAAQC,IAAI,8BAAA;IACd;EACF;EAEAC,sBAAsB;AACpB,WAAO,KAAKlB,YAAY,KAAKA,SAASmB;EACxC;EAEAC,sBAAsB,6BAAA;AACpB,QAAI,KAAKX,gBAAgB;AACvBO,cAAQC,IAAI,gCAAgC,KAAKjB,UAAUU,eAAAA;AAC3D,aAAO;IACT;AACA,WAAO;EACT,GANsB;;;;;;;EActBW,0BAA0BC,UAAoB;AAC5C,SAAKtB,UAAUuB,GAAG,mBAAmBD,QAAAA;AACrC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAmBF;KAAS;EAC3D;EAEAG,uBAAuBH,UAAoB;AACzC,SAAKtB,UAAUuB,GAAG,gBAAgBD,QAAAA;AAClC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAgBF;KAAS;EACxD;EAEAI,kBAAkBJ,UAAoB;AACpC,SAAKtB,UAAUuB,GAAG,WAAWD,QAAAA;AAC7B,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAWF;KAAS;EACnD;EAEAK,qBAAqBL,UAAoB;AACvC,SAAKtB,UAAUuB,GAAG,cAAcD,QAAAA;AAChC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAcF;KAAS;EACtD;EAEAM,uBAAuBC,OAAeP,UAAoB;AAExD,SAAKlB,oBAAoB,KAAKA,kBAAkB0B,OAAO,CAAC,CAAA,EAAGC,aAAAA,MAAmBT,aAAaS,aAAAA;EAC7F;EAEAC,0BAA0B;EAE1B;EAEA,MAAMC,kBAA4C;AAChD,QAAI,CAAC,KAAK9B,UAAU;AAClB,WAAKS,mBAAkB;AACvB,aAAO;IACT;AAEA,WAAO,MAAM,KAAKT,SAASW,KAAK,uBAAuB,CAAA,CAAE;EAC3D;EAEA,MAAMoB,YAAYC,SAAiB;AACjC,QAAI,CAAC,KAAKhC,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMwB,SAAS,MAAM,KAAKjC,SAASkC,UAAS;AAC5C,UAAMD,OAAOE,WAAU;AACvB,UAAMC,YAAY,MAAMH,OAAOF,YAAYC,OAAAA;AAC3C,WAAOI;EACT;;EAGAC,eAAeX,OAAeP,UAAoB;AAChD,QAAI,KAAKnB,UAAU;AACjBsC,aAAO,KAAKtC,SAASoB,GAAGM,OAAOP,QAAAA,CAAAA;IACjC;AACA,SAAKpB,UAAUsB,KAAKF,QAAAA;EACtB;EAEAoB,2BAA2Bb,OAAeP,UAAoB;AAC5D,QAAI,KAAKnB,UAAU;AACjBsC,aAAO,KAAKtC,SAASwC,eAAed,OAAOP,QAAAA,CAAAA;IAC7C;AACA,SAAKpB,YAAY,KAAKA,UAAU4B,OAAO,CAACC,kBAAkBT,aAAaS,aAAAA;EACzE;EAEAa,8BAA8B;AAC5B,QAAI,KAAKzC,UAAU;AACjBsC,aAAO,KAAKtC,SAAS0C,mBAAkB,CAAA;IACzC;EACF;EAEQjC,qBAAqB;AAC3BI,YAAQ8B,KAAK,iHAAA;EACf;AACF;","names":["forget","BrowserProvider","MetaMaskConnector","account","ethereum","window","listeners","provider","providerListeners","constructor","BrowserProvider","chainId","networkVersion","currentAccount","selectedAddress","connectWallet","logProviderMissing","accounts","send","length","console","log","isMetaMaskInstalled","isMetaMask","isWalletIsConnected","providerOnAccountsChanged","listener","on","push","providerOnChainChanged","providerOnConnect","providerOnDisconnect","providerRemoveListener","event","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","forget","web3ProviderRemoveListener","removeListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
|
package/dist/neutral/index.cjs
CHANGED
|
@@ -108,11 +108,9 @@ var MetaMaskConnector = class {
|
|
|
108
108
|
]);
|
|
109
109
|
}
|
|
110
110
|
providerRemoveListener(event, listener) {
|
|
111
|
-
this.ethereum?.removeListener(event, listener);
|
|
112
111
|
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
113
112
|
}
|
|
114
113
|
providerRemoveListeners() {
|
|
115
|
-
for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener);
|
|
116
114
|
}
|
|
117
115
|
async requestAccounts() {
|
|
118
116
|
if (!this.provider) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACCA,oBAAuB;AACvB,oBAA0C;AAEnC,IAAMA,oBAAN,MAAMA;EAHb,OAGaA;;;EACHC,UAAU;EACVC,WAAWC,OAAOD;EAElBE,YAAwB,CAAA;EACxBC;EACAC,oBAA2D,CAAA;EAEnEC,YAAYF,UAA4B;AACtC,QAAIA,UAAU;AACZ,WAAKA,WAAWA;IAClB,WAAW,KAAKH,UAAU;AACxB,WAAKG,WAAW,IAAIG,8BAAgBL,OAAOD,QAAQ;IACrD;EACF;EAEA,IAAIO,UAAU;AACZ,WAAO,KAAKP,UAAUQ;EACxB;EAEA,IAAIC,iBAAiB;AACnB,WAAO,KAAKT,UAAUU;EACxB;EAEA,MAAMC,gBAAgB;AACpB,QAAI,CAAC,KAAKR,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMC,WAAW,MAAM,KAAKV,SAASW,KAAK,uBAAuB,CAAA,CAAE;AAEnE,QAAID,SAASE,SAAS,GAAG;AACvB,WAAKhB,UAAUc,SAAS,CAAA;AACxBG,cAAQC,IAAI,cAAc,KAAKlB,OAAO;IACxC,OAAO;AACLiB,cAAQC,IAAI,8BAAA;IACd;EACF;EAEAC,sBAAsB;AACpB,WAAO,KAAKlB,YAAY,KAAKA,SAASmB;EACxC;EAEAC,sBAAsB,6BAAA;AACpB,QAAI,KAAKX,gBAAgB;AACvBO,cAAQC,IAAI,gCAAgC,KAAKjB,UAAUU,eAAAA;AAC3D,aAAO;IACT;AACA,WAAO;EACT,GANsB;;;;;;;EActBW,0BAA0BC,UAAoB;AAC5C,SAAKtB,UAAUuB,GAAG,mBAAmBD,QAAAA;AACrC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAmBF;KAAS;EAC3D;EAEAG,uBAAuBH,UAAoB;AACzC,SAAKtB,UAAUuB,GAAG,gBAAgBD,QAAAA;AAClC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAgBF;KAAS;EACxD;EAEAI,kBAAkBJ,UAAoB;AACpC,SAAKtB,UAAUuB,GAAG,WAAWD,QAAAA;AAC7B,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAWF;KAAS;EACnD;EAEAK,qBAAqBL,UAAoB;AACvC,SAAKtB,UAAUuB,GAAG,cAAcD,QAAAA;AAChC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAcF;KAAS;EACtD;EAEAM,uBAAuBC,OAAeP,UAAoB;
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector.js'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n //this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n //for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":"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","names":["MetaMaskConnector","account","ethereum","window","listeners","provider","providerListeners","constructor","BrowserProvider","chainId","networkVersion","currentAccount","selectedAddress","connectWallet","logProviderMissing","accounts","send","length","console","log","isMetaMaskInstalled","isMetaMask","isWalletIsConnected","providerOnAccountsChanged","listener","on","push","providerOnChainChanged","providerOnConnect","providerOnDisconnect","providerRemoveListener","event","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","forget","web3ProviderRemoveListener","removeListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
|
package/dist/neutral/index.d.cts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/neutral/index.d.mts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/neutral/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/neutral/index.js
CHANGED
|
@@ -84,11 +84,9 @@ var MetaMaskConnector = class {
|
|
|
84
84
|
]);
|
|
85
85
|
}
|
|
86
86
|
providerRemoveListener(event, listener) {
|
|
87
|
-
this.ethereum?.removeListener(event, listener);
|
|
88
87
|
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
89
88
|
}
|
|
90
89
|
providerRemoveListeners() {
|
|
91
|
-
for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener);
|
|
92
90
|
}
|
|
93
91
|
async requestAccounts() {
|
|
94
92
|
if (!this.provider) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";;;;AACA,SAASA,cAAc;AACvB,SAASC,uBAAiC;AAEnC,IAAMC,oBAAN,MAAMA;EAHb,OAGaA;;;EACHC,UAAU;EACVC,WAAWC,OAAOD;EAElBE,YAAwB,CAAA;EACxBC;EACAC,oBAA2D,CAAA;EAEnEC,YAAYF,UAA4B;AACtC,QAAIA,UAAU;AACZ,WAAKA,WAAWA;IAClB,WAAW,KAAKH,UAAU;AACxB,WAAKG,WAAW,IAAIG,gBAAgBL,OAAOD,QAAQ;IACrD;EACF;EAEA,IAAIO,UAAU;AACZ,WAAO,KAAKP,UAAUQ;EACxB;EAEA,IAAIC,iBAAiB;AACnB,WAAO,KAAKT,UAAUU;EACxB;EAEA,MAAMC,gBAAgB;AACpB,QAAI,CAAC,KAAKR,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMC,WAAW,MAAM,KAAKV,SAASW,KAAK,uBAAuB,CAAA,CAAE;AAEnE,QAAID,SAASE,SAAS,GAAG;AACvB,WAAKhB,UAAUc,SAAS,CAAA;AACxBG,cAAQC,IAAI,cAAc,KAAKlB,OAAO;IACxC,OAAO;AACLiB,cAAQC,IAAI,8BAAA;IACd;EACF;EAEAC,sBAAsB;AACpB,WAAO,KAAKlB,YAAY,KAAKA,SAASmB;EACxC;EAEAC,sBAAsB,6BAAA;AACpB,QAAI,KAAKX,gBAAgB;AACvBO,cAAQC,IAAI,gCAAgC,KAAKjB,UAAUU,eAAAA;AAC3D,aAAO;IACT;AACA,WAAO;EACT,GANsB;;;;;;;EActBW,0BAA0BC,UAAoB;AAC5C,SAAKtB,UAAUuB,GAAG,mBAAmBD,QAAAA;AACrC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAmBF;KAAS;EAC3D;EAEAG,uBAAuBH,UAAoB;AACzC,SAAKtB,UAAUuB,GAAG,gBAAgBD,QAAAA;AAClC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAgBF;KAAS;EACxD;EAEAI,kBAAkBJ,UAAoB;AACpC,SAAKtB,UAAUuB,GAAG,WAAWD,QAAAA;AAC7B,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAWF;KAAS;EACnD;EAEAK,qBAAqBL,UAAoB;AACvC,SAAKtB,UAAUuB,GAAG,cAAcD,QAAAA;AAChC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAcF;KAAS;EACtD;EAEAM,uBAAuBC,OAAeP,UAAoB;
|
|
1
|
+
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n //this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n //for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":"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","names":["forget","BrowserProvider","MetaMaskConnector","account","ethereum","window","listeners","provider","providerListeners","constructor","BrowserProvider","chainId","networkVersion","currentAccount","selectedAddress","connectWallet","logProviderMissing","accounts","send","length","console","log","isMetaMaskInstalled","isMetaMask","isWalletIsConnected","providerOnAccountsChanged","listener","on","push","providerOnChainChanged","providerOnConnect","providerOnDisconnect","providerRemoveListener","event","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","forget","web3ProviderRemoveListener","removeListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
|
package/dist/node/index.cjs
CHANGED
|
@@ -112,13 +112,9 @@ var _MetaMaskConnector = class _MetaMaskConnector {
|
|
|
112
112
|
]);
|
|
113
113
|
}
|
|
114
114
|
providerRemoveListener(event, listener) {
|
|
115
|
-
var _a;
|
|
116
|
-
(_a = this.ethereum) == null ? void 0 : _a.removeListener(event, listener);
|
|
117
115
|
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
118
116
|
}
|
|
119
117
|
providerRemoveListeners() {
|
|
120
|
-
var _a;
|
|
121
|
-
for (const [event, listener] of this.providerListeners) (_a = this.ethereum) == null ? void 0 : _a.removeListener(event, listener);
|
|
122
118
|
}
|
|
123
119
|
async requestAccounts() {
|
|
124
120
|
if (!this.provider) {
|
package/dist/node/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;ACCA,oBAAuB;AACvB,oBAA0C;AAEnC,IAAMA,qBAAN,MAAMA,mBAAAA;EACHC,UAAU;EACVC,WAAWC,OAAOD;EAElBE,YAAwB,CAAA;EACxBC;EACAC,oBAA2D,CAAA;EAEnEC,YAAYF,UAA4B;AACtC,QAAIA,UAAU;AACZ,WAAKA,WAAWA;IAClB,WAAW,KAAKH,UAAU;AACxB,WAAKG,WAAW,IAAIG,8BAAgBL,OAAOD,QAAQ;IACrD;EACF;EAEA,IAAIO,UAAU;AAnBhB;AAoBI,YAAO,UAAKP,aAAL,mBAAeQ;EACxB;EAEA,IAAIC,iBAAiB;AAvBvB;AAwBI,YAAO,UAAKT,aAAL,mBAAeU;EACxB;EAEA,MAAMC,gBAAgB;AACpB,QAAI,CAAC,KAAKR,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMC,WAAW,MAAM,KAAKV,SAASW,KAAK,uBAAuB,CAAA,CAAE;AAEnE,QAAID,SAASE,SAAS,GAAG;AACvB,WAAKhB,UAAUc,SAAS,CAAA;AACxBG,cAAQC,IAAI,cAAc,KAAKlB,OAAO;IACxC,OAAO;AACLiB,cAAQC,IAAI,8BAAA;IACd;EACF;EAEAC,sBAAsB;AACpB,WAAO,KAAKlB,YAAY,KAAKA,SAASmB;EACxC;EAEAC,sBAAsB,6BAAA;AA/CxB;AAgDI,QAAI,KAAKX,gBAAgB;AACvBO,cAAQC,IAAI,iCAAgC,UAAKjB,aAAL,mBAAeU,eAAAA;AAC3D,aAAO;IACT;AACA,WAAO;EACT,GANsB;;;;;;;EActBW,0BAA0BC,UAAoB;AA7DhD;AA8DI,eAAKtB,aAAL,mBAAeuB,GAAG,mBAAmBD;AACrC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAmBF;KAAS;EAC3D;EAEAG,uBAAuBH,UAAoB;AAlE7C;AAmEI,eAAKtB,aAAL,mBAAeuB,GAAG,gBAAgBD;AAClC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAgBF;KAAS;EACxD;EAEAI,kBAAkBJ,UAAoB;AAvExC;AAwEI,eAAKtB,aAAL,mBAAeuB,GAAG,WAAWD;AAC7B,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAWF;KAAS;EACnD;EAEAK,qBAAqBL,UAAoB;AA5E3C;AA6EI,eAAKtB,aAAL,mBAAeuB,GAAG,cAAcD;AAChC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAcF;KAAS;EACtD;EAEAM,uBAAuBC,OAAeP,UAAoB;
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector.js'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n //this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n //for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":"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","names":["MetaMaskConnector","account","ethereum","window","listeners","provider","providerListeners","constructor","BrowserProvider","chainId","networkVersion","currentAccount","selectedAddress","connectWallet","logProviderMissing","accounts","send","length","console","log","isMetaMaskInstalled","isMetaMask","isWalletIsConnected","providerOnAccountsChanged","listener","on","push","providerOnChainChanged","providerOnConnect","providerOnDisconnect","providerRemoveListener","event","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","forget","web3ProviderRemoveListener","removeListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
|
package/dist/node/index.d.cts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/node/index.d.mts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/node/index.d.ts
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './MetaMaskConnector';
|
|
1
|
+
export * from './MetaMaskConnector.js';
|
|
2
2
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/node/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA"}
|
package/dist/node/index.js
CHANGED
|
@@ -88,13 +88,9 @@ var _MetaMaskConnector = class _MetaMaskConnector {
|
|
|
88
88
|
]);
|
|
89
89
|
}
|
|
90
90
|
providerRemoveListener(event, listener) {
|
|
91
|
-
var _a;
|
|
92
|
-
(_a = this.ethereum) == null ? void 0 : _a.removeListener(event, listener);
|
|
93
91
|
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener);
|
|
94
92
|
}
|
|
95
93
|
providerRemoveListeners() {
|
|
96
|
-
var _a;
|
|
97
|
-
for (const [event, listener] of this.providerListeners) (_a = this.ethereum) == null ? void 0 : _a.removeListener(event, listener);
|
|
98
94
|
}
|
|
99
95
|
async requestAccounts() {
|
|
100
96
|
if (!this.provider) {
|
package/dist/node/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";;;;AACA,SAASA,cAAc;AACvB,SAASC,uBAAiC;AAEnC,IAAMC,qBAAN,MAAMA,mBAAAA;EACHC,UAAU;EACVC,WAAWC,OAAOD;EAElBE,YAAwB,CAAA;EACxBC;EACAC,oBAA2D,CAAA;EAEnEC,YAAYF,UAA4B;AACtC,QAAIA,UAAU;AACZ,WAAKA,WAAWA;IAClB,WAAW,KAAKH,UAAU;AACxB,WAAKG,WAAW,IAAIG,gBAAgBL,OAAOD,QAAQ;IACrD;EACF;EAEA,IAAIO,UAAU;AAnBhB;AAoBI,YAAO,UAAKP,aAAL,mBAAeQ;EACxB;EAEA,IAAIC,iBAAiB;AAvBvB;AAwBI,YAAO,UAAKT,aAAL,mBAAeU;EACxB;EAEA,MAAMC,gBAAgB;AACpB,QAAI,CAAC,KAAKR,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMC,WAAW,MAAM,KAAKV,SAASW,KAAK,uBAAuB,CAAA,CAAE;AAEnE,QAAID,SAASE,SAAS,GAAG;AACvB,WAAKhB,UAAUc,SAAS,CAAA;AACxBG,cAAQC,IAAI,cAAc,KAAKlB,OAAO;IACxC,OAAO;AACLiB,cAAQC,IAAI,8BAAA;IACd;EACF;EAEAC,sBAAsB;AACpB,WAAO,KAAKlB,YAAY,KAAKA,SAASmB;EACxC;EAEAC,sBAAsB,6BAAA;AA/CxB;AAgDI,QAAI,KAAKX,gBAAgB;AACvBO,cAAQC,IAAI,iCAAgC,UAAKjB,aAAL,mBAAeU,eAAAA;AAC3D,aAAO;IACT;AACA,WAAO;EACT,GANsB;;;;;;;EActBW,0BAA0BC,UAAoB;AA7DhD;AA8DI,eAAKtB,aAAL,mBAAeuB,GAAG,mBAAmBD;AACrC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAmBF;KAAS;EAC3D;EAEAG,uBAAuBH,UAAoB;AAlE7C;AAmEI,eAAKtB,aAAL,mBAAeuB,GAAG,gBAAgBD;AAClC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAgBF;KAAS;EACxD;EAEAI,kBAAkBJ,UAAoB;AAvExC;AAwEI,eAAKtB,aAAL,mBAAeuB,GAAG,WAAWD;AAC7B,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAWF;KAAS;EACnD;EAEAK,qBAAqBL,UAAoB;AA5E3C;AA6EI,eAAKtB,aAAL,mBAAeuB,GAAG,cAAcD;AAChC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAcF;KAAS;EACtD;EAEAM,uBAAuBC,OAAeP,UAAoB;
|
|
1
|
+
{"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\nimport { forget } from '@xylabs/forget'\nimport { BrowserProvider, Listener } from 'ethers'\n\nexport class MetaMaskConnector {\n private account = ''\n private ethereum = window.ethereum as MetaMaskInpageProvider\n\n private listeners: Listener[] = []\n private provider: BrowserProvider | undefined\n private providerListeners: [event: string, listener: Listener][] = []\n\n constructor(provider?: BrowserProvider) {\n if (provider) {\n this.provider = provider\n } else if (this.ethereum) {\n this.provider = new BrowserProvider(window.ethereum)\n }\n }\n\n get chainId() {\n return this.ethereum?.networkVersion\n }\n\n get currentAccount() {\n return this.ethereum?.selectedAddress\n }\n\n async connectWallet() {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const accounts = await this.provider.send('eth_requestAccounts', [])\n // We could have multiple accounts. Check for one.\n if (accounts.length > 0) {\n this.account = accounts[0]\n console.log('Connected:', this.account)\n } else {\n console.log('No authorized account found.')\n }\n }\n\n isMetaMaskInstalled() {\n return this.ethereum && this.ethereum.isMetaMask\n }\n\n isWalletIsConnected = () => {\n if (this.currentAccount) {\n console.log('Found an authorized account:', this.ethereum?.selectedAddress)\n return true\n }\n return false\n }\n\n /**\n * EIP-1193 Event Listeners\n *\n * .on in Web3Provider does not understand EIP-1193 events\n * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893\n */\n providerOnAccountsChanged(listener: Listener) {\n this.ethereum?.on('accountsChanged', listener)\n this.providerListeners.push(['accountsChanged', listener])\n }\n\n providerOnChainChanged(listener: Listener) {\n this.ethereum?.on('chainChanged', listener)\n this.providerListeners.push(['chainChanged', listener])\n }\n\n providerOnConnect(listener: Listener) {\n this.ethereum?.on('connect', listener)\n this.providerListeners.push(['connect', listener])\n }\n\n providerOnDisconnect(listener: Listener) {\n this.ethereum?.on('disconnect', listener)\n this.providerListeners.push(['disconnect', listener])\n }\n\n providerRemoveListener(event: string, listener: Listener) {\n //this.ethereum?.removeListener(event, listener)\n this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)\n }\n\n providerRemoveListeners() {\n //for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)\n }\n\n async requestAccounts(): Promise<string[] | null> {\n if (!this.provider) {\n this.logProviderMissing()\n return null\n }\n\n return await this.provider.send('eth_requestAccounts', [])\n }\n\n async signMessage(message: string) {\n if (!this.provider) {\n this.logProviderMissing()\n return\n }\n\n const signer = await this.provider.getSigner()\n await signer.getAddress()\n const signature = await signer.signMessage(message)\n return signature\n }\n\n /** Web3Provider Listeners - https://docs.ethers.org/v5/api/providers/provider/#Provider--events */\n web3ProviderOn(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.on(event, listener))\n }\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n if (this.provider) {\n forget(this.provider.removeListener(event, listener))\n }\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n if (this.provider) {\n forget(this.provider.removeAllListeners())\n }\n }\n\n private logProviderMissing() {\n console.warn('Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed')\n }\n}\n"],"mappings":";;;;AACA,SAASA,cAAc;AACvB,SAASC,uBAAiC;AAEnC,IAAMC,qBAAN,MAAMA,mBAAAA;EACHC,UAAU;EACVC,WAAWC,OAAOD;EAElBE,YAAwB,CAAA;EACxBC;EACAC,oBAA2D,CAAA;EAEnEC,YAAYF,UAA4B;AACtC,QAAIA,UAAU;AACZ,WAAKA,WAAWA;IAClB,WAAW,KAAKH,UAAU;AACxB,WAAKG,WAAW,IAAIG,gBAAgBL,OAAOD,QAAQ;IACrD;EACF;EAEA,IAAIO,UAAU;AAnBhB;AAoBI,YAAO,UAAKP,aAAL,mBAAeQ;EACxB;EAEA,IAAIC,iBAAiB;AAvBvB;AAwBI,YAAO,UAAKT,aAAL,mBAAeU;EACxB;EAEA,MAAMC,gBAAgB;AACpB,QAAI,CAAC,KAAKR,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMC,WAAW,MAAM,KAAKV,SAASW,KAAK,uBAAuB,CAAA,CAAE;AAEnE,QAAID,SAASE,SAAS,GAAG;AACvB,WAAKhB,UAAUc,SAAS,CAAA;AACxBG,cAAQC,IAAI,cAAc,KAAKlB,OAAO;IACxC,OAAO;AACLiB,cAAQC,IAAI,8BAAA;IACd;EACF;EAEAC,sBAAsB;AACpB,WAAO,KAAKlB,YAAY,KAAKA,SAASmB;EACxC;EAEAC,sBAAsB,6BAAA;AA/CxB;AAgDI,QAAI,KAAKX,gBAAgB;AACvBO,cAAQC,IAAI,iCAAgC,UAAKjB,aAAL,mBAAeU,eAAAA;AAC3D,aAAO;IACT;AACA,WAAO;EACT,GANsB;;;;;;;EActBW,0BAA0BC,UAAoB;AA7DhD;AA8DI,eAAKtB,aAAL,mBAAeuB,GAAG,mBAAmBD;AACrC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAmBF;KAAS;EAC3D;EAEAG,uBAAuBH,UAAoB;AAlE7C;AAmEI,eAAKtB,aAAL,mBAAeuB,GAAG,gBAAgBD;AAClC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAgBF;KAAS;EACxD;EAEAI,kBAAkBJ,UAAoB;AAvExC;AAwEI,eAAKtB,aAAL,mBAAeuB,GAAG,WAAWD;AAC7B,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAWF;KAAS;EACnD;EAEAK,qBAAqBL,UAAoB;AA5E3C;AA6EI,eAAKtB,aAAL,mBAAeuB,GAAG,cAAcD;AAChC,SAAKlB,kBAAkBoB,KAAK;MAAC;MAAcF;KAAS;EACtD;EAEAM,uBAAuBC,OAAeP,UAAoB;AAExD,SAAKlB,oBAAoB,KAAKA,kBAAkB0B,OAAO,CAAC,CAAA,EAAGC,aAAAA,MAAmBT,aAAaS,aAAAA;EAC7F;EAEAC,0BAA0B;EAE1B;EAEA,MAAMC,kBAA4C;AAChD,QAAI,CAAC,KAAK9B,UAAU;AAClB,WAAKS,mBAAkB;AACvB,aAAO;IACT;AAEA,WAAO,MAAM,KAAKT,SAASW,KAAK,uBAAuB,CAAA,CAAE;EAC3D;EAEA,MAAMoB,YAAYC,SAAiB;AACjC,QAAI,CAAC,KAAKhC,UAAU;AAClB,WAAKS,mBAAkB;AACvB;IACF;AAEA,UAAMwB,SAAS,MAAM,KAAKjC,SAASkC,UAAS;AAC5C,UAAMD,OAAOE,WAAU;AACvB,UAAMC,YAAY,MAAMH,OAAOF,YAAYC,OAAAA;AAC3C,WAAOI;EACT;;EAGAC,eAAeX,OAAeP,UAAoB;AAChD,QAAI,KAAKnB,UAAU;AACjBsC,aAAO,KAAKtC,SAASoB,GAAGM,OAAOP,QAAAA,CAAAA;IACjC;AACA,SAAKpB,UAAUsB,KAAKF,QAAAA;EACtB;EAEAoB,2BAA2Bb,OAAeP,UAAoB;AAC5D,QAAI,KAAKnB,UAAU;AACjBsC,aAAO,KAAKtC,SAASwC,eAAed,OAAOP,QAAAA,CAAAA;IAC7C;AACA,SAAKpB,YAAY,KAAKA,UAAU4B,OAAO,CAACC,kBAAkBT,aAAaS,aAAAA;EACzE;EAEAa,8BAA8B;AAC5B,QAAI,KAAKzC,UAAU;AACjBsC,aAAO,KAAKtC,SAAS0C,mBAAkB,CAAA;IACzC;EACF;EAEQjC,qBAAqB;AAC3BI,YAAQ8B,KAAK,iHAAA;EACf;AACF;AApIahD;AAAN,IAAMA,oBAAN;","names":["forget","BrowserProvider","MetaMaskConnector","account","ethereum","window","listeners","provider","providerListeners","constructor","BrowserProvider","chainId","networkVersion","currentAccount","selectedAddress","connectWallet","logProviderMissing","accounts","send","length","console","log","isMetaMaskInstalled","isMetaMask","isWalletIsConnected","providerOnAccountsChanged","listener","on","push","providerOnChainChanged","providerOnConnect","providerOnDisconnect","providerRemoveListener","event","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","forget","web3ProviderRemoveListener","removeListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
|
package/package.json
CHANGED
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
},
|
|
11
11
|
"dependencies": {
|
|
12
12
|
"@metamask/providers": "^17.1.0",
|
|
13
|
-
"@xylabs/forget": "^3.5.
|
|
13
|
+
"@xylabs/forget": "^3.5.9",
|
|
14
14
|
"ethers": "6.13.1"
|
|
15
15
|
},
|
|
16
16
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
@@ -58,6 +58,6 @@
|
|
|
58
58
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
59
59
|
},
|
|
60
60
|
"sideEffects": false,
|
|
61
|
-
"version": "2.
|
|
61
|
+
"version": "2.110.0",
|
|
62
62
|
"type": "module"
|
|
63
63
|
}
|
package/src/MetaMaskConnector.ts
CHANGED
|
@@ -81,12 +81,12 @@ export class MetaMaskConnector {
|
|
|
81
81
|
}
|
|
82
82
|
|
|
83
83
|
providerRemoveListener(event: string, listener: Listener) {
|
|
84
|
-
this.ethereum?.removeListener(event, listener)
|
|
84
|
+
//this.ethereum?.removeListener(event, listener)
|
|
85
85
|
this.providerListeners = this.providerListeners.filter(([, savedListener]) => listener !== savedListener)
|
|
86
86
|
}
|
|
87
87
|
|
|
88
88
|
providerRemoveListeners() {
|
|
89
|
-
for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)
|
|
89
|
+
//for (const [event, listener] of this.providerListeners) this.ethereum?.removeListener(event, listener)
|
|
90
90
|
}
|
|
91
91
|
|
|
92
92
|
async requestAccounts(): Promise<string[] | null> {
|
package/src/index.ts
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from './MetaMaskConnector'
|
|
1
|
+
export * from './MetaMaskConnector.js'
|