2014-12-16 20:31:36 -08:00
---
2015-08-14 22:45:55 -07:00
layout: docs
2019-05-03 10:52:58 -07:00
title: Migrating to v5
description: Track and review changes to the Bootstrap source files, documentation, and components to help you migrate from v4 to v5.
2015-08-05 17:47:45 -07:00
group: migration
2019-01-08 18:33:28 +02:00
aliases: "/migration/"
2017-05-29 12:01:04 -07:00
toc: true
2014-12-16 20:31:36 -08:00
---
2020-10-13 09:58:06 +02:00
## v5.0.0-alpha3
### Colors
- The color system which worked with `color-level()` and `$theme-color-interval` was removed in favor of a new color system.
- All `lighten()` and `darken()` functions in our codebase are replaced by `tint-color()` and `shade-color()` . These functions will mix the color with either white or black instead of changing its lightness by a fixed amount.
- The `scale-color()` will either tint or shade a color depending on whether its weight parameter is positive or negative.
- See [this PR ](https://github.com/twbs/bootstrap/pull/30622 ) for more details.
2020-10-19 11:06:14 +02:00
- Spinners now honor `prefers-reduced-motion: reduce` by slowing down animations. [See #31882 ](https://github.com/twbs/bootstrap/pull/31882 ).
2020-10-13 09:58:06 +02:00
2020-10-19 11:00:37 +02:00
### Reboot
- Introduce `$enable-smooth-scroll` , which applies `scroll-behavior: smooth` globally—except for users asking for reduced motion through `prefers-reduced-motion` media query. [See #31877 ](https://github.com/twbs/bootstrap/pull/31877 )
2020-07-01 15:43:06 +03:00
## v5.0.0-alpha2
2020-07-03 12:38:11 +01:00
### Sass
2020-09-26 11:26:45 +03:00
- Added default parameters to each `border-radius` mixin. [See #31571 ](https://github.com/twbs/bootstrap/pull/31571 ).
2020-09-26 11:45:44 +03:00
- Updated the next breakpoint when targeting only the `xs` breakpoint. [See #31500 ](https://github.com/twbs/bootstrap/pull/31500 ).
2020-09-26 11:26:45 +03:00
- `box-shadow` mixins now allow `null` values and drop `none` from multiple arguments. [See #30394 ](https://github.com/twbs/bootstrap/pull/30394 ).
2020-07-13 11:40:27 -07:00
### Docs
- Renamed "Screen readers" helper page to "Visually hidden", and filename to `visually-hidden`
- Renamed "Checks" page to "Checks & radios", and filename to `checks-radios`
- Improved documentation of check/radio powered button groups
2020-09-26 01:15:12 +03:00
- Improved skip links in our docs.
- Redesigned docs navigation for larger tap targets on mobile and a streamlined subnav.
2020-09-26 11:26:45 +03:00
- [#31114 ](https://github.com/twbs/bootstrap/pull/31114 ): Improved form documentation with regards to accessibility.
2020-09-26 01:15:12 +03:00
### Layout
- Container horizontal padding updated to match the gutter size of `.row` s.
2020-09-26 11:26:45 +03:00
- [#31439 ](https://github.com/twbs/bootstrap/pull/31439 ): Removed `flex: 1 0 100%` from rows due to regressions in grid behavior.
2020-07-13 11:40:27 -07:00
### Reboot
- Updated `th` styling to use a default `null` value for `font-weight` and inherit `text-align` instead of setting explicitly.
2020-07-03 12:38:11 +01:00
2020-07-13 11:23:38 -07:00
### Colors
- Bumped color contrast ratio from 3:1 to 4.5:1.
- Set `$black` as color contrast color instead of `$gray-900` .
2020-09-26 11:45:44 +03:00
- Improved `$green` (and its theme alias `$success` ) color to reach a new minimum color contrast (moving from `#28a745` to `#198754` ).
2020-07-13 11:23:38 -07:00
- Improved `$cyan` (and its theme alias `$info` ) color to be more vibrant (moving from `#17a2b8` to `#0dcaf0` ).
2020-08-03 09:42:31 -07:00
### Forms
2020-09-26 11:26:45 +03:00
- [#31383 ](https://github.com/twbs/bootstrap/pull/31383 ): Resized checks and radios to be `1em` instead of `1.25em` in an effort to make them scale better with custom `$font-size-base` values and more.
2020-08-03 09:42:31 -07:00
2020-07-01 15:43:06 +03:00
### Components
2020-09-26 01:15:12 +03:00
#### Badges
2020-08-02 14:28:23 +01:00
2020-09-26 11:26:45 +03:00
- [#31132 ](https://github.com/twbs/bootstrap/pull/31132 ): Increased default padding for badges from `.25em` /`.5em` to `.35em` /`.65em` .
2020-08-02 14:28:23 +01:00
2020-07-12 06:56:33 +02:00
#### Buttons
2020-09-26 01:15:12 +03:00
- [#30639 ](https://github.com/twbs/bootstrap/pull/30639 ): Disabled states of buttons are easier to customize thanks to additional arguments in the `button-variant()` mixin.
2020-09-26 11:26:45 +03:00
- [#30989 ](https://github.com/twbs/bootstrap/pull/30989 ): Updated buttons to ensure increased contrast on hover and active states.
2020-09-26 01:15:12 +03:00
#### Carousel
2020-09-26 11:26:45 +03:00
- Replaced chevron icons for carousel controls with new SVGs from [Bootstrap Icons ]({{< param "icons" >}} ).
- Added new [`.carousel-dark` variant ]({{< docsref "/components/carousel#dark-variant" >}} ) for dark text, controls, and indicators (great for lighter backgrounds).
2020-07-12 06:56:33 +02:00
2020-09-13 19:14:45 -07:00
#### Close button
- Renamed `.close` to `.btn-close` for a less generic name.
- Close buttons now use a `background-image` (embedded SVG) instead of a `×` in the HTML, allowing for easier customization without the need to touch your markup.
- Added new variables to better control the customization.
2020-09-30 20:57:00 +09:00
- Added new `.btn-close-white` variant that uses `filter: invert(1)` to enable higher contrast dismiss icons against darker backgrounds.
2020-09-13 19:14:45 -07:00
2020-09-26 01:15:12 +03:00
#### Collapse
2020-09-26 11:26:45 +03:00
- [#31346 ](https://github.com/twbs/bootstrap/pull/31346 ): Removed scroll anchoring for accordions.
2020-09-26 01:15:12 +03:00
#### Dropdowns
- Added new `.dropdown-menu-dark` variant and associated variables for on-demand dark dropdowns.
- Added new variable for `$dropdown-padding-x` .
- Darkened the dropdown divider for improved contrast.
2020-07-13 11:40:27 -07:00
#### Navs
2020-09-26 11:26:45 +03:00
- [#31035 ](https://github.com/twbs/bootstrap/pull/31035 ): Added new `null` variables for `font-size` , `font-weight` , `color` , and `:hover` `color` to the `.nav-link` class.
2020-09-26 01:15:12 +03:00
#### Pagination
2020-09-26 11:26:45 +03:00
- Added `transition` s to pagination links. [See #31396 ](https://github.com/twbs/bootstrap/pull/31396 ).
2020-07-13 11:40:27 -07:00
2020-07-01 15:43:06 +03:00
#### Popovers
2020-08-03 09:42:31 -07:00
- Renamed `whiteList` option to `allowList` .
2020-07-01 15:43:06 +03:00
2020-07-12 18:13:26 +05:30
#### Toasts
2020-09-26 11:26:45 +03:00
- [#31109 ](https://github.com/twbs/bootstrap/pull/31109 ): Made default toast duration 5 seconds.
- [#31155 ](https://github.com/twbs/bootstrap/pull/31155 ): Clear `timeout` before showing toasts.
- [#31381 ](https://github.com/twbs/bootstrap/pull/31381 ): Removed `overflow: hidden` from toasts and replaced with proper `border-radius` s with `calc()` functions.
2020-09-26 01:15:12 +03:00
- Updated docs to include additional examples for how to customize and theme toasts.
2020-07-12 18:13:26 +05:30
2020-07-01 15:43:06 +03:00
#### Tooltips
2020-08-03 09:42:31 -07:00
- Renamed `whiteList` option to `allowList` .
2020-07-01 15:43:06 +03:00
2020-09-21 14:15:15 -07:00
### Helpers
2020-09-22 16:30:00 -07:00
- Responsive embed helpers have been renamed to [ratio helpers ]({{< docsref "/helpers/ratio" >}} ) with new class names and improved behaviors, as well as a helpful CSS variable.
2020-09-26 11:45:44 +03:00
- Classes have been renamed to change `by` to `x` in the aspect ratio. For example, `.ratio-16by9` is now `.ratio-16x9` .
- We've dropped the `.embed-responsive-item` and element group selector in favor of a simpler `.ratio > *` selector. No more class is needed, and the ratio helper now works with any HTML element.
2020-09-22 16:30:00 -07:00
- The `$embed-responsive-aspect-ratios` Sass map has been renamed to `$aspect-ratios` and its values have been simplified to include the class name and the percentage as the `key: value` pair.
- CSS variables are now generated and included for each value in the Sass map. Modify the `--aspect-ratio` variable on the `.ratio` to create any [custom aspect ratio ]({{< docsref "/helpers/ratio#custom-ratios" >}} ).
2020-09-26 11:26:45 +03:00
- "Screen reader" classes are now ["visually hidden" classes ]({{< docsref "/helpers/visually-hidden" >}} ).
2020-09-26 01:15:12 +03:00
- Changed the Sass file from `scss/helpers/_screenreaders.scss` to `scss/helpers/_visually-hidden.scss`
- Renamed `.sr-only` and `.sr-only-focusable` to `.visually-hidden` and `.visually-hidden-focusable`
- Renamed `sr-only()` and `sr-only-focusable()` mixins to `visually-hidden()` and `visually-hidden-focusable()` .
### Utilities
2020-09-26 11:26:45 +03:00
- [#31280 ](https://github.com/twbs/bootstrap/pull/31280 ): Added new [position utilities ]({{< docsref "/utilities/position#arrange-elements" >}} ) for `top` , `right` , `bottom` , and `left` . Values include `0` , `50%` , and `100%` for each property.
2020-09-26 01:15:12 +03:00
- We also added new `translate` utilities to accompany those position utilities for centering elements when they're being positioned.
- Some great examples have been added to the docs to show these off.
2020-09-26 11:26:45 +03:00
- [#31484 ](https://github.com/twbs/bootstrap/pull/31484 ): Added new [`border-width` utility ]({{< docsref "/utilities/borders#border-width" >}} ).
- [#31473 ](https://github.com/twbs/bootstrap/pull/31473 ): The `.d-none` utility was moved in our CSS to give it more weight over other display utilities.
2020-09-21 14:15:15 -07:00
2020-07-01 15:43:06 +03:00
---
## v5.0.0-alpha1
### Browser support
2018-01-17 17:29:28 -08:00
2019-05-03 10:52:58 -07:00
See the browser and devices page for details on what is currently supported in Bootstrap 5. Since v4, here's what's changed to our browser support:
2018-01-17 17:29:28 -08:00
2020-03-09 15:37:46 +02:00
- Dropped support for Internet Explorer 10 and 11
2020-07-01 15:43:06 +03:00
- Dropped support for Microsoft Edge < 16
- Dropped support for Firefox < 60
- Dropped support for Safari < 10
- Dropped support for iOS Safari < 10
- Dropped support for Chrome < 60
- Dropped support for Android < 6
2018-01-17 17:29:28 -08:00
2020-07-01 15:43:06 +03:00
### Sass
2018-01-17 17:29:28 -08:00
2019-05-03 10:52:58 -07:00
Changes to our source Sass files and compiled CSS.
2018-01-17 17:29:28 -08:00
2018-09-18 02:10:07 +03:00
- Removed `hover` , `hover-focus` , `plain-hover-focus` , and `hover-focus-active` mixins. Use regular CSS syntax for these moving forward. [See #28267 ](https://github.com/twbs/bootstrap/pull/28267 ).
2019-08-21 10:33:26 +02:00
- Remove previously deprecated mixins
2019-05-03 10:52:58 -07:00
- `float()`
- `form-control-mixin()`
2019-08-21 10:33:26 +02:00
- `nav-divider()`
2019-05-03 10:52:58 -07:00
- `retina-img()`
- `text-hide()` (also dropped the associated utility class, `.text-hide` )
- `visibility()`
2019-12-14 14:27:59 +01:00
- `form-control-focus()`
2020-08-03 09:42:31 -07:00
- Rearranged forms source files under `scss/forms/` . [See Forms section for more details. ](#forms )
2019-05-08 22:57:59 -07:00
- Removed print styles and `$enable-print-styles` variable. Print display classes, however, have remained intact. [See #28339 ](https://github.com/twbs/bootstrap/pull/28339 ).
2019-07-25 09:41:13 +02:00
- Dropped `color()` , `theme-color()` & `gray()` functions in favor of variables. [See #29083 ](https://github.com/twbs/bootstrap/pull/29083 )
2020-10-13 09:58:06 +02:00
- The `theme-color-level()` function is renamed to `color-level()` and now accepts any color you want instead of only `$theme-color` colors. [See #29083 ](https://github.com/twbs/bootstrap/pull/29083 ) **Watch out:** `color-level()` was later on dropped in `v5.0.0-alpha3` .
2020-02-03 21:02:53 +01:00
- `$enable-grid-classes` doesn't disable the generation of container classes anymore [See #29146 ](https://github.com/twbs/bootstrap/pull/29146 )
2020-04-13 17:48:19 -07:00
- Renamed `$enable-prefers-reduced-motion-media-query` and `$enable-pointer-cursor-for-buttons` to `$enable-reduced-motion` and `$enable-button-pointers` for brevity.
2019-08-30 09:42:41 +02:00
- Line heights are dropped from several components to simplify our codebase. The `button-size()` and `pagination-size()` do not accept line height parameters anymore. [See #29271 ](https://github.com/twbs/bootstrap/pull/29271 )
2020-03-23 18:03:56 +01:00
- The `button-variant()` mixin now accepts 3 optional color parameters, for each button state, to override the color provided by `color-contrast()` . By default, these parameters will find which color provides more contrast against the button state's background color with `color-contrast()` .
- The `button-outline-variant()` mixin now accepts an additional argument, `$active-color` , for setting the button's active state text color. By default, this parameter will find which color provides more contrast against the button's active background color with `color-contrast()` .
2020-04-13 17:55:33 -07:00
- Ditch the Sass map merges, which makes it easier to remove redundant values. Keep in mind you now have to define all values in the Sass maps like `$theme-colors` . Check out how to deal with [Sass maps ]({{< docsref "/customize/sass#maps-and-loops" >}} ).
- `color-yiq()` function and related variables are renamed to `color-contrast()` since it's not related to YIQ colorspace anymore. [See #30168. ](https://github.com/twbs/bootstrap/pull/30168/ )
2020-04-15 14:13:45 +03:00
- `$yiq-contrasted-threshold` is renamed to `$min-contrast-ratio` .
- `$yiq-text-dark` and `$yiq-text-light` are respectively renamed to `$color-contrast-dark` and `$color-contrast-light` .
2020-04-14 17:28:20 +03:00
- Linear gradients are simplified when gradients are enabled and therefore, `gradient-bg()` now only accepts an optional `$color` parameter.
2020-04-15 14:13:45 +03:00
- The `bg-gradient-variant()` mixin is removed since the `.bg-gradient` class can now be used to add gradients to elements instead of the `.bg-gradient-*` classes.
2020-04-18 13:02:26 +02:00
- The `media-breakpoint-down()` uses the breakpoint itself instead of the next breakpoint. Use `media-breakpoint-down(lg)` instead of `media-breakpoint-down(md)` to target viewports smaller than the `lg` breakpoint.
- The `media-breakpoint-between()` mixin's second parameter also uses the breakpoint itself instead of the next breakpoint. Use `media-between(sm, lg)` instead of `media-breakpoint-between(sm, md)` to target viewports between the `sm` and `lg` breakpoints.
2020-09-26 11:45:44 +03:00
- The `box-shadow()` mixin now better supports `none` and `null` with multiple arguments. Now you can pass multiple arguments with either value and get the expected output. [See #30394 ](https://github.com/twbs/bootstrap/pull/30394 ).
2020-09-01 21:17:17 +00:00
- Each `border-radius()` mixin now has a default value. You can now call these mixins without specifying a border radius value and the `$border-radius` variable will be used. [See #31571 ](https://github.com/twbs/bootstrap/pull/31571 )
2017-10-22 12:22:22 -07:00
2020-07-01 15:43:06 +03:00
### JavaScript
2017-10-22 12:22:22 -07:00
2019-05-03 10:52:58 -07:00
Changes to our source and compiled JavaScript files.
2017-12-22 16:13:01 -08:00
2019-05-03 10:52:58 -07:00
- Dropped jQuery dependency and rewrote plugins to be in regular JavaScript.
2019-07-29 12:17:42 +03:00
- Removed underscore from public static methods like `_getInstance()` → `getInstance()` .
2017-12-22 16:13:01 -08:00
2020-07-01 15:43:06 +03:00
### Color system
2020-04-13 17:55:33 -07:00
We've updated the color system that powers Bootstrap to improve color contrast and provide a much more extensive set of colors.
2020-07-01 15:43:06 +03:00
- Updated blue and pink base colors (`-500` ) to ensure WCAG 2.1 AA contrast.
2020-04-27 10:19:08 -07:00
- Added new tints and shades for every color, providing nine separate colors for each base color, as new Sass variables.
- To support our color system, we've added new custom `tint-color()` and `shade-color()` functions to mix our colors appropriately.
2020-04-13 17:55:33 -07:00
2020-07-01 15:43:06 +03:00
### Grid and layout
2017-12-22 16:13:01 -08:00
2019-05-03 10:52:58 -07:00
Changes to any layout tools and our grid system.
2017-12-22 16:13:01 -08:00
2020-04-15 14:13:45 +03:00
- Dropped the `.media` component as it can be built with utility classes. [See #28265 ](https://github.com/twbs/bootstrap/pull/28265 ).
2019-09-28 16:16:52 +02:00
- Remove `position: relative` from grid columns.
- The horizontal padding is added to the direct children in a row instead of the columns themselves.
- This simplifies our codebase.
2020-09-26 11:45:44 +03:00
- The column classes can now be used stand-alone. Whenever they are used outside a `.row` , horizontal padding won't be added.
2020-04-15 14:13:45 +03:00
- The responsive gutter classes can be used to control the gutter width in horizontal, vertical or both directions.
2019-09-28 16:16:52 +02:00
- The gutter width is now set in `rem` and decreased from `30px` to `1.5rem` (24px).
2020-04-15 14:13:45 +03:00
- `bootstrap-grid.css` now only applies `box-sizing: border-box` to the column instead of resetting the global box-sizing. This way the grid system can be used, even if `box-sizing: border-box` is not applied to each element.
2017-12-22 16:13:01 -08:00
2020-07-01 15:43:06 +03:00
### Content, Reboot, etc
2017-12-22 16:13:01 -08:00
2019-05-03 10:52:58 -07:00
Changes to Reboot, typography, tables, and more.
2017-12-22 16:13:01 -08:00
2019-11-01 11:22:29 +01:00
- [RFS ]({{< docsref "/getting-started/rfs" >}} ) enabled for automated font size rescaling. [See #29152 ](https://github.com/twbs/bootstrap/pull/29152 )
2019-07-15 09:31:50 -07:00
- Reset default horizontal `padding-left` on `<ul>` and `<ol>` elements from browser default `40px` to `2rem` .
2020-03-24 15:00:00 +01:00
- Simplified table styles (no more odd top border) and tightened cell padding.
- Nested tables do not inherit styles anymore.
- `.thead-light` and `.thead-dark` are dropped in favor of the `.table-*` variant classes which can be used for all table elements (`thead` , `tbody` , `tfoot` , `tr` , `th` and `td` ).
- The `table-row-variant()` mixin is renamed to `table-variant()` and accepts only 2 parameters: `$color` (colon name) and `$value` (color code). The border color and accent colors are automatically calculated based on the table factor variables.
2020-05-14 10:43:33 -07:00
- Split table cell padding variables into `-y` and `-x` .
2019-07-25 18:12:14 +02:00
- Dropped `.pre-scrollable` class. [See #29135 ](https://github.com/twbs/bootstrap/pull/29135 )
2019-08-17 20:19:00 +02:00
- `.text-*` utilities do not add hover and focus states to links anymore. `.link-*` helper classes can be used instead. [See #29267 ](https://github.com/twbs/bootstrap/pull/29267 )
2020-08-05 16:00:32 -07:00
- Drop `.text-justify` class. [See #29793 ](https://github.com/twbs/bootstrap/pull/29793 )
2017-10-22 12:22:22 -07:00
2020-07-01 15:43:06 +03:00
### Typography
2020-04-14 04:57:11 -07:00
- Removed `$display-*` variables for a new `$display-font-sizes` Sass map.
2020-06-17 18:53:11 +02:00
- Removed individual `$display-*-weight` variables for a single `$display-font-weight` .
2020-04-14 04:57:11 -07:00
- Added two new `.display-*` heading styles, `.display-5` and `.display-6` .
- Resized existing display headings for a slightly more consistent set of `font-size` s.
2020-07-01 15:43:06 +03:00
### Forms
2017-12-30 16:38:09 -08:00
v5: Forms update (#28450)
* Initial spike of consolidated form checks
* Stub out forms rearrangement
- Prepping to drop non-custom file and range inputs
- Prepping to merge custom and native checks and radios (with switches)
- Prepping to merge custom select with form select
- Moving docs arround so forms has it's own area given volume of CSS
* Move input group Sass file to forms subdir
* Start to split and move the docs around
* Simpler imports
* Copyediting
* delete overview file
* Remove commented out code
* remove the custom-forms import
* rewrite flex-check as form-check, replace all custom properties
* Remove old forms doc
* stub out new subpage link section
* update migration guide
* Update nav, forms overview in page nav, and descriptions
* fix check bg position
* fix margin-top calculation
* rename .custom-select to .form-select
* Update validation styles for new checks
* add some vertical margin, fix inline checks
* fix docs examples
* better way to do this contents stuff, redo the toc while i'm at it
* page restyle for docs while here
* un-callout that, edit text
* redo padding on toc
* fix toc
* start to cleanup checks docs
* Rewrite Markdown tables into HTML
* Redesign tables, redo their docs
* Replace Open Iconic icons with custom Bootstrap icons
* Redesign the docs navbar, add a subheader, redo the sidebar
* Redesign docs homepage a bit
* Simplify table style overrides for docs tables
* Simplify docs typography for page titles and reading line length
* Stub out icons page
* Part of sidebar update, remove migration from nav.yml
* Move toc CSS to separate partial
* Change appearance of overview page
* fix sidebar arrow direction
* Add footer to docs layout
* Update descriptions
* Drop the .form-group class for margin utilities
* Remove lingering form-group-margin-bottom var
* improve footer spacing
* add headings to range page
* uncomment form range css
* Rename .custom-range to .form-range
* Drop unused docs var
* Uncomment the comment
* Remove unused variable
* Fix radio image sizing
* Reboot update: reset horizontal ul and ol padding
* de-dupe IDs
* tweak toc styles
* nvm, fix dropdown versions stuff
* remove sidebar nav toggle for now
* broken html
* fix more broken html, move css
* scss linting
* comment out broken helper docs
* scope styles
* scope styles
* Fixes #25540 and fixes #26407 for v5 only
* Update sidebar once more
* Match new sidenav order
* fix syntax error
* Rename custom-file to form-file, update paths, update migration docs for previous changes in #28696
* rename back
* fix size and alignment
* rename that back too
2019-07-12 16:52:33 -05:00
- Rearranged form documentation under its own top-level section.
- Split out old Forms page into several subpages
2020-04-15 14:13:45 +03:00
- Moved input groups docs under the new Forms section
v5: Forms update (#28450)
* Initial spike of consolidated form checks
* Stub out forms rearrangement
- Prepping to drop non-custom file and range inputs
- Prepping to merge custom and native checks and radios (with switches)
- Prepping to merge custom select with form select
- Moving docs arround so forms has it's own area given volume of CSS
* Move input group Sass file to forms subdir
* Start to split and move the docs around
* Simpler imports
* Copyediting
* delete overview file
* Remove commented out code
* remove the custom-forms import
* rewrite flex-check as form-check, replace all custom properties
* Remove old forms doc
* stub out new subpage link section
* update migration guide
* Update nav, forms overview in page nav, and descriptions
* fix check bg position
* fix margin-top calculation
* rename .custom-select to .form-select
* Update validation styles for new checks
* add some vertical margin, fix inline checks
* fix docs examples
* better way to do this contents stuff, redo the toc while i'm at it
* page restyle for docs while here
* un-callout that, edit text
* redo padding on toc
* fix toc
* start to cleanup checks docs
* Rewrite Markdown tables into HTML
* Redesign tables, redo their docs
* Replace Open Iconic icons with custom Bootstrap icons
* Redesign the docs navbar, add a subheader, redo the sidebar
* Redesign docs homepage a bit
* Simplify table style overrides for docs tables
* Simplify docs typography for page titles and reading line length
* Stub out icons page
* Part of sidebar update, remove migration from nav.yml
* Move toc CSS to separate partial
* Change appearance of overview page
* fix sidebar arrow direction
* Add footer to docs layout
* Update descriptions
* Drop the .form-group class for margin utilities
* Remove lingering form-group-margin-bottom var
* improve footer spacing
* add headings to range page
* uncomment form range css
* Rename .custom-range to .form-range
* Drop unused docs var
* Uncomment the comment
* Remove unused variable
* Fix radio image sizing
* Reboot update: reset horizontal ul and ol padding
* de-dupe IDs
* tweak toc styles
* nvm, fix dropdown versions stuff
* remove sidebar nav toggle for now
* broken html
* fix more broken html, move css
* scss linting
* comment out broken helper docs
* scope styles
* scope styles
* Fixes #25540 and fixes #26407 for v5 only
* Update sidebar once more
* Match new sidenav order
* fix syntax error
* Rename custom-file to form-file, update paths, update migration docs for previous changes in #28696
* rename back
* fix size and alignment
* rename that back too
2019-07-12 16:52:33 -05:00
- Rearranged source Sass files under `scss/forms/` , including moving over input group styles.
2020-09-26 11:45:44 +03:00
- Combined native and custom checkboxes and radios into a single `.form-check` class.
v5: Forms update (#28450)
* Initial spike of consolidated form checks
* Stub out forms rearrangement
- Prepping to drop non-custom file and range inputs
- Prepping to merge custom and native checks and radios (with switches)
- Prepping to merge custom select with form select
- Moving docs arround so forms has it's own area given volume of CSS
* Move input group Sass file to forms subdir
* Start to split and move the docs around
* Simpler imports
* Copyediting
* delete overview file
* Remove commented out code
* remove the custom-forms import
* rewrite flex-check as form-check, replace all custom properties
* Remove old forms doc
* stub out new subpage link section
* update migration guide
* Update nav, forms overview in page nav, and descriptions
* fix check bg position
* fix margin-top calculation
* rename .custom-select to .form-select
* Update validation styles for new checks
* add some vertical margin, fix inline checks
* fix docs examples
* better way to do this contents stuff, redo the toc while i'm at it
* page restyle for docs while here
* un-callout that, edit text
* redo padding on toc
* fix toc
* start to cleanup checks docs
* Rewrite Markdown tables into HTML
* Redesign tables, redo their docs
* Replace Open Iconic icons with custom Bootstrap icons
* Redesign the docs navbar, add a subheader, redo the sidebar
* Redesign docs homepage a bit
* Simplify table style overrides for docs tables
* Simplify docs typography for page titles and reading line length
* Stub out icons page
* Part of sidebar update, remove migration from nav.yml
* Move toc CSS to separate partial
* Change appearance of overview page
* fix sidebar arrow direction
* Add footer to docs layout
* Update descriptions
* Drop the .form-group class for margin utilities
* Remove lingering form-group-margin-bottom var
* improve footer spacing
* add headings to range page
* uncomment form range css
* Rename .custom-range to .form-range
* Drop unused docs var
* Uncomment the comment
* Remove unused variable
* Fix radio image sizing
* Reboot update: reset horizontal ul and ol padding
* de-dupe IDs
* tweak toc styles
* nvm, fix dropdown versions stuff
* remove sidebar nav toggle for now
* broken html
* fix more broken html, move css
* scss linting
* comment out broken helper docs
* scope styles
* scope styles
* Fixes #25540 and fixes #26407 for v5 only
* Update sidebar once more
* Match new sidenav order
* fix syntax error
* Rename custom-file to form-file, update paths, update migration docs for previous changes in #28696
* rename back
* fix size and alignment
* rename that back too
2019-07-12 16:52:33 -05:00
- New checks support sizing via `em` /`font-size` or explicit modifier classes now.
2019-07-15 09:43:59 -07:00
- New checks now appear larger by default for improved usability.
v5: Forms update (#28450)
* Initial spike of consolidated form checks
* Stub out forms rearrangement
- Prepping to drop non-custom file and range inputs
- Prepping to merge custom and native checks and radios (with switches)
- Prepping to merge custom select with form select
- Moving docs arround so forms has it's own area given volume of CSS
* Move input group Sass file to forms subdir
* Start to split and move the docs around
* Simpler imports
* Copyediting
* delete overview file
* Remove commented out code
* remove the custom-forms import
* rewrite flex-check as form-check, replace all custom properties
* Remove old forms doc
* stub out new subpage link section
* update migration guide
* Update nav, forms overview in page nav, and descriptions
* fix check bg position
* fix margin-top calculation
* rename .custom-select to .form-select
* Update validation styles for new checks
* add some vertical margin, fix inline checks
* fix docs examples
* better way to do this contents stuff, redo the toc while i'm at it
* page restyle for docs while here
* un-callout that, edit text
* redo padding on toc
* fix toc
* start to cleanup checks docs
* Rewrite Markdown tables into HTML
* Redesign tables, redo their docs
* Replace Open Iconic icons with custom Bootstrap icons
* Redesign the docs navbar, add a subheader, redo the sidebar
* Redesign docs homepage a bit
* Simplify table style overrides for docs tables
* Simplify docs typography for page titles and reading line length
* Stub out icons page
* Part of sidebar update, remove migration from nav.yml
* Move toc CSS to separate partial
* Change appearance of overview page
* fix sidebar arrow direction
* Add footer to docs layout
* Update descriptions
* Drop the .form-group class for margin utilities
* Remove lingering form-group-margin-bottom var
* improve footer spacing
* add headings to range page
* uncomment form range css
* Rename .custom-range to .form-range
* Drop unused docs var
* Uncomment the comment
* Remove unused variable
* Fix radio image sizing
* Reboot update: reset horizontal ul and ol padding
* de-dupe IDs
* tweak toc styles
* nvm, fix dropdown versions stuff
* remove sidebar nav toggle for now
* broken html
* fix more broken html, move css
* scss linting
* comment out broken helper docs
* scope styles
* scope styles
* Fixes #25540 and fixes #26407 for v5 only
* Update sidebar once more
* Match new sidenav order
* fix syntax error
* Rename custom-file to form-file, update paths, update migration docs for previous changes in #28696
* rename back
* fix size and alignment
* rename that back too
2019-07-12 16:52:33 -05:00
- Dropped `.custom-control` and associated classes.
2019-07-15 09:43:59 -07:00
- Renamed most `$custom-control` variables to `$form-control` ones.
v5: Forms update (#28450)
* Initial spike of consolidated form checks
* Stub out forms rearrangement
- Prepping to drop non-custom file and range inputs
- Prepping to merge custom and native checks and radios (with switches)
- Prepping to merge custom select with form select
- Moving docs arround so forms has it's own area given volume of CSS
* Move input group Sass file to forms subdir
* Start to split and move the docs around
* Simpler imports
* Copyediting
* delete overview file
* Remove commented out code
* remove the custom-forms import
* rewrite flex-check as form-check, replace all custom properties
* Remove old forms doc
* stub out new subpage link section
* update migration guide
* Update nav, forms overview in page nav, and descriptions
* fix check bg position
* fix margin-top calculation
* rename .custom-select to .form-select
* Update validation styles for new checks
* add some vertical margin, fix inline checks
* fix docs examples
* better way to do this contents stuff, redo the toc while i'm at it
* page restyle for docs while here
* un-callout that, edit text
* redo padding on toc
* fix toc
* start to cleanup checks docs
* Rewrite Markdown tables into HTML
* Redesign tables, redo their docs
* Replace Open Iconic icons with custom Bootstrap icons
* Redesign the docs navbar, add a subheader, redo the sidebar
* Redesign docs homepage a bit
* Simplify table style overrides for docs tables
* Simplify docs typography for page titles and reading line length
* Stub out icons page
* Part of sidebar update, remove migration from nav.yml
* Move toc CSS to separate partial
* Change appearance of overview page
* fix sidebar arrow direction
* Add footer to docs layout
* Update descriptions
* Drop the .form-group class for margin utilities
* Remove lingering form-group-margin-bottom var
* improve footer spacing
* add headings to range page
* uncomment form range css
* Rename .custom-range to .form-range
* Drop unused docs var
* Uncomment the comment
* Remove unused variable
* Fix radio image sizing
* Reboot update: reset horizontal ul and ol padding
* de-dupe IDs
* tweak toc styles
* nvm, fix dropdown versions stuff
* remove sidebar nav toggle for now
* broken html
* fix more broken html, move css
* scss linting
* comment out broken helper docs
* scope styles
* scope styles
* Fixes #25540 and fixes #26407 for v5 only
* Update sidebar once more
* Match new sidenav order
* fix syntax error
* Rename custom-file to form-file, update paths, update migration docs for previous changes in #28696
* rename back
* fix size and alignment
* rename that back too
2019-07-12 16:52:33 -05:00
- Combined native and custom selects into `.form-select` .
- Dropped `.custom-select` and associated classes.
2019-07-15 09:43:59 -07:00
- Renamed most `$custom-select` variables to `$form-select` ones.
2020-04-15 14:13:45 +03:00
- Updated file input component with the same overall design, but improved HTML.
2019-07-15 09:43:59 -07:00
- Refactored `.form-file` markup to resolve some visual bugs while allowing translation and button text changes via HTML instead of CSS.
- Dropped native `.form-control-file` and `.form-control-range` components entirely.
- Renamed `.custom-file` to `.form-file` (including variables).
- Added support for `:focus` and `:disabled` styles.
v5: Forms update (#28450)
* Initial spike of consolidated form checks
* Stub out forms rearrangement
- Prepping to drop non-custom file and range inputs
- Prepping to merge custom and native checks and radios (with switches)
- Prepping to merge custom select with form select
- Moving docs arround so forms has it's own area given volume of CSS
* Move input group Sass file to forms subdir
* Start to split and move the docs around
* Simpler imports
* Copyediting
* delete overview file
* Remove commented out code
* remove the custom-forms import
* rewrite flex-check as form-check, replace all custom properties
* Remove old forms doc
* stub out new subpage link section
* update migration guide
* Update nav, forms overview in page nav, and descriptions
* fix check bg position
* fix margin-top calculation
* rename .custom-select to .form-select
* Update validation styles for new checks
* add some vertical margin, fix inline checks
* fix docs examples
* better way to do this contents stuff, redo the toc while i'm at it
* page restyle for docs while here
* un-callout that, edit text
* redo padding on toc
* fix toc
* start to cleanup checks docs
* Rewrite Markdown tables into HTML
* Redesign tables, redo their docs
* Replace Open Iconic icons with custom Bootstrap icons
* Redesign the docs navbar, add a subheader, redo the sidebar
* Redesign docs homepage a bit
* Simplify table style overrides for docs tables
* Simplify docs typography for page titles and reading line length
* Stub out icons page
* Part of sidebar update, remove migration from nav.yml
* Move toc CSS to separate partial
* Change appearance of overview page
* fix sidebar arrow direction
* Add footer to docs layout
* Update descriptions
* Drop the .form-group class for margin utilities
* Remove lingering form-group-margin-bottom var
* improve footer spacing
* add headings to range page
* uncomment form range css
* Rename .custom-range to .form-range
* Drop unused docs var
* Uncomment the comment
* Remove unused variable
* Fix radio image sizing
* Reboot update: reset horizontal ul and ol padding
* de-dupe IDs
* tweak toc styles
* nvm, fix dropdown versions stuff
* remove sidebar nav toggle for now
* broken html
* fix more broken html, move css
* scss linting
* comment out broken helper docs
* scope styles
* scope styles
* Fixes #25540 and fixes #26407 for v5 only
* Update sidebar once more
* Match new sidenav order
* fix syntax error
* Rename custom-file to form-file, update paths, update migration docs for previous changes in #28696
* rename back
* fix size and alignment
* rename that back too
2019-07-12 16:52:33 -05:00
- Renamed `.custom-range` to `.form-range` (including variables).
- Dropped `.form-group` for margin utilities (we've replaced our docs examples with `.mb-3` ).
2019-09-28 16:16:52 +02:00
- Dropped `.form-row` for the more flexible grid gutters.
- Dropped `.form-inline` for the more flexible grid.
v5: Forms update (#28450)
* Initial spike of consolidated form checks
* Stub out forms rearrangement
- Prepping to drop non-custom file and range inputs
- Prepping to merge custom and native checks and radios (with switches)
- Prepping to merge custom select with form select
- Moving docs arround so forms has it's own area given volume of CSS
* Move input group Sass file to forms subdir
* Start to split and move the docs around
* Simpler imports
* Copyediting
* delete overview file
* Remove commented out code
* remove the custom-forms import
* rewrite flex-check as form-check, replace all custom properties
* Remove old forms doc
* stub out new subpage link section
* update migration guide
* Update nav, forms overview in page nav, and descriptions
* fix check bg position
* fix margin-top calculation
* rename .custom-select to .form-select
* Update validation styles for new checks
* add some vertical margin, fix inline checks
* fix docs examples
* better way to do this contents stuff, redo the toc while i'm at it
* page restyle for docs while here
* un-callout that, edit text
* redo padding on toc
* fix toc
* start to cleanup checks docs
* Rewrite Markdown tables into HTML
* Redesign tables, redo their docs
* Replace Open Iconic icons with custom Bootstrap icons
* Redesign the docs navbar, add a subheader, redo the sidebar
* Redesign docs homepage a bit
* Simplify table style overrides for docs tables
* Simplify docs typography for page titles and reading line length
* Stub out icons page
* Part of sidebar update, remove migration from nav.yml
* Move toc CSS to separate partial
* Change appearance of overview page
* fix sidebar arrow direction
* Add footer to docs layout
* Update descriptions
* Drop the .form-group class for margin utilities
* Remove lingering form-group-margin-bottom var
* improve footer spacing
* add headings to range page
* uncomment form range css
* Rename .custom-range to .form-range
* Drop unused docs var
* Uncomment the comment
* Remove unused variable
* Fix radio image sizing
* Reboot update: reset horizontal ul and ol padding
* de-dupe IDs
* tweak toc styles
* nvm, fix dropdown versions stuff
* remove sidebar nav toggle for now
* broken html
* fix more broken html, move css
* scss linting
* comment out broken helper docs
* scope styles
* scope styles
* Fixes #25540 and fixes #26407 for v5 only
* Update sidebar once more
* Match new sidenav order
* fix syntax error
* Rename custom-file to form-file, update paths, update migration docs for previous changes in #28696
* rename back
* fix size and alignment
* rename that back too
2019-07-12 16:52:33 -05:00
- Dropped support for `.form-control-plaintext` inside `.input-group` s.
2019-12-19 15:28:40 +01:00
- Dropped `.input-group-append` and `.input-group-prepend` . You can now just add buttons and `.input-group-text` as direct children of the input groups.
2020-03-31 20:02:57 +02:00
- Form labels now require the `.form-label` class. Sass variables are now available to style form labels to your needs. [See #30476 ](https://github.com/twbs/bootstrap/pull/30476 )
2017-12-22 15:29:49 -08:00
2020-07-01 15:43:06 +03:00
### Components
2017-12-22 15:29:49 -08:00
2020-04-30 06:17:08 -07:00
- Unified `padding` values for alerts, breadcrumbs, cards, dropdowns, list groups, modals, popovers, and tooltips to be based on our `$spacer` variable. [See #30564 ](https://github.com/twbs/bootstrap/pull/30564 ).
2020-07-01 15:43:06 +03:00
#### Disabled states
2019-12-27 17:40:06 +01:00
- Disabled states of the buttons, close button, pagination link & form range now have `pointer-events: none` added. This simplifies our codebase and makes it easier to override active states in CSS. [#29296 ](https://github.com/twbs/bootstrap/pull/29296 ).
2020-07-01 15:43:06 +03:00
#### Alerts
2017-12-22 15:29:49 -08:00
2020-08-03 09:42:31 -07:00
- Removed auto-darkening of `<hr>` elements in `.alert-*` class variants. `<hr>` s use `rgba()` for their color, so these should naturally blend anyway.
2017-12-22 15:29:49 -08:00
2020-07-01 15:43:06 +03:00
#### Badges
2017-09-26 14:50:35 +03:00
2019-05-03 10:52:58 -07:00
Badges were overhauled to better differentiate themselves from buttons and to better utilize utility classes.
2017-08-20 13:54:12 -07:00
2020-08-03 09:42:31 -07:00
- Removed and replaced `.badge` modifier classes with background utility classes (e.g., use `.bg-primary` instead of `.badge-primary` )
- Removed `.badge-pill` for the `.rounded-pill` utility class
- Removed badge's hover and focus styles for `a.badge` and `button.badge` .
2017-08-22 10:56:04 -07:00
2020-07-01 15:43:06 +03:00
#### Buttons
2020-05-02 11:11:24 +02:00
2020-06-27 19:31:59 +01:00
- The checkbox/radio toggle is removed from the button plugin in favour of a CSS only solution, which is documented in the [form checks and radios ]({{< docsref "/forms/checks-radios#toggle-buttons" >}} ) docs. The `.btn-check` class can be added to inputs, any label with `.btn` and modifier class can be used to theme the labels. [See #30650 ](https://github.com/twbs/bootstrap/pull/30650 ).
2020-05-02 11:11:24 +02:00
2020-07-01 15:43:06 +03:00
#### Cards
2019-06-30 16:59:58 +03:00
- Removed the card columns in favor of a Masonry grid [See #28922 ](https://github.com/twbs/bootstrap/pull/28922 ).
2020-04-15 14:13:45 +03:00
- Removed card decks in favor of the grid which adds more flexibility over responsive behavior.
2019-06-30 16:59:58 +03:00
2020-07-01 15:43:06 +03:00
#### Jumbotron
2019-06-07 13:44:26 +02:00
- The jumbotron component is removed in favor of utility classes like `.bg-light` for the background color and `.p-*` classes to control padding.
2020-07-01 15:43:06 +03:00
#### Navbars
2019-10-27 20:26:52 -07:00
- All navbars now require a container within. This drastically simplifies spacing requirements and removes the need for extensive CSS overrides we added for responsive containers in v4.
2020-07-01 15:43:06 +03:00
#### Pagination
2019-08-03 07:27:33 -07:00
- Pagination links now have customizable `margin-left` that are dynamically rounded on all corners when separated from one another.
2020-07-01 15:43:06 +03:00
#### Popovers
2019-05-12 10:01:13 +02:00
- Renamed `.arrow` to `.popover-arrow`
2020-07-01 15:43:06 +03:00
#### Tooltips
2019-05-12 10:01:13 +02:00
- Renamed `.arrow` to `.tooltip-arrow`
2020-07-01 15:43:06 +03:00
### Accessibility
2019-05-20 10:03:51 +02:00
2020-07-03 12:38:11 +01:00
- Unlike the old `.sr-only-focusable` , which only worked in combination with `.sr-only` , `.sr-only-focusable` can be used as a standalone class without `.sr-only` . [See #28720 ](https://github.com/twbs/bootstrap/pull/28720 ).
2019-05-20 10:03:51 +02:00
2020-07-01 15:43:06 +03:00
### Utilities
2017-08-20 13:54:12 -07:00
2019-06-05 00:51:36 +09:00
- Renamed `.text-monospace` to `.font-monospace`
2019-06-18 07:02:14 +02:00
- Decreased the number of responsive order utilities per breakpoint. The highest order utility with a number now is `.order-5` instead of `.order-12` . [See #28874 ](https://github.com/twbs/bootstrap/pull/28874 ).
2019-08-30 09:42:41 +02:00
- New `line-height` utilities: `.lh-1` , `.lh-sm` , `.lh-base` and `.lh-lg` . See [here ]({{< docsref "/utilities/text#line-height" >}} ).
2019-10-10 11:18:19 -07:00
- Added `.bg-body` for quickly setting the `<body>` 's background to additional elements.
2020-08-03 09:42:31 -07:00
- Drop `.text-hide` as it's an antiquated method for hiding text that shouldn't be used anymore
- Split utilities into property-value utility classes and helpers
2020-04-15 06:36:35 +02:00
- Negative margin utilities are disabled by default. You can re-enable them by setting `$enable-negative-margins: true` , but keep in mind this can increase the file size quite a lot.
2017-08-22 10:56:04 -07:00
2020-07-01 15:43:06 +03:00
### Docs
2019-08-27 08:44:35 +03:00
2020-05-14 09:01:40 +03:00
- Removed "Wall of browser bugs" page because it has become obsolete
2020-07-01 15:43:06 +03:00
- Switched from Jekyll to Hugo
### Build tools
2019-08-27 08:44:35 +03:00
2020-07-01 15:43:06 +03:00
- Updated all devDependencies
- We support only the latest Node.js LTS releases which are 10 and 12 at the time of writing