@mercurjs/vendor 2.0.0-canary.0

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 (290) hide show
  1. package/dist/[id]-23D3HY3G.js +444 -0
  2. package/dist/[id]-2VBOAZM4.js +1215 -0
  3. package/dist/[id]-A4FSDRER.js +325 -0
  4. package/dist/[id]-E45G2SDA.js +213 -0
  5. package/dist/[id]-FXKSI52D.js +477 -0
  6. package/dist/[id]-HHZ3BSXV.js +1166 -0
  7. package/dist/[id]-MIV4U5UW.js +137 -0
  8. package/dist/[id]-QSRIPPIP.js +612 -0
  9. package/dist/[id]-RGDXOC7T.js +499 -0
  10. package/dist/[id]-TI2MOR2C.js +377 -0
  11. package/dist/[id]-U5DT2ZLS.js +301 -0
  12. package/dist/[id]-UMFGLDM2.js +354 -0
  13. package/dist/[id]-VTFOP3BF.js +97 -0
  14. package/dist/[id]-ZYF75L6G.js +479 -0
  15. package/dist/[location_id]-4UIEW5KM.js +685 -0
  16. package/dist/[province_id]-ZCHPXXQN.js +205 -0
  17. package/dist/add-KNDQL6YN.js +660 -0
  18. package/dist/add-customer-groups-JA346MTF.js +275 -0
  19. package/dist/add-products-2VB57KXV.js +273 -0
  20. package/dist/add-promotions-KVKEP6EO.js +260 -0
  21. package/dist/add-to-campaign-V6D7JKRS.js +44 -0
  22. package/dist/additional-attributes-E36EZX4V.js +219 -0
  23. package/dist/adjust-inventory-P7AB7VIB.js +228 -0
  24. package/dist/allocate-items-QAS5PZLR.js +529 -0
  25. package/dist/areas-Y7VDWH7G.js +151 -0
  26. package/dist/attributes-UEM2VJKV.js +277 -0
  27. package/dist/breadcrumb-3QTVWXZB.js +27 -0
  28. package/dist/breadcrumb-5OTOCYNL.js +38 -0
  29. package/dist/breadcrumb-6NAAOPIY.js +11 -0
  30. package/dist/breadcrumb-ASB2YCNV.js +25 -0
  31. package/dist/breadcrumb-CIGKLKKS.js +28 -0
  32. package/dist/breadcrumb-EOYLR3IQ.js +22 -0
  33. package/dist/breadcrumb-LENACUAA.js +22 -0
  34. package/dist/breadcrumb-LIXGWUQF.js +44 -0
  35. package/dist/breadcrumb-MOQ7GI3Z.js +27 -0
  36. package/dist/breadcrumb-NCBGPQML.js +23 -0
  37. package/dist/breadcrumb-OVMEC5OZ.js +33 -0
  38. package/dist/breadcrumb-RIXJ5QSX.js +45 -0
  39. package/dist/breadcrumb-TZB6EWNC.js +31 -0
  40. package/dist/breadcrumb-WP34OXGQ.js +23 -0
  41. package/dist/campaigns-PMVKUFEA.js +28 -0
  42. package/dist/categories-CKKIUMYG.js +27 -0
  43. package/dist/chunk-26OOAKQ6.js +18 -0
  44. package/dist/chunk-2C3HUJ3Z.js +222 -0
  45. package/dist/chunk-2F3H6ORE.js +36 -0
  46. package/dist/chunk-2ZFELO2L.js +13 -0
  47. package/dist/chunk-3CK6OINO.js +448 -0
  48. package/dist/chunk-3EF54XFY.js +64 -0
  49. package/dist/chunk-3LPVUPZZ.js +74 -0
  50. package/dist/chunk-3QSRE5LS.js +161 -0
  51. package/dist/chunk-3SIDRPKT.js +185 -0
  52. package/dist/chunk-4F5GP7J7.js +45 -0
  53. package/dist/chunk-4GPAS5GW.js +36 -0
  54. package/dist/chunk-4MFMCZEJ.js +70 -0
  55. package/dist/chunk-4TBDDMFP.js +425 -0
  56. package/dist/chunk-4TLP3TAA.js +34 -0
  57. package/dist/chunk-54TMLQH3.js +9 -0
  58. package/dist/chunk-5NF4OTVV.js +169 -0
  59. package/dist/chunk-66V3GFSW.js +138 -0
  60. package/dist/chunk-6EYGH3TB.js +26 -0
  61. package/dist/chunk-6IJMSVC6.js +16 -0
  62. package/dist/chunk-6YA3C4NB.js +55 -0
  63. package/dist/chunk-7AV5EJJ5.js +29 -0
  64. package/dist/chunk-7RPRNVBS.js +45 -0
  65. package/dist/chunk-A2SY5L5G.js +183 -0
  66. package/dist/chunk-A5DJIOHN.js +4 -0
  67. package/dist/chunk-AIFLEWO2.js +56 -0
  68. package/dist/chunk-ASVMGV2B.js +80 -0
  69. package/dist/chunk-AW77UWCZ.js +363 -0
  70. package/dist/chunk-AYUG34XF.js +84 -0
  71. package/dist/chunk-AYVH6Q5O.js +31 -0
  72. package/dist/chunk-B2RVONU7.js +160 -0
  73. package/dist/chunk-BCU3FKP2.js +18 -0
  74. package/dist/chunk-BDGZ4EQO.js +86 -0
  75. package/dist/chunk-BDZOSMAX.js +23 -0
  76. package/dist/chunk-C6SUTRP2.js +13 -0
  77. package/dist/chunk-CDIZEXFJ.js +145 -0
  78. package/dist/chunk-CFETU5BI.js +261 -0
  79. package/dist/chunk-CMHI2RPL.js +20 -0
  80. package/dist/chunk-CP5IL4P6.js +98 -0
  81. package/dist/chunk-CUO22GTM.js +96 -0
  82. package/dist/chunk-CVVYQI5F.js +41 -0
  83. package/dist/chunk-DARJTN4I.js +60 -0
  84. package/dist/chunk-DB6ANJBO.js +35 -0
  85. package/dist/chunk-DC2K6CFQ.js +86 -0
  86. package/dist/chunk-DDEIH66R.js +123 -0
  87. package/dist/chunk-DY3XQPHC.js +31 -0
  88. package/dist/chunk-DYUTYBAQ.js +67 -0
  89. package/dist/chunk-E3MNEQID.js +24 -0
  90. package/dist/chunk-FBZHM2QZ.js +247 -0
  91. package/dist/chunk-FDZC3TFZ.js +717 -0
  92. package/dist/chunk-FGCKXH45.js +263 -0
  93. package/dist/chunk-FMFVTERD.js +0 -0
  94. package/dist/chunk-FOMEBUX6.js +89 -0
  95. package/dist/chunk-FQERBIVS.js +0 -0
  96. package/dist/chunk-GC33DBKG.js +143 -0
  97. package/dist/chunk-GDMNHL7E.js +144 -0
  98. package/dist/chunk-GTUR4HSV.js +53 -0
  99. package/dist/chunk-H35HHFTB.js +225 -0
  100. package/dist/chunk-HB3BP55W.js +25 -0
  101. package/dist/chunk-HHD2VUED.js +29 -0
  102. package/dist/chunk-HUNGNEPY.js +312 -0
  103. package/dist/chunk-HUZG6A3X.js +127 -0
  104. package/dist/chunk-INNFZYX2.js +183 -0
  105. package/dist/chunk-IQPN4PZJ.js +749 -0
  106. package/dist/chunk-IZ5RG5XI.js +72 -0
  107. package/dist/chunk-J2XP7VRG.js +1080 -0
  108. package/dist/chunk-JHIMVLB2.js +42 -0
  109. package/dist/chunk-JKXAL7WR.js +92 -0
  110. package/dist/chunk-JRTZWK77.js +1764 -0
  111. package/dist/chunk-JVBLYMY2.js +268 -0
  112. package/dist/chunk-JXP5YZ77.js +86 -0
  113. package/dist/chunk-KAZ5BYTQ.js +132 -0
  114. package/dist/chunk-KHHY7EEM.js +267 -0
  115. package/dist/chunk-LAVHRER2.js +17 -0
  116. package/dist/chunk-LQSLDDPT.js +67 -0
  117. package/dist/chunk-LWVBKUUL.js +77 -0
  118. package/dist/chunk-LYUCDASZ.js +115 -0
  119. package/dist/chunk-LZ7QV42C.js +37 -0
  120. package/dist/chunk-MAEP2UCK.js +110 -0
  121. package/dist/chunk-MG4GKUJW.js +31 -0
  122. package/dist/chunk-N2TQXB44.js +1280 -0
  123. package/dist/chunk-N3T24SEK.js +32 -0
  124. package/dist/chunk-NANYVBFI.js +106 -0
  125. package/dist/chunk-NCMUZ6BQ.js +0 -0
  126. package/dist/chunk-NCYTM57J.js +160 -0
  127. package/dist/chunk-NX26QE2O.js +47 -0
  128. package/dist/chunk-NYDJTWRL.js +389 -0
  129. package/dist/chunk-O5LRZEG6.js +253 -0
  130. package/dist/chunk-O6PRBSFL.js +115 -0
  131. package/dist/chunk-OJCDB3N5.js +539 -0
  132. package/dist/chunk-OSFOX7MG.js +176 -0
  133. package/dist/chunk-OVPAOBZB.js +110 -0
  134. package/dist/chunk-PADOWAXM.js +118 -0
  135. package/dist/chunk-PHOCVOZ5.js +9 -0
  136. package/dist/chunk-PKBMQBKP.js +7 -0
  137. package/dist/chunk-PLSJ74T2.js +298 -0
  138. package/dist/chunk-PVZBDWLK.js +41 -0
  139. package/dist/chunk-PWZKFTJS.js +247 -0
  140. package/dist/chunk-PXYDR7WQ.js +48 -0
  141. package/dist/chunk-PYQJ5N25.js +191 -0
  142. package/dist/chunk-Q4UVXS46.js +14 -0
  143. package/dist/chunk-QDPLZDMX.js +17 -0
  144. package/dist/chunk-QSGR43JM.js +30 -0
  145. package/dist/chunk-QUNDGPF7.js +92801 -0
  146. package/dist/chunk-R65A4P4H.js +136 -0
  147. package/dist/chunk-RE7YXVFG.js +128 -0
  148. package/dist/chunk-RETT6WME.js +37 -0
  149. package/dist/chunk-RHKRREUU.js +15 -0
  150. package/dist/chunk-RIILGKYR.js +32 -0
  151. package/dist/chunk-RM5RSDYP.js +353 -0
  152. package/dist/chunk-RNC4NFVK.js +170 -0
  153. package/dist/chunk-RSMZHZI2.js +2078 -0
  154. package/dist/chunk-RXM4B6HR.js +8 -0
  155. package/dist/chunk-S2WEYEQR.js +14 -0
  156. package/dist/chunk-S3PQKKNV.js +49 -0
  157. package/dist/chunk-S5GQ2SES.js +276 -0
  158. package/dist/chunk-SECZTXSU.js +31 -0
  159. package/dist/chunk-SI4ALL7W.js +180 -0
  160. package/dist/chunk-SID3COTK.js +21 -0
  161. package/dist/chunk-SMQT3ZNO.js +8 -0
  162. package/dist/chunk-SOZMJA7V.js +61 -0
  163. package/dist/chunk-TG3TCIL6.js +207 -0
  164. package/dist/chunk-THHRRYRS.js +16 -0
  165. package/dist/chunk-TKGWSUEI.js +0 -0
  166. package/dist/chunk-TTFCO5HU.js +173 -0
  167. package/dist/chunk-TXEPCJEQ.js +430 -0
  168. package/dist/chunk-U2EI2ZLM.js +32 -0
  169. package/dist/chunk-U2ZFCAPX.js +34 -0
  170. package/dist/chunk-U3X4DNV6.js +179 -0
  171. package/dist/chunk-UXKKD4AD.js +437 -0
  172. package/dist/chunk-UYJ65N46.js +261 -0
  173. package/dist/chunk-VDWGP2U6.js +71 -0
  174. package/dist/chunk-VGJTARSA.js +89 -0
  175. package/dist/chunk-VHMGJUYN.js +28 -0
  176. package/dist/chunk-VKC3XKFF.js +283 -0
  177. package/dist/chunk-VKOE5J66.js +31 -0
  178. package/dist/chunk-VOHEQ7B5.js +31 -0
  179. package/dist/chunk-VW56KWO2.js +9 -0
  180. package/dist/chunk-W4KHJ4D6.js +74 -0
  181. package/dist/chunk-W6Y3PPU5.js +73 -0
  182. package/dist/chunk-W6ZVQJYB.js +311 -0
  183. package/dist/chunk-WA3IVAUC.js +123 -0
  184. package/dist/chunk-WHTS4G5K.js +1551 -0
  185. package/dist/chunk-WIYFXWRI.js +30 -0
  186. package/dist/chunk-WPFTRRWV.js +455 -0
  187. package/dist/chunk-WQZ4ONQV.js +6 -0
  188. package/dist/chunk-WS652CCV.js +893 -0
  189. package/dist/chunk-XG4PTPRM.js +0 -0
  190. package/dist/chunk-XRNDVICA.js +85 -0
  191. package/dist/chunk-XXZJISPX.js +48 -0
  192. package/dist/chunk-Y224F4UU.js +81 -0
  193. package/dist/chunk-Y3FR5JC7.js +437 -0
  194. package/dist/chunk-Y4VBOHAP.js +111 -0
  195. package/dist/chunk-Y7QKP6QU.js +35 -0
  196. package/dist/chunk-YVCBMOJG.js +50 -0
  197. package/dist/chunk-Z2WPXJ6J.js +146 -0
  198. package/dist/chunk-ZA2KFUFR.js +19 -0
  199. package/dist/chunk-ZEKV7LGF.js +6 -0
  200. package/dist/chunk-ZFFA36DB.js +186 -0
  201. package/dist/chunk-ZPGWTLF2.js +499 -0
  202. package/dist/chunk-ZVT2QSWR.js +263 -0
  203. package/dist/chunk-ZZ7VKT2S.js +4113 -0
  204. package/dist/collections-TREF67TO.js +63 -0
  205. package/dist/configuration-KWAL2QZ5.js +152 -0
  206. package/dist/configuration-RNWBTRAH.js +205 -0
  207. package/dist/create-7UEEO5TM.js +125 -0
  208. package/dist/create-DTCDJMIT.js +634 -0
  209. package/dist/create-DYDRAY6V.js +622 -0
  210. package/dist/create-EJM5C2XP.js +27 -0
  211. package/dist/create-F7OMPGZV.js +853 -0
  212. package/dist/create-G4UJOJJ6.js +69 -0
  213. package/dist/create-IE6MYOIY.js +170 -0
  214. package/dist/create-L23TGTBH.js +225 -0
  215. package/dist/create-LOBCFTCT.js +583 -0
  216. package/dist/create-MKBBF2V3.js +150 -0
  217. package/dist/create-TFDUNJSI.js +163 -0
  218. package/dist/create-TMTZDKII.js +711 -0
  219. package/dist/create-XGF6DB5F.js +239 -0
  220. package/dist/create-YAAK7JQ3.js +1052 -0
  221. package/dist/create-YPCVTXAK.js +194 -0
  222. package/dist/create-ZU362U3B.js +310 -0
  223. package/dist/customers-4QWR5UOL.js +27 -0
  224. package/dist/edit-2QA5BVOY.js +735 -0
  225. package/dist/edit-47I7VVNB.js +167 -0
  226. package/dist/edit-5BUGSOTL.js +255 -0
  227. package/dist/edit-7LQATDUD.js +193 -0
  228. package/dist/edit-AQAPYMDY.js +260 -0
  229. package/dist/edit-BQLSTFTQ.js +138 -0
  230. package/dist/edit-BYXHU3IG.js +308 -0
  231. package/dist/edit-DG3MY3ZH.js +244 -0
  232. package/dist/edit-J3LD76JS.js +192 -0
  233. package/dist/edit-J6WCPHDS.js +205 -0
  234. package/dist/edit-KCZVZLSZ.js +131 -0
  235. package/dist/edit-LOKLQGM2.js +181 -0
  236. package/dist/edit-MDTTTB33.js +104 -0
  237. package/dist/edit-NFSU2K3O.js +413 -0
  238. package/dist/edit-RHNZWNXD.js +89 -0
  239. package/dist/edit-XU33IVZH.js +204 -0
  240. package/dist/edit-ZMINDMGM.js +116 -0
  241. package/dist/edit-budget-Z5USV462.js +145 -0
  242. package/dist/edit-inventory-item-YFW2AFRD.js +128 -0
  243. package/dist/edit-inventory-item-attributes-IYAMJDTB.js +278 -0
  244. package/dist/fulfillment-SKXAF3BZ.js +545 -0
  245. package/dist/fulfillment-providers-ACERVITQ.js +279 -0
  246. package/dist/home-PP7YYCSB.js +16 -0
  247. package/dist/index.css +6 -0
  248. package/dist/index.d.ts +39 -0
  249. package/dist/index.js +3656 -0
  250. package/dist/inventory-AIRQ2KNS.js +26 -0
  251. package/dist/locations-SQKM7JWN.js +23 -0
  252. package/dist/login-LKFCRHXN.js +35 -0
  253. package/dist/manage-locations-4PQS4QY7.js +195 -0
  254. package/dist/media-PL477QJO.js +703 -0
  255. package/dist/metadata-42MU3H7T.js +60 -0
  256. package/dist/metadata-DIJTVDF7.js +45 -0
  257. package/dist/metadata-NX3LEEB3.js +64 -0
  258. package/dist/metadata-RBDSM567.js +65 -0
  259. package/dist/metadata-VZTWNZPG.js +66 -0
  260. package/dist/metadata-X3XGQ563.js +67 -0
  261. package/dist/no-match-BO2NNLCM.js +33 -0
  262. package/dist/orders-2KHCHNO5.js +59 -0
  263. package/dist/organization-VQXCKHCN.js +233 -0
  264. package/dist/organize-3F5ZUIGB.js +23 -0
  265. package/dist/organize-WPWEPCF7.js +23 -0
  266. package/dist/pages/index.d.ts +1153 -0
  267. package/dist/pages/index.js +198 -0
  268. package/dist/payouts-3BY73LZ3.js +27 -0
  269. package/dist/price-lists-G256JJN7.js +34 -0
  270. package/dist/prices-EW7KBY6R.js +269 -0
  271. package/dist/pricing-3PUJDOZN.js +313 -0
  272. package/dist/product-tags-PI3RENEX.js +80 -0
  273. package/dist/product-types-WJPLJI7H.js +32 -0
  274. package/dist/product-variant-detail-EYTE7PHL.js +377 -0
  275. package/dist/product-variant-edit-PW7W5J5E.js +402 -0
  276. package/dist/products-GSN4I7BT.js +272 -0
  277. package/dist/products-RFYNEY57.js +85 -0
  278. package/dist/promotions-CIZIDQ64.js +31 -0
  279. package/dist/reset-password-OFUSH363.js +299 -0
  280. package/dist/return-reasons-4V2KVSRI.js +52 -0
  281. package/dist/sales-channels-MBWVM3X2.js +184 -0
  282. package/dist/sales-channels-ZKA62EAW.js +156 -0
  283. package/dist/seller-ZFDLKF5Y.js +36 -0
  284. package/dist/settings-NP2IAID5.js +111 -0
  285. package/dist/shipping-profile-7FTHSPY2.js +145 -0
  286. package/dist/shipping-profiles-7R6L65WG.js +43 -0
  287. package/dist/stock-ENMBCZRY.js +502 -0
  288. package/dist/stock-VYDJY46S.js +278 -0
  289. package/dist/tax-regions-V6G6244H.js +87 -0
  290. package/package.json +87 -0
