@metamask-previews/assets-controllers 58.0.0-preview-530f9e5 → 58.0.0-preview-f2d81961

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.
@@ -63,7 +63,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
63
63
  * @param options.state - Initial state to set on this controller.
64
64
  * @param options.messenger - The messenger.
65
65
  */
66
- constructor({ provider, state, messenger, }: {
66
+ constructor({ chainId: initialChainId, provider, state, messenger, }: {
67
67
  chainId: Hex;
68
68
  provider: Provider;
69
69
  state?: Partial<TokensControllerState>;
@@ -89,7 +89,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
89
89
  name?: string;
90
90
  image?: string;
91
91
  interactingAddress?: string;
92
- networkClientId: NetworkClientId;
92
+ networkClientId?: NetworkClientId;
93
93
  }): Promise<Token[]>;
94
94
  /**
95
95
  * Add a batch of tokens.
@@ -97,14 +97,14 @@ export declare class TokensController extends BaseController<typeof controllerNa
97
97
  * @param tokensToImport - Array of tokens to import.
98
98
  * @param networkClientId - Optional network client ID used to determine interacting chain ID.
99
99
  */
100
- addTokens(tokensToImport: Token[], networkClientId: NetworkClientId): Promise<void>;
100
+ addTokens(tokensToImport: Token[], networkClientId?: NetworkClientId): Promise<void>;
101
101
  /**
102
102
  * Ignore a batch of tokens.
103
103
  *
104
104
  * @param tokenAddressesToIgnore - Array of token addresses to ignore.
105
105
  * @param networkClientId - Optional network client ID used to determine interacting chain ID.
106
106
  */
107
- ignoreTokens(tokenAddressesToIgnore: string[], networkClientId: NetworkClientId): void;
107
+ ignoreTokens(tokenAddressesToIgnore: string[], networkClientId?: NetworkClientId): void;
108
108
  /**
109
109
  * Adds a batch of detected tokens to the stored token list.
110
110
  *
@@ -113,8 +113,8 @@ export declare class TokensController extends BaseController<typeof controllerNa
113
113
  * @param detectionDetails.selectedAddress - the account address on which the incomingDetectedTokens were detected.
114
114
  * @param detectionDetails.chainId - the chainId on which the incomingDetectedTokens were detected.
115
115
  */
116
- addDetectedTokens(incomingDetectedTokens: Token[], detectionDetails: {
117
- selectedAddress?: string;
116
+ addDetectedTokens(incomingDetectedTokens: Token[], detectionDetails?: {
117
+ selectedAddress: string;
118
118
  chainId: Hex;
119
119
  }): Promise<void>;
120
120
  /**
@@ -122,10 +122,9 @@ export declare class TokensController extends BaseController<typeof controllerNa
122
122
  * were previously added which do not yet had isERC721 field.
123
123
  *
124
124
  * @param tokenAddress - The contract address of the token requiring the isERC721 field added.
125
- * @param networkClientId - The network client ID of the network on which the token is detected.
126
125
  * @returns The new token object with the added isERC721 field.
127
126
  */
128
- updateTokenType(tokenAddress: string, networkClientId: NetworkClientId): Promise<{
127
+ updateTokenType(tokenAddress: string): Promise<{
129
128
  isERC721: any;
130
129
  address: string;
131
130
  decimals: number;
@@ -150,7 +149,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
150
149
  asset: Token;
151
150
  type: string;
152
151
  interactingAddress?: string;
153
- networkClientId: NetworkClientId;
152
+ networkClientId?: NetworkClientId;
154
153
  }): Promise<void>;
155
154
  /**
156
155
  * Removes all tokens from the ignored list.
@@ -1 +1 @@
1
- {"version":3,"file":"TokensController.d.cts","sourceRoot":"","sources":["../src/TokensController.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TokensController.d.cts","sourceRoot":"","sources":["../src/TokensController.ts"],"names":[],"mappings":"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"}
@@ -63,7 +63,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
63
63
  * @param options.state - Initial state to set on this controller.
64
64
  * @param options.messenger - The messenger.
65
65
  */
66
- constructor({ provider, state, messenger, }: {
66
+ constructor({ chainId: initialChainId, provider, state, messenger, }: {
67
67
  chainId: Hex;
68
68
  provider: Provider;
69
69
  state?: Partial<TokensControllerState>;
@@ -89,7 +89,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
89
89
  name?: string;
90
90
  image?: string;
91
91
  interactingAddress?: string;
92
- networkClientId: NetworkClientId;
92
+ networkClientId?: NetworkClientId;
93
93
  }): Promise<Token[]>;
94
94
  /**
95
95
  * Add a batch of tokens.
@@ -97,14 +97,14 @@ export declare class TokensController extends BaseController<typeof controllerNa
97
97
  * @param tokensToImport - Array of tokens to import.
98
98
  * @param networkClientId - Optional network client ID used to determine interacting chain ID.
99
99
  */
100
- addTokens(tokensToImport: Token[], networkClientId: NetworkClientId): Promise<void>;
100
+ addTokens(tokensToImport: Token[], networkClientId?: NetworkClientId): Promise<void>;
101
101
  /**
102
102
  * Ignore a batch of tokens.
103
103
  *
104
104
  * @param tokenAddressesToIgnore - Array of token addresses to ignore.
105
105
  * @param networkClientId - Optional network client ID used to determine interacting chain ID.
106
106
  */
107
- ignoreTokens(tokenAddressesToIgnore: string[], networkClientId: NetworkClientId): void;
107
+ ignoreTokens(tokenAddressesToIgnore: string[], networkClientId?: NetworkClientId): void;
108
108
  /**
109
109
  * Adds a batch of detected tokens to the stored token list.
110
110
  *
@@ -113,8 +113,8 @@ export declare class TokensController extends BaseController<typeof controllerNa
113
113
  * @param detectionDetails.selectedAddress - the account address on which the incomingDetectedTokens were detected.
114
114
  * @param detectionDetails.chainId - the chainId on which the incomingDetectedTokens were detected.
115
115
  */
116
- addDetectedTokens(incomingDetectedTokens: Token[], detectionDetails: {
117
- selectedAddress?: string;
116
+ addDetectedTokens(incomingDetectedTokens: Token[], detectionDetails?: {
117
+ selectedAddress: string;
118
118
  chainId: Hex;
119
119
  }): Promise<void>;
120
120
  /**
@@ -122,10 +122,9 @@ export declare class TokensController extends BaseController<typeof controllerNa
122
122
  * were previously added which do not yet had isERC721 field.
123
123
  *
124
124
  * @param tokenAddress - The contract address of the token requiring the isERC721 field added.
125
- * @param networkClientId - The network client ID of the network on which the token is detected.
126
125
  * @returns The new token object with the added isERC721 field.
127
126
  */
128
- updateTokenType(tokenAddress: string, networkClientId: NetworkClientId): Promise<{
127
+ updateTokenType(tokenAddress: string): Promise<{
129
128
  isERC721: any;
130
129
  address: string;
131
130
  decimals: number;
@@ -150,7 +149,7 @@ export declare class TokensController extends BaseController<typeof controllerNa
150
149
  asset: Token;
151
150
  type: string;
152
151
  interactingAddress?: string;
153
- networkClientId: NetworkClientId;
152
+ networkClientId?: NetworkClientId;
154
153
  }): Promise<void>;
155
154
  /**
156
155
  * Removes all tokens from the ignored list.
@@ -1 +1 @@
1
- {"version":3,"file":"TokensController.d.mts","sourceRoot":"","sources":["../src/TokensController.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TokensController.d.mts","sourceRoot":"","sources":["../src/TokensController.ts"],"names":[],"mappings":"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"}
@@ -9,7 +9,7 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
9
9
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
10
10
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
11
  };
12
- var _TokensController_instances, _TokensController_mutex, _TokensController_selectedAccountId, _TokensController_provider, _TokensController_abortController, _TokensController_onNetworkStateChange, _TokensController_onSelectedAccountChange, _TokensController_fetchTokenMetadata, _TokensController_detectIsERC721, _TokensController_getProvider, _TokensController_createEthersContract, _TokensController_generateRandomId, _TokensController_getNewAllTokensState, _TokensController_getAddressOrSelectedAddress, _TokensController_requestApproval, _TokensController_getSelectedAccount, _TokensController_getSelectedAddress;
12
+ var _TokensController_instances, _TokensController_mutex, _TokensController_chainId, _TokensController_selectedAccountId, _TokensController_provider, _TokensController_abortController, _TokensController_onNetworkDidChange, _TokensController_onNetworkStateChange, _TokensController_onSelectedAccountChange, _TokensController_fetchTokenMetadata, _TokensController_detectIsERC721, _TokensController_getProvider, _TokensController_createEthersContract, _TokensController_generateRandomId, _TokensController_getNewAllTokensState, _TokensController_getAddressOrSelectedAddress, _TokensController_requestApproval, _TokensController_getSelectedAccount, _TokensController_getSelectedAddress;
13
13
  function $importDefault(module) {
14
14
  if (module?.__esModule) {
15
15
  return module.default;
@@ -66,7 +66,7 @@ export class TokensController extends BaseController {
66
66
  * @param options.state - Initial state to set on this controller.
67
67
  * @param options.messenger - The messenger.
68
68
  */
69
- constructor({ provider, state, messenger, }) {
69
+ constructor({ chainId: initialChainId, provider, state, messenger, }) {
70
70
  super({
71
71
  name: controllerName,
72
72
  metadata,
@@ -78,14 +78,17 @@ export class TokensController extends BaseController {
78
78
  });
79
79
  _TokensController_instances.add(this);
80
80
  _TokensController_mutex.set(this, new Mutex());
81
+ _TokensController_chainId.set(this, void 0);
81
82
  _TokensController_selectedAccountId.set(this, void 0);
82
83
  _TokensController_provider.set(this, void 0);
83
84
  _TokensController_abortController.set(this, void 0);
85
+ __classPrivateFieldSet(this, _TokensController_chainId, initialChainId, "f");
84
86
  __classPrivateFieldSet(this, _TokensController_provider, provider, "f");
85
87
  __classPrivateFieldSet(this, _TokensController_selectedAccountId, __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAccount).call(this).id, "f");
86
88
  __classPrivateFieldSet(this, _TokensController_abortController, new AbortController(), "f");
87
89
  this.messagingSystem.registerActionHandler(`${controllerName}:addDetectedTokens`, this.addDetectedTokens.bind(this));
88
90
  this.messagingSystem.subscribe('AccountsController:selectedEvmAccountChange', __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_onSelectedAccountChange).bind(this));
91
+ this.messagingSystem.subscribe('NetworkController:networkDidChange', __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_onNetworkDidChange).bind(this));
89
92
  this.messagingSystem.subscribe('NetworkController:stateChange', __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_onNetworkStateChange).bind(this));
90
93
  this.messagingSystem.subscribe('TokenListController:stateChange', ({ tokensChainsCache }) => {
91
94
  const { allTokens } = this.state;
@@ -129,28 +132,37 @@ export class TokensController extends BaseController {
129
132
  * @returns Current token list.
130
133
  */
131
134
  async addToken({ address, symbol, decimals, name, image, interactingAddress, networkClientId, }) {
135
+ // TODO: remove this once this method is fully parameterized by chainId
136
+ const chainId = __classPrivateFieldGet(this, _TokensController_chainId, "f");
132
137
  const releaseLock = await __classPrivateFieldGet(this, _TokensController_mutex, "f").acquire();
133
138
  const { allTokens, allIgnoredTokens, allDetectedTokens } = this.state;
134
- const chainIdToUse = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
139
+ let currentChainId = chainId;
140
+ if (networkClientId) {
141
+ currentChainId = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
142
+ }
135
143
  const accountAddress = __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getAddressOrSelectedAddress).call(this, interactingAddress);
136
144
  try {
137
145
  address = toChecksumHexAddress(address);
138
- const tokens = allTokens[chainIdToUse]?.[accountAddress] || [];
139
- const ignoredTokens = allIgnoredTokens[chainIdToUse]?.[accountAddress] || [];
140
- const detectedTokens = allDetectedTokens[chainIdToUse]?.[accountAddress] || [];
146
+ const tokens = allTokens[currentChainId]?.[accountAddress] || [];
147
+ const ignoredTokens = allIgnoredTokens[currentChainId]?.[accountAddress] || [];
148
+ const detectedTokens = allDetectedTokens[currentChainId]?.[accountAddress] || [];
141
149
  const newTokens = [...tokens];
142
150
  const [isERC721, tokenMetadata] = await Promise.all([
143
151
  __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_detectIsERC721).call(this, address, networkClientId),
144
152
  // TODO parameterize the token metadata fetch by networkClientId
145
- __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_fetchTokenMetadata).call(this, address, chainIdToUse),
153
+ __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_fetchTokenMetadata).call(this, address),
146
154
  ]);
155
+ // TODO remove this once this method is fully parameterized by networkClientId
156
+ if (!networkClientId && currentChainId !== __classPrivateFieldGet(this, _TokensController_chainId, "f")) {
157
+ throw new Error('TokensController Error: Switched networks while adding token');
158
+ }
147
159
  const newEntry = {
148
160
  address,
149
161
  symbol,
150
162
  decimals,
151
163
  image: image ||
152
164
  formatIconUrlWithProxy({
153
- chainId: chainIdToUse,
165
+ chainId: currentChainId,
154
166
  tokenAddress: address,
155
167
  }),
156
168
  isERC721,
@@ -171,7 +183,7 @@ export class TokensController extends BaseController {
171
183
  newIgnoredTokens,
172
184
  newDetectedTokens,
173
185
  interactingAddress: accountAddress,
174
- interactingChainId: chainIdToUse,
186
+ interactingChainId: currentChainId,
175
187
  });
176
188
  const newState = {
177
189
  allTokens: newAllTokens,
@@ -197,7 +209,10 @@ export class TokensController extends BaseController {
197
209
  const releaseLock = await __classPrivateFieldGet(this, _TokensController_mutex, "f").acquire();
198
210
  const { allTokens, allIgnoredTokens, allDetectedTokens } = this.state;
199
211
  const importedTokensMap = {};
200
- const interactingChainId = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
212
+ let interactingChainId = __classPrivateFieldGet(this, _TokensController_chainId, "f");
213
+ if (networkClientId) {
214
+ interactingChainId = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
215
+ }
201
216
  // Used later to dedupe imported tokens
202
217
  const newTokensMap = [
203
218
  ...(allTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAccount).call(this).address] ||
@@ -224,7 +239,7 @@ export class TokensController extends BaseController {
224
239
  return formattedToken;
225
240
  });
226
241
  const newTokens = Object.values(newTokensMap);
227
- const newIgnoredTokens = allIgnoredTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)]?.filter((tokenAddress) => !newTokensMap[tokenAddress.toLowerCase()]);
242
+ const newIgnoredTokens = allIgnoredTokens[interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)]?.filter((tokenAddress) => !newTokensMap[tokenAddress.toLowerCase()]);
228
243
  const detectedTokensForGivenChain = interactingChainId
229
244
  ? allDetectedTokens?.[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)]
230
245
  : [];
@@ -252,13 +267,16 @@ export class TokensController extends BaseController {
252
267
  * @param networkClientId - Optional network client ID used to determine interacting chain ID.
253
268
  */
254
269
  ignoreTokens(tokenAddressesToIgnore, networkClientId) {
255
- const interactingChainId = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
270
+ let interactingChainId = __classPrivateFieldGet(this, _TokensController_chainId, "f");
271
+ if (networkClientId) {
272
+ interactingChainId = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
273
+ }
256
274
  const { allTokens, allDetectedTokens, allIgnoredTokens } = this.state;
257
275
  const ignoredTokensMap = {};
258
- const ignoredTokens = allIgnoredTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
276
+ const ignoredTokens = allIgnoredTokens[interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
259
277
  let newIgnoredTokens = [...ignoredTokens];
260
- const tokens = allTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
261
- const detectedTokens = allDetectedTokens[interactingChainId]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
278
+ const tokens = allTokens[interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
279
+ const detectedTokens = allDetectedTokens[interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[__classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this)] || [];
262
280
  const checksummedTokenAddresses = tokenAddressesToIgnore.map((address) => {
263
281
  const checksumAddress = toChecksumHexAddress(address);
264
282
  ignoredTokensMap[address.toLowerCase()] = true;
@@ -289,7 +307,7 @@ export class TokensController extends BaseController {
289
307
  */
290
308
  async addDetectedTokens(incomingDetectedTokens, detectionDetails) {
291
309
  const releaseLock = await __classPrivateFieldGet(this, _TokensController_mutex, "f").acquire();
292
- const { chainId } = detectionDetails;
310
+ const chainId = detectionDetails?.chainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f");
293
311
  // Previously selectedAddress could be an empty string. This is to preserve the behaviour
294
312
  const accountAddress = detectionDetails?.selectedAddress ?? __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this);
295
313
  const { allTokens, allDetectedTokens, allIgnoredTokens } = this.state;
@@ -339,9 +357,9 @@ export class TokensController extends BaseController {
339
357
  // We may be detecting tokens on a different chain/account pair than are currently configured.
340
358
  // Re-point `tokens` and `detectedTokens` to keep them referencing the current chain/account.
341
359
  const selectedAddress = __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this);
342
- newTokens = newAllTokens?.[chainId]?.[selectedAddress] || [];
360
+ newTokens = newAllTokens?.[__classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[selectedAddress] || [];
343
361
  newDetectedTokens =
344
- newAllDetectedTokens?.[chainId]?.[selectedAddress] || [];
362
+ newAllDetectedTokens?.[__classPrivateFieldGet(this, _TokensController_chainId, "f")]?.[selectedAddress] || [];
345
363
  this.update((state) => {
346
364
  state.allTokens = newAllTokens;
347
365
  state.allDetectedTokens = newAllDetectedTokens;
@@ -356,21 +374,20 @@ export class TokensController extends BaseController {
356
374
  * were previously added which do not yet had isERC721 field.
357
375
  *
358
376
  * @param tokenAddress - The contract address of the token requiring the isERC721 field added.
359
- * @param networkClientId - The network client ID of the network on which the token is detected.
360
377
  * @returns The new token object with the added isERC721 field.
361
378
  */
362
- async updateTokenType(tokenAddress, networkClientId) {
363
- const chainIdToUse = this.messagingSystem.call('NetworkController:getNetworkClientById', networkClientId).configuration.chainId;
364
- const isERC721 = await __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_detectIsERC721).call(this, tokenAddress, networkClientId);
379
+ async updateTokenType(tokenAddress) {
380
+ const isERC721 = await __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_detectIsERC721).call(this, tokenAddress);
381
+ const chainId = __classPrivateFieldGet(this, _TokensController_chainId, "f");
365
382
  const accountAddress = __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getSelectedAddress).call(this);
366
- const tokens = [...this.state.allTokens[chainIdToUse][accountAddress]];
383
+ const tokens = [...this.state.allTokens[chainId][accountAddress]];
367
384
  const tokenIndex = tokens.findIndex((token) => {
368
385
  return token.address.toLowerCase() === tokenAddress.toLowerCase();
369
386
  });
370
387
  const updatedToken = { ...tokens[tokenIndex], isERC721 };
371
388
  tokens[tokenIndex] = updatedToken;
372
389
  this.update((state) => {
373
- state.allTokens[chainIdToUse][accountAddress] = tokens;
390
+ state.allTokens[chainId][accountAddress] = tokens;
374
391
  });
375
392
  return updatedToken;
376
393
  }
@@ -494,7 +511,13 @@ export class TokensController extends BaseController {
494
511
  });
495
512
  }
496
513
  }
497
- _TokensController_mutex = new WeakMap(), _TokensController_selectedAccountId = new WeakMap(), _TokensController_provider = new WeakMap(), _TokensController_abortController = new WeakMap(), _TokensController_instances = new WeakSet(), _TokensController_onNetworkStateChange = function _TokensController_onNetworkStateChange(_, patches) {
514
+ _TokensController_mutex = new WeakMap(), _TokensController_chainId = new WeakMap(), _TokensController_selectedAccountId = new WeakMap(), _TokensController_provider = new WeakMap(), _TokensController_abortController = new WeakMap(), _TokensController_instances = new WeakSet(), _TokensController_onNetworkDidChange = function _TokensController_onNetworkDidChange({ selectedNetworkClientId }) {
515
+ const selectedNetworkClient = this.messagingSystem.call('NetworkController:getNetworkClientById', selectedNetworkClientId);
516
+ const { chainId } = selectedNetworkClient.configuration;
517
+ __classPrivateFieldGet(this, _TokensController_abortController, "f").abort();
518
+ __classPrivateFieldSet(this, _TokensController_abortController, new AbortController(), "f");
519
+ __classPrivateFieldSet(this, _TokensController_chainId, chainId, "f");
520
+ }, _TokensController_onNetworkStateChange = function _TokensController_onNetworkStateChange(_, patches) {
498
521
  // Remove state for deleted networks
499
522
  for (const patch of patches) {
500
523
  if (patch.op === 'remove' &&
@@ -514,12 +537,11 @@ _TokensController_mutex = new WeakMap(), _TokensController_selectedAccountId = n
514
537
  * Fetch metadata for a token.
515
538
  *
516
539
  * @param tokenAddress - The address of the token.
517
- * @param chainId - The chain ID of the network on which the token is detected.
518
540
  * @returns The token metadata.
519
541
  */
520
- async function _TokensController_fetchTokenMetadata(tokenAddress, chainId) {
542
+ async function _TokensController_fetchTokenMetadata(tokenAddress) {
521
543
  try {
522
- const token = await fetchTokenMetadata(chainId, tokenAddress, __classPrivateFieldGet(this, _TokensController_abortController, "f").signal);
544
+ const token = await fetchTokenMetadata(__classPrivateFieldGet(this, _TokensController_chainId, "f"), tokenAddress, __classPrivateFieldGet(this, _TokensController_abortController, "f").signal);
523
545
  return token;
524
546
  }
525
547
  catch (error) {
@@ -573,52 +595,53 @@ async function _TokensController_detectIsERC721(tokenAddress, networkClientId) {
573
595
  const { newTokens, newIgnoredTokens, newDetectedTokens, interactingAddress, interactingChainId, } = params;
574
596
  const { allTokens, allIgnoredTokens, allDetectedTokens } = this.state;
575
597
  const userAddressToAddTokens = __classPrivateFieldGet(this, _TokensController_instances, "m", _TokensController_getAddressOrSelectedAddress).call(this, interactingAddress);
598
+ const chainIdToAddTokens = interactingChainId ?? __classPrivateFieldGet(this, _TokensController_chainId, "f");
576
599
  let newAllTokens = allTokens;
577
600
  if (newTokens?.length ||
578
601
  (newTokens &&
579
602
  allTokens &&
580
- allTokens[interactingChainId] &&
581
- allTokens[interactingChainId][userAddressToAddTokens])) {
582
- const networkTokens = allTokens[interactingChainId];
603
+ allTokens[chainIdToAddTokens] &&
604
+ allTokens[chainIdToAddTokens][userAddressToAddTokens])) {
605
+ const networkTokens = allTokens[chainIdToAddTokens];
583
606
  const newNetworkTokens = {
584
607
  ...networkTokens,
585
608
  ...{ [userAddressToAddTokens]: newTokens },
586
609
  };
587
610
  newAllTokens = {
588
611
  ...allTokens,
589
- ...{ [interactingChainId]: newNetworkTokens },
612
+ ...{ [chainIdToAddTokens]: newNetworkTokens },
590
613
  };
591
614
  }
592
615
  let newAllIgnoredTokens = allIgnoredTokens;
593
616
  if (newIgnoredTokens?.length ||
594
617
  (newIgnoredTokens &&
595
618
  allIgnoredTokens &&
596
- allIgnoredTokens[interactingChainId] &&
597
- allIgnoredTokens[interactingChainId][userAddressToAddTokens])) {
598
- const networkIgnoredTokens = allIgnoredTokens[interactingChainId];
619
+ allIgnoredTokens[chainIdToAddTokens] &&
620
+ allIgnoredTokens[chainIdToAddTokens][userAddressToAddTokens])) {
621
+ const networkIgnoredTokens = allIgnoredTokens[chainIdToAddTokens];
599
622
  const newIgnoredNetworkTokens = {
600
623
  ...networkIgnoredTokens,
601
624
  ...{ [userAddressToAddTokens]: newIgnoredTokens },
602
625
  };
603
626
  newAllIgnoredTokens = {
604
627
  ...allIgnoredTokens,
605
- ...{ [interactingChainId]: newIgnoredNetworkTokens },
628
+ ...{ [chainIdToAddTokens]: newIgnoredNetworkTokens },
606
629
  };
607
630
  }
608
631
  let newAllDetectedTokens = allDetectedTokens;
609
632
  if (newDetectedTokens?.length ||
610
633
  (newDetectedTokens &&
611
634
  allDetectedTokens &&
612
- allDetectedTokens[interactingChainId] &&
613
- allDetectedTokens[interactingChainId][userAddressToAddTokens])) {
614
- const networkDetectedTokens = allDetectedTokens[interactingChainId];
635
+ allDetectedTokens[chainIdToAddTokens] &&
636
+ allDetectedTokens[chainIdToAddTokens][userAddressToAddTokens])) {
637
+ const networkDetectedTokens = allDetectedTokens[chainIdToAddTokens];
615
638
  const newDetectedNetworkTokens = {
616
639
  ...networkDetectedTokens,
617
640
  ...{ [userAddressToAddTokens]: newDetectedTokens },
618
641
  };
619
642
  newAllDetectedTokens = {
620
643
  ...allDetectedTokens,
621
- ...{ [interactingChainId]: newDetectedNetworkTokens },
644
+ ...{ [chainIdToAddTokens]: newDetectedNetworkTokens },
622
645
  };
623
646
  }
624
647
  return { newAllTokens, newAllIgnoredTokens, newAllDetectedTokens };