Skip to content

Latest commit

 

History

History
143 lines (97 loc) · 5.7 KB

README.md

File metadata and controls

143 lines (97 loc) · 5.7 KB

Form Design System

npm

A design system by CB Insights.

Getting started

Installation

The design system is comprised of a number of modules published as a single npm package.

yarn add @cbinsights/fds

or

npm i @cbinsights/fds

Importing

// JS constants like FDS.COLOR_MINT
import FDS from '@cbinsights/fds/lib/js/styleConstants';

// React components
import Flex from '@cbinsights/fds/lib/components/Flex';

// Icons
import CloudIcon from '@cbinsights/fds/lib/react/CloudIcon';

Use this unpkg link to see all files published to the npm package.

Documentation

Versions

This project uses semantic versioning. Refer to the Changelog for details on each major and minor release.


Development

  1. clone this repo
  2. run yarn && yarn build:full

Modules

Commands

Incomplete list of yarn targets.

Building

Some modules rely on others to be built first. It's a good idea to start with a yarn build:full before running focused builds.

Command Description
clean Cleans build artifacts in lib
build:dictionary Builds dictionary docs and lib
build:styles Builds base styles docs and lib
build:icons Builds icons docs and lib
build:comp Builds React component docs and lib
build:mui Builds material-ui theme lib
build:full Cleans all, then builds docs and lib for everything
build:distCSS Creates CSS rollup in lib/assets/

Icons

Command Description
icons:export Runs export script

Storybook

Command Description
storybook Runs local dev storybook server

Other

Command Description
yarn test Runs tests for all relevant packages
yarn snapshot-update Updates snapshots
yarn lint Runs eslint on all js files
yarn precommit Runs lint-staged to verify precommit hook will pass
yarn stats:css Prints a regex used to search all current FDS CSS classes
yarn stats:imports <PATH> Searches <PATH> for FDS component imports and prints a report

Docs

Documentation is published to Github Pages from the docs/ directory in master. Every time the build command is run, docs are regenerated to the root docs/ directory.

Versioning/Publishing

form-design-system is published as a single NPM package.

Please update the minor or major version as appropriate when making changes in a branch

version meaning
Major Introduces breaking changes, requiring consumers to make changes to support the new version
Minor Introduces new components, features or behaviors. Does not require consumers to make changes.
Patch Bug fixes, doc updates, very small changes that do not affect behavior.

Updating version number

We commit the major and minor version as variables in the GitLab CI configuration for this project. GitLab populates the patch version based on pipeline ID.

  CBI_MAJOR_VERSION: 9
  CBI_MINOR_VERSION: 4

To update the package version for @cbinsights/fds...

  1. Update the minor and/or major version in .gitlab-ci.yml
  2. Update CHANGELOG.md with a note about your changes
  3. Submit your PR.

Beta versions

GitLab will publish an npm version for any branch pushed to origin. Non-master branches publish with a "beta" tag followed by the short sha1 hash for the commit. Pushes to master will publish a "latest" version.

Branch version
master X.X.X (npm "latest" tag)
feature/my-cool-feature X.X.0-beta.d270ad1 (npm "beta" tag)