Skip to content

This module contains reusable components for the VA.gov design system published as an NPM package for use in the vets-website frontend codebase.

Notifications You must be signed in to change notification settings

department-of-veterans-affairs/component-library

Repository files navigation

Component library

Publishing workflow Latest version

Looking for install instructions as a consumer of the VA Design System?

This repository is for contributors and maintainers of the VA Design System. If you're looking for the install instructions as a consumer of the VA Design System, check out the install instructions in the VA Design System Documentation.

Repository structure

This is a monorepo containing the following packages:

  • web-components
  • react-components (deprecated)
  • css-library
  • storybook
  • design-system-dashboard-cli
  • integration-examples

The core package is for bundling the web-components and react-components packages into one for publishing.

  • note: The web-components package contains web components and the React bindings for those web components.
  • note: The react-components package is deprecated and will be removed in a future release.

The storybook package is for the combined story files from each *-components package.

The design-system-dashboard-cli package is used to gather metrics on design system usage.

The integration-examples package is for examples of how to integrate the VA Design System into different frameworks and build tools outside of vets-website (VA.gov).

Running Build via Storybook

To install dependencies in the component packages and run a local build of the component library in Storybook, run the following in the command line:

npm run dev

This setup script automates the following tasks:

  1. cd packages/web-components/
    1. yarn install
    2. yarn build
    3. yarn build-bindings (build React bindings)
    4. yarn watch:stencil (optional)
  2. cd ../react-components/
    1. yarn install
    2. yarn build
  3. cd ../core/
    1. yarn install
    2. yarn build
  4. cd ../storybook/
    1. yarn install
    2. yarn storybook

Running tests for web components

To run unit tests for all components, the commands are:

yarn test

and

yarn test.watch

To test a single file, run:

npx stencil test --e2e -- src/components/[component-name]/test/[component-name].e2e.ts

Replace [component-name] with the name of the component you want to test. Optionally, you can add --watchAll after --e2e to watch the file for changes. For example:

npx stencil test --e2e --watchAll -- src/components/[component-name]/test/[component-name].e2e.ts

Another option is to use wildcards to query for certain tests. For example, to run all tests for the va-accordion component, you can run:

npx stencil test --e2e  -- src/components/va-accordion/test/va-accordion-*

Contributing

Branch naming

This repo uses Chromatic to streamline reviews by publishing your changes online. A link containing your changes is automatically added to pull requests to aid others when reviewing your code.

In order for the preview link to work without making edits to the link, follow these rules when naming your branch:

  • Your branch must contain only lowercase letters, numbers and dashes
  • Your branch must not exceed 37 characters

See Chromatic's branch naming documentation for more information.

Content language

Our web components have linting which checks for hard-coded user-facing strings. At the moment this linting isn't integrated into CI - so you will only see it if you run yarn lint or if your editor has ESLint integration through a plugin.

Local development

Local development can be done using Storybook by following the complete build steps outlined in Running Build via Storybook.

Local testing in vets-website with Verdaccio

Contributors are encouraged to test their changes in vets-website using Verdaccio. What is Verdaccio? From the website:

Verdaccio is a simple, zero-config-required local private NPM registry. No need for an entire database just to get started…

Verdaccio allows contributors to publish a new version of the VA Design System component library on their local machine, and preview vets-website with their changes.

Before you begin

  1. VA Design System component library and vets-website require different versions of NodeJS. Be sure you have NVM installed before you begin.

  2. Download Node v14.15.0 and a current Node v18.x.x or v22.x.x

  3. Verdaccio also requires Python3. Ensure you have Python3 installed by opening a terminal window and typing the following command:

    which python3 # Should see output like /usr/bin/python3

    You should see an execution path if Python3 is installed. If not, install it and type which python3 again in a new terminal window.

Installing Verdaccio

  1. Install Verdaccio using NPM or Yarn:

    # Ensure Verdaccio compatibility with vets-website
    nvm use 14.15.0
    
    # If you're using NPM
    npm install --location=global [email protected]
    
    # If you're using Yarn
    yarn global add [email protected]
  2. Verify Verdaccio was installed correctly.

    verdaccio --version # Should see output like v5.5.0
  3. Start Verdaccio on your local machine. The server will be running at localhost:4873.

    verdaccio
  4. Create a new Verdaccio user by entering this command and following the prompts.

    npm adduser --registry http://localhost:4873/

