Design tokens
Design tokens are design decisions, translated into data. They act as a “source of truth” to help ensure that product experiences feel unified and cohesive.
data:image/s3,"s3://crabby-images/4e0b5/4e0b54d5bda879855cfcf088a33f21c1459cf3fd" alt=""
data:image/s3,"s3://crabby-images/98db4/98db46e4a7b0afce32d77e222c553ab40b27e867" alt=""
What are design tokens?#
Spectrum’s design token system#
Our design token system prioritizes predictability and flexibility. The overall methodology is to have a focused set of tokens rather than all possible tokens for all possible scenarios. However, it's important to note that tokens only provide some — if not most — of the information needed to represent or implement a UI component. The token system is one resource in Spectrum’s offerings rather than a complete knowledge set, and it’s used alongside design and engineering documentation.
Design tokens are directly integrated into our component libraries, UI kits, and other resources. They cover the various options of platform scales, color themes, component states, and much more. We also offer a variety of token types for teams to use directly within their products if they're not using a Spectrum implementation.
Design token types and terminology#
Token (or, design token)#
A design decision, represented as data. Each token has a carefully chosen name that communicates its intention and scope, and follows a set naming convention.
Value#
The data associated with the token name. This could either be another token (called an
picker-border-width
border-width-100
alert-dialog-minimum-width
Alias#
A token that references another token, instead of referencing a hard-coded value.
negative-border-color-default
negative-color-900
Component-specific token#
A token used for a particular component.
tooltip-maximum-width
200 px (mobile)
divider-thickness-small
Global token#
A token used across the design system. This is the opposite of a
corner-radius-75
component-height-100
40 px (mobile)
Examples of design tokens#
Size tokens#
Many of Spectrum’s components use size tokens that follow a t-shirt sizing categorization convention (small, medium, large, extra-large). These are designed to offer a limited number of size options that follow a linear scale: for example, on desktop, each size increases or decreases by 8 px. Since they’re used together to create hierarchy, it’s important to have a limited amount of sizes that work well in combination.
Specific components that need a wider range of sizing options use size tokens that follow a non-linear scale, where each increasing size is a multiple of the previous one. These are only for components that are frequently used inside of other components across a wide range of use cases — like avatars or thumbnails — and therefore require a more flexible range of sizes. They’re named with numerals because they’re not tied to specific t-shirt sizes.
We use detailed specs as part of our token definition process. Here’s some examples of the specs for size tokens for the
data:image/s3,"s3://crabby-images/c18f2/c18f2e8bbfdc27d9e00fb237ae1ae4c3d6878542" alt="Example of token specs showing size tokens. Global t-shirt size tokens for the text field component are component-height-75 for small, component-height-100 for medium, component-height-200 for large, and component-height-300 for extra-large. Component-specific size tokens for the avatar component are avatar-size-50, avatar-size-70, avatar-size-100, avatar-size-200, avatar-size-300, avatar-size-400, avatar-size-500, avatar-size-600, and avatar-size-700."
data:image/s3,"s3://crabby-images/d88db/d88dbdcc261feddd4b85b41df34045f3c0f24903" alt="Example of token specs showing size tokens. Global t-shirt size tokens for the text field component are component-height-75 for small, component-height-100 for medium, component-height-200 for large, and component-height-300 for extra-large. Component-specific size tokens for the avatar component are avatar-size-50, avatar-size-70, avatar-size-100, avatar-size-200, avatar-size-300, avatar-size-400, avatar-size-500, avatar-size-600, and avatar-size-700."
Color tokens#
Spectrum has both global and alias color tokens. A global color token is written as a specific value that’s part of the
data:image/s3,"s3://crabby-images/9b042/9b042019833a04311a05844adc126d679b120056" alt="Example of token specs for color tokens. Global color token gray-100 is hex values #F8F8F8 for lightest theme, #323232 for dark theme, #1D1D1D for darkest theme, and #F4F6FC for wireframe theme."
data:image/s3,"s3://crabby-images/5e315/5e3152309617ed77c9e805660eefa8114f011ec6" alt="Example of token specs for color tokens. Global color token gray-100 is hex values #F8F8F8 for lightest theme, #323232 for dark theme, #1D1D1D for darkest theme, and #F4F6FC for wireframe theme."
Layout tokens#
Spectrum’s layout tokens cover all fundamentals, including
data:image/s3,"s3://crabby-images/23b6a/23b6a8b165e987cb046a1ba08147820eade9d5c4" alt="Example of token specs showing various layout tokens for the text field component. Rounding is token corner-radius-100. Border is token border-width-100. Spacing tokens are component-edge-to-text-75 for size small, component-edge-to-text-100 for size medium, component-edge-to-text-200 for size large, and component-edge-to-text-300 for size extra large."
data:image/s3,"s3://crabby-images/01b75/01b75d5a275a4bb1cecef54f22f5b9edb35f898e" alt="Example of token specs showing various layout tokens for the text field component. Rounding is token corner-radius-100. Border is token border-width-100. Spacing tokens are component-edge-to-text-75 for size small, component-edge-to-text-100 for size medium, component-edge-to-text-200 for size large, and component-edge-to-text-300 for size extra large."
How Spectrum names design tokens#
Spectrum names design tokens very intentionally and strategically. This naming practice is part of the token system’s larger goals: to create a focused set of tokens, and to help more people understand and work with tokens in product design and development.
Naming principles#
-
Human-readable. Our tokens are communication tools that humans need to be able to readily understand. They use language and terminology already existing within Spectrum, and values are written as descriptively as possible. We do this to support our diverse array of product stakeholders — not just designers and engineers — who have varying levels of familiarity with and comfort using design tokens.
-
Flat structure. We use a flat structure — not a nested or tree structure — so that we aren’t prioritizing a particular coding construct. This is also so that token names can have a narrative, conversational feel.
-
Predictable and flexible. We follow a token naming structure that maps to a natural language convention and uses a set vocabulary. This allows us to communicate complex information in a way that’s predictable but can accommodate new updates and changes in the design system.
Naming structure#
We use a 3-part structure for coming up with token names: context, common unit, and clarification. It’s based on a common model for human language and narrative-building where the information communicated becomes increasingly granular. Token names start with broad context, then go into more specific detail.
data:image/s3,"s3://crabby-images/80a1b/80a1b4453154d8dbf1110a3aacccced9ad577382" alt="Chart showing the 3-part structure for how Spectrum names design tokens. The first part is the context, which is the most broad idea in what needs to be communicated in the name. Examples of this are a component, a system constant like a border or a background, or a color. The second part is the common unit, which is the most consistent idea. Examples of this are sizing, spacing, styling, or text. The third part is clarification, which is the most specific or detailed idea. Examples of this are a t-shirt size, and index or value, or a user-initiated state."
data:image/s3,"s3://crabby-images/0dd97/0dd97e3018448e4ab1acd23872c39eaac397d8fc" alt="Chart showing the 3-part structure for how Spectrum names design tokens. The first part is the context, which is the most broad idea in what needs to be communicated in the name. Examples of this are a component, a system constant like a border or a background, or a color. The second part is the common unit, which is the most consistent idea. Examples of this are sizing, spacing, styling, or text. The third part is clarification, which is the most specific or detailed idea. Examples of this are a t-shirt size, and index or value, or a user-initiated state."
Naming structure examples#
Not all token names need to have context, common unit, and clarification together — but they all follow the same order. You can think of the most specific piece of information in the hierarchy as equated to the property to set. Here’s some examples:
Usage guidelines#
Using global tokens#
Only use global tokens when there are no available aliases for your use case. Global tokens are easy to reference and are the building blocks of Spectrum, but they’re also the least tied to the logic of our design language.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/c8f55/c8f5504585c3edb29b11a9d6d960cf532dc83c19" alt="Key example showing correct usage of a global token. Token accent-background-color-default used for the background color of an accent button component."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/72a24/72a24f1f34942ce3109dc4f92608c0026f7f1d03" alt="Key example showing incorrect usage of a global token. Token blue-900 used for the background color of an accent button component."
Use aliases wherever they can apply#
Alias tokens are the recommended type to use when building your product with design tokens. They’re a shared language for understanding Spectrum, and they help to associate meaning, context, and intent to the design tokens you’re applying to your product.
Using aliases is a good way to ensure that your product can evolve alongside Spectrum as the design system evolves, and to minimize future maintenance for your product.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/05c50/05c50f5a715f0ba4404f14bbcb334412117712f7" alt="Key example showing correct usage of alias tokens. Tokens corner-radius-100 and disabled-border-color applied to a generic container."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/8166e/8166ee35cb63cc29dc207968b305a09525cb49e7" alt="Key example showing incorrect usage of alias tokens. 4 px and gray-300 applied to a generic container."
Use component-specific tokens for their respective component#
When building Spectrum verified components, use component-specific tokens. This ensures that as a component’s design evolves, you won’t have to retrace any higher-level design decisions that informed the updates.
It’s not recommended to use component-specific tokens interchangeably with other components, unless one is derivative of the other.
data:image/s3,"s3://crabby-images/9ce32/9ce328b25d55255a35291ea36bdd497c2b37ceb7" alt="do"
data:image/s3,"s3://crabby-images/b6719/b67198c320eafd05992b57cf8cf219b0b50d0109" alt="Key example showing correct usage of a component-specific token. Token progress-bar-thickness-small applied to a progress bar component."
data:image/s3,"s3://crabby-images/af2d4/af2d4ebe07d1a6373b352fa41be4b5427ffc328f" alt="dont"
data:image/s3,"s3://crabby-images/1e067/1e067320c0c7ed132d4948b7b8cfaa1b9fa633bf" alt="Key example showing incorrect usage of a component-specific token. Token slider-track-thickness applied to a progress bar component."
Using Spectrum tokens#
For more information, go to the