@uswds/elements
v1.0.0-alpha.5
Published
> [!CAUTION] > Work on USWDS Elements, the Web Component version of the Design System, is happening in this repository. This code may not all be suitable for production use. Please refer to the documentation for each component.
Keywords
Readme
[!CAUTION] Work on USWDS Elements, the Web Component version of the Design System, is happening in this repository. This code may not all be suitable for production use. Please refer to the documentation for each component.
USWDS Elements
The United States Web Design System is a toolkit of principles, guidance, and code that includes a library of open source user interface components and a visual style guide for U.S. federal government websites.
This repository contains the code for the Web Component-based version of the design system, which is currently in pre-release status, with a goal release of May 2025. We maintain other repositories for the current version of the design system, which we call USWDS Core, as well as its documentation and website. For USWDS Core and its documentation on the web, visit https://designsystem.digital.gov.
Over the course of the next several months and beyond, we will incrementally build new Web Component-based implementations of USWDS Core. As we ship new USWDS Web Components, our intent is that you'll be able to use them alongside existing USWDS code.
Upgrading to Web Components
We are releasing these Web Components (USWDS Elements) incrementally with the intent that they can also be added gradually to existing sites that are currently using USWDS. If you aren't currently using USWDS or you're using a version older than USWDS 3, we recommend adopting version 3 in the near term rather than waiting until all of USWDS Elements is production-ready.
Installation using node and npm
Install
node/npm. Below is a link to find the install method that coincides with your operating system:- Node (see .nvmrc for version number), Installation guides
Note for Windows users: If you are using Windows and are unfamiliar with Node or npm, we recommend following Team Treehouse's tutorial for more information or installing and running your project from Windows Subsystem for Linux (WSL).
Make sure you have installed it correctly:
npm -v 10.9.4 # This line may vary depending on what version of Node you've installed.Create a
package.jsonfile. You can do this manually, but an easier method is to use thenpm initcommand. This command will prompt you with a few questions to create yourpackage.jsonfile.Add
@uswds/uswdsto your project’spackage.json:npm install -S @uswds/elements
The @uswds/elements module is now installed as a dependency.
Note: We do not recommend directly editing the design system files in node_modules. One of the benefits of using a package manager is its ease of upgrade and installation. If you make customizations to the files in the package, any upgrade or re-installation will wipe them out.
Using USWDS Elements in your project
How you add the component to a page may vary depending on the tools you use in your work. If you use Vite, you can add components by importing them into a script that is imported elsewhere into a page:
// Importing into a javascript file, like index.js
import { UsaBanner } from "@uswds/elements";<!-- importing directly into an HTML page -->
<script type="module">
import { UsaBanner } from "@uswds/elements";
</script>
<usa-banner></usa-banner>Style theming and tokens
Each USWDS Element provides support for theming by exposing CSS custom properties (CSS variables) that can be used to control the appearance of the component.
There are interactive form controls in our Storybook instance that demonstrate how to use the theming variables, provide custom text, and otherwise customize the components.
For example, the usa-banner component can be customized by setting the --usa-banner-background-color CSS variable to a color of your choosing:
<style>
usa-banner {
--usa-banner-background-color: #d9e8f6; /** equivalent to `primary-lighter` from USWDS - https://designsystem.digital.gov/design-tokens/color/theme-tokens/#theme-color-tokens-table-2 */
--usa-banner-button-close-background-color: #d6f3ff;
}
</style>
<usa-banner></usa-banner>This can be seen in the demo on the USWDS Elements Storybook.
Note: Please be mindful of the accessibility implications of customizing component appearance. It is your responsibility to ensure that your customizations meet the accessibility requirements of the design system and pass any WCAG 2.2 or Section 508 accessibility tests.
Documentation
For more detailed documentation, refer to the Storybook for USWDS Elements. You can visit the most up-to-date Storybook documentation on Cloud.gov Pages.
Browser support
We’ve designed the design system to support older and newer browsers through progressive enhancement. The current major version of USWDS Elements (v1) follows the 2% rule: we officially support any browser above 2% usage as observed by analytics.usa.gov. Currently, this means support for the newest versions of Chrome, Firefox, and Safari.
Accessibility
The design system also meets the WCAG 2.0 AA accessibility guidelines and conforms to the standards of Section 508 of the Rehabilitation Act. Additionally, we try to meet the requirements of WCAG 2.2.
We use the following tools to ensure USWDS is accessible:
If you find any issues with our accessibility conformance, please create an issue in our GitHub repo or send us an email at [email protected]. We prioritize accessibility issues. See the Accessibility page of our website for more information.
Publishing
This repository is automatically published to NPM when a new release is created.
We use Changesets to manage changelogs, version bumps, pre-releases (alpha/beta), and automated publishing via GitHub Actions. The repository includes a pre-configured Changesets setup so you can create pre-releases (for example, alpha) and standard releases.
Pre-release flow
If you are working on a pre-release version, enter pre-release mode:
npx @changesets/cli pre enter <tag> # for example, npx @changesets/cli pre enter alphaThis will write a .changeset/pre.json that configures the pre-release tag and initial version. This file should be committed to the repository.
Note: Once you are in pre-release mode, you do not have to enter it every time. When you are ready to exit pre-release mode, run:
npx @changesets/cli pre exitVersion bumps, and publishing (Changesets)
Create a changeset describing your change(s)
Run the interactive prompt and follow the questions:
npx @changesets/cliThe command creates a file under the
.changeset/directory that describes the packages and the release type (patch/minor/major). You can edit this file to add more details, such as a link to the issue or pull request that the change addresses. The file will get a nonsensical name likefire-penguin-annex.md, and that's to be expected. These files are only in the repository for a short time and are used to generate changelogs and version bumps. They are not published to NPM and are cleaned up after the release is published.
Bump versions locally (optional)
To update package.json versions and changelogs locally before publishing:
npx @changesets/cli versionCommit the resulting changes (package.json updates and generated changelog files):
git add . git commit -m "chore(release): version packages and changelogs"
Publish
Option A — Let the repository automation handle publishing (recommended):
- Push your branch to GitHub and open a PR. The CI / release automation will run and, depending on the configuration and merged changesets, will publish releases when merged to
main.
- Push your branch to GitHub and open a PR. The CI / release automation will run and, depending on the configuration and merged changesets, will publish releases when merged to
Option B — Publish locally (requires NPM credentials and appropriate tokens):
npm run releaseThis script typically runs your tokenized publish flow (it may run builds and then
changeset publish).
How the automation works (GitHub Actions)
- There is a CI workflow configured to automate release and publish:
- The workflow runs on pushes to
mainand uses the Changesets GitHub Action. - The action can either create a release PR or publish directly to NPM depending on repository and action settings.
- The workflow uses repository secrets:
GITHUB_TOKEN— standard workflow permission for the action to create PRs/commits.
- The action is configured to run the project’s release script (for example
npm run release) and is run in a controlled environment; it will also disable Husky hooks during automated runs (HUSKY=0) to avoid local commit hooks blocking automation.
- The workflow runs on pushes to
Notes, tips, and troubleshooting
- Ensure your changeset accurately reflects the semantic change (patch/minor/major). Changesets drives the version bump and changelog generation.
- Pre-release flows:
- The repository includes a
.changeset/pre.jsonconfiguration that sets a default pre-release tag (e.g.,alpha) and initial versions for pre-release packages. Usenpx @changesets/cli pre enter <tag>to begin a pre-release cycle. - When in pre mode, version bumps will produce pre-release identifiers (for example,
1.0.0-alpha.1).
- The repository includes a
- CI vs local publish:
- For most contributors, pushing a properly authored changeset and opening a PR is the recommended route—automation will create the release or open the release PR for maintainers to review.
- If you must publish locally, make sure
NPM_TOKENis configured in your environment or use a CI/protected account to run the publish steps.
- If releases are not being published as expected:
- Verify
NPM_TOKENexists in repository secrets and has publish scope. - Ensure the commit/push to
maincontains a changeset (or the automation has been triggered by the Changesets action). - Review the release workflow logs in GitHub Actions for details (it will show the changesets step and any publishing errors).
- Verify
- If you want to change the default pre-release tag (for example, from
alphatobeta), update the.changeset/pre.jsonfile and follow the pre-mode steps above.
Example quick flow (pre-release -> publish via automation)
- On a feature branch, implement changes.
- Enter pre mode if you want pre-release tagging:
npx @changesets/cli pre enter --tag alpha
- Run
npx @changesets/cliand follow the prompts (choose the appropriate release type). - Commit the changeset file(s), push the branch, and open a PR.
- Once the PR is merged to
main, the repository release workflow will pick up the changeset and publish the pre-release to NPM (providedNPM_TOKENand workflow permissions are set).
If you have questions about changing the pre-release tag or the release automation behavior, or if you want a walkthrough of creating a test release in a fork, please open an issue or ask in the PR review comments.
Component Versions
| Component | Status |
| ------------ | --------- |
| usa-banner | Beta |
| usa-link | Pre-alpha |
