๐Ÿ“ฆ nianyi778 / nianyi778.github.io

๐Ÿ“„ astro.config.mjs ยท 114 lines
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
112
113
114import { rehypeHeadingIds } from '@astrojs/markdown-remark';
import sitemap from '@astrojs/sitemap';
import tailwind from '@astrojs/tailwind';
import toc from '@jsdevtools/rehype-toc';
import compress from '@playform/compress';
import {
	transformerMetaHighlight,
	transformerMetaWordHighlight,
	transformerNotationDiff,
	transformerNotationErrorLevel,
	transformerNotationFocus,
	transformerNotationHighlight,
	transformerNotationWordHighlight,
} from '@shikijs/transformers';
import icon from 'astro-icon';
import pagefind from 'astro-pagefind';
import { defineConfig } from 'astro/config';
import { rehypeAccessibleEmojis } from 'rehype-accessible-emojis';
import rehypeExternalLinks from 'rehype-external-links';
import rehypeKatax from 'rehype-katex';
import emoji from 'remark-emoji';
import remarkMath from 'remark-math';
import { Site } from './src/config';
import { getMarkdownEntries } from './src/utils/post';
import { remarkPostTime, remarkReadingTime } from './src/utils/remark';
import { transformerEnhanser } from './src/utils/shiki';

// Configure base differently for Vercel vs GitHub Pages
const normalizeBase = (val) => {
	if (!val || val === '/') return '/';
	let b = String(val);
	if (!b.startsWith('/')) b = `/${b}`;
	if (!b.endsWith('/')) b = `${b}/`;
	return b;
};
const isVercel = !!process.env.VERCEL;
const BASE = isVercel ? '/' : normalizeBase(process.env.BASE_URL);

const excludeSitemapFiles = (await getMarkdownEntries()).filter(
	(entry) => entry.file.data.hidden,
);

// https://astro.build/config
export default defineConfig({
	site: Site,
	base: BASE,
	build: {
		format: 'file',
	},
	integrations: [
		tailwind({
			applyBaseStyles: false,
		}),
		icon({
			iconDir: 'src/assets',
		}),
		pagefind(),
		sitemap({
			filter: (page) =>
				!excludeSitemapFiles.some((entry) => entry.url.href === page),
		}),
		compress({
			CSS: {
				csso: false,
				lightningcss: {
					minify: true,
				},
			},
			HTML: {
				removeComments: false,
			},
			Image: true,
			JavaScript: true,
			SVG: true,
			Parser: {
				CSS: 'lightningcss',
			},
		}),
	],
	prefetch: {
		defaultStrategy: 'tap',
	},
	markdown: {
		shikiConfig: {
			themes: {
				light: 'vitesse-light',
				dark: 'vitesse-dark',
			},
			// disable word wrap for horizontal scrolling
			wrap: false,
			// Add custom transformers: https://shiki.style/guide/transformers
			// Find common transformers: https://shiki.style/packages/transformers
			transformers: [
				transformerMetaHighlight(),
				transformerMetaWordHighlight(),
				transformerNotationDiff(),
				transformerNotationErrorLevel(),
				transformerNotationFocus(),
				transformerNotationHighlight(),
				transformerNotationWordHighlight(),
				transformerEnhanser(),
			],
		},
		remarkPlugins: [emoji, remarkMath, remarkPostTime, remarkReadingTime],
		rehypePlugins: [
			rehypeAccessibleEmojis,
			[rehypeExternalLinks, { target: '_blank' }],
			rehypeHeadingIds,
			toc,
			rehypeKatax,
		],
	},
});