@foxui/core 0.4.2 → 0.4.4

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.
package/README.md CHANGED
@@ -1,7 +1,5 @@
1
1
  # 🦊 fox ui
2
2
 
3
- This package has been moved to `@foxui/core`.
4
-
5
3
  svelte 5 + tailwind 4 ui kit, base components
6
4
 
7
5
  - [Accordion](https://flo-bit.dev/ui-kit/components/base/accordion)
@@ -7,40 +7,39 @@
7
7
  variants: {
8
8
  variant: {
9
9
  primary:
10
- 'border border-accent-500/20 dark:border-accent-500/20 bg-accent-500/10 dark:bg-accent-500/10 text-accent-700 dark:text-accent-400',
10
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-accent-500/5 dark:shadow-accent-500/2 inset-shadow-sm inset-shadow-accent-700/5 dark:inset-shadow-accent-500/2 border border-accent-500/15 dark:border-accent-500/15 bg-accent-200/50 dark:bg-accent-950/20 text-accent-900 dark:text-accent-400',
11
11
  primary_shift:
12
- 'border border-[oklch(from_var(--color-accent-500)_l_c_calc(h+35)_/_0.2)] dark:border-[oklch(from_var(--color-accent-500)_l_c_calc(h+35)_/_0.2)] bg-[oklch(from_var(--color-accent-500)_l_c_calc(h+35)_/_0.1)] text-[oklch(from_var(--color-accent-700)_l_c_calc(h+35))] dark:text-[oklch(from_var(--color-accent-400)_l_c_calc(h+35))]',
12
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-[oklch(from_var(--color-accent-500)_l_c_calc(h+35)_/_0.05)] dark:shadow-[oklch(from_var(--color-accent-500)_l_c_calc(h+35)_/_0.02)] inset-shadow-sm inset-shadow-[oklch(from_var(--color-accent-700)_l_c_calc(h+35)_/_0.05)] dark:inset-shadow-[oklch(from_var(--color-accent-500)_l_c_calc(h+35)_/_0.02)] border border-[oklch(from_var(--color-accent-500)_l_c_calc(h+35)_/_0.15)] dark:border-[oklch(from_var(--color-accent-500)_l_c_calc(h+35)_/_0.15)] bg-[oklch(from_var(--color-accent-200)_l_c_calc(h+35)_/_0.5)] dark:bg-[oklch(from_var(--color-accent-950)_l_c_calc(h+35)_/_0.2)] text-[oklch(from_var(--color-accent-900)_l_c_calc(h+35))] dark:text-[oklch(from_var(--color-accent-400)_l_c_calc(h+35))]',
13
13
  primary_shift_2:
14
- 'border border-[oklch(from_var(--color-accent-500)_l_c_calc(h+70)_/_0.2)] dark:border-[oklch(from_var(--color-accent-500)_l_c_calc(h+70)_/_0.2)] bg-[oklch(from_var(--color-accent-500)_l_c_calc(h+70)_/_0.1)] text-[oklch(from_var(--color-accent-700)_l_c_calc(h+70))] dark:text-[oklch(from_var(--color-accent-400)_l_c_calc(h+70))]',
14
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-[oklch(from_var(--color-accent-500)_l_c_calc(h+70)_/_0.05)] dark:shadow-[oklch(from_var(--color-accent-500)_l_c_calc(h+70)_/_0.02)] inset-shadow-sm inset-shadow-[oklch(from_var(--color-accent-700)_l_c_calc(h+70)_/_0.05)] dark:inset-shadow-[oklch(from_var(--color-accent-500)_l_c_calc(h+70)_/_0.02)] border border-[oklch(from_var(--color-accent-500)_l_c_calc(h+70)_/_0.15)] dark:border-[oklch(from_var(--color-accent-500)_l_c_calc(h+70)_/_0.15)] bg-[oklch(from_var(--color-accent-200)_l_c_calc(h+70)_/_0.5)] dark:bg-[oklch(from_var(--color-accent-950)_l_c_calc(h+70)_/_0.2)] text-[oklch(from_var(--color-accent-900)_l_c_calc(h+70))] dark:text-[oklch(from_var(--color-accent-400)_l_c_calc(h+70))]',
15
15
  secondary:
16
- 'bg-base-300/30 dark:bg-base-800/50 text-base-900 dark:text-base-50 border border-base-300/50 dark:border-base-700/30',
17
-
18
- red: 'border border-red-500/20 dark:border-red-500/20 bg-red-500/10 dark:bg-red-500/10 text-red-700 dark:text-red-400',
16
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-base-500/5 dark:shadow-base-500/2 inset-shadow-sm inset-shadow-base-700/2 dark:inset-shadow-base-500/2 bg-base-300/40 dark:bg-base-800/30 text-base-900 dark:text-base-50 border border-base-300/50 dark:border-base-700/30',
17
+ red: 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-red-500/5 dark:shadow-red-500/2 inset-shadow-sm inset-shadow-red-700/5 dark:inset-shadow-red-500/2 border border-red-500/15 dark:border-red-500/15 bg-red-200/50 dark:bg-red-950/20 text-red-900 dark:text-red-400',
18
+ orange:
19
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-orange-500/5 dark:shadow-orange-500/2 inset-shadow-sm inset-shadow-orange-700/5 dark:inset-shadow-orange-500/2 border border-orange-500/15 dark:border-orange-500/15 bg-orange-200/50 dark:bg-orange-950/20 text-orange-900 dark:text-orange-400',
20
+ amber:
21
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-amber-500/5 dark:shadow-amber-500/2 inset-shadow-sm inset-shadow-amber-700/5 dark:inset-shadow-amber-500/2 border border-amber-500/15 dark:border-amber-500/15 bg-amber-200/50 dark:bg-amber-950/20 text-amber-900 dark:text-amber-400',
19
22
  yellow:
20
- 'border border-yellow-500/20 dark:border-yellow-500/20 bg-yellow-500/10 dark:bg-yellow-500/10 text-yellow-700 dark:text-yellow-400',
23
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-yellow-500/5 dark:shadow-yellow-500/2 inset-shadow-sm inset-shadow-yellow-700/5 dark:inset-shadow-yellow-500/2 border border-yellow-500/15 dark:border-yellow-500/15 bg-yellow-200/50 dark:bg-yellow-950/20 text-yellow-900 dark:text-yellow-400',
24
+ lime: 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-lime-500/5 dark:shadow-lime-500/2 inset-shadow-sm inset-shadow-lime-700/5 dark:inset-shadow-lime-500/2 border border-lime-500/15 dark:border-lime-500/15 bg-lime-200/50 dark:bg-lime-950/20 text-lime-900 dark:text-lime-400',
21
25
  green:
22
- 'border border-green-500/20 dark:border-green-500/20 bg-green-500/10 dark:bg-green-500/10 text-green-700 dark:text-green-400',
23
- blue: 'border border-blue-500/20 dark:border-blue-500/20 bg-blue-500/10 dark:bg-blue-500/10 text-blue-700 dark:text-blue-400',
26
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-green-500/5 dark:shadow-green-500/2 inset-shadow-sm inset-shadow-green-700/5 dark:inset-shadow-green-500/2 border border-green-500/15 dark:border-green-500/15 bg-green-200/50 dark:bg-green-950/20 text-green-900 dark:text-green-400',
27
+ emerald:
28
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-emerald-500/5 dark:shadow-emerald-500/2 inset-shadow-sm inset-shadow-emerald-700/5 dark:inset-shadow-emerald-500/2 border border-emerald-500/15 dark:border-emerald-500/15 bg-emerald-200/50 dark:bg-emerald-950/20 text-emerald-900 dark:text-emerald-400',
29
+ teal: 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-teal-500/5 dark:shadow-teal-500/2 inset-shadow-sm inset-shadow-teal-700/5 dark:inset-shadow-teal-500/2 border border-teal-500/15 dark:border-teal-500/15 bg-teal-200/50 dark:bg-teal-950/20 text-teal-900 dark:text-teal-400',
30
+ cyan: 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-cyan-500/5 dark:shadow-cyan-500/2 inset-shadow-sm inset-shadow-cyan-700/5 dark:inset-shadow-cyan-500/2 border border-cyan-500/15 dark:border-cyan-500/15 bg-cyan-200/50 dark:bg-cyan-950/20 text-cyan-900 dark:text-cyan-400',
31
+ sky: 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-sky-500/5 dark:shadow-sky-500/2 inset-shadow-sm inset-shadow-sky-700/5 dark:inset-shadow-sky-500/2 border border-sky-500/15 dark:border-sky-500/15 bg-sky-200/50 dark:bg-sky-950/20 text-sky-900 dark:text-sky-400',
32
+ blue: 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-blue-500/5 dark:shadow-blue-500/2 inset-shadow-sm inset-shadow-blue-700/5 dark:inset-shadow-blue-500/2 border border-blue-500/15 dark:border-blue-500/15 bg-blue-200/50 dark:bg-blue-950/20 text-blue-900 dark:text-blue-400',
24
33
  indigo:
25
- 'border border-indigo-500/20 dark:border-indigo-500/20 bg-indigo-500/10 dark:bg-indigo-500/10 text-indigo-700 dark:text-indigo-400',
34
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-indigo-500/5 dark:shadow-indigo-500/2 inset-shadow-sm inset-shadow-indigo-700/5 dark:inset-shadow-indigo-500/2 border border-indigo-500/15 dark:border-indigo-500/15 bg-indigo-200/50 dark:bg-indigo-950/20 text-indigo-900 dark:text-indigo-400',
26
35
  violet:
27
- 'border border-violet-500/20 dark:border-violet-500/20 bg-violet-500/10 dark:bg-violet-500/10 text-violet-700 dark:text-violet-400',
36
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-violet-500/5 dark:shadow-violet-500/2 inset-shadow-sm inset-shadow-violet-700/5 dark:inset-shadow-violet-500/2 border border-violet-500/15 dark:border-violet-500/15 bg-violet-200/50 dark:bg-violet-950/20 text-violet-900 dark:text-violet-400',
28
37
  purple:
29
- 'border border-purple-500/20 dark:border-purple-500/20 bg-purple-500/10 dark:bg-purple-500/10 text-purple-700 dark:text-purple-400',
38
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-purple-500/5 dark:shadow-purple-500/2 inset-shadow-sm inset-shadow-purple-700/5 dark:inset-shadow-purple-500/2 border border-purple-500/15 dark:border-purple-500/15 bg-purple-200/50 dark:bg-purple-950/20 text-purple-900 dark:text-purple-400',
30
39
  fuchsia:
31
- 'border border-fuchsia-500/20 dark:border-fuchsia-500/20 bg-fuchsia-500/10 dark:bg-fuchsia-500/10 text-fuchsia-700 dark:text-fuchsia-400',
32
- pink: 'border border-pink-500/20 dark:border-pink-500/20 bg-pink-500/10 dark:bg-pink-500/10 text-pink-700 dark:text-pink-400',
33
- rose: 'border border-rose-500/20 dark:border-rose-500/20 bg-rose-500/10 dark:bg-rose-500/10 text-rose-700 dark:text-rose-400',
34
- orange:
35
- 'border border-orange-500/20 dark:border-orange-500/20 bg-orange-500/10 dark:bg-orange-500/10 text-orange-700 dark:text-orange-400',
36
- amber:
37
- 'border border-amber-500/20 dark:border-amber-500/20 bg-amber-500/10 dark:bg-amber-500/10 text-amber-700 dark:text-amber-400',
38
- lime: 'border border-lime-500/20 dark:border-lime-500/20 bg-lime-500/10 dark:bg-lime-500/10 text-lime-700 dark:text-lime-400',
39
- emerald:
40
- 'border border-emerald-500/20 dark:border-emerald-500/20 bg-emerald-500/10 dark:bg-emerald-500/10 text-emerald-700 dark:text-emerald-400',
41
- teal: 'border border-teal-500/20 dark:border-teal-500/20 bg-teal-500/10 dark:bg-teal-500/10 text-teal-700 dark:text-teal-400',
42
- cyan: 'border border-cyan-500/20 dark:border-cyan-500/20 bg-cyan-500/10 dark:bg-cyan-500/10 text-cyan-700 dark:text-cyan-400',
43
- sky: 'border border-sky-500/20 dark:border-sky-500/20 bg-sky-500/10 dark:bg-sky-500/10 text-sky-700 dark:text-sky-400'
40
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-fuchsia-500/5 dark:shadow-fuchsia-500/2 inset-shadow-sm inset-shadow-fuchsia-700/5 dark:inset-shadow-fuchsia-500/2 border border-fuchsia-500/15 dark:border-fuchsia-500/15 bg-fuchsia-200/50 dark:bg-fuchsia-950/20 text-fuchsia-900 dark:text-fuchsia-400',
41
+ pink: 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-pink-500/5 dark:shadow-pink-500/2 inset-shadow-sm inset-shadow-pink-700/5 dark:inset-shadow-pink-500/2 border border-pink-500/15 dark:border-pink-500/15 bg-pink-200/50 dark:bg-pink-950/20 text-pink-900 dark:text-pink-400',
42
+ rose: 'backdrop-blur-md backdrop-brightness-105 shadow-lg shadow-rose-500/5 dark:shadow-rose-500/2 inset-shadow-sm inset-shadow-rose-700/5 dark:inset-shadow-rose-500/2 border border-rose-500/15 dark:border-rose-500/15 bg-rose-200/50 dark:bg-rose-950/20 text-rose-900 dark:text-rose-400'
44
43
  },
45
44
  size: {
46
45
  sm: 'px-2 text-xs py-0.5 [&_svg]:size-3 gap-1.5',
@@ -6,8 +6,15 @@ export declare const badgeVariants: import("tailwind-variants").TVReturnType<{
6
6
  primary_shift_2: string;
7
7
  secondary: string;
8
8
  red: string;
9
+ orange: string;
10
+ amber: string;
9
11
  yellow: string;
12
+ lime: string;
10
13
  green: string;
14
+ emerald: string;
15
+ teal: string;
16
+ cyan: string;
17
+ sky: string;
11
18
  blue: string;
12
19
  indigo: string;
13
20
  violet: string;
@@ -15,13 +22,6 @@ export declare const badgeVariants: import("tailwind-variants").TVReturnType<{
15
22
  fuchsia: string;
16
23
  pink: string;
17
24
  rose: string;
18
- orange: string;
19
- amber: string;
20
- lime: string;
21
- emerald: string;
22
- teal: string;
23
- cyan: string;
24
- sky: string;
25
25
  };
26
26
  size: {
27
27
  sm: string;
@@ -35,8 +35,15 @@ export declare const badgeVariants: import("tailwind-variants").TVReturnType<{
35
35
  primary_shift_2: string;
36
36
  secondary: string;
37
37
  red: string;
38
+ orange: string;
39
+ amber: string;
38
40
  yellow: string;
41
+ lime: string;
39
42
  green: string;
43
+ emerald: string;
44
+ teal: string;
45
+ cyan: string;
46
+ sky: string;
40
47
  blue: string;
41
48
  indigo: string;
42
49
  violet: string;
@@ -44,13 +51,6 @@ export declare const badgeVariants: import("tailwind-variants").TVReturnType<{
44
51
  fuchsia: string;
45
52
  pink: string;
46
53
  rose: string;
47
- orange: string;
48
- amber: string;
49
- lime: string;
50
- emerald: string;
51
- teal: string;
52
- cyan: string;
53
- sky: string;
54
54
  };
55
55
  size: {
56
56
  sm: string;
@@ -64,8 +64,15 @@ export declare const badgeVariants: import("tailwind-variants").TVReturnType<{
64
64
  primary_shift_2: string;
65
65
  secondary: string;
66
66
  red: string;
67
+ orange: string;
68
+ amber: string;
67
69
  yellow: string;
70
+ lime: string;
68
71
  green: string;
72
+ emerald: string;
73
+ teal: string;
74
+ cyan: string;
75
+ sky: string;
69
76
  blue: string;
70
77
  indigo: string;
71
78
  violet: string;
@@ -73,13 +80,6 @@ export declare const badgeVariants: import("tailwind-variants").TVReturnType<{
73
80
  fuchsia: string;
74
81
  pink: string;
75
82
  rose: string;
76
- orange: string;
77
- amber: string;
78
- lime: string;
79
- emerald: string;
80
- teal: string;
81
- cyan: string;
82
- sky: string;
83
83
  };
84
84
  size: {
85
85
  sm: string;
@@ -9,7 +9,7 @@
9
9
  variants: {
10
10
  variant: {
11
11
  primary:
12
- 'backdrop-blur-md backdrop-brightness-105 shadow-lg transform-all shadow-accent-500/5 dark:shadow-accent-500/2 disabled:shadow-md active:shadow-md inset-shadow-sm inset-shadow-accent-700/5 dark:inset-shadow-accent-500/2 focus-visible:outline-accent-500 border border-accent-500/15 dark:border-accent-500/15 hover:bg-accent-200/60 dark:hover:bg-accent-950/25 bg-accent-200/50 dark:bg-accent-950/20 text-accent-800 dark:text-accent-400',
12
+ 'backdrop-blur-md backdrop-brightness-105 shadow-lg transform-all shadow-accent-500/5 dark:shadow-accent-500/2 disabled:shadow-md active:shadow-md inset-shadow-sm inset-shadow-accent-700/5 dark:inset-shadow-accent-500/2 focus-visible:outline-accent-500 border border-accent-500/15 dark:border-accent-500/15 hover:bg-accent-200/60 dark:hover:bg-accent-950/25 bg-accent-200/50 dark:bg-accent-950/20 text-accent-950 dark:text-accent-400',
13
13
  secondary:
14
14
  'backdrop-blur-md backdrop-brightness-105 shadow-lg transform-all shadow-base-500/5 dark:shadow-base-500/2 active:shadow-md inset-shadow-sm inset-shadow-base-700/2 dark:inset-shadow-base-500/2 focus-visible:outline-base-800 dark:focus-visible:outline-base-200 bg-base-300/40 dark:bg-base-800/30 text-base-900 dark:text-base-50 hover:bg-base-300/45 dark:hover:bg-base-800/35 border border-base-300/50 dark:border-base-700/30',
15
15
  link: 'focus-visible:outline-base-900 dark:focus-visible:outline-base-50 text-base-800 dark:text-base-200 font-semibold hover:text-accent-600 dark:hover:text-accent-400 data-[current=true]:text-accent-600 dark:data-[current=true]:text-accent-400',
@@ -1,61 +1,24 @@
1
- <script lang="ts" module>
2
- export const theme = $state({
3
- dark: false
4
- });
5
- </script>
6
-
7
1
  <script lang="ts">
8
2
  import { onMount } from 'svelte';
9
3
  import { Button, type ButtonProps } from '../button';
10
4
  import { cn } from '../../utils';
5
+ import { ModeWatcher, toggleMode } from 'mode-watcher';
11
6
 
12
- onMount(() => {
13
- // load from local storage
14
- const savedDarkMode = localStorage.getItem('darkMode');
15
- if (savedDarkMode) {
16
- theme.dark = JSON.parse(savedDarkMode);
17
- } else {
18
- // prefers color scheme?
19
- theme.dark = window.matchMedia('(prefers-color-scheme: dark)').matches;
20
- }
21
-
22
- // remove local storage
23
- // localStorage.removeItem("darkMode");
24
- setTheme(theme.dark);
25
-
26
- // recommended method for newer browsers: specify event-type as first argument
27
- window
28
- .matchMedia('(prefers-color-scheme: dark)')
29
- .addEventListener('change', (e) => e.matches && toggleTheme());
30
-
31
- window
32
- .matchMedia('(prefers-color-scheme: light)')
33
- .addEventListener('change', (e) => e.matches && toggleTheme());
34
- });
35
-
36
- function setTheme(dark: Boolean) {
37
- var root = document.getElementsByTagName('html')[0];
38
-
39
- if (dark) {
40
- root.classList.add('dark');
41
- } else {
42
- root.classList.remove('dark');
43
- }
44
- }
45
-
46
- function toggleTheme() {
47
- theme.dark = !theme.dark;
48
- // save to local storage
49
- localStorage.setItem('darkMode', JSON.stringify(theme.dark));
50
- setTheme(theme.dark);
51
- }
52
-
53
- let { class: className, ref = $bindable(null), ...restProps }: ButtonProps = $props();
7
+ let {
8
+ class: className,
9
+ ref = $bindable(null),
10
+ defaultMode = 'system',
11
+ ...restProps
12
+ }: ButtonProps & {
13
+ defaultMode?: 'light' | 'dark' | 'system';
14
+ } = $props();
54
15
  </script>
55
16
 
17
+ <ModeWatcher {defaultMode} />
18
+
56
19
  <Button
57
20
  variant="link"
58
- onclick={toggleTheme}
21
+ onclick={toggleMode}
59
22
  class={cn(
60
23
  'theme-toggle focus-visible:outline-base-900 dark:focus-visible:outline-base-100 flex items-center justify-center rounded-2xl focus-visible:outline-2',
61
24
  className
@@ -1,7 +1,7 @@
1
- export declare const theme: {
2
- dark: boolean;
3
- };
4
1
  import { type ButtonProps } from '../button';
5
- declare const ThemeToggle: import("svelte").Component<ButtonProps, {}, "ref">;
2
+ type $$ComponentProps = ButtonProps & {
3
+ defaultMode?: 'light' | 'dark' | 'system';
4
+ };
5
+ declare const ThemeToggle: import("svelte").Component<$$ComponentProps, {}, "ref">;
6
6
  type ThemeToggle = ReturnType<typeof ThemeToggle>;
7
7
  export default ThemeToggle;
@@ -1,2 +1,2 @@
1
1
  export { default as ThemeToggle } from './ThemeToggle.svelte';
2
- export { theme } from './ThemeToggle.svelte';
2
+ export { toggleMode, setMode, resetMode, mode, userPrefersMode, systemPrefersMode } from 'mode-watcher';
@@ -1,2 +1,2 @@
1
1
  export { default as ThemeToggle } from './ThemeToggle.svelte';
2
- export { theme } from './ThemeToggle.svelte';
2
+ export { toggleMode, setMode, resetMode, mode, userPrefersMode, systemPrefersMode } from 'mode-watcher';
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@foxui/core",
3
3
  "private": false,
4
- "version": "0.4.2",
4
+ "version": "0.4.4",
5
5
  "type": "module",
6
6
  "files": [
7
7
  "dist"
@@ -21,7 +21,9 @@
21
21
  "@eslint/compat": "^1.2.5",
22
22
  "@eslint/js": "^9.18.0",
23
23
  "@sveltejs/adapter-auto": "^6.0.0",
24
+ "@sveltejs/adapter-static": "^3.0.8",
24
25
  "@sveltejs/kit": "^2.16.0",
26
+ "@sveltejs/package": "^2.3.11",
25
27
  "@sveltejs/vite-plugin-svelte": "^5.0.0",
26
28
  "@tailwindcss/forms": "^0.5.9",
27
29
  "@tailwindcss/typography": "^0.5.15",
@@ -38,14 +40,13 @@
38
40
  "tailwindcss": "^4.1.5",
39
41
  "typescript": "^5.0.0",
40
42
  "typescript-eslint": "^8.20.0",
41
- "vite": "^6.2.6",
42
- "@sveltejs/adapter-static": "^3.0.8",
43
- "@sveltejs/package": "^2.3.11"
43
+ "vite": "^6.2.6"
44
44
  },
45
45
  "dependencies": {
46
46
  "@number-flow/svelte": "^0.3.7",
47
47
  "bits-ui": "^1.4.3",
48
48
  "clsx": "^2.1.1",
49
+ "mode-watcher": "^1.1.0",
49
50
  "svelte-sonner": "^0.3.28",
50
51
  "tailwind-merge": "^3.2.0",
51
52
  "tailwind-variants": "^1.0.0"