Customizing Colors

This lesson discusses how to customize and override colors and their swatches.

Customizing main colors

By default, css-theming will fall back to the following pre-defined colors map for each brightness:

// Colors used in light themes.
$ct-colors-light: (
  'grey': #697c93,
  'brown': #96663c,
  'yellow': #f1c40f,
  'orange': #f48701,
  'red': #ff1d25,
  'pink': #ff39f6,
  'purple': #952ff7,
  'violet': #c600ff,
  'indigo': #5700ff,
  'blue': #448aff,
  'green': #43b581,
) !default;

// Colors used in dark themes.
$ct-colors-dark: (
  'grey': #697c93,
  'brown': #96663c,
  'yellow': #f1c40f,
  'orange': #f69f34,
  'red': #ff3948,
  'pink': #ff61f8,
  'purple': #d835ff,
  'violet': #aa59f9,
  'indigo': #7933ff,
  'blue': #69a1ff,
  'green': #43b581,
) !default;

As you can tell, the defined color only mentions the main color. The main color refers to the 500 swatch of the color: --{color}-500, so in the case of red for example, it’ll be --red-500. All other swatches are computed dynamically by css-theming.

If you want to override the color map in the theme, you can provide a similar map. You’re free to define any number of colors from above, css-theming will fall back to the default for the other colors.

If you want to override the default for all themes, you can set $ct-colors-light or $ct-colors-dark to a new map of colors as long as they follow the same syntax. For example:

$ct-themes: (
  'default': (
    'brightness': 'light',
    'colors': (
      'red': #323232,
       ...
    )
  ),
  ...
);

Customizing semantic colors

Overriding semantic color targets is very similar, you’ll have to provide a similar map to the following default:

$ct-semantic-colors: (
  'primary': 'purple',
  'success': 'green',
  'info': 'blue',
  'warning': 'orange',
  'danger': 'red',
) !default;

$ct-semantic-colors maps a semantic color to a target color from the color map in the same theme. For example: primary to purple, success to green, and so on.

The map assigns a semantic color name (i.e primary) to a color target name from the color map in the same theme (i.e purple).

Customizing swatches

This is the default definition of the swatches in css-theming:

$ct-swatches: (
  50: 15%,
  75: 30%,
  100: 40%,
  200: 50%,
  300: 60%,
  400: 80%,
  500: 100%,
  600: 120%,
  700: 140%,
  800: 160%,
  900: 180%,
) !default;

css-theming uses this map to compute color swatches. You’re free to override this to anything you like. The key (i.e 50, 75, etc.) in the map will act as the swatch’s name. For example, from this map, the following variables will be produced for each color:

--{color}-50: ...
--{color}-75: ...
--{color}-100: ...
...

The value in the map will be used as the percentage of the mixing between the color and the whitish/blackish color css-theming chooses, depending on the theme’s brightness.


The same method follows for the rest of the props, you can always check the defaults in the src SCSS to figure out what you’re supposed to override.

Get hands-on with 1300+ tech skills courses.