Web UI

HOWTO: Customize Theme

Updated: December 4, 2024

Themes

Nuxeo Web UI provides several themes to change the look and feel of the UI. For the moment, they mostly provide color schemes applied to UI elements and a background image for some themes.

The available themes are:

  • Nuxeo (default)
  • Dark
  • Light
  • Kawaii

Customization

All the resources for each theme are located on the /themes/{name} folder, where name is the name of the theme and have the following files:

  • /themes/{name}/theme.html style definitions that allow customizing colors, fonts, or any other CSS properties for most elements used in the Web UI.

  • /themes/{name}/preview.jpg preview image that is displayed on the themes chooser page.

  • /themes/{name}/logo.png image used as application logo.

  • /themes/{name}/background.png image used as background (optional, available for some themes only).

To add a new theme or customize one of the provided ones you can simply deploy and override theme resources as described in HOWTO: deploy additional Web UI resources.

How to Create a Theme

This example provides an walk-through on how to create a new theme and add it as a contribution to the Web UI. We will create our new theme called new-light theme, which is base on the provider light theme with some customizations.

Without any customization the theme looks like this:

Make a copy of the light folder on /themes directory and name it new-light. Then make the following changes to it:

Edit the theme.html:

Add the font import on top of the file

<link href="https://fonts.googleapis.com/css?family=Gabriela" rel="stylesheet">

Then change the --nuxeo-app-font accordingly

<custom-style>
  <style is="custom-style">
    ...
    html {
      --nuxeo-app-font: 'Gabriela', Arial, sans-serif;
      ...
     }
     ...
  </style>
</custom-style>

Change some colors

  html {
    ...
    --nuxeo-badge-background: Tomato;
    ...
    --nuxeo-app-header-background: #CFD8DC;
    ...
    --nuxeo-sidebar-background: #58597a;
    ...
    --nuxeo-button-primary: Tomato;
    ...
  }

Change background to use a custom image

  html {
    --nuxeo-page-background: url(themes/new-light/background.png) repeat;
  }

And add a background.png image to /themes/new-light to use as background.

Now, to make the new theme avaliable, you need to add the new-light theme as a slot contribution, using the THEMES slot as follows:

<nuxeo-slot-content name="new-light-theme" slot="THEMES" order="50">
  <template>
    <nuxeo-theme name="new-light"></nuxeo-theme>
  </template>
</nuxeo-slot-content>

Where properties name="new-light" must match the name of the directory we created for the theme.

Furthermore, the name property is used to define the i18n label for the theme name based on the following convention:

"themes.{themeName}":"name of the theme"

For the current example, with search-name="assets", add the following entry to the messages.json file:

"themes.new-light":"New Light"

For more information about i18n translations, refer to Managing Translations

After customization the light theme will look like this: