@clayui/css 3.91.0 → 3.93.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 (83) hide show
  1. package/lib/css/atlas.css +623 -178
  2. package/lib/css/atlas.css.map +1 -1
  3. package/lib/css/base.css +330 -15
  4. package/lib/css/base.css.map +1 -1
  5. package/lib/css/cadmin.css +471 -93
  6. package/lib/css/cadmin.css.map +1 -1
  7. package/lib/images/icons/icons.svg +1 -1
  8. package/package.json +2 -2
  9. package/src/scss/_license-text.scss +1 -1
  10. package/src/scss/atlas/variables/_cards.scss +3 -4
  11. package/src/scss/atlas/variables/_clay-color.scss +1 -1
  12. package/src/scss/atlas/variables/_globals.scss +2 -2
  13. package/src/scss/atlas/variables/_navs.scss +6 -10
  14. package/src/scss/atlas/variables/_panels.scss +1 -1
  15. package/src/scss/atlas/variables/_popovers.scss +2 -1
  16. package/src/scss/atlas/variables/_sheets.scss +1 -1
  17. package/src/scss/atlas/variables/_sidebar.scss +1 -1
  18. package/src/scss/atlas/variables/_time.scss +1 -1
  19. package/src/scss/cadmin/components/_badges.scss +5 -1
  20. package/src/scss/cadmin/components/_drilldown.scss +1 -1
  21. package/src/scss/cadmin/components/_forms.scss +1 -1
  22. package/src/scss/cadmin/components/_input-groups.scss +2 -1
  23. package/src/scss/cadmin/components/_multi-step-nav.scss +42 -1
  24. package/src/scss/cadmin/components/_side-navigation.scss +2 -2
  25. package/src/scss/cadmin/components/_treeview.scss +18 -16
  26. package/src/scss/cadmin/components/_utilities-functional-important.scss +6 -0
  27. package/src/scss/cadmin/variables/_badges.scss +5 -0
  28. package/src/scss/cadmin/variables/_buttons.scss +14 -1
  29. package/src/scss/cadmin/variables/_clay-color.scss +1 -1
  30. package/src/scss/cadmin/variables/_date-picker.scss +8 -0
  31. package/src/scss/cadmin/variables/_globals.scss +2 -2
  32. package/src/scss/cadmin/variables/_multi-step-nav.scss +23 -0
  33. package/src/scss/cadmin/variables/_navs.scss +1 -2
  34. package/src/scss/cadmin/variables/_panels.scss +1 -1
  35. package/src/scss/cadmin/variables/_resizer.scss +2 -2
  36. package/src/scss/cadmin/variables/_sheets.scss +1 -1
  37. package/src/scss/cadmin/variables/_sidebar.scss +1 -1
  38. package/src/scss/cadmin/variables/_tbar.scss +2 -4
  39. package/src/scss/cadmin/variables/_time.scss +1 -1
  40. package/src/scss/cadmin/variables/_treeview.scss +21 -8
  41. package/src/scss/cadmin/variables/_utilities.scss +12 -1
  42. package/src/scss/components/_alerts.scss +24 -22
  43. package/src/scss/components/_aspect-ratio.scss +33 -31
  44. package/src/scss/components/_badges.scss +28 -22
  45. package/src/scss/components/_buttons.scss +105 -97
  46. package/src/scss/components/_drilldown.scss +1 -1
  47. package/src/scss/components/_dropdowns.scss +10 -8
  48. package/src/scss/components/_forms.scss +12 -9
  49. package/src/scss/components/_input-groups.scss +2 -1
  50. package/src/scss/components/_labels.scss +48 -44
  51. package/src/scss/components/_list-group.scss +13 -11
  52. package/src/scss/components/_loaders.scss +22 -18
  53. package/src/scss/components/_modals.scss +4 -2
  54. package/src/scss/components/_multi-step-nav.scss +45 -1
  55. package/src/scss/components/_navs.scss +10 -20
  56. package/src/scss/components/_popovers.scss +33 -27
  57. package/src/scss/components/_progress-bars.scss +39 -33
  58. package/src/scss/components/_sheets.scss +39 -0
  59. package/src/scss/components/_side-navigation.scss +2 -2
  60. package/src/scss/components/_sidebar.scss +12 -10
  61. package/src/scss/components/_spinners.scss +20 -0
  62. package/src/scss/components/_stickers.scss +50 -46
  63. package/src/scss/components/_tables.scss +32 -30
  64. package/src/scss/components/_treeview.scss +18 -12
  65. package/src/scss/components/_utilities-functional-important.scss +81 -63
  66. package/src/scss/functions/_global-functions.scss +25 -1
  67. package/src/scss/mixins/_alerts.scss +11 -9
  68. package/src/scss/mixins/_buttons.scss +60 -0
  69. package/src/scss/mixins/_dropdown-menu.scss +36 -0
  70. package/src/scss/mixins/_globals.scss +34 -0
  71. package/src/scss/mixins/_links.scss +9 -7
  72. package/src/scss/mixins/_nav.scss +16 -0
  73. package/src/scss/mixins/_transition.scss +12 -0
  74. package/src/scss/variables/_badges.scss +5 -0
  75. package/src/scss/variables/_buttons.scss +14 -1
  76. package/src/scss/variables/_date-picker.scss +2 -2
  77. package/src/scss/variables/_multi-step-nav.scss +23 -0
  78. package/src/scss/variables/_navs.scss +38 -5
  79. package/src/scss/variables/_resizer.scss +2 -2
  80. package/src/scss/variables/_sheets.scss +17 -0
  81. package/src/scss/variables/_tbar.scss +2 -2
  82. package/src/scss/variables/_treeview.scss +21 -8
  83. package/src/scss/variables/_utilities.scss +11 -0
