2019-07-12 20:40:54 +02:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
|
|
|
<meta charset="UTF-8">
|
|
|
|
<title>mermaid - Markdownish syntax for generating flowcharts, sequence diagrams, class diagrams, gantt charts and git graphs.</title>
|
|
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
|
|
|
|
<meta name="description" content="Markdownish syntax for generating flowcharts, sequence diagrams, class diagrams, gantt charts and git graphs.">
|
|
|
|
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
|
2020-06-24 21:26:55 +02:00
|
|
|
<!-- <link rel="stylesheet" href="//unpkg.com/docsify/lib/themes/vue.css"> -->
|
2021-09-18 08:03:34 +02:00
|
|
|
<link rel="stylesheet" href="theme.css">
|
2021-09-23 19:01:53 +02:00
|
|
|
<script src="//cdn.jsdelivr.net/npm/mermaid@8.13.0/dist/mermaid.min.js"></script>
|
|
|
|
<!-- <script src="http://localhost:9000/mermaid.js"></script> -->
|
2019-11-27 20:08:54 +01:00
|
|
|
<script>
|
|
|
|
(function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
|
|
|
|
(i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
|
|
|
|
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
|
|
|
|
})(window,document,'script','https://www.google-analytics.com/analytics.js','ga');
|
|
|
|
|
|
|
|
ga('create', 'UA-153180559-1', 'auto');
|
|
|
|
if(location) {
|
|
|
|
ga('send', 'pageview', location.hash);
|
|
|
|
}
|
|
|
|
|
|
|
|
</script>
|
2021-10-31 14:45:41 -07:00
|
|
|
<script>var require = { paths: { 'vs': 'https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.29.1/min/vs' } }</script>
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.29.1/min/vs/loader.min.js"></script>
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.29.1/min/vs/editor/editor.main.nls.js"></script>
|
|
|
|
<script src="https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.29.1/min/vs/editor/editor.main.js"></script>
|
|
|
|
<script>exports = {};</script>
|
|
|
|
<script src="https://unpkg.com/monaco-mermaid/browser.js"></script>
|
2019-11-27 20:08:54 +01:00
|
|
|
|
2019-07-12 20:40:54 +02:00
|
|
|
<style>
|
|
|
|
.markdown-section {
|
|
|
|
max-width: 1200px;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<div id="app"></div>
|
|
|
|
<script>
|
2021-11-01 18:00:39 -07:00
|
|
|
var initEditor = exports.default;
|
|
|
|
var parser = new DOMParser();
|
2021-10-31 14:45:41 -07:00
|
|
|
var currentCodeExample = 0;
|
|
|
|
var colorize = [];
|
|
|
|
|
2021-11-01 18:00:39 -07:00
|
|
|
function colorizeEverything(html) {
|
|
|
|
initEditor(monaco)
|
|
|
|
return new Promise((resolve, reject) => {
|
2021-11-01 19:33:01 -07:00
|
|
|
monaco.editor.setTheme('mermaid')
|
2021-11-01 18:00:39 -07:00
|
|
|
var parsed = parser.parseFromString(html, 'text/html').body
|
2021-11-01 19:33:01 -07:00
|
|
|
Promise.all([...parsed.querySelectorAll('pre[id*="code"]')].map(codeBlock => monaco.editor.colorize(codeBlock.innerText, 'mermaid'))).then(result => {
|
2021-11-01 18:00:39 -07:00
|
|
|
parsed.querySelectorAll('pre[id*="code"]').forEach((codeBlock, index) => codeBlock.innerHTML = result[index])
|
|
|
|
resolve(parsed.innerHTML)
|
|
|
|
})
|
2021-10-31 14:45:41 -07:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-11-25 12:43:16 -08:00
|
|
|
function escapeHTML(html) {
|
|
|
|
return html.replaceAll('&', '&').replaceAll('<', '<').replaceAll('>', '>').replaceAll('"', '"').replaceAll('\'', ''')
|
|
|
|
}
|
|
|
|
|
2019-07-12 20:40:54 +02:00
|
|
|
window.$docsify = {
|
|
|
|
search: 'auto',
|
|
|
|
name: 'mermaid',
|
2020-11-15 10:27:08 +08:00
|
|
|
repo: 'https://github.com/mermaid-js/mermaid',
|
2019-07-12 20:40:54 +02:00
|
|
|
loadSidebar: true,
|
|
|
|
mergeNavbar: true,
|
|
|
|
maxLevel: 4,
|
|
|
|
subMaxLevel: 2,
|
|
|
|
markdown: {
|
2019-07-17 18:14:22 +02:00
|
|
|
renderer: {
|
|
|
|
code: function(code, lang) {
|
2021-11-10 18:04:40 -08:00
|
|
|
if (lang.startsWith('mermaid') || lang === 'mmd') {
|
2021-11-01 20:18:18 -07:00
|
|
|
var resultingHTML = '';
|
|
|
|
|
2021-11-10 18:04:40 -08:00
|
|
|
if (lang === "mmd" || lang === 'mermaid-example') {
|
2021-11-01 20:18:18 -07:00
|
|
|
currentCodeExample++;
|
|
|
|
colorize.push(currentCodeExample);
|
|
|
|
resultingHTML += (
|
2021-11-25 12:43:16 -08:00
|
|
|
'<pre id="code' + currentCodeExample + '">' + escapeHTML(code) + '</pre>'
|
2021-11-01 20:18:18 -07:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
if (lang === 'mermaid' || lang === 'mermaid-example') {
|
|
|
|
resultingHTML += (
|
|
|
|
'<div class="mermaid">' + mermaid.render('mermaid-svg-' + num++, code) + "</div>"
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (resultingHTML !== '') {
|
|
|
|
return resultingHTML;
|
|
|
|
}
|
2019-07-17 18:14:22 +02:00
|
|
|
}
|
|
|
|
return this.origin.code.apply(this, arguments);
|
|
|
|
}
|
2019-07-12 20:40:54 +02:00
|
|
|
}
|
2020-11-15 10:27:08 +08:00
|
|
|
},
|
|
|
|
plugins: [
|
|
|
|
function (hook, vm) {
|
|
|
|
hook.beforeEach(function (html) {
|
|
|
|
url = 'https://github.com/mermaid-js/mermaid/blob/develop/docs/' + vm.route.file
|
|
|
|
var editHtml = '[:memo: Edit this Page](' + url + ')\n'
|
|
|
|
return editHtml + html
|
|
|
|
})
|
2021-10-31 14:45:41 -07:00
|
|
|
|
2021-11-01 18:00:39 -07:00
|
|
|
hook.afterEach(function (html, next) {
|
2021-11-25 12:43:16 -08:00
|
|
|
next(html);
|
2021-11-01 18:00:39 -07:00
|
|
|
(async() => {
|
|
|
|
while (!window.hasOwnProperty("monaco"))
|
|
|
|
await new Promise(resolve => setTimeout(resolve, 1000));
|
2021-11-25 12:43:16 -08:00
|
|
|
colorizeEverything(html).then(newHTML => document.querySelector('article.markdown-section').innerHTML = newHTML)
|
2021-11-01 18:00:39 -07:00
|
|
|
})();
|
2021-10-31 14:45:41 -07:00
|
|
|
})
|
2020-11-15 10:27:08 +08:00
|
|
|
}
|
|
|
|
]
|
2019-07-12 20:40:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
var num = 0;
|
2020-06-24 21:26:55 +02:00
|
|
|
const isDarkMode = window.matchMedia("(prefers-color-scheme: dark)").matches
|
|
|
|
|
2020-06-24 21:28:12 +02:00
|
|
|
const conf = { logLevel:4, startOnLoad: false, themeCSS:'.label { font-family: Source Sans Pro,Helvetica Neue,Arial,sans-serif; }' };
|
2020-07-22 19:22:02 +02:00
|
|
|
if(isDarkMode && false) conf.theme = 'dark';
|
2020-06-24 21:26:55 +02:00
|
|
|
mermaid.initialize(conf);
|
2019-07-12 20:40:54 +02:00
|
|
|
|
2019-11-27 20:08:54 +01:00
|
|
|
</script>
|
|
|
|
<script>
|
|
|
|
window.onhashchange = function(a) {
|
|
|
|
//code
|
|
|
|
if(location) {
|
|
|
|
ga('send', 'pageview', location.hash);
|
|
|
|
}
|
|
|
|
}
|
2019-07-12 20:40:54 +02:00
|
|
|
</script>
|
2020-11-15 10:27:08 +08:00
|
|
|
<script src="//cdn.jsdelivr.net/npm/docsify/lib/docsify.min.js"></script>
|
|
|
|
<script src="//cdn.jsdelivr.net/npm/docsify/lib/plugins/search.min.js"></script>
|
|
|
|
<script src="//cdn.jsdelivr.net/npm/docsify/lib/plugins/ga.min.js"></script>
|
2019-07-12 20:40:54 +02:00
|
|
|
</body>
|
|
|
|
</html>
|
2020-05-17 10:29:55 +02:00
|
|
|
<!-- -->
|
2020-10-25 00:30:20 -07:00
|
|
|
|
|
|
|
</html>
|