Skip to content

Instantly share code, notes, and snippets.

@ryanflorence
Last active February 10, 2023 21:25
Show Gist options
  • Save ryanflorence/fb3fe3209877e7a37700a20251804cca to your computer and use it in GitHub Desktop.
Save ryanflorence/fb3fe3209877e7a37700a20251804cca to your computer and use it in GitHub Desktop.
////////////////////////////////////////////////////////////////////////////////
// Create a directory called "pages" next to
// this file, put markdown files in there, and
// then run:
//
// ```
// $ node build.mjs
// ```
//
// Then deploy the "build" directory somewhere.
//
import path from "path";
import { promises as fs } from "fs";
import shell from "shelljs";
import cheerio from "cheerio";
import remark from "remark";
import html from "remark-html";
import report from "vfile-reporter";
////////////////////////////////////////////////////////////////////////////////
const __dirname = path.resolve();
const pagesDirectory = "pages"
////////////////////////////////////////////////////////////////////////////////
go();
////////////////////////////////////////////////////////////////////////////////
async function go() {
shell.rm("-rf", "build");
shell.mkdir("build");
let pages = await fs.readdir(path.join(__dirname, pagesDirectory));
await Promise.all(
pages.map(async (filename) => {
let page = path.join(__dirname, pagesDirectory, filename);
let body = await createPage(page);
await fs.writeFile(
path.join(__dirname, "build", filename.replace(/\.md$/, ".html")),
body
);
console.log("›", filename);
})
);
console.log("Done!");
}
async function createPage(filePath) {
let markdown = await fs.readFile(filePath);
return new Promise(async (resolve, reject) => {
// add remark plugins here for syntax highlighting, etc.
remark()
.use(html)
.process(String(markdown), async (err, markup) => {
if (err) {
console.error(report(err));
reject(err);
}
let page = getPage(String(markup));
resolve(page);
});
});
}
function getPage(body) {
let $ = cheerio.load(body);
let title = $("h1").text();
return `
<!DOCTYPE html>
<html lang="en">
<head>
<title>${title}</title>
<meta charset="UTF-8"/>
<meta name="viewport" content="width=device-width, initial-scale=1.0"/>
<link rel="stylesheet" href="https://unpkg.com/@exampledev/new.css@1.1.3/new.css" />
<style>body { font-family: "Iowan Old Style", "Apple Garamond", Baskerville, "Times New Roman", "Droid Serif", Times, "Source Serif Pro", serif; }</style>
</head>
<body>
${body}
</body>
</html>
`;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment