@almadar/ui 2.15.8 → 2.15.10

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 (125) hide show
  1. package/dist/components/atoms/ContentSection.d.ts +16 -0
  2. package/dist/components/atoms/SectionHeader.d.ts +14 -0
  3. package/dist/components/atoms/StatCard.d.ts +13 -0
  4. package/dist/components/atoms/index.d.ts +3 -0
  5. package/dist/components/atoms/svg/SvgBranch.d.ts +12 -0
  6. package/dist/components/atoms/svg/SvgConnection.d.ts +13 -0
  7. package/dist/components/atoms/svg/SvgFlow.d.ts +10 -0
  8. package/dist/components/atoms/svg/SvgGrid.d.ts +14 -0
  9. package/dist/components/atoms/svg/SvgLobe.d.ts +13 -0
  10. package/dist/components/atoms/svg/SvgMesh.d.ts +12 -0
  11. package/dist/components/atoms/svg/SvgMorph.d.ts +11 -0
  12. package/dist/components/atoms/svg/SvgNode.d.ts +12 -0
  13. package/dist/components/atoms/svg/SvgPulse.d.ts +12 -0
  14. package/dist/components/atoms/svg/SvgRing.d.ts +13 -0
  15. package/dist/components/atoms/svg/SvgShield.d.ts +11 -0
  16. package/dist/components/atoms/svg/SvgStack.d.ts +13 -0
  17. package/dist/components/atoms/svg/index.d.ts +12 -0
  18. package/dist/{chunk-ACUO2BBW.js → components/index.cjs} +24764 -16677
  19. package/dist/components/index.js +37757 -889
  20. package/dist/components/molecules/AnimatedCounter.d.ts +18 -0
  21. package/dist/components/molecules/ArticleSection.d.ts +18 -0
  22. package/dist/components/molecules/CTABanner.d.ts +31 -0
  23. package/dist/components/molecules/CaseStudyCard.d.ts +24 -0
  24. package/dist/components/molecules/CodeExample.d.ts +23 -0
  25. package/dist/components/molecules/CommunityLinks.d.ts +25 -0
  26. package/dist/components/molecules/DocBreadcrumb.d.ts +20 -0
  27. package/dist/components/molecules/DocCodeBlock.d.ts +13 -0
  28. package/dist/components/molecules/DocPagination.d.ts +14 -0
  29. package/dist/components/molecules/DocSearch.d.ts +15 -0
  30. package/dist/components/molecules/DocSidebar.d.ts +24 -0
  31. package/dist/components/molecules/DocTOC.d.ts +24 -0
  32. package/dist/components/molecules/FeatureCard.d.ts +26 -0
  33. package/dist/components/molecules/FeatureGrid.d.ts +19 -0
  34. package/dist/components/molecules/GradientDivider.d.ts +14 -0
  35. package/dist/components/molecules/HeroSection.d.ts +36 -0
  36. package/dist/components/molecules/InstallBox.d.ts +16 -0
  37. package/dist/components/molecules/MarketingFooter.d.ts +27 -0
  38. package/dist/components/molecules/PricingCard.d.ts +21 -0
  39. package/dist/components/molecules/PricingGrid.d.ts +13 -0
  40. package/dist/components/molecules/PullQuote.d.ts +14 -0
  41. package/dist/components/molecules/ServiceCatalog.d.ts +19 -0
  42. package/dist/components/molecules/ShowcaseCard.d.ts +20 -0
  43. package/dist/components/molecules/SocialProof.d.ts +25 -0
  44. package/dist/components/molecules/SplitSection.d.ts +21 -0
  45. package/dist/components/molecules/StatsGrid.d.ts +17 -0
  46. package/dist/components/molecules/StepFlow.d.ts +20 -0
  47. package/dist/components/molecules/TagCloud.d.ts +18 -0
  48. package/dist/components/molecules/TeamCard.d.ts +18 -0
  49. package/dist/components/molecules/index.d.ts +19 -0
  50. package/dist/components/molecules/svg/AIGenerates.d.ts +7 -0
  51. package/dist/components/molecules/svg/ClosedCircuit.d.ts +7 -0
  52. package/dist/components/molecules/svg/CommunityOwnership.d.ts +7 -0
  53. package/dist/components/molecules/svg/CompileAnywhere.d.ts +7 -0
  54. package/dist/components/molecules/svg/ComposableModels.d.ts +7 -0
  55. package/dist/components/molecules/svg/DescribeProveDeploy.d.ts +7 -0
  56. package/dist/components/molecules/svg/DomainGrid.d.ts +7 -0
  57. package/dist/components/molecules/svg/EventBus.d.ts +7 -0
  58. package/dist/components/molecules/svg/OrbitalUnit.d.ts +7 -0
  59. package/dist/components/molecules/svg/PlanVerifyRemember.d.ts +7 -0
  60. package/dist/components/molecules/svg/ProveCorrect.d.ts +7 -0
  61. package/dist/components/molecules/svg/ServiceLayers.d.ts +7 -0
  62. package/dist/components/molecules/svg/SharedReality.d.ts +7 -0
  63. package/dist/components/molecules/svg/StandardLibrary.d.ts +7 -0
  64. package/dist/components/molecules/svg/StateMachine.d.ts +7 -0
  65. package/dist/components/molecules/svg/WorldModel.d.ts +7 -0
  66. package/dist/components/molecules/svg/index.d.ts +16 -0
  67. package/dist/components/organisms/CaseStudyOrganism.d.ts +19 -0
  68. package/dist/components/organisms/FeatureGridOrganism.d.ts +20 -0
  69. package/dist/components/organisms/HeroOrganism.d.ts +18 -0
  70. package/dist/components/organisms/PricingOrganism.d.ts +19 -0
  71. package/dist/components/organisms/ShowcaseOrganism.d.ts +20 -0
  72. package/dist/components/organisms/StatsOrganism.d.ts +17 -0
  73. package/dist/components/organisms/StepFlowOrganism.d.ts +20 -0
  74. package/dist/components/organisms/TeamOrganism.d.ts +18 -0
  75. package/dist/components/organisms/game/three/index.cjs +2525 -0
  76. package/dist/components/organisms/game/three/index.js +1795 -50
  77. package/dist/components/organisms/index.d.ts +9 -0
  78. package/dist/components/organisms/marketing-types.d.ts +87 -0
  79. package/dist/components/templates/AboutPageTemplate.d.ts +26 -0
  80. package/dist/components/templates/FeatureDetailPageTemplate.d.ts +27 -0
  81. package/dist/components/templates/LandingPageTemplate.d.ts +31 -0
  82. package/dist/components/templates/PricingPageTemplate.d.ts +26 -0
  83. package/dist/components/templates/index.d.ts +4 -0
  84. package/dist/context/index.cjs +550 -0
  85. package/dist/context/index.js +420 -6
  86. package/dist/docs/index.cjs +4015 -0
  87. package/dist/docs/index.d.cts +412 -0
  88. package/dist/docs/index.d.ts +29 -0
  89. package/dist/docs/index.js +3977 -0
  90. package/dist/hooks/index.cjs +2606 -0
  91. package/dist/hooks/index.js +2535 -8
  92. package/dist/illustrations/index.cjs +3004 -0
  93. package/dist/illustrations/index.d.cts +261 -0
  94. package/dist/illustrations/index.d.ts +35 -0
  95. package/dist/illustrations/index.js +2971 -0
  96. package/dist/{chunk-XL7WB2O5.js → lib/index.cjs} +454 -274
  97. package/dist/lib/index.js +1407 -3
  98. package/dist/locales/index.cjs +340 -0
  99. package/dist/locales/index.js +105 -2
  100. package/dist/marketing/index.cjs +4683 -0
  101. package/dist/marketing/index.d.cts +831 -0
  102. package/dist/marketing/index.d.ts +62 -0
  103. package/dist/marketing/index.js +4626 -0
  104. package/dist/providers/index.cjs +4811 -0
  105. package/dist/providers/index.js +4765 -11
  106. package/dist/{chunk-K2D5D3WK.js → renderer/index.cjs} +101 -42
  107. package/dist/renderer/index.js +1036 -2
  108. package/dist/runtime/index.cjs +4400 -0
  109. package/dist/runtime/index.js +3615 -19
  110. package/dist/{chunk-N7MVUW4R.js → stores/index.cjs} +24 -1
  111. package/dist/stores/index.js +194 -2
  112. package/dist/tsup.config.d.ts +2 -1
  113. package/package.json +27 -12
  114. package/tailwind-preset.cjs +9 -0
  115. package/themes/index.css +22 -20
  116. package/dist/chunk-3HJHHULT.js +0 -93
  117. package/dist/chunk-3JGAROCW.js +0 -149
  118. package/dist/chunk-4N3BAPDB.js +0 -1667
  119. package/dist/chunk-CDIOHSKG.js +0 -661
  120. package/dist/chunk-DKQN5FVU.js +0 -279
  121. package/dist/chunk-JJHCOO34.js +0 -375
  122. package/dist/chunk-PKBMQBKP.js +0 -5
  123. package/dist/chunk-QIABKRCN.js +0 -107
  124. package/dist/chunk-SD3KVCY6.js +0 -1465
  125. package/dist/chunk-YXZM3WCF.js +0 -222
