@metamask/assets-controllers 35.0.0 → 36.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 (89) hide show
  1. package/CHANGELOG.md +22 -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 +5 -2
  7. package/dist/NftDetectionController.mjs +4 -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 +4 -2
  23. package/dist/assetsUtil.mjs +3 -1
  24. package/dist/{chunk-VELPHITE.mjs → chunk-24HGVPDI.mjs} +7 -1
  25. package/dist/chunk-24HGVPDI.mjs.map +1 -0
  26. package/dist/{chunk-GHKGU6GK.js → chunk-2J3CVSQ5.js} +5 -5
  27. package/dist/{chunk-56O7BVZV.mjs → chunk-2YFZGRUL.mjs} +2 -2
  28. package/dist/{chunk-7OZL6IDY.js → chunk-3QLHZOXA.js} +7 -7
  29. package/dist/{chunk-LBJTMJFA.js → chunk-4U2L56TY.js} +4 -4
  30. package/dist/{chunk-47CRHAUE.mjs → chunk-5IMEJ2FS.mjs} +2 -2
  31. package/dist/{chunk-OMNBGY7O.mjs → chunk-62HDABFM.mjs} +4 -4
  32. package/dist/{chunk-JEIAMJGS.mjs → chunk-7H2V5SW4.mjs} +2 -2
  33. package/dist/{chunk-UYH6NWKB.mjs → chunk-A7VI64MA.mjs} +2 -2
  34. package/dist/{chunk-JBF4XEGR.js → chunk-B46K3T54.js} +5 -5
  35. package/dist/{chunk-6PPM4ETZ.js → chunk-DOCJ35CC.js} +3 -3
  36. package/dist/{chunk-RPQ737HL.js → chunk-DSDI75PJ.js} +4 -4
  37. package/dist/{chunk-3GGCHDRG.js → chunk-HTIZ4JKG.js} +32 -8
  38. package/dist/chunk-HTIZ4JKG.js.map +1 -0
  39. package/dist/{chunk-RIMQ5DR3.js → chunk-IJS7EZU2.js} +7 -7
  40. package/dist/{chunk-GJCTAKK5.mjs → chunk-K6DUHENW.mjs} +2 -2
  41. package/dist/{chunk-ZX5G3X74.mjs → chunk-OCV7GPA2.mjs} +31 -7
  42. package/dist/chunk-OCV7GPA2.mjs.map +1 -0
  43. package/dist/{chunk-X4RMS365.js → chunk-OJLB6FID.js} +3 -3
  44. package/dist/{chunk-2TSAUGE7.mjs → chunk-PPJTMDXC.mjs} +2 -2
  45. package/dist/{chunk-NYVA7ZTQ.js → chunk-R4HATJKU.js} +8 -2
  46. package/dist/chunk-R4HATJKU.js.map +1 -0
  47. package/dist/{chunk-2IIQTSLV.mjs → chunk-RI6LDZPC.mjs} +67 -3
  48. package/dist/chunk-RI6LDZPC.mjs.map +1 -0
  49. package/dist/{chunk-4JLB5OIJ.mjs → chunk-RXBDSHHH.mjs} +5 -5
  50. package/dist/{chunk-2NQRWANM.js → chunk-TPUVGGNO.js} +11 -11
  51. package/dist/{chunk-354SINOH.js → chunk-Z6NCPTNT.js} +67 -3
  52. package/dist/chunk-Z6NCPTNT.js.map +1 -0
  53. package/dist/{chunk-Y45HQET7.mjs → chunk-ZWZZUFO5.mjs} +3 -3
  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/NftController.d.ts +5 -3
  60. package/dist/types/NftController.d.ts.map +1 -1
  61. package/dist/types/NftDetectionController.d.ts +35 -1
  62. package/dist/types/NftDetectionController.d.ts.map +1 -1
  63. package/dist/types/assetsUtil.d.ts +7 -0
  64. package/dist/types/assetsUtil.d.ts.map +1 -1
  65. package/package.json +6 -6
  66. package/dist/chunk-2IIQTSLV.mjs.map +0 -1
  67. package/dist/chunk-354SINOH.js.map +0 -1
  68. package/dist/chunk-3GGCHDRG.js.map +0 -1
  69. package/dist/chunk-NYVA7ZTQ.js.map +0 -1
  70. package/dist/chunk-VELPHITE.mjs.map +0 -1
  71. package/dist/chunk-ZX5G3X74.mjs.map +0 -1
  72. /package/dist/{chunk-GHKGU6GK.js.map → chunk-2J3CVSQ5.js.map} +0 -0
  73. /package/dist/{chunk-56O7BVZV.mjs.map → chunk-2YFZGRUL.mjs.map} +0 -0
  74. /package/dist/{chunk-7OZL6IDY.js.map → chunk-3QLHZOXA.js.map} +0 -0
  75. /package/dist/{chunk-LBJTMJFA.js.map → chunk-4U2L56TY.js.map} +0 -0
  76. /package/dist/{chunk-47CRHAUE.mjs.map → chunk-5IMEJ2FS.mjs.map} +0 -0
  77. /package/dist/{chunk-OMNBGY7O.mjs.map → chunk-62HDABFM.mjs.map} +0 -0
  78. /package/dist/{chunk-JEIAMJGS.mjs.map → chunk-7H2V5SW4.mjs.map} +0 -0
  79. /package/dist/{chunk-UYH6NWKB.mjs.map → chunk-A7VI64MA.mjs.map} +0 -0
  80. /package/dist/{chunk-JBF4XEGR.js.map → chunk-B46K3T54.js.map} +0 -0
  81. /package/dist/{chunk-6PPM4ETZ.js.map → chunk-DOCJ35CC.js.map} +0 -0
  82. /package/dist/{chunk-RPQ737HL.js.map → chunk-DSDI75PJ.js.map} +0 -0
  83. /package/dist/{chunk-RIMQ5DR3.js.map → chunk-IJS7EZU2.js.map} +0 -0
  84. /package/dist/{chunk-GJCTAKK5.mjs.map → chunk-K6DUHENW.mjs.map} +0 -0
  85. /package/dist/{chunk-X4RMS365.js.map → chunk-OJLB6FID.js.map} +0 -0
  86. /package/dist/{chunk-2TSAUGE7.mjs.map → chunk-PPJTMDXC.mjs.map} +0 -0
  87. /package/dist/{chunk-4JLB5OIJ.mjs.map → chunk-RXBDSHHH.mjs.map} +0 -0
  88. /package/dist/{chunk-2NQRWANM.js.map → chunk-TPUVGGNO.js.map} +0 -0
  89. /package/dist/{chunk-Y45HQET7.mjs.map → chunk-ZWZZUFO5.mjs.map} +0 -0
