@foxui/core 0.4.3 → 0.4.5

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.
@@ -65,7 +65,6 @@
65
65
  WithElementRef<HTMLAnchorAttributes> & {
66
66
  variant?: ButtonVariant;
67
67
  size?: ButtonSize;
68
- checkCurrent?: boolean;
69
68
  };
70
69
  </script>
71
70
 
@@ -85,7 +84,7 @@
85
84
  {#if href}
86
85
  <a
87
86
  bind:this={ref}
88
- class={cn('rounded-box', buttonVariants({ variant, size }), className)}
87
+ class={cn(buttonVariants({ variant, size }), className)}
89
88
  {href}
90
89
  {...restProps}
91
90
  >
@@ -94,7 +93,7 @@
94
93
  {:else}
95
94
  <button
96
95
  bind:this={ref}
97
- class={cn('rounded-box', buttonVariants({ variant, size }), className)}
96
+ class={cn(buttonVariants({ variant, size }), className)}
98
97
  {type}
99
98
  {...restProps}
100
99
  >
@@ -103,7 +103,6 @@ export type ButtonSize = VariantProps<typeof buttonVariants>['size'];
103
103
  export type ButtonProps = WithElementRef<HTMLButtonAttributes> & WithElementRef<HTMLAnchorAttributes> & {
104
104
  variant?: ButtonVariant;
105
105
  size?: ButtonSize;
106
- checkCurrent?: boolean;
107
106
  };
108
107
  declare const Button: import("svelte").Component<ButtonProps, {}, "ref">;
109
108
  type Button = ReturnType<typeof Button>;
@@ -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.3",
4
+ "version": "0.4.5",
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"