aboutsummaryrefslogtreecommitdiffstats
path: root/thallium-frontend/src/themes.tsx
blob: 010d487359a9fa663aa35b380b0a51fc58881e94 (plain) (blame)
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
/* eslint-disable react-refresh/only-export-components */

interface Theme {
    // We expose the selected theme here in case that in addition to using colours
    // component users want to apply different styles entirely based on the theme. (e.g. borders)
    selectedTheme: "light" | "dark";
    backgroundColor: string;
    textColor: string;
    borderColor: string;
    linkColor: string;
    cardBackgroundColor: string;
    cardShadow: string;
    accent: string;
    inputBackgroundColor: string;
    inputPlaceholderColor: string;
}

interface ThemesStore {
    light: Theme;
    dark: Theme;
}

const commonTheme = {
    accent: "#7e5da3",
};

const themes: ThemesStore = {
    light: {
        selectedTheme: "light",
        backgroundColor: "#f0f0f0",
        textColor: "#000",
        borderColor: "#838383",
        linkColor: "#7272ff",
        cardBackgroundColor: "#dbdbdb",
        cardShadow: "#d0d0d0",
        inputBackgroundColor: "#fff",
        inputPlaceholderColor: "#949494",
        ...commonTheme,
    },
    dark: {
        selectedTheme: "dark",
        backgroundColor: "#303030",
        textColor: "#fff",
        borderColor: "#949494",
        linkColor: "#8f8fff",
        cardBackgroundColor: "#2c2c2c",
        cardShadow: "#242323",
        inputBackgroundColor: "#444",
        inputPlaceholderColor: "#acacac",
        ...commonTheme,
    },
};

export default themes;

export type { Theme, ThemesStore };