mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams, class diagrams, gantt charts and git graphs.
45 lines (36 loc) • 1.09 kB
JavaScript
function decodeHTMLEntities (str) {
if (str && typeof str === 'string') {
// strip script/html tags
var element = document.querySelector('.editor')
str = str.replace(/<script[^>]*>([\S\s]*?)<\/script>/gmi, '')
str = str.replace(/<\/?\w(?:[^"'>]|"[^"]*"|'[^']*')*>/gmi, '')
element.innerHTML = str
str = element.textContent
element.textContent = ''
}
return str
}
var mermaidEditor = {
$: document.querySelector,
textField: '',
submit: '',
graph: '',
init: function () {
document.querySelector('.button').addEventListener('click', function () {
mermaidEditor.update()
})
},
update: function () {
var txt = document.querySelector('.editor').value
txt = txt.replace(/>/g, '>')
txt = txt.replace(/</g, '<')
txt = decodeHTMLEntities(txt).trim()
document.querySelector('.mermaid').innerHTML = txt
global.mermaid.init()
document.querySelector('.editor').value = txt
}
}
document.addEventListener('DOMContentLoaded', function () {
mermaidEditor.init()
}, false)
exports = mermaidEditor