-
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathastro.config.ts
73 lines (70 loc) · 1.95 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
import { readFileSync } from 'node:fs';
import { defineConfig } from 'astro/config';
import icon from 'astro-icon';
import mdx from '@astrojs/mdx';
import solid from '@astrojs/solid-js';
import sitemap from '@astrojs/sitemap';
import tailwind from '@astrojs/tailwind';
import { remarkReadingTime } from './plugins/remark-reading-time.mjs';
import react from '@astrojs/react';
import expressiveCode, { ExpressiveCodeTheme } from 'astro-expressive-code';
import { pluginCollapsibleSections } from '@expressive-code/plugin-collapsible-sections';
import { mermaid } from './plugins/remark-mermaid';
const darkTheme = readFileSync(new URL('./config/theme/tailwind-dark-slate.json', import.meta.url), 'utf-8');
const lightTheme = readFileSync(new URL('./config/theme/tailwind-breeze.json', import.meta.url), 'utf-8');
const remarkPlugins = [remarkReadingTime, mermaid];
export default defineConfig({
site: 'https://paularmstrong.dev',
trailingSlash: 'always',
compressHTML: true,
devToolbar: {
enabled: false,
},
integrations: [
expressiveCode({
themes: [ExpressiveCodeTheme.fromJSONString(darkTheme), ExpressiveCodeTheme.fromJSONString(lightTheme)],
tabWidth: 2,
useDarkModeMediaQuery: false,
styleOverrides: {
codeLineHeight: '1.4',
frames: {
frameBoxShadowCssValue: 'none',
},
},
plugins: [pluginCollapsibleSections()],
}),
icon(),
solid({
include: ['src/**'],
exclude: ['**/*react*/**'],
}),
react({
include: ['**/*react*/**'],
}),
tailwind(),
mdx({}),
sitemap({
serialize(item) {
if (item.url.endsWith('paularmstrong.dev/')) {
item.priority = 1.0;
} else if (item.url.endsWith('paularmstrong.dev/blog/')) {
// @ts-expect-error they used a TS enum <smh>
item.changefreq = 'daily';
item.priority = 0.9;
}
return item;
},
}),
],
markdown: {
remarkPlugins,
},
vite: {
build: {
sourcemap: true,
},
ssr: {
noExternal: ['react-component-benchmark'],
},
},
});