Notice: Node.js and Yarn needs to be installed on your local machine.
git clone <repository-url>
yarn install
cd packages/tokens
yarn run lint
yarn typecheck
yarn build
See below for more details about what these scripts do.
The tool used to process the design tokens is Style Dictionary. It takes a set of JSON files in the src
folder, process them applying specific filters and transformations, and generates in output a bunch of files in different formats (eg. CSS/Sass, JS, JSON) in the dist
folder.
Style Dictionary is run via a custom build
script (written in Node.js/TypeScript). In this script we generate dynamically a configuration object, pass it to Style Dictionary and then launch the buildPlatform
command. This is done for both products
and marketing
(they have different designs, so also use different design tokens).
Whenever there is an update to the "foundations/components" in Figma (e.g. a new color is added), these changes need to be transfered also to the code. This means updating the design token names/values in a specific JSON file in the src
folder, re-generate the tokens files in the output dist
folder, and then releasing them as package to the npm registry, so that can be used by other tools and projects.
- Make sure you have done the initial setup of the project (see details above)
- Make sure your local
main
branch is up to date - Create a custom branch from
main
.
The "build" step takes the "source" JSON files, process them, and generates in "output" a set of files that later will be published as npm package.
You can find the code that relates to this step in the file /scripts/build.ts
.
To run this script use the following command in your CLI (while in the packages/tokens
folder):
yarn build
This action will:
- Define a set of custom transformation methods
- Cleanup the
dist
folder - For each of the target platforms (
products
andmarketing
):- initialize Style Dictionary with a custom configuration specific for that target
- build the design tokens for the
web
platform- Style Dictionary this
- Check the git diff:
- if you see only the
Generated on
value changed in the output files it means there are no updates in the tokens, so there's no need to commit the changes. - if there were changes to the tokens names or values, you will see changes in the JSON files in the
src
folder and in the generated files in thedist
folder.
- if you see only the
- Commit and push the changes, then submit a pull request in GitHub.
- Once approved and merged to the
main
branch, you can proceed to the release phase.
See the release guide for details.