@camstack/ui-library 0.1.39 → 0.1.41

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 (159) hide show
  1. package/dist/composites/addon-global-settings-form.d.ts +60 -0
  2. package/dist/composites/addon-page-props.d.ts +12 -0
  3. package/dist/composites/agent-step-editor.d.ts +15 -0
  4. package/dist/composites/app-shell/app-shell.d.ts +19 -0
  5. package/dist/composites/app-shell/index.d.ts +3 -0
  6. package/dist/composites/app-shell/sidebar-item.d.ts +10 -0
  7. package/dist/composites/app-shell/sidebar.d.ts +14 -0
  8. package/dist/composites/audio-classification-list.d.ts +20 -0
  9. package/dist/composites/audio-level-waveform.d.ts +35 -0
  10. package/dist/composites/audio-waveform.d.ts +20 -0
  11. package/dist/composites/battery-badge.d.ts +12 -0
  12. package/dist/composites/breadcrumb.d.ts +25 -0
  13. package/dist/composites/camera-stream-player.d.ts +87 -0
  14. package/dist/composites/code-block.d.ts +6 -0
  15. package/dist/composites/config-form-builder.d.ts +18 -0
  16. package/dist/composites/config-form-field.d.ts +70 -0
  17. package/dist/composites/confirm-action-button.d.ts +41 -0
  18. package/dist/composites/confirm-dialog.d.ts +13 -0
  19. package/dist/composites/data-table/data-table-header.d.ts +10 -0
  20. package/dist/composites/data-table/data-table-pagination.d.ts +9 -0
  21. package/dist/composites/data-table/data-table-row.d.ts +10 -0
  22. package/dist/composites/data-table/data-table.d.ts +2 -0
  23. package/dist/composites/data-table/index.d.ts +2 -0
  24. package/dist/composites/data-table/types.d.ts +34 -0
  25. package/dist/composites/data-table.d.ts +37 -0
  26. package/dist/composites/detection-canvas.d.ts +29 -0
  27. package/dist/composites/detection-colors.d.ts +15 -0
  28. package/dist/composites/detection-overlay.d.ts +9 -0
  29. package/dist/composites/detection-result-tree.d.ts +11 -0
  30. package/dist/composites/dev-shell.d.ts +20 -0
  31. package/dist/composites/device-activity-panel.d.ts +29 -0
  32. package/dist/composites/device-card.d.ts +38 -0
  33. package/dist/composites/device-grid.d.ts +12 -0
  34. package/dist/composites/device-item/actions.d.ts +9 -0
  35. package/dist/composites/device-item/children-accordion.d.ts +11 -0
  36. package/dist/composites/device-item/features.d.ts +17 -0
  37. package/dist/composites/device-item/header.d.ts +14 -0
  38. package/dist/composites/device-item/helpers.d.ts +147 -0
  39. package/dist/composites/device-item/index.d.ts +5 -0
  40. package/dist/composites/device-item/preview.d.ts +23 -0
  41. package/dist/composites/device-item/status-dot.d.ts +5 -0
  42. package/dist/composites/device-list/empty-state.d.ts +6 -0
  43. package/dist/composites/device-list/filter-chips.d.ts +19 -0
  44. package/dist/composites/device-list/group.d.ts +6 -0
  45. package/dist/composites/device-list/index.d.ts +31 -0
  46. package/dist/composites/device-list/pagination.d.ts +18 -0
  47. package/dist/composites/device-list/url-state.d.ts +24 -0
  48. package/dist/composites/discovery-panel.d.ts +26 -0
  49. package/dist/composites/doorbell-recent-panel.d.ts +10 -0
  50. package/dist/composites/empty-state.d.ts +10 -0
  51. package/dist/composites/event-stream.d.ts +48 -0
  52. package/dist/composites/filter-bar.d.ts +28 -0
  53. package/dist/composites/form-field.d.ts +11 -0
  54. package/dist/composites/image-selector.d.ts +25 -0
  55. package/dist/composites/index.d.ts +99 -0
  56. package/dist/composites/inference-config-selector.d.ts +44 -0
  57. package/dist/composites/kebab-menu.d.ts +39 -0
  58. package/dist/composites/key-value-list.d.ts +9 -0
  59. package/dist/composites/log-stream.d.ts +61 -0
  60. package/dist/composites/login-form.d.ts +8 -0
  61. package/dist/composites/mount-addon-page.d.ts +16 -0
  62. package/dist/composites/node-picker.d.ts +15 -0
  63. package/dist/composites/page-header.d.ts +8 -0
  64. package/dist/composites/phase-icon.d.ts +5 -0
  65. package/dist/composites/pipeline-builder.d.ts +43 -0
  66. package/dist/composites/pipeline-runtime-selector.d.ts +16 -0
  67. package/dist/composites/pipeline-step.d.ts +65 -0
  68. package/dist/composites/pipeline-tree-matrix.d.ts +31 -0
  69. package/dist/composites/provider-badge.d.ts +7 -0
  70. package/dist/composites/ptz-overlay.d.ts +20 -0
  71. package/dist/composites/response-log.d.ts +9 -0
  72. package/dist/composites/slide-over-panel.d.ts +11 -0
  73. package/dist/composites/snapshot-button.d.ts +25 -0
  74. package/dist/composites/stat-card.d.ts +10 -0
  75. package/dist/composites/state-values-stream.d.ts +30 -0
  76. package/dist/composites/status-badge.d.ts +10 -0
  77. package/dist/composites/step-timings.d.ts +9 -0
  78. package/dist/composites/step-tree-master.d.ts +28 -0
  79. package/dist/composites/stream-panel.d.ts +143 -0
  80. package/dist/composites/version-badge.d.ts +24 -0
  81. package/dist/composites/widget-slot.d.ts +20 -0
  82. package/dist/contexts/custom-field-renderers.d.ts +26 -0
  83. package/dist/contexts/device-context.d.ts +20 -0
  84. package/dist/contexts/player-overlays.d.ts +56 -0
  85. package/dist/contexts/system-context.d.ts +19 -0
  86. package/dist/contexts/widget-registry.d.ts +68 -0
  87. package/dist/contexts/zone-editing.d.ts +59 -0
  88. package/dist/generated/system-hooks.d.ts +933 -0
  89. package/dist/hooks/index.d.ts +27 -0
  90. package/dist/hooks/use-cluster-nodes.d.ts +17 -0
  91. package/dist/hooks/use-debounced-string.d.ts +1 -0
  92. package/dist/hooks/use-device-battery.d.ts +14 -0
  93. package/dist/hooks/use-device-capability.d.ts +17 -0
  94. package/dist/hooks/use-device-detections.d.ts +50 -0
  95. package/dist/hooks/use-device-features.d.ts +25 -0
  96. package/dist/hooks/use-device-proxy.d.ts +106 -0
  97. package/dist/hooks/use-device-snapshot.d.ts +10 -0
  98. package/dist/hooks/use-device-webrtc.d.ts +108 -0
  99. package/dist/hooks/use-devices.d.ts +13 -0
  100. package/dist/hooks/use-doorbell-events.d.ts +20 -0
  101. package/dist/hooks/use-event-invalidation.d.ts +1 -0
  102. package/dist/hooks/use-event-stream.d.ts +5 -0
  103. package/dist/hooks/use-is-mobile.d.ts +8 -0
  104. package/dist/hooks/use-live-buffer.d.ts +8 -0
  105. package/dist/hooks/use-live-event.d.ts +3 -0
  106. package/dist/hooks/use-ptz.d.ts +54 -0
  107. package/dist/hooks/use-system-query.d.ts +12 -0
  108. package/dist/icons/index.d.ts +2 -0
  109. package/dist/icons/provider-icons.d.ts +3 -0
  110. package/dist/icons/status-icons.d.ts +3 -0
  111. package/dist/index.cjs +23485 -14252
  112. package/dist/index.cjs.map +1 -1
  113. package/dist/index.d.ts +14 -3787
  114. package/dist/index.js +22811 -13741
  115. package/dist/index.js.map +1 -1
  116. package/dist/lib/cn.d.ts +2 -0
  117. package/dist/lib/index.d.ts +8 -0
  118. package/dist/lib/mf-runtime-init.d.ts +1 -0
  119. package/dist/lib/phase-config.d.ts +16 -0
  120. package/dist/lib/pipeline-mirror.d.ts +23 -0
  121. package/dist/lib/responsive.d.ts +81 -0
  122. package/dist/lib/shared-context.d.ts +5 -0
  123. package/dist/lib/validate-template.d.ts +2 -0
  124. package/dist/primitives/badge.d.ts +11 -0
  125. package/dist/primitives/bottom-sheet.d.ts +9 -0
  126. package/dist/primitives/button.d.ts +10 -0
  127. package/dist/primitives/card.d.ts +9 -0
  128. package/dist/primitives/checkbox.d.ts +4 -0
  129. package/dist/primitives/collapsible-card.d.ts +15 -0
  130. package/dist/primitives/dialog.d.ts +20 -0
  131. package/dist/primitives/dropdown.d.ts +19 -0
  132. package/dist/primitives/floating-panel.d.ts +22 -0
  133. package/dist/primitives/icon-button.d.ts +13 -0
  134. package/dist/primitives/index.d.ts +21 -0
  135. package/dist/primitives/input.d.ts +11 -0
  136. package/dist/primitives/label.d.ts +4 -0
  137. package/dist/primitives/mobile-drawer.d.ts +10 -0
  138. package/dist/primitives/popover.d.ts +10 -0
  139. package/dist/primitives/scroll-area.d.ts +4 -0
  140. package/dist/primitives/select.d.ts +9 -0
  141. package/dist/primitives/separator.d.ts +9 -0
  142. package/dist/primitives/skeleton.d.ts +4 -0
  143. package/dist/primitives/switch.d.ts +7 -0
  144. package/dist/primitives/tabs.d.ts +17 -0
  145. package/dist/primitives/tooltip.d.ts +6 -0
  146. package/dist/theme/create-theme.d.ts +2 -0
  147. package/dist/theme/defaults.d.ts +4 -0
  148. package/dist/theme/index.cjs +228 -248
  149. package/dist/theme/index.cjs.map +1 -1
  150. package/dist/theme/index.d.ts +6 -128
  151. package/dist/theme/index.js +212 -214
  152. package/dist/theme/index.js.map +1 -1
  153. package/dist/theme/theme-provider.d.ts +10 -0
  154. package/dist/theme/theme-to-css.d.ts +2 -0
  155. package/dist/theme/{index.d.cts → types.d.ts} +5 -27
  156. package/dist/theme/use-theme-mode.d.ts +2 -0
  157. package/dist/trpc-react.d.ts +7 -0
  158. package/package.json +5 -3
  159. package/dist/index.d.cts +0 -3787
