Resolve and convert CSS colors.
npm i @asamuzakjp/css-color
import { convert, isColor, resolve } from '@asamuzakjp/css-color';
const resolvedValue = resolve(
'color-mix(in oklab, lch(67.5345 42.5 258.2), color(srgb 0 0.5 0))'
);
// 'oklab(0.620754 -0.0931934 -0.00374881)'
const convertedValue = covert.colorToHex('lab(46.2775% -47.5621 48.5837)');
// '#008000'
const result = isColor('green');
// true
resolves CSS color
-
color
string color value- system colors are not supported
-
opt
object? options (optional, default{}
)opt.currentColor
string?- color to use for
currentcolor
keyword - if omitted, it will be treated as a missing color,
i.e.
rgb(none none none / none)
- color to use for
opt.customProperty
object?- custom properties
- pair of
--
prefixed property name as a key and it's value, e.g.const opt = { customProperty: { '--some-color': '#008000', '--some-length': '16px' } };
- and/or
callback
function to get the value of the custom property, e.g.const node = document.getElementById('foo'); const opt = { customProperty: { callback: node.style.getPropertyValue } };
opt.dimension
object?- dimension, e.g. for converting relative length to pixels
- pair of unit as a key and number in pixels as it's value,
e.g. suppose
1em === 12px
,1rem === 16px
and100vw === 1024px
, thenconst opt = { dimension: { em: 12, rem: 16, vw: 10.24 } };
- and/or
callback
function to get the value as a number in pixels, e.g.const opt = { dimension: { callback: unit => { switch (unit) { case 'em': return 12; case 'rem': return 16; case 'vw': return 10.24; default: return; } } } };
opt.format
string?- output format, one of below
computedValue
(default), computed value of the colorspecifiedValue
, specified value of the colorhex
, hex color notation, i.e.#rrggbb
hexAlpha
, hex color notation with alpha channel, i.e.#rrggbbaa
- output format, one of below
opt.key
any?- key to return with the value, e.g. CSS property
background-color
- key to return with the value, e.g. CSS property
Returns (string? | Array) one of rgba?()
, #rrggbb(aa)?
, color-name
, color(color-space r g b / alpha)
, color(color-space x y z / alpha)
, (ok)?lab(l a b / alpha)
, (ok)?lch(l c h / alpha)
, '(empty-string)'
, null
, or [key, rgba?()]
etc. if key
is specified
- in
computedValue
, values are numbers, howeverrgb()
values are integers - in
specifiedValue
, returnsempty string
for unknown and/or invalid color - in
hex
, returnsnull
fortransparent
, and also returnsnull
if any ofr
,g
,b
,alpha
is not a number - in
hexAlpha
, returns#00000000
fortransparent
, however returnsnull
if any ofr
,g
,b
,alpha
is not a number
Contains various color conversion functions.
convert number to hex string
value
number color value
Returns string hex string: 00..ff
convert color to hex
Returns string #rrggbb(aa)?
convert color to hsl
Returns Array<number> [h, s, l, alpha]
convert color to hwb
Returns Array<number> [h, w, b, alpha]
convert color to lab
Returns Array<number> [l, a, b, alpha]
convert color to lch
Returns Array<number> [l, c, h, alpha]
convert color to oklab
Returns Array<number> [l, a, b, alpha]
convert color to oklch
Returns Array<number> [l, c, h, alpha]
convert color to rgb
Returns Array<number> [r, g, b, alpha]
convert color to xyz
Returns Array<number> [x, y, z, alpha]
convert color to xyz-d50
Returns Array<number> [x, y, z, alpha]
is valid color type
color
string color value- system colors are not supported
Returns boolean
The following resources have been of great help in the development of the CSS color.
Copyright (c) 2024 asamuzaK (Kazz)