-
Notifications
You must be signed in to change notification settings - Fork 2
/
astro.config.mjs
71 lines (68 loc) · 2.17 KB
/
astro.config.mjs
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
import { defineConfig, envField } from "astro/config";
import tailwind from "@astrojs/tailwind";
import sitemap from "@astrojs/sitemap";
import { readFileSync } from "node:fs";
import icon from "astro-icon";
import expressiveCode from "astro-expressive-code";
import colors from "tailwindcss/colors";
/** @type {import('astro-expressive-code').AstroExpressiveCodeOptions} */
const astroExpressiveCodeOptions = {
themes: ["houston", "catppuccin-latte"],
styleOverrides: {
frames: {
editorActiveTabBackground: ({ theme }) =>
theme.type === "dark" ? colors.zinc[800] : colors.white,
editorTabBarBackground: ({ theme }) =>
theme.type === "dark" ? colors.zinc[900] : colors.zinc[100],
frameBoxShadowCssValue: "none",
editorTabBarBorderBottomColor: ({ theme }) =>
theme.type === "dark" ? colors.zinc[700] : colors.zinc[200],
terminalBackground: ({ theme }) =>
theme.type === "dark" ? colors.zinc[800] : colors.white,
terminalTitlebarBackground: ({ theme }) =>
theme.type === "dark" ? colors.zinc[900] : colors.zinc[100],
terminalTitlebarBorderBottomColor: ({ theme }) =>
theme.type === "dark" ? colors.zinc[700] : colors.zinc[200],
},
codeBackground: ({ theme }) =>
theme.type === "dark" ? colors.zinc[800] : colors.white,
borderColor: ({ theme }) =>
theme.type === "dark" ? colors.zinc[700] : colors.zinc[200],
borderRadius: "0",
},
};
export default defineConfig({
integrations: [
tailwind(),
sitemap(),
expressiveCode(astroExpressiveCodeOptions),
icon(),
],
site: "https://www.kevinzc.com",
vite: {
plugins: [rawFonts([".ttf", ".woff"])],
optimizeDeps: {
exclude: ["@resvg/resvg-js"],
},
},
env: {
schema: {
GH_TOKEN: envField.string({ context: "server", access: "secret" }),
},
},
});
// vite plugin to import fonts
function rawFonts(ext) {
return {
name: "vite-plugin-raw-fonts",
transform(_, id) {
if (ext.some((e) => id.endsWith(e))) {
const buffer = readFileSync(id);
return {
code: `export default ${JSON.stringify(buffer)}`,
map: null,
};
}
},
};
}