@@ -1,200 +1,178 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
-
20
- // src/theme/index.ts
21
- var theme_exports = {};
22
- __export(theme_exports, {
23
- ThemeProvider: () => ThemeProvider,
24
- createTheme: () => createTheme,
25
- darkColors: () => darkColors,
26
- defaultTheme: () => defaultTheme,
27
- lightColors: () => lightColors,
28
- themeToCss: () => themeToCss,
29
- useThemeMode: () => useThemeMode
30
- });
31
- module.exports = __toCommonJS(theme_exports);
32
-
33
- // src/theme/defaults.ts
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
2
+ require("../index.cjs");
3
+ let react = require("react");
4
+ let react_jsx_runtime = require("react/jsx-runtime");
5
+ //#region src/theme/defaults.ts
34
6
  var providerColors = {
35
- frigate: "#3b82f6",
36
- scrypted: "#a855f7",
37
- reolink: "#06b6d4",
38
- homeAssistant: "#22d3ee",
39
- rtsp: "#78716c"
7
+ frigate: "#3b82f6",
8
+ scrypted: "#a855f7",
9
+ reolink: "#06b6d4",
10
+ homeAssistant: "#22d3ee",
11
+ rtsp: "#78716c"
40
12
  };
41
13
  var darkColors = {
42
- primary: "#f59e42",
43
- primaryForeground: "#0c0a09",
44
- background: "#0c0a09",
45
- backgroundElevated: "#1c1917",
46
- surface: "#1c1917",
47
- surfaceHover: "#292524",
48
- border: "#292524",
49
- borderSubtle: "#1c1917",
50
- foreground: "#fafaf9",
51
- foregroundMuted: "#a8a29e",
52
- foregroundSubtle: "#78716c",
53
- foregroundDisabled: "#57534e",
54
- success: "#4ade80",
55
- warning: "#fbbf24",
56
- danger: "#f87171",
57
- info: "#60a5fa",
58
- provider: providerColors
14
+ primary: "#f59e42",
15
+ primaryForeground: "#0c0a09",
16
+ background: "#0c0a09",
17
+ backgroundElevated: "#1c1917",
18
+ surface: "#1c1917",
19
+ surfaceHover: "#292524",
20
+ border: "#292524",
21
+ borderSubtle: "#1c1917",
22
+ foreground: "#fafaf9",
23
+ foregroundMuted: "#a8a29e",
24
+ foregroundSubtle: "#78716c",
25
+ foregroundDisabled: "#57534e",
26
+ success: "#4ade80",
27
+ warning: "#fbbf24",
28
+ danger: "#f87171",
29
+ info: "#60a5fa",
30
+ provider: providerColors
59
31
  };