@@ -89,31 +89,33 @@
89
89
  // Label Sizes
90
90
 
91
91
  @each $selector, $value in $label-sizes {
92
- $selector: if(
93
- starts-with($selector, '.') or
94
- starts-with($selector, '#') or
95
- starts-with($selector, '%'),
96
- $selector,
97
- str-insert($selector, '.', 1)
98
- );
99
-
100
- @if (starts-with($selector, '%') or map-get($value, extend)) {
101
- #{$selector} {
102
- @include clay-label-variant($value);
103
- }
104
- } @else {
105
- $placeholder: if(
106
- starts-with($selector, '.') or starts-with($selector, '#'),
107
- '%#{str-slice($selector, 2)}',
108
- '%#{$selector}'
92
+ @if not clay-is-map-unset($value) {
93
+ $selector: if(
94
+ starts-with($selector, '.') or
95
+ starts-with($selector, '#') or
96
+ starts-with($selector, '%'),
97
+ $selector,
98
+ str-insert($selector, '.', 1)
109
99
  );
110
100
 
111
- #{$placeholder} {
112
- @include clay-label-variant($value);
113
- }
101
+ @if (starts-with($selector, '%') or map-get($value, extend)) {
102
+ #{$selector} {
103
+ @include clay-label-variant($value);
104
+ }
105
+ } @else {
106
+ $placeholder: if(
107
+ starts-with($selector, '.') or starts-with($selector, '#'),
108
+ '%#{str-slice($selector, 2)}',
109
+ '%#{$selector}'
110
+ );
111
+
112
+ #{$placeholder} {
113
+ @include clay-label-variant($value);
114
+ }
114
115
 
115
- #{$selector} {
116
- @extend #{$placeholder} !optional;
116
+ #{$selector} {
117
+ @extend #{$placeholder} !optional;
118
+ }
117
119
  }
118
120
  }
119
121
  }
@@ -121,31 +123,33 @@
121
123
  // Label Variants
122
124
 
