Sass-Planifolia - Vanilla Sass helper functions
This is a collection of vanilla Sass helper functions, mostly centered around colors. It currently consists of only two modules:
- contrast for WCAG compatible color contrast functions
- color for color functions with supper for different color spaces, e.g. CIELAB, CIELUV, or HSLuv
These modules can be imported individually. The only define mixins and variables. They will not output any CSS. This means that importing them does not add a single byte to your CSS.
See the full documentation for more details.
npm install sass-planifolia
Import it in your Sass files:
@use "node_modules/sass-planifolia/sass/contrast";
@use "node_modules/sass-planifolia/sass/color";
.test {
background-color: red;
// pick between two colors (default: black and white) to get good contrast
color: contrast.color(red);
// mix orange with black or white to get good contrast to red
border-color: contrast.stretch(red, orange);
// mix red with black in a perceptually uniform color space
box-shadow: 0 0 1em color.shade(red, 0.5, 'lab');
}
- Vendor prefixes, polyfills or browser hacks. There are plenty of librariers for that.
- pt/px/em/rem conversion. That is (a) not possible and (b) not helpful. Each unit has its specific use case. Learn to use the right units directly!
- CSS Color Moudle Level 4 and CSS Color Module Level 5 are W3C Working Drafts (as of 2022-04-28) that would add similar features to CSS itself.
- PostCSS and Parcel both implement some of the functionality of CSS Color Module Level 4/5.
- oddbird/blend is yet another Sass library that implements similar features. The main difference is that the contrast function do not take transparency into account.