@marianmeres/stuic 3.0.1 → 3.0.3

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 (81) hide show
  1. package/dist/components/AlertConfirmPrompt/index.css +4 -4
  2. package/dist/components/Button/index.css +7 -7
  3. package/dist/components/DismissibleMessage/DismissibleMessage.svelte +1 -2
  4. package/dist/components/DismissibleMessage/index.css +10 -10
  5. package/dist/components/DropdownMenu/DropdownMenu.svelte +317 -73
  6. package/dist/components/DropdownMenu/DropdownMenu.svelte.d.ts +19 -0
  7. package/dist/components/DropdownMenu/index.css +64 -0
  8. package/dist/components/DropdownMenu/index.d.ts +1 -1
  9. package/dist/components/HoverExpandableWidth/HoverExpandableWidth.svelte +3 -1
  10. package/dist/components/HoverExpandableWidth/HoverExpandableWidth.svelte.d.ts +1 -0
  11. package/dist/components/Input/index.css +1 -1
  12. package/dist/components/Switch/index.css +1 -1
  13. package/dist/components/ThemePreview/ThemePreview.svelte +17 -17
  14. package/dist/components/ThemePreview/index.css +11 -12
  15. package/dist/icons/index.d.ts +1 -0
  16. package/dist/icons/index.js +1 -0
  17. package/dist/index.css +1 -1
  18. package/dist/themes/css/blue-orange.css +253 -0
  19. package/dist/themes/css/cyan-red.css +253 -0
  20. package/dist/themes/css/cyan-slate.css +253 -0
  21. package/dist/themes/css/emerald-amber-forest.css +253 -0
  22. package/dist/themes/css/emerald-pink.css +253 -0
  23. package/dist/themes/css/fuchsia-emerald.css +253 -0
  24. package/dist/themes/css/gray.css +253 -0
  25. package/dist/themes/css/indigo-amber.css +253 -0
  26. package/dist/themes/css/lime-fuchsia-neon.css +253 -0
  27. package/dist/themes/css/neutral.css +253 -0
  28. package/dist/themes/css/orange-pink-sunset.css +253 -0
  29. package/dist/themes/css/pink-emerald.css +253 -0
  30. package/dist/themes/css/pink-teal.css +253 -0
  31. package/dist/themes/css/purple-yellow.css +253 -0
  32. package/dist/themes/css/rainbow.css +253 -0
  33. package/dist/themes/css/red-blue.css +253 -0
  34. package/dist/themes/css/red-cyan.css +253 -0
  35. package/dist/themes/css/red-sky.css +253 -0
  36. package/dist/themes/css/rose-teal.css +253 -0
  37. package/dist/themes/css/sky-amber.css +253 -0
  38. package/dist/themes/css/slate-cyan.css +253 -0
  39. package/dist/themes/css/slate-teal-ocean.css +253 -0
  40. package/dist/themes/css/stone-orange-earth.css +253 -0
  41. package/dist/themes/css/teal-rose.css +253 -0
  42. package/dist/themes/css/violet-lime.css +253 -0
  43. package/dist/themes/css/violet-rose-dusk.css +253 -0
  44. package/dist/themes/emerald-amber-forest.d.ts +6 -0
  45. package/dist/themes/emerald-amber-forest.js +175 -0
  46. package/dist/themes/lime-fuchsia-neon.d.ts +6 -0
  47. package/dist/themes/lime-fuchsia-neon.js +175 -0
  48. package/dist/themes/orange-pink-sunset.d.ts +6 -0
  49. package/dist/themes/orange-pink-sunset.js +175 -0
  50. package/dist/themes/pink-teal.d.ts +6 -0
  51. package/dist/themes/pink-teal.js +175 -0
  52. package/dist/themes/red-sky.d.ts +6 -0
  53. package/dist/themes/red-sky.js +175 -0
  54. package/dist/themes/slate-teal-ocean.d.ts +6 -0
  55. package/dist/themes/slate-teal-ocean.js +175 -0
  56. package/dist/themes/stone-orange-earth.d.ts +6 -0
  57. package/dist/themes/stone-orange-earth.js +175 -0
  58. package/dist/themes/violet-rose-dusk.d.ts +6 -0
  59. package/dist/themes/violet-rose-dusk.js +175 -0
  60. package/dist/utils/design-tokens.d.ts +1 -1
  61. package/dist/utils/design-tokens.js +15 -1
  62. package/package.json +2 -2
  63. package/dist/base.css +0 -17
  64. package/dist/themes/blue-orange.css +0 -217
  65. package/dist/themes/cyan-red.css +0 -217
  66. package/dist/themes/cyan-slate.css +0 -217
  67. package/dist/themes/emerald-pink.css +0 -217
  68. package/dist/themes/fuchsia-emerald.css +0 -217
  69. package/dist/themes/gray.css +0 -217
  70. package/dist/themes/indigo-amber.css +0 -217
  71. package/dist/themes/neutral.css +0 -217
  72. package/dist/themes/pink-emerald.css +0 -217
  73. package/dist/themes/purple-yellow.css +0 -217
  74. package/dist/themes/rainbow.css +0 -217
  75. package/dist/themes/red-blue.css +0 -217
  76. package/dist/themes/red-cyan.css +0 -217
  77. package/dist/themes/rose-teal.css +0 -217
  78. package/dist/themes/sky-amber.css +0 -217
  79. package/dist/themes/slate-cyan.css +0 -217
  80. package/dist/themes/teal-rose.css +0 -217
  81. package/dist/themes/violet-lime.css +0 -217
