2020-02-11 22:27:34 +00:00
|
|
|
/* global mermaid */
|
|
|
|
|
|
|
|
function mermaidReady() {
|
|
|
|
return typeof mermaid !== 'undefined';
|
|
|
|
}
|
|
|
|
|
|
|
|
function mermaidInit() {
|
|
|
|
// Mermaid's wonderful API has two init methods: init() and initialize().
|
|
|
|
// init() is deprectated but works, and initialize() is recommended but doesn't
|
|
|
|
// work, so let's use init() for now.
|
2020-03-04 01:55:48 +00:00
|
|
|
if (mermaidReady()) {
|
|
|
|
try {
|
|
|
|
mermaid.init();
|
|
|
|
} catch (error) {
|
|
|
|
console.error('Mermaid error', error);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Resetting elements size - see mermaid.ts
|
|
|
|
const elements = document.getElementsByClassName('mermaid');
|
|
|
|
for (const element of elements) {
|
2020-05-09 20:51:01 +05:30
|
|
|
element.style.width = 'fit-content';
|
2020-03-04 01:55:48 +00:00
|
|
|
}
|
|
|
|
}
|
2020-02-11 22:27:34 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
document.addEventListener('joplin-noteDidUpdate', () => {
|
|
|
|
mermaidInit();
|
|
|
|
});
|
|
|
|
|
|
|
|
const initIID_ = setInterval(() => {
|
|
|
|
const isReady = mermaidReady();
|
|
|
|
if (isReady) {
|
|
|
|
clearInterval(initIID_);
|
|
|
|
mermaidInit();
|
|
|
|
}
|
|
|
|
}, 100);
|