@tsparticles/plugin-hsl-color
Version:
tsParticles HSL color plugin
45 lines (44 loc) • 1.75 kB
JavaScript
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;
}
}