123
125
  @each $color, $value in $label-palette {
124
- $selector: if(
125
- starts-with($color, '.') or
126
- starts-with($color, '#') or
127
- starts-with($color, '%'),
128
- $color,
129
- str-insert($color, '.label-', 1)
130
- );
131
-
132
- @if (starts-with($color, '%') or map-get($value, extend)) {
133
- #{$selector} {
134
- @include clay-label-variant($value);
135
- }
136
- } @else {
137
- $placeholder: if(
138
- starts-with($color, '.') or starts-with($color, '#'),
139
- '%#{str-slice($color, 2)}',
140
- '%label-#{$color}'
126
+ @if not clay-is-map-unset($value) {
127
+ $selector: if(
128
+ starts-with($color, '.') or
129
+ starts-with($color, '#') or
130
+ starts-with($color, '%'),
131
+ $color,
132
+ str-insert($color, '.label-', 1)
141
133
  );
142
134
 
143
- #{$placeholder} {
144
- @include clay-label-variant($value);
145
- }
135
+ @if (starts-with($color, '%') or map-get($value, extend)) {
136
+ #{$selector} {
137
+ @include clay-label-variant($value);
138
+ }
139
+ } @else {
140
+ $placeholder: if(
141
+ starts-with($color, '.') or starts-with($color, '#'),
142
+ '%#{str-slice($color, 2)}',
143
+ '%label-#{$color}'
144
+ );
145
+
146
+ #{$placeholder} {
147
+ @include clay-label-variant($value);
148
+ }
146
149
 
147
- #{$selector} {
148
- @extend #{$placeholder} !optional;
150
+ #{$selector} {
151
+ @extend #{$placeholder} !optional;
152
+ }
149
153
  }
150
154
  }
151
155
  }
@@ -410,20 +410,22 @@
410
410
  // List Group Item Variants
411
411
 
412
412
  @each $color, $value in $list-group-item-theme-colors {
413
- .list-group-item-#{$color} {
414
- @include clay-css($value);
413
+ @if not clay-is-map-unset($value) {
414
+ .list-group-item-#{$color} {
415
+ @include clay-css($value);
415
416
 
416
- &.list-group-item-action {
417
- &:hover {
418
- @include clay-css(map-get($value, hover));
419
- }
417
+ &.list-group-item-action {
418
+ &:hover {
419
+ @include clay-css(map-get($value, hover));
420
+ }
420
421
 
421
- &:focus {
422
- @include clay-css(map-get($value, focus));
423
- }
422
+ &:focus {
423
+ @include clay-css(map-get($value, focus));
424
+ }
424
425
 
425
- &.active {
426
- @include clay-css(map-get($value, active));
426
+ &.active {
427
+ @include clay-css(map-get($value, active));
428
+ }
427
429
  }
428
430
  }
429
431
  }
@@ -79,31 +79,35 @@
79
79
  // Loading Animation Sizes
80
80
 
81
81
  @each $selector, $value in $loading-animation-sizes {
82
- $_selector: if(
83
- starts-with($selector, '.') or
84
- starts-with($selector, '#') or
85
- starts-with($selector, '%'),
86
- $selector,
87
- str-insert($selector, '.', 1)
88
- );
82
+ @if not clay-is-map-unset($value) {
83
+ $_selector: if(
84
+ starts-with($selector, '.') or
85
+ starts-with($selector, '#') or
86
+ starts-with($selector, '%'),
87
+ $selector,
88
+ str-insert($selector, '.', 1)
89
+ );
89
90
 
90
- #{$_selector} {
91
- @include clay-spinner-variant($value);
91
+ #{$_selector} {
92
+ @include clay-spinner-variant($value);
93
+ }
92
94
  }
93
95
  }
94
96
 
95
97
  // Loading Animation Variants
96
98
 
97
99
  @each $selector, $value in $loading-animation-palette {
98
- $_selector: if(
99
- starts-with($selector, '.') or
100
- starts-with($selector, '#') or
101
- starts-with($selector, '%'),
102
- $selector,
103
- str-insert($selector, '.', 1)
104
- );
100
+ @if not clay-is-map-unset($value) {
101
+ $_selector: if(
102
+ starts-with($selector, '.') or
103
+ starts-with($selector, '#') or
104
+ starts-with($selector, '%'),
105
+ $selector,
106
+ str-insert($selector, '.', 1)
107
+ );
105
108
 
106
- #{$_selector} {
107
- @include clay-spinner-variant($value);
109
+ #{$_selector} {
110
+ @include clay-spinner-variant($value);
111
+ }
108
112
  }
109
113
  }
@@ -490,8 +490,10 @@
490
490
  // Modal Variants
491
491
 
492
492
  @each $color, $value in $modal-palette {
493
- .modal-#{$color} {
494
- @include clay-modal-variant($value);
493
+ @if not clay-is-map-unset($value) {
494
+ .modal-#{$color} {
495
+ @include clay-modal-variant($value);
496
+ }
495
497
  }
496
498
  }
497
499
 
@@ -121,6 +121,45 @@
121
121
  }
122
122
  }
123
123
 
124
+ &.error {
125
+ @include clay-css($multi-step-item-error);
126
+
127
+ .multi-step-title {
128
+ @include clay-css(
129
+ map-get($multi-step-item-error, multi-step-title)
130
+ );
131
+ }
132
+
133
+ .multi-step-icon {
134
+ $_multi-step-icon: setter(
135
+ map-get($multi-step-item-error, multi-step-icon)
136
+ );
137
+
138
+ @include clay-css($_multi-step-icon);
139
+
140
+ &[data-multi-step-icon] {
141
+ $_data-multi-step-icon: setter(
142
+ map-get($_multi-step-icon, data-multi-step-icon),
143
+ ()
144
+ );
145
+
146
+ &::before {
147
+ @include clay-css(map-get($_data-multi-step-icon, before));
148
+ }
149
+ }
150
+
151
+ .lexicon-icon {
152
+ @include clay-css(map-get($_multi-step-icon, lexicon-icon));
153
+ }
154
+ }
155
+
156
+ .multi-step-divider {
157
+ @include clay-css(
158
+ map-get($multi-step-item-error, multi-step-divider)
159
+ );
160
+ }
161
+ }
162
+
124
163
  &.disabled {
125
164
  .multi-step-title {
126
165
  color: $multi-step-title-disabled-color;
@@ -218,6 +257,9 @@
218
257
  .multi-step-icon {
219
258
  align-items: center;
220
259
  background-color: $multi-step-icon-bg;
260
+ background-position: center;
261
+ background-repeat: no-repeat;
262
+ background-size: $multi-step-icon-font-size;
221
263
  border-color: $multi-step-icon-border-color;
222
264
  border-radius: $multi-step-icon-border-radius;
223
265
  border-style: $multi-step-icon-border-style;
@@ -233,7 +275,9 @@
233
275
  padding-left: $multi-step-icon-padding-left;
234
276
  padding-right: $multi-step-icon-padding-right;
235
277
  padding-top: $multi-step-icon-padding-top;
236
- transition: $multi-step-icon-transition;
278
+
279
+ @include transition($multi-step-icon-transition);
280
+
237
281
  width: $multi-step-icon-size;
238
282
 
239
283
  &:hover {
@@ -135,20 +135,8 @@
135
135
  .nav-tabs {
136
136
  @include clay-nav-variant($nav-tabs);
137
137
 
138
- .dropdown-menu {
139
- @include border-top-radius(0);
140
-
141
- margin-top: math-sign($nav-tabs-border-width);
142
- }
143
-
144
138
  + .tab-content {
145
139
  .tab-pane {
146
- background-color: $nav-tabs-tab-pane-bg;
147
-
148
- @include border-radius($nav-tabs-tab-pane-border-radius);
149
-
150
- padding: $nav-tabs-tab-pane-padding;
151
-
152
140
  &.active:first-child {
153
141
  border-top-left-radius: 0;
154
142
  }
@@ -201,13 +189,15 @@
201
189
  // Nav Variants
202
190
 
203
191
  @each $key, $value in $nav-palette {
204
- $selector: if(
205
- starts-with($key, '.') or starts-with($key, '#'),
206
- $key,
207
- str-insert($key, '.', 1)
208
- );
209
-
210
- #{$selector} {
211
- @include clay-nav-variant($value);
192
+ @if not clay-is-map-unset($value) {
193
+ $selector: if(
194
+ starts-with($key, '.') or starts-with($key, '#'),
195
+ $key,
196
+ str-insert($key, '.', 1)
197
+ );
198
+
199
+ #{$selector} {
200
+ @include clay-nav-variant($value);
201
+ }
212
202
  }
213
203
  }
@@ -1,16 +1,18 @@
1
1
  // Popovers
2
2
 
3
3
  @each $selector, $value in $popovers {
4
- $selector: if(
5
- starts-with($selector, '.') or
6
- starts-with($selector, '#') or
7
- starts-with($selector, '%'),
8
- $selector,
9
- str-insert($selector, '.', 1)
10
- );
4
+ @if not clay-is-map-unset($value) {
5
+ $selector: if(
6
+ starts-with($selector, '.') or
7
+ starts-with($selector, '#') or
8
+ starts-with($selector, '%'),
9
+ $selector,
10
+ str-insert($selector, '.', 1)
11
+ );
11
12
 
12
- #{$selector} {
13
- @include clay-popover-variant($value);
13
+ #{$selector} {
14
+ @include clay-popover-variant($value);
15
+ }
14
16
  }
15
17
  }
16
18
 
@@ -150,32 +152,36 @@
150
152
  // Popover Headers
151
153
 
152
154
  @each $selector, $value in $popover-headers {
153
- $selector: if(
154
- starts-with($selector, '.') or
155
- starts-with($selector, '#') or
156
- starts-with($selector, '%'),
157
- $selector,
158
- str-insert($selector, '.', 1)
159
- );
155
+ @if not clay-is-map-unset($value) {
156
+ $selector: if(
157
+ starts-with($selector, '.') or
158
+ starts-with($selector, '#') or
159
+ starts-with($selector, '%'),
160
+ $selector,
161
+ str-insert($selector, '.', 1)
162
+ );
160
163
 
161
- #{$selector} {
162
- @include clay-popover-header-variant($value);
164
+ #{$selector} {
165
+ @include clay-popover-header-variant($value);
166
+ }
163
167
  }
164
168
  }
165
169
 
166
170
  // Popover Bodies
167
171
 
168
172
  @each $selector, $value in $popover-bodies {
169
- $selector: if(
170
- starts-with($selector, '.') or
171
- starts-with($selector, '#') or
172
- starts-with($selector, '%'),
173
- $selector,
174
- str-insert($selector, '.', 1)
175
- );
173
+ @if not clay-is-map-unset($value) {
174
+ $selector: if(
175
+ starts-with($selector, '.') or
176
+ starts-with($selector, '#') or
177
+ starts-with($selector, '%'),
178
+ $selector,
179
+ str-insert($selector, '.', 1)
180
+ );
176
181
 
177
- #{$selector} {
178
- @include clay-popover-header-variant($value);
182
+ #{$selector} {
183
+ @include clay-popover-header-variant($value);
184
+ }
179
185
  }
180
186
  }
181
187
 
@@ -61,6 +61,10 @@
61
61
  animation: none;
62
62
  }
63
63
  }
64
+
65
+ .c-prefers-reduced-motion & {
66
+ animation: none;
67
+ }
64
68
  }
65
69
  }
66
70
 
@@ -122,40 +126,42 @@
122
126
  // Progress Variants
123
127
 
124
128
  @each $color, $value in $progress-palette {
125
- .progress-#{$color} {
126
- .progress-bar {
127
- $progress-bar: setter(map-get($value, progress-bar), ());
128
- $progress-bar: map-merge(
129
- $progress-bar,
130
- (
131
- background-color:
132
- setter(
133
- map-get($progress-bar, background-color),
134
- map-get($value, bar-bg)
135
- ),
136
- )
137
- );
138
-
139
- @include clay-css($progress-bar);
140
- }
129
+ @if not clay-is-map-unset($value) {
130
+ .progress-#{$color} {
131
+ .progress-bar {
132
+ $progress-bar: setter(map-get($value, progress-bar), ());
133
+ $progress-bar: map-merge(
134
+ $progress-bar,
135
+ (
136
+ background-color:
137
+ setter(
138
+ map-get($progress-bar, background-color),
139
+ map-get($value, bar-bg)
140
+ ),
141
+ )
142
+ );
143
+
144
+ @include clay-css($progress-bar);
145
+ }
141
146
 
142
- .progress-group-feedback {
143
- $progress-group-feedback: setter(
144
- map-get($value, progress-group-feedback),
145
- ()
146
- );
147
- $progress-group-feedback: map-merge(
148
- $progress-group-feedback,
149
- (
150
- color:
151
- setter(
152
- map-get($progress-group-feedback, color),
153
- map-get($value, group-feedback-color)
154
- ),
155
- )
156
- );
157
-
158
- @include clay-css($progress-group-feedback);
147
+ .progress-group-feedback {
148
+ $progress-group-feedback: setter(
149
+ map-get($value, progress-group-feedback),
150
+ ()
151
+ );
152
+ $progress-group-feedback: map-merge(
153
+ $progress-group-feedback,
154
+ (
155
+ color:
156
+ setter(
157
+ map-get($progress-group-feedback, color),
158
+ map-get($value, group-feedback-color)
159
+ ),
160
+ )
161
+ );
162
+
163
+ @include clay-css($progress-group-feedback);
164
+ }
159
165
  }
160
166
  }
161
167
  }
