@medusajs/dashboard 3.0.0-snapshot-20251114155958 → 3.0.0-snapshot-20251126221441
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/{adjust-inventory-ZB3AVET7.mjs → adjust-inventory-WZOCLB5V.mjs} +1 -1
- package/dist/{api-key-management-create-U6VGZK7R.mjs → api-key-management-create-W7NL2IYN.mjs} +3 -3
- package/dist/{api-key-management-detail-B5XNEGKF.mjs → api-key-management-detail-3F77JKQT.mjs} +13 -13
- package/dist/{api-key-management-edit-TJM737A7.mjs → api-key-management-edit-TLVLXAVK.mjs} +3 -3
- package/dist/{api-key-management-list-ZRYMMTF5.mjs → api-key-management-list-FTLC3ELT.mjs} +3 -3
- package/dist/{api-key-management-sales-channels-D2RAHI7W.mjs → api-key-management-sales-channels-NYY3NZOE.mjs} +4 -4
- package/dist/app.css +3 -3
- package/dist/app.js +16021 -17376
- package/dist/app.mjs +11 -11
- package/dist/{campaign-create-IXOWJQ4L.mjs → campaign-create-LHL7FKQK.mjs} +3 -3
- package/dist/{campaign-detail-RCA3TBE4.mjs → campaign-detail-G2FIHVM2.mjs} +10 -10
- package/dist/{categories-metadata-5NBC7HX4.mjs → categories-metadata-YEF2WFML.mjs} +10 -10
- package/dist/{category-create-BTMZYQ5R.mjs → category-create-ELMCLH4J.mjs} +5 -5
- package/dist/{category-detail-RBUJVFPN.mjs → category-detail-ORXA4DBA.mjs} +14 -14
- package/dist/{category-edit-Q3KEELHO.mjs → category-edit-TYKLEYGE.mjs} +2 -2
- package/dist/{category-list-Z6HS6N75.mjs → category-list-IJ3DLPYQ.mjs} +5 -5
- package/dist/{category-organize-45NPSRNG.mjs → category-organize-PDLC54E2.mjs} +2 -2
- package/dist/{category-products-KREOO2KQ.mjs → category-products-GXTUJNT6.mjs} +13 -13
- package/dist/{chunk-SAZHCRHS.mjs → chunk-2PZVZSZW.mjs} +1 -1
- package/dist/{chunk-NFEW5CVI.mjs → chunk-3C6WQ7NH.mjs} +3 -37
- package/dist/{chunk-KF22R23X.mjs → chunk-3UOOSL7Y.mjs} +1 -1
- package/dist/{chunk-BYZSMXJ7.mjs → chunk-4DDI2KIE.mjs} +1 -1
- package/dist/{chunk-5N33TBBX.mjs → chunk-56TDUOXV.mjs} +1 -1
- package/dist/{chunk-67RC6SEX.mjs → chunk-5LGRZSEH.mjs} +1 -1
- package/dist/{chunk-W4TIFG3A.mjs → chunk-6KMZSZIA.mjs} +5 -5
- package/dist/{chunk-P23S5LDK.mjs → chunk-7V2JZU2B.mjs} +2 -2
- package/dist/{chunk-GHBURGZC.mjs → chunk-A6PWH2CK.mjs} +1 -1
- package/dist/{chunk-KJU3T6BK.mjs → chunk-AEMKNDRM.mjs} +2 -2
- package/dist/{chunk-QW4SQVMT.mjs → chunk-AENRV3N7.mjs} +50 -109
- package/dist/{chunk-O5DGX2NZ.mjs → chunk-AF7A24XI.mjs} +1 -1
- package/dist/{chunk-F7LJJHQT.mjs → chunk-C7F7MMXS.mjs} +1 -0
- package/dist/{chunk-CWIMWR6L.mjs → chunk-D6DIMX3W.mjs} +15 -15
- package/dist/{chunk-3RRA56WC.mjs → chunk-DODQ3KJT.mjs} +3 -8
- package/dist/{chunk-FJHAGJ5G.mjs → chunk-ETOJCN3Q.mjs} +1 -1
- package/dist/{chunk-YVQIO3JS.mjs → chunk-GYHQTVXN.mjs} +236 -318
- package/dist/{chunk-FNQ227BC.mjs → chunk-K5QWNI6V.mjs} +1 -1
- package/dist/{chunk-ZOJRDXH3.mjs → chunk-KC64IT2X.mjs} +1 -1
- package/dist/{chunk-K75OQ7QA.mjs → chunk-KHNOLBMA.mjs} +2 -2
- package/dist/{chunk-MOGV3UZD.mjs → chunk-KLNRCI3K.mjs} +1 -1
- package/dist/{chunk-YGEJFHC3.mjs → chunk-M3CKVBZC.mjs} +1 -1
- package/dist/{chunk-VW34SZWE.mjs → chunk-MDVO5GXZ.mjs} +2 -2
- package/dist/{chunk-7H6DB666.mjs → chunk-O4RZ3Y65.mjs} +1 -1
- package/dist/{chunk-5AM254NB.mjs → chunk-OFN7DIZA.mjs} +3 -83
- package/dist/{chunk-42TMWI76.mjs → chunk-OXPE5TAY.mjs} +1 -1
- package/dist/{chunk-NZNJSGGE.mjs → chunk-SIR4PJ4E.mjs} +3 -3
- package/dist/{chunk-QPJUVTKW.mjs → chunk-SWS2BE3M.mjs} +1 -1
- package/dist/{chunk-OMRGW7JS.mjs → chunk-T2ANPJ36.mjs} +3 -3
- package/dist/{chunk-ZE34KAKV.mjs → chunk-U63NCO35.mjs} +2 -2
- package/dist/{chunk-2WLOIS3L.mjs → chunk-WGRVE7KY.mjs} +21 -2
- package/dist/{chunk-BKJMQ6RP.mjs → chunk-WYITLR2E.mjs} +1 -1
- package/dist/{chunk-Y5TTJDGO.mjs → chunk-ZT7CR32D.mjs} +1 -1
- package/dist/{collection-add-products-KM4VO5G5.mjs → collection-add-products-D2KOVZPZ.mjs} +14 -14
- package/dist/{collection-create-RIGJHEX5.mjs → collection-create-I2A2X4VK.mjs} +2 -2
- package/dist/{collection-detail-MLVNULUS.mjs → collection-detail-ZT535E5T.mjs} +14 -14
- package/dist/{collection-edit-WX5G3FHR.mjs → collection-edit-RGH7NCUE.mjs} +2 -2
- package/dist/{collection-list-KWAHQGFE.mjs → collection-list-53JPFHPN.mjs} +23 -24
- package/dist/{collection-metadata-OMFOP3LA.mjs → collection-metadata-SQCA35II.mjs} +11 -11
- package/dist/{customer-detail-SVDGB2QD.mjs → customer-detail-W55EJ6LX.mjs} +14 -14
- package/dist/{customer-group-detail-OCQTI4GG.mjs → customer-group-detail-2WFTU5KU.mjs} +13 -13
- package/dist/{customer-group-list-K5MTMFLG.mjs → customer-group-list-GLF37WEN.mjs} +13 -13
- package/dist/{customers-add-customer-group-2LLBHTX3.mjs → customers-add-customer-group-KXT7RDV3.mjs} +13 -13
- package/dist/{edit-inventory-item-O6JLGZE4.mjs → edit-inventory-item-LMDNUI6M.mjs} +1 -1
- package/dist/{edit-inventory-item-attributes-AUVR3GYY.mjs → edit-inventory-item-attributes-DPJIHBP3.mjs} +1 -1
- package/dist/{edit-reservation-GQ6R6GVA.mjs → edit-reservation-IOOZBJ2T.mjs} +2 -2
- package/dist/{edit-rules-G7YMD5RC.mjs → edit-rules-7TG76PR3.mjs} +12 -12
- package/dist/en.json +3 -49
- package/dist/{inventory-create-GMFEGLE4.mjs → inventory-create-NQUETR3V.mjs} +10 -10
- package/dist/{inventory-detail-3BTAVXLJ.mjs → inventory-detail-ADLVUQJM.mjs} +10 -10
- package/dist/{inventory-list-ADJQDNX5.mjs → inventory-list-RQBI7UJX.mjs} +1 -1
- package/dist/{inventory-metadata-JJBXLQJG.mjs → inventory-metadata-45YATS7H.mjs} +10 -10
- package/dist/{inventory-stock-RHLN6ARK.mjs → inventory-stock-UG3CW3TM.mjs} +10 -10
- package/dist/{location-detail-F5QYFPUH.mjs → location-detail-BBPTVSP5.mjs} +15 -15
- package/dist/{location-fulfillment-providers-7JXNE6YT.mjs → location-fulfillment-providers-6AHWONY4.mjs} +14 -15
- package/dist/{location-sales-channels-JPH5BTUY.mjs → location-sales-channels-UVYT52SH.mjs} +3 -3
- package/dist/{location-service-zone-shipping-option-create-7VTPJAPA.mjs → location-service-zone-shipping-option-create-WEIDYZZT.mjs} +11 -11
- package/dist/{location-service-zone-shipping-option-edit-OYTEZGGC.mjs → location-service-zone-shipping-option-edit-TQNTCYII.mjs} +4 -4
- package/dist/{login-BGH5LSM4.mjs → login-VQ7YFW6V.mjs} +10 -10
- package/dist/{manage-locations-ATCDVTSR.mjs → manage-locations-2VDQ3ILT.mjs} +1 -1
- package/dist/{order-allocate-items-PHIW64XK.mjs → order-allocate-items-SSDLHV7A.mjs} +3 -3
- package/dist/{order-create-claim-NPQ6E5DR.mjs → order-create-claim-RAGNQ2RR.mjs} +18 -18
- package/dist/{order-create-edit-R4ZITC5I.mjs → order-create-edit-PRJWTWWE.mjs} +31 -16
- package/dist/{order-create-exchange-6XPYKVYN.mjs → order-create-exchange-DRSFEEL3.mjs} +60 -34
- package/dist/{order-create-fulfillment-7DVPBUES.mjs → order-create-fulfillment-URKHLFR7.mjs} +14 -14
- package/dist/{order-create-refund-7KEOYZTF.mjs → order-create-refund-VZG3UXLV.mjs} +15 -15
- package/dist/{order-create-return-J23AFCKP.mjs → order-create-return-P3OCXJSI.mjs} +6 -6
- package/dist/{order-create-shipment-KNXCANID.mjs → order-create-shipment-QZBUE342.mjs} +10 -10
- package/dist/{order-detail-7ATBL7GN.mjs → order-detail-32Y6JK42.mjs} +31 -31
- package/dist/{order-edit-billing-address-VS75YMUY.mjs → order-edit-billing-address-MUICLYNN.mjs} +11 -11
- package/dist/{order-edit-email-GEE7SF2E.mjs → order-edit-email-ADNCGCS3.mjs} +11 -11
- package/dist/{order-edit-shipping-address-HSRXSRLU.mjs → order-edit-shipping-address-NZF3KMVV.mjs} +11 -11
- package/dist/{order-list-GJTJHLZF.mjs → order-list-33SMDKZD.mjs} +5 -4
- package/dist/{order-metadata-LUBKP5Y4.mjs → order-metadata-UEKHMTAD.mjs} +10 -10
- package/dist/{order-receive-return-FLI44JN2.mjs → order-receive-return-5SB26KCQ.mjs} +11 -11
- package/dist/{order-request-transfer-NH2XCHMV.mjs → order-request-transfer-QS3LMEBW.mjs} +12 -12
- package/dist/{price-list-configuration-SS2VMD4N.mjs → price-list-configuration-CZPMKLNL.mjs} +4 -4
- package/dist/{price-list-create-DZR7JCDG.mjs → price-list-create-2YZRNBRI.mjs} +17 -17
- package/dist/{price-list-detail-4INABJQQ.mjs → price-list-detail-EGGLDH5B.mjs} +24 -20
- package/dist/{price-list-edit-VRI5T4W3.mjs → price-list-edit-3VNSZH4F.mjs} +2 -2
- package/dist/{price-list-list-S2HWTXKV.mjs → price-list-list-AU4IVCQN.mjs} +34 -18
- package/dist/{price-list-prices-add-DO43IEAD.mjs → price-list-prices-add-YRXYOXUG.mjs} +16 -14
- package/dist/{price-list-prices-edit-TRCLLGU4.mjs → price-list-prices-edit-UHOZKA75.mjs} +5 -3
- package/dist/{product-attributes-D6MNCAJB.mjs → product-attributes-W2PIZ6AU.mjs} +12 -12
- package/dist/{product-create-JQQTUEQL.mjs → product-create-UY3QXGNY.mjs} +554 -377
- package/dist/product-create-option-GAEPSU6J.mjs +145 -0
- package/dist/{product-create-variant-6UQRMACE.mjs → product-create-variant-RQEPRPG5.mjs} +11 -11
- package/dist/{product-detail-JMOULY3O.mjs → product-detail-FOLQUXCM.mjs} +54 -38
- package/dist/{product-edit-CC4OUBEC.mjs → product-edit-WRONAZ5F.mjs} +12 -12
- package/dist/product-edit-option-VIU3ZICO.mjs +150 -0
- package/dist/{product-export-BVREOXJT.mjs → product-export-ITQPBLG7.mjs} +22 -23
- package/dist/{product-image-variants-edit-7BBTFZO7.mjs → product-image-variants-edit-P2ZWO6DN.mjs} +10 -10
- package/dist/{product-import-UEXWOHOZ.mjs → product-import-WEHFNQXM.mjs} +10 -10
- package/dist/{product-list-RHHY3NAS.mjs → product-list-7QL2GZEA.mjs} +17 -17
- package/dist/{product-media-EKXMOSO4.mjs → product-media-WCLPCVR3.mjs} +2 -2
- package/dist/{product-metadata-DU2CNDKQ.mjs → product-metadata-LP3B3LXR.mjs} +10 -10
- package/dist/{product-organization-HU6YVPPV.mjs → product-organization-GKKUOJQV.mjs} +14 -14
- package/dist/{product-prices-UMEIS5AZ.mjs → product-prices-MKMKBH6P.mjs} +1 -1
- package/dist/{product-sales-channels-2SALTLTF.mjs → product-sales-channels-5YIO22UW.mjs} +3 -3
- package/dist/{product-shipping-profile-T4ZKHINJ.mjs → product-shipping-profile-GOESXQYV.mjs} +13 -13
- package/dist/{product-stock-CKBS4YDA.mjs → product-stock-KZ5NJINL.mjs} +10 -10
- package/dist/{product-tag-create-GFGPI7ML.mjs → product-tag-create-KOTNIDPO.mjs} +10 -10
- package/dist/{product-tag-detail-TTEWVF3I.mjs → product-tag-detail-4NEU4CQ4.mjs} +27 -28
- package/dist/{product-tag-edit-3XNTLATZ.mjs → product-tag-edit-UBVJB75M.mjs} +10 -10
- package/dist/{product-tag-list-24IJRVFR.mjs → product-tag-list-2JDK7DBC.mjs} +25 -26
- package/dist/{product-tag-metadata-JANWHZ3K.mjs → product-tag-metadata-H4QYJB5I.mjs} +10 -10
- package/dist/{product-type-detail-MAUHCM3C.mjs → product-type-detail-QSKBQZOO.mjs} +13 -13
- package/dist/{product-type-metadata-FAKUWQQF.mjs → product-type-metadata-OSGO33SD.mjs} +10 -10
- package/dist/{product-variant-detail-WHPECDUY.mjs → product-variant-detail-ATHRI3BX.mjs} +10 -10
- package/dist/{product-variant-edit-GR4RNE5G.mjs → product-variant-edit-457GNHH5.mjs} +11 -11
- package/dist/{product-variant-manage-inventory-items-IGDCLZQE.mjs → product-variant-manage-inventory-items-B7TUBSD5.mjs} +2 -2
- package/dist/{product-variant-media-EKI4BTEV.mjs → product-variant-media-6WWLRINP.mjs} +1 -1
- package/dist/{product-variant-metadata-DA2HKXXB.mjs → product-variant-metadata-GOUTYBDT.mjs} +10 -10
- package/dist/{promotion-add-campaign-DOALJUKJ.mjs → promotion-add-campaign-MKDYE7MW.mjs} +3 -3
- package/dist/{promotion-create-GGZULF2B.mjs → promotion-create-WCECPK2G.mjs} +18 -18
- package/dist/{promotion-detail-XK7U73XH.mjs → promotion-detail-JBM2LBZ4.mjs} +10 -10
- package/dist/{refund-reason-create-H7MHJ5C5.mjs → refund-reason-create-IAOKE37M.mjs} +10 -10
- package/dist/{refund-reason-edit-QY36CQVS.mjs → refund-reason-edit-D2VDINGV.mjs} +10 -10
- package/dist/{refund-reason-list-KSQW33QC.mjs → refund-reason-list-Q4TU7OVA.mjs} +13 -13
- package/dist/{region-create-UVJICJRX.mjs → region-create-QLPSK6TX.mjs} +1 -1
- package/dist/{region-edit-3NVXQECN.mjs → region-edit-JCJHA6TY.mjs} +1 -1
- package/dist/{region-metadata-4KQG6UL6.mjs → region-metadata-YLNPW7CL.mjs} +10 -10
- package/dist/{reservation-create-Z7TWUE2L.mjs → reservation-create-BW4CDTWR.mjs} +3 -3
- package/dist/{reservation-detail-W3FULMXT.mjs → reservation-detail-SMO3C2R5.mjs} +10 -10
- package/dist/{reservation-list-MN22JYAW.mjs → reservation-list-RGL67CIU.mjs} +2 -2
- package/dist/{reservation-metadata-AKAN5XNE.mjs → reservation-metadata-KU5AJF7S.mjs} +10 -10
- package/dist/{sales-channel-add-products-POHTQHMV.mjs → sales-channel-add-products-WGRIVVJA.mjs} +13 -13
- package/dist/{sales-channel-create-UFFXX5HK.mjs → sales-channel-create-TOBEDYFD.mjs} +2 -2
- package/dist/{sales-channel-detail-AACIFU2E.mjs → sales-channel-detail-VSTGXEZD.mjs} +13 -13
- package/dist/{sales-channel-edit-SP2HF4E3.mjs → sales-channel-edit-XUTE5GB5.mjs} +2 -2
- package/dist/{sales-channel-list-BY3KTVV6.mjs → sales-channel-list-2LXIRNZP.mjs} +11 -11
- package/dist/{sales-channel-metadata-KGOLI4BZ.mjs → sales-channel-metadata-RZMQYG4F.mjs} +10 -10
- package/dist/{shipping-option-type-create-PSQZW3RN.mjs → shipping-option-type-create-EQPBH6EA.mjs} +10 -10
- package/dist/{shipping-option-type-detail-WAW6TKJU.mjs → shipping-option-type-detail-BCCCVIIJ.mjs} +11 -11
- package/dist/{shipping-option-type-edit-2I44YHND.mjs → shipping-option-type-edit-CGTJ3HAR.mjs} +10 -10
- package/dist/{shipping-option-type-list-F4FRLW3P.mjs → shipping-option-type-list-3TLR4QZF.mjs} +11 -11
- package/dist/{shipping-profile-metadata-AZXPMPHG.mjs → shipping-profile-metadata-JSRQPOAD.mjs} +10 -10
- package/dist/{store-detail-AKRR64I6.mjs → store-detail-H53F5ESM.mjs} +10 -10
- package/dist/{store-edit-Q25HCMCQ.mjs → store-edit-3XS6IC2Z.mjs} +1 -1
- package/dist/{store-metadata-VLEDLAIJ.mjs → store-metadata-GHSJRHAV.mjs} +10 -10
- package/dist/{tax-region-create-JTM53LCS.mjs → tax-region-create-HYT3EOQO.mjs} +11 -11
- package/dist/{tax-region-detail-XBFYCVSH.mjs → tax-region-detail-TQS5425G.mjs} +28 -29
- package/dist/{tax-region-edit-2RRF7C7P.mjs → tax-region-edit-ZB36A456.mjs} +11 -11
- package/dist/{tax-region-province-detail-LGCYSFKE.mjs → tax-region-province-detail-CABVSQRU.mjs} +28 -29
- package/dist/{tax-region-tax-override-create-2W25EZNZ.mjs → tax-region-tax-override-create-ROK47GNE.mjs} +27 -28
- package/dist/{tax-region-tax-override-edit-ZSYNTYUG.mjs → tax-region-tax-override-edit-WRODO4LC.mjs} +26 -27
- package/dist/{user-detail-K5UMPO2L.mjs → user-detail-N6PT3KRP.mjs} +1 -1
- package/dist/{user-metadata-KOGHOQTW.mjs → user-metadata-DKZHLCPN.mjs} +10 -10
- package/dist/{workflow-execution-detail-4QAQ44YB.mjs → workflow-execution-detail-BQEMJSH6.mjs} +10 -10
- package/package.json +11 -11
- package/src/components/inputs/combobox/combobox.tsx +92 -173
- package/src/components/layout/main-layout/main-layout.tsx +4 -7
- package/src/dashboard-app/routes/get-route.map.tsx +12 -64
- package/src/hooks/api/index.ts +0 -1
- package/src/hooks/api/price-lists.tsx +32 -1
- package/src/hooks/api/products.tsx +66 -26
- package/src/hooks/table/filters/index.ts +0 -1
- package/src/i18n/translations/$schema.json +4 -172
- package/src/i18n/translations/en.json +3 -49
- package/src/routes/orders/order-create-edit/components/order-edit-create-form/order-edit-item.tsx +28 -3
- package/src/routes/orders/order-create-exchange/components/exchange-create-form/exchange-inbound-item.tsx +29 -4
- package/src/routes/orders/order-create-exchange/components/exchange-create-form/exchange-outbound-item.tsx +23 -4
- package/src/routes/orders/order-detail/constants.ts +1 -0
- package/src/routes/orders/order-list/const.ts +1 -0
- package/src/routes/price-lists/price-list-detail/components/price-list-general-section/price-list-general-section.tsx +10 -4
- package/src/routes/price-lists/price-list-list/components/price-list-list-table/price-count-cell.tsx +19 -0
- package/src/routes/price-lists/price-list-list/components/price-list-list-table/use-pricing-table-columns.tsx +5 -6
- package/src/routes/price-lists/price-list-prices-add/price-list-prices-add.tsx +4 -1
- package/src/routes/price-lists/price-list-prices-edit/price-list-prices-edit.tsx +3 -1
- package/src/routes/products/product-create/components/product-create-details-form/components/product-create-details-general-section/product-create-general-section.tsx +4 -16
- package/src/routes/products/product-create/components/product-create-details-form/components/product-create-details-variant-section/product-create-details-variant-section.tsx +198 -220
- package/src/routes/products/product-create/components/product-create-form/product-create-form.tsx +7 -4
- package/src/routes/products/product-create/constants.ts +0 -2
- package/src/routes/products/product-create/utils.ts +1 -6
- package/src/routes/products/product-create-option/components/create-product-option-form/create-product-option-form.tsx +122 -0
- package/src/routes/products/product-create-option/components/create-product-option-form/index.ts +1 -0
- package/src/routes/products/product-create-option/index.ts +1 -0
- package/src/routes/products/product-create-option/product-create-option.tsx +26 -0
- package/src/routes/products/product-detail/components/product-option-section/product-option-section.tsx +49 -31
- package/src/routes/products/product-edit-option/components/edit-product-option-form/edit-product-option-form.tsx +123 -0
- package/src/routes/products/product-edit-option/components/edit-product-option-form/index.ts +1 -0
- package/src/routes/products/product-edit-option/index.ts +1 -0
- package/src/routes/products/product-edit-option/product-edit-option.tsx +32 -0
- package/dist/chunk-ZHH3W7CN.mjs +0 -171
- package/dist/product-option-create-ML66ZKF3.mjs +0 -336
- package/dist/product-option-detail-DT7HJF5Q.mjs +0 -322
- package/dist/product-option-edit-GUKWRQQH.mjs +0 -324
- package/dist/product-option-list-KF3JSQ6Y.mjs +0 -262
- package/dist/product-option-metadata-BWWRRSAW.mjs +0 -71
- package/dist/product-options-manage-QYWBIHJA.mjs +0 -304
- package/src/hooks/api/product-options.tsx +0 -151
- package/src/hooks/table/columns/use-product-option-table-columns.tsx +0 -44
- package/src/hooks/table/filters/use-product-option-table-filters.tsx +0 -33
- package/src/hooks/table/query/use-product-option-table-query.tsx +0 -34
- package/src/routes/product-options/common/hooks/use-delete-product-option-action.tsx +0 -41
- package/src/routes/product-options/product-option-create/components/create-product-option-form/create-product-option-details.tsx +0 -71
- package/src/routes/product-options/product-option-create/components/create-product-option-form/create-product-option-form.tsx +0 -192
- package/src/routes/product-options/product-option-create/components/create-product-option-form/create-product-option-organize.tsx +0 -77
- package/src/routes/product-options/product-option-create/components/create-product-option-form/index.ts +0 -1
- package/src/routes/product-options/product-option-create/components/create-product-option-form/schema.ts +0 -15
- package/src/routes/product-options/product-option-create/index.ts +0 -1
- package/src/routes/product-options/product-option-create/product-option-create.tsx +0 -10
- package/src/routes/product-options/product-option-detail/breadcrumb.tsx +0 -14
- package/src/routes/product-options/product-option-detail/components/product-option-general-section/index.ts +0 -1
- package/src/routes/product-options/product-option-detail/components/product-option-general-section/product-option-general-section.tsx +0 -81
- package/src/routes/product-options/product-option-detail/components/product-option-product-section/index.ts +0 -1
- package/src/routes/product-options/product-option-detail/components/product-option-product-section/product-option-product-section.tsx +0 -74
- package/src/routes/product-options/product-option-detail/index.ts +0 -3
- package/src/routes/product-options/product-option-detail/loader.ts +0 -17
- package/src/routes/product-options/product-option-detail/product-option-detail.tsx +0 -50
- package/src/routes/product-options/product-option-edit/components/edit-product-option-form/edit-product-option-details.tsx +0 -94
- package/src/routes/product-options/product-option-edit/components/edit-product-option-form/edit-product-option-form.tsx +0 -116
- package/src/routes/product-options/product-option-edit/components/edit-product-option-form/edit-product-option-organize.tsx +0 -77
- package/src/routes/product-options/product-option-edit/components/edit-product-option-form/index.ts +0 -1
- package/src/routes/product-options/product-option-edit/components/edit-product-option-form/schema.ts +0 -13
- package/src/routes/product-options/product-option-edit/index.ts +0 -1
- package/src/routes/product-options/product-option-edit/product-option-edit.tsx +0 -34
- package/src/routes/product-options/product-option-list/components/product-option-list-table/index.ts +0 -1
- package/src/routes/product-options/product-option-list/components/product-option-list-table/product-option-list-table.tsx +0 -131
- package/src/routes/product-options/product-option-list/index.ts +0 -1
- package/src/routes/product-options/product-option-list/product-option-list.tsx +0 -19
- package/src/routes/product-options/product-option-metadata/index.ts +0 -1
- package/src/routes/product-options/product-option-metadata/product-option-metadata.tsx +0 -27
- package/src/routes/products/product-options-manage/components/product-options-manage-form/index.ts +0 -1
- package/src/routes/products/product-options-manage/components/product-options-manage-form/product-options-manage-form.tsx +0 -284
- package/src/routes/products/product-options-manage/index.ts +0 -1
- package/src/routes/products/product-options-manage/product-options-manage.tsx +0 -35
- package/dist/{chunk-2QH2TBJ2.mjs → chunk-ACJ3PPQJ.mjs} +3 -3
- package/dist/{customer-group-add-customers-2Y2GVCDV.mjs → customer-group-add-customers-QU4Q56SS.mjs} +3 -3
- package/dist/{customer-list-TG4D4QOT.mjs → customer-list-ZXCGIXJC.mjs} +3 -3
- package/dist/{location-list-ZJMZZ6T3.mjs → location-list-OYBI7EGV.mjs} +1 -1
- package/dist/{product-type-list-7WQ5D2KV.mjs → product-type-list-QX7QC6RI.mjs} +3 -3
- package/dist/{region-list-JAQXIBYD.mjs → region-list-XQRIBDMF.mjs} +3 -3
- package/dist/{return-reason-list-ATE2XU4H.mjs → return-reason-list-VYLLXDG4.mjs} +3 -3
- package/dist/{user-list-KPI3BTOA.mjs → user-list-6KATHOTJ.mjs} +3 -3
|
@@ -1,192 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,77 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { CreateProductOptionForm } from "./create-product-option-form"
|
|
@@ -1,15 +0,0 @@
|
|
|
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)
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { ProductOptionCreate as Component } from "./product-option-create"
|
|
@@ -1,10 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,14 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export * from "./product-option-general-section.tsx"
|
|
@@ -1,81 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export { ProductOptionProductSection } from "./product-option-product-section"
|
|
@@ -1,74 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,17 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,50 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,94 +0,0 @@
|
|
|
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
|
-
}
|