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    ,
35    red: colorRamp(chroma(color.red)),
36    orange: colorRamp(chroma(color.orange)),
37    yellow: colorRamp(chroma(color.yellow)),
38    green: colorRamp(chroma(color.green)),
39    cyan: colorRamp(chroma(color.teal)),
40    blue: colorRamp(chroma(color.blue)),
41    violet: colorRamp(chroma(color.purple)),
42    magenta: colorRamp(chroma(color.magenta)),
43};
44
45const syntax: ThemeSyntax = {
46    primary: { color: color.black },
47    "variable.special": { color: color.orange },
48    comment: { color: color.grey },
49    punctuation: { color: color.black },
50    keyword: { color: color.purple },
51    function: { color: color.blue },
52    type: { color: color.teal },
53    variant: { color: color.blue },
54    property: { color: color.red },
55    enum: { color: color.red },
56    operator: { color: color.teal },
57    string: { color: color.green },
58    number: { color: color.orange },
59    boolean: { color: color.orange },
60    title: { color: color.red, weight: fontWeights.normal },
61    "emphasis.strong": {
62        color: color.orange,
63    },
64    linkText: { color: color.blue },
65    linkUri: { color: color.teal },
66}
67
68export const light = createColorScheme(name, true, ramps, syntax)
69
70export const meta: Meta = {
71    name,
72    author: "simurai",
73    license: {
74        SPDX: "MIT",
75        https_url:
76            "https://raw.githubusercontent.com/atom/atom/master/packages/one-light-ui/LICENSE.md",
77        license_checksum:
78            "d5af8fc171f6f600c0ab4e7597dca398dda80dbe6821ce01cef78e859e7a00f8",
79    },
80    url: "https://github.com/atom/atom/tree/master/packages/one-light-ui",
81}