Security News
ESLint is Now Language-Agnostic: Linting JSON, Markdown, and Beyond
ESLint has added JSON and Markdown linting support with new officially-supported plugins, expanding its versatility beyond JavaScript.
@csstools/postcss-oklab-function
Advanced tools
@csstools/postcss-oklab-function is a PostCSS plugin that allows you to use the OKLab color function in your CSS. OKLab is a color space designed to be perceptually uniform, meaning that the perceived difference between colors is consistent across the entire color space. This plugin enables you to write colors in the OKLab color space and have them converted to a more widely supported format.
Using OKLab color function
This feature allows you to write colors using the OKLab color function in your CSS. The plugin will convert these colors to a more widely supported format, such as RGB.
/* Input CSS */
body {
color: oklab(59.69% 0.072 -0.236);
}
/* Output CSS */
body {
color: rgb(255, 0, 0);
}
Custom properties with OKLab
This feature allows you to define custom properties using the OKLab color function. The plugin will convert these custom properties to a more widely supported format.
/* Input CSS */
:root {
--primary-color: oklab(59.69% 0.072 -0.236);
}
body {
color: var(--primary-color);
}
/* Output CSS */
:root {
--primary-color: rgb(255, 0, 0);
}
body {
color: var(--primary-color);
}
postcss-color-function is a PostCSS plugin that allows you to use color-modifying functions in your CSS. It supports various color functions like lighten, darken, and adjust-hue. Unlike @csstools/postcss-oklab-function, it does not specifically support the OKLab color space but provides a broader range of color manipulation functions.
postcss-preset-env is a PostCSS plugin that allows you to use modern CSS features in your stylesheets. It includes support for various color functions, including the OKLab color space through the color-mod-function plugin. It offers a more comprehensive set of features compared to @csstools/postcss-oklab-function, which focuses solely on the OKLab color space.
PostCSS OKLab Function lets you use oklab
and oklch
color functions in
CSS, following the CSS Color specification.
.test-oklab {
color: oklab(40% 0.001236 0.0039);
}
.test-oklch {
color: oklch(40% 0.268735435 34.568626);
}
/* becomes */
.test-oklab {
color: rgb(73, 71, 69);
color: color(display-p3 0.28515 0.27983 0.27246);
}
.test-oklch {
color: rgb(131, 28, 0);
color: color(display-p3 0.49163 0.11178 0.00000);
}
Add PostCSS OKLab Function to your project:
npm install postcss @csstools/postcss-oklab-function --save-dev
Use it as a PostCSS plugin:
const postcss = require('postcss');
const postcssOKLabFunction = require('@csstools/postcss-oklab-function');
postcss([
postcssOKLabFunction(/* pluginOptions */)
]).process(YOUR_CSS /*, processOptions */);
PostCSS OKLab Function runs in all Node environments, with special instructions for:
Node | PostCSS CLI | Webpack | Gulp | Grunt |
---|
The preserve
option determines whether the original notation
is preserved. By default, it is not preserved.
postcssOKLabFunction({ preserve: true })
.test-oklab {
color: oklab(40% 0.001236 0.0039);
}
.test-oklch {
color: oklch(40% 0.268735435 34.568626);
}
/* becomes */
.test-oklab {
color: rgb(73, 71, 69);
color: color(display-p3 0.28515 0.27983 0.27246);
color: oklab(40% 0.001236 0.0039);
}
.test-oklch {
color: rgb(131, 28, 0);
color: color(display-p3 0.49163 0.11178 0.00000);
color: oklch(40% 0.268735435 34.568626);
}
The enableProgressiveCustomProperties
option determines whether the original notation
is wrapped with @supports
when used in Custom Properties. By default, it is enabled.
[!NOTE] We only recommend disabling this when you set
preserve
tofalse
or if you bring your own fix for Custom Properties.
See what the plugin does in its README.
postcssOKLabFunction({ enableProgressiveCustomProperties: false })
:root {
--firebrick: oklab(40% 0.234 0.39);
}
/* becomes */
:root {
--firebrick: rgb(133, 0, 67); /* will never be used, not even in older browser */
--firebrick: color(display-p3 0.49890 0.00000 0.25954); /* will never be used, not even in older browser */
--firebrick: oklab(40% 0.234 0.39);
}
The subFeatures.displayP3
option determines if color(display-p3 ...)
is used as a fallback.
By default, it is enabled.
display-p3
can display wider gamut colors than rgb
on some devices.
postcssOKLabFunction({
subFeatures: {
displayP3: false
}
})
.test-oklab {
color: oklab(40% 0.001236 0.0039);
}
.test-oklch {
color: oklch(40% 0.268735435 34.568626);
}
/* becomes */
.test-oklab {
color: rgb(73, 71, 69);
}
.test-oklch {
color: rgb(131, 28, 0);
}
This software or document includes material copied from or derived from https://github.com/w3c/csswg-drafts/tree/main/css-color-4. Copyright © 2022 W3C® (MIT, ERCIM, Keio, Beihang).
FAQs
Use oklab() and oklch() color functions in CSS
The npm package @csstools/postcss-oklab-function receives a total of 3,431,506 weekly downloads. As such, @csstools/postcss-oklab-function popularity was classified as popular.
We found that @csstools/postcss-oklab-function demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
ESLint has added JSON and Markdown linting support with new officially-supported plugins, expanding its versatility beyond JavaScript.
Security News
Members Hub is conducting large-scale campaigns to artificially boost Discord server metrics, undermining community trust and platform integrity.
Security News
NIST has failed to meet its self-imposed deadline of clearing the NVD's backlog by the end of the fiscal year. Meanwhile, CVE's awaiting analysis have increased by 33% since June.