Tokens Studio for Figma
  • Getting Started
    • Tokens Studio Plugin for Figma
    • Install the Figma Plugin
    • Pro Licence for the Figma Plugin
    • Join the Slack Community
    • Feature Requests - Featurebase
    • Changelog - Featurebase
  • Design Token Fundamentals
    • Intro to Design Tokens
      • Token Anatomy - Type
      • Token Anatomy - Value
      • Token Anatomy - Description
      • Token Anatomy - Name
  • Token Management
    • Token Types
      • Asset
      • Boolean
      • Border - Composite
      • Box Shadow - Composite
      • Color
        • Modified Colors (pro)
        • Gradient Colors
      • Dimension
        • Border Radius
        • Border Width
        • Sizing
        • Spacing
      • Number
      • Opacity
      • Other
      • Text (string)
      • Typography - Composite
        • Font Family
        • Font Weight
        • Font Fallbacks
        • Font Size
        • Line Height
        • Letter Spacing
        • Paragraph Indent
        • Paragraph Spacing
        • Text Case
        • Text Decoration
      • Composition (legacy)
    • Token Values
      • Token Values with References
      • Using Math in Token Values
    • Token Names
      • Token Name Technical Specs
      • Token Groups
      • Edit Token Names
    • Token Description
    • Token Sets
      • JSON View
  • Themes management
    • Themes (pro)
    • Themes that switch
  • Working in Figma
    • Variables and Tokens Studio
    • Styles and Tokens Studio
    • Export to Figma Guide
      • Export Options
      • Export Using Themes (pro)
      • Export Using Token Sets
      • Variables Skipped on Export
      • Styles with Variable References
    • Import from Figma Guide
      • Import Styles from Figma
      • Import Variables from Figma
        • Connect Themes to Imported Variables
        • Imported Variable Types and Token Types
    • Non-local Variables and Styles (pro)
    • Remove Tokens from Figma elements
    • Dev Mode in Figma
  • Settings Management
    • Plugin Settings
    • Base Font Size Setting
    • Token Format - W3C DTCG vs Legacy
  • Token Storage and Sync Integrations
    • Local Document - Figma File Token Storage
    • Remote Token Storage Integrations
      • GitHub - Git Sync Provider
      • GitLab - Git Sync Provider
      • Bitbucket - Git Sync Provider
      • Azure DevOps - Git Sync Provider
      • JSONBin - Cloud Sync Provider
      • Supernova - Cloud Sync Provider
      • Tokens Studio Platform - Cloud Sync Provider
      • URL - Server Sync Provider
      • Generic Versioned Storage - Server Sync Provider
    • Multi-file Sync to Remote Storage (pro)
    • Manage Sync Providers
      • Edit Sync Provider
      • Change Active Sync Provider
      • Remove Sync Provider
    • Sync Changes to Remote Storage - Push and Pull
    • Branch Switching (pro) - Version Control
  • Inspect and Debug Tokens
    • Inspect Tokens
    • Remap Tokens
  • Transform Tokens for Development
    • Style Dictionary + SD Transforms
    • Official docs for Style Dictionary
  • Style Dictionary Playground
  • Troubleshooting
    • Reset Tokens from Dev Console
    • Tokens Studio Status
  • Open Source
    • Contribute
    • Shared Plugin Data
Powered by GitBook
On this page
  • Font Size - Token Type
  • Base font size
  • Design decisions
  • Possible values
  • Values that reference another Token
  • W3C DTCG Token Format
  • Transforming Tokens
  • Resources

Was this helpful?

Edit on GitHub
Export as PDF
PreviousFont FallbacksNextLine Height

Last updated 4 months ago

Was this helpful?

Font Size - Token Type

Font Size Tokens define the height of the glyphs/characters as an individual property to be composed within a . It is not intended to be applied to text elements directly.

In Typography, the Letter Spacing and Line Height properties are related to the Font Size.

Base font size

When you assign a Token Value in Rem Units, it creates a relationship with the system's Base Font Size.

A Rem Unit acts as a multiplier of the Base Font Size. This allows the font size to be controlled by user preferences in a responsive way.

The value of 1rem in the Plugin can be configured in its settings.


Design decisions

Font Size, also known as point size or type size, defines the vertical size of each character/glyph in a typography design element.

A design system typically defines font sizes as a proportional scale to help with visual hierarchy and readability of text elements.

When we apply a Typography Composite Token to a text layer in Figma, these Font Size values will change the text layer:

  • Responsive - value in rem units

    • Example: heading at 2rem paragraph at 1rem

      • a person who has increased the font-size of a mobile phone will see the heading text twice as large as the paragraph text

  • Fixed - value in pixels

    • Example 32px

      • the text will remain the same size when a user zooms into a webpage


Possible values

Like all Tokens defining a dimension design decision, the value for the Font Size property must include a numeric value and, ideally, a unit of measure.

Tokens without a unit specified are applied as the pixel equivalent in Figma.

For Font Size Tokens, math might be used to create dynamic scales of font sizes that follow a particular multiplier, like the golden ratio.

Hard-coded values

The syntax used to write numeric values for the Font Size property is important.

  • Be sure to avoid any spaces between numbers and units of measurement.

  • Units are always written in lowercase.

  • Value should always be greater than 0.

Rem units (rem)

To support responsive design, you can define your Font Size Token in rem units, and the plugin automatically converts the value to the pixel equivalent when the Typography Composite Token is applied to the text element in Figma.

For example, a Font Size Token with a value of 2rem, when applied as a Typography Composite Token, will have letters appear as 32pxtall in Figma.

Tokens Studio supports Font Size Tokens in em units and will treat them the same as rem units when applying them to text layers in Figma.

Pixel units (px)

