This repository has been archived by the owner on Jan 11, 2025. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathastro.config.ts
99 lines (98 loc) · 2.35 KB
/
astro.config.ts
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
import { rehypeHeadingIds } from '@astrojs/markdown-remark'
import mdx from '@astrojs/mdx'
import sitemap from '@astrojs/sitemap'
import vue from '@astrojs/vue'
import { transformerCopyButton } from '@rehype-pretty/transformers'
import {
transformerMetaHighlight,
transformerNotationDiff,
} from '@shikijs/transformers'
import { defineConfig } from 'astro/config'
import rehypeAutolinkHeadings from 'rehype-autolink-headings'
import rehypeExternalLinks from 'rehype-external-links'
import rehypePrettyCode from 'rehype-pretty-code'
import UnoCSS from 'unocss/astro'
import pagefind from 'vite-plugin-pagefind'
import siteConfig from './src/site-config'
export default defineConfig({
site: siteConfig.site,
trailingSlash: 'never',
build: {
assets: '_assets',
format: 'file',
},
experimental: {
svg: true,
},
vite: {
ssr: {
noExternal: [
`${siteConfig.site}/pagefind/pagefind.js`,
`${siteConfig.site}/pagefind/pagefind-highlight.js`,
],
},
plugins: [pagefind()],
build: {
rollupOptions: {
external: [
`${siteConfig.site}/pagefind/pagefind.js`,
`${siteConfig.site}/pagefind/pagefind-highlight.js`,
],
},
},
},
integrations: [
mdx(),
sitemap(),
UnoCSS({
injectReset: true,
}),
vue({
template: {
compilerOptions: {
isCustomElement: tag => ['site-search'].includes(tag),
},
},
}),
],
markdown: {
// smartypants: false,
syntaxHighlight: false,
rehypePlugins: [
[rehypeExternalLinks, { target: '_blank', rel: 'noopener' }],
rehypeHeadingIds,
[
rehypeAutolinkHeadings,
{
properties: {
className: 'header-anchor',
ariaHidden: true,
},
content: [
{
type: 'text',
value: '#',
},
],
},
],
[
rehypePrettyCode,
{
theme: {
light: 'github-light-high-contrast',
dark: 'github-dark-high-contrast',
},
transformers: [
transformerNotationDiff(),
transformerMetaHighlight(),
transformerCopyButton({
visibility: 'hover',
feedbackDuration: 1000,
}),
],
},
],
],
},
})