-
Notifications
You must be signed in to change notification settings - Fork 2
/
astro.config.ts
118 lines (114 loc) · 3.25 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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
import { readFile } from "node:fs/promises";
import process from "node:process";
import mdx from "@astrojs/mdx";
import sitemap from "@astrojs/sitemap";
import solid from "@astrojs/solid-js";
import vercel from "@astrojs/vercel/serverless";
import { defineConfig } from "astro/config";
import icon from "astro-icon";
import { FontaineTransform } from "fontaine";
import rehypeAutolinkHeadings from "rehype-autolink-headings";
import rehypeExternalLinks from "rehype-external-links";
import rehypeSlug from "rehype-slug";
import remarkDirective from "remark-directive";
import unocss from "unocss/astro";
import { rehypeCopy, remarkAsides } from "./mdx-plugins";
const site = process.env.SITE_HOST === "luxass.com" ? "https://luxass.com" : "https://luxass.dev";
// eslint-disable-next-line no-console
console.log("site", site);
// https://astro.build/config
export default defineConfig({
site,
integrations: [
sitemap({
lastmod: new Date(),
changefreq: "daily",
async serialize(item) {
if (item.url !== `${site}/posts/` && item.url.includes("/posts/")) {
const url = item.url.replace("https://luxass.dev", "");
const content = await readFile(`./src/content${url.slice(0, url.length - 1)}.mdx`, "utf-8");
// parse front matter in content file.
const frontMatterEndIndex = content.indexOf("---", 3);
if (frontMatterEndIndex === -1) {
throw new Error(`Front matter not found in ${url}`);
}
const frontMatter = content.slice(3, frontMatterEndIndex).trim();
const isDraft = frontMatter.includes("draft: true");
// If draft is set to true, do not include in sitemap.
if (isDraft) {
return undefined;
}
}
return {
url: item.url,
lastmod: item.lastmod,
changefreq: item.changefreq,
priority: item.priority,
};
},
// filter(page) {
// return !page.startsWith("/posts")
// },
}),
solid(),
unocss({
injectReset: true,
}),
icon({
include: {
logos: ["npm-icon"],
lucide: ["clipboard", "clipboard-check", "search"],
tabler: ["mail"],
mdi: ["github", "arrow-top-right-thin", "rss", "sitemap", "linkedin", "arrow-right-thin"],
},
}),
mdx(),
],
experimental: {
contentCollectionCache: true,
contentLayer: true,
directRenderScript: true,
contentIntellisense: true,
},
prefetch: {
prefetchAll: true,
defaultStrategy: "load",
},
markdown: {
shikiConfig: {
themes: {
dark: "vitesse-dark",
light: "vitesse-light",
},
},
rehypePlugins: [
rehypeSlug,
rehypeAutolinkHeadings,
[rehypeExternalLinks, {
target: "_blank",
rel: ["noopener", "noreferrer"],
}],
rehypeCopy,
],
remarkPlugins: [
remarkDirective,
remarkAsides,
],
},
output: "hybrid",
adapter: vercel({
webAnalytics: {
enabled: true,
},
isr: {
expiration: 60 * 60 * 8,
},
}),
vite: {
plugins: [FontaineTransform.vite({
fallbacks: ["Arial"],
// id is the font src value in the CSS
resolvePath: (id) => new URL(`./public${id}`, import.meta.url),
})],
},
});