@0xsequence/marketplace-sdk 0.8.10 → 0.8.12

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 (436) hide show
  1. package/.changeset/fluffy-jokes-lay.md +5 -0
  2. package/.changeset/wise-bugs-boil.md +8 -0
  3. package/CHANGELOG.md +182 -3
  4. package/dist/CartIcon-Bll1rbxv.js +141 -0
  5. package/dist/CartIcon-Bll1rbxv.js.map +1 -0
  6. package/dist/CollectibleCard-CLQTl0_6.d.ts +8 -0
  7. package/dist/_internal-69NEWNUE.js +34 -0
  8. package/dist/_internal-69NEWNUE.js.map +1 -0
  9. package/dist/abi-BKyRjVcZ.js +0 -0
  10. package/dist/{alien_swap-2B65TDGT.js → alien_swap-B_76IMma.js} +5 -5
  11. package/dist/alien_swap-B_76IMma.js.map +1 -0
  12. package/dist/api-1KFxYh7o.js +232 -0
  13. package/dist/api-1KFxYh7o.js.map +1 -0
  14. package/dist/{aqua-xyz-WMYQLAIS.js → aqua-xyz-CMN_TFY5.js} +5 -5
  15. package/dist/aqua-xyz-CMN_TFY5.js.map +1 -0
  16. package/dist/{aura-V22RV5OG.js → aura-Cye_TuHj.js} +5 -5
  17. package/dist/aura-Cye_TuHj.js.map +1 -0
  18. package/dist/{blur-GE5QOMCM.js → blur-DWDMyMpK.js} +5 -5
  19. package/dist/blur-DWDMyMpK.js.map +1 -0
  20. package/dist/builder-api-BQvzykoU.js +28 -0
  21. package/dist/builder-api-BQvzykoU.js.map +1 -0
  22. package/dist/builder-api-DoK3907S.d.ts +12 -0
  23. package/dist/builder.gen-CxP9NT1p.js +303 -0
  24. package/dist/builder.gen-CxP9NT1p.js.map +1 -0
  25. package/dist/{coinbase-NLHJMGAP.js → coinbase-ByA_XRB0.js} +5 -5
  26. package/dist/coinbase-ByA_XRB0.js.map +1 -0
  27. package/dist/{element-2LGTYYSP.js → element-b77CyXIZ.js} +5 -5
  28. package/dist/element-b77CyXIZ.js.map +1 -0
  29. package/dist/{foundation-BPN66ZTN.js → foundation-DbOrKP9Y.js} +5 -5
  30. package/dist/foundation-DbOrKP9Y.js.map +1 -0
  31. package/dist/index-1bezgsFq.d.ts +1129 -0
  32. package/dist/index-4-kfOFdx.d.ts +22 -0
  33. package/dist/index-BEYefG1G.d.ts +24 -0
  34. package/dist/index-BHiSG-Yi.d.ts +312 -0
  35. package/dist/index-BIMIpDiI.d.ts +188 -0
  36. package/dist/index-BQW0PUkQ.d.ts +3973 -0
  37. package/dist/index-BfH21xmk.d.ts +117 -0
  38. package/dist/index-BjIwVzc4.d.ts +1057 -0
  39. package/dist/index-C39K_8SG.d.ts +1 -0
  40. package/dist/index-CN8puQQJ.d.ts +24 -0
  41. package/dist/index-Cl7PQOGu.d.ts +102 -0
  42. package/dist/index-D5v5iluA.d.ts +809 -0
  43. package/dist/index-DXMfTZ1F.d.ts +7 -0
  44. package/dist/index-DafWjEb4.d.ts +65 -0
  45. package/dist/index-ij9f8GAA.d.ts +1 -0
  46. package/dist/index.css +384 -371
  47. package/dist/index.d.ts +10 -28
  48. package/dist/index.js +13 -105
  49. package/dist/{looks-rare-MZRSOPT4.js → looks-rare-C1VqNcSM.js} +5 -5
  50. package/dist/looks-rare-C1VqNcSM.js.map +1 -0
  51. package/dist/{magic-eden-PUBL6KWW.js → magic-eden-ea_AGCZr.js} +5 -5
  52. package/dist/magic-eden-ea_AGCZr.js.map +1 -0
  53. package/dist/{manifold-GA445YJ6.js → manifold-8y8J2sjT.js} +5 -5
  54. package/dist/manifold-8y8J2sjT.js.map +1 -0
  55. package/dist/marketplace-logos-CSeGcPW4.js +50 -0
  56. package/dist/marketplace-logos-CSeGcPW4.js.map +1 -0
  57. package/dist/marketplace-nwnZv9Cb.js +1913 -0
  58. package/dist/marketplace-nwnZv9Cb.js.map +1 -0
  59. package/dist/marketplace.gen-Dqk8vRmD.js +1068 -0
  60. package/dist/marketplace.gen-Dqk8vRmD.js.map +1 -0
  61. package/dist/marketplaceConfig-D2MYFqll.js +71 -0
  62. package/dist/marketplaceConfig-D2MYFqll.js.map +1 -0
  63. package/dist/{mintify-UMC5PTKC.js → mintify-LA68TzWg.js} +5 -5
  64. package/dist/mintify-LA68TzWg.js.map +1 -0
  65. package/dist/{nftx-AX3CY3IE.js → nftx-D3Tc8nzd.js} +5 -5
  66. package/dist/nftx-D3Tc8nzd.js.map +1 -0
  67. package/dist/{okx-GNVLAE2R.js → okx-hbqg6oIJ.js} +5 -5
  68. package/dist/okx-hbqg6oIJ.js.map +1 -0
  69. package/dist/{open-sea-KI43GVEB.js → open-sea-BccuK8-t.js} +5 -5
  70. package/dist/open-sea-BccuK8-t.js.map +1 -0
  71. package/dist/options-DCi6_23w.js +34 -0
  72. package/dist/options-DCi6_23w.js.map +1 -0
  73. package/dist/primary-sale-Cw95phYC.js +1264 -0
  74. package/dist/primary-sale-Cw95phYC.js.map +1 -0
  75. package/dist/queries-DPvwtnO7.js +486 -0
  76. package/dist/queries-DPvwtnO7.js.map +1 -0
  77. package/dist/{rarible-2J3MMZJ7.js → rarible-BgTwwj9g.js} +5 -5
  78. package/dist/rarible-BgTwwj9g.js.map +1 -0
  79. package/dist/react/_internal/api/index.d.ts +4 -86
  80. package/dist/react/_internal/api/index.js +7 -150
  81. package/dist/react/_internal/databeat/index.d.ts +45 -41
  82. package/dist/react/_internal/databeat/index.js +23 -27
  83. package/dist/react/_internal/index.d.ts +7 -24
  84. package/dist/react/_internal/index.js +9 -176
  85. package/dist/react/_internal/wagmi/index.d.ts +4 -18
  86. package/dist/react/_internal/wagmi/index.js +5 -14
  87. package/dist/react/hooks/index.d.ts +17 -3803
  88. package/dist/react/hooks/index.js +23 -157
  89. package/dist/react/hooks/options/index.d.ts +5 -7
  90. package/dist/react/hooks/options/index.js +11 -19
  91. package/dist/react/index.d.ts +37 -33
  92. package/dist/react/index.js +23 -199
  93. package/dist/react/queries/index.d.ts +8 -26
  94. package/dist/react/queries/index.js +18 -40
  95. package/dist/react/ssr/index.d.ts +19 -13
  96. package/dist/react/ssr/index.js +29 -27
  97. package/dist/react/ssr/index.js.map +1 -1
  98. package/dist/react/ui/components/marketplace-collectible-card/index.d.ts +10 -0
  99. package/dist/react/ui/components/marketplace-collectible-card/index.js +23 -0
  100. package/dist/react/ui/components/marketplace-collectible-card/utils/index.d.ts +8 -0
  101. package/dist/react/ui/components/marketplace-collectible-card/utils/index.js +10 -0
  102. package/dist/react/ui/components/marketplace-logos/index.d.ts +26 -24
  103. package/dist/react/ui/components/marketplace-logos/index.js +3 -45
  104. package/dist/react/ui/icons/index.d.ts +1 -2
  105. package/dist/react/ui/icons/index.js +10 -14
  106. package/dist/react/ui/index.d.ts +10 -116
  107. package/dist/react/ui/index.js +23 -46
  108. package/dist/react/ui/modals/_internal/components/actionModal/index.d.ts +59 -33
  109. package/dist/react/ui/modals/_internal/components/actionModal/index.js +23 -31
  110. package/dist/react-BG7o4PId.js +8351 -0
  111. package/dist/react-BG7o4PId.js.map +1 -0
  112. package/dist/react-BbHBl6gg.css +80 -0
  113. package/dist/react-BbHBl6gg.css.map +1 -0
  114. package/dist/sdk-config-DJzxVPld.d.ts +1535 -0
  115. package/dist/{sequence-TGLUFEPQ.js → sequence-Do3kzb4J.js} +5 -5
  116. package/dist/sequence-Do3kzb4J.js.map +1 -0
  117. package/dist/src-Dz2CfBL0.js +8 -0
  118. package/dist/src-Dz2CfBL0.js.map +1 -0
  119. package/dist/{sudo-swap-M2O6E3TE.js → sudo-swap-B6vPKxBz.js} +5 -5
  120. package/dist/sudo-swap-B6vPKxBz.js.map +1 -0
  121. package/dist/{super-rare-UU2U4LIN.js → super-rare-eCm1SE6O.js} +5 -5
  122. package/dist/super-rare-eCm1SE6O.js.map +1 -0
  123. package/dist/token-CO5llIla.js +1312 -0
  124. package/dist/token-CO5llIla.js.map +1 -0
  125. package/dist/transaction-CcVViHEL.js +97 -0
  126. package/dist/transaction-CcVViHEL.js.map +1 -0
  127. package/dist/types/index.d.ts +3 -12
  128. package/dist/types/index.js +5 -44
  129. package/dist/types-BIJOaL4j.d.ts +68 -0
  130. package/dist/types-DwWE6xOF.js +13 -0
  131. package/dist/types-DwWE6xOF.js.map +1 -0
  132. package/dist/useCollection-C-mclKU0.d.ts +66 -0
  133. package/dist/utils/abi/index.d.ts +5 -3
  134. package/dist/utils/abi/index.js +6 -26
  135. package/dist/utils/abi/marketplace/index.d.ts +2 -805
  136. package/dist/utils/abi/marketplace/index.js +3 -11
  137. package/dist/utils/abi/primary-sale/index.d.ts +2 -1054
  138. package/dist/utils/abi/primary-sale/index.js +3 -9
  139. package/dist/utils/abi/token/index.d.ts +2 -1125
  140. package/dist/utils/abi/token/index.js +3 -11
  141. package/dist/utils/index.d.ts +8 -91
  142. package/dist/utils/index.js +11 -56
  143. package/dist/utils-BFdxaToy.js +216 -0
  144. package/dist/utils-BFdxaToy.js.map +1 -0
  145. package/dist/utils-Cat9_pef.js +44 -0
  146. package/dist/utils-Cat9_pef.js.map +1 -0
  147. package/dist/wagmi-DRctYEk6.js +159 -0
  148. package/dist/wagmi-DRctYEk6.js.map +1 -0
  149. package/dist/{x2y2-3W5BBMZC.js → x2y2-DD17tT91.js} +5 -5
  150. package/dist/x2y2-DD17tT91.js.map +1 -0
  151. package/dist/{zora-6EY6FUH6.js → zora-BpSG9UzS.js} +5 -5
  152. package/dist/zora-BpSG9UzS.js.map +1 -0
  153. package/package.json +21 -19
  154. package/src/index.ts +0 -1
  155. package/src/react/_internal/api/__mocks__/builder.msw.ts +157 -80
  156. package/src/react/_internal/api/__mocks__/indexer.msw.ts +1 -0
  157. package/src/react/_internal/api/builder-api.ts +2 -2
  158. package/src/react/_internal/api/builder.gen.ts +666 -112
  159. package/src/react/_internal/api/marketplace.gen.ts +2421 -1315
  160. package/src/react/_internal/api/services.ts +42 -49
  161. package/src/react/_internal/types.ts +1 -13
  162. package/src/react/_internal/wagmi/__tests__/create-config.test.ts +102 -87
  163. package/src/react/_internal/wagmi/create-config.ts +15 -6
  164. package/src/react/_internal/wagmi/get-connectors.ts +29 -21
  165. package/src/react/hooks/__tests__/__snapshots__/useListCollections.test.tsx.snap +273 -0
  166. package/src/react/hooks/__tests__/__snapshots__/useMarketplaceConfig.test.tsx.snap +122 -82
  167. package/src/react/hooks/__tests__/useAutoSelectFeeOption.test.tsx +7 -4
  168. package/src/react/hooks/__tests__/useCheckoutOptionsSalesContract.test.tsx +225 -0
  169. package/src/react/hooks/__tests__/useCollectionDetailsPolling.test.tsx +3 -3
  170. package/src/react/hooks/__tests__/useFilters.test.tsx +0 -16
  171. package/src/react/hooks/__tests__/useGenerateCancelTransaction.test.tsx +2 -3
  172. package/src/react/hooks/__tests__/useHighestOffer.test.tsx +0 -16
  173. package/src/react/hooks/__tests__/useInventory.test.tsx +6 -42
  174. package/src/react/hooks/__tests__/useListCollections.test.tsx +24 -57
  175. package/src/react/hooks/__tests__/{useCurrencies.test.tsx → useMarketCurrencies.test.tsx} +21 -15
  176. package/src/react/hooks/__tests__/useMarketplaceConfig.test.tsx +2 -59
  177. package/src/react/hooks/index.ts +9 -1
  178. package/src/react/hooks/useBalanceOfCollectible.tsx +14 -8
  179. package/src/react/hooks/useCancelTransactionSteps.tsx +5 -1
  180. package/src/react/hooks/useCheckoutOptions.tsx +2 -1
  181. package/src/react/hooks/useCheckoutOptionsSalesContract.tsx +67 -0
  182. package/src/react/hooks/useCollectionDetails.tsx +22 -7
  183. package/src/react/hooks/useConvertPriceToUSD.tsx +1 -1
  184. package/src/react/hooks/useCountListingsForCollectible.tsx +5 -4
  185. package/src/react/hooks/useCountOfCollectables.tsx +10 -7
  186. package/src/react/hooks/useCountOffersForCollectible.tsx +5 -4
  187. package/src/react/hooks/useCurrency.tsx +2 -2
  188. package/src/react/hooks/useERC721SaleMintedTokens.tsx +67 -0
  189. package/src/react/hooks/useFilters.tsx +14 -22
  190. package/src/react/hooks/useFloorOrder.tsx +5 -2
  191. package/src/react/hooks/useGenerateCancelTransaction.tsx +13 -6
  192. package/src/react/hooks/useGenerateListingTransaction.tsx +15 -5
  193. package/src/react/hooks/useGenerateOfferTransaction.tsx +15 -6
  194. package/src/react/hooks/useGenerateSellTransaction.tsx +15 -6
  195. package/src/react/hooks/useGetTokenSuppliesMap.ts +33 -0
  196. package/src/react/hooks/useInventory.tsx +7 -4
  197. package/src/react/hooks/useList1155ShopCardData.tsx +130 -0
  198. package/src/react/hooks/useList721ShopCardData.tsx +130 -0
  199. package/src/react/hooks/useListBalances.tsx +7 -8
  200. package/src/react/hooks/useListCollectibleActivities.tsx +2 -1
  201. package/src/react/hooks/useListCollectibles.tsx +1 -12
  202. package/src/react/hooks/useListCollectiblesPaginated.tsx +8 -5
  203. package/src/react/hooks/useListCollectionActivities.tsx +2 -1
  204. package/src/react/hooks/useListCollections.tsx +14 -76
  205. package/src/react/hooks/useListListingsForCollectible.tsx +2 -1
  206. package/src/react/hooks/useListMarketCardData.tsx +157 -0
  207. package/src/react/hooks/useListOffersForCollectible.tsx +2 -1
  208. package/src/react/hooks/useListPrimarySaleItems.ts +42 -0
  209. package/src/react/hooks/useMarketCurrencies.tsx +8 -0
  210. package/src/react/hooks/useMarketplaceConfig.tsx +0 -2
  211. package/src/react/hooks/useTokenSaleDetailsBatch.tsx +134 -0
  212. package/src/react/queries/highestOffer.ts +6 -4
  213. package/src/react/queries/index.ts +1 -0
  214. package/src/react/queries/inventory.ts +36 -2
  215. package/src/react/queries/listBalances.ts +14 -30
  216. package/src/react/queries/listCollectibles.ts +60 -7
  217. package/src/react/queries/listCollections.ts +124 -0
  218. package/src/react/queries/listTokenMetadata.ts +6 -1
  219. package/src/react/queries/lowestListing.ts +6 -4
  220. package/src/react/queries/marketCurrencies.ts +81 -0
  221. package/src/react/queries/marketplaceConfig.ts +82 -79
  222. package/src/react/ssr/__tests__/__snapshots__/create-ssr-client.test.ts.snap +122 -82
  223. package/src/react/ssr/__tests__/create-ssr-client.test.ts +0 -3
  224. package/src/react/ssr/create-ssr-client.ts +5 -10
  225. package/src/react/ui/components/_internals/action-button/ActionButton.tsx +47 -13
  226. package/src/react/ui/components/_internals/action-button/__tests__/ActionButtonBody.test.tsx +1 -1
  227. package/src/react/ui/components/_internals/action-button/__tests__/NonOwnerActions.test.tsx +28 -15
  228. package/src/react/ui/components/_internals/action-button/__tests__/OwnerActions.test.tsx +1 -1
  229. package/src/react/ui/components/_internals/action-button/__tests__/useActionButtonLogic.test.tsx +1 -1
  230. package/src/react/ui/components/_internals/action-button/components/ActionButtonBody.tsx +1 -1
  231. package/src/react/ui/components/_internals/action-button/components/NonOwnerActions.tsx +78 -15
  232. package/src/react/ui/components/_internals/action-button/components/OwnerActions.tsx +1 -1
  233. package/src/react/ui/components/_internals/action-button/hooks/useActionButtonLogic.ts +1 -1
  234. package/src/react/ui/components/marketplace-collectible-card/CollectibleCard.tsx +17 -0
  235. package/src/react/ui/components/marketplace-collectible-card/CollectibleCardSkeleton.tsx +24 -0
  236. package/src/react/ui/components/marketplace-collectible-card/Footer.tsx +231 -0
  237. package/src/react/ui/components/marketplace-collectible-card/components/ActionButtonWrapper.tsx +76 -0
  238. package/src/react/ui/components/marketplace-collectible-card/components/BaseCard.tsx +55 -0
  239. package/src/react/ui/components/marketplace-collectible-card/index.ts +3 -0
  240. package/src/react/ui/components/marketplace-collectible-card/types.ts +95 -0
  241. package/src/react/ui/components/marketplace-collectible-card/utils/formatPrice.ts +45 -0
  242. package/src/react/ui/components/marketplace-collectible-card/utils/index.ts +2 -0
  243. package/src/react/ui/components/marketplace-collectible-card/utils/supplyStatus.ts +39 -0
  244. package/src/react/ui/components/marketplace-collectible-card/variants/MarketCard.tsx +124 -0
  245. package/src/react/ui/components/marketplace-collectible-card/variants/ShopCard.tsx +105 -0
  246. package/src/react/ui/components/{collectible-card/media → media}/Media.tsx +52 -30
  247. package/src/react/ui/components/{collectible-card/media → media}/MediaSkeleton.tsx +1 -1
  248. package/src/react/ui/components/{collectible-card/media → media}/types.ts +4 -1
  249. package/src/react/ui/index.ts +5 -2
  250. package/src/react/ui/modals/BuyModal/__tests__/BuyModalRouter.test.tsx +554 -0
  251. package/src/react/ui/modals/BuyModal/__tests__/ERC1155ShopModal.test.tsx +385 -0
  252. package/src/react/ui/modals/BuyModal/__tests__/ERC721ShopModal.test.tsx +272 -0
  253. package/src/react/ui/modals/BuyModal/__tests__/Modal.test.tsx.bak +112 -0
  254. package/src/react/ui/modals/BuyModal/__tests__/Modal1155.test.tsx +117 -13
  255. package/src/react/ui/modals/BuyModal/__tests__/store.test.ts +10 -7
  256. package/src/react/ui/modals/BuyModal/components/BuyModalRouter.tsx +157 -0
  257. package/src/react/ui/modals/BuyModal/components/ERC1155BuyModal.tsx +136 -0
  258. package/src/react/ui/modals/BuyModal/components/ERC1155QuantityModal.tsx +184 -0
  259. package/src/react/ui/modals/BuyModal/components/ERC1155ShopModal.tsx +121 -0
  260. package/src/react/ui/modals/BuyModal/components/ERC721BuyModal.tsx +85 -0
  261. package/src/react/ui/modals/BuyModal/components/ERC721ShopModal.tsx +86 -0
  262. package/src/react/ui/modals/BuyModal/components/Modal.tsx +14 -0
  263. package/src/react/ui/modals/BuyModal/components/types.ts +8 -0
  264. package/src/react/ui/modals/BuyModal/hooks/__tests__/useCheckoutOptions.test.tsx +4 -4
  265. package/src/react/ui/modals/BuyModal/hooks/__tests__/useERC1155Checkout.test.tsx +379 -0
  266. package/src/react/ui/modals/BuyModal/hooks/__tests__/useERC721SalePaymentParams.test.tsx +253 -0
  267. package/src/react/ui/modals/BuyModal/hooks/__tests__/{useFees.test.tsx → useMarketPlatformFee.test.tsx} +37 -28
  268. package/src/react/ui/modals/BuyModal/hooks/useCheckoutOptions.ts +62 -44
  269. package/src/react/ui/modals/BuyModal/hooks/useERC1155Checkout.ts +73 -0
  270. package/src/react/ui/modals/BuyModal/hooks/useERC721SalePaymentParams.ts +196 -0
  271. package/src/react/ui/modals/BuyModal/hooks/useLoadData.ts +74 -18
  272. package/src/react/ui/modals/BuyModal/hooks/useMarketPlatformFee.ts +53 -0
  273. package/src/react/ui/modals/BuyModal/hooks/usePaymentModalParams.ts +27 -12
  274. package/src/react/ui/modals/BuyModal/store.ts +147 -13
  275. package/src/react/ui/modals/CreateListingModal/Modal.tsx +3 -5
  276. package/src/react/ui/modals/CreateListingModal/hooks/useCreateListing.tsx +5 -3
  277. package/src/react/ui/modals/CreateListingModal/hooks/useGetTokenApproval.ts +2 -1
  278. package/src/react/ui/modals/CreateListingModal/hooks/useTransactionSteps.tsx +7 -5
  279. package/src/react/ui/modals/MakeOfferModal/Modal.tsx +2 -3
  280. package/src/react/ui/modals/MakeOfferModal/hooks/useGetTokenApproval.tsx +2 -1
  281. package/src/react/ui/modals/MakeOfferModal/hooks/useMakeOffer.tsx +4 -3
  282. package/src/react/ui/modals/MakeOfferModal/hooks/useTransactionSteps.tsx +5 -3
  283. package/src/react/ui/modals/SellModal/Modal.tsx +0 -1
  284. package/src/react/ui/modals/SellModal/hooks/useGetTokenApproval.tsx +4 -3
  285. package/src/react/ui/modals/SellModal/hooks/useTransactionSteps.tsx +8 -5
  286. package/src/react/ui/modals/SuccessfulPurchaseModal/__tests__/Modal.test.tsx +11 -7
  287. package/src/react/ui/modals/SuccessfulPurchaseModal/index.tsx +34 -28
  288. package/src/react/ui/modals/SuccessfulPurchaseModal/store.ts +71 -0
  289. package/src/react/ui/modals/TransferModal/_views/enterWalletAddress/index.tsx +0 -1
  290. package/src/react/ui/modals/TransferModal/index.tsx +0 -1
  291. package/src/react/ui/modals/_internal/components/actionModal/ActionModal.test.tsx +0 -1
  292. package/src/react/ui/modals/_internal/components/actionModal/ActionModal.tsx +105 -108
  293. package/src/react/ui/modals/_internal/components/actionModal/store.ts +45 -12
  294. package/src/react/ui/modals/_internal/components/currencyOptionsSelect/__tests__/index.test.tsx +2 -2
  295. package/src/react/ui/modals/_internal/components/currencyOptionsSelect/index.tsx +7 -6
  296. package/src/react/ui/modals/_internal/components/selectWaasFeeOptions/__tests__/SelectWaasFeeOptions.test.tsx +13 -7
  297. package/src/react/ui/modals/_internal/components/selectWaasFeeOptions/index.tsx +3 -5
  298. package/src/react/ui/modals/_internal/components/selectWaasFeeOptions/useWaasFeeOptionManager.tsx +5 -3
  299. package/src/react/ui/modals/_internal/components/switchChainModal/__tests__/SwitchChainModal.test.tsx +12 -8
  300. package/src/react/ui/modals/_internal/components/switchChainModal/index.tsx +35 -33
  301. package/src/react/ui/modals/_internal/components/switchChainModal/store.ts +61 -32
  302. package/src/react/ui/modals/_internal/components/transactionDetails/index.tsx +2 -2
  303. package/src/react/ui/modals/_internal/hooks/useSelectWaasFeeOptions.ts +2 -12
  304. package/src/react/ui/modals/modal-provider.tsx +1 -1
  305. package/src/types/buyModalErrors.ts +438 -0
  306. package/src/types/index.ts +1 -3
  307. package/src/types/new-marketplace-types.ts +104 -0
  308. package/src/types/sdk-config.ts +22 -12
  309. package/src/types/types.ts +17 -0
  310. package/src/utils/_internal/error/transaction.ts +36 -1
  311. package/tsconfig.json +1 -1
  312. package/tsconfig.tsbuildinfo +1 -1
  313. package/tsdown.config.ts +25 -0
  314. package/.ctirc +0 -32
  315. package/dist/alien_swap-2B65TDGT.js.map +0 -1
  316. package/dist/aqua-xyz-WMYQLAIS.js.map +0 -1
  317. package/dist/aura-V22RV5OG.js.map +0 -1
  318. package/dist/blur-GE5QOMCM.js.map +0 -1
  319. package/dist/chunk-2PSNAIAT.js +0 -1
  320. package/dist/chunk-2PSNAIAT.js.map +0 -1
  321. package/dist/chunk-5C6ZZ6WX.js +0 -130
  322. package/dist/chunk-5C6ZZ6WX.js.map +0 -1
  323. package/dist/chunk-5O44EPXZ.js +0 -207
  324. package/dist/chunk-5O44EPXZ.js.map +0 -1
  325. package/dist/chunk-6CTFVBKU.js +0 -1
  326. package/dist/chunk-6CTFVBKU.js.map +0 -1
  327. package/dist/chunk-7F27CJZW.js +0 -1544
  328. package/dist/chunk-7F27CJZW.js.map +0 -1
  329. package/dist/chunk-A7BVFBWB.js +0 -81
  330. package/dist/chunk-A7BVFBWB.js.map +0 -1
  331. package/dist/chunk-D7RVSZAQ.js +0 -332
  332. package/dist/chunk-D7RVSZAQ.js.map +0 -1
  333. package/dist/chunk-DWTLVJAW.js +0 -42
  334. package/dist/chunk-DWTLVJAW.js.map +0 -1
  335. package/dist/chunk-FGM57QUU.js +0 -128
  336. package/dist/chunk-FGM57QUU.js.map +0 -1
  337. package/dist/chunk-FUM4OGOQ.js +0 -1027
  338. package/dist/chunk-FUM4OGOQ.js.map +0 -1
  339. package/dist/chunk-JKCF7HEA.js +0 -1
  340. package/dist/chunk-JKCF7HEA.js.map +0 -1
  341. package/dist/chunk-KTST7ORH.js +0 -53
  342. package/dist/chunk-KTST7ORH.js.map +0 -1
  343. package/dist/chunk-M6NJ73Y5.js +0 -154
  344. package/dist/chunk-M6NJ73Y5.js.map +0 -1
  345. package/dist/chunk-N7BPFK46.js +0 -1
  346. package/dist/chunk-N7BPFK46.js.map +0 -1
  347. package/dist/chunk-NX52D7NX.js +0 -135
  348. package/dist/chunk-NX52D7NX.js.map +0 -1
  349. package/dist/chunk-O34GCB47.js +0 -32
  350. package/dist/chunk-O34GCB47.js.map +0 -1
  351. package/dist/chunk-Q3ECVC4F.js +0 -811
  352. package/dist/chunk-Q3ECVC4F.js.map +0 -1
  353. package/dist/chunk-RVIUUJTP.js +0 -76
  354. package/dist/chunk-RVIUUJTP.js.map +0 -1
  355. package/dist/chunk-SXVUTSMT.js +0 -2895
  356. package/dist/chunk-SXVUTSMT.js.map +0 -1
  357. package/dist/chunk-UJSF7PSC.js +0 -5728
  358. package/dist/chunk-UJSF7PSC.js.map +0 -1
  359. package/dist/chunk-WH5BZC7W.js +0 -38
  360. package/dist/chunk-WH5BZC7W.js.map +0 -1
  361. package/dist/chunk-XX4EVWBF.js +0 -1292
  362. package/dist/chunk-XX4EVWBF.js.map +0 -1
  363. package/dist/chunk-Y2HJO2VY.js +0 -432
  364. package/dist/chunk-Y2HJO2VY.js.map +0 -1
  365. package/dist/chunk-Y63BOO6M.js +0 -11
  366. package/dist/chunk-Y63BOO6M.js.map +0 -1
  367. package/dist/coinbase-NLHJMGAP.js.map +0 -1
  368. package/dist/create-config-CAQcvjl6.d.ts +0 -8
  369. package/dist/element-2LGTYYSP.js.map +0 -1
  370. package/dist/foundation-BPN66ZTN.js.map +0 -1
  371. package/dist/get-query-client-D46hbjk6.d.ts +0 -5
  372. package/dist/index-MlUK9AQE.d.ts +0 -62
  373. package/dist/index.css.map +0 -1
  374. package/dist/index.js.map +0 -1
  375. package/dist/listTokenMetadata-DO4ChDjn.d.ts +0 -203
  376. package/dist/looks-rare-MZRSOPT4.js.map +0 -1
  377. package/dist/magic-eden-PUBL6KWW.js.map +0 -1
  378. package/dist/manifold-GA445YJ6.js.map +0 -1
  379. package/dist/marketplace.gen-DQzWciwC.d.ts +0 -1072
  380. package/dist/marketplaceConfig-D0MXemEl.d.ts +0 -17
  381. package/dist/mintify-UMC5PTKC.js.map +0 -1
  382. package/dist/nftx-AX3CY3IE.js.map +0 -1
  383. package/dist/okx-GNVLAE2R.js.map +0 -1
  384. package/dist/open-sea-KI43GVEB.js.map +0 -1
  385. package/dist/rarible-2J3MMZJ7.js.map +0 -1
  386. package/dist/react/_internal/api/index.js.map +0 -1
  387. package/dist/react/_internal/databeat/index.js.map +0 -1
  388. package/dist/react/_internal/index.js.map +0 -1
  389. package/dist/react/_internal/wagmi/index.js.map +0 -1
  390. package/dist/react/hooks/index.js.map +0 -1
  391. package/dist/react/hooks/options/index.js.map +0 -1
  392. package/dist/react/index.css +0 -2764
  393. package/dist/react/index.css.map +0 -1
  394. package/dist/react/index.js.map +0 -1
  395. package/dist/react/queries/index.js.map +0 -1
  396. package/dist/react/ui/components/collectible-card/index.css +0 -2764
  397. package/dist/react/ui/components/collectible-card/index.css.map +0 -1
  398. package/dist/react/ui/components/collectible-card/index.d.ts +0 -70
  399. package/dist/react/ui/components/collectible-card/index.js +0 -32
  400. package/dist/react/ui/components/collectible-card/index.js.map +0 -1
  401. package/dist/react/ui/components/marketplace-logos/index.js.map +0 -1
  402. package/dist/react/ui/icons/index.js.map +0 -1
  403. package/dist/react/ui/index.css +0 -2764
  404. package/dist/react/ui/index.css.map +0 -1
  405. package/dist/react/ui/index.js.map +0 -1
  406. package/dist/react/ui/modals/_internal/components/actionModal/index.js.map +0 -1
  407. package/dist/sdk-config-onSPBxJj.d.ts +0 -134
  408. package/dist/sequence-TGLUFEPQ.js.map +0 -1
  409. package/dist/services-CMSb9ipU.d.ts +0 -23
  410. package/dist/sudo-swap-M2O6E3TE.js.map +0 -1
  411. package/dist/super-rare-UU2U4LIN.js.map +0 -1
  412. package/dist/types/index.js.map +0 -1
  413. package/dist/types-B8xzPEKX.d.ts +0 -68
  414. package/dist/utils/abi/index.js.map +0 -1
  415. package/dist/utils/abi/marketplace/index.js.map +0 -1
  416. package/dist/utils/abi/primary-sale/index.js.map +0 -1
  417. package/dist/utils/abi/token/index.js.map +0 -1
  418. package/dist/utils/index.js.map +0 -1
  419. package/dist/x2y2-3W5BBMZC.js.map +0 -1
  420. package/dist/zora-6EY6FUH6.js.map +0 -1
  421. package/postcss.config.mjs +0 -5
  422. package/src/react/hooks/__tests__/__snapshots__/useRoyaltyPercentage.test.tsx.snap +0 -8
  423. package/src/react/hooks/useCurrencies.tsx +0 -77
  424. package/src/react/ui/components/collectible-card/CollectibleCard.tsx +0 -170
  425. package/src/react/ui/components/collectible-card/Footer.tsx +0 -157
  426. package/src/react/ui/components/collectible-card/__tests__/CollectibleCard.test.tsx +0 -94
  427. package/src/react/ui/components/collectible-card/__tests__/Footer.test.tsx +0 -136
  428. package/src/react/ui/components/collectible-card/__tests__/Media.test.tsx +0 -224
  429. package/src/react/ui/components/collectible-card/index.ts +0 -2
  430. package/src/react/ui/modals/BuyModal/ERC1155QuantityModal.tsx +0 -124
  431. package/src/react/ui/modals/BuyModal/Modal.tsx +0 -124
  432. package/src/react/ui/modals/BuyModal/__tests__/Modal.test.tsx +0 -104
  433. package/src/react/ui/modals/BuyModal/hooks/useFees.ts +0 -38
  434. package/src/react/ui/modals/SuccessfulPurchaseModal/_store.ts +0 -72
  435. package/tsup.config.ts +0 -23
  436. /package/src/react/ui/components/{collectible-card/media → media}/utils.ts +0 -0
@@ -0,0 +1,225 @@
1
+ import { skipToken } from '@tanstack/react-query';
2
+ import { renderHook, waitFor } from '@test';
3
+ import type { Address } from 'viem';
4
+ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
5
+ import { useCheckoutOptionsSalesContract } from '../useCheckoutOptionsSalesContract';
6
+
7
+ // Mock wagmi's useAccount hook
8
+ vi.mock('wagmi', async () => {
9
+ const actual = await vi.importActual('wagmi');
10
+ return {
11
+ ...actual,
12
+ useAccount: vi.fn(() => ({ address: '0xTestWallet' as Address })),
13
+ };
14
+ });
15
+
16
+ const mockContractAddress =
17
+ '0x1234567890123456789012345678901234567890' as Address;
18
+ const mockCollectionAddress =
19
+ '0xabcdefabcdefabcdefabcdefabcdefabcdefabcd' as Address;
20
+
21
+ describe('useCheckoutOptionsSalesContract', () => {
22
+ beforeEach(() => {
23
+ vi.clearAllMocks();
24
+ });
25
+
26
+ afterEach(() => {
27
+ vi.restoreAllMocks();
28
+ });
29
+
30
+ it('should fetch checkout options successfully', async () => {
31
+ const { result } = renderHook(() =>
32
+ useCheckoutOptionsSalesContract({
33
+ chainId: 1,
34
+ contractAddress: mockContractAddress,
35
+ collectionAddress: mockCollectionAddress,
36
+ items: [
37
+ {
38
+ quantity: '1',
39
+ tokenId: '1',
40
+ },
41
+ ],
42
+ }),
43
+ );
44
+
45
+ // Initially loading
46
+ expect(result.current.isLoading).toBe(true);
47
+ expect(result.current.data).toBeUndefined();
48
+
49
+ // Wait for successful response
50
+ await waitFor(() => {
51
+ expect(result.current.isSuccess).toBe(true);
52
+ });
53
+
54
+ // Check the response
55
+ expect(result.current.data).toEqual({
56
+ options: {
57
+ crypto: 'all',
58
+ swap: [],
59
+ nftCheckout: [],
60
+ onRamp: [],
61
+ },
62
+ });
63
+ });
64
+
65
+ it('should handle skipToken', () => {
66
+ const { result } = renderHook(() =>
67
+ useCheckoutOptionsSalesContract(skipToken),
68
+ );
69
+
70
+ // Should not be loading when skipToken is passed
71
+ expect(result.current.isLoading).toBe(false);
72
+ expect(result.current.isFetching).toBe(false);
73
+ expect(result.current.data).toBeUndefined();
74
+ });
75
+
76
+ it('should handle multiple items', async () => {
77
+ const { result } = renderHook(() =>
78
+ useCheckoutOptionsSalesContract({
79
+ chainId: 137,
80
+ contractAddress: mockContractAddress,
81
+ collectionAddress: mockCollectionAddress,
82
+ items: [
83
+ {
84
+ quantity: '2',
85
+ tokenId: '1',
86
+ },
87
+ {
88
+ quantity: '1',
89
+ tokenId: '2',
90
+ },
91
+ ],
92
+ }),
93
+ );
94
+
95
+ await waitFor(() => {
96
+ expect(result.current.isSuccess).toBe(true);
97
+ });
98
+
99
+ expect(result.current.data).toBeDefined();
100
+ expect(result.current.data?.options).toBeDefined();
101
+ });
102
+
103
+ it('should refetch when args change', async () => {
104
+ let chainIdProp = 1;
105
+ const itemsProp = [{ quantity: '1', tokenId: '1' }];
106
+
107
+ const { result, rerender } = renderHook(() =>
108
+ useCheckoutOptionsSalesContract({
109
+ chainId: chainIdProp,
110
+ contractAddress: mockContractAddress,
111
+ collectionAddress: mockCollectionAddress,
112
+ items: itemsProp,
113
+ }),
114
+ );
115
+
116
+ await waitFor(() => {
117
+ expect(result.current.isSuccess).toBe(true);
118
+ });
119
+
120
+ const firstData = result.current.data;
121
+
122
+ // Change chainId
123
+ chainIdProp = 137;
124
+ rerender();
125
+
126
+ await waitFor(() => {
127
+ expect(result.current.isFetching).toBe(true);
128
+ });
129
+
130
+ await waitFor(() => {
131
+ expect(result.current.isFetching).toBe(false);
132
+ });
133
+
134
+ // Data should still be the same (mocked response doesn't change)
135
+ expect(result.current.data).toEqual(firstData);
136
+ });
137
+
138
+ it('should use wallet address from useAccount', async () => {
139
+ const { useAccount } = await import('wagmi');
140
+ const mockUseAccount = vi.mocked(useAccount);
141
+
142
+ // Set a specific address
143
+ mockUseAccount.mockReturnValue({
144
+ address: '0xSpecificWallet' as Address,
145
+ isConnected: true,
146
+ isConnecting: false,
147
+ isDisconnected: false,
148
+ isReconnecting: false,
149
+ connector: null,
150
+ addresses: undefined,
151
+ chain: undefined,
152
+ chainId: undefined,
153
+ status: 'connected',
154
+ } as unknown as ReturnType<typeof useAccount>);
155
+
156
+ const { result } = renderHook(() =>
157
+ useCheckoutOptionsSalesContract({
158
+ chainId: 1,
159
+ contractAddress: mockContractAddress,
160
+ collectionAddress: mockCollectionAddress,
161
+ items: [{ quantity: '1', tokenId: '1' }],
162
+ }),
163
+ );
164
+
165
+ await waitFor(() => {
166
+ expect(result.current.isSuccess).toBe(true);
167
+ });
168
+
169
+ expect(result.current.data).toBeDefined();
170
+ });
171
+
172
+ it('should handle when wallet is not connected', async () => {
173
+ const { useAccount } = await import('wagmi');
174
+ const mockUseAccount = vi.mocked(useAccount);
175
+
176
+ // No wallet connected
177
+ mockUseAccount.mockReturnValue({
178
+ address: undefined,
179
+ isConnected: false,
180
+ isConnecting: false,
181
+ isDisconnected: true,
182
+ isReconnecting: false,
183
+ connector: null,
184
+ addresses: undefined,
185
+ chain: undefined,
186
+ chainId: undefined,
187
+ status: 'disconnected',
188
+ } as unknown as ReturnType<typeof useAccount>);
189
+
190
+ const { result } = renderHook(() =>
191
+ useCheckoutOptionsSalesContract({
192
+ chainId: 1,
193
+ contractAddress: mockContractAddress,
194
+ collectionAddress: mockCollectionAddress,
195
+ items: [{ quantity: '1', tokenId: '1' }],
196
+ }),
197
+ );
198
+
199
+ // The hook will still try to fetch even without a wallet (using undefined)
200
+ // Wait for it to complete
201
+ await waitFor(() => {
202
+ expect(result.current.isSuccess).toBe(true);
203
+ });
204
+
205
+ // The API should still return data even without wallet
206
+ expect(result.current.data).toBeDefined();
207
+ });
208
+
209
+ it('should handle empty items array', async () => {
210
+ const { result } = renderHook(() =>
211
+ useCheckoutOptionsSalesContract({
212
+ chainId: 1,
213
+ contractAddress: mockContractAddress,
214
+ collectionAddress: mockCollectionAddress,
215
+ items: [],
216
+ }),
217
+ );
218
+
219
+ await waitFor(() => {
220
+ expect(result.current.isSuccess).toBe(true);
221
+ });
222
+
223
+ expect(result.current.data).toBeDefined();
224
+ });
225
+ });
@@ -23,7 +23,7 @@ describe('useCollectionDetailsPolling', () => {
23
23
  // Mock initial syncing state
24
24
  const syncingCollection = {
25
25
  ...mockCollection,
26
- status: CollectionStatus.syncing_metadata,
26
+ status: CollectionStatus.syncing_orders,
27
27
  };
28
28
  let requestCount = 0;
29
29
 
@@ -58,7 +58,7 @@ describe('useCollectionDetailsPolling', () => {
58
58
  });
59
59
 
60
60
  // Should be in syncing state
61
- expect(result.current.data?.status).toBe(CollectionStatus.syncing_metadata);
61
+ expect(result.current.data?.status).toBe(CollectionStatus.syncing_orders);
62
62
 
63
63
  // Advance timer and run pending timers to trigger next poll
64
64
  await vi.advanceTimersByTimeAsync(2000);
@@ -79,7 +79,7 @@ describe('useCollectionDetailsPolling', () => {
79
79
  it('should stop polling after max attempts', async () => {
80
80
  const syncingCollection = {
81
81
  ...mockCollection,
82
- status: CollectionStatus.syncing_metadata,
82
+ status: CollectionStatus.syncing_orders,
83
83
  };
84
84
  let requestCount = 0;
85
85
 
@@ -85,22 +85,6 @@ describe('useFilters', () => {
85
85
  `);
86
86
  });
87
87
 
88
- it('should validate input parameters', async () => {
89
- const invalidArgs: UseFiltersArgs = {
90
- ...defaultArgs,
91
- // @ts-expect-error
92
- chainId: {}, // Using an object instead of a string/number will fail validation
93
- };
94
-
95
- const { result } = renderHook(() => useFilters(invalidArgs));
96
-
97
- await waitFor(() => {
98
- expect(result.current.isError).toBe(true);
99
- });
100
-
101
- expect(result.current.error).toBeDefined();
102
- });
103
-
104
88
  it('should return filter values in correct format', async () => {
105
89
  const { result } = renderHook(() => useFilters(defaultArgs));
106
90
 
@@ -3,7 +3,6 @@ import { http, HttpResponse } from 'msw';
3
3
  import { zeroAddress } from 'viem';
4
4
  import { describe, expect, it, vi } from 'vitest';
5
5
  import {
6
- createMockStep,
7
6
  createMockSteps,
8
7
  mockMarketplaceEndpoint,
9
8
  } from '../../_internal/api/__mocks__/marketplace.msw';
@@ -85,7 +84,7 @@ describe('useGenerateCancelTransaction', () => {
85
84
  );
86
85
 
87
86
  const { result } = renderHook(() =>
88
- useGenerateCancelTransaction(invalidArgs),
87
+ useGenerateCancelTransaction(defaultArgs),
89
88
  );
90
89
 
91
90
  await act(async () => {
@@ -124,7 +123,7 @@ describe('useGenerateCancelTransaction', () => {
124
123
 
125
124
  await waitFor(() => {
126
125
  expect(onSuccess).toHaveBeenCalledWith(
127
- [createMockStep(StepType.cancel)],
126
+ createMockSteps([StepType.cancel]),
128
127
  defaultArgs,
129
128
  undefined,
130
129
  );
@@ -98,20 +98,4 @@ describe('useHighestOffer', () => {
98
98
  expect(result.current.data).toBeDefined();
99
99
  expect(result.current.error).toBeNull();
100
100
  });
101
-
102
- it('should validate input parameters', async () => {
103
- const invalidArgs = {
104
- ...defaultArgs,
105
- chainId: 'invalid-chain' as string, // Properly typed as string
106
- };
107
-
108
- // @ts-expect-error - for testing purposes
109
- const { result } = renderHook(() => useHighestOffer(invalidArgs));
110
-
111
- await waitFor(() => {
112
- expect(result.current.isError).toBe(true);
113
- });
114
-
115
- expect(result.current.error).toBeDefined();
116
- });
117
101
  });
@@ -1,11 +1,7 @@
1
1
  import { renderHook, server, waitFor } from '@test';
2
2
  import { http, HttpResponse } from 'msw';
3
- import { zeroAddress } from 'viem';
3
+ import { type Address, zeroAddress } from 'viem';
4
4
  import { beforeEach, describe, expect, it } from 'vitest';
5
- import {
6
- createLookupMarketplaceConfigHandler,
7
- mockConfig,
8
- } from '../../_internal/api/__mocks__/builder.msw';
9
5
  import {
10
6
  mockIndexerEndpoint,
11
7
  mockTokenBalance,
@@ -22,8 +18,7 @@ mockCollectibleOrder.metadata.tokenId = '1';
22
18
 
23
19
  describe('useInventory', () => {
24
20
  const defaultArgs: UseInventoryArgs = {
25
- accountAddress:
26
- '0x1234567890123456789012345678901234567890' as `0x${string}`,
21
+ accountAddress: '0x1234567890123456789012345678901234567890' as Address,
27
22
  chainId: 1,
28
23
  collectionAddress: zeroAddress,
29
24
  };
@@ -67,7 +62,7 @@ describe('useInventory', () => {
67
62
  ...defaultArgs,
68
63
  // Add a unique key to avoid caching
69
64
  collectionAddress:
70
- '0xdeadbeef0000000000000000000000000000dead' as `0x${string}`,
65
+ '0xdeadbeef0000000000000000000000000000dead' as Address,
71
66
  }),
72
67
  );
73
68
 
@@ -97,7 +92,7 @@ describe('useInventory', () => {
97
92
  const newArgs = {
98
93
  ...defaultArgs,
99
94
  collectionAddress:
100
- '0x1234567890123456789012345678901234567890' as `0x${string}`,
95
+ '0x1234567890123456789012345678901234567890' as Address,
101
96
  };
102
97
 
103
98
  rerender(() => useInventory(newArgs));
@@ -128,36 +123,6 @@ describe('useInventory', () => {
128
123
  expect(result.current.isFetched).toBe(false);
129
124
  });
130
125
 
131
- it('should use isLaos721 flag from marketplaceConfig', async () => {
132
- // Setup config with LAOS collection
133
- const laosCollectionAddress = '0x1234567890123456789012345678901234567890';
134
- const configWithLaos = {
135
- ...mockConfig,
136
- collections: [
137
- {
138
- ...mockConfig.collections[0],
139
- address: laosCollectionAddress,
140
- isLAOSERC721: true,
141
- },
142
- ],
143
- };
144
- server.use(createLookupMarketplaceConfigHandler(configWithLaos));
145
-
146
- const laosArgs: UseInventoryArgs = {
147
- ...defaultArgs,
148
- collectionAddress: laosCollectionAddress as `0x${string}`,
149
- };
150
-
151
- const { result } = renderHook(() => useInventory(laosArgs));
152
-
153
- await waitFor(() => {
154
- expect(result.current.isLoading).toBe(false);
155
- });
156
-
157
- expect(result.current.data).toBeDefined();
158
- expect(result.current.isSuccess).toBe(true);
159
- });
160
-
161
126
  it('should fetch data from indexer when marketplace API has no more results', async () => {
162
127
  // Mock marketplace API with empty results
163
128
  server.use(
@@ -245,10 +210,9 @@ describe('useInventory', () => {
245
210
  // Use unique test args to avoid caching issues
246
211
  const testArgs = {
247
212
  ...defaultArgs,
248
- accountAddress:
249
- '0xabcdef1234567890abcdef1234567890abcdef12' as `0x${string}`,
213
+ accountAddress: '0xabcdef1234567890abcdef1234567890abcdef12' as Address,
250
214
  collectionAddress:
251
- '0xabcdef1234567890abcdef1234567890abcdef12' as `0x${string}`,
215
+ '0xabcdef1234567890abcdef1234567890abcdef12' as Address,
252
216
  };
253
217
 
254
218
  const { result } = renderHook(() => useInventory(testArgs));
@@ -1,15 +1,13 @@
1
1
  import { renderHook, server, waitFor } from '@test';
2
2
  import { http, HttpResponse } from 'msw';
3
+ import type { Address } from 'viem';
3
4
  import { describe, expect, it } from 'vitest';
4
- import { MarketplaceType, OrderbookKind } from '../../../types';
5
+ import { OrderbookKind } from '../../_internal';
5
6
  import {
6
- createLookupMarketplaceConfigHandler,
7
+ createLookupMarketplaceHandler,
7
8
  mockConfig,
8
9
  } from '../../_internal/api/__mocks__/builder.msw';
9
- import {
10
- mockEthCollection,
11
- mockPolCollection,
12
- } from '../../_internal/api/__mocks__/metadata.msw';
10
+ import { mockEthCollection } from '../../_internal/api/__mocks__/metadata.msw';
13
11
  import { useListCollections } from '../useListCollections';
14
12
 
15
13
  describe('useListCollections', () => {
@@ -22,16 +20,16 @@ describe('useListCollections', () => {
22
20
  });
23
21
 
24
22
  // Verify the data matches our mock
25
- expect(result.current.data).toEqual([mockEthCollection, mockPolCollection]);
23
+ expect(result.current.data).toMatchSnapshot();
26
24
  expect(result.current.error).toBeNull();
27
25
  });
28
26
 
29
27
  it('should handle empty collections', async () => {
30
28
  // Mock marketplace config with empty collections
31
29
  server.use(
32
- createLookupMarketplaceConfigHandler({
30
+ createLookupMarketplaceHandler({
33
31
  ...mockConfig,
34
- collections: [],
32
+ marketCollections: [],
35
33
  }),
36
34
  );
37
35
 
@@ -41,65 +39,35 @@ describe('useListCollections', () => {
41
39
  expect(result.current.data).toBeDefined();
42
40
  });
43
41
 
44
- expect(result.current.data).toEqual([]);
42
+ expect(result.current.data).toMatchSnapshot();
45
43
  expect(result.current.error).toBeNull();
46
44
  });
47
45
 
48
- it('should handle error states', async () => {
49
- // Mock marketplace config with collection
50
- server.use(
51
- createLookupMarketplaceConfigHandler({
52
- ...mockConfig,
53
- collections: [
54
- {
55
- chainId: 1,
56
- address:
57
- '0x1234567890123456789012345678901234567890' as `0x${string}`,
58
- feePercentage: 2.5,
59
- marketplaceType: MarketplaceType.ORDERBOOK,
60
- currencyOptions: [],
61
- exchanges: [],
62
- bannerUrl: '',
63
- destinationMarketplace: OrderbookKind.sequence_marketplace_v2,
64
- },
65
- ],
66
- }),
67
- http.post('*/rpc/Metadata/GetContractInfoBatch', () => {
68
- return new HttpResponse(
69
- JSON.stringify({ error: { message: 'Failed to fetch collections' } }),
70
- { status: 500 },
71
- );
72
- }),
73
- );
74
-
75
- const { result } = renderHook(() => useListCollections());
76
-
77
- await waitFor(() => {
78
- expect(result.current.isError).toBe(true);
79
- });
80
-
81
- expect(result.current.error).toBeDefined();
82
- expect(result.current.data).toBeUndefined();
83
- });
84
-
85
46
  it('should handle disabled queries', async () => {
86
47
  let requestMade = false;
87
48
 
88
49
  // Mock marketplace config with collection
89
50
  server.use(
90
- createLookupMarketplaceConfigHandler({
51
+ createLookupMarketplaceHandler({
91
52
  ...mockConfig,
92
- collections: [
53
+ marketCollections: [
93
54
  {
55
+ id: 1,
56
+ projectId: 1,
57
+ contractType: 'ERC721',
94
58
  chainId: 1,
95
- address:
96
- '0x1234567890123456789012345678901234567890' as `0x${string}`,
59
+ itemsAddress:
60
+ '0x1234567890123456789012345678901234567890' as Address,
97
61
  feePercentage: 2.5,
98
- marketplaceType: MarketplaceType.ORDERBOOK,
99
62
  currencyOptions: [],
100
- exchanges: [],
101
63
  bannerUrl: '',
102
- destinationMarketplace: OrderbookKind.sequence_marketplace_v2,
64
+ destinationMarketplace: OrderbookKind.opensea,
65
+ filterSettings: {
66
+ filterOrder: ['Category', 'Level', 'Element'],
67
+ exclusions: [],
68
+ },
69
+ createdAt: new Date('2025-03-16T13:04:16.098Z').toISOString(),
70
+ updatedAt: new Date('2025-03-16T13:04:16.098Z').toISOString(),
103
71
  },
104
72
  ],
105
73
  }),
@@ -129,14 +97,13 @@ describe('useListCollections', () => {
129
97
  });
130
98
 
131
99
  it('should handle multiple collections from different chains', async () => {
132
- // TODO: This test should be more robust, make sure we validate that the marketplace config has multiple chains
133
- // then the to equal should just check that we are fetching the data from those
134
100
  const { result } = renderHook(() => useListCollections());
135
101
 
136
102
  await waitFor(() => {
137
103
  expect(result.current.data).toBeDefined();
138
104
  });
139
105
 
140
- expect(result.current.data).toEqual([mockEthCollection, mockPolCollection]);
106
+ const set = new Set(result.current.data?.map((c) => c.chainId));
107
+ expect(set.size).toBeGreaterThan(1);
141
108
  });
142
109
  });
@@ -1,21 +1,22 @@
1
1
  import { renderHook, server, waitFor } from '@test';
2
2
  import { USDC_ADDRESS } from '@test/const';
3
3
  import { http, HttpResponse } from 'msw';
4
+ import type { Address } from 'viem';
4
5
  import { describe, expect, it } from 'vitest';
5
6
  import { mockConfig } from '../../_internal/api/__mocks__/builder.msw';
6
7
  import {
7
8
  mockCurrencies,
8
9
  mockMarketplaceEndpoint,
9
10
  } from '../../_internal/api/__mocks__/marketplace.msw';
10
- import { useCurrencies } from '../useCurrencies';
11
+ import { useMarketCurrencies } from '../useMarketCurrencies';
11
12
 
12
- describe('useCurrencies', () => {
13
+ describe('useMarketCurrencies', () => {
13
14
  const defaultArgs = {
14
15
  chainId: 1,
15
16
  };
16
17
 
17
18
  it('should fetch currencies successfully', async () => {
18
- const { result } = renderHook(() => useCurrencies(defaultArgs));
19
+ const { result } = renderHook(() => useMarketCurrencies(defaultArgs));
19
20
 
20
21
  // Initially loading
21
22
  expect(result.current.isLoading).toBe(true);
@@ -37,7 +38,7 @@ describe('useCurrencies', () => {
37
38
  includeNativeCurrency: false,
38
39
  };
39
40
 
40
- const { result } = renderHook(() => useCurrencies(argsWithoutNative));
41
+ const { result } = renderHook(() => useMarketCurrencies(argsWithoutNative));
41
42
 
42
43
  await waitFor(() => {
43
44
  expect(result.current.isLoading).toBe(false);
@@ -51,10 +52,11 @@ describe('useCurrencies', () => {
51
52
  it('should filter currencies by collection address', async () => {
52
53
  const args = {
53
54
  ...defaultArgs,
54
- collectionAddress: mockConfig.collections[1].address,
55
- } satisfies Parameters<typeof useCurrencies>[0];
55
+ collectionAddress: mockConfig.marketCollections[1]
56
+ .itemsAddress as Address,
57
+ } satisfies Parameters<typeof useMarketCurrencies>[0];
56
58
 
57
- const { result } = renderHook(() => useCurrencies(args));
59
+ const { result } = renderHook(() => useMarketCurrencies(args));
58
60
 
59
61
  await waitFor(() => {
60
62
  expect(result.current.isLoading).toBe(false);
@@ -64,7 +66,7 @@ describe('useCurrencies', () => {
64
66
  (c) => c.contractAddress,
65
67
  );
66
68
  expect(currencyAddresses).toEqual(
67
- mockConfig.collections[1].currencyOptions,
69
+ mockConfig.marketCollections[1].currencyOptions,
68
70
  );
69
71
  });
70
72
 
@@ -79,7 +81,7 @@ describe('useCurrencies', () => {
79
81
  }),
80
82
  );
81
83
 
82
- const { result } = renderHook(() => useCurrencies(defaultArgs));
84
+ const { result } = renderHook(() => useMarketCurrencies(defaultArgs));
83
85
 
84
86
  await waitFor(() => {
85
87
  expect(result.current.isError).toBe(true);
@@ -90,7 +92,9 @@ describe('useCurrencies', () => {
90
92
  });
91
93
 
92
94
  it('should refetch when chainId changes', async () => {
93
- const { result, rerender } = renderHook(() => useCurrencies(defaultArgs));
95
+ const { result, rerender } = renderHook(() =>
96
+ useMarketCurrencies(defaultArgs),
97
+ );
94
98
 
95
99
  // Wait for initial data
96
100
  await waitFor(() => {
@@ -103,7 +107,7 @@ describe('useCurrencies', () => {
103
107
  chainId: 5,
104
108
  };
105
109
 
106
- rerender(() => useCurrencies(newArgs));
110
+ rerender(() => useMarketCurrencies(newArgs));
107
111
 
108
112
  // Wait for new data
109
113
  await waitFor(() => {
@@ -123,7 +127,7 @@ describe('useCurrencies', () => {
123
127
  },
124
128
  };
125
129
 
126
- const { result } = renderHook(() => useCurrencies(argsWithQuery));
130
+ const { result } = renderHook(() => useMarketCurrencies(argsWithQuery));
127
131
 
128
132
  // Should not fetch when disabled
129
133
  expect(result.current.isLoading).toBe(false);
@@ -137,7 +141,9 @@ describe('useCurrencies', () => {
137
141
  currencyOptions: [USDC_ADDRESS],
138
142
  };
139
143
 
140
- const { result } = renderHook(() => useCurrencies(argsWithCombinedFilters));
144
+ const { result } = renderHook(() =>
145
+ useMarketCurrencies(argsWithCombinedFilters),
146
+ );
141
147
 
142
148
  await waitFor(() => {
143
149
  expect(result.current.isLoading).toBe(false);
@@ -168,9 +174,9 @@ describe('useCurrencies', () => {
168
174
  ...defaultArgs,
169
175
  includeNativeCurrency: false,
170
176
  collectionAddress: '0x1234567890123456789012345678901234567890',
171
- } satisfies Parameters<typeof useCurrencies>[0];
177
+ } satisfies Parameters<typeof useMarketCurrencies>[0];
172
178
 
173
- const { result } = renderHook(() => useCurrencies(args));
179
+ const { result } = renderHook(() => useMarketCurrencies(args));
174
180
 
175
181
  await waitFor(() => {
176
182
  expect(result.current.isLoading).toBe(false);