Skip to content

A Tailwind css plugin to generate semantic color utilities

License

Notifications You must be signed in to change notification settings

synw/tailwindcss-semantic-colors

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

7 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Tailwindcss semantic colors plugin

pub package

A Tailwind css plugin to generate semantic color utilities with dark mode support

Install

npm install -D tailwindcss-semantic-colors
# or
yarn add -D tailwindcss-semantic-colors

Enable the plugin in tailwind.config.js:

module.exports = {
  // ...
  plugins: [
    // ...
    require('tailwindcss-semantic-colors'),
  ],
}

Usage

Define your semantic colors in the theme in tailwind.config.js.

const colors = require('tailwindcss/colors')

module.exports = {
  // ...
  darkMode: 'class',
  theme: {
    semanticColors: {
      primary: {
        light: {
          bg: colors.cyan[700],
          txt: colors.white
        },
        dark: {
          bg: colors.cyan[800],
          txt: colors.neutral[100]
        }
      },
      // ...
    }
  },
}

Background and text utilities

All the color utilities generated support the dark mode. Example: writing:

<div class="primary">Primary block</div>

will do the same as:

<div class="text-white bg-cyan-700 dark:bg-cyan-800 dark:text-neutral-100">Primary block</div>

Background only utilities

<div class="block-primary">Primary background block</div>

will do the same as:

<div class="bg-cyan-700 dark:bg-cyan-800">Primary background block</div>

Text only utilities

<div class="txt-primary">Primary text block</div>

will do the same as:

<div class="text-cyan-700 dark:text-cyan-800">Primary text block</div>

Border utilities

<div class="border bord-primary">Block with border</div>

will do the same as:

<div class="border border-cyan-700 dark:border-cyan-800">Block with border</div>

Variants

To apply variants on a color. If we have defined another semantic color:

    semanticColors: {
      warning: {
        light: {
          bg: colors.amber[500],
          txt: colors.white
        },
        dark: {
          bg: colors.amber[600],
          txt: colors.neutral[100]
        }
      },
      // ...
    }

Example of the hover variant:

<div class="primary hover:warning">Primary hover block</div>

will do the same as:

<div class="text-white bg-cyan-700 dark:bg-cyan-800 dark:text-neutral-100 hover:bg-amber-500 hover:text-white dark:hover:bg-amber-600 dark:hover:text-neutral-100">
  Primary hover block
</div>

Many variants are enabled by default but you can configure your variants in tailwind.config.js.

module.exports = {
  // ...
  variants: {
    semanticColors: ['focus', 'hover']
  }
}

About

A Tailwind css plugin to generate semantic color utilities

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published