91 lines
2.9 KiB
TypeScript

import { Renderer } from "@libs/markdown";
import HighlightPlugin from "@libs/markdown/plugins/highlighting";
import { walk } from "@std/fs";
import * as pathTools from "@std/path";
function injectIntoTemplate(
name: string,
rendered: string,
dirComponents: [],
fileName: string,
): string {
const breadcrumbs: string[] = [];
for (const component of dirComponents) {
breadcrumbs.push(`<a>${component}</a>`);
}
breadcrumbs.push(`<span>${fileName}</span>`);
let content = [
"<!DOCTYPE html>",
"<html>",
"<head>",
[
`<title>Docs: ${name}</title>`,
'<script src="./headers.js" defer></script>',
'<link rel="shortcut icon" href="/favicon.ico">',
'<meta charset="UTF-8">',
'<meta name="viewport" content="width=device-width, initial-scale=1.0">',
'<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">',
'<meta name="color-scheme" content="dark">',
'<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.11.1/styles/base16/gruvbox-dark-hard.css">',
'<link rel="stylesheet" href="./style.css">',
],
"</head>",
"<body>",
[
`<nav>${breadcrumbs.join("/")}</nav>`,
rendered,
],
"</body>",
"</html>",
];
while (content.some((x) => Array.isArray(x))) {
content = content.flat();
}
return content.join("");
}
async function renderMarkdown() {
const renderer = await Renderer.with({
plugins: [HighlightPlugin],
});
for await (
const entry of walk("src", { exts: [".md"], includeDirs: false })
) {
const parsed = pathTools.parse(entry.path);
const dirComponents = parsed.dir.split(pathTools.SEPARATOR_PATTERN);
dirComponents.shift();
parsed.dir = pathTools.join("-", ...dirComponents);
parsed.ext = ".html";
parsed.base = `${parsed.name}${parsed.ext}`;
await Deno.mkdir(parsed.dir, { recursive: true });
const content = await renderer.render(await Deno.readTextFile(entry.path));
await Deno.writeTextFile(
pathTools.format(parsed),
injectIntoTemplate(parsed.name, content, dirComponents),
);
}
}
async function copyStaticFiles() {
for await (const entry of walk("static", { includeDirs: false })) {
const parsed = pathTools.parse(entry.path);
const dirComponents = parsed.dir.split(pathTools.SEPARATOR_PATTERN);
dirComponents.shift();
parsed.dir = pathTools.join("-", ...dirComponents);
await Deno.mkdir(parsed.dir, { recursive: true });
await Deno.copyFile(entry.path, pathTools.format(parsed));
}
}
async function main() {
await renderMarkdown();
await copyStaticFiles();
}
if (import.meta.main) {
main();
}