UNPKG

@tsparticles/plugin-hsl-color

Version:

tsParticles HSL color plugin

45 lines (44 loc) 1.75 kB
import { getRangeValue, hslToRgb, hslaToRgba, parseAlpha, } from "@tsparticles/engine"; var HslIndexes; (function (HslIndexes) { HslIndexes[HslIndexes["h"] = 1] = "h"; HslIndexes[HslIndexes["s"] = 2] = "s"; HslIndexes[HslIndexes["l"] = 3] = "l"; HslIndexes[HslIndexes["a"] = 5] = "a"; })(HslIndexes || (HslIndexes = {})); export class HslColorManager { constructor() { this.key = "hsl"; this.stringPrefix = "hsl"; } handleColor(color) { const colorValue = color.value, hslColor = colorValue.hsl ?? color.value; if (hslColor.h !== undefined && hslColor.s !== undefined && hslColor.l !== undefined) { return hslToRgb(hslColor); } } handleRangeColor(color) { const colorValue = color.value, hslColor = colorValue.hsl ?? color.value; if (hslColor.h !== undefined && hslColor.l !== undefined) { return hslToRgb({ h: getRangeValue(hslColor.h), l: getRangeValue(hslColor.l), s: getRangeValue(hslColor.s), }); } } parseString(input) { if (!input.startsWith("hsl")) { return; } const regex = /hsla?\(\s*(\d+)\s*[\s,]\s*(\d+)%\s*[\s,]\s*(\d+)%\s*([\s,]\s*(0|1|0?\.\d+|(\d{1,3})%)\s*)?\)/i, result = regex.exec(input), minLength = 4, defaultAlpha = 1, radix = 10; return result ? hslaToRgba({ a: result.length > minLength ? parseAlpha(result[HslIndexes.a]) : defaultAlpha, h: parseInt(result[HslIndexes.h], radix), l: parseInt(result[HslIndexes.l], radix), s: parseInt(result[HslIndexes.s], radix), }) : undefined; } }