bootstrap 4.6.2 → 5.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (149) hide show
  1. checksums.yaml +4 -4
  2. data/.travis.yml +2 -1
  3. data/README.md +7 -4
  4. data/assets/javascripts/bootstrap/alert.js +192 -115
  5. data/assets/javascripts/bootstrap/base-component.js +63 -0
  6. data/assets/javascripts/bootstrap/button.js +96 -179
  7. data/assets/javascripts/bootstrap/carousel.js +472 -359
  8. data/assets/javascripts/bootstrap/collapse.js +379 -225
  9. data/assets/javascripts/bootstrap/dom/data.js +68 -0
  10. data/assets/javascripts/bootstrap/dom/event-handler.js +322 -0
  11. data/assets/javascripts/bootstrap/dom/manipulator.js +88 -0
  12. data/assets/javascripts/bootstrap/dom/selector-engine.js +85 -0
  13. data/assets/javascripts/bootstrap/dropdown.js +472 -355
  14. data/assets/javascripts/bootstrap/modal.js +612 -438
  15. data/assets/javascripts/bootstrap/offcanvas.js +671 -0
  16. data/assets/javascripts/bootstrap/popover.js +138 -167
  17. data/assets/javascripts/bootstrap/scrollspy.js +250 -192
  18. data/assets/javascripts/bootstrap/tab.js +241 -144
  19. data/assets/javascripts/bootstrap/toast.js +223 -157
  20. data/assets/javascripts/bootstrap/tooltip.js +651 -487
  21. data/assets/javascripts/bootstrap-global-this-define.js +6 -0
  22. data/assets/javascripts/bootstrap-global-this-undefine.js +2 -0
  23. data/assets/javascripts/bootstrap-sprockets.js +8 -1
  24. data/assets/javascripts/bootstrap.js +3277 -2590
  25. data/assets/javascripts/bootstrap.min.js +3 -3
  26. data/assets/stylesheets/_bootstrap-grid.scss +53 -18
  27. data/assets/stylesheets/_bootstrap-reboot.scss +6 -3
  28. data/assets/stylesheets/_bootstrap.scss +18 -10
  29. data/assets/stylesheets/bootstrap/_accordion.scss +118 -0
  30. data/assets/stylesheets/bootstrap/_alert.scss +15 -10
  31. data/assets/stylesheets/bootstrap/_badge.scss +2 -27
  32. data/assets/stylesheets/bootstrap/_breadcrumb.scss +3 -17
  33. data/assets/stylesheets/bootstrap/_button-group.scss +21 -45
  34. data/assets/stylesheets/bootstrap/_buttons.scss +29 -60
  35. data/assets/stylesheets/bootstrap/_card.scss +20 -91
  36. data/assets/stylesheets/bootstrap/_carousel.scss +64 -35
  37. data/assets/stylesheets/bootstrap/_close.scss +30 -30
  38. data/assets/stylesheets/bootstrap/_containers.scss +41 -0
  39. data/assets/stylesheets/bootstrap/_dropdown.scss +84 -36
  40. data/assets/stylesheets/bootstrap/_forms.scss +9 -347
  41. data/assets/stylesheets/bootstrap/_functions.scss +84 -69
  42. data/assets/stylesheets/bootstrap/_grid.scss +3 -54
  43. data/assets/stylesheets/bootstrap/_helpers.scss +7 -0
  44. data/assets/stylesheets/bootstrap/_images.scss +1 -1
  45. data/assets/stylesheets/bootstrap/_list-group.scss +28 -8
  46. data/assets/stylesheets/bootstrap/_mixins.scss +8 -13
  47. data/assets/stylesheets/bootstrap/_modal.scss +45 -57
  48. data/assets/stylesheets/bootstrap/_nav.scss +20 -6
  49. data/assets/stylesheets/bootstrap/_navbar.scss +45 -71
  50. data/assets/stylesheets/bootstrap/_offcanvas.scss +77 -0
  51. data/assets/stylesheets/bootstrap/_pagination.scss +10 -20
  52. data/assets/stylesheets/bootstrap/_popover.scss +24 -36
  53. data/assets/stylesheets/bootstrap/_progress.scss +5 -4
  54. data/assets/stylesheets/bootstrap/_reboot.scss +316 -179
  55. data/assets/stylesheets/bootstrap/_root.scss +5 -8
  56. data/assets/stylesheets/bootstrap/_spinners.scss +11 -7
  57. data/assets/stylesheets/bootstrap/_tables.scss +79 -114
  58. data/assets/stylesheets/bootstrap/_toasts.scss +20 -15
  59. data/assets/stylesheets/bootstrap/_tooltip.scss +21 -21
  60. data/assets/stylesheets/bootstrap/_transitions.scss +2 -7
  61. data/assets/stylesheets/bootstrap/_type.scss +38 -59
  62. data/assets/stylesheets/bootstrap/_utilities.scss +594 -18
  63. data/assets/stylesheets/bootstrap/_variables.scss +800 -485
  64. data/assets/stylesheets/bootstrap/bootstrap-utilities.scss +18 -0
  65. data/assets/stylesheets/bootstrap/forms/_floating-labels.scss +61 -0
  66. data/assets/stylesheets/bootstrap/forms/_form-check.scss +152 -0
  67. data/assets/stylesheets/bootstrap/forms/_form-control.scss +219 -0
  68. data/assets/stylesheets/bootstrap/forms/_form-range.scss +91 -0
  69. data/assets/stylesheets/bootstrap/forms/_form-select.scss +67 -0
  70. data/assets/stylesheets/bootstrap/forms/_form-text.scss +11 -0
  71. data/assets/stylesheets/bootstrap/forms/_input-group.scss +121 -0
  72. data/assets/stylesheets/bootstrap/forms/_labels.scss +36 -0
  73. data/assets/stylesheets/bootstrap/forms/_validation.scss +12 -0
  74. data/assets/stylesheets/bootstrap/helpers/_colored-links.scss +12 -0
  75. data/assets/stylesheets/bootstrap/helpers/_position.scss +30 -0
  76. data/assets/stylesheets/bootstrap/helpers/_ratio.scss +26 -0
  77. data/assets/stylesheets/bootstrap/helpers/_stretched-link.scss +15 -0
  78. data/assets/stylesheets/bootstrap/helpers/_text-truncation.scss +7 -0
  79. data/assets/stylesheets/bootstrap/helpers/_visually-hidden.scss +8 -0
  80. data/assets/stylesheets/bootstrap/mixins/_alert.scss +3 -5
  81. data/assets/stylesheets/bootstrap/mixins/_border-radius.scss +10 -8
  82. data/assets/stylesheets/bootstrap/mixins/_box-shadow.scss +7 -9
  83. data/assets/stylesheets/bootstrap/mixins/_breakpoints.scss +14 -10
  84. data/assets/stylesheets/bootstrap/mixins/_buttons.scss +71 -48
  85. data/assets/stylesheets/bootstrap/mixins/_caret.scss +10 -8
  86. data/assets/stylesheets/bootstrap/mixins/_clearfix.scss +2 -0
  87. data/assets/stylesheets/bootstrap/mixins/_color-scheme.scss +7 -0
  88. data/assets/stylesheets/bootstrap/mixins/_container.scss +9 -0
  89. data/assets/stylesheets/bootstrap/mixins/_forms.scss +39 -97
  90. data/assets/stylesheets/bootstrap/mixins/_gradients.scss +13 -11
  91. data/assets/stylesheets/bootstrap/mixins/_grid.scss +90 -34
  92. data/assets/stylesheets/bootstrap/mixins/_image.scss +1 -21
  93. data/assets/stylesheets/bootstrap/mixins/_list-group.scss +5 -2
  94. data/assets/stylesheets/bootstrap/mixins/_lists.scss +1 -1
  95. data/assets/stylesheets/bootstrap/mixins/_pagination.scss +17 -8
  96. data/assets/stylesheets/bootstrap/mixins/_reset-text.scss +3 -3
  97. data/assets/stylesheets/bootstrap/mixins/_table-variants.scss +21 -0
  98. data/assets/stylesheets/bootstrap/mixins/_transition.scss +1 -1
  99. data/assets/stylesheets/bootstrap/mixins/_utilities.scss +68 -0
  100. data/assets/stylesheets/bootstrap/mixins/_visually-hidden.scss +29 -0
  101. data/assets/stylesheets/bootstrap/utilities/_api.scss +47 -0
  102. data/assets/stylesheets/bootstrap/vendor/_rfs.scss +214 -130
  103. data/bootstrap.gemspec +1 -3
  104. data/lib/bootstrap/version.rb +2 -2
  105. data/tasks/updater/js.rb +19 -16
  106. data/test/dummy_rails/app/assets/javascripts/application.js +4 -3
  107. data/test/dummy_rails/app/views/layouts/application.html.erb +3 -1
  108. data/test/dummy_rails/app/views/pages/root.html +89 -0
  109. data/test/dummy_rails/config/application.rb +0 -3
  110. data/test/gemfiles/rails_6_1.gemfile +7 -0
  111. metadata +45 -73
  112. data/assets/javascripts/bootstrap/util.js +0 -189
  113. data/assets/stylesheets/bootstrap/_code.scss +0 -48
  114. data/assets/stylesheets/bootstrap/_custom-forms.scss +0 -526
  115. data/assets/stylesheets/bootstrap/_input-group.scss +0 -211
  116. data/assets/stylesheets/bootstrap/_jumbotron.scss +0 -17
  117. data/assets/stylesheets/bootstrap/_media.scss +0 -8
  118. data/assets/stylesheets/bootstrap/_print.scss +0 -132
  119. data/assets/stylesheets/bootstrap/mixins/_background-variant.scss +0 -23
  120. data/assets/stylesheets/bootstrap/mixins/_badge.scss +0 -17
  121. data/assets/stylesheets/bootstrap/mixins/_float.scss +0 -14
  122. data/assets/stylesheets/bootstrap/mixins/_grid-framework.scss +0 -80
  123. data/assets/stylesheets/bootstrap/mixins/_hover.scss +0 -37
  124. data/assets/stylesheets/bootstrap/mixins/_nav-divider.scss +0 -11
  125. data/assets/stylesheets/bootstrap/mixins/_screen-reader.scss +0 -34
  126. data/assets/stylesheets/bootstrap/mixins/_size.scss +0 -7
  127. data/assets/stylesheets/bootstrap/mixins/_table-row.scss +0 -39
  128. data/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss +0 -17
  129. data/assets/stylesheets/bootstrap/mixins/_text-hide.scss +0 -11
  130. data/assets/stylesheets/bootstrap/mixins/_visibility.scss +0 -8
  131. data/assets/stylesheets/bootstrap/utilities/_align.scss +0 -8
  132. data/assets/stylesheets/bootstrap/utilities/_background.scss +0 -19
  133. data/assets/stylesheets/bootstrap/utilities/_borders.scss +0 -75
  134. data/assets/stylesheets/bootstrap/utilities/_display.scss +0 -26
  135. data/assets/stylesheets/bootstrap/utilities/_embed.scss +0 -39
  136. data/assets/stylesheets/bootstrap/utilities/_flex.scss +0 -51
  137. data/assets/stylesheets/bootstrap/utilities/_float.scss +0 -11
  138. data/assets/stylesheets/bootstrap/utilities/_interactions.scss +0 -5
  139. data/assets/stylesheets/bootstrap/utilities/_overflow.scss +0 -5
  140. data/assets/stylesheets/bootstrap/utilities/_position.scss +0 -32
  141. data/assets/stylesheets/bootstrap/utilities/_screenreaders.scss +0 -11
  142. data/assets/stylesheets/bootstrap/utilities/_shadows.scss +0 -6
  143. data/assets/stylesheets/bootstrap/utilities/_sizing.scss +0 -20
  144. data/assets/stylesheets/bootstrap/utilities/_spacing.scss +0 -73
  145. data/assets/stylesheets/bootstrap/utilities/_stretched-link.scss +0 -19
  146. data/assets/stylesheets/bootstrap/utilities/_text.scss +0 -72
  147. data/assets/stylesheets/bootstrap/utilities/_visibility.scss +0 -13
  148. data/test/dummy_rails/app/views/pages/root.html.slim +0 -58
  149. /data/assets/stylesheets/bootstrap/{utilities → helpers}/_clearfix.scss +0 -0
@@ -1,347 +1,9 @@
1
- // stylelint-disable selector-no-qualifying-type
2
-
3
- //
4
- // Textual form controls
5
- //
6
-
7
- .form-control {
8
- display: block;
9
- width: 100%;
10
- height: $input-height;
11
- padding: $input-padding-y $input-padding-x;
12
- font-family: $input-font-family;
13
- @include font-size($input-font-size);
14
- font-weight: $input-font-weight;
15
- line-height: $input-line-height;
16
- color: $input-color;
17
- background-color: $input-bg;
18
- background-clip: padding-box;
19
- border: $input-border-width solid $input-border-color;
20
-
21
- // Note: This has no effect on <select>s in some browsers, due to the limited stylability of `<select>`s in CSS.
22
- @include border-radius($input-border-radius, 0);
23
-
24
- @include box-shadow($input-box-shadow);
25
- @include transition($input-transition);
26
-
27
- // Unstyle the caret on `<select>`s in IE10+.
28
- &::-ms-expand {
29
- background-color: transparent;
30
- border: 0;
31
- }
32
-
33
- // Customize the `:focus` state to imitate native WebKit styles.
34
- @include form-control-focus($ignore-warning: true);
35
-
36
- // Placeholder
37
- &::placeholder {
38
- color: $input-placeholder-color;
39
- // Override Firefox's unusual default opacity; see https://github.com/twbs/bootstrap/pull/11526.
40
- opacity: 1;
41
- }
42
-
43
- // Disabled and read-only inputs
44
- //
45
- // HTML5 says that controls under a fieldset > legend:first-child won't be
46
- // disabled if the fieldset is disabled. Due to implementation difficulty, we
47
- // don't honor that edge case; we style them as disabled anyway.
48
- &:disabled,
49
- &[readonly] {
50
- background-color: $input-disabled-bg;
51
- // iOS fix for unreadable disabled content; see https://github.com/twbs/bootstrap/issues/11655.
52
- opacity: 1;
53
- }
54
- }
55
-
56
- input[type="date"],
57
- input[type="time"],
58
- input[type="datetime-local"],
59
- input[type="month"] {
60
- &.form-control {
61
- appearance: none; // Fix appearance for date inputs in Safari
62
- }
63
- }
64
-
65
- select.form-control {
66
- // Remove select outline from select box in FF
67
- &:-moz-focusring {
68
- color: transparent;
69
- text-shadow: 0 0 0 $input-color;
70
- }
71
-
72
- &:focus::-ms-value {
73
- // Suppress the nested default white text on blue background highlight given to
74
- // the selected option text when the (still closed) <select> receives focus
75
- // in IE and (under certain conditions) Edge, as it looks bad and cannot be made to
76
- // match the appearance of the native widget.
77
- // See https://github.com/twbs/bootstrap/issues/19398.
78
- color: $input-color;
79
- background-color: $input-bg;
80
- }
81
- }
82
-
83
- // Make file inputs better match text inputs by forcing them to new lines.
84
- .form-control-file,
85
- .form-control-range {
86
- display: block;
87
- width: 100%;
88
- }
89
-
90
-
91
- //
92
- // Labels
93
- //
94
-
95
- // For use with horizontal and inline forms, when you need the label (or legend)
96
- // text to align with the form controls.
97
- .col-form-label {
98
- padding-top: add($input-padding-y, $input-border-width);
99
- padding-bottom: add($input-padding-y, $input-border-width);
100
- margin-bottom: 0; // Override the `<label>/<legend>` default
101
- @include font-size(inherit); // Override the `<legend>` default
102
- line-height: $input-line-height;
103
- }
104
-
105
- .col-form-label-lg {
106
- padding-top: add($input-padding-y-lg, $input-border-width);
107
- padding-bottom: add($input-padding-y-lg, $input-border-width);
108
- @include font-size($input-font-size-lg);
109
- line-height: $input-line-height-lg;
110
- }
111
-
112
- .col-form-label-sm {
113
- padding-top: add($input-padding-y-sm, $input-border-width);
114
- padding-bottom: add($input-padding-y-sm, $input-border-width);
115
- @include font-size($input-font-size-sm);
116
- line-height: $input-line-height-sm;
117
- }
118
-
119
-
120
- // Readonly controls as plain text
121
- //
122
- // Apply class to a readonly input to make it appear like regular plain
123
- // text (without any border, background color, focus indicator)
124
-
125
- .form-control-plaintext {
126
- display: block;
127
- width: 100%;
128
- padding: $input-padding-y 0;
129
- margin-bottom: 0; // match inputs if this class comes on inputs with default margins
130
- @include font-size($input-font-size);
131
- line-height: $input-line-height;
132
- color: $input-plaintext-color;
133
- background-color: transparent;
134
- border: solid transparent;
135
- border-width: $input-border-width 0;
136
-
137
- &.form-control-sm,
138
- &.form-control-lg {
139
- padding-right: 0;
140
- padding-left: 0;
141
- }
142
- }
143
-
144
-
145
- // Form control sizing
146
- //
147
- // Build on `.form-control` with modifier classes to decrease or increase the
148
- // height and font-size of form controls.
149
- //
150
- // Repeated in `_input_group.scss` to avoid Sass extend issues.
151
-
152
- .form-control-sm {
153
- height: $input-height-sm;
154
- padding: $input-padding-y-sm $input-padding-x-sm;
155
- @include font-size($input-font-size-sm);
156
- line-height: $input-line-height-sm;
157
- @include border-radius($input-border-radius-sm);
158
- }
159
-
160
- .form-control-lg {
161
- height: $input-height-lg;
162
- padding: $input-padding-y-lg $input-padding-x-lg;
163
- @include font-size($input-font-size-lg);
164
- line-height: $input-line-height-lg;
165
- @include border-radius($input-border-radius-lg);
166
- }
167
-
168
- // stylelint-disable-next-line no-duplicate-selectors
169
- select.form-control {
170
- &[size],
171
- &[multiple] {
172
- height: auto;
173
- }
174
- }
175
-
176
- textarea.form-control {
177
- height: auto;
178
- }
179
-
180
- // Form groups
181
- //
182
- // Designed to help with the organization and spacing of vertical forms. For
183
- // horizontal forms, use the predefined grid classes.
184
-
185
- .form-group {
186
- margin-bottom: $form-group-margin-bottom;
187
- }
188
-
189
- .form-text {
190
- display: block;
191
- margin-top: $form-text-margin-top;
192
- }
193
-
194
-
195
- // Form grid
196
- //
197
- // Special replacement for our grid system's `.row` for tighter form layouts.
198
-
199
- .form-row {
200
- display: flex;
201
- flex-wrap: wrap;
202
- margin-right: -$form-grid-gutter-width * .5;
203
- margin-left: -$form-grid-gutter-width * .5;
204
-
205
- > .col,
206
- > [class*="col-"] {
207
- padding-right: $form-grid-gutter-width * .5;
208
- padding-left: $form-grid-gutter-width * .5;
209
- }
210
- }
211
-
212
-
213
- // Checkboxes and radios
214
- //
215
- // Indent the labels to position radios/checkboxes as hanging controls.
216
-
217
- .form-check {
218
- position: relative;
219
- display: block;
220
- padding-left: $form-check-input-gutter;
221
- }
222
-
223
- .form-check-input {
224
- position: absolute;
225
- margin-top: $form-check-input-margin-y;
226
- margin-left: -$form-check-input-gutter;
227
-
228
- // Use [disabled] and :disabled for workaround https://github.com/twbs/bootstrap/issues/28247
229
- &[disabled] ~ .form-check-label,
230
- &:disabled ~ .form-check-label {
231
- color: $text-muted;
232
- }
233
- }
234
-
235
- .form-check-label {
236
- margin-bottom: 0; // Override default `<label>` bottom margin
237
- }
238
-
239
- .form-check-inline {
240
- display: inline-flex;
241
- align-items: center;
242
- padding-left: 0; // Override base .form-check
243
- margin-right: $form-check-inline-margin-x;
244
-
245
- // Undo .form-check-input defaults and add some `margin-right`.
246
- .form-check-input {
247
- position: static;
248
- margin-top: 0;
249
- margin-right: $form-check-inline-input-margin-x;
250
- margin-left: 0;
251
- }
252
- }
253
-
254
-
255
- // Form validation
256
- //
257
- // Provide feedback to users when form field values are valid or invalid. Works
258
- // primarily for client-side validation via scoped `:invalid` and `:valid`
259
- // pseudo-classes but also includes `.is-invalid` and `.is-valid` classes for
260
- // server side validation.
261
-
262
- @each $state, $data in $form-validation-states {
263
- @include form-validation-state($state, map-get($data, color), map-get($data, icon));
264
- }
265
-
266
- // Inline forms
267
- //
268
- // Make forms appear inline(-block) by adding the `.form-inline` class. Inline
269
- // forms begin stacked on extra small (mobile) devices and then go inline when
270
- // viewports reach <768px.
271
- //
272
- // Requires wrapping inputs and labels with `.form-group` for proper display of
273
- // default HTML form controls and our custom form controls (e.g., input groups).
274
-
275
- .form-inline {
276
- display: flex;
277
- flex-flow: row wrap;
278
- align-items: center; // Prevent shorter elements from growing to same height as others (e.g., small buttons growing to normal sized button height)
279
-
280
- // Because we use flex, the initial sizing of checkboxes is collapsed and
281
- // doesn't occupy the full-width (which is what we want for xs grid tier),
282
- // so we force that here.
283
- .form-check {
284
- width: 100%;
285
- }
286
-
287
- // Kick in the inline
288
- @include media-breakpoint-up(sm) {
289
- label {
290
- display: flex;
291
- align-items: center;
292
- justify-content: center;
293
- margin-bottom: 0;
294
- }
295
-
296
- // Inline-block all the things for "inline"
297
- .form-group {
298
- display: flex;
299
- flex: 0 0 auto;
300
- flex-flow: row wrap;
301
- align-items: center;
302
- margin-bottom: 0;
303
- }
304
-
305
- // Allow folks to *not* use `.form-group`
306
- .form-control {
307
- display: inline-block;
308
- width: auto; // Prevent labels from stacking above inputs in `.form-group`
309
- vertical-align: middle;
310
- }
311
-
312
- // Make static controls behave like regular ones
313
- .form-control-plaintext {
314
- display: inline-block;
315
- }
316
-
317
- .input-group,
318
- .custom-select {
319
- width: auto;
320
- }
321
-
322
- // Remove default margin on radios/checkboxes that were used for stacking, and
323
- // then undo the floating of radios and checkboxes to match.
324
- .form-check {
325
- display: flex;
326
- align-items: center;
327
- justify-content: center;
328
- width: auto;
329
- padding-left: 0;
330
- }
331
- .form-check-input {
332
- position: relative;
333
- flex-shrink: 0;
334
- margin-top: 0;
335
- margin-right: $form-check-input-margin-x;
336
- margin-left: 0;
337
- }
338
-
339
- .custom-control {
340
- align-items: center;
341
- justify-content: center;
342
- }
343
- .custom-control-label {
344
- margin-bottom: 0;
345
- }
346
- }
347
- }
1
+ @import "forms/labels";
2
+ @import "forms/form-text";
3
+ @import "forms/form-control";
4
+ @import "forms/form-select";
5
+ @import "forms/form-check";
6
+ @import "forms/form-range";
7
+ @import "forms/floating-labels";
8
+ @import "forms/input-group";
9
+ @import "forms/validation";
@@ -32,6 +32,29 @@
32
32
  }
