Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/denis-sokolov/color
Colors in UI
https://github.com/denis-sokolov/color
chroma hcl-colors lightness manipulation-color opacity
Last synced: about 2 months ago
JSON representation
Colors in UI
- Host: GitHub
- URL: https://github.com/denis-sokolov/color
- Owner: denis-sokolov
- License: isc
- Created: 2020-12-20T10:36:33.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2023-01-02T09:50:24.000Z (about 2 years ago)
- Last Synced: 2024-10-19T05:19:21.622Z (3 months ago)
- Topics: chroma, hcl-colors, lightness, manipulation-color, opacity
- Language: TypeScript
- Homepage:
- Size: 104 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Colors in UIs
Color manipulation for use in consistent design systems. Uses HCL color space for computation, but allows simple format input and output.
See also Lea Verou’s [Color.js](https://colorjs.io/) and the awesome [blog post about HCL colors](https://lea.verou.me/2020/04/lch-colors-in-css-what-why-and-how/).
```ts
import { colorFromString } from "ui-colors";const themeColorCode = "#9973ba";
const themeColor = colorFromString(themeColorCode);const text = themeColor.lightness > 50 ? "black" : "white";
const dark = themeColor.withLightness(30).asCss();
const light = themeColor.withLightness(80).asCss();
```Beware of various number scales:
- Hue is 0-359;
- Red, green, blue components are 0-255;
- Opacity, HSL saturation and lightness are 0-1;
- Main lightness is 0 to 100 in practice, but is [unbounded in theory](https://www.w3.org/TR/css-color-4/#specifying-lab-lch)
- Chroma is 0 to about 130 in practice, but is unbounded;## Constructors
Simple: colorFromHex("#aabbcc"), colorFromLch(70, 12, 350), colorFromHsl(350, 0.2, 0.8), colorFromRgb(120, 120, 120). Opacity is an optional last argument.
Smart constructor tries to parse the string as any format it can think of: colorFromString("...").
## Fields
color.chroma, color.hue, color.lightness, color.opacity, color.rgb.approximation
## Manipulation
color.withChroma(12), color.withHue(350), color.withLightness(70)
## Display
color.asPrettyLch()
color.asCss().approximation, color.asPrettyHex().approximation, color.asPrettyHsl().approximation, color.asPrettyRgb().approximation