@medusajs/dashboard 3.0.0-snapshot-20251106143524 → 3.0.0-snapshot-20251106181920

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 (267) hide show
  1. package/dist/{add-campaign-promotions-UR3UM3MV.mjs → add-campaign-promotions-ZUJD7HBF.mjs} +4 -4
  2. package/dist/{adjust-inventory-7EWRE2HD.mjs → adjust-inventory-MEJEPP4Y.mjs} +1 -1
  3. package/dist/{api-key-management-create-SPLD3JMO.mjs → api-key-management-create-4OZWVOSF.mjs} +3 -3
  4. package/dist/{api-key-management-detail-Z6V22XWR.mjs → api-key-management-detail-K3A3T6ET.mjs} +17 -17
  5. package/dist/{api-key-management-edit-2VPL7PHB.mjs → api-key-management-edit-FYLVVQOA.mjs} +3 -3
  6. package/dist/{api-key-management-list-TVLEYYQO.mjs → api-key-management-list-6YG52LWY.mjs} +8 -8
  7. package/dist/{api-key-management-sales-channels-Y25FWD5A.mjs → api-key-management-sales-channels-S5IFH7LP.mjs} +8 -8
  8. package/dist/app.css +3 -3
  9. package/dist/app.js +58386 -60410
  10. package/dist/app.mjs +12 -12
  11. package/dist/{campaign-create-GD2D45NX.mjs → campaign-create-NEKUWDGF.mjs} +2 -2
  12. package/dist/{campaign-detail-YDLSCIRO.mjs → campaign-detail-2H2W4W5B.mjs} +15 -15
  13. package/dist/{campaign-list-M2462W5W.mjs → campaign-list-3452F4Y6.mjs} +6 -6
  14. package/dist/{categories-metadata-2HM7G27P.mjs → categories-metadata-ZEYU33GV.mjs} +10 -10
  15. package/dist/{category-create-BC2VUVKO.mjs → category-create-N7PP3GWU.mjs} +5 -5
  16. package/dist/{category-detail-IZ3AWOCP.mjs → category-detail-DKY37LPO.mjs} +18 -18
  17. package/dist/{category-edit-U5Y5KJ2Y.mjs → category-edit-IFDQP7EZ.mjs} +2 -2
  18. package/dist/{category-list-BJLRBYZC.mjs → category-list-2M4BCRAL.mjs} +9 -9
  19. package/dist/{category-organize-4NXFDN2I.mjs → category-organize-76I7PO24.mjs} +2 -2
  20. package/dist/{category-products-55LDLRRQ.mjs → category-products-VVRGW25X.mjs} +17 -17
  21. package/dist/{chunk-VEYZCWO5.mjs → chunk-227DWSFF.mjs} +16 -16
  22. package/dist/{chunk-2X25XWOW.mjs → chunk-2D44OO7A.mjs} +1 -1
  23. package/dist/{chunk-CV65NY6Y.mjs → chunk-2WZUO66T.mjs} +1 -1
  24. package/dist/{chunk-IKXQEHLS.mjs → chunk-3G33PZVQ.mjs} +1 -1
  25. package/dist/{chunk-ULQ3V4CC.mjs → chunk-3MPO56OL.mjs} +2 -2
  26. package/dist/{chunk-SUYYSKCB.mjs → chunk-67ORSRVT.mjs} +16 -23
  27. package/dist/{chunk-MQALAB34.mjs → chunk-7PWZ5GMG.mjs} +1 -1
  28. package/dist/{chunk-5IPYLNMF.mjs → chunk-ET6EGRW3.mjs} +692 -3840
  29. package/dist/{chunk-6IXLTZ2H.mjs → chunk-FA5QNPXE.mjs} +2 -2
  30. package/dist/{chunk-GU5PJRPM.mjs → chunk-FKIOYL3D.mjs} +1 -1
  31. package/dist/{chunk-IXZVR3HG.mjs → chunk-GBKLLUUX.mjs} +1 -1
  32. package/dist/{chunk-ALKTJGWS.mjs → chunk-GI6XX5VU.mjs} +2 -2
  33. package/dist/{chunk-PVW6M64S.mjs → chunk-GLVCH422.mjs} +1 -1
  34. package/dist/{chunk-4BGVSXZZ.mjs → chunk-GVPJPLE2.mjs} +15 -48
  35. package/dist/{chunk-6XWHQ6ON.mjs → chunk-GVVAVAXG.mjs} +1 -1
  36. package/dist/{chunk-3DO2JGVG.mjs → chunk-HGFZAXHD.mjs} +1 -1
  37. package/dist/{chunk-3C6WQ7NH.mjs → chunk-IBSMG7AF.mjs} +37 -3
  38. package/dist/{chunk-GA3UMQMZ.mjs → chunk-IVZ6BMDB.mjs} +1 -1
  39. package/dist/{chunk-EQKJ5FSL.mjs → chunk-JAXWGF4M.mjs} +1 -1
  40. package/dist/{chunk-LEKWKUIS.mjs → chunk-JC75WAC7.mjs} +3 -3
  41. package/dist/{chunk-MBGEZAIM.mjs → chunk-JDA2MYND.mjs} +1 -1
  42. package/dist/{chunk-LOAL44PP.mjs → chunk-JDEH6Z4M.mjs} +1 -1
  43. package/dist/{chunk-2O43G3RH.mjs → chunk-LYTIMAIZ.mjs} +1 -1
  44. package/dist/{chunk-OGAZYXOV.mjs → chunk-NGR5XU3K.mjs} +1 -1
  45. package/dist/{chunk-3JJBLFYN.mjs → chunk-OI4W5AEL.mjs} +6 -2
  46. package/dist/{chunk-T57MRRCF.mjs → chunk-ORMX5RJQ.mjs} +1 -1
  47. package/dist/{chunk-XYHXWLTJ.mjs → chunk-P5RVJWPK.mjs} +1 -1
  48. package/dist/{chunk-DZWH2RV6.mjs → chunk-PFKKVLZX.mjs} +1 -1
  49. package/dist/{chunk-YTN73JYH.mjs → chunk-PJ5EUKOB.mjs} +1 -1
  50. package/dist/{chunk-2GWGNMAA.mjs → chunk-Q33G337Z.mjs} +1 -1
  51. package/dist/{chunk-YGLRZQ4C.mjs → chunk-QXXHLVRQ.mjs} +1 -1
  52. package/dist/{chunk-M4Q5Q4I3.mjs → chunk-S34JJVBQ.mjs} +2 -2
  53. package/dist/{chunk-WTK7SR6S.mjs → chunk-SBFWPL42.mjs} +2 -2
  54. package/dist/{chunk-ROKB75YP.mjs → chunk-SJ3E4T6B.mjs} +1 -1
  55. package/dist/{chunk-3BE5PBQZ.mjs → chunk-SMDWWXCD.mjs} +4 -4
  56. package/dist/{chunk-NDXL7ZT5.mjs → chunk-TNMXAPPT.mjs} +1 -1
  57. package/dist/{chunk-S5GNHYAG.mjs → chunk-UTVAHVAY.mjs} +6 -6
  58. package/dist/{chunk-NL376WAO.mjs → chunk-VAIHVNV6.mjs} +1 -1
  59. package/dist/{chunk-YA5PS6KW.mjs → chunk-W77EPLUD.mjs} +1 -1
  60. package/dist/{chunk-KXRW6JRE.mjs → chunk-WOFUOGLO.mjs} +123 -33
  61. package/dist/{chunk-N4N4KGET.mjs → chunk-WWQZD7WM.mjs} +1 -1
  62. package/dist/{chunk-5IFK2ZTA.mjs → chunk-Y2XQE25L.mjs} +2 -2
  63. package/dist/{chunk-R2QF6AQX.mjs → chunk-Y6ZQFV7H.mjs} +1 -1
  64. package/dist/{chunk-WGIRB6HY.mjs → chunk-YSQG2JDM.mjs} +1 -1
  65. package/dist/chunk-ZHH3W7CN.mjs +171 -0
  66. package/dist/{collection-add-products-7CFVTCLK.mjs → collection-add-products-QCSFXELK.mjs} +18 -18
  67. package/dist/{collection-create-CUZFWEOB.mjs → collection-create-45RYGDW7.mjs} +2 -2
  68. package/dist/{collection-detail-3NMMB3CC.mjs → collection-detail-OLC6DMBZ.mjs} +18 -18
  69. package/dist/{collection-edit-22I7EEJG.mjs → collection-edit-YBPBHLLZ.mjs} +2 -2
  70. package/dist/{collection-list-VNKB3725.mjs → collection-list-6UJNE2QB.mjs} +28 -27
  71. package/dist/{collection-metadata-ZUFYY4OU.mjs → collection-metadata-QG55V5ZM.mjs} +11 -11
  72. package/dist/{customer-detail-PAYUFGP6.mjs → customer-detail-XOCZDUJL.mjs} +20 -20
  73. package/dist/{customer-group-add-customers-MW2XH2F6.mjs → customer-group-add-customers-TQAH4IPM.mjs} +9 -9
  74. package/dist/{customer-group-detail-LJ6YVB2C.mjs → customer-group-detail-EWSDTVTQ.mjs} +19 -19
  75. package/dist/{customer-group-list-M2OOZLIZ.mjs → customer-group-list-NFXAELFY.mjs} +15 -15
  76. package/dist/{customer-list-MZ7ZRERV.mjs → customer-list-TXAB4URJ.mjs} +9 -9
  77. package/dist/{customers-add-customer-group-IAIRRQ2I.mjs → customers-add-customer-group-EYZMFVBS.mjs} +17 -17
  78. package/dist/{edit-inventory-item-5RPZHCM7.mjs → edit-inventory-item-TFJL5H5X.mjs} +1 -1
  79. package/dist/{edit-inventory-item-attributes-R73ZTBYG.mjs → edit-inventory-item-attributes-O3K7OB56.mjs} +1 -1
  80. package/dist/{edit-reservation-WMLAFMYU.mjs → edit-reservation-Z5TFZERY.mjs} +2 -2
  81. package/dist/{edit-rules-KV43O773.mjs → edit-rules-IE77WUXD.mjs} +10 -10
  82. package/dist/en.json +51 -4
  83. package/dist/{inventory-create-NW5WSPBV.mjs → inventory-create-HQ5XLKOJ.mjs} +10 -10
  84. package/dist/{inventory-detail-ZJ5U5FSA.mjs → inventory-detail-DAINM7WP.mjs} +14 -14
  85. package/dist/{inventory-list-HHTQRKQW.mjs → inventory-list-5ROSUTXF.mjs} +5 -5
  86. package/dist/{inventory-metadata-7XR4ON7G.mjs → inventory-metadata-HUL56OD2.mjs} +10 -10
  87. package/dist/{inventory-stock-VTIDGTOY.mjs → inventory-stock-5VIUWKTQ.mjs} +10 -10
  88. package/dist/{location-detail-WZM4EXFM.mjs → location-detail-QMLCFID5.mjs} +15 -15
  89. package/dist/{location-fulfillment-providers-DNIVH7XD.mjs → location-fulfillment-providers-NAFFMP3P.mjs} +19 -18
  90. package/dist/{location-sales-channels-3JAXXM3Q.mjs → location-sales-channels-D37LXTKQ.mjs} +7 -7
  91. package/dist/{location-service-zone-create-D2HXXX63.mjs → location-service-zone-create-27MNMKPQ.mjs} +5 -5
  92. package/dist/{location-service-zone-manage-areas-LVVT6XBE.mjs → location-service-zone-manage-areas-U3EPNWSI.mjs} +5 -5
  93. package/dist/{location-service-zone-shipping-option-create-F3EQW67U.mjs → location-service-zone-shipping-option-create-VM4TEJHY.mjs} +10 -10
  94. package/dist/{login-VZALGB6R.mjs → login-MTGOV7KC.mjs} +10 -10
  95. package/dist/{manage-locations-WMH3RQMR.mjs → manage-locations-OHDFBORX.mjs} +1 -1
  96. package/dist/{order-allocate-items-MZ7Y4FU4.mjs → order-allocate-items-NU65ZXHE.mjs} +3 -3
  97. package/dist/{order-create-claim-2FPE6XP2.mjs → order-create-claim-LTE2E75R.mjs} +20 -20
  98. package/dist/{order-create-edit-PVGKIS6G.mjs → order-create-edit-TPU3CKUU.mjs} +15 -15
  99. package/dist/{order-create-exchange-G4JY4FSX.mjs → order-create-exchange-FVSBZI7P.mjs} +26 -26
  100. package/dist/{order-create-fulfillment-VTICR6OE.mjs → order-create-fulfillment-NFGPDCBV.mjs} +13 -13
  101. package/dist/{order-create-refund-RWDVIXPV.mjs → order-create-refund-DC7C3R4Y.mjs} +15 -15
  102. package/dist/{order-create-return-VEUCH5BA.mjs → order-create-return-RLXYVZLO.mjs} +8 -8
  103. package/dist/{order-create-shipment-2KNYEHSU.mjs → order-create-shipment-RDYWCG3A.mjs} +10 -10
  104. package/dist/{order-detail-2EFNG3UB.mjs → order-detail-VVOZ6E2R.mjs} +33 -33
  105. package/dist/{order-edit-billing-address-T6BIIRAX.mjs → order-edit-billing-address-LV7453CS.mjs} +10 -10
  106. package/dist/{order-edit-email-SLUOGWRO.mjs → order-edit-email-4U5C6UKX.mjs} +10 -10
  107. package/dist/{order-edit-shipping-address-YUES5K5Q.mjs → order-edit-shipping-address-6IQC2CVP.mjs} +10 -10
  108. package/dist/{order-list-EEC3VSLN.mjs → order-list-INSYF52F.mjs} +13 -13
  109. package/dist/{order-metadata-HS33MC6S.mjs → order-metadata-EEV4IWOM.mjs} +10 -10
  110. package/dist/{order-receive-return-E6BGSZVL.mjs → order-receive-return-IWHR3EBF.mjs} +11 -11
  111. package/dist/{order-request-transfer-7IIDQ37I.mjs → order-request-transfer-65R4A7HS.mjs} +10 -10
  112. package/dist/{price-list-configuration-WQEQFG6M.mjs → price-list-configuration-L5XYCVP2.mjs} +8 -8
  113. package/dist/{price-list-create-36BOXETM.mjs → price-list-create-5GIMBRG2.mjs} +21 -21
  114. package/dist/{price-list-detail-6CJ63F65.mjs → price-list-detail-7AL2EBRL.mjs} +22 -22
  115. package/dist/{price-list-edit-GXDLVOU4.mjs → price-list-edit-DHG5STG4.mjs} +2 -2
  116. package/dist/{price-list-list-2HDOJIC6.mjs → price-list-list-QQKZEFSU.mjs} +7 -7
  117. package/dist/{price-list-prices-add-AVPP57TL.mjs → price-list-prices-add-2OO4QEZB.mjs} +17 -17
  118. package/dist/{price-list-prices-edit-J7HCNDTO.mjs → price-list-prices-edit-2FB25KWU.mjs} +2 -2
  119. package/dist/{product-attributes-TWEJQQBK.mjs → product-attributes-CCQ6WAOD.mjs} +13 -13
  120. package/dist/{product-create-GTUUDEAP.mjs → product-create-AIRCVZAE.mjs} +346 -552
  121. package/dist/{product-create-variant-ZWY57BX7.mjs → product-create-variant-7BD5KQHQ.mjs} +10 -10
  122. package/dist/{product-detail-F4MVAHFN.mjs → product-detail-IYMXYAPH.mjs} +28 -55
  123. package/dist/{product-edit-NEIZ3SID.mjs → product-edit-PDGQHCQ2.mjs} +13 -13
  124. package/dist/{product-export-5WBXPUYP.mjs → product-export-5EINLQDF.mjs} +26 -25
  125. package/dist/{product-image-variants-edit-T3STDZJG.mjs → product-image-variants-edit-DDSEBG5H.mjs} +14 -14
  126. package/dist/{product-import-5VLF2ZN4.mjs → product-import-IQJWHNYN.mjs} +10 -10
  127. package/dist/{product-list-BX2QNNQK.mjs → product-list-PUQEGU75.mjs} +23 -23
  128. package/dist/{product-media-Z3NNTB7H.mjs → product-media-Q5XFYZRS.mjs} +2 -2
  129. package/dist/{product-metadata-LMDEXR3V.mjs → product-metadata-WCKNOZXX.mjs} +10 -10
  130. package/dist/product-option-create-MWFWB2SU.mjs +336 -0
  131. package/dist/product-option-detail-UKKEZPG7.mjs +323 -0
  132. package/dist/product-option-edit-NHAF7B4P.mjs +324 -0
  133. package/dist/product-option-list-C6ZR2WIX.mjs +266 -0
  134. package/dist/product-option-metadata-OWSGHNDC.mjs +71 -0
  135. package/dist/product-options-manage-N73G5IXY.mjs +206 -0
  136. package/dist/{product-organization-5N2EIUXB.mjs → product-organization-HHME5F2C.mjs} +14 -14
  137. package/dist/{product-prices-MCZYVPQW.mjs → product-prices-GVEPABHQ.mjs} +1 -1
  138. package/dist/{product-sales-channels-LRMOPHMH.mjs → product-sales-channels-ZC5ONPG7.mjs} +7 -7
  139. package/dist/{product-shipping-profile-AHJE77VR.mjs → product-shipping-profile-KXSBDGRD.mjs} +13 -13
  140. package/dist/{product-stock-O2BH5R45.mjs → product-stock-LXRLD7FA.mjs} +10 -10
  141. package/dist/{product-tag-create-GOJTE5XA.mjs → product-tag-create-RAJEWM5O.mjs} +10 -10
  142. package/dist/{product-tag-detail-LDKRRJWH.mjs → product-tag-detail-EOW2GMOL.mjs} +36 -35
  143. package/dist/{product-tag-edit-IT4GHLSO.mjs → product-tag-edit-ZOO56XMF.mjs} +10 -10
  144. package/dist/{product-tag-list-3ERYK5WE.mjs → product-tag-list-B2UX2OHB.mjs} +35 -34
  145. package/dist/{product-tag-metadata-QV2BOGP2.mjs → product-tag-metadata-OZB7SVDN.mjs} +10 -10
  146. package/dist/{product-type-detail-UJ6QTCGQ.mjs → product-type-detail-4YZUC6ZS.mjs} +17 -17
  147. package/dist/{product-type-list-73DQPW4H.mjs → product-type-list-J2WDYTZK.mjs} +9 -9
  148. package/dist/{product-type-metadata-5TDBJGNQ.mjs → product-type-metadata-6QT47ZSR.mjs} +10 -10
  149. package/dist/{product-variant-detail-JMPD7LEZ.mjs → product-variant-detail-HOOYZSS2.mjs} +14 -14
  150. package/dist/{product-variant-edit-DW27AYBX.mjs → product-variant-edit-J2MTJA75.mjs} +10 -10
  151. package/dist/{product-variant-manage-inventory-items-T5OB3YX3.mjs → product-variant-manage-inventory-items-P4QUORRH.mjs} +1 -1
  152. package/dist/{product-variant-media-PHRCKUDK.mjs → product-variant-media-U5RG7AOW.mjs} +1 -1
  153. package/dist/{product-variant-metadata-4KJE6B2R.mjs → product-variant-metadata-ZRSZO2D4.mjs} +10 -10
  154. package/dist/{profile-detail-MEZKVQAB.mjs → profile-detail-UTJBWZSA.mjs} +1 -1
  155. package/dist/{profile-edit-XAHDV2DG.mjs → profile-edit-OOYMTKX6.mjs} +1 -1
  156. package/dist/{promotion-create-F27AOTVZ.mjs → promotion-create-2E4EF4SP.mjs} +15 -15
  157. package/dist/{promotion-detail-L3FNHH6O.mjs → promotion-detail-P2BHIQDG.mjs} +13 -13
  158. package/dist/{promotion-list-R5JKSO4I.mjs → promotion-list-MN6YJCYA.mjs} +4 -4
  159. package/dist/{refund-reason-create-5ATQ2IPU.mjs → refund-reason-create-I3BIJFJH.mjs} +10 -10
  160. package/dist/{refund-reason-edit-F7AMOTG3.mjs → refund-reason-edit-2BEZASQH.mjs} +10 -10
  161. package/dist/{refund-reason-list-NS4SVHGZ.mjs → refund-reason-list-NIJHHOXJ.mjs} +20 -20
  162. package/dist/{region-add-countries-G5BOUL2E.mjs → region-add-countries-KGFPZSRE.mjs} +4 -4
  163. package/dist/{region-create-MLPUWT5W.mjs → region-create-YJJRTAYO.mjs} +4 -4
  164. package/dist/{region-detail-RICQRZUA.mjs → region-detail-ERE4ZF2I.mjs} +4 -4
  165. package/dist/{region-list-CJYT43SH.mjs → region-list-KE5HCKOR.mjs} +7 -7
  166. package/dist/{region-metadata-CRAHVHOC.mjs → region-metadata-RLZSQNGW.mjs} +10 -10
  167. package/dist/{reservation-create-YZMZ6HSS.mjs → reservation-create-4R2XEEZU.mjs} +2 -2
  168. package/dist/{reservation-detail-6MCBQZAE.mjs → reservation-detail-7OYGNK4L.mjs} +10 -10
  169. package/dist/{reservation-list-XP4YX4TR.mjs → reservation-list-VY44QEH6.mjs} +7 -7
  170. package/dist/{reservation-metadata-IQNJPNAX.mjs → reservation-metadata-VJIAGIMF.mjs} +10 -10
  171. package/dist/{return-reason-list-7MBVORVO.mjs → return-reason-list-6UKR2BLW.mjs} +12 -12
  172. package/dist/{sales-channel-add-products-GQQ7Z3PT.mjs → sales-channel-add-products-KAUMNKMD.mjs} +17 -17
  173. package/dist/{sales-channel-create-7ISLGNGC.mjs → sales-channel-create-I6ME6QBM.mjs} +2 -2
  174. package/dist/{sales-channel-detail-P2HXFYB4.mjs → sales-channel-detail-5SXDKP6P.mjs} +17 -17
  175. package/dist/{sales-channel-edit-2PEHGAWF.mjs → sales-channel-edit-O7GM2B6O.mjs} +2 -2
  176. package/dist/{sales-channel-list-4PJLCQ77.mjs → sales-channel-list-JKZ6TIY7.mjs} +15 -15
  177. package/dist/{sales-channel-metadata-ZOCPAIGM.mjs → sales-channel-metadata-33P5SKDI.mjs} +10 -10
  178. package/dist/{shipping-option-type-create-YR2QV2OG.mjs → shipping-option-type-create-KVYNWD2Q.mjs} +10 -10
  179. package/dist/{shipping-option-type-detail-TYHGCV2X.mjs → shipping-option-type-detail-YX3HMXNI.mjs} +11 -11
  180. package/dist/{shipping-option-type-edit-6KL3MHVT.mjs → shipping-option-type-edit-ODXQMHYJ.mjs} +10 -10
  181. package/dist/{shipping-option-type-list-AWJRR7U5.mjs → shipping-option-type-list-XCQNWDDA.mjs} +16 -16
  182. package/dist/{shipping-profile-metadata-A33XKBQN.mjs → shipping-profile-metadata-K34DAKGY.mjs} +10 -10
  183. package/dist/{shipping-profiles-list-7SVGIP72.mjs → shipping-profiles-list-KYYSHLSZ.mjs} +4 -4
  184. package/dist/{store-add-currencies-V3IBSI45.mjs → store-add-currencies-SNSW7A6O.mjs} +4 -4
  185. package/dist/{store-detail-3WFTRPJW.mjs → store-detail-3Z3BK2BH.mjs} +14 -14
  186. package/dist/{store-metadata-LMRFCZ3J.mjs → store-metadata-FESGAO7E.mjs} +10 -10
  187. package/dist/{tax-region-create-5Y6EA7XE.mjs → tax-region-create-EVFVC6HN.mjs} +10 -10
  188. package/dist/{tax-region-detail-HXVZA2PP.mjs → tax-region-detail-ULHK52CD.mjs} +38 -37
  189. package/dist/{tax-region-edit-IKEWHRUK.mjs → tax-region-edit-CXEPD2F2.mjs} +10 -10
  190. package/dist/{tax-region-province-detail-VT3BUKLS.mjs → tax-region-province-detail-VUY4PDGN.mjs} +38 -37
  191. package/dist/{tax-region-tax-override-create-RZUVOGNR.mjs → tax-region-tax-override-create-WWZZVAG5.mjs} +37 -36
  192. package/dist/{tax-region-tax-override-edit-OEQOEE6I.mjs → tax-region-tax-override-edit-HVZRD44G.mjs} +36 -35
  193. package/dist/{user-detail-DFZPKHG2.mjs → user-detail-YTVBPRH5.mjs} +1 -1
  194. package/dist/{user-invite-QK3ZCSGG.mjs → user-invite-FQNKJKMD.mjs} +4 -4
  195. package/dist/{user-list-RH43CTBN.mjs → user-list-73SJSKYT.mjs} +6 -6
  196. package/dist/{user-metadata-BQKW4WAU.mjs → user-metadata-33W3JSHN.mjs} +10 -10
  197. package/dist/{workflow-execution-detail-D5QUZFTV.mjs → workflow-execution-detail-SHEXD5OL.mjs} +10 -10
  198. package/dist/{workflow-execution-list-6UTBTVX4.mjs → workflow-execution-list-JOVBPL45.mjs} +4 -4
  199. package/package.json +9 -9
  200. package/src/components/layout/main-layout/main-layout.tsx +7 -5
  201. package/src/components/layout/nav-item/nav-item.tsx +4 -14
  202. package/src/dashboard-app/dashboard-app.tsx +0 -1
  203. package/src/dashboard-app/routes/get-route.map.tsx +64 -12
  204. package/src/dashboard-app/types.ts +0 -1
  205. package/src/hooks/api/index.ts +1 -0
  206. package/src/hooks/api/product-options.tsx +151 -0
  207. package/src/hooks/api/products.tsx +23 -63
  208. package/src/hooks/table/columns/use-product-option-table-columns.tsx +43 -0
  209. package/src/hooks/table/filters/index.ts +1 -0
  210. package/src/hooks/table/filters/use-product-option-table-filters.tsx +33 -0
  211. package/src/hooks/table/query/use-product-option-table-query.tsx +34 -0
  212. package/src/i18n/languages.ts +16 -23
  213. package/src/i18n/translations/$schema.json +176 -5
  214. package/src/i18n/translations/en.json +51 -4
  215. package/src/i18n/translations/index.ts +0 -4
  216. package/src/routes/product-options/common/hooks/use-delete-product-option-action.tsx +41 -0
  217. package/src/routes/product-options/product-option-create/components/create-product-option-form/create-product-option-details.tsx +71 -0
  218. package/src/routes/product-options/product-option-create/components/create-product-option-form/create-product-option-form.tsx +192 -0
  219. package/src/routes/product-options/product-option-create/components/create-product-option-form/create-product-option-organize.tsx +77 -0
  220. package/src/routes/product-options/product-option-create/components/create-product-option-form/index.ts +1 -0
  221. package/src/routes/product-options/product-option-create/components/create-product-option-form/schema.ts +15 -0
  222. package/src/routes/product-options/product-option-create/index.ts +1 -0
  223. package/src/routes/product-options/product-option-create/product-option-create.tsx +10 -0
  224. package/src/routes/product-options/product-option-detail/breadcrumb.tsx +14 -0
  225. package/src/routes/product-options/product-option-detail/components/product-option-general-section/index.ts +1 -0
  226. package/src/routes/product-options/product-option-detail/components/product-option-general-section/product-option-general-section.tsx +81 -0
  227. package/src/routes/product-options/product-option-detail/components/product-option-product-section/index.ts +1 -0
  228. package/src/routes/product-options/product-option-detail/components/product-option-product-section/product-option-product-section.tsx +74 -0
  229. package/src/routes/product-options/product-option-detail/index.ts +3 -0
  230. package/src/routes/product-options/product-option-detail/loader.ts +17 -0
  231. package/src/routes/product-options/product-option-detail/product-option-detail.tsx +50 -0
  232. package/src/routes/product-options/product-option-edit/components/edit-product-option-form/edit-product-option-details.tsx +94 -0
  233. package/src/routes/product-options/product-option-edit/components/edit-product-option-form/edit-product-option-form.tsx +116 -0
  234. package/src/routes/product-options/product-option-edit/components/edit-product-option-form/edit-product-option-organize.tsx +77 -0
  235. package/src/routes/product-options/product-option-edit/components/edit-product-option-form/index.ts +1 -0
  236. package/src/routes/product-options/product-option-edit/components/edit-product-option-form/schema.ts +13 -0
  237. package/src/routes/product-options/product-option-edit/index.ts +1 -0
  238. package/src/routes/product-options/product-option-edit/product-option-edit.tsx +34 -0
  239. package/src/routes/product-options/product-option-list/components/product-option-list-table/index.ts +1 -0
  240. package/src/routes/product-options/product-option-list/components/product-option-list-table/product-option-list-table.tsx +131 -0
  241. package/src/routes/product-options/product-option-list/index.ts +1 -0
  242. package/src/routes/product-options/product-option-list/product-option-list.tsx +19 -0
  243. package/src/routes/product-options/product-option-metadata/index.ts +1 -0
  244. package/src/routes/product-options/product-option-metadata/product-option-metadata.tsx +27 -0
  245. package/src/routes/products/product-create/components/product-create-details-form/components/product-create-details-variant-section/product-create-details-variant-section.tsx +214 -198
  246. package/src/routes/products/product-create/components/product-create-form/product-create-form.tsx +4 -7
  247. package/src/routes/products/product-create/constants.ts +1 -0
  248. package/src/routes/products/product-create/utils.ts +6 -1
  249. package/src/routes/products/product-detail/components/product-option-section/product-option-section.tsx +7 -38
  250. package/src/routes/products/product-options-manage/components/product-options-manage-form/index.ts +1 -0
  251. package/src/routes/products/product-options-manage/components/product-options-manage-form/product-options-manage-form.tsx +147 -0
  252. package/src/routes/products/product-options-manage/index.ts +1 -0
  253. package/src/routes/products/product-options-manage/product-options-manage.tsx +35 -0
  254. package/dist/product-create-option-D2636LJL.mjs +0 -145
  255. package/dist/product-edit-option-DYAFZIT2.mjs +0 -150
  256. package/src/i18n/translations/ptPT.json +0 -3219
  257. package/src/routes/products/product-create-option/components/create-product-option-form/create-product-option-form.tsx +0 -122
  258. package/src/routes/products/product-create-option/components/create-product-option-form/index.ts +0 -1
  259. package/src/routes/products/product-create-option/index.ts +0 -1
  260. package/src/routes/products/product-create-option/product-create-option.tsx +0 -26
  261. package/src/routes/products/product-edit-option/components/edit-product-option-form/edit-product-option-form.tsx +0 -123
  262. package/src/routes/products/product-edit-option/components/edit-product-option-form/index.ts +0 -1
  263. package/src/routes/products/product-edit-option/index.ts +0 -1
  264. package/src/routes/products/product-edit-option/product-edit-option.tsx +0 -32
  265. package/dist/{chunk-ELPHCFRW.mjs → chunk-MK4E5XQX.mjs} +3 -3
  266. package/dist/{location-list-W6EHBBE5.mjs → location-list-MVIK73QC.mjs} +1 -1
  267. package/dist/{location-service-zone-shipping-option-edit-27MYKN7R.mjs → location-service-zone-shipping-option-edit-WN4MTZSB.mjs} +3 -3
@@ -0,0 +1,192 @@
1
+ import { zodResolver } from "@hookform/resolvers/zod"
2
+ import { Button, ProgressStatus, ProgressTabs, toast } from "@medusajs/ui"
3
+ import { useForm } from "react-hook-form"
4
+ import { useTranslation } from "react-i18next"
5
+
6
+ import { useState } from "react"
7
+ import {
8
+ RouteFocusModal,
9
+ useRouteModal,
10
+ } from "../../../../../components/modals"
11
+ import { KeyboundForm } from "../../../../../components/utilities/keybound-form"
12
+ import { useCreateProductOption } from "../../../../../hooks/api"
13
+ import { CreateProductOptionDetails } from "./create-product-option-details"
14
+ import { CreateProductOptionOrganize } from "./create-product-option-organize"
15
+ import {
16
+ CreateProductOptionDetailsSchema,
17
+ CreateProductOptionSchema,
18
+ } from "./schema"
19
+ import { useDocumentDirection } from "../../../../../hooks/use-document-direction"
20
+
21
+ enum Tab {
22
+ DETAILS = "details",
23
+ ORGANIZE = "organize",
24
+ }
25
+
26
+ export const CreateProductOptionForm = () => {
27
+ const { t } = useTranslation()
28
+ const { handleSuccess } = useRouteModal()
29
+ const direction = useDocumentDirection()
30
+ const [activeTab, setActiveTab] = useState<Tab>(Tab.DETAILS)
31
+ const [validDetails, setValidDetails] = useState(false)
32
+
33
+ const form = useForm<CreateProductOptionSchema>({
34
+ defaultValues: {
35
+ title: "",
36
+ values: [],
37
+ value_ranks: {},
38
+ },
39
+ resolver: zodResolver(CreateProductOptionSchema),
40
+ })
41
+
42
+ const handleTabChange = (tab: Tab) => {
43
+ if (tab === Tab.ORGANIZE) {
44
+ const { title, values } = form.getValues()
45
+
46
+ const result = CreateProductOptionDetailsSchema.safeParse({
47
+ title,
48
+ values,
49
+ })
50
+
51
+ if (!result.success) {
52
+ result.error.errors.forEach((error) => {
53
+ form.setError(
54
+ error.path.join(".") as keyof CreateProductOptionSchema,
55
+ {
56
+ type: "manual",
57
+ message: error.message,
58
+ }
59
+ )
60
+ })
61
+
62
+ return
63
+ }
64
+
65
+ form.clearErrors()
66
+ setValidDetails(true)
67
+ }
68
+
69
+ setActiveTab(tab)
70
+ }
71
+
72
+ const { mutateAsync, isPending } = useCreateProductOption()
73
+
74
+ const handleSubmit = form.handleSubmit((data) => {
75
+ const { title, values, value_ranks } = data
76
+
77
+ mutateAsync(
78
+ {
79
+ title,
80
+ values,
81
+ ranks: value_ranks,
82
+ },
83
+ {
84
+ onSuccess: ({ product_option }) => {
85
+ toast.success(
86
+ t("productOptions.create.successToast", {
87
+ title: product_option.title,
88
+ })
89
+ )
90
+
91
+ handleSuccess(`/product-options/${product_option.id}`)
92
+ },
93
+ onError: (error) => {
94
+ toast.error(error.message)
95
+ },
96
+ }
97
+ )
98
+ })
99
+
100
+ const organizeStatus: ProgressStatus =
101
+ form.getFieldState("value_ranks")?.isDirty || activeTab === Tab.ORGANIZE
102
+ ? "in-progress"
103
+ : "not-started"
104
+
105
+ const detailsStatus: ProgressStatus = validDetails
106
+ ? "completed"
107
+ : "in-progress"
108
+
109
+ return (
110
+ <RouteFocusModal.Form form={form}>
111
+ <KeyboundForm
112
+ onSubmit={handleSubmit}
113
+ className="flex size-full flex-col overflow-hidden"
114
+ >
115
+ <ProgressTabs
116
+ dir={direction}
117
+ value={activeTab}
118
+ onValueChange={(tab) => handleTabChange(tab as Tab)}
119
+ className="flex size-full flex-col"
120
+ >
121
+ <RouteFocusModal.Header>
122
+ <div className="flex w-full items-center justify-between">
123
+ <div className="-my-2 w-full max-w-[400px] border-l">
124
+ <ProgressTabs.List className="grid w-full grid-cols-2">
125
+ <ProgressTabs.Trigger
126
+ value={Tab.DETAILS}
127
+ status={detailsStatus}
128
+ className="w-full min-w-0 overflow-hidden"
129
+ >
130
+ <span className="truncate">
131
+ {t("productOptions.create.tabs.details")}
132
+ </span>
133
+ </ProgressTabs.Trigger>
134
+ <ProgressTabs.Trigger
135
+ value={Tab.ORGANIZE}
136
+ status={organizeStatus}
137
+ className="w-full min-w-0 overflow-hidden"
138
+ >
139
+ <span className="truncate">
140
+ {t("productOptions.create.tabs.organize")}
141
+ </span>
142
+ </ProgressTabs.Trigger>
143
+ </ProgressTabs.List>
144
+ </div>
145
+ </div>
146
+ </RouteFocusModal.Header>
147
+ <RouteFocusModal.Body className="flex size-full flex-col overflow-auto">
148
+ <ProgressTabs.Content value={Tab.DETAILS}>
149
+ <CreateProductOptionDetails form={form} />
150
+ </ProgressTabs.Content>
151
+ <ProgressTabs.Content
152
+ value={Tab.ORGANIZE}
153
+ className="bg-ui-bg-subtle flex-1"
154
+ >
155
+ <CreateProductOptionOrganize form={form} />
156
+ </ProgressTabs.Content>
157
+ </RouteFocusModal.Body>
158
+ <RouteFocusModal.Footer>
159
+ <div className="flex items-center justify-end gap-x-2">
160
+ <RouteFocusModal.Close asChild>
161
+ <Button size="small" variant="secondary">
162
+ {t("actions.cancel")}
163
+ </Button>
164
+ </RouteFocusModal.Close>
165
+ {activeTab === Tab.ORGANIZE ? (
166
+ <Button
167
+ key="submit-btn"
168
+ size="small"
169
+ variant="primary"
170
+ type="submit"
171
+ isLoading={isPending}
172
+ >
173
+ {t("actions.save")}
174
+ </Button>
175
+ ) : (
176
+ <Button
177
+ key="continue-btn"
178
+ size="small"
179
+ variant="primary"
180
+ type="button"
181
+ onClick={() => handleTabChange(Tab.ORGANIZE)}
182
+ >
183
+ {t("actions.continue")}
184
+ </Button>
185
+ )}
186
+ </div>
187
+ </RouteFocusModal.Footer>
188
+ </ProgressTabs>
189
+ </KeyboundForm>
190
+ </RouteFocusModal.Form>
191
+ )
192
+ }
@@ -0,0 +1,77 @@
1
+ import { Text } from "@medusajs/ui"
2
+ import { useMemo } from "react"
3
+ import { UseFormReturn, useWatch } from "react-hook-form"
4
+ import { SortableList } from "../../../../../components/common/sortable-list"
5
+ import { CreateProductOptionSchema } from "./schema"
6
+
7
+ type CreateProductOptionOrganizeProps = {
8
+ form: UseFormReturn<CreateProductOptionSchema>
9
+ }
10
+
11
+ type ValueItem = {
12
+ id: string
13
+ value: string
14
+ rank: number
15
+ }
16
+
17
+ export const CreateProductOptionOrganize = ({
18
+ form,
19
+ }: CreateProductOptionOrganizeProps) => {
20
+ const values = useWatch({
21
+ control: form.control,
22
+ name: "values",
23
+ })
24
+
25
+ const valueRanks = useWatch({
26
+ control: form.control,
27
+ name: "value_ranks",
28
+ })
29
+
30
+ const items = useMemo<ValueItem[]>(() => {
31
+ if (!values || values.length === 0) {
32
+ return []
33
+ }
34
+
35
+ return values
36
+ .map((value, index) => ({
37
+ id: value,
38
+ value,
39
+ rank: valueRanks?.[value] ?? index,
40
+ }))
41
+ .sort((a, b) => a.rank - b.rank)
42
+ }, [values, valueRanks])
43
+
44
+ const handleChange = (newItems: ValueItem[]) => {
45
+ const newRanks: Record<string, number> = {}
46
+ newItems.forEach((item, index) => {
47
+ newRanks[item.value] = index
48
+ })
49
+
50
+ form.setValue("value_ranks", newRanks, {
51
+ shouldDirty: true,
52
+ shouldTouch: true,
53
+ })
54
+ }
55
+
56
+ if (!values || values.length === 0) {
57
+ return null
58
+ }
59
+
60
+ return (
61
+ <SortableList
62
+ items={items}
63
+ onChange={handleChange}
64
+ renderItem={(item) => (
65
+ <SortableList.Item
66
+ id={item.id}
67
+ className="border-ui-border-base border-b last:border-b-0"
68
+ >
69
+ <div className="flex flex-1 items-center gap-x-3 px-4 py-3">
70
+ <SortableList.DragHandle />
71
+ <Text size="small">{item.value}</Text>
72
+ </div>
73
+ </SortableList.Item>
74
+ )}
75
+ />
76
+ )
77
+ }
@@ -0,0 +1 @@
1
+ export { CreateProductOptionForm } from "./create-product-option-form"
@@ -0,0 +1,15 @@
1
+ import { z } from "zod"
2
+
3
+ export const CreateProductOptionDetailsSchema = z.object({
4
+ title: z.string().min(1),
5
+ values: z.array(z.string()).min(1, "At least one value is required"),
6
+ })
7
+
8
+ export type CreateProductOptionSchema = z.infer<
9
+ typeof CreateProductOptionSchema
10
+ >
11
+ export const CreateProductOptionSchema = z
12
+ .object({
13
+ value_ranks: z.record(z.string(), z.number()).optional(),
14
+ })
15
+ .merge(CreateProductOptionDetailsSchema)
@@ -0,0 +1 @@
1
+ export { ProductOptionCreate as Component } from "./product-option-create"
@@ -0,0 +1,10 @@
1
+ import { RouteFocusModal } from "../../../components/modals"
2
+ import { CreateProductOptionForm } from "./components/create-product-option-form/create-product-option-form"
3
+
4
+ export const ProductOptionCreate = () => {
5
+ return (
6
+ <RouteFocusModal>
7
+ <CreateProductOptionForm />
8
+ </RouteFocusModal>
9
+ )
10
+ }
@@ -0,0 +1,14 @@
1
+ import { HttpTypes } from "@medusajs/types"
2
+ import { UIMatch } from "react-router-dom"
3
+
4
+ export const ProductOptionBreadcrumb = (
5
+ match: UIMatch<HttpTypes.AdminProductOptionResponse>
6
+ ) => {
7
+ const productOption = match.data.product_option
8
+
9
+ if (!productOption) {
10
+ return null
11
+ }
12
+
13
+ return <span>{productOption.title}</span>
14
+ }
@@ -0,0 +1 @@
1
+ export * from "./product-option-general-section.tsx"
@@ -0,0 +1,81 @@
1
+ import { PencilSquare, Trash } from "@medusajs/icons"
2
+ import { HttpTypes } from "@medusajs/types"
3
+ import { Badge, Container, Heading } from "@medusajs/ui"
4
+ import { useMemo } from "react"
5
+ import { useTranslation } from "react-i18next"
6
+ import { ActionMenu } from "../../../../../components/common/action-menu"
7
+ import { useDeleteProductOptionAction } from "../../../common/hooks/use-delete-product-option-action.tsx"
8
+
9
+ export const ProductOptionGeneralSection = ({
10
+ productOption,
11
+ }: {
12
+ productOption: HttpTypes.AdminProductOption
13
+ }) => {
14
+ const { t } = useTranslation()
15
+
16
+ const handleDelete = useDeleteProductOptionAction(productOption)
17
+
18
+ const sortedValues = useMemo(() => {
19
+ if (!productOption.values) {
20
+ return []
21
+ }
22
+
23
+ return [...productOption.values].sort((a: any, b: any) => {
24
+ const rankA = a.rank ?? Number.MAX_VALUE
25
+ const rankB = b.rank ?? Number.MAX_VALUE
26
+ return rankA - rankB
27
+ })
28
+ }, [productOption.values])
29
+
30
+ return (
31
+ <Container className="divide-y p-0">
32
+ <div className="flex items-center justify-between px-6 py-4">
33
+ <Heading>{productOption.title}</Heading>
34
+ <div className="flex items-center gap-x-2">
35
+ <Badge size="xsmall" color="blue">
36
+ {t(
37
+ `general.${productOption.is_exclusive ? "exclusive" : "global"}`
38
+ )}
39
+ </Badge>
40
+ <ActionMenu
41
+ groups={[
42
+ {
43
+ actions: [
44
+ {
45
+ label: t("actions.edit"),
46
+ icon: <PencilSquare />,
47
+ to: "edit",
48
+ },
49
+ ],
50
+ },
51
+ {
52
+ actions: [
53
+ {
54
+ label: t("actions.delete"),
55
+ icon: <Trash />,
56
+ onClick: handleDelete,
57
+ },
58
+ ],
59
+ },
60
+ ]}
61
+ />
62
+ </div>
63
+ </div>
64
+ <div className="px-6 py-4">
65
+ <ValuesDisplay values={sortedValues} />
66
+ </div>
67
+ </Container>
68
+ )
69
+ }
70
+
71
+ const ValuesDisplay = ({ values }: { values: any[] }) => {
72
+ return (
73
+ <div className="flex flex-wrap items-center gap-2">
74
+ {values.map((value) => (
75
+ <Badge key={value.id} size="xsmall">
76
+ {value.value}
77
+ </Badge>
78
+ ))}
79
+ </div>
80
+ )
81
+ }
@@ -0,0 +1 @@
1
+ export { ProductOptionProductSection } from "./product-option-product-section"
@@ -0,0 +1,74 @@
1
+ import { HttpTypes } from "@medusajs/types"
2
+ import { Container } from "@medusajs/ui"
3
+ import { keepPreviousData } from "@tanstack/react-query"
4
+ import { useMemo } from "react"
5
+ import { useTranslation } from "react-i18next"
6
+ import { DataTable } from "../../../../../components/data-table"
7
+ import { useProducts } from "../../../../../hooks/api"
8
+ import { useProductTableColumns } from "../../../../../hooks/table/columns"
9
+ import { useProductTableQuery } from "../../../../../hooks/table/query"
10
+
11
+ type ProductOptionProductSectionProps = {
12
+ productOption: HttpTypes.AdminProductOption
13
+ }
14
+
15
+ const PAGE_SIZE = 10
16
+
17
+ export const ProductOptionProductSection = ({
18
+ productOption,
19
+ }: ProductOptionProductSectionProps) => {
20
+ const { t } = useTranslation()
21
+
22
+ const { searchParams } = useProductTableQuery({ pageSize: PAGE_SIZE })
23
+
24
+ const productIds = productOption.products?.map((p: any) => p.id) || []
25
+
26
+ const { products, count, isLoading, isError, error } = useProducts(
27
+ {
28
+ limit: PAGE_SIZE,
29
+ ...searchParams,
30
+ id: productIds.length > 0 ? productIds : undefined,
31
+ },
32
+ {
33
+ placeholderData: keepPreviousData,
34
+ enabled: productIds.length > 0,
35
+ }
36
+ )
37
+
38
+ const columns = useColumns()
39
+
40
+ if (isError) {
41
+ throw error
42
+ }
43
+
44
+ return (
45
+ <Container className="divide-y p-0">
46
+ <DataTable
47
+ data={products}
48
+ columns={columns}
49
+ rowCount={count}
50
+ pageSize={PAGE_SIZE}
51
+ getRowId={(row) => row.id}
52
+ heading={t("products.domain")}
53
+ emptyState={{
54
+ empty: {
55
+ heading: t("general.noRecordsMessage"),
56
+ },
57
+ filtered: {
58
+ heading: t("general.noRecordsMessage"),
59
+ description: t("general.noRecordsMessageFiltered"),
60
+ },
61
+ }}
62
+ isLoading={isLoading}
63
+ enableSearch={true}
64
+ rowHref={(row) => `/products/${row.id}`}
65
+ />
66
+ </Container>
67
+ )
68
+ }
69
+
70
+ const useColumns = () => {
71
+ const columns = useProductTableColumns()
72
+
73
+ return useMemo(() => [...columns], [columns])
74
+ }
@@ -0,0 +1,3 @@
1
+ export { ProductOptionBreadcrumb as Breadcrumb } from "./breadcrumb"
2
+ export { ProductOptionDetail as Component } from "./product-option-detail"
3
+ export { productOptionLoader as loader } from "./loader"
@@ -0,0 +1,17 @@
1
+ import { LoaderFunctionArgs } from "react-router-dom"
2
+
3
+ import { sdk } from "../../../lib/client"
4
+ import { queryClient } from "../../../lib/query-client"
5
+ import { productOptionsQueryKeys } from "../../../hooks/api/product-options.tsx"
6
+
7
+ const productOptionDetailQuery = (id: string) => ({
8
+ queryKey: productOptionsQueryKeys.detail(id),
9
+ queryFn: async () => sdk.admin.productOption.retrieve(id),
10
+ })
11
+
12
+ export const productOptionLoader = async ({ params }: LoaderFunctionArgs) => {
13
+ const id = params.id
14
+ const query = productOptionDetailQuery(id!)
15
+
16
+ return queryClient.ensureQueryData(query)
17
+ }
@@ -0,0 +1,50 @@
1
+ import { useLoaderData, useParams } from "react-router-dom"
2
+
3
+ import { SingleColumnPageSkeleton } from "../../../components/common/skeleton"
4
+ import { SingleColumnPage } from "../../../components/layout/pages"
5
+ import { useExtension } from "../../../providers/extension-provider"
6
+ import { useProductOption } from "../../../hooks/api"
7
+ import { productOptionLoader } from "./loader.ts"
8
+ import { ProductOptionGeneralSection } from "./components/product-option-general-section"
9
+ import { ProductOptionProductSection } from "./components/product-option-product-section"
10
+
11
+ export const ProductOptionDetail = () => {
12
+ const { id } = useParams()
13
+
14
+ const initialData = useLoaderData() as Awaited<
15
+ ReturnType<typeof productOptionLoader>
16
+ >
17
+
18
+ const { getWidgets } = useExtension()
19
+
20
+ const { product_option, isLoading, isError, error } = useProductOption(
21
+ id!,
22
+ undefined,
23
+ {
24
+ initialData,
25
+ }
26
+ )
27
+
28
+ if (isLoading || !product_option) {
29
+ return <SingleColumnPageSkeleton sections={2} showJSON showMetadata />
30
+ }
31
+
32
+ if (isError) {
33
+ throw error
34
+ }
35
+
36
+ return (
37
+ <SingleColumnPage
38
+ widgets={{
39
+ after: getWidgets("product_option.details.after"),
40
+ before: getWidgets("product_option.details.before"),
41
+ }}
42
+ showJSON
43
+ showMetadata
44
+ data={product_option}
45
+ >
46
+ <ProductOptionGeneralSection productOption={product_option} />
47
+ <ProductOptionProductSection productOption={product_option} />
48
+ </SingleColumnPage>
49
+ )
50
+ }
@@ -0,0 +1,94 @@
1
+ import { Input } from "@medusajs/ui"
2
+ import { useEffect } from "react"
3
+ import { UseFormReturn, useWatch } from "react-hook-form"
4
+ import { useTranslation } from "react-i18next"
5
+
6
+ import { Form } from "../../../../../components/common/form"
7
+ import { ChipInput } from "../../../../../components/inputs/chip-input"
8
+ import { EditProductOptionSchema } from "./schema"
9
+
10
+ type EditProductOptionDetailsProps = {
11
+ form: UseFormReturn<EditProductOptionSchema>
12
+ }
13
+
14
+ export const EditProductOptionDetails = ({
15
+ form,
16
+ }: EditProductOptionDetailsProps) => {
17
+ const { t } = useTranslation()
18
+
19
+ const values = useWatch({
20
+ control: form.control,
21
+ name: "values",
22
+ })
23
+
24
+ const valueRanks = useWatch({
25
+ control: form.control,
26
+ name: "value_ranks",
27
+ })
28
+
29
+ useEffect(() => {
30
+ if (!values || !valueRanks) {
31
+ return
32
+ }
33
+
34
+ const validValueSet = new Set(values)
35
+ const currentRanks = { ...valueRanks }
36
+ let hasStaleEntries = false
37
+
38
+ Object.keys(currentRanks).forEach((key) => {
39
+ if (!validValueSet.has(key)) {
40
+ delete currentRanks[key]
41
+ hasStaleEntries = true
42
+ }
43
+ })
44
+
45
+ if (hasStaleEntries) {
46
+ form.setValue("value_ranks", currentRanks, {
47
+ shouldDirty: true,
48
+ shouldTouch: true,
49
+ })
50
+ }
51
+ }, [values, valueRanks, form])
52
+
53
+ return (
54
+ <div className="flex flex-col gap-y-4">
55
+ <Form.Field
56
+ control={form.control}
57
+ name="title"
58
+ render={({ field }) => {
59
+ return (
60
+ <Form.Item>
61
+ <Form.Label>{t("productOptions.fields.title.label")}</Form.Label>
62
+ <Form.Control>
63
+ <Input
64
+ autoComplete="off"
65
+ {...field}
66
+ placeholder={t("productOptions.fields.title.placeholder")}
67
+ />
68
+ </Form.Control>
69
+ <Form.ErrorMessage />
70
+ </Form.Item>
71
+ )
72
+ }}
73
+ />
74
+ <Form.Field
75
+ control={form.control}
76
+ name="values"
77
+ render={({ field }) => {
78
+ return (
79
+ <Form.Item>
80
+ <Form.Label>{t("productOptions.fields.values.label")}</Form.Label>
81
+ <Form.Control>
82
+ <ChipInput
83
+ {...field}
84
+ placeholder={t("productOptions.fields.values.placeholder")}
85
+ />
86
+ </Form.Control>
87
+ <Form.ErrorMessage />
88
+ </Form.Item>
89
+ )
90
+ }}
91
+ />
92
+ </div>
93
+ )
94
+ }