@@ -0,0 +1,263 @@
1
+ import {
2
+ KeyboundForm
3
+ } from "./chunk-U2ZFCAPX.js";
4
+ import {
5
+ RouteFocusModal
6
+ } from "./chunk-3CK6OINO.js";
7
+
8
+ // src/components/tabbed-form/tabbed-form.tsx
9
+ import { Button, ProgressTabs } from "@medusajs/ui";
10
+ import {
11
+ Children,
12
+ createContext,
13
+ useContext,
14
+ useMemo as useMemo2
15
+ } from "react";
16
+ import { useTranslation } from "react-i18next";
17
+
18
+ // src/components/tabbed-form/use-tab-management.ts
19
+ import { useCallback, useEffect, useMemo, useState } from "react";
20
+ var useTabManagement = ({
21
+ tabs,
22
+ form
23
+ }) => {
24
+ const visibleTabs = useMemo(
25
+ () => tabs.filter((t) => !t.isVisible || t.isVisible(form)),
26
+ [tabs, form]
27
+ );
28
+ const [activeTabId, setActiveTabId] = useState(
29
+ visibleTabs[0]?.id ?? ""
30
+ );
31
+ const [tabState, setTabState] = useState(() => {
32
+ const state = {};
33
+ visibleTabs.forEach((t, i) => {
34
+ state[t.id] = i === 0 ? "in-progress" : "not-started";
35
+ });
36
+ return state;
37
+ });
38
+ useEffect(() => {
39
+ const newState = {};
40
+ const activeIndex2 = visibleTabs.findIndex((t) => t.id === activeTabId);
41
+ visibleTabs.forEach((t, i) => {
42
+ if (i < activeIndex2) {
43
+ newState[t.id] = "completed";
44
+ } else if (i === activeIndex2) {
45
+ newState[t.id] = "in-progress";
46
+ } else {
47
+ newState[t.id] = tabState[t.id] ?? "not-started";
48
+ }
49
+ });
50
+ setTabState(newState);
51
+ }, [activeTabId, visibleTabs]);
52
+ const activeIndex = visibleTabs.findIndex((t) => t.id === activeTabId);
53
+ const isLastTab = activeIndex === visibleTabs.length - 1;
54
+ const onNext = useCallback(async () => {
55
+ const valid = await form.trigger();
56
+ if (!valid) {
57
+ return;
58
+ }
59
+ if (activeIndex < visibleTabs.length - 1) {
60
+ setActiveTabId(visibleTabs[activeIndex + 1].id);
61
+ }
62
+ }, [form, activeIndex, visibleTabs]);
63
+ const onTabChange = useCallback(
64
+ async (tabId) => {
65
+ const valid = await form.trigger();
66
+ if (!valid) {
67
+ return;
68
+ }
69
+ setActiveTabId(tabId);
70
+ },
71
+ [form]
72
+ );
73
+ return {
74
+ activeTabId,
75
+ setActiveTabId,
76
+ tabState,
77
+ visibleTabs,
78
+ isLastTab,
79
+ onNext,
80
+ onTabChange
81
+ };
82
+ };
83
+
84
+ // src/components/tabbed-form/tabbed-form.tsx
85
+ import { jsx, jsxs } from "react/jsx-runtime";
86
+ var TabbedFormContext = createContext(null);
87
+ var useTabbedForm = () => {
88
+ const form = useContext(TabbedFormContext);
89
+ if (!form) {
90
+ throw new Error("useTabbedForm must be used within a TabbedForm");
91
+ }
92
+ return form;
93
+ };
94
+ function resolveTabMeta(child) {
95
+ const type = child.type;
96
+ const meta = type?._tabMeta;
97
+ if (!meta && !child.props?.id) {
98
+ return null;
99
+ }
100
+ return {
101
+ id: child.props?.id ?? meta?.id ?? "",
102
+ labelKey: meta?.labelKey ?? "",
103
+ label: child.props?.label,
104
+ validationFields: child.props?.validationFields ?? meta?.validationFields,
105
+ isVisible: child.props?.isVisible ?? meta?.isVisible
106
+ };
107
+ }
108
+ function collectTabs(children) {
109
+ const tabs = [];
110
+ const elements = [];
111
+ Children.forEach(children, (child) => {
112
+ if (!child || typeof child !== "object" || !("type" in child)) {
113
+ return;
114
+ }
115
+ const meta = resolveTabMeta(child);
116
+ if (meta) {
117
+ tabs.push(meta);
118
+ elements.push(child);
119
+ }
120
+ });
121
+ return { tabs, elements };
122
+ }
123
+ function Root({
124
+ form,
125
+ onSubmit,
126
+ children,
127
+ isLoading,
128
+ footer,
129
+ transformTabs
130
+ }) {
131
+ const { t } = useTranslation();
132
+ const { tabs: rawTabs, elements } = useMemo2(
133
+ () => collectTabs(children),
134
+ [children]
135
+ );
136
+ const tabs = useMemo2(
137
+ () => transformTabs ? transformTabs(rawTabs) : rawTabs,
138
+ [transformTabs, rawTabs]
139
+ );
140
+ const {
141
+ activeTabId,
142
+ tabState,
143
+ visibleTabs,
144
+ isLastTab,
145
+ onNext,
146
+ onTabChange
147
+ } = useTabManagement({
148
+ tabs,
149
+ form
150
+ });
151
+ const visibleElements = elements.filter((el) => {
152
+ const meta = resolveTabMeta(el);
153
+ return meta && visibleTabs.some((vt) => vt.id === meta.id);
154
+ });
155
+ return /* @__PURE__ */ jsx(TabbedFormContext.Provider, { value: form, children: /* @__PURE__ */ jsx(RouteFocusModal.Form, { form, children: /* @__PURE__ */ jsxs(
156
+ KeyboundForm,
157
+ {
158
+ onKeyDown: (e) => {
159
+ if (e.key === "Enter") {
160
+ if (e.target instanceof HTMLTextAreaElement && !(e.metaKey || e.ctrlKey)) {
161
+ return;
162
+ }
163
+ e.preventDefault();
164
+ if (e.metaKey || e.ctrlKey) {
165
+ if (!isLastTab) {
166
+ e.preventDefault();
167
+ e.stopPropagation();
168
+ onNext();
169
+ return;
170
+ }
171
+ onSubmit();
172
+ }
173
+ }
174
+ },
175
+ onSubmit,
176
+ className: "flex h-full flex-col",
177
+ children: [
178
+ /* @__PURE__ */ jsxs(
179
+ ProgressTabs,
180
+ {
181
+ value: activeTabId,
182
+ onValueChange: onTabChange,
183
+ className: "flex h-full flex-col overflow-hidden",
184
+ children: [
185
+ /* @__PURE__ */ jsx(RouteFocusModal.Header, { children: /* @__PURE__ */ jsx("div", { className: "-my-2 w-full border-l", children: /* @__PURE__ */ jsx(ProgressTabs.List, { className: "justify-start-start flex w-full items-center", children: visibleTabs.map((tab) => /* @__PURE__ */ jsx(
186
+ ProgressTabs.Trigger,
187
+ {
188
+ status: tabState[tab.id] ?? "not-started",
189
+ value: tab.id,
190
+ className: "max-w-[200px] truncate",
191
+ children: tab.label ?? t(tab.labelKey)
192
+ },
193
+ tab.id
194
+ )) }) }) }),
195
+ /* @__PURE__ */ jsx(RouteFocusModal.Body, { className: "size-full overflow-hidden", children: visibleElements.map((element) => {
196
+ const meta = resolveTabMeta(element);
197
+ return /* @__PURE__ */ jsx(
198
+ ProgressTabs.Content,
199
+ {
200
+ className: "size-full overflow-y-auto",
201
+ value: meta.id,
202
+ children: element
203
+ },
204
+ meta.id
205
+ );
206
+ }) })
207
+ ]
208
+ }
209
+ ),
210
+ /* @__PURE__ */ jsx(RouteFocusModal.Footer, { children: footer ? footer({ isLastTab, onNext, isLoading }) : /* @__PURE__ */ jsx(
211
+ DefaultFooter,
212
+ {
213
+ isLastTab,
214
+ onNext,
215
+ isLoading
216
+ }
217
+ ) })
218
+ ]
219
+ }
220
+ ) }) });
221
+ }
222
+ var DefaultFooter = ({
223
+ isLastTab,
224
+ onNext,
225
+ isLoading
226
+ }) => {
227
+ const { t } = useTranslation();
228
+ return /* @__PURE__ */ jsxs("div", { className: "flex items-center justify-end gap-x-2", children: [
229
+ /* @__PURE__ */ jsx(RouteFocusModal.Close, { asChild: true, children: /* @__PURE__ */ jsx(Button, { variant: "secondary", size: "small", children: t("actions.cancel") }) }),
230
+ isLastTab ? /* @__PURE__ */ jsx(
231
+ Button,
232
+ {
233
+ type: "submit",
234
+ variant: "primary",
235
+ size: "small",
236
+ isLoading,
237
+ children: t("actions.save")
238
+ },
239
+ "submit-button"
240
+ ) : /* @__PURE__ */ jsx(
241
+ Button,
242
+ {
243
+ type: "button",
244
+ variant: "primary",
245
+ size: "small",
246
+ onClick: () => onNext(),
247
+ children: t("actions.continue")
248
+ },
249
+ "next-button"
250
+ )
251
+ ] });
252
+ };
253
+ var Tab = ({
254
+ children
255
+ }) => {
256
+ return /* @__PURE__ */ jsx("div", { className: "flex flex-col items-center p-16", children: /* @__PURE__ */ jsx("div", { className: "flex w-full max-w-[720px] flex-col gap-y-8", children }) });
257
+ };
258
+ var TabbedForm = Object.assign(Root, { Tab, useForm: useTabbedForm });
259
+
260
+ export {
261
+ useTabbedForm,
262
+ TabbedForm
263
+ };
File without changes
@@ -0,0 +1,89 @@
1
+ import {
2
+ FileUpload
3
+ } from "./chunk-VKC3XKFF.js";
4
+ import {
5
+ Form
6
+ } from "./chunk-3QSRE5LS.js";
7
+
8
+ // src/pages/products/common/components/upload-media-form-item/upload-media-form-item.tsx
9
+ import { useCallback } from "react";
10
+ import { useTranslation } from "react-i18next";
11
+ import { jsx, jsxs } from "react/jsx-runtime";
12
+ var SUPPORTED_FORMATS = ["image/jpeg", "image/png", "image/webp", "image/heic", "image/svg+xml"];
13
+ var SUPPORTED_FORMATS_FILE_EXTENSIONS = [".jpeg", ".png", ".webp", ".heic", ".svg"];
14
+ var MAX_FILE_SIZE = 2 * 1024 * 1024;
15
+ var UploadMediaFormItem = ({
16
+ form,
17
+ append,
18
+ showHint = true
19
+ }) => {
20
+ const { t } = useTranslation();
21
+ const hasInvalidFiles = useCallback(
22
+ (fileList) => {
23
+ const invalidTypeFile = fileList.find((f) => !SUPPORTED_FORMATS.includes(f.file.type));
24
+ if (invalidTypeFile) {
25
+ form.setError("media", {
26
+ type: "invalid_file",
27
+ message: t("products.media.invalidFileType", {
28
+ name: invalidTypeFile.file.name,
29
+ types: SUPPORTED_FORMATS_FILE_EXTENSIONS.join(", ")
30
+ })
31
+ });
32
+ return true;
33
+ }
34
+ const oversizedFile = fileList.find((f) => f.file.size > MAX_FILE_SIZE);
35
+ if (oversizedFile) {
36
+ form.setError("media", {
37
+ type: "invalid_file",
38
+ message: t("products.media.fileTooLarge", {
39
+ name: oversizedFile.file.name,
40
+ maxSize: "2MB"
41
+ })
42
+ });
43
+ return true;
44
+ }
45
+ return false;
46
+ },
47
+ [form, t]
48
+ );
49
+ const onUploaded = useCallback(
50
+ (files) => {
51
+ form.clearErrors("media");
52
+ if (hasInvalidFiles(files)) {
53
+ return;
54
+ }
55
+ files.forEach((f) => append({ ...f, isThumbnail: false }));
56
+ },
57
+ [form, append, hasInvalidFiles]
58
+ );
59
+ return /* @__PURE__ */ jsx(
60
+ Form.Field,
61
+ {
62
+ control: form.control,
63
+ name: "media",
64
+ render: () => {
65
+ return /* @__PURE__ */ jsx(Form.Item, { children: /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-y-2", children: [
66
+ /* @__PURE__ */ jsxs("div", { className: "flex flex-col gap-y-1", children: [
67
+ /* @__PURE__ */ jsx(Form.Label, { optional: true, children: t("products.media.label") }),
68
+ showHint && /* @__PURE__ */ jsx(Form.Hint, { children: t("products.media.editHint") })
69
+ ] }),
70
+ /* @__PURE__ */ jsx(Form.Control, { children: /* @__PURE__ */ jsx(
71
+ FileUpload,
72
+ {
73
+ label: t("products.media.uploadImagesLabel"),
74
+ hint: t("products.media.uploadImagesHint"),
75
+ hasError: !!form.formState.errors.media,
76
+ formats: SUPPORTED_FORMATS,
77
+ onUploaded
78
+ }
79
+ ) }),
80
+ /* @__PURE__ */ jsx(Form.ErrorMessage, {})
81
+ ] }) });
82
+ }
83
+ }
84
+ );
85
+ };
86
+
87
+ export {
88
+ UploadMediaFormItem
89
+ };
File without changes
@@ -0,0 +1,143 @@
1
+ import {
2
+ StatusCell
3
+ } from "./chunk-DB6ANJBO.js";
4
+ import {
5
+ PlaceholderCell
6
+ } from "./chunk-PHOCVOZ5.js";
7
+ import {
8
+ Thumbnail
9
+ } from "./chunk-WIYFXWRI.js";
10
+
11
+ // src/hooks/table/columns/use-product-table-columns.tsx
12
+ import { createColumnHelper } from "@tanstack/react-table";
13
+ import { useMemo } from "react";
14
+
15
+ // src/components/table/table-cells/product/collection-cell/collection-cell.tsx
16
+ import { useTranslation } from "react-i18next";
17
+ import { jsx } from "react/jsx-runtime";
18
+ var CollectionCell = ({ collection }) => {
19
+ if (!collection) {
20
+ return /* @__PURE__ */ jsx(PlaceholderCell, {});
21
+ }
22
+ return /* @__PURE__ */ jsx("div", { className: "flex h-full w-full items-center overflow-hidden", children: /* @__PURE__ */ jsx("span", { className: "truncate", children: collection.title }) });
23
+ };
24
+ var CollectionHeader = () => {
25
+ const { t } = useTranslation();
26
+ return /* @__PURE__ */ jsx("div", { className: "flex h-full w-full items-center", children: /* @__PURE__ */ jsx("span", { children: t("fields.collection") }) });
27
+ };
28
+
29
+ // src/components/table/table-cells/product/product-cell/product-cell.tsx
30
+ import { useTranslation as useTranslation2 } from "react-i18next";
31
+ import { jsx as jsx2, jsxs } from "react/jsx-runtime";
32
+ var ProductCell = ({ product }) => {
33
+ return /* @__PURE__ */ jsxs("div", { className: "flex h-full w-full max-w-[250px] items-center gap-x-3 overflow-hidden", children: [
34
+ /* @__PURE__ */ jsx2("div", { className: "w-fit flex-shrink-0", children: /* @__PURE__ */ jsx2(Thumbnail, { src: product.thumbnail }) }),
35
+ /* @__PURE__ */ jsx2("span", { title: product.title, className: "truncate", children: product.title })
36
+ ] });
37
+ };
38
+ var ProductHeader = () => {
39
+ const { t } = useTranslation2();
40
+ return /* @__PURE__ */ jsx2("div", { className: "flex h-full w-full items-center", children: /* @__PURE__ */ jsx2("span", { children: t("fields.product") }) });
41
+ };
42
+
43
+ // src/components/table/table-cells/product/product-status-cell/product-status-cell.tsx
44
+ import { useTranslation as useTranslation3 } from "react-i18next";
45
+ import { jsx as jsx3 } from "react/jsx-runtime";
46
+ var ProductStatusCell = ({ status }) => {
47
+ const { t } = useTranslation3();
48
+ const [color, text] = {
49
+ draft: ["grey", t("products.productStatus.draft")],
50
+ proposed: ["orange", t("products.productStatus.proposed")],
51
+ published: ["green", t("products.productStatus.published")],
52
+ rejected: ["red", t("products.productStatus.rejected")]
53
+ }[status];
54
+ return /* @__PURE__ */ jsx3(StatusCell, { color, children: text });
55
+ };
56
+ var ProductStatusHeader = () => {
57
+ const { t } = useTranslation3();
58
+ return /* @__PURE__ */ jsx3("div", { className: "flex h-full w-full items-center", children: /* @__PURE__ */ jsx3("span", { children: t("fields.status") }) });
59
+ };
60
+
61
+ // src/components/table/table-cells/product/sales-channels-cell/sales-channels-cell.tsx
62
+ import { Tooltip } from "@medusajs/ui";
63
+ import { useTranslation as useTranslation4 } from "react-i18next";
64
+ import { jsx as jsx4, jsxs as jsxs2 } from "react/jsx-runtime";
65
+ var SalesChannelsCell = ({
66
+ salesChannels
67
+ }) => {
68
+ const { t } = useTranslation4();
69
+ if (!salesChannels || !salesChannels.length) {
70
+ return /* @__PURE__ */ jsx4(PlaceholderCell, {});
71
+ }
72
+ if (salesChannels.length > 2) {
73
+ return /* @__PURE__ */ jsxs2("div", { className: "flex h-full w-full items-center gap-x-1 overflow-hidden", children: [
74
+ /* @__PURE__ */ jsx4("span", { className: "truncate", children: salesChannels.slice(0, 2).map((sc) => sc.name).join(", ") }),
75
+ /* @__PURE__ */ jsx4(
76
+ Tooltip,
77
+ {
78
+ content: /* @__PURE__ */ jsx4("ul", { children: salesChannels.slice(2).map((sc) => /* @__PURE__ */ jsx4("li", { children: sc.name }, sc.id)) }),
79
+ children: /* @__PURE__ */ jsx4("span", { className: "text-xs", children: t("general.plusCountMore", {
80
+ count: salesChannels.length - 2
81
+ }) })
82
+ }
83
+ )
84
+ ] });
85
+ }
86
+ const channels = salesChannels.map((sc) => sc.name).join(", ");
87
+ return /* @__PURE__ */ jsx4("div", { className: "flex h-full w-full items-center overflow-hidden max-w-[250px]", children: /* @__PURE__ */ jsx4("span", { title: channels, className: "truncate", children: channels }) });
88
+ };
89
+ var SalesChannelHeader = () => {
90
+ const { t } = useTranslation4();
91
+ return /* @__PURE__ */ jsx4("div", { className: "flex h-full w-full items-center", children: /* @__PURE__ */ jsx4("span", { children: t("fields.salesChannels") }) });
92
+ };
93
+
94
+ // src/components/table/table-cells/product/variant-cell/variant-cell.tsx
95
+ import { useTranslation as useTranslation5 } from "react-i18next";
96
+ import { jsx as jsx5 } from "react/jsx-runtime";
97
+ var VariantCell = ({ variants }) => {
98
+ const { t } = useTranslation5();
99
+ if (!variants || !variants.length) {
100
+ return /* @__PURE__ */ jsx5(PlaceholderCell, {});
101
+ }
102
+ return /* @__PURE__ */ jsx5("div", { className: "flex h-full w-full items-center overflow-hidden", children: /* @__PURE__ */ jsx5("span", { className: "truncate", children: t("products.variantCount", { count: variants.length }) }) });
103
+ };
104
+ var VariantHeader = () => {
105
+ const { t } = useTranslation5();
106
+ return /* @__PURE__ */ jsx5("div", { className: "flex h-full w-full items-center", children: /* @__PURE__ */ jsx5("span", { children: t("fields.variants") }) });
107
+ };
108
+
109
+ // src/hooks/table/columns/use-product-table-columns.tsx
110
+ import { jsx as jsx6 } from "react/jsx-runtime";
111
+ var columnHelper = createColumnHelper();
112
+ var useProductTableColumns = () => {
113
+ return useMemo(
114
+ () => [
115
+ columnHelper.display({
116
+ id: "product",
117
+ header: () => /* @__PURE__ */ jsx6(ProductHeader, {}),
118
+ cell: ({ row }) => /* @__PURE__ */ jsx6(ProductCell, { product: row.original })
119
+ }),
120
+ columnHelper.accessor("collection", {
121
+ header: () => /* @__PURE__ */ jsx6(CollectionHeader, {}),
122
+ cell: ({ row }) => /* @__PURE__ */ jsx6(CollectionCell, { collection: row.original.collection })
123
+ }),
124
+ columnHelper.accessor("sales_channels", {
125
+ header: () => /* @__PURE__ */ jsx6(SalesChannelHeader, {}),
126
+ cell: ({ row }) => /* @__PURE__ */ jsx6(SalesChannelsCell, { salesChannels: row.original.sales_channels })
127
+ }),
128
+ columnHelper.accessor("variants", {
129
+ header: () => /* @__PURE__ */ jsx6(VariantHeader, {}),
130
+ cell: ({ row }) => /* @__PURE__ */ jsx6(VariantCell, { variants: row.original.variants })
131
+ }),
132
+ columnHelper.accessor("status", {
133
+ header: () => /* @__PURE__ */ jsx6(ProductStatusHeader, {}),
134
+ cell: ({ row }) => /* @__PURE__ */ jsx6(ProductStatusCell, { status: row.original.status })
135
+ })
136
+ ],
137
+ []
138
+ );
139
+ };
140
+
141
+ export {
142
+ useProductTableColumns
143
+ };
@@ -0,0 +1,144 @@
1
+ import {
2
+ useOrderTableColumns
3
+ } from "./chunk-KHHY7EEM.js";
4
+ import {
5
+ useOrderTableFilters
6
+ } from "./chunk-Z2WPXJ6J.js";
7
+ import {
8
+ useOrderTableQuery
9
+ } from "./chunk-6YA3C4NB.js";
10
+ import {
11
+ _DataTable,
12
+ useDataTable
13
+ } from "./chunk-WHTS4G5K.js";
14
+ import {
15
+ SingleColumnPage
16
+ } from "./chunk-RM5RSDYP.js";
17
+ import {
18
+ useOrders
19
+ } from "./chunk-ZFFA36DB.js";
20
+
21
+ // src/pages/orders/order-list-page.tsx
22
+ import { Children as Children3 } from "react";
23
+
24
+ // src/pages/orders/_components/order-list-table/order-list-table.tsx
25
+ import { Children as Children2 } from "react";
26
+ import { Container } from "@medusajs/ui";
27
+
28
+ // src/pages/orders/_components/order-list-table/order-list-header.tsx
29
+ import { Children } from "react";
30
+ import { useTranslation } from "react-i18next";
31
+ import { Heading } from "@medusajs/ui";
32
+ import { jsx } from "react/jsx-runtime";
33
+ var OrderListTitle = () => {
34
+ const { t } = useTranslation();
35
+ return /* @__PURE__ */ jsx(Heading, { children: t("orders.domain") });
36
+ };
37
+ var OrderListActions = ({
38
+ children
39
+ }) => {
40
+ return /* @__PURE__ */ jsx("div", { className: "flex items-center justify-center gap-x-2", children: Children.count(children) > 0 ? children : null });
41
+ };
42
+ var OrderListHeader = ({
43
+ children
44
+ }) => {
45
+ return /* @__PURE__ */ jsx("div", { className: "flex items-center justify-between px-6 py-4", children: Children.count(children) > 0 ? children : /* @__PURE__ */ jsx(OrderListTitle, {}) });
46
+ };
47
+
48
+ // src/pages/orders/_components/order-list-table/order-list-data-table.tsx
49
+ import { useTranslation as useTranslation2 } from "react-i18next";
50
+ import { jsx as jsx2 } from "react/jsx-runtime";
51
+ var PAGE_SIZE = 10;
52
+ var OrderListDataTable = () => {
53
+ const { t } = useTranslation2();
54
+ const { raw, searchParams } = useOrderTableQuery({
55
+ pageSize: PAGE_SIZE
56
+ });
57
+ const { orders, count, isError, error, isLoading } = useOrders({
58
+ fields: [
59
+ "id",
60
+ "status",
61
+ "created_at",
62
+ "email",
63
+ "display_id",
64
+ "custom_display_id",
65
+ "payment_status",
66
+ "fulfillment_status",
67
+ "total",
68
+ "currency_code",
69
+ "*customer",
70
+ "*sales_channel",
71
+ "*payment_collections"
72
+ ].join(","),
73
+ ...searchParams
74
+ });
75
+ const columns = useOrderTableColumns({});
76
+ const filters = useOrderTableFilters();
77
+ const { table } = useDataTable({
78
+ data: orders ?? [],
79
+ columns,
80
+ enablePagination: true,
81
+ count,
82
+ pageSize: PAGE_SIZE
83
+ });
84
+ if (isError) {
85
+ throw error;
86
+ }
87
+ return /* @__PURE__ */ jsx2(
88
+ _DataTable,
89
+ {
90
+ columns,
91
+ table,
92
+ pagination: true,
93
+ filters,
94
+ navigateTo: (row) => `/orders/${row.original.id}`,
95
+ count,
96
+ isLoading,
97
+ pageSize: PAGE_SIZE,
98
+ orderBy: [
99
+ {
100
+ key: "display_id",
101
+ label: t("orders.fields.displayId")
102
+ },
103
+ {
104
+ key: "created_at",
105
+ label: t("fields.createdAt")
106
+ },
107
+ {
108
+ key: "updated_at",
109
+ label: t("fields.updatedAt")
110
+ }
111
+ ],
112
+ queryObject: raw,
113
+ noRecords: {
114
+ message: t("orders.list.noRecordsMessage")
115
+ }
116
+ }
117
+ );
118
+ };
119
+
120
+ // src/pages/orders/_components/order-list-table/order-list-table.tsx
121
+ import { Fragment, jsx as jsx3, jsxs } from "react/jsx-runtime";
122
+ var OrderListTable = ({ children }) => {
123
+ return /* @__PURE__ */ jsx3(Container, { className: "divide-y p-0", children: Children2.count(children) > 0 ? children : /* @__PURE__ */ jsxs(Fragment, { children: [
124
+ /* @__PURE__ */ jsx3(OrderListHeader, {}),
125
+ /* @__PURE__ */ jsx3(OrderListDataTable, {})
126
+ ] }) });
127
+ };
128
+
129
+ // src/pages/orders/order-list-page.tsx
130
+ import { jsx as jsx4 } from "react/jsx-runtime";
131
+ var Root = ({ children }) => {
132
+ return /* @__PURE__ */ jsx4(SingleColumnPage, { children: Children3.count(children) > 0 ? children : /* @__PURE__ */ jsx4(OrderListTable, {}) });
133
+ };
134
+ var OrderListPage = Object.assign(Root, {
135
+ Table: OrderListTable,
136
+ Header: OrderListHeader,
137
+ HeaderTitle: OrderListTitle,
138
+ HeaderActions: OrderListActions,
139
+ DataTable: OrderListDataTable
140
+ });
141
+
142
+ export {
143
+ OrderListPage
144
+ };
@@ -0,0 +1,53 @@
1
+ import {
2
+ queryKeysFactory
3
+ } from "./chunk-ZA2KFUFR.js";
4
+ import {
5
+ sdk
6
+ } from "./chunk-Y224F4UU.js";
7
+
8
+ // src/hooks/api/price-preferences.tsx
9
+ import {
10
+ useMutation,
11
+ useQuery
12
+ } from "@tanstack/react-query";
13
+ var PRICE_PREFERENCES_QUERY_KEY = "price-preferences";
14
+ var pricePreferencesQueryKeys = queryKeysFactory(
15
+ PRICE_PREFERENCES_QUERY_KEY
16
+ );
17
+ var usePricePreferences = (query, options) => {
18
+ const { data, ...rest } = useQuery({
19
+ queryFn: () => sdk.vendor.pricePreferences.query({ ...query }),
20
+ queryKey: pricePreferencesQueryKeys.list(query),
21
+ ...options
22
+ });
23
+ return { ...data, ...rest };
24
+ };
25
+
26
+ // src/hooks/api/store.tsx
27
+ import { useMutation as useMutation2, useQuery as useQuery2 } from "@tanstack/react-query";
28
+ import { ClientError } from "@mercurjs/client";
29
+ var STORE_QUERY_KEY = "store";
30
+ var storeQueryKeys = queryKeysFactory(STORE_QUERY_KEY);
31
+ async function retrieveActiveStore(query) {
32
+ const response = await sdk.vendor.stores.query({ ...query });
33
+ const activeStore = response.stores?.[0];
34
+ if (!activeStore) {
35
+ throw new ClientError("No active store found", "Not Found", 404);
36
+ }
37
+ return { store: activeStore };
38
+ }
39
+ var useStore = (query) => {
40
+ const { data, ...rest } = useQuery2({
41
+ queryFn: () => retrieveActiveStore(query),
42
+ queryKey: storeQueryKeys.details()
43
+ });
44
+ return {
45
+ ...data,
46
+ ...rest
47
+ };
48
+ };
49
+
50
+ export {
51
+ usePricePreferences,
52
+ useStore
53
+ };