Configuration

Configure your Yumma CSS project.

Install the CLI

Yumma CSS includes the Yumma CLI, a powerful tool for generating production-ready styles.

pnpm add yummacss -D

Create your configuration file

Initialize a configuration file in your project.

pnpx yummacss init

This creates a yumma.config.mjs file at your project root.

import { defineConfig } from "yummacss";

export default defineConfig({
  source: [""],
  output: "",
});

Source

A collection of paths for your template files (e.g., .js, .tsx, .html). The CLI scans these files for utilities to include in the final CSS file.

Use glob patterns to include subfolders & specific file types.

import { defineConfig } from "yummacss";

export default defineConfig({
  source: ["./src/**/*.html"],
});

Output

Specifies the output path for the compiled CSS file.

import { defineConfig } from "yummacss";

export default defineConfig({
  output: "./src/styles.css",
});

Normalize

Determines whether to include base styles normalization.

import { defineConfig } from "yummacss";

export default defineConfig({
  normalize: true, // default: true
});

Prefix

Prepends a custom string to all generated Yumma CSS utility classes, effectively namespacing them to avoid collisions.

import { defineConfig } from "yummacss";

export default defineConfig({
  prefix: "ui",
});

When a prefix is set, all utilities must include it-including entries in the safelist. For example, if your prefix is ui, use ui-bg-red instead of bg-red.

<button class="ui-bg-indigo ui-c-white ui-p-4 ui-br-sm">Prefixed Button</button>

Theme

Extends or overrides default design tokens.

Colors

Define custom color families. The compiler automatically generates shades (from 0 to 9) unless a full palette is explicitly provided.

Use percentage to control how much the shade is lightened or darkened.

import { defineConfig } from "yummacss";

export default defineConfig({
  theme: {
    colors: {
      brand: "#9333EA",
      percentage: {
        light: 14,
        dark: 14,
      },
    },
  },
});

Screens

Define custom media query breakpoints or override existing ones.

import { defineConfig } from "yummacss";

export default defineConfig({
  theme: {
    screens: {
      sm: "40rem",
      md: "48rem",
      lg: "64rem",
      xl: "80rem",
      xxl: "96rem",
      "3xl": "112rem",
    },
  },
});

Safelist

An array of utility classes that should always be generated in the final CSS output, regardless of whether they are present in your source files. Use this for classes that are added dynamically via JavaScript.

Use safelist for classes generated dynamically at runtime. For example, in React, a template literal like `bg-\${color}-5` cannot be detected by the file scanner, making a safelist necessary.

import { defineConfig } from "yummacss";

export default defineConfig({
  safelist: ["bg-red", "c-white", "fw-700"],
});

Generate styles

The CLI scans files specified in source & generates a CSS file based on the utilities used.

HTML Input

<button class="bg-white c-black bw-1">Button</button>

CSS Output

Running the build or watch command generates the following CSS:

.bg-white {
  background-color: #ffffff;
}

.bw-1 {
  border-width: 1px;
}

.c-black {
  color: #000000;
}

CLI commands

The Yumma CSS CLI provides commands to manage your project.

Create a yumma.config.mjs file before running these commands. If you haven't, run yummacss init.

Build

Compile your Yumma CSS files once.

npx yummacss build

Watch

Watch for file changes & recompile automatically.

npx yummacss watch