@wwtdev/bsds-css 2.28.0 → 3.0.0-rc.21

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 (94) hide show
  1. package/README.md +4 -4
  2. package/dist/wwt-bsds-preset.js +196 -68
  3. package/dist/wwt-bsds.css +2189 -1471
  4. package/dist/wwt-bsds.min.css +1 -1
  5. package/package.json +7 -11
  6. package/dist/components/_accordions.scss +0 -122
  7. package/dist/components/_alert.scss +0 -143
  8. package/dist/components/_badge.scss +0 -95
  9. package/dist/components/_banner.scss +0 -68
  10. package/dist/components/_buttons.scss +0 -289
  11. package/dist/components/_chart.scss +0 -169
  12. package/dist/components/_circle-buttons.scss +0 -231
  13. package/dist/components/_dropdown-options.scss +0 -236
  14. package/dist/components/_dropdown.scss +0 -189
  15. package/dist/components/_empty-state.scss +0 -99
  16. package/dist/components/_filter-buttons.scss +0 -116
  17. package/dist/components/_flyout.scss +0 -75
  18. package/dist/components/_form-booleans.scss +0 -182
  19. package/dist/components/_form-character-count.scss +0 -21
  20. package/dist/components/_form-container.scss +0 -111
  21. package/dist/components/_form-elements.scss +0 -40
  22. package/dist/components/_form-field-details.scss +0 -19
  23. package/dist/components/_form-hints.scss +0 -22
  24. package/dist/components/_form-input-composite.scss +0 -312
  25. package/dist/components/_form-input-phone.scss +0 -21
  26. package/dist/components/_form-input-search.scss +0 -74
  27. package/dist/components/_form-labels.scss +0 -40
  28. package/dist/components/_form-switches.scss +0 -154
  29. package/dist/components/_form-text-fields.scss +0 -205
  30. package/dist/components/_horizontal-navigation-mobile.scss +0 -238
  31. package/dist/components/_horizontal-navigation.scss +0 -220
  32. package/dist/components/_inline-tabs.scss +0 -86
  33. package/dist/components/_loader.scss +0 -105
  34. package/dist/components/_modal.scss +0 -185
  35. package/dist/components/_overlay.scss +0 -34
  36. package/dist/components/_pagination.scss +0 -85
  37. package/dist/components/_pills.scss +0 -224
  38. package/dist/components/_profile-details.scss +0 -44
  39. package/dist/components/_profile-img.scss +0 -73
  40. package/dist/components/_profile-layout.scss +0 -29
  41. package/dist/components/_spinner.scss +0 -95
  42. package/dist/components/_tab-list.scss +0 -151
  43. package/dist/components/_table.scss +0 -331
  44. package/dist/components/_tables.scss +0 -84
  45. package/dist/components/_timeline.scss +0 -122
  46. package/dist/components/_toast.scss +0 -149
  47. package/dist/components/_toaster.scss +0 -27
  48. package/dist/components/_tooltip.scss +0 -179
  49. package/dist/components/_vertical-navigation.scss +0 -280
  50. package/dist/components/accordions.css +0 -118
  51. package/dist/components/alert.css +0 -139
  52. package/dist/components/badge.css +0 -91
  53. package/dist/components/banner.css +0 -64
  54. package/dist/components/buttons.css +0 -285
  55. package/dist/components/chart.css +0 -165
  56. package/dist/components/circle-buttons.css +0 -227
  57. package/dist/components/dropdown-options.css +0 -232
  58. package/dist/components/dropdown.css +0 -185
  59. package/dist/components/empty-state.css +0 -95
  60. package/dist/components/filter-buttons.css +0 -112
  61. package/dist/components/flyout.css +0 -71
  62. package/dist/components/form-booleans.css +0 -178
  63. package/dist/components/form-character-count.css +0 -17
  64. package/dist/components/form-container.css +0 -108
  65. package/dist/components/form-elements.css +0 -36
  66. package/dist/components/form-field-details.css +0 -15
  67. package/dist/components/form-hints.css +0 -18
  68. package/dist/components/form-input-composite.css +0 -308
  69. package/dist/components/form-input-phone.css +0 -17
  70. package/dist/components/form-input-search.css +0 -70
  71. package/dist/components/form-labels.css +0 -36
  72. package/dist/components/form-switches.css +0 -150
  73. package/dist/components/form-text-fields.css +0 -201
  74. package/dist/components/horizontal-navigation-mobile.css +0 -234
  75. package/dist/components/horizontal-navigation.css +0 -216
  76. package/dist/components/inline-tabs.css +0 -83
  77. package/dist/components/loader.css +0 -101
  78. package/dist/components/modal.css +0 -181
  79. package/dist/components/overlay.css +0 -30
  80. package/dist/components/pagination.css +0 -81
  81. package/dist/components/pills.css +0 -220
  82. package/dist/components/profile-details.css +0 -40
  83. package/dist/components/profile-img.css +0 -69
  84. package/dist/components/profile-layout.css +0 -25
  85. package/dist/components/spinner.css +0 -91
  86. package/dist/components/tab-list.css +0 -147
  87. package/dist/components/table.css +0 -327
  88. package/dist/components/tables.css +0 -80
  89. package/dist/components/timeline.css +0 -118
  90. package/dist/components/toast.css +0 -145
  91. package/dist/components/toaster.css +0 -23
  92. package/dist/components/tooltip.css +0 -175
  93. package/dist/components/vertical-navigation.css +0 -276
  94. package/dist/wwt-bsds-wc-base.css +0 -1129
