@datarecce/ui 0.1.28 → 0.1.30

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 (82) hide show
  1. package/dist/{RecceCheckContext-tUxygNmN.js → RecceCheckContext-DPpu9nG5.js} +2 -2
  2. package/dist/{RecceCheckContext-tUxygNmN.js.map → RecceCheckContext-DPpu9nG5.js.map} +1 -1
  3. package/dist/{RecceCheckContext-CiG9fGRW.mjs → RecceCheckContext-bXdfQLGG.mjs} +2 -2
  4. package/dist/{RecceCheckContext-CiG9fGRW.mjs.map → RecceCheckContext-bXdfQLGG.mjs.map} +1 -1
  5. package/dist/api.d.mts +1 -1
  6. package/dist/api.d.ts +1 -1
  7. package/dist/api.js +4 -3
  8. package/dist/api.mjs +4 -3
  9. package/dist/{components-Cvfq_6t4.js → components-B-YxuuPz.js} +66 -65
  10. package/dist/{components-Cvfq_6t4.js.map → components-B-YxuuPz.js.map} +1 -1
  11. package/dist/{components-D2DRqJsz.css → components-BeAjVBV3.css} +1 -1
  12. package/dist/{components-D2DRqJsz.css.map → components-BeAjVBV3.css.map} +1 -1
  13. package/dist/{components-Bt0G4cpr.mjs → components-DCOI1YlQ.mjs} +8 -7
  14. package/dist/{components-Bt0G4cpr.mjs.map → components-DCOI1YlQ.mjs.map} +1 -1
  15. package/dist/{components-dVXbmdqd.css → components-iUxcqtUB.css} +1 -1
  16. package/dist/{components-dVXbmdqd.css.map → components-iUxcqtUB.css.map} +1 -1
  17. package/dist/components.d.mts +1 -1
  18. package/dist/components.d.ts +1 -1
  19. package/dist/components.js +6 -5
  20. package/dist/components.mjs +6 -5
  21. package/dist/hooks-B9hsc1oD.js +40 -0
  22. package/dist/hooks-B9hsc1oD.js.map +1 -0
  23. package/dist/hooks-DjBNmTdh.mjs +34 -0
  24. package/dist/hooks-DjBNmTdh.mjs.map +1 -0
  25. package/dist/hooks.d.mts +1 -1
  26. package/dist/hooks.d.ts +1 -1
  27. package/dist/hooks.js +13 -12
  28. package/dist/hooks.mjs +5 -4
  29. package/dist/{html2canvas-pro.esm-BR5xeFe-.mjs → html2canvas-pro.esm-BInzOtWO.mjs} +1 -1
  30. package/dist/{html2canvas-pro.esm-BR5xeFe-.mjs.map → html2canvas-pro.esm-BInzOtWO.mjs.map} +1 -1
  31. package/dist/{html2canvas-pro.esm-CVOsBdk0.js → html2canvas-pro.esm-WJxOmKlq.js} +1 -1
  32. package/dist/{html2canvas-pro.esm-CVOsBdk0.js.map → html2canvas-pro.esm-WJxOmKlq.js.map} +1 -1
  33. package/dist/{index-CUtFlKOo.d.ts → index-BNUP2V_N.d.ts} +70 -70
  34. package/dist/index-BNUP2V_N.d.ts.map +1 -0
  35. package/dist/{index-OJCzYajo.d.mts → index-DOPZuhD8.d.mts} +70 -70
  36. package/dist/{index-OJCzYajo.d.mts.map → index-DOPZuhD8.d.mts.map} +1 -1
  37. package/dist/index.d.mts +1 -1
  38. package/dist/index.d.ts +1 -1
  39. package/dist/index.js +16 -15
  40. package/dist/index.js.map +1 -1
  41. package/dist/index.mjs +8 -7
  42. package/dist/index.mjs.map +1 -1
  43. package/dist/mui-theme-B2wm_cvZ.js +732 -0
  44. package/dist/mui-theme-B2wm_cvZ.js.map +1 -0
  45. package/dist/mui-theme-CUhybmBq.mjs +696 -0
  46. package/dist/mui-theme-CUhybmBq.mjs.map +1 -0
  47. package/dist/{state-DyHCt6IJ.mjs → state-B9yzhuKs.mjs} +186 -712
  48. package/dist/state-B9yzhuKs.mjs.map +1 -0
  49. package/dist/{state-eEsMhIy4.css → state-DOUPNifc.css} +1 -1
  50. package/dist/{state-eEsMhIy4.css.map → state-DOUPNifc.css.map} +1 -1
  51. package/dist/{state-FkYREAs-.js → state-lPCQsWy5.js} +246 -754
  52. package/dist/state-lPCQsWy5.js.map +1 -0
  53. package/dist/theme.d.mts +186 -0
  54. package/dist/theme.d.mts.map +1 -0
  55. package/dist/theme.d.ts +186 -0
  56. package/dist/theme.d.ts.map +1 -0
  57. package/dist/theme.js +9 -0
  58. package/dist/theme.mjs +4 -0
  59. package/dist/{tooltipMessage-CrXjOmVM.mjs → tooltipMessage-B--I3p1V.mjs} +1 -1
  60. package/dist/{tooltipMessage-CrXjOmVM.mjs.map → tooltipMessage-B--I3p1V.mjs.map} +1 -1
  61. package/dist/{tooltipMessage-Dbi1kkfi.js → tooltipMessage-DosF13kZ.js} +1 -1
  62. package/dist/{tooltipMessage-Dbi1kkfi.js.map → tooltipMessage-DosF13kZ.js.map} +1 -1
  63. package/dist/types.d.mts +1 -1
  64. package/dist/types.d.ts +1 -1
  65. package/dist/types.js +2 -2
  66. package/dist/types.mjs +2 -2
  67. package/dist/{urls-D7PrPolY.mjs → urls-B1Ymdoz-.mjs} +1 -1
  68. package/dist/{urls-D7PrPolY.mjs.map → urls-B1Ymdoz-.mjs.map} +1 -1
  69. package/dist/{urls-SazAekCZ.js → urls-C4eAc82S.js} +1 -1
  70. package/dist/{urls-SazAekCZ.js.map → urls-C4eAc82S.js.map} +1 -1
  71. package/dist/{version-BGNaeW6k.js → version-Dh8sZhvs.js} +2 -2
  72. package/dist/{version-BGNaeW6k.js.map → version-Dh8sZhvs.js.map} +1 -1
  73. package/dist/{version-Dav28qEz.mjs → version-OnOKzBeQ.mjs} +2 -2
  74. package/dist/{version-Dav28qEz.mjs.map → version-OnOKzBeQ.mjs.map} +1 -1
  75. package/package.json +6 -1
  76. package/dist/hooks-BxV6qN9q.mjs +0 -233
  77. package/dist/hooks-BxV6qN9q.mjs.map +0 -1
  78. package/dist/hooks-CriUVJO1.js +0 -287
  79. package/dist/hooks-CriUVJO1.js.map +0 -1
  80. package/dist/index-CUtFlKOo.d.ts.map +0 -1
  81. package/dist/state-DyHCt6IJ.mjs.map +0 -1
  82. package/dist/state-FkYREAs-.js.map +0 -1
