@wagmi/core 0.3.5 → 0.3.6

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.
Files changed (31) hide show
  1. package/connectors/coinbaseWallet/dist/wagmi-core-connectors-coinbaseWallet.cjs.dev.js +28 -9
  2. package/connectors/coinbaseWallet/dist/wagmi-core-connectors-coinbaseWallet.cjs.prod.js +28 -9
  3. package/connectors/coinbaseWallet/dist/wagmi-core-connectors-coinbaseWallet.esm.js +28 -9
  4. package/connectors/metaMask/dist/wagmi-core-connectors-metaMask.cjs.dev.js +10 -8
  5. package/connectors/metaMask/dist/wagmi-core-connectors-metaMask.cjs.prod.js +10 -8
  6. package/connectors/metaMask/dist/wagmi-core-connectors-metaMask.esm.js +10 -8
  7. package/connectors/mock/dist/wagmi-core-connectors-mock.cjs.dev.js +19 -6
  8. package/connectors/mock/dist/wagmi-core-connectors-mock.cjs.prod.js +19 -6
  9. package/connectors/mock/dist/wagmi-core-connectors-mock.esm.js +19 -6
  10. package/connectors/walletConnect/dist/wagmi-core-connectors-walletConnect.cjs.dev.js +28 -5
  11. package/connectors/walletConnect/dist/wagmi-core-connectors-walletConnect.cjs.prod.js +28 -5
  12. package/connectors/walletConnect/dist/wagmi-core-connectors-walletConnect.esm.js +28 -5
  13. package/dist/{base-321ac87a.cjs.dev.js → base-d45bb8f9.cjs.dev.js} +5 -3
  14. package/dist/{base-41fb6637.esm.js → base-d69e580f.esm.js} +6 -4
  15. package/dist/{base-6841ebe0.cjs.prod.js → base-ffe4d8ed.cjs.prod.js} +5 -3
  16. package/dist/{client-4172f963.cjs.dev.js → client-20bfac7f.cjs.dev.js} +66 -12
  17. package/dist/{client-87c1ff8b.esm.js → client-61f14c97.esm.js} +66 -12
  18. package/dist/{client-a06c45f3.cjs.prod.js → client-8b124969.cjs.prod.js} +66 -12
  19. package/dist/declarations/src/actions/accounts/connect.d.ts +3 -1
  20. package/dist/declarations/src/client.d.ts +1 -0
  21. package/dist/declarations/src/connectors/base.d.ts +7 -2
  22. package/dist/declarations/src/connectors/coinbaseWallet.d.ts +4 -2
  23. package/dist/declarations/src/connectors/injected.d.ts +9 -1
  24. package/dist/declarations/src/connectors/metaMask.d.ts +2 -2
  25. package/dist/declarations/src/connectors/mock/connector.d.ts +6 -2
  26. package/dist/declarations/src/connectors/mock/provider.d.ts +1 -1
  27. package/dist/declarations/src/connectors/walletConnect.d.ts +7 -2
  28. package/dist/wagmi-core.cjs.dev.js +6 -3
  29. package/dist/wagmi-core.cjs.prod.js +6 -3
  30. package/dist/wagmi-core.esm.js +8 -5
  31. package/package.json +1 -1
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var base = require('../../../dist/base-321ac87a.cjs.dev.js');
5
+ var base = require('../../../dist/base-d45bb8f9.cjs.dev.js');
6
6
  var ethers = require('ethers');
7
7
  var utils = require('ethers/lib/utils');
8
8
  var chains = require('../../../dist/chains-98e2e613.cjs.dev.js');
@@ -34,8 +34,15 @@ var _provider = /*#__PURE__*/new WeakMap();
34
34
  var _isUserRejectedRequestError = /*#__PURE__*/new WeakSet();
35
35
 
