- Upgrade USWDS from v3.9.0 to v3.11.0 (see release notes) (!25, !27)
- Updated dependencies specifier for USWDS to only allow patch-level USWDS version increases. Unlike the Login.gov Design System, USWDS does not follow semantic versioning, and therefore it is not safe to assume that USWDS minor versions contain backwards-compatible changes.
- Align Validation component message icons with the first line of the message text.
- Upgrade USWDS from v3.8.1 to v3.9.0 (see release notes) (!14, !17)
- Update styling for Default (previously "Other") Alert component variant, for greater distinction from other variants and consistency with U.S. Web Design System. (#449)
- It is no longer necessary to assign the
usa-alert--other
class to use these styles, and it can be safely removed. Existing code assigningusa-alert--other
should continue to display the updated default styles as expected.
- It is no longer necessary to assign the
- Improve compatibility of badge icon styling for inner Icon component. (#445)
- Improve text contrast for code syntax highlighting. (!2)
- Upgrade USWDS from v3.8.0 to v3.8.1 (see release notes) (#448)
- Update styling for Alert component for increased contrast and consistency with U.S. Web Design System. (#439)
- Update styling for Validation component icons for consistency with U.S. Web Design System. (#441)
- Update markup for badge component to use U.S. Web Design System icons. (#442)
- Existing usage will not be affected until the next major release (see "Deprecations").
- Badge component markup has been updated and will be required in the next major release. (#442)
- Custom alert icons will be removed in the next major release, use U.S. Web Design System alerts instead.
alerts/error.svg
alerts/info.svg
alerts/success.svg
alerts/unphishable.svg
alerts/warning.svg
- Update styling for Tag component for consistency with U.S. Web Design System. (#426)
- Hide collapsed Accordion component content while JavaScript loads. (#434)
- Upgrade USWDS from v3.7.1 to v3.8.0 (see release notes) (#425)
- Prose styling overrides have been removed. Text formatting should now adhere to the defaults from the U.S. Web Design System. (#390)
- Drop support for Internet Explorer. (#387)
- Support was indirectly dropped in v7.0.0 via the upgrade to USWDS v3.0.0, which similarly ended explicit support for Internet Explorer. This package had continued to include Internet Explorer in its Browserslist configuration, but this has now been removed.
- Remove utility classes for raw color tokens. (#405)
- These colors were usually incorrect because they were using U.S. Web Design System defaults instead of the Login.gov Design System color set.
- In most common cases, these should be replaced with stateful equivalents ("success" instead of "green") or theme colors ("base" instead of "gray-50").
- Applies to the following utilities:
- Background color (
bg-*
) - Border color (
border-*
) - Text color (
text-*
) - Outline color (
outline-*
) - Text underline color (
underline-*
)
- Background color (
- The following colors are removed:
red
(useerror
instead)orange
gold
yellow
(usewarning
instead)green
(usesuccess
instead)mint
cyan
blue
(useprimary
instead)indigo
violet
magenta
gray-10
(usebase-lighter
instead)gray-30
(usebase-light
instead)gray-50
(usebase
instead)gray-70
(usebase-darker
instead)gray-90
(usebase-darkest
instead)
- Remove images not integral to the design system. (#410)
- If you use any of these images, consider proposed alternatives below, or copy the image from the previous release into your project:
illustrations/fail.svg
(legacy alert icon, new alert icons will be introduced in a future release)illustrations/security-key.svg
angle-arrow-down-white-hover.svg
(useexpand_more
icon instead)angle-arrow-down-white.svg
(useexpand_more
icon instead)angle-arrow-down.svg
(useexpand_more
icon instead)angle-arrow-up-white-hover.svg
(useexpand_less
icon instead)angle-arrow-up-white.svg
(useexpand_less
icon instead)angle-arrow-up.svg
(useexpand_less
icon instead)close-primary.svg
(useclose
icon instead)close.svg
(useclose
icon instead)hero.png
- If you use any of these images, consider proposed alternatives below, or copy the image from the previous release into your project:
- Align JavaScript component names with U.S. Web Design System. (#414)
header
is now namednavigation
validation
is now namedvalidator
- Optimize images to reduce their size. (#411)
- Browser-ready JavaScript bundles are now minified. (#421)
- Add TypeScript types for JavaScript components. (#413)
- Include
init.js
as both a package entrypoint and precompiled asset withindist/assets/js
, which provides the functionality of U.S. Web Design System'suswds-init.js
script to reduce the appearance of flashing content during page load. See README Browser-Ready JavaScript Bundles for usage instructions. (#421)
- Add missing JavaScript exports for
button
,inPageNavigation
,inputMask
,languageSelector
, andrange
. (#407) - Fix
dist/assets/js/main.js
compilation to properly consider browser support. (#421) - Fix strict ES Module import errors due to lack of fully-qualified file path when importing
auto
entrypoint. (#422) - Fix background color when hovering an expanded navigation section on large viewport sizes. (#418)
- Replace code compiler Babel with ESBuild. (#387)
- This is not expected to have a downstream impact, but there may be subtle differences in the compiled code due to this change.
- Fix issue with dual export backwards-compatibility resulting in errors loading in CommonJS projects. (#401)
- Fix strict ES Module import errors due to lack of fully-qualified file path. (#400)
- Add variant support for danger outline buttons. (#383)
- Improve consistency with USWDS disabled buttons styles. (#383)
- USWDS v3.5.0 removed
.usa-button--disabled
styling in favor of[aria-disabled="true"]
. This wasn't documented as a breaking change, and it's expected the any.usa-button--disabled
usage would not be stylized correctly since those changes. You should replace any usage ofusa-button--disabled
with either the[disabled]
or[aria-disabled="true"]
attributes.
- USWDS v3.5.0 removed
- The package is now distributed using native ES Modules as the default output. This should not impact downstream CommonJS projects, as a CommonJS distributable is still included for now. (#395)
- Fix an issue where accordion icons appear smaller when hovering the expander button. (#379)
- Serif fonts are disabled by default. This should not have a noticeable impact in most cases, since the Serif fonts were already previously assigned to Public Sans (a Sans Serif font). (#374)
- Update USWDS from 3.4.1 to 3.6.1 (#362, #375)
- See release notes:
- Note "Breaking" changes in the above minor releases. Additionally, the
inputPrefixSuffix
JavaScript named export has been removed.
- Fix appearance of borders in segmented "Big" button groups. (#359)
- Improve compilation time for default package by upwards of 50%. (#356)
- Fix issue where the Process List "Big" variant would show with the connected line when not rendered in prose content. (#357)
- Add meta charset to documentation layout to fix visual regressions tests (#361)
- Fix header navigation current link styling regression in 7.0.0 release. (#352)
- Fix dark background sections to show heading text as white. (#352)
- Fix issue causing search button widths to collapse when displayed in narrow containers. (#354)
Note: While these are backwards-incompatible changes, the major version is not being changed because they impact features which were never part of a publicly-documented API.
- Remove
.usa-sidenav--sticky
CSS class. (#352)
- NPM package renamed from
identity-style-guide
to@18f/identity-design-system
. (#331) - Update USWDS from 2.13.3 to 3.4.1. (#321)
- Polyfills have been removed, consistent with current Login.gov browser support
- The following JavaScript named exports have been renamed or removed:
navigation
is renamed toheader
validator
is renamed tovalidation
- Refer to README.md for updated usage instructions, as well as the U.S. Web Design System migration guide.
- Sass artifacts now require Dart Sass. The Ruby Sass and LibSass (C) compilers are no longer supported. (#298)
- To improve performance of the default CSS bundle, responsive utility breakpoints other than
tablet:
have been disabled by default. Previously,mobile-lg:
anddesktop:
utilities were also enabled. You can restore the original settings by overriding the$theme-utility-breakpoints
Sass variable. (#298)- Component styling which previously responded to now-disabled breakpoints have been updated to standardize on the
tablet
breakpoint. This affectsusa-button--wide
,usa-search--big
, andusa-intro
CSS classes.
- Component styling which previously responded to now-disabled breakpoints have been updated to standardize on the
- Image URLs in stylesheets are no longer processed by
asset-path-if-exists
. For Rails integrations, consider using the$theme-image-path
Sass variable in combination with Sprocketsresolve_assets_in_css_urls
option. (#298) - The deprecated
$image-path
Sass variable setting has been removed. Use$theme-image-path
instead. (#298) - The deprecated
alerts/success-badge.svg
image has been removed. Usealerts/success.svg
instead. (#298) - The deprecated
.usa-form-hint
CSS class has been removed. Use.usa-hint
instead. (#337) - Removed
usa-alert__paragraph
alert helper class. Usemeasure-3
measure utility instead. (#298) - The Spinner component has been removed (
.lg-spinner
). A new "Loading" component will be made available in a future release. (#347) - The all-white Login.gov logo
login-gov-logo-rev.svg
has been replaced with a new color-reversed versionsrc/img/login-gov-logo-reverse.svg
. (#351)
- Add Tag component styles. (#346)
- Add new "Big" variant of Dropdown component. (#328)
- Add new "Big" variants of Text Input and Textarea components. (#326)
- Update Text Input styling to adhere to design specification. (#325)
- Increase line-height for accordion heading content to improve readability. (#316)
- Update USWDS from v2.13.2 to 2.13.3. (#312)
- Add styles and markdown content for selected and disabled radios and checkboxes. (#313)
- Fix an issue where search field submit buttons would not show text at small viewport sizes. (#311)
- The
alerts/success-badge.svg
image will be removed in a future major version. Usealerts/success.svg
instead. (#306)
- Improve appearance of illustrated tile checkboxes and radio buttons. (#309)
- Use correct "Success" green color for
alerts/unphishable.svg
icon. (#306)
- Remove documentation-specific images from published package. (#300)
- Remove duplicate styles. (#301)
- Reconcile redundant focus styles with U.S. Web Design System. (#302)
- Remove documentation site styles from design system artifact. (#305)
- Reduce size of SVG images. (#307)
- Update USWDS from v2.13.1 to 2.13.2. (#304)
- Update dependencies to resolve vulnerability advisories. (#308)
- Changing the radio tile image size from 1rem to 1.5rem. (#299)
- Line height calculations are improved such that the desired token size will always apply regardless of font family or scale. (#291)
- In the case of headings, line-height will fall back to the configured body line-height if the resulting actual line-height would be smaller than body content when using the heading scale.
- Body font size has been increased slightly to restore an effective font size of 1rem. (#292)
- The Process List component no longer applies vertical padding which would affect its layout relative to surrounding content. (#290)
- Input hint text is no longer italicized. (#293)
- New variation of checkbox and radio button tiles with illustrations is added to form fields. (#296)
- Improve vertical spacing in heading of Process List item spanning multiple lines. (#288)
- Fix external link icon margin when followed by additional text content. (#289)
- Field validation success is added to form validation. (#265)
- Added custom styling for the Process List component. (#279)
- The default font is now Public Sans for both headings and body copy. This is not being considered a breaking change, as it is the new default guidance. To preserve existing font settings to allow more time to migrate, set
$theme-font-type-sans: 'source-sans-pro';
and$theme-font-type-serif: 'merriweather';
. (#264) - Add Login.gov-specific component configuration. (#258)
- Identifier component
- Link colors on dark backgrounds
- The default line-height is now set to 1.5. This is not being considered a breaking change, as it is the new default guidance. To preserve existing font settings to allow more time to migrate, set
$theme-body-line-height: 6
. (#283) - Overlay is now shown with a lighter backdrop color. (#260)
- Form Dropdown is now more visually consistent with other form fields. (#263)
- Form hint text is now shown with an italicized style and increased vertical margins. (#262)
- Icons for form validation errors are aligned to the top. (#265)
- The tile variant of checkboxes and radio buttons have a slightly increased font size. (#281)
- Checkbox and radio labels which span multiple lines should now appear with a consistent line height relative to surrounding body copy. (#283)
- Search will now show full text labels at all sizes, and uses standardized font tokens. (#259)
- Fix an issue where
.usa-input--error
would apply the incorrect border color unless also accompanied by.usa-input
,.usa-textarea
, or.usa-select
. (#275)
- Upgraded USWDS from v2.12.1 to v2.13.1 (see release notes) (#269, #277, #280)
- All theme variables are now set as default values, allowing you to override them for per-project requirements. (#247)
- Note: Since the design system is meant to be an opinionated set of smart defaults, it's recommended to use restraint with variable customization, or at least consider when it may be more appropriate to adjust a setting from the design system itself in order to maintain consistency across projects.
- Responsive variants of width utility classes are now enabled. (#248)
- Navbar link text is no longer uppercase. (#249)
- Visual alignment of Badge component is improved, and its markup guidance has been simplified with improved accessibility semantics. (#251)
- Field validation error messages now use updated styling to always display an icon as part of the error message, and not within the field itself. The modifier classes
usa-input--inline
andusa-error-message--with-icon
no longer have any effect and can be safely removed. (#255) - Focus styles for links and unstyled buttons are now the same. (#253)
- USWDS is upgraded to the latest version, from v2.11.2 to v2.12.1.
- Whitespace in checkbox and radio label markup will no longer cause the label text to be misplaced.
- Margins surrounding an external link icon have been increased slightly.
- Padding and label font size for tile checkboxes and radio buttons have increased slightly.
- USWDS is upgraded to the latest version, from v2.9.0 to v2.11.2.
- The bordered and large styles of checkboxes and radio buttons have updated guidance to improve compatibility with the USWDS tile style. The classes
usa-radio-bordered
,usa-radio-large
,usa-checkbox-bordered
, andusa-checkbox-large
have been removed. Instead, addusa-radio__input--bordered
,usa-radio__input--tile
,usa-checkbox__input--bordered
,usa-checkbox__input--tile
respectively as modifiers to the element with the classusa-radio__input
orusa-checkbox__input
.
- The bordered and large styles of checkboxes and radio buttons have updated guidance to improve compatibility with the USWDS tile style. The classes
- The Accordion component no longer includes a "Close" button. Remove any instances of
<button class="usa-accordion__close-button">
in your project, or references to theaccordionCloseButton
exported member of the JavaScript package.
- Add support for SASS package entrypoints to limit or control loading of styles, similar to USWDS components. Available packages are
packages/required
,packages/global
,packages/components
, andpackages/utilities
. - The Side Navigation component is now documented and includes updated and improved styling. While this should not require any markup changes, you should validate that the updated styling does not conflict with any product-specific styles for side navigation.
- Reduce the border width of the normal outline button to the intended width of
1px
(previously2px
). The big variant of the outline button is unaffected by this change, and remains2px
. - Fix rounded corners on sidebar current page item.
- Fix unintentional rounded corners on search text field.
- Fix utility classes not always applying as expected when applied to components. For example, using
margin-
utility classes on an unstyled button would previously unexpectedly conflict with and not take precedent over the button's own margins. - Fix all instances of font weight appearance of unstyled buttons in content which applies anti-aliased font smoothing. Previous bug fix attempts had still missed default
:hover
and:active
states.
- Fix font weight appearance of unstyled buttons in content which applies anti-aliased font smoothing.
- Fix the appearance of unstyled buttons to appear visually identical to a link.
- Fix an issue where a second focus ring effect was still applied to the unstyled button variant.
- Several button variants have been removed. These include:
- Success (
usa-button--success
) - Dropdown (
usa-button--dropdown
) - Small (
usa-button--small
) - Tiny (
usa-button--tiny
)
- Success (
- The Password Strength Meter component has been removed.
- Link hover and active colors are now distinct.
- Before: Hover and active colors are both
primary-darker
. - After: Hover is
primary-dark
, and active isprimary-darker
.
- Before: Hover and active colors are both
- Improved support for "Unstyled" button variant
- Add three new button variants to control width:
usa-button--wide
displays a button at a wider (minimum) width at larger viewport displays.usa-button--flexible-width
displays a button at flexible width regardless of viewport size, and overrides default mobile appearance of full-width buttons.usa-button--full-width
displays a button at full width regardless of viewport size, and overrides default desktop appearance of flexible-width buttons.
- Fix an issue where focused buttons appear with a double focus ring style.
- Fix an issue where using the "auto" package entrypoint may cause components not to be loaded when used with some bundlers (e.g. Webpack).
- Add documentation for "Big" button variants.
- Rename "Secondary" as "Outline" in buttons documentation.
- The Spinner button has been removed (
.usa-button__lg-invokeSpinner
). - Favicon images have been updated for consistency with the U.S. Web Design System. Existing references to
favicon-16x16.png
should be updated tofavicon-16.png
.favicon-32x32.png
has been removed. The closest substitute isfavicon-40.png
, at size 40 pixels x 40 pixels.
- New favicon size variations are available. The complete set of pixel sizes are:
16
,40
,57
,72
,114
,144
,192
.
- Fix an issue where builds may produce styles in an unpredictable order.
- Fix an issue where
.usa-display
heading font size was rendered larger than intended. - Fix an issue where
dropdownButton
was using invalid CommonJS syntax when imported from ES module entrypoint. - Fix an issue where
.usa-prose
heading margins were not applied consistently. - Fix an issue where importing subpaths may not resolve correctly using native ES modules.
- Replace deprecated USWDS variable references with updated equivalent values.
- Updates USWDS from 2.0.3 to 2.9.0. Review release notes for specific changes which may apply. Specific impactful changes include...
- The Tooltip component is now inherited from USWDS, newly introduced as of USWDS 2.8.0. See component documentation for more information. The markup of this component is significantly different than that of the component previously implemented in the Login.gov Design System.
- Due to a rounding precision fix, line-heights for text may appear larger than it had previously.
- Guidance for many components has been updated to improve accessibility and usability of markup. Neglecting to update this markup should not result in user-facing regressions, but you are recommended to update to improve end-user experience. Refer to the release notes and related component documentation for specifics:
- SVG images should include
role="img"
. - Numeric fields should use
type="text" inputmode="numeric"
instead oftype="number"
. - Search forms should assign
role="search"
to the form element. - Banner should be rendered as a
section
element instead of adiv
, and include a descriptivearia-label
. - Footer and hero content should include a descriptive
aria-label
. - Graphic list should use
h2
as a heading element instead ofh3
.
- SVG images should include
- "Official government website" banner text has been updated. Refer to USWDS guidance for updated markup.
- The published NPM package can now be imported into a project. Bundlers that support dead-code elimination (Webpack, etc.) can automatically remove unused code to optimize bundle size. Existing usage of JavaScript code from
dist/assets/
is unaffected by these changes.
- Fixed support for multiple dropdown buttons on a page.