package/CHANGELOG.md CHANGED
@@ -7,6 +7,26 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [36.0.0]
11
+
12
+ ### Added
13
+
14
+ - Add optional `topBid` property to the `NftMetadata` type. This property must be of type `TopBid`. ([#4522](https://github.com/MetaMask/core/pull/4522))
15
+ - Add optional `floorAsk` property to the `TokenCollection` type. This property must be of type `FloorAskCollection`. ([#4522](https://github.com/MetaMask/core/pull/4522))
16
+ - Add linea mainnet support to nft detection supported networks ([#4515](https://github.com/MetaMask/core/pull/4515))
17
+ - The `Collection` type is expanded to include the following 'string'-type optional properties: `contractDeployedAt`, `creator`, `ownerCount`, and an optional property `topBid` of the type `TopBid & { sourceDomain?: string; }`. ([#4443](https://github.com/MetaMask/core/pull/4443))
18
+
19
+ ### Changed
20
+
21
+ - Fetch NFT collections data from the NFT-API `Get Collections` endpoint when calling the `detectNfts` method of `NftDetectionController`, and the `updateNftMetadata` and `watchNft` methods of `NftController`. ([#4443](https://github.com/MetaMask/core/pull/4443))
22
+ - Bump `@metamask/utils` to `^9.0.0` ([#4516](https://github.com/MetaMask/core/pull/4516))
23
+ - Bump `@metamask/rpc-errors` to `^6.3.1` ([#4516](https://github.com/MetaMask/core/pull/4516))
24
+
25
+ ### Fixed
26
+
27
+ - **BREAKING:** The `attributes` property of the `NftMetadata` type must be of type `Attributes[]` ([#4522](https://github.com/MetaMask/core/pull/4522))
28
+ - The `attributes` property was added and typed as `Attributes` on `v28.0.0`.
29
+
10
30
  ## [35.0.0]
11
31
 
12
32
  ### Changed
@@ -993,7 +1013,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
993
1013
 
994
1014
  - Use Ethers for AssetsContractController ([#845](https://github.com/MetaMask/core/pull/845))
995
1015
 
996
- [Unreleased]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@35.0.0...HEAD
1016
+ [Unreleased]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@36.0.0...HEAD
1017
+ [36.0.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@35.0.0...@metamask/assets-controllers@36.0.0
997
1018
  [35.0.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@34.0.0...@metamask/assets-controllers@35.0.0
998
1019
  [34.0.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@33.0.0...@metamask/assets-controllers@34.0.0
999
1020
  [33.0.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@32.0.0...@metamask/assets-controllers@33.0.0
@@ -3,16 +3,16 @@
3
3
 
4
4
 
5
5
 
6
- var _chunkRIMQ5DR3js = require('./chunk-RIMQ5DR3.js');
7
- require('./chunk-LBJTMJFA.js');
8
- require('./chunk-6PPM4ETZ.js');
9
- require('./chunk-JBF4XEGR.js');
10
- require('./chunk-NYVA7ZTQ.js');
6
+ var _chunkIJS7EZU2js = require('./chunk-IJS7EZU2.js');
7
+ require('./chunk-4U2L56TY.js');
8
+ require('./chunk-DOCJ35CC.js');
9
+ require('./chunk-B46K3T54.js');
10
+ require('./chunk-R4HATJKU.js');
11
11
  require('./chunk-Z4BLTVTB.js');
12
12
 
13
13
 
14
14
 
15
15
 
16
16
 
17
- exports.AssetsContractController = _chunkRIMQ5DR3js.AssetsContractController; exports.MISSING_PROVIDER_ERROR = _chunkRIMQ5DR3js.MISSING_PROVIDER_ERROR; exports.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = _chunkRIMQ5DR3js.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID; exports.default = _chunkRIMQ5DR3js.AssetsContractController_default;
17
+ exports.AssetsContractController = _chunkIJS7EZU2js.AssetsContractController; exports.MISSING_PROVIDER_ERROR = _chunkIJS7EZU2js.MISSING_PROVIDER_ERROR; exports.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID = _chunkIJS7EZU2js.SINGLE_CALL_BALANCES_ADDRESS_BY_CHAINID; exports.default = _chunkIJS7EZU2js.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-OMNBGY7O.mjs";
7
- import "./chunk-JEIAMJGS.mjs";
8
- import "./chunk-56O7BVZV.mjs";
9
- import "./chunk-UYH6NWKB.mjs";
10
- import "./chunk-VELPHITE.mjs";
6
+ } from "./chunk-62HDABFM.mjs";
7
+ import "./chunk-7H2V5SW4.mjs";
8
+ import "./chunk-2YFZGRUL.mjs";
9
+ import "./chunk-A7VI64MA.mjs";
10
+ import "./chunk-24HGVPDI.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 _chunk3GGCHDRGjs = require('./chunk-3GGCHDRG.js');
5
+ var _chunkHTIZ4JKGjs = require('./chunk-HTIZ4JKG.js');
6
6
  require('./chunk-RGHTNZQ6.js');
7
- require('./chunk-NYVA7ZTQ.js');
7
+ require('./chunk-R4HATJKU.js');
8
8
  require('./chunk-Z4BLTVTB.js');
9
9
 
10
10
 
11
11
 
12
12
 
13
- exports.NftController = _chunk3GGCHDRGjs.NftController; exports.default = _chunk3GGCHDRGjs.NftController_default; exports.getDefaultNftControllerState = _chunk3GGCHDRGjs.getDefaultNftControllerState;
13
+ exports.NftController = _chunkHTIZ4JKGjs.NftController; exports.default = _chunkHTIZ4JKGjs.NftController_default; exports.getDefaultNftControllerState = _chunkHTIZ4JKGjs.getDefaultNftControllerState;
14
14
  //# sourceMappingURL=NftController.js.map
@@ -2,9 +2,9 @@ import {
2
2
  NftController,
3
3
  NftController_default,
4
4
  getDefaultNftControllerState
5
- } from "./chunk-ZX5G3X74.mjs";
5
+ } from "./chunk-OCV7GPA2.mjs";
6
6
  import "./chunk-CP3HC7AQ.mjs";
7
- import "./chunk-VELPHITE.mjs";
7
+ import "./chunk-24HGVPDI.mjs";
8
8
  import "./chunk-XUI43LEZ.mjs";
9
9
  export {
10
10
  NftController,
@@ -2,12 +2,15 @@
2
2
 
3
3
 
4
4
 
5
- var _chunk354SINOHjs = require('./chunk-354SINOH.js');
5
+
6
+ var _chunkZ6NCPTNTjs = require('./chunk-Z6NCPTNT.js');
6
7
  require('./chunk-RGHTNZQ6.js');
8
+ require('./chunk-R4HATJKU.js');
7
9
  require('./chunk-Z4BLTVTB.js');
8
10
 
9
11
 
10
12
 
11
13
 
12
- exports.BlockaidResultType = _chunk354SINOHjs.BlockaidResultType; exports.NftDetectionController = _chunk354SINOHjs.NftDetectionController; exports.default = _chunk354SINOHjs.NftDetectionController_default;
14
+
15
+ exports.BlockaidResultType = _chunkZ6NCPTNTjs.BlockaidResultType; exports.MAX_GET_COLLECTION_BATCH_SIZE = _chunkZ6NCPTNTjs.MAX_GET_COLLECTION_BATCH_SIZE; exports.NftDetectionController = _chunkZ6NCPTNTjs.NftDetectionController; exports.default = _chunkZ6NCPTNTjs.NftDetectionController_default;
13
16
  //# sourceMappingURL=NftDetectionController.js.map
@@ -1,12 +1,15 @@
1
1
  import {
2
2
  BlockaidResultType,
3
+ MAX_GET_COLLECTION_BATCH_SIZE,
3
4
  NftDetectionController,
4
5
  NftDetectionController_default
5
- } from "./chunk-2IIQTSLV.mjs";
6
+ } from "./chunk-RI6LDZPC.mjs";
6
7
  import "./chunk-CP3HC7AQ.mjs";
8
+ import "./chunk-24HGVPDI.mjs";
7
9
  import "./chunk-XUI43LEZ.mjs";
8
10
  export {
9
11
  BlockaidResultType,
12
+ MAX_GET_COLLECTION_BATCH_SIZE,
10
13
  NftDetectionController,
11
14
  NftDetectionController_default as default
12
15
  };
@@ -1,9 +1,9 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunk6PPM4ETZjs = require('../chunk-6PPM4ETZ.js');
4
- require('../chunk-NYVA7ZTQ.js');
3
+ var _chunkDOCJ35CCjs = require('../chunk-DOCJ35CC.js');
4
+ require('../chunk-R4HATJKU.js');
5
5
  require('../chunk-Z4BLTVTB.js');
6
6
 
7
7
 
8
- exports.ERC20Standard = _chunk6PPM4ETZjs.ERC20Standard;
8
+ exports.ERC20Standard = _chunkDOCJ35CCjs.ERC20Standard;
9
9
  //# sourceMappingURL=ERC20Standard.js.map
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  ERC20Standard
3
- } from "../chunk-56O7BVZV.mjs";
4
- import "../chunk-VELPHITE.mjs";
3
+ } from "../chunk-2YFZGRUL.mjs";
4
+ import "../chunk-24HGVPDI.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 _chunkJBF4XEGRjs = require('../../../chunk-JBF4XEGR.js');
4
- require('../../../chunk-NYVA7ZTQ.js');
3
+ var _chunkB46K3T54js = require('../../../chunk-B46K3T54.js');
4
+ require('../../../chunk-R4HATJKU.js');
5
5
  require('../../../chunk-Z4BLTVTB.js');
6
6
 
7
7
 
8
- exports.ERC1155Standard = _chunkJBF4XEGRjs.ERC1155Standard;
8
+ exports.ERC1155Standard = _chunkB46K3T54js.ERC1155Standard;
9
9
  //# sourceMappingURL=ERC1155Standard.js.map
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  ERC1155Standard
3
- } from "../../../chunk-UYH6NWKB.mjs";
4
- import "../../../chunk-VELPHITE.mjs";
3
+ } from "../../../chunk-A7VI64MA.mjs";
4
+ import "../../../chunk-24HGVPDI.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 _chunkLBJTMJFAjs = require('../../../chunk-LBJTMJFA.js');
4
- require('../../../chunk-NYVA7ZTQ.js');
3
+ var _chunk4U2L56TYjs = require('../../../chunk-4U2L56TY.js');
4
+ require('../../../chunk-R4HATJKU.js');
5
5
  require('../../../chunk-Z4BLTVTB.js');
6
6
 
7
7
 
8
- exports.ERC721Standard = _chunkLBJTMJFAjs.ERC721Standard;
8
+ exports.ERC721Standard = _chunk4U2L56TYjs.ERC721Standard;
9
9
  //# sourceMappingURL=ERC721Standard.js.map
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  ERC721Standard
3
- } from "../../../chunk-JEIAMJGS.mjs";
4
- import "../../../chunk-VELPHITE.mjs";
3
+ } from "../../../chunk-7H2V5SW4.mjs";
4
+ import "../../../chunk-24HGVPDI.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 _chunkGHKGU6GKjs = require('./chunk-GHKGU6GK.js');
8
- require('./chunk-NYVA7ZTQ.js');
7
+ var _chunk2J3CVSQ5js = require('./chunk-2J3CVSQ5.js');
8
+ require('./chunk-R4HATJKU.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 = _chunkGHKGU6GKjs.STATIC_MAINNET_TOKEN_LIST; exports.TokenDetectionController = _chunkGHKGU6GKjs.TokenDetectionController; exports.controllerName = _chunkGHKGU6GKjs.controllerName; exports.default = _chunkGHKGU6GKjs.TokenDetectionController_default; exports.isEqualCaseInsensitive = _chunkGHKGU6GKjs.isEqualCaseInsensitive;
16
+ exports.STATIC_MAINNET_TOKEN_LIST = _chunk2J3CVSQ5js.STATIC_MAINNET_TOKEN_LIST; exports.TokenDetectionController = _chunk2J3CVSQ5js.TokenDetectionController; exports.controllerName = _chunk2J3CVSQ5js.controllerName; exports.default = _chunk2J3CVSQ5js.TokenDetectionController_default; exports.isEqualCaseInsensitive = _chunk2J3CVSQ5js.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-2TSAUGE7.mjs";
8
- import "./chunk-VELPHITE.mjs";
7
+ } from "./chunk-PPJTMDXC.mjs";
8
+ import "./chunk-24HGVPDI.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 _chunk7OZL6IDYjs = require('./chunk-7OZL6IDY.js');
6
- require('./chunk-X4RMS365.js');
7
- require('./chunk-NYVA7ZTQ.js');
5
+ var _chunk3QLHZOXAjs = require('./chunk-3QLHZOXA.js');
6
+ require('./chunk-OJLB6FID.js');
7
+ require('./chunk-R4HATJKU.js');
8
8
  require('./chunk-Z4BLTVTB.js');
9
9
 
10
10
 
11
11
 
12
12
 
13
- exports.TokenListController = _chunk7OZL6IDYjs.TokenListController; exports.default = _chunk7OZL6IDYjs.TokenListController_default; exports.getDefaultTokenListState = _chunk7OZL6IDYjs.getDefaultTokenListState;
13
+ exports.TokenListController = _chunk3QLHZOXAjs.TokenListController; exports.default = _chunk3QLHZOXAjs.TokenListController_default; exports.getDefaultTokenListState = _chunk3QLHZOXAjs.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-Y45HQET7.mjs";
6
- import "./chunk-47CRHAUE.mjs";
7
- import "./chunk-VELPHITE.mjs";
5
+ } from "./chunk-ZWZZUFO5.mjs";
6
+ import "./chunk-5IMEJ2FS.mjs";
7
+ import "./chunk-24HGVPDI.mjs";
8
8
  import "./chunk-XUI43LEZ.mjs";
9
9
  export {
10
10
  TokenListController,
@@ -3,16 +3,16 @@
3
3
 
4
4
 
5
5
 
6
- var _chunkRPQ737HLjs = require('./chunk-RPQ737HL.js');
6
+ var _chunkDSDI75PJjs = require('./chunk-DSDI75PJ.js');
7
7
  require('./chunk-V6DNVROD.js');
8
8
  require('./chunk-7K6PSEAA.js');
9
9
  require('./chunk-ZG5MS2TO.js');
10
- require('./chunk-NYVA7ZTQ.js');
10
+ require('./chunk-R4HATJKU.js');
11
11
  require('./chunk-Z4BLTVTB.js');
12
12
 
13
13
 
14
14
 
15
15
 
16
16
 
17
- exports.TokenRatesController = _chunkRPQ737HLjs.TokenRatesController; exports.controllerName = _chunkRPQ737HLjs.controllerName; exports.default = _chunkRPQ737HLjs.TokenRatesController_default; exports.getDefaultTokenRatesControllerState = _chunkRPQ737HLjs.getDefaultTokenRatesControllerState;
17
+ exports.TokenRatesController = _chunkDSDI75PJjs.TokenRatesController; exports.controllerName = _chunkDSDI75PJjs.controllerName; exports.default = _chunkDSDI75PJjs.TokenRatesController_default; exports.getDefaultTokenRatesControllerState = _chunkDSDI75PJjs.getDefaultTokenRatesControllerState;
18
18
  //# sourceMappingURL=TokenRatesController.js.map
@@ -3,11 +3,11 @@ import {
3
3
  TokenRatesController_default,
4
4
  controllerName,
5
5
  getDefaultTokenRatesControllerState
6
- } from "./chunk-GJCTAKK5.mjs";
6
+ } from "./chunk-K6DUHENW.mjs";
7
7
  import "./chunk-XQO3EG4J.mjs";
8
8
  import "./chunk-TTH3ES66.mjs";
9
9
  import "./chunk-JTXPJ6TK.mjs";
10
- import "./chunk-VELPHITE.mjs";
10
+ import "./chunk-24HGVPDI.mjs";
11
11
  import "./chunk-XUI43LEZ.mjs";
12
12
  export {
13
13
  TokenRatesController,
@@ -2,15 +2,15 @@
2
2
 
3
3
 
4
4
 
5
- var _chunk2NQRWANMjs = require('./chunk-2NQRWANM.js');
6
- require('./chunk-6PPM4ETZ.js');
7
- require('./chunk-JBF4XEGR.js');
8
- require('./chunk-X4RMS365.js');
9
- require('./chunk-NYVA7ZTQ.js');
5
+ var _chunkTPUVGGNOjs = require('./chunk-TPUVGGNO.js');
6
+ require('./chunk-DOCJ35CC.js');
7
+ require('./chunk-B46K3T54.js');
8
+ require('./chunk-OJLB6FID.js');
9
+ require('./chunk-R4HATJKU.js');
10
10
  require('./chunk-Z4BLTVTB.js');
11
11
 
12
12
 
13
13
 
14
14
 
15
- exports.TokensController = _chunk2NQRWANMjs.TokensController; exports.default = _chunk2NQRWANMjs.TokensController_default; exports.getDefaultTokensState = _chunk2NQRWANMjs.getDefaultTokensState;
15
+ exports.TokensController = _chunkTPUVGGNOjs.TokensController; exports.default = _chunkTPUVGGNOjs.TokensController_default; exports.getDefaultTokensState = _chunkTPUVGGNOjs.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-4JLB5OIJ.mjs";
6
- import "./chunk-56O7BVZV.mjs";
7
- import "./chunk-UYH6NWKB.mjs";
8
- import "./chunk-47CRHAUE.mjs";
9
- import "./chunk-VELPHITE.mjs";
5
+ } from "./chunk-RXBDSHHH.mjs";
6
+ import "./chunk-2YFZGRUL.mjs";
7
+ import "./chunk-A7VI64MA.mjs";
8
+ import "./chunk-5IMEJ2FS.mjs";
9
+ import "./chunk-24HGVPDI.mjs";
10
10
  import "./chunk-XUI43LEZ.mjs";
11
11
  export {
12
12
  TokensController,
@@ -14,7 +14,8 @@
14
14
 
15
15
 
16
16
 
17
- var _chunkNYVA7ZTQjs = require('./chunk-NYVA7ZTQ.js');
17
+
18
+ var _chunkR4HATJKUjs = require('./chunk-R4HATJKU.js');
18
19
  require('./chunk-Z4BLTVTB.js');
19
20
 
20
21
 
@@ -32,5 +33,6 @@ require('./chunk-Z4BLTVTB.js');
32
33
 
33
34
 
34
35
 
35
- exports.SupportedTokenDetectionNetworks = _chunkNYVA7ZTQjs.SupportedTokenDetectionNetworks; exports.TOKEN_PRICES_BATCH_SIZE = _chunkNYVA7ZTQjs.TOKEN_PRICES_BATCH_SIZE; exports.addUrlProtocolPrefix = _chunkNYVA7ZTQjs.addUrlProtocolPrefix; exports.compareNftMetadata = _chunkNYVA7ZTQjs.compareNftMetadata; exports.divideIntoBatches = _chunkNYVA7ZTQjs.divideIntoBatches; exports.ethersBigNumberToBN = _chunkNYVA7ZTQjs.ethersBigNumberToBN; exports.fetchTokenContractExchangeRates = _chunkNYVA7ZTQjs.fetchTokenContractExchangeRates; exports.formatAggregatorNames = _chunkNYVA7ZTQjs.formatAggregatorNames; exports.formatIconUrlWithProxy = _chunkNYVA7ZTQjs.formatIconUrlWithProxy; exports.getFormattedIpfsUrl = _chunkNYVA7ZTQjs.getFormattedIpfsUrl; exports.getIpfsCIDv1AndPath = _chunkNYVA7ZTQjs.getIpfsCIDv1AndPath; exports.isTokenDetectionSupportedForNetwork = _chunkNYVA7ZTQjs.isTokenDetectionSupportedForNetwork; exports.isTokenListSupportedForNetwork = _chunkNYVA7ZTQjs.isTokenListSupportedForNetwork; exports.reduceInBatchesSerially = _chunkNYVA7ZTQjs.reduceInBatchesSerially; exports.removeIpfsProtocolPrefix = _chunkNYVA7ZTQjs.removeIpfsProtocolPrefix;
36
+
37
+ exports.SupportedTokenDetectionNetworks = _chunkR4HATJKUjs.SupportedTokenDetectionNetworks; exports.TOKEN_PRICES_BATCH_SIZE = _chunkR4HATJKUjs.TOKEN_PRICES_BATCH_SIZE; exports.addUrlProtocolPrefix = _chunkR4HATJKUjs.addUrlProtocolPrefix; exports.compareNftMetadata = _chunkR4HATJKUjs.compareNftMetadata; exports.divideIntoBatches = _chunkR4HATJKUjs.divideIntoBatches; exports.ethersBigNumberToBN = _chunkR4HATJKUjs.ethersBigNumberToBN; exports.fetchTokenContractExchangeRates = _chunkR4HATJKUjs.fetchTokenContractExchangeRates; exports.formatAggregatorNames = _chunkR4HATJKUjs.formatAggregatorNames; exports.formatIconUrlWithProxy = _chunkR4HATJKUjs.formatIconUrlWithProxy; exports.getFormattedIpfsUrl = _chunkR4HATJKUjs.getFormattedIpfsUrl; exports.getIpfsCIDv1AndPath = _chunkR4HATJKUjs.getIpfsCIDv1AndPath; exports.hasNewCollectionFields = _chunkR4HATJKUjs.hasNewCollectionFields; exports.isTokenDetectionSupportedForNetwork = _chunkR4HATJKUjs.isTokenDetectionSupportedForNetwork; exports.isTokenListSupportedForNetwork = _chunkR4HATJKUjs.isTokenListSupportedForNetwork; exports.reduceInBatchesSerially = _chunkR4HATJKUjs.reduceInBatchesSerially; exports.removeIpfsProtocolPrefix = _chunkR4HATJKUjs.removeIpfsProtocolPrefix;
36
38
  //# sourceMappingURL=assetsUtil.js.map
@@ -10,11 +10,12 @@ import {
10
10
  formatIconUrlWithProxy,
11
11
  getFormattedIpfsUrl,
12
12
  getIpfsCIDv1AndPath,
13
+ hasNewCollectionFields,
13
14
  isTokenDetectionSupportedForNetwork,
14
15
  isTokenListSupportedForNetwork,
15
16
  reduceInBatchesSerially,
16
17
  removeIpfsProtocolPrefix
17
- } from "./chunk-VELPHITE.mjs";
18
+ } from "./chunk-24HGVPDI.mjs";
18
19
  import "./chunk-XUI43LEZ.mjs";
19
20
  export {
20
21
  SupportedTokenDetectionNetworks,
@@ -28,6 +29,7 @@ export {
28
29
  formatIconUrlWithProxy,
29
30
  getFormattedIpfsUrl,
30
31
  getIpfsCIDv1AndPath,
32
+ hasNewCollectionFields,
31
33
  isTokenDetectionSupportedForNetwork,
32
34
  isTokenListSupportedForNetwork,
33
35
  reduceInBatchesSerially,
@@ -27,6 +27,11 @@ function compareNftMetadata(newNftMetadata, nft) {
27
27
  }, 0);
28
28
  return differentValues > 0;
29
29
  }
30
+ function hasNewCollectionFields(newNftMetadata, nft) {
31
+ const keysNewNftMetadata = Object.keys(newNftMetadata.collection ?? {});
32
+ const keysExistingNft = new Set(Object.keys(nft.collection ?? {}));
33
+ return keysNewNftMetadata.some((key) => !keysExistingNft.has(key));
34
+ }
30
35
  var aggregatorNameByKey = {
31
36
  aave: "Aave",
32
37
  bancor: "Bancor",
@@ -192,6 +197,7 @@ async function fetchTokenContractExchangeRates({
192
197
  export {
193
198
  TOKEN_PRICES_BATCH_SIZE,
194
199
  compareNftMetadata,
200
+ hasNewCollectionFields,
195
201
  formatAggregatorNames,
196
202
  formatIconUrlWithProxy,
197
203
  SupportedTokenDetectionNetworks,
@@ -206,4 +212,4 @@ export {
206
212
  reduceInBatchesSerially,
207
213
  fetchTokenContractExchangeRates
208
214
  };
209
- //# sourceMappingURL=chunk-VELPHITE.mjs.map
215
+ //# sourceMappingURL=chunk-24HGVPDI.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/assetsUtil.ts"],"sourcesContent":["import type { BigNumber } from '@ethersproject/bignumber';\nimport {\n convertHexToDecimal,\n toChecksumHexAddress,\n} from '@metamask/controller-utils';\nimport type { Hex } from '@metamask/utils';\nimport { remove0x } from '@metamask/utils';\nimport BN from 'bn.js';\nimport { CID } from 'multiformats/cid';\n\nimport type { Nft, NftMetadata } from './NftController';\nimport type { AbstractTokenPricesService } from './token-prices-service';\nimport { type ContractExchangeRates } from './TokenRatesController';\n\n/**\n * The maximum number of token addresses that should be sent to the Price API in\n * a single request.\n */\nexport const TOKEN_PRICES_BATCH_SIZE = 30;\n\n/**\n * Compares nft metadata entries to any nft entry.\n * We need this method when comparing a new fetched nft metadata, in case a entry changed to a defined value,\n * there's a need to update the nft in state.\n *\n * @param newNftMetadata - Nft metadata object.\n * @param nft - Nft object to compare with.\n * @returns Whether there are differences.\n */\nexport function compareNftMetadata(newNftMetadata: NftMetadata, nft: Nft) {\n const keys: (keyof NftMetadata)[] = [\n 'image',\n 'backgroundColor',\n 'imagePreview',\n 'imageThumbnail',\n 'imageOriginal',\n 'animation',\n 'animationOriginal',\n 'externalLink',\n 'tokenURI',\n ];\n const differentValues = keys.reduce((value, key) => {\n if (newNftMetadata[key] && newNftMetadata[key] !== nft[key]) {\n return value + 1;\n }\n return value;\n }, 0);\n return differentValues > 0;\n}\n\n/**\n * Checks whether the existing nft object has all the keys of the new incoming nft metadata object\n * @param newNftMetadata - New nft metadata object\n * @param nft - Existing nft object to compare with\n * @returns Whether the existing nft object has all the new keys from the new Nft metadata object\n */\nexport function hasNewCollectionFields(\n newNftMetadata: NftMetadata,\n nft: Nft,\n): boolean {\n const keysNewNftMetadata = Object.keys(newNftMetadata.collection ?? {});\n const keysExistingNft = new Set(Object.keys(nft.collection ?? {}));\n\n return keysNewNftMetadata.some((key) => !keysExistingNft.has(key));\n}\n\nconst aggregatorNameByKey: Record<string, string> = {\n aave: 'Aave',\n bancor: 'Bancor',\n cmc: 'CMC',\n cryptocom: 'Crypto.com',\n coinGecko: 'CoinGecko',\n oneInch: '1inch',\n paraswap: 'Paraswap',\n pmm: 'PMM',\n zapper: 'Zapper',\n zerion: 'Zerion',\n zeroEx: '0x',\n synthetix: 'Synthetix',\n yearn: 'Yearn',\n apeswap: 'ApeSwap',\n binanceDex: 'BinanceDex',\n pancakeTop100: 'PancakeTop100',\n pancakeExtended: 'PancakeExtended',\n balancer: 'Balancer',\n quickswap: 'QuickSwap',\n matcha: 'Matcha',\n pangolinDex: 'PangolinDex',\n pangolinDexStableCoin: 'PangolinDexStableCoin',\n pangolinDexAvaxBridge: 'PangolinDexAvaxBridge',\n traderJoe: 'TraderJoe',\n airswapLight: 'AirswapLight',\n kleros: 'Kleros',\n};\n\n/**\n * Formats aggregator names to presentable format.\n *\n * @param aggregators - List of token list names in camelcase.\n * @returns Formatted aggregator names.\n */\nexport const formatAggregatorNames = (aggregators: string[]) => {\n return aggregators.map(\n (key) =>\n aggregatorNameByKey[key] ||\n `${key[0].toUpperCase()}${key.substring(1, key.length)}`,\n );\n};\n\n/**\n * Format token list assets to use image proxy from Codefi.\n *\n * @param params - Object that contains chainID and tokenAddress.\n * @param params.chainId - ChainID of network in 0x-prefixed hexadecimal format.\n * @param params.tokenAddress - Address of token in mixed or lowercase.\n * @returns Formatted image url\n */\nexport const formatIconUrlWithProxy = ({\n chainId,\n tokenAddress,\n}: {\n chainId: Hex;\n tokenAddress: string;\n}) => {\n const chainIdDecimal = convertHexToDecimal(chainId).toString();\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/restrict-template-expressions\n return `https://static.cx.metamask.io/api/v1/tokenIcons/${chainIdDecimal}/${tokenAddress.toLowerCase()}.png`;\n};\n\n/**\n * Networks where token detection is supported - Values are in hex format\n */\nexport enum SupportedTokenDetectionNetworks {\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n mainnet = '0x1', // decimal: 1\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n bsc = '0x38', // decimal: 56\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n polygon = '0x89', // decimal: 137\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n avax = '0xa86a', // decimal: 43114\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n aurora = '0x4e454152', // decimal: 1313161554\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n linea_goerli = '0xe704', // decimal: 59140\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n linea_mainnet = '0xe708', // decimal: 59144\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n arbitrum = '0xa4b1', // decimal: 42161\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n optimism = '0xa', // decimal: 10\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n base = '0x2105', // decimal: 8453\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n zksync = '0x144', // decimal: 324\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n cronos = '0x19', // decimal: 25\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n celo = '0xa4ec', // decimal: 42220\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n gnosis = '0x64', // decimal: 100\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n fantom = '0xfa', // decimal: 250\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n polygon_zkevm = '0x44d', // decimal: 1101\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n moonbeam = '0x504', // decimal: 1284\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n moonriver = '0x505', // decimal: 1285\n}\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 function isTokenDetectionSupportedForNetwork(chainId: Hex): boolean {\n return Object.values<Hex>(SupportedTokenDetectionNetworks).includes(chainId);\n}\n\n/**\n * Check if token list polling is enabled for a given network.\n * Currently this method is used to support e2e testing for consumers of this package.\n *\n * @param chainId - ChainID of network\n * @returns Whether the current network supports tokenlists\n */\nexport function isTokenListSupportedForNetwork(chainId: Hex): boolean {\n return isTokenDetectionSupportedForNetwork(chainId);\n}\n\n/**\n * Removes IPFS protocol prefix from input string.\n *\n * @param ipfsUrl - An IPFS url (e.g. ipfs://{content id})\n * @returns IPFS content identifier and (possibly) path in a string\n * @throws Will throw if the url passed is not IPFS.\n */\nexport function removeIpfsProtocolPrefix(ipfsUrl: string) {\n if (ipfsUrl.startsWith('ipfs://ipfs/')) {\n return ipfsUrl.replace('ipfs://ipfs/', '');\n } else if (ipfsUrl.startsWith('ipfs://')) {\n return ipfsUrl.replace('ipfs://', '');\n }\n // this method should not be used with non-ipfs urls (i.e. startsWith('ipfs://') === true)\n throw new Error('this method should not be used with non ipfs urls');\n}\n\n/**\n * Extracts content identifier and path from an input string.\n *\n * @param ipfsUrl - An IPFS URL minus the IPFS protocol prefix\n * @returns IFPS content identifier (cid) and sub path as string.\n * @throws Will throw if the url passed is not ipfs.\n */\nexport function getIpfsCIDv1AndPath(ipfsUrl: string): {\n cid: string;\n path?: string;\n} {\n const url = removeIpfsProtocolPrefix(ipfsUrl);\n\n // check if there is a path\n // (CID is everything preceding first forward slash, path is everything after)\n const index = url.indexOf('/');\n const cid = index !== -1 ? url.substring(0, index) : url;\n const path = index !== -1 ? url.substring(index) : undefined;\n\n // We want to ensure that the CID is v1 (https://docs.ipfs.io/concepts/content-addressing/#identifier-formats)\n // because most cid v0s appear to be incompatible with IPFS subdomains\n return {\n cid: CID.parse(cid).toV1().toString(),\n path,\n };\n}\n\n/**\n * Formats URL correctly for use retrieving assets hosted on IPFS.\n *\n * @param ipfsGateway - The users preferred IPFS gateway (full URL or just host).\n * @param ipfsUrl - The IFPS URL pointed at the asset.\n * @param subdomainSupported - Boolean indicating whether the URL should be formatted with subdomains or not.\n * @returns A formatted URL, with the user's preferred IPFS gateway and format (subdomain or not), pointing to an asset hosted on IPFS.\n */\nexport function getFormattedIpfsUrl(\n ipfsGateway: string,\n ipfsUrl: string,\n subdomainSupported: boolean,\n): string {\n const { host, protocol, origin } = new URL(addUrlProtocolPrefix(ipfsGateway));\n if (subdomainSupported) {\n const { cid, path } = getIpfsCIDv1AndPath(ipfsUrl);\n return `${protocol}//${cid}.ipfs.${host}${path ?? ''}`;\n }\n const cidAndPath = removeIpfsProtocolPrefix(ipfsUrl);\n return `${origin}/ipfs/${cidAndPath}`;\n}\n\n/**\n * Adds URL protocol prefix to input URL string if missing.\n *\n * @param urlString - An IPFS URL.\n * @returns A URL with a https:// prepended.\n */\nexport function addUrlProtocolPrefix(urlString: string): string {\n if (!urlString.match(/(^http:\\/\\/)|(^https:\\/\\/)/u)) {\n return `https://${urlString}`;\n }\n return urlString;\n}\n\n/**\n * Converts an Ethers BigNumber to a BN.\n *\n * @param bigNumber - An Ethers BigNumber instance.\n * @returns A BN object.\n */\nexport function ethersBigNumberToBN(bigNumber: BigNumber): BN {\n return new BN(remove0x(bigNumber.toHexString()), 'hex');\n}\n\n/**\n * Partitions a list of values into groups that are at most `batchSize` in\n * length.\n *\n * @param values - The list of values.\n * @param args - The remaining arguments.\n * @param args.batchSize - The desired maximum number of values per batch.\n * @returns The list of batches.\n */\nexport function divideIntoBatches<Value>(\n values: Value[],\n { batchSize }: { batchSize: number },\n): Value[][] {\n const batches = [];\n for (let i = 0; i < values.length; i += batchSize) {\n batches.push(values.slice(i, i + batchSize));\n }\n return batches;\n}\n\n/**\n * Constructs an object from processing batches of the given values\n * sequentially.\n *\n * @param args - The arguments to this function.\n * @param args.values - A list of values to iterate over.\n * @param args.batchSize - The maximum number of values in each batch.\n * @param args.eachBatch - A function to call for each batch. This function is\n * similar to the function that `Array.prototype.reduce` takes, in that it\n * receives the object that is being built, each batch in the list of batches\n * and the index, and should return an updated version of the object.\n * @param args.initialResult - The initial value of the final data structure,\n * i.e., the value that will be fed into the first call of `eachBatch`.\n * @returns The built object.\n */\nexport async function reduceInBatchesSerially<\n Value,\n Result extends Record<PropertyKey, unknown>,\n>({\n values,\n batchSize,\n eachBatch,\n initialResult,\n}: {\n values: Value[];\n batchSize: number;\n eachBatch: (\n workingResult: Partial<Result>,\n batch: Value[],\n index: number,\n ) => Partial<Result> | Promise<Partial<Result>>;\n initialResult: Partial<Result>;\n}): Promise<Result> {\n const batches = divideIntoBatches(values, { batchSize });\n let workingResult = initialResult;\n for (const [index, batch] of batches.entries()) {\n workingResult = await eachBatch(workingResult, batch, index);\n }\n // There's no way around this — we have to assume that in the end, the result\n // matches the intended type.\n const finalResult = workingResult as Result;\n return finalResult;\n}\n\n/**\n * Retrieves token prices for a set of contract addresses in a specific currency and chainId.\n *\n * @param args - The arguments to function.\n * @param args.tokenPricesService - An object in charge of retrieving token prices.\n * @param args.nativeCurrency - The native currency to request price in.\n * @param args.tokenAddresses - The list of contract addresses.\n * @param args.chainId - The chainId of the tokens.\n * @returns The prices for the requested tokens.\n */\nexport async function fetchTokenContractExchangeRates({\n tokenPricesService,\n nativeCurrency,\n tokenAddresses,\n chainId,\n}: {\n tokenPricesService: AbstractTokenPricesService;\n nativeCurrency: string;\n tokenAddresses: Hex[];\n chainId: Hex;\n}): Promise<ContractExchangeRates> {\n const isChainIdSupported =\n tokenPricesService.validateChainIdSupported(chainId);\n const isCurrencySupported =\n tokenPricesService.validateCurrencySupported(nativeCurrency);\n\n if (!isChainIdSupported || !isCurrencySupported) {\n return {};\n }\n\n const tokenPricesByTokenAddress = await reduceInBatchesSerially<\n Hex,\n Awaited<ReturnType<AbstractTokenPricesService['fetchTokenPrices']>>\n >({\n values: [...tokenAddresses].sort(),\n batchSize: TOKEN_PRICES_BATCH_SIZE,\n eachBatch: async (allTokenPricesByTokenAddress, batch) => {\n const tokenPricesByTokenAddressForBatch =\n await tokenPricesService.fetchTokenPrices({\n tokenAddresses: batch,\n chainId,\n currency: nativeCurrency,\n });\n\n return {\n ...allTokenPricesByTokenAddress,\n ...tokenPricesByTokenAddressForBatch,\n };\n },\n initialResult: {},\n });\n\n return Object.entries(tokenPricesByTokenAddress).reduce(\n (obj, [tokenAddress, tokenPrice]) => {\n return {\n ...obj,\n [toChecksumHexAddress(tokenAddress)]: tokenPrice?.price,\n };\n },\n {},\n );\n}\n"],"mappings":"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","names":["SupportedTokenDetectionNetworks"]}
@@ -1,6 +1,6 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
2
2
 
3
- var _chunkNYVA7ZTQjs = require('./chunk-NYVA7ZTQ.js');
3
+ var _chunkR4HATJKUjs = require('./chunk-R4HATJKU.js');
4
4
 
5
5
 
6
6
 
@@ -99,7 +99,7 @@ var TokenDetectionController = class extends _pollingcontroller.StaticIntervalPo
99
99
  _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _networkClientId, networkClientId);
100
100
  const { useTokenDetection: defaultUseTokenDetection } = this.messagingSystem.call("PreferencesController:getState");
101
101
  _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _isDetectionEnabledFromPreferences, defaultUseTokenDetection);
102
- _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _isDetectionEnabledForNetwork, _chunkNYVA7ZTQjs.isTokenDetectionSupportedForNetwork.call(void 0, chainId));
102
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _isDetectionEnabledForNetwork, _chunkR4HATJKUjs.isTokenDetectionSupportedForNetwork.call(void 0, chainId));
103
103
  _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _getBalancesInSingleCall, getBalancesInSingleCall);
104
104
  _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _trackMetaMetricsEvent, trackMetaMetricsEvent);
105
105
  const { isUnlocked } = this.messagingSystem.call(
@@ -169,7 +169,7 @@ var TokenDetectionController = class extends _pollingcontroller.StaticIntervalPo
169
169
  const { chainId, networkClientId: selectedNetworkClientId } = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectChainIdAndNetworkClientId, getCorrectChainIdAndNetworkClientId_fn).call(this, networkClientId);
170
170
  const chainIdAgainstWhichToDetect = chainId;
171
171
  const networkClientIdAgainstWhichToDetect = selectedNetworkClientId;
172
- if (!_chunkNYVA7ZTQjs.isTokenDetectionSupportedForNetwork.call(void 0, chainIdAgainstWhichToDetect)) {
172
+ if (!_chunkR4HATJKUjs.isTokenDetectionSupportedForNetwork.call(void 0, chainIdAgainstWhichToDetect)) {
173
173
  return;
174
174
  }
175
175
  if (!_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _isDetectionEnabledFromPreferences) && chainIdAgainstWhichToDetect !== _controllerutils.ChainId.mainnet) {
@@ -260,7 +260,7 @@ registerEventListeners_fn = function() {
260
260
  async ({ selectedNetworkClientId }) => {
261
261
  const isNetworkClientIdChanged = _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _networkClientId) !== selectedNetworkClientId;
262
262
  const { chainId: newChainId } = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getCorrectChainIdAndNetworkClientId, getCorrectChainIdAndNetworkClientId_fn).call(this, selectedNetworkClientId);
263
- _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _isDetectionEnabledForNetwork, _chunkNYVA7ZTQjs.isTokenDetectionSupportedForNetwork.call(void 0, newChainId));
263
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _isDetectionEnabledForNetwork, _chunkR4HATJKUjs.isTokenDetectionSupportedForNetwork.call(void 0, newChainId));
264
264
  if (isNetworkClientIdChanged && _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _isDetectionEnabledForNetwork)) {
265
265
  _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _networkClientId, selectedNetworkClientId);
266
266
  await _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _restartTokenDetection, restartTokenDetection_fn).call(this, {
@@ -431,4 +431,4 @@ var TokenDetectionController_default = TokenDetectionController;
431
431
 
432
432
 
433
433
  exports.isEqualCaseInsensitive = isEqualCaseInsensitive; exports.STATIC_MAINNET_TOKEN_LIST = STATIC_MAINNET_TOKEN_LIST; exports.controllerName = controllerName; exports.TokenDetectionController = TokenDetectionController; exports.TokenDetectionController_default = TokenDetectionController_default;
434
- //# sourceMappingURL=chunk-GHKGU6GK.js.map
434
+ //# sourceMappingURL=chunk-2J3CVSQ5.js.map
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  ethersBigNumberToBN
3
- } from "./chunk-VELPHITE.mjs";
3
+ } from "./chunk-24HGVPDI.mjs";
4
4
 
5
5
  // src/Standards/ERC20Standard.ts
6
6
  import { toUtf8 } from "@ethereumjs/util";
@@ -112,4 +112,4 @@ var ERC20Standard = class {
112
112
  export {
113
113
  ERC20Standard
114
114
  };
115
- //# sourceMappingURL=chunk-56O7BVZV.mjs.map
115
+ //# sourceMappingURL=chunk-2YFZGRUL.mjs.map
@@ -1,11 +1,11 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkX4RMS365js = require('./chunk-X4RMS365.js');
3
+ var _chunkOJLB6FIDjs = require('./chunk-OJLB6FID.js');
4
4
 
5
5
 
6
6
 
7
7
 
8
- var _chunkNYVA7ZTQjs = require('./chunk-NYVA7ZTQ.js');
8
+ var _chunkR4HATJKUjs = require('./chunk-R4HATJKU.js');
9
9
 
10
10
 
11
11
 
@@ -99,7 +99,7 @@ var TokenListController = class extends _pollingcontroller.StaticIntervalPolling
99
99
  * Start polling for the token list.
100
100
  */
101
101
  async start() {
102
- if (!_chunkNYVA7ZTQjs.isTokenListSupportedForNetwork.call(void 0, this.chainId)) {
102
+ if (!_chunkR4HATJKUjs.isTokenListSupportedForNetwork.call(void 0, this.chainId)) {
103
103
  return;
104
104
  }
105
105
  await this.startPolling();
@@ -175,7 +175,7 @@ var TokenListController = class extends _pollingcontroller.StaticIntervalPolling
175
175
  tokenList = { ...cachedTokens };
176
176
  } else {
177
177
  const tokensFromAPI = await _controllerutils.safelyExecute.call(void 0,
178
- () => _chunkX4RMS365js.fetchTokenListByChainId.call(void 0,
178
+ () => _chunkOJLB6FIDjs.fetchTokenListByChainId.call(void 0,
179
179
  chainId,
180
180
  this.abortController.signal
181
181
  )
@@ -194,8 +194,8 @@ var TokenListController = class extends _pollingcontroller.StaticIntervalPolling
194
194
  for (const token of tokensFromAPI) {
195
195
  const formattedToken = {
196
196
  ...token,
197
- aggregators: _chunkNYVA7ZTQjs.formatAggregatorNames.call(void 0, token.aggregators),
198
- iconUrl: _chunkNYVA7ZTQjs.formatIconUrlWithProxy.call(void 0, {
197
+ aggregators: _chunkR4HATJKUjs.formatAggregatorNames.call(void 0, token.aggregators),
198
+ iconUrl: _chunkR4HATJKUjs.formatIconUrlWithProxy.call(void 0, {
199
199
  chainId,
200
200
  tokenAddress: token.address
201
201
  })
@@ -288,4 +288,4 @@ var TokenListController_default = TokenListController;
288
288
 
289
289
 
290
290
  exports.getDefaultTokenListState = getDefaultTokenListState; exports.TokenListController = TokenListController; exports.TokenListController_default = TokenListController_default;
291
- //# sourceMappingURL=chunk-7OZL6IDY.js.map
291
+ //# sourceMappingURL=chunk-3QLHZOXA.js.map
@@ -1,6 +1,6 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkNYVA7ZTQjs = require('./chunk-NYVA7ZTQ.js');
3
+ var _chunkR4HATJKUjs = require('./chunk-R4HATJKU.js');
4
4
 
5
5
  // src/Standards/NftStandards/ERC721/ERC721Standard.ts
6
6
  var _contracts = require('@ethersproject/contracts');
@@ -133,7 +133,7 @@ var ERC721Standard = class {
133
133
  _controllerutils.safelyExecute.call(void 0, () => this.getAssetName(address)),
134
134
  tokenId ? _controllerutils.safelyExecute.call(void 0,
135
135
  () => this.getTokenURI(address, tokenId).then(
136
- (uri) => uri.startsWith("ipfs://") ? _chunkNYVA7ZTQjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, uri, true) : uri
136
+ (uri) => uri.startsWith("ipfs://") ? _chunkR4HATJKUjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, uri, true) : uri
137
137
  )
138
138
  ) : void 0
139
139
  ]);
@@ -144,7 +144,7 @@ var ERC721Standard = class {
144
144
  const object = await response.json();
145
145
  image = object?.image;
146
146
  if (image?.startsWith("ipfs://")) {
147
- image = _chunkNYVA7ZTQjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, image, true);
147
+ image = _chunkR4HATJKUjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, image, true);
148
148
  }
149
149
  } catch {
150
150
  }
@@ -175,4 +175,4 @@ var ERC721Standard = class {
175
175
 
176
176
 
177
177
  exports.ERC721Standard = ERC721Standard;
178
- //# sourceMappingURL=chunk-LBJTMJFA.js.map
178
+ //# sourceMappingURL=chunk-4U2L56TY.js.map