one-light.ts

 1import chroma from "chroma-js"
 2import { fontWeights } from "../common"
 3import { Meta, ThemeSyntax } from "./common/colorScheme"
 4import { colorRamp, createColorScheme } from "./common/ramps"
 5
 6const name = "One Light"
 7
 8const color = {
 9    black: "#383A41",
10    grey: "#A2A3A7",
11    red: "#D36050",
12    orange: "#AD6F26",
13    yellow: "#DFC184",
14    green: "#659F58",
15    teal: "#3982B7",
16    blue: "#5B79E3",
17    purple: "#A449AB",
18    magenta: "#994EA6",
19}
20
21const ramps = {
22    neutral: chroma
23        .scale([
24            "#383A41",
25            "#535456",
26            "#696c77",
27            "#9D9D9F",
28            "#A9A9A9",
29            "#DBDBDC",
30            "#EAEAEB",
31            "#FAFAFA",
32        ])
33        .domain([0.05, 0.22, 0.25, 0.45, 0.62, 0.8, 0.9, 1]),
34    red: colorRamp(chroma(color.red)),
35    orange: colorRamp(chroma(color.orange)),
36    yellow: colorRamp(chroma(color.yellow)),
37    green: colorRamp(chroma(color.green)),
38    cyan: colorRamp(chroma(color.teal)),
39    blue: colorRamp(chroma(color.blue)),
40    violet: colorRamp(chroma(color.purple)),
41    magenta: colorRamp(chroma(color.magenta)),
42}
43
44const syntax: ThemeSyntax = {
45    primary: { color: color.black },
46    "variable.special": { color: color.orange },
47    comment: { color: color.grey },
48    punctuation: { color: color.black },
49    keyword: { color: color.purple },
50    function: { color: color.blue },
51    type: { color: color.teal },
52    variant: { color: color.blue },
53    property: { color: color.red },
54    enum: { color: color.red },
55    operator: { color: color.teal },
56    string: { color: color.green },
57    number: { color: color.orange },
58    boolean: { color: color.orange },
59    title: { color: color.red, weight: fontWeights.normal },
60    "emphasis.strong": {
61        color: color.orange,
62    },
63    linkText: { color: color.blue },
64    linkUri: { color: color.teal },
65}
66
67export const light = createColorScheme(name, true, ramps, syntax)
68
69export const meta: Meta = {
70    name,
71    author: "simurai",
72    license: {
73        SPDX: "MIT",
74        https_url:
75            "https://raw.githubusercontent.com/atom/atom/master/packages/one-light-ui/LICENSE.md",
76        license_checksum:
77            "d5af8fc171f6f600c0ab4e7597dca398dda80dbe6821ce01cef78e859e7a00f8",
78    },
79    url: "https://github.com/atom/atom/tree/master/packages/one-light-ui",
80}