205 lines
5.9 KiB
JavaScript
205 lines
5.9 KiB
JavaScript
import sitemap from "@astrojs/sitemap";
|
|
import svelte from "@astrojs/svelte";
|
|
import tailwind from "@astrojs/tailwind";
|
|
import { pluginCollapsibleSections } from "@expressive-code/plugin-collapsible-sections";
|
|
import { pluginLineNumbers } from "@expressive-code/plugin-line-numbers";
|
|
import swup from "@swup/astro";
|
|
import { defineConfig } from "astro/config";
|
|
import expressiveCode from "astro-expressive-code";
|
|
import icon from "astro-icon";
|
|
import rehypeAutolinkHeadings from "rehype-autolink-headings";
|
|
import rehypeComponents from "rehype-components"; /* Render the custom directive content */
|
|
import rehypeKatex from "rehype-katex";
|
|
import katex from "katex";
|
|
import "katex/dist/contrib/mhchem.mjs"; // 加载 mhchem 扩展
|
|
import rehypeSlug from "rehype-slug";
|
|
import remarkDirective from "remark-directive"; /* Handle directives */
|
|
import remarkGithubAdmonitionsToDirectives from "remark-github-admonitions-to-directives";
|
|
import remarkMath from "remark-math";
|
|
import remarkSectionize from "remark-sectionize";
|
|
import { expressiveCodeConfig, siteConfig } from "./src/config";
|
|
import { pluginCustomCopyButton } from "./src/plugins/expressive-code/custom-copy-button.js";
|
|
import { pluginLanguageBadge } from "./src/plugins/expressive-code/language-badge.ts";
|
|
import { AdmonitionComponent } from "./src/plugins/rehype-component-admonition.mjs";
|
|
import { GithubCardComponent } from "./src/plugins/rehype-component-github-card.mjs";
|
|
import { rehypeMermaid } from "./src/plugins/rehype-mermaid.mjs";
|
|
import { parseDirectiveNode } from "./src/plugins/remark-directive-rehype.js";
|
|
import { remarkExcerpt } from "./src/plugins/remark-excerpt.js";
|
|
import { remarkMermaid } from "./src/plugins/remark-mermaid.js";
|
|
import { remarkReadingTime } from "./src/plugins/remark-reading-time.mjs";
|
|
import mdx from "@astrojs/mdx";
|
|
import searchIndexer from "./src/integrations/searchIndex.mts";
|
|
import rehypeEmailProtection from "./src/plugins/rehype-email-protection.mjs";
|
|
import rehypeFigure from "./src/plugins/rehype-figure.mjs";
|
|
|
|
// https://astro.build/config
|
|
export default defineConfig({
|
|
site: siteConfig.site_url,
|
|
|
|
base: "/",
|
|
trailingSlash: "always",
|
|
integrations: [
|
|
tailwind({
|
|
nesting: true,
|
|
}),
|
|
swup({
|
|
theme: false,
|
|
animationClass: "transition-swup-", // see https://swup.js.org/options/#animationselector
|
|
// the default value `transition-` cause transition delay
|
|
// when the Tailwind class `transition-all` is used
|
|
containers: ["main", "#right-sidebar-dynamic", "#floating-toc-wrapper"],
|
|
smoothScrolling: false,
|
|
cache: true,
|
|
preload: true,
|
|
accessibility: true,
|
|
updateHead: true,
|
|
updateBodyClass: false,
|
|
globalInstance: true,
|
|
// 滚动相关配置优化
|
|
resolveUrl: (url) => url,
|
|
animateHistoryBrowsing: false,
|
|
skipPopStateHandling: (event) => {
|
|
// 跳过锚点链接的处理,让浏览器原生处理
|
|
return event.state && event.state.url && event.state.url.includes("#");
|
|
},
|
|
}),
|
|
icon({
|
|
include: {
|
|
"preprocess: vitePreprocess(),": ["*"],
|
|
"fa6-brands": ["*"],
|
|
"fa6-regular": ["*"],
|
|
"fa6-solid": ["*"],
|
|
mdi: ["*"],
|
|
},
|
|
}),
|
|
expressiveCode({
|
|
themes: [expressiveCodeConfig.darkTheme, expressiveCodeConfig.lightTheme],
|
|
useDarkModeMediaQuery: false,
|
|
themeCssSelector: (theme) => `[data-theme='${theme.name}']`,
|
|
plugins: [
|
|
pluginCollapsibleSections(),
|
|
pluginLineNumbers(),
|
|
// pluginLanguageBadge(),
|
|
pluginCustomCopyButton(),
|
|
],
|
|
defaultProps: {
|
|
wrap: false,
|
|
overridesByLang: {
|
|
shellsession: {
|
|
showLineNumbers: false,
|
|
},
|
|
},
|
|
},
|
|
styleOverrides: {
|
|
borderRadius: "0.75rem",
|
|
codeFontSize: "0.875rem",
|
|
codeFontFamily:
|
|
"'JetBrains Mono Variable', ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace",
|
|
codeLineHeight: "1.5rem",
|
|
frames: {},
|
|
textMarkers: {
|
|
delHue: 0,
|
|
insHue: 180,
|
|
markHue: 250,
|
|
},
|
|
},
|
|
frames: {
|
|
showCopyToClipboardButton: false,
|
|
},
|
|
}),
|
|
svelte(),
|
|
sitemap({
|
|
filter: (page) => {
|
|
// 根据页面开关配置过滤sitemap
|
|
const url = new URL(page);
|
|
const pathname = url.pathname;
|
|
|
|
if (pathname === "/sponsor/" && !siteConfig.pages.sponsor) {
|
|
return false;
|
|
}
|
|
if (pathname === "/guestbook/" && !siteConfig.pages.guestbook) {
|
|
return false;
|
|
}
|
|
if (pathname === "/bangumi/" && !siteConfig.pages.bangumi) {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
},
|
|
}),
|
|
searchIndexer(),
|
|
mdx(),
|
|
],
|
|
markdown: {
|
|
remarkPlugins: [
|
|
remarkMath,
|
|
remarkReadingTime,
|
|
remarkExcerpt,
|
|
remarkGithubAdmonitionsToDirectives,
|
|
remarkDirective,
|
|
remarkSectionize,
|
|
parseDirectiveNode,
|
|
remarkMermaid,
|
|
],
|
|
rehypePlugins: [
|
|
[rehypeKatex, { katex }],
|
|
rehypeSlug,
|
|
rehypeMermaid,
|
|
rehypeFigure,
|
|
[rehypeEmailProtection, { method: "base64" }], // 邮箱保护插件,支持 'base64' 或 'rot13'
|
|
[
|
|
rehypeComponents,
|
|
{
|
|
components: {
|
|
github: GithubCardComponent,
|
|
note: (x, y) => AdmonitionComponent(x, y, "note"),
|
|
tip: (x, y) => AdmonitionComponent(x, y, "tip"),
|
|
important: (x, y) => AdmonitionComponent(x, y, "important"),
|
|
caution: (x, y) => AdmonitionComponent(x, y, "caution"),
|
|
warning: (x, y) => AdmonitionComponent(x, y, "warning"),
|
|
},
|
|
},
|
|
],
|
|
[
|
|
rehypeAutolinkHeadings,
|
|
{
|
|
behavior: "append",
|
|
properties: {
|
|
className: ["anchor"],
|
|
},
|
|
content: {
|
|
type: "element",
|
|
tagName: "span",
|
|
properties: {
|
|
className: ["anchor-icon"],
|
|
"data-pagefind-ignore": true,
|
|
},
|
|
children: [
|
|
{
|
|
type: "text",
|
|
value: "#",
|
|
},
|
|
],
|
|
},
|
|
},
|
|
],
|
|
],
|
|
},
|
|
vite: {
|
|
build: {
|
|
rollupOptions: {
|
|
onwarn(warning, warn) {
|
|
// temporarily suppress this warning
|
|
if (
|
|
warning.message.includes("is dynamically imported by") &&
|
|
warning.message.includes("but also statically imported by")
|
|
) {
|
|
return;
|
|
}
|
|
warn(warning);
|
|
},
|
|
},
|
|
},
|
|
},
|
|
});
|