Frontend Token Definitions
Liferay DXP/Portal 7.3+
The visual rules of style books consist of options grouped into categories. For example, in the Buttons category there can be an option called Background Color.

Each option in the style book is defined with a token. The collection of all tokens defined for a theme is a frontend token definition. The frontend token definition is a JSON file provided by the theme CSS client extension, or via the theme in earlier releases.
Beginning with Liferay DXP 2024.Q2/Portal GA120, you can provide the frontend token definition in a theme CSS client extension that you apply to all the site’s pages. Earlier releases required a theme module.
Defining Tokens for Your Style Book
The frontend token definition is tied to your theme CSS client extension (or theme), so each frontend token must correspond to a CSS variable from your provided CSS. Specify the frontend tokens in a frontend-token-definition.json file:
- 
Theme CSS client extensions: place the frontend token definition in your client extension project and define the path in the client-extension.yaml. For example,frontendTokenDefinitionJSON: src/frontend-token-definition.json
- 
Themes: place the frontend token definition file in your theme module’s src/WEB-INF/folder, namedfrontend-token-definition.json.
Frontend Token Categories
Frontend tokens defining the options for configuring your style book are grouped into categories. Each category appears in the drop-down menu when editing your style book.

Use a frontendTokenCategories field to define each of these categories in your theme’s src/WEB-INF/frontend-token-definition.json file:
{
 "frontendTokenCategories": [
  {
   "frontendTokenSets": [],
   "label": "buttons",
   "name": "buttons"
  }
 ]
}
Define a label and a name for each of your frontend token categories. The label value is interpreted as a language key and displayed as the option in the drop-down menu for your category. 
Frontend Token Sets
Each category is further organized into frontend token sets which correspond to the collapsible groups of options that appear when editing a style book.
For example, using the default Classic theme, the Button Primary frontend token set (within the Buttons category) includes all frontend tokens for standard button color options:

Define each frontend token set inside a category’s frontendTokenSets field:
{
 "frontendTokenCategories": [
  {
   "frontendTokenSets": [
    {
     "frontendTokens": [],
     "label": "primary-buttons",
     "name": "primaryButtons"
    }
   ],
   "label": "buttons",
   "name": "buttons"
  }
 ]
}
Define a label and name for each frontend token set like with each category.
Defining Frontend Tokens
Define the frontend tokens within each token set’s frontendTokens field. Here’s a list of all the properties you can use for your frontend tokens:
| Property | Description | 
|---|---|
| defaultValue | The default value displayed for the option. This field must match the default value used in the CSS. | 
| editorType | Use this field if you want to use a color picker editor for the field. The only supported value is ColorPicker. If no value is set, a text input is used. If you need a select input, use thevalidValuesproperty instead (these two properties cannot be used together). | 
| mappings | The mapping between the frontend token definition name to the corresponding CSS variable name (must contain typeandvalueas nested fields). UsecssVariableas thetypeand define thevalueas the CSS variable name. | 
| label | The language key that appears for the option when editing a Style Book. | 
| name | The frontend token’s name. | 
| type | The type of data the frontend token displays. Use Integer,Float, orStringto display a text field holding those types of values. UseBooleanto display a checkbox. UseLengthto provide customizable units of measurement (e.g. pixels, ems, percentages). | 
| validValues | Optional property that lists available options for the User in the UI. This field must contain a nested list of labelandvaluepairs (valueis the field’s value in CSS). This property cannot be used together witheditorType. Defining a value forvalidValuesmakes the input type automatically a select input. | 
The JSON schema for frontend token definitions is publicly available in Liferay’s repository.
Here’s an example list of frontend tokens within a frontend token set:
"frontendTokens": [
    {
        "defaultValue": "#0B5FFF",
        "editorType": "ColorPicker",
        "label": "primary",
        "mappings": [
            {
                "type": "cssVariable",
                "value": "primary"
            }
        ],
        "name": "primaryColor",
        "type": "String"
    },
    {
        "defaultValue": "sans-serif",
        "label": "font-family",
        "mappings": [
            {
                "type": "cssVariable",
                "value": "fontFamily"
            }
        ],
        "name": "fontFamily",
        "type": "String",
        "validValues": [
            {
                "label": "sans-serif",
                "value": "sans-serif"
            },
            {
                "label": "monospace",
                "value": "Courier New"
            }
        ]
    }
]
Matching CSS Variables to Style Book Tokens
Every frontend token defined in your frontend token definition must represent a style (color, spacing, font, etc.) in the CSS of your theme CSS client extension or theme.
The styles that your frontend tokens represent are coded as CSS variables. You can reference the corresponding CSS variables on any page where the frontend token definition is applied.
For example, this token provides an option to configure a font:
{
 "defaultValue": "sans-serif",
 "label": "font-family-base",
 "mappings": [
  {
   "type": "cssVariable",
   "value": "font-family-base"
  }
 ],
 "name": "fontFamilyBase",
 "type": "String"
}
You can access this token in your CSS, referencing it as a CSS variable (using the var(--token-name) syntax):
body {
 font-family: var(--font-family-base);
}
The value in the frontend token definition’s mappings (font-family-base) matches the variable name in the CSS. Use two hyphens to precede the CSS variable name (in this example, --font-family-base).