@@ -0,0 +1,175 @@
1
+ const light = {
2
+ colors: {
3
+ intent: {
4
+ primary: {
5
+ DEFAULT: "var(--color-slate-700)",
6
+ foreground: "var(--color-white)",
7
+ hover: "var(--color-slate-800)",
8
+ active: "var(--color-slate-900)",
9
+ },
10
+ accent: {
11
+ DEFAULT: "var(--color-teal-500)",
12
+ foreground: "var(--color-white)",
13
+ hover: "var(--color-teal-600)",
14
+ active: "var(--color-teal-700)",
15
+ },
16
+ destructive: {
17
+ DEFAULT: "var(--color-red-600)",
18
+ foreground: "var(--color-white)",
19
+ hover: "var(--color-red-700)",
20
+ active: "var(--color-red-800)",
21
+ },
22
+ warning: {
23
+ DEFAULT: "var(--color-amber-500)",
24
+ foreground: "var(--color-white)",
25
+ hover: "var(--color-amber-600)",
26
+ active: "var(--color-amber-700)",
27
+ },
28
+ success: {
29
+ DEFAULT: "var(--color-teal-600)",
30
+ foreground: "var(--color-white)",
31
+ hover: "var(--color-teal-700)",
32
+ active: "var(--color-teal-800)",
33
+ },
34
+ info: {
35
+ DEFAULT: "var(--color-cyan-500)",
36
+ foreground: "var(--color-white)",
37
+ hover: "var(--color-cyan-600)",
38
+ active: "var(--color-cyan-700)",
39
+ },
40
+ },
41
+ role: {
42
+ paired: {
43
+ background: {
44
+ DEFAULT: "var(--color-slate-50)",
45
+ foreground: "var(--color-slate-900)",
46
+ },
47
+ surface: {
48
+ DEFAULT: "var(--color-slate-100)",
49
+ foreground: "var(--color-slate-900)",
50
+ hover: "var(--color-slate-200)",
51
+ active: "var(--color-slate-300)",
52
+ },
53
+ "surface-1": {
54
+ DEFAULT: "var(--color-slate-200)",
55
+ foreground: "var(--color-slate-900)",
56
+ hover: "var(--color-slate-300)",
57
+ active: "var(--color-slate-400)",
58
+ },
59
+ "surface-2": {
60
+ DEFAULT: "var(--color-slate-300)",
61
+ foreground: "var(--color-slate-900)",
62
+ hover: "var(--color-slate-400)",
63
+ active: "var(--color-slate-500)",
64
+ },
65
+ muted: {
66
+ DEFAULT: "var(--color-slate-200)",
67
+ foreground: "var(--color-slate-500)",
68
+ hover: "var(--color-slate-300)",
69
+ active: "var(--color-slate-400)",
70
+ },
71
+ },
72
+ single: {
73
+ foreground: "var(--color-slate-900)",
74
+ border: {
75
+ DEFAULT: "var(--color-slate-300)",
76
+ hover: "var(--color-slate-400)",
77
+ active: "var(--color-slate-500)",
78
+ },
79
+ input: {
80
+ DEFAULT: "var(--color-white)",
81
+ hover: "var(--color-slate-50)",
82
+ },
83
+ ring: "color-mix(in srgb, var(--color-teal-500) 20%, transparent)",
84
+ },
85
+ },
86
+ },
87
+ };
88
+ const dark = {
89
+ colors: {
90
+ intent: {
91
+ primary: {
92
+ DEFAULT: "var(--color-slate-400)",
93
+ foreground: "var(--color-slate-950)",
94
+ hover: "var(--color-slate-300)",
95
+ active: "var(--color-slate-200)",
96
+ },
97
+ accent: {
98
+ DEFAULT: "var(--color-teal-400)",
99
+ foreground: "var(--color-white)",
100
+ hover: "var(--color-teal-300)",
101
+ active: "var(--color-teal-200)",
102
+ },
103
+ destructive: {
104
+ DEFAULT: "var(--color-red-500)",
105
+ foreground: "var(--color-white)",
106
+ hover: "var(--color-red-400)",
107
+ active: "var(--color-red-300)",
108
+ },
109
+ warning: {
110
+ DEFAULT: "var(--color-amber-400)",
111
+ foreground: "var(--color-black)",
112
+ hover: "var(--color-amber-300)",
113
+ active: "var(--color-amber-200)",
114
+ },
115
+ success: {
116
+ DEFAULT: "var(--color-teal-500)",
117
+ foreground: "var(--color-white)",
118
+ hover: "var(--color-teal-400)",
119
+ active: "var(--color-teal-300)",
120
+ },
121
+ info: {
122
+ DEFAULT: "var(--color-cyan-400)",
123
+ foreground: "var(--color-black)",
124
+ hover: "var(--color-cyan-300)",
125
+ active: "var(--color-cyan-200)",
126
+ },
127
+ },
128
+ role: {
129
+ paired: {
130
+ background: {
131
+ DEFAULT: "var(--color-slate-950)",
132
+ foreground: "var(--color-slate-50)",
133
+ },
134
+ surface: {
135
+ DEFAULT: "var(--color-slate-900)",
136
+ foreground: "var(--color-slate-100)",
137
+ hover: "var(--color-slate-800)",
138
+ active: "var(--color-slate-700)",
139
+ },
140
+ "surface-1": {
141
+ DEFAULT: "var(--color-slate-800)",
142
+ foreground: "var(--color-slate-100)",
143
+ hover: "var(--color-slate-700)",
144
+ active: "var(--color-slate-600)",
145
+ },
146
+ "surface-2": {
147
+ DEFAULT: "var(--color-slate-700)",
148
+ foreground: "var(--color-slate-100)",
149
+ hover: "var(--color-slate-600)",
150
+ active: "var(--color-slate-500)",
151
+ },
152
+ muted: {
153
+ DEFAULT: "var(--color-slate-800)",
154
+ foreground: "var(--color-slate-500)",
155
+ hover: "var(--color-slate-700)",
156
+ active: "var(--color-slate-600)",
157
+ },
158
+ },
159
+ single: {
160
+ foreground: "var(--color-slate-50)",
161
+ border: {
162
+ DEFAULT: "var(--color-slate-700)",
163
+ hover: "var(--color-slate-600)",
164
+ active: "var(--color-slate-500)",
165
+ },
166
+ input: {
167
+ DEFAULT: "var(--color-slate-900)",
168
+ hover: "var(--color-slate-800)",
169
+ },
170
+ ring: "color-mix(in srgb, var(--color-teal-400) 25%, transparent)",
171
+ },
172
+ },
173
+ },
174
+ };
175
+ export default { light, dark };
@@ -0,0 +1,6 @@
1
+ import type { TokenSchema } from "../utils/design-tokens.js";
2
+ declare const _default: {
3
+ light: TokenSchema;
4
+ dark: TokenSchema;
5
+ };
6
+ export default _default;
@@ -0,0 +1,175 @@
1
+ const light = {
2
+ colors: {
3
+ intent: {
4
+ primary: {
5
+ DEFAULT: "var(--color-stone-700)",
6
+ foreground: "var(--color-white)",
7
+ hover: "var(--color-stone-800)",
8
+ active: "var(--color-stone-900)",
9
+ },
10
+ accent: {
11
+ DEFAULT: "var(--color-orange-600)",
12
+ foreground: "var(--color-white)",
13
+ hover: "var(--color-orange-700)",
14
+ active: "var(--color-orange-800)",
15
+ },
16
+ destructive: {
17
+ DEFAULT: "var(--color-red-600)",
18
+ foreground: "var(--color-white)",
19
+ hover: "var(--color-red-700)",
20
+ active: "var(--color-red-800)",
21
+ },
22
+ warning: {
23
+ DEFAULT: "var(--color-orange-500)",
24
+ foreground: "var(--color-white)",
25
+ hover: "var(--color-orange-600)",
26
+ active: "var(--color-orange-700)",
27
+ },
28
+ success: {
29
+ DEFAULT: "var(--color-green-600)",
30
+ foreground: "var(--color-white)",
31
+ hover: "var(--color-green-700)",
32
+ active: "var(--color-green-800)",
33
+ },
34
+ info: {
35
+ DEFAULT: "var(--color-sky-600)",
36
+ foreground: "var(--color-white)",
37
+ hover: "var(--color-sky-700)",
38
+ active: "var(--color-sky-800)",
39
+ },
40
+ },
41
+ role: {
42
+ paired: {
43
+ background: {
44
+ DEFAULT: "var(--color-stone-100)",
45
+ foreground: "var(--color-stone-900)",
46
+ },
47
+ surface: {
48
+ DEFAULT: "var(--color-stone-200)",
49
+ foreground: "var(--color-stone-900)",
50
+ hover: "var(--color-stone-300)",
51
+ active: "var(--color-stone-400)",
52
+ },
53
+ "surface-1": {
54
+ DEFAULT: "var(--color-stone-300)",
55
+ foreground: "var(--color-stone-900)",
56
+ hover: "var(--color-stone-400)",
57
+ active: "var(--color-stone-500)",
58
+ },
59
+ "surface-2": {
60
+ DEFAULT: "var(--color-stone-400)",
61
+ foreground: "var(--color-stone-900)",
62
+ hover: "var(--color-stone-500)",
63
+ active: "var(--color-stone-600)",
64
+ },
65
+ muted: {
66
+ DEFAULT: "var(--color-stone-300)",
67
+ foreground: "var(--color-stone-500)",
68
+ hover: "var(--color-stone-400)",
69
+ active: "var(--color-stone-500)",
70
+ },
71
+ },
72
+ single: {
73
+ foreground: "var(--color-stone-900)",
74
+ border: {
75
+ DEFAULT: "var(--color-stone-400)",
76
+ hover: "var(--color-stone-500)",
77
+ active: "var(--color-stone-600)",
78
+ },
79
+ input: {
80
+ DEFAULT: "var(--color-stone-50)",
81
+ hover: "var(--color-stone-100)",
82
+ },
83
+ ring: "color-mix(in srgb, var(--color-stone-700) 20%, transparent)",
84
+ },
85
+ },
86
+ },
87
+ };
88
+ const dark = {
89
+ colors: {
90
+ intent: {
91
+ primary: {
92
+ DEFAULT: "var(--color-stone-400)",
93
+ foreground: "var(--color-stone-950)",
94
+ hover: "var(--color-stone-300)",
95
+ active: "var(--color-stone-200)",
96
+ },
97
+ accent: {
98
+ DEFAULT: "var(--color-orange-500)",
99
+ foreground: "var(--color-black)",
100
+ hover: "var(--color-orange-400)",
101
+ active: "var(--color-orange-300)",
102
+ },
103
+ destructive: {
104
+ DEFAULT: "var(--color-red-500)",
105
+ foreground: "var(--color-white)",
106
+ hover: "var(--color-red-400)",
107
+ active: "var(--color-red-300)",
108
+ },
109
+ warning: {
110
+ DEFAULT: "var(--color-orange-400)",
111
+ foreground: "var(--color-black)",
112
+ hover: "var(--color-orange-300)",
113
+ active: "var(--color-orange-200)",
114
+ },
115
+ success: {
116
+ DEFAULT: "var(--color-green-500)",
117
+ foreground: "var(--color-white)",
118
+ hover: "var(--color-green-400)",
119
+ active: "var(--color-green-300)",
120
+ },
121
+ info: {
122
+ DEFAULT: "var(--color-sky-400)",
123
+ foreground: "var(--color-black)",
124
+ hover: "var(--color-sky-300)",
125
+ active: "var(--color-sky-200)",
126
+ },
127
+ },
128
+ role: {
129
+ paired: {
130
+ background: {
131
+ DEFAULT: "var(--color-stone-950)",
132
+ foreground: "var(--color-stone-100)",
133
+ },
134
+ surface: {
135
+ DEFAULT: "var(--color-stone-900)",
136
+ foreground: "var(--color-stone-100)",
137
+ hover: "var(--color-stone-800)",
138
+ active: "var(--color-stone-700)",
139
+ },
140
+ "surface-1": {
141
+ DEFAULT: "var(--color-stone-800)",
142
+ foreground: "var(--color-stone-100)",
143
+ hover: "var(--color-stone-700)",
144
+ active: "var(--color-stone-600)",
145
+ },
146
+ "surface-2": {
147
+ DEFAULT: "var(--color-stone-700)",
148
+ foreground: "var(--color-stone-100)",
149
+ hover: "var(--color-stone-600)",
150
+ active: "var(--color-stone-500)",
151
+ },
152
+ muted: {
153
+ DEFAULT: "var(--color-stone-800)",
154
+ foreground: "var(--color-stone-500)",
155
+ hover: "var(--color-stone-700)",
156
+ active: "var(--color-stone-600)",
157
+ },
158
+ },
159
+ single: {
160
+ foreground: "var(--color-stone-100)",
161
+ border: {
162
+ DEFAULT: "var(--color-stone-700)",
163
+ hover: "var(--color-stone-600)",
164
+ active: "var(--color-stone-500)",
165
+ },
166
+ input: {
167
+ DEFAULT: "var(--color-stone-900)",
168
+ hover: "var(--color-stone-800)",
169
+ },
170
+ ring: "color-mix(in srgb, var(--color-stone-400) 25%, transparent)",
171
+ },
172
+ },
173
+ },
174
+ };
175
+ export default { light, dark };
@@ -0,0 +1,6 @@
1
+ import type { TokenSchema } from "../utils/design-tokens.js";
2
+ declare const _default: {
3
+ light: TokenSchema;
4
+ dark: TokenSchema;
5
+ };
6
+ export default _default;
@@ -0,0 +1,175 @@
1
+ const light = {
2
+ colors: {
3
+ intent: {
4
+ primary: {
5
+ DEFAULT: "var(--color-violet-600)",
6
+ foreground: "var(--color-white)",
7
+ hover: "var(--color-violet-700)",
8
+ active: "var(--color-violet-800)",
9
+ },
10
+ accent: {
11
+ DEFAULT: "var(--color-rose-500)",
12
+ foreground: "var(--color-white)",
13
+ hover: "var(--color-rose-600)",
14
+ active: "var(--color-rose-700)",
15
+ },
16
+ destructive: {
17
+ DEFAULT: "var(--color-red-600)",
18
+ foreground: "var(--color-white)",
19
+ hover: "var(--color-red-700)",
20
+ active: "var(--color-red-800)",
21
+ },
22
+ warning: {
23
+ DEFAULT: "var(--color-amber-500)",
24
+ foreground: "var(--color-white)",
25
+ hover: "var(--color-amber-600)",
26
+ active: "var(--color-amber-700)",
27
+ },
28
+ success: {
29
+ DEFAULT: "var(--color-emerald-600)",
30
+ foreground: "var(--color-white)",
31
+ hover: "var(--color-emerald-700)",
32
+ active: "var(--color-emerald-800)",
33
+ },
34
+ info: {
35
+ DEFAULT: "var(--color-sky-500)",
36
+ foreground: "var(--color-white)",
37
+ hover: "var(--color-sky-600)",
38
+ active: "var(--color-sky-700)",
39
+ },
40
+ },
41
+ role: {
42
+ paired: {
43
+ background: {
44
+ DEFAULT: "var(--color-zinc-50)",
45
+ foreground: "var(--color-zinc-900)",
46
+ },
47
+ surface: {
48
+ DEFAULT: "var(--color-zinc-100)",
49
+ foreground: "var(--color-zinc-900)",
50
+ hover: "var(--color-zinc-200)",
51
+ active: "var(--color-zinc-300)",
52
+ },
53
+ "surface-1": {
54
+ DEFAULT: "var(--color-zinc-200)",
55
+ foreground: "var(--color-zinc-900)",
56
+ hover: "var(--color-zinc-300)",
57
+ active: "var(--color-zinc-400)",
58
+ },
59
+ "surface-2": {
60
+ DEFAULT: "var(--color-zinc-300)",
61
+ foreground: "var(--color-zinc-900)",
62
+ hover: "var(--color-zinc-400)",
63
+ active: "var(--color-zinc-500)",
64
+ },
65
+ muted: {
66
+ DEFAULT: "var(--color-zinc-200)",
67
+ foreground: "var(--color-zinc-500)",
68
+ hover: "var(--color-zinc-300)",
69
+ active: "var(--color-zinc-400)",
70
+ },
71
+ },
72
+ single: {
73
+ foreground: "var(--color-zinc-900)",
74
+ border: {
75
+ DEFAULT: "var(--color-zinc-300)",
76
+ hover: "var(--color-zinc-400)",
77
+ active: "var(--color-zinc-500)",
78
+ },
79
+ input: {
80
+ DEFAULT: "var(--color-white)",
81
+ hover: "var(--color-zinc-50)",
82
+ },
83
+ ring: "color-mix(in srgb, var(--color-violet-500) 20%, transparent)",
84
+ },
85
+ },
86
+ },
87
+ };
88
+ const dark = {
89
+ colors: {
90
+ intent: {
91
+ primary: {
92
+ DEFAULT: "var(--color-violet-400)",
93
+ foreground: "var(--color-white)",
94
+ hover: "var(--color-violet-300)",
95
+ active: "var(--color-violet-200)",
96
+ },
97
+ accent: {
98
+ DEFAULT: "var(--color-rose-400)",
99
+ foreground: "var(--color-white)",
100
+ hover: "var(--color-rose-300)",
101
+ active: "var(--color-rose-200)",
102
+ },
103
+ destructive: {
104
+ DEFAULT: "var(--color-red-500)",
105
+ foreground: "var(--color-white)",
106
+ hover: "var(--color-red-400)",
107
+ active: "var(--color-red-300)",
108
+ },
109
+ warning: {
110
+ DEFAULT: "var(--color-amber-400)",
111
+ foreground: "var(--color-black)",
112
+ hover: "var(--color-amber-300)",
113
+ active: "var(--color-amber-200)",
114
+ },
115
+ success: {
116
+ DEFAULT: "var(--color-emerald-500)",
117
+ foreground: "var(--color-white)",
118
+ hover: "var(--color-emerald-400)",
119
+ active: "var(--color-emerald-300)",
120
+ },
121
+ info: {
122
+ DEFAULT: "var(--color-sky-400)",
123
+ foreground: "var(--color-black)",
124
+ hover: "var(--color-sky-300)",
125
+ active: "var(--color-sky-200)",
126
+ },
127
+ },
128
+ role: {
129
+ paired: {
130
+ background: {
131
+ DEFAULT: "var(--color-zinc-950)",
132
+ foreground: "var(--color-zinc-50)",
133
+ },
134
+ surface: {
135
+ DEFAULT: "var(--color-zinc-900)",
136
+ foreground: "var(--color-zinc-100)",
137
+ hover: "var(--color-zinc-800)",
138
+ active: "var(--color-zinc-700)",
139
+ },
140
+ "surface-1": {
141
+ DEFAULT: "var(--color-zinc-800)",
142
+ foreground: "var(--color-zinc-100)",
143
+ hover: "var(--color-zinc-700)",
144
+ active: "var(--color-zinc-600)",
145
+ },
146
+ "surface-2": {
147
+ DEFAULT: "var(--color-zinc-700)",
148
+ foreground: "var(--color-zinc-100)",
149
+ hover: "var(--color-zinc-600)",
150
+ active: "var(--color-zinc-500)",
151
+ },
152
+ muted: {
153
+ DEFAULT: "var(--color-zinc-800)",
154
+ foreground: "var(--color-zinc-500)",
155
+ hover: "var(--color-zinc-700)",
156
+ active: "var(--color-zinc-600)",
157
+ },
158
+ },
159
+ single: {
160
+ foreground: "var(--color-zinc-50)",
161
+ border: {
162
+ DEFAULT: "var(--color-zinc-700)",
163
+ hover: "var(--color-zinc-600)",
164
+ active: "var(--color-zinc-500)",
165
+ },
166
+ input: {
167
+ DEFAULT: "var(--color-zinc-900)",
168
+ hover: "var(--color-zinc-800)",
169
+ },
170
+ ring: "color-mix(in srgb, var(--color-violet-400) 25%, transparent)",
171
+ },
172
+ },
173
+ },
174
+ };
175
+ export default { light, dark };
@@ -35,7 +35,7 @@ export type TokenSchema = {
35
35
  };
