@keenmate/pure-admin-core 2.3.0 → 2.3.2

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 (69) hide show
  1. package/README.md +7 -5
  2. package/dist/css/main.css +207 -181
  3. package/package.json +1 -1
  4. package/snippets/buttons.html +375 -365
  5. package/src/scss/_base-css-variables.scss +8 -0
  6. package/src/scss/_core.scss +121 -121
  7. package/src/scss/core-components/_alerts.scss +227 -227
  8. package/src/scss/core-components/_badges.scss +16 -16
  9. package/src/scss/core-components/_base.scss +125 -125
  10. package/src/scss/core-components/_buttons.scss +580 -548
  11. package/src/scss/core-components/_callouts.scss +152 -152
  12. package/src/scss/core-components/_cards.scss +488 -488
  13. package/src/scss/core-components/_checkbox-lists.scss +289 -289
  14. package/src/scss/core-components/_code.scss +141 -141
  15. package/src/scss/core-components/_command-palette.scss +509 -509
  16. package/src/scss/core-components/_comparison.scss +172 -172
  17. package/src/scss/core-components/_data-display.scss +9 -9
  18. package/src/scss/core-components/_data-viz.scss +9 -9
  19. package/src/scss/core-components/_detail-panel.scss +1 -1
  20. package/src/scss/core-components/_file-selector.scss +780 -780
  21. package/src/scss/core-components/_filter-card.scss +58 -58
  22. package/src/scss/core-components/_forms.scss +16 -16
  23. package/src/scss/core-components/_grid.scss +293 -293
  24. package/src/scss/core-components/_layout.scss +15 -15
  25. package/src/scss/core-components/_lists.scss +211 -211
  26. package/src/scss/core-components/_loaders.scss +277 -277
  27. package/src/scss/core-components/_logic-tree.scss +280 -280
  28. package/src/scss/core-components/_modals.scss +203 -203
  29. package/src/scss/core-components/_notifications.scss +320 -320
  30. package/src/scss/core-components/_pagers.scss +141 -141
  31. package/src/scss/core-components/_popconfirm.scss +170 -170
  32. package/src/scss/core-components/_profile.scss +405 -405
  33. package/src/scss/core-components/_scrollbars.scss +40 -40
  34. package/src/scss/core-components/_settings-panel.scss +141 -141
  35. package/src/scss/core-components/_statistics.scss +200 -201
  36. package/src/scss/core-components/_tables.scss +900 -900
  37. package/src/scss/core-components/_tabs.scss +504 -504
  38. package/src/scss/core-components/_timeline.scss +589 -589
  39. package/src/scss/core-components/_toasts.scss +425 -425
  40. package/src/scss/core-components/_tooltips.scss +605 -605
  41. package/src/scss/core-components/_utilities.scss +1 -1
  42. package/src/scss/core-components/_web-components-theme.scss +21 -21
  43. package/src/scss/core-components/badges/_badge-base.scss +121 -121
  44. package/src/scss/core-components/badges/_badge-group.scss +25 -25
  45. package/src/scss/core-components/badges/_composite-badge-variants.scss +396 -396
  46. package/src/scss/core-components/badges/_composite-badge.scss +70 -70
  47. package/src/scss/core-components/badges/_index.scss +10 -10
  48. package/src/scss/core-components/badges/_labels.scss +155 -155
  49. package/src/scss/core-components/forms/_checkboxes-radios.scss +205 -205
  50. package/src/scss/core-components/forms/_form-inputs.scss +136 -135
  51. package/src/scss/core-components/forms/_form-layout.scss +66 -66
  52. package/src/scss/core-components/forms/_form-states.scss +115 -115
  53. package/src/scss/core-components/forms/_index.scss +12 -12
  54. package/src/scss/core-components/forms/_input-groups.scss +154 -154
  55. package/src/scss/core-components/forms/_input-wrapper.scss +89 -89
  56. package/src/scss/core-components/forms/_query-editor.scss +313 -313
  57. package/src/scss/core-components/layout/_index.scss +11 -11
  58. package/src/scss/core-components/layout/_layout-container.scss +168 -168
  59. package/src/scss/core-components/layout/_layout-responsive.scss +99 -99
  60. package/src/scss/core-components/layout/_navbar-elements.scss +250 -250
  61. package/src/scss/core-components/layout/_navbar.scss +83 -83
  62. package/src/scss/core-components/layout/_sidebar-states.scss +237 -237
  63. package/src/scss/core-components/layout/_sidebar.scss +234 -234
  64. package/src/scss/main.scss +7 -7
  65. package/src/scss/utilities.scss +740 -740
  66. package/src/scss/variables/_base.scss +228 -228
  67. package/src/scss/variables/_components.scss +748 -748
  68. package/src/scss/variables/_layout.scss +65 -65
  69. package/src/scss/variables/_typography.scss +37 -37