@@ -1,10 +1,424 @@
1
- import { ThemeProvider, useTheme } from '../chunk-DKQN5FVU.js';
2
- export { BUILT_IN_THEMES, ThemeContext_default as ThemeContext, ThemeProvider, UISlotContext, UISlotProvider, useSlotContent, useSlotHasContent, useTheme, useUISlots } from '../chunk-DKQN5FVU.js';
3
- import '../chunk-3JGAROCW.js';
4
- import '../chunk-PKBMQBKP.js';
5
- import { createContext, useCallback, useMemo, useContext } from 'react';
1
+ import { createContext, useMemo, useContext, useState, useEffect, useCallback, useRef } from 'react';
6
2
  import { jsx } from 'react/jsx-runtime';
7
3
 
4
+ var DEFAULT_SLOTS = {
5
+ main: null,
6
+ sidebar: null,
7
+ modal: null,
8
+ drawer: null,
9
+ overlay: null,
10
+ center: null,
11
+ toast: null,
12
+ "hud-top": null,
13
+ "hud-bottom": null,
14
+ "hud-left": null,
15
+ "hud-right": null,
16
+ floating: null
17
+ };
18
+ var idCounter = 0;
19
+ function generateId() {
20
+ return `slot-content-${++idCounter}-${Date.now()}`;
21
+ }
22
+ function useUISlotManager() {
23
+ const [slots, setSlots] = useState(DEFAULT_SLOTS);
24
+ const subscribersRef = useRef(/* @__PURE__ */ new Set());
25
+ const timersRef = useRef(/* @__PURE__ */ new Map());
26
+ useEffect(() => {
27
+ return () => {
28
+ timersRef.current.forEach((timer) => clearTimeout(timer));
29
+ timersRef.current.clear();
30
+ };
31
+ }, []);
32
+ const notifySubscribers = useCallback((slot, content) => {
33
+ subscribersRef.current.forEach((callback) => {
34
+ try {
35
+ callback(slot, content);
36
+ } catch (error) {
37
+ console.error("[UISlots] Subscriber error:", error);
38
+ }
39
+ });
40
+ }, []);
41
+ const render = useCallback((config) => {
42
+ const id = generateId();
43
+ const content = {
44
+ id,
45
+ pattern: config.pattern,
46
+ props: config.props ?? {},
47
+ priority: config.priority ?? 0,
48
+ animation: config.animation ?? "fade",
49
+ onDismiss: config.onDismiss,
50
+ sourceTrait: config.sourceTrait
51
+ };
52
+ if (config.autoDismissMs && config.autoDismissMs > 0) {
53
+ content.autoDismissAt = Date.now() + config.autoDismissMs;
54
+ const timer = setTimeout(() => {
55
+ setSlots((prev) => {
56
+ if (prev[config.target]?.id === id) {
57
+ content.onDismiss?.();
58
+ notifySubscribers(config.target, null);
59
+ return { ...prev, [config.target]: null };
60
+ }
61
+ return prev;
62
+ });
63
+ timersRef.current.delete(id);
64
+ }, config.autoDismissMs);
65
+ timersRef.current.set(id, timer);
66
+ }
67
+ setSlots((prev) => {
68
+ const existing = prev[config.target];
69
+ if (existing && existing.priority > content.priority) {
70
+ console.warn(
71
+ `[UISlots] Slot "${config.target}" already has higher priority content (${existing.priority} > ${content.priority})`
72
+ );
73
+ return prev;
74
+ }
75
+ notifySubscribers(config.target, content);
76
+ return { ...prev, [config.target]: content };
77
+ });
78
+ return id;
79
+ }, [notifySubscribers]);
80
+ const clear = useCallback((slot) => {
81
+ setSlots((prev) => {
82
+ const content = prev[slot];
83
+ if (content) {
84
+ const timer = timersRef.current.get(content.id);
85
+ if (timer) {
86
+ clearTimeout(timer);
87
+ timersRef.current.delete(content.id);
88
+ }
89
+ content.onDismiss?.();
90
+ notifySubscribers(slot, null);
91
+ }
92
+ return { ...prev, [slot]: null };
93
+ });
94
+ }, [notifySubscribers]);
95
+ const clearById = useCallback((id) => {
96
+ setSlots((prev) => {
97
+ const entry = Object.entries(prev).find(([, content]) => content?.id === id);
98
+ if (entry) {
99
+ const [slot, content] = entry;
100
+ const timer = timersRef.current.get(id);
101
+ if (timer) {
102
+ clearTimeout(timer);
103
+ timersRef.current.delete(id);
104
+ }
105
+ content.onDismiss?.();
106
+ notifySubscribers(slot, null);
107
+ return { ...prev, [slot]: null };
108
+ }
109
+ return prev;
110
+ });
111
+ }, [notifySubscribers]);
112
+ const clearAll = useCallback(() => {
113
+ timersRef.current.forEach((timer) => clearTimeout(timer));
114
+ timersRef.current.clear();
115
+ setSlots((prev) => {
116
+ Object.entries(prev).forEach(([slot, content]) => {
117
+ if (content) {
118
+ content.onDismiss?.();
119
+ notifySubscribers(slot, null);
120
+ }
121
+ });
122
+ return DEFAULT_SLOTS;
123
+ });
124
+ }, [notifySubscribers]);
125
+ const subscribe = useCallback((callback) => {
126
+ subscribersRef.current.add(callback);
127
+ return () => {
128
+ subscribersRef.current.delete(callback);
129
+ };
130
+ }, []);
131
+ const hasContent = useCallback((slot) => {
132
+ return slots[slot] !== null;
133
+ }, [slots]);
134
+ const getContent = useCallback((slot) => {
135
+ return slots[slot];
136
+ }, [slots]);
137
+ return {
138
+ slots,
139
+ render,
140
+ clear,
141
+ clearById,
142
+ clearAll,
143
+ subscribe,
144
+ hasContent,
145
+ getContent
146
+ };
147
+ }
148
+ var UISlotContext = createContext(null);
149
+ function UISlotProvider({ children }) {
150
+ const slotManager = useUISlotManager();
151
+ const contextValue = useMemo(() => slotManager, [slotManager]);
152
+ return /* @__PURE__ */ jsx(UISlotContext.Provider, { value: contextValue, children });
153
+ }
154
+ function useUISlots() {
155
+ const context = useContext(UISlotContext);
156
+ if (!context) {
157
+ throw new Error(
158
+ "useUISlots must be used within a UISlotProvider. Make sure your component tree is wrapped with <UISlotProvider>."
159
+ );
160
+ }
161
+ return context;
162
+ }
163
+ function useSlotContent(slot) {
164
+ const { getContent } = useUISlots();
165
+ return getContent(slot);
166
+ }
167
+ function useSlotHasContent(slot) {
168
+ const { hasContent } = useUISlots();
169
+ return hasContent(slot);
170
+ }
171
+ var BUILT_IN_THEMES = [
172
+ {
173
+ name: "wireframe",
174
+ displayName: "Wireframe",
175
+ hasLightMode: true,
176
+ hasDarkMode: true
177
+ },
178
+ {
179
+ name: "minimalist",
180
+ displayName: "Minimalist",
181
+ hasLightMode: true,
182
+ hasDarkMode: true
183
+ },
184
+ {
185
+ name: "almadar",
186
+ displayName: "Almadar",
187
+ hasLightMode: true,
188
+ hasDarkMode: true
189
+ },
190
+ {
191
+ name: "trait-wars",
192
+ displayName: "Trait Wars",
193
+ hasLightMode: false,
194
+ hasDarkMode: true
195
+ },
196
+ // Extended themes
197
+ {
198
+ name: "ocean",
199
+ displayName: "Ocean",
200
+ hasLightMode: true,
201
+ hasDarkMode: true
202
+ },
203
+ {
204
+ name: "forest",
205
+ displayName: "Forest",
206
+ hasLightMode: true,
207
+ hasDarkMode: true
208
+ },
209
+ {
210
+ name: "sunset",
211
+ displayName: "Sunset",
212
+ hasLightMode: true,
213
+ hasDarkMode: true
214
+ },
215
+ {
216
+ name: "lavender",
217
+ displayName: "Lavender",
218
+ hasLightMode: true,
219
+ hasDarkMode: true
220
+ },
221
+ {
222
+ name: "rose",
223
+ displayName: "Rose",
224
+ hasLightMode: true,
225
+ hasDarkMode: true
226
+ },
227
+ {
228
+ name: "slate",
229
+ displayName: "Slate",
230
+ hasLightMode: true,
231
+ hasDarkMode: true
232
+ },
233
+ {
234
+ name: "ember",
235
+ displayName: "Ember",
236
+ hasLightMode: true,
237
+ hasDarkMode: true
238
+ },
239
+ {
240
+ name: "midnight",
241
+ displayName: "Midnight",
242
+ hasLightMode: true,
243
+ hasDarkMode: true
244
+ },
245
+ {
246
+ name: "sand",
247
+ displayName: "Sand",
248
+ hasLightMode: true,
249
+ hasDarkMode: true
250
+ },
251
+ {
252
+ name: "neon",
253
+ displayName: "Neon",
254
+ hasLightMode: true,
255
+ hasDarkMode: true
256
+ },
257
+ {
258
+ name: "arctic",
259
+ displayName: "Arctic",
260
+ hasLightMode: true,
261
+ hasDarkMode: true
262
+ },
263
+ {
264
+ name: "copper",
265
+ displayName: "Copper",
266
+ hasLightMode: true,
267
+ hasDarkMode: true
268
+ }
269
+ ];
270
+ var ThemeContext = createContext(void 0);
271
+ var THEME_STORAGE_KEY = "theme";
272
+ var MODE_STORAGE_KEY = "theme-mode";
273
+ function getSystemMode() {
274
+ if (typeof window === "undefined") return "light";
275
+ return window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light";
276
+ }
277
+ function resolveMode(mode) {
278
+ if (mode === "system") {
279
+ return getSystemMode();
280
+ }
281
+ return mode;
282
+ }
283
+ var ThemeProvider = ({
284
+ children,
285
+ themes = [],
286
+ defaultTheme = "wireframe",
287
+ defaultMode = "system",
288
+ targetRef
289
+ }) => {
290
+ const availableThemes = useMemo(() => {
291
+ const themeMap = /* @__PURE__ */ new Map();
292
+ BUILT_IN_THEMES.forEach((t) => themeMap.set(t.name, t));
293
+ themes.forEach((t) => themeMap.set(t.name, t));
294
+ return Array.from(themeMap.values());
295
+ }, [themes]);
296
+ const isScoped = !!targetRef;
297
+ const [theme, setThemeState] = useState(() => {
298
+ if (isScoped || typeof window === "undefined") return defaultTheme;
299
+ const stored = localStorage.getItem(THEME_STORAGE_KEY);
300
+ const validThemes = [
301
+ ...BUILT_IN_THEMES.map((t) => t.name),
302
+ ...themes.map((t) => t.name)
303
+ ];
304
+ if (stored && validThemes.includes(stored)) {
305
+ return stored;
306
+ }
307
+ return defaultTheme;
308
+ });
309
+ const [mode, setModeState] = useState(() => {
310
+ if (isScoped || typeof window === "undefined") return defaultMode;
311
+ const stored = localStorage.getItem(MODE_STORAGE_KEY);
312
+ if (stored === "light" || stored === "dark" || stored === "system") {
313
+ return stored;
314
+ }
315
+ return defaultMode;
316
+ });
317
+ const [resolvedMode, setResolvedMode] = useState(
318
+ () => resolveMode(mode)
319
+ );
320
+ const appliedTheme = useMemo(
321
+ () => `${theme}-${resolvedMode}`,
322
+ [theme, resolvedMode]
323
+ );
324
+ useEffect(() => {
325
+ const updateResolved = () => {
326
+ setResolvedMode(resolveMode(mode));
327
+ };
328
+ updateResolved();
329
+ if (mode === "system") {
330
+ const mediaQuery = window.matchMedia("(prefers-color-scheme: dark)");
331
+ const handleChange = () => updateResolved();
332
+ mediaQuery.addEventListener("change", handleChange);
333
+ return () => mediaQuery.removeEventListener("change", handleChange);
334
+ }
335
+ return void 0;
336
+ }, [mode]);
337
+ useEffect(() => {
338
+ if (isScoped) {
339
+ if (targetRef?.current) {
340
+ targetRef.current.setAttribute("data-theme", appliedTheme);
341
+ targetRef.current.classList.remove("light", "dark");
342
+ targetRef.current.classList.add(resolvedMode);
343
+ }
344
+ return;
345
+ }
346
+ const root = document.documentElement;
347
+ root.setAttribute("data-theme", appliedTheme);
348
+ root.classList.remove("light", "dark");
349
+ root.classList.add(resolvedMode);
350
+ }, [appliedTheme, resolvedMode, targetRef, isScoped]);
351
+ const setTheme = useCallback(
352
+ (newTheme) => {
353
+ const validTheme = availableThemes.find((t) => t.name === newTheme);
354
+ if (validTheme) {
355
+ setThemeState(newTheme);
356
+ if (!isScoped && typeof window !== "undefined") {
357
+ localStorage.setItem(THEME_STORAGE_KEY, newTheme);
358
+ }
359
+ } else {
360
+ console.warn(
361
+ `Theme "${newTheme}" not found. Available: ${availableThemes.map((t) => t.name).join(", ")}`
362
+ );
363
+ }
364
+ },
365
+ [availableThemes]
366
+ );
367
+ const setMode = useCallback((newMode) => {
368
+ setModeState(newMode);
369
+ if (!isScoped && typeof window !== "undefined") {
370
+ localStorage.setItem(MODE_STORAGE_KEY, newMode);
371
+ }
372
+ }, []);
373
+ const toggleMode = useCallback(() => {
374
+ const newMode = resolvedMode === "dark" ? "light" : "dark";
375
+ setMode(newMode);
376
+ }, [resolvedMode, setMode]);
377
+ const contextValue = useMemo(
378
+ () => ({
379
+ theme,
380
+ mode,
381
+ resolvedMode,
382
+ setTheme,
383
+ setMode,
384
+ toggleMode,
385
+ availableThemes,
386
+ appliedTheme
387
+ }),
388
+ [
389
+ theme,
390
+ mode,
391
+ resolvedMode,
392
+ setTheme,
393
+ setMode,
394
+ toggleMode,
395
+ availableThemes,
396
+ appliedTheme
397
+ ]
398
+ );
399
+ return /* @__PURE__ */ jsx(ThemeContext.Provider, { value: contextValue, children });
400
+ };
401
+ function useTheme() {
402
+ const context = useContext(ThemeContext);
403
+ if (context === void 0) {
404
+ return {
405
+ theme: "wireframe",
406
+ mode: "light",
407
+ resolvedMode: "light",
408
+ setTheme: () => {
409
+ },
410
+ setMode: () => {
411
+ },
412
+ toggleMode: () => {
413
+ },
414
+ availableThemes: BUILT_IN_THEMES,
415
+ appliedTheme: "wireframe-light"
416
+ };
417
+ }
418
+ return context;
419
+ }
420
+ var ThemeContext_default = ThemeContext;
421
+
8
422
  // context/DesignThemeContext.tsx
9
423
  var DesignThemeProvider = ThemeProvider;
10
424
  function useDesignTheme() {
@@ -114,4 +528,4 @@ function useUserForEvaluation() {
114
528
  return isLoggedIn && user ? user : void 0;
115
529
  }
116
530
 
117
- export { ANONYMOUS_USER, DesignThemeProvider, UserContext, UserProvider, useDesignTheme, useHasPermission, useHasRole, useUser, useUserForEvaluation };
531
+ export { ANONYMOUS_USER, BUILT_IN_THEMES, DesignThemeProvider, ThemeContext_default as ThemeContext, ThemeProvider, UISlotContext, UISlotProvider, UserContext, UserProvider, useDesignTheme, useHasPermission, useHasRole, useSlotContent, useSlotHasContent, useTheme, useUISlots, useUser, useUserForEvaluation };