bigbuffet-rw/packages/pl-fe/tailwind/colors.ts

41 lines
1.4 KiB
TypeScript
Raw Normal View History

import type{ RecursiveKeyValuePair } from 'tailwindcss/types/config';
2023-12-20 18:34:09 -08:00
/** https://tailwindcss.com/docs/customizing-colors#using-css-variables */
const withOpacityValue = (variable: string): string => `rgb(var(${variable}) / <alpha-value>)`;
2023-12-20 18:34:09 -08:00
/** Parse a single color as a CSS variable. */
const toColorVariable = (colorName: string, tint: number | null = null): string => {
const suffix = tint ? `-${tint}` : '';
const variable = `--color-${colorName}${suffix}`;
return withOpacityValue(variable);
};
/** Parse list of tints into Tailwind function with CSS variables. */
const parseTints = (colorName: string, tints: number[]): RecursiveKeyValuePair =>
tints.reduce<Record<string, string>>((colorObj, tint) => {
2023-12-20 18:34:09 -08:00
colorObj[tint] = toColorVariable(colorName, tint);
return colorObj;
}, {});
interface ColorMatrix {
[colorName: string]: number[] | boolean;
}
/** Parse color matrix into Tailwind color palette. */
const parseColorMatrix = (colorMatrix: ColorMatrix): RecursiveKeyValuePair =>
Object.entries(colorMatrix).reduce<RecursiveKeyValuePair>((palette, colorData) => {
2023-12-20 18:34:09 -08:00
const [colorName, tints] = colorData;
// Conditionally parse array or single-tint colors
if (Array.isArray(tints)) {
palette[colorName] = parseTints(colorName, tints);
} else if (tints === true) {
palette[colorName] = toColorVariable(colorName);
}
return palette;
}, {});
export { withOpacityValue, parseColorMatrix };