@mercurjs/admin 2.1.6 → 2.2.0-canary.11

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 (338) hide show
  1. package/dist/[id]-BAPEFPAO.js +505 -0
  2. package/dist/{add-campaign-promotions-6Z2STQT4.js → add-campaign-promotions-KOGSYV2W.js} +14 -16
  3. package/dist/{adjust-inventory-NVBPZYOF.js → adjust-inventory-3IQ657W2.js} +15 -15
  4. package/dist/{api-key-management-create-THDCXGWK.js → api-key-management-create-UD5V7TOU.js} +3 -3
  5. package/dist/{api-key-management-detail-IRYR6J2I.js → api-key-management-detail-NBNHERF6.js} +27 -27
  6. package/dist/{api-key-management-edit-LTVNXP6T.js → api-key-management-edit-4TLKJSAE.js} +3 -3
  7. package/dist/{api-key-management-list-4WCDP4B3.js → api-key-management-list-SZUSD6UI.js} +11 -13
  8. package/dist/{api-key-management-sales-channels-NVFG2ESH.js → api-key-management-sales-channels-TK6XEGF3.js} +15 -15
  9. package/dist/attribute-create-IKTP5XRS.js +583 -0
  10. package/dist/attribute-create-possible-value-EXVHC272.js +476 -0
  11. package/dist/{attribute-detail-R26GDX7Q.js → attribute-detail-V4QI34FV.js} +78 -69
  12. package/dist/attribute-edit-LUY66TG3.js +183 -0
  13. package/dist/attribute-edit-possible-value-IOS3625C.js +164 -0
  14. package/dist/{attribute-edit-ranking-CEBR5LJ7.js → attribute-edit-ranking-7AAAYEC7.js} +66 -61
  15. package/dist/{attribute-list-XR7OSL2H.js → attribute-list-EMPHZ32M.js} +26 -29
  16. package/dist/{campaign-create-AZTR5UZP.js → campaign-create-VFFIIRE4.js} +5 -5
  17. package/dist/{campaign-detail-TCPO6DTI.js → campaign-detail-QY3AALUR.js} +29 -31
  18. package/dist/{campaign-list-DCLVAFEM.js → campaign-list-NQGNOFVZ.js} +10 -12
  19. package/dist/{categories-metadata-YVUNHMQT.js → categories-metadata-Z5JAWPAK.js} +19 -19
  20. package/dist/{category-create-DG3Z5RYE.js → category-create-GMCJABRW.js} +4 -4
  21. package/dist/{category-detail-K2UNFPRV.js → category-detail-IP5EPIUR.js} +32 -32
  22. package/dist/{category-edit-IXU6E3YT.js → category-edit-GLE4NTFG.js} +5 -5
  23. package/dist/{category-list-2MG37UXJ.js → category-list-SNVOQ64L.js} +11 -13
  24. package/dist/{category-organize-CCX2INRS.js → category-organize-UY4M4N7S.js} +2 -2
  25. package/dist/{category-products-LKT7564A.js → category-products-HWXJR7KR.js} +32 -32
  26. package/dist/{chunk-FSPZYOY6.js → chunk-2OF7GB7J.js} +4 -4
  27. package/dist/{chunk-W576GZBG.js → chunk-3AO6X4CE.js} +9 -9
  28. package/dist/{chunk-MANWKYT3.js → chunk-3HY4I76Q.js} +139 -204
  29. package/dist/{chunk-7YHAFHGI.js → chunk-3JSAS7QP.js} +92 -165
  30. package/dist/chunk-3VDLE5GA.js +87 -0
  31. package/dist/{chunk-GJPGL7RP.js → chunk-3VTAK3S6.js} +108 -28
  32. package/dist/{chunk-VIGX66F7.js → chunk-3XSC3NEG.js} +14 -1
  33. package/dist/{chunk-DBNPVU3L.js → chunk-453BC56K.js} +1 -1
  34. package/dist/{chunk-N23OD7WS.js → chunk-4GFS57XI.js} +7 -7
  35. package/dist/{chunk-EWMEXGFZ.js → chunk-4PU6GDCE.js} +19 -19
  36. package/dist/{chunk-C3WE6EFO.js → chunk-4YWKKCTT.js} +1 -2
  37. package/dist/chunk-533GMKEG.js +125 -0
  38. package/dist/{chunk-CEG375CR.js → chunk-5AZCIOS4.js} +4 -4
  39. package/dist/{chunk-X3YEY2PY.js → chunk-5FFZQPTT.js} +11 -11
  40. package/dist/{chunk-AEFDAU3Y.js → chunk-5KGMGL4N.js} +4 -24
  41. package/dist/chunk-5UPOHLBD.js +213 -0
  42. package/dist/{chunk-6676HWGI.js → chunk-623TMW36.js} +4 -4
  43. package/dist/{chunk-DL2ZIXBO.js → chunk-6FHQCLHQ.js} +1 -1
  44. package/dist/{chunk-WIQ2HBJG.js → chunk-72PLRAWM.js} +13 -13
  45. package/dist/{chunk-3IBSB2U6.js → chunk-7KZ5X5SU.js} +14 -14
  46. package/dist/chunk-7MMLCMV3.js +142 -0
  47. package/dist/{chunk-VGM5UQRA.js → chunk-A62MTLPR.js} +806 -327
  48. package/dist/{chunk-35Q6JF3S.js → chunk-A7JOHU6Q.js} +4 -4
  49. package/dist/{chunk-ARMGWHYU.js → chunk-ABWW3JHS.js} +19 -19
  50. package/dist/{chunk-UXD3VNBO.js → chunk-AJLGY3LQ.js} +1 -2
  51. package/dist/{chunk-HY3CV5V6.js → chunk-AKTAFKIU.js} +4 -4
  52. package/dist/{chunk-V7EPLR3E.js → chunk-BFT3CN5L.js} +10 -10
  53. package/dist/{chunk-HGULM6DF.js → chunk-BGQ7H2KL.js} +10 -10
  54. package/dist/{chunk-SOJ4TLWP.js → chunk-BPCU5QJE.js} +5 -5
  55. package/dist/{chunk-F67RRVMJ.js → chunk-BQ6ZDY6L.js} +13 -13
  56. package/dist/{chunk-GXRLLA5H.js → chunk-CKD5563X.js} +4 -4
  57. package/dist/{chunk-E3DLJSYD.js → chunk-COP7NFSJ.js} +1 -1
  58. package/dist/{chunk-ABUQBBEM.js → chunk-CVFVEDMV.js} +4 -4
  59. package/dist/{chunk-6A7MR5NS.js → chunk-CVZA23ES.js} +11 -11
  60. package/dist/{chunk-7MTFPHXR.js → chunk-CYGCCNIC.js} +8 -8
  61. package/dist/{chunk-6MJ5HPIP.js → chunk-D2VXOF46.js} +6 -6
  62. package/dist/{chunk-OQMBWJPH.js → chunk-DELK6EWH.js} +13 -187
  63. package/dist/{chunk-N57BOIPU.js → chunk-DJWOIRLV.js} +1 -1
  64. package/dist/{chunk-Z2QQZOG3.js → chunk-DN2K5EAH.js} +1 -1
  65. package/dist/{chunk-UEEYZGM3.js → chunk-DRJAKRTI.js} +46 -17
  66. package/dist/chunk-EBYWGIOR.js +334 -0
  67. package/dist/{chunk-MMEZWZXV.js → chunk-EGTH3PUK.js} +20 -20
  68. package/dist/{chunk-4LQX5FRH.js → chunk-EMQP2CNF.js} +5 -5
  69. package/dist/{chunk-WRRMBJBQ.js → chunk-ENFXIYIH.js} +1 -1
  70. package/dist/{chunk-KHHMQM2L.js → chunk-EYFWEKFJ.js} +5 -5
  71. package/dist/chunk-F52JLHE3.js +2051 -0
  72. package/dist/{chunk-MNYDJXTM.js → chunk-FB7DDNCA.js} +5 -5
  73. package/dist/{chunk-BEU674HI.js → chunk-FDD7TANX.js} +5 -5
  74. package/dist/{chunk-GZBVMHXS.js → chunk-FFNSWUDC.js} +10 -10
  75. package/dist/{chunk-Y3FXVIJO.js → chunk-FNKBJCNF.js} +6 -6
  76. package/dist/{chunk-GAD5DQOY.js → chunk-G5DQCCPL.js} +2 -2
  77. package/dist/{chunk-35NDMIYZ.js → chunk-GVEF6UDT.js} +1 -1
  78. package/dist/{chunk-5CK6XEFV.js → chunk-H3MAUKL7.js} +174 -118
  79. package/dist/{chunk-B6SYYKJI.js → chunk-HDOWEXDH.js} +13 -13
  80. package/dist/{chunk-Z4WRKGME.js → chunk-HEGPAGJT.js} +11 -11
  81. package/dist/{chunk-63OSYRLS.js → chunk-HR7TFO2X.js} +4 -4
  82. package/dist/{chunk-4Q7LZQVY.js → chunk-IAWZQKUH.js} +10 -10
  83. package/dist/chunk-IIFQ7KYL.js +171 -0
  84. package/dist/{chunk-DVKO4VRC.js → chunk-IQZ3T2Q4.js} +12 -12
  85. package/dist/{chunk-Y2M536WR.js → chunk-JHBNG7OD.js} +17 -0
  86. package/dist/{chunk-LNAXUDW2.js → chunk-JSH7JEKY.js} +60 -62
  87. package/dist/chunk-JSMUFZZN.js +101 -0
  88. package/dist/{chunk-X4DGVTMC.js → chunk-K4WU4PVL.js} +5 -5
  89. package/dist/{chunk-MWX5JCOM.js → chunk-KT7X72J4.js} +161 -172
  90. package/dist/{chunk-R46PKJUT.js → chunk-KXIA66EJ.js} +13 -13
  91. package/dist/{chunk-2OYCT5NO.js → chunk-LGL4QSGB.js} +6 -6
  92. package/dist/{chunk-PBQ5M44A.js → chunk-LJDGVBOQ.js} +11 -47
  93. package/dist/chunk-LO2ZWQGL.js +6 -0
  94. package/dist/{chunk-VVWB3GIK.js → chunk-LYZDVZWA.js} +3 -12
  95. package/dist/{chunk-SPIVEW2Y.js → chunk-M572YFDA.js} +8 -8
  96. package/dist/{chunk-4ZN3D4YS.js → chunk-MEXH366L.js} +9 -9
  97. package/dist/{chunk-MKA5JWE6.js → chunk-MR3MLNWV.js} +35 -35
  98. package/dist/{chunk-SJQG3RCN.js → chunk-MVDPDVMI.js} +19 -19
  99. package/dist/{chunk-J24X54DB.js → chunk-MVNO35S5.js} +7 -7
  100. package/dist/{chunk-XBHUWCBD.js → chunk-N4GJRJF5.js} +1 -1
  101. package/dist/{chunk-34I4QIBD.js → chunk-N6YOACEW.js} +1 -1
  102. package/dist/{chunk-NEN6KWAJ.js → chunk-N7OVIX55.js} +12 -12
  103. package/dist/{chunk-6YGOXPB5.js → chunk-NGDOLGBQ.js} +21 -9
  104. package/dist/{chunk-YKDEE7ZL.js → chunk-NJP3DEE5.js} +1 -1
  105. package/dist/{chunk-HKDFWQ6Q.js → chunk-NQEXDLYH.js} +460 -2
  106. package/dist/{chunk-AZAGUAN4.js → chunk-O2XHQTBX.js} +15 -15
  107. package/dist/{chunk-3IN6MMKV.js → chunk-OFOKVLV3.js} +2 -2
  108. package/dist/chunk-OMBP3YSV.js +165 -0
  109. package/dist/{chunk-B6FG7A6W.js → chunk-P5XVG4PY.js} +1 -1
  110. package/dist/{chunk-LFATSJPO.js → chunk-PASEZJC7.js} +9 -9
  111. package/dist/chunk-PT5PLV3N.js +78 -0
  112. package/dist/{chunk-4IZ2RD3L.js → chunk-PXKDYD3M.js} +8 -8
  113. package/dist/chunk-PYDRHQTY.js +24 -0
  114. package/dist/{chunk-XB3HXEZB.js → chunk-QLEGHL2Q.js} +78 -73
  115. package/dist/{chunk-3B6MTW5G.js → chunk-QUHSHIAC.js} +3 -0
  116. package/dist/{chunk-3DOCALSU.js → chunk-QUPUWR42.js} +395 -11
  117. package/dist/{chunk-NRJ7F7JW.js → chunk-R7ESTJHN.js} +14 -14
  118. package/dist/{chunk-7QWLLYOY.js → chunk-RQPDD3RI.js} +1 -1
  119. package/dist/{chunk-JCSPXBS3.js → chunk-SJGIQGEC.js} +1 -1
  120. package/dist/{chunk-3ZSYFPHB.js → chunk-SUVFPJ4J.js} +19 -19
  121. package/dist/{chunk-YEUUI6JF.js → chunk-TE4IF3MM.js} +1 -1
  122. package/dist/{chunk-OVEBN3NC.js → chunk-TZDRRTAX.js} +5 -5
  123. package/dist/{chunk-HNUA6XIW.js → chunk-UCX2T4BQ.js} +14 -14
  124. package/dist/{chunk-GZMXTNDN.js → chunk-UCYSCKZV.js} +1432 -1380
  125. package/dist/chunk-UIVWOKWT.js +63 -0
  126. package/dist/{chunk-3T5S5RDO.js → chunk-UXGLM3B4.js} +4 -4
  127. package/dist/{chunk-UYO5Y4JI.js → chunk-VT5E7OMM.js} +11 -11
  128. package/dist/{chunk-TAKEQAZZ.js → chunk-VT6QIVZW.js} +0 -93
  129. package/dist/{chunk-5ZBQICCP.js → chunk-VY7PT4SI.js} +15 -15
  130. package/dist/{chunk-O5YFLNSQ.js → chunk-W3FDZPPF.js} +101 -290
  131. package/dist/chunk-W6CW4WHC.js +1755 -0
  132. package/dist/{chunk-ORI7UXS6.js → chunk-W6V2L2FX.js} +6 -6
  133. package/dist/chunk-WPVDACTL.js +60 -0
  134. package/dist/{chunk-5OS2MBRB.js → chunk-WTK4MLMF.js} +8 -8
  135. package/dist/{chunk-GDHF6CT5.js → chunk-X45JKZYW.js} +11 -11
  136. package/dist/{chunk-PIZ7FN3L.js → chunk-X7H7TIOT.js} +16 -16
  137. package/dist/{chunk-GKJLFLGN.js → chunk-XJ3WC4G7.js} +4 -4
  138. package/dist/{chunk-SESTTUVM.js → chunk-YN3FGNJM.js} +53 -1
  139. package/dist/{chunk-S4SVK5DE.js → chunk-YVLANFBK.js} +29 -1
  140. package/dist/{chunk-U7WZYWGA.js → chunk-Z5T5EPLF.js} +1 -1
  141. package/dist/{chunk-M73MP4NC.js → chunk-ZO7A6VYP.js} +19 -19
  142. package/dist/{collection-add-products-IRYJ6U6P.js → collection-add-products-ABWXUOFD.js} +32 -32
  143. package/dist/{collection-create-3BTRORHU.js → collection-create-BRMP6SIZ.js} +2 -2
  144. package/dist/{collection-detail-263PM4DL.js → collection-detail-AMGR2B5N.js} +30 -30
  145. package/dist/{collection-edit-L5GPFBBX.js → collection-edit-YLWUEU4C.js} +2 -2
  146. package/dist/{collection-list-CEU2EZ6K.js → collection-list-6HZE43AC.js} +38 -40
  147. package/dist/{collection-metadata-KHGPTV5C.js → collection-metadata-JS5QP3GD.js} +19 -19
  148. package/dist/{commission-rate-create-U3XQ4S27.js → commission-rate-create-PSPSJZR5.js} +57 -58
  149. package/dist/{commission-rate-detail-MY3F2RHR.js → commission-rate-detail-U72E4ZIO.js} +20 -20
  150. package/dist/{commission-rate-edit-MPEWXGTE.js → commission-rate-edit-7NJPABVA.js} +57 -58
  151. package/dist/{commission-rate-list-JPBOTOTA.js → commission-rate-list-Y5XLEO67.js} +8 -10
  152. package/dist/{constants-CAwtRicB.d.ts → constants-Bahlh59D.d.ts} +8 -4
  153. package/dist/{customer-detail-2QBJPF7S.js → customer-detail-2RWBN6C4.js} +30 -32
  154. package/dist/{customer-group-add-customers-JCLAH45C.js → customer-group-add-customers-VJUBEN7M.js} +13 -15
  155. package/dist/{customer-group-detail-BDKFWKTI.js → customer-group-detail-ED66F7JM.js} +26 -28
  156. package/dist/{customer-group-list-3NEEJXQH.js → customer-group-list-6YUFKBHH.js} +26 -28
  157. package/dist/{customer-group-metadata-YJXZFSFG.js → customer-group-metadata-VQUOWR3P.js} +19 -19
  158. package/dist/{customer-list-ZIFNZXO4.js → customer-list-MB6WZFMA.js} +11 -13
  159. package/dist/{customer-metadata-SG6M7X3Q.js → customer-metadata-47AVJXRI.js} +19 -19
  160. package/dist/{customers-add-customer-group-OQIFQZBL.js → customers-add-customer-group-HI7J7YKN.js} +29 -31
  161. package/dist/{edit-inventory-item-TDG2ZTPM.js → edit-inventory-item-MBPSBJL4.js} +15 -15
  162. package/dist/{edit-inventory-item-attributes-T56PJTCT.js → edit-inventory-item-attributes-RVYWOFAC.js} +15 -15
  163. package/dist/{edit-reservation-T6SKOG2F.js → edit-reservation-7BLGYXCJ.js} +5 -5
  164. package/dist/{edit-rules-4AHZQGCX.js → edit-rules-ZWDKM5M3.js} +19 -18
  165. package/dist/index.d.ts +2 -2
  166. package/dist/index.js +792 -632
  167. package/dist/{inventory-create-P26OGAHD.js → inventory-create-Q4VBPXSG.js} +22 -22
  168. package/dist/{inventory-detail-7W7UUWNT.js → inventory-detail-6CKO3A3Y.js} +28 -30
  169. package/dist/{inventory-list-PA4B4RWY.js → inventory-list-2JGX6BRI.js} +10 -12
  170. package/dist/{inventory-metadata-LUGA3KNV.js → inventory-metadata-COGGE5ZR.js} +19 -19
  171. package/dist/{inventory-stock-UZSYXXPX.js → inventory-stock-2QIKS7LE.js} +204 -42
  172. package/dist/loader-OU7SKXOD.js +28 -0
  173. package/dist/{location-detail-RUC2ZP3K.js → location-detail-HOCNTQ7K.js} +24 -24
  174. package/dist/{location-fulfillment-providers-WDET6TJP.js → location-fulfillment-providers-YQ2XFPAJ.js} +38 -39
  175. package/dist/{location-list-R7EECG5Z.js → location-list-I2UMU25V.js} +21 -22
  176. package/dist/{location-sales-channels-IS6E3I4S.js → location-sales-channels-GKIWX6B2.js} +12 -12
  177. package/dist/{location-service-zone-create-HAQVVTKP.js → location-service-zone-create-ZS3UWJAA.js} +8 -11
  178. package/dist/{location-service-zone-manage-areas-5LCENMAM.js → location-service-zone-manage-areas-S7QZTIFT.js} +8 -11
  179. package/dist/{location-service-zone-shipping-option-create-FV5Y2PNB.js → location-service-zone-shipping-option-create-6GYLJHEC.js} +25 -24
  180. package/dist/{location-service-zone-shipping-option-edit-PLEDWIY3.js → location-service-zone-shipping-option-edit-3PGSNKYT.js} +8 -7
  181. package/dist/{location-service-zone-shipping-option-pricing-6QHLZ6IN.js → location-service-zone-shipping-option-pricing-POBJOF3Z.js} +13 -13
  182. package/dist/{login-EWHQY6G3.js → login-N7CVSQNG.js} +15 -15
  183. package/dist/{manage-locations-TU5HCIKG.js → manage-locations-TKLOHP3D.js} +1 -1
  184. package/dist/{marketplace-add-currencies-PB73MHM6.js → marketplace-add-currencies-6ANNBGZM.js} +8 -10
  185. package/dist/{marketplace-detail-3KFGJWQ7.js → marketplace-detail-K52ALYGT.js} +27 -29
  186. package/dist/{marketplace-edit-U5B6WA56.js → marketplace-edit-6Q3G2OY5.js} +5 -4
  187. package/dist/{marketplace-metadata-VYCPYFJD.js → marketplace-metadata-ZSX3IQF4.js} +22 -22
  188. package/dist/offers-UBD6NICA.js +442 -0
  189. package/dist/{order-create-claim-R2SX6YUS.js → order-create-claim-OVHMMR3J.js} +284 -293
  190. package/dist/{order-create-edit-AONQC3TO.js → order-create-edit-HEOYCYZO.js} +216 -155
  191. package/dist/{order-create-exchange-7KKMJHXE.js → order-create-exchange-L56VKQBL.js} +291 -271
  192. package/dist/{order-create-refund-KWYYLAED.js → order-create-refund-UTJKJ3AJ.js} +23 -23
  193. package/dist/{order-create-return-BQFRANNG.js → order-create-return-FLGYGUTQ.js} +66 -41
  194. package/dist/{order-detail-BITJD73H.js → order-detail-KAB4MV7X.js} +34 -37
  195. package/dist/{order-edit-billing-address-FLEI4VDB.js → order-edit-billing-address-RUURVISC.js} +18 -18
  196. package/dist/{order-edit-email-AZIA6X5Q.js → order-edit-email-OO7AMRHC.js} +17 -17
  197. package/dist/{order-edit-shipping-address-GJMUSOPK.js → order-edit-shipping-address-BRRXUE76.js} +17 -17
  198. package/dist/{order-list-O7C7ENXI.js → order-list-S3AJC6L5.js} +26 -28
  199. package/dist/{order-metadata-RXIJOP4V.js → order-metadata-OHK6TPAO.js} +20 -20
  200. package/dist/{order-request-transfer-6IZVCHGV.js → order-request-transfer-YLMXC7NL.js} +19 -18
  201. package/dist/pages/index.d.ts +562 -706
  202. package/dist/pages/index.js +202 -205
  203. package/dist/{payout-detail-JWS2Q4TY.js → payout-detail-TWO6HN4E.js} +3 -3
  204. package/dist/{payout-list-PW6BFT4O.js → payout-list-7WJZFNW5.js} +9 -11
  205. package/dist/{price-list-configuration-N5D5OFXX.js → price-list-configuration-Q5H22ZE2.js} +13 -15
  206. package/dist/{price-list-create-NQFC2JIJ.js → price-list-create-OYAVGRM5.js} +37 -37
  207. package/dist/{price-list-detail-HRVLVBPS.js → price-list-detail-Q4GFFUFG.js} +32 -32
  208. package/dist/{price-list-edit-BVVLQ5WV.js → price-list-edit-YY4SXEI3.js} +5 -5
  209. package/dist/{price-list-list-K4IJFZYH.js → price-list-list-OIOY43TF.js} +13 -15
  210. package/dist/{price-list-prices-add-WXEGEWRA.js → price-list-prices-add-KONZVSVQ.js} +33 -33
  211. package/dist/{price-list-prices-edit-KJEKS6TL.js → price-list-prices-edit-SMUKU7Q6.js} +24 -24
  212. package/dist/product-add-existing-attributes-GGRRNFDK.js +456 -0
  213. package/dist/{product-attributes-ASPKDH7H.js → product-attributes-C3KHQF2I.js} +4 -4
  214. package/dist/product-bulk-edit-J3CMBZN2.js +285 -0
  215. package/dist/{product-create-BDQ66ECX.js → product-create-UR5OFGUY.js} +38 -39
  216. package/dist/product-create-attribute-XARMC6FJ.js +224 -0
  217. package/dist/product-create-variant-6VUKYLWE.js +20 -0
  218. package/dist/{product-detail-DCHR4B4T.js → product-detail-OLFVJZ7T.js} +26 -30
  219. package/dist/{product-edit-IASCMBET.js → product-edit-F4CKOIUO.js} +13 -8
  220. package/dist/product-edit-attribute-LG2ZM6HQ.js +175 -0
  221. package/dist/{product-list-X72QPKOK.js → product-list-2BWYAATR.js} +33 -33
  222. package/dist/{product-media-VNSFLCSH.js → product-media-EUDMCJ75.js} +16 -9
  223. package/dist/{product-metadata-GJ7C2UJG.js → product-metadata-5WVNFCRL.js} +22 -22
  224. package/dist/{product-organization-PN22LYKQ.js → product-organization-BFWDCHP4.js} +18 -18
  225. package/dist/{product-sales-channels-J2ZNRKZT.js → product-sales-channels-WKQSYOEX.js} +15 -15
  226. package/dist/{product-shipping-profile-G7UPGWYK.js → product-shipping-profile-WDLKA2SN.js} +6 -5
  227. package/dist/{product-tag-create-PHJICTE4.js → product-tag-create-KQSVCWMC.js} +15 -15
  228. package/dist/{product-tag-detail-4CKJMGHR.js → product-tag-detail-CWDAY7F3.js} +54 -55
  229. package/dist/{product-tag-edit-G4UNGXPT.js → product-tag-edit-B4SIZCUK.js} +15 -15
  230. package/dist/{product-tag-list-WQLWIZZW.js → product-tag-list-2OK3OCMZ.js} +54 -55
  231. package/dist/{product-tag-metadata-I4V6CR6Z.js → product-tag-metadata-MASTMIKE.js} +19 -19
  232. package/dist/{product-type-detail-7GHH4ACU.js → product-type-detail-3X7ZTZJN.js} +30 -30
  233. package/dist/{product-type-list-LTYTTF4F.js → product-type-list-TM26QMHR.js} +12 -14
  234. package/dist/{product-type-metadata-KGVRMMTQ.js → product-type-metadata-6BKTQHQC.js} +19 -19
  235. package/dist/{product-variant-detail-PHGVJWUV.js → product-variant-detail-PQ4RKPZT.js} +23 -43
  236. package/dist/product-variant-edit-TLF475SH.js +776 -0
  237. package/dist/{product-variant-metadata-HV72UBCP.js → product-variant-metadata-3M72B3PM.js} +19 -19
  238. package/dist/{profile-detail-UQTGEFYF.js → profile-detail-ZRL5SERS.js} +4 -4
  239. package/dist/{promotion-add-campaign-M4OT6URB.js → promotion-add-campaign-S3JJSFHT.js} +8 -7
  240. package/dist/{promotion-create-GM37OXEW.js → promotion-create-OKZBUSJD.js} +25 -24
  241. package/dist/{promotion-detail-PDBRQII7.js → promotion-detail-MMNEDRXD.js} +23 -23
  242. package/dist/{promotion-list-XW4PNLJF.js → promotion-list-DHWW7FTI.js} +13 -15
  243. package/dist/{refund-reason-create-M2CYTCEM.js → refund-reason-create-N4DZ4UHS.js} +15 -15
  244. package/dist/{refund-reason-edit-M4XBV633.js → refund-reason-edit-OAHRDKXW.js} +15 -15
  245. package/dist/{refund-reason-list-OXBLAGYO.js → refund-reason-list-YLH4LD4S.js} +40 -39
  246. package/dist/{region-add-countries-T4XZ2CU3.js → region-add-countries-COXN4LP3.js} +7 -9
  247. package/dist/{region-create-MQXTWBKC.js → region-create-P66Q65XY.js} +14 -15
  248. package/dist/{region-detail-6OFP76OY.js → region-detail-P2HHBYFV.js} +11 -13
  249. package/dist/{region-edit-QNJ2HT76.js → region-edit-XFE54SAO.js} +8 -7
  250. package/dist/{region-list-EYTDREE2.js → region-list-2XXKCDDX.js} +11 -13
  251. package/dist/{region-metadata-4JWOEGTZ.js → region-metadata-BJSTTZFL.js} +22 -22
  252. package/dist/{reservation-create-26QAWABA.js → reservation-create-TXYAY3KF.js} +2 -2
  253. package/dist/{reservation-detail-G26K6HZV.js → reservation-detail-CEENG76D.js} +23 -23
  254. package/dist/{reservation-list-CHHR6CEV.js → reservation-list-SORWYHI4.js} +11 -13
  255. package/dist/{reservation-metadata-JFLJ27A3.js → reservation-metadata-G3QBZF4K.js} +22 -22
  256. package/dist/{reset-password-S6IBWG47.js → reset-password-QGQ4GAHK.js} +1 -1
  257. package/dist/{return-reason-list-65LQDOZB.js → return-reason-list-7HTIV7NK.js} +28 -29
  258. package/dist/{sales-channel-add-products-FH7B7UYR.js → sales-channel-add-products-3VZ5SLLP.js} +33 -33
  259. package/dist/{sales-channel-create-NSZEHGZE.js → sales-channel-create-XBR3QESI.js} +2 -2
  260. package/dist/{sales-channel-detail-KCS472HN.js → sales-channel-detail-PHRSKCNM.js} +30 -30
  261. package/dist/{sales-channel-edit-W6Z2ERBJ.js → sales-channel-edit-ILBZBQP4.js} +2 -2
  262. package/dist/{sales-channel-list-6HBRUZ2Z.js → sales-channel-list-3GCESYAM.js} +23 -23
  263. package/dist/{sales-channel-metadata-NDSKXOGH.js → sales-channel-metadata-HVPGS756.js} +19 -19
  264. package/dist/{shipping-option-type-create-MEL24PGH.js → shipping-option-type-create-3ZKT7WAC.js} +15 -15
  265. package/dist/{shipping-option-type-detail-IS7CNAYI.js → shipping-option-type-detail-IYXWAK7F.js} +21 -21
  266. package/dist/{shipping-option-type-edit-IVBHURXR.js → shipping-option-type-edit-QRXYNNRW.js} +15 -15
  267. package/dist/{shipping-option-type-list-BTPCLBSD.js → shipping-option-type-list-MLIDCA3L.js} +26 -28
  268. package/dist/{shipping-profile-detail-L3IHPGLL.js → shipping-profile-detail-YAKZHWZI.js} +5 -5
  269. package/dist/{shipping-profile-metadata-UZPX2PHJ.js → shipping-profile-metadata-T4HPNTLH.js} +21 -21
  270. package/dist/{shipping-profiles-list-2JKVMEZG.js → shipping-profiles-list-JF2SQIQ7.js} +9 -11
  271. package/dist/{store-bulk-edit-WBBPQAAC.js → store-bulk-edit-BNF3HH5K.js} +7 -7
  272. package/dist/{store-create-OQVFVIK4.js → store-create-KFLNOD73.js} +18 -18
  273. package/dist/{store-details-NRNZNKBY.js → store-details-E347PHAN.js} +47 -62
  274. package/dist/{store-edit-PZWUMDFA.js → store-edit-Y6NLBIOP.js} +14 -14
  275. package/dist/{store-list-GWOYTUBA.js → store-list-S2L44OLB.js} +39 -41
  276. package/dist/{store-member-invite-Z5S63WYE.js → store-member-invite-J5XSPWMW.js} +3 -3
  277. package/dist/{tax-region-create-5DDZ23QQ.js → tax-region-create-MIDQXQS4.js} +18 -17
  278. package/dist/{tax-region-detail-VNBNS7FS.js → tax-region-detail-AC7B3G57.js} +28 -29
  279. package/dist/{tax-region-edit-OARZRBVK.js → tax-region-edit-5CORTHTC.js} +17 -16
  280. package/dist/{tax-region-list-WCHVLVVC.js → tax-region-list-FIBHEFVD.js} +9 -9
  281. package/dist/{tax-region-metadata-XJRFOG7I.js → tax-region-metadata-QQZIQPAD.js} +19 -19
  282. package/dist/{tax-region-province-detail-MXYZMUX7.js → tax-region-province-detail-2MGX7LEO.js} +26 -27
  283. package/dist/{tax-region-tax-override-create-LGST6PD7.js → tax-region-tax-override-create-IONGD4TG.js} +57 -58
  284. package/dist/{tax-region-tax-override-edit-5XNWTGDS.js → tax-region-tax-override-edit-RIT6YRVK.js} +57 -58
  285. package/dist/{user-detail-LGIMHLY4.js → user-detail-MMVBN3AE.js} +6 -6
  286. package/dist/{user-invite-ZZSWFXFM.js → user-invite-HLZJ7FST.js} +14 -16
  287. package/dist/{user-list-5QJJS7EA.js → user-list-TR7RSGUO.js} +9 -11
  288. package/dist/{user-metadata-376YJMY3.js → user-metadata-OZLU3Y2X.js} +19 -19
  289. package/package.json +5 -5
  290. package/dist/attribute-create-EAOQ6KT6.js +0 -1010
  291. package/dist/attribute-create-possible-value-BIU2L7AN.js +0 -437
  292. package/dist/attribute-edit-DRHFOHMK.js +0 -282
  293. package/dist/attribute-edit-possible-value-G2ON2AE3.js +0 -264
  294. package/dist/chunk-2U5BRCQO.js +0 -170
  295. package/dist/chunk-33XUAKRP.js +0 -6
  296. package/dist/chunk-4GPAS5GW.js +0 -36
  297. package/dist/chunk-4ZTZTIIM.js +0 -69
  298. package/dist/chunk-7O5NDICV.js +0 -120
  299. package/dist/chunk-7XXM72CF.js +0 -679
  300. package/dist/chunk-IGTRIAUC.js +0 -84
  301. package/dist/chunk-KYPPQGGE.js +0 -467
  302. package/dist/chunk-LBXPX3XC.js +0 -1260
  303. package/dist/chunk-LO7XX5M7.js +0 -6
  304. package/dist/chunk-MXGDKEU5.js +0 -248
  305. package/dist/chunk-OG4WH7IW.js +0 -420
  306. package/dist/chunk-QOQSXNEF.js +0 -37
  307. package/dist/chunk-QSGR43JM.js +0 -30
  308. package/dist/chunk-RSBZREKG.js +0 -144
  309. package/dist/chunk-RXM4B6HR.js +0 -8
  310. package/dist/chunk-UM7ZR3VU.js +0 -14
  311. package/dist/chunk-WCEMRNW4.js +0 -6
  312. package/dist/chunk-Z5I2Z6L3.js +0 -160
  313. package/dist/chunk-ZMC7BKLT.js +0 -56
  314. package/dist/chunk-ZXYKF4A2.js +0 -2146
  315. package/dist/order-allocate-items-2B6T5JCK.js +0 -563
  316. package/dist/order-create-fulfillment-2FTTWTFE.js +0 -642
  317. package/dist/order-create-shipment-7XP6PDTD.js +0 -214
  318. package/dist/order-receive-return-JV3X7YHG.js +0 -562
  319. package/dist/product-create-option-B7SV42LO.js +0 -148
  320. package/dist/product-create-variant-7YAG2YRZ.js +0 -56
  321. package/dist/product-edit-option-KVTIY5NM.js +0 -156
  322. package/dist/product-export-YZ2XSXFN.js +0 -137
  323. package/dist/product-import-KOSPPCSW.js +0 -267
  324. package/dist/product-prices-HI4SOTMP.js +0 -267
  325. package/dist/product-stock-666D3AMJ.js +0 -544
  326. package/dist/product-variant-edit-L77HDGTA.js +0 -547
  327. package/dist/product-variant-manage-inventory-items-WENX2QCZ.js +0 -341
  328. package/dist/{chunk-XCANTVXS.js → chunk-CPXK5RSJ.js} +6 -6
  329. package/dist/{chunk-Y6NK6GBB.js → chunk-GP4J42UD.js} +5 -5
  330. package/dist/{chunk-L56WFGUN.js → chunk-IMR3MZDP.js} +3 -3
  331. package/dist/{chunk-OB4NOV4M.js → chunk-LYZT5REU.js} +3 -3
  332. package/dist/{chunk-ZBJ56XDB.js → chunk-Q2ULPJJ6.js} +3 -3
  333. package/dist/{chunk-KCYUY2AI.js → chunk-WQFFCK3R.js} +6 -6
  334. package/dist/{chunk-ZW34ZAIP.js → chunk-WYA62MUL.js} +8 -8
  335. package/dist/{chunk-56AUQBQX.js → chunk-YYMACYP6.js} +5 -5
  336. package/dist/{customer-edit-X4HQOUAE.js → customer-edit-JZ4PQTIN.js} +3 -3
  337. package/dist/{profile-edit-Y5UUUKVH.js → profile-edit-HQTWYWZ7.js} +6 -6
  338. package/dist/{promotion-edit-details-E2XKWY7L.js → promotion-edit-details-TKRC5HES.js} +6 -6
