@duskmoon-dev/core 0.1.0 → 1.0.0

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 (51) hide show
  1. package/README.md +366 -78
  2. package/dist/components/accordion.css +244 -0
  3. package/dist/components/alert.css +199 -0
  4. package/dist/components/appbar.css +308 -0
  5. package/dist/components/autocomplete.css +269 -0
  6. package/dist/components/avatar.css +167 -0
  7. package/dist/components/badge.css +178 -0
  8. package/dist/components/bottom-navigation.css +263 -0
  9. package/dist/components/bottomsheet.css +334 -0
  10. package/dist/components/button.css +474 -0
  11. package/dist/components/card.css +220 -0
  12. package/dist/components/chip.css +211 -0
  13. package/dist/components/collapse.css +254 -0
  14. package/dist/components/datepicker.css +347 -0
  15. package/dist/components/dialog.css +173 -0
  16. package/dist/components/divider.css +284 -0
  17. package/dist/components/drawer.css +371 -0
  18. package/dist/components/file-upload.css +321 -0
  19. package/dist/components/form.css +441 -0
  20. package/dist/components/index.css +9994 -0
  21. package/dist/components/input.css +240 -0
  22. package/dist/components/list.css +188 -0
  23. package/dist/components/markdown-body.css +405 -0
  24. package/dist/components/modal.css +291 -0
  25. package/dist/components/navigation.css +392 -0
  26. package/dist/components/popover.css +326 -0
  27. package/dist/components/progress.css +238 -0
  28. package/dist/components/rating.css +230 -0
  29. package/dist/components/skeleton.css +216 -0
  30. package/dist/components/slider.css +327 -0
  31. package/dist/components/snackbar.css +311 -0
  32. package/dist/components/stepper.css +313 -0
  33. package/dist/components/switch.css +277 -0
  34. package/dist/components/table.css +199 -0
  35. package/dist/components/timeline.css +353 -0
  36. package/dist/components/toast.css +251 -0
  37. package/dist/components/tooltip.css +284 -0
  38. package/dist/index.css +10699 -0
  39. package/dist/themes/moonlight.css +168 -0
  40. package/dist/themes/sunshine.css +166 -0
  41. package/dist/types/index.d.ts +14 -0
  42. package/dist/types/index.d.ts.map +1 -0
  43. package/dist/types/plugin.d.ts +69 -0
  44. package/dist/types/plugin.d.ts.map +1 -0
  45. package/dist/types/theme.d.ts +202 -0
  46. package/dist/types/theme.d.ts.map +1 -0
  47. package/package.json +137 -18
  48. package/dist/index.cjs +0 -243
  49. package/dist/index.cjs.map +0 -15
  50. package/dist/index.js +0 -211
  51. package/dist/index.js.map +0 -15
