Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@asamuzakjp/css-color

Package Overview
Dependencies
Maintainers
0
Versions
29
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@asamuzakjp/css-color

CSS color - Resolve and convert CSS colors.

  • 2.4.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
273K
increased by171515.72%
Maintainers
0
Weekly downloads
 
Created
Source

CSS color

build CodeQL npm (scoped)

Resolve and convert CSS colors.

Install

npm i @asamuzakjp/css-color

Usage

import { convert, 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'

resolve(color, opt)

resolves CSS color

Parameters
  • color string color value

    • system colors are not supported
  • opt object? options (optional, default {})

    • opt.currentColor string? color to use for currentcolor keyword
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }
    • opt.format string? output format, one of computedValue (default), specifiedValue, rgb, hex, hexAlpha
      • computedValue is a computed value of the color
      • specifiedValue is a specified value of the color
      • hexAlpha is a hex color notation with alpha channel, i.e. #rrggbbaa
    • opt.key any? key e.g. CSS property background-color

Returns (string? | Array) one of rgba?(), #rrggbb(aa)?, color-name, '(empty-string)', color(color-space r g b / alpha), color(color-space x y z / alpha), lab(l a b / alpha), lch(l c h / alpha), oklab(l a b / alpha), oklch(l c h / alpha), null, or [key, rgba?()] etc. if key is specified

  • in computedValue, values are numbers, however rgb() values are integers
  • in specifiedValue, returns empty string for unknown and/or invalid color
  • in rgb, values are rounded to integers, and returns rgba(0, 0, 0, 0) for unknown and/or invalid color
  • in hex, returns null for transparent, and also returns null if any of r, g, b, alpha is not a number
  • in hexAlpha, returns #00000000 for transparent, however returns null if any of r, g, b, alpha is not a number

convert

Contains various color conversion functions.

convert.numberToHex(value)

convert number to hex string

Parameters

Returns string hex string: 00..ff

convert.colorToHex(value, opt)

convert color to hex

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.alpha boolean? return in #rrggbbaa notation
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns string #rrggbb(aa)?

convert.colorToHsl(value, opt)

convert color to hsl

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns Array<number> [h, s, l, alpha]

convert.colorToHwb(value, opt)

convert color to hwb

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns Array<number> [h, w, b, alpha]

convert.colorToLab(value, opt)

convert color to lab

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns Array<number> [l, a, b, alpha]

convert.colorToLch(value, opt)

convert color to lch

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns Array<number> [l, c, h, alpha]

convert.colorToOklab(value, opt)

convert color to oklab

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns Array<number> [l, a, b, alpha]

convert.colorToOklch(value, opt)

convert color to oklch

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns Array<number> [l, c, h, alpha]

convert.colorToRgb(value, opt)

convert color to rgb

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns Array<number> [r, g, b, alpha]

convert.colorToXyz(value, opt)

convert color to xyz

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }
    • opt.d50 boolean? xyz in d50 white point

Returns Array<number> [x, y, z, alpha]

convert.colorToXyzD50(value, opt)

convert color to xyz-d50

Parameters
  • value string color value
  • opt object? options (optional, default {})
    • opt.cssCalc object? options for @csstools/css-calc, e.g. cssCalc: { globals: new Map([['foo', 'bar'], ['baz', 1]]) }
    • opt.customProperty object? custom properties
      • pair of -- prefixed property name and value, e.g. customProperty: { '--some-color': '#0000ff' }
      • and/or callback function to get the value, e.g. customProperty: { callback: someDeclaration.getPropertyValue }

Returns Array<number> [x, y, z, alpha]


Copyright (c) 2024 asamuzaK (Kazz)

FAQs

Package last updated on 13 Dec 2024

Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc