@metamask/assets-controllers 28.0.0 → 29.0.0

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 (88) hide show
  1. package/CHANGELOG.md +23 -1
  2. package/dist/AssetsContractController.js +6 -6
  3. package/dist/AssetsContractController.mjs +5 -5
  4. package/dist/NftController.js +3 -3
  5. package/dist/NftController.mjs +2 -2
  6. package/dist/NftDetectionController.js +2 -2
  7. package/dist/NftDetectionController.mjs +1 -1
  8. package/dist/Standards/ERC20Standard.js +3 -3
  9. package/dist/Standards/ERC20Standard.mjs +2 -2
  10. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.js +3 -3
  11. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.mjs +2 -2
  12. package/dist/Standards/NftStandards/ERC721/ERC721Standard.js +3 -3
  13. package/dist/Standards/NftStandards/ERC721/ERC721Standard.mjs +2 -2
  14. package/dist/TokenDetectionController.js +3 -3
  15. package/dist/TokenDetectionController.mjs +2 -2
  16. package/dist/TokenListController.js +4 -4
  17. package/dist/TokenListController.mjs +3 -3
  18. package/dist/TokenRatesController.js +3 -3
  19. package/dist/TokenRatesController.mjs +2 -2
  20. package/dist/TokensController.js +6 -6
  21. package/dist/TokensController.mjs +5 -5
  22. package/dist/assetsUtil.js +2 -2
  23. package/dist/assetsUtil.mjs +1 -1
  24. package/dist/{chunk-GCWWC4X3.js → chunk-3ZHN4GFT.js} +5 -5
  25. package/dist/{chunk-RDWXY4OF.mjs → chunk-5MRF7YPD.mjs} +12 -5
  26. package/dist/chunk-5MRF7YPD.mjs.map +1 -0
  27. package/dist/{chunk-ZM42FNAQ.mjs → chunk-6XOM7KOQ.mjs} +5 -5
  28. package/dist/{chunk-KDMDWUVX.mjs → chunk-ASFD56OL.mjs} +9 -5
  29. package/dist/chunk-ASFD56OL.mjs.map +1 -0
  30. package/dist/{chunk-BM7EPTR6.js → chunk-BO2WZDUM.js} +3 -3
  31. package/dist/{chunk-CNICDMRI.mjs → chunk-D3PCUDTX.mjs} +2 -2
  32. package/dist/{chunk-Q6TLNHYC.js → chunk-DEQZ35QE.js} +7 -7
  33. package/dist/{chunk-QVSSEGA5.js → chunk-I53XGBU3.js} +5 -5
  34. package/dist/{chunk-RUPB4ELK.js → chunk-IOQX3VTD.js} +4 -4
  35. package/dist/{chunk-UNKIHWZH.js → chunk-KM3J4DO6.js} +4 -4
  36. package/dist/{chunk-KS4MOA2T.mjs → chunk-LLYYJY7H.mjs} +2 -2
  37. package/dist/{chunk-D6BDJYSK.js → chunk-LS6R3HQL.js} +8 -1
  38. package/dist/chunk-LS6R3HQL.js.map +1 -0
  39. package/dist/{chunk-IURNPMBB.mjs → chunk-NXGX7LZJ.mjs} +2 -2
  40. package/dist/{chunk-TGKUZNML.js → chunk-OBOWNEJU.js} +4 -4
  41. package/dist/{chunk-D3N35ABH.js → chunk-OHSQRYVL.js} +3 -3
  42. package/dist/{chunk-NHX4QGOD.mjs → chunk-OWTCG2N3.mjs} +2 -2
  43. package/dist/{chunk-C4JDCQG2.js → chunk-QHU4H6HP.js} +15 -8
  44. package/dist/chunk-QHU4H6HP.js.map +1 -0
  45. package/dist/{chunk-QQAG6ECS.mjs → chunk-RUE635TV.mjs} +3 -3
  46. package/dist/{chunk-4PAJC7WC.mjs → chunk-S6CZP74C.mjs} +2 -2
  47. package/dist/{chunk-N5H5KDJZ.mjs → chunk-S7UA2DU7.mjs} +2 -2
  48. package/dist/{chunk-E2SLNUD4.js → chunk-SOK5YX7I.js} +11 -11
  49. package/dist/{chunk-AC5HGIHS.mjs → chunk-V46CHMOU.mjs} +2 -2
  50. package/dist/{chunk-JEGLHDNA.js → chunk-X2MMIBYW.js} +9 -5
  51. package/dist/chunk-X2MMIBYW.js.map +1 -0
  52. package/dist/{chunk-ZPAX2HLQ.mjs → chunk-X5PLVMOQ.mjs} +8 -1
  53. package/dist/chunk-X5PLVMOQ.mjs.map +1 -0
  54. package/dist/index.js +13 -13
  55. package/dist/index.mjs +12 -12
  56. package/dist/token-service.js +3 -3
  57. package/dist/token-service.mjs +2 -2
  58. package/dist/tsconfig.build.tsbuildinfo +1 -1
  59. package/dist/types/AssetsContractController.d.ts.map +1 -1
  60. package/dist/types/NftDetectionController.d.ts +5 -1
  61. package/dist/types/NftDetectionController.d.ts.map +1 -1
  62. package/dist/types/assetsUtil.d.ts +9 -2
  63. package/dist/types/assetsUtil.d.ts.map +1 -1
  64. package/package.json +11 -11
  65. package/dist/chunk-C4JDCQG2.js.map +0 -1
  66. package/dist/chunk-D6BDJYSK.js.map +0 -1
  67. package/dist/chunk-JEGLHDNA.js.map +0 -1
  68. package/dist/chunk-KDMDWUVX.mjs.map +0 -1
  69. package/dist/chunk-RDWXY4OF.mjs.map +0 -1
  70. package/dist/chunk-ZPAX2HLQ.mjs.map +0 -1
  71. /package/dist/{chunk-GCWWC4X3.js.map → chunk-3ZHN4GFT.js.map} +0 -0
  72. /package/dist/{chunk-ZM42FNAQ.mjs.map → chunk-6XOM7KOQ.mjs.map} +0 -0
  73. /package/dist/{chunk-BM7EPTR6.js.map → chunk-BO2WZDUM.js.map} +0 -0
  74. /package/dist/{chunk-CNICDMRI.mjs.map → chunk-D3PCUDTX.mjs.map} +0 -0
  75. /package/dist/{chunk-Q6TLNHYC.js.map → chunk-DEQZ35QE.js.map} +0 -0
  76. /package/dist/{chunk-QVSSEGA5.js.map → chunk-I53XGBU3.js.map} +0 -0
  77. /package/dist/{chunk-RUPB4ELK.js.map → chunk-IOQX3VTD.js.map} +0 -0
  78. /package/dist/{chunk-UNKIHWZH.js.map → chunk-KM3J4DO6.js.map} +0 -0
  79. /package/dist/{chunk-KS4MOA2T.mjs.map → chunk-LLYYJY7H.mjs.map} +0 -0
  80. /package/dist/{chunk-IURNPMBB.mjs.map → chunk-NXGX7LZJ.mjs.map} +0 -0
  81. /package/dist/{chunk-TGKUZNML.js.map → chunk-OBOWNEJU.js.map} +0 -0
  82. /package/dist/{chunk-D3N35ABH.js.map → chunk-OHSQRYVL.js.map} +0 -0
  83. /package/dist/{chunk-NHX4QGOD.mjs.map → chunk-OWTCG2N3.mjs.map} +0 -0
  84. /package/dist/{chunk-QQAG6ECS.mjs.map → chunk-RUE635TV.mjs.map} +0 -0
  85. /package/dist/{chunk-4PAJC7WC.mjs.map → chunk-S6CZP74C.mjs.map} +0 -0
  86. /package/dist/{chunk-N5H5KDJZ.mjs.map → chunk-S7UA2DU7.mjs.map} +0 -0
  87. /package/dist/{chunk-E2SLNUD4.js.map → chunk-SOK5YX7I.js.map} +0 -0
  88. /package/dist/{chunk-AC5HGIHS.mjs.map → chunk-V46CHMOU.mjs.map} +0 -0