36
36
  };
37
37
  export type GeneratedTokens = Record<string, string>;
38
- export declare function generateCssTokens(schema: TokenSchema, prefix?: string): GeneratedTokens;
38
+ export declare function generateCssTokens(schema: TokenSchema, prefix?: string, mode?: "light" | "dark"): GeneratedTokens;
39
39
  /** Convert tokens object to CSS :root declaration */
40
40
  export declare function toCssString(tokens: GeneratedTokens, selector?: string): string;
41
41
  /** Create dark mode override tokens */
@@ -38,12 +38,26 @@ function generateSingleColorTokens(tokens, key, color, prefix = "stuic-") {
38
38
  // ============================================================================
39
39
  // Generator
40
40
  // ============================================================================
41
- export function generateCssTokens(schema, prefix = "stuic-") {
41
+ export function generateCssTokens(schema, prefix = "stuic-", mode = "light") {
42
42
  const tokens = {};
43
43
  // Intent colors
44
44
  for (const [key, pair] of Object.entries(schema.colors.intent)) {
45
45
  generatePairedColorTokens(tokens, key, pair, prefix);
46
46
  }
47
+ // Surface-intent tokens (auto-derived from intent colors)
48
+ // These provide subtle tinted backgrounds for callouts, alerts, highlighted content, etc.
49
+ const contrastMix = mode === "light" ? "black" : "white";
50
+ for (const key of Object.keys(schema.colors.intent)) {
51
+ // Background: 15% tint
52
+ tokens[`${prefix}color-surface-${key}`] =
53
+ `color-mix(in srgb, var(--${prefix}color-${key}) 15%, var(--stuic-color-background))`;
54
+ // Foreground: darken in light mode, lighten in dark mode for contrast
55
+ tokens[`${prefix}color-surface-${key}-foreground`] =
56
+ `color-mix(in srgb, var(--${prefix}color-${key}), ${contrastMix} 10%)`;
57
+ // Border: 30% tint
58
+ tokens[`${prefix}color-surface-${key}-border`] =
59
+ `color-mix(in srgb, var(--${prefix}color-${key}) 30%, var(--stuic-color-background))`;
60
+ }
47
61
  // Role colors (paired)
48
62
  for (const [key, pair] of Object.entries(schema.colors.role.paired)) {
49
63
  generatePairedColorTokens(tokens, key, pair, prefix);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@marianmeres/stuic",
3
- "version": "3.0.1",
3
+ "version": "3.0.3",
4
4
  "files": [
5
5
  "dist",
6
6
  "!dist/**/*.test.*",
@@ -74,6 +74,6 @@
74
74
  "rp": "pnpm run build && ./release.sh patch",
75
75
  "rpm": "pnpm run build && ./release.sh minor",
76
76
  "build:theme": "tsx scripts/generate-theme.ts",
77
- "build:theme:all": "pnpm run build:theme --indir=src/lib/themes --outdir=src/lib/themes"
77
+ "build:theme:all": "pnpm run build:theme --indir=src/lib/themes --outdir=src/lib/themes/css"
78
78
  }
79
79
  }
package/dist/base.css DELETED
@@ -1,17 +0,0 @@
1
- /* Base styles for STUIC components */
2
- @layer base {
3
- button:not(:disabled),
4
- [role="button"]:not(:disabled) {
5
- cursor: pointer;
6
- }
7
-
8
- button:disabled,
9
- [role="button"]:disabled,
10
- input:disabled {
11
- cursor: not-allowed !important;
12
- }
13
- }
14
-
15
- .scrollbar-thin {
16
- scrollbar-width: thin;
17
- }