Publish your component-library changes to Verdaccio

The next step is to update the core and web-component package versions in their respective package.json files. Note: You must use Node v18.x.x or v22.x.x for this step.

  1. Navigate to component-library and switch to Node [18, 22]

    cd component-library/
    nvm use 18.x.x # Or version 22
    nvm use 22.x.x
  2. Navigate to packages/web-components and update the package version. Assuming the current version is 10.1.1, you could change the version to 10.1.2-rc1 or something similar.

    ! packages/web-components/package.json
    
    - "version": "10.1.1"
    + "version": "10.1.2-rc1"
  3. Navigate to packages/core and update the package version using the same logic

    ! packages/core/package.json
    
    - "version": "15.0.1"
    + "version": "15.0.2-rc1"
  4. Still in the packages/core package.json file, update the VADS dependency entry

    ! packages/core/package.json
    
    dependencies: {
    -   "@department-of-veterans-affairs/web-components": "workspace:*"
    +   "@department-of-veterans-affairs/web-components": "^10.2.2-rc1"
    }
  5. Build the components using the Running Build via Storybook instructions. Ignore the last step to start Storybook; you won't need it for this process.

  6. Publish the core package to Verdaccio

    cd ../packages/core/
    npm publish --registry http://localhost:4873
  7. Publish the web-component package to Veraccio

    cd ../packages/web-components/
    npm publish --registry http://localhost:4873

Link vets-website to local Verdaccio registry

You're now ready to switch to vets-website and update the VADS dependency. Note: You must use Node v14.15.0 for this step.

  1. Run the following commands to point to your local Verdaccio registry

    cd vets-website/
    nvm use 14.15.0 # Ensure correct Node version
    yarn config set registry http://localhost:4873
    npm config set registry http://localhost:4873
  2. Add the local core package to vets-website and start the server

    yarn add -W @department-of-veterans-affairs/[email protected]
    yarn watch

Reverting to the default registry

After you are finished testing, reset vets-website to use the standard registry. Note: You must use Node v14.15.0 for this step.

# Using NPM
nvm use 14.15.0 # Ensure correct Node version
npm config set registry https://registry.yarnpkg.com/

# Or using Yarn
nvm use 14.15.0
yarn config set registry https://registry.yarnpkg.com/
yarn config set npmRegistryServer https://registry.yarnpkg.com/

Troubleshooting

  1. If you encounter Webpack errors during the yarn watch step in vets-website, try deleting the node_modules/ folder, then reinstalling dependencies.

    cd vets-website/
    rm -rf node_modules/ # Careful with this one
    yarn install
    yarn watch
  2. If you encounter errors in the component-library or vets-website build or watch steps, try changing your Node version.

    nvm use 14.15.0
    nvm use 18.x.x OR nvm use 22.x.x

Using Verdaccio on GitHub Codespaces

This is useful if you want to test changes to the component-library in a Codespace and get a public URL to share with others. See Using GitHub Codespaces for more information on how to set up a Codespaces for vets-website.

  1. Start a Codespace within the vets-website repo
  2. Clone the component-library repo in the Codespace filesystem, and change to your desired branch
    git clone https://github.com/department-of-veterans-affairs/component-library.git
    cd component-library
    git checkout your-branch-name
  3. Verdaccio may work better in it's own folder, so it can be installed in a new folder.
    cd /workspaces
    mkdir local-npm-registry
    cd local-npm-registry
    npm init -y
    # make sure to use node v14 for this step
    nvm use 14.15.0
    npm install [email protected]
  4. Optionally, add a start script to package.json
    "verdaccio": "verdaccio"
  5. Start Verdaccio
    npm run verdaccio
  6. Verify Verdaccio is running
    curl -X GET http://localhost:4873/
    # or expose this port publicly in GitHub Codespaces and visit URL in browser
  7. Add npm user to the local registry
    npm adduser --registry http://localhost:4873/
  8. Add the local Verdaccio registry to your project
    cd ../vets-website/
    yarn config set registry http://localhost:4873
    npm config set registry http://localhost:4873
  9. Install the local component-library package
    yarn add -W @department-of-veterans-affairs/[email protected]
  10. Follow steps to Publish your component-library changes to Verdaccio and Link vets-website to local Verdaccio registry If at any point you see a connection refused error, make sure you are using node v14.15.0
  11. Run the local watch script for vets-website to start FE dev server, mock API server script, and any other local commands to prepare your environment.
    yarn watch --env entry=your-app-here
    yarn mock-api --responses=path/to/your/mock-api-responses.js
  12. Continue the Set up Codespaces for development workflow steps to finish setting up your Codespace and expose a public port for your use case.

