/
useThemeVariables.ts
65 lines (56 loc) · 1.43 KB
/
useThemeVariables.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
import { useMemo } from "react";
import { HexString, getContrastRatio } from "@react-md/utils";
import {
DEFAULT_PRIMARY_COLOR,
DEFAULT_SECONDARY_COLOR,
} from "components/Theme/useTheme";
type CSSVariableValue = string | number | null;
interface CSSVariable {
name: string;
value: CSSVariableValue;
}
function isWhiteHighestContrast(color: HexString): boolean {
const lightRatio = getContrastRatio(color, "#fff");
const darkRatio = getContrastRatio(color, "#000");
return lightRatio > darkRatio;
}
export default function useThemeVariables(
primaryColor: HexString,
secondaryColor: HexString
): CSSVariable[] {
return useMemo(() => {
if (
primaryColor === DEFAULT_PRIMARY_COLOR &&
secondaryColor === DEFAULT_SECONDARY_COLOR
) {
return [];
}
const variables: CSSVariable[] = [
{
name: "--rmd-theme-primary",
value: primaryColor,
},
{
name: "--rmd-theme-secondary",
value: secondaryColor,
},
];
if (primaryColor) {
if (isWhiteHighestContrast(primaryColor)) {
variables.push({
name: "--rmd-theme-on-primary",
value: "#fff",
});
}
}
if (secondaryColor) {
if (isWhiteHighestContrast(secondaryColor)) {
variables.push({
name: "--rmd-theme-on-secondary",
value: "#fff",
});
}
}
return variables;
}, [primaryColor, secondaryColor]);
}