@abstraks-dev/ui-library 1.0.1

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 (158) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +708 -0
  3. package/dist/__tests__/Anchor.test.js +145 -0
  4. package/dist/__tests__/ArrowRight.test.js +91 -0
  5. package/dist/__tests__/Avatar.test.js +123 -0
  6. package/dist/__tests__/Button.test.js +82 -0
  7. package/dist/__tests__/Card.test.js +198 -0
  8. package/dist/__tests__/CheckCircle.test.js +98 -0
  9. package/dist/__tests__/Checkbox.test.js +161 -0
  10. package/dist/__tests__/ChevronDown.test.js +73 -0
  11. package/dist/__tests__/Close.test.js +98 -0
  12. package/dist/__tests__/EditSquare.test.js +99 -0
  13. package/dist/__tests__/Error.test.js +74 -0
  14. package/dist/__tests__/Footer.test.js +66 -0
  15. package/dist/__tests__/Heading.test.js +227 -0
  16. package/dist/__tests__/Hero.test.js +74 -0
  17. package/dist/__tests__/Label.test.js +123 -0
  18. package/dist/__tests__/Loader.test.js +115 -0
  19. package/dist/__tests__/MenuHover.test.js +137 -0
  20. package/dist/__tests__/Paragraph.test.js +93 -0
  21. package/dist/__tests__/PlusCircle.test.js +99 -0
  22. package/dist/__tests__/Radio.test.js +153 -0
  23. package/dist/__tests__/Select.test.js +187 -0
  24. package/dist/__tests__/Tabs.test.js +162 -0
  25. package/dist/__tests__/TextArea.test.js +127 -0
  26. package/dist/__tests__/TextInput.test.js +181 -0
  27. package/dist/__tests__/Toggle.test.js +120 -0
  28. package/dist/__tests__/TrashX.test.js +99 -0
  29. package/dist/__tests__/useHeadingAccessibility.test.js +144 -0
  30. package/dist/components/Anchor.js +131 -0
  31. package/dist/components/Animation.js +129 -0
  32. package/dist/components/AnimationGroup.js +207 -0
  33. package/dist/components/AnimationToggle.js +216 -0
  34. package/dist/components/Avatar.js +153 -0
  35. package/dist/components/Button.js +218 -0
  36. package/dist/components/Card.js +222 -0
  37. package/dist/components/Checkbox.js +305 -0
  38. package/dist/components/Crud.js +564 -0
  39. package/dist/components/DragAndDrop.js +337 -0
  40. package/dist/components/Error.js +206 -0
  41. package/dist/components/Footer.js +99 -0
  42. package/dist/components/Form.js +412 -0
  43. package/dist/components/Header.js +372 -0
  44. package/dist/components/Heading.js +134 -0
  45. package/dist/components/Hero.js +181 -0
  46. package/dist/components/Label.js +256 -0
  47. package/dist/components/Loader.js +302 -0
  48. package/dist/components/MenuHover.js +114 -0
  49. package/dist/components/Paragraph.js +128 -0
  50. package/dist/components/Prompt.js +61 -0
  51. package/dist/components/Radio.js +254 -0
  52. package/dist/components/Select.js +422 -0
  53. package/dist/components/SideMenu.js +313 -0
  54. package/dist/components/Tabs.js +297 -0
  55. package/dist/components/TextArea.js +370 -0
  56. package/dist/components/TextInput.js +286 -0
  57. package/dist/components/Toggle.js +186 -0
  58. package/dist/components/crudFiles/CrudEditBase.js +150 -0
  59. package/dist/components/crudFiles/CrudViewBase.js +39 -0
  60. package/dist/components/crudFiles/crudDevelopment.js +118 -0
  61. package/dist/components/crudFiles/crudEditHandlers.js +50 -0
  62. package/dist/constants/animation.js +30 -0
  63. package/dist/icons/ArrowIcon.js +32 -0
  64. package/dist/icons/ArrowRight.js +33 -0
  65. package/dist/icons/CheckCircle.js +33 -0
  66. package/dist/icons/ChevronDown.js +28 -0
  67. package/dist/icons/Close.js +33 -0
  68. package/dist/icons/EditSquare.js +33 -0
  69. package/dist/icons/Ellipses.js +34 -0
  70. package/dist/icons/Hamburger.js +39 -0
  71. package/dist/icons/LoadingSpinner.js +42 -0
  72. package/dist/icons/PlusCircle.js +33 -0
  73. package/dist/icons/SaveIcon.js +32 -0
  74. package/dist/icons/TrashX.js +33 -0
  75. package/dist/icons/__tests__/CheckCircle.test.js +9 -0
  76. package/dist/icons/__tests__/ChevronDown.test.js +9 -0
  77. package/dist/icons/__tests__/Close.test.js +9 -0
  78. package/dist/icons/__tests__/EditSquare.test.js +9 -0
  79. package/dist/icons/__tests__/PlusCircle.test.js +9 -0
  80. package/dist/icons/__tests__/TrashX.test.js +9 -0
  81. package/dist/icons/index.js +89 -0
  82. package/dist/index.js +332 -0
  83. package/dist/setupTests.js +3 -0
  84. package/dist/styles/_variables.scss +286 -0
  85. package/dist/styles/anchor.scss +40 -0
  86. package/dist/styles/animation-accessibility.scss +96 -0
  87. package/dist/styles/animation-toggle.scss +233 -0
  88. package/dist/styles/animation.scss +3781 -0
  89. package/dist/styles/avatar.scss +285 -0
  90. package/dist/styles/button.scss +430 -0
  91. package/dist/styles/card.scss +210 -0
  92. package/dist/styles/checkbox.scss +160 -0
  93. package/dist/styles/crud.scss +474 -0
  94. package/dist/styles/dragAndDrop.scss +312 -0
  95. package/dist/styles/error.scss +232 -0
  96. package/dist/styles/footer.scss +58 -0
  97. package/dist/styles/form.scss +420 -0
  98. package/dist/styles/grid.scss +29 -0
  99. package/dist/styles/header.scss +276 -0
  100. package/dist/styles/heading.scss +118 -0
  101. package/dist/styles/hero.scss +185 -0
  102. package/dist/styles/htmlElements.scss +20 -0
  103. package/dist/styles/image.scss +9 -0
  104. package/dist/styles/label.scss +340 -0
  105. package/dist/styles/list-item.scss +5 -0
  106. package/dist/styles/loader.scss +354 -0
  107. package/dist/styles/logo.scss +19 -0
  108. package/dist/styles/main.css +9056 -0
  109. package/dist/styles/main.css.map +1 -0
  110. package/dist/styles/main.scss +0 -0
  111. package/dist/styles/menu-hover.scss +30 -0
  112. package/dist/styles/paragraph.scss +88 -0
  113. package/dist/styles/prompt.scss +51 -0
  114. package/dist/styles/radio.scss +202 -0
  115. package/dist/styles/select.scss +363 -0
  116. package/dist/styles/side-menu.scss +334 -0
  117. package/dist/styles/tabs.scss +540 -0
  118. package/dist/styles/text-area.scss +388 -0
  119. package/dist/styles/text-input.scss +171 -0
  120. package/dist/styles/toggle.scss +0 -0
  121. package/dist/styles/unordered-list.scss +8 -0
  122. package/dist/utils/ScrollHandler.js +30 -0
  123. package/dist/utils/accessibility.js +128 -0
  124. package/dist/utils/heroUtils.js +316 -0
  125. package/dist/utils/index.js +104 -0
  126. package/dist/utils/inputValidation.js +29 -0
  127. package/dist/utils/keyboardNavigation.js +536 -0
  128. package/dist/utils/labelUtils.js +708 -0
  129. package/dist/utils/loaderUtils.js +387 -0
  130. package/dist/utils/menuUtils.js +575 -0
  131. package/dist/utils/useHeadingAccessibility.js +298 -0
  132. package/dist/utils/useRadioGroup.js +260 -0
  133. package/dist/utils/useSelectAccessibility.js +426 -0
  134. package/dist/utils/useTabsAccessibility.js +278 -0
  135. package/dist/utils/useTextAreaAccessibility.js +255 -0
  136. package/dist/utils/useTextInputAccessibility.js +295 -0
  137. package/dist/utils/useTypographyAccessibility.js +168 -0
  138. package/dist/utils/useWindowSize.js +32 -0
  139. package/dist/utils/utils/ScrollHandler.js +26 -0
  140. package/dist/utils/utils/accessibility.js +133 -0
  141. package/dist/utils/utils/heroUtils.js +348 -0
  142. package/dist/utils/utils/index.js +9 -0
  143. package/dist/utils/utils/inputValidation.js +22 -0
  144. package/dist/utils/utils/keyboardNavigation.js +664 -0
  145. package/dist/utils/utils/labelUtils.js +772 -0
  146. package/dist/utils/utils/loaderUtils.js +436 -0
  147. package/dist/utils/utils/menuUtils.js +651 -0
  148. package/dist/utils/utils/useHeadingAccessibility.js +334 -0
  149. package/dist/utils/utils/useRadioGroup.js +311 -0
  150. package/dist/utils/utils/useSelectAccessibility.js +498 -0
  151. package/dist/utils/utils/useTabsAccessibility.js +316 -0
  152. package/dist/utils/utils/useTextAreaAccessibility.js +303 -0
  153. package/dist/utils/utils/useTextInputAccessibility.js +338 -0
  154. package/dist/utils/utils/useTypographyAccessibility.js +180 -0
  155. package/dist/utils/utils/useWindowSize.js +26 -0
  156. package/dist/utils/utils/validation.js +131 -0
  157. package/dist/utils/validation.js +139 -0
  158. package/package.json +90 -0
