jasmincss 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 (76) hide show
  1. package/README.md +524 -0
  2. package/bin/jasmin.js +45 -0
  3. package/dist/index.d.ts +62 -0
  4. package/dist/index.js +14568 -0
  5. package/dist/index.mjs +14524 -0
  6. package/dist/jasmin.css +63308 -0
  7. package/dist/jasmin.min.css +1 -0
  8. package/dist/plugins/nextjs.js +14777 -0
  9. package/dist/plugins/nextjs.mjs +14747 -0
  10. package/dist/plugins/vite.js +14889 -0
  11. package/dist/plugins/vite.mjs +14860 -0
  12. package/package.json +101 -0
  13. package/src/cli/add.js +83 -0
  14. package/src/cli/init.js +210 -0
  15. package/src/cli/run.js +142 -0
  16. package/src/components/accordion.js +309 -0
  17. package/src/components/alerts.js +357 -0
  18. package/src/components/avatars.js +331 -0
  19. package/src/components/badges.js +353 -0
  20. package/src/components/buttons.js +412 -0
  21. package/src/components/cards.js +342 -0
  22. package/src/components/carousel.js +495 -0
  23. package/src/components/chips.js +440 -0
  24. package/src/components/command-palette.js +434 -0
  25. package/src/components/datepicker.js +517 -0
  26. package/src/components/dropdown.js +411 -0
  27. package/src/components/forms.js +516 -0
  28. package/src/components/index.js +81 -0
  29. package/src/components/modals.js +349 -0
  30. package/src/components/navigation.js +463 -0
  31. package/src/components/offcanvas.js +390 -0
  32. package/src/components/popover.js +427 -0
  33. package/src/components/progress.js +396 -0
  34. package/src/components/rating.js +394 -0
  35. package/src/components/skeleton.js +408 -0
  36. package/src/components/spinner.js +453 -0
  37. package/src/components/stepper.js +389 -0
  38. package/src/components/tables.js +304 -0
  39. package/src/components/timeline.js +452 -0
  40. package/src/components/timepicker.js +529 -0
  41. package/src/components/tooltips.js +345 -0
  42. package/src/components/upload.js +490 -0
  43. package/src/config/defaults.js +263 -0
  44. package/src/config/loader.js +109 -0
  45. package/src/core/base.js +241 -0
  46. package/src/core/compiler.js +135 -0
  47. package/src/core/utilities/accessibility.js +290 -0
  48. package/src/core/utilities/animations.js +205 -0
  49. package/src/core/utilities/background.js +109 -0
  50. package/src/core/utilities/colors.js +234 -0
  51. package/src/core/utilities/columns.js +161 -0
  52. package/src/core/utilities/effects.js +261 -0
  53. package/src/core/utilities/filters.js +135 -0
  54. package/src/core/utilities/icons.js +806 -0
  55. package/src/core/utilities/index.js +239 -0
  56. package/src/core/utilities/layout.js +321 -0
  57. package/src/core/utilities/scroll.js +205 -0
  58. package/src/core/utilities/spacing.js +120 -0
  59. package/src/core/utilities/svg.js +191 -0
  60. package/src/core/utilities/transforms.js +116 -0
  61. package/src/core/utilities/typography.js +188 -0
  62. package/src/index.js +7 -0
  63. package/src/js/components/accordion.js +154 -0
  64. package/src/js/components/alert.js +198 -0
  65. package/src/js/components/carousel.js +226 -0
  66. package/src/js/components/dropdown.js +166 -0
  67. package/src/js/components/modal.js +169 -0
  68. package/src/js/components/offcanvas.js +175 -0
  69. package/src/js/components/popover.js +221 -0
  70. package/src/js/components/tabs.js +163 -0
  71. package/src/js/components/tooltip.js +200 -0
  72. package/src/js/index.js +79 -0
  73. package/src/js/types/config.d.ts +228 -0
  74. package/src/js/types/index.d.ts +439 -0
  75. package/src/plugins/nextjs.js +100 -0
  76. package/src/plugins/vite.js +133 -0
