@xyo-network/metamask-connector 2.84.18 → 2.85.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.
@@ -3,6 +3,7 @@ var __defProp = Object.defineProperty;
3
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
6
7
  var __export = (target, all) => {
7
8
  for (var name in all)
8
9
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -27,6 +28,9 @@ module.exports = __toCommonJS(src_exports);
27
28
  // src/MetaMaskConnector.ts
28
29
  var import_ethers = require("ethers");
29
30
  var MetaMaskConnector = class {
31
+ static {
32
+ __name(this, "MetaMaskConnector");
33
+ }
30
34
  account = "";
31
35
  ethereum = window.ethereum;
32
36
  listeners = [];
@@ -69,26 +73,38 @@ var MetaMaskConnector = class {
69
73
  return false;
70
74
  };
71
75
  /**
72
- * EIP-1193 Event Listeners
73
- *
74
- * .on in Web3Provider does not understand EIP-1193 events
75
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
76
- */
76
+ * EIP-1193 Event Listeners
77
+ *
78
+ * .on in Web3Provider does not understand EIP-1193 events
79
+ * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
80
+ */
77
81
  providerOnAccountsChanged(listener) {
78
82
  this.ethereum?.on("accountsChanged", listener);
79
- this.providerListeners.push(["accountsChanged", listener]);
83
+ this.providerListeners.push([
84
+ "accountsChanged",
85
+ listener
86
+ ]);
80
87
  }
81
88
  providerOnChainChanged(listener) {
82
89
  this.ethereum?.on("chainChanged", listener);
83
- this.providerListeners.push(["chainChanged", listener]);
90
+ this.providerListeners.push([
91
+ "chainChanged",
92
+ listener
93
+ ]);
84
94
  }
85
95
  providerOnConnect(listener) {
86
96
  this.ethereum?.on("connect", listener);
87
- this.providerListeners.push(["connect", listener]);
97
+ this.providerListeners.push([
98
+ "connect",
99
+ listener
100
+ ]);
88
101
  }
89
102
  providerOnDisconnect(listener) {
90
103
  this.ethereum?.on("disconnect", listener);
91
- this.providerListeners.push(["disconnect", listener]);
104
+ this.providerListeners.push([
105
+ "disconnect",
106
+ listener
107
+ ]);
92
108
  }
93
109
  providerRemoveListener(event, listener) {
94
110
  this.ethereum?.removeListener(event, listener);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\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 this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\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":[]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\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 this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\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","removeListener","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","web3ProviderRemoveListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
@@ -1,6 +1,12 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
1
4
  // src/MetaMaskConnector.ts
2
5
  import { BrowserProvider } from "ethers";
3
6
  var MetaMaskConnector = class {
7
+ static {
8
+ __name(this, "MetaMaskConnector");
9
+ }
4
10
  account = "";
5
11
  ethereum = window.ethereum;
6
12
  listeners = [];
@@ -43,26 +49,38 @@ var MetaMaskConnector = class {
43
49
  return false;
44
50
  };
45
51
  /**
46
- * EIP-1193 Event Listeners
47
- *
48
- * .on in Web3Provider does not understand EIP-1193 events
49
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
50
- */
52
+ * EIP-1193 Event Listeners
53
+ *
54
+ * .on in Web3Provider does not understand EIP-1193 events
55
+ * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
56
+ */
51
57
  providerOnAccountsChanged(listener) {
52
58
  this.ethereum?.on("accountsChanged", listener);
53
- this.providerListeners.push(["accountsChanged", listener]);
59
+ this.providerListeners.push([
60
+ "accountsChanged",
61
+ listener
62
+ ]);
54
63
  }
55
64
  providerOnChainChanged(listener) {
56
65
  this.ethereum?.on("chainChanged", listener);
57
- this.providerListeners.push(["chainChanged", listener]);
66
+ this.providerListeners.push([
67
+ "chainChanged",
68
+ listener
69
+ ]);
58
70
  }
59
71
  providerOnConnect(listener) {
60
72
  this.ethereum?.on("connect", listener);
61
- this.providerListeners.push(["connect", listener]);
73
+ this.providerListeners.push([
74
+ "connect",
75
+ listener
76
+ ]);
62
77
  }
63
78
  providerOnDisconnect(listener) {
64
79
  this.ethereum?.on("disconnect", listener);
65
- this.providerListeners.push(["disconnect", listener]);
80
+ this.providerListeners.push([
81
+ "disconnect",
82
+ listener
83
+ ]);
66
84
  }
67
85
  providerRemoveListener(event, listener) {
68
86
  this.ethereum?.removeListener(event, listener);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\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 this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\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":[]}
1
+ {"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\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 this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\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":["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","removeListener","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","web3ProviderRemoveListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
@@ -3,6 +3,7 @@ var __defProp = Object.defineProperty;
3
3
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
4
  var __getOwnPropNames = Object.getOwnPropertyNames;
5
5
  var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
6
7
  var __export = (target, all) => {
7
8
  for (var name in all)
8
9
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -26,7 +27,7 @@ module.exports = __toCommonJS(src_exports);
26
27
 
27
28
  // src/MetaMaskConnector.ts
28
29
  var import_ethers = require("ethers");
29
- var MetaMaskConnector = class {
30
+ var _MetaMaskConnector = class _MetaMaskConnector {
30
31
  account = "";
31
32
  ethereum = window.ethereum;
32
33
  listeners = [];
@@ -72,30 +73,42 @@ var MetaMaskConnector = class {
72
73
  return false;
73
74
  };
74
75
  /**
75
- * EIP-1193 Event Listeners
76
- *
77
- * .on in Web3Provider does not understand EIP-1193 events
78
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
79
- */
76
+ * EIP-1193 Event Listeners
77
+ *
78
+ * .on in Web3Provider does not understand EIP-1193 events
79
+ * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
80
+ */
80
81
  providerOnAccountsChanged(listener) {
81
82
  var _a;
82
83
  (_a = this.ethereum) == null ? void 0 : _a.on("accountsChanged", listener);
83
- this.providerListeners.push(["accountsChanged", listener]);
84
+ this.providerListeners.push([
85
+ "accountsChanged",
86
+ listener
87
+ ]);
84
88
  }
85
89
  providerOnChainChanged(listener) {
86
90
  var _a;
87
91
  (_a = this.ethereum) == null ? void 0 : _a.on("chainChanged", listener);
88
- this.providerListeners.push(["chainChanged", listener]);
92
+ this.providerListeners.push([
93
+ "chainChanged",
94
+ listener
95
+ ]);
89
96
  }
90
97
  providerOnConnect(listener) {
91
98
  var _a;
92
99
  (_a = this.ethereum) == null ? void 0 : _a.on("connect", listener);
93
- this.providerListeners.push(["connect", listener]);
100
+ this.providerListeners.push([
101
+ "connect",
102
+ listener
103
+ ]);
94
104
  }
95
105
  providerOnDisconnect(listener) {
96
106
  var _a;
97
107
  (_a = this.ethereum) == null ? void 0 : _a.on("disconnect", listener);
98
- this.providerListeners.push(["disconnect", listener]);
108
+ this.providerListeners.push([
109
+ "disconnect",
110
+ listener
111
+ ]);
99
112
  }
100
113
  providerRemoveListener(event, listener) {
101
114
  var _a;
@@ -143,6 +156,8 @@ var MetaMaskConnector = class {
143
156
  console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
144
157
  }
145
158
  };
159
+ __name(_MetaMaskConnector, "MetaMaskConnector");
160
+ var MetaMaskConnector = _MetaMaskConnector;
146
161
  // Annotate the CommonJS export names for ESM import in node:
147
162
  0 && (module.exports = {
148
163
  MetaMaskConnector
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\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 this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\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":[]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/MetaMaskConnector.ts"],"sourcesContent":["export * from './MetaMaskConnector'\n","import { MetaMaskInpageProvider } from '@metamask/providers'\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 this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\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","removeListener","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","web3ProviderRemoveListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
@@ -1,6 +1,9 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
3
+
1
4
  // src/MetaMaskConnector.ts
2
5
  import { BrowserProvider } from "ethers";
3
- var MetaMaskConnector = class {
6
+ var _MetaMaskConnector = class _MetaMaskConnector {
4
7
  account = "";
5
8
  ethereum = window.ethereum;
6
9
  listeners = [];
@@ -46,30 +49,42 @@ var MetaMaskConnector = class {
46
49
  return false;
47
50
  };
48
51
  /**
49
- * EIP-1193 Event Listeners
50
- *
51
- * .on in Web3Provider does not understand EIP-1193 events
52
- * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
53
- */
52
+ * EIP-1193 Event Listeners
53
+ *
54
+ * .on in Web3Provider does not understand EIP-1193 events
55
+ * see - https://github.com/ethers-io/ethers.js/discussions/1560#discussioncomment-730893
56
+ */
54
57
  providerOnAccountsChanged(listener) {
55
58
  var _a;
56
59
  (_a = this.ethereum) == null ? void 0 : _a.on("accountsChanged", listener);
57
- this.providerListeners.push(["accountsChanged", listener]);
60
+ this.providerListeners.push([
61
+ "accountsChanged",
62
+ listener
63
+ ]);
58
64
  }
59
65
  providerOnChainChanged(listener) {
60
66
  var _a;
61
67
  (_a = this.ethereum) == null ? void 0 : _a.on("chainChanged", listener);
62
- this.providerListeners.push(["chainChanged", listener]);
68
+ this.providerListeners.push([
69
+ "chainChanged",
70
+ listener
71
+ ]);
63
72
  }
64
73
  providerOnConnect(listener) {
65
74
  var _a;
66
75
  (_a = this.ethereum) == null ? void 0 : _a.on("connect", listener);
67
- this.providerListeners.push(["connect", listener]);
76
+ this.providerListeners.push([
77
+ "connect",
78
+ listener
79
+ ]);
68
80
  }
69
81
  providerOnDisconnect(listener) {
70
82
  var _a;
71
83
  (_a = this.ethereum) == null ? void 0 : _a.on("disconnect", listener);
72
- this.providerListeners.push(["disconnect", listener]);
84
+ this.providerListeners.push([
85
+ "disconnect",
86
+ listener
87
+ ]);
73
88
  }
74
89
  providerRemoveListener(event, listener) {
75
90
  var _a;
@@ -117,6 +132,8 @@ var MetaMaskConnector = class {
117
132
  console.warn("Cannot call this method because there is no web3 provider connected. Please confirm that metamask is installed");
118
133
  }
119
134
  };
135
+ __name(_MetaMaskConnector, "MetaMaskConnector");
136
+ var MetaMaskConnector = _MetaMaskConnector;
120
137
  export {
121
138
  MetaMaskConnector
122
139
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\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 this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\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":[]}
1
+ {"version":3,"sources":["../../src/MetaMaskConnector.ts"],"sourcesContent":["import { MetaMaskInpageProvider } from '@metamask/providers'\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 this.provider?.on(event, listener)\n this.listeners.push(listener)\n }\n\n web3ProviderRemoveListener(event: string, listener: Listener) {\n this.provider?.removeListener(event, listener)\n this.listeners = this.listeners.filter((savedListener) => listener !== savedListener)\n }\n\n web3ProviderRemoveListeners() {\n this.provider?.removeAllListeners()\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":["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","removeListener","filter","savedListener","providerRemoveListeners","requestAccounts","signMessage","message","signer","getSigner","getAddress","signature","web3ProviderOn","web3ProviderRemoveListener","web3ProviderRemoveListeners","removeAllListeners","warn"]}
package/package.json CHANGED
@@ -57,6 +57,6 @@
57
57
  "url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
58
58
  },
59
59
  "sideEffects": false,
60
- "version": "2.84.18",
60
+ "version": "2.85.0",
61
61
  "type": "module"
62
62
  }