@wagmi/connectors 0.3.9-cjs → 0.3.9
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-V2FVPXGH.js +69 -69
- 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 +53 -53
- 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 +41 -1
- package/safe/package.json +1 -1
- package/walletConnect/package.json +1 -1
- package/walletConnectLegacy/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
|
+
};
|
package/dist/chunk-V2FVPXGH.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) {
|
|
@@ -87,7 +87,7 @@ function getInjectedName(ethereum) {
|
|
|
87
87
|
if (provider.isMetaMask)
|
|
88
88
|
return "MetaMask";
|
|
89
89
|
};
|
|
90
|
-
if (
|
|
90
|
+
if (ethereum.providers?.length) {
|
|
91
91
|
const nameSet = /* @__PURE__ */ new Set();
|
|
92
92
|
let unknownCount = 1;
|
|
93
93
|
for (const provider of ethereum.providers) {
|
|
@@ -101,14 +101,14 @@ function getInjectedName(ethereum) {
|
|
|
101
101
|
const names = [...nameSet];
|
|
102
102
|
if (names.length)
|
|
103
103
|
return names;
|
|
104
|
-
return
|
|
104
|
+
return names[0] ?? "Injected";
|
|
105
105
|
}
|
|
106
|
-
return
|
|
106
|
+
return getName(ethereum) ?? "Injected";
|
|
107
107
|
}
|
|
108
108
|
|
|
109
109
|
// src/injected.ts
|
|
110
110
|
var _provider;
|
|
111
|
-
var InjectedConnector = class extends
|
|
111
|
+
var InjectedConnector = class extends Connector {
|
|
112
112
|
constructor({
|
|
113
113
|
chains,
|
|
114
114
|
options: options_
|
|
@@ -119,25 +119,25 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
119
119
|
...options_
|
|
120
120
|
};
|
|
121
121
|
super({ chains, options });
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
122
|
+
__publicField(this, "id", "injected");
|
|
123
|
+
__publicField(this, "name");
|
|
124
|
+
__publicField(this, "ready");
|
|
125
|
+
__privateAdd(this, _provider, void 0);
|
|
126
|
+
__publicField(this, "shimDisconnectKey", `${this.id}.shimDisconnect`);
|
|
127
|
+
__publicField(this, "onAccountsChanged", (accounts) => {
|
|
128
128
|
if (accounts.length === 0)
|
|
129
129
|
this.emit("disconnect");
|
|
130
130
|
else
|
|
131
131
|
this.emit("change", {
|
|
132
|
-
account:
|
|
132
|
+
account: getAddress(accounts[0])
|
|
133
133
|
});
|
|
134
134
|
});
|
|
135
|
-
|
|
136
|
-
const id =
|
|
135
|
+
__publicField(this, "onChainChanged", (chainId) => {
|
|
136
|
+
const id = normalizeChainId(chainId);
|
|
137
137
|
const unsupported = this.isChainUnsupported(id);
|
|
138
138
|
this.emit("change", { chain: { id, unsupported } });
|
|
139
139
|
});
|
|
140
|
-
|
|
140
|
+
__publicField(this, "onDisconnect", async (error) => {
|
|
141
141
|
if (error.code === 1013) {
|
|
142
142
|
const provider = await this.getProvider();
|
|
143
143
|
if (provider) {
|
|
@@ -148,7 +148,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
148
148
|
}
|
|
149
149
|
this.emit("disconnect");
|
|
150
150
|
if (this.options.shimDisconnect)
|
|
151
|
-
|
|
151
|
+
getClient().storage?.removeItem(this.shimDisconnectKey);
|
|
152
152
|
});
|
|
153
153
|
const provider = options.getProvider();
|
|
154
154
|
if (typeof options.name === "string")
|
|
@@ -171,7 +171,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
171
171
|
try {
|
|
172
172
|
const provider = await this.getProvider();
|
|
173
173
|
if (!provider)
|
|
174
|
-
throw new
|
|
174
|
+
throw new ConnectorNotFoundError();
|
|
175
175
|
if (provider.on) {
|
|
176
176
|
provider.on("accountsChanged", this.onAccountsChanged);
|
|
177
177
|
provider.on("chainChanged", this.onChainChanged);
|
|
@@ -181,7 +181,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
181
181
|
const accounts = await provider.request({
|
|
182
182
|
method: "eth_requestAccounts"
|
|
183
183
|
});
|
|
184
|
-
const account =
|
|
184
|
+
const account = getAddress(accounts[0]);
|
|
185
185
|
let id = await this.getChainId();
|
|
186
186
|
let unsupported = this.isChainUnsupported(id);
|
|
187
187
|
if (chainId && id !== chainId) {
|
|
@@ -190,75 +190,75 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
190
190
|
unsupported = this.isChainUnsupported(id);
|
|
191
191
|
}
|
|
192
192
|
if (this.options.shimDisconnect)
|
|
193
|
-
|
|
193
|
+
getClient().storage?.setItem(this.shimDisconnectKey, true);
|
|
194
194
|
return { account, chain: { id, unsupported }, provider };
|
|
195
195
|
} catch (error) {
|
|
196
196
|
if (this.isUserRejectedRequestError(error))
|
|
197
|
-
throw new
|
|
197
|
+
throw new UserRejectedRequestError(error);
|
|
198
198
|
if (error.code === -32002)
|
|
199
|
-
throw new
|
|
199
|
+
throw new ResourceUnavailableError(error);
|
|
200
200
|
throw error;
|
|
201
201
|
}
|
|
202
202
|
}
|
|
203
203
|
async disconnect() {
|
|
204
204
|
const provider = await this.getProvider();
|
|
205
|
-
if (!
|
|
205
|
+
if (!provider?.removeListener)
|
|
206
206
|
return;
|
|
207
207
|
provider.removeListener("accountsChanged", this.onAccountsChanged);
|
|
208
208
|
provider.removeListener("chainChanged", this.onChainChanged);
|
|
209
209
|
provider.removeListener("disconnect", this.onDisconnect);
|
|
210
210
|
if (this.options.shimDisconnect)
|
|
211
|
-
|
|
211
|
+
getClient().storage?.removeItem(this.shimDisconnectKey);
|
|
212
212
|
}
|
|
213
213
|
async getAccount() {
|
|
214
214
|
const provider = await this.getProvider();
|
|
215
215
|
if (!provider)
|
|
216
|
-
throw new
|
|
216
|
+
throw new ConnectorNotFoundError();
|
|
217
217
|
const accounts = await provider.request({
|
|
218
218
|
method: "eth_accounts"
|
|
219
219
|
});
|
|
220
|
-
return
|
|
220
|
+
return getAddress(accounts[0]);
|
|
221
221
|
}
|
|
222
222
|
async getChainId() {
|
|
223
223
|
const provider = await this.getProvider();
|
|
224
224
|
if (!provider)
|
|
225
|
-
throw new
|
|
226
|
-
return provider.request({ method: "eth_chainId" }).then(
|
|
225
|
+
throw new ConnectorNotFoundError();
|
|
226
|
+
return provider.request({ method: "eth_chainId" }).then(normalizeChainId);
|
|
227
227
|
}
|
|
228
228
|
async getProvider() {
|
|
229
229
|
const provider = this.options.getProvider();
|
|
230
230
|
if (provider)
|
|
231
|
-
|
|
232
|
-
return
|
|
231
|
+
__privateSet(this, _provider, provider);
|
|
232
|
+
return __privateGet(this, _provider);
|
|
233
233
|
}
|
|
234
234
|
async getSigner({ chainId } = {}) {
|
|
235
235
|
const [provider, account] = await Promise.all([
|
|
236
236
|
this.getProvider(),
|
|
237
237
|
this.getAccount()
|
|
238
238
|
]);
|
|
239
|
-
return new
|
|
239
|
+
return new providers.Web3Provider(
|
|
240
240
|
provider,
|
|
241
241
|
chainId
|
|
242
242
|
).getSigner(account);
|
|
243
243
|
}
|
|
244
244
|
async isAuthorized() {
|
|
245
245
|
try {
|
|
246
|
-
if (this.options.shimDisconnect && !
|
|
246
|
+
if (this.options.shimDisconnect && !getClient().storage?.getItem(this.shimDisconnectKey))
|
|
247
247
|
return false;
|
|
248
248
|
const provider = await this.getProvider();
|
|
249
249
|
if (!provider)
|
|
250
|
-
throw new
|
|
250
|
+
throw new ConnectorNotFoundError();
|
|
251
251
|
const account = await this.getAccount();
|
|
252
252
|
return !!account;
|
|
253
|
-
} catch
|
|
253
|
+
} catch {
|
|
254
254
|
return false;
|
|
255
255
|
}
|
|
256
256
|
}
|
|
257
257
|
async switchChain(chainId) {
|
|
258
258
|
const provider = await this.getProvider();
|
|
259
259
|
if (!provider)
|
|
260
|
-
throw new
|
|
261
|
-
const id =
|
|
260
|
+
throw new ConnectorNotFoundError();
|
|
261
|
+
const id = hexValue(chainId);
|
|
262
262
|
try {
|
|
263
263
|
await Promise.all([
|
|
264
264
|
provider.request({
|
|
@@ -267,23 +267,23 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
267
267
|
}),
|
|
268
268
|
new Promise(
|
|
269
269
|
(res) => this.on("change", ({ chain }) => {
|
|
270
|
-
if (
|
|
270
|
+
if (chain?.id === chainId)
|
|
271
271
|
res();
|
|
272
272
|
})
|
|
273
273
|
)
|
|
274
274
|
]);
|
|
275
|
-
return
|
|
275
|
+
return this.chains.find((x) => x.id === chainId) ?? {
|
|
276
276
|
id: chainId,
|
|
277
277
|
name: `Chain ${id}`,
|
|
278
278
|
network: `${id}`,
|
|
279
279
|
nativeCurrency: { name: "Ether", decimals: 18, symbol: "ETH" },
|
|
280
280
|
rpcUrls: { default: { http: [""] }, public: { http: [""] } }
|
|
281
|
-
}
|
|
281
|
+
};
|
|
282
282
|
} catch (error) {
|
|
283
283
|
const chain = this.chains.find((x) => x.id === chainId);
|
|
284
284
|
if (!chain)
|
|
285
|
-
throw new
|
|
286
|
-
if (error.code === 4902 ||
|
|
285
|
+
throw new ChainNotConfiguredError({ chainId, connectorId: this.id });
|
|
286
|
+
if (error.code === 4902 || error?.data?.originalError?.code === 4902) {
|
|
287
287
|
try {
|
|
288
288
|
await provider.request({
|
|
289
289
|
method: "wallet_addEthereumChain",
|
|
@@ -292,27 +292,27 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
292
292
|
chainId: id,
|
|
293
293
|
chainName: chain.name,
|
|
294
294
|
nativeCurrency: chain.nativeCurrency,
|
|
295
|
-
rpcUrls: [
|
|
295
|
+
rpcUrls: [chain.rpcUrls.public?.http[0] ?? ""],
|
|
296
296
|
blockExplorerUrls: this.getBlockExplorerUrls(chain)
|
|
297
297
|
}
|
|
298
298
|
]
|
|
299
299
|
});
|
|
300
300
|
const currentChainId = await this.getChainId();
|
|
301
301
|
if (currentChainId !== chainId)
|
|
302
|
-
throw new
|
|
302
|
+
throw new ProviderRpcError(
|
|
303
303
|
"User rejected switch after adding network.",
|
|
304
304
|
{ code: 4001 }
|
|
305
305
|
);
|
|
306
306
|
return chain;
|
|
307
307
|
} catch (addError) {
|
|
308
308
|
if (this.isUserRejectedRequestError(addError))
|
|
309
|
-
throw new
|
|
310
|
-
throw new
|
|
309
|
+
throw new UserRejectedRequestError(error);
|
|
310
|
+
throw new AddChainError();
|
|
311
311
|
}
|
|
312
312
|
}
|
|
313
313
|
if (this.isUserRejectedRequestError(error))
|
|
314
|
-
throw new
|
|
315
|
-
throw new
|
|
314
|
+
throw new UserRejectedRequestError(error);
|
|
315
|
+
throw new SwitchChainError(error);
|
|
316
316
|
}
|
|
317
317
|
}
|
|
318
318
|
async watchAsset({
|
|
@@ -323,7 +323,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
323
323
|
}) {
|
|
324
324
|
const provider = await this.getProvider();
|
|
325
325
|
if (!provider)
|
|
326
|
-
throw new
|
|
326
|
+
throw new ConnectorNotFoundError();
|
|
327
327
|
return provider.request({
|
|
328
328
|
method: "wallet_watchAsset",
|
|
329
329
|
params: {
|
|
@@ -343,6 +343,6 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
343
343
|
};
|
|
344
344
|
_provider = new WeakMap();
|
|
345
345
|
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
346
|
+
export {
|
|
347
|
+
InjectedConnector
|
|
348
|
+
};
|
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-V2FVPXGH.js";
|
|
4
|
+
import "./chunk-5NCTPR6C.js";
|
|
5
|
+
export {
|
|
6
|
+
InjectedConnector
|
|
7
|
+
};
|