@@ -64,6 +64,45 @@
64
64
  }
65
65
  }
66
66
 
67
+ .sheet-row {
68
+ @include clay-css($sheet-row);
69
+
70
+ @if (map-get($sheet-row, media-breakpoint-up)) {
71
+ @each $breakpoint in map-keys(map-get($sheet-row, media-breakpoint-up))
72
+ {
73
+ $media-breakpoint-up: map-deep-get(
74
+ $sheet-row,
75
+ media-breakpoint-up,
76
+ $breakpoint
77
+ );
78
+
79
+ @if ($breakpoint) {
80
+ @include media-breakpoint-up($breakpoint) {
81
+ @include clay-css($media-breakpoint-up);
82
+ }
83
+ }
84
+ }
85
+ }
86
+
87
+ @if (map-get($sheet-row, media-breakpoint-down)) {
88
+ @each $breakpoint
89
+ in map-keys(map-get($sheet-row, media-breakpoint-down))
90
+ {
91
+ $media-breakpoint-down: map-deep-get(
92
+ $sheet-row,
93
+ media-breakpoint-down,
94
+ $breakpoint
95
+ );
96
+
97
+ @if ($breakpoint) {
98
+ @include media-breakpoint-down($breakpoint) {
99
+ @include clay-css($media-breakpoint-down);
100
+ }
101
+ }
102
+ }
103
+ }
104
+ }
105
+
67
106
  .sheet-header {
68
107
  margin-bottom: $sheet-header-margin-bottom;
69
108
 
@@ -91,14 +91,14 @@
91
91
  .sidenav-content,
92
92
  .sidenav-menu,
93
93
  .sidenav-menu-slider {
94
- transition: $sidenav-transition;
94
+ @include transition($sidenav-transition);
95
95
  }
96
96
  }
97
97
 
98
98
  // Simple Sidenav Transition
99
99
 
100
100
  .sidenav-transition {
101
- transition: $sidenav-transition;
101
+ @include transition($sidenav-transition);
102
102
  }
103
103
 
104
104
  // Simple Sidenav
@@ -105,15 +105,17 @@
105
105
  // Sidebar Variants
106
106
 
107
107
  @each $color, $value in $sidebar-palette {
108
- $selector: if(
109
- starts-with($color, '.') or
110
- starts-with($color, '#') or
111
- starts-with($color, '%'),
112
- $color,
113
- str-insert($color, '.', 1)
114
- );
115
-
116
- #{$selector} {
117
- @include clay-sidebar-variant($value);
108
+ @if not clay-is-map-unset($value) {
109
+ $selector: if(
110
+ starts-with($color, '.') or
111
+ starts-with($color, '#') or
112
+ starts-with($color, '%'),
113
+ $color,
114
+ str-insert($color, '.', 1)
115
+ );
116
+
117
+ #{$selector} {
118
+ @include clay-sidebar-variant($value);
119
+ }
118
120
  }
119
121
  }
@@ -17,6 +17,16 @@
17
17
  height: $spinner-height;
18
18
  vertical-align: text-bottom;
19
19
  width: $spinner-width;
20
+
21
+ @if $enable-prefers-reduced-motion-media-query {
22
+ @media (prefers-reduced-motion: reduce) {
23
+ animation: none;
24
+ }
25
+ }
26
+
27
+ .c-prefers-reduced-motion & {
28
+ animation: none;
29
+ }
20
30
  }
21
31
 
22
32
  .spinner-border-sm {
@@ -45,6 +55,16 @@
45
55
  opacity: 0;
46
56
  vertical-align: text-bottom;
47
57
  width: $spinner-width;
58
+
59
+ @if $enable-prefers-reduced-motion-media-query {
60
+ @media (prefers-reduced-motion: reduce) {
61
+ animation: none;
62
+ }
63
+ }
64
+
65
+ .c-prefers-reduced-motion & {
66
+ animation: none;
67
+ }
48
68
  }
49
69
 
50
70
  .spinner-grow-sm {