@@ -0,0 +1,696 @@
1
+ "use client"
2
+ import { createTheme } from "@mui/material/styles";
3
+
4
+ //#region recce-source/js/src/components/ui/mui-theme.ts
5
+ /**
6
+ * MUI Theme Configuration for Recce
7
+ *
8
+ * This theme mirrors the existing Chakra UI theme tokens from theme.ts
9
+ * to ensure visual consistency during the migration period.
10
+ *
11
+ * Color palette mappings:
12
+ * - iochmara (custom blue) -> primary
13
+ * - cyan -> secondary
14
+ * - brand (orange) -> custom palette
15
+ * - green -> success
16
+ * - amber -> warning
17
+ * - red -> error
18
+ * - neutral -> grey
19
+ */
20
+ const white = "#FFFFFF";
21
+ const black = "#000000";
22
+ const colors = {
23
+ white,
24
+ black,
25
+ iochmara: {
26
+ 50: "#EAF3FB",
27
+ 100: "#C4DDF3",
28
+ 200: "#9EC6EB",
29
+ 300: "#79B0E2",
30
+ 400: "#5599D8",
31
+ 500: "#3182CE",
32
+ 600: "#2A6CA7",
33
+ 700: "#225581",
34
+ 800: "#193E5C",
35
+ 900: "#102638",
36
+ 950: "#060E14"
37
+ },
38
+ cyan: {
39
+ 50: "#ECFEFF",
40
+ 100: "#CFFAFE",
41
+ 200: "#A5F3FC",
42
+ 300: "#67E8F9",
43
+ 400: "#22D3EE",
44
+ 500: "#06B6D4",
45
+ 600: "#0891B2",
46
+ 700: "#0E7490",
47
+ 800: "#155E75",
48
+ 900: "#164E63",
49
+ 950: "#083344"
50
+ },
51
+ neutral: {
52
+ 50: "#FAFAFA",
53
+ 100: "#F5F5F5",
54
+ 200: "#E5E5E5",
55
+ 300: "#D4D4D4",
56
+ 400: "#A3A3A3",
57
+ 500: "#737373",
58
+ 600: "#525252",
59
+ 700: "#404040",
60
+ 800: "#262626",
61
+ 900: "#171717",
62
+ 950: "#0A0A0A"
63
+ },
64
+ amber: {
65
+ 50: "#FFFBEB",
66
+ 100: "#FEF3C7",
67
+ 200: "#FDE68A",
68
+ 300: "#FCD34D",
69
+ 400: "#FBBF24",
70
+ 500: "#F59E0B",
71
+ 600: "#D97706",
72
+ 700: "#B45309",
73
+ 800: "#92400E",
74
+ 900: "#78350F",
75
+ 950: "#431407"
76
+ },
77
+ yellow: {
78
+ 50: "#FEFCE8",
79
+ 100: "#FEF9C3",
80
+ 200: "#FEF08A",
81
+ 300: "#FDE047",
82
+ 400: "#FACC15",
83
+ 500: "#EAB308",
84
+ 600: "#CA8A04",
85
+ 700: "#A16207",
86
+ 800: "#854D0E",
87
+ 900: "#713F12",
88
+ 950: "#422006"
89
+ },
90
+ green: {
91
+ 50: "#F0FDF4",
92
+ 100: "#DCFCE7",
93
+ 200: "#BBF7D0",
94
+ 300: "#86EFAC",
95
+ 400: "#4ADE80",
96
+ 500: "#22C55E",
97
+ 600: "#16A34A",
98
+ 700: "#15803D",
99
+ 800: "#166534",
100
+ 900: "#14532D",
101
+ 950: "#052E16"
102
+ },
103
+ red: {
104
+ 50: "#FEF2F2",
105
+ 100: "#FEE2E2",
106
+ 200: "#FECACA",
107
+ 300: "#FCA5A5",
108
+ 400: "#F87171",
109
+ 500: "#EF4444",
110
+ 600: "#DC2626",
111
+ 700: "#B91C1C",
112
+ 800: "#991B1B",
113
+ 900: "#7F1D1D",
114
+ 950: "#450A0A"
115
+ },
116
+ rose: {
117
+ 50: "#FFF1F2",
118
+ 100: "#FFE4E6",
119
+ 200: "#FECDD3",
120
+ 300: "#FDA4AF",
121
+ 400: "#FB7185",
122
+ 500: "#F43F5E",
123
+ 600: "#E11D48",
124
+ 700: "#BE123C",
125
+ 800: "#9F1239",
126
+ 900: "#881337",
127
+ 950: "#4C0519"
128
+ },
129
+ fuchsia: {
130
+ 50: "#FDF4FF",
131
+ 100: "#FAE8FF",
132
+ 200: "#F5D0FE",
133
+ 300: "#F0ABFC",
134
+ 400: "#E879F9",
135
+ 500: "#D946EF",
136
+ 600: "#C026D3",
137
+ 700: "#A21CAF",
138
+ 800: "#86198F",
139
+ 900: "#701A75",
140
+ 950: "#4A044E"
141
+ },
142
+ brand: {
143
+ 50: "#FFDED5",
144
+ 100: "#FFC1B0",
145
+ 200: "#FFA58C",
146
+ 300: "#FF8967",
147
+ 400: "#FF6E42",
148
+ 500: "#FD541E",
149
+ 600: "#F04104",
150
+ 700: "#C93A06",
151
+ 800: "#A23206",
152
+ 900: "#7C2906",
153
+ 950: "#571E05"
154
+ }
155
+ };
156
+ const semanticColors = {
157
+ envBase: colors.amber[500],
158
+ envCurrent: colors.iochmara[500]
159
+ };
160
+ /**
161
+ * Helper to generate button color variants for a given color
162
+ * Creates contained, outlined, and text variant styles
163
+ */
164
+ function createButtonColorVariants(colorName, colorScale) {
165
+ return [
166
+ {
167
+ props: {
168
+ color: colorName,
169
+ variant: "contained"
170
+ },
171
+ style: {
172
+ backgroundColor: colorScale[500],
173
+ color: white,
174
+ "&:hover": { backgroundColor: colorScale[600] }
175
+ }
176
+ },
177
+ {
178
+ props: {
179
+ color: colorName,
180
+ variant: "outlined"
181
+ },
182
+ style: {
183
+ borderColor: colorScale[500],
184
+ color: colorScale[600],
185
+ "&:hover": {
186
+ borderColor: colorScale[600],
187
+ backgroundColor: `${colorScale[50]}80`
188
+ }
189
+ }
190
+ },
191
+ {
192
+ props: {
193
+ color: colorName,
194
+ variant: "text"
195
+ },
196
+ style: {
197
+ color: colorScale[600],
198
+ "&:hover": { backgroundColor: `${colorScale[50]}80` }
199
+ }
200
+ }
201
+ ];
202
+ }
203
+ /**
204
+ * Helper to generate CircularProgress color variants
205
+ */
206
+ function createProgressColorVariant(colorName, colorScale) {
207
+ return {
208
+ props: { color: colorName },
209
+ style: { color: colorScale[500] }
210
+ };
211
+ }
212
+ /**
213
+ * Helper to generate Badge color variants
214
+ */
215
+ function createBadgeColorVariant(colorName, colorScale) {
216
+ return {
217
+ props: { color: colorName },
218
+ style: { "& .MuiBadge-badge": {
219
+ backgroundColor: colorScale[500],
220
+ color: white
221
+ } }
222
+ };
223
+ }
224
+ /**
225
+ * Helper to generate Chip color variants
226
+ */
227
+ function createChipColorVariants(colorName, colorScale) {
228
+ return [{
229
+ props: {
230
+ color: colorName,
231
+ variant: "filled"
232
+ },
233
+ style: {
234
+ backgroundColor: colorScale[500],
235
+ color: white,
236
+ "&:hover": { backgroundColor: colorScale[600] }
237
+ }
238
+ }, {
239
+ props: {
240
+ color: colorName,
241
+ variant: "outlined"
242
+ },
243
+ style: {
244
+ borderColor: colorScale[500],
245
+ color: colorScale[600]
246
+ }
247
+ }];
248
+ }
249
+ const buttonColorVariants = [
250
+ ...createButtonColorVariants("iochmara", colors.iochmara),
251
+ ...createButtonColorVariants("cyan", colors.cyan),
252
+ ...createButtonColorVariants("amber", colors.amber),
253
+ ...createButtonColorVariants("green", colors.green),
254
+ ...createButtonColorVariants("red", colors.red),
255
+ ...createButtonColorVariants("rose", colors.rose),
256
+ ...createButtonColorVariants("fuchsia", colors.fuchsia),
257
+ ...createButtonColorVariants("brand", colors.brand)
258
+ ];
259
+ const progressColorVariants = [
260
+ createProgressColorVariant("iochmara", colors.iochmara),
261
+ createProgressColorVariant("cyan", colors.cyan),
262
+ createProgressColorVariant("amber", colors.amber),
263
+ createProgressColorVariant("green", colors.green),
264
+ createProgressColorVariant("red", colors.red),
265
+ createProgressColorVariant("rose", colors.rose),
266
+ createProgressColorVariant("fuchsia", colors.fuchsia),
267
+ createProgressColorVariant("brand", colors.brand),
268
+ createProgressColorVariant("neutral", colors.neutral)
269
+ ];
270
+ const badgeColorVariants = [
271
+ createBadgeColorVariant("iochmara", colors.iochmara),
272
+ createBadgeColorVariant("cyan", colors.cyan),
273
+ createBadgeColorVariant("amber", colors.amber),
274
+ createBadgeColorVariant("green", colors.green),
275
+ createBadgeColorVariant("red", colors.red),
276
+ createBadgeColorVariant("rose", colors.rose),
277
+ createBadgeColorVariant("fuchsia", colors.fuchsia),
278
+ createBadgeColorVariant("brand", colors.brand),
279
+ createBadgeColorVariant("neutral", colors.neutral)
280
+ ];
281
+ const chipColorVariants = [
282
+ ...createChipColorVariants("iochmara", colors.iochmara),
283
+ ...createChipColorVariants("cyan", colors.cyan),
284
+ ...createChipColorVariants("amber", colors.amber),
285
+ ...createChipColorVariants("green", colors.green),
286
+ ...createChipColorVariants("red", colors.red),
287
+ ...createChipColorVariants("rose", colors.rose),
288
+ ...createChipColorVariants("fuchsia", colors.fuchsia),
289
+ ...createChipColorVariants("brand", colors.brand),
290
+ ...createChipColorVariants("neutral", colors.neutral)
291
+ ];
292
+ const componentOverrides = {
293
+ MuiButton: {
294
+ defaultProps: { disableElevation: true },
295
+ variants: [{
296
+ props: { size: "xsmall" },
297
+ style: {
298
+ padding: "0 0.5rem",
299
+ fontSize: "0.75rem",
300
+ fontWeight: 500,
301
+ borderRadius: 4,
302
+ minHeight: "unset",
303
+ lineHeight: 1.5
304
+ }
305
+ }, ...buttonColorVariants],
306
+ styleOverrides: {
307
+ root: ({ theme, ownerState }) => ({
308
+ textTransform: "none",
309
+ fontWeight: 500,
310
+ borderRadius: 6,
311
+ ...ownerState.color === "neutral" && ownerState.variant === "contained" && {
312
+ backgroundColor: colors.neutral[700],
313
+ color: white,
314
+ "&:hover": { backgroundColor: colors.neutral[800] }
315
+ },
316
+ ...ownerState.color === "neutral" && ownerState.variant === "outlined" && {
317
+ borderColor: theme.palette.mode === "dark" ? colors.neutral[500] : colors.neutral[300],
318
+ color: theme.palette.mode === "dark" ? colors.neutral[100] : colors.neutral[900],
319
+ "&:hover": {
320
+ borderColor: theme.palette.mode === "dark" ? colors.neutral[400] : colors.neutral[400],
321
+ backgroundColor: theme.palette.mode === "dark" ? colors.neutral[700] : colors.neutral[100]
322
+ }
323
+ },
324
+ ...ownerState.color === "neutral" && ownerState.variant === "text" && {
325
+ color: theme.palette.mode === "dark" ? colors.neutral[200] : colors.neutral[700],
326
+ "&:hover": { backgroundColor: theme.palette.mode === "dark" ? colors.neutral[700] : colors.neutral[100] }
327
+ }
328
+ }),
329
+ sizeSmall: {
330
+ padding: "0.25rem 0.75rem",
331
+ fontSize: "0.875rem"
332
+ },
333
+ sizeMedium: {
334
+ padding: "0.5rem 1rem",
335
+ fontSize: "1rem"
336
+ },
337
+ sizeLarge: {
338
+ padding: "0.75rem 1.5rem",
339
+ fontSize: "1.125rem"
340
+ },
341
+ contained: { "&:hover": { boxShadow: "none" } },
342
+ outlined: {
343
+ borderWidth: "1px",
344
+ "&:hover": { borderWidth: "1px" }
345
+ },
346
+ text: ({ theme }) => ({ "&:hover": { backgroundColor: theme.palette.mode === "dark" ? "rgba(255, 255, 255, 0.08)" : "rgba(0, 0, 0, 0.04)" } })
347
+ }
348
+ },
349
+ MuiIconButton: { styleOverrides: {
350
+ root: { borderRadius: 6 },
351
+ sizeSmall: { padding: 4 },
352
+ sizeMedium: { padding: 8 },
353
+ sizeLarge: { padding: 12 }
354
+ } },
355
+ MuiTextField: {
356
+ defaultProps: {
357
+ variant: "outlined",
358
+ size: "small"
359
+ },
360
+ styleOverrides: { root: { "& .MuiOutlinedInput-root": { borderRadius: 6 } } }
361
+ },
362
+ MuiOutlinedInput: { styleOverrides: {
363
+ root: {
364
+ borderRadius: 6,
365
+ "&:hover .MuiOutlinedInput-notchedOutline": { borderColor: colors.iochmara[400] },
366
+ "&.Mui-focused .MuiOutlinedInput-notchedOutline": {
367
+ borderColor: colors.iochmara[500],
368
+ borderWidth: 2
369
+ }
370
+ },
371
+ notchedOutline: ({ theme }) => ({ borderColor: theme.palette.mode === "dark" ? colors.neutral[600] : colors.neutral[300] })
372
+ } },
373
+ MuiCheckbox: {
374
+ defaultProps: { color: "primary" },
375
+ styleOverrides: { root: { borderRadius: 4 } }
376
+ },
377
+ MuiSwitch: { defaultProps: { color: "primary" } },
378
+ MuiDialog: { styleOverrides: { paper: { borderRadius: 8 } } },
379
+ MuiDialogTitle: { styleOverrides: { root: {
380
+ fontWeight: 600,
381
+ fontSize: "1.125rem"
382
+ } } },
383
+ MuiMenu: { styleOverrides: { paper: ({ theme }) => ({
384
+ borderRadius: 8,
385
+ boxShadow: theme.shadows[3]
386
+ }) } },
387
+ MuiMenuItem: { styleOverrides: { root: ({ theme }) => ({
388
+ fontSize: "0.875rem",
389
+ padding: "0.5rem 0.75rem",
390
+ "&:hover": { backgroundColor: theme.palette.mode === "dark" ? colors.neutral[600] : colors.neutral[100] },
391
+ "&.Mui-selected": {
392
+ backgroundColor: theme.palette.mode === "dark" ? colors.iochmara[900] : colors.iochmara[50],
393
+ "&:hover": { backgroundColor: theme.palette.mode === "dark" ? colors.iochmara[800] : colors.iochmara[100] }
394
+ }
395
+ }) } },
396
+ MuiChip: {
397
+ variants: [{
398
+ props: { size: "xsmall" },
399
+ style: {
400
+ height: 20,
401
+ fontSize: "0.625rem"
402
+ }
403
+ }, ...chipColorVariants],
404
+ styleOverrides: {
405
+ root: {
406
+ borderRadius: 6,
407
+ fontWeight: 500
408
+ },
409
+ sizeSmall: {
410
+ height: 24,
411
+ fontSize: "0.75rem"
412
+ },
413
+ sizeMedium: {
414
+ height: 32,
415
+ fontSize: "0.875rem"
416
+ }
417
+ }
418
+ },
419
+ MuiTooltip: { styleOverrides: {
420
+ tooltip: ({ theme }) => ({
421
+ backgroundColor: theme.palette.mode === "dark" ? colors.neutral[700] : colors.neutral[800],
422
+ fontSize: "0.75rem",
423
+ padding: "0.25rem 0.5rem",
424
+ borderRadius: 4
425
+ }),
426
+ arrow: ({ theme }) => ({ color: theme.palette.mode === "dark" ? colors.neutral[700] : colors.neutral[800] })
427
+ } },
428
+ MuiAlert: { styleOverrides: {
429
+ root: { borderRadius: 6 },
430
+ standardSuccess: ({ theme }) => ({
431
+ backgroundColor: theme.palette.mode === "dark" ? colors.green[900] : colors.green[50],
432
+ color: theme.palette.mode === "dark" ? colors.green[200] : colors.green[800]
433
+ }),
434
+ standardWarning: ({ theme }) => ({
435
+ backgroundColor: theme.palette.mode === "dark" ? colors.amber[900] : colors.amber[50],
436
+ color: theme.palette.mode === "dark" ? colors.amber[200] : colors.amber[800]
437
+ }),
438
+ standardError: ({ theme }) => ({
439
+ backgroundColor: theme.palette.mode === "dark" ? colors.red[900] : colors.red[50],
440
+ color: theme.palette.mode === "dark" ? colors.red[200] : colors.red[800]
441
+ }),
442
+ standardInfo: ({ theme }) => ({
443
+ backgroundColor: theme.palette.mode === "dark" ? colors.iochmara[900] : colors.iochmara[50],
444
+ color: theme.palette.mode === "dark" ? colors.iochmara[200] : colors.iochmara[800]
445
+ })
446
+ } },
447
+ MuiTabs: { styleOverrides: { indicator: { height: 2 } } },
448
+ MuiTab: { styleOverrides: { root: {
449
+ textTransform: "none",
450
+ fontWeight: 500,
451
+ minHeight: 48
452
+ } } },
453
+ MuiAvatar: { styleOverrides: { root: { fontWeight: 500 } } },
454
+ MuiBadge: {
455
+ variants: badgeColorVariants,
456
+ styleOverrides: { badge: {
457
+ fontWeight: 500,
458
+ fontSize: "0.75rem"
459
+ } }
460
+ },
461
+ MuiCircularProgress: {
462
+ defaultProps: { color: "primary" },
463
+ variants: progressColorVariants
464
+ },
465
+ MuiLink: {
466
+ defaultProps: {
467
+ underline: "hover",
468
+ fontWeight: 500
469
+ },
470
+ styleOverrides: { root: {
471
+ color: colors.iochmara[600],
472
+ textDecorationColor: colors.iochmara[300],
473
+ "&:hover": { color: colors.iochmara[700] }
474
+ } }
475
+ },
476
+ MuiPaper: { styleOverrides: { rounded: { borderRadius: 8 } } },
477
+ MuiPopover: { styleOverrides: { paper: ({ theme }) => ({
478
+ borderRadius: 8,
479
+ boxShadow: theme.shadows[3]
480
+ }) } },
481
+ MuiDivider: { styleOverrides: { root: ({ theme }) => ({ borderColor: theme.palette.mode === "dark" ? colors.neutral[700] : colors.neutral[200] }) } },
482
+ MuiBreadcrumbs: { styleOverrides: { separator: ({ theme }) => ({ color: theme.palette.mode === "dark" ? colors.neutral[500] : colors.neutral[400] }) } }
483
+ };
484
+ const baseThemeOptions = {
485
+ palette: {
486
+ primary: {
487
+ main: colors.iochmara[500],
488
+ light: colors.iochmara[300],
489
+ dark: colors.iochmara[600],
490
+ contrastText: white
491
+ },
492
+ secondary: {
493
+ main: colors.cyan[500],
494
+ light: colors.cyan[400],
495
+ dark: colors.cyan[600],
496
+ contrastText: white
497
+ },
498
+ success: {
499
+ main: colors.green[500],
500
+ light: colors.green[400],
501
+ dark: colors.green[600],
502
+ contrastText: white
503
+ },
504
+ warning: {
505
+ main: colors.amber[500],
506
+ light: colors.amber[400],
507
+ dark: colors.amber[600],
508
+ contrastText: white
509
+ },
510
+ error: {
511
+ main: colors.red[500],
512
+ light: colors.red[400],
513
+ dark: colors.red[600],
514
+ contrastText: white
515
+ },
516
+ grey: {
517
+ 50: colors.neutral[50],
518
+ 100: colors.neutral[100],
519
+ 200: colors.neutral[200],
520
+ 300: colors.neutral[300],
521
+ 400: colors.neutral[400],
522
+ 500: colors.neutral[500],
523
+ 600: colors.neutral[600],
524
+ 700: colors.neutral[700],
525
+ 800: colors.neutral[800],
526
+ 900: colors.neutral[900]
527
+ }
528
+ },
529
+ typography: {
530
+ fontFamily: "ui-sans-serif, system-ui, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\", \"Noto Color Emoji\"",
531
+ fontWeightLight: 300,
532
+ fontWeightRegular: 400,
533
+ fontWeightMedium: 500,
534
+ fontWeightBold: 700,
535
+ h1: {
536
+ fontWeight: 700,
537
+ fontSize: "2.25rem",
538
+ lineHeight: 1.2
539
+ },
540
+ h2: {
541
+ fontWeight: 700,
542
+ fontSize: "1.875rem",
543
+ lineHeight: 1.2
544
+ },
545
+ h3: {
546
+ fontWeight: 600,
547
+ fontSize: "1.5rem",
548
+ lineHeight: 1.3
549
+ },
550
+ h4: {
551
+ fontWeight: 600,
552
+ fontSize: "1.25rem",
553
+ lineHeight: 1.4
554
+ },
555
+ h5: {
556
+ fontWeight: 600,
557
+ fontSize: "1.125rem",
558
+ lineHeight: 1.4
559
+ },
560
+ h6: {
561
+ fontWeight: 600,
562
+ fontSize: "1rem",
563
+ lineHeight: 1.5
564
+ },
565
+ body1: {
566
+ fontSize: "0.875rem",
567
+ lineHeight: 1.5
568
+ },
569
+ body2: {
570
+ fontSize: "0.75rem",
571
+ lineHeight: 1.5
572
+ },
573
+ button: {
574
+ textTransform: "none",
575
+ fontWeight: 500
576
+ }
577
+ },
578
+ shape: { borderRadius: 6 },
579
+ spacing: 4,
580
+ components: componentOverrides
581
+ };
582
+ const lightThemeOptions = {
583
+ ...baseThemeOptions,
584
+ palette: {
585
+ ...baseThemeOptions.palette,
586
+ mode: "light",
587
+ background: {
588
+ default: white,
589
+ paper: white
590
+ },
591
+ text: {
592
+ primary: colors.neutral[900],
593
+ secondary: colors.neutral[600]
594
+ }
595
+ }
596
+ };
597
+ const darkThemeOptions = {
598
+ ...baseThemeOptions,
599
+ palette: {
600
+ ...baseThemeOptions.palette,
601
+ mode: "dark",
602
+ background: {
603
+ default: colors.neutral[900],
604
+ paper: colors.neutral[800]
605
+ },
606
+ text: {
607
+ primary: colors.neutral[50],
608
+ secondary: colors.neutral[400]
609
+ }
610
+ }
611
+ };
612
+ const lightTheme = createTheme(lightThemeOptions);
613
+ const darkTheme = createTheme(darkThemeOptions);
614
+ const muiTheme = lightTheme;
615
+ function createPaletteColor(colorScale) {
616
+ return {
617
+ main: colorScale[500],
618
+ light: colorScale[300],
619
+ dark: colorScale[600],
620
+ contrastText: white
621
+ };
622
+ }
623
+ const customPaletteAdditions = {
624
+ brand: createPaletteColor(colors.brand),
625
+ iochmara: {
626
+ main: colors.iochmara[500],
627
+ light: colors.iochmara[50],
628
+ dark: colors.iochmara[700],
629
+ contrastText: white
630
+ },
631
+ cyan: createPaletteColor(colors.cyan),
632
+ amber: createPaletteColor(colors.amber),
633
+ green: createPaletteColor(colors.green),
634
+ red: createPaletteColor(colors.red),
635
+ rose: createPaletteColor(colors.rose),
636
+ fuchsia: createPaletteColor(colors.fuchsia),
637
+ neutral: {
638
+ main: colors.neutral[500],
639
+ light: colors.neutral[300],
640
+ dark: colors.neutral[600],
641
+ contrastText: white
642
+ },
643
+ envBase: semanticColors.envBase,
644
+ envCurrent: semanticColors.envCurrent
645
+ };
646
+ Object.assign(lightTheme.palette, customPaletteAdditions);
647
+ Object.assign(darkTheme.palette, customPaletteAdditions);
648
+ /**
649
+ * Semantic variant mappings from Chakra-style tokens to scale values
650
+ * These map semantic names to numeric scale values in the color palette
651
+ */
652
+ const semanticVariantMap = {
653
+ solid: 600,
654
+ subtle: 50,
655
+ muted: 200,
656
+ emphasized: 500,
657
+ focusRing: 400,
658
+ light: 300
659
+ };
660
+ /**
661
+ * Color aliases - map Chakra color names to our color palette
662
+ */
663
+ const colorAliases = {
664
+ orange: "amber",
665
+ gray: "neutral"
666
+ };
667
+ /**
668
+ * Token lookup function to mimic Chakra UI's token API
669
+ * Usage: token("colors.green.solid") => "#16A34A"
670
+ */
671
+ function token(path) {
672
+ const parts = path.split(".");
673
+ if (parts[0] === "colors" && parts.length >= 3) {
674
+ let colorName = parts[1];
675
+ const variant = parts[2];
676
+ if (colorName in colorAliases) colorName = colorAliases[colorName];
677
+ if (colorName === "white") return white;
678
+ if (colorName === "black") return black;
679
+ if (colorName in semanticColors) {
680
+ const semantic = semanticColors[colorName];
681
+ if (typeof semantic === "object" && variant in semantic) return semantic[variant];
682
+ }
683
+ if (colorName in colors) {
684
+ const color = colors[colorName];
685
+ if (typeof color === "object" && variant in color) return color[variant];
686
+ if (variant in semanticVariantMap) {
687
+ const scaleValue = semanticVariantMap[variant];
688
+ if (typeof color === "object" && scaleValue in color) return color[scaleValue];
689
+ }
690
+ }
691
+ }
692
+ }
693
+
694
+ //#endregion
695
+ export { semanticColors as a, muiTheme as i, darkTheme as n, token as o, lightTheme as r, colors as t };
696
+ //# sourceMappingURL=mui-theme-CUhybmBq.mjs.map