-
-
Notifications
You must be signed in to change notification settings - Fork 6
/
main.js
111 lines (102 loc) · 3.75 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
import JsonUrl from "json-url";
import { variants } from "@catppuccin/palette";
const accents = [
"rosewater",
"flamingo",
"pink",
"mauve",
"red",
"maroon",
"peach",
"yellow",
"green",
"teal",
"sky",
"sapphire",
"blue",
"lavender",
];
const jsonCodec = JsonUrl("lzma");
const hexToRgb = (hex) => {
const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex);
return result
? {
r: parseInt(result[1], 16),
g: parseInt(result[2], 16),
b: parseInt(result[3], 16),
}
: null;
};
const capitalize = (s) => {
if (typeof s !== "string") return "";
return s.charAt(0).toUpperCase() + s.slice(1);
};
(async () => {
for (const flavour of Object.keys(variants)) {
console.log(`<details>\n<summary>${capitalize(flavour)}</summary>\n`);
const lib = {};
Object.keys(variants[flavour]).forEach((colour) => {
const hex = variants[flavour][colour]["hex"];
const { r, g, b } = hexToRgb(hex);
lib[colour] = {
r,
g,
b,
};
});
for (const accent of accents) {
lib.accent = lib[accent];
const theme = {
colors: {
toolbar: lib["base"],
toolbar_text: lib["text"],
frame: lib["crust"],
tab_background_text: lib["text"],
toolbar_field: lib["mantle"],
toolbar_field_text: lib["text"],
tab_line: lib["accent"],
popup: lib["base"],
popup_text: lib["text"],
button_background_active: lib["overlay0"],
frame_inactive: lib["crust"],
icons_attention: lib["accent"],
icons: lib["accent"],
ntp_background: lib["crust"],
ntp_text: lib["text"],
popup_border: lib["accent"],
popup_highlight_text: lib["text"],
popup_highlight: lib["overlay0"],
sidebar_border: lib["accent"],
sidebar_highlight_text: lib["crust"],
sidebar_highlight: lib["accent"],
sidebar_text: lib["text"],
sidebar: lib["base"],
tab_background_separator: lib["accent"],
tab_loading: lib["accent"],
tab_selected: lib["base"],
tab_text: lib["text"],
toolbar_bottom_separator: lib["base"],
toolbar_field_border_focus: lib["accent"],
toolbar_field_border: lib["base"],
toolbar_field_focus: lib["base"],
toolbar_field_highlight_text: lib["base"],
toolbar_field_highlight: lib["accent"],
toolbar_field_separator: lib["accent"],
toolbar_vertical_separator: lib["accent"],
},
images: {
additional_backgrounds: ["./bg-000.svg"],
custom_backgrounds: [],
},
title: `Catppuccin ${flavour} ${accent}`,
};
const url = await jsonCodec.compress(theme);
const link = `<a href="https://color.firefox.com/?theme=${url}">${capitalize(
accent
)}</a>`;
const img = `<img src="https://raw.githubusercontent.com/catppuccin/catppuccin/main/assets/palette/circles/${flavour}_${accent}.png" height="12" width="12"/>`;
console.log(` - ${img} ${link}`);
}
console.log(`</details>`);
}
})();