2024-07-06 09:46:13 +01:00
|
|
|
import sitemap from "@astrojs/sitemap";
|
|
|
|
import svelte from "@astrojs/svelte";
|
|
|
|
import tailwind from "@astrojs/tailwind";
|
|
|
|
import swup from "@swup/astro";
|
|
|
|
import Compress from "astro-compress";
|
|
|
|
import icon from "astro-icon";
|
|
|
|
import { defineConfig } from "astro/config";
|
|
|
|
import Color from "colorjs.io";
|
|
|
|
import rehypeAutolinkHeadings from "rehype-autolink-headings";
|
2024-07-05 11:46:46 +01:00
|
|
|
import rehypeComponents from "rehype-components"; /* Render the custom directive content */
|
2024-07-06 09:46:13 +01:00
|
|
|
import rehypeKatex from "rehype-katex";
|
|
|
|
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 { AdmonitionComponent } from "./src/plugins/rehype-component-admonition.mjs";
|
|
|
|
import { GithubCardComponent } from "./src/plugins/rehype-component-github-card.mjs";
|
|
|
|
import { parseDirectiveNode } from "./src/plugins/remark-directive-rehype.js";
|
|
|
|
import { remarkReadingTime } from "./src/plugins/remark-reading-time.mjs";
|
2024-07-05 11:46:46 +01:00
|
|
|
|
2024-07-06 09:46:13 +01:00
|
|
|
const oklchToHex = str => {
|
|
|
|
const DEFAULT_HUE = 250;
|
|
|
|
const regex = /-?\d+(\.\d+)?/g;
|
|
|
|
const matches = str.string.match(regex);
|
|
|
|
const lch = [matches[0], matches[1], DEFAULT_HUE];
|
2024-07-05 11:46:46 +01:00
|
|
|
return new Color("oklch", lch).to("srgb").toString({
|
|
|
|
format: "hex",
|
2024-07-06 09:46:13 +01:00
|
|
|
});
|
|
|
|
};
|
2024-07-05 11:46:46 +01:00
|
|
|
|
|
|
|
// https://astro.build/config
|
|
|
|
export default defineConfig({
|
2024-07-06 09:46:13 +01:00
|
|
|
site: "https://blog.devcomp.xyz/",
|
2024-07-05 11:46:46 +01:00
|
|
|
base: "/",
|
|
|
|
trailingSlash: "always",
|
|
|
|
integrations: [
|
|
|
|
tailwind(),
|
|
|
|
swup({
|
|
|
|
theme: false,
|
2024-07-06 09:46:13 +01:00
|
|
|
animationClass: "transition-",
|
|
|
|
containers: ["main"],
|
2024-07-05 11:46:46 +01:00
|
|
|
smoothScrolling: true,
|
|
|
|
cache: true,
|
|
|
|
preload: true,
|
|
|
|
accessibility: true,
|
|
|
|
globalInstance: true,
|
|
|
|
}),
|
|
|
|
icon({
|
|
|
|
include: {
|
|
|
|
"material-symbols": ["*"],
|
|
|
|
"fa6-brands": ["*"],
|
|
|
|
"fa6-regular": ["*"],
|
|
|
|
"fa6-solid": ["*"],
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
Compress({
|
|
|
|
Image: false,
|
|
|
|
}),
|
|
|
|
svelte(),
|
|
|
|
sitemap(),
|
|
|
|
],
|
|
|
|
markdown: {
|
2024-07-06 09:46:13 +01:00
|
|
|
remarkPlugins: [
|
|
|
|
remarkMath,
|
|
|
|
remarkReadingTime,
|
|
|
|
remarkGithubAdmonitionsToDirectives,
|
|
|
|
remarkDirective,
|
|
|
|
parseDirectiveNode,
|
|
|
|
],
|
2024-07-05 11:46:46 +01:00
|
|
|
rehypePlugins: [
|
|
|
|
rehypeKatex,
|
|
|
|
rehypeSlug,
|
2024-07-06 09:46:13 +01:00
|
|
|
[
|
|
|
|
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"),
|
|
|
|
},
|
2024-07-05 11:46:46 +01:00
|
|
|
},
|
2024-07-06 09:46:13 +01:00
|
|
|
],
|
2024-07-05 11:46:46 +01:00
|
|
|
[
|
|
|
|
rehypeAutolinkHeadings,
|
|
|
|
{
|
|
|
|
behavior: "append",
|
|
|
|
properties: {
|
|
|
|
className: ["anchor"],
|
|
|
|
},
|
|
|
|
content: {
|
|
|
|
type: "element",
|
|
|
|
tagName: "span",
|
|
|
|
properties: {
|
|
|
|
className: ["anchor-icon"],
|
2024-07-06 09:46:13 +01:00
|
|
|
"data-pagefind-ignore": true,
|
2024-07-05 11:46:46 +01:00
|
|
|
},
|
|
|
|
children: [
|
|
|
|
{
|
|
|
|
type: "text",
|
|
|
|
value: "#",
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
],
|
|
|
|
},
|
|
|
|
vite: {
|
|
|
|
build: {
|
|
|
|
rollupOptions: {
|
|
|
|
onwarn(warning, warn) {
|
|
|
|
// temporarily suppress this warning
|
2024-07-06 09:46:13 +01:00
|
|
|
if (
|
|
|
|
warning.message.includes("is dynamically imported by") &&
|
|
|
|
warning.message.includes("but also statically imported by")
|
|
|
|
) {
|
2024-07-05 11:46:46 +01:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
warn(warning);
|
2024-07-06 09:46:13 +01:00
|
|
|
},
|
|
|
|
},
|
2024-07-05 11:46:46 +01:00
|
|
|
},
|
|
|
|
css: {
|
|
|
|
preprocessorOptions: {
|
|
|
|
stylus: {
|
|
|
|
define: {
|
|
|
|
oklchToHex: oklchToHex,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2024-07-06 09:46:13 +01:00
|
|
|
});
|