@@ -1,1260 +0,0 @@
1
- import {
2
- SidebarLink
3
- } from "./chunk-4GPAS5GW.js";
4
- import {
5
- getFormattedCountry
6
- } from "./chunk-W6Y3PPU5.js";
7
- import {
8
- PRODUCT_VARIANT_IDS_KEY
9
- } from "./chunk-33XUAKRP.js";
10
- import {
11
- ProductSellerSection
12
- } from "./chunk-QOQSXNEF.js";
13
- import {
14
- SectionRow
15
- } from "./chunk-3XPXUIK3.js";
16
- import {
17
- PRODUCT_DETAIL_QUERY
18
- } from "./chunk-35NDMIYZ.js";
19
- import {
20
- TwoColumnPage
21
- } from "./chunk-E74OUNA3.js";
22
- import {
23
- useDataTableDateColumns,
24
- useDataTableDateFilters
25
- } from "./chunk-54RTJBYO.js";
26
- import {
27
- DataTable
28
- } from "./chunk-OB4NOV4M.js";
29
- import {
30
- TwoColumnPageSkeleton
31
- } from "./chunk-INNFZYX2.js";
32
- import {
33
- ActionMenu
34
- } from "./chunk-BDGZ4EQO.js";
35
- import {
36
- useQueryParams
37
- } from "./chunk-THHRRYRS.js";
38
- import {
39
- useSalesChannels
40
- } from "./chunk-DL2ZIXBO.js";
41
- import {
42
- useDeleteProduct,
43
- useDeleteProductOption,
44
- useDeleteVariantLazy,
45
- useProduct,
46
- useProductVariants,
47
- useUpdateProduct
48
- } from "./chunk-5CK6XEFV.js";
49
-
50
- // src/pages/products/product-detail/product-detail.tsx
51
- import { Children } from "react";
52
- import { useLoaderData, useParams } from "react-router-dom";
53
-
54
- // src/pages/products/product-detail/components/product-attribute-section/product-attribute-section.tsx
55
- import { PencilSquare } from "@medusajs/icons";
56
- import { Container, Heading } from "@medusajs/ui";
57
- import { useTranslation } from "react-i18next";
58
- import { jsx, jsxs } from "react/jsx-runtime";
59
- var ProductAttributeSection = ({
60
- product
61
- }) => {
62
- const { t } = useTranslation();
63
- return /* @__PURE__ */ jsxs(Container, { className: "divide-y p-0", "data-testid": "product-attribute-section", children: [
64
- /* @__PURE__ */ jsxs(
65
- "div",
66
- {
67
- className: "flex items-center justify-between px-6 py-4",
68
- "data-testid": "product-attribute-header",
69
- children: [
70
- /* @__PURE__ */ jsx(Heading, { level: "h2", "data-testid": "product-attribute-title", children: t("products.attributes") }),
71
- /* @__PURE__ */ jsx(
72
- ActionMenu,
73
- {
74
- groups: [
75
- {
76
- actions: [
77
- {
78
- label: t("actions.edit"),
79
- to: "attributes",
80
- icon: /* @__PURE__ */ jsx(PencilSquare, {})
81
- }
82
- ]
83
- }
84
- ],
85
- "data-testid": "product-attribute-action-menu"
86
- }
87
- )
88
- ]
89
- }
90
- ),
91
- /* @__PURE__ */ jsx(
92
- SectionRow,
93
- {
94
- title: t("fields.height"),
95
- value: product.height,
96
- "data-testid": "product-height-row"
97
- }
98
- ),
99
- /* @__PURE__ */ jsx(
100
- SectionRow,
101
- {
102
- title: t("fields.width"),
103
- value: product.width,
104
- "data-testid": "product-width-row"
105
- }
106
- ),
107
- /* @__PURE__ */ jsx(
108
- SectionRow,
109
- {
110
- title: t("fields.length"),
111
- value: product.length,
112
- "data-testid": "product-length-row"
113
- }
114
- ),
115
- /* @__PURE__ */ jsx(
116
- SectionRow,
117
- {
118
- title: t("fields.weight"),
119
- value: product.weight,
120
- "data-testid": "product-weight-row"
121
- }
122
- ),
123
- /* @__PURE__ */ jsx(
124
- SectionRow,
125
- {
126
- title: t("fields.midCode"),
127
- value: product.mid_code,
128
- "data-testid": "product-mid-code-row"
129
- }
130
- ),
131
- /* @__PURE__ */ jsx(
132
- SectionRow,
133
- {
134
- title: t("fields.hsCode"),
135
- value: product.hs_code,
136
- "data-testid": "product-hs-code-row"
137
- }
138
- ),
139
- /* @__PURE__ */ jsx(
140
- SectionRow,
141
- {
142
- title: t("fields.countryOfOrigin"),
143
- value: getFormattedCountry(product.origin_country),
144
- "data-testid": "product-country-of-origin-row"
145
- }
146
- )
147
- ] });
148
- };
149
-
150
- // src/pages/products/product-detail/components/product-general-section/product-general-section.tsx
151
- import { PencilSquare as PencilSquare2, Trash } from "@medusajs/icons";
152
- import { Container as Container2, Heading as Heading2, StatusBadge, usePrompt } from "@medusajs/ui";
153
- import { useTranslation as useTranslation2 } from "react-i18next";
154
- import { useNavigate } from "react-router-dom";
155
- import { jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime";
156
- var productStatusColor = (status) => {
157
- switch (status) {
158
- case "draft":
159
- return "grey";
160
- case "proposed":
161
- return "orange";
162
- case "published":
163
- return "green";
164
- case "rejected":
165
- return "red";
166
- default:
167
- return "grey";
168
- }
169
- };
170
- var ProductGeneralSection = ({
171
- product
172
- }) => {
173
- const { t } = useTranslation2();
174
- const prompt = usePrompt();
175
- const navigate = useNavigate();
176
- const { mutateAsync } = useDeleteProduct(product.id);
177
- const handleDelete = async () => {
178
- const res = await prompt({
179
- title: t("general.areYouSure"),
180
- description: t("products.deleteWarning", {
181
- title: product.title
182
- }),
183
- confirmText: t("actions.delete"),
184
- cancelText: t("actions.cancel")
185
- });
186
- if (!res) {
187
- return;
188
- }
189
- await mutateAsync(void 0, {
190
- onSuccess: () => {
191
- navigate("..");
192
- }
193
- });
194
- };
195
- return /* @__PURE__ */ jsxs2(Container2, { className: "divide-y p-0", "data-testid": "product-general-section", children: [
196
- /* @__PURE__ */ jsxs2(
197
- "div",
198
- {
199
- className: "flex items-center justify-between px-6 py-4",
200
- "data-testid": "product-general-header",
201
- children: [
202
- /* @__PURE__ */ jsx2(Heading2, { "data-testid": "product-general-title", children: product.title }),
203
- /* @__PURE__ */ jsxs2(
204
- "div",
205
- {
206
- className: "flex items-center gap-x-4",
207
- "data-testid": "product-general-actions",
208
- children: [
209
- /* @__PURE__ */ jsx2(
210
- StatusBadge,
211
- {
212
- color: productStatusColor(product.status),
213
- "data-testid": "product-status-badge",
214
- children: t(`products.productStatus.${product.status}`)
215
- }
216
- ),
217
- /* @__PURE__ */ jsx2(
218
- ActionMenu,
219
- {
220
- groups: [
221
- {
222
- actions: [
223
- {
224
- label: t("actions.edit"),
225
- to: "edit",
226
- icon: /* @__PURE__ */ jsx2(PencilSquare2, {})
227
- }
228
- ]
229
- },
230
- {
231
- actions: [
232
- {
233
- label: t("actions.delete"),
234
- onClick: handleDelete,
235
- icon: /* @__PURE__ */ jsx2(Trash, {})
236
- }
237
- ]
238
- }
239
- ],
240
- "data-testid": "product-general-action-menu"
241
- }
242
- )
243
- ]
244
- }
245
- )
246
- ]
247
- }
248
- ),
249
- /* @__PURE__ */ jsx2(
250
- SectionRow,
251
- {
252
- title: t("fields.description"),
253
- value: product.description,
254
- "data-testid": "product-description-row"
255
- }
256
- ),
257
- /* @__PURE__ */ jsx2(
258
- SectionRow,
259
- {
260
- title: t("fields.subtitle"),
261
- value: product.subtitle,
262
- "data-testid": "product-subtitle-row"
263
- }
264
- ),
265
- /* @__PURE__ */ jsx2(
266
- SectionRow,
267
- {
268
- title: t("fields.handle"),
269
- value: `/${product.handle}`,
270
- "data-testid": "product-handle-row"
271
- }
272
- ),
273
- /* @__PURE__ */ jsx2(
274
- SectionRow,
275
- {
276
- title: t("fields.discountable"),
277
- value: product.discountable ? t("fields.true") : t("fields.false"),
278
- "data-testid": "product-discountable-row"
279
- }
280
- )
281
- ] });
282
- };
283
-
284
- // src/pages/products/product-detail/components/product-media-section/product-media-section.tsx
285
- import { PencilSquare as PencilSquare3, ThumbnailBadge } from "@medusajs/icons";
286
- import {
287
- Button,
288
- Checkbox,
289
- CommandBar,
290
- Container as Container3,
291
- Heading as Heading3,
292
- Text,
293
- Tooltip,
294
- clx,
295
- usePrompt as usePrompt2
296
- } from "@medusajs/ui";
297
- import { useState } from "react";
298
- import { useTranslation as useTranslation3 } from "react-i18next";
299
- import { Link } from "react-router-dom";
300
- import { jsx as jsx3, jsxs as jsxs3 } from "react/jsx-runtime";
301
- var ProductMediaSection = ({
302
- product
303
- }) => {
304
- const { t } = useTranslation3();
305
- const prompt = usePrompt2();
306
- const [selection, setSelection] = useState({});
307
- const media = getMedia(product);
308
- const handleCheckedChange = (id) => {
309
- setSelection((prev) => {
310
- if (prev[id]) {
311
- const { [id]: _, ...rest } = prev;
312
- return rest;
313
- } else {
314
- return { ...prev, [id]: true };
315
- }
316
- });
317
- };
318
- const { mutateAsync } = useUpdateProduct(product.id);
319
- const handleDelete = async () => {
320
- const ids = Object.keys(selection);
321
- const includingThumbnail = ids.some(
322
- (id) => media.find((m) => m.id === id)?.isThumbnail
323
- );
324
- const res = await prompt({
325
- title: t("general.areYouSure"),
326
- description: includingThumbnail ? t("products.media.deleteWarningWithThumbnail", {
327
- count: ids.length
328
- }) : t("products.media.deleteWarning", {
329
- count: ids.length
330
- }),
331
- confirmText: t("actions.delete"),
332
- cancelText: t("actions.cancel")
333
- });
334
- if (!res) {
335
- return;
336
- }
337
- const mediaToKeep = product.images?.filter((i) => !ids.includes(i.id)).map((i) => ({ url: i.url }));
338
- await mutateAsync(
339
- {
340
- images: mediaToKeep,
341
- thumbnail: includingThumbnail ? "" : void 0
342
- },
343
- {
344
- onSuccess: () => {
345
- setSelection({});
346
- }
347
- }
348
- );
349
- };
350
- return /* @__PURE__ */ jsxs3(Container3, { className: "divide-y p-0", "data-testid": "product-media-section", children: [
351
- /* @__PURE__ */ jsxs3("div", { className: "flex items-center justify-between px-6 py-4", "data-testid": "product-media-header", children: [
352
- /* @__PURE__ */ jsx3(Heading3, { level: "h2", "data-testid": "product-media-title", children: t("products.media.label") }),
353
- /* @__PURE__ */ jsx3(
354
- ActionMenu,
355
- {
356
- groups: [
357
- {
358
- actions: [
359
- {
360
- label: t("actions.edit"),
361
- to: "media?view=edit",
362
- icon: /* @__PURE__ */ jsx3(PencilSquare3, {})
363
- }
364
- ]
365
- }
366
- ],
367
- "data-testid": "product-media-action-menu"
368
- }
369
- )
370
- ] }),
371
- media.length > 0 ? /* @__PURE__ */ jsx3("div", { className: "grid grid-cols-[repeat(auto-fill,minmax(96px,1fr))] gap-4 px-6 py-4", "data-testid": "product-media-grid", children: media.map((i, index) => {
372
- const isSelected = selection[i.id];
373
- return /* @__PURE__ */ jsxs3(
374
- "div",
375
- {
376
- className: "shadow-elevation-card-rest hover:shadow-elevation-card-hover transition-fg group relative aspect-square size-full cursor-pointer overflow-hidden rounded-[8px]",
377
- "data-testid": `product-media-item-${i.id}`,
378
- children: [
379
- /* @__PURE__ */ jsx3(
380
- "div",
381
- {
382
- className: clx(
383
- "transition-fg invisible absolute right-2 top-2 opacity-0 group-hover:visible group-hover:opacity-100",
384
- {
385
- "visible opacity-100": isSelected
386
- }
387
- ),
388
- "data-testid": `product-media-checkbox-container-${i.id}`,
389
- children: /* @__PURE__ */ jsx3(
390
- Checkbox,
391
- {
392
- checked: selection[i.id] || false,
393
- onCheckedChange: () => handleCheckedChange(i.id),
394
- "data-testid": `product-media-checkbox-${i.id}`
395
- }
396
- )
397
- }
398
- ),
399
- i.isThumbnail && /* @__PURE__ */ jsx3("div", { className: "absolute left-2 top-2", "data-testid": `product-media-thumbnail-badge-${i.id}`, children: /* @__PURE__ */ jsx3(Tooltip, { content: t("fields.thumbnail"), children: /* @__PURE__ */ jsx3(ThumbnailBadge, {}) }) }),
400
- /* @__PURE__ */ jsx3(Link, { to: `media`, state: { curr: index }, "data-testid": `product-media-link-${i.id}`, children: /* @__PURE__ */ jsx3(
401
- "img",
402
- {
403
- src: i.url,
404
- alt: product.title,
405
- className: "size-full object-cover",
406
- "data-testid": `product-media-image-${i.id}`
407
- }
408
- ) })
409
- ]
410
- },
411
- i.id
412
- );
413
- }) }) : /* @__PURE__ */ jsxs3("div", { className: "flex flex-col items-center gap-y-4 pb-8 pt-6", "data-testid": "product-media-empty-state", children: [
414
- /* @__PURE__ */ jsxs3("div", { className: "flex flex-col items-center", children: [
415
- /* @__PURE__ */ jsx3(
416
- Text,
417
- {
418
- size: "small",
419
- leading: "compact",
420
- weight: "plus",
421
- className: "text-ui-fg-subtle",
422
- "data-testid": "product-media-empty-state-header",
423
- children: t("products.media.emptyState.header")
424
- }
425
- ),
426
- /* @__PURE__ */ jsx3(Text, { size: "small", className: "text-ui-fg-muted", "data-testid": "product-media-empty-state-description", children: t("products.media.emptyState.description") })
427
- ] }),
428
- /* @__PURE__ */ jsx3(Button, { size: "small", variant: "secondary", asChild: true, "data-testid": "product-media-empty-state-button", children: /* @__PURE__ */ jsx3(Link, { to: "media?view=edit", "data-testid": "product-media-empty-state-link", children: t("products.media.emptyState.action") }) })
429
- ] }),
430
- /* @__PURE__ */ jsx3(CommandBar, { open: !!Object.keys(selection).length, "data-testid": "product-media-command-bar", children: /* @__PURE__ */ jsxs3(CommandBar.Bar, { "data-testid": "product-media-command-bar-bar", children: [
431
- /* @__PURE__ */ jsx3(CommandBar.Value, { "data-testid": "product-media-command-bar-value", children: t("general.countSelected", {
432
- count: Object.keys(selection).length
433
- }) }),
434
- /* @__PURE__ */ jsx3(CommandBar.Seperator, { "data-testid": "product-media-command-bar-separator" }),
435
- /* @__PURE__ */ jsx3(
436
- CommandBar.Command,
437
- {
438
- action: handleDelete,
439
- label: t("actions.delete"),
440
- shortcut: "d",
441
- "data-testid": "product-media-command-bar-delete"
442
- }
443
- )
444
- ] }) })
445
- ] });
446
- };
447
- var getMedia = (product) => {
448
- const { images = [], thumbnail } = product;
449
- const media = images.map((image) => ({
450
- id: image.id,
451
- url: image.url,
452
- isThumbnail: image.url === thumbnail
453
- }));
454
- if (thumbnail && !media.some((mediaItem) => mediaItem.url === thumbnail)) {
455
- media.unshift({
456
- id: "img_thumbnail",
457
- url: thumbnail,
458
- isThumbnail: true
459
- });
460
- }
461
- return media;
462
- };
463
-
464
- // src/pages/products/product-detail/components/product-option-section/product-option-section.tsx
465
- import { PencilSquare as PencilSquare4, Plus, Trash as Trash2 } from "@medusajs/icons";
466
- import { Badge, Container as Container4, Heading as Heading4, usePrompt as usePrompt3 } from "@medusajs/ui";
467
- import { useTranslation as useTranslation4 } from "react-i18next";
468
- import { jsx as jsx4, jsxs as jsxs4 } from "react/jsx-runtime";
469
- var OptionActions = ({
470
- productId,
471
- option
472
- }) => {
473
- const { t } = useTranslation4();
474
- const { mutateAsync } = useDeleteProductOption(productId, option.id);
475
- const prompt = usePrompt3();
476
- const handleDelete = async () => {
477
- const res = await prompt({
478
- title: t("general.areYouSure"),
479
- description: t("products.options.deleteWarning", {
480
- title: option.title
481
- }),
482
- confirmText: t("actions.delete"),
483
- cancelText: t("actions.cancel")
484
- });
485
- if (!res) {
486
- return;
487
- }
488
- await mutateAsync();
489
- };
490
- return /* @__PURE__ */ jsx4(
491
- ActionMenu,
492
- {
493
- groups: [
494
- {
495
- actions: [
496
- {
497
- label: t("actions.edit"),
498
- to: `options/${option.id}/edit`,
499
- icon: /* @__PURE__ */ jsx4(PencilSquare4, {})
500
- }
501
- ]
502
- },
503
- {
504
- actions: [
505
- {
506
- label: t("actions.delete"),
507
- onClick: handleDelete,
508
- icon: /* @__PURE__ */ jsx4(Trash2, {})
509
- }
510
- ]
511
- }
512
- ],
513
- "data-testid": `product-option-actions-${option.id}`
514
- }
515
- );
516
- };
517
- var ProductOptionSection = ({
518
- product
519
- }) => {
520
- const { t } = useTranslation4();
521
- return /* @__PURE__ */ jsxs4(Container4, { className: "divide-y p-0", "data-testid": "product-option-section", children: [
522
- /* @__PURE__ */ jsxs4("div", { className: "flex items-center justify-between px-6 py-4", "data-testid": "product-option-header", children: [
523
- /* @__PURE__ */ jsx4(Heading4, { level: "h2", "data-testid": "product-option-title", children: t("products.options.header") }),
524
- /* @__PURE__ */ jsx4(
525
- ActionMenu,
526
- {
527
- groups: [
528
- {
529
- actions: [
530
- {
531
- label: t("actions.create"),
532
- to: "options/create",
533
- icon: /* @__PURE__ */ jsx4(Plus, {})
534
- }
535
- ]
536
- }
537
- ],
538
- "data-testid": "product-option-action-menu"
539
- }
540
- )
541
- ] }),
542
- product.options?.map((option) => {
543
- return /* @__PURE__ */ jsx4(
544
- SectionRow,
545
- {
546
- title: option.title,
547
- value: option.values?.map((val) => {
548
- return /* @__PURE__ */ jsx4(
549
- Badge,
550
- {
551
- size: "2xsmall",
552
- className: "flex min-w-[20px] items-center justify-center",
553
- "data-testid": `product-option-value-badge-${option.id}-${val.value}`,
554
- children: val.value
555
- },
556
- val.value
557
- );
558
- }),
559
- actions: /* @__PURE__ */ jsx4(OptionActions, { productId: product.id, option }),
560
- "data-testid": `product-option-row-${option.id}`
561
- },
562
- option.id
563
- );
564
- })
565
- ] });
566
- };
567
-
568
- // src/pages/products/product-detail/components/product-organization-section/product-organization-section.tsx
569
- import { PencilSquare as PencilSquare5 } from "@medusajs/icons";
570
- import { Badge as Badge2, Container as Container5, Heading as Heading5, Tooltip as Tooltip2 } from "@medusajs/ui";
571
- import { useTranslation as useTranslation5 } from "react-i18next";
572
- import { Link as Link2 } from "react-router-dom";
573
- import { jsx as jsx5, jsxs as jsxs5 } from "react/jsx-runtime";
574
- var ProductOrganizationSection = ({
575
- product
576
- }) => {
577
- const { t } = useTranslation5();
578
- return /* @__PURE__ */ jsxs5(
579
- Container5,
580
- {
581
- className: "divide-y p-0",
582
- "data-testid": "product-organization-section",
583
- children: [
584
- /* @__PURE__ */ jsxs5(
585
- "div",
586
- {
587
- className: "flex items-center justify-between px-6 py-4",
588
- "data-testid": "product-organization-header",
589
- children: [
590
- /* @__PURE__ */ jsx5(Heading5, { level: "h2", "data-testid": "product-organization-title", children: t("products.organization.header") }),
591
- /* @__PURE__ */ jsx5(
592
- ActionMenu,
593
- {
594
- groups: [
595
- {
596
- actions: [
597
- {
598
- label: t("actions.edit"),
599
- to: "organization",
600
- icon: /* @__PURE__ */ jsx5(PencilSquare5, {})
601
- }
602
- ]
603
- }
604
- ],
605
- "data-testid": "product-organization-action-menu"
606
- }
607
- )
608
- ]
609
- }
610
- ),
611
- /* @__PURE__ */ jsx5(
612
- SectionRow,
613
- {
614
- title: t("fields.tags"),
615
- value: product.tags?.length ? product.tags.map((tag) => /* @__PURE__ */ jsx5(
616
- OrganizationTag,
617
- {
618
- label: tag.value,
619
- to: `/settings/product-tags/${tag.id}`
620
- },
621
- tag.id
622
- )) : void 0,
623
- "data-testid": "product-tags-row"
624
- }
625
- ),
626
- /* @__PURE__ */ jsx5(
627
- SectionRow,
628
- {
629
- title: t("fields.type"),
630
- value: product.type ? /* @__PURE__ */ jsx5(
631
- OrganizationTag,
632
- {
633
- label: product.type.value,
634
- to: `/settings/product-types/${product.type_id}`
635
- }
636
- ) : void 0,
637
- "data-testid": "product-type-row"
638
- }
639
- ),
640
- /* @__PURE__ */ jsx5(
641
- SectionRow,
642
- {
643
- title: t("fields.collection"),
644
- value: product.collection ? /* @__PURE__ */ jsx5(
645
- OrganizationTag,
646
- {
647
- label: product.collection.title,
648
- to: `/collections/${product.collection.id}`
649
- }
650
- ) : void 0,
651
- "data-testid": "product-collection-row"
652
- }
653
- ),
654
- /* @__PURE__ */ jsx5(
655
- SectionRow,
656
- {
657
- title: t("fields.categories"),
658
- value: product.categories?.length ? product.categories.map((pcat) => /* @__PURE__ */ jsx5(
659
- OrganizationTag,
660
- {
661
- label: pcat.name,
662
- to: `/categories/${pcat.id}`
663
- },
664
- pcat.id
665
- )) : void 0,
666
- "data-testid": "product-categories-row"
667
- }
668
- )
669
- ]
670
- }
671
- );
672
- };
673
- var OrganizationTag = ({ label, to }) => {
674
- return /* @__PURE__ */ jsx5(Tooltip2, { content: label, children: /* @__PURE__ */ jsx5(Badge2, { size: "2xsmall", className: "block w-fit truncate", asChild: true, children: /* @__PURE__ */ jsx5(
675
- Link2,
676
- {
677
- to,
678
- "data-testid": `organization-tag-${label.toLowerCase().replace(/\s+/g, "-")}`,
679
- children: label
680
- }
681
- ) }) });
682
- };
683
-
684
- // src/pages/products/product-detail/components/product-sales-channel-section/product-sales-channel-section.tsx
685
- import { Channels, PencilSquare as PencilSquare6 } from "@medusajs/icons";
686
- import { Container as Container6, Heading as Heading6, Text as Text2, Tooltip as Tooltip3 } from "@medusajs/ui";
687
- import { Trans, useTranslation as useTranslation6 } from "react-i18next";
688
- import { jsx as jsx6, jsxs as jsxs6 } from "react/jsx-runtime";
689
- var ProductSalesChannelSection = ({
690
- product
691
- }) => {
692
- const { count } = useSalesChannels();
693
- const { t } = useTranslation6();
694
- const availableInSalesChannels = product.sales_channels?.map((sc) => ({
695
- id: sc.id,
696
- name: sc.name
697
- })) ?? [];
698
- const firstChannels = availableInSalesChannels.slice(0, 3);
699
- const restChannels = availableInSalesChannels.slice(3);
700
- return /* @__PURE__ */ jsxs6(Container6, { className: "flex flex-col gap-y-4 px-6 py-4", "data-testid": "product-sales-channel-section", children: [
701
- /* @__PURE__ */ jsxs6("div", { className: "flex items-center justify-between", "data-testid": "product-sales-channel-header", children: [
702
- /* @__PURE__ */ jsx6(Heading6, { level: "h2", "data-testid": "product-sales-channel-title", children: t("fields.sales_channels") }),
703
- /* @__PURE__ */ jsx6(
704
- ActionMenu,
705
- {
706
- groups: [
707
- {
708
- actions: [
709
- {
710
- label: t("actions.edit"),
711
- to: "sales-channels",
712
- icon: /* @__PURE__ */ jsx6(PencilSquare6, {})
713
- }
714
- ]
715
- }
716
- ],
717
- "data-testid": "product-sales-channel-action-menu"
718
- }
719
- )
720
- ] }),
721
- /* @__PURE__ */ jsxs6("div", { className: "grid grid-cols-[28px_1fr] items-center gap-x-3", "data-testid": "product-sales-channels-content", children: [
722
- /* @__PURE__ */ jsx6("div", { className: "bg-ui-bg-base shadow-borders-base flex size-7 items-center justify-center rounded-md", "data-testid": "product-sales-channels-icon-container", children: /* @__PURE__ */ jsx6("div", { className: "bg-ui-bg-component flex size-6 items-center justify-center rounded-[4px]", children: /* @__PURE__ */ jsx6(Channels, { className: "text-ui-fg-subtle", "data-testid": "product-sales-channels-icon" }) }) }),
723
- availableInSalesChannels.length > 0 ? /* @__PURE__ */ jsxs6("div", { className: "flex items-center gap-x-1", "data-testid": "product-sales-channels-list", children: [
724
- /* @__PURE__ */ jsx6(Text2, { size: "small", leading: "compact", "data-testid": "product-sales-channels-names", children: firstChannels.map((sc) => sc.name).join(", ") }),
725
- restChannels.length > 0 && /* @__PURE__ */ jsx6(
726
- Tooltip3,
727
- {
728
- content: /* @__PURE__ */ jsx6("ul", { children: restChannels.map((sc) => /* @__PURE__ */ jsx6("li", { children: sc.name }, sc.id)) }),
729
- "data-testid": "product-sales-channels-more-tooltip",
730
- children: /* @__PURE__ */ jsx6(
731
- Text2,
732
- {
733
- size: "small",
734
- leading: "compact",
735
- className: "text-ui-fg-subtle",
736
- "data-testid": "product-sales-channels-more-count",
737
- children: `+${restChannels.length}`
738
- }
739
- )
740
- }
741
- )
742
- ] }) : /* @__PURE__ */ jsx6(Text2, { size: "small", leading: "compact", className: "text-ui-fg-subtle", "data-testid": "product-sales-channels-empty", children: t("products.noSalesChannels") })
743
- ] }),
744
- /* @__PURE__ */ jsx6("div", { "data-testid": "product-sales-channels-stats", children: /* @__PURE__ */ jsx6(Text2, { className: "text-ui-fg-subtle", size: "small", leading: "compact", "data-testid": "product-sales-channels-stats-text", children: /* @__PURE__ */ jsx6(
745
- Trans,
746
- {
747
- i18nKey: "sales_channels.availableIn",
748
- values: {
749
- x: availableInSalesChannels.length,
750
- y: count ?? 0
751
- },
752
- components: [
753
- /* @__PURE__ */ jsx6(
754
- "span",
755
- {
756
- className: "text-ui-fg-base txt-compact-medium-plus",
757
- "data-testid": "product-sales-channels-count"
758
- },
759
- "x"
760
- ),
761
- /* @__PURE__ */ jsx6(
762
- "span",
763
- {
764
- className: "text-ui-fg-base txt-compact-medium-plus",
765
- "data-testid": "product-sales-channels-total"
766
- },
767
- "y"
768
- )
769
- ]
770
- }
771
- ) }) })
772
- ] });
773
- };
774
-
775
- // src/pages/products/product-detail/components/product-shipping-profile-section/product-shipping-profile-section.tsx
776
- import { PencilSquare as PencilSquare7, ShoppingBag } from "@medusajs/icons";
777
- import { Container as Container7, Heading as Heading7 } from "@medusajs/ui";
778
- import { useTranslation as useTranslation7 } from "react-i18next";
779
- import { jsx as jsx7, jsxs as jsxs7 } from "react/jsx-runtime";
780
- var ProductShippingProfileSection = ({
781
- product
782
- }) => {
783
- const { t } = useTranslation7();
784
- const shippingProfile = product.shipping_profile;
785
- return /* @__PURE__ */ jsxs7(Container7, { className: "p-0", "data-testid": "product-shipping-profile-section", children: [
786
- /* @__PURE__ */ jsxs7("div", { className: "flex items-center justify-between px-6 py-4", "data-testid": "product-shipping-profile-header", children: [
787
- /* @__PURE__ */ jsx7(Heading7, { level: "h2", "data-testid": "product-shipping-profile-title", children: t("products.shippingProfile.header") }),
788
- /* @__PURE__ */ jsx7(
789
- ActionMenu,
790
- {
791
- groups: [
792
- {
793
- actions: [
794
- {
795
- label: t("actions.edit"),
796
- to: "shipping-profile",
797
- icon: /* @__PURE__ */ jsx7(PencilSquare7, {})
798
- }
799
- ]
800
- }
801
- ],
802
- "data-testid": "product-shipping-profile-action-menu"
803
- }
804
- )
805
- ] }),
806
- shippingProfile && /* @__PURE__ */ jsx7("div", { "data-testid": "product-shipping-profile-link-container", children: /* @__PURE__ */ jsx7(
807
- SidebarLink,
808
- {
809
- to: `/settings/locations/shipping-profiles/${shippingProfile.id}`,
810
- labelKey: shippingProfile.name,
811
- descriptionKey: shippingProfile.type,
812
- icon: /* @__PURE__ */ jsx7(ShoppingBag, {}),
813
- "data-testid": "product-shipping-profile-link"
814
- }
815
- ) })
816
- ] });
817
- };
818
-
819
- // src/pages/products/product-detail/components/product-variant-section/product-variant-section.tsx
820
- import { useCallback, useMemo } from "react";
821
- import { Buildings, Component, PencilSquare as PencilSquare8, Trash as Trash3 } from "@medusajs/icons";
822
- import {
823
- Badge as Badge3,
824
- clx as clx2,
825
- Container as Container8,
826
- createDataTableColumnHelper,
827
- createDataTableCommandHelper,
828
- createDataTableFilterHelper,
829
- Tooltip as Tooltip4,
830
- usePrompt as usePrompt4
831
- } from "@medusajs/ui";
832
- import { keepPreviousData } from "@tanstack/react-query";
833
- import { useTranslation as useTranslation8 } from "react-i18next";
834
- import { useNavigate as useNavigate2, useSearchParams } from "react-router-dom";
835
- import { jsx as jsx8, jsxs as jsxs8 } from "react/jsx-runtime";
836
- var PAGE_SIZE = 10;
837
- var PREFIX = "pv";
838
- var ProductVariantSection = ({
839
- product
840
- }) => {
841
- const { t } = useTranslation8();
842
- const { q, order, offset, allow_backorder, manage_inventory, created_at, updated_at } = useQueryParams(
843
- ["q", "order", "offset", "manage_inventory", "allow_backorder", "created_at", "updated_at"],
844
- PREFIX
845
- );
846
- const columns = useColumns(product);
847
- const filters = useFilters();
848
- const commands = useCommands();
849
- const { variants, count, isPending, isError, error } = useProductVariants(
850
- product.id,
851
- {
852
- q,
853
- order: order ? order : "variant_rank",
854
- offset: offset ? parseInt(offset) : void 0,
855
- limit: PAGE_SIZE,
856
- allow_backorder: allow_backorder ? JSON.parse(allow_backorder) : void 0,
857
- manage_inventory: manage_inventory ? JSON.parse(manage_inventory) : void 0,
858
- created_at: created_at ? JSON.parse(created_at) : void 0,
859
- updated_at: updated_at ? JSON.parse(updated_at) : void 0,
860
- fields: "title,sku,*options,created_at,updated_at,*inventory_items.inventory.location_levels,inventory_quantity,manage_inventory"
861
- },
862
- {
863
- placeholderData: keepPreviousData
864
- }
865
- );
866
- if (isError) {
867
- throw error;
868
- }
869
- return /* @__PURE__ */ jsx8(
870
- Container8,
871
- {
872
- className: "divide-y p-0",
873
- "data-testid": "product-variant-section",
874
- children: /* @__PURE__ */ jsx8("div", { "data-testid": "product-variants-table-container", children: /* @__PURE__ */ jsx8(
875
- DataTable,
876
- {
877
- data: variants,
878
- columns,
879
- filters,
880
- rowCount: count,
881
- getRowId: (row) => row.id,
882
- rowHref: (row) => `/products/${product.id}/variants/${row.id}`,
883
- pageSize: PAGE_SIZE,
884
- isLoading: isPending,
885
- heading: t("products.variants.header"),
886
- emptyState: {
887
- empty: {
888
- heading: t("products.variants.empty.heading"),
889
- description: t("products.variants.empty.description")
890
- },
891
- filtered: {
892
- heading: t("products.variants.filtered.heading"),
893
- description: t("products.variants.filtered.description")
894
- }
895
- },
896
- action: {
897
- label: t("actions.create"),
898
- to: `variants/create`
899
- },
900
- actionMenu: {
901
- groups: [
902
- {
903
- actions: [
904
- {
905
- label: t("products.editPrices"),
906
- to: `prices`,
907
- icon: /* @__PURE__ */ jsx8(PencilSquare8, {})
908
- },
909
- {
910
- label: t("inventory.stock.action"),
911
- to: `stock`,
912
- icon: /* @__PURE__ */ jsx8(Buildings, {})
913
- }
914
- ]
915
- }
916
- ],
917
- "data-testid": "product-variant-section-action-menu"
918
- },
919
- commands,
920
- prefix: PREFIX
921
- }
922
- ) })
923
- }
924
- );
925
- };
926
- var columnHelper = createDataTableColumnHelper();
927
- var useColumns = (product) => {
928
- const { t } = useTranslation8();
929
- const navigate = useNavigate2();
930
- const { mutateAsync } = useDeleteVariantLazy(product.id);
931
- const prompt = usePrompt4();
932
- const [searchParams] = useSearchParams();
933
- const tableSearchParams = useMemo(() => {
934
- const filtered = new URLSearchParams();
935
- for (const [key, value] of searchParams.entries()) {
936
- if (key.startsWith(`${PREFIX}_`)) {
937
- filtered.append(key, value);
938
- }
939
- }
940
- return filtered;
941
- }, [searchParams]);
942
- const dateColumns = useDataTableDateColumns();
943
- const handleDelete = useCallback(
944
- async (id, title) => {
945
- const res = await prompt({
946
- title: t("general.areYouSure"),
947
- description: t("products.deleteVariantWarning", {
948
- title
949
- }),
950
- confirmText: t("actions.delete"),
951
- cancelText: t("actions.cancel")
952
- });
953
- if (!res) {
954
- return;
955
- }
956
- await mutateAsync({ variantId: id });
957
- },
958
- [mutateAsync, prompt, t]
959
- );
960
- const optionColumns = useMemo(() => {
961
- if (!product?.options) {
962
- return [];
963
- }
964
- return product.options.map((option) => {
965
- return columnHelper.display({
966
- id: option.id,
967
- header: option.title,
968
- cell: ({ row }) => {
969
- const variantOpt = row.original.options?.find((opt) => opt.option_id === option.id);
970
- if (!variantOpt) {
971
- return /* @__PURE__ */ jsx8("span", { className: "text-ui-fg-muted", children: "-" });
972
- }
973
- return /* @__PURE__ */ jsx8(
974
- "div",
975
- {
976
- className: "flex items-center",
977
- "data-testid": `product-variant-option-${option.id}-${row.original.id}`,
978
- children: /* @__PURE__ */ jsx8(Tooltip4, { content: variantOpt.value, children: /* @__PURE__ */ jsx8(
979
- Badge3,
980
- {
981
- size: "2xsmall",
982
- title: variantOpt.value,
983
- className: "inline-flex min-w-[20px] max-w-[140px] items-center justify-center overflow-hidden truncate",
984
- "data-testid": `product-variant-option-badge-${option.id}-${row.original.id}-${variantOpt.value}`,
985
- children: variantOpt.value
986
- }
987
- ) })
988
- }
989
- );
990
- }
991
- });
992
- });
993
- }, [product]);
994
- const getActions = useCallback(
995
- (ctx) => {
996
- const variant = ctx.row.original;
997
- const mainActions = [
998
- {
999
- icon: /* @__PURE__ */ jsx8(PencilSquare8, {}),
1000
- label: t("actions.edit"),
1001
- onClick: (row) => {
1002
- navigate(
1003
- `edit-variant?variant_id=${row.row.original.id}&${tableSearchParams.toString()}`,
1004
- {
1005
- state: {
1006
- restore_params: tableSearchParams.toString()
1007
- }
1008
- }
1009
- );
1010
- }
1011
- }
1012
- ];
1013
- const secondaryActions = [
1014
- {
1015
- icon: /* @__PURE__ */ jsx8(Trash3, {}),
1016
- label: t("actions.delete"),
1017
- onClick: () => handleDelete(variant.id, variant.title)
1018
- }
1019
- ];
1020
- const inventoryItemsCount = variant.inventory_items?.length || 0;
1021
- switch (inventoryItemsCount) {
1022
- case 0:
1023
- break;
1024
- case 1: {
1025
- const inventoryItemLink = `/inventory/${variant.inventory_items[0].inventory.id}`;
1026
- mainActions.push({
1027
- label: t("products.variant.inventory.actions.inventoryItems"),
1028
- onClick: () => {
1029
- navigate(inventoryItemLink);
1030
- },
1031
- icon: /* @__PURE__ */ jsx8(Buildings, {})
1032
- });
1033
- break;
1034
- }
1035
- default: {
1036
- const ids = variant.inventory_items?.map((i) => i.inventory?.id);
1037
- if (!ids || ids.length === 0) {
1038
- break;
1039
- }
1040
- const inventoryKitLink = `/inventory?${new URLSearchParams({
1041
- id: ids.join(",")
1042
- }).toString()}`;
1043
- mainActions.push({
1044
- label: t("products.variant.inventory.actions.inventoryKit"),
1045
- onClick: () => {
1046
- navigate(inventoryKitLink);
1047
- },
1048
- icon: /* @__PURE__ */ jsx8(Component, {})
1049
- });
1050
- }
1051
- }
1052
- return [mainActions, secondaryActions];
1053
- },
1054
- [handleDelete, navigate, t, tableSearchParams]
1055
- );
1056
- const getInventory = useCallback(
1057
- (variant) => {
1058
- const castVariant = variant;
1059
- if (!variant.manage_inventory) {
1060
- return {
1061
- text: t("products.variant.inventory.notManaged"),
1062
- hasInventoryKit: false,
1063
- notManaged: true
1064
- };
1065
- }
1066
- const quantity = variant.inventory_quantity;
1067
- const inventoryItems = castVariant.inventory_items?.map((i) => i.inventory).filter(Boolean);
1068
- const hasInventoryKit = inventoryItems.length > 1;
1069
- const locations = {};
1070
- inventoryItems.forEach((i) => {
1071
- i.location_levels?.forEach((l) => {
1072
- locations[l.id] = true;
1073
- });
1074
- });
1075
- const locationCount = Object.keys(locations).length;
1076
- const text = hasInventoryKit ? t("products.variant.tableItemAvailable", {
1077
- availableCount: quantity
1078
- }) : t("products.variant.tableItem", {
1079
- availableCount: quantity,
1080
- locationCount,
1081
- count: locationCount
1082
- });
1083
- return { text, hasInventoryKit, quantity, notManaged: false };
1084
- },
1085
- [t]
1086
- );
1087
- return useMemo(() => {
1088
- return [
1089
- columnHelper.accessor("title", {
1090
- header: t("fields.title"),
1091
- enableSorting: true,
1092
- sortAscLabel: t("filters.sorting.alphabeticallyAsc"),
1093
- sortDescLabel: t("filters.sorting.alphabeticallyDesc")
1094
- }),
1095
- columnHelper.accessor("sku", {
1096
- header: t("fields.sku"),
1097
- enableSorting: true,
1098
- sortAscLabel: t("filters.sorting.alphabeticallyAsc"),
1099
- sortDescLabel: t("filters.sorting.alphabeticallyDesc")
1100
- }),
1101
- ...optionColumns,
1102
- columnHelper.display({
1103
- id: "inventory",
1104
- header: t("fields.inventory"),
1105
- cell: ({ row }) => {
1106
- const { text, hasInventoryKit, quantity, notManaged } = getInventory(row.original);
1107
- return /* @__PURE__ */ jsx8(Tooltip4, { content: text, children: /* @__PURE__ */ jsxs8(
1108
- "div",
1109
- {
1110
- className: "flex h-full w-full items-center gap-2 overflow-hidden",
1111
- "data-testid": `product-variant-inventory-${row.original.id}`,
1112
- children: [
1113
- hasInventoryKit && /* @__PURE__ */ jsx8(
1114
- Component,
1115
- {
1116
- "data-testid": `product-variant-inventory-kit-icon-${row.original.id}`
1117
- }
1118
- ),
1119
- /* @__PURE__ */ jsx8(
1120
- "span",
1121
- {
1122
- className: clx2("truncate", {
1123
- "text-ui-fg-error": !quantity && !notManaged
1124
- }),
1125
- "data-testid": `product-variant-inventory-text-${row.original.id}`,
1126
- children: text
1127
- }
1128
- )
1129
- ]
1130
- }
1131
- ) });
1132
- },
1133
- maxSize: 250
1134
- }),
1135
- ...dateColumns,
1136
- columnHelper.action({
1137
- actions: getActions
1138
- })
1139
- ];
1140
- }, [t, optionColumns, dateColumns, getActions, getInventory]);
1141
- };
1142
- var filterHelper = createDataTableFilterHelper();
1143
- var useFilters = () => {
1144
- const { t } = useTranslation8();
1145
- const dateFilters = useDataTableDateFilters();
1146
- return useMemo(() => {
1147
- return [
1148
- filterHelper.accessor("allow_backorder", {
1149
- type: "radio",
1150
- label: t("fields.allowBackorder"),
1151
- options: [
1152
- { label: t("filters.radio.yes"), value: "true" },
1153
- { label: t("filters.radio.no"), value: "false" }
1154
- ]
1155
- }),
1156
- filterHelper.accessor("manage_inventory", {
1157
- type: "radio",
1158
- label: t("fields.manageInventory"),
1159
- options: [
1160
- { label: t("filters.radio.yes"), value: "true" },
1161
- { label: t("filters.radio.no"), value: "false" }
1162
- ]
1163
- }),
1164
- ...dateFilters
1165
- ];
1166
- }, [t, dateFilters]);
1167
- };
1168
- var commandHelper = createDataTableCommandHelper();
1169
- var useCommands = () => {
1170
- const { t } = useTranslation8();
1171
- const navigate = useNavigate2();
1172
- return [
1173
- commandHelper.command({
1174
- label: t("inventory.stock.action"),
1175
- shortcut: "i",
1176
- action: async (selection) => {
1177
- navigate(`stock?${PRODUCT_VARIANT_IDS_KEY}=${Object.keys(selection).join(",")}`);
1178
- }
1179
- })
1180
- ];
1181
- };
1182
-
1183
- // src/pages/products/product-detail/product-detail.tsx
1184
- import { jsx as jsx9, jsxs as jsxs9 } from "react/jsx-runtime";
1185
- var Root = ({ children }) => {
1186
- const initialData = useLoaderData();
1187
- const { id } = useParams();
1188
- const { product: rawProduct, isLoading, isError, error } = useProduct(
1189
- id,
1190
- PRODUCT_DETAIL_QUERY,
1191
- {
1192
- initialData
1193
- }
1194
- );
1195
- const product = rawProduct;
1196
- if (isLoading || !product) {
1197
- return /* @__PURE__ */ jsx9(
1198
- TwoColumnPageSkeleton,
1199
- {
1200
- mainSections: 4,
1201
- sidebarSections: 3,
1202
- showJSON: true,
1203
- showMetadata: true
1204
- }
1205
- );
1206
- }
1207
- if (isError) {
1208
- throw error;
1209
- }
1210
- return Children.count(children) > 0 ? /* @__PURE__ */ jsx9(
1211
- TwoColumnPage,
1212
- {
1213
- data: product,
1214
- showJSON: true,
1215
- showMetadata: true,
1216
- "data-testid": "product-detail-page",
1217
- children
1218
- }
1219
- ) : /* @__PURE__ */ jsxs9(
1220
- TwoColumnPage,
1221
- {
1222
- data: product,
1223
- showJSON: true,
1224
- showMetadata: true,
1225
- "data-testid": "product-detail-page",
1226
- children: [
1227
- /* @__PURE__ */ jsxs9(TwoColumnPage.Main, { "data-testid": "product-detail-main", children: [
1228
- /* @__PURE__ */ jsx9(ProductGeneralSection, { product }),
1229
- /* @__PURE__ */ jsx9(ProductMediaSection, { product }),
1230
- /* @__PURE__ */ jsx9(ProductOptionSection, { product }),
1231
- /* @__PURE__ */ jsx9(ProductVariantSection, { product })
1232
- ] }),
1233
- /* @__PURE__ */ jsxs9(TwoColumnPage.Sidebar, { "data-testid": "product-detail-sidebar", children: [
1234
- /* @__PURE__ */ jsx9(ProductSellerSection, { seller: product.seller }),
1235
- /* @__PURE__ */ jsx9(ProductSalesChannelSection, { product }),
1236
- /* @__PURE__ */ jsx9(ProductShippingProfileSection, { product }),
1237
- /* @__PURE__ */ jsx9(ProductOrganizationSection, { product }),
1238
- /* @__PURE__ */ jsx9(ProductAttributeSection, { product })
1239
- ] })
1240
- ]
1241
- }
1242
- );
1243
- };
1244
- var ProductDetailPage = Object.assign(Root, {
1245
- Main: TwoColumnPage.Main,
1246
- Sidebar: TwoColumnPage.Sidebar,
1247
- MainGeneralSection: ProductGeneralSection,
1248
- MainMediaSection: ProductMediaSection,
1249
- MainOptionSection: ProductOptionSection,
1250
- MainVariantSection: ProductVariantSection,
1251
- SidebarSellerSection: ProductSellerSection,
1252
- SidebarSalesChannelSection: ProductSalesChannelSection,
1253
- SidebarShippingProfileSection: ProductShippingProfileSection,
1254
- SidebarOrganizationSection: ProductOrganizationSection,
1255
- SidebarAttributeSection: ProductAttributeSection
1256
- });
1257
-
1258
- export {
1259
- ProductDetailPage
1260
- };