@@ -0,0 +1,313 @@
1
+ /**
2
+ * Stepper Component Styles
3
+ * DuskMoonUI - Material Design 3 inspired stepper/wizard system
4
+ */
5
+
6
+ @layer components {
7
+ /* Base Stepper (Horizontal) */
8
+ .stepper {
9
+ display: flex;
10
+ align-items: flex-start;
11
+ gap: 0;
12
+ }
13
+
14
+ /* Stepper Step */
15
+ .stepper-step {
16
+ display: flex;
17
+ flex-direction: column;
18
+ align-items: center;
19
+ flex: 1;
20
+ position: relative;
21
+ }
22
+
23
+ /* Step Connector (using explicit class) */
24
+ .stepper-step-connector {
25
+ position: absolute;
26
+ top: 1.25rem;
27
+ left: calc(50% + 1.25rem);
28
+ width: calc(100% - 2.5rem);
29
+ height: 2px;
30
+ background-color: var(--color-outline-variant);
31
+ }
32
+
33
+ .stepper-step:last-child .stepper-step-connector {
34
+ display: none;
35
+ }
36
+
37
+ .stepper-step-completed .stepper-step-connector {
38
+ background-color: var(--color-primary);
39
+ }
40
+
41
+ /* Step Button */
42
+ .stepper-step-button {
43
+ display: flex;
44
+ flex-direction: column;
45
+ align-items: center;
46
+ gap: 0.5rem;
47
+ cursor: pointer;
48
+ z-index: 1;
49
+ background: none;
50
+ border: none;
51
+ padding: 0;
52
+ }
53
+
54
+ .stepper-step-button:focus-visible {
55
+ outline: none;
56
+ }
57
+
58
+ .stepper-step-button:focus-visible .stepper-step-icon {
59
+ outline: 2px solid var(--color-primary);
60
+ outline-offset: 2px;
61
+ }
62
+
63
+ /* Step Icon (Number/Icon Circle) */
64
+ .stepper-step-icon {
65
+ display: flex;
66
+ align-items: center;
67
+ justify-content: center;
68
+ width: 2.5rem;
69
+ height: 2.5rem;
70
+ font-size: 0.875rem;
71
+ font-weight: 500;
72
+ color: var(--color-on-surface-variant);
73
+ background-color: var(--color-surface);
74
+ border: 2px solid var(--color-outline-variant);
75
+ border-radius: 50%;
76
+ transition: background-color 150ms ease-in-out, border-color 150ms ease-in-out, color 150ms ease-in-out;
77
+ }
78
+
79
+ .stepper-step-active .stepper-step-icon {
80
+ background-color: var(--color-primary);
81
+ border-color: var(--color-primary);
82
+ color: var(--color-on-primary);
83
+ }
84
+
85
+ .stepper-step-completed .stepper-step-icon {
86
+ background-color: var(--color-primary);
87
+ border-color: var(--color-primary);
88
+ color: var(--color-on-primary);
89
+ }
90
+
91
+ .stepper-step-error .stepper-step-icon {
92
+ background-color: var(--color-error);
93
+ border-color: var(--color-error);
94
+ color: var(--color-on-error);
95
+ }
96
+
97
+ .stepper-step-disabled .stepper-step-icon {
98
+ opacity: 0.6;
99
+ cursor: not-allowed;
100
+ }
101
+
102
+ /* Step Labels */
103
+ .stepper-step-label {
104
+ font-size: 0.875rem;
105
+ font-weight: 500;
106
+ color: var(--color-on-surface);
107
+ text-align: center;
108
+ }
109
+
110
+ .stepper-step-active .stepper-step-label {
111
+ color: var(--color-primary);
112
+ }
113
+
114
+ .stepper-step-error .stepper-step-label {
115
+ color: var(--color-error);
116
+ }
117
+
118
+ .stepper-step-description {
119
+ font-size: 0.75rem;
120
+ color: var(--color-on-surface-variant);
121
+ margin-top: 0.125rem;
122
+ text-align: center;
123
+ }
124
+
125
+ /* Step Content (for vertical stepper) */
126
+ .stepper-step-content {
127
+ margin-top: 1.5rem;
128
+ padding: 0 1rem;
129
+ width: 100%;
130
+ }
131
+
132
+ /* Optional Step Marker */
133
+ .stepper-step-optional::after {
134
+ content: '(Optional)';
135
+ display: block;
136
+ font-size: 0.6875rem;
137
+ color: var(--color-on-surface-variant);
138
+ margin-top: 0.125rem;
139
+ }
140
+
141
+ /* Vertical Stepper */
142
+ .stepper-vertical {
143
+ flex-direction: column;
144
+ align-items: flex-start;
145
+ }
146
+
147
+ .stepper-vertical .stepper-step {
148
+ flex-direction: row;
149
+ align-items: flex-start;
150
+ width: 100%;
151
+ }
152
+
153
+ .stepper-vertical .stepper-step-connector {
154
+ top: 2.5rem;
155
+ left: 1.25rem;
156
+ width: 2px;
157
+ height: calc(100% - 2.5rem);
158
+ transform: translateX(-50%);
159
+ }
160
+
161
+ .stepper-vertical .stepper-step-button {
162
+ flex-direction: row;
163
+ align-items: center;
164
+ }
165
+
166
+ .stepper-vertical .stepper-step-label,
167
+ .stepper-vertical .stepper-step-description {
168
+ text-align: left;
169
+ margin-left: 1rem;
170
+ }
171
+
172
+ .stepper-vertical .stepper-step-content {
173
+ margin-top: 0;
174
+ margin-left: 3.5rem;
175
+ padding: 1rem 0 1.5rem;
176
+ }
177
+
178
+ /* Color Variants */
179
+ .stepper-secondary .stepper-step-active .stepper-step-icon,
180
+ .stepper-secondary .stepper-step-completed .stepper-step-icon {
181
+ background-color: var(--color-secondary);
182
+ border-color: var(--color-secondary);
183
+ color: var(--color-on-secondary);
184
+ }
185
+
186
+ .stepper-secondary .stepper-step-completed .stepper-step-connector {
187
+ background-color: var(--color-secondary);
188
+ }
189
+
190
+ .stepper-secondary .stepper-step-active .stepper-step-label {
191
+ color: var(--color-secondary);
192
+ }
193
+
194
+ .stepper-tertiary .stepper-step-active .stepper-step-icon,
195
+ .stepper-tertiary .stepper-step-completed .stepper-step-icon {
196
+ background-color: var(--color-tertiary);
197
+ border-color: var(--color-tertiary);
198
+ color: var(--color-on-tertiary);
199
+ }
200
+
201
+ .stepper-tertiary .stepper-step-completed .stepper-step-connector {
202
+ background-color: var(--color-tertiary);
203
+ }
204
+
205
+ .stepper-tertiary .stepper-step-active .stepper-step-label {
206
+ color: var(--color-tertiary);
207
+ }
208
+
209
+ /* Compact/Small Variant */
210
+ .stepper-sm .stepper-step-icon {
211
+ width: 2rem;
212
+ height: 2rem;
213
+ font-size: 0.75rem;
214
+ }
215
+
216
+ .stepper-sm .stepper-step-connector {
217
+ top: 1rem;
218
+ left: calc(50% + 1rem);
219
+ width: calc(100% - 2rem);
220
+ }
221
+
222
+ .stepper-sm .stepper-step-label {
223
+ font-size: 0.75rem;
224
+ }
225
+
226
+ .stepper-sm .stepper-step-description {
227
+ font-size: 0.625rem;
228
+ }
229
+
230
+ /* Large Variant */
231
+ .stepper-lg .stepper-step-icon {
232
+ width: 3rem;
233
+ height: 3rem;
234
+ font-size: 1rem;
235
+ }
236
+
237
+ .stepper-lg .stepper-step-connector {
238
+ top: 1.5rem;
239
+ left: calc(50% + 1.5rem);
240
+ width: calc(100% - 3rem);
241
+ }
242
+
243
+ /* Alternative Label Positioning */
244
+ .stepper-alt-labels .stepper-step-connector {
245
+ top: 1.25rem;
246
+ left: calc(50% + 2rem);
247
+ width: calc(100% - 4rem);
248
+ }
249
+
250
+ /* Dot Stepper (Minimal) */
251
+ .stepper-dots {
252
+ gap: 0.5rem;
253
+ }
254
+
255
+ .stepper-dots .stepper-step-icon {
256
+ width: 0.75rem;
257
+ height: 0.75rem;
258
+ font-size: 0;
259
+ border-width: 0;
260
+ background-color: var(--color-outline-variant);
261
+ }
262
+
263
+ .stepper-dots .stepper-step-active .stepper-step-icon {
264
+ width: 1.5rem;
265
+ border-radius: 9999px;
266
+ background-color: var(--color-primary);
267
+ }
268
+
269
+ .stepper-dots .stepper-step-completed .stepper-step-icon {
270
+ background-color: var(--color-primary);
271
+ }
272
+
273
+ .stepper-dots .stepper-step-connector {
274
+ display: none;
275
+ }
276
+
277
+ .stepper-dots .stepper-step-label,
278
+ .stepper-dots .stepper-step-description {
279
+ display: none;
280
+ }
281
+
282
+ /* Clickable Steps */
283
+ .stepper-clickable .stepper-step-button {
284
+ cursor: pointer;
285
+ }
286
+
287
+ .stepper-clickable .stepper-step-button:hover .stepper-step-icon {
288
+ border-color: var(--color-primary);
289
+ }
290
+
291
+ .stepper-clickable .stepper-step-completed .stepper-step-button:hover .stepper-step-icon {
292
+ background-color: var(--color-primary-container);
293
+ }
294
+
295
+ /* Disabled State */
296
+ .stepper-step-disabled .stepper-step-button {
297
+ cursor: not-allowed;
298
+ opacity: 0.6;
299
+ }
300
+
301
+ /* Icon Stepper */
302
+ .stepper-icons .stepper-step-icon {
303
+ font-size: 1.25rem;
304
+ }
305
+
306
+ /* Reduce Motion */
307
+ @media (prefers-reduced-motion: reduce) {
308
+ .stepper-step-icon,
309
+ .stepper-dots .stepper-step-icon {
310
+ transition: none;
311
+ }
312
+ }
313
+ }
@@ -0,0 +1,277 @@
1
+ /**
2
+ * Switch Component Styles
3
+ * DuskMoonUI - Material Design 3 inspired switch/toggle system
4
+ */
5
+
6
+ @layer components {
7
+ /* Base Switch */
8
+ .switch {
9
+ position: relative;
10
+ display: inline-flex;
11
+ align-items: center;
12
+ gap: 0.75rem;
13
+ cursor: pointer;
14
+ user-select: none;
15
+ }
16
+
17
+ /* Hidden Input */
18
+ .switch-input {
19
+ position: absolute;
20
+ width: 0;
21
+ height: 0;
22
+ opacity: 0;
23
+ }
24
+
25
+ /* Switch Track */
26
+ .switch-track {
27
+ position: relative;
28
+ width: 3.25rem;
29
+ height: 2rem;
30
+ background-color: var(--color-surface-container-highest);
31
+ border: 2px solid var(--color-outline);
32
+ border-radius: 9999px;
33
+ transition: background-color 200ms ease-in-out, border-color 200ms ease-in-out;
34
+ }
35
+
36
+ /* Switch Thumb */
37
+ .switch-thumb {
38
+ position: absolute;
39
+ top: 50%;
40
+ left: 0.25rem;
41
+ width: 1rem;
42
+ height: 1rem;
43
+ background-color: var(--color-outline);
44
+ border-radius: 50%;
45
+ transform: translateY(-50%);
46
+ transition: left 200ms ease-in-out, width 200ms ease-in-out, height 200ms ease-in-out, background-color 200ms ease-in-out;
47
+ }
48
+
49
+ /* Checked State */
50
+ .switch-input:checked + .switch-track {
51
+ background-color: var(--color-primary);
52
+ border-color: var(--color-primary);
53
+ }
54
+
55
+ .switch-input:checked + .switch-track .switch-thumb {
56
+ left: calc(100% - 1.5rem);
57
+ width: 1.5rem;
58
+ height: 1.5rem;
59
+ background-color: var(--color-primary-content);
60
+ }
61
+
62
+ /* Hover State */
63
+ .switch:hover .switch-track::before {
64
+ content: '';
65
+ position: absolute;
66
+ top: 50%;
67
+ left: 0.125rem;
68
+ width: 2.5rem;
69
+ height: 2.5rem;
70
+ background-color: var(--color-on-surface);
71
+ border-radius: 50%;
72
+ transform: translate(-0.75rem, -50%);
73
+ opacity: 0.08;
74
+ transition: opacity 150ms ease-in-out;
75
+ }
76
+
77
+ .switch:hover .switch-input:checked + .switch-track::before {
78
+ left: auto;
79
+ right: 0.125rem;
80
+ transform: translate(0.75rem, -50%);
81
+ background-color: var(--color-primary);
82
+ }
83
+
84
+ /* Focus State */
85
+ .switch-input:focus-visible + .switch-track {
86
+ outline: 2px solid var(--color-primary);
87
+ outline-offset: 2px;
88
+ }
89
+
90
+ /* Disabled State */
91
+ .switch-input:disabled + .switch-track {
92
+ opacity: 0.38;
93
+ cursor: not-allowed;
94
+ }
95
+
96
+ .switch:has(.switch-input:disabled) {
97
+ cursor: not-allowed;
98
+ }
99
+
100
+ /* Switch Label */
101
+ .switch-label {
102
+ font-size: 0.875rem;
103
+ color: var(--color-on-surface);
104
+ }
105
+
106
+ .switch-label-left {
107
+ order: -1;
108
+ }
109
+
110
+ /* Size Variants */
111
+ .switch-sm .switch-track {
112
+ width: 2.5rem;
113
+ height: 1.5rem;
114
+ }
115
+
116
+ .switch-sm .switch-thumb {
117
+ width: 0.75rem;
118
+ height: 0.75rem;
119
+ }
120
+
121
+ .switch-sm .switch-input:checked + .switch-track .switch-thumb {
122
+ left: calc(100% - 1.125rem);
123
+ width: 1.125rem;
124
+ height: 1.125rem;
125
+ }
126
+
127
+ .switch-lg .switch-track {
128
+ width: 4rem;
129
+ height: 2.5rem;
130
+ }
131
+
132
+ .switch-lg .switch-thumb {
133
+ width: 1.25rem;
134
+ height: 1.25rem;
135
+ left: 0.375rem;
136
+ }
137
+
138
+ .switch-lg .switch-input:checked + .switch-track .switch-thumb {
139
+ left: calc(100% - 1.875rem);
140
+ width: 1.875rem;
141
+ height: 1.875rem;
142
+ }
143
+
144
+ /* Color Variants - on parent .switch or on .switch-track */
145
+ /* Primary is default, but explicit class for consistency */
146
+ .switch-primary .switch-input:checked + .switch-track,
147
+ .switch-input:checked + .switch-track.switch-primary {
148
+ background-color: var(--color-primary);
149
+ border-color: var(--color-primary);
150
+ }
151
+
152
+ .switch-primary .switch-input:checked + .switch-track .switch-thumb,
153
+ .switch-input:checked + .switch-track.switch-primary .switch-thumb {
154
+ background-color: var(--color-primary-content);
155
+ }
156
+
157
+ .switch-secondary .switch-input:checked + .switch-track,
158
+ .switch-input:checked + .switch-track.switch-secondary {
159
+ background-color: var(--color-secondary);
160
+ border-color: var(--color-secondary);
161
+ }
162
+
163
+ .switch-secondary .switch-input:checked + .switch-track .switch-thumb,
164
+ .switch-input:checked + .switch-track.switch-secondary .switch-thumb {
165
+ background-color: var(--color-secondary-content);
166
+ }
167
+
168
+ .switch-tertiary .switch-input:checked + .switch-track,
169
+ .switch-input:checked + .switch-track.switch-tertiary {
170
+ background-color: var(--color-tertiary);
171
+ border-color: var(--color-tertiary);
172
+ }
173
+
174
+ .switch-tertiary .switch-input:checked + .switch-track .switch-thumb,
175
+ .switch-input:checked + .switch-track.switch-tertiary .switch-thumb {
176
+ background-color: var(--color-tertiary-content);
177
+ }
178
+
179
+ .switch-success .switch-input:checked + .switch-track,
180
+ .switch-input:checked + .switch-track.switch-success {
181
+ background-color: var(--color-success);
182
+ border-color: var(--color-success);
183
+ }
184
+
185
+ .switch-error .switch-input:checked + .switch-track,
186
+ .switch-input:checked + .switch-track.switch-error {
187
+ background-color: var(--color-error);
188
+ border-color: var(--color-error);
189
+ }
190
+
191
+ /* With Icons */
192
+ .switch-icon .switch-thumb {
193
+ display: flex;
194
+ align-items: center;
195
+ justify-content: center;
196
+ font-size: 0.625rem;
197
+ }
198
+
199
+ .switch-icon .switch-input:checked + .switch-track .switch-thumb {
200
+ font-size: 0.875rem;
201
+ }
202
+
203
+ /* Labeled Track */
204
+ .switch-labeled-track .switch-track {
205
+ width: 4rem;
206
+ display: flex;
207
+ align-items: center;
208
+ justify-content: space-between;
209
+ padding: 0 0.5rem;
210
+ }
211
+
212
+ .switch-labeled-track .switch-track-label {
213
+ font-size: 0.625rem;
214
+ font-weight: 600;
215
+ color: var(--color-on-surface-variant);
216
+ text-transform: uppercase;
217
+ transition: opacity 150ms ease-in-out;
218
+ }
219
+
220
+ .switch-labeled-track .switch-track-on {
221
+ opacity: 0;
222
+ }
223
+
224
+ .switch-labeled-track .switch-track-off {
225
+ opacity: 1;
226
+ }
227
+
228
+ .switch-labeled-track .switch-input:checked + .switch-track .switch-track-on {
229
+ opacity: 1;
230
+ color: var(--color-primary-content);
231
+ }
232
+
233
+ .switch-labeled-track .switch-input:checked + .switch-track .switch-track-off {
234
+ opacity: 0;
235
+ }
236
+
237
+ /* Loading State */
238
+ .switch-loading .switch-thumb::after {
239
+ content: '';
240
+ position: absolute;
241
+ top: 50%;
242
+ left: 50%;
243
+ width: 0.75rem;
244
+ height: 0.75rem;
245
+ border: 2px solid transparent;
246
+ border-top-color: var(--color-on-surface);
247
+ border-radius: 50%;
248
+ transform: translate(-50%, -50%);
249
+ animation: switch-spin 600ms linear infinite;
250
+ }
251
+
252
+ @keyframes switch-spin {
253
+ to {
254
+ transform: translate(-50%, -50%) rotate(360deg);
255
+ }
256
+ }
257
+
258
+ /* Group */
259
+ .switch-group {
260
+ display: flex;
261
+ flex-direction: column;
262
+ gap: 0.75rem;
263
+ }
264
+
265
+ /* Reduce Motion */
266
+ @media (prefers-reduced-motion: reduce) {
267
+ .switch-track,
268
+ .switch-thumb,
269
+ .switch-track::before {
270
+ transition: none;
271
+ }
272
+
273
+ .switch-loading .switch-thumb::after {
274
+ animation: none;
275
+ }
276
+ }
277
+ }