Co-Pilot
Updated 24 days ago

design-tokens-skill

Iilikescience
0.0k
ilikescience/design-tokens-skill
82
Agent Score

💡 Summary

This skill provides expert guidance on design tokens using the DTCG specification.

🎯 Target Audience

UI/UX DesignersFront-end DevelopersProduct ManagersDesign System EngineersAccessibility Advocates

🤖 AI Roast:Powerful, but the setup might scare off the impatient.

Security AnalysisMedium Risk

Risk: Medium. Review: shell/CLI command execution; outbound network access (SSRF, data egress); API keys/tokens handling and storage; filesystem read/write scope and path traversal; dependency pinning and supply-chain risk. Run with least privilege and audit before enabling in production.


name: design-tokens description: Expert in design tokens using the DTCG specification. Use this skill when users ask about design tokens, DTCG format, token validation, formatting, transformation, color spaces (sRGB, Display P3, OKLCH), references and aliasing, resolvers, theming with modifiers/contexts, multi-platform design systems, accessibility, or working with tools like jq, jsonata, and terrazzo. Helps with token file creation, resolver configuration, structure, naming conventions, and best practices.

Design Tokens Expert

Expert guidance for working with design tokens following the Design Tokens Community Group (DTCG) specification.

Quick Reference

| Topic | Reference | |-------|-----------| | Token types, structure, validation | reference/format.md | | Color spaces, components, alpha, common mistakes | reference/color.md | | Sets, modifiers, resolution order | reference/resolver.md | | jq, JSONata, Figma export, Terrazzo config | reference/tools.md | | Common patterns and examples | examples/use-cases.md |

Getting Started: See Getting Started Guides for step-by-step workflows.

Specification Sources

Based on the latest DTCG Draft Community Group Reports:

Core Concepts

Token Structure

A token is a JSON object with $value. Special properties use $ prefix:

{ "brand-blue": { "$type": "color", "$value": { "colorSpace": "srgb", "components": [0.15, 0.39, 0.92], "hex": "#2563eb" }, "$description": "Primary brand color" } }

Token Types

Atomic: color, dimension, fontFamily, fontWeight, duration, cubicBezier, number

Composite: strokeStyle, border, shadow, gradient, typography, transition

See reference/format.md for complete type definitions.

Color Format

Colors use structured objects (not hex strings):

{ "$type": "color", "$value": { "colorSpace": "srgb", "components": [1, 0, 0.5], "alpha": 0.8, "hex": "#ff0080" } }

Supported spaces: srgb, display-p3, oklch, oklab, hsl, hwb, lab, lch, and more. See reference/color.md.

References (Aliasing)

Two syntaxes supported:

  1. Curly braces - Token-level references: "{path.to.token}"
  2. JSON Pointer ($ref) - Property-level access: {"$ref": "#/path/to/$value/property"}

Token reference example:

{ "color": { "primary": {"$type": "color", "$value": {"colorSpace": "srgb", "components": [0, 0.4, 0.8]}} }, "button": { "background": {"$type": "color", "$value": "{color.primary}"} } }

JSON Pointer example (accessing array elements):

{ "blue": { "$type": "color", "$value": {"colorSpace": "okhsl", "components": [0.733, 0.8, 0.5]} }, "blue-hue": { "$type": "number", "$ref": "#/blue/$value/components/0" } }

See reference/format.md for complete reference syntax details.

Groups and Type Inheritance

Groups organize tokens. $type on a group applies to all children:

{ "spacing": { "$type": "dimension", "sm": {"$value": {"value": 8, "unit": "px"}}, "md": {"$value": {"value": 16, "unit": "px"}}, "lg": {"$value": {"value": 24, "unit": "px"}} } }

Resolvers for Theming

Resolvers manage tokens across contexts (themes, platforms, densities):

{ "name": "my-system", "version": "2025.10", "sets": { "core": {"sources": [{"$ref": "tokens/base.json"}]} }, "modifiers": { "theme": { "contexts": { "light": [{"$ref": "themes/light.json"}], "dark": [{"$ref": "themes/dark.json"}] }, "default": "light" } }, "resolutionOrder": [ {"$ref": "#/sets/core"}, {"$ref": "#/modifiers/theme"} ] }

See reference/resolver.md for complete documentation.

Getting Started Guides

Quick Start: Convert CSS Variables to DTCG

Starting point: Existing CSS custom properties

