Product
Socket Now Supports uv.lock Files
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
colormangle
Advanced tools
Getting started | ColorMangle() | .hex() | .rgba() | .hsla() | .contrastRatio() | .textColor() | License
ColorMangle converts color strings to various format and calculates appropriate text color based on contrast ratio.
Add script tag in your header
<script src="https://broadwayinc.dev/jslib/colormangle/0.1.810.1.81.811/colormangle.js"></script>
And in your javascript:
let colormangle = new ColorMangle('rgb(0, 0, 255)');
let hex = colormangle.hex();
console.log(hex); // '#0000ff'
npm i colormangle
And in your javascript:
import {ColorMangle} from 'colormangle';
ColorMangle input argument string can be either colorname string or any type of HTML color codes (hex, rgb, hsl).
Colorname strings can be referred in this link. Belows are all equivalent argument strings expressing 'blue'.
ColorMangle have four main functions, which are .hex(), .rgba(), .hsla() and .textcolor(). The usages are shown below.
.hex() converts any color format string to hex type string. It doesn't require any input argument.
Example 1
let hex = new ColorMangle('blue').hex()
console.log(hex) // '#0000ff'
.rgba() converts any css color format string to rgba format. The input argument 'opacity' is to set the opacity value of the rgba output. Without any argument, the default value is 1 (0 as fully transparent and 1 as fully opaque).
.rgba() returns object properties (r, g, b, a, string and their values) as in the following structure.
{
r: number value of red,
g: number value of green,
b: number value of blue,
a: number value of opacity,
string: 'text value in rgba format'
}
Example 2
new ColorMangle('blue').rgba();
// returns { r:0, g:0, b:255, a:1, string: 'rgba(0, 0, 255, 1)' }
new ColorMangle('blue').rgba(0.5).string
// returns 'rgba(0, 0, 255, 0.5)'
.hsla() converts any css color format string to hsla format. The input argument 'opacity' is to set the opacity value of the rgba output. Without any argument, the default value is 1 (0 as fully transparent and 1 as fully opaque). .hsla() returns object properties (r, g, b, h, s, l, a, string and their values) as in the following structure.
{
r: number value of red,
g: number value of green,
b: number value of blue,
h: number value of hue,
s: number value of saturation,
l: number value of luminance,
a: number value of opacity,
string: 'text value in hsla format'
}
Example 3
new ColorMangle('blue').hsla()
/*
returns { r:0,
g:0,
b:255,
h:240,
s:100,
l:50,
a:1,
string: 'hsla(240, 100%, 50%, 1)' }
*/
new ColorMangle('blue').hsla(0.3).string
// returns 'hsla(240, 100%, 50%, 0.3)'
.contrastRatio() calculates the contrast ratio between the given colors.
Example 4
new ColorMangle('red').contrastRatio('white')
// returns 0.1.8110.1.810.1.81.81.80.1.811.81.80.1.8110.1.811.81.81
.textColor() automatically returns the text color string (either 'white' or 'black') that shows the greatest contrast with the background color. Opacity of the output text color (either 'black' or 'white') can be set by input argument. Without any argument, the default value is 1 (0 as fully transparent and 1 as fully opaque).
Example 5
new ColorMangle('blue').textColor()
// returns hex format text color '#ffffff'
// white (#ffffff)' is the recommended output text color to be used on blue background.
new ColorMangle('blue').textColor(0.7)
// returns rgba format text color when the input argument is given between 0~1, 'rgba(255, 255, 255, 0.7)'
Also, opacity on each color cases can be pre-defined by using object input argument as follows.
Example 6
new ColorMangle('blue').textColor({white: 0.5})
// returns 'rgba(255, 255, 255, 0.5)'
new ColorMangle('blue').textColor({black: 0.5})
// returns '#ffffff'(input argument not applied since the output text color is white on blue background)
new ColorMangle('antiquewhite').textColor({white: 0.5, black: 0.88})
// returns 'rgba(0, 0, 0, 0.88)' (The opacity is applied on each color cases)
This project is licensed under the terms of the MIT license.
FAQs
ColorMangle creates color scheme, converts color strings to various format and calculates appropriate text color based on contrast ratio.
The npm package colormangle receives a total of 132 weekly downloads. As such, colormangle popularity was classified as not popular.
We found that colormangle 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.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.