@progressiveui/styles 10.30.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 (265) hide show
  1. package/CHANGELOG.md +621 -0
  2. package/README.md +85 -0
  3. package/index-with-tokens.scss +26 -0
  4. package/index.scss +12 -0
  5. package/package.json +42 -0
  6. package/scss/_breakpoint.scss +2 -0
  7. package/scss/_config.scss +30 -0
  8. package/scss/_feature-flags.scss +1 -0
  9. package/scss/_font-face.scss +13 -0
  10. package/scss/_global-defaults.scss +14 -0
  11. package/scss/_grid.scss +32 -0
  12. package/scss/_motion.scss +67 -0
  13. package/scss/_reset.scss +172 -0
  14. package/scss/_spacing.scss +4 -0
  15. package/scss/_theme.scss +102 -0
  16. package/scss/_themes.scss +14 -0
  17. package/scss/_type.scss +143 -0
  18. package/scss/_zone.scss +26 -0
  19. package/scss/components/_index.scss +82 -0
  20. package/scss/components/accordion/_accordion.legacy.scss +348 -0
  21. package/scss/components/accordion/_accordion.scss +118 -0
  22. package/scss/components/accordion/_index.scss +4 -0
  23. package/scss/components/anchor-navigation/_anchor-navigation.scss +37 -0
  24. package/scss/components/anchor-navigation/_index.scss +4 -0
  25. package/scss/components/auth-layout/_auth-layout.scss +55 -0
  26. package/scss/components/auth-layout/_index.scss +11 -0
  27. package/scss/components/avatar/_avatar.scss +61 -0
  28. package/scss/components/avatar/_index.scss +4 -0
  29. package/scss/components/banner-navigation/_banner-navigation.scss +80 -0
  30. package/scss/components/banner-navigation/_index.scss +4 -0
  31. package/scss/components/blockquote/_blockquote.scss +156 -0
  32. package/scss/components/blockquote/_index.scss +4 -0
  33. package/scss/components/breadcrumb/_breadcrumb.scss +89 -0
  34. package/scss/components/breadcrumb/_index.scss +4 -0
  35. package/scss/components/button/_button.scss +520 -0
  36. package/scss/components/button/_index.scss +5 -0
  37. package/scss/components/button/_mixins.scss +92 -0
  38. package/scss/components/button/_vars.scss +69 -0
  39. package/scss/components/card/_card-external.scss +149 -0
  40. package/scss/components/card/_card.scss +138 -0
  41. package/scss/components/card/_index.scss +7 -0
  42. package/scss/components/checkbox/_checkbox.scss +195 -0
  43. package/scss/components/checkbox/_index.scss +11 -0
  44. package/scss/components/code-snippet/_code-snippet.scss +581 -0
  45. package/scss/components/code-snippet/_index.scss +11 -0
  46. package/scss/components/code-snippet/_mixins.scss +21 -0
  47. package/scss/components/col/_col.scss +54 -0
  48. package/scss/components/col/_index.scss +4 -0
  49. package/scss/components/combo-box/_combo-box.scss +45 -0
  50. package/scss/components/combo-box/_index.scss +11 -0
  51. package/scss/components/content-switcher/_content-switcher.scss +132 -0
  52. package/scss/components/content-switcher/_index.scss +11 -0
  53. package/scss/components/context-menu/_context-menu.scss +26 -0
  54. package/scss/components/context-menu/_index.scss +11 -0
  55. package/scss/components/credits/_credits.scss +30 -0
  56. package/scss/components/credits/_index.scss +11 -0
  57. package/scss/components/data-table/_data-table.scss +1005 -0
  58. package/scss/components/data-table/_index.scss +12 -0
  59. package/scss/components/data-table/_mixins.scss +38 -0
  60. package/scss/components/data-table/_vars.scss +13 -0
  61. package/scss/components/data-table/action/_data-table-action.scss +587 -0
  62. package/scss/components/data-table/action/_index.scss +11 -0
  63. package/scss/components/data-table/expandable/_data-table-expandable.scss +411 -0
  64. package/scss/components/data-table/expandable/_index.scss +11 -0
  65. package/scss/components/data-table/skeleton/_data-table-skeleton.scss +72 -0
  66. package/scss/components/data-table/skeleton/_index.scss +11 -0
  67. package/scss/components/data-table/sort/_data-table-sort.scss +245 -0
  68. package/scss/components/data-table/sort/_index.scss +11 -0
  69. package/scss/components/date-picker/_date-picker.scss +896 -0
  70. package/scss/components/date-picker/_flatpickr.scss +538 -0
  71. package/scss/components/date-picker/_index.scss +11 -0
  72. package/scss/components/date-picker-new/_date-picker-new.scss +100 -0
  73. package/scss/components/date-picker-new/_index.scss +4 -0
  74. package/scss/components/date-picker-new/react-datepicker/datepicker.scss +692 -0
  75. package/scss/components/date-picker-new/react-datepicker/mixins.scss +88 -0
  76. package/scss/components/date-picker-new/react-datepicker/variables.scss +20 -0
  77. package/scss/components/dropdown/_dropdown.scss +493 -0
  78. package/scss/components/dropdown/_index.scss +11 -0
  79. package/scss/components/empty/_empty.scss +105 -0
  80. package/scss/components/empty/_index.scss +11 -0
  81. package/scss/components/file-uploader/_file-uploader.scss +321 -0
  82. package/scss/components/file-uploader/_index.scss +11 -0
  83. package/scss/components/footer/_footer.scss +258 -0
  84. package/scss/components/footer/_footer_external.scss +153 -0
  85. package/scss/components/footer/_index.scss +14 -0
  86. package/scss/components/form/_form.scss +146 -0
  87. package/scss/components/form/_index.scss +4 -0
  88. package/scss/components/form-controls/_form-controls.scss +53 -0
  89. package/scss/components/form-controls/_index.scss +11 -0
  90. package/scss/components/form-error/_form-error.scss +25 -0
  91. package/scss/components/form-error/_index.scss +11 -0
  92. package/scss/components/form-group/_form-group.scss +109 -0
  93. package/scss/components/form-group/_index.scss +11 -0
  94. package/scss/components/form-hint/_form-hint.scss +28 -0
  95. package/scss/components/form-hint/_index.scss +11 -0
  96. package/scss/components/form-wizard/_form-wizard.scss +48 -0
  97. package/scss/components/form-wizard/_index.scss +11 -0
  98. package/scss/components/grid/_grid.scss +80 -0
  99. package/scss/components/grid/_index.scss +4 -0
  100. package/scss/components/hero/_hero-external.scss +84 -0
  101. package/scss/components/hero/_hero.scss +321 -0
  102. package/scss/components/hero/_index.scss +14 -0
  103. package/scss/components/icon/_icon.scss +19 -0
  104. package/scss/components/icon/_index.scss +11 -0
  105. package/scss/components/info-bar/_index.scss +11 -0
  106. package/scss/components/info-bar/_info-bar.scss +21 -0
  107. package/scss/components/inline-loading/_index.scss +11 -0
  108. package/scss/components/inline-loading/_inline-loading.scss +159 -0
  109. package/scss/components/inline-loading/_keyframes.scss +12 -0
  110. package/scss/components/input/_index.scss +11 -0
  111. package/scss/components/input/_input.scss +87 -0
  112. package/scss/components/input/_vars.scss +31 -0
  113. package/scss/components/item/_index.scss +11 -0
  114. package/scss/components/item/_item.scss +227 -0
  115. package/scss/components/link/_index.scss +11 -0
  116. package/scss/components/link/_link.scss +109 -0
  117. package/scss/components/list/_index.scss +4 -0
  118. package/scss/components/list/_list.scss +144 -0
  119. package/scss/components/list-box/_index.scss +11 -0
  120. package/scss/components/list-box/_list-box.scss +813 -0
  121. package/scss/components/loading/_animation.scss +39 -0
  122. package/scss/components/loading/_functions.scss +10 -0
  123. package/scss/components/loading/_index.scss +11 -0
  124. package/scss/components/loading/_keyframes.scss +48 -0
  125. package/scss/components/loading/_loading.scss +72 -0
  126. package/scss/components/loading/_mixins.scss +42 -0
  127. package/scss/components/loading/_vars.scss +26 -0
  128. package/scss/components/main-navigation/_index.scss +14 -0
  129. package/scss/components/main-navigation/_main-navigation.scss +360 -0
  130. package/scss/components/main-navigation/_main-navigation_external.scss +527 -0
  131. package/scss/components/menu/_index.scss +11 -0
  132. package/scss/components/menu/_menu.scss +143 -0
  133. package/scss/components/modal/_index.scss +11 -0
  134. package/scss/components/modal/_mixins.scss +10 -0
  135. package/scss/components/modal/_modal.scss +224 -0
  136. package/scss/components/module/_index.scss +4 -0
  137. package/scss/components/module/_module.scss +199 -0
  138. package/scss/components/multiselect/_index.scss +11 -0
  139. package/scss/components/multiselect/_multiselect.scss +103 -0
  140. package/scss/components/notification/_index.scss +21 -0
  141. package/scss/components/notification/_inline-notification.scss +321 -0
  142. package/scss/components/notification/_mixins.scss +41 -0
  143. package/scss/components/notification/_notification.scss +480 -0
  144. package/scss/components/notification/_toast-notification.scss +249 -0
  145. package/scss/components/notification/_tokens.scss +126 -0
  146. package/scss/components/number-input/_index.scss +11 -0
  147. package/scss/components/number-input/_number-input.scss +195 -0
  148. package/scss/components/overflow-menu/_index.scss +11 -0
  149. package/scss/components/overflow-menu/_overflow-menu.scss +351 -0
  150. package/scss/components/pagination/_index.scss +11 -0
  151. package/scss/components/pagination/_pagination.scss +214 -0
  152. package/scss/components/pagination-nav/_index.scss +11 -0
  153. package/scss/components/pagination-nav/_mixins.scss +38 -0
  154. package/scss/components/pagination-nav/_pagination-nav.scss +171 -0
  155. package/scss/components/popover/_index.scss +11 -0
  156. package/scss/components/popover/_popover.scss +323 -0
  157. package/scss/components/progress-bar/_index.scss +11 -0
  158. package/scss/components/progress-bar/_progress-bar.scss +82 -0
  159. package/scss/components/progress-indicator/_index.scss +11 -0
  160. package/scss/components/progress-indicator/_progress-indicator.scss +328 -0
  161. package/scss/components/radio-button/_index.scss +4 -0
  162. package/scss/components/radio-button/_radio-button.scss +239 -0
  163. package/scss/components/react-dropzone/_index.scss +11 -0
  164. package/scss/components/react-dropzone/_react-dropzone.scss +58 -0
  165. package/scss/components/react-select/_index.scss +11 -0
  166. package/scss/components/react-select/_react-select.scss +90 -0
  167. package/scss/components/read-more/_index.scss +11 -0
  168. package/scss/components/read-more/_read-more.scss +102 -0
  169. package/scss/components/search/_index.scss +4 -0
  170. package/scss/components/search/_search.scss +436 -0
  171. package/scss/components/secondary-navigation/_index.scss +4 -0
  172. package/scss/components/secondary-navigation/_secondary-navigation.scss +61 -0
  173. package/scss/components/select/_index.scss +11 -0
  174. package/scss/components/select/_select.scss +224 -0
  175. package/scss/components/sidebar/_index.scss +11 -0
  176. package/scss/components/sidebar/_sidebar.scss +118 -0
  177. package/scss/components/skeleton-text/_index.scss +4 -0
  178. package/scss/components/skeleton-text/_skeleton-text.scss +22 -0
  179. package/scss/components/slider/_index.scss +4 -0
  180. package/scss/components/slider/_slider.scss +274 -0
  181. package/scss/components/step-navigation/_index.scss +4 -0
  182. package/scss/components/step-navigation/_step-navigation.scss +136 -0
  183. package/scss/components/step-navigation-item/_index.scss +4 -0
  184. package/scss/components/step-navigation-item/_step-navigation-item.scss +377 -0
  185. package/scss/components/story/_index.scss +11 -0
  186. package/scss/components/story/_story.scss +519 -0
  187. package/scss/components/structured-list/_index.scss +11 -0
  188. package/scss/components/structured-list/_mixins.scss +59 -0
  189. package/scss/components/structured-list/_structured-list.scss +235 -0
  190. package/scss/components/sub-navigation/_index.scss +4 -0
  191. package/scss/components/sub-navigation/_sub-navigation.scss +113 -0
  192. package/scss/components/table/_index.scss +11 -0
  193. package/scss/components/table/table.scss +88 -0
  194. package/scss/components/tabs/_index.scss +4 -0
  195. package/scss/components/tabs/_tabs.scss +185 -0
  196. package/scss/components/tabs/_vars.scss +23 -0
  197. package/scss/components/tag/_index.scss +12 -0
  198. package/scss/components/tag/_mixins.scss +19 -0
  199. package/scss/components/tag/_tag.scss +137 -0
  200. package/scss/components/tag/_tokens.scss +702 -0
  201. package/scss/components/text-area/_index.scss +11 -0
  202. package/scss/components/text-area/_text-area.scss +120 -0
  203. package/scss/components/text-input/_index.scss +11 -0
  204. package/scss/components/text-input/_text-input.scss +19 -0
  205. package/scss/components/tile/_index.scss +11 -0
  206. package/scss/components/tile/_tile.scss +269 -0
  207. package/scss/components/time-picker/_index.scss +11 -0
  208. package/scss/components/time-picker/_time-picker.scss +94 -0
  209. package/scss/components/toggle/_index.scss +11 -0
  210. package/scss/components/toggle/_toggle.scss +192 -0
  211. package/scss/components/tooltip/_index.scss +11 -0
  212. package/scss/components/tooltip/_mixins.scss +107 -0
  213. package/scss/components/tooltip/_tooltip.scss +128 -0
  214. package/scss/components/tooltip/_vars.scss +6 -0
  215. package/scss/components/tooltip/animations/fade.scss +10 -0
  216. package/scss/components/tooltip/themes/light-border.scss +158 -0
  217. package/scss/components/tooltip/themes/light.scss +28 -0
  218. package/scss/components/treeview/_index.scss +11 -0
  219. package/scss/components/treeview/_treeview.scss +177 -0
  220. package/scss/components/ui-shell/_functions.scss +19 -0
  221. package/scss/components/ui-shell/_index.scss +11 -0
  222. package/scss/components/ui-shell/_mixins.scss +56 -0
  223. package/scss/components/ui-shell/_ui-shell.scss +23 -0
  224. package/scss/components/ui-shell/content/_content.scss +34 -0
  225. package/scss/components/ui-shell/content/_index.scss +11 -0
  226. package/scss/components/ui-shell/header/_header.scss +382 -0
  227. package/scss/components/ui-shell/header/_index.scss +11 -0
  228. package/scss/components/ui-shell/header-panel/_header-panel.scss +41 -0
  229. package/scss/components/ui-shell/header-panel/_index.scss +11 -0
  230. package/scss/components/ui-shell/side-nav/_index.scss +11 -0
  231. package/scss/components/ui-shell/side-nav/_side-nav.scss +526 -0
  232. package/scss/components/ui-shell/switcher/_index.scss +11 -0
  233. package/scss/components/ui-shell/switcher/_switcher.scss +78 -0
  234. package/scss/components/unit/_index.scss +11 -0
  235. package/scss/components/unit/_unit.scss +277 -0
  236. package/scss/components/user/_index.scss +11 -0
  237. package/scss/components/user/_user.scss +104 -0
  238. package/scss/components/value/_index.scss +11 -0
  239. package/scss/components/value/_value.scss +41 -0
  240. package/scss/components/wrapper/_index.scss +11 -0
  241. package/scss/components/wrapper/_wrapper.scss +71 -0
  242. package/scss/utilities/_box-shadow.scss +14 -0
  243. package/scss/utilities/_button-reset.scss +31 -0
  244. package/scss/utilities/_component-reset.scss +25 -0
  245. package/scss/utilities/_component-tokens.scss +27 -0
  246. package/scss/utilities/_convert.scss +41 -0
  247. package/scss/utilities/_custom-property.scss +56 -0
  248. package/scss/utilities/_focus-outline.scss +68 -0
  249. package/scss/utilities/_high-contrast-mode.scss +37 -0
  250. package/scss/utilities/_index.scss +24 -0
  251. package/scss/utilities/_input-base.scss +63 -0
  252. package/scss/utilities/_keyframes.scss +76 -0
  253. package/scss/utilities/_layer-set.scss +31 -0
  254. package/scss/utilities/_layer.scss +52 -0
  255. package/scss/utilities/_placeholder-colors.scss +10 -0
  256. package/scss/utilities/_read-only.scss +19 -0
  257. package/scss/utilities/_rotate.scss +19 -0
  258. package/scss/utilities/_rtl.scss +21 -0
  259. package/scss/utilities/_skeleton.scss +44 -0
  260. package/scss/utilities/_text-gradient.scss +20 -0
  261. package/scss/utilities/_text-overflow.scss +23 -0
  262. package/scss/utilities/_text-truncate.scss +29 -0
  263. package/scss/utilities/_visually-hidden.scss +38 -0
  264. package/scss/utilities/_z-index.scss +38 -0
  265. package/styles.css +1 -0
