diff options
Diffstat (limited to 'static')
-rw-r--r-- | static/js/mermaid.js | 28 | ||||
-rw-r--r-- | static/js/theme-switch.js | 28 |
2 files changed, 56 insertions, 0 deletions
diff --git a/static/js/mermaid.js b/static/js/mermaid.js new file mode 100644 index 0000000..c348dc6 --- /dev/null +++ b/static/js/mermaid.js @@ -0,0 +1,28 @@ +import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid/dist/mermaid.esm.min.mjs'; + +const this_js_script = document.getElementById('mermaid_script'); +const light_theme = this_js_script.getAttribute('data-light-theme'); +const dark_theme = this_js_script.getAttribute('data-dark-theme'); + +function runmermaid() { + const theme = (document.body.classList.contains('dark') ? dark_theme : light_theme) + mermaid.initialize({ startOnLoad: false, theme: theme}); + const items = document.querySelectorAll('.mermaid'); + let counter = 0; + for (const item of items) { + const id = counter++; + if(item.originalCode === undefined) { + item.originalCode = item.textContent.trim(); + } + mermaid.render("mermaid"+id, item.originalCode).then((val) => { + item.innerHTML = val.svg + }, (err) => { + console.log(err); + // Workaround: move incorrectly placed error messages into their diagram + item.innerHTML = ""; + item.appendChild(document.getElementById("mermaid" + id)); + }); + } +} +document.addEventListener('DOMContentLoaded', runmermaid); +window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', runmermaid); diff --git a/static/js/theme-switch.js b/static/js/theme-switch.js new file mode 100644 index 0000000..a617fda --- /dev/null +++ b/static/js/theme-switch.js @@ -0,0 +1,28 @@ +function isAuto() { + return document.body.classList.contains("auto"); +} + +function setTheme() { + if (!isAuto()) { + return + } + + document.body.classList.remove("auto"); + let cls = "light"; + if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) { + cls = "dark"; + } + + document.body.classList.add(cls); +} + +function invertBody() { + document.body.classList.toggle("dark"); + document.body.classList.toggle("light"); +} + +if (isAuto()) { + window.matchMedia('(prefers-color-scheme: dark)').addListener(invertBody); +} + +setTheme(); |