value-color
Version:
Library for working with colors. Includes RGB and HSL creation, gradients, and built-in names.
184 lines (143 loc) • 30.2 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.complement = exports.toRGB = exports.toHSL = exports.darkCharcoal = exports.charcoal = exports.lightCharcoal = exports.darkGrey = exports.grey = exports.lightGrey = exports.white = exports.black = exports.darkBrown = exports.brown = exports.lightBrown = exports.darkPurple = exports.purple = exports.lightPurple = exports.darkBlue = exports.blue = exports.lightBlue = exports.darkGreen = exports.green = exports.lightGreen = exports.darkYellow = exports.yellow = exports.lightYellow = exports.darkOrange = exports.orange = exports.lightOrange = exports.darkRed = exports.red = exports.lightRed = exports.grayscale = exports.hsl = exports.hsla = exports.rgb = exports.rgba = exports.match = undefined;
var _throw = require("throw.flow");
var _throw2 = _interopRequireDefault(_throw);
var _Angle = require("./Angle");
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
const match = exports.match = match => value => {
if (value instanceof HSLAColor) {
return match.HSLA(value);
} else if (value instanceof RGBAColor) {
return match.RGBA(value);
} else if (value == null) {
return match._();
} else if (typeof value === "object") {
const { red, green, blue, alpha, hue, saturation, lightness } = value;
if (typeof red === "number" && typeof green === "number" && typeof blue === "number") {
if (typeof alpha === "number") {
return match.rgba(red, green, blue, alpha);
} else {
return match.rgb(red, green, blue);
}
} else if (typeof hue === "number" && typeof saturation === "number" && typeof lightness === "number") {
if (typeof alpha === "number") {
return match.hsla(hue, saturation, lightness, alpha);
} else {
return match.hsl(hue, saturation, lightness);
}
}
}
return match._();
};
class RGBAColor {
constructor(red, green, blue, alpha) {
this.red = red;
this.green = green;
this.blue = blue;
this.alpha = alpha;
}
static complement(red, green, blue, alpha) {
const { hue, saturation, lightness } = rgba2hsla(red, green, blue, alpha);
return HSLAColor.complement(hue, saturation, lightness, alpha);
}
}
class HSLAColor {
constructor(hue, saturation, lightness, alpha) {
this.hue = hue;
this.saturation = saturation;
this.lightness = lightness;
this.alpha = alpha;
}
static complement(hue, saturation, lightness, alpha) {
return new HSLAColor(hue + (0, _Angle.degrees)(180), saturation, lightness, alpha);
}
}
const rgba = exports.rgba = (red, green, blue, alpha) => new RGBAColor(red, green, blue, alpha);
const rgb = exports.rgb = (red, green, blue) => new RGBAColor(red, green, blue, 1);
const hsla = exports.hsla = (hue, saturation, lightness, alpha) => new HSLAColor(hue - (0, _Angle.turns)(Math.floor(hue / (2 * Math.PI))), saturation, lightness, alpha);
const hsl = exports.hsl = (hue, saturation, lightness) => hsla(hue, saturation, lightness, 1);
const grayscale = exports.grayscale = value => new HSLAColor(0, 0, 1 - value, 1);
const fmod = (f, n) => {
const integer = Math.floor(f);
return integer % n + f - integer;
};
const lightRed = exports.lightRed = rgb(239, 41, 41);
const red = exports.red = rgb(204, 0, 0);
const darkRed = exports.darkRed = rgb(164, 0, 0);
const lightOrange = exports.lightOrange = rgb(252, 175, 62);
const orange = exports.orange = rgb(245, 121, 0);
const darkOrange = exports.darkOrange = rgb(206, 92, 0);
const lightYellow = exports.lightYellow = rgb(255, 233, 79);
const yellow = exports.yellow = rgb(237, 212, 0);
const darkYellow = exports.darkYellow = rgb(196, 160, 0);
const lightGreen = exports.lightGreen = rgb(138, 226, 52);
const green = exports.green = rgb(115, 210, 22);
const darkGreen = exports.darkGreen = rgb(78, 154, 6);
const lightBlue = exports.lightBlue = rgb(114, 159, 207);
const blue = exports.blue = rgb(52, 101, 164);
const darkBlue = exports.darkBlue = rgb(32, 74, 135);
const lightPurple = exports.lightPurple = rgb(173, 127, 168);
const purple = exports.purple = rgb(117, 80, 123);
const darkPurple = exports.darkPurple = rgb(92, 53, 102);
const lightBrown = exports.lightBrown = rgb(233, 185, 110);
const brown = exports.brown = rgb(193, 125, 17);
const darkBrown = exports.darkBrown = rgb(143, 89, 2);
const black = exports.black = rgb(0, 0, 0);
const white = exports.white = rgb(255, 255, 255);
const lightGrey = exports.lightGrey = rgb(238, 238, 236);
const grey = exports.grey = rgb(211, 215, 207);
const darkGrey = exports.darkGrey = rgb(186, 189, 182);
const lightCharcoal = exports.lightCharcoal = rgb(136, 138, 133);
const charcoal = exports.charcoal = rgb(85, 87, 83);
const darkCharcoal = exports.darkCharcoal = rgb(46, 52, 54);
const hsla2rgba = (hue, saturation, lightness, alpha) => {
const chroma = (1 - Math.abs(2 * lightness - 1)) * saturation;
const h = hue / (0, _Angle.degrees)(60);
const x = chroma * (1 - Math.abs(fmod(h, 2 - 1)));
const [r, g, b] = h < 0 ? [0, 0, 0] : h < 1 ? [chroma, x, 0] : h < 2 ? [x, chroma, 0] : h < 3 ? [0, chroma, x] : h < 4 ? [0, x, chroma] : h < 5 ? [x, 0, chroma] : h < 6 ? [chroma, 0, x] : [0, 0, 0];
const m = lightness - chroma / 2;
const color = new RGBAColor(Math.round(255 * (r + m)), Math.round(255 * (g + m)), Math.round(255 * (b + m)), alpha);
return color;
};
const rgba2hsla = (red, green, blue, alpha) => {
const [r, g, b] = [red / 255, green / 255, blue / 255];
const max = Math.max(Math.max(r, g), b);
const min = Math.min(Math.min(r, g), b);
const delta = max - min;
const h = max === r ? fmod((g - b) / delta, 6) : max === g ? (b - r) / delta + 2 : (r - g) / delta + 4;
const hue = (0, _Angle.degrees)(60) * h;
const lightness = (max + min) / 2;
const saturation = lightness === 0 ? 0 : delta / (1 - Math.abs(2 * lightness - 1));
return new HSLAColor(hue, lightness, saturation, alpha);
};
const toHSL = exports.toHSL = match({
RGBA: ({ red, green, blue, alpha }) => rgba2hsla(red, green, blue, alpha),
rgba: rgba2hsla,
rgb: (red, green, blue) => rgba2hsla(red, green, blue, 1),
HSLA: hsla => hsla,
hsla: hsla,
hsl: hsl,
_: _throw2.default
});
const toRGB = exports.toRGB = match({
HSLA: ({ hue, saturation, lightness, alpha }) => hsla2rgba(hue, saturation, lightness, alpha),
hsla: hsla2rgba,
hsl: (hue, saturation, lightness) => hsla2rgba(hue, saturation, lightness, 1),
RGBA: rgba => rgba,
rgba: rgba,
rgb: rgb,
_: _throw2.default
});
const complement = exports.complement = match({
HSLA: ({ hue, saturation, lightness, alpha }) => HSLAColor.complement(hue, saturation, lightness, alpha),
hsla: HSLAColor.complement,
hsl: (hue, saturation, lightness) => HSLAColor.complement(hue, saturation, lightness, 1),
RGBA: ({ red, green, blue, alpha }) => RGBAColor.complement(red, green, blue, alpha),
rgba: RGBAColor.complement,
rgb: (red, green, blue) => RGBAColor.complement(red, green, blue, 1),
_: _throw2.default
});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["src/Color.js"],"names":["match","value","HSLAColor","HSLA","RGBAColor","RGBA","_","red","green","blue","alpha","hue","saturation","lightness","rgba","rgb","hsla","hsl","constructor","complement","rgba2hsla","Math","floor","PI","grayscale","fmod","f","n","integer","lightRed","darkRed","lightOrange","orange","darkOrange","lightYellow","yellow","darkYellow","lightGreen","darkGreen","lightBlue","darkBlue","lightPurple","purple","darkPurple","lightBrown","brown","darkBrown","black","white","lightGrey","grey","darkGrey","lightCharcoal","charcoal","darkCharcoal","hsla2rgba","chroma","abs","h","x","r","g","b","m","color","round","max","min","delta","toHSL","toRGB"],"mappings":"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","file":"Color.js","sourceRoot":"src","sourcesContent":["/* @flow */\n\nimport crash from \"throw.flow\"\nimport { turns, degrees } from \"./Angle\"\nimport type { Int, Float } from \"./Number\"\n\nexport interface RGBA {\n  red: Int,\n  green: Int,\n  blue: Int,\n  alpha: Float\n}\n\nexport interface HSLA {\n  hue: Float,\n  saturation: Float,\n  lightness: Float,\n  alpha: Float\n}\n\nexport type Color = RGBA | HSLA\n\ninterface Match<a> {\n  RGBA: (color: RGBA) => a,\n  HSLA: (color: HSLA) => a,\n  rgb: (red: Int, green: Int, blue: Int) => a,\n  rgba: (red: Int, green: Int, blue: Int, alpha: Float) => a,\n  hsl: (hue: Float, saturation: Float, lightness: Float) => a,\n  hsla: (hue: Float, saturation: Float, lightness: Float, alpha: Float) => a,\n  _: () => a\n}\n\nexport const match = <a>(match: Match<a>): ((value: mixed) => a) => (\n  value: mixed\n): a => {\n  if (value instanceof HSLAColor) {\n    return match.HSLA(value)\n  } else if (value instanceof RGBAColor) {\n    return match.RGBA(value)\n  } else if (value == null) {\n    return match._()\n  } else if (typeof value === \"object\") {\n    const { red, green, blue, alpha, hue, saturation, lightness } = value\n    if (\n      typeof red === \"number\" &&\n      typeof green === \"number\" &&\n      typeof blue === \"number\"\n    ) {\n      if (typeof alpha === \"number\") {\n        return match.rgba(red, green, blue, alpha)\n      } else {\n        return match.rgb(red, green, blue)\n      }\n    } else if (\n      typeof hue === \"number\" &&\n      typeof saturation === \"number\" &&\n      typeof lightness === \"number\"\n    ) {\n      if (typeof alpha === \"number\") {\n        return match.hsla(hue, saturation, lightness, alpha)\n      } else {\n        return match.hsl(hue, saturation, lightness)\n      }\n    }\n  }\n\n  return match._()\n}\n\nclass RGBAColor implements RGBA {\n  red: Int\n  green: Int\n  blue: Int\n  alpha: Float\n\n  constructor(red: Int, green: Int, blue: Int, alpha: Float) {\n    this.red = red\n    this.green = green\n    this.blue = blue\n    this.alpha = alpha\n  }\n\n  static complement(red: Int, green: Int, blue: Int, alpha: Float): Color {\n    const { hue, saturation, lightness } = rgba2hsla(red, green, blue, alpha)\n    return HSLAColor.complement(hue, saturation, lightness, alpha)\n  }\n}\n\nclass HSLAColor implements HSLA {\n  hue: Float\n  saturation: Float\n  lightness: Float\n  alpha: Float\n\n  constructor(hue: Float, saturation: Float, lightness: Float, alpha: Float) {\n    this.hue = hue\n    this.saturation = saturation\n    this.lightness = lightness\n    this.alpha = alpha\n  }\n\n  static complement(\n    hue: Float,\n    saturation: Float,\n    lightness: Float,\n    alpha: Float\n  ): HSLA {\n    return new HSLAColor(hue + degrees(180), saturation, lightness, alpha)\n  }\n}\n\n// Create RGB colors with an alpha component for transparency.\n// The alpha component is specified with numbers between 0 and 1\nexport const rgba = (red: Int, green: Int, blue: Int, alpha: Float): RGBA =>\n  new RGBAColor(red, green, blue, alpha)\n\n// Create RGB colors from numbers between 0 and 255 inclusive\nexport const rgb = (red: Int, green: Int, blue: Int): RGBA =>\n  new RGBAColor(red, green, blue, 1)\n\n/**\n * Create [HSL colors](http://en.wikipedia.org/wiki/HSL_and_HSV)\n * with an alpha component for transparency.\n */\nexport const hsla = (\n  hue: Float,\n  saturation: Float,\n  lightness: Float,\n  alpha: Float\n): HSLA =>\n  new HSLAColor(\n    hue - turns(Math.floor(hue / (2 * Math.PI))),\n    saturation,\n    lightness,\n    alpha\n  )\n\n/**\n * Create [HSL colors](http://en.wikipedia.org/wiki/HSL_and_HSV). This gives\n * you access to colors more like a color wheel, where all hues are aranged in a\n * circle that you specify with angles (radians).\n * \n * ```js\n * const red = hsl(degrees(0), 1, 0.5)\n * const green = hsl(degrees(120), 1, 0.5)\n * const blue = hsl(degrees(240), 1, 0.5)\n * const pastelRed = hsl(degrees(0), 0.7, 0.7)\n * ```\n * \n * To cycle through all colors, just cycle through degrees. The saturation level\n * is how vibrant the color is, like a dial between grey and bright colors. The\n * lightness level is a dial between white and black.\n */\nexport const hsl = (hue: Float, saturation: Float, lightness: Float): HSLA =>\n  hsla(hue, saturation, lightness, 1)\n\n/**\n * Produce a gray based on the input. 0 is white, 1 is black.\n */\nexport const grayscale = (value: Float): Color =>\n  new HSLAColor(0, 0, 1 - value, 1)\n\nconst fmod = (f: Float, n: Int): Float => {\n  const integer = Math.floor(f)\n  return integer % n + f - integer\n}\n\n/**\n * ## Built-in Colors\n * \n * These colors come from the [Tango palette](http://tango.freedesktop.org/Tango_Icon_Theme_Guidelines)\n * which provides aesthetically reasonable defaults for colors. Each color also\n * comes with a light and dark version.\n */\nexport const lightRed = rgb(239, 41, 41)\nexport const red = rgb(204, 0, 0)\nexport const darkRed = rgb(164, 0, 0)\n\nexport const lightOrange = rgb(252, 175, 62)\nexport const orange = rgb(245, 121, 0)\nexport const darkOrange = rgb(206, 92, 0)\n\nexport const lightYellow = rgb(255, 233, 79)\nexport const yellow = rgb(237, 212, 0)\nexport const darkYellow = rgb(196, 160, 0)\n\nexport const lightGreen = rgb(138, 226, 52)\nexport const green = rgb(115, 210, 22)\nexport const darkGreen = rgb(78, 154, 6)\n\nexport const lightBlue = rgb(114, 159, 207)\nexport const blue = rgb(52, 101, 164)\nexport const darkBlue = rgb(32, 74, 135)\n\nexport const lightPurple = rgb(173, 127, 168)\nexport const purple = rgb(117, 80, 123)\nexport const darkPurple = rgb(92, 53, 102)\n\nexport const lightBrown = rgb(233, 185, 110)\nexport const brown = rgb(193, 125, 17)\nexport const darkBrown = rgb(143, 89, 2)\n\nexport const black = rgb(0, 0, 0)\nexport const white = rgb(255, 255, 255)\n\nexport const lightGrey = rgb(238, 238, 236)\nexport const grey = rgb(211, 215, 207)\nexport const darkGrey = rgb(186, 189, 182)\n\nexport const lightCharcoal = rgb(136, 138, 133)\nexport const charcoal = rgb(85, 87, 83)\nexport const darkCharcoal = rgb(46, 52, 54)\n\nconst hsla2rgba = (\n  hue: Float,\n  saturation: Float,\n  lightness: Float,\n  alpha: Float\n): RGBA => {\n  const chroma = (1 - Math.abs(2 * lightness - 1)) * saturation\n  const h = hue / degrees(60)\n  const x = chroma * (1 - Math.abs(fmod(h, 2 - 1)))\n\n  const [r, g, b] = h < 0\n    ? [0, 0, 0]\n    : h < 1\n      ? [chroma, x, 0]\n      : h < 2\n        ? [x, chroma, 0]\n        : h < 3\n          ? [0, chroma, x]\n          : h < 4\n            ? [0, x, chroma]\n            : h < 5 ? [x, 0, chroma] : h < 6 ? [chroma, 0, x] : [0, 0, 0]\n\n  const m = lightness - chroma / 2\n\n  const color = new RGBAColor(\n    Math.round(255 * (r + m)),\n    Math.round(255 * (g + m)),\n    Math.round(255 * (b + m)),\n    alpha\n  )\n\n  return color\n}\n\nconst rgba2hsla = (red: Int, green: Int, blue: Int, alpha: Float): HSLA => {\n  const [r, g, b] = [red / 255, green / 255, blue / 255]\n  const max = Math.max(Math.max(r, g), b)\n  const min = Math.min(Math.min(r, g), b)\n  const delta = max - min\n\n  const h = max === r\n    ? fmod((g - b) / delta, 6)\n    : max === g ? (b - r) / delta + 2 : (r - g) / delta + 4\n  const hue = degrees(60) * h\n\n  const lightness = (max + min) / 2\n  const saturation = lightness === 0\n    ? 0\n    : delta / (1 - Math.abs(2 * lightness - 1))\n\n  return new HSLAColor(hue, lightness, saturation, alpha)\n}\n\n/**\n * Convert given color into the HSL format.\n */\nexport const toHSL: (color: Color) => HSLA = match({\n  RGBA: ({ red, green, blue, alpha }) => rgba2hsla(red, green, blue, alpha),\n  rgba: rgba2hsla,\n  rgb: (red, green, blue) => rgba2hsla(red, green, blue, 1),\n  HSLA: hsla => hsla,\n  hsla: hsla,\n  hsl: hsl,\n  _: crash\n})\n\n/**\n * Convert given color into the RGB format.\n */\nexport const toRGB: (color: Color) => RGBA = match({\n  HSLA: ({ hue, saturation, lightness, alpha }) =>\n    hsla2rgba(hue, saturation, lightness, alpha),\n  hsla: hsla2rgba,\n  hsl: (hue, saturation, lightness) => hsla2rgba(hue, saturation, lightness, 1),\n  RGBA: rgba => rgba,\n  rgba: rgba,\n  rgb: rgb,\n  _: crash\n})\n\n/**\n * Produce a \"complementary color\". The two colors will\n * accent each other. This is the same as rotating the hue by 180deg;\n */\nexport const complement: (color: Color) => Color = match({\n  HSLA: ({ hue, saturation, lightness, alpha }) =>\n    HSLAColor.complement(hue, saturation, lightness, alpha),\n  hsla: HSLAColor.complement,\n  hsl: (hue, saturation, lightness) =>\n    HSLAColor.complement(hue, saturation, lightness, 1),\n  RGBA: ({ red, green, blue, alpha }) =>\n    RGBAColor.complement(red, green, blue, alpha),\n  rgba: RGBAColor.complement,\n  rgb: (red, green, blue) => RGBAColor.complement(red, green, blue, 1),\n  _: crash\n})\n"]}
;