60
32
  var lightColors = {
61
- primary: "#e67e22",
62
- primaryForeground: "#ffffff",
63
- background: "#fafaf9",
64
- backgroundElevated: "#ffffff",
65
- surface: "#f5f5f4",
66
- surfaceHover: "#e7e5e4",
67
- border: "#d6d3d1",
68
- borderSubtle: "#e7e5e4",
69
- foreground: "#1c1917",
70
- foregroundMuted: "#57534e",
71
- foregroundSubtle: "#78716c",
72
- foregroundDisabled: "#a8a29e",
73
- success: "#16a34a",
74
- warning: "#d97706",
75
- danger: "#dc2626",
76
- info: "#2563eb",
77
- provider: providerColors
33
+ primary: "#e67e22",
34
+ primaryForeground: "#ffffff",
35
+ background: "#fafaf9",
36
+ backgroundElevated: "#ffffff",
37
+ surface: "#f5f5f4",
38
+ surfaceHover: "#e7e5e4",
39
+ border: "#d6d3d1",
40
+ borderSubtle: "#e7e5e4",
41
+ foreground: "#1c1917",
42
+ foregroundMuted: "#57534e",
43
+ foregroundSubtle: "#78716c",
44
+ foregroundDisabled: "#a8a29e",
45
+ success: "#16a34a",
46
+ warning: "#d97706",
47
+ danger: "#dc2626",
48
+ info: "#2563eb",
49
+ provider: providerColors
78
50
  };
79
51
  var defaultTheme = {
80
- colors: {
81
- dark: darkColors,
82
- light: lightColors
83
- },
84
- spacing: {
85
- xs: 2,
86
- sm: 4,
87
- md: 8,
88
- lg: 12,
89
- xl: 16,
90
- "2xl": 24,
91
- "3xl": 32
92
- },
93
- radius: {
94
- sm: 4,
95
- md: 6,
96
- lg: 8,
97
- xl: 12
98
- },
99
- typography: {
100
- fontFamily: '-apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif',
101
- sizes: {
102
- xs: { fontSize: 10, lineHeight: 14 },
103
- sm: { fontSize: 11, lineHeight: 16 },
104
- base: { fontSize: 12, lineHeight: 18 },
105
- lg: { fontSize: 13, lineHeight: 18 },
106
- xl: { fontSize: 14, lineHeight: 20 },
107
- "2xl": { fontSize: 16, lineHeight: 22 },
108
- "3xl": { fontSize: 20, lineHeight: 28 }
109
- },
110
- weights: {
111
- regular: 400,
112
- medium: 500,
113
- semibold: 600,
114
- bold: 700
115
- }
116
- },
117
- table: {
118
- rowHeight: 28,
119
- headerHeight: 24,
120
- cellPaddingX: 8,
121
- cellPaddingY: 6
122
- },
123
- sidebar: {
124
- width: 176,
125
- itemHeight: 28,
126
- iconSize: 14
127
- }
52
+ colors: {
53
+ dark: darkColors,
54
+ light: lightColors
55
+ },
56
+ spacing: {
57
+ xs: 2,
58
+ sm: 4,
59
+ md: 8,
60
+ lg: 12,
61
+ xl: 16,
62
+ "2xl": 24,
63
+ "3xl": 32
64
+ },
65
+ radius: {
66
+ sm: 4,
67
+ md: 6,
68
+ lg: 8,
69
+ xl: 12
70
+ },
71
+ typography: {
72
+ fontFamily: "-apple-system, BlinkMacSystemFont, \"Segoe UI\", sans-serif",
73
+ sizes: {
74
+ xs: {
75
+ fontSize: 10,
76
+ lineHeight: 14
77
+ },
78
+ sm: {
79
+ fontSize: 11,
80
+ lineHeight: 16
81
+ },
82
+ base: {
83
+ fontSize: 12,
84
+ lineHeight: 18
85
+ },
86
+ lg: {
87
+ fontSize: 13,
88
+ lineHeight: 18
89
+ },
90
+ xl: {
91
+ fontSize: 14,
92
+ lineHeight: 20
93
+ },
94
+ "2xl": {
95
+ fontSize: 16,
96
+ lineHeight: 22
97
+ },
98
+ "3xl": {
99
+ fontSize: 20,
100
+ lineHeight: 28
101
+ }
102
+ },
103
+ weights: {
104
+ regular: 400,
105
+ medium: 500,
106
+ semibold: 600,
107
+ bold: 700
108
+ }
109
+ },
110
+ table: {
111
+ rowHeight: 28,
112
+ headerHeight: 24,
113
+ cellPaddingX: 8,
114
+ cellPaddingY: 6
115
+ },
116
+ sidebar: {
117
+ width: 176,
118
+ itemHeight: 28,
119
+ iconSize: 14
120
+ }
128
121
  };
129
-
130
- // src/theme/create-theme.ts
122
+ //#endregion
123
+ //#region src/theme/create-theme.ts
131
124
  function deepMerge(target, source) {
132
- const result = { ...target };
133
- for (const key in source) {
134
- const sourceVal = source[key];
135
- const targetVal = target[key];
136
- if (sourceVal !== void 0 && typeof sourceVal === "object" && sourceVal !== null && !Array.isArray(sourceVal) && typeof targetVal === "object" && targetVal !== null) {
137
- result[key] = deepMerge(
138
- targetVal,
139
- sourceVal
140
- );
141
- } else if (sourceVal !== void 0) {
142
- result[key] = sourceVal;
143
- }
144
- }
145
- return result;
125
+ const result = { ...target };
126
+ for (const key in source) {
127
+ const sourceVal = source[key];
128
+ const targetVal = target[key];
129
+ if (sourceVal !== void 0 && typeof sourceVal === "object" && sourceVal !== null && !Array.isArray(sourceVal) && typeof targetVal === "object" && targetVal !== null) result[key] = deepMerge(targetVal, sourceVal);
130
+ else if (sourceVal !== void 0) result[key] = sourceVal;
131
+ }
132
+ return result;
146
133
  }
