Skip to main content Red Hat Design System logo Contribute on Github v2.0.0 Home
About About the design systemHow we buildRoadmap
Get started OverviewDesignersDevelopers
Foundations OverviewColorGridPersonalization patternsSpacingTypography
Tokens Overview Global colorBox shadowTypographyBorderOpacitySpaceLengthIconBreakpointsMedia queries
Elements All elements Accordion Alert Audio player Avatar Back to top Badge Blockquote Breadcrumb Button Call to action Card Code block Dialog Footer Health index Icon Navigation (primary)Planned Navigation (secondary) Pagination PopoverPlanned Progress stepsPlanned Site status Skip link Spinner Statistic Subnavigation Surface Switch Table Tabs Tag Tile Timestamp Tooltip Video embed
Patterns All patternsAnnouncementCardDisclosureFilterFormLinkLink with iconLogo wallSearch barSkip navigationSticky bannerSticky cardTabsTileVideo thumbnail
Accessibility FundamentalsContentDesignDevelopmentContributorsQa and testingAssistive technologiesResources
Design/code status Release notes Get support

Overview

  1. Introduction
  2. Installation
  3. Token categories
  4. Types of tokens
  5. Why we need tokens
  6. Tokens and our design system
  7. Naming tokens
  8. Themes
  1. Introduction
  2. Installation
  3. Token categories
  4. Types of tokens
  5. Why we need tokens
  6. Tokens and our design system
  7. Naming tokens
  8. Themes

Introduction

Design tokens are the source of truth of our design decisions. They are also the values needed to maintain our design system, including color, space, typography, etc. Designers, developers, engineers, etc. use tokens instead of hard-coded values to create flexible yet seamless user experiences across a variety of platforms and technologies. Design tokens will soon be directly integrated into all of our websites, libraries, and tools.

Flow showing how a color like brand red becomes a token, how it is named, and how it is applied to a call to action

Installation

To install design tokens, please visit our dedicated repo for instructions.

Install our design tokens

Token categories

We want your feedback on our tokens. Contact us if there are missing values or if you have an idea for an output format or tool integration.

Types of tokens

Global tokens

Global tokens represent the foundations of our design language and should have context-agnostic names. These can be used and are inherited by other token types.

--rh-brand-red-500

Semantic tokens

Semantic tokens represent context or abstraction. They communicate the purpose of a token and are effective when a value with a single intent is used multiple times.

--rh-color-surface-lightest

Element tokens

Element tokens link semantic tokens to specific elements. They are prefixed with the element name and ship in the @rhds/elements package, rather than @rhds/tokens.

--rh-cta-color-primary

Why we need tokens

In addition to being the source of truth of our design decisions, design tokens help us track system-wide changes. When we make an update, that change will propagate consistently across all of our experiences. For example, if we update a color to be more accessible, or a font size to be more legible, these changes will propagate to every page which uses the updated @rhds/tokens package.

Design tokens can also bring teams together under common practices. For example, designers, developers, engineers, etc. can all use the same tokens and work toward consistency even if a token is updated.

Flow showing how changing a global token like a color will propagate through the entire design system

Tokens and our design system

We are working toward a platform-agnostic and shareable resource for our collective design decisions. Our goal is to enable users to download, customize, and apply tokens to their designs and code without keeping track of so many websites, libraries, and tools.

Flow showing how tokens can be utilized in design programs as well as applied to various touchpoints like brand, web, and product

Naming tokens

Design tokens are names based on how they are used. For example, --rh-color-surface-lightest is used as a background colour in light color contexts. A clear and predictable name ensures that attributes are displayed correctly and any actions are communicated clearly. Tokens should be named by proceeding from the general to the specific, e.g. colour (general), surface (more specific), lightest (most specific).

Destructive button with a Danger text label showing its assigned token name underneath

Aliases

Some of our design tokens leverage an additional layer of abstraction called aliases. Alias tokens point to a global token which holds their value.

We use aliases to help systematize the desired values referenced by our tokens. One benefit of this approach is that by using alias tokens, users can reference semantic aliases instead of hard-coded values. Another benefit is that it enables flexibility. If we need to update an alias and want those changes applied across the design system, we only need to change that single alias in order for it to propagate everywhere.

Flow showing how 1 global token is applied to 2 different elements because the alias names are different

Themes

Themes are collections of design tokens that reference specific values. These values change when a user switches themes. Using themes enables us to ship one design system while serving multiple design languages that need to meet different audience or brand requirements.

Examples of how tokens are applied to elements in the light and dark themes

Other libraries

To learn more about our other libraries, visit the getting started page.

© 2021-2024 Red Hat, Inc. Deploys by Netlify