1import { chroma, ThemeAppearance, ThemeConfig, color_ramp } from "../../common"
2import { meta, build_syntax, Variant } from "./common"
3
4const variant: Variant = {
5 colors: {
6 base00: "#202746",
7 base01: "#293256",
8 base02: "#5e6687",
9 base03: "#6b7394",
10 base04: "#898ea4",
11 base05: "#979db4",
12 base06: "#dfe2f1",
13 base07: "#f5f7ff",
14 base08: "#c94922",
15 base09: "#c76b29",
16 base0A: "#c08b30",
17 base0B: "#ac9739",
18 base0C: "#22a2c9",
19 base0D: "#3d8fd1",
20 base0E: "#6679cc",
21 base0F: "#9c637a",
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} Sulphurpool 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)