2022-03-29 19:08:00 +00:00
|
|
|
import chroma from "chroma-js";
|
2022-03-29 22:28:19 +00:00
|
|
|
import core from "./core";
|
|
|
|
import { Color } from "./lib";
|
2022-03-29 19:08:00 +00:00
|
|
|
import Theme, { BackgroundColor, Weight } from "./theme";
|
|
|
|
|
|
|
|
export function text(
|
|
|
|
theme: Theme,
|
|
|
|
fontFamily: keyof typeof core.fontFamily,
|
|
|
|
color: keyof Theme["textColor"],
|
|
|
|
properties?: { size?: keyof typeof core["fontSize"]; weight?: Weight }
|
|
|
|
) {
|
|
|
|
const sizeKey = properties.size || fontFamily === "sans" ? "sm" : "md";
|
|
|
|
const size = core.fontSize[sizeKey].value;
|
|
|
|
|
|
|
|
return {
|
|
|
|
family: core.fontFamily[fontFamily],
|
|
|
|
color: theme.textColor[color].value,
|
|
|
|
...properties,
|
|
|
|
size,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-03-29 22:28:19 +00:00
|
|
|
export interface BorderOptions {
|
|
|
|
width?: number;
|
|
|
|
top?: boolean;
|
|
|
|
bottom?: boolean;
|
|
|
|
left?: boolean;
|
|
|
|
right?: boolean;
|
|
|
|
overlay?: boolean;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function border(
|
|
|
|
theme: Theme,
|
|
|
|
color: keyof Theme["borderColor"],
|
|
|
|
options?: BorderOptions
|
|
|
|
) {
|
2022-03-29 19:08:00 +00:00
|
|
|
return {
|
|
|
|
color: theme.borderColor[color].value,
|
|
|
|
width: 1,
|
2022-03-29 22:28:19 +00:00
|
|
|
...options,
|
2022-03-29 19:08:00 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
2022-03-29 22:28:19 +00:00
|
|
|
export function iconColor(theme: Theme, color: keyof Theme["iconColor"]) {
|
|
|
|
return theme.iconColor[color].value;
|
|
|
|
}
|
|
|
|
|
2022-03-29 19:08:00 +00:00
|
|
|
export interface Player {
|
|
|
|
selection: {
|
|
|
|
cursor: Color;
|
|
|
|
selection: Color;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function player(
|
|
|
|
theme: Theme,
|
|
|
|
playerNumber: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8
|
|
|
|
): Player {
|
|
|
|
return {
|
|
|
|
selection: {
|
|
|
|
cursor: theme.player[playerNumber].cursorColor.value,
|
|
|
|
selection: theme.player[playerNumber].selectionColor.value,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
export function backgroundColor(
|
|
|
|
theme: Theme,
|
|
|
|
name: keyof Theme["backgroundColor"],
|
|
|
|
state?: keyof BackgroundColor
|
|
|
|
): Color {
|
|
|
|
return theme.backgroundColor[name][state || "base"].value;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function shadow(theme) {
|
|
|
|
return {
|
|
|
|
blur: 16,
|
|
|
|
color: chroma("black").alpha(theme.shadowAlpha.value).hex(),
|
|
|
|
offset: [0, 2],
|
|
|
|
};
|
|
|
|
}
|