147
134
  function createTheme(overrides) {
148
- if (!overrides) return structuredClone(defaultTheme);
149
- return deepMerge(structuredClone(defaultTheme), overrides);
135
+ if (!overrides) return structuredClone(defaultTheme);
136
+ return deepMerge(structuredClone(defaultTheme), overrides);
150
137
  }
151
-
152
- // src/theme/theme-to-css.ts
138
+ //#endregion
139
+ //#region src/theme/theme-to-css.ts
153
140
  function camelToKebab(str) {
154
- return str.replace(/[A-Z]/g, (m) => `-${m.toLowerCase()}`);
141
+ return str.replace(/[A-Z]/g, (m) => `-${m.toLowerCase()}`);
155
142
  }
156
143
  function colorTokenToCssVar(key) {
157
- return `--color-${camelToKebab(key)}`;
144
+ return `--color-${camelToKebab(key)}`;
158
145
  }
159
146
  function generateColorBlock(colors) {
160
- const lines = [];
161
- for (const [key, value] of Object.entries(colors)) {
162
- if (key === "provider") continue;
163
- lines.push(` ${colorTokenToCssVar(key)}: ${value};`);
164
- }
165
- return lines.join("\n");
147
+ const lines = [];
148
+ for (const [key, value] of Object.entries(colors)) {
149
+ if (key === "provider") continue;
150
+ lines.push(` ${colorTokenToCssVar(key)}: ${value};`);
151
+ }
152
+ return lines.join("\n");
166
153
  }
167
154
  function generateProviderColors(provider) {
168
- const lines = [];
169
- for (const [key, value] of Object.entries(provider)) {
170
- lines.push(` --color-provider-${camelToKebab(key)}: ${value};`);
171
- }
172
- return lines.join("\n");
155
+ const lines = [];
156
+ for (const [key, value] of Object.entries(provider)) lines.push(` --color-provider-${camelToKebab(key)}: ${value};`);
157
+ return lines.join("\n");
173
158
  }
174
159
  function generateSpacingTokens(spacing) {
175
- const lines = [];
176
- for (const [key, value] of Object.entries(spacing)) {
177
- lines.push(` --spacing-${key}: ${value}px;`);
178
- }
179
- return lines.join("\n");
160
+ const lines = [];
161
+ for (const [key, value] of Object.entries(spacing)) lines.push(` --spacing-${key}: ${value}px;`);
162
+ return lines.join("\n");
180
163
  }
181
164
  function generateRadiusTokens(radius) {
182
- const lines = [];
183
- for (const [key, value] of Object.entries(radius)) {
184
- lines.push(` --radius-${key}: ${value}px;`);
185
- }
186
- return lines.join("\n");
165
+ const lines = [];
166
+ for (const [key, value] of Object.entries(radius)) lines.push(` --radius-${key}: ${value}px;`);
167
+ return lines.join("\n");
187
168
  }
