2023-05-30 08:02:20 -07:00
|
|
|
import remarkMath from "remark-math"
|
2023-07-22 17:27:41 -07:00
|
|
|
import rehypeKatex from "rehype-katex"
|
2023-12-18 09:48:40 -08:00
|
|
|
import rehypeMathjax from "rehype-mathjax/svg"
|
2023-05-30 08:02:20 -07:00
|
|
|
import { QuartzTransformerPlugin } from "../types"
|
|
|
|
|
2023-07-09 19:32:24 -07:00
|
|
|
interface Options {
|
2023-07-22 17:27:41 -07:00
|
|
|
renderEngine: "katex" | "mathjax"
|
2023-07-09 19:32:24 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
export const Latex: QuartzTransformerPlugin<Options> = (opts?: Options) => {
|
2023-07-22 17:27:41 -07:00
|
|
|
const engine = opts?.renderEngine ?? "katex"
|
2023-07-09 19:32:24 -07:00
|
|
|
return {
|
|
|
|
name: "Latex",
|
|
|
|
markdownPlugins() {
|
|
|
|
return [remarkMath]
|
|
|
|
},
|
|
|
|
htmlPlugins() {
|
2023-08-10 21:16:07 -07:00
|
|
|
if (engine === "katex") {
|
|
|
|
return [[rehypeKatex, { output: "html" }]]
|
|
|
|
} else {
|
|
|
|
return [rehypeMathjax]
|
|
|
|
}
|
2023-07-09 19:32:24 -07:00
|
|
|
},
|
|
|
|
externalResources() {
|
2023-08-10 21:16:07 -07:00
|
|
|
if (engine === "katex") {
|
|
|
|
return {
|
|
|
|
css: [
|
|
|
|
// base css
|
2024-02-18 20:26:04 -08:00
|
|
|
"https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.9/katex.min.css",
|
2023-08-10 21:16:07 -07:00
|
|
|
],
|
|
|
|
js: [
|
|
|
|
{
|
|
|
|
// fix copy behaviour: https://github.com/KaTeX/KaTeX/blob/main/contrib/copy-tex/README.md
|
2024-02-18 20:26:04 -08:00
|
|
|
src: "https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.16.9/contrib/copy-tex.min.js",
|
2023-08-10 21:16:07 -07:00
|
|
|
loadTime: "afterDOMReady",
|
|
|
|
contentType: "external",
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return {}
|
|
|
|
}
|
2023-07-22 17:27:41 -07:00
|
|
|
},
|
2023-05-30 08:02:20 -07:00
|
|
|
}
|
2023-07-09 19:32:24 -07:00
|
|
|
}
|