@wagmi/connectors 0.2.7-cjs → 0.2.7
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-SCGCTBHA.js +71 -71
- package/dist/coinbaseWallet.js +59 -59
- package/dist/index.js +6 -6
- package/dist/injected.js +7 -7
- package/dist/ledger.js +45 -45
- package/dist/metaMask.js +34 -34
- package/dist/mock/index.js +62 -62
- package/dist/safe.js +45 -45
- package/dist/walletConnect.js +87 -87
- 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 +37 -1
- 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
|
+
};
|
package/dist/chunk-SCGCTBHA.js
CHANGED
|
@@ -1,24 +1,24 @@
|
|
|
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) {
|
|
@@ -66,7 +66,7 @@ function getInjectedName(ethereum) {
|
|
|
66
66
|
if (provider.isXDEFI)
|
|
67
67
|
return "XDEFI Wallet";
|
|
68
68
|
};
|
|
69
|
-
if (
|
|
69
|
+
if (ethereum.providers?.length) {
|
|
70
70
|
const nameSet = /* @__PURE__ */ new Set();
|
|
71
71
|
let unknownCount = 1;
|
|
72
72
|
for (const provider of ethereum.providers) {
|
|
@@ -80,14 +80,14 @@ function getInjectedName(ethereum) {
|
|
|
80
80
|
const names = [...nameSet];
|
|
81
81
|
if (names.length)
|
|
82
82
|
return names;
|
|
83
|
-
return
|
|
83
|
+
return names[0] ?? "Injected";
|
|
84
84
|
}
|
|
85
|
-
return
|
|
85
|
+
return getName(ethereum) ?? "Injected";
|
|
86
86
|
}
|
|
87
87
|
|
|
88
88
|
// src/injected.ts
|
|
89
89
|
var _provider, _switchingChains;
|
|
90
|
-
var InjectedConnector = class extends
|
|
90
|
+
var InjectedConnector = class extends Connector {
|
|
91
91
|
constructor({
|
|
92
92
|
chains,
|
|
93
93
|
options: options_
|
|
@@ -99,33 +99,33 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
99
99
|
...options_
|
|
100
100
|
};
|
|
101
101
|
super({ chains, options });
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
102
|
+
__publicField(this, "id", "injected");
|
|
103
|
+
__publicField(this, "name");
|
|
104
|
+
__publicField(this, "ready");
|
|
105
|
+
__privateAdd(this, _provider, void 0);
|
|
106
|
+
__privateAdd(this, _switchingChains, void 0);
|
|
107
|
+
__publicField(this, "shimDisconnectKey", `${this.id}.shimDisconnect`);
|
|
108
|
+
__publicField(this, "onAccountsChanged", (accounts) => {
|
|
109
109
|
if (accounts.length === 0)
|
|
110
110
|
this.emit("disconnect");
|
|
111
111
|
else
|
|
112
112
|
this.emit("change", {
|
|
113
|
-
account:
|
|
113
|
+
account: getAddress(accounts[0])
|
|
114
114
|
});
|
|
115
115
|
});
|
|
116
|
-
|
|
117
|
-
const id =
|
|
116
|
+
__publicField(this, "onChainChanged", (chainId) => {
|
|
117
|
+
const id = normalizeChainId(chainId);
|
|
118
118
|
const unsupported = this.isChainUnsupported(id);
|
|
119
119
|
this.emit("change", { chain: { id, unsupported } });
|
|
120
120
|
});
|
|
121
|
-
|
|
122
|
-
if (this.options.shimChainChangedDisconnect &&
|
|
123
|
-
|
|
121
|
+
__publicField(this, "onDisconnect", () => {
|
|
122
|
+
if (this.options.shimChainChangedDisconnect && __privateGet(this, _switchingChains)) {
|
|
123
|
+
__privateSet(this, _switchingChains, false);
|
|
124
124
|
return;
|
|
125
125
|
}
|
|
126
126
|
this.emit("disconnect");
|
|
127
127
|
if (this.options.shimDisconnect)
|
|
128
|
-
|
|
128
|
+
getClient().storage?.removeItem(this.shimDisconnectKey);
|
|
129
129
|
});
|
|
130
130
|
const provider = options.getProvider();
|
|
131
131
|
if (typeof options.name === "string")
|
|
@@ -148,7 +148,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
148
148
|
try {
|
|
149
149
|
const provider = await this.getProvider();
|
|
150
150
|
if (!provider)
|
|
151
|
-
throw new
|
|
151
|
+
throw new ConnectorNotFoundError();
|
|
152
152
|
if (provider.on) {
|
|
153
153
|
provider.on("accountsChanged", this.onAccountsChanged);
|
|
154
154
|
provider.on("chainChanged", this.onChainChanged);
|
|
@@ -158,7 +158,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
158
158
|
const accounts = await provider.request({
|
|
159
159
|
method: "eth_requestAccounts"
|
|
160
160
|
});
|
|
161
|
-
const account =
|
|
161
|
+
const account = getAddress(accounts[0]);
|
|
162
162
|
let id = await this.getChainId();
|
|
163
163
|
let unsupported = this.isChainUnsupported(id);
|
|
164
164
|
if (chainId && id !== chainId) {
|
|
@@ -167,77 +167,77 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
167
167
|
unsupported = this.isChainUnsupported(id);
|
|
168
168
|
}
|
|
169
169
|
if (this.options.shimDisconnect)
|
|
170
|
-
|
|
170
|
+
getClient().storage?.setItem(this.shimDisconnectKey, true);
|
|
171
171
|
return { account, chain: { id, unsupported }, provider };
|
|
172
172
|
} catch (error) {
|
|
173
173
|
if (this.isUserRejectedRequestError(error))
|
|
174
|
-
throw new
|
|
174
|
+
throw new UserRejectedRequestError(error);
|
|
175
175
|
if (error.code === -32002)
|
|
176
|
-
throw new
|
|
176
|
+
throw new ResourceUnavailableError(error);
|
|
177
177
|
throw error;
|
|
178
178
|
}
|
|
179
179
|
}
|
|
180
180
|
async disconnect() {
|
|
181
181
|
const provider = await this.getProvider();
|
|
182
|
-
if (!
|
|
182
|
+
if (!provider?.removeListener)
|
|
183
183
|
return;
|
|
184
184
|
provider.removeListener("accountsChanged", this.onAccountsChanged);
|
|
185
185
|
provider.removeListener("chainChanged", this.onChainChanged);
|
|
186
186
|
provider.removeListener("disconnect", this.onDisconnect);
|
|
187
187
|
if (this.options.shimDisconnect)
|
|
188
|
-
|
|
188
|
+
getClient().storage?.removeItem(this.shimDisconnectKey);
|
|
189
189
|
}
|
|
190
190
|
async getAccount() {
|
|
191
191
|
const provider = await this.getProvider();
|
|
192
192
|
if (!provider)
|
|
193
|
-
throw new
|
|
193
|
+
throw new ConnectorNotFoundError();
|
|
194
194
|
const accounts = await provider.request({
|
|
195
195
|
method: "eth_accounts"
|
|
196
196
|
});
|
|
197
|
-
return
|
|
197
|
+
return getAddress(accounts[0]);
|
|
198
198
|
}
|
|
199
199
|
async getChainId() {
|
|
200
200
|
const provider = await this.getProvider();
|
|
201
201
|
if (!provider)
|
|
202
|
-
throw new
|
|
203
|
-
return provider.request({ method: "eth_chainId" }).then(
|
|
202
|
+
throw new ConnectorNotFoundError();
|
|
203
|
+
return provider.request({ method: "eth_chainId" }).then(normalizeChainId);
|
|
204
204
|
}
|
|
205
205
|
async getProvider() {
|
|
206
206
|
const provider = this.options.getProvider();
|
|
207
207
|
if (provider)
|
|
208
|
-
|
|
209
|
-
return
|
|
208
|
+
__privateSet(this, _provider, provider);
|
|
209
|
+
return __privateGet(this, _provider);
|
|
210
210
|
}
|
|
211
211
|
async getSigner({ chainId } = {}) {
|
|
212
212
|
const [provider, account] = await Promise.all([
|
|
213
213
|
this.getProvider(),
|
|
214
214
|
this.getAccount()
|
|
215
215
|
]);
|
|
216
|
-
return new
|
|
216
|
+
return new providers.Web3Provider(
|
|
217
217
|
provider,
|
|
218
218
|
chainId
|
|
219
219
|
).getSigner(account);
|
|
220
220
|
}
|
|
221
221
|
async isAuthorized() {
|
|
222
222
|
try {
|
|
223
|
-
if (this.options.shimDisconnect && !
|
|
223
|
+
if (this.options.shimDisconnect && !getClient().storage?.getItem(this.shimDisconnectKey))
|
|
224
224
|
return false;
|
|
225
225
|
const provider = await this.getProvider();
|
|
226
226
|
if (!provider)
|
|
227
|
-
throw new
|
|
227
|
+
throw new ConnectorNotFoundError();
|
|
228
228
|
const account = await this.getAccount();
|
|
229
229
|
return !!account;
|
|
230
|
-
} catch
|
|
230
|
+
} catch {
|
|
231
231
|
return false;
|
|
232
232
|
}
|
|
233
233
|
}
|
|
234
234
|
async switchChain(chainId) {
|
|
235
235
|
if (this.options.shimChainChangedDisconnect)
|
|
236
|
-
|
|
236
|
+
__privateSet(this, _switchingChains, true);
|
|
237
237
|
const provider = await this.getProvider();
|
|
238
238
|
if (!provider)
|
|
239
|
-
throw new
|
|
240
|
-
const id =
|
|
239
|
+
throw new ConnectorNotFoundError();
|
|
240
|
+
const id = hexValue(chainId);
|
|
241
241
|
try {
|
|
242
242
|
await Promise.all([
|
|
243
243
|
provider.request({
|
|
@@ -246,23 +246,23 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
246
246
|
}),
|
|
247
247
|
new Promise(
|
|
248
248
|
(res) => this.on("change", ({ chain }) => {
|
|
249
|
-
if (
|
|
249
|
+
if (chain?.id === chainId)
|
|
250
250
|
res();
|
|
251
251
|
})
|
|
252
252
|
)
|
|
253
253
|
]);
|
|
254
|
-
return
|
|
254
|
+
return this.chains.find((x) => x.id === chainId) ?? {
|
|
255
255
|
id: chainId,
|
|
256
256
|
name: `Chain ${id}`,
|
|
257
257
|
network: `${id}`,
|
|
258
258
|
nativeCurrency: { name: "Ether", decimals: 18, symbol: "ETH" },
|
|
259
259
|
rpcUrls: { default: { http: [""] }, public: { http: [""] } }
|
|
260
|
-
}
|
|
260
|
+
};
|
|
261
261
|
} catch (error) {
|
|
262
262
|
const chain = this.chains.find((x) => x.id === chainId);
|
|
263
263
|
if (!chain)
|
|
264
|
-
throw new
|
|
265
|
-
if (error.code === 4902 ||
|
|
264
|
+
throw new ChainNotConfiguredError({ chainId, connectorId: this.id });
|
|
265
|
+
if (error.code === 4902 || error?.data?.originalError?.code === 4902) {
|
|
266
266
|
try {
|
|
267
267
|
await provider.request({
|
|
268
268
|
method: "wallet_addEthereumChain",
|
|
@@ -271,7 +271,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
271
271
|
chainId: id,
|
|
272
272
|
chainName: chain.name,
|
|
273
273
|
nativeCurrency: chain.nativeCurrency,
|
|
274
|
-
rpcUrls: [
|
|
274
|
+
rpcUrls: [chain.rpcUrls.public?.http[0] ?? ""],
|
|
275
275
|
blockExplorerUrls: this.getBlockExplorerUrls(chain)
|
|
276
276
|
}
|
|
277
277
|
]
|
|
@@ -279,13 +279,13 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
279
279
|
return chain;
|
|
280
280
|
} catch (addError) {
|
|
281
281
|
if (this.isUserRejectedRequestError(addError))
|
|
282
|
-
throw new
|
|
283
|
-
throw new
|
|
282
|
+
throw new UserRejectedRequestError(error);
|
|
283
|
+
throw new AddChainError();
|
|
284
284
|
}
|
|
285
285
|
}
|
|
286
286
|
if (this.isUserRejectedRequestError(error))
|
|
287
|
-
throw new
|
|
288
|
-
throw new
|
|
287
|
+
throw new UserRejectedRequestError(error);
|
|
288
|
+
throw new SwitchChainError(error);
|
|
289
289
|
}
|
|
290
290
|
}
|
|
291
291
|
async watchAsset({
|
|
@@ -296,7 +296,7 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
296
296
|
}) {
|
|
297
297
|
const provider = await this.getProvider();
|
|
298
298
|
if (!provider)
|
|
299
|
-
throw new
|
|
299
|
+
throw new ConnectorNotFoundError();
|
|
300
300
|
return provider.request({
|
|
301
301
|
method: "wallet_watchAsset",
|
|
302
302
|
params: {
|
|
@@ -317,6 +317,6 @@ var InjectedConnector = class extends _chunk5NCTPR6Cjs.Connector {
|
|
|
317
317
|
_provider = new WeakMap();
|
|
318
318
|
_switchingChains = new WeakMap();
|
|
319
319
|
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
320
|
+
export {
|
|
321
|
+
InjectedConnector
|
|
322
|
+
};
|
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-SCGCTBHA.js";
|
|
4
|
+
import "./chunk-5NCTPR6C.js";
|
|
5
|
+
export {
|
|
6
|
+
InjectedConnector
|
|
7
|
+
};
|