@mercurjs/vendor 2.1.2 → 2.2.0-canary.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (230) hide show
  1. package/dist/{[id]-PDGHF5J2.js → [id]-2DQX3YWJ.js} +35 -31
  2. package/dist/{[id]-TO6KT3ZE.js → [id]-4OBGG7OH.js} +23 -21
  3. package/dist/{[id]-X4DDKOMQ.js → [id]-4PKMKNJH.js} +26 -22
  4. package/dist/[id]-4STHLE4N.js +1442 -0
  5. package/dist/{[id]-4VCL3MMM.js → [id]-5UFO4RKF.js} +26 -22
  6. package/dist/{[id]-H3C3ZSC6.js → [id]-6MXCVV5J.js} +25 -21
  7. package/dist/{[id]-6PXEWRG7.js → [id]-7BAKUHUO.js} +13 -13
  8. package/dist/{[id]-7RUAH3TI.js → [id]-K2CT7BXQ.js} +4 -4
  9. package/dist/{[id]-3G5G7ZFV.js → [id]-KJIQTFGE.js} +22 -20
  10. package/dist/{[id]-INOFZHL7.js → [id]-LTNOHLGE.js} +16 -16
  11. package/dist/{[id]-B3LHVQM5.js → [id]-PGIT5WJC.js} +25 -21
  12. package/dist/{[id]-T2ROPEGY.js → [id]-Y2ISCLUD.js} +7 -7
  13. package/dist/{[id]-Y7GAMNC5.js → [id]-ZCMSBEVM.js} +4 -4
  14. package/dist/{[id]-UTKO3VG4.js → [id]-ZWWMJAKI.js} +9 -9
  15. package/dist/{[location_id]-D55RQOXT.js → [location_id]-NUBXDDJC.js} +9 -9
  16. package/dist/{[province_id]-OFH2ZOFQ.js → [province_id]-H2QAPKVH.js} +20 -18
  17. package/dist/{add-C6OX5C54.js → add-GZJ7OMV3.js} +34 -30
  18. package/dist/add-KQAABWCR.js +392 -0
  19. package/dist/{add-customer-groups-PJRJUWS2.js → add-customer-groups-RAHCP67U.js} +16 -14
  20. package/dist/{add-products-INOLNPO6.js → add-products-TSVQHC67.js} +23 -19
  21. package/dist/{add-promotions-AHDOP52Q.js → add-promotions-CSCAJZHV.js} +7 -7
  22. package/dist/{add-to-campaign-HL6NGRR4.js → add-to-campaign-DLP7PSQB.js} +4 -4
  23. package/dist/{address-KRENKSLP.js → address-7F5SN7PV.js} +17 -15
  24. package/dist/{adjust-inventory-H4EUP7J3.js → adjust-inventory-SZF4W7LR.js} +2 -2
  25. package/dist/{allocate-items-SUCUZU4D.js → allocate-items-SDFS5GYN.js} +6 -6
  26. package/dist/{areas-UUMZDXLX.js → areas-7Y6BVS5A.js} +8 -8
  27. package/dist/{attributes-CALEHJJG.js → attributes-MBZ76HVZ.js} +3 -3
  28. package/dist/{breadcrumb-BS7Y5OKF.js → breadcrumb-65SAGUUL.js} +2 -2
  29. package/dist/{breadcrumb-6W2VP3OZ.js → breadcrumb-7PURSRTT.js} +13 -11
  30. package/dist/{breadcrumb-M5Z5WA6I.js → breadcrumb-EDPMEN2P.js} +2 -2
  31. package/dist/breadcrumb-FLDHJRVY.js +26 -0
  32. package/dist/{breadcrumb-VNNZ3TTW.js → breadcrumb-HND5FFWC.js} +2 -2
  33. package/dist/{breadcrumb-OIGGCB3L.js → breadcrumb-QV2IAX7N.js} +8 -2
  34. package/dist/{breadcrumb-KQSFIXQ4.js → breadcrumb-VWELWDB2.js} +1 -1
  35. package/dist/{breadcrumb-IG7VZGW2.js → breadcrumb-WRG4SITG.js} +13 -11
  36. package/dist/{breadcrumb-TW5JEOYS.js → breadcrumb-ZCG2RHIU.js} +12 -10
  37. package/dist/{campaigns-HS6MIO7X.js → campaigns-L6ULR6KR.js} +5 -5
  38. package/dist/{categories-PKWR3FM3.js → categories-FUZQKBXV.js} +6 -6
  39. package/dist/{chunk-PDQSPKG5.js → chunk-2DXNJURE.js} +1 -1
  40. package/dist/{chunk-ZZO3INVE.js → chunk-2MDGYHWN.js} +128 -25
  41. package/dist/{chunk-5UD4P6YL.js → chunk-2USXZSTK.js} +4 -4
  42. package/dist/{chunk-6SBMVLJ2.js → chunk-36L54SQQ.js} +1 -1
  43. package/dist/chunk-37G4Y5I7.js +101 -0
  44. package/dist/{chunk-5M3SL4UZ.js → chunk-3CVJA5UE.js} +9 -104
  45. package/dist/chunk-432S4FGR.js +0 -0
  46. package/dist/{chunk-KQGVSLUI.js → chunk-44RQ5PTN.js} +1803 -914
  47. package/dist/{chunk-Y2QI7KWS.js → chunk-4LVP635F.js} +408 -664
  48. package/dist/{chunk-UL4O5M4S.js → chunk-4S6XGIC6.js} +1 -18
  49. package/dist/chunk-5ZVWOCAC.js +426 -0
  50. package/dist/{chunk-WITQNQXN.js → chunk-6BS2AVGJ.js} +3 -3
  51. package/dist/{chunk-ZYOXKUKZ.js → chunk-7LBY5JLV.js} +1 -1
  52. package/dist/chunk-7SLWXX6L.js +811 -0
  53. package/dist/{chunk-LQYMBSRQ.js → chunk-AIZM66CG.js} +1 -1
  54. package/dist/{chunk-IZ5RG5XI.js → chunk-AJLGY3LQ.js} +1 -21
  55. package/dist/{chunk-WFE6CT6M.js → chunk-AVOIZO63.js} +21 -77
  56. package/dist/chunk-C2FG3SX2.js +68 -0
  57. package/dist/chunk-CFRWIQIZ.js +43 -0
  58. package/dist/{chunk-WNVEMFIK.js → chunk-CNMY5HVP.js} +2 -2
  59. package/dist/{chunk-BLVJAKBA.js → chunk-DDH7ULIQ.js} +1 -1
  60. package/dist/chunk-DIW4GRTI.js +503 -0
  61. package/dist/{chunk-JQP7MOFH.js → chunk-DVEKYLPV.js} +1 -1
  62. package/dist/{chunk-QX45GVAL.js → chunk-EIUYXS7E.js} +8 -8
  63. package/dist/{chunk-N7OVXN72.js → chunk-EROX26D4.js} +1 -1
  64. package/dist/{chunk-2RHAI7WK.js → chunk-EZ3JOAUS.js} +1 -1
  65. package/dist/{chunk-HFRHHT36.js → chunk-FDR22JMM.js} +63 -8
  66. package/dist/{chunk-PEKANQ3T.js → chunk-FJUUGFXL.js} +2 -2
  67. package/dist/{chunk-3CK6OINO.js → chunk-GDWBOQI5.js} +3 -5
  68. package/dist/{chunk-47SXTGLN.js → chunk-GXIAIITP.js} +63 -200
  69. package/dist/{chunk-4MFMCZEJ.js → chunk-H6LZ77GX.js} +2 -2
  70. package/dist/chunk-IWLDKGYQ.js +95 -0
  71. package/dist/chunk-K4X324QP.js +18 -0
  72. package/dist/{chunk-VQ5EKDA3.js → chunk-KD7RYE6R.js} +1 -1
  73. package/dist/chunk-LEWA4BPH.js +18 -0
  74. package/dist/{chunk-7Q5SDEK7.js → chunk-LNM2D2I4.js} +4 -4
  75. package/dist/{chunk-LPOAVK6Y.js → chunk-LQD232FW.js} +47 -12
  76. package/dist/{chunk-OXXL4WQU.js → chunk-M7KSRYRI.js} +5 -5
  77. package/dist/chunk-MBFHMJHN.js +2063 -0
  78. package/dist/{chunk-I2IKYOZX.js → chunk-N4MVIBFM.js} +19 -19
  79. package/dist/{chunk-PCMNEUMV.js → chunk-NHFEY3EI.js} +1 -1
  80. package/dist/{chunk-RTAWYMQP.js → chunk-NJMNYS7G.js} +1 -1
  81. package/dist/{chunk-HGQTL7NX.js → chunk-NSZQERLE.js} +2 -2
  82. package/dist/{chunk-RL7SFZOF.js → chunk-NXNJQZCP.js} +1 -1
  83. package/dist/{chunk-CNLP35S7.js → chunk-OD3U3TX4.js} +16 -31
  84. package/dist/{chunk-D2MA5TAP.js → chunk-PBD36EZJ.js} +2 -2
  85. package/dist/{chunk-4ZGFODSC.js → chunk-PZ44R4AS.js} +1 -1
  86. package/dist/{chunk-ZEVYT6IX.js → chunk-QNNJN4H6.js} +116 -286
  87. package/dist/{chunk-WBI7FEGI.js → chunk-QS6RWIBL.js} +1 -1
  88. package/dist/chunk-QT7YFHCA.js +198 -0
  89. package/dist/{chunk-GYV6SKY7.js → chunk-QXLRABYH.js} +4 -6
  90. package/dist/chunk-RXZFEFNV.js +73 -0
  91. package/dist/{chunk-RUE5BPC2.js → chunk-RZLN2Q6G.js} +1 -1
  92. package/dist/{chunk-NYDJTWRL.js → chunk-SGR4DMCW.js} +4 -4
  93. package/dist/chunk-T6LHVNWO.js +27 -0
  94. package/dist/{chunk-DKQ4XMSN.js → chunk-TNVYTMBL.js} +6 -6
  95. package/dist/{chunk-32RYSB2V.js → chunk-TODJFRLH.js} +2 -2
  96. package/dist/{chunk-P3ZTO6T2.js → chunk-UAF2S447.js} +1 -1
  97. package/dist/{chunk-J6BRLL3F.js → chunk-UCQKXXLD.js} +2 -2
  98. package/dist/chunk-UORPTGV2.js +114 -0
  99. package/dist/{chunk-CYTNBXWF.js → chunk-UX7J5NZG.js} +9 -9
  100. package/dist/{chunk-X4FLOQ45.js → chunk-WBHFU3MG.js} +2 -2
  101. package/dist/chunk-WLT7K7K7.js +63 -0
  102. package/dist/{chunk-4URLUCTD.js → chunk-WUPJADSO.js} +2 -2
  103. package/dist/{chunk-ITI54CII.js → chunk-X4INVIWL.js} +5 -5
  104. package/dist/{chunk-PTW7JNAP.js → chunk-XFQJU6FA.js} +4 -4
  105. package/dist/{collections-DJZI2RM2.js → collections-3OPR3DSD.js} +22 -19
  106. package/dist/{configuration-RHPIO2QT.js → configuration-C4IGBNXH.js} +1 -1
  107. package/dist/{configuration-GN3TO77H.js → configuration-UOSNP45I.js} +3 -3
  108. package/dist/{create-3EK5CNNX.js → create-2MQFQHTE.js} +33 -29
  109. package/dist/{create-YO55Z3YD.js → create-2PCLG7TV.js} +32 -38
  110. package/dist/{create-G4T2PAJH.js → create-35MYQPVM.js} +23 -21
  111. package/dist/{create-HKJVSFB7.js → create-BJ4OO6LS.js} +23 -21
  112. package/dist/create-DDPIXCXT.js +210 -0
  113. package/dist/{create-7S7CZWEN.js → create-GB3ZA4LH.js} +4 -4
  114. package/dist/create-JDGM5KXE.js +193 -0
  115. package/dist/{create-IDVCZHIX.js → create-ORXYT74H.js} +14 -12
  116. package/dist/{create-GHM7OTCR.js → create-R7K3ECN6.js} +1 -1
  117. package/dist/{create-D6EW3EWC.js → create-SFU3W3ZH.js} +1 -1
  118. package/dist/{create-3ZVXEPX5.js → create-SQ3FYMGI.js} +25 -21
  119. package/dist/{create-33TRLASX.js → create-UPYB65PD.js} +1 -1
  120. package/dist/{create-OCFPLNNY.js → create-UQNYMVBM.js} +6 -6
  121. package/dist/{create-OGLPDVOI.js → create-XAD5NMSJ.js} +37 -35
  122. package/dist/{create-KGYL7FBM.js → create-XVHOCZHJ.js} +1 -1
  123. package/dist/{create-4AE3VTWN.js → create-YBF4YGWG.js} +2 -2
  124. package/dist/{customers-6ZLE65UX.js → customers-ETXVNM3G.js} +5 -5
  125. package/dist/{edit-QBISX7D3.js → edit-2Q7TRUTL.js} +14 -12
  126. package/dist/{edit-B5B3XKDM.js → edit-522DG3BY.js} +1 -1
  127. package/dist/{edit-ATXE6CM5.js → edit-C4OCKQVU.js} +1 -1
  128. package/dist/{edit-IR6V2IDN.js → edit-FKXIQ6ZI.js} +19 -17
  129. package/dist/{edit-4HZHLYI3.js → edit-GQNIINRR.js} +1 -1
  130. package/dist/{edit-LRRJTHV2.js → edit-KAKVPHZZ.js} +1 -1
  131. package/dist/{edit-ZSOI56BQ.js → edit-L5ZZLMAY.js} +22 -22
  132. package/dist/{edit-FNDDSSMT.js → edit-NYD45J2Q.js} +37 -8
  133. package/dist/{edit-GIJXLMC3.js → edit-O4JLGKQR.js} +2 -2
  134. package/dist/{edit-5CJZRHAA.js → edit-ORXS3A2Y.js} +1 -1
  135. package/dist/{edit-FC64DWB2.js → edit-Q3UQIOLS.js} +1 -1
  136. package/dist/{edit-7HTH2UJF.js → edit-REDDBLTA.js} +3 -3
  137. package/dist/{edit-2KRJIPRK.js → edit-SGUY2CCK.js} +19 -17
  138. package/dist/{edit-B75KK5ZX.js → edit-SWRWWFW6.js} +35 -31
  139. package/dist/{edit-7GVP6SRA.js → edit-ZAHCMF5U.js} +1 -1
  140. package/dist/{edit-RNT555GP.js → edit-ZCXUG42Q.js} +13 -11
  141. package/dist/{edit-MYSWY6W4.js → edit-ZMERG3L7.js} +1 -1
  142. package/dist/{edit-budget-J27CSEZH.js → edit-budget-L3CCEWNF.js} +1 -1
  143. package/dist/{edit-inventory-item-US77M2FF.js → edit-inventory-item-6B7ITDGD.js} +2 -2
  144. package/dist/{edit-inventory-item-attributes-UGAE2NAZ.js → edit-inventory-item-attributes-Y7MQZLXI.js} +3 -3
  145. package/dist/{fulfillment-DCS67LTK.js → fulfillment-75Z4H23W.js} +16 -14
  146. package/dist/{fulfillment-providers-GM5PO6N3.js → fulfillment-providers-KCQWL62T.js} +20 -17
  147. package/dist/index.css +27 -62
  148. package/dist/index.d.ts +3 -10
  149. package/dist/index.js +522 -458
  150. package/dist/{inventory-OPZ2FSEE.js → inventory-KAUVPMPZ.js} +6 -6
  151. package/dist/{invite-764K3TJS.js → invite-6CPYVHDX.js} +24 -21
  152. package/dist/{invite-KEJLNXEZ.js → invite-CI2P4GF6.js} +15 -12
  153. package/dist/loader-FBB5OQRT.js +31 -0
  154. package/dist/{locations-ZVPTQCQY.js → locations-INS6FTMJ.js} +4 -4
  155. package/dist/{login-OUHRNNXA.js → login-KY342RMK.js} +12 -10
  156. package/dist/{manage-locations-YUKEFCBJ.js → manage-locations-WNHEBS3A.js} +2 -2
  157. package/dist/{media-4KYFHB5V.js → media-KOYAOXG6.js} +41 -9
  158. package/dist/{metadata-NYYL26MQ.js → metadata-2CMH4I6U.js} +16 -14
  159. package/dist/{metadata-AWUKZ25V.js → metadata-5BPOBBU2.js} +3 -3
  160. package/dist/{metadata-OCE6A3JE.js → metadata-GWI6R4ES.js} +15 -13
  161. package/dist/{metadata-G7KZXVNE.js → metadata-NUXUC2JA.js} +15 -13
  162. package/dist/{metadata-XP3ZYW2M.js → metadata-TLDUF5KV.js} +17 -15
  163. package/dist/{metadata-PYY4IB7K.js → metadata-WR4RFXO5.js} +16 -14
  164. package/dist/offer-create-page-YKMHHTU5.js +743 -0
  165. package/dist/offer-detail-page-6MAHNNIO.js +488 -0
  166. package/dist/offer-edit-page-DYQFU6JU.js +151 -0
  167. package/dist/offer-inventory-batch-page-WKCWNDNK.js +290 -0
  168. package/dist/offer-pricing-edit-page-4TYGGSOE.js +195 -0
  169. package/dist/offers-UGQJNGTD.js +32 -0
  170. package/dist/{onboarding-WXZHW62K.js → onboarding-43LQQQGQ.js} +22 -20
  171. package/dist/{orders-LWJ472VM.js → orders-R2LOJ6N5.js} +24 -21
  172. package/dist/organization-XGFU4YDG.js +375 -0
  173. package/dist/{organize-RFOMQCBG.js → organize-HNJUHEEG.js} +4 -4
  174. package/dist/{organize-OVKJ3HZO.js → organize-K6QMAMEN.js} +4 -4
  175. package/dist/pages/index.d.ts +415 -758
  176. package/dist/pages/index.js +81 -77
  177. package/dist/{payment-details-UVXYCTUK.js → payment-details-64US5XWD.js} +17 -15
  178. package/dist/{payouts-TR7K5I37.js → payouts-UXJDTXDL.js} +6 -6
  179. package/dist/{price-lists-S2WNELFZ.js → price-lists-KBPUVSZI.js} +8 -8
  180. package/dist/{pricing-UF27DAXA.js → pricing-DF6C5XK4.js} +35 -32
  181. package/dist/{product-tags-2CKH2M6D.js → product-tags-CL7HSEDI.js} +32 -28
  182. package/dist/{product-types-FX43JEO2.js → product-types-UUHBV4IZ.js} +5 -5
  183. package/dist/product-variant-detail-RVWEYVPC.js +220 -0
  184. package/dist/{product-variant-edit-P3DSIFE3.js → product-variant-edit-MNCS7ZYW.js} +126 -66
  185. package/dist/{products-H5EMRJYS.js → products-4KV5Y2JY.js} +23 -19
  186. package/dist/{products-2LHGS7X3.js → products-SXYTQFJ3.js} +40 -43
  187. package/dist/{professional-details-HYKTH44B.js → professional-details-5T2VS6MM.js} +16 -14
  188. package/dist/{profile-PB27WIRW.js → profile-6XGHAT7H.js} +20 -18
  189. package/dist/{promotions-5EYPGHJP.js → promotions-O7U4BTK6.js} +8 -8
  190. package/dist/{register-4O4F6YZK.js → register-GDKN3SKM.js} +16 -14
  191. package/dist/{reset-password-GTWLBOFK.js → reset-password-EICPAY2N.js} +1 -1
  192. package/dist/{return-reasons-LOKYRGMI.js → return-reasons-M6IR77XW.js} +16 -14
  193. package/dist/{sales-channels-7R2IY3KG.js → sales-channels-B6FULRWI.js} +8 -7
  194. package/dist/{sales-channels-Y4LRP7JC.js → sales-channels-JW3QUYR7.js} +8 -7
  195. package/dist/{settings-2XDLFYMS.js → settings-SAAHTUZZ.js} +39 -35
  196. package/dist/{shipment-4GW2JFWB.js → shipment-Q33QBMXX.js} +13 -11
  197. package/dist/{shipping-profile-R3NABPQF.js → shipping-profile-Y4SNEPZX.js} +2 -2
  198. package/dist/{shipping-profiles-QVKNFLCW.js → shipping-profiles-2NWKCEJK.js} +18 -16
  199. package/dist/{stock-5RXNUPUT.js → stock-7CSVEJJU.js} +19 -17
  200. package/dist/{store-DE2RGX7T.js → store-GHFWU7EV.js} +28 -25
  201. package/dist/{store-closure-DNMCHUXD.js → store-closure-P5PD2RSV.js} +16 -14
  202. package/dist/{store-select-GZEJHRZ7.js → store-select-KDT6USQA.js} +17 -15
  203. package/dist/{tax-regions-UD6P5FVC.js → tax-regions-YXZW7UVX.js} +5 -5
  204. package/dist/{team-JXKAVRPU.js → team-EDJ62747.js} +25 -23
  205. package/dist/types-CtCEtTE6.d.ts +16 -0
  206. package/package.json +3 -3
  207. package/dist/[id]-BYP37PU4.js +0 -1314
  208. package/dist/add-KRAGFFBJ.js +0 -158
  209. package/dist/bulk-edit-3SMBLIOA.js +0 -244
  210. package/dist/chunk-4KX6CBJ4.js +0 -178
  211. package/dist/chunk-DLNNTQRY.js +0 -217
  212. package/dist/chunk-FX4V5JCF.js +0 -37
  213. package/dist/chunk-GC33DBKG.js +0 -143
  214. package/dist/chunk-NK4NR6MN.js +0 -173
  215. package/dist/chunk-PFU6FSXY.js +0 -430
  216. package/dist/chunk-QJEOPT2P.js +0 -330
  217. package/dist/chunk-QSGR43JM.js +0 -30
  218. package/dist/chunk-STR3NGWE.js +0 -3736
  219. package/dist/create-3DOO3RNH.js +0 -716
  220. package/dist/create-I7HV3RM6.js +0 -150
  221. package/dist/edit-K2AD335I.js +0 -237
  222. package/dist/edit-VO5XLIEL.js +0 -362
  223. package/dist/edit-stocks-and-prices-MHHQFWFA.js +0 -408
  224. package/dist/organization-LPYQRTQC.js +0 -303
  225. package/dist/prices-3OXV5RGY.js +0 -270
  226. package/dist/product-variant-detail-WV4KXVXR.js +0 -590
  227. package/dist/stock-GPC3BCL6.js +0 -500
  228. package/dist/{chunk-SDSEW72R.js → chunk-E2HQPY32.js} +3 -3
  229. package/dist/{chunk-6WY5X4PE.js → chunk-L7QKFC5N.js} +7 -7
  230. /package/dist/{chunk-CAS74NLJ.js → chunk-YV6MK4PZ.js} +0 -0
