@mercurjs/admin 2.1.2 → 2.2.0-canary.1

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 (336) hide show
  1. package/dist/[id]-YI7UXOO2.js +499 -0
  2. package/dist/{add-campaign-promotions-6Z2STQT4.js → add-campaign-promotions-OLNTDP26.js} +14 -16
  3. package/dist/{adjust-inventory-NVBPZYOF.js → adjust-inventory-CVWSBMHU.js} +13 -12
  4. package/dist/{api-key-management-create-THDCXGWK.js → api-key-management-create-7RWOCVAO.js} +3 -3
  5. package/dist/{api-key-management-detail-IRYR6J2I.js → api-key-management-detail-ZIIDMHFI.js} +24 -23
  6. package/dist/{api-key-management-edit-LTVNXP6T.js → api-key-management-edit-ACH6TJAX.js} +3 -3
  7. package/dist/{api-key-management-list-4WCDP4B3.js → api-key-management-list-JHBBXGHH.js} +11 -13
  8. package/dist/{api-key-management-sales-channels-NVFG2ESH.js → api-key-management-sales-channels-XEBTUB5V.js} +15 -15
  9. package/dist/attribute-create-BYO7BDF5.js +562 -0
  10. package/dist/attribute-create-possible-value-EXVHC272.js +476 -0
  11. package/dist/{attribute-detail-R26GDX7Q.js → attribute-detail-36XP35P6.js} +74 -64
  12. package/dist/attribute-edit-WMJWHT7Z.js +183 -0
  13. package/dist/attribute-edit-possible-value-KTUZ7YLW.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-OHU2QMUG.js} +24 -26
  16. package/dist/{campaign-create-AZTR5UZP.js → campaign-create-VFFIIRE4.js} +4 -4
  17. package/dist/{campaign-detail-TCPO6DTI.js → campaign-detail-AZKBPDLC.js} +27 -28
  18. package/dist/{campaign-list-DCLVAFEM.js → campaign-list-NQGNOFVZ.js} +10 -12
  19. package/dist/{categories-metadata-YVUNHMQT.js → categories-metadata-YZUP43OH.js} +17 -16
  20. package/dist/{category-create-DG3Z5RYE.js → category-create-2MRYTSYM.js} +4 -4
  21. package/dist/{category-detail-K2UNFPRV.js → category-detail-KTFD3VVR.js} +29 -28
  22. package/dist/{category-edit-IXU6E3YT.js → category-edit-QLOS2LBA.js} +5 -5
  23. package/dist/{category-list-2MG37UXJ.js → category-list-U7ZQBSZN.js} +11 -13
  24. package/dist/{category-organize-CCX2INRS.js → category-organize-TIKTYJFZ.js} +2 -2
  25. package/dist/{category-products-LKT7564A.js → category-products-7P5DSQN4.js} +30 -29
  26. package/dist/{chunk-6YGOXPB5.js → chunk-2LQ5SCPB.js} +5 -5
  27. package/dist/{chunk-ZZO3INVE.js → chunk-2MDGYHWN.js} +128 -25
  28. package/dist/{chunk-X3YEY2PY.js → chunk-2S6VXFBZ.js} +8 -8
  29. package/dist/{chunk-5CK6XEFV.js → chunk-2YYXP6XI.js} +183 -111
  30. package/dist/{chunk-GAD5DQOY.js → chunk-3EDQIZV6.js} +2 -2
  31. package/dist/{chunk-4IZ2RD3L.js → chunk-3IVTUFBM.js} +8 -8
  32. package/dist/{chunk-7YHAFHGI.js → chunk-3JSAS7QP.js} +92 -165
  33. package/dist/{chunk-DVKO4VRC.js → chunk-3P4VTL4S.js} +12 -12
  34. package/dist/{chunk-GJPGL7RP.js → chunk-3VTAK3S6.js} +108 -28
  35. package/dist/{chunk-C3WE6EFO.js → chunk-4YWKKCTT.js} +1 -2
  36. package/dist/chunk-533GMKEG.js +125 -0
  37. package/dist/chunk-57BHSFNA.js +101 -0
  38. package/dist/{chunk-AEFDAU3Y.js → chunk-5KGMGL4N.js} +4 -24
  39. package/dist/{chunk-VGM5UQRA.js → chunk-637OFDFC.js} +809 -306
  40. package/dist/{chunk-NRJ7F7JW.js → chunk-6AZKWCVL.js} +14 -14
  41. package/dist/{chunk-JCSPXBS3.js → chunk-6FIU2V6Y.js} +1 -1
  42. package/dist/chunk-77T2UI6L.js +1671 -0
  43. package/dist/{chunk-B6SYYKJI.js → chunk-A4UQKKGC.js} +13 -13
  44. package/dist/{chunk-B6FG7A6W.js → chunk-A772RAKB.js} +1 -1
  45. package/dist/{chunk-35Q6JF3S.js → chunk-A7JOHU6Q.js} +4 -4
  46. package/dist/{chunk-N57BOIPU.js → chunk-AB2LHP3M.js} +1 -1
  47. package/dist/chunk-ABFL4ACD.js +207 -0
  48. package/dist/{chunk-HY3CV5V6.js → chunk-AKTAFKIU.js} +4 -4
  49. package/dist/{chunk-N23OD7WS.js → chunk-ALATTLBM.js} +7 -7
  50. package/dist/{chunk-PBQ5M44A.js → chunk-AXTQMIIK.js} +13 -30
  51. package/dist/{chunk-TAKEQAZZ.js → chunk-B3EEDC47.js} +2 -2
  52. package/dist/{chunk-EWMEXGFZ.js → chunk-BCVUMATY.js} +18 -18
  53. package/dist/{chunk-34I4QIBD.js → chunk-BE6JLTMI.js} +1 -1
  54. package/dist/{chunk-V7EPLR3E.js → chunk-BFT3CN5L.js} +10 -10
  55. package/dist/{chunk-O5YFLNSQ.js → chunk-BGGUVHDG.js} +27 -27
  56. package/dist/{chunk-HGULM6DF.js → chunk-BGQ7H2KL.js} +10 -10
  57. package/dist/{chunk-3DOCALSU.js → chunk-BHOZKBYY.js} +395 -11
  58. package/dist/{chunk-KHHMQM2L.js → chunk-BLYJZMNE.js} +5 -5
  59. package/dist/chunk-CBG4E3M3.js +165 -0
  60. package/dist/{chunk-5ZBQICCP.js → chunk-CBGXKU7Z.js} +18 -18
  61. package/dist/{chunk-LFATSJPO.js → chunk-CKACZXMP.js} +9 -9
  62. package/dist/{chunk-GXRLLA5H.js → chunk-CKD5563X.js} +4 -4
  63. package/dist/{chunk-E3DLJSYD.js → chunk-COP7NFSJ.js} +1 -1
  64. package/dist/{chunk-ABUQBBEM.js → chunk-CVFVEDMV.js} +4 -4
  65. package/dist/chunk-CYGIJOA5.js +79 -0
  66. package/dist/{chunk-CXO3C3L2.js → chunk-D5T7QOVY.js} +11 -11
  67. package/dist/{chunk-ARMGWHYU.js → chunk-DOSKHIRH.js} +16 -16
  68. package/dist/{chunk-UEEYZGM3.js → chunk-DRJAKRTI.js} +46 -17
  69. package/dist/{chunk-NEN6KWAJ.js → chunk-ED7XNGZD.js} +12 -12
  70. package/dist/{chunk-W576GZBG.js → chunk-EJTB2SLE.js} +9 -9
  71. package/dist/{chunk-32OKBVER.js → chunk-ELM74U2R.js} +5 -5
  72. package/dist/chunk-EREXPX6I.js +348 -0
  73. package/dist/{chunk-MNYDJXTM.js → chunk-FB7DDNCA.js} +5 -5
  74. package/dist/{chunk-GZBVMHXS.js → chunk-FFNSWUDC.js} +10 -10
  75. package/dist/{chunk-YKDEE7ZL.js → chunk-FTAR3BDS.js} +1 -1
  76. package/dist/{chunk-2OYCT5NO.js → chunk-G4PROEJI.js} +5 -5
  77. package/dist/{chunk-OQMBWJPH.js → chunk-GKW445WA.js} +1 -1
  78. package/dist/{chunk-LNAXUDW2.js → chunk-GLPS6QFG.js} +64 -62
  79. package/dist/{chunk-3IN6MMKV.js → chunk-GNLPUGYK.js} +2 -2
  80. package/dist/{chunk-3IBSB2U6.js → chunk-H23AKDB2.js} +14 -14
  81. package/dist/{chunk-Z2QQZOG3.js → chunk-H5PYBIOZ.js} +1 -1
  82. package/dist/{chunk-63OSYRLS.js → chunk-HR7TFO2X.js} +4 -4
  83. package/dist/{chunk-XB3HXEZB.js → chunk-HWBUIBJD.js} +77 -72
  84. package/dist/{chunk-4Q7LZQVY.js → chunk-IAWZQKUH.js} +10 -10
  85. package/dist/{chunk-2U5BRCQO.js → chunk-IEPNHH7Z.js} +1 -1
  86. package/dist/chunk-IIFQ7KYL.js +171 -0
  87. package/dist/{chunk-HNUA6XIW.js → chunk-IRTI3AS3.js} +14 -14
  88. package/dist/chunk-J65IXAGI.js +292 -0
  89. package/dist/{chunk-VIGX66F7.js → chunk-JQBSPUH2.js} +1 -1
  90. package/dist/{chunk-4ZN3D4YS.js → chunk-K4TGNN4P.js} +9 -9
  91. package/dist/{chunk-R46PKJUT.js → chunk-KXIA66EJ.js} +13 -13
  92. package/dist/{chunk-CIH5DSU7.js → chunk-LCGLQNOI.js} +11 -11
  93. package/dist/{chunk-RE3AYHPM.js → chunk-LLOKYZMI.js} +4 -4
  94. package/dist/chunk-LT3REHJG.js +2355 -0
  95. package/dist/{chunk-VVWB3GIK.js → chunk-LYZDVZWA.js} +3 -12
  96. package/dist/{chunk-AZAGUAN4.js → chunk-MN3AEVR7.js} +15 -15
  97. package/dist/{chunk-J24X54DB.js → chunk-MVNO35S5.js} +7 -7
  98. package/dist/{chunk-PIZ7FN3L.js → chunk-N2LH7A4X.js} +9 -9
  99. package/dist/{chunk-SPIVEW2Y.js → chunk-NQBSSM5V.js} +8 -8
  100. package/dist/{chunk-HKDFWQ6Q.js → chunk-NQEXDLYH.js} +460 -2
  101. package/dist/{chunk-HO7Z6MC3.js → chunk-NZ2LHIKD.js} +33 -33
  102. package/dist/{chunk-DBNPVU3L.js → chunk-OSEIN4Y2.js} +1 -1
  103. package/dist/{chunk-XBHUWCBD.js → chunk-P25PIADJ.js} +1 -1
  104. package/dist/{chunk-GPKTJXGG.js → chunk-PCLSODMO.js} +32 -32
  105. package/dist/{chunk-WRRMBJBQ.js → chunk-PXTJJQKJ.js} +1 -1
  106. package/dist/chunk-PYDRHQTY.js +24 -0
  107. package/dist/{chunk-ORI7UXS6.js → chunk-Q6I2IKJB.js} +6 -6
  108. package/dist/{chunk-X4DGVTMC.js → chunk-QIU6DJY6.js} +5 -5
  109. package/dist/{chunk-F67RRVMJ.js → chunk-RKH3A4O3.js} +13 -13
  110. package/dist/chunk-RQ4NMLSS.js +8 -0
  111. package/dist/{chunk-7QWLLYOY.js → chunk-RQPDD3RI.js} +1 -1
  112. package/dist/{chunk-DL2ZIXBO.js → chunk-S5BJ5CMF.js} +1 -1
  113. package/dist/chunk-SG76L7C7.js +61 -0
  114. package/dist/{chunk-3ZSYFPHB.js → chunk-SRDK3XX7.js} +20 -20
  115. package/dist/{chunk-SJQG3RCN.js → chunk-TGFZ4UBK.js} +19 -19
  116. package/dist/{chunk-WIQ2HBJG.js → chunk-TITPJHIL.js} +13 -13
  117. package/dist/{chunk-SOJ4TLWP.js → chunk-TP7L6M7V.js} +5 -5
  118. package/dist/{chunk-OG4WH7IW.js → chunk-U7XILJH6.js} +35 -32
  119. package/dist/{chunk-7MTFPHXR.js → chunk-UPNMDPFX.js} +6 -6
  120. package/dist/{chunk-7XXM72CF.js → chunk-UR6HGBFE.js} +62 -89
  121. package/dist/{chunk-5OS2MBRB.js → chunk-UXQAHUGZ.js} +8 -8
  122. package/dist/chunk-V5XHY5LP.js +39 -0
  123. package/dist/{chunk-NHAOR25V.js → chunk-W7NN2EFL.js} +20 -20
  124. package/dist/{chunk-YEUUI6JF.js → chunk-WDH5C2NS.js} +1 -1
  125. package/dist/{chunk-BEU674HI.js → chunk-WKCYMDTV.js} +5 -5
  126. package/dist/{chunk-M73MP4NC.js → chunk-WNYDGJ3E.js} +19 -19
  127. package/dist/{chunk-6MJ5HPIP.js → chunk-WS63IRBI.js} +3 -3
  128. package/dist/chunk-WV4SQ57G.js +141 -0
  129. package/dist/{chunk-Y3FXVIJO.js → chunk-WVKVPGJW.js} +4 -4
  130. package/dist/{chunk-GDHF6CT5.js → chunk-X45JKZYW.js} +11 -11
  131. package/dist/{chunk-GKJLFLGN.js → chunk-XJ3WC4G7.js} +4 -4
  132. package/dist/{chunk-4LQX5FRH.js → chunk-XODRTI2W.js} +7 -7
  133. package/dist/{chunk-U7WZYWGA.js → chunk-XZZTC7E5.js} +1 -1
  134. package/dist/{chunk-7A5WEMNW.js → chunk-Y3NVKGGI.js} +11 -11
  135. package/dist/{chunk-33XUAKRP.js → chunk-YGAX72XV.js} +3 -1
  136. package/dist/{chunk-FSPZYOY6.js → chunk-YLKG7W4P.js} +4 -4
  137. package/dist/{chunk-SESTTUVM.js → chunk-YN3FGNJM.js} +53 -1
  138. package/dist/{chunk-3T5S5RDO.js → chunk-ZHOI4QMK.js} +4 -4
  139. package/dist/{chunk-CEG375CR.js → chunk-ZSFJVRRS.js} +4 -4
  140. package/dist/chunk-ZZ3XFIEM.js +84 -0
  141. package/dist/{collection-add-products-IRYJ6U6P.js → collection-add-products-XL2TAKQD.js} +30 -29
  142. package/dist/{collection-create-3BTRORHU.js → collection-create-HUNYHKUJ.js} +2 -2
  143. package/dist/{collection-detail-263PM4DL.js → collection-detail-2DSZVOI7.js} +28 -27
  144. package/dist/{collection-edit-L5GPFBBX.js → collection-edit-OQGYTQDO.js} +2 -2
  145. package/dist/{collection-list-IVPTNBSI.js → collection-list-NGCW7OTG.js} +35 -36
  146. package/dist/{collection-metadata-KHGPTV5C.js → collection-metadata-47N7TUOH.js} +17 -16
  147. package/dist/{commission-rate-create-3N6BHEGT.js → commission-rate-create-BQY3UGKV.js} +53 -53
  148. package/dist/{commission-rate-detail-MY3F2RHR.js → commission-rate-detail-LAZZLZVX.js} +18 -17
  149. package/dist/{commission-rate-edit-WZDPXLLZ.js → commission-rate-edit-DAFXNYYN.js} +53 -53
  150. package/dist/{commission-rate-list-JPBOTOTA.js → commission-rate-list-Y5XLEO67.js} +8 -10
  151. package/dist/{constants-CAwtRicB.d.ts → constants-26tEckuq.d.ts} +3 -3
  152. package/dist/{customer-detail-2QBJPF7S.js → customer-detail-D5SSLNFT.js} +27 -28
  153. package/dist/{customer-group-add-customers-JCLAH45C.js → customer-group-add-customers-VJUBEN7M.js} +13 -15
  154. package/dist/{customer-group-detail-BDKFWKTI.js → customer-group-detail-KRT7E2JA.js} +24 -25
  155. package/dist/{customer-group-list-3NEEJXQH.js → customer-group-list-KKDIESQ6.js} +24 -25
  156. package/dist/{customer-group-metadata-YJXZFSFG.js → customer-group-metadata-J6JY7DZ3.js} +17 -16
  157. package/dist/{customer-list-ZIFNZXO4.js → customer-list-MB6WZFMA.js} +11 -13
  158. package/dist/{customer-metadata-SG6M7X3Q.js → customer-metadata-AH2LBK4T.js} +17 -16
  159. package/dist/{customers-add-customer-group-OQIFQZBL.js → customers-add-customer-group-AHGAPEIS.js} +27 -28
  160. package/dist/{edit-inventory-item-TDG2ZTPM.js → edit-inventory-item-ADNLKLCN.js} +13 -12
  161. package/dist/{edit-inventory-item-attributes-T56PJTCT.js → edit-inventory-item-attributes-XVR2WLDU.js} +13 -12
  162. package/dist/{edit-reservation-T6SKOG2F.js → edit-reservation-HQQL42QX.js} +7 -7
  163. package/dist/{edit-rules-4AHZQGCX.js → edit-rules-YMKM5JPI.js} +17 -15
  164. package/dist/index.d.ts +2 -2
  165. package/dist/index.js +824 -598
  166. package/dist/{inventory-create-P26OGAHD.js → inventory-create-IVESXFSV.js} +19 -18
  167. package/dist/{inventory-detail-7W7UUWNT.js → inventory-detail-TINIAFVB.js} +26 -27
  168. package/dist/{inventory-list-PA4B4RWY.js → inventory-list-YLIAKQXI.js} +10 -12
  169. package/dist/{inventory-metadata-LUGA3KNV.js → inventory-metadata-6INRH2JC.js} +17 -16
  170. package/dist/{inventory-stock-UZSYXXPX.js → inventory-stock-6YGTATID.js} +21 -20
  171. package/dist/loader-6KDBTRVR.js +26 -0
  172. package/dist/{location-detail-RUC2ZP3K.js → location-detail-EK2S7WOK.js} +22 -21
  173. package/dist/{location-fulfillment-providers-WDET6TJP.js → location-fulfillment-providers-KUUNC2KP.js} +36 -36
  174. package/dist/{location-list-R7EECG5Z.js → location-list-IV323QW2.js} +19 -19
  175. package/dist/{location-sales-channels-IS6E3I4S.js → location-sales-channels-EYUXMTW7.js} +12 -12
  176. package/dist/{location-service-zone-create-HAQVVTKP.js → location-service-zone-create-ZS3UWJAA.js} +8 -11
  177. package/dist/{location-service-zone-manage-areas-5LCENMAM.js → location-service-zone-manage-areas-S7QZTIFT.js} +8 -11
  178. package/dist/{location-service-zone-shipping-option-create-FV5Y2PNB.js → location-service-zone-shipping-option-create-36JZFRGY.js} +23 -21
  179. package/dist/{location-service-zone-shipping-option-edit-PLEDWIY3.js → location-service-zone-shipping-option-edit-3PGSNKYT.js} +8 -7
  180. package/dist/{location-service-zone-shipping-option-pricing-6QHLZ6IN.js → location-service-zone-shipping-option-pricing-JLGCOZGS.js} +8 -8
  181. package/dist/{login-EWHQY6G3.js → login-6L3RMREO.js} +13 -12
  182. package/dist/{manage-locations-TU5HCIKG.js → manage-locations-CFTM6DNH.js} +1 -1
  183. package/dist/{marketplace-add-currencies-PB73MHM6.js → marketplace-add-currencies-6ANNBGZM.js} +8 -10
  184. package/dist/{marketplace-detail-3KFGJWQ7.js → marketplace-detail-BAU2MEJT.js} +22 -23
  185. package/dist/{marketplace-edit-U5B6WA56.js → marketplace-edit-6Q3G2OY5.js} +5 -4
  186. package/dist/{marketplace-metadata-VYCPYFJD.js → marketplace-metadata-KRCGKOCA.js} +17 -16
  187. package/dist/offers-IFKM6EQT.js +440 -0
  188. package/dist/{order-allocate-items-2B6T5JCK.js → order-allocate-items-DJ2V4B7A.js} +11 -11
  189. package/dist/{order-create-claim-R2SX6YUS.js → order-create-claim-RMDDCUZ6.js} +27 -61
  190. package/dist/{order-create-edit-G35PDCQ2.js → order-create-edit-PQ54JFZZ.js} +24 -58
  191. package/dist/{order-create-exchange-7KKMJHXE.js → order-create-exchange-T6DBVS75.js} +41 -48
  192. package/dist/{order-create-fulfillment-2FTTWTFE.js → order-create-fulfillment-SMSUJSBN.js} +22 -20
  193. package/dist/{order-create-refund-KWYYLAED.js → order-create-refund-OW3MIXBY.js} +17 -16
  194. package/dist/{order-create-return-BQFRANNG.js → order-create-return-YCX6C3VP.js} +25 -27
  195. package/dist/{order-create-shipment-7XP6PDTD.js → order-create-shipment-5ZAWH5CZ.js} +14 -13
  196. package/dist/{order-detail-BITJD73H.js → order-detail-2OAEGBQG.js} +29 -30
  197. package/dist/{order-edit-billing-address-FLEI4VDB.js → order-edit-billing-address-VGZBQHF5.js} +15 -14
  198. package/dist/{order-edit-email-AZIA6X5Q.js → order-edit-email-OOCXVRET.js} +14 -13
  199. package/dist/{order-edit-shipping-address-GJMUSOPK.js → order-edit-shipping-address-B4F3E5RE.js} +14 -13
  200. package/dist/{order-list-D2SJOMZ2.js → order-list-DQTMCEFD.js} +25 -27
  201. package/dist/{order-metadata-RXIJOP4V.js → order-metadata-AN6MPHHT.js} +18 -17
  202. package/dist/{order-receive-return-JV3X7YHG.js → order-receive-return-DZ4IUOHY.js} +20 -19
  203. package/dist/{order-request-transfer-6IZVCHGV.js → order-request-transfer-A2NJSQ4H.js} +16 -14
  204. package/dist/pages/index.d.ts +702 -566
  205. package/dist/pages/index.js +192 -184
  206. package/dist/{payout-detail-JWS2Q4TY.js → payout-detail-TWO6HN4E.js} +3 -3
  207. package/dist/{payout-list-PW6BFT4O.js → payout-list-7WJZFNW5.js} +9 -11
  208. package/dist/{price-list-configuration-N5D5OFXX.js → price-list-configuration-XAHXLCXR.js} +13 -15
  209. package/dist/{price-list-create-NQFC2JIJ.js → price-list-create-37SCDSPN.js} +35 -34
  210. package/dist/{price-list-detail-HRVLVBPS.js → price-list-detail-4Q2HBLAM.js} +30 -29
  211. package/dist/{price-list-edit-BVVLQ5WV.js → price-list-edit-ZVLD4M5T.js} +5 -5
  212. package/dist/{price-list-list-K4IJFZYH.js → price-list-list-ER4TOZTY.js} +13 -15
  213. package/dist/{price-list-prices-add-WXEGEWRA.js → price-list-prices-add-UASPZXKT.js} +31 -30
  214. package/dist/{price-list-prices-edit-KJEKS6TL.js → price-list-prices-edit-WHCIGSB2.js} +22 -21
  215. package/dist/product-add-existing-attributes-7HEJUR6J.js +420 -0
  216. package/dist/{product-attributes-ASPKDH7H.js → product-attributes-MHRXZK5S.js} +4 -4
  217. package/dist/product-brand-create-B3ZJGHUQ.js +171 -0
  218. package/dist/product-brand-detail-6MPQ3UFN.js +100 -0
  219. package/dist/product-brand-edit-3TQDHZNN.js +179 -0
  220. package/dist/product-brand-list-ZBPBSRQN.js +30 -0
  221. package/dist/product-brand-metadata-EAMW6PQJ.js +87 -0
  222. package/dist/product-bulk-edit-J6ZP7GGM.js +287 -0
  223. package/dist/{product-create-BDQ66ECX.js → product-create-KHJWRSUB.js} +34 -34
  224. package/dist/product-create-attribute-ZT3VZDNZ.js +196 -0
  225. package/dist/{product-create-option-B7SV42LO.js → product-create-option-NIAP75EE.js} +6 -24
  226. package/dist/{product-create-variant-7YAG2YRZ.js → product-create-variant-LCE47YFO.js} +25 -21
  227. package/dist/{product-detail-DCHR4B4T.js → product-detail-GLISGO65.js} +25 -27
  228. package/dist/{product-edit-IASCMBET.js → product-edit-EKAZRIJ6.js} +15 -8
  229. package/dist/product-edit-option-OZUZGMIM.js +166 -0
  230. package/dist/{product-list-X72QPKOK.js → product-list-2CTGPDDT.js} +31 -30
  231. package/dist/{product-media-VNSFLCSH.js → product-media-KREKRDOC.js} +15 -8
  232. package/dist/{product-metadata-GJ7C2UJG.js → product-metadata-O3BAEUYB.js} +20 -19
  233. package/dist/{product-organization-PN22LYKQ.js → product-organization-SBQY44IF.js} +61 -18
  234. package/dist/{product-prices-HI4SOTMP.js → product-prices-R5JOHVGS.js} +8 -8
  235. package/dist/{product-sales-channels-J2ZNRKZT.js → product-sales-channels-TFOGXCMI.js} +15 -15
  236. package/dist/{product-shipping-profile-G7UPGWYK.js → product-shipping-profile-E4HJ4EYW.js} +6 -5
  237. package/dist/{product-stock-666D3AMJ.js → product-stock-EIP2XJUR.js} +28 -27
  238. package/dist/{product-tag-create-PHJICTE4.js → product-tag-create-7JBM6I3V.js} +13 -12
  239. package/dist/{product-tag-detail-B7JEBNMJ.js → product-tag-detail-MTFAPSG2.js} +51 -51
  240. package/dist/{product-tag-edit-G4UNGXPT.js → product-tag-edit-O2ADFDD6.js} +13 -12
  241. package/dist/{product-tag-list-MAUUWH25.js → product-tag-list-EOULJIYQ.js} +51 -51
  242. package/dist/{product-tag-metadata-I4V6CR6Z.js → product-tag-metadata-SBOUTUXY.js} +17 -16
  243. package/dist/{product-type-detail-7GHH4ACU.js → product-type-detail-H4CZN27J.js} +28 -27
  244. package/dist/{product-type-list-LTYTTF4F.js → product-type-list-TM26QMHR.js} +12 -14
  245. package/dist/{product-type-metadata-KGVRMMTQ.js → product-type-metadata-KN5OXR6J.js} +17 -16
  246. package/dist/{product-variant-detail-PHGVJWUV.js → product-variant-detail-H2YRFDAU.js} +27 -37
  247. package/dist/product-variant-edit-6W7LKCEE.js +867 -0
  248. package/dist/{product-variant-manage-inventory-items-WENX2QCZ.js → product-variant-manage-inventory-items-Q5MJG3EJ.js} +6 -10
  249. package/dist/{product-variant-metadata-HV72UBCP.js → product-variant-metadata-QESZ7VS2.js} +17 -16
  250. package/dist/{profile-detail-UQTGEFYF.js → profile-detail-ZRL5SERS.js} +4 -4
  251. package/dist/{promotion-add-campaign-M4OT6URB.js → promotion-add-campaign-O3RTMS3W.js} +6 -5
  252. package/dist/{promotion-create-GM37OXEW.js → promotion-create-TGC6BVWF.js} +23 -21
  253. package/dist/{promotion-detail-PDBRQII7.js → promotion-detail-VYIXZMMD.js} +21 -20
  254. package/dist/{promotion-list-XW4PNLJF.js → promotion-list-C3SKV5BJ.js} +13 -15
  255. package/dist/{refund-reason-create-M2CYTCEM.js → refund-reason-create-2KEQFOID.js} +13 -12
  256. package/dist/{refund-reason-edit-M4XBV633.js → refund-reason-edit-E7CB7SM3.js} +13 -12
  257. package/dist/{refund-reason-list-2S2MDKBQ.js → refund-reason-list-TAHJK4OX.js} +37 -35
  258. package/dist/{region-add-countries-T4XZ2CU3.js → region-add-countries-COXN4LP3.js} +7 -9
  259. package/dist/{region-create-MQXTWBKC.js → region-create-P66Q65XY.js} +14 -15
  260. package/dist/{region-detail-6OFP76OY.js → region-detail-P2HHBYFV.js} +11 -13
  261. package/dist/{region-edit-QNJ2HT76.js → region-edit-XFE54SAO.js} +8 -7
  262. package/dist/{region-list-EYTDREE2.js → region-list-2XXKCDDX.js} +11 -13
  263. package/dist/{region-metadata-4JWOEGTZ.js → region-metadata-723RQGHS.js} +17 -16
  264. package/dist/{reservation-create-26QAWABA.js → reservation-create-Y3HG4AZA.js} +4 -4
  265. package/dist/{reservation-detail-G26K6HZV.js → reservation-detail-HQMADZ56.js} +19 -18
  266. package/dist/{reservation-list-CHHR6CEV.js → reservation-list-YKC3JJ6K.js} +11 -13
  267. package/dist/{reservation-metadata-JFLJ27A3.js → reservation-metadata-UG4YTEMY.js} +18 -17
  268. package/dist/{reset-password-S6IBWG47.js → reset-password-2VNU52CE.js} +1 -1
  269. package/dist/{return-reason-list-MCGW2JV3.js → return-reason-list-IHFO2LJK.js} +27 -28
  270. package/dist/{sales-channel-add-products-FH7B7UYR.js → sales-channel-add-products-YZTQ2SDS.js} +31 -30
  271. package/dist/{sales-channel-create-NSZEHGZE.js → sales-channel-create-BSNCLZWR.js} +2 -2
  272. package/dist/{sales-channel-detail-KCS472HN.js → sales-channel-detail-67G7K3IE.js} +28 -27
  273. package/dist/{sales-channel-edit-W6Z2ERBJ.js → sales-channel-edit-FUDXMZYV.js} +2 -2
  274. package/dist/{sales-channel-list-6HBRUZ2Z.js → sales-channel-list-GYLGH4U7.js} +21 -20
  275. package/dist/{sales-channel-metadata-NDSKXOGH.js → sales-channel-metadata-H6RSHKVP.js} +17 -16
  276. package/dist/{shipping-option-type-create-MEL24PGH.js → shipping-option-type-create-QAOW7753.js} +13 -12
  277. package/dist/{shipping-option-type-detail-IS7CNAYI.js → shipping-option-type-detail-QGWVDTDU.js} +19 -18
  278. package/dist/{shipping-option-type-edit-IVBHURXR.js → shipping-option-type-edit-WXYBDRNY.js} +13 -12
  279. package/dist/{shipping-option-type-list-BTPCLBSD.js → shipping-option-type-list-YSWP6DSC.js} +24 -25
  280. package/dist/{shipping-profile-detail-L3IHPGLL.js → shipping-profile-detail-YAKZHWZI.js} +5 -5
  281. package/dist/{shipping-profile-metadata-UZPX2PHJ.js → shipping-profile-metadata-UE53IA3J.js} +19 -18
  282. package/dist/{shipping-profiles-list-2JKVMEZG.js → shipping-profiles-list-JF2SQIQ7.js} +9 -11
  283. package/dist/{store-bulk-edit-A4ZWZ7HJ.js → store-bulk-edit-UYNQ2CPG.js} +7 -7
  284. package/dist/{store-create-OQVFVIK4.js → store-create-WNFRHXWR.js} +13 -12
  285. package/dist/{store-details-BOGWBWE7.js → store-details-R2GQU7HE.js} +44 -44
  286. package/dist/{store-edit-77WKNZUH.js → store-edit-UW3QOFFX.js} +11 -11
  287. package/dist/{store-list-2G34KVD5.js → store-list-5CV7VJLO.js} +36 -37
  288. package/dist/{store-member-invite-4GDKCSTT.js → store-member-invite-M4NVBUXM.js} +3 -3
  289. package/dist/{tax-region-create-5DDZ23QQ.js → tax-region-create-3KVECMFN.js} +16 -14
  290. package/dist/{tax-region-detail-VNBNS7FS.js → tax-region-detail-AOT4X4DZ.js} +26 -26
  291. package/dist/{tax-region-edit-OARZRBVK.js → tax-region-edit-5T7VHKIA.js} +15 -13
  292. package/dist/{tax-region-list-WCHVLVVC.js → tax-region-list-FIBHEFVD.js} +9 -9
  293. package/dist/{tax-region-metadata-XJRFOG7I.js → tax-region-metadata-RSZCJGJT.js} +17 -16
  294. package/dist/{tax-region-province-detail-MXYZMUX7.js → tax-region-province-detail-XEMIX5SQ.js} +24 -24
  295. package/dist/{tax-region-tax-override-create-VIOPM26G.js → tax-region-tax-override-create-KVVY4AF2.js} +54 -54
  296. package/dist/{tax-region-tax-override-edit-5FW6YCCW.js → tax-region-tax-override-edit-TVX7SMJD.js} +54 -54
  297. package/dist/{user-detail-LGIMHLY4.js → user-detail-W7DGVXDZ.js} +6 -6
  298. package/dist/{user-invite-ZZSWFXFM.js → user-invite-HLZJ7FST.js} +14 -16
  299. package/dist/{user-list-5QJJS7EA.js → user-list-TR7RSGUO.js} +9 -11
  300. package/dist/{user-metadata-376YJMY3.js → user-metadata-3AFZX3DM.js} +17 -16
  301. package/package.json +3 -3
  302. package/dist/attribute-create-EAOQ6KT6.js +0 -1010
  303. package/dist/attribute-create-possible-value-BIU2L7AN.js +0 -437
  304. package/dist/attribute-edit-DRHFOHMK.js +0 -282
  305. package/dist/attribute-edit-possible-value-G2ON2AE3.js +0 -264
  306. package/dist/chunk-35NDMIYZ.js +0 -8
  307. package/dist/chunk-4GPAS5GW.js +0 -36
  308. package/dist/chunk-4ZTZTIIM.js +0 -69
  309. package/dist/chunk-7O5NDICV.js +0 -120
  310. package/dist/chunk-IGTRIAUC.js +0 -84
  311. package/dist/chunk-KYPPQGGE.js +0 -467
  312. package/dist/chunk-LBXPX3XC.js +0 -1260
  313. package/dist/chunk-LO7XX5M7.js +0 -6
  314. package/dist/chunk-MXGDKEU5.js +0 -248
  315. package/dist/chunk-QOQSXNEF.js +0 -37
  316. package/dist/chunk-RSBZREKG.js +0 -144
  317. package/dist/chunk-WCEMRNW4.js +0 -6
  318. package/dist/chunk-Z5I2Z6L3.js +0 -160
  319. package/dist/chunk-ZMC7BKLT.js +0 -56
  320. package/dist/chunk-ZXYKF4A2.js +0 -2146
  321. package/dist/product-edit-option-KVTIY5NM.js +0 -156
  322. package/dist/product-export-E7RBOIO6.js +0 -137
  323. package/dist/product-import-KOSPPCSW.js +0 -267
  324. package/dist/product-variant-edit-L77HDGTA.js +0 -547
  325. package/dist/{chunk-XCANTVXS.js → chunk-CPXK5RSJ.js} +6 -6
  326. package/dist/{chunk-Y6NK6GBB.js → chunk-GP4J42UD.js} +5 -5
  327. package/dist/{chunk-L56WFGUN.js → chunk-IMR3MZDP.js} +3 -3
  328. package/dist/{chunk-OB4NOV4M.js → chunk-LYZT5REU.js} +3 -3
  329. package/dist/{chunk-ZBJ56XDB.js → chunk-Q2ULPJJ6.js} +3 -3
  330. package/dist/{chunk-MWX5JCOM.js → chunk-V6OGMYAI.js} +3 -3
  331. package/dist/{chunk-KCYUY2AI.js → chunk-WQFFCK3R.js} +6 -6
  332. package/dist/{chunk-ZW34ZAIP.js → chunk-WYA62MUL.js} +8 -8
  333. package/dist/{chunk-56AUQBQX.js → chunk-YYMACYP6.js} +5 -5
  334. package/dist/{customer-edit-X4HQOUAE.js → customer-edit-JZ4PQTIN.js} +3 -3
  335. package/dist/{profile-edit-Y5UUUKVH.js → profile-edit-HQTWYWZ7.js} +6 -6
  336. 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
- };