@@ -1,135 +1,136 @@
1
- /* ========================================
2
- Form Input Elements
3
- Input, select, textarea base styles and sizes
4
- ======================================== */
5
- @use '../../variables' as *;
6
-
7
- .pa-input {
8
- width: 100%;
9
- height: #{$base-input-size-md-height}rem;
10
- padding: $input-padding-v $input-padding-h;
11
- border: $border-width-base solid var(--pa-border-color);
12
- border-radius: $border-radius;
13
- font-size: $font-size-sm;
14
- background-color: var(--pa-input-bg);
15
- color: var(--pa-text-color-1);
16
- transition: border-color $transition-fast $easing-snappy;
17
-
18
- &:focus {
19
- outline: none;
20
- border-color: var(--pa-input-focus-border-color);
21
- box-shadow: 0 0 0 $focus-ring-width var(--pa-accent-light);
22
- }
23
- }
24
-
25
- .pa-select {
26
- width: 100%;
27
- height: #{$base-input-size-md-height}rem;
28
- padding: $select-padding-v $select-padding-h;
29
- border: $border-width-base solid var(--pa-border-color);
30
- border-radius: $border-radius;
31
- font-size: $font-size-sm;
32
- background-color: var(--pa-input-bg);
33
- color: var(--pa-text-color-1);
34
- transition: border-color $transition-fast $easing-snappy;
35
-
36
- &:focus {
37
- outline: none;
38
- border-color: var(--pa-select-focus-border-color);
39
- box-shadow: 0 0 0 $focus-ring-width var(--pa-accent-light);
40
- }
41
- }
42
-
43
- .pa-textarea {
44
- width: 100%;
45
- padding: $input-padding-v $input-padding-h;
46
- border: $border-width-base solid var(--pa-border-color);
47
- border-radius: $border-radius;
48
- font-size: $font-size-sm;
49
- background-color: var(--pa-input-bg);
50
- color: var(--pa-text-color-1);
51
- transition: border-color $transition-fast $easing-snappy;
52
- resize: vertical;
53
- min-height: $textarea-min-height;
54
-
55
- &:focus {
56
- outline: none;
57
- border-color: var(--pa-textarea-focus-border-color);
58
- box-shadow: 0 0 0 $focus-ring-width var(--pa-accent-light);
59
- }
60
-
61
- &::placeholder {
62
- color: var(--pa-text-color-2);
63
- }
64
- }
65
-
66
- // Input Sizes - heights aligned with $base-input-size-* variables
67
- .pa-input--xs,
68
- .pa-select--xs {
69
- height: #{$base-input-size-xs-height}rem;
70
- padding: $input-padding-xs-v $input-padding-h;
71
- font-size: $font-size-xs;
72
- }
73
-
74
- .pa-input--sm,
75
- .pa-select--sm {
76
- height: #{$base-input-size-sm-height}rem;
77
- padding: $input-padding-v $input-padding-h;
78
- font-size: $font-size-sm;
79
- }
80
-
81
- .pa-input--lg,
82
- .pa-select--lg {
83
- height: #{$base-input-size-lg-height}rem;
84
- padding: $input-padding-v $input-padding-h;
85
- font-size: $font-size-base;
86
- }
87
-
88
- .pa-input--xl,
89
- .pa-select--xl {
90
- height: #{$base-input-size-xl-height}rem;
91
- padding: $input-padding-v $input-padding-h;
92
- font-size: $font-size-lg;
93
- }
94
-
95
- // Textarea Sizes - height sets initial size, min-height prevents shrinking below that
96
- .pa-textarea--xs {
97
- height: 4rem;
98
- min-height: 4rem;
99
- padding: $input-padding-xs-v $input-padding-h;
100
- font-size: $font-size-xs;
101
- }
102
-
103
- .pa-textarea--sm {
104
- height: 6rem;
105
- min-height: 6rem;
106
- padding: $input-padding-v $input-padding-h;
107
- font-size: $font-size-sm;
108
- }
109
-
110
- .pa-textarea--lg {
111
- height: 12rem;
112
- min-height: 12rem;
113
- padding: $input-padding-v $input-padding-h;
114
- font-size: $font-size-base;
115
- }
116
-
117
- .pa-textarea--xl {
118
- height: 16rem;
119
- min-height: 16rem;
120
- padding: $input-padding-v $input-padding-h;
121
- font-size: $font-size-lg;
122
- }
123
-
124
- // Dark mode: invert native date/time picker icons for visibility
125
- .pa-mode-dark {
126
- input[type="date"],
127
- input[type="time"],
128
- input[type="datetime-local"],
129
- input[type="month"],
130
- input[type="week"] {
131
- &::-webkit-calendar-picker-indicator {
132
- filter: invert(1);
133
- }
134
- }
135
- }
1
+ /* ========================================
2
+ Form Input Elements
3
+ Input, select, textarea base styles and sizes
4
+ ======================================== */
5
+ @use '../../variables' as *;
6
+
7
+ .pa-input {
8
+ width: 100%;
9
+ height: #{$base-input-size-md-height}rem;
10
+ padding: $input-padding-v $input-padding-h;
11
+ border: $border-width-base solid var(--pa-border-color);
12
+ border-radius: var(--pa-border-radius);
13
+ font-size: $font-size-sm;
14
+ background-color: var(--pa-input-bg);
15
+ color: var(--pa-text-color-1);
16
+ transition: border-color $transition-fast $easing-snappy;
17
+
18
+ &:focus {
19
+ outline: none;
20
+ border-color: var(--pa-input-focus-border-color);
21
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-accent-light);
22
+ }
23
+ }
24
+
25
+ .pa-select {
26
+ width: 100%;
27
+ height: #{$base-input-size-md-height}rem;
28
+ padding: $select-padding-v $select-padding-h;
29
+ border: $border-width-base solid var(--pa-border-color);
30
+ border-radius: var(--pa-border-radius);
31
+ font-size: $font-size-sm;
32
+ line-height: normal;
33
+ background-color: var(--pa-input-bg);
34
+ color: var(--pa-text-color-1);
35
+ transition: border-color $transition-fast $easing-snappy;
36
+
37
+ &:focus {
38
+ outline: none;
39
+ border-color: var(--pa-select-focus-border-color);
40
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-accent-light);
41
+ }
42
+ }
43
+
44
+ .pa-textarea {
45
+ width: 100%;
46
+ padding: $input-padding-v $input-padding-h;
47
+ border: $border-width-base solid var(--pa-border-color);
48
+ border-radius: var(--pa-border-radius);
49
+ font-size: $font-size-sm;
50
+ background-color: var(--pa-input-bg);
51
+ color: var(--pa-text-color-1);
52
+ transition: border-color $transition-fast $easing-snappy;
53
+ resize: vertical;
54
+ min-height: $textarea-min-height;
55
+
56
+ &:focus {
57
+ outline: none;
58
+ border-color: var(--pa-textarea-focus-border-color);
59
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-accent-light);
60
+ }
61
+
62
+ &::placeholder {
63
+ color: var(--pa-text-color-2);
64
+ }
65
+ }
66
+
67
+ // Input Sizes - heights aligned with $base-input-size-* variables
68
+ .pa-input--xs,
69
+ .pa-select--xs {
70
+ height: #{$base-input-size-xs-height}rem;
71
+ padding: $input-padding-xs-v $input-padding-h;
72
+ font-size: $font-size-xs;
73
+ }
74
+
75
+ .pa-input--sm,
76
+ .pa-select--sm {
77
+ height: #{$base-input-size-sm-height}rem;
78
+ padding: $input-padding-v $input-padding-h;
79
+ font-size: $font-size-sm;
80
+ }
81
+
82
+ .pa-input--lg,
83
+ .pa-select--lg {
84
+ height: #{$base-input-size-lg-height}rem;
85
+ padding: $input-padding-v $input-padding-h;
86
+ font-size: $font-size-base;
87
+ }
88
+
89
+ .pa-input--xl,
90
+ .pa-select--xl {
91
+ height: #{$base-input-size-xl-height}rem;
92
+ padding: $input-padding-v $input-padding-h;
93
+ font-size: $font-size-lg;
94
+ }
95
+
96
+ // Textarea Sizes - height sets initial size, min-height prevents shrinking below that
97
+ .pa-textarea--xs {
98
+ height: 4rem;
99
+ min-height: 4rem;
100
+ padding: $input-padding-xs-v $input-padding-h;
101
+ font-size: $font-size-xs;
102
+ }
103
+
104
+ .pa-textarea--sm {
105
+ height: 6rem;
106
+ min-height: 6rem;
107
+ padding: $input-padding-v $input-padding-h;
108
+ font-size: $font-size-sm;
109
+ }
110
+
111
+ .pa-textarea--lg {
112
+ height: 12rem;
113
+ min-height: 12rem;
114
+ padding: $input-padding-v $input-padding-h;
115
+ font-size: $font-size-base;
116
+ }
117
+
118
+ .pa-textarea--xl {
119
+ height: 16rem;
120
+ min-height: 16rem;
121
+ padding: $input-padding-v $input-padding-h;
122
+ font-size: $font-size-lg;
123
+ }
124
+
125
+ // Dark mode: invert native date/time picker icons for visibility
126
+ .pa-mode-dark {
127
+ input[type="date"],
128
+ input[type="time"],
129
+ input[type="datetime-local"],
130
+ input[type="month"],
131
+ input[type="week"] {
132
+ &::-webkit-calendar-picker-indicator {
133
+ filter: invert(1);
134
+ }
135
+ }
136
+ }
@@ -1,66 +1,66 @@
1
- /* ========================================
2
- Form Layout
3
- Form groups, form containers, horizontal layouts
4
- ======================================== */
5
- @use '../../variables' as *;
6
-
7
- // Form Elements
8
- .pa-form-group {
9
- margin-bottom: $form-group-margin-bottom;
10
-
11
- // Remove margins when first/last child in card body (direct, in forms+grids, or in grid columns)
12
- .pa-card__body > &:first-child,
13
- .pa-card__body > .pa-form > .pure-g > [class*="pure-u"]:first-child > &:first-child,
14
- .pa-card__body > [class*="pure-u"]:first-child > &:first-child {
15
- margin-top: 0;
16
- }
17
- .pa-card__body > &:last-child,
18
- .pa-card__body > .pa-form > .pure-g > [class*="pure-u"]:last-child > &:last-child,
19
- .pa-card__body > [class*="pure-u"]:last-child > &:last-child {
20
- margin-bottom: 0;
21
- }
22
- }
23
-
24
- // Horizontal form group (label on left, input on right)
25
- .pa-form-group--horizontal {
26
- display: flex;
27
- align-items: flex-start;
28
- gap: $spacing-base;
29
-
30
- label {
31
- flex-shrink: 0;
32
- padding-top: $input-padding-v;
33
- margin-bottom: 0;
34
- color: var(--pa-text-color-1);
35
- font-weight: $font-weight-medium;
36
- font-size: $font-size-sm;
37
- }
38
-
39
- // Input container takes remaining space
40
- > .pa-input,
41
- > .pa-select,
42
- > .pa-textarea {
43
- flex: 1;
44
- }
45
- }
46
-
47
- .pa-form {
48
- .pa-form-group {
49
- label {
50
- display: flex;
51
- align-items: center;
52
- gap: $form-scale;
53
- margin-bottom: $form-label-margin-bottom;
54
- color: var(--pa-text-color-1);
55
- font-weight: $font-weight-medium;
56
- font-size: $font-size-sm;
57
- }
58
- }
59
-
60
- .pa-form-actions {
61
- margin-top: $spacing-base;
62
- display: flex;
63
- gap: $form-scale;
64
- flex-wrap: wrap;
65
- }
66
- }
1
+ /* ========================================
2
+ Form Layout
3
+ Form groups, form containers, horizontal layouts
4
+ ======================================== */
5
+ @use '../../variables' as *;
6
+
7
+ // Form Elements
8
+ .pa-form-group {
9
+ margin-bottom: $form-group-margin-bottom;
10
+
11
+ // Remove margins when first/last child in card body (direct, in forms+grids, or in grid columns)
12
+ .pa-card__body > &:first-child,
13
+ .pa-card__body > .pa-form > .pure-g > [class*="pure-u"]:first-child > &:first-child,
14
+ .pa-card__body > [class*="pure-u"]:first-child > &:first-child {
15
+ margin-top: 0;
16
+ }
17
+ .pa-card__body > &:last-child,
18
+ .pa-card__body > .pa-form > .pure-g > [class*="pure-u"]:last-child > &:last-child,
19
+ .pa-card__body > [class*="pure-u"]:last-child > &:last-child {
20
+ margin-bottom: 0;
21
+ }
22
+ }
23
+
24
+ // Horizontal form group (label on left, input on right)
25
+ .pa-form-group--horizontal {
26
+ display: flex;
27
+ align-items: flex-start;
28
+ gap: $spacing-base;
29
+
30
+ label {
31
+ flex-shrink: 0;
32
+ padding-top: $input-padding-v;
33
+ margin-bottom: 0;
34
+ color: var(--pa-text-color-1);
35
+ font-weight: $font-weight-medium;
36
+ font-size: $font-size-sm;
37
+ }
38
+
39
+ // Input container takes remaining space
40
+ > .pa-input,
41
+ > .pa-select,
42
+ > .pa-textarea {
43
+ flex: 1;
44
+ }
45
+ }
46
+
47
+ .pa-form {
48
+ .pa-form-group {
49
+ label {
50
+ display: flex;
51
+ align-items: center;
52
+ gap: $form-scale;
53
+ margin-bottom: $form-label-margin-bottom;
54
+ color: var(--pa-text-color-1);
55
+ font-weight: $font-weight-medium;
56
+ font-size: $font-size-sm;
57
+ }
58
+ }
59
+
60
+ .pa-form-actions {
61
+ margin-top: $spacing-base;
62
+ display: flex;
63
+ gap: $form-scale;
64
+ flex-wrap: wrap;
65
+ }
66
+ }
@@ -1,115 +1,115 @@
1
- /* ========================================
2
- Form Validation States
3
- Input states (error, success, warning), form groups with states, help text
4
- ======================================== */
5
- @use '../../variables' as *;
6
-
7
- // Input States
8
- .pa-input--error,
9
- .pa-select--error {
10
- border-color: var(--pa-danger-bg);
11
-
12
- &:focus {
13
- border-color: var(--pa-danger-bg);
14
- box-shadow: 0 0 0 $focus-ring-width var(--pa-danger-bg-light);
15
- }
16
- }
17
-
18
- .pa-input--success,
19
- .pa-select--success {
20
- border-color: var(--pa-success-bg);
21
-
22
- &:focus {
23
- border-color: var(--pa-success-bg);
24
- box-shadow: 0 0 0 $focus-ring-width var(--pa-success-bg-light);
25
- }
26
- }
27
-
28
- .pa-input--warning,
29
- .pa-select--warning {
30
- border-color: var(--pa-warning-bg);
31
-
32
- &:focus {
33
- border-color: var(--pa-warning-bg);
34
- box-shadow: 0 0 0 $focus-ring-width var(--pa-warning-bg-light);
35
- }
36
- }
37
-
38
- // Form Groups with States
39
- .pa-form-group--error {
40
- .pa-input,
41
- .pa-select {
42
- border-color: var(--pa-danger-bg);
43
-
44
- &:focus {
45
- border-color: var(--pa-danger-bg);
46
- box-shadow: 0 0 0 $focus-ring-width var(--pa-danger-bg-light);
47
- }
48
- }
49
- }
50
-
51
- .pa-form-group--success {
52
- .pa-input,
53
- .pa-select {
54
- border-color: var(--pa-success-bg);
55
-
56
- &:focus {
57
- border-color: var(--pa-success-bg);
58
- box-shadow: 0 0 0 $focus-ring-width var(--pa-success-bg-light);
59
- }
60
- }
61
- }
62
-
63
- .pa-form-group--warning {
64
- .pa-input,
65
- .pa-select {
66
- border-color: var(--pa-warning-bg);
67
-
68
- &:focus {
69
- border-color: var(--pa-warning-bg);
70
- box-shadow: 0 0 0 $focus-ring-width var(--pa-warning-bg-light);
71
- }
72
- }
73
- }
74
-
75
- // Form Help Text
76
- .pa-form-help {
77
- display: block;
78
- margin-top: $form-help-margin-top;
79
- font-size: $font-size-xs;
80
- color: var(--pa-text-color-2);
81
-
82
- &--error {
83
- color: var(--pa-danger-bg);
84
- }
85
-
86
- &--success {
87
- color: var(--pa-success-bg);
88
- }
89
-
90
- &--warning {
91
- color: var(--pa-warning-bg);
92
- }
93
- }
94
-
95
- // Theme Color Variants for Help Text (color-1 through color-9)
96
- @for $i from 1 through 9 {
97
- .pa-form-help--color-#{$i} {
98
- color: var(--pa-color-#{$i});
99
- }
100
- }
101
-
102
- // Theme Color Variants for Inputs (color-1 through color-9)
103
- // These use theme-customizable colors from --pa-color-* CSS variables
104
- @for $i from 1 through 9 {
105
- .pa-input--color-#{$i},
106
- .pa-select--color-#{$i},
107
- .pa-textarea--color-#{$i} {
108
- border-color: var(--pa-color-#{$i});
109
-
110
- &:focus {
111
- border-color: var(--pa-color-#{$i});
112
- box-shadow: 0 0 0 $focus-ring-width color-mix(in srgb, var(--pa-color-#{$i}) 25%, transparent);
113
- }
114
- }
115
- }
1
+ /* ========================================
2
+ Form Validation States
3
+ Input states (error, success, warning), form groups with states, help text
4
+ ======================================== */
5
+ @use '../../variables' as *;
6
+
7
+ // Input States
8
+ .pa-input--error,
9
+ .pa-select--error {
10
+ border-color: var(--pa-danger-bg);
11
+
12
+ &:focus {
13
+ border-color: var(--pa-danger-bg);
14
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-danger-bg-light);
15
+ }
16
+ }
17
+
18
+ .pa-input--success,
19
+ .pa-select--success {
20
+ border-color: var(--pa-success-bg);
21
+
22
+ &:focus {
23
+ border-color: var(--pa-success-bg);
24
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-success-bg-light);
25
+ }
26
+ }
27
+
28
+ .pa-input--warning,
29
+ .pa-select--warning {
30
+ border-color: var(--pa-warning-bg);
31
+
32
+ &:focus {
33
+ border-color: var(--pa-warning-bg);
34
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-warning-bg-light);
35
+ }
36
+ }
37
+
38
+ // Form Groups with States
39
+ .pa-form-group--error {
40
+ .pa-input,
41
+ .pa-select {
42
+ border-color: var(--pa-danger-bg);
43
+
44
+ &:focus {
45
+ border-color: var(--pa-danger-bg);
46
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-danger-bg-light);
47
+ }
48
+ }
49
+ }
50
+
51
+ .pa-form-group--success {
52
+ .pa-input,
53
+ .pa-select {
54
+ border-color: var(--pa-success-bg);
55
+
56
+ &:focus {
57
+ border-color: var(--pa-success-bg);
58
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-success-bg-light);
59
+ }
60
+ }
61
+ }
62
+
63
+ .pa-form-group--warning {
64
+ .pa-input,
65
+ .pa-select {
66
+ border-color: var(--pa-warning-bg);
67
+
68
+ &:focus {
69
+ border-color: var(--pa-warning-bg);
70
+ box-shadow: 0 0 0 $focus-ring-width var(--pa-warning-bg-light);
71
+ }
72
+ }
73
+ }
74
+
75
+ // Form Help Text
76
+ .pa-form-help {
77
+ display: block;
78
+ margin-top: $form-help-margin-top;
79
+ font-size: $font-size-xs;
80
+ color: var(--pa-text-color-2);
81
+
82
+ &--error {
83
+ color: var(--pa-danger-bg);
84
+ }
85
+
86
+ &--success {
87
+ color: var(--pa-success-bg);
88
+ }
89
+
90
+ &--warning {
91
+ color: var(--pa-warning-bg);
92
+ }
93
+ }
94
+
95
+ // Theme Color Variants for Help Text (color-1 through color-9)
96
+ @for $i from 1 through 9 {
97
+ .pa-form-help--color-#{$i} {
98
+ color: var(--pa-color-#{$i});
99
+ }
100
+ }
101
+
102
+ // Theme Color Variants for Inputs (color-1 through color-9)
103
+ // These use theme-customizable colors from --pa-color-* CSS variables
104
+ @for $i from 1 through 9 {
105
+ .pa-input--color-#{$i},
106
+ .pa-select--color-#{$i},
107
+ .pa-textarea--color-#{$i} {
108
+ border-color: var(--pa-color-#{$i});
109
+
110
+ &:focus {
111
+ border-color: var(--pa-color-#{$i});
112
+ box-shadow: 0 0 0 $focus-ring-width color-mix(in srgb, var(--pa-color-#{$i}) 25%, transparent);
113
+ }
114
+ }
115
+ }
@@ -1,12 +1,12 @@
1
- /* ========================================
2
- Forms Index
3
- Central import point for all form component modules
4
- ======================================== */
5
-
6
- @forward 'form-layout';
7
- @forward 'form-inputs';
8
- @forward 'form-states';
9
- @forward 'input-groups';
10
- @forward 'input-wrapper';
11
- @forward 'query-editor';
12
- @forward 'checkboxes-radios';
1
+ /* ========================================
2
+ Forms Index
3
+ Central import point for all form component modules
4
+ ======================================== */
5
+
6
+ @forward 'form-layout';
7
+ @forward 'form-inputs';
8
+ @forward 'form-states';
9
+ @forward 'input-groups';
10
+ @forward 'input-wrapper';
11
+ @forward 'query-editor';
12
+ @forward 'checkboxes-radios';