-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathastro.config.ts
More file actions
84 lines (81 loc) · 2.3 KB
/
astro.config.ts
File metadata and controls
84 lines (81 loc) · 2.3 KB
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
import { defineConfig, envField, fontProviders } from "astro/config";
import { rehypeHeadingIds } from "@astrojs/markdown-remark";
import sitemap from "@astrojs/sitemap";
import remarkToc from "remark-toc";
import remarkCollapse from "remark-collapse";
import {
transformerNotationDiff,
transformerNotationHighlight,
transformerNotationWordHighlight,
} from "@shikijs/transformers";
import { SITE } from "./src/config";
import {
ASTRO_FONT_REGISTRATIONS,
type FontProviderName,
resolveFontProviderName,
} from "./src/config/fonts";
import { rehypeArticleCodeBlocks } from "./src/plugins/rehypeArticleCodeBlocks";
import { codeLanguageShikiAliases } from "./src/utils/codeLanguage";
function getAstroFontProvider(provider: FontProviderName) {
switch (resolveFontProviderName(provider)) {
case "google":
return fontProviders.google();
}
}
// https://astro.build/config
export default defineConfig({
site: SITE.website,
integrations: [
sitemap({
filter: page => SITE.showArchives || !page.endsWith("/archives"),
}),
],
markdown: {
remarkPlugins: [remarkToc, [remarkCollapse, { test: "Table of contents" }]],
rehypePlugins: [rehypeHeadingIds, rehypeArticleCodeBlocks],
shikiConfig: {
// For more themes, visit https://shiki.style/themes
themes: { light: "min-light", dark: "night-owl" },
defaultColor: false,
langAlias: codeLanguageShikiAliases,
wrap: false,
transformers: [
transformerNotationHighlight(),
transformerNotationWordHighlight(),
transformerNotationDiff({ matchAlgorithm: "v3" }),
],
},
},
vite: {
build: {
chunkSizeWarningLimit: 800,
},
optimizeDeps: {
exclude: ["@resvg/resvg-js"],
},
},
image: {
responsiveStyles: true,
layout: "constrained",
},
env: {
schema: {
PUBLIC_GOOGLE_SITE_VERIFICATION: envField.string({
access: "public",
context: "client",
optional: true,
}),
},
},
experimental: {
preserveScriptOrder: true,
fonts: ASTRO_FONT_REGISTRATIONS.map(font => ({
name: font.name,
provider: getAstroFontProvider(font.provider),
cssVariable: font.cssVariable,
fallbacks: [...font.fallbacks],
weights: [...font.weights],
styles: [...font.styles],
})),
},
});