@@ -1,716 +0,0 @@
1
- import {
2
- useComboboxData
3
- } from "./chunk-OVPAOBZB.js";
4
- import {
5
- optionalInt,
6
- partialFormValidation
7
- } from "./chunk-IZ5RG5XI.js";
8
- import {
9
- castNumber
10
- } from "./chunk-SMQT3ZNO.js";
11
- import {
12
- Combobox
13
- } from "./chunk-VBRTC2VU.js";
14
- import {
15
- DataGrid,
16
- createDataGridHelper,
17
- createDataGridPriceColumns
18
- } from "./chunk-Y2QI7KWS.js";
19
- import "./chunk-IQPN4PZJ.js";
20
- import "./chunk-TKGWSUEI.js";
21
- import {
22
- KeyboundForm
23
- } from "./chunk-U2ZFCAPX.js";
24
- import {
25
- RouteDrawer,
26
- RouteFocusModal,
27
- useRouteModal
28
- } from "./chunk-3CK6OINO.js";
29
- import {
30
- Form
31
- } from "./chunk-3QSRE5LS.js";
32
- import "./chunk-47SXTGLN.js";
33
- import "./chunk-F4OJN2F2.js";
34
- import "./chunk-LRARA622.js";
35
- import "./chunk-M6N4ISXL.js";
36
- import "./chunk-S7EKBD2C.js";
37
- import "./chunk-VXMOPVRH.js";
38
- import "./chunk-IQWK723D.js";
39
- import "./chunk-VV6IKGCN.js";
40
- import "./chunk-PCMNEUMV.js";
41
- import "./chunk-BOZJOOGW.js";
42
- import "./chunk-RL7SFZOF.js";
43
- import "./chunk-LWJF63JW.js";
44
- import "./chunk-NBPMNUKZ.js";
45
- import "./chunk-WBI7FEGI.js";
46
- import "./chunk-VXWN37PT.js";
47
- import {
48
- usePricePreferences,
49
- useRegions
50
- } from "./chunk-UL4O5M4S.js";
51
- import {
52
- useStore
53
- } from "./chunk-FX4V5JCF.js";
54
- import "./chunk-3B34B2M2.js";
55
- import "./chunk-RUE5BPC2.js";
56
- import "./chunk-WIYFXWRI.js";
57
- import "./chunk-LAVHRER2.js";
58
- import "./chunk-Y7QKP6QU.js";
59
- import "./chunk-INNFZYX2.js";
60
- import {
61
- useCreateProductVariant,
62
- useProduct
63
- } from "./chunk-ZEVYT6IX.js";
64
- import "./chunk-A5DJIOHN.js";
65
- import "./chunk-RHKRREUU.js";
66
- import "./chunk-ZA2KFUFR.js";
67
- import {
68
- fetchQuery
69
- } from "./chunk-RIN4CBRB.js";
70
- import "./chunk-NBMM2TZK.js";
71
-
72
- // src/pages/products/[id]/variants/create/index.tsx
73
- import { useParams } from "react-router-dom";
74
-
75
- // src/pages/products/[id]/variants/create/create-product-variant-form/create-product-variant-form.tsx
76
- import { zodResolver } from "@hookform/resolvers/zod";
77
- import { Button as Button2, ProgressTabs, toast } from "@medusajs/ui";
78
- import { useEffect, useMemo as useMemo2, useState } from "react";
79
- import { useFieldArray as useFieldArray2, useForm, useWatch as useWatch2 } from "react-hook-form";
80
- import { useTranslation as useTranslation4 } from "react-i18next";
81
-
82
- // src/pages/products/[id]/variants/create/create-product-variant-form/constants.ts
83
- import { z } from "zod";
84
- import * as zod from "zod";
85
- var CreateProductVariantSchema = z.object({
86
- title: z.string().min(1),
87
- sku: z.string().optional(),
88
- manage_inventory: z.boolean().optional(),
89
- allow_backorder: z.boolean().optional(),
90
- inventory_kit: z.boolean().optional(),
91
- options: z.record(z.string()),
92
- prices: zod.record(zod.string(), zod.string().or(zod.number()).optional()).optional(),
93
- inventory: z.array(
94
- z.object({
95
- inventory_item_id: z.string(),
96
- required_quantity: optionalInt
97
- })
98
- ).optional()
99
- });
100
- var CreateVariantDetailsSchema = CreateProductVariantSchema.pick({
101
- title: true,
102
- sku: true,
103
- manage_inventory: true,
104
- allow_backorder: true,
105
- inventory_kit: true,
106
- options: true
107
- });
108
- var CreateVariantDetailsFields = Object.keys(
109
- CreateVariantDetailsSchema.shape
110
- );
111
- var CreateVariantPriceSchema = CreateProductVariantSchema.pick({
112
- prices: true
113
- });
114
- var CreateVariantPriceFields = Object.keys(
115
- CreateVariantPriceSchema.shape
116
- );
117
-
118
- // src/pages/products/[id]/variants/create/create-product-variant-form/details-tab.tsx
119
- import { Heading, Input } from "@medusajs/ui";
120
- import { useTranslation } from "react-i18next";
121
- import { jsx, jsxs } from "react/jsx-runtime";
122
- function DetailsTab({ form, product }) {
123
- const { t } = useTranslation();
124
- return /* @__PURE__ */ jsx("div", { className: "flex flex-1 flex-col items-center overflow-y-auto", children: /* @__PURE__ */ jsxs("div", { className: "flex w-full max-w-[720px] flex-col gap-y-8 px-8 py-16", children: [
125
- /* @__PURE__ */ jsx(Heading, { level: "h1", children: t("products.variant.create.header") }),
126
- /* @__PURE__ */ jsxs("div", { className: "my-8 grid grid-cols-1 gap-4 md:grid-cols-2", children: [
127
- /* @__PURE__ */ jsx(
128
- Form.Field,
129
- {
130
- control: form.control,
131
- name: "title",
132
- render: ({ field }) => {
133
- return /* @__PURE__ */ jsxs(Form.Item, { children: [
134
- /* @__PURE__ */ jsx(Form.Label, { children: t("fields.title") }),
135
- /* @__PURE__ */ jsx(Form.Control, { children: /* @__PURE__ */ jsx(Input, { ...field }) }),
136
- /* @__PURE__ */ jsx(Form.ErrorMessage, {})
137
- ] });
138
- }
139
- }
140
- ),
141
- /* @__PURE__ */ jsx(
142
- Form.Field,
143
- {
144
- control: form.control,
145
- name: "sku",
146
- render: ({ field }) => {
147
- return /* @__PURE__ */ jsxs(Form.Item, { children: [
148
- /* @__PURE__ */ jsx(Form.Label, { optional: true, children: t("fields.sku") }),
149
- /* @__PURE__ */ jsx(Form.Control, { children: /* @__PURE__ */ jsx(Input, { ...field }) }),
150
- /* @__PURE__ */ jsx(Form.ErrorMessage, {})
151
- ] });
152
- }
153
- }
154
- ),
155
- (product.options || []).map((option) => /* @__PURE__ */ jsx(
156
- Form.Field,
157
- {
158
- control: form.control,
159
- name: `options.${option.title}`,
160
- render: ({ field: { value, onChange, ...field } }) => {
161
- return /* @__PURE__ */ jsxs(Form.Item, { children: [
162
- /* @__PURE__ */ jsx(Form.Label, { children: option.title }),
163
- /* @__PURE__ */ jsx(Form.Control, { children: /* @__PURE__ */ jsx(
164
- Combobox,
165
- {
166
- value,
167
- onChange: (v) => {
168
- onChange(v);
169
- },
170
- ...field,
171
- options: option.values.map((v) => ({
172
- label: v.value,
173
- value: v.value
174
- }))
175
- }
176
- ) })
177
- ] });
178
- }
179
- },
180
- option.id
181
- ))
182
- ] })
183
- ] }) });
184
- }
185
- var details_tab_default = DetailsTab;
186
-
187
- // src/pages/products/[id]/variants/create/create-product-variant-form/inventory-kit-tab.tsx
188
- import { useFieldArray } from "react-hook-form";
189
- import { Button, Heading as Heading2, IconButton, Input as Input2, Label } from "@medusajs/ui";
190
- import { XMarkMini } from "@medusajs/icons";
191
- import { useTranslation as useTranslation2 } from "react-i18next";
192
- import { jsx as jsx2, jsxs as jsxs2 } from "react/jsx-runtime";
193
- function InventoryKitTab({ form }) {
194
- const { t } = useTranslation2();
195
- const inventory = useFieldArray({
196
- control: form.control,
197
- name: `inventory`
198
- });
199
- const inventoryFormData = inventory.fields;
200
- const items = useComboboxData({
201
- queryKey: ["inventory_items"],
202
- queryFn: (params) => fetchQuery(`/vendor/inventory-items`, {
203
- method: "GET",
204
- query: params
205
- }),
206
- getOptions: (data) => data.inventory_items.map((item) => ({
207
- label: item.title || item.sku || item.id,
208
- value: item.id
209
- }))
210
- });
211
- const isItemOptionDisabled = (option, inventoryIndex) => {
212
- return inventoryFormData?.some(
213
- (i, index) => index != inventoryIndex && i.inventory_item_id === option.value
214
- );
215
- };
216
- return /* @__PURE__ */ jsx2("div", { className: "flex flex-col items-center p-16", children: /* @__PURE__ */ jsx2("div", { className: "flex w-full max-w-[720px] flex-col gap-y-8", children: /* @__PURE__ */ jsxs2("div", { id: "organize", className: "flex flex-col gap-y-8", children: [
217
- /* @__PURE__ */ jsx2(Heading2, { children: t("products.create.inventory.heading") }),
218
- /* @__PURE__ */ jsxs2("div", { className: "grid gap-y-4", children: [
219
- /* @__PURE__ */ jsxs2("div", { className: "flex items-start justify-between gap-x-4", children: [
220
- /* @__PURE__ */ jsxs2("div", { className: "flex flex-col", children: [
221
- /* @__PURE__ */ jsx2(Form.Label, { children: form.getValues("title") }),
222
- /* @__PURE__ */ jsx2(Form.Hint, { children: t("products.create.inventory.label") })
223
- ] }),
224
- /* @__PURE__ */ jsx2(
225
- Button,
226
- {
227
- size: "small",
228
- variant: "secondary",
229
- type: "button",
230
- onClick: () => {
231
- inventory.append({
232
- inventory_item_id: "",
233
- required_quantity: ""
234
- });
235
- },
236
- children: t("actions.add")
237
- }
238
- )
239
- ] }),
240
- inventory.fields.map((inventoryItem, inventoryIndex) => /* @__PURE__ */ jsxs2(
241
- "li",
242
- {
243
- className: "bg-ui-bg-component shadow-elevation-card-rest grid grid-cols-[1fr_28px] items-center gap-1.5 rounded-xl p-1.5",
244
- children: [
245
- /* @__PURE__ */ jsxs2("div", { className: "grid grid-cols-[min-content,1fr] items-center gap-1.5", children: [
246
- /* @__PURE__ */ jsx2("div", { className: "flex items-center px-2 py-1.5", children: /* @__PURE__ */ jsx2(
247
- Label,
248
- {
249
- size: "xsmall",
250
- weight: "plus",
251
- className: "text-ui-fg-subtle",
252
- htmlFor: `inventory.${inventoryIndex}.inventory_item_id`,
253
- children: t("fields.item")
254
- }
255
- ) }),
256
- /* @__PURE__ */ jsx2(
257
- Form.Field,
258
- {
259
- control: form.control,
260
- name: `inventory.${inventoryIndex}.inventory_item_id`,
261
- render: ({ field }) => {
262
- return /* @__PURE__ */ jsx2(Form.Item, { children: /* @__PURE__ */ jsx2(Form.Control, { children: /* @__PURE__ */ jsx2(
263
- Combobox,
264
- {
265
- ...field,
266
- options: items.options.map((o) => ({
267
- ...o,
268
- disabled: isItemOptionDisabled(
269
- o,
270
- inventoryIndex
271
- )
272
- })),
273
- searchValue: items.searchValue,
274
- onSearchValueChange: items.onSearchValueChange,
275
- fetchNextPage: items.fetchNextPage,
276
- className: "bg-ui-bg-field-component hover:bg-ui-bg-field-component-hover",
277
- placeholder: t(
278
- "products.create.inventory.itemPlaceholder"
279
- )
280
- }
281
- ) }) });
282
- }
283
- }
284
- ),
285
- /* @__PURE__ */ jsx2("div", { className: "flex items-center px-2 py-1.5", children: /* @__PURE__ */ jsx2(
286
- Label,
287
- {
288
- size: "xsmall",
289
- weight: "plus",
290
- className: "text-ui-fg-subtle",
291
- htmlFor: `inventory.${inventoryIndex}.required_quantity`,
292
- children: t("fields.quantity")
293
- }
294
- ) }),
295
- /* @__PURE__ */ jsx2(
296
- Form.Field,
297
- {
298
- control: form.control,
299
- name: `inventory.${inventoryIndex}.required_quantity`,
300
- render: ({ field: { onChange, value, ...field } }) => {
301
- return /* @__PURE__ */ jsxs2(Form.Item, { children: [
302
- /* @__PURE__ */ jsx2(Form.Control, { children: /* @__PURE__ */ jsx2(
303
- Input2,
304
- {
305
- type: "number",
306
- className: "bg-ui-bg-field-component",
307
- min: 0,
308
- value,
309
- onChange: (e) => {
310
- const value2 = e.target.value;
311
- if (value2 === "") {
312
- onChange(null);
313
- } else {
314
- onChange(Number(value2));
315
- }
316
- },
317
- ...field,
318
- placeholder: t(
319
- "products.create.inventory.quantityPlaceholder"
320
- )
321
- }
322
- ) }),
323
- /* @__PURE__ */ jsx2(Form.ErrorMessage, {})
324
- ] });
325
- }
326
- }
327
- )
328
- ] }),
329
- /* @__PURE__ */ jsx2(
330
- IconButton,
331
- {
332
- type: "button",
333
- size: "small",
334
- variant: "transparent",
335
- className: "text-ui-fg-muted",
336
- onClick: () => inventory.remove(inventoryIndex),
337
- children: /* @__PURE__ */ jsx2(XMarkMini, {})
338
- }
339
- )
340
- ]
341
- },
342
- inventoryItem.id
343
- ))
344
- ] })
345
- ] }) }) });
346
- }
347
- var inventory_kit_tab_default = InventoryKitTab;
348
-
349
- // src/pages/products/[id]/variants/create/create-product-variant-form/pricing-tab.tsx
350
- import { useMemo } from "react";
351
- import { useWatch } from "react-hook-form";
352
- import { useTranslation as useTranslation3 } from "react-i18next";
353
- import { jsx as jsx3 } from "react/jsx-runtime";
354
- function PricingTab({ form }) {
355
- const { store } = useStore();
356
- const { regions } = useRegions({ limit: 9999 });
357
- const { price_preferences: pricePreferences } = usePricePreferences({});
358
- const { setCloseOnEscape } = useRouteModal();
359
- const columns = useVariantPriceGridColumns({
360
- currencies: store?.supported_currencies,
361
- regions,
362
- pricePreferences
363
- });
364
- const variant = useWatch({
365
- control: form.control
366
- });
367
- return /* @__PURE__ */ jsx3(
368
- DataGrid,
369
- {
370
- columns,
371
- data: [variant],
372
- state: form,
373
- onEditingChange: (editing) => setCloseOnEscape(!editing)
374
- }
375
- );
376
- }
377
- var columnHelper = createDataGridHelper();
378
- var useVariantPriceGridColumns = ({
379
- currencies = [],
380
- regions: _regions = [],
381
- pricePreferences = []
382
- }) => {
383
- const { t } = useTranslation3();
384
- return useMemo(() => {
385
- return [
386
- columnHelper.column({
387
- id: t("fields.title"),
388
- header: t("fields.title"),
389
- cell: (context) => {
390
- const entity = context.row.original;
391
- return /* @__PURE__ */ jsx3(DataGrid.ReadonlyCell, { context, children: /* @__PURE__ */ jsx3("div", { className: "flex h-full w-full items-center gap-x-2 overflow-hidden", children: /* @__PURE__ */ jsx3("span", { className: "truncate", children: entity.title }) }) });
392
- },
393
- disableHiding: true
394
- }),
395
- ...createDataGridPriceColumns({
396
- currencies: currencies.map((c) => c.currency_code),
397
- pricePreferences,
398
- getFieldName: (context, value) => {
399
- if (context.column.id?.startsWith("currency_prices")) {
400
- return `prices.${value}`;
401
- }
402
- return `prices.${value}`;
403
- },
404
- t
405
- })
406
- ];
407
- }, [t, currencies, pricePreferences]);
408
- };
409
- var pricing_tab_default = PricingTab;
410
-
411
- // src/pages/products/[id]/variants/create/create-product-variant-form/create-product-variant-form.tsx
412
- import { jsx as jsx4, jsxs as jsxs3 } from "react/jsx-runtime";
413
- var initialTabState = {
414
- ["detail" /* DETAIL */]: "in-progress",
415
- ["price" /* PRICE */]: "not-started",
416
- ["inventory" /* INVENTORY */]: "not-started"
417
- };
418
- var CreateProductVariantForm = ({
419
- product
420
- }) => {
421
- const { t } = useTranslation4();
422
- const { handleSuccess } = useRouteModal();
423
- const [tab, setTab] = useState(
424
- "detail" /* DETAIL */
425
- );
426
- const [tabState, setTabState] = useState(initialTabState);
427
- const form = useForm({
428
- defaultValues: {
429
- sku: "",
430
- title: "",
431
- manage_inventory: false,
432
- allow_backorder: false,
433
- inventory_kit: false,
434
- options: {}
435
- },
436
- resolver: zodResolver(CreateProductVariantSchema)
437
- });
438
- const { mutateAsync, isPending } = useCreateProductVariant(product.id);
439
- const { regions } = useRegions({ limit: 9999 });
440
- const regionsCurrencyMap = useMemo2(() => {
441
- if (!regions?.length) {
442
- return {};
443
- }
444
- return regions.reduce(
445
- (acc, reg) => {
446
- acc[reg.id] = reg.currency_code;
447
- return acc;
448
- },
449
- {}
450
- );
451
- }, [regions]);
452
- const isManageInventoryEnabled = useWatch2({
453
- control: form.control,
454
- name: "manage_inventory"
455
- });
456
- const isInventoryKitEnabled = useWatch2({
457
- control: form.control,
458
- name: "inventory_kit"
459
- });
460
- const inventoryField = useFieldArray2({
461
- control: form.control,
462
- name: `inventory`
463
- });
464
- const inventoryTabEnabled = isManageInventoryEnabled && isInventoryKitEnabled;
465
- const tabOrder = useMemo2(() => {
466
- if (inventoryTabEnabled) {
467
- return ["detail" /* DETAIL */, "price" /* PRICE */, "inventory" /* INVENTORY */];
468
- }
469
- return ["detail" /* DETAIL */, "price" /* PRICE */, "inventory" /* INVENTORY */];
470
- }, [inventoryTabEnabled]);
471
- useEffect(() => {
472
- if (isInventoryKitEnabled && inventoryField.fields.length === 0) {
473
- inventoryField.append({
474
- inventory_item_id: "",
475
- required_quantity: void 0
476
- });
477
- }
478
- }, [
479
- isInventoryKitEnabled,
480
- inventoryField.fields.length,
481
- inventoryField
482
- ]);
483
- const handleChangeTab = (update) => {
484
- if (tab === update) {
485
- return;
486
- }
487
- if (tabOrder.indexOf(update) < tabOrder.indexOf(tab)) {
488
- const isCurrentTabDirty = false;
489
- setTabState((prev) => ({
490
- ...prev,
491
- [tab]: isCurrentTabDirty ? prev[tab] : "not-started",
492
- [update]: "in-progress"
493
- }));
494
- setTab(update);
495
- return;
496
- }
497
- const tabs = tabOrder.slice(0, tabOrder.indexOf(update));
498
- for (const tab2 of tabs) {
499
- if (tab2 === "detail" /* DETAIL */) {
500
- if (!partialFormValidation(
501
- form,
502
- CreateVariantDetailsFields,
503
- CreateVariantDetailsSchema
504
- )) {
505
- setTabState((prev) => ({
506
- ...prev,
507
- [tab2]: "in-progress"
508
- }));
509
- setTab(tab2);
510
- return;
511
- }
512
- setTabState((prev) => ({
513
- ...prev,
514
- [tab2]: "completed"
515
- }));
516
- } else if (tab2 === "price" /* PRICE */) {
517
- if (!partialFormValidation(
518
- form,
519
- CreateVariantPriceFields,
520
- CreateVariantPriceSchema
521
- )) {
522
- setTabState((prev) => ({
523
- ...prev,
524
- [tab2]: "in-progress"
525
- }));
526
- setTab(tab2);
527
- return;
528
- }
529
- setTabState((prev) => ({
530
- ...prev,
531
- [tab2]: "completed"
532
- }));
533
- }
534
- }
535
- setTabState((prev) => ({
536
- ...prev,
537
- [tab]: "completed",
538
- [update]: "in-progress"
539
- }));
540
- setTab(update);
541
- };
542
- const handleNextTab = (tab2) => {
543
- if (tabOrder.indexOf(tab2) + 1 >= tabOrder.length) {
544
- return;
545
- }
546
- const nextTab = tabOrder[tabOrder.indexOf(tab2) + 1];
547
- handleChangeTab(nextTab);
548
- };
549
- const handleSubmit = form.handleSubmit(async (data) => {
550
- const { sku, title } = data;
551
- await mutateAsync(
552
- {
553
- title,
554
- sku: sku || void 0,
555
- allow_backorder: false,
556
- manage_inventory: true,
557
- options: data.options,
558
- prices: Object.entries(data.prices ?? {}).map(([currencyOrRegion, value]) => {
559
- if (value === "" || value === void 0) {
560
- return void 0;
561
- }
562
- const amount = castNumber(value);
563
- if (currencyOrRegion.startsWith("reg_")) {
564
- return {
565
- rules: { region_id: currencyOrRegion },
566
- currency_code: regionsCurrencyMap[currencyOrRegion],
567
- amount
568
- };
569
- } else {
570
- return {
571
- currency_code: currencyOrRegion,
572
- amount
573
- };
574
- }
575
- }).filter(
576
- (price) => !!price
577
- )
578
- },
579
- {
580
- onSuccess: () => {
581
- handleSuccess();
582
- },
583
- onError: (error) => {
584
- toast.error(error.message);
585
- }
586
- }
587
- );
588
- });
589
- return /* @__PURE__ */ jsx4(RouteFocusModal.Form, { form, children: /* @__PURE__ */ jsx4(
590
- ProgressTabs,
591
- {
592
- value: tab,
593
- onValueChange: (tab2) => handleChangeTab(tab2),
594
- className: "flex h-full flex-col overflow-hidden",
595
- children: /* @__PURE__ */ jsxs3(
596
- KeyboundForm,
597
- {
598
- onSubmit: handleSubmit,
599
- className: "flex h-full flex-col overflow-hidden",
600
- children: [
601
- /* @__PURE__ */ jsx4(RouteFocusModal.Header, { children: /* @__PURE__ */ jsx4("div", { className: "flex w-full items-center justify-between gap-x-4", children: /* @__PURE__ */ jsx4("div", { className: "-my-2 w-full max-w-[600px] border-l", children: /* @__PURE__ */ jsxs3(ProgressTabs.List, { className: "grid w-full grid-cols-3", children: [
602
- /* @__PURE__ */ jsx4(
603
- ProgressTabs.Trigger,
604
- {
605
- status: tabState.detail,
606
- value: "detail" /* DETAIL */,
607
- children: t("priceLists.create.tabs.details")
608
- }
609
- ),
610
- /* @__PURE__ */ jsx4(
611
- ProgressTabs.Trigger,
612
- {
613
- status: tabState.price,
614
- value: "price" /* PRICE */,
615
- children: t("priceLists.create.tabs.prices")
616
- }
617
- ),
618
- !!inventoryTabEnabled && /* @__PURE__ */ jsx4(
619
- ProgressTabs.Trigger,
620
- {
621
- status: tabState.inventory,
622
- value: "inventory" /* INVENTORY */,
623
- children: t("products.create.tabs.inventory")
624
- }
625
- )
626
- ] }) }) }) }),
627
- /* @__PURE__ */ jsxs3(RouteFocusModal.Body, { className: "size-full overflow-hidden", children: [
628
- /* @__PURE__ */ jsx4(
629
- ProgressTabs.Content,
630
- {
631
- className: "size-full overflow-y-auto",
632
- value: "detail" /* DETAIL */,
633
- children: /* @__PURE__ */ jsx4(details_tab_default, { form, product })
634
- }
635
- ),
636
- /* @__PURE__ */ jsx4(
637
- ProgressTabs.Content,
638
- {
639
- className: "size-full overflow-y-auto",
640
- value: "price" /* PRICE */,
641
- children: /* @__PURE__ */ jsx4(pricing_tab_default, { form })
642
- }
643
- ),
644
- !!inventoryTabEnabled && /* @__PURE__ */ jsx4(
645
- ProgressTabs.Content,
646
- {
647
- className: "size-full overflow-hidden",
648
- value: "inventory" /* INVENTORY */,
649
- children: /* @__PURE__ */ jsx4(inventory_kit_tab_default, { form })
650
- }
651
- )
652
- ] }),
653
- /* @__PURE__ */ jsx4(RouteFocusModal.Footer, { children: /* @__PURE__ */ jsxs3("div", { className: "flex items-center justify-end gap-x-2", children: [
654
- /* @__PURE__ */ jsx4(RouteDrawer.Close, { asChild: true, children: /* @__PURE__ */ jsx4(Button2, { variant: "secondary", size: "small", children: t("actions.cancel") }) }),
655
- /* @__PURE__ */ jsx4(
656
- PrimaryButton,
657
- {
658
- tab,
659
- next: handleNextTab,
660
- isLoading: isPending,
661
- inventoryTabEnabled: !!inventoryTabEnabled
662
- }
663
- )
664
- ] }) })
665
- ]
666
- }
667
- )
668
- }
669
- ) });
670
- };
671
- var PrimaryButton = ({
672
- tab,
673
- next,
674
- isLoading,
675
- inventoryTabEnabled
676
- }) => {
677
- const { t } = useTranslation4();
678
- if (inventoryTabEnabled && tab === "inventory" /* INVENTORY */ || !inventoryTabEnabled && tab === "price" /* PRICE */) {
679
- return /* @__PURE__ */ jsx4(
680
- Button2,
681
- {
682
- type: "submit",
683
- variant: "primary",
684
- size: "small",
685
- isLoading,
686
- children: t("actions.save")
687
- },
688
- "submit-button"
689
- );
690
- }
691
- return /* @__PURE__ */ jsx4(
692
- Button2,
693
- {
694
- type: "button",
695
- variant: "primary",
696
- size: "small",
697
- onClick: () => next(tab),
698
- children: t("actions.continue")
699
- },
700
- "next-button"
701
- );
702
- };
703
-
704
- // src/pages/products/[id]/variants/create/index.tsx
705
- import { jsx as jsx5 } from "react/jsx-runtime";
706
- var Component = () => {
707
- const { id } = useParams();
708
- const { product, isLoading, isError, error } = useProduct(id);
709
- if (isError) {
710
- throw error;
711
- }
712
- return /* @__PURE__ */ jsx5(RouteFocusModal, { children: !isLoading && product && /* @__PURE__ */ jsx5(CreateProductVariantForm, { product }) });
713
- };
714
- export {
715
- Component
716
- };