From a8728585e65e853d16eebebf52f33aa84755e9e4 Mon Sep 17 00:00:00 2001 From: xRyul <47340038+xRyul@users.noreply.github.com> Date: Thu, 23 May 2024 01:17:57 +0100 Subject: [PATCH] Add extra support for coloring: HSL, HSB, HSV, HEX, RGB. Now we can use color: hwb(360,100%,36%) etc. (#334) --- src/util/util.ts | 77 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) diff --git a/src/util/util.ts b/src/util/util.ts index c9c26e8..45f1ab4 100644 --- a/src/util/util.ts +++ b/src/util/util.ts @@ -49,6 +49,35 @@ export function getParametersFromSource( let { title, collapse, icon, color, metadata } = params; + // If color is in RGB format + if (color && color.startsWith('rgb')) { + color = color.slice(4, -1); + } + + // If color is in Hex format, convert it to RGB + if (color && color.startsWith('#')) { + const hex = color.slice(1); + const bigint = parseInt(hex, 16); + const r = (bigint >> 16) & 255; + const g = (bigint >> 8) & 255; + const b = bigint & 255; + color = `${r}, ${g}, ${b}`; + } + + // If color is in HSL format, convert it to RGB + if (color && color.startsWith('hsl')) { + const [h, s, l] = color.slice(4, -1).split(',').map(str => Number(str.replace('%', '').trim())); + const [r, g, b] = hslToRgb(h, s, l); + color = `${r}, ${g}, ${b}`; + } + + // If color is in HSB format, convert it to RGB + if (color && (color.startsWith('hsb') || color.startsWith('hsv'))) { + const [h, s, v] = color.slice(4, -1).split(',').map(str => Number(str.replace('%', '').trim())); + const [r, g, b] = hsbToRgb(h, s, v); + color = `${r}, ${g}, ${b}`; + } + let content = lines.slice(skipLines).join("\n"); /** @@ -83,3 +112,51 @@ export function getParametersFromSource( return { title, collapse, content, icon, color, metadata }; } + +function hslToRgb(h: number, s: number, l: number) { + h /= 360; + s /= 100; + l /= 100; + let r, g, b; + + if (s === 0) { + r = g = b = l; // achromatic + } else { + const hue2rgb = (p: number, q: number, t: number) => { + if (t < 0) t += 1; + if (t > 1) t -= 1; + if (t < 1 / 6) return p + (q - p) * 6 * t; + if (t < 1 / 2) return q; + if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6; + return p; + }; + const q = l < 0.5 ? l * (1 + s) : l + s - l * s; + const p = 2 * l - q; + r = hue2rgb(p, q, h + 1 / 3); + g = hue2rgb(p, q, h); + b = hue2rgb(p, q, h - 1 / 3); + } + + return [Math.round(r * 255), Math.round(g * 255), Math.round(b * 255)]; +} + +function hsbToRgb(h: number, s: number, b: number) { + h /= 360; + s /= 100; + b /= 100; + let r, g, bb; + let i = Math.floor(h * 6); + let f = h * 6 - i; + let p = b * (1 - s); + let q = b * (1 - f * s); + let t = b * (1 - (1 - f) * s); + switch (i % 6) { + case 0: r = b, g = t, bb = p; break; + case 1: r = q, g = b, bb = p; break; + case 2: r = p, g = b, bb = t; break; + case 3: r = p, g = q, bb = b; break; + case 4: r = t, g = p, bb = b; break; + case 5: r = b, g = p, bb = q; break; + } + return [Math.round(r * 255), Math.round(g * 255), Math.round(bb * 255)]; +} \ No newline at end of file