@wagmi/connectors 0.2.4-cjs → 0.2.5
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/coinbaseWallet/package.json +1 -1
- package/dist/chunk-5NCTPR6C.js +14 -14
- package/dist/{chunk-6IU3YKWQ.js → chunk-N7MKKIYR.js} +73 -71
- package/dist/coinbaseWallet.js +59 -59
- package/dist/index.d.ts +1 -1
- package/dist/index.js +6 -6
- package/dist/injected.d.ts +1 -1
- package/dist/injected.js +7 -7
- package/dist/ledger.js +45 -45
- package/dist/metaMask.d.ts +1 -1
- package/dist/metaMask.js +35 -33
- package/dist/mock/index.js +62 -62
- package/dist/safe.js +42 -42
- package/dist/{types-15a470bc.d.ts → types-acc5bc95.d.ts} +1 -0
- package/dist/walletConnect.js +89 -88
- package/injected/package.json +1 -1
- package/ledger/package.json +1 -1
- package/metaMask/package.json +1 -1
- package/mock/package.json +1 -1
- package/package.json +39 -3
- package/safe/package.json +1 -1
- package/walletConnect/package.json +1 -1
package/dist/chunk-5NCTPR6C.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
2
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
3
|
var __publicField = (obj, key, value) => {
|
|
4
4
|
__defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
@@ -28,11 +28,11 @@ var __privateMethod = (obj, member, method) => {
|
|
|
28
28
|
};
|
|
29
29
|
|
|
30
30
|
// src/base.ts
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
var Connector = class extends
|
|
31
|
+
import { goerli, mainnet } from "@wagmi/core/chains";
|
|
32
|
+
import { default as EventEmitter } from "eventemitter3";
|
|
33
|
+
var Connector = class extends EventEmitter {
|
|
34
34
|
constructor({
|
|
35
|
-
chains = [
|
|
35
|
+
chains = [mainnet, goerli],
|
|
36
36
|
options
|
|
37
37
|
}) {
|
|
38
38
|
super();
|
|
@@ -42,7 +42,7 @@ var Connector = class extends _eventemitter32.default {
|
|
|
42
42
|
this.options = options;
|
|
43
43
|
}
|
|
44
44
|
getBlockExplorerUrls(chain) {
|
|
45
|
-
const { default: blockExplorer, ...blockExplorers } =
|
|
45
|
+
const { default: blockExplorer, ...blockExplorers } = chain.blockExplorers ?? {};
|
|
46
46
|
if (blockExplorer)
|
|
47
47
|
return [
|
|
48
48
|
blockExplorer.url,
|
|
@@ -54,11 +54,11 @@ var Connector = class extends _eventemitter32.default {
|
|
|
54
54
|
}
|
|
55
55
|
};
|
|
56
56
|
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
57
|
+
export {
|
|
58
|
+
__publicField,
|
|
59
|
+
__privateGet,
|
|
60
|
+
__privateAdd,
|
|
61
|
+
__privateSet,
|
|
62
|
+
__privateMethod,
|
|
63
|
+
Connector
|
|
64
|
+
};
|
|
@@ -1,30 +1,32 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
import {
|
|
2
|
+
Connector,
|
|
3
|
+
__privateAdd,
|
|
4
|
+
__privateGet,
|
|
5
|
+
__privateSet,
|
|
6
|
+
__publicField
|
|
7
|
+
} from "./chunk-5NCTPR6C.js";
|
|
8
8
|
|
|
9
9
|
// src/injected.ts
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
10
|
+
import {
|
|
11
|
+
AddChainError,
|
|
12
|
+
ChainNotConfiguredError,
|
|
13
|
+
ConnectorNotFoundError,
|
|
14
|
+
ResourceUnavailableError,
|
|
15
|
+
SwitchChainError,
|
|
16
|
+
UserRejectedRequestError,
|
|
17
|
+
getClient,
|
|
18
|
+
normalizeChainId
|
|
19
|
+
} from "@wagmi/core";
|
|
20
|
+
import { providers } from "ethers";
|
|
21
|
+
import { getAddress, hexValue } from "ethers/lib/utils.js";
|
|
22
22
|
|
|
23
23
|
// src/utils/getInjectedName.ts
|
|
24
24
|
function getInjectedName(ethereum) {
|
|
25
25
|
if (!ethereum)
|
|
26
26
|
return "Injected";
|
|
27
27
|
const getName = (provider) => {
|
|
28
|
+
if (provider.isApexWallet)
|
|
29
|
+
return "Apex Wallet";
|
|
28
30
|
if (provider.isAvalanche)
|
|
29
31
|
return "Core Wallet";
|
|
30
32
|
if (provider.isBitKeep)
|
|
@@ -60,7 +62,7 @@ function getInjectedName(ethereum) {
|
|
|
60
62
|
if (provider.isMetaMask)
|
|
61
63
|
return "MetaMask";
|
|
62
64
|
};
|
|
63
|
-
if (
|
|
65
|
+
if (ethereum.providers?.length) {
|
|
64
66
|
const nameSet = /* @__PURE__ */ new Set();
|
|
65
67
|
let unknownCount = 1;
|
|
66
68
|
for (const provider of ethereum.providers) {
|
|
@@ -74,14 +76,14 @@ function getInjectedName(ethereum) {
|
|
|
74
76
|
const names = [...nameSet];
|
|
75
77
|
if (names.length)
|
|
76
78
|
return names;
|
|
77
|
-
return
|
|
79
|
+
return names[0] ?? "Injected";
|
|
78
80
|
}
|
|
79
|
-
return
|
|
81
|
+
return getName(ethereum) ?? "Injected";
|
|
80
82
|
}
|
|
81
83
|
|
|
82
84
|
// src/injected.ts
|
|
83
85
|
var _provider, _switchingChains;
|
|
84
|
-
var InjectedConnector = class extends
|
|
86
|
+
var InjectedConnector = class extends Connector {
|
|
85
87
|
constructor({
|
|
86
88
|
chains,
|
|
87
89
|
options: options_
|
|
@@ -93,33 +95,33 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
93
95
|
...options_
|
|
94
96
|
};
|
|
95
97
|
super({ chains, options });
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
98
|
+
__publicField(this, "id");
|
|
99
|
+
__publicField(this, "name");
|
|
100
|
+
__publicField(this, "ready");
|
|
101
|
+
__privateAdd(this, _provider, void 0);
|
|
102
|
+
__privateAdd(this, _switchingChains, void 0);
|
|
103
|
+
__publicField(this, "shimDisconnectKey", `${this.id}.shimDisconnect`);
|
|
104
|
+
__publicField(this, "onAccountsChanged", (accounts) => {
|
|
103
105
|
if (accounts.length === 0)
|
|
104
106
|
this.emit("disconnect");
|
|
105
107
|
else
|
|
106
108
|
this.emit("change", {
|
|
107
|
-
account:
|
|
109
|
+
account: getAddress(accounts[0])
|
|
108
110
|
});
|
|
109
111
|
});
|
|
110
|
-
|
|
111
|
-
const id =
|
|
112
|
+
__publicField(this, "onChainChanged", (chainId) => {
|
|
113
|
+
const id = normalizeChainId(chainId);
|
|
112
114
|
const unsupported = this.isChainUnsupported(id);
|
|
113
115
|
this.emit("change", { chain: { id, unsupported } });
|
|
114
116
|
});
|
|
115
|
-
|
|
116
|
-
if (this.options.shimChainChangedDisconnect &&
|
|
117
|
-
|
|
117
|
+
__publicField(this, "onDisconnect", () => {
|
|
118
|
+
if (this.options.shimChainChangedDisconnect && __privateGet(this, _switchingChains)) {
|
|
119
|
+
__privateSet(this, _switchingChains, false);
|
|
118
120
|
return;
|
|
119
121
|
}
|
|
120
122
|
this.emit("disconnect");
|
|
121
123
|
if (this.options.shimDisconnect)
|
|
122
|
-
|
|
124
|
+
getClient().storage?.removeItem(this.shimDisconnectKey);
|
|
123
125
|
});
|
|
124
126
|
const provider = options.getProvider();
|
|
125
127
|
if (typeof options.name === "string")
|
|
@@ -143,7 +145,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
143
145
|
try {
|
|
144
146
|
const provider = await this.getProvider();
|
|
145
147
|
if (!provider)
|
|
146
|
-
throw new
|
|
148
|
+
throw new ConnectorNotFoundError();
|
|
147
149
|
if (provider.on) {
|
|
148
150
|
provider.on("accountsChanged", this.onAccountsChanged);
|
|
149
151
|
provider.on("chainChanged", this.onChainChanged);
|
|
@@ -153,7 +155,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
153
155
|
const accounts = await provider.request({
|
|
154
156
|
method: "eth_requestAccounts"
|
|
155
157
|
});
|
|
156
|
-
const account =
|
|
158
|
+
const account = getAddress(accounts[0]);
|
|
157
159
|
let id = await this.getChainId();
|
|
158
160
|
let unsupported = this.isChainUnsupported(id);
|
|
159
161
|
if (chainId && id !== chainId) {
|
|
@@ -162,77 +164,77 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
162
164
|
unsupported = this.isChainUnsupported(id);
|
|
163
165
|
}
|
|
164
166
|
if (this.options.shimDisconnect)
|
|
165
|
-
|
|
167
|
+
getClient().storage?.setItem(this.shimDisconnectKey, true);
|
|
166
168
|
return { account, chain: { id, unsupported }, provider };
|
|
167
169
|
} catch (error) {
|
|
168
170
|
if (this.isUserRejectedRequestError(error))
|
|
169
|
-
throw new
|
|
171
|
+
throw new UserRejectedRequestError(error);
|
|
170
172
|
if (error.code === -32002)
|
|
171
|
-
throw new
|
|
173
|
+
throw new ResourceUnavailableError(error);
|
|
172
174
|
throw error;
|
|
173
175
|
}
|
|
174
176
|
}
|
|
175
177
|
async disconnect() {
|
|
176
178
|
const provider = await this.getProvider();
|
|
177
|
-
if (!
|
|
179
|
+
if (!provider?.removeListener)
|
|
178
180
|
return;
|
|
179
181
|
provider.removeListener("accountsChanged", this.onAccountsChanged);
|
|
180
182
|
provider.removeListener("chainChanged", this.onChainChanged);
|
|
181
183
|
provider.removeListener("disconnect", this.onDisconnect);
|
|
182
184
|
if (this.options.shimDisconnect)
|
|
183
|
-
|
|
185
|
+
getClient().storage?.removeItem(this.shimDisconnectKey);
|
|
184
186
|
}
|
|
185
187
|
async getAccount() {
|
|
186
188
|
const provider = await this.getProvider();
|
|
187
189
|
if (!provider)
|
|
188
|
-
throw new
|
|
190
|
+
throw new ConnectorNotFoundError();
|
|
189
191
|
const accounts = await provider.request({
|
|
190
192
|
method: "eth_accounts"
|
|
191
193
|
});
|
|
192
|
-
return
|
|
194
|
+
return getAddress(accounts[0]);
|
|
193
195
|
}
|
|
194
196
|
async getChainId() {
|
|
195
197
|
const provider = await this.getProvider();
|
|
196
198
|
if (!provider)
|
|
197
|
-
throw new
|
|
198
|
-
return provider.request({ method: "eth_chainId" }).then(
|
|
199
|
+
throw new ConnectorNotFoundError();
|
|
200
|
+
return provider.request({ method: "eth_chainId" }).then(normalizeChainId);
|
|
199
201
|
}
|
|
200
202
|
async getProvider() {
|
|
201
203
|
const provider = this.options.getProvider();
|
|
202
204
|
if (provider)
|
|
203
|
-
|
|
204
|
-
return
|
|
205
|
+
__privateSet(this, _provider, provider);
|
|
206
|
+
return __privateGet(this, _provider);
|
|
205
207
|
}
|
|
206
208
|
async getSigner({ chainId } = {}) {
|
|
207
209
|
const [provider, account] = await Promise.all([
|
|
208
210
|
this.getProvider(),
|
|
209
211
|
this.getAccount()
|
|
210
212
|
]);
|
|
211
|
-
return new
|
|
213
|
+
return new providers.Web3Provider(
|
|
212
214
|
provider,
|
|
213
215
|
chainId
|
|
214
216
|
).getSigner(account);
|
|
215
217
|
}
|
|
216
218
|
async isAuthorized() {
|
|
217
219
|
try {
|
|
218
|
-
if (this.options.shimDisconnect && !
|
|
220
|
+
if (this.options.shimDisconnect && !getClient().storage?.getItem(this.shimDisconnectKey))
|
|
219
221
|
return false;
|
|
220
222
|
const provider = await this.getProvider();
|
|
221
223
|
if (!provider)
|
|
222
|
-
throw new
|
|
224
|
+
throw new ConnectorNotFoundError();
|
|
223
225
|
const account = await this.getAccount();
|
|
224
226
|
return !!account;
|
|
225
|
-
} catch
|
|
227
|
+
} catch {
|
|
226
228
|
return false;
|
|
227
229
|
}
|
|
228
230
|
}
|
|
229
231
|
async switchChain(chainId) {
|
|
230
232
|
if (this.options.shimChainChangedDisconnect)
|
|
231
|
-
|
|
233
|
+
__privateSet(this, _switchingChains, true);
|
|
232
234
|
const provider = await this.getProvider();
|
|
233
235
|
if (!provider)
|
|
234
|
-
throw new
|
|
235
|
-
const id =
|
|
236
|
+
throw new ConnectorNotFoundError();
|
|
237
|
+
const id = hexValue(chainId);
|
|
236
238
|
try {
|
|
237
239
|
await Promise.all([
|
|
238
240
|
provider.request({
|
|
@@ -241,23 +243,23 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
241
243
|
}),
|
|
242
244
|
new Promise(
|
|
243
245
|
(res) => this.on("change", ({ chain }) => {
|
|
244
|
-
if (
|
|
246
|
+
if (chain?.id === chainId)
|
|
245
247
|
res();
|
|
246
248
|
})
|
|
247
249
|
)
|
|
248
250
|
]);
|
|
249
|
-
return
|
|
251
|
+
return this.chains.find((x) => x.id === chainId) ?? {
|
|
250
252
|
id: chainId,
|
|
251
253
|
name: `Chain ${id}`,
|
|
252
254
|
network: `${id}`,
|
|
253
255
|
nativeCurrency: { name: "Ether", decimals: 18, symbol: "ETH" },
|
|
254
256
|
rpcUrls: { default: { http: [""] }, public: { http: [""] } }
|
|
255
|
-
}
|
|
257
|
+
};
|
|
256
258
|
} catch (error) {
|
|
257
259
|
const chain = this.chains.find((x) => x.id === chainId);
|
|
258
260
|
if (!chain)
|
|
259
|
-
throw new
|
|
260
|
-
if (error.code === 4902 ||
|
|
261
|
+
throw new ChainNotConfiguredError({ chainId, connectorId: this.id });
|
|
262
|
+
if (error.code === 4902 || error?.data?.originalError?.code === 4902) {
|
|
261
263
|
try {
|
|
262
264
|
await provider.request({
|
|
263
265
|
method: "wallet_addEthereumChain",
|
|
@@ -266,7 +268,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
266
268
|
chainId: id,
|
|
267
269
|
chainName: chain.name,
|
|
268
270
|
nativeCurrency: chain.nativeCurrency,
|
|
269
|
-
rpcUrls: [
|
|
271
|
+
rpcUrls: [chain.rpcUrls.public?.http[0] ?? ""],
|
|
270
272
|
blockExplorerUrls: this.getBlockExplorerUrls(chain)
|
|
271
273
|
}
|
|
272
274
|
]
|
|
@@ -274,13 +276,13 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
274
276
|
return chain;
|
|
275
277
|
} catch (addError) {
|
|
276
278
|
if (this.isUserRejectedRequestError(addError))
|
|
277
|
-
throw new
|
|
278
|
-
throw new
|
|
279
|
+
throw new UserRejectedRequestError(error);
|
|
280
|
+
throw new AddChainError();
|
|
279
281
|
}
|
|
280
282
|
}
|
|
281
283
|
if (this.isUserRejectedRequestError(error))
|
|
282
|
-
throw new
|
|
283
|
-
throw new
|
|
284
|
+
throw new UserRejectedRequestError(error);
|
|
285
|
+
throw new SwitchChainError(error);
|
|
284
286
|
}
|
|
285
287
|
}
|
|
286
288
|
async watchAsset({
|
|
@@ -291,7 +293,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
291
293
|
}) {
|
|
292
294
|
const provider = await this.getProvider();
|
|
293
295
|
if (!provider)
|
|
294
|
-
throw new
|
|
296
|
+
throw new ConnectorNotFoundError();
|
|
295
297
|
return provider.request({
|
|
296
298
|
method: "wallet_watchAsset",
|
|
297
299
|
params: {
|
|
@@ -312,6 +314,6 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
312
314
|
_provider = new WeakMap();
|
|
313
315
|
_switchingChains = new WeakMap();
|
|
314
316
|
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
317
|
+
export {
|
|
318
|
+
InjectedConnector
|
|
319
|
+
};
|
package/dist/coinbaseWallet.js
CHANGED
|
@@ -1,24 +1,24 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
import {
|
|
2
|
+
Connector,
|
|
3
|
+
__privateAdd,
|
|
4
|
+
__privateGet,
|
|
5
|
+
__privateMethod,
|
|
6
|
+
__privateSet,
|
|
7
|
+
__publicField
|
|
8
|
+
} from "./chunk-5NCTPR6C.js";
|
|
9
9
|
|
|
10
10
|
// src/coinbaseWallet.ts
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
11
|
+
import {
|
|
12
|
+
AddChainError,
|
|
13
|
+
ChainNotConfiguredError,
|
|
14
|
+
SwitchChainError,
|
|
15
|
+
UserRejectedRequestError,
|
|
16
|
+
normalizeChainId
|
|
17
|
+
} from "@wagmi/core";
|
|
18
|
+
import { providers } from "ethers";
|
|
19
|
+
import { getAddress, hexValue } from "ethers/lib/utils.js";
|
|
20
20
|
var _client, _provider, _isUserRejectedRequestError, isUserRejectedRequestError_fn;
|
|
21
|
-
var CoinbaseWalletConnector = class extends
|
|
21
|
+
var CoinbaseWalletConnector = class extends Connector {
|
|
22
22
|
constructor({ chains, options }) {
|
|
23
23
|
super({
|
|
24
24
|
chains,
|
|
@@ -27,24 +27,24 @@ var CoinbaseWalletConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
27
27
|
...options
|
|
28
28
|
}
|
|
29
29
|
});
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
30
|
+
__privateAdd(this, _isUserRejectedRequestError);
|
|
31
|
+
__publicField(this, "id", "coinbaseWallet");
|
|
32
|
+
__publicField(this, "name", "Coinbase Wallet");
|
|
33
|
+
__publicField(this, "ready", true);
|
|
34
|
+
__privateAdd(this, _client, void 0);
|
|
35
|
+
__privateAdd(this, _provider, void 0);
|
|
36
|
+
__publicField(this, "onAccountsChanged", (accounts) => {
|
|
37
37
|
if (accounts.length === 0)
|
|
38
38
|
this.emit("disconnect");
|
|
39
39
|
else
|
|
40
|
-
this.emit("change", { account:
|
|
40
|
+
this.emit("change", { account: getAddress(accounts[0]) });
|
|
41
41
|
});
|
|
42
|
-
|
|
43
|
-
const id =
|
|
42
|
+
__publicField(this, "onChainChanged", (chainId) => {
|
|
43
|
+
const id = normalizeChainId(chainId);
|
|
44
44
|
const unsupported = this.isChainUnsupported(id);
|
|
45
45
|
this.emit("change", { chain: { id, unsupported } });
|
|
46
46
|
});
|
|
47
|
-
|
|
47
|
+
__publicField(this, "onDisconnect", () => {
|
|
48
48
|
this.emit("disconnect");
|
|
49
49
|
});
|
|
50
50
|
}
|
|
@@ -56,7 +56,7 @@ var CoinbaseWalletConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
56
56
|
provider.on("disconnect", this.onDisconnect);
|
|
57
57
|
this.emit("message", { type: "connecting" });
|
|
58
58
|
const accounts = await provider.enable();
|
|
59
|
-
const account =
|
|
59
|
+
const account = getAddress(accounts[0]);
|
|
60
60
|
let id = await this.getChainId();
|
|
61
61
|
let unsupported = this.isChainUnsupported(id);
|
|
62
62
|
if (chainId && id !== chainId) {
|
|
@@ -67,7 +67,7 @@ var CoinbaseWalletConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
67
67
|
return {
|
|
68
68
|
account,
|
|
69
69
|
chain: { id, unsupported },
|
|
70
|
-
provider: new
|
|
70
|
+
provider: new providers.Web3Provider(
|
|
71
71
|
provider
|
|
72
72
|
)
|
|
73
73
|
};
|
|
@@ -75,12 +75,12 @@ var CoinbaseWalletConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
75
75
|
if (/(user closed modal|accounts received is empty)/i.test(
|
|
76
76
|
error.message
|
|
77
77
|
))
|
|
78
|
-
throw new
|
|
78
|
+
throw new UserRejectedRequestError(error);
|
|
79
79
|
throw error;
|
|
80
80
|
}
|
|
81
81
|
}
|
|
82
82
|
async disconnect() {
|
|
83
|
-
if (!
|
|
83
|
+
if (!__privateGet(this, _provider))
|
|
84
84
|
return;
|
|
85
85
|
const provider = await this.getProvider();
|
|
86
86
|
provider.removeListener("accountsChanged", this.onAccountsChanged);
|
|
@@ -94,39 +94,39 @@ var CoinbaseWalletConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
94
94
|
const accounts = await provider.request({
|
|
95
95
|
method: "eth_accounts"
|
|
96
96
|
});
|
|
97
|
-
return
|
|
97
|
+
return getAddress(accounts[0]);
|
|
98
98
|
}
|
|
99
99
|
async getChainId() {
|
|
100
100
|
const provider = await this.getProvider();
|
|
101
|
-
const chainId =
|
|
101
|
+
const chainId = normalizeChainId(provider.chainId);
|
|
102
102
|
return chainId;
|
|
103
103
|
}
|
|
104
104
|
async getProvider() {
|
|
105
|
-
if (!
|
|
106
|
-
let CoinbaseWalletSDK = (await
|
|
105
|
+
if (!__privateGet(this, _provider)) {
|
|
106
|
+
let CoinbaseWalletSDK = (await import("@coinbase/wallet-sdk")).default;
|
|
107
107
|
if (typeof CoinbaseWalletSDK !== "function" && typeof CoinbaseWalletSDK.default === "function")
|
|
108
108
|
CoinbaseWalletSDK = CoinbaseWalletSDK.default;
|
|
109
|
-
|
|
109
|
+
__privateSet(this, _client, new CoinbaseWalletSDK(this.options));
|
|
110
110
|
class WalletProvider {
|
|
111
111
|
}
|
|
112
112
|
class Client {
|
|
113
113
|
}
|
|
114
|
-
const walletExtensionChainId =
|
|
114
|
+
const walletExtensionChainId = __privateGet(this, _client).walletExtension?.getChainId();
|
|
115
115
|
const chain = this.chains.find(
|
|
116
116
|
(chain2) => this.options.chainId ? chain2.id === this.options.chainId : chain2.id === walletExtensionChainId
|
|
117
117
|
) || this.chains[0];
|
|
118
|
-
const chainId = this.options.chainId ||
|
|
119
|
-
const jsonRpcUrl = this.options.jsonRpcUrl ||
|
|
120
|
-
|
|
118
|
+
const chainId = this.options.chainId || chain?.id;
|
|
119
|
+
const jsonRpcUrl = this.options.jsonRpcUrl || chain?.rpcUrls.default.http[0];
|
|
120
|
+
__privateSet(this, _provider, __privateGet(this, _client).makeWeb3Provider(jsonRpcUrl, chainId));
|
|
121
121
|
}
|
|
122
|
-
return
|
|
122
|
+
return __privateGet(this, _provider);
|
|
123
123
|
}
|
|
124
124
|
async getSigner({ chainId } = {}) {
|
|
125
125
|
const [provider, account] = await Promise.all([
|
|
126
126
|
this.getProvider(),
|
|
127
127
|
this.getAccount()
|
|
128
128
|
]);
|
|
129
|
-
return new
|
|
129
|
+
return new providers.Web3Provider(
|
|
130
130
|
provider,
|
|
131
131
|
chainId
|
|
132
132
|
).getSigner(account);
|
|
@@ -135,29 +135,29 @@ var CoinbaseWalletConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
135
135
|
try {
|
|
136
136
|
const account = await this.getAccount();
|
|
137
137
|
return !!account;
|
|
138
|
-
} catch
|
|
138
|
+
} catch {
|
|
139
139
|
return false;
|
|
140
140
|
}
|
|
141
141
|
}
|
|
142
142
|
async switchChain(chainId) {
|
|
143
143
|
const provider = await this.getProvider();
|
|
144
|
-
const id =
|
|
144
|
+
const id = hexValue(chainId);
|
|
145
145
|
try {
|
|
146
146
|
await provider.request({
|
|
147
147
|
method: "wallet_switchEthereumChain",
|
|
148
148
|
params: [{ chainId: id }]
|
|
149
149
|
});
|
|
150
|
-
return
|
|
150
|
+
return this.chains.find((x) => x.id === chainId) ?? {
|
|
151
151
|
id: chainId,
|
|
152
152
|
name: `Chain ${id}`,
|
|
153
153
|
network: `${id}`,
|
|
154
154
|
nativeCurrency: { name: "Ether", decimals: 18, symbol: "ETH" },
|
|
155
155
|
rpcUrls: { default: { http: [""] }, public: { http: [""] } }
|
|
156
|
-
}
|
|
156
|
+
};
|
|
157
157
|
} catch (error) {
|
|
158
158
|
const chain = this.chains.find((x) => x.id === chainId);
|
|
159
159
|
if (!chain)
|
|
160
|
-
throw new
|
|
160
|
+
throw new ChainNotConfiguredError({ chainId, connectorId: this.id });
|
|
161
161
|
if (error.code === 4902) {
|
|
162
162
|
try {
|
|
163
163
|
await provider.request({
|
|
@@ -167,21 +167,21 @@ var CoinbaseWalletConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
167
167
|
chainId: id,
|
|
168
168
|
chainName: chain.name,
|
|
169
169
|
nativeCurrency: chain.nativeCurrency,
|
|
170
|
-
rpcUrls: [
|
|
170
|
+
rpcUrls: [chain.rpcUrls.public?.http[0] ?? ""],
|
|
171
171
|
blockExplorerUrls: this.getBlockExplorerUrls(chain)
|
|
172
172
|
}
|
|
173
173
|
]
|
|
174
174
|
});
|
|
175
175
|
return chain;
|
|
176
176
|
} catch (addError) {
|
|
177
|
-
if (
|
|
178
|
-
throw new
|
|
179
|
-
throw new
|
|
177
|
+
if (__privateMethod(this, _isUserRejectedRequestError, isUserRejectedRequestError_fn).call(this, addError))
|
|
178
|
+
throw new UserRejectedRequestError(addError);
|
|
179
|
+
throw new AddChainError();
|
|
180
180
|
}
|
|
181
181
|
}
|
|
182
|
-
if (
|
|
183
|
-
throw new
|
|
184
|
-
throw new
|
|
182
|
+
if (__privateMethod(this, _isUserRejectedRequestError, isUserRejectedRequestError_fn).call(this, error))
|
|
183
|
+
throw new UserRejectedRequestError(error);
|
|
184
|
+
throw new SwitchChainError(error);
|
|
185
185
|
}
|
|
186
186
|
}
|
|
187
187
|
async watchAsset({
|
|
@@ -211,6 +211,6 @@ _isUserRejectedRequestError = new WeakSet();
|
|
|
211
211
|
isUserRejectedRequestError_fn = function(error) {
|
|
212
212
|
return /(user rejected)/i.test(error.message);
|
|
213
213
|
};
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
214
|
+
export {
|
|
215
|
+
CoinbaseWalletConnector
|
|
216
|
+
};
|
package/dist/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export { C as Connector, a as ConnectorData, b as ConnectorEvents } from './base-84a689bb.js';
|
|
2
|
-
export { E as Ethereum } from './types-
|
|
2
|
+
export { E as Ethereum } from './types-acc5bc95.js';
|
|
3
3
|
import '@wagmi/core';
|
|
4
4
|
import '@wagmi/core/chains';
|
|
5
5
|
import 'eventemitter3';
|
package/dist/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import {
|
|
2
|
+
Connector
|
|
3
|
+
} from "./chunk-5NCTPR6C.js";
|
|
4
|
+
export {
|
|
5
|
+
Connector
|
|
6
|
+
};
|
package/dist/injected.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { Address } from '@wagmi/core';
|
|
|
2
2
|
import { Chain } from '@wagmi/core/chains';
|
|
3
3
|
import { providers } from 'ethers';
|
|
4
4
|
import { C as Connector } from './base-84a689bb.js';
|
|
5
|
-
import { E as Ethereum } from './types-
|
|
5
|
+
import { E as Ethereum } from './types-acc5bc95.js';
|
|
6
6
|
import 'eventemitter3';
|
|
7
7
|
import 'abitype';
|
|
8
8
|
|
package/dist/injected.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
import {
|
|
2
|
+
InjectedConnector
|
|
3
|
+
} from "./chunk-N7MKKIYR.js";
|
|
4
|
+
import "./chunk-5NCTPR6C.js";
|
|
5
|
+
export {
|
|
6
|
+
InjectedConnector
|
|
7
|
+
};
|