@@ -1,227 +0,0 @@
1
- /*
2
- Properties : Defaults // Description
3
- ====================================
4
- --btn-icon-bg-color: var(--btn-main); // icon bg color (base state)
5
- --btn-icon-padding: .75rem; // padding around icon svg
6
- --btn-icon-size: 1.5rem; // svg width and height
7
- --btn-icon-stroke-color: var(--bs-white);
8
- --btn-main: var(--bs-blue-base); // many things... should probably break this up
9
- --btn-text-color: var(--bs-ink-base);
10
- --btn-text-size: var(--bs-text-md);
11
-
12
- --btn-border-color: transparent; // focus state outline color - transparent base state, --btn-main base focus state
13
- --btn-border-color-focused: var(--btn-main); // focus state ring color set on variants
14
- --btn-secondary: var(--bs-blue-medium); // hover state icon bg
15
- --btn-shadow-color-active: var(--btn-main); // active state shadow color (icon bg)
16
- --btn-text-color-hovered: var(--bs-ink-base); // hover state text color
17
- */
18
-
19
- :where(.bs-circle-button) {
20
- --btn-border-color-focused: var(--btn-main);
21
- --btn-border-color: transparent;
22
- --btn-focus-inset: -0.25rem;
23
- --btn-gap: .5rem;
24
- --btn-icon-bg-color: var(--btn-main);
25
- --btn-icon-padding: .75rem;
26
- --btn-icon-size: 1.5rem;
27
- --btn-icon-stroke-color: var(--bs-white);
28
- --btn-main: var(--bs-blue-base);
29
- --btn-secondary: var(--bs-blue-medium);
30
- --btn-shadow-color-active: var(--btn-main);
31
- --btn-text-color-hovered: var(--bs-ink-base);
32
- --btn-text-color: var(--bs-ink-base);
33
- --btn-text-size: 1.125rem;
34
- --btn-text-weight: 400;
35
- }
36
-
37
- .bs-circle-button {
38
- align-items: center;
39
- background-color: transparent;
40
- color: var(--btn-text-color);
41
- cursor: pointer;
42
- display: inline-flex;
43
- font-size: var(--btn-text-size);
44
- font-weight: var(--btn-text-weight);
45
- gap: var(--btn-gap);
46
- outline: none;
47
- position: relative;
48
- vertical-align: middle;
49
- }
50
-
51
- a.bs-circle-button {
52
- align-items: center;
53
- display: inline-flex;
54
- outline: none;
55
- text-decoration: none;
56
- }
57
-
58
- .bs-circle-button :where(.bs-circle-button-icon) {
59
- align-items: center;
60
- background-color: var(--btn-icon-bg-color);
61
- border: none;
62
- border-radius: 50%;
63
- color: var(--btn-icon-stroke-color);
64
- display: inline-flex;
65
- justify-content: center;
66
- outline: 2px solid transparent;
67
- padding: var(--btn-icon-padding);
68
- position: relative;
69
- transition: all 100ms ease-in-out;
70
- }
71
-
72
- .bs-circle-button :where(.bs-circle-button-icon)::before {
73
- border-color: var(--btn-border-color);
74
- border-radius: 50%;
75
- border-style: solid;
76
- border-width: 0.125rem;
77
- content: '';
78
- inset: var(--btn-focus-inset);
79
- position: absolute;
80
- transition: border-color 125ms ease-in-out, transform 100ms ease-in-out;
81
- }
82
-
83
- .bs-circle-button :where(.bs-circle-button-icon) :where(.bs-icon) {
84
- --icon-size: var(--btn-icon-size);
85
- }
86
-
87
- /* non-bs-icon svgs */
88
- .bs-circle-button :where(.bs-circle-button-icon) > :where(svg) {
89
- height: var(--btn-icon-size);
90
- width: var(--btn-icon-size);
91
- }
92
-
93
- /* Icon Buttons with Text */
94
- .bs-circle-button:where([data-text]:not([data-text="false"])) {
95
- --btn-text-size: var(--bs-text-md);
96
- --btn-icon-size: 0.75rem;
97
- --btn-icon-padding: 0.375rem;
98
- }
99
-
100
- /* Ghost Buttons */
101
- .bs-circle-button:where([data-ghost]:not([data-ghost="false"])) {
102
- --btn-icon-bg-color: transparent;
103
- --btn-icon-stroke-color: var(--btn-main);
104
- --btn-light: var(--bs-blue-10);
105
- --btn-secondary: var(--bs-blue-10);
106
- }
107
-
108
- /* Active, Hover, Focus states */
109
- .bs-circle-button:active, .bs-circle-button:hover {
110
- --btn-icon-bg-color: var(--btn-secondary);
111
- --btn-text-color: var(--btn-text-color-hovered);
112
- }
113
- .bs-circle-button:active :where(.bs-circle-button-icon) {
114
- box-shadow: inset 0px 0px 4px 1px var(--btn-shadow-color-active);
115
- transform-origin: center;
116
- transform: scale(0.97);
117
- }
118
-
119
- .bs-circle-button:where([data-direction="right"]):hover :where(.bs-circle-button-icon),
120
- .bs-circle-button:where([data-direction="right"]):hover::before {
121
- transform: translateX(.25rem);
122
- }
123
- .bs-circle-button:where([data-direction="left"]):hover :where(.bs-circle-button-icon),
124
- .bs-circle-button:where([data-direction="left"]):hover::before {
125
- transform: translateX(-.25rem);
126
- }
127
-
128
- .bs-circle-button:where([data-ghost]:not([data-ghost="false"])):hover {
129
- --btn-icon-bg-color: var(--btn-light);
130
- }
131
-
132
- .bs-circle-button:where(:focus-visible) {
133
- --btn-border-color: var(--btn-border-color-focused);
134
- }
135
-
136
- /* Disabled State */
137
- .bs-circle-button:where(:disabled, [aria-disabled]:not([aria-disabled="false"])) /* for links as buttons */ {
138
- --btn-icon-stroke-color: var(--bs-ink-disabled);
139
- --btn-text-color: var(--bs-ink-disabled);
140
- pointer-events: none;
141
- }
142
- .bs-circle-button:where(:disabled, [aria-disabled]:not([aria-disabled="false"])) {
143
- --btn-icon-bg-color: var(--bs-bg-disabled);
144
- }
145
-
146
- /* Button Size */
147
- .bs-circle-button:where([data-size^='sm']) {
148
- --btn-icon-padding: .375rem;
149
- --btn-icon-size: .75rem;
150
- --btn-text-size: .875rem;
151
- }
152
-
153
- .bs-circle-button:where([data-size^='sm'][data-text]:not([data-text="false"])) {
154
- --btn-icon-padding: .3125rem;
155
- --btn-icon-size: .625rem;
156
- --btn-text-size: 1rem;
157
- }
158
-
159
- .bs-circle-button:where([data-size='xs'][data-text]:not([data-text="false"])) {
160
- --btn-icon-padding: .25rem;
161
- --btn-icon-size: .5rem;
162
- --btn-text-size: .875rem;
163
- }
164
-
165
- /* Color Variants */
166
- .bs-circle-button:where([data-variant^="color"]) {
167
- --btn-gap: .5rem;
168
- --btn-icon-bg-color: transparent;
169
- --btn-icon-padding: 0;
170
- --btn-icon-size: .75rem; /* stays the same for all sizes */
171
- --btn-icon-stroke-color: var(--btn-text-color);
172
- --btn-secondary: transparent;
173
- --btn-shadow-color-active: transparent;
174
- }
175
- .bs-circle-button:where([data-variant="color-blue"]) {
176
- --btn-border-color-focused: var(--bs-ink-blue);
177
- --btn-text-color: var(--bs-ink-blue);
178
- --btn-text-color-hovered: var(--bs-blue-base);
179
- }
180
-
181
- .bs-circle-button:where([data-variant="color-royal"]) {
182
- --btn-border-color-focused: var(--bs-ink-royal);
183
- --btn-text-color: var(--bs-ink-royal);
184
- --btn-text-color-hovered: var(--bs-royal-medium);
185
- }
186
-
187
- .bs-circle-button:where([data-variant="color-purple"]) {
188
- --btn-border-color-focused: var(--bs-purple-400);
189
- --btn-text-color: var(--bs-ink-purple);
190
- --btn-text-color-hovered: var(--bs-purple-medium);
191
- }
192
-
193
- .bs-circle-button:where([data-variant="color-pink"]) {
194
- --btn-border-color-focused: var(--bs-pink-400);
195
- --btn-text-color: var(--bs-ink-pink);
196
- --btn-text-color-hovered: var(--bs-pink-base);
197
- }
198
-
199
- .bs-circle-button:where([data-variant="color-orange"]) {
200
- --btn-border-color-focused: var(--bs-ink-orange);
201
- --btn-text-color: var(--bs-ink-orange);
202
- --btn-text-color-hovered: var(--bs-orange-base);
203
- }
204
-
205
- .bs-circle-button:where([data-variant="color-red"]) {
206
- --btn-border-color-focused: var(--bs-ink-red);
207
- --btn-text-color: var(--bs-ink-red);
208
- --btn-text-color-hovered: var(--bs-red-base);
209
- }
210
-
211
- .bs-circle-button:where([data-variant="color-white"]) {
212
- --btn-border-color-focused: var(--bs-ink-white);
213
- --btn-text-color: var(--bs-ink-white);
214
- /* 80% of --bs-white */
215
- --btn-text-color-hovered: rgba(255, 255, 255, 0.8);
216
- }
217
-
218
- .bs-circle-button:where([data-variant^="color"]):where(:disabled, [aria-disabled]:not([aria-disabled="false"])) {
219
- --btn-icon-bg-color: transparent;
220
- --btn-text-color: var(--bs-ink-disabled);
221
- }
222
-
223
- /* size XXS only supported for color variants */
224
- .bs-circle-button:where([data-variant^="color"]):where([data-size='xxs'][data-text]:not([data-text="false"])) {
225
- --btn-text-size: .75rem;
226
- --btn-text-weight: 600;
227
- }
@@ -1,232 +0,0 @@
1
- /* Option list */
2
- .bs-dropdown-options {
3
- display: flex;
4
- flex-direction: column;
5
- gap: 0.5rem;
6
- list-style: none;
7
- margin-bottom: 0.25rem;
8
- margin-top: 0.25rem;
9
- max-height: var(--options-height-max, 20rem);/* constrain scrollable to options section */
10
- overflow-y: auto;
11
- padding-block: 0.5rem;
12
- padding-left: 0;
13
- position: relative;
14
- }
15
-
16
- .bs-dropdown-options:focus-visible {
17
- outline: none;
18
- }
19
-
20
- /* Stabilize scrollbar gutter for Firefox (https://bugzilla.mozilla.org/show_bug.cgi?id=764076) */
21
- @media (min-width: 1166px) {
22
- /* 5th or 8th child triggers overflow-y (depending on variant) */
23
- :where([data-width="content"]) > .bs-dropdown-options:where(:has([data-variant*="description"]:nth-child(5))),
24
- :where([data-width="content"]) > .bs-dropdown-options:where(:has(li:not([data-variant*="description"]):nth-child(8))) {
25
- scrollbar-gutter: stable;
26
- }
27
-
28
- /* Fallback for older Firefox+ only if we're not setting data-overflow values */
29
- @supports not selector(:has(*)) {
30
- :where([data-width="content"]) > .bs-dropdown-options {
31
- scrollbar-gutter: stable;
32
- }
33
- }
34
-
35
- /* Also allow this for js solutions if :has not available via data-overflow */
36
- /* Reset scrollbar gutter when data-overflow is used */
37
- :where([data-width="content"]) > .bs-dropdown-options:where([data-overflow]) {
38
- scrollbar-gutter: auto;
39
- }
40
-
41
- :where([data-width="content"]) > .bs-dropdown-options:where([data-overflow="true"]) {
42
- scrollbar-gutter: stable;
43
- }
44
- }
45
-
46
- /* Option list item */
47
- .bs-dropdown-options :where(li) {
48
- align-items: center;
49
- border-bottom: 2px solid transparent;
50
- border-left: 4px solid transparent;
51
- border-radius: 3px;
52
- border-right: 2px solid transparent;
53
- border-top: 2px solid transparent;
54
- color: var(--bs-ink-base);
55
- column-gap: 0.5rem;
56
- cursor: pointer;
57
- display: grid;
58
- padding-block: 0.25rem;
59
- padding-inline: 1.25rem;
60
- row-gap: 0.125rem;
61
- word-break: break-word;
62
- word-wrap: break-word;
63
- }
64
-
65
- /* Variant: 2-col */
66
- .bs-dropdown-options :where(li[data-variant~="2-col"]) {
67
- grid-template-columns: min-content 1fr;
68
- }
69
-
70
- /* Variant: 3-col */
71
- .bs-dropdown-options :where(li[data-variant~="3-col"]) {
72
- grid-template-columns: min-content min-content 1fr;
73
- }
74
-
75
- /* Variant: description */
76
- .bs-dropdown-options :where(li:not([data-variant*="-col"])[data-variant~="description"] > :nth-child(2)),
77
- .bs-dropdown-options :where(li[data-variant~="2-col"][data-variant~="description"] > :nth-child(3)),
78
- .bs-dropdown-options :where(li[data-variant~="3-col"][data-variant~="description"] > :nth-child(4)) {
79
- color: var(--bs-ink-light);
80
- font-size: var(--bs-text-xs);
81
- min-height: 1.125rem;
82
- line-height: 1.125rem;
83
- }
84
-
85
- /* Variant: 2-col description */
86
- .bs-dropdown-options :where(li[data-variant~="2-col"][data-variant~="description"] > :nth-child(3)) {
87
- grid-column-start: 2;
88
- }
89
-
90
- /* Variant: 3-col description */
91
- .bs-dropdown-options :where(li[data-variant~="3-col"][data-variant~="description"] > :nth-child(4)) {
92
- grid-column-start: 3;
93
- }
94
-
95
- /* Hover or data-selected */
96
- .bs-dropdown-options :where(li:not([role="separator"]):hover),
97
- .bs-dropdown-options :where(li[data-selected]) {
98
- background-color: var(--bs-bg-medium-to-light);
99
- border-left: 4px solid var(--bs-ink-blue);
100
- color: var(--bs-ink-blue);
101
- outline: none;
102
- }
103
-
104
- /* Variant: negative */
105
- .bs-dropdown-options :where(li[data-variant~="negative"]:hover),
106
- .bs-dropdown-options :where(li[data-variant~="negative"][data-selected]),
107
- .bs-dropdown-options :where(li[data-variant~="negative"][data-selected]:hover) {
108
- /* 25% alpha version of --bs-red-400 */
109
- background-color: rgba(248, 169, 170, 0.25);
110
- border-left: 4px solid var(--bs-ink-red);
111
- color: var(--bs-ink-red);
112
- }
113
-
114
- /* Hover or data-selected for 2-col/3-col/description variants */
115
- .bs-dropdown-options :where(li:not([data-variant*="-col"])[data-variant~="description"]:hover > :nth-child(2)),
116
- .bs-dropdown-options :where(li[data-variant~="2-col"][data-variant~="description"]:hover > :nth-child(3)),
117
- .bs-dropdown-options :where(li[data-variant~="3-col"][data-variant~="description"]:hover > :nth-child(4)),
118
- .bs-dropdown-options :where(li:not([data-variant*="-col"])[data-variant~="description"][data-selected] > :nth-child(2)),
119
- .bs-dropdown-options :where(li[data-variant~="2-col"][data-variant~="description"][data-selected] > :nth-child(3)),
120
- .bs-dropdown-options :where(li[data-variant~="3-col"][data-variant~="description"][data-selected] > :nth-child(4)) {
121
- color: var(--bs-ink-blue);
122
- }
123
-
124
- /* Hover or data-selected for negative + 2-col/3-col/description variants */
125
- .bs-dropdown-options :where(li[data-variant~="negative"]:not([data-variant*="-col"])[data-variant~="description"]:hover > :nth-child(2)),
126
- .bs-dropdown-options :where(li[data-variant~="negative"][data-variant~="2-col"][data-variant~="description"]:hover > :nth-child(3)),
127
- .bs-dropdown-options :where(li[data-variant~="negative"][data-variant~="3-col"][data-variant~="description"]:hover > :nth-child(4)),
128
- .bs-dropdown-options :where(li[data-variant~="negative"]:not([data-variant*="-col"])[data-variant~="description"][data-selected] > :nth-child(2)),
129
- .bs-dropdown-options :where(li[data-variant~="negative"][data-variant~="2-col"][data-variant~="description"][data-selected] > :nth-child(3)),
130
- .bs-dropdown-options :where(li[data-variant~="negative"][data-variant~="3-col"][data-variant~="description"][data-selected] > :nth-child(4)) {
131
- color: var(--bs-ink-red);
132
- }
133
-
134
- /* List option keyboard navigation focus */
135
- .bs-dropdown-options:where(:focus-visible) :where(li[data-active]) {
136
- --focus-border-color: var(--bs-blue-base);
137
- border: 2px solid var(--focus-border-color);
138
- outline: none;
139
- padding-left: 1.375rem;
140
- }
141
-
142
- /* Navigation focus on a selected element should preserve 4px left border */
143
- .bs-dropdown-options:where(:focus-visible) :where(li[data-selected][data-active]) {
144
- border-left: 4px solid var(--focus-border-color);
145
- padding-left: 1.25rem;
146
- }
147
-
148
- /* data-variant="negative" list option keyboard navigation focus */
149
- .bs-dropdown-options:where(:focus-visible) :where(li[data-variant~="negative"][data-active]) {
150
- --focus-border-color: var(--bs-red-200);
151
- }
152
-
153
- /* Multi-select divider */
154
- .bs-dropdown-options :where(li[role="separator"]) {
155
- cursor: default;
156
- padding-block: 0.125rem;
157
- padding-right: 1.375rem;
158
- }
159
-
160
- /* Multi-select divider line */
161
- .bs-dropdown-options :where(hr) {
162
- background-color: var(--bs-navy-light);
163
- height: .0625rem;
164
- margin-block: 0;
165
- margin-inline: 0;
166
- }
167
-
168
- /* Disable hover styles */
169
- .bs-dropdown-options :where(li[data-no-hover]:hover) {
170
- background-color: transparent;
171
- border-left-color: transparent;
172
- color: var(--bs-ink-base);
173
- cursor: default;
174
- }
175
-
176
- /* Style label to look like other options */
177
- .bs-dropdown-options :where(li label) {
178
- cursor: pointer;
179
- font-size: 1rem;
180
- font-weight: 400;
181
- }
182
-
183
- /* Don't change option color when checkbox is present */
184
- .bs-dropdown-options :where(li[data-variant~="checkbox"]):hover,
185
- .bs-dropdown-options :where(li[data-variant~="checkbox"][data-selected]) {
186
- color: var(--bs-ink-base);
187
- }
188
-
189
- /* Don't change description color when checkbox is present */
190
- .bs-dropdown-options :where(li[data-variant~="checkbox"][data-variant~="2-col"][data-variant~="description"]):hover > :nth-child(3),
191
- .bs-dropdown-options :where(li[data-variant~="checkbox"][data-variant~="2-col"][data-variant~="description"][data-selected]) > :nth-child(3),
192
- .bs-dropdown-options :where(li[data-variant~="checkbox"][data-variant~="3-col"][data-variant~="description"]):hover > :nth-child(4),
193
- .bs-dropdown-options :where(li[data-variant~="checkbox"][data-variant~="3-col"][data-variant~="description"][data-selected]) > :nth-child(4) {
194
- color: var(--bs-ink-light);
195
- }
196
-
197
- /* Overrides mobile style when not min-width 1166 */
198
- .bs-dropdown:where([data-no-mobile="true"]) :where(.bs-dropdown-options) :where(li) {
199
- padding-left: 0.5rem;
200
- padding-right: 0.75rem;
201
- }
202
-
203
- .bs-dropdown:where([data-no-mobile="true"]) :where(.bs-dropdown-options) :where(li[role="separator"]) {
204
- padding-right: 0.625rem;
205
- }
206
-
207
- .bs-dropdown:where([data-no-mobile="true"]) :where(.bs-dropdown-options:focus-visible) :where(li[data-active]) {
208
- padding-left: 0.625rem;
209
- }
210
-
211
- .bs-dropdown:where([data-no-mobile="true"]) :where(.bs-dropdown-options:focus-visible) :where(li[data-selected][data-active]) {
212
- padding-left: 0.5rem;
213
- }
214
-
215
- @media (min-width: 1166px) {
216
- .bs-dropdown-options :where(li) {
217
- padding-left: 0.5rem;
218
- padding-right: 0.75rem;
219
- }
220
-
221
- .bs-dropdown-options :where(li[role="separator"]) {
222
- padding-right: 0.625rem;
223
- }
224
-
225
- .bs-dropdown-options:where(:focus-visible) :where(li[data-active]) {
226
- padding-left: 0.625rem;
227
- }
228
-
229
- .bs-dropdown-options:where(:focus-visible) :where(li[data-selected][data-active]) {
230
- padding-left: 0.5rem;
231
- }
232
- }
@@ -1,185 +0,0 @@
1
- /* Parent */
2
- .bs-dropdown-parent {
3
- display: inline-block;
4
- position: relative;
5
- }
6
-
7
- /* Backdrop for mobile bottom sheet */
8
- .bs-dropdown-backdrop {
9
- -webkit-backdrop-filter: blur(4px);
10
- backdrop-filter: blur(4px);
11
- background: rgba(29, 30, 72, 0.05);
12
- bottom: 0;
13
- content: "";
14
- left: 0;
15
- position: fixed;
16
- right: 0;
17
- top: 0;
18
- z-index: 998;
19
- }
20
-
21
- /* Content */
22
- .bs-dropdown {
23
- --dropdown-bottom: 0;
24
- --dropdown-left: 0;
25
- --dropdown-right: auto;
26
- --dropdown-top: auto;
27
- --dropdown-width: 100%;
28
- --dropdown-transform: translate(0, 100%);
29
-
30
- background-color: var(--bs-bg-base-to-medium);
31
- border-radius: 4px;
32
- bottom: var(--dropdown-bottom);
33
- box-shadow: var(--bs-shadow-contentMedium);
34
- left: var(--dropdown-left);
35
- line-height: 1.5rem;
36
- margin: 0;
37
- opacity: 0;
38
- overflow-y: auto;
39
- position: fixed;
40
- right: var(--dropdown-right);
41
- top: var(--dropdown-top);
42
- transform-origin: center bottom;
43
- transform: var(--dropdown-transform);
44
- transition-duration: 75ms;
45
- transition-property: opacity, transform;
46
- transition-timing-function: ease-in-out;
47
- width: var(--dropdown-width);
48
- z-index: 999;
49
- }
50
-
51
- /* Mobile Header */
52
- .bs-dropdown > :where(header) {
53
- border-bottom: 1px solid var(--bs-border-base);
54
- display: flex;
55
- justify-content: space-between;
56
- padding: 1.5rem;
57
- }
58
-
59
- .bs-dropdown > :where(header) :where(h3) {
60
- font-size: 1.25rem;
61
- }
62
-
63
- .bs-dropdown > :where(header) :where(p) {
64
- font-size: 1rem;
65
- }
66
-
67
- .bs-dropdown > :where(header) :where(button) {
68
- cursor: pointer;
69
- height: 1rem;
70
- width: 1rem;
71
- }
72
-
73
- /* data-shown */
74
- .bs-dropdown:where([data-shown]:not([data-shown="false"])) {
75
- --dropdown-transform: translate(0, 0);
76
- opacity: 1;
77
- }
78
-
79
- /* Sizing */
80
- .bs-dropdown:where([data-width="sm"]) {
81
- --dropdown-wscreen-width: 10rem;
82
- }
83
-
84
- .bs-dropdown:where([data-width="md"]),
85
- .bs-dropdown:where(:not([data-width])) {
86
- --dropdown-wscreen-width: 20rem;
87
- }
88
-
89
- .bs-dropdown:where([data-width="lg"]) {
90
- --dropdown-wscreen-width: 40rem;
91
- }
92
-
93
- .bs-dropdown:where([data-width="content"]) {
94
- --dropdown-wscreen-width: max-content;
95
- }
96
-
97
- .bs-dropdown-parent:where([data-width="anchor"]) :where(.bs-dropdown) {
98
- --dropdown-wscreen-width: 100%;
99
- }
100
-
101
- /* data-top */
102
- .bs-dropdown:where([data-top]:not([data-top="false"])) {
103
- --dropdown-wscreen-bottom: calc(100% + 0.5rem);
104
- --dropdown-wscreen-top: auto;
105
- }
106
-
107
- /* data-center */
108
- .bs-dropdown-parent:where([data-center]:not([data-center="false"])) :where(.bs-dropdown) {
109
- --dropdown-transform: translate(-50%, 0);
110
- --dropdown-wscreen-left: 50%;
111
- }
112
-
113
- /* data-right */
114
- .bs-dropdown-parent:where([data-right]:not([data-right="false"])) :where(.bs-dropdown) {
115
- --dropdown-transform: translate(0, 0);
116
- --dropdown-wscreen-left: auto;
117
- --dropdown-wscreen-right: 0;
118
- }
119
-
120
- /* Overrides mobile style when not min-width 1166 */
121
- .bs-dropdown:where([data-no-mobile="true"]) {
122
- --dropdown-bottom: var(--dropdown-wscreen-bottom, auto);
123
- --dropdown-left: var(--dropdown-wscreen-left, initial);
124
- --dropdown-right: var(--dropdown-wscreen-right, initial);
125
- --dropdown-top: var(--dropdown-wscreen-top, calc(100% + 0.5rem));
126
- --dropdown-width: var(--dropdown-wscreen-width, initial);
127
- --dropdown-transform: initial;
128
-
129
- position: absolute;
130
- }
131
-
132
- .bs-dropdown:where([data-no-mobile="true"]) > :where(header) {
133
- display: none;
134
- }
135
-
136
- @media (min-width: 1166px) {
137
- .bs-dropdown-backdrop {
138
- display: none;
139
- }
140
-
141
- .bs-dropdown {
142
- --dropdown-bottom: var(--dropdown-wscreen-bottom, auto);
143
- --dropdown-left: var(--dropdown-wscreen-left, initial);
144
- --dropdown-right: var(--dropdown-wscreen-right, initial);
145
- --dropdown-top: var(--dropdown-wscreen-top, calc(100% + 0.5rem));
146
- --dropdown-width: var(--dropdown-wscreen-width, initial);
147
- --dropdown-transform: initial;
148
-
149
- position: absolute;
150
- }
151
-
152
- /* Hide the header */
153
- .bs-dropdown > :where(header) {
154
- display: none;
155
- }
156
- }
157
-
158
- /* Vue Transition Styles - Only used in Vue component */
159
- .bs-dropdown:where(.bs-dropdown-enter-from),
160
- .bs-dropdown:where(.bs-dropdown-leave-to) {
161
- opacity: 0;
162
- transform: var(--dropdown-transform);
163
- }
164
-
165
- .bs-dropdown:where(.bs-dropdown-enter-to),
166
- .bs-dropdown:where(.bs-dropdown-leave-from) {
167
- opacity: 1;
168
- transform: translate(0, 0);
169
- }
170
-
171
- .bs-dropdown :where(.mobile-select-button-container) {
172
- display: none;
173
- overflow: hidden;
174
- }
175
-
176
- @media (max-width: 1166px) {
177
- .bs-dropdown :where(.mobile-select-button-container) {
178
- display: flex;
179
- }
180
- }
181
-
182
- .bs-dropdown :where(.mobile-select-button) {
183
- margin: .875rem;
184
- width: 100%;
185
- }