1import { chroma, ThemeAppearance, ThemeConfig, colorRamp } from "../../common"
2import { meta, buildSyntax, 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 = buildSyntax(variant)
26
27const getTheme = (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 licenseType: meta.licenseType,
35 licenseUrl: meta.licenseUrl,
36 licenseFile: `${__dirname}/LICENSE`,
37 inputColor: {
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: colorRamp(chroma(colors.base08)),
49 orange: colorRamp(chroma(colors.base09)),
50 yellow: colorRamp(chroma(colors.base0A)),
51 green: colorRamp(chroma(colors.base0B)),
52 cyan: colorRamp(chroma(colors.base0C)),
53 blue: colorRamp(chroma(colors.base0D)),
54 violet: colorRamp(chroma(colors.base0E)),
55 magenta: colorRamp(chroma(colors.base0F)),
56 },
57 override: { syntax },
58 }
59}
60
61export const theme = getTheme(variant)