@@ -0,0 +1,813 @@
1
+ @use "../button/tokens" as *;
2
+ @use "../text-input";
3
+ @use "../tag";
4
+ @use "../tag/mixins" as *;
5
+ @use "../../config" as *;
6
+ @use "../../theme" as *;
7
+ @use "../../type" as *;
8
+ @use "../../spacing" as *;
9
+ @use "../../motion" as *;
10
+ @use "../../utilities/box-shadow" as *;
11
+ @use "../../utilities/button-reset";
12
+ @use "../../utilities/convert" as *;
13
+ @use "../../utilities/focus-outline" as *;
14
+ @use "../../utilities/high-contrast-mode" as *;
15
+ @use "../../utilities/z-index" as *;
16
+
17
+ /// @type Number
18
+ /// @access public
19
+ /// @group list-box
20
+ $list-box-width: 100%;
21
+
22
+ /// @type Number
23
+ /// @access public
24
+ /// @group list-box
25
+ $list-box-height: calcRem(40px);
26
+
27
+ /// @type Number
28
+ /// @access public
29
+ /// @group list-box
30
+ $list-box-inline-height: $list-box-height;
31
+
32
+ /// @type Number
33
+ /// @access public
34
+ /// @group list-box
35
+ $list-box-menu-width: calcRem(300px);
36
+
37
+ /// List box styles
38
+ /// @access public
39
+ /// @group list-box
40
+ @mixin list-box {
41
+ // The overall container element for a `list-box`. Has two variants,
42
+ // `disabled` and `inline`.
43
+ .#{$prefix}--list-box__wrapper--inline {
44
+ display: inline-grid;
45
+ align-items: center;
46
+ grid-gap: calcRem(4px);
47
+ grid-template: auto auto / auto auto;
48
+
49
+ .#{$prefix}--label {
50
+ @include type-style("body-short");
51
+ }
52
+
53
+ .#{$prefix}--label,
54
+ .#{$prefix}--form__helper-text,
55
+ .#{$prefix}--form-requirement {
56
+ margin: 0;
57
+ }
58
+
59
+ .#{$prefix}--form__helper-text {
60
+ max-width: none;
61
+ }
62
+
63
+ .#{$prefix}--form-requirement {
64
+ grid-column: 2;
65
+ }
66
+ }
67
+
68
+ .#{$prefix}--list-box {
69
+ @include reset;
70
+
71
+ position: relative;
72
+ width: $list-box-width;
73
+ height: calcRem(40px);
74
+ max-height: calcRem(40px);
75
+ border: none;
76
+ border-bottom: 1px solid $border-strong;
77
+ background-color: $fill-field;
78
+ color: $text-body-default;
79
+ cursor: pointer;
80
+ transition: all $duration-fast-01 motion(standard, productive);
81
+
82
+ &:hover {
83
+ background-color: $field-hover;
84
+ }
85
+ }
86
+
87
+ // TODO V11: Remove xl selector
88
+ .#{$prefix}--list-box--xl,
89
+ .#{$prefix}--list-box--lg {
90
+ height: calcRem(48px);
91
+ max-height: calcRem(48px);
92
+ }
93
+
94
+ .#{$prefix}--list-box--sm {
95
+ height: calcRem(32px);
96
+ max-height: calcRem(32px);
97
+ }
98
+
99
+ .#{$prefix}--list-box--expanded {
100
+ border-bottom-color: $border-subtle;
101
+ }
102
+
103
+ .#{$prefix}--list-box--expanded:hover {
104
+ background-color: $fill-field;
105
+ }
106
+
107
+ // V11: Possibly deprecate
108
+ .#{$prefix}--list-box--expanded:hover.#{$prefix}--list-box--light:hover {
109
+ //TODO: background-color: $field-02;
110
+ }
111
+
112
+ .#{$prefix}--list-box .#{$prefix}--text-input {
113
+ min-width: 0;
114
+ height: 100%;
115
+ }
116
+
117
+ // invalid states
118
+ .#{$prefix}--list-box__invalid-icon {
119
+ position: absolute;
120
+ top: 50%;
121
+ right: $spacing-08;
122
+ fill: $support-error-main;
123
+ transform: translateY(-50%);
124
+ }
125
+
126
+ .#{$prefix}--list-box__invalid-icon--warning {
127
+ fill: $support-warning;
128
+ }
129
+
130
+ .#{$prefix}--list-box__invalid-icon--warning path[fill] {
131
+ fill: $black-100;
132
+ opacity: 1;
133
+ }
134
+
135
+ .#{$prefix}--list-box[data-invalid] .#{$prefix}--list-box__field,
136
+ .#{$prefix}--list-box.#{$prefix}--list-box--warning
137
+ .#{$prefix}--list-box__field {
138
+ padding-right: $spacing-10;
139
+ border-bottom: 0;
140
+ }
141
+
142
+ .#{$prefix}--list-box[data-invalid].#{$prefix}--list-box--inline
143
+ .#{$prefix}--list-box__field {
144
+ padding-right: calcRem(56px);
145
+ }
146
+
147
+ // V11: Possibly deprecate
148
+ // Light variation for 'list-box'
149
+ .#{$prefix}--list-box--light {
150
+ //TODO: background-color: $field-02;
151
+
152
+ &:hover {
153
+ background-color: $hover-light-ui;
154
+ }
155
+ }
156
+
157
+ // V11: Possibly deprecate
158
+ .#{$prefix}--list-box--light .#{$prefix}--list-box__menu {
159
+ background: $field-02;
160
+ }
161
+
162
+ // V11: Possibly deprecate
163
+ .#{$prefix}--list-box--light .#{$prefix}--list-box__menu-item__option {
164
+ border-top-color: $decorative-01;
165
+ }
166
+
167
+ .#{$prefix}--list-box--light.#{$prefix}--list-box--expanded {
168
+ border-bottom-color: transparent;
169
+ }
170
+
171
+ // Disabled state for `list-box`
172
+ .#{$prefix}--list-box--disabled:hover {
173
+ background-color: $fill-field;
174
+ }
175
+
176
+ // V11: Possibly deprecate
177
+ .#{$prefix}--list-box--light.#{$prefix}--list-box--disabled {
178
+ //TODO: background-color: $field-02;
179
+ }
180
+
181
+ .#{$prefix}--list-box--disabled,
182
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__field,
183
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__field:focus {
184
+ border-bottom-color: transparent;
185
+ outline: none;
186
+ }
187
+
188
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__label,
189
+ .#{$prefix}--list-box--disabled.#{$prefix}--list-box--inline
190
+ .#{$prefix}--list-box__label {
191
+ color: $text-disabled;
192
+ }
193
+
194
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__menu-icon > svg,
195
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__selection > svg {
196
+ fill: $icon-disabled;
197
+ }
198
+
199
+ .#{$prefix}--list-box--disabled,
200
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__field,
201
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__menu-icon {
202
+ cursor: not-allowed;
203
+ }
204
+
205
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__menu-item,
206
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__menu-item:hover,
207
+ .#{$prefix}--list-box--disabled
208
+ .#{$prefix}--list-box__menu-item--highlighted {
209
+ color: $text-disabled;
210
+ text-decoration: none;
211
+ }
212
+
213
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__selection:hover {
214
+ cursor: not-allowed;
215
+ }
216
+
217
+ // disabled && invalid
218
+ .#{$prefix}--list-box--disabled.#{$prefix}--list-box[data-invalid]
219
+ .#{$prefix}--list-box__field {
220
+ padding-right: $spacing-09;
221
+ }
222
+
223
+ .#{$prefix}--list-box--disabled.#{$prefix}--list-box[data-invalid].#{$prefix}--list-box--inline
224
+ .#{$prefix}--list-box__field {
225
+ padding-right: $spacing-07;
226
+ }
227
+
228
+ // Inline variant for a `list-box`
229
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline {
230
+ border-width: 0;
231
+ background-color: transparent;
232
+
233
+ &:hover {
234
+ background-color: $field-hover;
235
+ }
236
+ }
237
+
238
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline.#{$prefix}--list-box--expanded {
239
+ border-bottom-width: 0;
240
+ }
241
+
242
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline.#{$prefix}--list-box--expanded
243
+ .#{$prefix}--list-box__field[aria-expanded="true"] {
244
+ border-width: 0;
245
+ }
246
+
247
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline.#{$prefix}--list-box--expanded:hover,
248
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline.#{$prefix}--list-box--disabled:hover {
249
+ background-color: transparent;
250
+ }
251
+
252
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline
253
+ .#{$prefix}--list-box__field {
254
+ padding: 0 $spacing-07 0 $spacing-03;
255
+ }
256
+
257
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline
258
+ .#{$prefix}--list-box__menu-icon {
259
+ right: $spacing-03;
260
+ }
261
+
262
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline
263
+ .#{$prefix}--list-box__invalid-icon {
264
+ right: $spacing-07;
265
+ }
266
+
267
+ .#{$prefix}--list-box--inline .#{$prefix}--list-box__label {
268
+ color: $text-body-default;
269
+ }
270
+
271
+ .#{$prefix}--list-box--inline .#{$prefix}--list-box__field {
272
+ height: 100%;
273
+ }
274
+
275
+ .#{$prefix}--dropdown--inline .#{$prefix}--list-box__field {
276
+ max-width: calcRem(480px);
277
+ }
278
+
279
+ .#{$prefix}--dropdown--inline .#{$prefix}--list-box__menu {
280
+ min-width: calcRem(288px);
281
+ max-width: calcRem(480px);
282
+ }
283
+
284
+ // The field we use for input, showing selection, etc.
285
+ .#{$prefix}--list-box__field {
286
+ @include button-reset.reset;
287
+
288
+ position: relative;
289
+ display: inline-flex;
290
+ overflow: hidden;
291
+ // Account for the border in `.bx--list-box`
292
+ height: calc(100% + 1px);
293
+ align-items: center;
294
+ padding: 0 $spacing-09 0 $spacing-05;
295
+ cursor: pointer;
296
+ outline: none;
297
+ text-overflow: ellipsis;
298
+ vertical-align: top;
299
+ white-space: nowrap;
300
+ }
301
+
302
+ .#{$prefix}--list-box__field:focus {
303
+ @include focus-outline("outline");
304
+ }
305
+
306
+ .#{$prefix}--list-box__field[disabled] {
307
+ color: $text-disabled;
308
+ outline: none;
309
+ }
310
+
311
+ // populated input field
312
+ .#{$prefix}--list-box__field .#{$prefix}--text-input {
313
+ padding-right: calcRem(72px);
314
+ }
315
+
316
+ // invalid && populated input field
317
+ .#{$prefix}--list-box[data-invalid]
318
+ .#{$prefix}--list-box__field
319
+ .#{$prefix}--text-input,
320
+ .#{$prefix}--list-box--warning
321
+ .#{$prefix}--list-box__field
322
+ .#{$prefix}--text-input {
323
+ // to account for clear input button outline
324
+ padding-right: calcRem(98px);
325
+ }
326
+
327
+ .#{$prefix}--list-box[data-invalid]
328
+ .#{$prefix}--list-box__field
329
+ .#{$prefix}--text-input
330
+ + .#{$prefix}--list-box__invalid-icon,
331
+ .#{$prefix}--list-box--warning
332
+ .#{$prefix}--list-box__field
333
+ .#{$prefix}--text-input
334
+ + .#{$prefix}--list-box__invalid-icon {
335
+ // to account for clear input button outline
336
+ right: calcRem(66px);
337
+ }
338
+
339
+ // empty input field
340
+ .#{$prefix}--list-box__field .#{$prefix}--text-input--empty {
341
+ padding-right: $spacing-09;
342
+ }
343
+
344
+ // invalid && empty input field
345
+ .#{$prefix}--list-box[data-invalid]
346
+ .#{$prefix}--list-box__field
347
+ .#{$prefix}--text-input--empty,
348
+ .#{$prefix}--list-box--warning
349
+ .#{$prefix}--list-box__field
350
+ .#{$prefix}--text-input--empty {
351
+ padding-right: carbon--mini-units(9);
352
+ }
353
+
354
+ .#{$prefix}--list-box[data-invalid]
355
+ .#{$prefix}--list-box__field
356
+ .#{$prefix}--text-input--empty
357
+ + .#{$prefix}--list-box__invalid-icon,
358
+ .#{$prefix}--list-box--warning
359
+ .#{$prefix}--list-box__field
360
+ .#{$prefix}--text-input--empty
361
+ + .#{$prefix}--list-box__invalid-icon {
362
+ // to account for clear input button outline
363
+ right: calcRem(40px);
364
+ }
365
+
366
+ // Label for a `list-box__field`
367
+ .#{$prefix}--list-box__label {
368
+ @include type-style("body-short");
369
+
370
+ overflow: hidden;
371
+ color: $text-body-default;
372
+ text-overflow: ellipsis;
373
+ user-select: none;
374
+ white-space: nowrap;
375
+ }
376
+
377
+ // Menu status inside of a `list-box__field`
378
+ .#{$prefix}--list-box__menu-icon {
379
+ @include button-reset.reset($width: false);
380
+
381
+ position: absolute;
382
+ right: $spacing-05;
383
+ display: flex;
384
+ width: calcRem(24px);
385
+ height: calcRem(24px);
386
+ align-items: center;
387
+ justify-content: center;
388
+ cursor: pointer;
389
+ outline: none;
390
+ transition: transform $duration-fast-01 motion(standard, productive);
391
+ }
392
+
393
+ .#{$prefix}--list-box__menu-icon > svg {
394
+ fill: $icon-primary;
395
+ }
396
+
397
+ .#{$prefix}--list-box__menu-icon--open {
398
+ width: calcRem(24px);
399
+ justify-content: center;
400
+ transform: rotate(180deg);
401
+ }
402
+
403
+ // Selection indicator for a `list-box__field`
404
+ .#{$prefix}--list-box__selection {
405
+ @include button-reset.reset($width: false);
406
+
407
+ position: absolute;
408
+ top: 50%;
409
+ /* to preserve .5rem space between icons according to spec top/transform used to center the combobox clear selection icon in IE11 */
410
+ right: calcRem(36px);
411
+ display: flex;
412
+ width: calcRem(24px);
413
+ height: calcRem(24px);
414
+ align-items: center;
415
+ justify-content: center;
416
+ cursor: pointer;
417
+ transform: translateY(-50%);
418
+ transition: background-color $duration-fast-01 motion(standard, productive);
419
+ user-select: none;
420
+
421
+ &:focus {
422
+ @include focus-outline("outline");
423
+
424
+ &:hover {
425
+ @include focus-outline("outline");
426
+ }
427
+ }
428
+ }
429
+
430
+ .#{$prefix}--list-box__selection > svg {
431
+ fill: $icon-primary;
432
+ }
433
+
434
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__selection:focus {
435
+ outline: none;
436
+ }
437
+
438
+ // Modifier for a selection to show that multiple selections have been made
439
+ .#{$prefix}--list-box__selection--multi {
440
+ @include type-style("label");
441
+
442
+ position: static;
443
+ top: auto;
444
+ display: flex;
445
+ width: auto;
446
+ height: calcRem(24px);
447
+ align-items: center;
448
+ justify-content: space-between;
449
+ padding: calcRem(8px);
450
+ // Align with hover circle of X button
451
+ padding-right: calcRem(2px);
452
+ margin-right: calcRem(10px);
453
+ background-color: $background-inverse;
454
+ border-radius: calcRem(12px);
455
+ color: $text-inverse-default;
456
+ line-height: 0;
457
+ transform: none;
458
+ }
459
+
460
+ .#{$prefix}--list-box__selection--multi > svg {
461
+ width: calcRem(20px);
462
+ height: calcRem(20px);
463
+ padding: calcRem(2px);
464
+ margin-left: calcRem(4px);
465
+ fill: $icon-inverse;
466
+
467
+ &:hover {
468
+ background-color: $button-secondary-hover;
469
+ border-radius: 50%;
470
+ }
471
+ }
472
+
473
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__selection--multi {
474
+ @include tag-theme($text-disabled, $field-disabled);
475
+
476
+ > svg {
477
+ fill: $icon-disabled;
478
+
479
+ &:hover {
480
+ background-color: initial;
481
+ }
482
+ }
483
+ }
484
+
485
+ .#{$prefix}--list-box__selection--multi:hover {
486
+ outline: none;
487
+ }
488
+
489
+ // Descendant of a `list-box` that displays a list of options to select
490
+ .#{$prefix}--list-box__menu {
491
+ @include box-shadow();
492
+
493
+ position: absolute;
494
+ z-index: z("dropdown");
495
+ right: 0;
496
+ left: 0;
497
+ width: $list-box-width;
498
+ background-color: $layer-primary;
499
+ overflow-y: auto;
500
+ transition: max-height $duration-fast-02 motion(standard, productive);
501
+
502
+ &:focus {
503
+ // remove default browser focus in firefox
504
+ @include focus-outline("border");
505
+ }
506
+ }
507
+
508
+ .#{$prefix}--list-box
509
+ .#{$prefix}--list-box__field[aria-expanded="false"]
510
+ + .#{$prefix}--list-box__menu {
511
+ max-height: 0;
512
+ }
513
+
514
+ .#{$prefix}--list-box--expanded .#{$prefix}--list-box__menu {
515
+ // 40px item height * 5.5 items shown
516
+ max-height: calcRem(220px);
517
+ }
518
+
519
+ // TODO V11: Remove xl selector
520
+ .#{$prefix}--list-box--expanded.#{$prefix}--list-box--xl
521
+ .#{$prefix}--list-box__menu,
522
+ .#{$prefix}--list-box--expanded.#{$prefix}--list-box--lg
523
+ .#{$prefix}--list-box__menu {
524
+ // 48px item height * 5.5 items shown
525
+ max-height: calcRem(264px);
526
+ }
527
+
528
+ .#{$prefix}--list-box--expanded.#{$prefix}--list-box--sm
529
+ .#{$prefix}--list-box__menu {
530
+ // 32px item height * 5.5 items shown
531
+ max-height: calcRem(176px);
532
+ }
533
+
534
+ // Descendant of a `list-box__menu` that represents a selection for a control
535
+ .#{$prefix}--list-box__menu-item {
536
+ @include type-style("body-short");
537
+
538
+ position: relative;
539
+ height: calcRem(40px);
540
+ color: $text-body-secondary;
541
+ cursor: pointer;
542
+ transition: background $duration-fast-01 motion(standard, productive);
543
+ user-select: none;
544
+
545
+ &:hover {
546
+ background-color: $layer-hover;
547
+ }
548
+
549
+ &:active {
550
+ background-color: $layer-selected;
551
+ }
552
+ }
553
+
554
+ // V11: Possibly deprecate
555
+ .#{$prefix}--list-box--light .#{$prefix}--list-box__menu-item:hover {
556
+ background-color: $hover-light-ui;
557
+ }
558
+
559
+ .#{$prefix}--list-box--sm .#{$prefix}--list-box__menu-item {
560
+ height: calcRem(32px);
561
+ }
562
+
563
+ // TODO V11: Remove xl selector
564
+ .#{$prefix}--list-box--xl .#{$prefix}--list-box__menu-item,
565
+ .#{$prefix}--list-box--lg .#{$prefix}--list-box__menu-item {
566
+ height: calcRem(48px);
567
+ }
568
+
569
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__menu-item:hover {
570
+ background-color: transparent;
571
+ }
572
+
573
+ // V11: Possibly deprecate
574
+ .#{$prefix}--list-box--light .#{$prefix}--list-box__menu-item:active {
575
+ // To Do: What should this variable be?
576
+ // background-color: $selected-light-ui;
577
+ }
578
+
579
+ .#{$prefix}--list-box--disabled
580
+ .#{$prefix}--list-box__menu-item__option:hover {
581
+ border-top-color: $border-subtle;
582
+ }
583
+
584
+ .#{$prefix}--list-box__menu-item:first-of-type
585
+ .#{$prefix}--list-box__menu-item__option {
586
+ border-top-color: transparent;
587
+ }
588
+
589
+ .#{$prefix}--list-box__menu-item:hover
590
+ .#{$prefix}--list-box__menu-item__option {
591
+ color: $text-body-default;
592
+ }
593
+
594
+ .#{$prefix}--list-box__menu-item:hover
595
+ + .#{$prefix}--list-box__menu-item
596
+ .#{$prefix}--list-box__menu-item__option {
597
+ border-top-color: transparent;
598
+ }
599
+
600
+ .#{$prefix}--list-box--disabled
601
+ .#{$prefix}--list-box__menu-item:hover
602
+ + .#{$prefix}--list-box__menu-item
603
+ .#{$prefix}--list-box__menu-item__option {
604
+ border-top-color: $border-subtle;
605
+ }
606
+
607
+ .#{$prefix}--list-box__menu-item__option {
608
+ @include focus-outline("reset");
609
+
610
+ display: block;
611
+ overflow: hidden;
612
+ height: calcRem(40px);
613
+ padding: calcRem(11px) 0;
614
+ padding-right: $spacing-06;
615
+ border-top: 1px solid transparent;
616
+ border-top-color: $border-subtle;
617
+ border-bottom: 1px solid transparent;
618
+ margin: 0 $spacing-05;
619
+ color: $text-body-secondary;
620
+ font-weight: normal;
621
+ line-height: 1rem;
622
+ text-decoration: none;
623
+ text-overflow: ellipsis;
624
+ transition: border-color $duration-fast-01 motion(standard, productive),
625
+ color $duration-fast-01 motion(standard, productive);
626
+ white-space: nowrap;
627
+
628
+ &:focus {
629
+ @include focus-outline("outline");
630
+
631
+ padding: calcRem(11px) calcRem(16px);
632
+ border-color: transparent;
633
+ margin: 0;
634
+ }
635
+
636
+ &:hover {
637
+ border-color: transparent;
638
+ color: $text-body-default;
639
+ }
640
+ }
641
+
642
+ .#{$prefix}--list-box--sm .#{$prefix}--list-box__menu-item__option {
643
+ height: calcRem(32px);
644
+ padding-top: calcRem(7px);
645
+ padding-bottom: calcRem(7px);
646
+ }
647
+
648
+ // TODO V11: Remove xl selector
649
+ .#{$prefix}--list-box--xl .#{$prefix}--list-box__menu-item__option,
650
+ .#{$prefix}--list-box--lg .#{$prefix}--list-box__menu-item__option {
651
+ height: calcRem(48px);
652
+ padding-top: calcRem(15px);
653
+ padding-bottom: calcRem(15px);
654
+ }
655
+
656
+ .#{$prefix}--list-box--disabled
657
+ .#{$prefix}--list-box__menu-item:hover
658
+ .#{$prefix}--list-box__menu-item__option,
659
+ .#{$prefix}--list-box--disabled .#{$prefix}--list-box__menu-item__option {
660
+ color: $text-disabled;
661
+ }
662
+
663
+ .#{$prefix}--list-box.#{$prefix}--list-box--inline
664
+ .#{$prefix}--list-box__menu-item__option {
665
+ margin: 0 $spacing-03;
666
+
667
+ &:focus {
668
+ padding-right: $spacing-03;
669
+ padding-left: $spacing-03;
670
+ margin: 0;
671
+ }
672
+ }
673
+
674
+ .#{$prefix}--list-box__menu-item--highlighted {
675
+ border-color: transparent;
676
+ background-color: $layer-hover;
677
+ color: $text-body-default;
678
+ }
679
+
680
+ .#{$prefix}--list-box__menu-item--highlighted
681
+ .#{$prefix}--list-box__menu-item__option,
682
+ .#{$prefix}--list-box__menu-item--highlighted
683
+ + .#{$prefix}--list-box__menu-item
684
+ .#{$prefix}--list-box__menu-item__option {
685
+ border-top-color: transparent;
686
+ }
687
+
688
+ .#{$prefix}--list-box__menu-item--highlighted
689
+ .#{$prefix}--list-box__menu-item__option {
690
+ color: $text-body-default;
691
+ }
692
+
693
+ .#{$prefix}--list-box__menu-item--active {
694
+ border-bottom-color: $layer-selected;
695
+ background-color: $layer-selected;
696
+ color: $text-body-default;
697
+ }
698
+
699
+ // V11: Possibly deprecate
700
+ .#{$prefix}--list-box--light .#{$prefix}--list-box__menu-item--active {
701
+ // To Do: What should this token be?
702
+ // border-bottom-color: $selected-light-ui;
703
+ // background-color: $selected-light-ui;
704
+ }
705
+
706
+ .#{$prefix}--list-box__menu-item--active:hover,
707
+ .#{$prefix}--list-box__menu-item--active.#{$prefix}--list-box__menu-item--highlighted {
708
+ border-bottom-color: $layer-selected;
709
+ background-color: $layer-selected;
710
+ }
711
+
712
+ .#{$prefix}--list-box__menu-item--active
713
+ .#{$prefix}--list-box__menu-item__option {
714
+ color: $text-body-default;
715
+ }
716
+
717
+ // Hide top border if previous list item is selected
718
+ .#{$prefix}--list-box__menu-item--active
719
+ + .#{$prefix}--list-box__menu-item
720
+ > .#{$prefix}--list-box__menu-item__option {
721
+ border-top-color: transparent;
722
+ }
723
+
724
+ .#{$prefix}--list-box__menu-item__selected-icon {
725
+ position: absolute;
726
+ top: 50%;
727
+ right: calcRem(16px);
728
+ display: none;
729
+ fill: $icon-primary;
730
+ transform: translateY(-50%);
731
+ }
732
+
733
+ .#{$prefix}--list-box--inline
734
+ .#{$prefix}--list-box__menu-item__selected-icon {
735
+ right: calcRem(8px);
736
+ }
737
+
738
+ .#{$prefix}--list-box__menu-item--active
739
+ .#{$prefix}--list-box__menu-item__selected-icon {
740
+ display: block;
741
+ }
742
+
743
+ .#{$prefix}--list-box__menu-item .#{$prefix}--checkbox-label {
744
+ width: 100%;
745
+ }
746
+
747
+ .#{$prefix}--list-box__menu-item .#{$prefix}--checkbox-label-text {
748
+ overflow: hidden;
749
+ text-overflow: ellipsis;
750
+ white-space: nowrap;
751
+ }
752
+
753
+ // Dropdown top orientation modifiers
754
+ .#{$prefix}--list-box--up .#{$prefix}--list-box__menu {
755
+ bottom: 2.5rem;
756
+ }
757
+
758
+ .#{$prefix}--list-box--up.#{$prefix}--dropdown--sm
759
+ .#{$prefix}--list-box__menu,
760
+ .#{$prefix}--list-box--up.#{$prefix}--list-box--sm
761
+ .#{$prefix}--list-box__menu,
762
+ .#{$prefix}--list-box--up
763
+ .#{$prefix}--list-box--sm
764
+ .#{$prefix}--list-box__menu {
765
+ bottom: 2rem;
766
+ }
767
+
768
+ // TODO V11: Remove xl selector
769
+ .#{$prefix}--list-box--up.#{$prefix}--dropdown--xl
770
+ .#{$prefix}--list-box__menu,
771
+ .#{$prefix}--list-box--up.#{$prefix}--list-box--xl
772
+ .#{$prefix}--list-box__menu,
773
+ .#{$prefix}--list-box--up.#{$prefix}--dropdown--lg
774
+ .#{$prefix}--list-box__menu,
775
+ .#{$prefix}--list-box--up.#{$prefix}--list-box--lg
776
+ .#{$prefix}--list-box__menu,
777
+ .#{$prefix}--list-box--up
778
+ .#{$prefix}--list-box--lg
779
+ .#{$prefix}--list-box__menu {
780
+ bottom: 3rem;
781
+ }
782
+
783
+ // Tweaks for descendants
784
+ // When handling input, we need to target nodes that specifically opt-in to
785
+ // the type text in order to make sure the text input is styled
786
+ // correctly.
787
+ // TODO: remove [role='combobox'] in v11
788
+ .#{$prefix}--list-box input[role="combobox"],
789
+ .#{$prefix}--list-box input[type="text"] {
790
+ min-width: 0;
791
+ background-color: inherit;
792
+ }
793
+
794
+ // Windows HCM fix
795
+ .#{$prefix}--list-box__field,
796
+ .#{$prefix}--list-box__menu,
797
+ .#{$prefix}--multi-select .#{$prefix}--tag--filter {
798
+ @include high-contrast-mode("outline");
799
+ }
800
+
801
+ .#{$prefix}--list-box__field:focus,
802
+ .#{$prefix}--multi-select .#{$prefix}--tag__close-icon:focus,
803
+ .#{$prefix}--list-box__menu-item--highlighted
804
+ .#{$prefix}--list-box__menu-item__option {
805
+ @include high-contrast-mode("focus");
806
+ }
807
+
808
+ .#{$prefix}--list-box__menu-icon > svg,
809
+ .#{$prefix}--list-box__selection > svg,
810
+ .#{$prefix}--list-box__selection--multi > svg {
811
+ @include high-contrast-mode("icon-fill");
812
+ }
813
+ }