33
33
  }
34
34
 
35
+ // Internal Bootstrap function to turn maps into its negative variant.
36
+ // It prefixes the keys with `n` and makes the value negative.
37
+ @function negativify-map($map) {
38
+ $result: ();
39
+ @each $key, $value in $map {
40
+ @if $key != 0 {
41
+ $result: map-merge($result, ("n" + $key: (-$value)));
42
+ }
43
+ }
44
+ @return $result;
45
+ }
46
+
47
+ // Get multiple keys from a sass map
48
+ @function map-get-multiple($map, $values) {
49
+ $result: ();
50
+ @each $key, $value in $map {
51
+ @if (index($values, $key) != null) {
52
+ $result: map-merge($result, ($key: $value));
53
+ }
54
+ }
55
+ @return $result;
56
+ }
57
+
35
58
  // Replace `$search` with `$replace` in `$string`
36
59
  // Used on our SVG icon backgrounds for custom forms.
37
60
  //
@@ -70,41 +93,79 @@
70
93
  }
71
94
 
72
95
  // Color contrast
73
- @function color-yiq($color, $dark: $yiq-text-dark, $light: $yiq-text-light) {
74
- $r: red($color);
75
- $g: green($color);
76
- $b: blue($color);
96
+ // See https://github.com/twbs/bootstrap/pull/30168
97
+
98
+ // A list of pre-calculated numbers of pow(($value / 255 + .055) / 1.055, 2.4). (from 0 to 255)
99
+ // stylelint-disable-next-line scss/dollar-variable-default, scss/dollar-variable-pattern
100
+ $_luminance-list: .0008 .001 .0011 .0013 .0015 .0017 .002 .0022 .0025 .0027 .003 .0033 .0037 .004 .0044 .0048 .0052 .0056 .006 .0065 .007 .0075 .008 .0086 .0091 .0097 .0103 .011 .0116 .0123 .013 .0137 .0144 .0152 .016 .0168 .0176 .0185 .0194 .0203 .0212 .0222 .0232 .0242 .0252 .0262 .0273 .0284 .0296 .0307 .0319 .0331 .0343 .0356 .0369 .0382 .0395 .0409 .0423 .0437 .0452 .0467 .0482 .0497 .0513 .0529 .0545 .0561 .0578 .0595 .0612 .063 .0648 .0666 .0685 .0704 .0723 .0742 .0762 .0782 .0802 .0823 .0844 .0865 .0887 .0908 .0931 .0953 .0976 .0999 .1022 .1046 .107 .1095 .1119 .1144 .117 .1195 .1221 .1248 .1274 .1301 .1329 .1356 .1384 .1413 .1441 .147 .15 .1529 .1559 .159 .162 .1651 .1683 .1714 .1746 .1779 .1812 .1845 .1878 .1912 .1946 .1981 .2016 .2051 .2086 .2122 .2159 .2195 .2232 .227 .2307 .2346 .2384 .2423 .2462 .2502 .2542 .2582 .2623 .2664 .2705 .2747 .2789 .2831 .2874 .2918 .2961 .3005 .305 .3095 .314 .3185 .3231 .3278 .3325 .3372 .3419 .3467 .3515 .3564 .3613 .3663 .3712 .3763 .3813 .3864 .3916 .3968 .402 .4072 .4125 .4179 .4233 .4287 .4342 .4397 .4452 .4508 .4564 .4621 .4678 .4735 .4793 .4851 .491 .4969 .5029 .5089 .5149 .521 .5271 .5333 .5395 .5457 .552 .5583 .5647 .5711 .5776 .5841 .5906 .5972 .6038 .6105 .6172 .624 .6308 .6376 .6445 .6514 .6584 .6654 .6724 .6795 .6867 .6939 .7011 .7084 .7157 .7231 .7305 .7379 .7454 .7529 .7605 .7682 .7758 .7835 .7913 .7991 .807 .8148 .8228 .8308 .8388 .8469 .855 .8632 .8714 .8796 .8879 .8963 .9047 .9131 .9216 .9301 .9387 .9473 .956 .9647 .9734 .9823 .9911 1;
101
+
102
+ @function color-contrast($background, $color-contrast-dark: $color-contrast-dark, $color-contrast-light: $color-contrast-light, $min-contrast-ratio: $min-contrast-ratio) {
103
+ $foregrounds: $color-contrast-light, $color-contrast-dark, $white, $black;
104
+ $max-ratio: 0;
105
+ $max-ratio-color: null;
106
+
107
+ @each $color in $foregrounds {
108
+ $contrast-ratio: contrast-ratio($background, $color);
109
+ @if $contrast-ratio > $min-contrast-ratio {
110
+ @return $color;
111
+ } @else if $contrast-ratio > $max-ratio {
112
+ $max-ratio: $contrast-ratio;
113
+ $max-ratio-color: $color;
114
+ }
115
+ }
77
116
 
78
- $yiq: (($r * 299) + ($g * 587) + ($b * 114)) * .001;
117
+ @warn "Found no color leading to #{$min-contrast-ratio}:1 contrast ratio against #{$background}...";
79
118
 
80
- @if ($yiq >= $yiq-contrasted-threshold) {
81
- @return $dark;
82
- } @else {
83
- @return $light;
84
- }
119
+ @return $max-ratio-color;
85
120
  }
86
121
 
87
- // Retrieve color Sass maps
88
- @function color($key: "blue") {
89
- @return map-get($colors, $key);
122
+ @function contrast-ratio($background, $foreground: $color-contrast-light) {
123
+ $l1: luminance($background);
124
+ $l2: luminance(opaque($background, $foreground));
125
+
126
+ @return if($l1 > $l2, ($l1 + .05) / ($l2 + .05), ($l2 + .05) / ($l1 + .05));
90
127
  }
91
128
 
92
- @function theme-color($key: "primary") {
93
- @return map-get($theme-colors, $key);
129
+ // Return WCAG2.0 relative luminance
130
+ // See https://www.w3.org/WAI/GL/wiki/Relative_luminance
131
+ // See https://www.w3.org/TR/WCAG20-TECHS/G17.html#G17-tests
132
+ @function luminance($color) {
133
+ $rgb: (
134
+ "r": red($color),
135
+ "g": green($color),
136
+ "b": blue($color)
137
+ );
138
+
139
+ @each $name, $value in $rgb {
140
+ $value: if($value / 255 < .03928, $value / 255 / 12.92, nth($_luminance-list, $value + 1));
141
+ $rgb: map-merge($rgb, ($name: $value));
142
+ }
143
+
144
+ @return (map-get($rgb, "r") * .2126) + (map-get($rgb, "g") * .7152) + (map-get($rgb, "b") * .0722);
145
+ }
146
+
147
+ // Return opaque color
148
+ // opaque(#fff, rgba(0, 0, 0, .5)) => #808080
149
+ @function opaque($background, $foreground) {
150
+ @return mix(rgba($foreground, 1), $background, opacity($foreground) * 100);
94
151
  }
95
152
 
96
- @function gray($key: "100") {
97
- @return map-get($grays, $key);
153
+ // scss-docs-start color-functions
154
+ // Tint a color: mix a color with white
155
+ @function tint-color($color, $weight) {
156
+ @return mix(white, $color, $weight);
98
157
  }
99
158
 
100
- // Request a theme color level
101
- @function theme-color-level($color-name: "primary", $level: 0) {
102
- $color: theme-color($color-name);
103
- $color-base: if($level > 0, $black, $white);
104
- $level: abs($level);
159
+ // Shade a color: mix a color with black
160
+ @function shade-color($color, $weight) {
161
+ @return mix(black, $color, $weight);
162
+ }
105
163
 
106
- @return mix($color-base, $color, $level * $theme-color-interval);
164
+ // Shade the color if the weight is positive, else tint it
165
+ @function shift-color($color, $weight) {
166
+ @return if($weight > 0, shade-color($color, $weight), tint-color($color, -$weight));
107
167
  }
168
+ // scss-docs-end color-functions
108
169
 
109
170
  // Return valid calc
110
171
  @function add($value1, $value2, $return-calc: true) {
@@ -140,51 +201,5 @@
140
201
  @return $value1 - $value2;
141
202
  }
142
203
 
143
- @if type-of($value2) != number {
144
- $value2: unquote("(") + $value2 + unquote(")");
145
- }
146
-
147
204
  @return if($return-calc == true, calc(#{$value1} - #{$value2}), $value1 + unquote(" - ") + $value2);
148
205
  }
149
-
150
- @function divide($dividend, $divisor, $precision: 10) {
151
- $sign: if($dividend > 0 and $divisor > 0 or $dividend < 0 and $divisor < 0, 1, -1);
152
- $dividend: abs($dividend);
153
- $divisor: abs($divisor);
154
- @if $dividend == 0 {
155
- @return 0;
156
- }
157
- @if $divisor == 0 {
158
- @error "Cannot divide by 0";
159
- }
160
- $remainder: $dividend;
161
- $result: 0;
162
- $factor: 10;
163
- @while ($remainder > 0 and $precision >= 0) {
164
- $quotient: 0;
165
- @while ($remainder >= $divisor) {
166
- $remainder: $remainder - $divisor;
167
- $quotient: $quotient + 1;
168
- }
169
- $result: $result * 10 + $quotient;
170
- $factor: $factor * .1;
171
- $remainder: $remainder * 10;
172
- $precision: $precision - 1;
173
- @if ($precision < 0 and $remainder >= $divisor * 5) {
174
- $result: $result + 1;
175
- }
176
- }
177
- $result: $result * $factor * $sign;
178
- $dividend-unit: unit($dividend);
179
- $divisor-unit: unit($divisor);
180
- $unit-map: (
181
- "px": 1px,
182
- "rem": 1rem,
183
- "em": 1em,
184
- "%": 1%
185
- );
186
- @if ($dividend-unit != $divisor-unit and map-has-key($unit-map, $dividend-unit)) {
187
- $result: $result * map-get($unit-map, $dividend-unit);
188
- }
189
- @return $result;
190
- }
@@ -1,46 +1,3 @@
1
- // Container widths
2
- //
3
- // Set the container width, and override it for fixed navbars in media queries.
4
-
5
- @if $enable-grid-classes {
6
- // Single container class with breakpoint max-widths
7
- .container,
8
- // 100% wide container at all breakpoints
9
- .container-fluid {
10
- @include make-container();
11
- }
12
-
13
- // Responsive containers that are 100% wide until a breakpoint
14
- @each $breakpoint, $container-max-width in $container-max-widths {
15
- .container-#{$breakpoint} {
16
- @extend .container-fluid;
17
- }
18
-
19
- @include media-breakpoint-up($breakpoint, $grid-breakpoints) {
20
- %responsive-container-#{$breakpoint} {
21
- max-width: $container-max-width;
22
- }
23
-
24
- // Extend each breakpoint which is smaller or equal to the current breakpoint
25
- $extend-breakpoint: true;
26
-
27
- @each $name, $width in $grid-breakpoints {
28
- @if ($extend-breakpoint) {
29
- .container#{breakpoint-infix($name, $grid-breakpoints)} {
30
- @extend %responsive-container-#{$breakpoint};
31
- }
32
-
33
- // Once the current breakpoint is reached, stop extending
34
- @if ($breakpoint == $name) {
35
- $extend-breakpoint: false;
36
- }
37
- }
38
- }
39
- }
40
- }
41
- }
42
-
43
-
44
1
  // Row
45
2
  //
46
3
  // Rows contain your columns.
@@ -48,22 +5,14 @@
48
5
  @if $enable-grid-classes {
49
6
  .row {
50
7
  @include make-row();
51
- }
52
8
 
53
- // Remove the negative margin from default .row, then the horizontal padding
54
- // from all immediate children columns (to prevent runaway style inheritance).
55
- .no-gutters {
56
- margin-right: 0;
57
- margin-left: 0;
58
-
59
- > .col,
60
- > [class*="col-"] {
61
- padding-right: 0;
62
- padding-left: 0;
9
+ > * {
10
+ @include make-col-ready();
63
11
  }
64
12
  }
65
13
  }
66
14
 
15
+
67
16
  // Columns
68
17
  //
69
18
  // Common styles for small and large grid columns
@@ -0,0 +1,7 @@
1
+ @import "helpers/clearfix";
2
+ @import "helpers/colored-links";
3
+ @import "helpers/ratio";
4
+ @import "helpers/position";
5
+ @import "helpers/visually-hidden";
6
+ @import "helpers/stretched-link";
7
+ @import "helpers/text-truncation";
@@ -32,7 +32,7 @@
32
32
  }
33
33
 
34
34
  .figure-img {
35
- margin-bottom: $spacer * .5;
35
+ margin-bottom: $spacer / 2;
36
36
  line-height: 1;
37
37
  }
38
38
 
@@ -12,6 +12,17 @@
12
12
  @include border-radius($list-group-border-radius);
13
13
  }
14
14
 
15
+ .list-group-numbered {
16
+ list-style-type: none;
17
+ counter-reset: section;
18
+
19
+ > li::before {
20
+ // Increments only this instance of the section counter
21
+ content: counters(section, ".") ". ";
22
+ counter-increment: section;
23
+ }
24
+ }
25
+
15
26
 
16
27
  // Interactive list items
17
28
  //
@@ -24,7 +35,8 @@
24
35
  text-align: inherit; // For `<button>`s (anchors inherit)
25
36
 
26
37
  // Hover state
27
- @include hover-focus() {
38
+ &:hover,
39
+ &:focus {
28
40
  z-index: 1; // Place hover/focus items above their siblings for proper border styling
29
41
  color: $list-group-action-hover-color;
30
42
  text-decoration: none;
@@ -98,13 +110,13 @@
98
110
 
99
111
  > .list-group-item {
100
112
  &:first-child {
101
- @include border-bottom-left-radius($list-group-border-radius);
102
- @include border-top-right-radius(0);
113
+ @include border-bottom-start-radius($list-group-border-radius);
114
+ @include border-top-end-radius(0);
103
115
  }
104
116
 
105
117
  &:last-child {
106
- @include border-top-right-radius($list-group-border-radius);
107
- @include border-bottom-left-radius(0);
118
+ @include border-top-end-radius($list-group-border-radius);
119
+ @include border-bottom-start-radius(0);
108
120
  }
109
121
 
110
122
  &.active {
@@ -144,11 +156,19 @@
144
156
  }
145
157
 
146
158
 
147
- // Contextual variants
159
+ // scss-docs-start list-group-modifiers
160
+ // List group contextual variants
148
161
  //
149
162
  // Add modifier classes to change text and background color on individual items.
150
163
  // Organizationally, this must come after the `:hover` states.
151
164
 
152
- @each $color, $value in $theme-colors {
153
- @include list-group-item-variant($color, theme-color-level($color, -9), theme-color-level($color, 6));
165
+ @each $state, $value in $theme-colors {
166
+ $list-group-background: shift-color($value, $list-group-item-bg-scale);
167
+ $list-group-color: shift-color($value, $list-group-item-color-scale);
168
+ @if (contrast-ratio($list-group-background, $list-group-color) < $min-contrast-ratio) {
169
+ $list-group-color: mix($value, color-contrast($list-group-background), abs($list-group-item-color-scale));
170
+ }
171
+
172
+ @include list-group-item-variant($state, $list-group-background, $list-group-color);
154
173
  }
174
+ // scss-docs-end list-group-modifiers