bootstrap-scss 5.2.0 → 5.2.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 (86) hide show
  1. package/README.md +1 -1
  2. package/_accordion.scss +149 -146
  3. package/_alert.scss +71 -71
  4. package/_badge.scss +38 -38
  5. package/_breadcrumb.scss +40 -40
  6. package/_button-group.scss +142 -142
  7. package/_buttons.scss +207 -186
  8. package/_card.scss +234 -234
  9. package/_carousel.scss +229 -229
  10. package/_close.scss +40 -40
  11. package/_containers.scss +41 -41
  12. package/_dropdown.scss +249 -248
  13. package/_forms.scss +9 -9
  14. package/_functions.scss +302 -302
  15. package/_grid.scss +33 -33
  16. package/_helpers.scss +10 -10
  17. package/_list-group.scss +192 -191
  18. package/_maps.scss +54 -54
  19. package/_mixins.scss +43 -43
  20. package/_modal.scss +237 -237
  21. package/_nav.scss +172 -172
  22. package/_navbar.scss +278 -276
  23. package/_offcanvas.scss +144 -143
  24. package/_pagination.scss +109 -109
  25. package/_placeholders.scss +51 -51
  26. package/_popover.scss +196 -196
  27. package/_progress.scss +59 -59
  28. package/_reboot.scss +610 -610
  29. package/_root.scss +73 -73
  30. package/_spinners.scss +85 -85
  31. package/_tables.scss +164 -164
  32. package/_toasts.scss +73 -70
  33. package/_tooltip.scss +120 -120
  34. package/_transitions.scss +27 -27
  35. package/_type.scss +106 -106
  36. package/_utilities.scss +647 -647
  37. package/_variables.scss +1634 -1633
  38. package/bootstrap-grid.scss +64 -64
  39. package/bootstrap-reboot.scss +9 -9
  40. package/bootstrap-utilities.scss +15 -15
  41. package/bootstrap.scss +51 -51
  42. package/forms/_floating-labels.scss +75 -74
  43. package/forms/_form-check.scss +175 -175
  44. package/forms/_form-control.scss +194 -194
  45. package/forms/_form-range.scss +91 -91
  46. package/forms/_form-select.scss +71 -71
  47. package/forms/_form-text.scss +11 -11
  48. package/forms/_input-group.scss +132 -129
  49. package/forms/_labels.scss +36 -36
  50. package/forms/_validation.scss +12 -12
  51. package/helpers/_clearfix.scss +3 -3
  52. package/helpers/_color-bg.scss +10 -10
  53. package/helpers/_colored-links.scss +12 -12
  54. package/helpers/_position.scss +36 -36
  55. package/helpers/_ratio.scss +26 -26
  56. package/helpers/_stacks.scss +15 -15
  57. package/helpers/_stretched-link.scss +15 -15
  58. package/helpers/_text-truncation.scss +7 -7
  59. package/helpers/_visually-hidden.scss +8 -8
  60. package/helpers/_vr.scss +8 -8
  61. package/mixins/_alert.scss +15 -15
  62. package/mixins/_backdrop.scss +14 -14
  63. package/mixins/_banner.scss +9 -9
  64. package/mixins/_border-radius.scss +78 -78
  65. package/mixins/_box-shadow.scss +18 -18
  66. package/mixins/_breakpoints.scss +127 -127
  67. package/mixins/_buttons.scss +70 -70
  68. package/mixins/_caret.scss +64 -64
  69. package/mixins/_clearfix.scss +9 -9
  70. package/mixins/_color-scheme.scss +7 -7
  71. package/mixins/_container.scss +11 -11
  72. package/mixins/_forms.scss +152 -152
  73. package/mixins/_gradients.scss +47 -47
  74. package/mixins/_grid.scss +151 -151
  75. package/mixins/_image.scss +16 -16
  76. package/mixins/_list-group.scss +24 -24
  77. package/mixins/_lists.scss +7 -7
  78. package/mixins/_pagination.scss +10 -10
  79. package/mixins/_reset-text.scss +17 -17
  80. package/mixins/_table-variants.scss +24 -24
  81. package/mixins/_transition.scss +26 -26
  82. package/mixins/_utilities.scss +97 -97
  83. package/mixins/_visually-hidden.scss +29 -29
  84. package/package.json +1 -1
  85. package/utilities/_api.scss +47 -47
  86. package/vendor/_rfs.scss +354 -354
package/_modal.scss CHANGED
@@ -1,237 +1,237 @@
1
- // stylelint-disable function-disallowed-list
2
-
3
- // .modal-open - body class for killing the scroll
4
- // .modal - container to scroll within
5
- // .modal-dialog - positioning shell for the actual modal
6
- // .modal-content - actual modal w/ bg and corners and stuff
7
-
8
-
9
- // Container that the modal scrolls within
10
- .modal {
11
- // scss-docs-start modal-css-vars
12
- --#{$prefix}modal-zindex: #{$zindex-modal};
13
- --#{$prefix}modal-width: #{$modal-md};
14
- --#{$prefix}modal-padding: #{$modal-inner-padding};
15
- --#{$prefix}modal-margin: #{$modal-dialog-margin};
16
- --#{$prefix}modal-color: #{$modal-content-color};
17
- --#{$prefix}modal-bg: #{$modal-content-bg};
18
- --#{$prefix}modal-border-color: #{$modal-content-border-color};
19
- --#{$prefix}modal-border-width: #{$modal-content-border-width};
20
- --#{$prefix}modal-border-radius: #{$modal-content-border-radius};
21
- --#{$prefix}modal-box-shadow: #{$modal-content-box-shadow-xs};
22
- --#{$prefix}modal-inner-border-radius: #{$modal-content-inner-border-radius};
23
- --#{$prefix}modal-header-padding-x: #{$modal-header-padding-x};
24
- --#{$prefix}modal-header-padding-y: #{$modal-header-padding-y};
25
- --#{$prefix}modal-header-padding: #{$modal-header-padding}; // Todo in v6: Split this padding into x and y
26
- --#{$prefix}modal-header-border-color: #{$modal-header-border-color};
27
- --#{$prefix}modal-header-border-width: #{$modal-header-border-width};
28
- --#{$prefix}modal-title-line-height: #{$modal-title-line-height};
29
- --#{$prefix}modal-footer-gap: #{$modal-footer-margin-between};
30
- --#{$prefix}modal-footer-bg: #{$modal-footer-bg};
31
- --#{$prefix}modal-footer-border-color: #{$modal-footer-border-color};
32
- --#{$prefix}modal-footer-border-width: #{$modal-footer-border-width};
33
- // scss-docs-end modal-css-vars
34
-
35
- position: fixed;
36
- top: 0;
37
- left: 0;
38
- z-index: var(--#{$prefix}modal-zindex);
39
- display: none;
40
- width: 100%;
41
- height: 100%;
42
- overflow-x: hidden;
43
- overflow-y: auto;
44
- // Prevent Chrome on Windows from adding a focus outline. For details, see
45
- // https://github.com/twbs/bootstrap/pull/10951.
46
- outline: 0;
47
- // We deliberately don't use `-webkit-overflow-scrolling: touch;` due to a
48
- // gnarly iOS Safari bug: https://bugs.webkit.org/show_bug.cgi?id=158342
49
- // See also https://github.com/twbs/bootstrap/issues/17695
50
- }
51
-
52
- // Shell div to position the modal with bottom padding
53
- .modal-dialog {
54
- position: relative;
55
- width: auto;
56
- margin: var(--#{$prefix}modal-margin);
57
- // allow clicks to pass through for custom click handling to close modal
58
- pointer-events: none;
59
-
60
- // When fading in the modal, animate it to slide down
61
- .modal.fade & {
62
- @include transition($modal-transition);
63
- transform: $modal-fade-transform;
64
- }
65
- .modal.show & {
66
- transform: $modal-show-transform;
67
- }
68
-
69
- // When trying to close, animate focus to scale
70
- .modal.modal-static & {
71
- transform: $modal-scale-transform;
72
- }
73
- }
74
-
75
- .modal-dialog-scrollable {
76
- height: calc(100% - var(--#{$prefix}modal-margin) * 2);
77
-
78
- .modal-content {
79
- max-height: 100%;
80
- overflow: hidden;
81
- }
82
-
83
- .modal-body {
84
- overflow-y: auto;
85
- }
86
- }
87
-
88
- .modal-dialog-centered {
89
- display: flex;
90
- align-items: center;
91
- min-height: calc(100% - var(--#{$prefix}modal-margin) * 2);
92
- }
93
-
94
- // Actual modal
95
- .modal-content {
96
- position: relative;
97
- display: flex;
98
- flex-direction: column;
99
- width: 100%; // Ensure `.modal-content` extends the full width of the parent `.modal-dialog`
100
- // counteract the pointer-events: none; in the .modal-dialog
101
- color: var(--#{$prefix}modal-color);
102
- pointer-events: auto;
103
- background-color: var(--#{$prefix}modal-bg);
104
- background-clip: padding-box;
105
- border: var(--#{$prefix}modal-border-width) solid var(--#{$prefix}modal-border-color);
106
- @include border-radius(var(--#{$prefix}modal-border-radius));
107
- @include box-shadow(var(--#{$prefix}modal-box-shadow));
108
- // Remove focus outline from opened modal
109
- outline: 0;
110
- }
111
-
112
- // Modal background
113
- .modal-backdrop {
114
- // scss-docs-start modal-backdrop-css-vars
115
- --#{$prefix}backdrop-zindex: #{$zindex-modal-backdrop};
116
- --#{$prefix}backdrop-bg: #{$modal-backdrop-bg};
117
- --#{$prefix}backdrop-opacity: #{$modal-backdrop-opacity};
118
- // scss-docs-end modal-backdrop-css-vars
119
-
120
- @include overlay-backdrop(var(--#{$prefix}backdrop-zindex), var(--#{$prefix}backdrop-bg), var(--#{$prefix}backdrop-opacity));
121
- }
122
-
123
- // Modal header
124
- // Top section of the modal w/ title and dismiss
125
- .modal-header {
126
- display: flex;
127
- flex-shrink: 0;
128
- align-items: center;
129
- justify-content: space-between; // Put modal header elements (title and dismiss) on opposite ends
130
- padding: var(--#{$prefix}modal-header-padding);
131
- border-bottom: var(--#{$prefix}modal-header-border-width) solid var(--#{$prefix}modal-header-border-color);
132
- @include border-top-radius(var(--#{$prefix}modal-inner-border-radius));
133
-
134
- .btn-close {
135
- padding: calc(var(--#{$prefix}modal-header-padding-y) * .5) calc(var(--#{$prefix}modal-header-padding-x) * .5);
136
- margin: calc(var(--#{$prefix}modal-header-padding-y) * -.5) calc(var(--#{$prefix}modal-header-padding-x) * -.5) calc(var(--#{$prefix}modal-header-padding-y) * -.5) auto;
137
- }
138
- }
139
-
140
- // Title text within header
141
- .modal-title {
142
- margin-bottom: 0;
143
- line-height: var(--#{$prefix}modal-title-line-height);
144
- }
145
-
146
- // Modal body
147
- // Where all modal content resides (sibling of .modal-header and .modal-footer)
148
- .modal-body {
149
- position: relative;
150
- // Enable `flex-grow: 1` so that the body take up as much space as possible
151
- // when there should be a fixed height on `.modal-dialog`.
152
- flex: 1 1 auto;
153
- padding: var(--#{$prefix}modal-padding);
154
- }
155
-
156
- // Footer (for actions)
157
- .modal-footer {
158
- display: flex;
159
- flex-shrink: 0;
160
- flex-wrap: wrap;
161
- align-items: center; // vertically center
162
- justify-content: flex-end; // Right align buttons with flex property because text-align doesn't work on flex items
163
- padding: calc(var(--#{$prefix}modal-padding) - var(--#{$prefix}modal-footer-gap) * .5);
164
- background-color: var(--#{$prefix}modal-footer-bg);
165
- border-top: var(--#{$prefix}modal-footer-border-width) solid var(--#{$prefix}modal-footer-border-color);
166
- @include border-bottom-radius(var(--#{$prefix}modal-inner-border-radius));
167
-
168
- // Place margin between footer elements
169
- // This solution is far from ideal because of the universal selector usage,
170
- // but is needed to fix https://github.com/twbs/bootstrap/issues/24800
171
- > * {
172
- margin: calc(var(--#{$prefix}modal-footer-gap) * .5); // Todo in v6: replace with gap on parent class
173
- }
174
- }
175
-
176
- // Scale up the modal
177
- @include media-breakpoint-up(sm) {
178
- .modal {
179
- --#{$prefix}modal-margin: #{$modal-dialog-margin-y-sm-up};
180
- --#{$prefix}modal-box-shadow: #{$modal-content-box-shadow-sm-up};
181
- }
182
-
183
- // Automatically set modal's width for larger viewports
184
- .modal-dialog {
185
- max-width: var(--#{$prefix}modal-width);
186
- margin-right: auto;
187
- margin-left: auto;
188
- }
189
-
190
- .modal-sm {
191
- --#{$prefix}modal-width: #{$modal-sm};
192
- }
193
- }
194
-
195
- @include media-breakpoint-up(lg) {
196
- .modal-lg,
197
- .modal-xl {
198
- --#{$prefix}modal-width: #{$modal-lg};
199
- }
200
- }
201
-
202
- @include media-breakpoint-up(xl) {
203
- .modal-xl {
204
- --#{$prefix}modal-width: #{$modal-xl};
205
- }
206
- }
207
-
208
- // scss-docs-start modal-fullscreen-loop
209
- @each $breakpoint in map-keys($grid-breakpoints) {
210
- $infix: breakpoint-infix($breakpoint, $grid-breakpoints);
211
- $postfix: if($infix != "", $infix + "-down", "");
212
-
213
- @include media-breakpoint-down($breakpoint) {
214
- .modal-fullscreen#{$postfix} {
215
- width: 100vw;
216
- max-width: none;
217
- height: 100%;
218
- margin: 0;
219
-
220
- .modal-content {
221
- height: 100%;
222
- border: 0;
223
- @include border-radius(0);
224
- }
225
-
226
- .modal-header,
227
- .modal-footer {
228
- @include border-radius(0);
229
- }
230
-
231
- .modal-body {
232
- overflow-y: auto;
233
- }
234
- }
235
- }
236
- }
237
- // scss-docs-end modal-fullscreen-loop
1
+ // stylelint-disable function-disallowed-list
2
+
3
+ // .modal-open - body class for killing the scroll
4
+ // .modal - container to scroll within
5
+ // .modal-dialog - positioning shell for the actual modal
6
+ // .modal-content - actual modal w/ bg and corners and stuff
7
+
8
+
9
+ // Container that the modal scrolls within
10
+ .modal {
11
+ // scss-docs-start modal-css-vars
12
+ --#{$prefix}modal-zindex: #{$zindex-modal};
13
+ --#{$prefix}modal-width: #{$modal-md};
14
+ --#{$prefix}modal-padding: #{$modal-inner-padding};
15
+ --#{$prefix}modal-margin: #{$modal-dialog-margin};
16
+ --#{$prefix}modal-color: #{$modal-content-color};
17
+ --#{$prefix}modal-bg: #{$modal-content-bg};
18
+ --#{$prefix}modal-border-color: #{$modal-content-border-color};
19
+ --#{$prefix}modal-border-width: #{$modal-content-border-width};
20
+ --#{$prefix}modal-border-radius: #{$modal-content-border-radius};
21
+ --#{$prefix}modal-box-shadow: #{$modal-content-box-shadow-xs};
22
+ --#{$prefix}modal-inner-border-radius: #{$modal-content-inner-border-radius};
23
+ --#{$prefix}modal-header-padding-x: #{$modal-header-padding-x};
24
+ --#{$prefix}modal-header-padding-y: #{$modal-header-padding-y};
25
+ --#{$prefix}modal-header-padding: #{$modal-header-padding}; // Todo in v6: Split this padding into x and y
26
+ --#{$prefix}modal-header-border-color: #{$modal-header-border-color};
27
+ --#{$prefix}modal-header-border-width: #{$modal-header-border-width};
28
+ --#{$prefix}modal-title-line-height: #{$modal-title-line-height};
29
+ --#{$prefix}modal-footer-gap: #{$modal-footer-margin-between};
30
+ --#{$prefix}modal-footer-bg: #{$modal-footer-bg};
31
+ --#{$prefix}modal-footer-border-color: #{$modal-footer-border-color};
32
+ --#{$prefix}modal-footer-border-width: #{$modal-footer-border-width};
33
+ // scss-docs-end modal-css-vars
34
+
35
+ position: fixed;
36
+ top: 0;
37
+ left: 0;
38
+ z-index: var(--#{$prefix}modal-zindex);
39
+ display: none;
40
+ width: 100%;
41
+ height: 100%;
42
+ overflow-x: hidden;
43
+ overflow-y: auto;
44
+ // Prevent Chrome on Windows from adding a focus outline. For details, see
45
+ // https://github.com/twbs/bootstrap/pull/10951.
46
+ outline: 0;
47
+ // We deliberately don't use `-webkit-overflow-scrolling: touch;` due to a
48
+ // gnarly iOS Safari bug: https://bugs.webkit.org/show_bug.cgi?id=158342
49
+ // See also https://github.com/twbs/bootstrap/issues/17695
50
+ }
51
+
52
+ // Shell div to position the modal with bottom padding
53
+ .modal-dialog {
54
+ position: relative;
55
+ width: auto;
56
+ margin: var(--#{$prefix}modal-margin);
57
+ // allow clicks to pass through for custom click handling to close modal
58
+ pointer-events: none;
59
+
60
+ // When fading in the modal, animate it to slide down
61
+ .modal.fade & {
62
+ @include transition($modal-transition);
63
+ transform: $modal-fade-transform;
64
+ }
65
+ .modal.show & {
66
+ transform: $modal-show-transform;
67
+ }
68
+
69
+ // When trying to close, animate focus to scale
70
+ .modal.modal-static & {
71
+ transform: $modal-scale-transform;
72
+ }
73
+ }
74
+
75
+ .modal-dialog-scrollable {
76
+ height: calc(100% - var(--#{$prefix}modal-margin) * 2);
77
+
78
+ .modal-content {
79
+ max-height: 100%;
80
+ overflow: hidden;
81
+ }
82
+
83
+ .modal-body {
84
+ overflow-y: auto;
85
+ }
86
+ }
87
+
88
+ .modal-dialog-centered {
89
+ display: flex;
90
+ align-items: center;
91
+ min-height: calc(100% - var(--#{$prefix}modal-margin) * 2);
92
+ }
93
+
94
+ // Actual modal
95
+ .modal-content {
96
+ position: relative;
97
+ display: flex;
98
+ flex-direction: column;
99
+ width: 100%; // Ensure `.modal-content` extends the full width of the parent `.modal-dialog`
100
+ // counteract the pointer-events: none; in the .modal-dialog
101
+ color: var(--#{$prefix}modal-color);
102
+ pointer-events: auto;
103
+ background-color: var(--#{$prefix}modal-bg);
104
+ background-clip: padding-box;
105
+ border: var(--#{$prefix}modal-border-width) solid var(--#{$prefix}modal-border-color);
106
+ @include border-radius(var(--#{$prefix}modal-border-radius));
107
+ @include box-shadow(var(--#{$prefix}modal-box-shadow));
108
+ // Remove focus outline from opened modal
109
+ outline: 0;
110
+ }
111
+
112
+ // Modal background
113
+ .modal-backdrop {
114
+ // scss-docs-start modal-backdrop-css-vars
115
+ --#{$prefix}backdrop-zindex: #{$zindex-modal-backdrop};
116
+ --#{$prefix}backdrop-bg: #{$modal-backdrop-bg};
117
+ --#{$prefix}backdrop-opacity: #{$modal-backdrop-opacity};
118
+ // scss-docs-end modal-backdrop-css-vars
119
+
120
+ @include overlay-backdrop(var(--#{$prefix}backdrop-zindex), var(--#{$prefix}backdrop-bg), var(--#{$prefix}backdrop-opacity));
121
+ }
122
+
123
+ // Modal header
124
+ // Top section of the modal w/ title and dismiss
125
+ .modal-header {
126
+ display: flex;
127
+ flex-shrink: 0;
128
+ align-items: center;
129
+ justify-content: space-between; // Put modal header elements (title and dismiss) on opposite ends
130
+ padding: var(--#{$prefix}modal-header-padding);
131
+ border-bottom: var(--#{$prefix}modal-header-border-width) solid var(--#{$prefix}modal-header-border-color);
132
+ @include border-top-radius(var(--#{$prefix}modal-inner-border-radius));
133
+
134
+ .btn-close {
135
+ padding: calc(var(--#{$prefix}modal-header-padding-y) * .5) calc(var(--#{$prefix}modal-header-padding-x) * .5);
136
+ margin: calc(-.5 * var(--#{$prefix}modal-header-padding-y)) calc(-.5 * var(--#{$prefix}modal-header-padding-x)) calc(-.5 * var(--#{$prefix}modal-header-padding-y)) auto;
137
+ }
138
+ }
139
+
140
+ // Title text within header
141
+ .modal-title {
142
+ margin-bottom: 0;
143
+ line-height: var(--#{$prefix}modal-title-line-height);
144
+ }
145
+
146
+ // Modal body
147
+ // Where all modal content resides (sibling of .modal-header and .modal-footer)
148
+ .modal-body {
149
+ position: relative;
150
+ // Enable `flex-grow: 1` so that the body take up as much space as possible
151
+ // when there should be a fixed height on `.modal-dialog`.
152
+ flex: 1 1 auto;
153
+ padding: var(--#{$prefix}modal-padding);
154
+ }
155
+
156
+ // Footer (for actions)
157
+ .modal-footer {
158
+ display: flex;
159
+ flex-shrink: 0;
160
+ flex-wrap: wrap;
161
+ align-items: center; // vertically center
162
+ justify-content: flex-end; // Right align buttons with flex property because text-align doesn't work on flex items
163
+ padding: calc(var(--#{$prefix}modal-padding) - var(--#{$prefix}modal-footer-gap) * .5);
164
+ background-color: var(--#{$prefix}modal-footer-bg);
165
+ border-top: var(--#{$prefix}modal-footer-border-width) solid var(--#{$prefix}modal-footer-border-color);
166
+ @include border-bottom-radius(var(--#{$prefix}modal-inner-border-radius));
167
+
168
+ // Place margin between footer elements
169
+ // This solution is far from ideal because of the universal selector usage,
170
+ // but is needed to fix https://github.com/twbs/bootstrap/issues/24800
171
+ > * {
172
+ margin: calc(var(--#{$prefix}modal-footer-gap) * .5); // Todo in v6: replace with gap on parent class
173
+ }
174
+ }
175
+
176
+ // Scale up the modal
177
+ @include media-breakpoint-up(sm) {
178
+ .modal {
179
+ --#{$prefix}modal-margin: #{$modal-dialog-margin-y-sm-up};
180
+ --#{$prefix}modal-box-shadow: #{$modal-content-box-shadow-sm-up};
181
+ }
182
+
183
+ // Automatically set modal's width for larger viewports
184
+ .modal-dialog {
185
+ max-width: var(--#{$prefix}modal-width);
186
+ margin-right: auto;
187
+ margin-left: auto;
188
+ }
189
+
190
+ .modal-sm {
191
+ --#{$prefix}modal-width: #{$modal-sm};
192
+ }
193
+ }
194
+
195
+ @include media-breakpoint-up(lg) {
196
+ .modal-lg,
197
+ .modal-xl {
198
+ --#{$prefix}modal-width: #{$modal-lg};
199
+ }
200
+ }
201
+
202
+ @include media-breakpoint-up(xl) {
203
+ .modal-xl {
204
+ --#{$prefix}modal-width: #{$modal-xl};
205
+ }
206
+ }
207
+
208
+ // scss-docs-start modal-fullscreen-loop
209
+ @each $breakpoint in map-keys($grid-breakpoints) {
210
+ $infix: breakpoint-infix($breakpoint, $grid-breakpoints);
211
+ $postfix: if($infix != "", $infix + "-down", "");
212
+
213
+ @include media-breakpoint-down($breakpoint) {
214
+ .modal-fullscreen#{$postfix} {
215
+ width: 100vw;
216
+ max-width: none;
217
+ height: 100%;
218
+ margin: 0;
219
+
220
+ .modal-content {
221
+ height: 100%;
222
+ border: 0;
223
+ @include border-radius(0);
224
+ }
225
+
226
+ .modal-header,
227
+ .modal-footer {
228
+ @include border-radius(0);
229
+ }
230
+
231
+ .modal-body {
232
+ overflow-y: auto;
233
+ }
234
+ }
235
+ }
236
+ }
237
+ // scss-docs-end modal-fullscreen-loop