@wagmi/connectors 0.3.19-cjs → 0.3.20
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-2VZS2JHJ.js +69 -69
- package/dist/chunk-5NCTPR6C.js +14 -14
- package/dist/coinbaseWallet.js +59 -59
- package/dist/index.js +6 -6
- package/dist/injected.js +7 -7
- package/dist/ledger.js +56 -56
- package/dist/metaMask.js +35 -35
- package/dist/mock/index.js +62 -62
- package/dist/safe.js +45 -45
- package/dist/walletConnect.js +102 -102
- package/dist/walletConnectLegacy.js +54 -54
- 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 +43 -3
- package/safe/package.json +1 -1
- package/walletConnect/package.json +1 -1
- package/walletConnectLegacy/package.json +1 -1
package/dist/chunk-2VZS2JHJ.js
CHANGED
|
@@ -1,25 +1,25 @@
|
|
|
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
|
-
|
|
22
|
-
|
|
10
|
+
import {
|
|
11
|
+
AddChainError,
|
|
12
|
+
ChainNotConfiguredError,
|
|
13
|
+
ConnectorNotFoundError,
|
|
14
|
+
ProviderRpcError,
|
|
15
|
+
ResourceUnavailableError,
|
|
16
|
+
SwitchChainError,
|
|
17
|
+
UserRejectedRequestError,
|
|
18
|
+
getClient,
|
|
19
|
+
normalizeChainId
|
|
20
|
+
} from "@wagmi/core";
|
|
21
|
+
import { providers } from "ethers";
|
|
22
|
+
import { getAddress, hexValue } from "ethers/lib/utils.js";
|
|
23
23
|
|
|
24
24
|
// src/utils/getInjectedName.ts
|
|
25
25
|
function getInjectedName(ethereum) {
|
|
@@ -95,7 +95,7 @@ function getInjectedName(ethereum) {
|
|
|
95
95
|
if (provider.isMetaMask)
|
|
96
96
|
return "MetaMask";
|
|
97
97
|
};
|
|
98
|
-
if (
|
|
98
|
+
if (ethereum.providers?.length) {
|
|
99
99
|
const nameSet = /* @__PURE__ */ new Set();
|
|
100
100
|
let unknownCount = 1;
|
|
101
101
|
for (const provider of ethereum.providers) {
|
|
@@ -109,14 +109,14 @@ function getInjectedName(ethereum) {
|
|
|
109
109
|
const names = [...nameSet];
|
|
110
110
|
if (names.length)
|
|
111
111
|
return names;
|
|
112
|
-
return
|
|
112
|
+
return names[0] ?? "Injected";
|
|
113
113
|
}
|
|
114
|
-
return
|
|
114
|
+
return getName(ethereum) ?? "Injected";
|
|
115
115
|
}
|
|
116
116
|
|
|
117
117
|
// src/injected.ts
|
|
118
118
|
var _provider;
|
|
119
|
-
var InjectedConnector = class extends
|
|
119
|
+
var InjectedConnector = class extends Connector {
|
|
120
120
|
constructor({
|
|
121
121
|
chains,
|
|
122
122
|
options: options_
|
|
@@ -127,25 +127,25 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
127
127
|
...options_
|
|
128
128
|
};
|
|
129
129
|
super({ chains, options });
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
130
|
+
__publicField(this, "id", "injected");
|
|
131
|
+
__publicField(this, "name");
|
|
132
|
+
__publicField(this, "ready");
|
|
133
|
+
__privateAdd(this, _provider, void 0);
|
|
134
|
+
__publicField(this, "shimDisconnectKey", `${this.id}.shimDisconnect`);
|
|
135
|
+
__publicField(this, "onAccountsChanged", (accounts) => {
|
|
136
136
|
if (accounts.length === 0)
|
|
137
137
|
this.emit("disconnect");
|
|
138
138
|
else
|
|
139
139
|
this.emit("change", {
|
|
140
|
-
account:
|
|
140
|
+
account: getAddress(accounts[0])
|
|
141
141
|
});
|
|
142
142
|
});
|
|
143
|
-
|
|
144
|
-
const id =
|
|
143
|
+
__publicField(this, "onChainChanged", (chainId) => {
|
|
144
|
+
const id = normalizeChainId(chainId);
|
|
145
145
|
const unsupported = this.isChainUnsupported(id);
|
|
146
146
|
this.emit("change", { chain: { id, unsupported } });
|
|
147
147
|
});
|
|
148
|
-
|
|
148
|
+
__publicField(this, "onDisconnect", async (error) => {
|
|
149
149
|
if (error.code === 1013) {
|
|
150
150
|
const provider = await this.getProvider();
|
|
151
151
|
if (provider) {
|
|
@@ -156,7 +156,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
156
156
|
}
|
|
157
157
|
this.emit("disconnect");
|
|
158
158
|
if (this.options.shimDisconnect)
|
|
159
|
-
|
|
159
|
+
getClient().storage?.removeItem(this.shimDisconnectKey);
|
|
160
160
|
});
|
|
161
161
|
const provider = options.getProvider();
|
|
162
162
|
if (typeof options.name === "string")
|
|
@@ -179,7 +179,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
179
179
|
try {
|
|
180
180
|
const provider = await this.getProvider();
|
|
181
181
|
if (!provider)
|
|
182
|
-
throw new
|
|
182
|
+
throw new ConnectorNotFoundError();
|
|
183
183
|
if (provider.on) {
|
|
184
184
|
provider.on("accountsChanged", this.onAccountsChanged);
|
|
185
185
|
provider.on("chainChanged", this.onChainChanged);
|
|
@@ -189,7 +189,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
189
189
|
const accounts = await provider.request({
|
|
190
190
|
method: "eth_requestAccounts"
|
|
191
191
|
});
|
|
192
|
-
const account =
|
|
192
|
+
const account = getAddress(accounts[0]);
|
|
193
193
|
let id = await this.getChainId();
|
|
194
194
|
let unsupported = this.isChainUnsupported(id);
|
|
195
195
|
if (chainId && id !== chainId) {
|
|
@@ -198,75 +198,75 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
198
198
|
unsupported = this.isChainUnsupported(id);
|
|
199
199
|
}
|
|
200
200
|
if (this.options.shimDisconnect)
|
|
201
|
-
|
|
201
|
+
getClient().storage?.setItem(this.shimDisconnectKey, true);
|
|
202
202
|
return { account, chain: { id, unsupported }, provider };
|
|
203
203
|
} catch (error) {
|
|
204
204
|
if (this.isUserRejectedRequestError(error))
|
|
205
|
-
throw new
|
|
205
|
+
throw new UserRejectedRequestError(error);
|
|
206
206
|
if (error.code === -32002)
|
|
207
|
-
throw new
|
|
207
|
+
throw new ResourceUnavailableError(error);
|
|
208
208
|
throw error;
|
|
209
209
|
}
|
|
210
210
|
}
|
|
211
211
|
async disconnect() {
|
|
212
212
|
const provider = await this.getProvider();
|
|
213
|
-
if (!
|
|
213
|
+
if (!provider?.removeListener)
|
|
214
214
|
return;
|
|
215
215
|
provider.removeListener("accountsChanged", this.onAccountsChanged);
|
|
216
216
|
provider.removeListener("chainChanged", this.onChainChanged);
|
|
217
217
|
provider.removeListener("disconnect", this.onDisconnect);
|
|
218
218
|
if (this.options.shimDisconnect)
|
|
219
|
-
|
|
219
|
+
getClient().storage?.removeItem(this.shimDisconnectKey);
|
|
220
220
|
}
|
|
221
221
|
async getAccount() {
|
|
222
222
|
const provider = await this.getProvider();
|
|
223
223
|
if (!provider)
|
|
224
|
-
throw new
|
|
224
|
+
throw new ConnectorNotFoundError();
|
|
225
225
|
const accounts = await provider.request({
|
|
226
226
|
method: "eth_accounts"
|
|
227
227
|
});
|
|
228
|
-
return
|
|
228
|
+
return getAddress(accounts[0]);
|
|
229
229
|
}
|
|
230
230
|
async getChainId() {
|
|
231
231
|
const provider = await this.getProvider();
|
|
232
232
|
if (!provider)
|
|
233
|
-
throw new
|
|
234
|
-
return provider.request({ method: "eth_chainId" }).then(
|
|
233
|
+
throw new ConnectorNotFoundError();
|
|
234
|
+
return provider.request({ method: "eth_chainId" }).then(normalizeChainId);
|
|
235
235
|
}
|
|
236
236
|
async getProvider() {
|
|
237
237
|
const provider = this.options.getProvider();
|
|
238
238
|
if (provider)
|
|
239
|
-
|
|
240
|
-
return
|
|
239
|
+
__privateSet(this, _provider, provider);
|
|
240
|
+
return __privateGet(this, _provider);
|
|
241
241
|
}
|
|
242
242
|
async getSigner({ chainId } = {}) {
|
|
243
243
|
const [provider, account] = await Promise.all([
|
|
244
244
|
this.getProvider(),
|
|
245
245
|
this.getAccount()
|
|
246
246
|
]);
|
|
247
|
-
return new
|
|
247
|
+
return new providers.Web3Provider(
|
|
248
248
|
provider,
|
|
249
249
|
chainId
|
|
250
250
|
).getSigner(account);
|
|
251
251
|
}
|
|
252
252
|
async isAuthorized() {
|
|
253
253
|
try {
|
|
254
|
-
if (this.options.shimDisconnect && !
|
|
254
|
+
if (this.options.shimDisconnect && !getClient().storage?.getItem(this.shimDisconnectKey))
|
|
255
255
|
return false;
|
|
256
256
|
const provider = await this.getProvider();
|
|
257
257
|
if (!provider)
|
|
258
|
-
throw new
|
|
258
|
+
throw new ConnectorNotFoundError();
|
|
259
259
|
const account = await this.getAccount();
|
|
260
260
|
return !!account;
|
|
261
|
-
} catch
|
|
261
|
+
} catch {
|
|
262
262
|
return false;
|
|
263
263
|
}
|
|
264
264
|
}
|
|
265
265
|
async switchChain(chainId) {
|
|
266
266
|
const provider = await this.getProvider();
|
|
267
267
|
if (!provider)
|
|
268
|
-
throw new
|
|
269
|
-
const id =
|
|
268
|
+
throw new ConnectorNotFoundError();
|
|
269
|
+
const id = hexValue(chainId);
|
|
270
270
|
try {
|
|
271
271
|
await Promise.all([
|
|
272
272
|
provider.request({
|
|
@@ -275,23 +275,23 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
275
275
|
}),
|
|
276
276
|
new Promise(
|
|
277
277
|
(res) => this.on("change", ({ chain }) => {
|
|
278
|
-
if (
|
|
278
|
+
if (chain?.id === chainId)
|
|
279
279
|
res();
|
|
280
280
|
})
|
|
281
281
|
)
|
|
282
282
|
]);
|
|
283
|
-
return
|
|
283
|
+
return this.chains.find((x) => x.id === chainId) ?? {
|
|
284
284
|
id: chainId,
|
|
285
285
|
name: `Chain ${id}`,
|
|
286
286
|
network: `${id}`,
|
|
287
287
|
nativeCurrency: { name: "Ether", decimals: 18, symbol: "ETH" },
|
|
288
288
|
rpcUrls: { default: { http: [""] }, public: { http: [""] } }
|
|
289
|
-
}
|
|
289
|
+
};
|
|
290
290
|
} catch (error) {
|
|
291
291
|
const chain = this.chains.find((x) => x.id === chainId);
|
|
292
292
|
if (!chain)
|
|
293
|
-
throw new
|
|
294
|
-
if (error.code === 4902 ||
|
|
293
|
+
throw new ChainNotConfiguredError({ chainId, connectorId: this.id });
|
|
294
|
+
if (error.code === 4902 || error?.data?.originalError?.code === 4902) {
|
|
295
295
|
try {
|
|
296
296
|
await provider.request({
|
|
297
297
|
method: "wallet_addEthereumChain",
|
|
@@ -300,27 +300,27 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
300
300
|
chainId: id,
|
|
301
301
|
chainName: chain.name,
|
|
302
302
|
nativeCurrency: chain.nativeCurrency,
|
|
303
|
-
rpcUrls: [
|
|
303
|
+
rpcUrls: [chain.rpcUrls.public?.http[0] ?? ""],
|
|
304
304
|
blockExplorerUrls: this.getBlockExplorerUrls(chain)
|
|
305
305
|
}
|
|
306
306
|
]
|
|
307
307
|
});
|
|
308
308
|
const currentChainId = await this.getChainId();
|
|
309
309
|
if (currentChainId !== chainId)
|
|
310
|
-
throw new
|
|
310
|
+
throw new ProviderRpcError(
|
|
311
311
|
"User rejected switch after adding network.",
|
|
312
312
|
{ code: 4001 }
|
|
313
313
|
);
|
|
314
314
|
return chain;
|
|
315
315
|
} catch (addError) {
|
|
316
316
|
if (this.isUserRejectedRequestError(addError))
|
|
317
|
-
throw new
|
|
318
|
-
throw new
|
|
317
|
+
throw new UserRejectedRequestError(addError);
|
|
318
|
+
throw new AddChainError();
|
|
319
319
|
}
|
|
320
320
|
}
|
|
321
321
|
if (this.isUserRejectedRequestError(error))
|
|
322
|
-
throw new
|
|
323
|
-
throw new
|
|
322
|
+
throw new UserRejectedRequestError(error);
|
|
323
|
+
throw new SwitchChainError(error);
|
|
324
324
|
}
|
|
325
325
|
}
|
|
326
326
|
async watchAsset({
|
|
@@ -331,7 +331,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
331
331
|
}) {
|
|
332
332
|
const provider = await this.getProvider();
|
|
333
333
|
if (!provider)
|
|
334
|
-
throw new
|
|
334
|
+
throw new ConnectorNotFoundError();
|
|
335
335
|
return provider.request({
|
|
336
336
|
method: "wallet_watchAsset",
|
|
337
337
|
params: {
|
|
@@ -351,6 +351,6 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
351
351
|
};
|
|
352
352
|
_provider = new WeakMap();
|
|
353
353
|
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
354
|
+
export {
|
|
355
|
+
InjectedConnector
|
|
356
|
+
};
|
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
|
+
};
|
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.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.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
1
|
+
import {
|
|
2
|
+
InjectedConnector
|
|
3
|
+
} from "./chunk-2VZS2JHJ.js";
|
|
4
|
+
import "./chunk-5NCTPR6C.js";
|
|
5
|
+
export {
|
|
6
|
+
InjectedConnector
|
|
7
|
+
};
|