27 lines
854 B
TypeScript
Raw Normal View History

2021-09-11 17:43:07 +08:00
// Reference: https://github.com/mermaid-js/mermaid
import { PluginSimple } from "markdown-it/lib";
import { hash } from "@vuepress/utils";
const MermaidPlugin: PluginSimple = function (md) {
const fence = md.renderer.rules.fence;
md.renderer.rules.fence = (...args) => {
const [tokens, idx] = args;
const { info } = tokens[idx];
2021-09-11 18:37:02 +08:00
if (info.trim() === "mermaid") {
2021-09-11 17:43:07 +08:00
const token = tokens[idx];
const key = `mermaid_${hash(idx)}`;
let { content } = token;
content = content.replaceAll(";\n", ";");
content = content.replaceAll("\n\n", ";");
content = content.replaceAll("\n", ";");
2021-09-11 18:37:02 +08:00
content = content.replaceAll('"', "'");
2021-09-11 17:43:07 +08:00
return `<Mermaid identifier="${key}" graph="${content}"></Mermaid>`;
}
const rawCode = fence(...args);
return `${rawCode}`;
};
};
export { MermaidPlugin };