package/CHANGELOG.md CHANGED
@@ -7,6 +7,27 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [29.0.0]
11
+
12
+ ### Added
13
+
14
+ - Add token detection on 7 more networks ([#4184](https://github.com/MetaMask/core/pull/4184))
15
+ - New supported networks are: cronos, celo, gnosis, fantom, polygon_zkevm, moonbeam, and moonriver
16
+
17
+ ### Changed
18
+
19
+ - **BREAKING** Changed `NftDetectionController` constructor `options` argument ([#4178](https://github.com/MetaMask/core/pull/4178))
20
+ - Added `options.disabled` and `options.selectedAddress` properties
21
+ - **BREAKING** Bump `@metamask/keyring-controller` peer dependency to ^16.0.0 ([#4234](https://github.com/MetaMask/core/pull/4234))
22
+ - **BREAKING** Bump `@metamask/accounts-controller` peer dependency to ^14.0.0 ([#4234](https://github.com/MetaMask/core/pull/4234))
23
+ - **BREAKING** Bump `@metamask/preferences-controller` peer dependency to ^11.0.0 ([#4234](https://github.com/MetaMask/core/pull/4234))
24
+ - Bump `@metamask/keyring-api` to `^6.0.0` ([#4193](https://github.com/MetaMask/core/pull/4193))
25
+ - Lower number of tokens returned by API calls ([#4207](https://github.com/MetaMask/core/pull/4207))
26
+ - Limit changed from `200` to `50`
27
+ - Bump `@metamask/base-controller` to `^5.0.2` ([#4232](https://github.com/MetaMask/core/pull/4232))
28
+ - Bump `@metamask/approval-controller` to `^6.0.2` ([#4234](https://github.com/MetaMask/core/pull/4234))
29
+ - Bump `@metamask/polling-controller` to `^6.0.2` ([#4234](https://github.com/MetaMask/core/pull/4234))
30
+
10
31
  ## [28.0.0]
11
32
 
12
33
  ### Added
@@ -752,7 +773,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
752
773
 
753
774
  - Use Ethers for AssetsContractController ([#845](https://github.com/MetaMask/core/pull/845))
754
775
 
755
- [Unreleased]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@28.0.0...HEAD
776
+ [Unreleased]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@29.0.0...HEAD
777
+ [29.0.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@28.0.0...@metamask/assets-controllers@29.0.0
756
778
  [28.0.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@27.2.0...@metamask/assets-controllers@28.0.0
757
779
  [27.2.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@27.1.0...@metamask/assets-controllers@27.2.0
758
780
  [27.1.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@27.0.1...@metamask/assets-controllers@27.1.0
@@ -3,16 +3,16 @@
3
3
 
4
4
 
5
5
 
6
- var _chunkC4JDCQG2js = require('./chunk-C4JDCQG2.js');
7
- require('./chunk-TGKUZNML.js');
8
- require('./chunk-GCWWC4X3.js');
9
- require('./chunk-BM7EPTR6.js');
10
- require('./chunk-D6BDJYSK.js');
6
+ var _chunkQHU4H6HPjs = require('./chunk-QHU4H6HP.js');
7
+ require('./chunk-OBOWNEJU.js');
8
+ require('./chunk-3ZHN4GFT.js');
9
+ require('./chunk-BO2WZDUM.js');
10
+ require('./chunk-LS6R3HQL.js');
11
11
  require('./chunk-Z4BLTVTB.js');
12
12
 
13
13
 
14
14
 
15
15
 
16
16
 
17
- exports.AssetsContractController = _chunkC4JDCQG2js.AssetsContractController; exports.MISSING_PROVIDER_ERROR = _chunkC4JDCQG2js.MISSING_PROVIDER_ERROR; exports.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = _chunkC4JDCQG2js.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID; exports.default = _chunkC4JDCQG2js.AssetsContractController_default;
17
+ exports.AssetsContractController = _chunkQHU4H6HPjs.AssetsContractController; exports.MISSING_PROVIDER_ERROR = _chunkQHU4H6HPjs.MISSING_PROVIDER_ERROR; exports.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = _chunkQHU4H6HPjs.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID; exports.default = _chunkQHU4H6HPjs.AssetsContractController_default;
18
18
  //# sourceMappingURL=AssetsContractController.js.map
@@ -3,11 +3,11 @@ import {
3
3
  AssetsContractController_default,
4
4
  MISSING_PROVIDER_ERROR,
5
5
  SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID
6
- } from "./chunk-RDWXY4OF.mjs";
7
- import "./chunk-AC5HGIHS.mjs";
8
- import "./chunk-N5H5KDJZ.mjs";
9
- import "./chunk-KS4MOA2T.mjs";
10
- import "./chunk-ZPAX2HLQ.mjs";
6
+ } from "./chunk-5MRF7YPD.mjs";
7
+ import "./chunk-V46CHMOU.mjs";
8
+ import "./chunk-S7UA2DU7.mjs";
9
+ import "./chunk-LLYYJY7H.mjs";
10
+ import "./chunk-X5PLVMOQ.mjs";
11
11
  import "./chunk-XUI43LEZ.mjs";
12
12
  export {
13
13
  AssetsContractController,
@@ -2,13 +2,13 @@
2
2
 
3
3
 
4
4
 
5
- var _chunkUNKIHWZHjs = require('./chunk-UNKIHWZH.js');
5
+ var _chunkKM3J4DO6js = require('./chunk-KM3J4DO6.js');
6
6
  require('./chunk-RGHTNZQ6.js');
7
- require('./chunk-D6BDJYSK.js');
7
+ require('./chunk-LS6R3HQL.js');
8
8
  require('./chunk-Z4BLTVTB.js');
9
9
 
10
10
 
11
11
 
12
12
 
13
- exports.NftController = _chunkUNKIHWZHjs.NftController; exports.default = _chunkUNKIHWZHjs.NftController_default; exports.getDefaultNftState = _chunkUNKIHWZHjs.getDefaultNftState;
13
+ exports.NftController = _chunkKM3J4DO6js.NftController; exports.default = _chunkKM3J4DO6js.NftController_default; exports.getDefaultNftState = _chunkKM3J4DO6js.getDefaultNftState;
14
14
  //# sourceMappingURL=NftController.js.map
@@ -2,9 +2,9 @@ import {
2
2
  NftController,
3
3
  NftController_default,
4
4
  getDefaultNftState
5
- } from "./chunk-4PAJC7WC.mjs";
5
+ } from "./chunk-S6CZP74C.mjs";
6
6
  import "./chunk-CP3HC7AQ.mjs";
7
- import "./chunk-ZPAX2HLQ.mjs";
7
+ import "./chunk-X5PLVMOQ.mjs";
8
8
  import "./chunk-XUI43LEZ.mjs";
9
9
  export {
10
10
  NftController,
@@ -2,12 +2,12 @@
2
2
 
3
3
 
4
4
 
5
- var _chunkJEGLHDNAjs = require('./chunk-JEGLHDNA.js');
5
+ var _chunkX2MMIBYWjs = require('./chunk-X2MMIBYW.js');
6
6
  require('./chunk-RGHTNZQ6.js');
7
7
  require('./chunk-Z4BLTVTB.js');
8
8
 
9
9
 
10
10
 
11
11
 
12
- exports.BlockaidResultType = _chunkJEGLHDNAjs.BlockaidResultType; exports.NftDetectionController = _chunkJEGLHDNAjs.NftDetectionController; exports.default = _chunkJEGLHDNAjs.NftDetectionController_default;
12
+ exports.BlockaidResultType = _chunkX2MMIBYWjs.BlockaidResultType; exports.NftDetectionController = _chunkX2MMIBYWjs.NftDetectionController; exports.default = _chunkX2MMIBYWjs.NftDetectionController_default;
13
13
  //# sourceMappingURL=NftDetectionController.js.map
@@ -2,7 +2,7 @@ import {
2
2
  BlockaidResultType,
3
3
  NftDetectionController,
4
4
  NftDetectionController_default
5
- } from "./chunk-KDMDWUVX.mjs";
5
+ } from "./chunk-ASFD56OL.mjs";
6
6
  import "./chunk-CP3HC7AQ.mjs";
7
7
  import "./chunk-XUI43LEZ.mjs";
8
8
  export {
@@ -1,9 +1,9 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkBM7EPTR6js = require('../chunk-BM7EPTR6.js');
4
- require('../chunk-D6BDJYSK.js');
3
+ var _chunkBO2WZDUMjs = require('../chunk-BO2WZDUM.js');
4
+ require('../chunk-LS6R3HQL.js');
5
5
  require('../chunk-Z4BLTVTB.js');
6
6
 
7
7
 
8
- exports.ERC20Standard = _chunkBM7EPTR6js.ERC20Standard;
8
+ exports.ERC20Standard = _chunkBO2WZDUMjs.ERC20Standard;
9
9
  //# sourceMappingURL=ERC20Standard.js.map
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  ERC20Standard
3
- } from "../chunk-KS4MOA2T.mjs";
4
- import "../chunk-ZPAX2HLQ.mjs";
3
+ } from "../chunk-LLYYJY7H.mjs";
4
+ import "../chunk-X5PLVMOQ.mjs";
5
5
  import "../chunk-XUI43LEZ.mjs";
6
6
  export {
7
7
  ERC20Standard
@@ -1,9 +1,9 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkGCWWC4X3js = require('../../../chunk-GCWWC4X3.js');
4
- require('../../../chunk-D6BDJYSK.js');
3
+ var _chunk3ZHN4GFTjs = require('../../../chunk-3ZHN4GFT.js');
4
+ require('../../../chunk-LS6R3HQL.js');
5
5
  require('../../../chunk-Z4BLTVTB.js');
6
6
 
7
7
 
8
- exports.ERC1155Standard = _chunkGCWWC4X3js.ERC1155Standard;
8
+ exports.ERC1155Standard = _chunk3ZHN4GFTjs.ERC1155Standard;
9
9
  //# sourceMappingURL=ERC1155Standard.js.map
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  ERC1155Standard
3
- } from "../../../chunk-N5H5KDJZ.mjs";
4
- import "../../../chunk-ZPAX2HLQ.mjs";
3
+ } from "../../../chunk-S7UA2DU7.mjs";
4
+ import "../../../chunk-X5PLVMOQ.mjs";
5
5
  import "../../../chunk-XUI43LEZ.mjs";
6
6
  export {
7
7
  ERC1155Standard
@@ -1,9 +1,9 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkTGKUZNMLjs = require('../../../chunk-TGKUZNML.js');
4
- require('../../../chunk-D6BDJYSK.js');
3
+ var _chunkOBOWNEJUjs = require('../../../chunk-OBOWNEJU.js');
4
+ require('../../../chunk-LS6R3HQL.js');
5
5
  require('../../../chunk-Z4BLTVTB.js');
6
6
 
7
7
 
8
- exports.ERC721Standard = _chunkTGKUZNMLjs.ERC721Standard;
8
+ exports.ERC721Standard = _chunkOBOWNEJUjs.ERC721Standard;
9
9
  //# sourceMappingURL=ERC721Standard.js.map
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  ERC721Standard
3
- } from "../../../chunk-AC5HGIHS.mjs";
4
- import "../../../chunk-ZPAX2HLQ.mjs";
3
+ } from "../../../chunk-V46CHMOU.mjs";
4
+ import "../../../chunk-X5PLVMOQ.mjs";
5
5
  import "../../../chunk-XUI43LEZ.mjs";
6
6
  export {
7
7
  ERC721Standard
@@ -4,8 +4,8 @@
4
4
 
5
5
 
6
6
 
7
- var _chunkQVSSEGA5js = require('./chunk-QVSSEGA5.js');
8
- require('./chunk-D6BDJYSK.js');
7
+ var _chunkI53XGBU3js = require('./chunk-I53XGBU3.js');
8
+ require('./chunk-LS6R3HQL.js');
9
9
  require('./chunk-Z4BLTVTB.js');
10
10
 
11
11
 
@@ -13,5 +13,5 @@ require('./chunk-Z4BLTVTB.js');
13
13
 
14
14
 
15
15
 
16
- exports.STATIC_MAINNET_TOKEN_LIST = _chunkQVSSEGA5js.STATIC_MAINNET_TOKEN_LIST; exports.TokenDetectionController = _chunkQVSSEGA5js.TokenDetectionController; exports.controllerName = _chunkQVSSEGA5js.controllerName; exports.default = _chunkQVSSEGA5js.TokenDetectionController_default; exports.isEqualCaseInsensitive = _chunkQVSSEGA5js.isEqualCaseInsensitive;
16
+ exports.STATIC_MAINNET_TOKEN_LIST = _chunkI53XGBU3js.STATIC_MAINNET_TOKEN_LIST; exports.TokenDetectionController = _chunkI53XGBU3js.TokenDetectionController; exports.controllerName = _chunkI53XGBU3js.controllerName; exports.default = _chunkI53XGBU3js.TokenDetectionController_default; exports.isEqualCaseInsensitive = _chunkI53XGBU3js.isEqualCaseInsensitive;
17
17
  //# sourceMappingURL=TokenDetectionController.js.map
@@ -4,8 +4,8 @@ import {
4
4
  TokenDetectionController_default,
5
5
  controllerName,
6
6
  isEqualCaseInsensitive
7
- } from "./chunk-CNICDMRI.mjs";
8
- import "./chunk-ZPAX2HLQ.mjs";
7
+ } from "./chunk-D3PCUDTX.mjs";
8
+ import "./chunk-X5PLVMOQ.mjs";
9
9
  import "./chunk-XUI43LEZ.mjs";
10
10
  export {
11
11
  STATIC_MAINNET_TOKEN_LIST,
@@ -2,13 +2,13 @@
2
2
 
3
3
 
4
4
 
5
- var _chunkQ6TLNHYCjs = require('./chunk-Q6TLNHYC.js');
6
- require('./chunk-D3N35ABH.js');
7
- require('./chunk-D6BDJYSK.js');
5
+ var _chunkDEQZ35QEjs = require('./chunk-DEQZ35QE.js');
6
+ require('./chunk-OHSQRYVL.js');
7
+ require('./chunk-LS6R3HQL.js');
8
8
  require('./chunk-Z4BLTVTB.js');
9
9
 
10
10
 
11
11
 
12
12
 
13
- exports.TokenListController = _chunkQ6TLNHYCjs.TokenListController; exports.default = _chunkQ6TLNHYCjs.TokenListController_default; exports.getDefaultTokenListState = _chunkQ6TLNHYCjs.getDefaultTokenListState;
13
+ exports.TokenListController = _chunkDEQZ35QEjs.TokenListController; exports.default = _chunkDEQZ35QEjs.TokenListController_default; exports.getDefaultTokenListState = _chunkDEQZ35QEjs.getDefaultTokenListState;
14
14
  //# sourceMappingURL=TokenListController.js.map
@@ -2,9 +2,9 @@ import {
2
2
  TokenListController,
3
3
  TokenListController_default,
4
4
  getDefaultTokenListState
5
- } from "./chunk-QQAG6ECS.mjs";
6
- import "./chunk-IURNPMBB.mjs";
7
- import "./chunk-ZPAX2HLQ.mjs";
5
+ } from "./chunk-RUE635TV.mjs";
6
+ import "./chunk-NXGX7LZJ.mjs";
7
+ import "./chunk-X5PLVMOQ.mjs";
8
8
  import "./chunk-XUI43LEZ.mjs";
9
9
  export {
10
10
  TokenListController,
@@ -1,12 +1,12 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
3
 
4
- var _chunkRUPB4ELKjs = require('./chunk-RUPB4ELK.js');
4
+ var _chunkIOQX3VTDjs = require('./chunk-IOQX3VTD.js');
5
5
  require('./chunk-DYH5P3VY.js');
6
- require('./chunk-D6BDJYSK.js');
6
+ require('./chunk-LS6R3HQL.js');
7
7
  require('./chunk-Z4BLTVTB.js');
8
8
 
9
9
 
10
10
 
11
- exports.TokenRatesController = _chunkRUPB4ELKjs.TokenRatesController; exports.default = _chunkRUPB4ELKjs.TokenRatesController_default;
11
+ exports.TokenRatesController = _chunkIOQX3VTDjs.TokenRatesController; exports.default = _chunkIOQX3VTDjs.TokenRatesController_default;
12
12
  //# sourceMappingURL=TokenRatesController.js.map
@@ -1,9 +1,9 @@
1
1
  import {
2
2
  TokenRatesController,
3
3
  TokenRatesController_default
4
- } from "./chunk-NHX4QGOD.mjs";
4
+ } from "./chunk-OWTCG2N3.mjs";
5
5
  import "./chunk-PWZE6KJV.mjs";
6
- import "./chunk-ZPAX2HLQ.mjs";
6
+ import "./chunk-X5PLVMOQ.mjs";
7
7
  import "./chunk-XUI43LEZ.mjs";
8
8
  export {
9
9
  TokenRatesController,
@@ -2,15 +2,15 @@
2
2
 
3
3
 
4
4
 
5
- var _chunkE2SLNUD4js = require('./chunk-E2SLNUD4.js');
6
- require('./chunk-GCWWC4X3.js');
7
- require('./chunk-BM7EPTR6.js');
8
- require('./chunk-D3N35ABH.js');
9
- require('./chunk-D6BDJYSK.js');
5
+ var _chunkSOK5YX7Ijs = require('./chunk-SOK5YX7I.js');
6
+ require('./chunk-3ZHN4GFT.js');
7
+ require('./chunk-BO2WZDUM.js');
8
+ require('./chunk-OHSQRYVL.js');
9
+ require('./chunk-LS6R3HQL.js');
10
10
  require('./chunk-Z4BLTVTB.js');
11
11
 
12
12
 
13
13
 
14
14
 
15
- exports.TokensController = _chunkE2SLNUD4js.TokensController; exports.default = _chunkE2SLNUD4js.TokensController_default; exports.getDefaultTokensState = _chunkE2SLNUD4js.getDefaultTokensState;
15
+ exports.TokensController = _chunkSOK5YX7Ijs.TokensController; exports.default = _chunkSOK5YX7Ijs.TokensController_default; exports.getDefaultTokensState = _chunkSOK5YX7Ijs.getDefaultTokensState;
16
16
  //# sourceMappingURL=TokensController.js.map
@@ -2,11 +2,11 @@ import {
2
2
  TokensController,
3
3
  TokensController_default,
4
4
  getDefaultTokensState
5
- } from "./chunk-ZM42FNAQ.mjs";
6
- import "./chunk-N5H5KDJZ.mjs";
7
- import "./chunk-KS4MOA2T.mjs";
8
- import "./chunk-IURNPMBB.mjs";
9
- import "./chunk-ZPAX2HLQ.mjs";
5
+ } from "./chunk-6XOM7KOQ.mjs";
6
+ import "./chunk-S7UA2DU7.mjs";
7
+ import "./chunk-LLYYJY7H.mjs";
8
+ import "./chunk-NXGX7LZJ.mjs";
9
+ import "./chunk-X5PLVMOQ.mjs";
10
10
  import "./chunk-XUI43LEZ.mjs";
11
11
  export {
12
12
  TokensController,
@@ -14,7 +14,7 @@
14
14
 
15
15
 
16
16
 
17
- var _chunkD6BDJYSKjs = require('./chunk-D6BDJYSK.js');
17
+ var _chunkLS6R3HQLjs = require('./chunk-LS6R3HQL.js');
18
18
  require('./chunk-Z4BLTVTB.js');
19
19
 
20
20
 
@@ -32,5 +32,5 @@ require('./chunk-Z4BLTVTB.js');
32
32
 
33
33
 
34
34
 
35
- exports.SupportedTokenDetectionNetworks = _chunkD6BDJYSKjs.SupportedTokenDetectionNetworks; exports.TOKEN_PRICES_BATCH_SIZE = _chunkD6BDJYSKjs.TOKEN_PRICES_BATCH_SIZE; exports.addUrlProtocolPrefix = _chunkD6BDJYSKjs.addUrlProtocolPrefix; exports.compareNftMetadata = _chunkD6BDJYSKjs.compareNftMetadata; exports.divideIntoBatches = _chunkD6BDJYSKjs.divideIntoBatches; exports.ethersBigNumberToBN = _chunkD6BDJYSKjs.ethersBigNumberToBN; exports.fetchTokenContractExchangeRates = _chunkD6BDJYSKjs.fetchTokenContractExchangeRates; exports.formatAggregatorNames = _chunkD6BDJYSKjs.formatAggregatorNames; exports.formatIconUrlWithProxy = _chunkD6BDJYSKjs.formatIconUrlWithProxy; exports.getFormattedIpfsUrl = _chunkD6BDJYSKjs.getFormattedIpfsUrl; exports.getIpfsCIDv1AndPath = _chunkD6BDJYSKjs.getIpfsCIDv1AndPath; exports.isTokenDetectionSupportedForNetwork = _chunkD6BDJYSKjs.isTokenDetectionSupportedForNetwork; exports.isTokenListSupportedForNetwork = _chunkD6BDJYSKjs.isTokenListSupportedForNetwork; exports.reduceInBatchesSerially = _chunkD6BDJYSKjs.reduceInBatchesSerially; exports.removeIpfsProtocolPrefix = _chunkD6BDJYSKjs.removeIpfsProtocolPrefix;
35
+ exports.SupportedTokenDetectionNetworks = _chunkLS6R3HQLjs.SupportedTokenDetectionNetworks; exports.TOKEN_PRICES_BATCH_SIZE = _chunkLS6R3HQLjs.TOKEN_PRICES_BATCH_SIZE; exports.addUrlProtocolPrefix = _chunkLS6R3HQLjs.addUrlProtocolPrefix; exports.compareNftMetadata = _chunkLS6R3HQLjs.compareNftMetadata; exports.divideIntoBatches = _chunkLS6R3HQLjs.divideIntoBatches; exports.ethersBigNumberToBN = _chunkLS6R3HQLjs.ethersBigNumberToBN; exports.fetchTokenContractExchangeRates = _chunkLS6R3HQLjs.fetchTokenContractExchangeRates; exports.formatAggregatorNames = _chunkLS6R3HQLjs.formatAggregatorNames; exports.formatIconUrlWithProxy = _chunkLS6R3HQLjs.formatIconUrlWithProxy; exports.getFormattedIpfsUrl = _chunkLS6R3HQLjs.getFormattedIpfsUrl; exports.getIpfsCIDv1AndPath = _chunkLS6R3HQLjs.getIpfsCIDv1AndPath; exports.isTokenDetectionSupportedForNetwork = _chunkLS6R3HQLjs.isTokenDetectionSupportedForNetwork; exports.isTokenListSupportedForNetwork = _chunkLS6R3HQLjs.isTokenListSupportedForNetwork; exports.reduceInBatchesSerially = _chunkLS6R3HQLjs.reduceInBatchesSerially; exports.removeIpfsProtocolPrefix = _chunkLS6R3HQLjs.removeIpfsProtocolPrefix;
36
36
  //# sourceMappingURL=assetsUtil.js.map
@@ -14,7 +14,7 @@ import {
14
14
  isTokenListSupportedForNetwork,
15
15
  reduceInBatchesSerially,
16
16
  removeIpfsProtocolPrefix
17
- } from "./chunk-ZPAX2HLQ.mjs";
17
+ } from "./chunk-X5PLVMOQ.mjs";
18
18
  import "./chunk-XUI43LEZ.mjs";
19
19
  export {
20
20
  SupportedTokenDetectionNetworks,
@@ -1,7 +1,7 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
3
 
4
- var _chunkD6BDJYSKjs = require('./chunk-D6BDJYSK.js');
4
+ var _chunkLS6R3HQLjs = require('./chunk-LS6R3HQL.js');
5
5
 
6
6
  // src/Standards/NftStandards/ERC1155/ERC1155Standard.ts
7
7
  var _contracts = require('@ethersproject/contracts');
@@ -73,7 +73,7 @@ var ERC1155Standard = class {
73
73
  async getBalanceOf(contractAddress, address, tokenId) {
74
74
  const contract = new (0, _contracts.Contract)(contractAddress, _metamaskethabis.abiERC1155, this.provider);
75
75
  const balance = await contract.balanceOf(address, tokenId);
76
- return _chunkD6BDJYSKjs.ethersBigNumberToBN.call(void 0, balance);
76
+ return _chunkLS6R3HQLjs.ethersBigNumberToBN.call(void 0, balance);
77
77
  }
78
78
  /**
79
79
  * Transfer single ERC1155 token.
@@ -184,7 +184,7 @@ var ERC1155Standard = class {
184
184
  _controllerutils.safelyExecute.call(void 0, () => this.getAssetName(address)),
185
185
  tokenId ? _controllerutils.safelyExecute.call(void 0,
186
186
  () => this.getTokenURI(address, tokenId).then(
187
- (uri) => uri.startsWith("ipfs://") ? _chunkD6BDJYSKjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, uri, true) : uri
187
+ (uri) => uri.startsWith("ipfs://") ? _chunkLS6R3HQLjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, uri, true) : uri
188
188
  )
189
189
  ) : void 0
190
190
  ]);
@@ -194,7 +194,7 @@ var ERC1155Standard = class {
194
194
  const object = await response.json();
195
195
  image = object?.image;
196
196
  if (image?.startsWith("ipfs://")) {
197
- image = _chunkD6BDJYSKjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, image, true);
197
+ image = _chunkLS6R3HQLjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, image, true);
198
198
  }
199
199
  } catch {
200
200
  }
@@ -212,4 +212,4 @@ var ERC1155Standard = class {
212
212
 
213
213
 
214
214
  exports.ERC1155Standard = ERC1155Standard;
215
- //# sourceMappingURL=chunk-GCWWC4X3.js.map
215
+ //# sourceMappingURL=chunk-3ZHN4GFT.js.map
@@ -1,12 +1,12 @@
1
1
  import {
2
2
  ERC721Standard
3
- } from "./chunk-AC5HGIHS.mjs";
3
+ } from "./chunk-V46CHMOU.mjs";
4
4
  import {
5
5
  ERC1155Standard
6
- } from "./chunk-N5H5KDJZ.mjs";
6
+ } from "./chunk-S7UA2DU7.mjs";
7
7
  import {
8
8
  ERC20Standard
9
- } from "./chunk-KS4MOA2T.mjs";
9
+ } from "./chunk-LLYYJY7H.mjs";
10
10
 
11
11
  // src/AssetsContractController.ts
12
12
  import { Contract } from "@ethersproject/contracts";
@@ -25,7 +25,14 @@ var SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = {
25
25
  ["0xa4b1" /* arbitrum */]: "0x151E24A486D7258dd7C33Fb67E4bB01919B7B32c",
26
26
  ["0xa" /* optimism */]: "0xB1c568e9C3E6bdaf755A60c7418C269eb11524FC",
27
27
  ["0x2105" /* base */]: "0x6AA75276052D96696134252587894ef5FFA520af",
28
- ["0x144" /* zksync */]: "0x458fEd3144680a5b8bcfaa0F9594aa19B4Ea2D34"
28
+ ["0x144" /* zksync */]: "0x458fEd3144680a5b8bcfaa0F9594aa19B4Ea2D34",
29
+ ["0x19" /* cronos */]: "0x768ca200f0fc702ac9ea502498c18f5eff176378",
30
+ ["0xa4ec" /* celo */]: "0x6aa75276052d96696134252587894ef5ffa520af",
31
+ ["0x64" /* gnosis */]: "0x6aa75276052d96696134252587894ef5ffa520af",
32
+ ["0xfa" /* fantom */]: "0x6aa75276052d96696134252587894ef5ffa520af",
33
+ ["0x44d" /* polygon_zkevm */]: "0x6aa75276052d96696134252587894ef5ffa520af",
34
+ ["0x504" /* moonbeam */]: "0x6aa75276052d96696134252587894ef5ffa520af",
35
+ ["0x505" /* moonriver */]: "0x6aa75276052d96696134252587894ef5ffa520af"
29
36
  };
30
37
  var MISSING_PROVIDER_ERROR = "AssetsContractController failed to set the provider correctly. A provider must be set for this method to be available";
31
38
  var AssetsContractController = class extends BaseControllerV1 {
@@ -358,4 +365,4 @@ export {
358
365
  AssetsContractController,
359
366
  AssetsContractController_default
360
367
  };
361
- //# sourceMappingURL=chunk-RDWXY4OF.mjs.map
368
+ //# sourceMappingURL=chunk-5MRF7YPD.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/AssetsContractController.ts"],"sourcesContent":["import { Contract } from '@ethersproject/contracts';\nimport { Web3Provider } from '@ethersproject/providers';\nimport type { BaseConfig, BaseState } from '@metamask/base-controller';\nimport { BaseControllerV1 } from '@metamask/base-controller';\nimport { IPFS_DEFAULT_GATEWAY_URL } from '@metamask/controller-utils';\nimport type {\n NetworkClientId,\n NetworkState,\n NetworkController,\n Provider,\n} from '@metamask/network-controller';\nimport type { PreferencesState } from '@metamask/preferences-controller';\nimport type { Hex } from '@metamask/utils';\nimport type BN from 'bn.js';\nimport abiSingleCallBalancesContract from 'single-call-balance-checker-abi';\n\nimport { SupportedTokenDetectionNetworks } from './assetsUtil';\nimport { ERC20Standard } from './Standards/ERC20Standard';\nimport { ERC1155Standard } from './Standards/NftStandards/ERC1155/ERC1155Standard';\nimport { ERC721Standard } from './Standards/NftStandards/ERC721/ERC721Standard';\n\n/**\n * Check if token detection is enabled for certain networks\n *\n * @param chainId - ChainID of network\n * @returns Whether the current network supports token detection\n */\nexport const SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID: Record<Hex, string> = {\n [SupportedTokenDetectionNetworks.mainnet]:\n '0xb1f8e55c7f64d203c1400b9d8555d050f94adf39',\n [SupportedTokenDetectionNetworks.bsc]:\n '0x2352c63A83f9Fd126af8676146721Fa00924d7e4',\n [SupportedTokenDetectionNetworks.polygon]:\n '0x2352c63A83f9Fd126af8676146721Fa00924d7e4',\n [SupportedTokenDetectionNetworks.avax]:\n '0xD023D153a0DFa485130ECFdE2FAA7e612EF94818',\n [SupportedTokenDetectionNetworks.aurora]:\n '0x1286415D333855237f89Df27D388127181448538',\n [SupportedTokenDetectionNetworks.linea_goerli]:\n '0x10dAd7Ca3921471f616db788D9300DC97Db01783',\n [SupportedTokenDetectionNetworks.linea_mainnet]:\n '0xF62e6a41561b3650a69Bb03199C735e3E3328c0D',\n [SupportedTokenDetectionNetworks.arbitrum]:\n '0x151E24A486D7258dd7C33Fb67E4bB01919B7B32c',\n [SupportedTokenDetectionNetworks.optimism]:\n '0xB1c568e9C3E6bdaf755A60c7418C269eb11524FC',\n [SupportedTokenDetectionNetworks.base]:\n '0x6AA75276052D96696134252587894ef5FFA520af',\n [SupportedTokenDetectionNetworks.zksync]:\n '0x458fEd3144680a5b8bcfaa0F9594aa19B4Ea2D34',\n [SupportedTokenDetectionNetworks.cronos]:\n '0x768ca200f0fc702ac9ea502498c18f5eff176378',\n [SupportedTokenDetectionNetworks.celo]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.gnosis]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.fantom]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.polygon_zkevm]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.moonbeam]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n [SupportedTokenDetectionNetworks.moonriver]:\n '0x6aa75276052d96696134252587894ef5ffa520af',\n};\n\nexport const MISSING_PROVIDER_ERROR =\n 'AssetsContractController failed to set the provider correctly. A provider must be set for this method to be available';\n\n/**\n * @type AssetsContractConfig\n *\n * Assets Contract controller configuration\n * @property provider - Provider used to create a new web3 instance\n */\n// This interface was created before this ESLint rule was added.\n// Convert to a `type` in a future major version.\n// eslint-disable-next-line @typescript-eslint/consistent-type-definitions\nexport interface AssetsContractConfig extends BaseConfig {\n provider: Provider | undefined;\n ipfsGateway: string;\n chainId: Hex;\n}\n\n/**\n * @type BalanceMap\n *\n * Key value object containing the balance for each tokenAddress\n * @property [tokenAddress] - Address of the token\n */\n// This interface was created before this ESLint rule was added.\n// Convert to a `type` in a future major version.\n// eslint-disable-next-line @typescript-eslint/consistent-type-definitions\nexport interface BalanceMap {\n [tokenAddress: string]: BN;\n}\n\n/**\n * Controller that interacts with contracts on mainnet through web3\n */\nexport class AssetsContractController extends BaseControllerV1<\n AssetsContractConfig,\n BaseState\n> {\n private _provider?: Provider;\n\n /**\n * Name of this controller used during composition\n */\n override name = 'AssetsContractController';\n\n private readonly getNetworkClientById: NetworkController['getNetworkClientById'];\n\n /**\n * Creates a AssetsContractController instance.\n *\n * @param options - The controller options.\n * @param options.chainId - The chain ID of the current network.\n * @param options.onPreferencesStateChange - Allows subscribing to preference controller state changes.\n * @param options.onNetworkDidChange - Allows subscribing to network controller networkDidChange events.\n * @param options.getNetworkClientById - Gets the network client with the given id from the NetworkController.\n * @param config - Initial options used to configure this controller.\n * @param state - Initial state to set on this controller.\n */\n constructor(\n {\n chainId: initialChainId,\n onPreferencesStateChange,\n onNetworkDidChange,\n getNetworkClientById,\n }: {\n chainId: Hex;\n onPreferencesStateChange: (\n listener: (preferencesState: PreferencesState) => void,\n ) => void;\n onNetworkDidChange: (\n listener: (networkState: NetworkState) => void,\n ) => void;\n getNetworkClientById: NetworkController['getNetworkClientById'];\n },\n config?: Partial<AssetsContractConfig>,\n state?: Partial<BaseState>,\n ) {\n super(config, state);\n this.defaultConfig = {\n provider: undefined,\n ipfsGateway: IPFS_DEFAULT_GATEWAY_URL,\n chainId: initialChainId,\n };\n this.initialize();\n this.getNetworkClientById = getNetworkClientById;\n\n onPreferencesStateChange(({ ipfsGateway }) => {\n this.configure({ ipfsGateway });\n });\n\n onNetworkDidChange((networkState) => {\n if (this.config.chainId !== networkState.providerConfig.chainId) {\n this.configure({\n chainId: networkState.providerConfig.chainId,\n });\n }\n });\n }\n\n /**\n * Sets a new provider.\n *\n * TODO: Replace this wth a method.\n *\n * @property provider - Provider used to create a new underlying Web3 instance\n */\n set provider(provider: Provider) {\n this._provider = provider;\n }\n\n get provider() {\n throw new Error('Property only used for setting');\n }\n\n /**\n * Get the relevant provider instance.\n *\n * @param networkClientId - Network Client ID.\n * @returns Web3Provider instance.\n */\n getProvider(networkClientId?: NetworkClientId): Web3Provider {\n const provider = networkClientId\n ? this.getNetworkClientById(networkClientId).provider\n : this._provider;\n\n if (provider === undefined) {\n throw new Error(MISSING_PROVIDER_ERROR);\n }\n\n // @ts-expect-error TODO: remove this annotation once the `Eip1193Provider` class is released\n return new Web3Provider(provider);\n }\n\n /**\n * Get the relevant chain ID.\n *\n * @param networkClientId - Network Client ID used to get the provider.\n * @returns Hex chain ID.\n */\n getChainId(networkClientId?: NetworkClientId): Hex {\n return networkClientId\n ? this.getNetworkClientById(networkClientId).configuration.chainId\n : this.config.chainId;\n }\n\n /**\n * Get a ERC20Standard instance using the relevant provider instance.\n *\n * @param networkClientId - Network Client ID used to get the provider.\n * @returns ERC20Standard instance.\n */\n getERC20Standard(networkClientId?: NetworkClientId): ERC20Standard {\n const provider = this.getProvider(networkClientId);\n return new ERC20Standard(provider);\n }\n\n /**\n * Get a ERC721Standard instance using the relevant provider instance.\n *\n * @param networkClientId - Network Client ID used to get the provider.\n * @returns ERC721Standard instance.\n */\n getERC721Standard(networkClientId?: NetworkClientId): ERC721Standard {\n const provider = this.getProvider(networkClientId);\n return new ERC721Standard(provider);\n }\n\n /**\n * Get a ERC1155Standard instance using the relevant provider instance.\n *\n * @param networkClientId - Network Client ID used to get the provider.\n * @returns ERC1155Standard instance.\n */\n getERC1155Standard(networkClientId?: NetworkClientId): ERC1155Standard {\n const provider = this.getProvider(networkClientId);\n return new ERC1155Standard(provider);\n }\n\n /**\n * Get balance or count for current account on specific asset contract.\n *\n * @param address - Asset ERC20 contract address.\n * @param selectedAddress - Current account public address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to BN object containing balance for current account on specific asset contract.\n */\n async getERC20BalanceOf(\n address: string,\n selectedAddress: string,\n networkClientId?: NetworkClientId,\n ): Promise<BN> {\n const erc20Standard = this.getERC20Standard(networkClientId);\n return erc20Standard.getBalanceOf(address, selectedAddress);\n }\n\n /**\n * Query for the decimals for a given ERC20 asset.\n *\n * @param address - ERC20 asset contract address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'decimals'.\n */\n async getERC20TokenDecimals(\n address: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc20Standard = this.getERC20Standard(networkClientId);\n return erc20Standard.getTokenDecimals(address);\n }\n\n /**\n * Query for the name for a given ERC20 asset.\n *\n * @param address - ERC20 asset contract address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'decimals'.\n */\n async getERC20TokenName(\n address: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc20Standard = this.getERC20Standard(networkClientId);\n return erc20Standard.getTokenName(address);\n }\n\n /**\n * Enumerate assets assigned to an owner.\n *\n * @param address - ERC721 asset contract address.\n * @param selectedAddress - Current account public address.\n * @param index - An NFT counter less than `balanceOf(selectedAddress)`.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to token identifier for the 'index'th asset assigned to 'selectedAddress'.\n */\n getERC721NftTokenId(\n address: string,\n selectedAddress: string,\n index: number,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getNftTokenId(address, selectedAddress, index);\n }\n\n /**\n * Enumerate assets assigned to an owner.\n *\n * @param tokenAddress - ERC721 asset contract address.\n * @param userAddress - Current account public address.\n * @param tokenId - ERC721 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to an object containing the token standard and a set of details which depend on which standard the token supports.\n */\n async getTokenStandardAndDetails(\n tokenAddress: string,\n userAddress?: string,\n tokenId?: string,\n networkClientId?: NetworkClientId,\n ): Promise<{\n standard: string;\n tokenURI?: string | undefined;\n symbol?: string | undefined;\n name?: string | undefined;\n decimals?: string | undefined;\n balance?: BN | undefined;\n }> {\n // Asserts provider is available\n this.getProvider(networkClientId);\n\n const { ipfsGateway } = this.config;\n\n // ERC721\n try {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return {\n ...(await erc721Standard.getDetails(\n tokenAddress,\n ipfsGateway,\n tokenId,\n )),\n };\n } catch {\n // Ignore\n }\n\n // ERC1155\n try {\n const erc1155Standard = this.getERC1155Standard(networkClientId);\n return {\n ...(await erc1155Standard.getDetails(\n tokenAddress,\n ipfsGateway,\n tokenId,\n )),\n };\n } catch {\n // Ignore\n }\n\n // ERC20\n try {\n const erc20Standard = this.getERC20Standard(networkClientId);\n return {\n ...(await erc20Standard.getDetails(tokenAddress, userAddress)),\n };\n } catch {\n // Ignore\n }\n\n throw new Error('Unable to determine contract standard');\n }\n\n /**\n * Query for tokenURI for a given ERC721 asset.\n *\n * @param address - ERC721 asset contract address.\n * @param tokenId - ERC721 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'tokenURI'.\n */\n async getERC721TokenURI(\n address: string,\n tokenId: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getTokenURI(address, tokenId);\n }\n\n /**\n * Query for name for a given asset.\n *\n * @param address - ERC721 or ERC20 asset contract address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'name'.\n */\n async getERC721AssetName(\n address: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getAssetName(address);\n }\n\n /**\n * Query for symbol for a given asset.\n *\n * @param address - ERC721 or ERC20 asset contract address.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'symbol'.\n */\n async getERC721AssetSymbol(\n address: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getAssetSymbol(address);\n }\n\n /**\n * Query for owner for a given ERC721 asset.\n *\n * @param address - ERC721 asset contract address.\n * @param tokenId - ERC721 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the owner address.\n */\n async getERC721OwnerOf(\n address: string,\n tokenId: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc721Standard = this.getERC721Standard(networkClientId);\n return erc721Standard.getOwnerOf(address, tokenId);\n }\n\n /**\n * Query for tokenURI for a given asset.\n *\n * @param address - ERC1155 asset contract address.\n * @param tokenId - ERC1155 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'tokenURI'.\n */\n async getERC1155TokenURI(\n address: string,\n tokenId: string,\n networkClientId?: NetworkClientId,\n ): Promise<string> {\n const erc1155Standard = this.getERC1155Standard(networkClientId);\n return erc1155Standard.getTokenURI(address, tokenId);\n }\n\n /**\n * Query for balance of a given ERC 1155 token.\n *\n * @param userAddress - Wallet public address.\n * @param nftAddress - ERC1155 asset contract address.\n * @param nftId - ERC1155 asset identifier.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'balanceOf'.\n */\n async getERC1155BalanceOf(\n userAddress: string,\n nftAddress: string,\n nftId: string,\n networkClientId?: NetworkClientId,\n ): Promise<BN> {\n const erc1155Standard = this.getERC1155Standard(networkClientId);\n return erc1155Standard.getBalanceOf(nftAddress, userAddress, nftId);\n }\n\n /**\n * Transfer single ERC1155 token.\n *\n * @param nftAddress - ERC1155 token address.\n * @param senderAddress - ERC1155 token sender.\n * @param recipientAddress - ERC1155 token recipient.\n * @param nftId - ERC1155 token id.\n * @param qty - Quantity of tokens to be sent.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns Promise resolving to the 'transferSingle' ERC1155 token.\n */\n async transferSingleERC1155(\n nftAddress: string,\n senderAddress: string,\n recipientAddress: string,\n nftId: string,\n qty: string,\n networkClientId?: NetworkClientId,\n ): Promise<void> {\n const erc1155Standard = this.getERC1155Standard(networkClientId);\n return erc1155Standard.transferSingle(\n nftAddress,\n senderAddress,\n recipientAddress,\n nftId,\n qty,\n );\n }\n\n /**\n * Get the token balance for a list of token addresses in a single call. Only non-zero balances\n * are returned.\n *\n * @param selectedAddress - The address to check token balances for.\n * @param tokensToDetect - The token addresses to detect balances for.\n * @param networkClientId - Network Client ID to fetch the provider with.\n * @returns The list of non-zero token balances.\n */\n async getBalancesInSingleCall(\n selectedAddress: string,\n tokensToDetect: string[],\n networkClientId?: NetworkClientId,\n ) {\n const chainId = this.getChainId(networkClientId);\n const provider = this.getProvider(networkClientId);\n if (!(chainId in SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID)) {\n // Only fetch balance if contract address exists\n return {};\n }\n const contractAddress = SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID[chainId];\n\n const contract = new Contract(\n contractAddress,\n abiSingleCallBalancesContract,\n provider,\n );\n const result = await contract.balances([selectedAddress], tokensToDetect);\n const nonZeroBalances: BalanceMap = {};\n /* istanbul ignore else */\n if (result.length > 0) {\n tokensToDetect.forEach((tokenAddress, index) => {\n const balance: BN = result[index];\n /* istanbul ignore else */\n if (String(balance) !== '0') {\n nonZeroBalances[tokenAddress] = balance;\n }\n });\n }\n return nonZeroBalances;\n }\n}\n\nexport default AssetsContractController;\n"],"mappings":"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","names":[]}
@@ -1,17 +1,17 @@
1
1
  import {
2
2
  ERC1155Standard
3
- } from "./chunk-N5H5KDJZ.mjs";
3
+ } from "./chunk-S7UA2DU7.mjs";
4
4
  import {
5
5
  ERC20Standard
6
- } from "./chunk-KS4MOA2T.mjs";
6
+ } from "./chunk-LLYYJY7H.mjs";
7
7
  import {
8
8
  TOKEN_METADATA_NO_SUPPORT_ERROR,
9
9
  fetchTokenMetadata
10
- } from "./chunk-IURNPMBB.mjs";
10
+ } from "./chunk-NXGX7LZJ.mjs";
11
11
  import {
12
12
  formatAggregatorNames,
13
13
  formatIconUrlWithProxy
14
- } from "./chunk-ZPAX2HLQ.mjs";
14
+ } from "./chunk-X5PLVMOQ.mjs";
15
15
 
16
16
  // src/TokensController.ts
17
17
  import { Contract } from "@ethersproject/contracts";
@@ -701,4 +701,4 @@ export {
701
701
  TokensController,
702
702
  TokensController_default
703
703
  };
704
- //# sourceMappingURL=chunk-ZM42FNAQ.mjs.map
704
+ //# sourceMappingURL=chunk-6XOM7KOQ.mjs.map
@@ -27,6 +27,8 @@ var NftDetectionController = class extends StaticIntervalPollingControllerV1 {
27
27
  * @param options.addNft - Add an NFT.
28
28
  * @param options.getNftApi - Gets the URL to fetch an NFT from OpenSea.
29
29
  * @param options.getNftState - Gets the current state of the Assets controller.
30
+ * @param options.disabled - Represents previous value of useNftDetection. Used to detect changes of useNftDetection. Default value is true.
31
+ * @param options.selectedAddress - Represents current selected address.
30
32
  * @param options.getNetworkClientById - Gets the network client by ID, from the NetworkController.
31
33
  * @param config - Initial options used to configure this controller.
32
34
  * @param state - Initial state to set on this controller.
@@ -39,7 +41,9 @@ var NftDetectionController = class extends StaticIntervalPollingControllerV1 {
39
41
  getOpenSeaApiKey,
40
42
  addNft,
41
43
  getNftApi,
42
- getNftState
44
+ getNftState,
45
+ disabled: initialDisabled,
46
+ selectedAddress: initialSelectedAddress
43
47
  }, config, state) {
44
48
  super(config, state);
45
49
  /**
@@ -58,8 +62,8 @@ var NftDetectionController = class extends StaticIntervalPollingControllerV1 {
58
62
  this.defaultConfig = {
59
63
  interval: DEFAULT_INTERVAL,
60
64
  chainId: initialChainId,
61
- selectedAddress: "",
62
- disabled: true
65
+ selectedAddress: initialSelectedAddress,
66
+ disabled: initialDisabled
63
67
  };
64
68
  this.initialize();
65
69
  this.getNftState = getNftState;
@@ -89,7 +93,7 @@ var NftDetectionController = class extends StaticIntervalPollingControllerV1 {
89
93
  address,
90
94
  next
91
95
  }) {
92
- return `${NFT_API_BASE_URL}/users/${address}/tokens?chainIds=1&limit=200&includeTopBid=true&continuation=${next ?? ""}`;
96
+ return `${NFT_API_BASE_URL}/users/${address}/tokens?chainIds=1&limit=50&includeTopBid=true&continuation=${next ?? ""}`;
93
97
  }
94
98
  async getOwnerNfts(address) {
95
99
  let nftApiResponse;
@@ -228,4 +232,4 @@ export {
228
232
  NftDetectionController,
229
233
  NftDetectionController_default
230
234
  };
231
- //# sourceMappingURL=chunk-KDMDWUVX.mjs.map
235
+ //# sourceMappingURL=chunk-ASFD56OL.mjs.map