188
169
  function themeToCss(theme) {
189
- const darkColorBlock = generateColorBlock(theme.colors.dark);
190
- const lightColorBlock = generateColorBlock(theme.colors.light);
191
- const providerBlock = generateProviderColors(theme.colors.dark.provider);
192
- const spacingBlock = generateSpacingTokens(theme.spacing);
193
- const radiusBlock = generateRadiusTokens(theme.radius);
194
- return `@theme {
195
- ${providerBlock}
196
- ${spacingBlock}
197
- ${radiusBlock}
170
+ const darkColorBlock = generateColorBlock(theme.colors.dark);
171
+ const lightColorBlock = generateColorBlock(theme.colors.light);
172
+ return `@theme {
173
+ ${generateProviderColors(theme.colors.dark.provider)}
174
+ ${generateSpacingTokens(theme.spacing)}
175
+ ${generateRadiusTokens(theme.radius)}
198
176
  }
199
177
 
200
178
  .dark {
@@ -218,89 +196,91 @@ ${lightColorBlock.replace(/^ {2}/gm, " ")}
218
196
  }
219
197
  `;
220
198
  }
221
-
222
- // src/theme/theme-provider.tsx
223
- var import_react = require("react");
224
- var import_jsx_runtime = require("react/jsx-runtime");
225
- var ThemeContext = (0, import_react.createContext)(null);
226
- var TOGGLE_ORDER = ["dark", "light", "system"];
199
+ //#endregion
200
+ //#region src/theme/theme-provider.tsx
201
+ var ThemeContext = (0, react.createContext)(null);
202
+ var TOGGLE_ORDER = [
203
+ "dark",
204
+ "light",
205
+ "system"
206
+ ];
227
207
  function getSystemPreference() {
228
- if (typeof window === "undefined") return "dark";
229
- return window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light";
208
+ if (typeof window === "undefined") return "dark";
209
+ return window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light";
230
210
  }
231
211
  function getInitialMode(storageKey, defaultMode) {
232
- if (typeof window === "undefined") return defaultMode;
233
- const stored = localStorage.getItem(storageKey);
234
- if (stored === "dark" || stored === "light" || stored === "system") {
235
- return stored;
236
- }
237
- return defaultMode;
212
+ if (typeof window === "undefined") return defaultMode;
213
+ const stored = localStorage.getItem(storageKey);
214
+ if (stored === "dark" || stored === "light" || stored === "system") return stored;
215
+ return defaultMode;
238
216
  }
239
217
  function resolveMode(mode) {
240
- if (mode === "system") return getSystemPreference();
241
- return mode;
218
+ if (mode === "system") return getSystemPreference();
219
+ return mode;
242
220
  }
243
- function ThemeProvider({
244
- children,
245
- defaultMode = "system",
246
- storageKey = "camstack-theme-mode"
247
- }) {
248
- const [mode, setModeState] = (0, import_react.useState)(() => getInitialMode(storageKey, defaultMode));
249
- const [resolvedMode, setResolvedMode] = (0, import_react.useState)(() => resolveMode(mode));
250
- const setMode = (0, import_react.useCallback)(
251
- (newMode) => {
252
- setModeState(newMode);
253
- setResolvedMode(resolveMode(newMode));
254
- if (typeof window !== "undefined") {
255
- localStorage.setItem(storageKey, newMode);
256
- }
257
- },
258
- [storageKey]
259
- );
260
- const toggleMode = (0, import_react.useCallback)(() => {
261
- const currentIndex = TOGGLE_ORDER.indexOf(mode);
262
- const nextIndex = (currentIndex + 1) % TOGGLE_ORDER.length;
263
- setMode(TOGGLE_ORDER[nextIndex] ?? "dark");
264
- }, [mode, setMode]);
265
- (0, import_react.useEffect)(() => {
266
- if (typeof document === "undefined") return;
267
- const root = document.documentElement;
268
- root.classList.remove("dark", "light");
269
- root.classList.add(resolvedMode);
270
- }, [mode, resolvedMode]);
271
- (0, import_react.useEffect)(() => {
272
- if (typeof window === "undefined" || mode !== "system") return;
273
- const mediaQuery = window.matchMedia("(prefers-color-scheme: dark)");
274
- const handleChange = () => {
275
- setResolvedMode(getSystemPreference());
276
- };
277
- mediaQuery.addEventListener("change", handleChange);
278
- return () => mediaQuery.removeEventListener("change", handleChange);
279
- }, [mode]);
280
- const value = (0, import_react.useMemo)(
281
- () => ({ mode, resolvedMode, setMode, toggleMode }),
282
- [mode, resolvedMode, setMode, toggleMode]
283
- );
284
- return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(ThemeContext.Provider, { value, children });
221
+ function ThemeProvider({ children, defaultMode = "system", storageKey = "camstack-theme-mode" }) {
222
+ const [mode, setModeState] = (0, react.useState)(() => getInitialMode(storageKey, defaultMode));
223
+ const [resolvedMode, setResolvedMode] = (0, react.useState)(() => resolveMode(mode));
224
+ const setMode = (0, react.useCallback)((newMode) => {
225
+ setModeState(newMode);
226
+ setResolvedMode(resolveMode(newMode));
227
+ if (typeof window !== "undefined") localStorage.setItem(storageKey, newMode);
228
+ }, [storageKey]);
229
+ const toggleMode = (0, react.useCallback)(() => {
230
+ setMode(TOGGLE_ORDER[(TOGGLE_ORDER.indexOf(mode) + 1) % TOGGLE_ORDER.length] ?? "dark");
231
+ }, [mode, setMode]);
232
+ (0, react.useEffect)(() => {
233
+ if (typeof document === "undefined") return;
234
+ const root = document.documentElement;
235
+ root.classList.remove("dark", "light");
236
+ root.classList.add(resolvedMode);
237
+ }, [mode, resolvedMode]);
238
+ (0, react.useEffect)(() => {
239
+ if (typeof window === "undefined" || mode !== "system") return;
240
+ const mediaQuery = window.matchMedia("(prefers-color-scheme: dark)");
241
+ const handleChange = () => {
242
+ setResolvedMode(getSystemPreference());
243
+ };
244
+ mediaQuery.addEventListener("change", handleChange);
245
+ return () => mediaQuery.removeEventListener("change", handleChange);
246
+ }, [mode]);
247
+ const value = (0, react.useMemo)(() => ({
248
+ mode,
249
+ resolvedMode,
250
+ setMode,
251
+ toggleMode
252
+ }), [
253
+ mode,
254
+ resolvedMode,
255
+ setMode,
256
+ toggleMode
257
+ ]);
258
+ return /* @__PURE__ */ (0, react_jsx_runtime.jsx)(ThemeContext.Provider, {
259
+ value,
260
+ children
261
+ });
285
262
  }
286
-
287
- // src/theme/use-theme-mode.ts
288
- var import_react2 = require("react");
263
+ //#endregion
264
+ //#region src/theme/use-theme-mode.ts
289
265
  function useThemeMode() {
290
- const context = (0, import_react2.useContext)(ThemeContext);
291
- if (!context) {
292
- throw new Error("useThemeMode must be used within a ThemeProvider");
293
- }
294
- return context;
266
+ const context = (0, react.useContext)(ThemeContext);
267
+ if (!context) throw new Error("useThemeMode must be used within a ThemeProvider");
268
+ return context;
295
269
  }
296
- // Annotate the CommonJS export names for ESM import in node:
297
- 0 && (module.exports = {
298
- ThemeProvider,
299
- createTheme,
300
- darkColors,
301
- defaultTheme,
302
- lightColors,
303
- themeToCss,
304
- useThemeMode
305
- });
270
+ //#endregion
271
+ exports.ThemeProvider = ThemeProvider;
272
+ exports.ThemeProvider$1 = ThemeProvider;
273
+ exports.createTheme = createTheme;
274
+ exports.createTheme$1 = createTheme;
275
+ exports.darkColors = darkColors;
276
+ exports.darkColors$1 = darkColors;
277
+ exports.defaultTheme = defaultTheme;
278
+ exports.defaultTheme$1 = defaultTheme;
279
+ exports.lightColors = lightColors;
280
+ exports.lightColors$1 = lightColors;
281
+ exports.themeToCss = themeToCss;
282
+ exports.themeToCss$1 = themeToCss;
283
+ exports.useThemeMode = useThemeMode;
284
+ exports.useThemeMode$1 = useThemeMode;
285
+
306
286
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/theme/index.ts","../../src/theme/defaults.ts","../../src/theme/create-theme.ts","../../src/theme/theme-to-css.ts","../../src/theme/theme-provider.tsx","../../src/theme/use-theme-mode.ts"],"sourcesContent":["export type {\n CamStackColorTokens,\n CamStackTheme,\n ThemeMode,\n DeepPartial,\n UseThemeModeReturn,\n} from './types'\n\nexport { darkColors, lightColors, defaultTheme } from './defaults'\nexport { createTheme } from './create-theme'\nexport { themeToCss } from './theme-to-css'\nexport { ThemeProvider } from './theme-provider'\nexport { useThemeMode } from './use-theme-mode'\n","import type { CamStackColorTokens, CamStackTheme } from './types'\n\nconst providerColors: CamStackColorTokens['provider'] = {\n frigate: '#3b82f6',\n scrypted: '#a855f7',\n reolink: '#06b6d4',\n homeAssistant: '#22d3ee',\n rtsp: '#78716c',\n}\n\nexport const darkColors: CamStackColorTokens = {\n primary: '#f59e42',\n primaryForeground: '#0c0a09',\n background: '#0c0a09',\n backgroundElevated: '#1c1917',\n surface: '#1c1917',\n surfaceHover: '#292524',\n border: '#292524',\n borderSubtle: '#1c1917',\n foreground: '#fafaf9',\n foregroundMuted: '#a8a29e',\n foregroundSubtle: '#78716c',\n foregroundDisabled: '#57534e',\n success: '#4ade80',\n warning: '#fbbf24',\n danger: '#f87171',\n info: '#60a5fa',\n provider: providerColors,\n}\n\nexport const lightColors: CamStackColorTokens = {\n primary: '#e67e22',\n primaryForeground: '#ffffff',\n background: '#fafaf9',\n backgroundElevated: '#ffffff',\n surface: '#f5f5f4',\n surfaceHover: '#e7e5e4',\n border: '#d6d3d1',\n borderSubtle: '#e7e5e4',\n foreground: '#1c1917',\n foregroundMuted: '#57534e',\n foregroundSubtle: '#78716c',\n foregroundDisabled: '#a8a29e',\n success: '#16a34a',\n warning: '#d97706',\n danger: '#dc2626',\n info: '#2563eb',\n provider: providerColors,\n}\n\nexport const defaultTheme: CamStackTheme = {\n colors: {\n dark: darkColors,\n light: lightColors,\n },\n spacing: {\n xs: 2,\n sm: 4,\n md: 8,\n lg: 12,\n xl: 16,\n '2xl': 24,\n '3xl': 32,\n },\n radius: {\n sm: 4,\n md: 6,\n lg: 8,\n xl: 12,\n },\n typography: {\n fontFamily: '-apple-system, BlinkMacSystemFont, \"Segoe UI\", sans-serif',\n sizes: {\n xs: { fontSize: 10, lineHeight: 14 },\n sm: { fontSize: 11, lineHeight: 16 },\n base: { fontSize: 12, lineHeight: 18 },\n lg: { fontSize: 13, lineHeight: 18 },\n xl: { fontSize: 14, lineHeight: 20 },\n '2xl': { fontSize: 16, lineHeight: 22 },\n '3xl': { fontSize: 20, lineHeight: 28 },\n },\n weights: {\n regular: 400,\n medium: 500,\n semibold: 600,\n bold: 700,\n },\n },\n table: {\n rowHeight: 28,\n headerHeight: 24,\n cellPaddingX: 8,\n cellPaddingY: 6,\n },\n sidebar: {\n width: 176,\n itemHeight: 28,\n iconSize: 14,\n },\n}\n","import type { CamStackTheme, DeepPartial } from './types'\nimport { defaultTheme } from './defaults'\n\nfunction deepMerge<T extends object>(target: T, source: DeepPartial<T>): T {\n const result = { ...target }\n for (const key in source) {\n const sourceVal = source[key]\n const targetVal = target[key]\n if (\n sourceVal !== undefined &&\n typeof sourceVal === 'object' &&\n sourceVal !== null &&\n !Array.isArray(sourceVal) &&\n typeof targetVal === 'object' &&\n targetVal !== null\n ) {\n result[key] = deepMerge(\n targetVal as Record<string, unknown>,\n sourceVal as Record<string, unknown>,\n ) as T[typeof key]\n } else if (sourceVal !== undefined) {\n result[key] = sourceVal as T[typeof key]\n }\n }\n return result\n}\n\nexport function createTheme(overrides?: DeepPartial<CamStackTheme>): CamStackTheme {\n if (!overrides) return structuredClone(defaultTheme)\n return deepMerge(structuredClone(defaultTheme), overrides)\n}\n","import type { CamStackColorTokens, CamStackTheme } from './types'\n\nfunction camelToKebab(str: string): string {\n return str.replace(/[A-Z]/g, (m) => `-${m.toLowerCase()}`)\n}\n\nfunction colorTokenToCssVar(key: string): string {\n return `--color-${camelToKebab(key)}`\n}\n\nfunction generateColorBlock(colors: CamStackColorTokens): string {\n const lines: string[] = []\n for (const [key, value] of Object.entries(colors)) {\n if (key === 'provider') continue\n lines.push(` ${colorTokenToCssVar(key)}: ${value};`)\n }\n return lines.join('\\n')\n}\n\nfunction generateProviderColors(provider: CamStackColorTokens['provider']): string {\n const lines: string[] = []\n for (const [key, value] of Object.entries(provider)) {\n lines.push(` --color-provider-${camelToKebab(key)}: ${value};`)\n }\n return lines.join('\\n')\n}\n\nfunction generateSpacingTokens(spacing: CamStackTheme['spacing']): string {\n const lines: string[] = []\n for (const [key, value] of Object.entries(spacing)) {\n lines.push(` --spacing-${key}: ${value}px;`)\n }\n return lines.join('\\n')\n}\n\nfunction generateRadiusTokens(radius: CamStackTheme['radius']): string {\n const lines: string[] = []\n for (const [key, value] of Object.entries(radius)) {\n lines.push(` --radius-${key}: ${value}px;`)\n }\n return lines.join('\\n')\n}\n\nexport function themeToCss(theme: CamStackTheme): string {\n const darkColorBlock = generateColorBlock(theme.colors.dark)\n const lightColorBlock = generateColorBlock(theme.colors.light)\n const providerBlock = generateProviderColors(theme.colors.dark.provider)\n const spacingBlock = generateSpacingTokens(theme.spacing)\n const radiusBlock = generateRadiusTokens(theme.radius)\n\n return `@theme {\n${providerBlock}\n${spacingBlock}\n${radiusBlock}\n}\n\n.dark {\n${darkColorBlock}\n}\n\n.light {\n${lightColorBlock}\n}\n\n@media (prefers-color-scheme: dark) {\n :root {\n${darkColorBlock.replace(/^ {2}/gm, ' ')}\n }\n}\n\n@media (prefers-color-scheme: light) {\n :root {\n${lightColorBlock.replace(/^ {2}/gm, ' ')}\n }\n}\n`\n}\n","import { createContext, useCallback, useEffect, useMemo, useState } from 'react'\nimport type { ReactNode } from 'react'\nimport type { ThemeMode, UseThemeModeReturn } from './types'\n\nexport const ThemeContext = createContext<UseThemeModeReturn | null>(null)\n\ninterface ThemeProviderProps {\n children: ReactNode\n defaultMode?: ThemeMode\n storageKey?: string\n}\n\nconst TOGGLE_ORDER: readonly ThemeMode[] = ['dark', 'light', 'system'] as const\n\nfunction getSystemPreference(): 'dark' | 'light' {\n if (typeof window === 'undefined') return 'dark'\n return window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'\n}\n\nfunction getInitialMode(storageKey: string, defaultMode: ThemeMode): ThemeMode {\n if (typeof window === 'undefined') return defaultMode\n const stored = localStorage.getItem(storageKey)\n if (stored === 'dark' || stored === 'light' || stored === 'system') {\n return stored\n }\n return defaultMode\n}\n\nfunction resolveMode(mode: ThemeMode): 'dark' | 'light' {\n if (mode === 'system') return getSystemPreference()\n return mode\n}\n\nexport function ThemeProvider({\n children,\n defaultMode = 'system',\n storageKey = 'camstack-theme-mode',\n}: ThemeProviderProps) {\n const [mode, setModeState] = useState<ThemeMode>(() => getInitialMode(storageKey, defaultMode))\n const [resolvedMode, setResolvedMode] = useState<'dark' | 'light'>(() => resolveMode(mode))\n\n const setMode = useCallback(\n (newMode: ThemeMode) => {\n setModeState(newMode)\n setResolvedMode(resolveMode(newMode))\n if (typeof window !== 'undefined') {\n localStorage.setItem(storageKey, newMode)\n }\n },\n [storageKey],\n )\n\n const toggleMode = useCallback(() => {\n const currentIndex = TOGGLE_ORDER.indexOf(mode)\n const nextIndex = (currentIndex + 1) % TOGGLE_ORDER.length\n setMode(TOGGLE_ORDER[nextIndex] ?? 'dark')\n }, [mode, setMode])\n\n // Apply CSS class on document.documentElement\n useEffect(() => {\n if (typeof document === 'undefined') return\n\n const root = document.documentElement\n root.classList.remove('dark', 'light')\n // Always apply the resolved class — even in 'system' mode, the CSS\n // variables need the .dark or .light class to activate\n root.classList.add(resolvedMode)\n }, [mode, resolvedMode])\n\n // Listen for system theme changes when in 'system' mode\n useEffect(() => {\n if (typeof window === 'undefined' || mode !== 'system') return\n\n const mediaQuery = window.matchMedia('(prefers-color-scheme: dark)')\n const handleChange = () => {\n setResolvedMode(getSystemPreference())\n }\n\n mediaQuery.addEventListener('change', handleChange)\n return () => mediaQuery.removeEventListener('change', handleChange)\n }, [mode])\n\n const value = useMemo<UseThemeModeReturn>(\n () => ({ mode, resolvedMode, setMode, toggleMode }),\n [mode, resolvedMode, setMode, toggleMode],\n )\n\n return <ThemeContext.Provider value={value}>{children}</ThemeContext.Provider>\n}\n","import { useContext } from 'react'\nimport { ThemeContext } from './theme-provider'\nimport type { UseThemeModeReturn } from './types'\n\nexport function useThemeMode(): UseThemeModeReturn {\n const context = useContext(ThemeContext)\n if (!context) {\n throw new Error('useThemeMode must be used within a ThemeProvider')\n }\n return context\n}\n"],"mappings":"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","names":["import_react"]}
1
+ {"version":3,"file":"index.cjs","names":[],"sources":["../../src/theme/defaults.ts","../../src/theme/create-theme.ts","../../src/theme/theme-to-css.ts","../../src/theme/theme-provider.tsx","../../src/theme/use-theme-mode.ts"],"sourcesContent":["import type { CamStackColorTokens, CamStackTheme } from './types'\n\nconst providerColors: CamStackColorTokens['provider'] = {\n frigate: '#3b82f6',\n scrypted: '#a855f7',\n reolink: '#06b6d4',\n homeAssistant: '#22d3ee',\n rtsp: '#78716c',\n}\n\nexport const darkColors: CamStackColorTokens = {\n primary: '#f59e42',\n primaryForeground: '#0c0a09',\n background: '#0c0a09',\n backgroundElevated: '#1c1917',\n surface: '#1c1917',\n surfaceHover: '#292524',\n border: '#292524',\n borderSubtle: '#1c1917',\n foreground: '#fafaf9',\n foregroundMuted: '#a8a29e',\n foregroundSubtle: '#78716c',\n foregroundDisabled: '#57534e',\n success: '#4ade80',\n warning: '#fbbf24',\n danger: '#f87171',\n info: '#60a5fa',\n provider: providerColors,\n}\n\nexport const lightColors: CamStackColorTokens = {\n primary: '#e67e22',\n primaryForeground: '#ffffff',\n background: '#fafaf9',\n backgroundElevated: '#ffffff',\n surface: '#f5f5f4',\n surfaceHover: '#e7e5e4',\n border: '#d6d3d1',\n borderSubtle: '#e7e5e4',\n foreground: '#1c1917',\n foregroundMuted: '#57534e',\n foregroundSubtle: '#78716c',\n foregroundDisabled: '#a8a29e',\n success: '#16a34a',\n warning: '#d97706',\n danger: '#dc2626',\n info: '#2563eb',\n provider: providerColors,\n}\n\nexport const defaultTheme: CamStackTheme = {\n colors: {\n dark: darkColors,\n light: lightColors,\n },\n spacing: {\n xs: 2,\n sm: 4,\n md: 8,\n lg: 12,\n xl: 16,\n '2xl': 24,\n '3xl': 32,\n },\n radius: {\n sm: 4,\n md: 6,\n lg: 8,\n xl: 12,\n },\n typography: {\n fontFamily: '-apple-system, BlinkMacSystemFont, \"Segoe UI\", sans-serif',\n sizes: {\n xs: { fontSize: 10, lineHeight: 14 },\n sm: { fontSize: 11, lineHeight: 16 },\n base: { fontSize: 12, lineHeight: 18 },\n lg: { fontSize: 13, lineHeight: 18 },\n xl: { fontSize: 14, lineHeight: 20 },\n '2xl': { fontSize: 16, lineHeight: 22 },\n '3xl': { fontSize: 20, lineHeight: 28 },\n },\n weights: {\n regular: 400,\n medium: 500,\n semibold: 600,\n bold: 700,\n },\n },\n table: {\n rowHeight: 28,\n headerHeight: 24,\n cellPaddingX: 8,\n cellPaddingY: 6,\n },\n sidebar: {\n width: 176,\n itemHeight: 28,\n iconSize: 14,\n },\n}\n","import type { CamStackTheme, DeepPartial } from './types'\nimport { defaultTheme } from './defaults'\n\nfunction deepMerge<T extends object>(target: T, source: DeepPartial<T>): T {\n const result = { ...target }\n for (const key in source) {\n const sourceVal = source[key]\n const targetVal = target[key]\n if (\n sourceVal !== undefined &&\n typeof sourceVal === 'object' &&\n sourceVal !== null &&\n !Array.isArray(sourceVal) &&\n typeof targetVal === 'object' &&\n targetVal !== null\n ) {\n result[key] = deepMerge(\n targetVal as Record<string, unknown>,\n sourceVal as Record<string, unknown>,\n ) as T[typeof key]\n } else if (sourceVal !== undefined) {\n result[key] = sourceVal as T[typeof key]\n }\n }\n return result\n}\n\nexport function createTheme(overrides?: DeepPartial<CamStackTheme>): CamStackTheme {\n if (!overrides) return structuredClone(defaultTheme)\n return deepMerge(structuredClone(defaultTheme), overrides)\n}\n","import type { CamStackColorTokens, CamStackTheme } from './types'\n\nfunction camelToKebab(str: string): string {\n return str.replace(/[A-Z]/g, (m) => `-${m.toLowerCase()}`)\n}\n\nfunction colorTokenToCssVar(key: string): string {\n return `--color-${camelToKebab(key)}`\n}\n\nfunction generateColorBlock(colors: CamStackColorTokens): string {\n const lines: string[] = []\n for (const [key, value] of Object.entries(colors)) {\n if (key === 'provider') continue\n lines.push(` ${colorTokenToCssVar(key)}: ${value};`)\n }\n return lines.join('\\n')\n}\n\nfunction generateProviderColors(provider: CamStackColorTokens['provider']): string {\n const lines: string[] = []\n for (const [key, value] of Object.entries(provider)) {\n lines.push(` --color-provider-${camelToKebab(key)}: ${value};`)\n }\n return lines.join('\\n')\n}\n\nfunction generateSpacingTokens(spacing: CamStackTheme['spacing']): string {\n const lines: string[] = []\n for (const [key, value] of Object.entries(spacing)) {\n lines.push(` --spacing-${key}: ${value}px;`)\n }\n return lines.join('\\n')\n}\n\nfunction generateRadiusTokens(radius: CamStackTheme['radius']): string {\n const lines: string[] = []\n for (const [key, value] of Object.entries(radius)) {\n lines.push(` --radius-${key}: ${value}px;`)\n }\n return lines.join('\\n')\n}\n\nexport function themeToCss(theme: CamStackTheme): string {\n const darkColorBlock = generateColorBlock(theme.colors.dark)\n const lightColorBlock = generateColorBlock(theme.colors.light)\n const providerBlock = generateProviderColors(theme.colors.dark.provider)\n const spacingBlock = generateSpacingTokens(theme.spacing)\n const radiusBlock = generateRadiusTokens(theme.radius)\n\n return `@theme {\n${providerBlock}\n${spacingBlock}\n${radiusBlock}\n}\n\n.dark {\n${darkColorBlock}\n}\n\n.light {\n${lightColorBlock}\n}\n\n@media (prefers-color-scheme: dark) {\n :root {\n${darkColorBlock.replace(/^ {2}/gm, ' ')}\n }\n}\n\n@media (prefers-color-scheme: light) {\n :root {\n${lightColorBlock.replace(/^ {2}/gm, ' ')}\n }\n}\n`\n}\n","import { createContext, useCallback, useEffect, useMemo, useState } from 'react'\nimport type { ReactNode } from 'react'\nimport type { ThemeMode, UseThemeModeReturn } from './types'\n\nexport const ThemeContext = createContext<UseThemeModeReturn | null>(null)\n\ninterface ThemeProviderProps {\n children: ReactNode\n defaultMode?: ThemeMode\n storageKey?: string\n}\n\nconst TOGGLE_ORDER: readonly ThemeMode[] = ['dark', 'light', 'system'] as const\n\nfunction getSystemPreference(): 'dark' | 'light' {\n if (typeof window === 'undefined') return 'dark'\n return window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light'\n}\n\nfunction getInitialMode(storageKey: string, defaultMode: ThemeMode): ThemeMode {\n if (typeof window === 'undefined') return defaultMode\n const stored = localStorage.getItem(storageKey)\n if (stored === 'dark' || stored === 'light' || stored === 'system') {\n return stored\n }\n return defaultMode\n}\n\nfunction resolveMode(mode: ThemeMode): 'dark' | 'light' {\n if (mode === 'system') return getSystemPreference()\n return mode\n}\n\nexport function ThemeProvider({\n children,\n defaultMode = 'system',\n storageKey = 'camstack-theme-mode',\n}: ThemeProviderProps) {\n const [mode, setModeState] = useState<ThemeMode>(() => getInitialMode(storageKey, defaultMode))\n const [resolvedMode, setResolvedMode] = useState<'dark' | 'light'>(() => resolveMode(mode))\n\n const setMode = useCallback(\n (newMode: ThemeMode) => {\n setModeState(newMode)\n setResolvedMode(resolveMode(newMode))\n if (typeof window !== 'undefined') {\n localStorage.setItem(storageKey, newMode)\n }\n },\n [storageKey],\n )\n\n const toggleMode = useCallback(() => {\n const currentIndex = TOGGLE_ORDER.indexOf(mode)\n const nextIndex = (currentIndex + 1) % TOGGLE_ORDER.length\n setMode(TOGGLE_ORDER[nextIndex] ?? 'dark')\n }, [mode, setMode])\n\n // Apply CSS class on document.documentElement\n useEffect(() => {\n if (typeof document === 'undefined') return\n\n const root = document.documentElement\n root.classList.remove('dark', 'light')\n // Always apply the resolved class — even in 'system' mode, the CSS\n // variables need the .dark or .light class to activate\n root.classList.add(resolvedMode)\n }, [mode, resolvedMode])\n\n // Listen for system theme changes when in 'system' mode\n useEffect(() => {\n if (typeof window === 'undefined' || mode !== 'system') return\n\n const mediaQuery = window.matchMedia('(prefers-color-scheme: dark)')\n const handleChange = () => {\n setResolvedMode(getSystemPreference())\n }\n\n mediaQuery.addEventListener('change', handleChange)\n return () => mediaQuery.removeEventListener('change', handleChange)\n }, [mode])\n\n const value = useMemo<UseThemeModeReturn>(\n () => ({ mode, resolvedMode, setMode, toggleMode }),\n [mode, resolvedMode, setMode, toggleMode],\n )\n\n return <ThemeContext.Provider value={value}>{children}</ThemeContext.Provider>\n}\n","import { useContext } from 'react'\nimport { ThemeContext } from './theme-provider'\nimport type { UseThemeModeReturn } from './types'\n\nexport function useThemeMode(): UseThemeModeReturn {\n const context = useContext(ThemeContext)\n if (!context) {\n throw new Error('useThemeMode must be used within a ThemeProvider')\n }\n return context\n}\n"],"mappings":"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"}