@@ -0,0 +1,540 @@
1
+ @use 'variables' as *;
2
+
3
+ /* ==========================================================================
4
+ Tabs Component Styles
5
+ ========================================================================== */
6
+
7
+ /**
8
+ * Tabs Wrapper
9
+ * Main container for the entire tabs component
10
+ */
11
+ .tabs-wrapper {
12
+ display: flex;
13
+ flex-direction: column;
14
+ font-family: $font-family-body;
15
+ width: 100%;
16
+
17
+ /* Orientation variants */
18
+ &--vertical {
19
+ flex-direction: row;
20
+
21
+ .tabs__list {
22
+ flex-direction: column;
23
+ border-right: 1px solid $border-color;
24
+ border-bottom: none;
25
+ min-width: 200px;
26
+ }
27
+
28
+ .tabs__panels {
29
+ flex: 1;
30
+ }
31
+ }
32
+
33
+ /* Size variants */
34
+ &--small {
35
+ font-size: $font-size-sm;
36
+ }
37
+
38
+ &--medium {
39
+ font-size: $font-size-base;
40
+ }
41
+
42
+ &--large {
43
+ font-size: $font-size-lg;
44
+ }
45
+
46
+ /* Disabled state */
47
+ &--disabled {
48
+ opacity: 0.6;
49
+ pointer-events: none;
50
+ }
51
+ }
52
+
53
+ /**
54
+ * Tab List
55
+ * Container for tab buttons
56
+ */
57
+ .tabs__list {
58
+ display: flex;
59
+ border-bottom: 1px solid $border-color;
60
+ background-color: $background-color;
61
+ overflow-x: auto;
62
+ scrollbar-width: thin;
63
+
64
+ /* Focus management */
65
+ &:focus-within {
66
+ outline: 2px solid $focus-color;
67
+ outline-offset: 2px;
68
+ }
69
+
70
+ /* Size variants */
71
+ &--small {
72
+ min-height: 2rem;
73
+ }
74
+
75
+ &--medium {
76
+ min-height: 2.5rem;
77
+ }
78
+
79
+ &--large {
80
+ min-height: 3rem;
81
+ }
82
+
83
+ /* Vertical orientation */
84
+ &--vertical {
85
+ flex-direction: column;
86
+ border-bottom: none;
87
+ border-right: 1px solid $border-color;
88
+ overflow-y: auto;
89
+ overflow-x: hidden;
90
+ }
91
+ }
92
+
93
+ /**
94
+ * Individual Tab Button
95
+ */
96
+ .tabs__tab {
97
+ /* Reset and base styles */
98
+ appearance: none;
99
+ background-color: transparent;
100
+ border: none;
101
+ color: $color-font-body;
102
+ cursor: pointer;
103
+ display: flex;
104
+ align-items: center;
105
+ gap: $spacing-xs;
106
+ font-family: inherit;
107
+ font-size: inherit;
108
+ font-weight: $font-weight-medium;
109
+ line-height: $line-height-tight;
110
+ padding: $spacing-sm $spacing-md;
111
+ position: relative;
112
+ transition: all 0.2s ease;
113
+ white-space: nowrap;
114
+ text-decoration: none;
115
+
116
+ /* Hover state */
117
+ &:hover:not(:disabled):not(.tabs__tab--disabled) {
118
+ background-color: $gray-100;
119
+ color: $color-primary;
120
+ }
121
+
122
+ /* Focus state */
123
+ &:focus {
124
+ outline: 2px solid $focus-color;
125
+ outline-offset: -2px;
126
+ z-index: 1;
127
+ }
128
+
129
+ /* Active state */
130
+ &--active {
131
+ background-color: $background-color;
132
+ color: $color-primary;
133
+ font-weight: $font-weight-semibold;
134
+
135
+ /* Default variant - bottom border */
136
+ &::after {
137
+ content: '';
138
+ position: absolute;
139
+ bottom: -1px;
140
+ left: 0;
141
+ right: 0;
142
+ height: 2px;
143
+ background-color: $color-primary;
144
+ }
145
+ }
146
+
147
+ /* Disabled state */
148
+ &--disabled,
149
+ &:disabled {
150
+ background-color: transparent;
151
+ color: $gray-500;
152
+ cursor: not-allowed;
153
+ opacity: 0.6;
154
+
155
+ &:hover {
156
+ background-color: transparent;
157
+ color: $gray-500;
158
+ }
159
+ }
160
+
161
+ /* Size variants */
162
+ &--small {
163
+ padding: $spacing-xs $spacing-sm;
164
+ font-size: $font-size-xs;
165
+ }
166
+
167
+ &--medium {
168
+ padding: $spacing-sm $spacing-md;
169
+ font-size: $font-size-sm;
170
+ }
171
+
172
+ &--large {
173
+ padding: $spacing-md $spacing-lg;
174
+ font-size: $font-size-base;
175
+ }
176
+ }
177
+
178
+ /**
179
+ * Tab Icon
180
+ */
181
+ .tabs__tab-icon {
182
+ display: flex;
183
+ align-items: center;
184
+ flex-shrink: 0;
185
+ font-size: 1em;
186
+ }
187
+
188
+ /**
189
+ * Tab Label
190
+ */
191
+ .tabs__tab-label {
192
+ flex: 1;
193
+ text-align: left;
194
+ min-width: 0; /* Allow text truncation */
195
+ }
196
+
197
+ /**
198
+ * Tab Badge
199
+ */
200
+ .tabs__tab-badge {
201
+ background-color: $color-error;
202
+ border-radius: 50%;
203
+ color: $color-white;
204
+ display: flex;
205
+ align-items: center;
206
+ justify-content: center;
207
+ font-size: 0.75em;
208
+ font-weight: $font-weight-bold;
209
+ min-width: 1.2em;
210
+ height: 1.2em;
211
+ padding: 0 0.2em;
212
+ line-height: 1;
213
+ }
214
+
215
+ /**
216
+ * Tab Panels Container
217
+ */
218
+ .tabs__panels {
219
+ position: relative;
220
+ background-color: $background-color;
221
+ flex: 1;
222
+ }
223
+
224
+ /**
225
+ * Individual Tab Panel
226
+ */
227
+ .tabs__panel {
228
+ display: none;
229
+ outline: none;
230
+
231
+ /* Active panel */
232
+ &--active {
233
+ display: block;
234
+ }
235
+
236
+ /* Focus management */
237
+ &:focus {
238
+ outline: 2px solid $focus-color;
239
+ outline-offset: 2px;
240
+ }
241
+
242
+ /* Size variants */
243
+ &--small {
244
+ font-size: $font-size-sm;
245
+ }
246
+
247
+ &--medium {
248
+ font-size: $font-size-base;
249
+ }
250
+
251
+ &--large {
252
+ font-size: $font-size-lg;
253
+ }
254
+ }
255
+
256
+ /**
257
+ * Panel Content
258
+ */
259
+ .tabs__panel-content {
260
+ padding: $spacing-md;
261
+ color: $color-font-body;
262
+ line-height: $line-height-base;
263
+
264
+ /* Size variants */
265
+ .tabs__panel--small & {
266
+ padding: $spacing-sm;
267
+ }
268
+
269
+ .tabs__panel--large & {
270
+ padding: $spacing-lg;
271
+ }
272
+ }
273
+
274
+ /* ==========================================================================
275
+ Variant Styles
276
+ ========================================================================== */
277
+
278
+ /**
279
+ * Pills Variant
280
+ */
281
+ .tabs-wrapper--pills {
282
+ .tabs__list {
283
+ border-bottom: none;
284
+ gap: $spacing-xs;
285
+ padding: $spacing-xs;
286
+ background-color: $gray-100;
287
+ border-radius: $border-radius-md;
288
+ }
289
+
290
+ .tabs__tab {
291
+ border-radius: $border-radius-sm;
292
+
293
+ &--active {
294
+ background-color: $color-primary;
295
+ color: $color-white;
296
+
297
+ &::after {
298
+ display: none;
299
+ }
300
+
301
+ &:hover {
302
+ background-color: $color-primary;
303
+ color: $color-white;
304
+ }
305
+ }
306
+ }
307
+ }
308
+
309
+ /**
310
+ * Underline Variant
311
+ */
312
+ .tabs-wrapper--underline {
313
+ .tabs__list {
314
+ border-bottom: 1px solid $border-color;
315
+ background-color: transparent;
316
+ }
317
+
318
+ .tabs__tab {
319
+ border-bottom: 2px solid transparent;
320
+
321
+ &--active {
322
+ background-color: transparent;
323
+ border-bottom-color: $color-primary;
324
+
325
+ &::after {
326
+ display: none;
327
+ }
328
+ }
329
+ }
330
+ }
331
+
332
+ /**
333
+ * Boxed Variant
334
+ */
335
+ .tabs-wrapper--boxed {
336
+ .tabs__list {
337
+ border: 1px solid $border-color;
338
+ border-radius: $border-radius-md $border-radius-md 0 0;
339
+ background-color: $gray-100;
340
+ }
341
+
342
+ .tabs__tab {
343
+ border-right: 1px solid $border-color;
344
+
345
+ &:last-child {
346
+ border-right: none;
347
+ }
348
+
349
+ &--active {
350
+ background-color: $background-color;
351
+ border-bottom: 1px solid $background-color;
352
+ margin-bottom: -1px;
353
+
354
+ &::after {
355
+ display: none;
356
+ }
357
+ }
358
+ }
359
+
360
+ .tabs__panels {
361
+ border: 1px solid $border-color;
362
+ border-top: none;
363
+ border-radius: 0 0 $border-radius-md $border-radius-md;
364
+ }
365
+ }
366
+
367
+ /* ==========================================================================
368
+ Responsive Design
369
+ ========================================================================== */
370
+
371
+ @media #{$medium} {
372
+ .tabs__tab {
373
+ &--small {
374
+ padding: $spacing-sm $spacing-md;
375
+ font-size: $font-size-sm;
376
+ }
377
+
378
+ &--medium {
379
+ padding: $spacing-md $spacing-lg;
380
+ font-size: $font-size-base;
381
+ }
382
+
383
+ &--large {
384
+ padding: $spacing-lg $spacing-xl;
385
+ font-size: $font-size-lg;
386
+ }
387
+ }
388
+
389
+ .tabs__panel-content {
390
+ padding: $spacing-lg;
391
+
392
+ .tabs__panel--small & {
393
+ padding: $spacing-md;
394
+ }
395
+
396
+ .tabs__panel--large & {
397
+ padding: $spacing-xl;
398
+ }
399
+ }
400
+ }
401
+
402
+ @media #{$large} {
403
+ .tabs__list {
404
+ overflow-x: visible;
405
+
406
+ &--small {
407
+ min-height: 2.25rem;
408
+ }
409
+
410
+ &--medium {
411
+ min-height: 2.75rem;
412
+ }
413
+
414
+ &--large {
415
+ min-height: 3.25rem;
416
+ }
417
+ }
418
+
419
+ .tabs__tab {
420
+ &--large {
421
+ padding: $spacing-lg $spacing-xl;
422
+ font-size: $font-size-xl;
423
+ }
424
+ }
425
+ }
426
+
427
+ @media #{$xlarge} {
428
+ .tabs-wrapper--vertical {
429
+ .tabs__list {
430
+ min-width: 250px;
431
+ }
432
+ }
433
+
434
+ .tabs__panel-content {
435
+ padding: $spacing-xl;
436
+
437
+ .tabs__panel--small & {
438
+ padding: $spacing-lg;
439
+ }
440
+
441
+ .tabs__panel--large & {
442
+ padding: $spacing-2xl;
443
+ }
444
+ }
445
+ }
446
+
447
+ /* ==========================================================================
448
+ High Contrast Mode Support
449
+ ========================================================================== */
450
+ @media (prefers-contrast: high) {
451
+ .tabs__tab {
452
+ border: 1px solid transparent;
453
+ font-weight: $font-weight-semibold;
454
+
455
+ &:focus {
456
+ outline: 3px solid currentColor;
457
+ outline-offset: 2px;
458
+ }
459
+
460
+ &--active {
461
+ border-color: currentColor;
462
+ font-weight: $font-weight-bold;
463
+
464
+ &::after {
465
+ height: 3px;
466
+ }
467
+ }
468
+ }
469
+
470
+ .tabs__tab-badge {
471
+ border: 2px solid currentColor;
472
+ }
473
+ }
474
+
475
+ /* ==========================================================================
476
+ Light Theme Support
477
+ ========================================================================== */
478
+ @media (prefers-color-scheme: light) {
479
+ .tabs__list {
480
+ background-color: $color-white;
481
+ border-color: $gray-300;
482
+ }
483
+
484
+ .tabs__tab {
485
+ color: $gray-600;
486
+
487
+ &:hover:not(:disabled):not(.tabs__tab--disabled) {
488
+ background-color: $gray-100;
489
+ color: $color-primary;
490
+ }
491
+
492
+ &--active {
493
+ background-color: $color-white;
494
+ color: $color-primary;
495
+ }
496
+
497
+ &--disabled,
498
+ &:disabled {
499
+ color: $gray-500;
500
+ }
501
+ }
502
+
503
+ .tabs__panels {
504
+ background-color: $color-white;
505
+ }
506
+
507
+ .tabs__panel-content {
508
+ color: $gray-600;
509
+ }
510
+
511
+ /* Variant adjustments for light mode */
512
+ .tabs-wrapper--pills .tabs__list {
513
+ background-color: $gray-100;
514
+ }
515
+
516
+ .tabs-wrapper--boxed {
517
+ .tabs__list {
518
+ background-color: $gray-100;
519
+ border-color: $gray-300;
520
+ }
521
+
522
+ .tabs__tab--active {
523
+ background-color: $color-white;
524
+ border-bottom-color: $color-white;
525
+ }
526
+
527
+ .tabs__panels {
528
+ border-color: $gray-300;
529
+ }
530
+ }
531
+ }
532
+
533
+ /* ==========================================================================
534
+ Reduced Motion Support
535
+ ========================================================================== */
536
+ @media (prefers-reduced-motion: reduce) {
537
+ .tabs__tab {
538
+ transition: none;
539
+ }
540
+ }