@medusajs/dashboard 2.12.3-preview-20251217120154 → 2.12.3-snapshot-20251216185234

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 (271) hide show
  1. package/dist/{add-campaign-promotions-4QLXO46G.mjs → add-campaign-promotions-OYPGISTF.mjs} +2 -2
  2. package/dist/{adjust-inventory-2MFA656V.mjs → adjust-inventory-26YXAXQL.mjs} +4 -3
  3. package/dist/{api-key-management-create-ZUVF3SLR.mjs → api-key-management-create-EMP32G2D.mjs} +6 -5
  4. package/dist/{api-key-management-detail-THD74G7I.mjs → api-key-management-detail-6RCDH73M.mjs} +11 -10
  5. package/dist/{api-key-management-edit-42HNUSXL.mjs → api-key-management-edit-IBM3ZXHK.mjs} +6 -5
  6. package/dist/{api-key-management-list-66CFOILY.mjs → api-key-management-list-KC5GOWAU.mjs} +4 -3
  7. package/dist/{api-key-management-sales-channels-HN3THM5J.mjs → api-key-management-sales-channels-LUB5G6RC.mjs} +6 -5
  8. package/dist/app.css +53 -0
  9. package/dist/app.js +13537 -11320
  10. package/dist/app.mjs +12 -11
  11. package/dist/{campaign-budget-edit-6DMZGUCI.mjs → campaign-budget-edit-B5MSE26J.mjs} +2 -2
  12. package/dist/{campaign-configuration-UNFRB5HR.mjs → campaign-configuration-QOE3D2BE.mjs} +2 -2
  13. package/dist/{campaign-create-QXG7PD3S.mjs → campaign-create-FJOECKGT.mjs} +3 -3
  14. package/dist/{campaign-detail-WR3XHHV2.mjs → campaign-detail-5Q4BYCPX.mjs} +11 -10
  15. package/dist/{campaign-edit-HN4US7DV.mjs → campaign-edit-K2POQH7M.mjs} +2 -2
  16. package/dist/{categories-metadata-BCZ463KN.mjs → categories-metadata-J7M3XWI7.mjs} +14 -13
  17. package/dist/{category-create-FFIBWXAH.mjs → category-create-KHJZSC7G.mjs} +5 -4
  18. package/dist/{category-detail-4HXJ5Z7N.mjs → category-detail-S5IPXMHX.mjs} +29 -13
  19. package/dist/{category-edit-74MZ6TXN.mjs → category-edit-CTA2EPDG.mjs} +5 -4
  20. package/dist/{category-list-OCJY2UJV.mjs → category-list-QBYJ4T3R.mjs} +20 -4
  21. package/dist/{category-organize-B6EFBFKB.mjs → category-organize-SXP33XET.mjs} +5 -4
  22. package/dist/{category-products-2HXLZDHL.mjs → category-products-KPW6BA5J.mjs} +14 -13
  23. package/dist/{chunk-XIVBRONM.mjs → chunk-23GTCEOV.mjs} +1 -1
  24. package/dist/{chunk-2NZDHAOE.mjs → chunk-27MGH3HR.mjs} +2 -2
  25. package/dist/{chunk-N3FCYZV6.mjs → chunk-2XTBDCGE.mjs} +1 -1
  26. package/dist/{chunk-RU4ZS47V.mjs → chunk-4JQR6QNW.mjs} +2 -2
  27. package/dist/{chunk-Z6NHG5LQ.mjs → chunk-6P4Q4AAP.mjs} +3 -3
  28. package/dist/{chunk-F5NZDW7L.mjs → chunk-A2WBKOXJ.mjs} +2 -2
  29. package/dist/{chunk-F63F3FIT.mjs → chunk-A4XYK3MY.mjs} +2 -2
  30. package/dist/{chunk-NT6C7CHT.mjs → chunk-AWRCV3ME.mjs} +1 -1
  31. package/dist/{chunk-5X6SKB2P.mjs → chunk-BMS2QLJY.mjs} +1 -1
  32. package/dist/{chunk-3YPRDSZ6.mjs → chunk-BZKI5J2M.mjs} +1 -1
  33. package/dist/{chunk-25UWYEJX.mjs → chunk-CQOOXWPZ.mjs} +1 -1
  34. package/dist/{chunk-5DUMSVP6.mjs → chunk-CVHJAKLQ.mjs} +3 -3
  35. package/dist/{chunk-42OOM4DJ.mjs → chunk-D6UW7URG.mjs} +23 -6
  36. package/dist/{chunk-LHNU4DYZ.mjs → chunk-DBXWB3RF.mjs} +2 -2
  37. package/dist/{chunk-N4O5FAUC.mjs → chunk-FYWHE3W5.mjs} +1 -1
  38. package/dist/{chunk-QPKW37WR.mjs → chunk-GRZSG4EP.mjs} +244 -14
  39. package/dist/chunk-HGRIOEAR.mjs +32 -0
  40. package/dist/{chunk-Y5UO73CH.mjs → chunk-HTCYX4VD.mjs} +1 -1
  41. package/dist/{chunk-34KFHPN6.mjs → chunk-IAV7IKJ6.mjs} +1 -1
  42. package/dist/{chunk-6W3BKVOC.mjs → chunk-KFYQTOGB.mjs} +1 -1
  43. package/dist/{chunk-EQTBJSBZ.mjs → chunk-KIIT4BNH.mjs} +3 -0
  44. package/dist/{chunk-W7SLPIO2.mjs → chunk-LZFWCKOF.mjs} +655 -147
  45. package/dist/{chunk-PNPT4W2F.mjs → chunk-MJDHVDOW.mjs} +1 -1
  46. package/dist/{chunk-D4J3CEWH.mjs → chunk-N3SAXQVR.mjs} +2 -2
  47. package/dist/{chunk-Q6MSICBU.mjs → chunk-O333RR6K.mjs} +1 -1
  48. package/dist/{chunk-F65T2X7G.mjs → chunk-OL24RDYM.mjs} +5 -5
  49. package/dist/{chunk-7ZYDO3XO.mjs → chunk-OL6MEUKW.mjs} +295 -194
  50. package/dist/{chunk-7AX6R6G6.mjs → chunk-OSHH5GAS.mjs} +13 -1
  51. package/dist/{chunk-YAPTGHGP.mjs → chunk-PHLCT2HA.mjs} +1 -1
  52. package/dist/{chunk-35LSPN2U.mjs → chunk-QKALAT7P.mjs} +1 -1
  53. package/dist/{chunk-UM4OIJZ3.mjs → chunk-S22SJRPO.mjs} +1 -1
  54. package/dist/{chunk-4YAPXPLM.mjs → chunk-ST4P6BQN.mjs} +1 -1
  55. package/dist/{chunk-B3AOQW2B.mjs → chunk-U6G4M5LP.mjs} +1 -1
  56. package/dist/{chunk-HWKLNKOY.mjs → chunk-U726TGCM.mjs} +1 -1
  57. package/dist/{chunk-HKIF5HVL.mjs → chunk-UJ2TMPV4.mjs} +12 -0
  58. package/dist/{chunk-NHDFPGQ3.mjs → chunk-UWY5ZV66.mjs} +13 -1
  59. package/dist/{chunk-XXBP2Z5M.mjs → chunk-WVA4O7QS.mjs} +1 -1
  60. package/dist/{chunk-PXJFCRIV.mjs → chunk-WYATCUOM.mjs} +4 -4
  61. package/dist/{chunk-AH4DORIW.mjs → chunk-XY7A7GZJ.mjs} +1 -1
  62. package/dist/{chunk-FQDPOKEK.mjs → chunk-Y2YVTIJI.mjs} +1 -1
  63. package/dist/{chunk-L4NOVTH5.mjs → chunk-YIOBBZUB.mjs} +2 -2
  64. package/dist/{chunk-MY6I7UJG.mjs → chunk-YYOPBKME.mjs} +3 -3
  65. package/dist/{chunk-LEJUZW3P.mjs → chunk-Z6BFNHEO.mjs} +12 -0
  66. package/dist/{chunk-HFT7Q5Y5.mjs → chunk-ZMG5B4FG.mjs} +1 -1
  67. package/dist/{collection-add-products-JWAQ277T.mjs → collection-add-products-FU2BS3D3.mjs} +14 -13
  68. package/dist/{collection-create-DCRW344Z.mjs → collection-create-GWKWVT7B.mjs} +5 -4
  69. package/dist/{collection-detail-F4ON763T.mjs → collection-detail-VJE7XHLV.mjs} +28 -12
  70. package/dist/{collection-edit-UNFEW6HT.mjs → collection-edit-EZIO2BR5.mjs} +5 -4
  71. package/dist/{collection-list-4C5HVO6Y.mjs → collection-list-IGA6SCNF.mjs} +29 -13
  72. package/dist/{collection-metadata-P4A5DXBQ.mjs → collection-metadata-QK7MI3D2.mjs} +14 -13
  73. package/dist/{customer-create-XCLZENJS.mjs → customer-create-IA56MXE6.mjs} +2 -2
  74. package/dist/{customer-create-address-4HZUIAM7.mjs → customer-create-address-27M25HTO.mjs} +2 -2
  75. package/dist/{customer-detail-X3RQJPXP.mjs → customer-detail-MOV2T3LF.mjs} +12 -11
  76. package/dist/{customer-edit-BW5GVTQI.mjs → customer-edit-XQ5NWIVX.mjs} +2 -2
  77. package/dist/{customer-group-add-customers-SOXMSWQH.mjs → customer-group-add-customers-XMR2WBXX.mjs} +2 -2
  78. package/dist/{customer-group-create-6YV7W6TI.mjs → customer-group-create-RY4FVEIW.mjs} +2 -2
  79. package/dist/{customer-group-detail-NG32WKJT.mjs → customer-group-detail-6T7OXGQD.mjs} +11 -10
  80. package/dist/{customer-group-edit-7NXU34BQ.mjs → customer-group-edit-MQWARIQZ.mjs} +2 -2
  81. package/dist/{customer-group-list-EBETHKKO.mjs → customer-group-list-AJEAF5D2.mjs} +11 -10
  82. package/dist/{customer-group-metadata-WK2BGEGO.mjs → customer-group-metadata-JQJRLLXG.mjs} +3 -3
  83. package/dist/{customer-metadata-ZUWCUTM7.mjs → customer-metadata-HN2DYD5I.mjs} +3 -3
  84. package/dist/{customers-add-customer-group-7FYD54MZ.mjs → customers-add-customer-group-QVTVSQYM.mjs} +13 -12
  85. package/dist/{edit-inventory-item-Y5W6VTHJ.mjs → edit-inventory-item-H7DAZWIT.mjs} +4 -3
  86. package/dist/{edit-inventory-item-attributes-NAAZDFEJ.mjs → edit-inventory-item-attributes-7HTXXPGZ.mjs} +4 -3
  87. package/dist/{edit-reservation-2UD4RZJX.mjs → edit-reservation-OVTRZHJR.mjs} +5 -4
  88. package/dist/{edit-rules-2W3BXEXR.mjs → edit-rules-SMVRTCUP.mjs} +13 -12
  89. package/dist/en.json +38 -0
  90. package/dist/{inventory-create-VQEK7C5T.mjs → inventory-create-BK52VALF.mjs} +14 -13
  91. package/dist/{inventory-detail-HUHQ6ZNE.mjs → inventory-detail-ZPSEMYI2.mjs} +11 -10
  92. package/dist/{inventory-list-RUSSPKHE.mjs → inventory-list-RXJPSVZE.mjs} +2 -1
  93. package/dist/{inventory-metadata-X52VGHA7.mjs → inventory-metadata-FNEJ3RAT.mjs} +14 -13
  94. package/dist/{inventory-stock-EKTOYN2F.mjs → inventory-stock-6WYWLWJ7.mjs} +15 -14
  95. package/dist/{invite-VKHAAF4Z.mjs → invite-FVE4ZBKB.mjs} +2 -2
  96. package/dist/{location-create-RPLEXUZR.mjs → location-create-WZ43K3W7.mjs} +2 -2
  97. package/dist/{location-detail-UVWYE6Q2.mjs → location-detail-N3GUZSY7.mjs} +12 -11
  98. package/dist/{location-edit-L4ISEQHX.mjs → location-edit-VCS7GVWQ.mjs} +2 -2
  99. package/dist/{location-fulfillment-providers-HZZUHPVL.mjs → location-fulfillment-providers-7ZUJAGNY.mjs} +15 -14
  100. package/dist/{location-list-Z42ZYHUF.mjs → location-list-KVBA6J47.mjs} +2 -2
  101. package/dist/{location-sales-channels-XIMOK66B.mjs → location-sales-channels-P3QJTFDT.mjs} +5 -4
  102. package/dist/{location-service-zone-create-7ZNVLEE3.mjs → location-service-zone-create-J43WN6G4.mjs} +3 -3
  103. package/dist/{location-service-zone-edit-6OUAFEZD.mjs → location-service-zone-edit-KHHMSPXD.mjs} +2 -2
  104. package/dist/{location-service-zone-manage-areas-EOULKRYD.mjs → location-service-zone-manage-areas-6ZPMKMSX.mjs} +3 -3
  105. package/dist/{location-service-zone-shipping-option-create-M7G4SKNP.mjs → location-service-zone-shipping-option-create-CNRWYZQC.mjs} +15 -14
  106. package/dist/{location-service-zone-shipping-option-edit-M2HJAASG.mjs → location-service-zone-shipping-option-edit-4CGPQ3VT.mjs} +2 -2
  107. package/dist/{location-service-zone-shipping-option-pricing-23QLNSBT.mjs → location-service-zone-shipping-option-pricing-OGWI7VPT.mjs} +4 -4
  108. package/dist/{login-NSCAMAU6.mjs → login-VNOLI5YG.mjs} +13 -12
  109. package/dist/{manage-locations-JD6FSBOT.mjs → manage-locations-7HH6R4UP.mjs} +4 -3
  110. package/dist/{order-allocate-items-5T57NZOB.mjs → order-allocate-items-HZGGYJ42.mjs} +6 -5
  111. package/dist/{order-create-claim-TE56IE7P.mjs → order-create-claim-SCDJGM46.mjs} +15 -14
  112. package/dist/{order-create-edit-RDFYBVFY.mjs → order-create-edit-2WALBPXS.mjs} +14 -13
  113. package/dist/{order-create-exchange-B5ZOEQCJ.mjs → order-create-exchange-LQU4YN7F.mjs} +15 -14
  114. package/dist/{order-create-fulfillment-SRRP6X64.mjs → order-create-fulfillment-OWUVTZXW.mjs} +13 -12
  115. package/dist/{order-create-refund-PTOM65QK.mjs → order-create-refund-Q6HQY42R.mjs} +13 -12
  116. package/dist/{order-create-return-3C2QVNYN.mjs → order-create-return-52GHGW5Z.mjs} +7 -6
  117. package/dist/{order-create-shipment-HNILNFXB.mjs → order-create-shipment-WAGGEPRW.mjs} +13 -12
  118. package/dist/{order-detail-3OUZOQ7G.mjs → order-detail-PVPGEWGY.mjs} +15 -14
  119. package/dist/{order-edit-billing-address-3IO7GXIK.mjs → order-edit-billing-address-UM76J4KX.mjs} +13 -12
  120. package/dist/{order-edit-email-QIAEOUBV.mjs → order-edit-email-CL3KNOCM.mjs} +13 -12
  121. package/dist/{order-edit-shipping-address-QGGMHGBC.mjs → order-edit-shipping-address-PIESTGVL.mjs} +13 -12
  122. package/dist/{order-export-JYYFTOWR.mjs → order-export-LE363ZLB.mjs} +14 -13
  123. package/dist/{order-list-RFR3HNDQ.mjs → order-list-GRLQWN4L.mjs} +6 -5
  124. package/dist/{order-metadata-ZBDTMBHZ.mjs → order-metadata-FHBB7MTG.mjs} +14 -13
  125. package/dist/{order-receive-return-V42FTCFY.mjs → order-receive-return-PRVKP6J2.mjs} +14 -13
  126. package/dist/{order-request-transfer-A6NNIN2O.mjs → order-request-transfer-XSAGRUMT.mjs} +13 -12
  127. package/dist/{price-list-configuration-RTUEJENE.mjs → price-list-configuration-6S3MLNXQ.mjs} +6 -5
  128. package/dist/{price-list-create-GRT27KOM.mjs → price-list-create-K5JEZT57.mjs} +17 -16
  129. package/dist/{price-list-detail-VKIWM7HP.mjs → price-list-detail-Q5VG5VGW.mjs} +13 -12
  130. package/dist/{price-list-edit-SW7YIR3Z.mjs → price-list-edit-53UW35L3.mjs} +5 -4
  131. package/dist/{price-list-list-LF2PL4B5.mjs → price-list-list-DG5YEZ44.mjs} +4 -3
  132. package/dist/{price-list-prices-add-ISLZDQNI.mjs → price-list-prices-add-2MQ226U4.mjs} +16 -15
  133. package/dist/{price-list-prices-edit-C6SX2TLJ.mjs → price-list-prices-edit-OJZLV7OS.mjs} +7 -6
  134. package/dist/{product-attributes-REJ5NF2D.mjs → product-attributes-YF4TZOIO.mjs} +14 -13
  135. package/dist/{product-create-4TFE3JHQ.mjs → product-create-KJML2332.mjs} +16 -15
  136. package/dist/{product-create-option-GEGQNSMQ.mjs → product-create-option-7AOXAA4S.mjs} +4 -3
  137. package/dist/{product-create-variant-WI6D5CDG.mjs → product-create-variant-5EBCLM54.mjs} +14 -13
  138. package/dist/{product-detail-BEIDGPKY.mjs → product-detail-QG72542C.mjs} +59 -17
  139. package/dist/{product-edit-ZRQUK5OQ.mjs → product-edit-DZZR775Q.mjs} +14 -13
  140. package/dist/{product-edit-option-HBIOBQTS.mjs → product-edit-option-LWJT3CYJ.mjs} +4 -3
  141. package/dist/{product-export-GIEFG4MA.mjs → product-export-5AD7NELI.mjs} +15 -14
  142. package/dist/{product-image-variants-edit-AAMRK4KQ.mjs → product-image-variants-edit-M6QF2RLE.mjs} +13 -12
  143. package/dist/{product-import-43UXKCL3.mjs → product-import-V3KQN4TV.mjs} +13 -12
  144. package/dist/{product-list-D4CVUBQQ.mjs → product-list-EUWZIFTM.mjs} +25 -12
  145. package/dist/{product-media-EGK66SRX.mjs → product-media-3VJ7KENL.mjs} +4 -3
  146. package/dist/{product-metadata-55CAQTPS.mjs → product-metadata-GL2MVPDI.mjs} +14 -13
  147. package/dist/{product-organization-7J7MUM6F.mjs → product-organization-O7RHELMQ.mjs} +15 -14
  148. package/dist/{product-prices-WQDE4XYT.mjs → product-prices-YWV6MSM6.mjs} +5 -4
  149. package/dist/{product-sales-channels-GIJ7Q57M.mjs → product-sales-channels-PPXUG4KT.mjs} +5 -4
  150. package/dist/{product-shipping-profile-KIDRTPWA.mjs → product-shipping-profile-ETQFZ7DC.mjs} +4 -3
  151. package/dist/{product-stock-22S2HGMM.mjs → product-stock-AKEFMK5O.mjs} +15 -14
  152. package/dist/{product-tag-create-7GPE246H.mjs → product-tag-create-PQMDDKWH.mjs} +13 -12
  153. package/dist/{product-tag-detail-R6C2TTA4.mjs → product-tag-detail-I3MBZX7U.mjs} +30 -14
  154. package/dist/{product-tag-edit-WA6FGSIP.mjs → product-tag-edit-K3BBQLJR.mjs} +13 -12
  155. package/dist/{product-tag-list-U7PLHMLF.mjs → product-tag-list-JUWSOMB7.mjs} +30 -14
  156. package/dist/{product-tag-metadata-EJ7FEXSE.mjs → product-tag-metadata-MJH5LH7E.mjs} +14 -13
  157. package/dist/{product-type-create-HBDROTGB.mjs → product-type-create-DRFXTL5O.mjs} +4 -3
  158. package/dist/{product-type-detail-TYQ7MJFE.mjs → product-type-detail-RKHT5NBL.mjs} +29 -13
  159. package/dist/{product-type-edit-H3JCMVRV.mjs → product-type-edit-SRHCZDK7.mjs} +4 -3
  160. package/dist/{product-type-list-KIKWBPD7.mjs → product-type-list-QQKAHBJ3.mjs} +19 -3
  161. package/dist/{product-type-metadata-Q6W5GL7Z.mjs → product-type-metadata-CDJDFFGQ.mjs} +14 -13
  162. package/dist/{product-variant-detail-SPJ7MZTK.mjs → product-variant-detail-XAYG5CKE.mjs} +27 -11
  163. package/dist/{product-variant-edit-BW7QMHC5.mjs → product-variant-edit-DEZEY2H2.mjs} +13 -12
  164. package/dist/{product-variant-manage-inventory-items-BLHCH6QD.mjs → product-variant-manage-inventory-items-Y2VEOHP7.mjs} +4 -3
  165. package/dist/{product-variant-media-KLSUISGH.mjs → product-variant-media-2WLVNGI4.mjs} +4 -3
  166. package/dist/{product-variant-metadata-GDMVC4MZ.mjs → product-variant-metadata-VTZDNWUT.mjs} +14 -13
  167. package/dist/{profile-edit-YBBXXCCK.mjs → profile-edit-ZNXO6WME.mjs} +2 -2
  168. package/dist/{promotion-add-campaign-JRTM7WBR.mjs → promotion-add-campaign-DO67QK6M.mjs} +3 -3
  169. package/dist/{promotion-create-HF6DTKCC.mjs → promotion-create-HWFNUQXG.mjs} +15 -14
  170. package/dist/{promotion-detail-HTM3F2VO.mjs → promotion-detail-QC36KXB3.mjs} +11 -10
  171. package/dist/{promotion-edit-details-AREFQ6O5.mjs → promotion-edit-details-6BSOOWQN.mjs} +2 -2
  172. package/dist/{refund-reason-create-RKIH46D6.mjs → refund-reason-create-YHCDEHGQ.mjs} +13 -12
  173. package/dist/{refund-reason-edit-V3KC6NMO.mjs → refund-reason-edit-CZ5QZ2SZ.mjs} +13 -12
  174. package/dist/{refund-reason-list-M5BOHFWU.mjs → refund-reason-list-OJYYEYJE.mjs} +11 -10
  175. package/dist/{region-add-countries-OF5RUSYU.mjs → region-add-countries-2VAVXMJQ.mjs} +2 -2
  176. package/dist/{region-create-BGOWVCTR.mjs → region-create-NA7Y2LN4.mjs} +2 -2
  177. package/dist/{region-edit-5GO25GDF.mjs → region-edit-WAU347DP.mjs} +2 -2
  178. package/dist/{region-metadata-5NGUNAXZ.mjs → region-metadata-H6XXUQ4S.mjs} +14 -13
  179. package/dist/{reservation-create-Z2SUMBGT.mjs → reservation-create-ZCIYM6JI.mjs} +5 -4
  180. package/dist/{reservation-detail-JH77TQHN.mjs → reservation-detail-LZAQL4XA.mjs} +11 -10
  181. package/dist/{reservation-list-WHBGZSVH.mjs → reservation-list-B47DXTA7.mjs} +3 -2
  182. package/dist/{reservation-metadata-ERCWXYVL.mjs → reservation-metadata-5HZSDDOK.mjs} +14 -13
  183. package/dist/{reset-password-5TAYQEUV.mjs → reset-password-Y5WVXV4Q.mjs} +2 -2
  184. package/dist/{return-reason-create-NXWDC6AC.mjs → return-reason-create-HM54WRJY.mjs} +2 -2
  185. package/dist/{return-reason-edit-M6IKNNKB.mjs → return-reason-edit-VSIRHVQ6.mjs} +2 -2
  186. package/dist/{sales-channel-add-products-DTAXWL6H.mjs → sales-channel-add-products-F7YV4MO5.mjs} +14 -13
  187. package/dist/{sales-channel-create-E7BDTPWD.mjs → sales-channel-create-MI7HHZYE.mjs} +5 -4
  188. package/dist/{sales-channel-detail-XWHV7J7X.mjs → sales-channel-detail-MXIPZCGA.mjs} +12 -11
  189. package/dist/{sales-channel-edit-HMPA3Y3L.mjs → sales-channel-edit-VSHOIR37.mjs} +5 -4
  190. package/dist/{sales-channel-list-7NSEFCXQ.mjs → sales-channel-list-RLGL7FM3.mjs} +11 -10
  191. package/dist/{sales-channel-metadata-CMZN74K7.mjs → sales-channel-metadata-M364R4RJ.mjs} +14 -13
  192. package/dist/{shipping-option-type-create-4BN2GBHP.mjs → shipping-option-type-create-C5WUWON7.mjs} +13 -12
  193. package/dist/{shipping-option-type-detail-YB3TCED2.mjs → shipping-option-type-detail-PENS2K73.mjs} +12 -11
  194. package/dist/{shipping-option-type-edit-MDO7ALAU.mjs → shipping-option-type-edit-CIU5EHRP.mjs} +13 -12
  195. package/dist/{shipping-option-type-list-DJAT4RKX.mjs → shipping-option-type-list-DIOX7VG7.mjs} +12 -11
  196. package/dist/{shipping-profile-create-752TMBBE.mjs → shipping-profile-create-26R64I3Z.mjs} +2 -2
  197. package/dist/{shipping-profile-metadata-HQI7PCPU.mjs → shipping-profile-metadata-75G2NNMA.mjs} +14 -13
  198. package/dist/{store-add-currencies-PEWNEWCH.mjs → store-add-currencies-OX2WXFMS.mjs} +2 -2
  199. package/dist/{store-add-locales-JLRTXG3Q.mjs → store-add-locales-VJ4RJ7UI.mjs} +12 -11
  200. package/dist/{store-detail-MOLAYNQZ.mjs → store-detail-JSNPOB2F.mjs} +11 -10
  201. package/dist/{store-edit-FTLPT55E.mjs → store-edit-5ZS562ZO.mjs} +2 -2
  202. package/dist/{store-metadata-ZJD23O4D.mjs → store-metadata-CYXTVJUE.mjs} +14 -13
  203. package/dist/{tax-region-create-NCO2OQ3I.mjs → tax-region-create-DWGL4EUT.mjs} +13 -12
  204. package/dist/{tax-region-detail-RIABXU7D.mjs → tax-region-detail-2AE2EFI3.mjs} +21 -20
  205. package/dist/{tax-region-edit-YZALLSZY.mjs → tax-region-edit-EEVEEU2Q.mjs} +13 -12
  206. package/dist/{tax-region-list-BXZBUXRJ.mjs → tax-region-list-P4LDOPZD.mjs} +3 -3
  207. package/dist/{tax-region-province-create-5JP3PVID.mjs → tax-region-province-create-GKJ7WMRS.mjs} +2 -2
  208. package/dist/{tax-region-province-detail-UKLRVJS2.mjs → tax-region-province-detail-4ERSEQFF.mjs} +20 -19
  209. package/dist/{tax-region-tax-override-create-33XGHH7A.mjs → tax-region-tax-override-create-PHCGEF7V.mjs} +16 -15
  210. package/dist/{tax-region-tax-override-edit-WOKZSPTY.mjs → tax-region-tax-override-edit-SMRPSILC.mjs} +17 -16
  211. package/dist/{tax-region-tax-rate-create-O2SDSXCH.mjs → tax-region-tax-rate-create-MECFGVPL.mjs} +2 -2
  212. package/dist/{tax-region-tax-rate-edit-W62VEVKT.mjs → tax-region-tax-rate-edit-7DYSPYOD.mjs} +2 -2
  213. package/dist/translation-list-UF7FLXOW.mjs +441 -0
  214. package/dist/translations-edit-USQJNMAY.mjs +707 -0
  215. package/dist/{user-detail-KEDJ7N3Q.mjs → user-detail-BJUXLZZQ.mjs} +2 -1
  216. package/dist/{user-edit-LXQCTDGA.mjs → user-edit-ZBB4RMTP.mjs} +2 -2
  217. package/dist/{user-invite-YH33WUC2.mjs → user-invite-GAGIM5DO.mjs} +2 -2
  218. package/dist/{user-metadata-4WOICEE7.mjs → user-metadata-2WPJOEJA.mjs} +14 -13
  219. package/dist/{workflow-execution-detail-OKM6P4SX.mjs → workflow-execution-detail-H2AKEZJX.mjs} +11 -10
  220. package/package.json +9 -9
  221. package/src/components/common/icon-avatar/icon-avatar.tsx +4 -0
  222. package/src/components/data-grid/components/data-grid-cell-container.tsx +13 -4
  223. package/src/components/data-grid/components/data-grid-multiline-cell.tsx +103 -0
  224. package/src/components/data-grid/components/data-grid-readonly-cell.tsx +13 -3
  225. package/src/components/data-grid/components/data-grid-root.tsx +271 -60
  226. package/src/components/data-grid/components/data-grid-text-cell.tsx +7 -7
  227. package/src/components/data-grid/components/data-grid-textarea-modal-cell.tsx +233 -0
  228. package/src/components/data-grid/components/index.ts +2 -0
  229. package/src/components/data-grid/data-grid.tsx +16 -1
  230. package/src/components/data-grid/helpers/create-data-grid-column-helper.ts +18 -0
  231. package/src/components/data-grid/hooks/use-data-grid-cell.tsx +12 -1
  232. package/src/components/data-grid/hooks/use-data-grid-keydown-event.tsx +43 -3
  233. package/src/components/data-grid/types.ts +1 -0
  234. package/src/components/layout/settings-layout/settings-layout.tsx +11 -1
  235. package/src/components/modals/route-focus-modal/route-focus-modal.tsx +8 -3
  236. package/src/components/modals/route-modal-form/route-modal-form.tsx +6 -1
  237. package/src/components/modals/route-modal-provider/route-provider.tsx +16 -4
  238. package/src/dashboard-app/routes/get-route.map.tsx +19 -0
  239. package/src/hooks/api/categories.tsx +32 -0
  240. package/src/hooks/api/collections.tsx +31 -0
  241. package/src/hooks/api/index.ts +1 -0
  242. package/src/hooks/api/product-types.tsx +32 -0
  243. package/src/hooks/api/product-variants.tsx +47 -3
  244. package/src/hooks/api/products.tsx +29 -0
  245. package/src/hooks/api/tags.tsx +32 -0
  246. package/src/hooks/api/translations.tsx +306 -0
  247. package/src/hooks/use-infinite-list.tsx +92 -0
  248. package/src/i18n/translations/$schema.json +122 -0
  249. package/src/i18n/translations/en.json +38 -0
  250. package/src/i18n/translations/es.json +38 -0
  251. package/src/routes/categories/category-detail/components/category-general-section/category-general-section.tsx +16 -1
  252. package/src/routes/categories/category-list/components/category-list-table/category-list-table.tsx +16 -1
  253. package/src/routes/collections/collection-detail/components/collection-general-section/collection-general-section.tsx +16 -1
  254. package/src/routes/collections/collection-list/components/collection-list-table/collection-row-actions.tsx +16 -1
  255. package/src/routes/product-tags/product-tag-detail/components/product-tag-general-section/product-tag-general-section.tsx +16 -1
  256. package/src/routes/product-tags/product-tag-list/components/product-tag-list-table/product-tag-list-table.tsx +16 -1
  257. package/src/routes/product-types/product-type-detail/components/product-type-general-section/product-type-general-section.tsx +16 -1
  258. package/src/routes/product-types/product-type-list/components/product-type-list-table/product-table-row-actions.tsx +16 -1
  259. package/src/routes/product-variants/product-variant-detail/components/variant-general-section/variant-general-section.tsx +16 -1
  260. package/src/routes/products/product-detail/components/product-general-section/product-general-section.tsx +16 -1
  261. package/src/routes/products/product-detail/components/product-variant-section/product-variant-section.tsx +32 -1
  262. package/src/routes/products/product-list/components/product-list-table/product-list-table.tsx +15 -1
  263. package/src/routes/translations/translation-list/components/active-locales-section/active-locales-section.tsx +68 -0
  264. package/src/routes/translations/translation-list/components/translation-list-section/translation-list-section.tsx +44 -0
  265. package/src/routes/translations/translation-list/components/translations-completion-section/translations-completion-section.tsx +224 -0
  266. package/src/routes/translations/translation-list/index.tsx +1 -0
  267. package/src/routes/translations/translation-list/translation-list.tsx +138 -0
  268. package/src/routes/translations/translations-edit/components/translations-edit-form/index.ts +1 -0
  269. package/src/routes/translations/translations-edit/components/translations-edit-form/translations-edit-form.tsx +792 -0
  270. package/src/routes/translations/translations-edit/index.ts +1 -0
  271. package/src/routes/translations/translations-edit/translations-edit.tsx +90 -0
