Tiny, useful color functions.
This work is public domain (LICENSE), so feel free to use whatever you like.
npm i --save @rpearce/hexThis library's compilation target is ES2022, but it only uses features from
ES2017 and below. If you find you need to support older environments, run this
project through your build system.
import { rgbaToHex } from '@rpearce/hex'
rgbaToHex([]) // '#000000ff'
rgbaToHex([ 120, 55, 168 ]) // '#7837a8ff'
rgbaToHex([ 120, 55, 168, 1 ]) // '#7837a8ff'
rgbaToHex([ 120, 55, 168, 0.5 ]) // '#7837a87f'
rgbaToHex([ 120, 55, 168, 0 ]) // '#7837a800'Blend together two R, G or B (red, green or blue) color numbers.
interface Blend {
(x: number, y: number, n?: number): number
}import { blend } from '@rpearce/hex'
blend(120, 255, 0) // 120
blend(120, 255, 1) // 255
blend(120, 255, 0.7) // 223
blend(120, 0, 0.7) // 66
blend(120, 127, 0.5) // 124Blend together two alpha values.
interface BlendAlpha {
(x: number, y: number, n?: number): number
}import { blendAlpha } from '@rpearce/hex'
blendAlpha(0.1, 0.9, 0) // 0.1
blendAlpha(0.1, 0.9, 1) // 0.9
blendAlpha(0.1, 1, 0.7) // 0.73
blendAlpha(0.4, 0, 0.7) // 0.12
blendAlpha(0, 0.5, 0.5) // 0.25
blendAlpha(0, 1, 0.5) // 0.5Blend two hexadecimal color values together, shifting from one color to the next
via a fraction between 0 and 1. Hexadecimal equivalent to rgbaCssBlend.
interface HexBlend {
(hexA: string, hexB: string, n: number): string
}import { hexBlend } from '@rpearce/hex'
hexBlend('#7837A8', '#FFF', 0) // '#7837a8'
hexBlend('#7837A8', '#FFF', 1) // '#ffffff'
hexBlend('#7837A8', '#FFF', 0.7) // '#dfd7e8'
hexBlend('#7837A8', '#000', 0.7) // '#421e5c'
hexBlend('#7837A8', '#ff6602', 0.5) // '#c75277'
hexBlend('#7837A880', '#FFF', 0.7) // '#dfd7e8d8'Convert hexadecimal color codes to an array of RGBa values.
interface HexToRgba {
(hex: string): [number, number, number, number]
}import { hexToRgba } from '@rpearce/hex'
// hex-8
hexToRgba('0099ff80') // [ 0, 153, 255, 0.5 ]
hexToRgba('#0099ff80') // [ 0, 153, 255, 0.5 ]
// hex-6
hexToRgba('0099ff') // [ 0, 153, 255, 1 ]
hexToRgba('#0099ff') // [ 0, 153, 255, 1 ]
// hex-4
hexToRgba('09f9') // [ 0, 153, 255, 0.6 ]
hexToRgba('#09f9') // [ 0, 153, 255, 0.6 ]
// hex-3
hexToRgba('09f') // [ 0, 153, 255, 1 ]
hexToRgba('#09f') // [ 0, 153, 255, 1 ]Convert hexadecimal color codes to rgba().
interface HexToRgbaCss {
(hex: string, alpha?: number): string
}import { hexToRgbaCss } from '@rpearce/hex'
// hex-8
hexToRgbaCss('0099ff80') // 'rgba(0,153,255,0.5)'
hexToRgbaCss('#0099ff80') // 'rgba(0,153,255,0.5)'
hexToRgbaCss('#0099ff80', 0.3) // 'rgba(0,153,255,0.3)'
// hex-6
hexToRgbaCss('0099ff') // 'rgba(0,153,255,1)'
hexToRgbaCss('#0099ff') // 'rgba(0,153,255,1)'
hexToRgbaCss('#0099ff', 0.2) // 'rgba(0,153,255,0.2)'
// hex-4
hexToRgbaCss('09f9') // 'rgba(0,153,255,0.6)'
hexToRgbaCss('#09f9') // 'rgba(0,153,255,0.6)'
hexToRgbaCss('#09f9', 0.12) // 'rgba(0,153,255,0.12)'
// hex-3
hexToRgbaCss('09f') // 'rgba(0,153,255,1)'
hexToRgbaCss('#09f') // 'rgba(0,153,255,1)'
hexToRgbaCss('#09f', 0.45) // 'rgba(0,153,255,0.45)'Parse various forms of hexadecimal colors.
interface Parse {
(hex?: string): string
}import { parse } from '@rpearce/hex'
// hex-8
parse('0099ff80') // '0099ff80'
parse('#0099ff80') // '0099ff80'
// hex-6
parse('0099ff') // '0099ff'
parse('#0099ff') // '0099ff'
// hex-4
parse('09f8') // '0099ff88'
parse('#09f8') // '0099ff88'
// hex-3
parse('09f') // '0099ff'
parse('#09f') // '0099ff'interface ParseRgba {
(rgba?: string): [number, number, number, number]
}import { parseRgba } from '@rpearce/hex'
parseRgba('') // [ 0, 0, 0, 1 ]
parseRgba('rgb(120, 55, 168)') // [ 120, 55, 168, 1 ]
parseRgba('rgba(120, 55, 168, 1)') // [ 120, 55, 168, 1 ]
parseRgba('rgba(120, 55, 168, 0.3)') // [ 120, 55, 168, 0.3 ]Blend two rgba() color values together, shifting from one color to the next
via a fraction between 0 and 1. RGBa equivalent to hexBlend.
interface RgbaCssBlend {
(rgbaA: string, rgbaB: string, alpha: number): string
}import { rgbaCssBlend } from '@rpearce/hex'
rgbaCssBlend('rgba(120, 55, 168, 1)', 'rgba(255, 255, 255, 1)', 0.7) // 'rgba(223,215,232,1)'
rgbaCssBlend('rgba(120, 55, 168, 1)', 'rgba(0, 0, 0, 1)', 0.7) // 'rgba(66,30,92,1)'
rgbaCssBlend('rgba(120, 55, 168, 1)', 'rgba(255, 102, 2, 1)', 0.5) // 'rgba(199,82,119,1)'Convert rgba() to hexadecimal.
interface RgbaCssToHex {
(rgba?: string): string
}import { rgbaCssToHex } from '@rpearce/hex'
rgbaCssToHex('') // '#000000ff'
rgbaCssToHex('rgba(120, 55, 168, 1)') // '#7837a8ff'
rgbaCssToHex('rgba(120, 55, 168, 0.5)') // '#7837a87f'
rgbaCssToHex('rgba(120, 55, 168, 0.3)') // '#7837a84c'Convert an array of RGBa values to hexadecimal.
interface RgbaToHex {
(rgba?: [number?, number?, number?, number?] | []): string
}import { rgbaToHex } from '@rpearce/hex'
rgbaToHex([]) // '#000000ff'
rgbaToHex([ 120, 55, 168 ]) // '#7837a8ff'
rgbaToHex([ 120, 55, 168, 1 ]) // '#7837a8ff'
rgbaToHex([ 120, 55, 168, 0.5 ]) // '#7837a87f'
rgbaToHex([ 120, 55, 168, 0 ]) // '#7837a800'Convert an array of RGBa values to rgba().
interface RgbaToRgbaCss {
(rgba?: [number?, number?, number?, number?] | []): string
}import { rgbaToRgbaCss } from '@rpearce/hex'
rgbaToRgbaCss([]) // 'rgba(0,0,0,1)'
rgbaToRgbaCss([ 120, 55, 168 ]) // 'rgba(120,55,168,1)'
rgbaToRgbaCss([ 120, 55, 168, 1 ]) // 'rgba(120,55,168,1)'
rgbaToRgbaCss([ 120, 55, 168, 0.3 ]) // 'rgba(120,55,168,0.3)'Thanks goes to these wonderful people (emoji key):
Robert Pearce π» π π‘ π€ |
This project follows the all-contributors specification. Contributions of any kind welcome!