@@ -0,0 +1,440 @@
1
+ // Chips/Tags component for JasminCSS
2
+
3
+ export function generateChipStyles(config) {
4
+ return `/* Chip Base */
5
+ .chip {
6
+ display: inline-flex;
7
+ align-items: center;
8
+ gap: 0.375rem;
9
+ padding: 0.25rem 0.75rem;
10
+ font-size: 0.875rem;
11
+ font-weight: 500;
12
+ line-height: 1.5;
13
+ color: var(--j-text);
14
+ background-color: var(--j-bg-subtle);
15
+ border: 1px solid var(--j-border);
16
+ border-radius: var(--j-radius-full, 9999px);
17
+ white-space: nowrap;
18
+ transition: all 150ms ease-in-out;
19
+ }
20
+
21
+ /* Chip Colors */
22
+ .chip-primary {
23
+ background-color: var(--j-primary);
24
+ border-color: var(--j-primary);
25
+ color: white;
26
+ }
27
+
28
+ .chip-secondary {
29
+ background-color: var(--j-secondary);
30
+ border-color: var(--j-secondary);
31
+ color: white;
32
+ }
33
+
34
+ .chip-accent {
35
+ background-color: var(--j-accent);
36
+ border-color: var(--j-accent);
37
+ color: white;
38
+ }
39
+
40
+ .chip-success {
41
+ background-color: var(--j-success);
42
+ border-color: var(--j-success);
43
+ color: white;
44
+ }
45
+
46
+ .chip-warning {
47
+ background-color: var(--j-warning);
48
+ border-color: var(--j-warning);
49
+ color: white;
50
+ }
51
+
52
+ .chip-error {
53
+ background-color: var(--j-error);
54
+ border-color: var(--j-error);
55
+ color: white;
56
+ }
57
+
58
+ .chip-info {
59
+ background-color: var(--j-info);
60
+ border-color: var(--j-info);
61
+ color: white;
62
+ }
63
+
64
+ /* Soft/Light Chips */
65
+ .chip-soft-primary {
66
+ background-color: color-mix(in srgb, var(--j-primary) 15%, transparent);
67
+ border-color: color-mix(in srgb, var(--j-primary) 30%, transparent);
68
+ color: var(--j-primary);
69
+ }
70
+
71
+ .chip-soft-secondary {
72
+ background-color: color-mix(in srgb, var(--j-secondary) 15%, transparent);
73
+ border-color: color-mix(in srgb, var(--j-secondary) 30%, transparent);
74
+ color: var(--j-secondary);
75
+ }
76
+
77
+ .chip-soft-success {
78
+ background-color: color-mix(in srgb, var(--j-success) 15%, transparent);
79
+ border-color: color-mix(in srgb, var(--j-success) 30%, transparent);
80
+ color: var(--j-success);
81
+ }
82
+
83
+ .chip-soft-warning {
84
+ background-color: color-mix(in srgb, var(--j-warning) 15%, transparent);
85
+ border-color: color-mix(in srgb, var(--j-warning) 30%, transparent);
86
+ color: var(--j-warning);
87
+ }
88
+
89
+ .chip-soft-error {
90
+ background-color: color-mix(in srgb, var(--j-error) 15%, transparent);
91
+ border-color: color-mix(in srgb, var(--j-error) 30%, transparent);
92
+ color: var(--j-error);
93
+ }
94
+
95
+ .chip-soft-info {
96
+ background-color: color-mix(in srgb, var(--j-info) 15%, transparent);
97
+ border-color: color-mix(in srgb, var(--j-info) 30%, transparent);
98
+ color: var(--j-info);
99
+ }
100
+
101
+ /* Outline Chips */
102
+ .chip-outline {
103
+ background-color: transparent;
104
+ }
105
+
106
+ .chip-outline-primary {
107
+ background-color: transparent;
108
+ border-color: var(--j-primary);
109
+ color: var(--j-primary);
110
+ }
111
+
112
+ .chip-outline-secondary {
113
+ background-color: transparent;
114
+ border-color: var(--j-secondary);
115
+ color: var(--j-secondary);
116
+ }
117
+
118
+ .chip-outline-success {
119
+ background-color: transparent;
120
+ border-color: var(--j-success);
121
+ color: var(--j-success);
122
+ }
123
+
124
+ .chip-outline-warning {
125
+ background-color: transparent;
126
+ border-color: var(--j-warning);
127
+ color: var(--j-warning);
128
+ }
129
+
130
+ .chip-outline-error {
131
+ background-color: transparent;
132
+ border-color: var(--j-error);
133
+ color: var(--j-error);
134
+ }
135
+
136
+ /* Chip Sizes */
137
+ .chip-xs {
138
+ padding: 0 0.5rem;
139
+ font-size: 0.75rem;
140
+ gap: 0.25rem;
141
+ }
142
+
143
+ .chip-sm {
144
+ padding: 0.125rem 0.625rem;
145
+ font-size: 0.8125rem;
146
+ }
147
+
148
+ .chip-lg {
149
+ padding: 0.375rem 1rem;
150
+ font-size: 1rem;
151
+ }
152
+
153
+ .chip-xl {
154
+ padding: 0.5rem 1.25rem;
155
+ font-size: 1.125rem;
156
+ }
157
+
158
+ /* Chip Shapes */
159
+ .chip-rounded {
160
+ border-radius: var(--j-radius-lg, 0.5rem);
161
+ }
162
+
163
+ .chip-square {
164
+ border-radius: var(--j-radius-sm, 0.25rem);
165
+ }
166
+
167
+ /* Chip with Avatar/Image */
168
+ .chip-avatar {
169
+ padding-left: 0.25rem;
170
+ }
171
+
172
+ .chip-avatar-img {
173
+ width: 1.5rem;
174
+ height: 1.5rem;
175
+ border-radius: 50%;
176
+ object-fit: cover;
177
+ }
178
+
179
+ .chip-sm .chip-avatar-img {
180
+ width: 1.25rem;
181
+ height: 1.25rem;
182
+ }
183
+
184
+ .chip-lg .chip-avatar-img {
185
+ width: 1.75rem;
186
+ height: 1.75rem;
187
+ }
188
+
189
+ /* Chip with Icon */
190
+ .chip-icon {
191
+ width: 1rem;
192
+ height: 1rem;
193
+ flex-shrink: 0;
194
+ }
195
+
196
+ .chip-sm .chip-icon {
197
+ width: 0.875rem;
198
+ height: 0.875rem;
199
+ }
200
+
201
+ .chip-lg .chip-icon {
202
+ width: 1.25rem;
203
+ height: 1.25rem;
204
+ }
205
+
206
+ /* Removable/Deletable Chip */
207
+ .chip-removable {
208
+ padding-right: 0.375rem;
209
+ }
210
+
211
+ .chip-remove {
212
+ display: flex;
213
+ align-items: center;
214
+ justify-content: center;
215
+ width: 1.125rem;
216
+ height: 1.125rem;
217
+ padding: 0;
218
+ margin-left: 0.125rem;
219
+ background-color: transparent;
220
+ border: none;
221
+ border-radius: 50%;
222
+ cursor: pointer;
223
+ color: inherit;
224
+ opacity: 0.7;
225
+ transition: all 150ms ease-in-out;
226
+ }
227
+
228
+ .chip-remove:hover {
229
+ opacity: 1;
230
+ background-color: rgba(0, 0, 0, 0.1);
231
+ }
232
+
233
+ .chip-primary .chip-remove:hover,
234
+ .chip-secondary .chip-remove:hover,
235
+ .chip-success .chip-remove:hover,
236
+ .chip-warning .chip-remove:hover,
237
+ .chip-error .chip-remove:hover,
238
+ .chip-info .chip-remove:hover {
239
+ background-color: rgba(255, 255, 255, 0.2);
240
+ }
241
+
242
+ .chip-remove svg,
243
+ .chip-remove-icon {
244
+ width: 0.75rem;
245
+ height: 0.75rem;
246
+ }
247
+
248
+ /* Default X icon */
249
+ .chip-remove::before {
250
+ content: "×";
251
+ font-size: 1rem;
252
+ line-height: 1;
253
+ font-weight: 700;
254
+ }
255
+
256
+ .chip-remove svg + .chip-remove::before,
257
+ .chip-remove:has(svg)::before {
258
+ display: none;
259
+ }
260
+
261
+ /* Clickable/Interactive Chip */
262
+ .chip-clickable {
263
+ cursor: pointer;
264
+ }
265
+
266
+ .chip-clickable:hover {
267
+ background-color: var(--j-bg-muted);
268
+ }
269
+
270
+ .chip-clickable:active {
271
+ transform: scale(0.95);
272
+ }
273
+
274
+ .chip-clickable.chip-primary:hover {
275
+ background-color: color-mix(in srgb, var(--j-primary) 85%, black);
276
+ }
277
+
278
+ .chip-clickable.chip-secondary:hover {
279
+ background-color: color-mix(in srgb, var(--j-secondary) 85%, black);
280
+ }
281
+
282
+ .chip-clickable.chip-success:hover {
283
+ background-color: color-mix(in srgb, var(--j-success) 85%, black);
284
+ }
285
+
286
+ /* Selected Chip */
287
+ .chip-selected,
288
+ .chip[aria-selected="true"] {
289
+ background-color: var(--j-primary);
290
+ border-color: var(--j-primary);
291
+ color: white;
292
+ }
293
+
294
+ .chip-selected::before,
295
+ .chip[aria-selected="true"]::before {
296
+ content: "✓";
297
+ margin-right: 0.125rem;
298
+ font-size: 0.75em;
299
+ }
300
+
301
+ /* Disabled Chip */
302
+ .chip:disabled,
303
+ .chip.disabled {
304
+ opacity: 0.5;
305
+ cursor: not-allowed;
306
+ pointer-events: none;
307
+ }
308
+
309
+ /* Chip Group */
310
+ .chip-group {
311
+ display: flex;
312
+ flex-wrap: wrap;
313
+ gap: 0.5rem;
314
+ }
315
+
316
+ .chip-group-sm {
317
+ gap: 0.25rem;
318
+ }
319
+
320
+ .chip-group-lg {
321
+ gap: 0.75rem;
322
+ }
323
+
324
+ /* Chip Group - Connected */
325
+ .chip-group-connected {
326
+ gap: 0;
327
+ }
328
+
329
+ .chip-group-connected .chip {
330
+ border-radius: 0;
331
+ margin-left: -1px;
332
+ }
333
+
334
+ .chip-group-connected .chip:first-child {
335
+ border-radius: var(--j-radius-full, 9999px) 0 0 var(--j-radius-full, 9999px);
336
+ margin-left: 0;
337
+ }
338
+
339
+ .chip-group-connected .chip:last-child {
340
+ border-radius: 0 var(--j-radius-full, 9999px) var(--j-radius-full, 9999px) 0;
341
+ }
342
+
343
+ /* Chip Input (for tag input fields) */
344
+ .chip-input-wrapper {
345
+ display: flex;
346
+ flex-wrap: wrap;
347
+ align-items: center;
348
+ gap: 0.375rem;
349
+ padding: 0.375rem 0.5rem;
350
+ min-height: 2.5rem;
351
+ border: 1px solid var(--j-border);
352
+ border-radius: var(--j-radius-default, 0.375rem);
353
+ background-color: var(--j-bg);
354
+ cursor: text;
355
+ transition: border-color 150ms ease-in-out, box-shadow 150ms ease-in-out;
356
+ }
357
+
358
+ .chip-input-wrapper:focus-within {
359
+ border-color: var(--j-primary);
360
+ box-shadow: 0 0 0 3px color-mix(in srgb, var(--j-primary) 20%, transparent);
361
+ }
362
+
363
+ .chip-input-wrapper .chip {
364
+ margin: 0;
365
+ }
366
+
367
+ .chip-input {
368
+ flex: 1;
369
+ min-width: 8rem;
370
+ padding: 0.25rem;
371
+ border: none;
372
+ background: transparent;
373
+ font-size: 0.875rem;
374
+ color: var(--j-text);
375
+ outline: none;
376
+ }
377
+
378
+ .chip-input::placeholder {
379
+ color: var(--j-text-muted);
380
+ }
381
+
382
+ /* Chip with Counter */
383
+ .chip-counter {
384
+ display: inline-flex;
385
+ align-items: center;
386
+ justify-content: center;
387
+ min-width: 1.25rem;
388
+ height: 1.25rem;
389
+ padding: 0 0.375rem;
390
+ margin-left: 0.25rem;
391
+ font-size: 0.75rem;
392
+ font-weight: 600;
393
+ background-color: rgba(0, 0, 0, 0.15);
394
+ border-radius: var(--j-radius-full, 9999px);
395
+ }
396
+
397
+ .chip-primary .chip-counter,
398
+ .chip-secondary .chip-counter,
399
+ .chip-success .chip-counter,
400
+ .chip-warning .chip-counter,
401
+ .chip-error .chip-counter {
402
+ background-color: rgba(255, 255, 255, 0.25);
403
+ }
404
+
405
+ /* Glow Chips (Futuristic) */
406
+ .chip-glow {
407
+ box-shadow: 0 0 10px currentColor;
408
+ }
409
+
410
+ .chip-glow-primary {
411
+ background-color: var(--j-primary);
412
+ border-color: var(--j-primary);
413
+ color: white;
414
+ box-shadow: 0 0 15px var(--j-primary);
415
+ }
416
+
417
+ .chip-glow-secondary {
418
+ background-color: var(--j-secondary);
419
+ border-color: var(--j-secondary);
420
+ color: white;
421
+ box-shadow: 0 0 15px var(--j-secondary);
422
+ }
423
+
424
+ /* Filter Chips */
425
+ .chip-filter {
426
+ cursor: pointer;
427
+ user-select: none;
428
+ }
429
+
430
+ .chip-filter:not(.chip-selected):hover {
431
+ border-color: var(--j-primary);
432
+ }
433
+
434
+ .chip-filter-group {
435
+ display: flex;
436
+ flex-wrap: wrap;
437
+ gap: 0.5rem;
438
+ }
439
+ `;
440
+ }