36
36
  class CoinbaseWalletConnector extends base.Connector {
37
- constructor(config) {
38
- super(config);
37
+ constructor(_ref) {
38
+ let {
39
+ chains,
40
+ options
41
+ } = _ref;
42
+ super({
43
+ chains,
44
+ options
45
+ });
39
46
 
40
47
  base._classPrivateMethodInitSpec(this, _isUserRejectedRequestError);
41
48
 
@@ -77,7 +84,11 @@ class CoinbaseWalletConnector extends base.Connector {
77
84
  });
78
85
  }
79
86
 
80
- async connect() {
87
+ async connect(_ref2) {
88
+ let {
89
+ chainId
90
+ } = _ref2;
91
+
81
92
  try {
82
93
  const provider = await this.getProvider();
83
94
  provider.on('accountsChanged', this.onAccountsChanged);
@@ -87,9 +98,17 @@ class CoinbaseWalletConnector extends base.Connector {
87
98
  type: 'connecting'
88
99
  });
89
100
  const accounts = await provider.enable();
90
- const account = utils.getAddress(accounts[0]);
91
- const id = await this.getChainId();
92
- const unsupported = this.isChainUnsupported(id);
101
+ const account = utils.getAddress(accounts[0]); // Switch to chain if provided
102
+
103
+ let id = await this.getChainId();
104
+ let unsupported = this.isChainUnsupported(id);
105
+
106
+ if (chainId && id !== chainId) {
107
+ const chain = await this.switchChain(chainId);
108
+ id = chain.id;
109
+ unsupported = this.isChainUnsupported(id);
110
+ }
111
+
93
112
  return {
94
113
  account,
95
114
  chain: {
@@ -211,13 +230,13 @@ class CoinbaseWalletConnector extends base.Connector {
211
230
  }
212
231
  }
213
232
 
214
- async watchAsset(_ref) {
233
+ async watchAsset(_ref3) {
215
234
  let {
216
235
  address,
217
236
  decimals = 18,
218
237
  image,
219
238
  symbol
220
- } = _ref;
239
+ } = _ref3;
221
240
  const provider = await this.getProvider();
222
241
  return await provider.request({
223
242
  method: 'wallet_watchAsset',
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var base = require('../../../dist/base-6841ebe0.cjs.prod.js');
5
+ var base = require('../../../dist/base-ffe4d8ed.cjs.prod.js');
6
6
  var ethers = require('ethers');
7
7
  var utils = require('ethers/lib/utils');
8
8
  var chains = require('../../../dist/chains-0dd661ab.cjs.prod.js');
@@ -34,8 +34,15 @@ var _provider = /*#__PURE__*/new WeakMap();
34
34
  var _isUserRejectedRequestError = /*#__PURE__*/new WeakSet();
35
35
 
36
36
  class CoinbaseWalletConnector extends base.Connector {
37
- constructor(config) {
38
- super(config);
37
+ constructor(_ref) {
38
+ let {
39
+ chains,
40
+ options
41
+ } = _ref;
42
+ super({
43
+ chains,
44
+ options
45
+ });
39
46
 
40
47
  base._classPrivateMethodInitSpec(this, _isUserRejectedRequestError);
41
48
 
@@ -77,7 +84,11 @@ class CoinbaseWalletConnector extends base.Connector {
77
84
  });
78
85
  }
79
86
 
80
- async connect() {
87
+ async connect(_ref2) {
88
+ let {
89
+ chainId
90
+ } = _ref2;
91
+
81
92
  try {
82
93
  const provider = await this.getProvider();
83
94
  provider.on('accountsChanged', this.onAccountsChanged);
@@ -87,9 +98,17 @@ class CoinbaseWalletConnector extends base.Connector {
87
98
  type: 'connecting'
88
99
  });
89
100
  const accounts = await provider.enable();
90
- const account = utils.getAddress(accounts[0]);
91
- const id = await this.getChainId();
92
- const unsupported = this.isChainUnsupported(id);
101
+ const account = utils.getAddress(accounts[0]); // Switch to chain if provided
102
+
103
+ let id = await this.getChainId();
104
+ let unsupported = this.isChainUnsupported(id);
105
+
106
+ if (chainId && id !== chainId) {
107
+ const chain = await this.switchChain(chainId);
108
+ id = chain.id;
109
+ unsupported = this.isChainUnsupported(id);
110
+ }
111
+
93
112
  return {
94
113
  account,
95
114
  chain: {
@@ -211,13 +230,13 @@ class CoinbaseWalletConnector extends base.Connector {
211
230
  }
212
231
  }
213
232
 
214
- async watchAsset(_ref) {
233
+ async watchAsset(_ref3) {
215
234
  let {
216
235
  address,
217
236
  decimals = 18,
218
237
  image,
219
238
  symbol
220
- } = _ref;
239
+ } = _ref3;
221
240
  const provider = await this.getProvider();
222
241
  return await provider.request({
223
242
  method: 'wallet_watchAsset',
@@ -1,4 +1,4 @@
1
- import { b as Connector, _ as _classPrivateMethodInitSpec, f as _defineProperty, g as _classPrivateFieldInitSpec, n as normalizeChainId, U as UserRejectedRequestError, j as _classPrivateFieldGet, i as _classPrivateFieldSet, c as ChainNotConfiguredError, h as _classPrivateMethodGet, A as AddChainError, e as SwitchChainError } from '../../../dist/base-41fb6637.esm.js';
1
+ import { b as Connector, _ as _classPrivateMethodInitSpec, f as _defineProperty, g as _classPrivateFieldInitSpec, n as normalizeChainId, U as UserRejectedRequestError, h as _classPrivateFieldGet, i as _classPrivateFieldSet, c as ChainNotConfiguredError, j as _classPrivateMethodGet, A as AddChainError, e as SwitchChainError } from '../../../dist/base-d69e580f.esm.js';
2
2
  import { providers } from 'ethers';
3
3
  import { getAddress, hexValue } from 'ethers/lib/utils';
4
4
  import { a as allChains } from '../../../dist/chains-a0a80d94.esm.js';
@@ -12,8 +12,15 @@ var _provider = /*#__PURE__*/new WeakMap();
12
12
  var _isUserRejectedRequestError = /*#__PURE__*/new WeakSet();
13
13
 
14
14
  class CoinbaseWalletConnector extends Connector {
15
- constructor(config) {
16
- super(config);
15
+ constructor(_ref) {
16
+ let {
17
+ chains,
18
+ options
19
+ } = _ref;
20
+ super({
21
+ chains,
22
+ options
23
+ });
17
24
 
18
25
  _classPrivateMethodInitSpec(this, _isUserRejectedRequestError);
19
26
 
@@ -55,7 +62,11 @@ class CoinbaseWalletConnector extends Connector {
55
62
  });
56
63
  }
57
64
 
58
- async connect() {
65
+ async connect(_ref2) {
66
+ let {
67
+ chainId
68
+ } = _ref2;
69
+
59
70
  try {
60
71
  const provider = await this.getProvider();
61
72
  provider.on('accountsChanged', this.onAccountsChanged);
@@ -65,9 +76,17 @@ class CoinbaseWalletConnector extends Connector {
65
76
  type: 'connecting'
66
77
  });
67
78
  const accounts = await provider.enable();
68
- const account = getAddress(accounts[0]);
69
- const id = await this.getChainId();
70
- const unsupported = this.isChainUnsupported(id);
79
+ const account = getAddress(accounts[0]); // Switch to chain if provided
80
+
81
+ let id = await this.getChainId();
82
+ let unsupported = this.isChainUnsupported(id);
83
+
84
+ if (chainId && id !== chainId) {
85
+ const chain = await this.switchChain(chainId);
86
+ id = chain.id;
87
+ unsupported = this.isChainUnsupported(id);
88
+ }
89
+
71
90
  return {
72
91
  account,
73
92
  chain: {
@@ -189,13 +208,13 @@ class CoinbaseWalletConnector extends Connector {
189
208
  }
190
209
  }
191
210
 
192
- async watchAsset(_ref) {
211
+ async watchAsset(_ref3) {
193
212
  let {
194
213
  address,
195
214
  decimals = 18,
196
215
  image,
197
216
  symbol
198
- } = _ref;
217
+ } = _ref3;
199
218
  const provider = await this.getProvider();
200
219
  return await provider.request({
201
220
  method: 'wallet_watchAsset',
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var base = require('../../../dist/base-321ac87a.cjs.dev.js');
6
- var client = require('../../../dist/client-4172f963.cjs.dev.js');
5
+ var base = require('../../../dist/base-d45bb8f9.cjs.dev.js');
6
+ var client = require('../../../dist/client-20bfac7f.cjs.dev.js');
7
7
  require('eventemitter3');
8
8
  require('../../../dist/chains-98e2e613.cjs.dev.js');
9
9
  require('../../../dist/rpcs-9c4eb960.cjs.dev.js');
@@ -22,15 +22,17 @@ class MetaMaskConnector extends client.InjectedConnector {
22
22
  constructor() {
23
23
  let {
24
24
  chains,
25
- options
25
+ options: options_
26
26
  } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
27
+ const options = {
28
+ name: 'MetaMask',
29
+ shimDisconnect: true,
30
+ shimChainChangedDisconnect: true,
31
+ ...options_
32
+ };
27
33
  super({
28
34
  chains,
29
- options: {
30
- name: 'MetaMask',
31
- shimDisconnect: true,
32
- ...options
33
- }
35
+ options
34
36
  });
35
37
 
36
38
  base._classPrivateMethodInitSpec(this, _findProvider);
@@ -2,8 +2,8 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var base = require('../../../dist/base-6841ebe0.cjs.prod.js');
6
- var client = require('../../../dist/client-a06c45f3.cjs.prod.js');
5
+ var base = require('../../../dist/base-ffe4d8ed.cjs.prod.js');
6
+ var client = require('../../../dist/client-8b124969.cjs.prod.js');
7
7
  require('eventemitter3');
8
8
  require('../../../dist/chains-0dd661ab.cjs.prod.js');
9
9
  require('../../../dist/rpcs-b3c52116.cjs.prod.js');
@@ -22,15 +22,17 @@ class MetaMaskConnector extends client.InjectedConnector {
22
22
  constructor() {
23
23
  let {
24
24
  chains,
25
- options
25
+ options: options_
26
26
  } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
27
+ const options = {
28
+ name: 'MetaMask',
29
+ shimDisconnect: true,
30
+ shimChainChangedDisconnect: true,
31
+ ...options_
32
+ };
27
33
  super({
28
34
  chains,
29
- options: {
30
- name: 'MetaMask',
31
- shimDisconnect: true,
32
- ...options
33
- }
35
+ options
34
36
  });
35
37
 
36
38
  base._classPrivateMethodInitSpec(this, _findProvider);
@@ -1,5 +1,5 @@
1
- import { _ as _classPrivateMethodInitSpec, f as _defineProperty, h as _classPrivateMethodGet, g as _classPrivateFieldInitSpec, i as _classPrivateFieldSet, j as _classPrivateFieldGet } from '../../../dist/base-41fb6637.esm.js';
2
- import { I as InjectedConnector } from '../../../dist/client-87c1ff8b.esm.js';
1
+ import { _ as _classPrivateMethodInitSpec, f as _defineProperty, j as _classPrivateMethodGet, g as _classPrivateFieldInitSpec, i as _classPrivateFieldSet, h as _classPrivateFieldGet } from '../../../dist/base-d69e580f.esm.js';
2
+ import { I as InjectedConnector } from '../../../dist/client-61f14c97.esm.js';
3
3
  import 'eventemitter3';
4
4
  import '../../../dist/chains-a0a80d94.esm.js';
5
5
  import '../../../dist/rpcs-7cfbd91c.esm.js';
@@ -18,15 +18,17 @@ class MetaMaskConnector extends InjectedConnector {
18
18
  constructor() {
19
19
  let {
20
20
  chains,
21
- options
21
+ options: options_
22
22
  } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
23
+ const options = {
24
+ name: 'MetaMask',
25
+ shimDisconnect: true,
26
+ shimChainChangedDisconnect: true,
27
+ ...options_
28
+ };
23
29
  super({
24
30
  chains,
25
- options: {
26
- name: 'MetaMask',
27
- shimDisconnect: true,
28
- ...options
29
- }
31
+ options
30
32
  });
31
33
 
32
34
  _classPrivateMethodInitSpec(this, _findProvider);
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var base = require('../../../dist/base-321ac87a.cjs.dev.js');
5
+ var base = require('../../../dist/base-d45bb8f9.cjs.dev.js');
6
6
  var utils = require('ethers/lib/utils');
7
7
  var EventEmitter = require('eventemitter3');
8
8
  var ethers = require('ethers');
@@ -19,9 +19,12 @@ var _signer = /*#__PURE__*/new WeakMap();
19
19
 
20
20
  class MockProvider extends ethers.providers.BaseProvider {
21
21
  constructor(options) {
22
- var _options$network;
22
+ var _options$chainId;
23
23
 
24
- super((_options$network = options.network) !== null && _options$network !== void 0 ? _options$network : 1);
24
+ super({
25
+ name: 'Network',
26
+ chainId: (_options$chainId = options.chainId) !== null && _options$chainId !== void 0 ? _options$chainId : 1
27
+ });
25
28
 
26
29
  base._defineProperty(this, "events", new EventEmitter__default["default"]());
27
30
 
@@ -73,7 +76,7 @@ class MockProvider extends ethers.providers.BaseProvider {
73
76
  var _classPrivateFieldGet4;
74
77
 
75
78
  if ((_classPrivateFieldGet4 = base._classPrivateFieldGet(this, _options).flags) !== null && _classPrivateFieldGet4 !== void 0 && _classPrivateFieldGet4.failSwitchChain) throw new base.UserRejectedRequestError(new Error('Failed to switch chain'));
76
- base._classPrivateFieldGet(this, _options).network = chainId;
79
+ base._classPrivateFieldGet(this, _options).chainId = chainId;
77
80
  this.network.chainId = chainId;
78
81
  this.events.emit('chainChanged', chainId);
79
82
  }
@@ -154,7 +157,12 @@ class MockConnector extends base.Connector {
154
157
  async connect() {
155
158
  var _this$options$flags;
156
159
 
157
- const provider = await this.getProvider();
160
+ let {
161
+ chainId
162
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
163
+ const provider = await this.getProvider({
164
+ chainId
165
+ });
158
166
  provider.on('accountsChanged', this.onAccountsChanged);
159
167
  provider.on('chainChanged', this.onChainChanged);
160
168
  provider.on('disconnect', this.onDisconnect);
@@ -200,7 +208,12 @@ class MockConnector extends base.Connector {
200
208
  }
201
209
 
202
210
  async getProvider() {
203
- if (!base._classPrivateFieldGet(this, _provider)) base._classPrivateFieldSet(this, _provider, new MockProvider(this.options));
211
+ let {
212
+ chainId
213
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
214
+ if (!base._classPrivateFieldGet(this, _provider) || chainId) base._classPrivateFieldSet(this, _provider, new MockProvider({ ...this.options,
215
+ chainId
216
+ }));
204
217
  return base._classPrivateFieldGet(this, _provider);
205
218
  }
206
219
 
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var base = require('../../../dist/base-6841ebe0.cjs.prod.js');
5
+ var base = require('../../../dist/base-ffe4d8ed.cjs.prod.js');
6
6
  var utils = require('ethers/lib/utils');
7
7
  var EventEmitter = require('eventemitter3');
8
8
  var ethers = require('ethers');
@@ -19,9 +19,12 @@ var _signer = /*#__PURE__*/new WeakMap();
19
19
 
20
20
  class MockProvider extends ethers.providers.BaseProvider {
21
21
  constructor(options) {
22
- var _options$network;
22
+ var _options$chainId;
23
23
 
24
- super((_options$network = options.network) !== null && _options$network !== void 0 ? _options$network : 1);
24
+ super({
25
+ name: 'Network',
26
+ chainId: (_options$chainId = options.chainId) !== null && _options$chainId !== void 0 ? _options$chainId : 1
27
+ });
25
28
 
26
29
  base._defineProperty(this, "events", new EventEmitter__default["default"]());
27
30
 
@@ -73,7 +76,7 @@ class MockProvider extends ethers.providers.BaseProvider {
73
76
  var _classPrivateFieldGet4;
74
77
 
75
78
  if ((_classPrivateFieldGet4 = base._classPrivateFieldGet(this, _options).flags) !== null && _classPrivateFieldGet4 !== void 0 && _classPrivateFieldGet4.failSwitchChain) throw new base.UserRejectedRequestError(new Error('Failed to switch chain'));
76
- base._classPrivateFieldGet(this, _options).network = chainId;
79
+ base._classPrivateFieldGet(this, _options).chainId = chainId;
77
80
  this.network.chainId = chainId;
78
81
  this.events.emit('chainChanged', chainId);
79
82
  }
@@ -154,7 +157,12 @@ class MockConnector extends base.Connector {
154
157
  async connect() {
155
158
  var _this$options$flags;
156
159
 
157
- const provider = await this.getProvider();
160
+ let {
161
+ chainId
162
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
163
+ const provider = await this.getProvider({
164
+ chainId
165
+ });
158
166
  provider.on('accountsChanged', this.onAccountsChanged);
159
167
  provider.on('chainChanged', this.onChainChanged);
160
168
  provider.on('disconnect', this.onDisconnect);
@@ -200,7 +208,12 @@ class MockConnector extends base.Connector {
200
208
  }
201
209
 
202
210
  async getProvider() {
203
- if (!base._classPrivateFieldGet(this, _provider)) base._classPrivateFieldSet(this, _provider, new MockProvider(this.options));
211
+ let {
212
+ chainId
213
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
214
+ if (!base._classPrivateFieldGet(this, _provider) || chainId) base._classPrivateFieldSet(this, _provider, new MockProvider({ ...this.options,
215
+ chainId
216
+ }));
204
217
  return base._classPrivateFieldGet(this, _provider);
205
218
  }
206
219
 
@@ -1,4 +1,4 @@
1
- import { f as _defineProperty, g as _classPrivateFieldInitSpec, i as _classPrivateFieldSet, j as _classPrivateFieldGet, U as UserRejectedRequestError, b as Connector, _ as _classPrivateMethodInitSpec, n as normalizeChainId, h as _classPrivateMethodGet } from '../../../dist/base-41fb6637.esm.js';
1
+ import { f as _defineProperty, g as _classPrivateFieldInitSpec, i as _classPrivateFieldSet, h as _classPrivateFieldGet, U as UserRejectedRequestError, b as Connector, _ as _classPrivateMethodInitSpec, n as normalizeChainId, j as _classPrivateMethodGet } from '../../../dist/base-d69e580f.esm.js';
2
2
  import { getAddress } from 'ethers/lib/utils';
3
3
  import EventEmitter from 'eventemitter3';
4
4
  import { providers } from 'ethers';
@@ -11,9 +11,12 @@ var _signer = /*#__PURE__*/new WeakMap();
11
11
 
12
12
  class MockProvider extends providers.BaseProvider {
13
13
  constructor(options) {
14
- var _options$network;
14
+ var _options$chainId;
15
15
 
16
- super((_options$network = options.network) !== null && _options$network !== void 0 ? _options$network : 1);
16
+ super({
17
+ name: 'Network',
18
+ chainId: (_options$chainId = options.chainId) !== null && _options$chainId !== void 0 ? _options$chainId : 1
19
+ });
17
20
 
18
21
  _defineProperty(this, "events", new EventEmitter());
19
22
 
@@ -65,7 +68,7 @@ class MockProvider extends providers.BaseProvider {
65
68
  var _classPrivateFieldGet4;
66
69
 
67
70
  if ((_classPrivateFieldGet4 = _classPrivateFieldGet(this, _options).flags) !== null && _classPrivateFieldGet4 !== void 0 && _classPrivateFieldGet4.failSwitchChain) throw new UserRejectedRequestError(new Error('Failed to switch chain'));
68
- _classPrivateFieldGet(this, _options).network = chainId;
71
+ _classPrivateFieldGet(this, _options).chainId = chainId;
69
72
  this.network.chainId = chainId;
70
73
  this.events.emit('chainChanged', chainId);
71
74
  }
@@ -146,7 +149,12 @@ class MockConnector extends Connector {
146
149
  async connect() {
147
150
  var _this$options$flags;
148
151
 
149
- const provider = await this.getProvider();
152
+ let {
153
+ chainId
154
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
155
+ const provider = await this.getProvider({
156
+ chainId
157
+ });
150
158
  provider.on('accountsChanged', this.onAccountsChanged);
151
159
  provider.on('chainChanged', this.onChainChanged);
152
160
  provider.on('disconnect', this.onDisconnect);
@@ -192,7 +200,12 @@ class MockConnector extends Connector {
192
200
  }
193
201
 
194
202
  async getProvider() {
195
- if (!_classPrivateFieldGet(this, _provider)) _classPrivateFieldSet(this, _provider, new MockProvider(this.options));
203
+ let {
204
+ chainId
205
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
206
+ if (!_classPrivateFieldGet(this, _provider) || chainId) _classPrivateFieldSet(this, _provider, new MockProvider({ ...this.options,
207
+ chainId
208
+ }));
196
209
  return _classPrivateFieldGet(this, _provider);
197
210
  }
198
211
 
@@ -2,11 +2,14 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var base = require('../../../dist/base-321ac87a.cjs.dev.js');
5
+ var base = require('../../../dist/base-d45bb8f9.cjs.dev.js');
6
6
  var ethers = require('ethers');
7
7
  var utils = require('ethers/lib/utils');
8
+ var client = require('../../../dist/client-20bfac7f.cjs.dev.js');
8
9
  var chains = require('../../../dist/chains-98e2e613.cjs.dev.js');
9
10
  require('eventemitter3');
11
+ require('zustand/vanilla');
12
+ require('zustand/middleware');
10
13
  require('../../../dist/rpcs-9c4eb960.cjs.dev.js');
11
14
 
12
15
  function _interopNamespace(e) {
@@ -80,10 +83,24 @@ class WalletConnectConnector extends base.Connector {
80
83
  }
81
84
 
82
85
  async connect() {
86
+ let {
87
+ chainId
88
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
89
+
83
90
  try {
84
91
  var _provider$connector$p, _provider$connector, _provider$connector$p2;
85
92
 
86
- const provider = await this.getProvider(true);
93
+ let targetChainId = chainId;
94
+
95
+ if (!targetChainId) {
96
+ const lastUsedChainId = client.getClient().lastUsedChainId;
97
+ if (lastUsedChainId && !this.isChainUnsupported(lastUsedChainId)) targetChainId = lastUsedChainId;
98
+ }
99
+
100
+ const provider = await this.getProvider({
101
+ chainId: targetChainId,
102
+ create: true
103
+ });
87
104
  provider.on('accountsChanged', this.onAccountsChanged);
88
105
  provider.on('chainChanged', this.onChainChanged);
89
106
  provider.on('disconnect', this.onDisconnect); // Defer message to the next tick to ensure wallet connect data (provided by `.enable()`) is available
@@ -135,11 +152,17 @@ class WalletConnectConnector extends base.Connector {
135
152
  return chainId;
136
153
  }
137
154
 
138
- async getProvider(create) {
155
+ async getProvider() {
156
+ var _this$options;
157
+
158
+ let {
159
+ chainId = ((_this$options = this.options) === null || _this$options === void 0 ? void 0 : _this$options.chainId) || this.chains[0].id,
160
+ create = false
161
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
162
+
139
163
  if (!base._classPrivateFieldGet(this, _provider) || create) {
140
- var _this$options, _this$options2, _this$options3;
164
+ var _this$options2, _this$options3;
141
165
 
142
- const chainId = ((_this$options = this.options) === null || _this$options === void 0 ? void 0 : _this$options.chainId) || this.chains[0].id;
143
166
  const rpc = !((_this$options2 = this.options) !== null && _this$options2 !== void 0 && _this$options2.infuraId) ? this.chains.reduce((rpc, chain) => ({ ...rpc,
144
167
  [chain.id]: chain.rpcUrls.default
145
168
  }), {}) : {};
@@ -2,11 +2,14 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- var base = require('../../../dist/base-6841ebe0.cjs.prod.js');
5
+ var base = require('../../../dist/base-ffe4d8ed.cjs.prod.js');
6
6
  var ethers = require('ethers');
7
7
  var utils = require('ethers/lib/utils');
8
+ var client = require('../../../dist/client-8b124969.cjs.prod.js');
8
9
  var chains = require('../../../dist/chains-0dd661ab.cjs.prod.js');
9
10
  require('eventemitter3');
11
+ require('zustand/vanilla');
12
+ require('zustand/middleware');
10
13
  require('../../../dist/rpcs-b3c52116.cjs.prod.js');
11
14
 
12
15
  function _interopNamespace(e) {
@@ -80,10 +83,24 @@ class WalletConnectConnector extends base.Connector {
80
83
  }
81
84
 
82
85
  async connect() {
86
+ let {
87
+ chainId
88
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
89
+
83
90
  try {
84
91
  var _provider$connector$p, _provider$connector, _provider$connector$p2;
85
92
 
86
- const provider = await this.getProvider(true);
93
+ let targetChainId = chainId;
94
+
95
+ if (!targetChainId) {
96
+ const lastUsedChainId = client.getClient().lastUsedChainId;
97
+ if (lastUsedChainId && !this.isChainUnsupported(lastUsedChainId)) targetChainId = lastUsedChainId;
98
+ }
99
+
100
+ const provider = await this.getProvider({
101
+ chainId: targetChainId,
102
+ create: true
103
+ });
87
104
  provider.on('accountsChanged', this.onAccountsChanged);
88
105
  provider.on('chainChanged', this.onChainChanged);
89
106
  provider.on('disconnect', this.onDisconnect); // Defer message to the next tick to ensure wallet connect data (provided by `.enable()`) is available
@@ -135,11 +152,17 @@ class WalletConnectConnector extends base.Connector {
135
152
  return chainId;
136
153
  }
137
154
 
138
- async getProvider(create) {
155
+ async getProvider() {
156
+ var _this$options;
157
+
158
+ let {
159
+ chainId = ((_this$options = this.options) === null || _this$options === void 0 ? void 0 : _this$options.chainId) || this.chains[0].id,
160
+ create = false
161
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
162
+
139
163
  if (!base._classPrivateFieldGet(this, _provider) || create) {
140
- var _this$options, _this$options2, _this$options3;
164
+ var _this$options2, _this$options3;
141
165
 
142
- const chainId = ((_this$options = this.options) === null || _this$options === void 0 ? void 0 : _this$options.chainId) || this.chains[0].id;
143
166
  const rpc = !((_this$options2 = this.options) !== null && _this$options2 !== void 0 && _this$options2.infuraId) ? this.chains.reduce((rpc, chain) => ({ ...rpc,
144
167
  [chain.id]: chain.rpcUrls.default
145
168
  }), {}) : {};