Should you require the character size to remain static even when users change their preferences, the Font Size value can be defined in pixel units. For example:

20px

Units not supported by Figma

  • percentage (%)

  • em and percentage combined

  • viewport width (vw)

You can still create Font Size Tokens with these units using the Tokens Studio plugin.

When you apply them to design elements in Figma, the Token will be present and visible to engineers inspecting the design element in Figma, but the Token won't interact with the Font Size property in Figma's UI.

It will be up to the engineers working to transform the design Tokens in Style Dictionary if they want to transform the values as you've entered them or change them in some way.

Values that reference another Token

When trying to reference another Token as the Value for a Font Size Token, you will see Tokens in the dropdown list that are:

  • Living in Token Sets that are currently active.

    • In the left menu on the plugin's Tokens page, a checkmark is visible next to the Token Set name.

  • Token Type is compatible:

    • The same = fontSizes

    • number

    • dimension


W3C DTCG Token Format

Font Size is not yet an official Token type in the W3C Design Token Community Group specifications.

"The size of the typography. The value of this property MUST be a valid dimension value or a reference to a dimension Token." - 9.7. Typography

Tokens Studio has added Font Size as an unofficial Token type in anticipation it will be added to the W3C specs in the near future.

Token Type syntax

In Tokens Studio, the Font Size Token has a unique syntax in code which identifies if the Token is:

  • An independent property Token

  • Part of a Typography Composite Token

Looking at the JSON format, the "type" is written in plural "fontSizes" when the Font Size Token is defined as an independent property Token.

This example shows a Font Size property Token named font-size-small with the value in pixels (see line 4).

{
   "font-size-small": {
      "value": "20px",
      "type": "fontSizes"
   }
}

This is in contrast to the Typography Composite Token, which has the property Token "type" written in the singular "fontSize".

This example shows a Typography Composite Token with the Font Weight property Token named font-size-small referenced as the value (see line 5).

{
   "paragraph-3": {
      "value": {
         "fontFamily": "{font-family-sans}",
         "fontWeight": "{font-weight-default}",
         "lineHeight": "{line-height-classic}",
         "fontSize": "{font-size-small}",
         "letterSpacing": "{letter-spacing-tight}",
         "paragraphSpacing": "{paragraphSpacing.none}"
         "paragraphIndent": "{paragraphIndent.none}"
         "textCase": "{textCase.none}",
         "textDecoration": "{textDecoration.none}"
      },
      "type": "typography"
   }
}

Transforming Tokens

When transforming Font Size Tokens, there are specific configurations to be aware of.

Font Size Token values entered as a number without a unit converted to a number with pixels as a unit.

Token Values entered with math equations need to be checked and resolved.

The preprocessor in the SD-Transforms package will automatically convert the Tokens Studio specific Token Type of fontSizes to align with the DTCG Format Token Type of fontSize.

Font Size Tokens, as part of Typography Composite Tokens, require the SD-Transforms option to expand composite Tokens into multiple Tokens.


Resources

Mentioned in this doc:

Figma resources:

CSS resources:

Community resources:

  • WHAT - LINK

  • Font size scalar tool

Known issues and bugs

  • None yet

Requests, roadmap and changelog

  • None

In this property is also called font-size.

There are additional units properties that are not supported in Figma.

However, it is mentioned as a required part of a

→

→

→

SD-Transforms -

Style Dictionary -

Design Tokens Community Group -

Design Tokens Community Group -

Design in Figma -

MDN Web Docs -

W3 Schools -

Tokens Studio Plugin GitHub -

Base Font Size Setting
CSS
commonly used in CSS for Font Size
typography Token
SD-Transforms Read-Me Doc, ts/size/px
SD-Transforms Read-Me Doc, ts/resolveMath
SD-Transforms Read-Me Doc, Using the preprocessor
Read Me
https://styledictionary.com/
W3C Draft
9.7 Typography
Explore Text Properties, Font Size
Font Size
Font Size
Open issues for Token Type Font Size
Typography Token
Page cover image
Creating a new Font Size Token in the Tokens Studio Plugin for Figma.
Cover

Font Size Tokens can be attached to Number Variables in Figma.

The Typography Composite Token form is open, with each property referencing another Token. The Font Size property is highlighted.

Rem Units act as a multiplier of the base font size, so when a user changes their preferences to a larger font size or uses a zoom feature in your product, elements defined in rem units will respond accordingly.

The value of 1rem can be configured in the .

Engineers typically transform Tokens used in code with , which is tool-agnostic. Tokens coming from Tokens Studio require an additional step: , an npm package that prepares Tokens for Style Dictionary.

💡 Something to share?

All Token Types that accept numeric values can use math equations to calculate their value in Tokens Studio.

Jump to the guide on Tokens with Math Values by selecting the card below to learn more.

However, like all Token Types, you can "force" a reference by manually entering the Token Name between curly brackets.

For example {token.name.here}

The value will show a broken reference until the originating Token Set is marked as enabled.

Jump to the guide on Token Values with References by selecting the card below to learn more.

plugin settings for Base Font Size
Style Dictionary
@Tokens-studio/sd-transforms
Submit it here!
Using Math in Token Values
Token Values with References

Make sure you look at the generic SD-Transforms package to include this option, which allows you to further customize this transformation further using Style Dictionary.

→

"object, object" When you transform your Typography Tokens and they show "object, object", it means your SD-Transforms configuration needs to be adjusted to include "expand".

SD-Transforms Read-Me Doc, Using Expand

🐞 If you are experiencing an issue not listed here, please reach out to us on the Troubleshooting channel of our , , or send us an email support@tokens.studio

community Slack
submit it on our feedback tool

💌 Visit to contribute or subscribe to updates.

https://feedback.tokens.studio/