-
-
Notifications
You must be signed in to change notification settings - Fork 0
/
astro.config.ts
63 lines (61 loc) · 1.59 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
import { defineConfig } from "astro/config";
import tailwind from "@astrojs/tailwind";
import react from "@astrojs/react";
import remarkToc from "remark-toc";
import remarkCollapse from "remark-collapse";
import sitemap from "@astrojs/sitemap";
import { SITE } from "./src/config";
// https://astro.build/config
export default defineConfig({
site: SITE.website,
integrations: [
tailwind({
applyBaseStyles: false,
}),
react(),
sitemap({
serialize(sitemap_item) {
const url = sitemap_item.url;
const isRoot = /devavatar.com\/$/.test(url);
const isAbout = /about\/$/.test(url);
const isCredits = /credits\/$/.test(url);
// const isHire = /hire\/$/.test(url); // Temporarily removed
const postSlug = url.match(/\/posts\/([^\/]+)\/?$/)?.[1] ?? false;
const isPost = postSlug && isNaN(Number(postSlug));
// console.log({ url, isRoot, isPost, isAbout, isCredits, isHire });
if (isRoot || isAbout || isCredits || isPost) {
if (isPost) {
sitemap_item.priority = 1;
}
return sitemap_item;
} else {
return undefined;
}
},
changefreq: "weekly",
lastmod: new Date(),
priority: 0.8,
}),
],
markdown: {
remarkPlugins: [
remarkToc,
[
remarkCollapse,
{
test: "Table of contents",
},
],
],
shikiConfig: {
theme: "one-dark-pro",
wrap: true,
},
},
vite: {
optimizeDeps: {
exclude: ["@resvg/resvg-js"],
},
},
scopedStyleStrategy: "where",
});