Publishing

Updating the version

To publish changes from the react-components subpackage, make sure the version number in packages/react-components/package.json and the version number in packages/core/package.json have been updated to be one ahead of the published versions.

To publish changes from the web-components subpackage, make sure the version number in packages/web-components/package.json and the version number in packages/core/package.json have been updated to be one ahead of the published versions.

yarn version is available to use to make changes in the CLI. To change the version of the package you are working on run one of the following commands: yarn version major, yarn version minor, or yarn version patch. For guidance on which command to use please see below.

Releasing

The Design System Team will create a release minimally at the beginning of each sprint (every other Thursday), and may additionally be performed as-needed when critical bug fixes need to go out. Reach out in #vfs-platform-support or #platform-design-system Slack channel if you have a need for an unscheduled release.

For Design System Team only:

  1. If you are unsure if a new release should be created, check with the Release Manager and/or the team first.
    • The DST Release Manager is the engineer on duty for the weekly support rotation.
  2. Determine if the releases should be major, minor, or patch releases.
    • Review the PR labels on the merged PRs since the last release to check which is the highest level of change (major, minor, or patch) for each package changed. This will determine the new package.json version.
  3. Create a PR for the component-library that does the following:
    • Update the package.json version in the packages that updates have been made.
      • core (required) - packages/core/package.json must be updated for the publishing workflow
        • web-components (if needed)
        • css-library (if needed)
        • react-components (if needed)
    • Run yarn install in each package directory to update yarn.lock.
    • Create the PR with the tag ignore-for-release.
    • Get approval and merge.
  4. From the repo's homepage click on "Releases" in the right-hand sidebar.
  5. Click on the "Draft a new release" button near the top of the page.
  6. Click on the "Choose a tag" drop-down and type the letter v followed by the new "core" version number. The target should remain main.
    • Example: v50.1.2
  7. For the release title, type the same thing you entered for the tag.
    • Example: v50.1.2
  8. Click on the "Generate release notes" button.
    • If the button is disabled, double-check that the tag/version number is correct and hasn't been released before.
  9. Review the release notes for any typos and/or unnecessary notes.
    • The release notes are intended for public use so they should be professional in tone, easily understandable, and concise.
  10. Ensure the "Set as the latest release" checkbox is checked.
  11. Take a screenshot of the release notes and post in the #design-system-forms channel on Slack.
    • This is to double-check that everything looks good, that there aren't any last-minute additions to the release that need to be included, and for general awareness of what will be released.
  12. Click the "Publish release" button. GitHub Actions will take care of any necessary build and publishing steps.
    • You can watch to make sure the release is created successfully from the Github Actions tab.
  13. Once the packages have been published to NPM, create a PR for the following repositories that updates the dependency versions:

How to choose a version number

Pull requests are labeled as major, minor, patch, ignore-for-release, or css-library for generating release notes.

This repo follows semantic versioning. Here are some examples of which changes correspond to which version (MAJOR, MINOR, or PATCH) increase.

Major

  • Component is removed
  • Component API is changed and it causes a breaking change

Minor

  • New component is added
  • New variant is added for a component
  • Non-breaking or backwards compatible component API change

Patch

  • Accessibility fix
  • Styling fix
  • Functionality fix

About

This module contains reusable components for the VA.gov design system published as an NPM package for use in the vets-website frontend codebase.

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Contributors 95