@@ -1,4 +1,4 @@
1
- import { PencilSquare, Trash } from "@medusajs/icons"
1
+ import { GlobeEurope, PencilSquare, Trash } from "@medusajs/icons"
2
2
  import { HttpTypes } from "@medusajs/types"
3
3
  import { Container, Heading, StatusBadge, toast, usePrompt } from "@medusajs/ui"
4
4
  import { useTranslation } from "react-i18next"
@@ -8,6 +8,7 @@ import { ActionMenu } from "../../../../../components/common/action-menu"
8
8
  import { SectionRow } from "../../../../../components/common/section"
9
9
  import { useDeleteProduct } from "../../../../../hooks/api/products"
10
10
  import { useExtension } from "../../../../../providers/extension-provider"
11
+ import { useFeatureFlag } from "../../../../../providers/feature-flag-provider"
11
12
 
12
13
  const productStatusColor = (status: string) => {
13
14
  switch (status) {
@@ -35,6 +36,7 @@ export const ProductGeneralSection = ({
35
36
  const prompt = usePrompt()
36
37
  const navigate = useNavigate()
37
38
  const { getDisplays } = useExtension()
39
+ const isTranslationsEnabled = useFeatureFlag("translation")
38
40
 
39
41
  const displays = getDisplays("product", "general")
40
42
 
@@ -85,6 +87,19 @@ export const ProductGeneralSection = ({
85
87
  },
86
88
  ],
87
89
  },
90
+ ...(isTranslationsEnabled
91
+ ? [
92
+ {
93
+ actions: [
94
+ {
95
+ label: t("translations.actions.manage"),
96
+ to: `/settings/translations/edit?reference=product&reference_id=${product.id}`,
97
+ icon: <GlobeEurope />,
98
+ },
99
+ ],
100
+ },
101
+ ]
102
+ : []),
88
103
  {
89
104
  actions: [
90
105
  {
@@ -1,4 +1,10 @@
1
- import { Buildings, Component, PencilSquare, Trash } from "@medusajs/icons"
1
+ import {
2
+ Buildings,
3
+ Component,
4
+ GlobeEurope,
5
+ PencilSquare,
6
+ Trash,
7
+ } from "@medusajs/icons"
2
8
  import { HttpTypes } from "@medusajs/types"
3
9
  import {
4
10
  Badge,
@@ -26,6 +32,7 @@ import {
26
32
  import { useQueryParams } from "../../../../../hooks/use-query-params"
27
33
  import { PRODUCT_VARIANT_IDS_KEY } from "../../../common/constants"
28
34
  import { Thumbnail } from "../../../../../components/common/thumbnail"
35
+ import { useFeatureFlag } from "../../../../../providers/feature-flag-provider"
29
36
 
30
37
  type ProductVariantSectionProps = {
31
38
  product: HttpTypes.AdminProduct
@@ -38,6 +45,7 @@ export const ProductVariantSection = ({
38
45
  product,
39
46
  }: ProductVariantSectionProps) => {
40
47
  const { t } = useTranslation()
48
+ const isTranslationsEnabled = useFeatureFlag("translation")
41
49
 
42
50
  const { q, order, offset, allow_backorder, manage_inventory } =
43
51
  useQueryParams(
@@ -70,6 +78,11 @@ export const ProductVariantSection = ({
70
78
  }
71
79
  )
72
80
 
81
+ const translationParams = new URLSearchParams()
82
+ variants?.forEach((variant) => {
83
+ translationParams.append("reference_id", variant.id)
84
+ })
85
+
73
86
  if (isError) {
74
87
  throw error
75
88
  }
@@ -115,6 +128,15 @@ export const ProductVariantSection = ({
115
128
  to: `stock`,
116
129
  icon: <Buildings />,
117
130
  },
131
+ ...(isTranslationsEnabled
132
+ ? [
133
+ {
134
+ icon: <GlobeEurope />,
135
+ label: t("translations.actions.manage"),
136
+ to: `/settings/translations/edit?reference=product_variant&${translationParams.toString()}`,
137
+ },
138
+ ]
139
+ : []),
118
140
  ],
119
141
  },
120
142
  ],
@@ -225,6 +247,15 @@ const useColumns = (product: HttpTypes.AdminProduct) => {
225
247
  )
226
248
  },
227
249
  },
250
+ {
251
+ icon: <GlobeEurope />,
252
+ label: t("translations.actions.manage"),
253
+ onClick: () => {
254
+ navigate(
255
+ `/settings/translations/edit?reference=product_variant&reference_id=${variant.id}`
256
+ )
257
+ },
258
+ },
228
259
  ]
229
260
 
230
261
  const secondaryActions: DataTableAction<HttpTypes.AdminProductVariant>[] =
@@ -1,4 +1,4 @@
1
- import { PencilSquare, Trash } from "@medusajs/icons"
1
+ import { GlobeEurope, PencilSquare, Trash } from "@medusajs/icons"
2
2
  import { Button, Container, Heading, toast, usePrompt } from "@medusajs/ui"
3
3
  import { keepPreviousData } from "@tanstack/react-query"
4
4
  import { createColumnHelper } from "@tanstack/react-table"
@@ -110,6 +110,7 @@ const ProductActions = ({ product }: { product: HttpTypes.AdminProduct }) => {
110
110
  const { t } = useTranslation()
111
111
  const prompt = usePrompt()
112
112
  const { mutateAsync } = useDeleteProduct(product.id)
113
+ const isTranslationsEnabled = useFeatureFlag("translation")
113
114
 
114
115
  const handleDelete = async () => {
115
116
  const res = await prompt({
@@ -153,6 +154,19 @@ const ProductActions = ({ product }: { product: HttpTypes.AdminProduct }) => {
153
154
  },
154
155
  ],
155
156
  },
157
+ ...(isTranslationsEnabled
158
+ ? [
159
+ {
160
+ actions: [
161
+ {
162
+ icon: <GlobeEurope />,
163
+ label: t("translations.actions.manage"),
164
+ to: `/settings/translations/edit?reference=product&reference_id=${product.id}`,
165
+ },
166
+ ],
167
+ },
168
+ ]
169
+ : []),
156
170
  {
157
171
  actions: [
158
172
  {
@@ -0,0 +1,68 @@
1
+ import { PencilSquare, Language } from "@medusajs/icons"
2
+ import { Container, Heading, IconButton, InlineTip, Text } from "@medusajs/ui"
3
+ import { useTranslation } from "react-i18next"
4
+ import { IconAvatar } from "../../../../../components/common/icon-avatar"
5
+ import { HttpTypes } from "@medusajs/types"
6
+ import { useCallback } from "react"
7
+ import { useNavigate } from "react-router-dom"
8
+
9
+ type ActiveLocalesSectionProps = {
10
+ locales: HttpTypes.AdminLocale[]
11
+ }
12
+
13
+ export const ActiveLocalesSection = ({
14
+ locales,
15
+ }: ActiveLocalesSectionProps) => {
16
+ const { t } = useTranslation()
17
+ const navigate = useNavigate()
18
+
19
+ const handleManageLocales = useCallback(() => {
20
+ navigate("/settings/store/locales")
21
+ }, [navigate])
22
+
23
+ const renderLocales = useCallback(() => {
24
+ const maxLocalesToDetail = 2
25
+ if (locales.length <= maxLocalesToDetail) {
26
+ return locales.map((locale) => locale.name).join(", ")
27
+ }
28
+
29
+ return `${locales
30
+ .slice(0, maxLocalesToDetail)
31
+ .map((locale) => locale.name)
32
+ .join(", ")} + ${locales.length - maxLocalesToDetail}`
33
+ }, [locales])
34
+
35
+ const hasLocales = locales.length > 0
36
+
37
+ return (
38
+ <Container className="flex flex-col p-0">
39
+ <div className="flex items-center justify-between px-6 py-4">
40
+ <Heading>{t("translations.activeLocales.heading")}</Heading>
41
+ <IconButton variant="transparent" onClick={handleManageLocales}>
42
+ <PencilSquare></PencilSquare>
43
+ </IconButton>
44
+ </div>
45
+ <div className="px-1 pb-1">
46
+ {hasLocales ? (
47
+ <Container className="bg-ui-bg-component flex items-center gap-x-4 px-6 py-2">
48
+ <IconAvatar>
49
+ <Language />
50
+ </IconAvatar>
51
+ <div className="flex flex-col">
52
+ <Text size="small" weight="plus">
53
+ {t("translations.activeLocales.subtitle")}
54
+ </Text>
55
+ <Text className="text-ui-fg-subtle" size="small">
56
+ {renderLocales()}
57
+ </Text>
58
+ </div>
59
+ </Container>
60
+ ) : (
61
+ <InlineTip label="Tip">
62
+ {t("translations.activeLocales.noLocalesTip")}
63
+ </InlineTip>
64
+ )}
65
+ </div>
66
+ </Container>
67
+ )
68
+ }
@@ -0,0 +1,44 @@
1
+ import { Button, Container, Text } from "@medusajs/ui"
2
+ import { Link } from "react-router-dom"
3
+ import { TranslatableEntity } from "../../translation-list"
4
+ import { useTranslation } from "react-i18next"
5
+
6
+ type TranslationListSectionProps = {
7
+ entities: TranslatableEntity[]
8
+ hasLocales: boolean
9
+ }
10
+
11
+ export const TranslationListSection = ({
12
+ entities,
13
+ hasLocales = false,
14
+ }: TranslationListSectionProps) => {
15
+ const { t } = useTranslation()
16
+
17
+ return (
18
+ <Container className="divide-y p-0">
19
+ {entities.map((entity) => (
20
+ <div
21
+ key={entity.reference}
22
+ className="grid grid-cols-[250px_1fr_auto] items-center gap-x-4 px-6 py-4"
23
+ >
24
+ <Text size="small" weight="plus">
25
+ {entity.label}
26
+ </Text>
27
+ <Text size="small" className="text-ui-fg-subtle">
28
+ {t("translations.list.metrics", {
29
+ translated: (entity.translatedCount ?? 0).toLocaleString(),
30
+ total: (entity.totalCount ?? 0).toLocaleString(),
31
+ })}
32
+ </Text>
33
+ <Link
34
+ to={`/settings/translations/edit?reference=${entity.reference}`}
35
+ >
36
+ <Button variant="secondary" size="small" disabled={!hasLocales}>
37
+ Edit
38
+ </Button>
39
+ </Link>
40
+ </div>
41
+ ))}
42
+ </Container>
43
+ )
44
+ }
@@ -0,0 +1,224 @@
1
+ import { AdminTranslationEntityStatistics, HttpTypes } from "@medusajs/types"
2
+ import { Container, Heading, Text, Tooltip } from "@medusajs/ui"
3
+ import { useMemo, useState } from "react"
4
+ import { useTranslation } from "react-i18next"
5
+
6
+ type TranslationsCompletionSectionProps = {
7
+ statistics: Record<string, AdminTranslationEntityStatistics>
8
+ locales: HttpTypes.AdminLocale[]
9
+ }
10
+
11
+ type LocaleStats = {
12
+ code: string
13
+ name: string
14
+ translated: number
15
+ toTranslate: number
16
+ total: number
17
+ }
18
+
19
+ export const TranslationsCompletionSection = ({
20
+ statistics,
21
+ locales,
22
+ }: TranslationsCompletionSectionProps) => {
23
+ const { t } = useTranslation()
24
+ const [hoveredLocale, setHoveredLocale] = useState<string | null>(null)
25
+
26
+ const { translatedCount, totalCount } = Object.values(statistics).reduce(
27
+ (acc, curr) => ({
28
+ translatedCount: acc.translatedCount + curr.translated,
29
+ totalCount: acc.totalCount + curr.expected,
30
+ }),
31
+ { totalCount: 0, translatedCount: 0 }
32
+ )
33
+
34
+ const percentage = totalCount > 0 ? (translatedCount / totalCount) * 100 : 0
35
+ const remaining = Math.max(0, totalCount - translatedCount)
36
+
37
+ const localeStats = useMemo((): LocaleStats[] => {
38
+ const localeMap = new Map<
39
+ string,
40
+ { translated: number; expected: number }
41
+ >()
42
+
43
+ locales.forEach((locale) => {
44
+ localeMap.set(locale.code, { translated: 0, expected: 0 })
45
+ })
46
+
47
+ Object.values(statistics).forEach((entityStats) => {
48
+ if (entityStats.by_locale) {
49
+ Object.entries(entityStats.by_locale).forEach(
50
+ ([localeCode, localeData]) => {
51
+ const existing = localeMap.get(localeCode)
52
+ if (existing) {
53
+ existing.translated += localeData.translated
54
+ existing.expected += localeData.expected
55
+ }
56
+ }
57
+ )
58
+ }
59
+ })
60
+
61
+ return locales.map((locale) => {
62
+ const stats = localeMap.get(locale.code) || { translated: 0, expected: 0 }
63
+ return {
64
+ code: locale.code,
65
+ name: locale.name,
66
+ translated: stats.translated,
67
+ toTranslate: Math.max(0, stats.expected - stats.translated),
68
+ total: stats.expected,
69
+ }
70
+ })
71
+ }, [statistics, locales])
72
+
73
+ const maxTotal = useMemo(
74
+ () => Math.max(...localeStats.map((s) => s.total), 1),
75
+ [localeStats]
76
+ )
77
+
78
+ return (
79
+ <Container className="flex flex-col gap-y-3 px-6 py-4">
80
+ <div className="flex items-center justify-between">
81
+ <Heading>{t("translations.completion.heading")}</Heading>
82
+ <Text size="small" weight="plus" className="text-ui-fg-subtle">
83
+ {translatedCount.toLocaleString()} {t("general.of")}{" "}
84
+ {totalCount.toLocaleString()}
85
+ </Text>
86
+ </div>
87
+
88
+ <div className="flex h-3 w-full overflow-hidden">
89
+ {percentage > 0 ? (
90
+ <>
91
+ <div
92
+ className="mr-0.5 h-full rounded-sm transition-all"
93
+ style={{
94
+ width: `${percentage}%`,
95
+ backgroundColor: "var(--bg-interactive)",
96
+ }}
97
+ />
98
+ <div
99
+ className="h-full flex-1 rounded-sm"
100
+ style={{
101
+ backgroundColor: "var(--bg-interactive)",
102
+ opacity: 0.3,
103
+ }}
104
+ />
105
+ </>
106
+ ) : (
107
+ <div
108
+ className="h-full w-full rounded-full"
109
+ style={{
110
+ backgroundColor: "var(--bg-interactive)",
111
+ opacity: 0.3,
112
+ }}
113
+ />
114
+ )}
115
+ </div>
116
+
117
+ <div className="flex items-center justify-between">
118
+ <Text size="small" weight="plus" className="text-ui-fg-subtle">
119
+ {percentage.toFixed(1)}%
120
+ </Text>
121
+ <Text size="small" weight="plus" className="text-ui-fg-subtle">
122
+ {remaining.toLocaleString()} {t("general.remaining").toLowerCase()}
123
+ </Text>
124
+ </div>
125
+
126
+ {localeStats.length > 0 && (
127
+ <div className="mt-4 flex flex-col gap-y-2">
128
+ <div className="flex h-32 w-full items-end gap-1">
129
+ {localeStats.map((locale) => {
130
+ const heightPercent = (locale.total / maxTotal) * 100
131
+ const translatedPercent =
132
+ locale.total > 0 ? (locale.translated / locale.total) * 100 : 0
133
+
134
+ return (
135
+ <Tooltip
136
+ key={locale.code}
137
+ open={hoveredLocale === locale.code}
138
+ content={
139
+ <div className="flex flex-col gap-y-1 p-1">
140
+ <Text size="small" weight="plus">
141
+ {locale.name}
142
+ </Text>
143
+ <div className="flex items-center justify-between">
144
+ <div className="flex items-center gap-x-2">
145
+ <div
146
+ className="h-2 w-2 rounded-full"
147
+ style={{ backgroundColor: "var(--bg-interactive)" }}
148
+ />
149
+ <Text
150
+ size="small"
151
+ weight="plus"
152
+ className="text-ui-fg-subtle"
153
+ >
154
+ {t("translations.completion.translated")}
155
+ </Text>
156
+ </div>
157
+ <Text size="small" weight="plus">
158
+ {locale.translated}
159
+ </Text>
160
+ </div>
161
+ <div className="flex items-center gap-x-2">
162
+ <div
163
+ className="h-2 w-2 rounded-full"
164
+ style={{
165
+ backgroundColor: "var(--bg-interactive)",
166
+ opacity: 0.3,
167
+ }}
168
+ />
169
+ <Text
170
+ size="small"
171
+ weight="plus"
172
+ className="text-ui-fg-subtle"
173
+ >
174
+ {t("translations.completion.toTranslate")}
175
+ </Text>
176
+ <Text size="small" weight="plus">
177
+ {locale.toTranslate}
178
+ </Text>
179
+ </div>
180
+ </div>
181
+ }
182
+ >
183
+ <div
184
+ className="flex min-w-2 flex-1 cursor-pointer flex-col justify-end overflow-hidden rounded-t-sm transition-opacity"
185
+ style={{ height: `${heightPercent}%` }}
186
+ onMouseEnter={() => setHoveredLocale(locale.code)}
187
+ onMouseLeave={() => setHoveredLocale(null)}
188
+ >
189
+ <div
190
+ className="w-full rounded-t-sm"
191
+ style={{
192
+ height: `${100 - translatedPercent}%`,
193
+ backgroundColor: "var(--bg-interactive)",
194
+ opacity: 0.3,
195
+ minHeight: locale.toTranslate > 0 ? "2px" : "0",
196
+ }}
197
+ />
198
+ {translatedPercent > 0 && (
199
+ <div
200
+ className="mt-0.5 w-full rounded-sm"
201
+ style={{
202
+ height: `${translatedPercent}%`,
203
+ backgroundColor: "var(--bg-interactive)",
204
+ minHeight: locale.translated > 0 ? "2px" : "0",
205
+ }}
206
+ />
207
+ )}
208
+ </div>
209
+ </Tooltip>
210
+ )
211
+ })}
212
+ </div>
213
+ <Text
214
+ size="small"
215
+ weight="plus"
216
+ className="text-ui-fg-muted text-center"
217
+ >
218
+ {t("translations.completion.footer")}
219
+ </Text>
220
+ </div>
221
+ )}
222
+ </Container>
223
+ )
224
+ }
@@ -0,0 +1 @@
1
+ export { TranslationList as Component } from "./translation-list"
@@ -0,0 +1,138 @@
1
+ import { Container, Heading, Text } from "@medusajs/ui"
2
+ import { TwoColumnPage } from "../../../components/layout/pages"
3
+ import { useTranslation } from "react-i18next"
4
+ import {
5
+ useStore,
6
+ useTranslationSettings,
7
+ useTranslationStatistics,
8
+ } from "../../../hooks/api"
9
+ import { ActiveLocalesSection } from "./components/active-locales-section/active-locales-section"
10
+ import { TranslationListSection } from "./components/translation-list-section/translation-list-section"
11
+ import { TranslationsCompletionSection } from "./components/translations-completion-section/translations-completion-section"
12
+ import { TwoColumnPageSkeleton } from "../../../components/common/skeleton"
13
+ import { useMemo } from "react"
14
+
15
+ export type TranslatableEntity = {
16
+ label: string
17
+ reference: string
18
+ translatableFields: string[]
19
+ translatedCount?: number
20
+ totalCount?: number
21
+ }
22
+
23
+ export const TranslationList = () => {
24
+ const { t } = useTranslation()
25
+
26
+ const { store, isPending, isError, error } = useStore()
27
+ const {
28
+ translatable_fields,
29
+ isPending: isTranslationSettingsPending,
30
+ isError: isTranslationSettingsError,
31
+ error: translationSettingsError,
32
+ } = useTranslationSettings()
33
+ const {
34
+ statistics,
35
+ isPending: isTranslationStatisticsPending,
36
+ isError: isTranslationStatisticsError,
37
+ error: translationStatisticsError,
38
+ } = useTranslationStatistics(
39
+ {
40
+ locales:
41
+ store?.supported_locales?.map(
42
+ (suportedLocale) => suportedLocale.locale_code
43
+ ) ?? [],
44
+ entity_types: Object.keys(translatable_fields ?? {}),
45
+ },
46
+ {
47
+ enabled:
48
+ !!translatable_fields && !!store && store.supported_locales?.length > 0,
49
+ }
50
+ )
51
+
52
+ if (isError || isTranslationSettingsError || isTranslationStatisticsError) {
53
+ throw error || translationSettingsError || translationStatisticsError
54
+ }
55
+
56
+ const hasLocales = (store?.supported_locales ?? []).length > 0
57
+
58
+ const translatableEntities: TranslatableEntity[] = useMemo(() => {
59
+ if (!translatable_fields) {
60
+ return []
61
+ }
62
+
63
+ return Object.entries(translatable_fields)
64
+ .filter(
65
+ ([entity]) =>
66
+ !["product_option", "product_option_value"].includes(entity)
67
+ )
68
+ .map(([entity, fields]) => {
69
+ const entityStatistics = statistics?.[entity] ?? {
70
+ translated: 0,
71
+ expected: 0,
72
+ }
73
+
74
+ return {
75
+ label: entity
76
+ .split("_")
77
+ .map((word) => word.charAt(0).toUpperCase() + word.slice(1))
78
+ .join(" "),
79
+ reference: entity,
80
+ translatableFields: fields,
81
+ translatedCount: entityStatistics.translated,
82
+ totalCount: entityStatistics.expected,
83
+ }
84
+ })
85
+ }, [translatable_fields, statistics])
86
+
87
+ const isReady =
88
+ !!store &&
89
+ !isPending &&
90
+ !isTranslationSettingsPending &&
91
+ !!translatable_fields &&
92
+ ((!!statistics && !isTranslationStatisticsPending) || !hasLocales)
93
+
94
+ if (!isReady) {
95
+ return <TwoColumnPageSkeleton sidebarSections={2} />
96
+ }
97
+
98
+ return (
99
+ <TwoColumnPage
100
+ widgets={{
101
+ before: [],
102
+ after: [],
103
+ sideBefore: [],
104
+ sideAfter: [],
105
+ }}
106
+ >
107
+ <TwoColumnPage.Main>
108
+ <Container className="flex flex-col px-6 py-4">
109
+ <Heading>Manage {t("translations.domain")}</Heading>
110
+ <Text className="text-ui-fg-subtle" size="small">
111
+ {t("translations.subtitle")}
112
+ </Text>
113
+ </Container>
114
+ <TranslationListSection
115
+ entities={translatableEntities}
116
+ hasLocales={hasLocales}
117
+ />
118
+ </TwoColumnPage.Main>
119
+ <TwoColumnPage.Sidebar>
120
+ <ActiveLocalesSection
121
+ locales={
122
+ store?.supported_locales?.map(
123
+ (suportedLocale) => suportedLocale.locale
124
+ ) ?? []
125
+ }
126
+ ></ActiveLocalesSection>
127
+ <TranslationsCompletionSection
128
+ statistics={statistics ?? {}}
129
+ locales={
130
+ store?.supported_locales?.map(
131
+ (supportedLocale) => supportedLocale.locale
132
+ ) ?? []
133
+ }
134
+ />
135
+ </TwoColumnPage.Sidebar>
136
+ </TwoColumnPage>
137
+ )
138
+ }
@@ -0,0 +1 @@
1
+ export * from "./translations-edit-form"