2022-03-29 19:33:03 +00:00
|
|
|
import chroma from "chroma-js";
|
|
|
|
|
2022-03-29 19:08:00 +00:00
|
|
|
export type Color = string;
|
|
|
|
|
2022-03-29 19:33:03 +00:00
|
|
|
function getColorRamp(colorName, baseColor, steps = 10) {
|
|
|
|
let hsl = chroma(baseColor).hsl();
|
|
|
|
let h = Math.round(hsl[0]);
|
|
|
|
let lightColor = chroma.hsl(h, 0.88, 0.96).hex();
|
|
|
|
let darkColor = chroma.hsl(h, 0.68, 0.32).hex();
|
|
|
|
|
|
|
|
let ramp = chroma
|
|
|
|
.scale([lightColor, baseColor, darkColor])
|
|
|
|
.domain([0, 0.5, 1])
|
|
|
|
.mode("hsl")
|
|
|
|
.gamma(1)
|
|
|
|
.correctLightness(true)
|
|
|
|
.padding([0, 0.15])
|
|
|
|
.colors(steps);
|
|
|
|
|
|
|
|
let tokens = {};
|
|
|
|
let token = {};
|
|
|
|
let colorNumber = 0;
|
|
|
|
|
|
|
|
for (let i = 0; i < steps; i++) {
|
|
|
|
if (i !== 0) {
|
|
|
|
colorNumber = i * 100;
|
|
|
|
}
|
|
|
|
|
|
|
|
token = {
|
|
|
|
[`${colorName}_${colorNumber}`]: {
|
|
|
|
value: ramp[i].value,
|
|
|
|
rootValue: baseColor,
|
|
|
|
step: i,
|
|
|
|
type: "color",
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
Object.assign(token, tokens);
|
|
|
|
}
|
|
|
|
|
|
|
|
return tokens;
|
|
|
|
}
|
|
|
|
|
2022-03-29 19:08:00 +00:00
|
|
|
export default {
|
2022-03-29 19:33:03 +00:00
|
|
|
color: {
|
|
|
|
rose: getColorRamp("rose", "#F43F5E", 10),
|
|
|
|
},
|
|
|
|
|
2022-03-29 19:08:00 +00:00
|
|
|
fontFamily: {
|
|
|
|
sans: "Zed Sans",
|
|
|
|
mono: "Zed Mono",
|
|
|
|
},
|
|
|
|
fontSize: {
|
|
|
|
"3xs": {
|
|
|
|
value: "8",
|
|
|
|
type: "fontSizes",
|
|
|
|
},
|
|
|
|
"2xs": {
|
|
|
|
value: "10",
|
|
|
|
type: "fontSizes",
|
|
|
|
},
|
|
|
|
xs: {
|
|
|
|
value: "12",
|
|
|
|
type: "fontSizes",
|
|
|
|
},
|
|
|
|
sm: {
|
|
|
|
value: "14",
|
|
|
|
type: "fontSizes",
|
|
|
|
},
|
|
|
|
md: {
|
|
|
|
value: "16",
|
|
|
|
type: "fontSizes",
|
|
|
|
},
|
|
|
|
lg: {
|
|
|
|
value: "18",
|
|
|
|
type: "fontSizes",
|
|
|
|
},
|
|
|
|
xl: {
|
|
|
|
value: "20",
|
|
|
|
type: "fontSizes",
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|