1import { chroma, ThemeAppearance, ThemeConfig, color_ramp } from "../../common"
2import { meta, build_syntax, Variant } from "./common"
3
4const variant: Variant = {
5 colors: {
6 base00: "#f4fbf4",
7 base01: "#cfe8cf",
8 base02: "#8ca68c",
9 base03: "#809980",
10 base04: "#687d68",
11 base05: "#5e6e5e",
12 base06: "#242924",
13 base07: "#131513",
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 Light`,
32 author: meta.author,
33 appearance: ThemeAppearance.Light,
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 [
40 colors.base00,
41 colors.base01,
42 colors.base02,
43 colors.base03,
44 colors.base04,
45 colors.base05,
46 colors.base06,
47 colors.base07,
48 ].reverse()
49 ),
50 red: color_ramp(chroma(colors.base08)),
51 orange: color_ramp(chroma(colors.base09)),
52 yellow: color_ramp(chroma(colors.base0A)),
53 green: color_ramp(chroma(colors.base0B)),
54 cyan: color_ramp(chroma(colors.base0C)),
55 blue: color_ramp(chroma(colors.base0D)),
56 violet: color_ramp(chroma(colors.base0E)),
57 magenta: color_ramp(chroma(colors.base0F)),
58 },
59 override: { syntax },
60 }
61}
62
63export const theme = get_theme(variant)