newechoes/astro.config.mjs

158 lines
4.2 KiB
JavaScript
Raw Normal View History

2025-02-24 16:18:36 +08:00
// @ts-check
import { defineConfig } from "astro/config";
2025-02-24 16:18:36 +08:00
import tailwindcss from "@tailwindcss/vite";
import mdx from "@astrojs/mdx";
import react from "@astrojs/react";
import remarkEmoji from "remark-emoji";
import rehypeExternalLinks from "rehype-external-links";
import sitemap from "@astrojs/sitemap";
import fs from "node:fs";
import path from "node:path";
import { SITE_URL } from "./src/consts";
2025-03-08 18:16:42 +08:00
import vercel from "@astrojs/vercel";
2025-03-09 14:37:44 +08:00
2025-03-08 18:16:42 +08:00
function getArticleDate(articleId) {
try {
2025-03-10 21:12:16 +08:00
// 处理多级目录的文章路径
const mdPath = path.join(process.cwd(), "src/content", articleId + ".md");
const mdxPath = path.join(process.cwd(), "src/content", articleId + ".mdx");
2025-03-10 21:12:16 +08:00
let filePath = fs.existsSync(mdPath) ? mdPath : mdxPath;
2025-03-10 21:12:16 +08:00
if (fs.existsSync(filePath)) {
const content = fs.readFileSync(filePath, "utf-8");
2025-03-08 18:16:42 +08:00
const match = content.match(/date:\s*(\d{4}-\d{2}-\d{2})/);
if (match) {
return new Date(match[1]).toISOString();
}
}
} catch (error) {
console.error("Error reading article date:", error);
2025-03-08 18:16:42 +08:00
}
2025-03-10 21:12:16 +08:00
return new Date().toISOString(); // 如果没有日期,返回当前时间
2025-03-08 18:16:42 +08:00
}
2025-03-03 21:16:16 +08:00
2025-02-24 16:18:36 +08:00
// https://astro.build/config
2025-03-03 21:16:16 +08:00
export default defineConfig({
2025-03-09 14:37:44 +08:00
site: SITE_URL,
output: "static",
trailingSlash: "ignore",
2025-03-09 14:37:44 +08:00
2025-03-08 18:16:42 +08:00
build: {
format: "directory",
2025-03-08 18:16:42 +08:00
},
2025-03-09 14:37:44 +08:00
2025-03-03 21:16:16 +08:00
vite: {
plugins: [tailwindcss()],
build: {
rollupOptions: {
output: {
// 手动分块配置
manualChunks: {
// 将地图组件单独打包
"world-heatmap": ["./src/components/WorldHeatmap.tsx"],
// 将 React 相关库单独打包
"react-vendor": ["react", "react-dom"],
// 其他大型依赖也可以单独打包
"chart-vendor": ["chart.js"],
2025-03-09 14:37:44 +08:00
// 将 ECharts 单独打包
"echarts-vendor": ["echarts"],
// 将其他组件打包到一起
components: ["./src/components"],
},
},
},
// 提高警告阈值,避免不必要的警告
chunkSizeWarningLimit: 1000,
},
2025-03-03 21:16:16 +08:00
},
2025-03-08 18:16:42 +08:00
integrations: [
// MDX 集成配置
mdx({
// 不使用共享的 markdown 配置
extendMarkdownConfig: false,
// 为 MDX 单独配置所需功能
remarkPlugins: [
// 添加表情符号支持
2025-03-29 16:09:16 +08:00
[remarkEmoji, { emoticon: false, padded: true }]
],
rehypePlugins: [
[rehypeExternalLinks, { target: '_blank', rel: ['nofollow', 'noopener', 'noreferrer'] }]
],
// 设置代码块处理行为
remarkRehype: {
allowDangerousHtml: false // 不解析 HTML
},
gfm: true
}),
2025-03-08 18:16:42 +08:00
react(),
sitemap({
filter: (page) => !page.includes("/api/"),
2025-03-08 18:16:42 +08:00
serialize(item) {
if (!item) return undefined;
// 文章页面
if (item.url.includes("/articles/")) {
2025-03-08 18:16:42 +08:00
// 从 URL 中提取文章 ID
const articleId = item.url
.replace(SITE_URL + "/articles/", "")
.replace(/\/$/, "");
2025-03-08 18:16:42 +08:00
const publishDate = getArticleDate(articleId);
2025-03-10 21:12:16 +08:00
return {
...item,
priority: 0.8,
lastmod: publishDate,
2025-03-10 21:12:16 +08:00
};
2025-03-08 18:16:42 +08:00
}
// 其他页面
else {
let priority = 0.7; // 默认优先级
2025-03-08 18:16:42 +08:00
// 首页最高优先级
if (item.url === SITE_URL + "/") {
2025-03-08 18:16:42 +08:00
priority = 1.0;
}
// 文章列表页次高优先级
else if (item.url === SITE_URL + "/articles/") {
2025-03-08 18:16:42 +08:00
priority = 0.9;
}
return {
...item,
priority,
2025-03-08 18:16:42 +08:00
};
}
},
}),
2025-03-08 18:16:42 +08:00
],
2025-03-09 14:37:44 +08:00
2025-03-03 21:16:16 +08:00
// Markdown 配置
markdown: {
syntaxHighlight: 'prism',
remarkPlugins: [
2025-03-29 16:09:16 +08:00
[remarkEmoji, { emoticon: false, padded: true }]
2025-03-03 21:16:16 +08:00
],
rehypePlugins: [
[rehypeExternalLinks, { target: '_blank', rel: ['nofollow', 'noopener', 'noreferrer'] }]
],
gfm: true,
// 设置 remark-rehype 选项以控制HTML处理
remarkRehype: {
// 保留原始HTML格式但仅在非代码块区域
allowDangerousHtml: true,
// 确保代码块内容不被解析
passThrough: ['code']
},
2025-03-03 21:16:16 +08:00
shikiConfig: {
theme: "github-dark",
2025-03-03 21:16:16 +08:00
langs: [],
wrap: true,
},
2025-03-09 14:37:44 +08:00
},
adapter: vercel(),
});