atelier-seaside-dark.ts

 1import { chroma, ThemeAppearance, ThemeConfig, color_ramp } from "../../common"
 2import { meta, build_syntax, Variant } from "./common"
 3
 4const variant: Variant = {
 5    colors: {
 6        base00: "#131513",
 7        base01: "#242924",
 8        base02: "#5e6e5e",
 9        base03: "#687d68",
10        base04: "#809980",
11        base05: "#8ca68c",
12        base06: "#cfe8cf",
13        base07: "#f4fbf4",
14        base08: "#e6193c",
15        base09: "#87711d",
16        base0A: "#98981b",
17        base0B: "#29a329",
18        base0C: "#1999b3",
19        base0D: "#3d62f5",
20        base0E: "#ad2bee",
21        base0F: "#e619c3",
22    },
23}
24
25const syntax = build_syntax(variant)
26
27const get_theme = (variant: Variant): ThemeConfig => {
28    const { colors } = variant
29
30    return {
31        name: `${meta.name} Seaside Dark`,
32        author: meta.author,
33        appearance: ThemeAppearance.Dark,
34        license_type: meta.license_type,
35        license_url: meta.license_url,
36        license_file: `${__dirname}/LICENSE`,
37        input_color: {
38            neutral: chroma.scale([
39                colors.base00,
40                colors.base01,
41                colors.base02,
42                colors.base03,
43                colors.base04,
44                colors.base05,
45                colors.base06,
46                colors.base07,
47            ]),
48            red: color_ramp(chroma(colors.base08)),
49            orange: color_ramp(chroma(colors.base09)),
50            yellow: color_ramp(chroma(colors.base0A)),
51            green: color_ramp(chroma(colors.base0B)),
52            cyan: color_ramp(chroma(colors.base0C)),
53            blue: color_ramp(chroma(colors.base0D)),
54            violet: color_ramp(chroma(colors.base0E)),
55            magenta: color_ramp(chroma(colors.base0F)),
56        },
57        override: { syntax },
58    }
59}
60
61export const theme = get_theme(variant)