:root { --color-primary: #2563eb; --color-background: #ffffff; --spacing-sm: 8px; --spacing-md: 16px; }

Step 1: Create primitives.tokens.json

{ "color": { "primitive": { "$type": "color", "blue-500": { "$value": { "colorSpace": "srgb", "components": [0.145, 0.388, 0.922], "hex": "#2563eb" } }, "white": { "$value": { "colorSpace": "srgb", "components": [1, 1, 1], "hex": "#ffffff" } } } }, "spacing": { "$type": "dimension", "scale": { "sm": { "$value": { "value": 8, "unit": "px" } }, "md": { "$value": { "value": 16, "unit": "px" } } } } }

Step 2: Create semantic.tokens.json with references

{ "color": { "interactive": { "$type": "color", "primary": { "$value": "{color.primitive.blue-500}" } }, "background": { "$type": "color", "page": { "$value": "{color.primitive.white}" } } }, "spacing": { "$type": "dimension", "component": { "padding": { "$value": "{spacing.scale.sm}" }, "gap": { "$value": "{spacing.scale.md}" } } } }

Conversion tips:

  • RGB hex to sRGB: divide each channel by 255 (e.g., 37/255 = 0.145)
  • Keep hex as fallback in the hex property
  • Create semantic layer for purpose-driven naming

Quick Start: Set Up Terrazzo with Dark Mode

Step 1: Install dependencies

npm install -D @terrazzo/cli @terrazzo/plugin-css

Step 2: Create token files with mode extensions

tokens/themes/light.tokens.json:

{ "$extensions": { "mode": "light" }, "color": { "background": { "$type": "color", "page": { "$value": { "colorSpace": "srgb", "components": [1, 1, 1], "hex": "#ffffff" } } }, "text": { "$type": "color", "primary": { "$value": { "colorSpace": "srgb", "components": [0.07, 0.07, 0.07], "hex": "#121212" } } } } }

tokens/themes/dark.tokens.json:

{ "$extensions": { "mode": "dark" }, "color": { "background": { "$type": "color", "page": { "$value": { "colorSpace": "srgb", "components": [0.07, 0.07, 0.07], "hex": "#121212" } } }, "text": { "$type": "color", "primary": { "$value": { "colorSpace": "srgb", "components": [0.95, 0.95, 0.95], "hex": "#f2f2f2" } } } } }

Step 3: Create terrazzo.config.mjs

import { defineConfig } from "@terrazzo/cli"; import pluginCSS from "@terrazzo/plugin-css"; export default defineConfig({ tokens: [ "./tokens/primitives.tokens.json", "./tokens/themes/light.tokens.json", "./tokens/themes/dark.tokens.json" ], outDir: "./dist/", plugins: [ pluginCSS({ filename: "tokens.css", modeSelectors: [ { mode: "light", selectors: [":root", "[data-theme='light']"] }, { mode: "dark", selectors: ["[data-theme='dark']", "@media (prefers-color-scheme: dark)"] } ] }) ] });

Step 4: Build and use

npx terrazzo build

In your HTML:

<html data-theme="light"><!-- or "dark" -->

Quick Start: Import Figma Variables Export

Step 1: Export from Figma

  • Open Variables panel in Figma
  • Use a DTCG export plugin or Figma's built-in export
  • Save as figma-export.json

Step 2: Validate the export

# Check JSON is valid jq '.' figma-export.json > /dev/null && echo "Valid JSON" # List all token paths jq -r 'paths(has("$value")) | join(".")' figma-export.json

Step 3: Add mode extensions if needed

If Figma exported separate mode files, add $extensions.mode:

# Add mode to light theme file jq '. + {"$extensions": {"mode": "light"}}' light.json > light.tokens.json

Step 4: Add hex fallbacks (if missing)

Figma exports sRGB components but may omit hex:

# Quick check if hex values exist jq '.. | objects | select(.colorSpace == "srgb") | select(.hex == null)' figma-export.json

Step 5: Configure Terrazzo

Create terrazzo.config.mjs pointing to your imported files and build.

Common Figma export issues:

  • Flat structure (no primitives/semantic separation) - reorganize manually
  • Space in token names - use jq to convert to kebab-case
  • Missing $type on groups - add type inheritance

Workflows

Creating a Token File

Token File Creation:
- [ ] Step 1: Define file structure (primitives → semantic → components)
- [ ] Step 2: Create primitive tokens with explicit types
- [ ] Step 3: Create semantic tokens referencing primitives
- [ ] Step 4: Validate structure and references
- [ ] Step 5: Test with target tools (Terrazzo, etc.)

Step 1: Define structure

Organize into layers:

tokens/
├── primitives.tokens.json   # Raw values (colors, spacing scales)
├── semantic.tokens.json     # Purpose-driven aliases
└── components.tokens.json   # Component-specific tokens

Step 2: Create primitives

{ "color": { "primitive": { "$type": "color", "blue": { "500": {"$value": {"colorSpace": "srgb", "components": [0.15, 0.39, 0.92], "hex": "#2563eb"}} } } } }

Step 3: Create semantic tokens

{ "color": { "interactive": { "$type": "color", "default": {"$value": "{color.primitive.blue.500}"} } } }

Step 4: Validate

Check for:

  • All tokens have resolvable $type
  • No circular references
  • Valid value formats for each type
  • Names don't contain {, }, . or start with $

Step 5: Test with tools

terrazzo validate tokens.json terrazzo build --input tokens.json --output test.css --format css

Settin

5-Dim Analysis
Clarity9/10
Novelty7/10
Utility9/10
Completeness8/10
Maintainability8/10
Pros & Cons

Pros

  • Comprehensive guidance on design tokens.
  • Supports multiple color spaces.
  • Facilitates multi-platform design systems.

Cons

  • May require familiarity with JSON.
  • Complexity can be overwhelming for beginners.
  • Limited to design token use cases.

Related Skills

flutter-claude-code

A
toolCo-Pilot
82/ 100

“Powerful, but the setup might scare off the impatient.”

claude-designer-skill

A
toolCo-Pilot
82/ 100

“Powerful, but the setup might scare off the impatient.”

figma-use

A
toolCo-Pilot
82/ 100

“Powerful, but the setup might scare off the impatient.”

Disclaimer: This content is sourced from GitHub open source projects for display and rating purposes only.

Copyright belongs to the original author ilikescience.