53 lines
1.3 KiB
JavaScript
53 lines
1.3 KiB
JavaScript
/*!
|
|
* reveal.js Mermaid plugin
|
|
*/
|
|
|
|
import mermaid from "mermaid";
|
|
|
|
const Plugin = {
|
|
id: "mermaid",
|
|
|
|
init: function (reveal) {
|
|
|
|
let { ...mermaidConfig } = reveal.getConfig().mermaid || {};
|
|
|
|
mermaid.mermaidAPI.initialize({
|
|
// The node size will be calculated incorrectly if set `startOnLoad: start`,
|
|
// so we need to manually render.
|
|
startOnLoad: false,
|
|
...mermaidConfig,
|
|
});
|
|
|
|
const mermaidEls = reveal.getRevealElement().querySelectorAll(".mermaid");
|
|
|
|
Array.from(mermaidEls).forEach(function (el) {
|
|
var insertSvg = function (svgCode, bindFunctions) {
|
|
el.innerHTML = svgCode;
|
|
};
|
|
|
|
var graphDefinition = el.textContent.trim();
|
|
|
|
try {
|
|
mermaid.mermaidAPI.render(
|
|
`mermaid-${Math.random().toString(36).substring(2)}`,
|
|
graphDefinition,
|
|
insertSvg
|
|
);
|
|
} catch (error) {
|
|
let errorStr = "";
|
|
if (error?.str) {
|
|
// From mermaid 9.1.4, error.message does not exists anymore
|
|
errorStr = error.str;
|
|
}
|
|
if (error?.message) {
|
|
errorStr = error.message;
|
|
}
|
|
console.error(errorStr, { error, graphDefinition, el });
|
|
el.innerHTML = errorStr;
|
|
}
|
|
});
|
|
},
|
|
};
|
|
|
|
export default () => Plugin;
|