Skip to content

Latest commit

 

History

History
95 lines (61 loc) · 3.35 KB

README.md

File metadata and controls

95 lines (61 loc) · 3.35 KB

unocss-preset-radix

Installation

pnpm add -D unocss-preset-radix

Usage

import { defineConfig, presetUno } from "unocss";
import { presetRadix } from "unocss-preset-radix";

export default defineConfig({
  presets: [
    presetUno(),
    presetRadix({
      palette: ["blue", "green", "red"],
      aliases: {
        primary: "green",
        base: "slate",
      },
    }),
  ],
});

Alphas

Alphas are available as extra shades in each scale. For example bg-blue5 for solid, bg-blue5A for alpha.

Foregrounds

The optimized foreground colors are available as -fg shades. For example text-blue-fg for white text-amber-fg for white. These colors are based on the Radix docs. This also works with hues and aliases.

Data Variants

The preset adds shortcut variants for some of the common data attributes used in the Radix Primitives library, this does not mean you need to use Radix Primitives to use this preset, and these likely work with other standards-friendly component libraries as well.

Variant Selector
radix-open [data-state='open']
radix-closed [data-state='closed']
radix-horizontal [data-orientation='horizontal']
radix-vertical [data-orientation='vertical']
radix-disabled [data-disabled]
radix-enabled :not([data-disabled])

Some of these variants have no naming conflict with the base preset, e.g. radix-closed could be closed, but this is not universally true, so they are prefixed. The prefix is customizable with variantPrefix and defaults to radix.

Options

palette

An array of the Radix UI Colors you'd like to include. Dark mode and alpha variants are automatic. Overlay colors are added by default.

prefix

The prefix used for the CSS variables generated by the preset. Default is --un-preset-radix-.

variantPrefix

The prefix used for the generated variants. Default is radix-.

darkSelector

The selector used for dark mode palette. Default is .dark-theme.

lightSelector

The selector used for dark mode palette. Default is :root, .light-theme.

aliases

A key value object of color aliases in the format alias: target that allows you to set aliases for the color palette. You cannot set aliases to other aliases. Alpha variants for aliases are generated automatically, so for then given alias brand: blue, an alias brandA: blueA will also be generated.

extend

A boolean that sets whether or not the preset will completely overwrite or merge with the previous palette. Default is true.

hue

With any scale included in your palette, you can use the utility hue-{scale} like hue-red or hue-sand. This sets a series of CSS variables that allow usage of hue in place of a color. For example:

<div class="hue-red bg-hue4" />
<div class="bg-red4" />

are equivilant.

This allows you to add all the hues you'd like to use to your safelist, and be able to dynamically choose the colorway of an element using JS or whatever your poison of choice is.

This feature is heavily inspired by Imba's hue