@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.
- package/dist/{add-campaign-promotions-4QLXO46G.mjs → add-campaign-promotions-OYPGISTF.mjs} +2 -2
- package/dist/{adjust-inventory-2MFA656V.mjs → adjust-inventory-26YXAXQL.mjs} +4 -3
- package/dist/{api-key-management-create-ZUVF3SLR.mjs → api-key-management-create-EMP32G2D.mjs} +6 -5
- package/dist/{api-key-management-detail-THD74G7I.mjs → api-key-management-detail-6RCDH73M.mjs} +11 -10
- package/dist/{api-key-management-edit-42HNUSXL.mjs → api-key-management-edit-IBM3ZXHK.mjs} +6 -5
- package/dist/{api-key-management-list-66CFOILY.mjs → api-key-management-list-KC5GOWAU.mjs} +4 -3
- package/dist/{api-key-management-sales-channels-HN3THM5J.mjs → api-key-management-sales-channels-LUB5G6RC.mjs} +6 -5
- package/dist/app.css +53 -0
- package/dist/app.js +13537 -11320
- package/dist/app.mjs +12 -11
- package/dist/{campaign-budget-edit-6DMZGUCI.mjs → campaign-budget-edit-B5MSE26J.mjs} +2 -2
- package/dist/{campaign-configuration-UNFRB5HR.mjs → campaign-configuration-QOE3D2BE.mjs} +2 -2
- package/dist/{campaign-create-QXG7PD3S.mjs → campaign-create-FJOECKGT.mjs} +3 -3
- package/dist/{campaign-detail-WR3XHHV2.mjs → campaign-detail-5Q4BYCPX.mjs} +11 -10
- package/dist/{campaign-edit-HN4US7DV.mjs → campaign-edit-K2POQH7M.mjs} +2 -2
- package/dist/{categories-metadata-BCZ463KN.mjs → categories-metadata-J7M3XWI7.mjs} +14 -13
- package/dist/{category-create-FFIBWXAH.mjs → category-create-KHJZSC7G.mjs} +5 -4
- package/dist/{category-detail-4HXJ5Z7N.mjs → category-detail-S5IPXMHX.mjs} +29 -13
- package/dist/{category-edit-74MZ6TXN.mjs → category-edit-CTA2EPDG.mjs} +5 -4
- package/dist/{category-list-OCJY2UJV.mjs → category-list-QBYJ4T3R.mjs} +20 -4
- package/dist/{category-organize-B6EFBFKB.mjs → category-organize-SXP33XET.mjs} +5 -4
- package/dist/{category-products-2HXLZDHL.mjs → category-products-KPW6BA5J.mjs} +14 -13
- package/dist/{chunk-XIVBRONM.mjs → chunk-23GTCEOV.mjs} +1 -1
- package/dist/{chunk-2NZDHAOE.mjs → chunk-27MGH3HR.mjs} +2 -2
- package/dist/{chunk-N3FCYZV6.mjs → chunk-2XTBDCGE.mjs} +1 -1
- package/dist/{chunk-RU4ZS47V.mjs → chunk-4JQR6QNW.mjs} +2 -2
- package/dist/{chunk-Z6NHG5LQ.mjs → chunk-6P4Q4AAP.mjs} +3 -3
- package/dist/{chunk-F5NZDW7L.mjs → chunk-A2WBKOXJ.mjs} +2 -2
- package/dist/{chunk-F63F3FIT.mjs → chunk-A4XYK3MY.mjs} +2 -2
- package/dist/{chunk-NT6C7CHT.mjs → chunk-AWRCV3ME.mjs} +1 -1
- package/dist/{chunk-5X6SKB2P.mjs → chunk-BMS2QLJY.mjs} +1 -1
- package/dist/{chunk-3YPRDSZ6.mjs → chunk-BZKI5J2M.mjs} +1 -1
- package/dist/{chunk-25UWYEJX.mjs → chunk-CQOOXWPZ.mjs} +1 -1
- package/dist/{chunk-5DUMSVP6.mjs → chunk-CVHJAKLQ.mjs} +3 -3
- package/dist/{chunk-42OOM4DJ.mjs → chunk-D6UW7URG.mjs} +23 -6
- package/dist/{chunk-LHNU4DYZ.mjs → chunk-DBXWB3RF.mjs} +2 -2
- package/dist/{chunk-N4O5FAUC.mjs → chunk-FYWHE3W5.mjs} +1 -1
- package/dist/{chunk-QPKW37WR.mjs → chunk-GRZSG4EP.mjs} +244 -14
- package/dist/chunk-HGRIOEAR.mjs +32 -0
- package/dist/{chunk-Y5UO73CH.mjs → chunk-HTCYX4VD.mjs} +1 -1
- package/dist/{chunk-34KFHPN6.mjs → chunk-IAV7IKJ6.mjs} +1 -1
- package/dist/{chunk-6W3BKVOC.mjs → chunk-KFYQTOGB.mjs} +1 -1
- package/dist/{chunk-EQTBJSBZ.mjs → chunk-KIIT4BNH.mjs} +3 -0
- package/dist/{chunk-W7SLPIO2.mjs → chunk-LZFWCKOF.mjs} +655 -147
- package/dist/{chunk-PNPT4W2F.mjs → chunk-MJDHVDOW.mjs} +1 -1
- package/dist/{chunk-D4J3CEWH.mjs → chunk-N3SAXQVR.mjs} +2 -2
- package/dist/{chunk-Q6MSICBU.mjs → chunk-O333RR6K.mjs} +1 -1
- package/dist/{chunk-F65T2X7G.mjs → chunk-OL24RDYM.mjs} +5 -5
- package/dist/{chunk-7ZYDO3XO.mjs → chunk-OL6MEUKW.mjs} +295 -194
- package/dist/{chunk-7AX6R6G6.mjs → chunk-OSHH5GAS.mjs} +13 -1
- package/dist/{chunk-YAPTGHGP.mjs → chunk-PHLCT2HA.mjs} +1 -1
- package/dist/{chunk-35LSPN2U.mjs → chunk-QKALAT7P.mjs} +1 -1
- package/dist/{chunk-UM4OIJZ3.mjs → chunk-S22SJRPO.mjs} +1 -1
- package/dist/{chunk-4YAPXPLM.mjs → chunk-ST4P6BQN.mjs} +1 -1
- package/dist/{chunk-B3AOQW2B.mjs → chunk-U6G4M5LP.mjs} +1 -1
- package/dist/{chunk-HWKLNKOY.mjs → chunk-U726TGCM.mjs} +1 -1
- package/dist/{chunk-HKIF5HVL.mjs → chunk-UJ2TMPV4.mjs} +12 -0
- package/dist/{chunk-NHDFPGQ3.mjs → chunk-UWY5ZV66.mjs} +13 -1
- package/dist/{chunk-XXBP2Z5M.mjs → chunk-WVA4O7QS.mjs} +1 -1
- package/dist/{chunk-PXJFCRIV.mjs → chunk-WYATCUOM.mjs} +4 -4
- package/dist/{chunk-AH4DORIW.mjs → chunk-XY7A7GZJ.mjs} +1 -1
- package/dist/{chunk-FQDPOKEK.mjs → chunk-Y2YVTIJI.mjs} +1 -1
- package/dist/{chunk-L4NOVTH5.mjs → chunk-YIOBBZUB.mjs} +2 -2
- package/dist/{chunk-MY6I7UJG.mjs → chunk-YYOPBKME.mjs} +3 -3
- package/dist/{chunk-LEJUZW3P.mjs → chunk-Z6BFNHEO.mjs} +12 -0
- package/dist/{chunk-HFT7Q5Y5.mjs → chunk-ZMG5B4FG.mjs} +1 -1
- package/dist/{collection-add-products-JWAQ277T.mjs → collection-add-products-FU2BS3D3.mjs} +14 -13
- package/dist/{collection-create-DCRW344Z.mjs → collection-create-GWKWVT7B.mjs} +5 -4
- package/dist/{collection-detail-F4ON763T.mjs → collection-detail-VJE7XHLV.mjs} +28 -12
- package/dist/{collection-edit-UNFEW6HT.mjs → collection-edit-EZIO2BR5.mjs} +5 -4
- package/dist/{collection-list-4C5HVO6Y.mjs → collection-list-IGA6SCNF.mjs} +29 -13
- package/dist/{collection-metadata-P4A5DXBQ.mjs → collection-metadata-QK7MI3D2.mjs} +14 -13
- package/dist/{customer-create-XCLZENJS.mjs → customer-create-IA56MXE6.mjs} +2 -2
- package/dist/{customer-create-address-4HZUIAM7.mjs → customer-create-address-27M25HTO.mjs} +2 -2
- package/dist/{customer-detail-X3RQJPXP.mjs → customer-detail-MOV2T3LF.mjs} +12 -11
- package/dist/{customer-edit-BW5GVTQI.mjs → customer-edit-XQ5NWIVX.mjs} +2 -2
- package/dist/{customer-group-add-customers-SOXMSWQH.mjs → customer-group-add-customers-XMR2WBXX.mjs} +2 -2
- package/dist/{customer-group-create-6YV7W6TI.mjs → customer-group-create-RY4FVEIW.mjs} +2 -2
- package/dist/{customer-group-detail-NG32WKJT.mjs → customer-group-detail-6T7OXGQD.mjs} +11 -10
- package/dist/{customer-group-edit-7NXU34BQ.mjs → customer-group-edit-MQWARIQZ.mjs} +2 -2
- package/dist/{customer-group-list-EBETHKKO.mjs → customer-group-list-AJEAF5D2.mjs} +11 -10
- package/dist/{customer-group-metadata-WK2BGEGO.mjs → customer-group-metadata-JQJRLLXG.mjs} +3 -3
- package/dist/{customer-metadata-ZUWCUTM7.mjs → customer-metadata-HN2DYD5I.mjs} +3 -3
- package/dist/{customers-add-customer-group-7FYD54MZ.mjs → customers-add-customer-group-QVTVSQYM.mjs} +13 -12
- package/dist/{edit-inventory-item-Y5W6VTHJ.mjs → edit-inventory-item-H7DAZWIT.mjs} +4 -3
- package/dist/{edit-inventory-item-attributes-NAAZDFEJ.mjs → edit-inventory-item-attributes-7HTXXPGZ.mjs} +4 -3
- package/dist/{edit-reservation-2UD4RZJX.mjs → edit-reservation-OVTRZHJR.mjs} +5 -4
- package/dist/{edit-rules-2W3BXEXR.mjs → edit-rules-SMVRTCUP.mjs} +13 -12
- package/dist/en.json +38 -0
- package/dist/{inventory-create-VQEK7C5T.mjs → inventory-create-BK52VALF.mjs} +14 -13
- package/dist/{inventory-detail-HUHQ6ZNE.mjs → inventory-detail-ZPSEMYI2.mjs} +11 -10
- package/dist/{inventory-list-RUSSPKHE.mjs → inventory-list-RXJPSVZE.mjs} +2 -1
- package/dist/{inventory-metadata-X52VGHA7.mjs → inventory-metadata-FNEJ3RAT.mjs} +14 -13
- package/dist/{inventory-stock-EKTOYN2F.mjs → inventory-stock-6WYWLWJ7.mjs} +15 -14
- package/dist/{invite-VKHAAF4Z.mjs → invite-FVE4ZBKB.mjs} +2 -2
- package/dist/{location-create-RPLEXUZR.mjs → location-create-WZ43K3W7.mjs} +2 -2
- package/dist/{location-detail-UVWYE6Q2.mjs → location-detail-N3GUZSY7.mjs} +12 -11
- package/dist/{location-edit-L4ISEQHX.mjs → location-edit-VCS7GVWQ.mjs} +2 -2
- package/dist/{location-fulfillment-providers-HZZUHPVL.mjs → location-fulfillment-providers-7ZUJAGNY.mjs} +15 -14
- package/dist/{location-list-Z42ZYHUF.mjs → location-list-KVBA6J47.mjs} +2 -2
- package/dist/{location-sales-channels-XIMOK66B.mjs → location-sales-channels-P3QJTFDT.mjs} +5 -4
- package/dist/{location-service-zone-create-7ZNVLEE3.mjs → location-service-zone-create-J43WN6G4.mjs} +3 -3
- package/dist/{location-service-zone-edit-6OUAFEZD.mjs → location-service-zone-edit-KHHMSPXD.mjs} +2 -2
- package/dist/{location-service-zone-manage-areas-EOULKRYD.mjs → location-service-zone-manage-areas-6ZPMKMSX.mjs} +3 -3
- package/dist/{location-service-zone-shipping-option-create-M7G4SKNP.mjs → location-service-zone-shipping-option-create-CNRWYZQC.mjs} +15 -14
- package/dist/{location-service-zone-shipping-option-edit-M2HJAASG.mjs → location-service-zone-shipping-option-edit-4CGPQ3VT.mjs} +2 -2
- package/dist/{location-service-zone-shipping-option-pricing-23QLNSBT.mjs → location-service-zone-shipping-option-pricing-OGWI7VPT.mjs} +4 -4
- package/dist/{login-NSCAMAU6.mjs → login-VNOLI5YG.mjs} +13 -12
- package/dist/{manage-locations-JD6FSBOT.mjs → manage-locations-7HH6R4UP.mjs} +4 -3
- package/dist/{order-allocate-items-5T57NZOB.mjs → order-allocate-items-HZGGYJ42.mjs} +6 -5
- package/dist/{order-create-claim-TE56IE7P.mjs → order-create-claim-SCDJGM46.mjs} +15 -14
- package/dist/{order-create-edit-RDFYBVFY.mjs → order-create-edit-2WALBPXS.mjs} +14 -13
- package/dist/{order-create-exchange-B5ZOEQCJ.mjs → order-create-exchange-LQU4YN7F.mjs} +15 -14
- package/dist/{order-create-fulfillment-SRRP6X64.mjs → order-create-fulfillment-OWUVTZXW.mjs} +13 -12
- package/dist/{order-create-refund-PTOM65QK.mjs → order-create-refund-Q6HQY42R.mjs} +13 -12
- package/dist/{order-create-return-3C2QVNYN.mjs → order-create-return-52GHGW5Z.mjs} +7 -6
- package/dist/{order-create-shipment-HNILNFXB.mjs → order-create-shipment-WAGGEPRW.mjs} +13 -12
- package/dist/{order-detail-3OUZOQ7G.mjs → order-detail-PVPGEWGY.mjs} +15 -14
- package/dist/{order-edit-billing-address-3IO7GXIK.mjs → order-edit-billing-address-UM76J4KX.mjs} +13 -12
- package/dist/{order-edit-email-QIAEOUBV.mjs → order-edit-email-CL3KNOCM.mjs} +13 -12
- package/dist/{order-edit-shipping-address-QGGMHGBC.mjs → order-edit-shipping-address-PIESTGVL.mjs} +13 -12
- package/dist/{order-export-JYYFTOWR.mjs → order-export-LE363ZLB.mjs} +14 -13
- package/dist/{order-list-RFR3HNDQ.mjs → order-list-GRLQWN4L.mjs} +6 -5
- package/dist/{order-metadata-ZBDTMBHZ.mjs → order-metadata-FHBB7MTG.mjs} +14 -13
- package/dist/{order-receive-return-V42FTCFY.mjs → order-receive-return-PRVKP6J2.mjs} +14 -13
- package/dist/{order-request-transfer-A6NNIN2O.mjs → order-request-transfer-XSAGRUMT.mjs} +13 -12
- package/dist/{price-list-configuration-RTUEJENE.mjs → price-list-configuration-6S3MLNXQ.mjs} +6 -5
- package/dist/{price-list-create-GRT27KOM.mjs → price-list-create-K5JEZT57.mjs} +17 -16
- package/dist/{price-list-detail-VKIWM7HP.mjs → price-list-detail-Q5VG5VGW.mjs} +13 -12
- package/dist/{price-list-edit-SW7YIR3Z.mjs → price-list-edit-53UW35L3.mjs} +5 -4
- package/dist/{price-list-list-LF2PL4B5.mjs → price-list-list-DG5YEZ44.mjs} +4 -3
- package/dist/{price-list-prices-add-ISLZDQNI.mjs → price-list-prices-add-2MQ226U4.mjs} +16 -15
- package/dist/{price-list-prices-edit-C6SX2TLJ.mjs → price-list-prices-edit-OJZLV7OS.mjs} +7 -6
- package/dist/{product-attributes-REJ5NF2D.mjs → product-attributes-YF4TZOIO.mjs} +14 -13
- package/dist/{product-create-4TFE3JHQ.mjs → product-create-KJML2332.mjs} +16 -15
- package/dist/{product-create-option-GEGQNSMQ.mjs → product-create-option-7AOXAA4S.mjs} +4 -3
- package/dist/{product-create-variant-WI6D5CDG.mjs → product-create-variant-5EBCLM54.mjs} +14 -13
- package/dist/{product-detail-BEIDGPKY.mjs → product-detail-QG72542C.mjs} +59 -17
- package/dist/{product-edit-ZRQUK5OQ.mjs → product-edit-DZZR775Q.mjs} +14 -13
- package/dist/{product-edit-option-HBIOBQTS.mjs → product-edit-option-LWJT3CYJ.mjs} +4 -3
- package/dist/{product-export-GIEFG4MA.mjs → product-export-5AD7NELI.mjs} +15 -14
- package/dist/{product-image-variants-edit-AAMRK4KQ.mjs → product-image-variants-edit-M6QF2RLE.mjs} +13 -12
- package/dist/{product-import-43UXKCL3.mjs → product-import-V3KQN4TV.mjs} +13 -12
- package/dist/{product-list-D4CVUBQQ.mjs → product-list-EUWZIFTM.mjs} +25 -12
- package/dist/{product-media-EGK66SRX.mjs → product-media-3VJ7KENL.mjs} +4 -3
- package/dist/{product-metadata-55CAQTPS.mjs → product-metadata-GL2MVPDI.mjs} +14 -13
- package/dist/{product-organization-7J7MUM6F.mjs → product-organization-O7RHELMQ.mjs} +15 -14
- package/dist/{product-prices-WQDE4XYT.mjs → product-prices-YWV6MSM6.mjs} +5 -4
- package/dist/{product-sales-channels-GIJ7Q57M.mjs → product-sales-channels-PPXUG4KT.mjs} +5 -4
- package/dist/{product-shipping-profile-KIDRTPWA.mjs → product-shipping-profile-ETQFZ7DC.mjs} +4 -3
- package/dist/{product-stock-22S2HGMM.mjs → product-stock-AKEFMK5O.mjs} +15 -14
- package/dist/{product-tag-create-7GPE246H.mjs → product-tag-create-PQMDDKWH.mjs} +13 -12
- package/dist/{product-tag-detail-R6C2TTA4.mjs → product-tag-detail-I3MBZX7U.mjs} +30 -14
- package/dist/{product-tag-edit-WA6FGSIP.mjs → product-tag-edit-K3BBQLJR.mjs} +13 -12
- package/dist/{product-tag-list-U7PLHMLF.mjs → product-tag-list-JUWSOMB7.mjs} +30 -14
- package/dist/{product-tag-metadata-EJ7FEXSE.mjs → product-tag-metadata-MJH5LH7E.mjs} +14 -13
- package/dist/{product-type-create-HBDROTGB.mjs → product-type-create-DRFXTL5O.mjs} +4 -3
- package/dist/{product-type-detail-TYQ7MJFE.mjs → product-type-detail-RKHT5NBL.mjs} +29 -13
- package/dist/{product-type-edit-H3JCMVRV.mjs → product-type-edit-SRHCZDK7.mjs} +4 -3
- package/dist/{product-type-list-KIKWBPD7.mjs → product-type-list-QQKAHBJ3.mjs} +19 -3
- package/dist/{product-type-metadata-Q6W5GL7Z.mjs → product-type-metadata-CDJDFFGQ.mjs} +14 -13
- package/dist/{product-variant-detail-SPJ7MZTK.mjs → product-variant-detail-XAYG5CKE.mjs} +27 -11
- package/dist/{product-variant-edit-BW7QMHC5.mjs → product-variant-edit-DEZEY2H2.mjs} +13 -12
- package/dist/{product-variant-manage-inventory-items-BLHCH6QD.mjs → product-variant-manage-inventory-items-Y2VEOHP7.mjs} +4 -3
- package/dist/{product-variant-media-KLSUISGH.mjs → product-variant-media-2WLVNGI4.mjs} +4 -3
- package/dist/{product-variant-metadata-GDMVC4MZ.mjs → product-variant-metadata-VTZDNWUT.mjs} +14 -13
- package/dist/{profile-edit-YBBXXCCK.mjs → profile-edit-ZNXO6WME.mjs} +2 -2
- package/dist/{promotion-add-campaign-JRTM7WBR.mjs → promotion-add-campaign-DO67QK6M.mjs} +3 -3
- package/dist/{promotion-create-HF6DTKCC.mjs → promotion-create-HWFNUQXG.mjs} +15 -14
- package/dist/{promotion-detail-HTM3F2VO.mjs → promotion-detail-QC36KXB3.mjs} +11 -10
- package/dist/{promotion-edit-details-AREFQ6O5.mjs → promotion-edit-details-6BSOOWQN.mjs} +2 -2
- package/dist/{refund-reason-create-RKIH46D6.mjs → refund-reason-create-YHCDEHGQ.mjs} +13 -12
- package/dist/{refund-reason-edit-V3KC6NMO.mjs → refund-reason-edit-CZ5QZ2SZ.mjs} +13 -12
- package/dist/{refund-reason-list-M5BOHFWU.mjs → refund-reason-list-OJYYEYJE.mjs} +11 -10
- package/dist/{region-add-countries-OF5RUSYU.mjs → region-add-countries-2VAVXMJQ.mjs} +2 -2
- package/dist/{region-create-BGOWVCTR.mjs → region-create-NA7Y2LN4.mjs} +2 -2
- package/dist/{region-edit-5GO25GDF.mjs → region-edit-WAU347DP.mjs} +2 -2
- package/dist/{region-metadata-5NGUNAXZ.mjs → region-metadata-H6XXUQ4S.mjs} +14 -13
- package/dist/{reservation-create-Z2SUMBGT.mjs → reservation-create-ZCIYM6JI.mjs} +5 -4
- package/dist/{reservation-detail-JH77TQHN.mjs → reservation-detail-LZAQL4XA.mjs} +11 -10
- package/dist/{reservation-list-WHBGZSVH.mjs → reservation-list-B47DXTA7.mjs} +3 -2
- package/dist/{reservation-metadata-ERCWXYVL.mjs → reservation-metadata-5HZSDDOK.mjs} +14 -13
- package/dist/{reset-password-5TAYQEUV.mjs → reset-password-Y5WVXV4Q.mjs} +2 -2
- package/dist/{return-reason-create-NXWDC6AC.mjs → return-reason-create-HM54WRJY.mjs} +2 -2
- package/dist/{return-reason-edit-M6IKNNKB.mjs → return-reason-edit-VSIRHVQ6.mjs} +2 -2
- package/dist/{sales-channel-add-products-DTAXWL6H.mjs → sales-channel-add-products-F7YV4MO5.mjs} +14 -13
- package/dist/{sales-channel-create-E7BDTPWD.mjs → sales-channel-create-MI7HHZYE.mjs} +5 -4
- package/dist/{sales-channel-detail-XWHV7J7X.mjs → sales-channel-detail-MXIPZCGA.mjs} +12 -11
- package/dist/{sales-channel-edit-HMPA3Y3L.mjs → sales-channel-edit-VSHOIR37.mjs} +5 -4
- package/dist/{sales-channel-list-7NSEFCXQ.mjs → sales-channel-list-RLGL7FM3.mjs} +11 -10
- package/dist/{sales-channel-metadata-CMZN74K7.mjs → sales-channel-metadata-M364R4RJ.mjs} +14 -13
- package/dist/{shipping-option-type-create-4BN2GBHP.mjs → shipping-option-type-create-C5WUWON7.mjs} +13 -12
- package/dist/{shipping-option-type-detail-YB3TCED2.mjs → shipping-option-type-detail-PENS2K73.mjs} +12 -11
- package/dist/{shipping-option-type-edit-MDO7ALAU.mjs → shipping-option-type-edit-CIU5EHRP.mjs} +13 -12
- package/dist/{shipping-option-type-list-DJAT4RKX.mjs → shipping-option-type-list-DIOX7VG7.mjs} +12 -11
- package/dist/{shipping-profile-create-752TMBBE.mjs → shipping-profile-create-26R64I3Z.mjs} +2 -2
- package/dist/{shipping-profile-metadata-HQI7PCPU.mjs → shipping-profile-metadata-75G2NNMA.mjs} +14 -13
- package/dist/{store-add-currencies-PEWNEWCH.mjs → store-add-currencies-OX2WXFMS.mjs} +2 -2
- package/dist/{store-add-locales-JLRTXG3Q.mjs → store-add-locales-VJ4RJ7UI.mjs} +12 -11
- package/dist/{store-detail-MOLAYNQZ.mjs → store-detail-JSNPOB2F.mjs} +11 -10
- package/dist/{store-edit-FTLPT55E.mjs → store-edit-5ZS562ZO.mjs} +2 -2
- package/dist/{store-metadata-ZJD23O4D.mjs → store-metadata-CYXTVJUE.mjs} +14 -13
- package/dist/{tax-region-create-NCO2OQ3I.mjs → tax-region-create-DWGL4EUT.mjs} +13 -12
- package/dist/{tax-region-detail-RIABXU7D.mjs → tax-region-detail-2AE2EFI3.mjs} +21 -20
- package/dist/{tax-region-edit-YZALLSZY.mjs → tax-region-edit-EEVEEU2Q.mjs} +13 -12
- package/dist/{tax-region-list-BXZBUXRJ.mjs → tax-region-list-P4LDOPZD.mjs} +3 -3
- package/dist/{tax-region-province-create-5JP3PVID.mjs → tax-region-province-create-GKJ7WMRS.mjs} +2 -2
- package/dist/{tax-region-province-detail-UKLRVJS2.mjs → tax-region-province-detail-4ERSEQFF.mjs} +20 -19
- package/dist/{tax-region-tax-override-create-33XGHH7A.mjs → tax-region-tax-override-create-PHCGEF7V.mjs} +16 -15
- package/dist/{tax-region-tax-override-edit-WOKZSPTY.mjs → tax-region-tax-override-edit-SMRPSILC.mjs} +17 -16
- package/dist/{tax-region-tax-rate-create-O2SDSXCH.mjs → tax-region-tax-rate-create-MECFGVPL.mjs} +2 -2
- package/dist/{tax-region-tax-rate-edit-W62VEVKT.mjs → tax-region-tax-rate-edit-7DYSPYOD.mjs} +2 -2
- package/dist/translation-list-UF7FLXOW.mjs +441 -0
- package/dist/translations-edit-USQJNMAY.mjs +707 -0
- package/dist/{user-detail-KEDJ7N3Q.mjs → user-detail-BJUXLZZQ.mjs} +2 -1
- package/dist/{user-edit-LXQCTDGA.mjs → user-edit-ZBB4RMTP.mjs} +2 -2
- package/dist/{user-invite-YH33WUC2.mjs → user-invite-GAGIM5DO.mjs} +2 -2
- package/dist/{user-metadata-4WOICEE7.mjs → user-metadata-2WPJOEJA.mjs} +14 -13
- package/dist/{workflow-execution-detail-OKM6P4SX.mjs → workflow-execution-detail-H2AKEZJX.mjs} +11 -10
- package/package.json +9 -9
- package/src/components/common/icon-avatar/icon-avatar.tsx +4 -0
- package/src/components/data-grid/components/data-grid-cell-container.tsx +13 -4
- package/src/components/data-grid/components/data-grid-multiline-cell.tsx +103 -0
- package/src/components/data-grid/components/data-grid-readonly-cell.tsx +13 -3
- package/src/components/data-grid/components/data-grid-root.tsx +271 -60
- package/src/components/data-grid/components/data-grid-text-cell.tsx +7 -7
- package/src/components/data-grid/components/data-grid-textarea-modal-cell.tsx +233 -0
- package/src/components/data-grid/components/index.ts +2 -0
- package/src/components/data-grid/data-grid.tsx +16 -1
- package/src/components/data-grid/helpers/create-data-grid-column-helper.ts +18 -0
- package/src/components/data-grid/hooks/use-data-grid-cell.tsx +12 -1
- package/src/components/data-grid/hooks/use-data-grid-keydown-event.tsx +43 -3
- package/src/components/data-grid/types.ts +1 -0
- package/src/components/layout/settings-layout/settings-layout.tsx +11 -1
- package/src/components/modals/route-focus-modal/route-focus-modal.tsx +8 -3
- package/src/components/modals/route-modal-form/route-modal-form.tsx +6 -1
- package/src/components/modals/route-modal-provider/route-provider.tsx +16 -4
- package/src/dashboard-app/routes/get-route.map.tsx +19 -0
- package/src/hooks/api/categories.tsx +32 -0
- package/src/hooks/api/collections.tsx +31 -0
- package/src/hooks/api/index.ts +1 -0
- package/src/hooks/api/product-types.tsx +32 -0
- package/src/hooks/api/product-variants.tsx +47 -3
- package/src/hooks/api/products.tsx +29 -0
- package/src/hooks/api/tags.tsx +32 -0
- package/src/hooks/api/translations.tsx +306 -0
- package/src/hooks/use-infinite-list.tsx +92 -0
- package/src/i18n/translations/$schema.json +122 -0
- package/src/i18n/translations/en.json +38 -0
- package/src/i18n/translations/es.json +38 -0
- package/src/routes/categories/category-detail/components/category-general-section/category-general-section.tsx +16 -1
- package/src/routes/categories/category-list/components/category-list-table/category-list-table.tsx +16 -1
- package/src/routes/collections/collection-detail/components/collection-general-section/collection-general-section.tsx +16 -1
- package/src/routes/collections/collection-list/components/collection-list-table/collection-row-actions.tsx +16 -1
- package/src/routes/product-tags/product-tag-detail/components/product-tag-general-section/product-tag-general-section.tsx +16 -1
- package/src/routes/product-tags/product-tag-list/components/product-tag-list-table/product-tag-list-table.tsx +16 -1
- package/src/routes/product-types/product-type-detail/components/product-type-general-section/product-type-general-section.tsx +16 -1
- package/src/routes/product-types/product-type-list/components/product-type-list-table/product-table-row-actions.tsx +16 -1
- package/src/routes/product-variants/product-variant-detail/components/variant-general-section/variant-general-section.tsx +16 -1
- package/src/routes/products/product-detail/components/product-general-section/product-general-section.tsx +16 -1
- package/src/routes/products/product-detail/components/product-variant-section/product-variant-section.tsx +32 -1
- package/src/routes/products/product-list/components/product-list-table/product-list-table.tsx +15 -1
- package/src/routes/translations/translation-list/components/active-locales-section/active-locales-section.tsx +68 -0
- package/src/routes/translations/translation-list/components/translation-list-section/translation-list-section.tsx +44 -0
- package/src/routes/translations/translation-list/components/translations-completion-section/translations-completion-section.tsx +224 -0
- package/src/routes/translations/translation-list/index.tsx +1 -0
- package/src/routes/translations/translation-list/translation-list.tsx +138 -0
- package/src/routes/translations/translations-edit/components/translations-edit-form/index.ts +1 -0
- package/src/routes/translations/translations-edit/components/translations-edit-form/translations-edit-form.tsx +792 -0
- package/src/routes/translations/translations-edit/index.ts +1 -0
- 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 {
|
|
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>[] =
|
package/src/routes/products/product-list/components/product-list-table/product-list-table.tsx
CHANGED
|
@@ -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"
|