/** * Web page integration module for the mermaid framework. It uses the mermaidAPI for mermaid functionality and to render * the diagrams to svg code. */ var he = require('he'); var mermaidAPI = require('./mermaidAPI'); var nextId = 0; var log = require('./logger').create(); module.exports.mermaidAPI = mermaidAPI; /** * ## init * Function that goes through the document to find the chart definitions in there and render them. * * The function tags the processed attributes with the attribute data-processed and ignores found elements with the * attribute already set. This way the init function can be triggered several times. * * Optionally, `init` can accept in the second argument one of the following: * - a DOM Node * - an array of DOM nodes (as would come from a jQuery selector) * - a W3C selector, a la `.mermaid` * * ```mermaid * graph LR; * a(Find elements)-->b{Processed} * b-->|Yes|c(Leave element) * b-->|No |d(Transform) * ``` * Renders the mermaid diagrams * @param nodes a css selector or an array of nodes */ var init = function () { log.debug('Starting rendering diagrams'); var nodes; if(arguments.length >= 2){ /*! sequence config was passed as #1 */ if(typeof arguments[0] !== 'undefined'){ mermaid.sequenceConfig = arguments[0]; } nodes = arguments[1]; } else{ nodes = arguments[0]; } // if last argument is a function this is the callback function var callback; if(typeof arguments[arguments.length-1] === 'function'){ callback = arguments[arguments.length-1]; log.debug('Callback function found'); }else{ if(typeof mermaidAPI.getConfig().mermaid.callback === 'function'){ callback = mermaidAPI.getConfig().mermaid.callback; log.debug('Callback function found'); }else{ log.debug('No Callback function found'); } } nodes = nodes === undefined ? document.querySelectorAll('.mermaid') : typeof nodes === "string" ? document.querySelectorAll(nodes) : nodes instanceof Node ? [nodes] /*! Last case - sequence config was passed pick next */ : nodes; var i; if(typeof mermaid_config !== 'undefined'){ mermaidAPI.initialize(mermaid_config); } log.debug('Start On Load before: '+mermaid.startOnLoad); if(typeof mermaid.startOnLoad !== 'undefined'){ log.debug('Start On Load inner: '+mermaid.startOnLoad); mermaidAPI.initialize({startOnLoad:mermaid.startOnLoad}); } if(typeof mermaid.ganttConfig !== 'undefined'){ mermaidAPI.initialize({gantt:mermaid.ganttConfig}); } var insertSvg = function(svgCode){ element.innerHTML = svgCode; if(typeof callback !== 'undefined'){ callback(id); } }; for (i = 0; i < nodes.length; i++) { var element = nodes[i]; /*! Check if previously processed */ if(!element.getAttribute("data-processed")) { element.setAttribute("data-processed", true); } else { continue; } var id = 'mermaidChart' + nextId++; var txt = element.innerHTML; txt = txt.replace(/>/g,'>'); txt = txt.replace(/