Skip to content

Open source design and front-end development resources for creating Section 508 compliant, responsive, and consistent websites.

License

Notifications You must be signed in to change notification settings

CMSgov/design-system

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

CMS Design System

The design system is a set of open source design and front-end development resources for creating Section 508 compliant, responsive, and consistent websites. It builds on the U.S. Web Design System and extends it to support additional CSS and React components, utility classes, and a grid framework to allow teams to quickly prototype and build accessible, responsive, production-ready websites.

Contents

Packages

You're currently at the root of a monorepo containing multiple NPM packages located in the packages directory. View the README.md in each of these for additional details.

Name Description
CMS Design System The core CSS, JS, and React components for the design system.
@cmsgov/design-system
Healthcare.gov Design System Design system used by application teams at healthcare.gov
npm
Medicare.gov Design System Design system used by application teams at medicare.gov
npm
CMSDS Documentation Gatsby based CMSDS Documentation site.

Running locally

This project uses npm for package management. If you're using a node version manager, set your node version to our project default with a command like nvm use (nvm) or n auto (n). If you're not using a node version manager, you can inspect our .nvmrc file to see what version we're currently using.

Note: When you create a Git commit, any staged scripts will be automatically run through appropriate linters and formatters. If a linter catches an error, your commit will fail. This is a feature, not a bug :)

Scripts

These scripts can all be run from the root level of the repo:

  • npm install
    • Note that because we use npm workspaces, our design system packages are symlinked in the root node_modules directory to be used directly by our other packages. This means that the ds-healthcare-gov package always uses the most up-to-date version of our local design-system package, and so on.
  • npm run build
    • Compiles everything and makes things release-ready
    • Building is required to get TypeScript completion for the core package in child design system packages
  • npm run build:{core,cmsgov,healthcare,medicare}
    • Builds a specific brand of the design system and its corresponding package
    • npm run build:core -- --analyze-bundles will run a bundle analysis and write reports to ./bundle-analysis
  • npm run build:docs
    • Statically builds a copy of the doc site
    • You can then serve it with npm run serve:docs
  • npm run build:storybook
    • Statically builds a copy of Storybook to ./storybook-static
    • You can then serve it with npm run serve:storybook
    • For development, just use npm run storybook
  • npm run build:examples
    • Statically builds a copy of the example projects in ./examples
    • You can then serve them with npm run serve:examples
    • Alternatively you can build and run individual examples. See the README in examples directory for more details.
  • npm run start
    • Starts local server running the documentation site
    • Regenerates documentation when files change
    • Before running start run the build command
  • npm run storybook
    • Starts storybook for easier local development for the core package
    • npm run storybook:react starts Storybook with React instead of Preact
  • npm run test
    • Alias of npm run test:unit
  • npm run test:unit
    • Runs JS unit tests for all packages
    • npm run test:unit -- -u updates Jest snapshots
    • npm run test:unit:preact runs the unit tests in Preact mode
    • npm run test:unit:wc runs the unit tests for the web components, which have to run in Preact mode
  • npm run test:browser
    • Runs accessibility and visual-regression tests using Playwright. See Visual regression testing section below for details. This is the base command that defaults to the basic tests that cover Storybook stories, but we have several different kinds of browser tests under different sub-commands.
    • Note that this command will accept any arguments that Playwright accepts.
    • npm run test:browser -- -u updates reference screenshots used for visual regression testing. Update these only when we expect the visual changes. You can use this argument on any of the browser-test sub-commands to update snapshots for specific kinds of tests.
    • npm run test:browser -- --no-build will skip building the tests' pre-requisites. This is useful if you've already done it and haven't made any changes to the source.
    • npm run test:browser -- --grep "Alert" will only run tests with "Alert" in the name.
    • npm run test:browser:interaction runs VRT interaction tests to validate visual state of components after interaction.
    • npm run test:browser:examples runs VRT tests for our example projects.
    • npm run test:browser:storybook-docs checks for regressions in prop tables in storybook docs.
    • npm run test:browser:all runs all of our visual regression tests.
  • npm run lint
    • Runs just the linting portion of the tests, eslint and stylelint
  • npm run type-check
    • Checks static TypeScript types. Note that the core package must build successfully for downstream type checks to work.
  • npm run deploy-demo
    • Builds the doc site locally and deploys it to a branch-specific path on GitHub Pages. The terminal will display the URL where the demo was deployed to after it is done running.
  • npm run release
  • npm run release:notes
    • Interactive script that generates draft release notes and associated ticket information from GitHub Milestones in the CMSDS public repository.
  • npm run release:patch
    • Interactive script that collects the merge commits from pull requests associated with a given milestone and cherry-picks them onto the current branch (use with release branch)

Visual regression testing

We use Playwright to test our components for visual regressions. We have several suites of visual regression tests, but our main suite uses Storybook stories as references. These tests will load a story or other reference material, take a screenshot within a docker container (for consistency), and compare those screenshots with ones previously taken and committed to version control.

Tests can be run in a docker container or out, but we only check in VRT reference images taken inside the docker container, because taking them outside of a container will produce inconsistent results from machine to machine. The reason you might run them outside of docker is if you're working on the tests themselves and want to run in headful mode so you can see what's happening and troubleshoot Note that updating the visual regression test reference images locally requires that you be signed into Docker.

There are a lot of tests, so it can be helpful to constrain the tests you run locally by using Playwright's --grep argument.

Updating the visual regression tests with Docker:

  1. Open the Docker app, and make sure you're signed in (Docker Desktop requires a license now).
  2. Run npm run test:browser to begin comparing component images
    1. If differences are detected and unexpected, evaluate your changes - we only want to update and commit references when we expect the visual changes detected.
    2. If differences are detected and expected, run npm run test:browser -- -u, verify the changes, and then commit them.

Development outside of Docker:

  • Run any of the browser-test sub-commands with the --no-docker flag, like npm run test:browser:examples --no-docker.
  • If you've never installed Playwright, running the npm run test:browser command will prompt you to install it, which you will want to do. The reason we don't need it installed when running it in Docker is because the Docker image contains all of its own dependencies.
  • Because snapshots will probably fail outside of the Docker container, pass --ignore-snapshots if you want to just see that the tests execute properly.
  • You can turn off headless mode by using Playwright's --headed flag.
  • Playwright's --debug flag is another helpful argument because it will pause and allow you to step through the tests.
  • Don't forget that you can run a subset of tests by using Playwright's --grep argument.
  • Remember that passing --no-build will skip re-building the source material like Storybook stories if you haven't made any changes to them and are only changing the tests themselves.
  • Here's an example of a command you might run to debug the dropdown tests: npm run test:browser:interaction --no-docker --no-build --headed --debug --ignore-snapshots --grep "Dropdown"

Design Assets

The CMS Design System provides a Figma file and library containing components, styles, and design tokens. These assets are regularly updated alongside the codebase, and updates are automatically synced for designers using the Figma Library, across all CMS brands.

We use Figma's multi-mode variable system to define theme variants for each of our theme-level tokens. These theme-level tokens can be used in our shared design library. Tokens can be edited by developers comfortable with JSON, and by designers using Figma's variable tables. Changes to tokens can be synced both ways: from the code repository to Figma, and from Figma to the code repository.

Examples

Examples of the design system in use can be found in the examples directory.

Contributing

Please read the CONTRIBUTING.md document to learn about contributing to the design system, and our coding guidelines.

Contact

To get in touch with the CMS Design System team, please visit design.cms.gov/contact for a list of ways to contact us.

One of our goals is to ensure a welcoming environment for all contributors. Please take a look at our Code of Conduct to learn more.

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy