mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.
549 lines (482 loc) • 34.8 kB
HTML
<html>
<head>
<title>mermaid.js</title>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link rel="stylesheet" media="all" href="../doc-style.css" />
<script src="../doc-filelist.js"></script>
<script>
var relativeDir = "../", thisFile = "Users/knut/Documents/source/mermaid/src/mermaid.js", defaultSidebar = true;
</script>
<script src="../doc-script.js"></script>
<script src="../mermaid.js"></script>
<link rel="stylesheet" href="../mermaid.css" />
</head>
<body>
<div id="sidebar_wrapper">
<div id="sidebar_switch">
<span class="tree">Files</span>
<span class="headings">Headings</span>
</div>
<div id="tree"></div>
<div id="headings">
<div class="heading h1">
<a href="#mermaid.js">mermaid.js</a>
</div>
<div class="heading h2">
<a href="#init">init</a>
</div>
<div class="heading h2">
<a href="#version">version</a>
</div>
<div class="heading h2">
<a href="#initialize">initialize</a>
</div>
<div class="heading h2">
<a href="#parseError">parseError</a>
</div>
<div class="heading h2">
<a href="#contentLoaded">contentLoaded</a>
</div>
</div>
</div>
<div id="sidebar-toggle"></div>
<div id="container"><div class="background highlight"></div>
<table cellpadding="0" cellspacing="0">
<tbody>
<tr>
<td class="docs">
<div class="pilwrap" id="mermaid.js">
<h1>
<a href="#mermaid.js" name="mermaid.js" class="pilcrow">¶</a>mermaid.js
</h1>
</div>
</td>
<td class="code highlight"></td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-1" id="section-1">¶</a>
</div>
<p>(function (root, factory) {
if (typeof exports === 'object') {
// CommonJS
module.exports = factory(require('b'));
} else if (typeof define === 'function' && define.amd) {
// AMD
define(['b'], function (b) {
return (root.returnExportsGlobal = factory(b));
});
} else {
// Global Variables
root.returnExportsGlobal = factory(root.b);
}
}(this, function (b) {</p>
<div class="dox">
<div class="summary"><p>Web page integration module for the mermaid framework. It uses the mermaidAPI for mermaid functionality and to render
the diagrams to svg code.</p>
</div>
<div class="body">
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre><span class="kd">var</span> <span class="nx">mermaidAPI</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./mermaidAPI'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">nextId</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">log</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./logger'</span><span class="p">).</span><span class="nx">create</span><span class="p">();</span>
<span class="nx">module</span><span class="p">.</span><span class="nx">exports</span><span class="p">.</span><span class="nx">mermaidAPI</span> <span class="o">=</span> <span class="nx">mermaidAPI</span><span class="p">;</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs"><div class="dox">
<div class="summary"><div class="pilwrap" id="init">
<h2>
<a href="#init" name="init" class="pilcrow">¶</a>
init</h2>
</div>
<p>Function that goes through the document to find the chart definitions in there and render them.</p>
</div>
<div class="body"><p>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.</p>
<p>Optionally, <code>init</code> can accept in the second argument one of the following:</p>
<ul>
<li>a DOM Node</li>
<li>an array of DOM nodes (as would come from a jQuery selector)</li>
<li>a W3C selector, a la <code>.mermaid</code></li>
</ul>
<script>mermaid.initialize({startOnLoad:true});</script><div class="mermaid">graph LR;
a(Find elements)-->b{Processed}
b-->|Yes|c(Leave element)
b-->|No |d(Transform)</div><p>Renders the mermaid diagrams</p>
</div>
<div class="details">
<div class="dox_tag_title">Params</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">nodes</span>
<span>a css selector or an array of nodes
</span>
</div>
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">init</span> <span class="o">=</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'Starting rendering diagrams'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">nodes</span><span class="p">;</span>
<span class="k">if</span><span class="p">(</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span> <span class="o">>=</span> <span class="mi">2</span><span class="p">){</span>
<span class="cm">/*! sequence config was passed as #1 */</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">arguments</span><span class="p">[</span><span class="mi">0</span><span class="p">]</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">mermaid</span><span class="p">.</span><span class="nx">sequenceConfig</span> <span class="o">=</span> <span class="nx">arguments</span><span class="p">[</span><span class="mi">0</span><span class="p">];</span>
<span class="p">}</span>
<span class="nx">nodes</span> <span class="o">=</span> <span class="nx">arguments</span><span class="p">[</span><span class="mi">1</span><span class="p">];</span>
<span class="p">}</span>
<span class="k">else</span><span class="p">{</span>
<span class="nx">nodes</span> <span class="o">=</span> <span class="nx">arguments</span><span class="p">[</span><span class="mi">0</span><span class="p">];</span>
<span class="p">}</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-3" id="section-3">¶</a>
</div>
<p>if last argument is a function this is the callback function</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">callback</span><span class="p">;</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">arguments</span><span class="p">[</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span><span class="o">-</span><span class="mi">1</span><span class="p">]</span> <span class="o">===</span> <span class="s1">'function'</span><span class="p">){</span>
<span class="nx">callback</span> <span class="o">=</span> <span class="nx">arguments</span><span class="p">[</span><span class="nx">arguments</span><span class="p">.</span><span class="nx">length</span><span class="o">-</span><span class="mi">1</span><span class="p">];</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'Callback function found'</span><span class="p">);</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="kd">var</span> <span class="nx">conf</span><span class="o">=</span> <span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">getConfig</span><span class="p">();</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">mermaid</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">callback</span> <span class="o">===</span> <span class="s1">'function'</span><span class="p">){</span>
<span class="nx">callback</span> <span class="o">=</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">callback</span><span class="p">;</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'Callback function found'</span><span class="p">);</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'No Callback function found'</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="nx">nodes</span> <span class="o">=</span> <span class="nx">nodes</span> <span class="o">===</span> <span class="kc">undefined</span> <span class="o">?</span> <span class="nb">document</span><span class="p">.</span><span class="nx">querySelectorAll</span><span class="p">(</span><span class="s1">'.mermaid'</span><span class="p">)</span>
<span class="o">:</span> <span class="k">typeof</span> <span class="nx">nodes</span> <span class="o">===</span> <span class="s2">"string"</span> <span class="o">?</span> <span class="nb">document</span><span class="p">.</span><span class="nx">querySelectorAll</span><span class="p">(</span><span class="nx">nodes</span><span class="p">)</span>
<span class="o">:</span> <span class="nx">nodes</span> <span class="k">instanceof</span> <span class="nx">Node</span> <span class="o">?</span> <span class="p">[</span><span class="nx">nodes</span><span class="p">]</span>
<span class="cm">/*! Last case - sequence config was passed pick next */</span>
<span class="o">:</span> <span class="nx">nodes</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">i</span><span class="p">;</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">mermaid_config</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">initialize</span><span class="p">(</span><span class="nx">mermaid_config</span><span class="p">);</span>
<span class="p">}</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'Start On Load before: '</span><span class="o">+</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">);</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'Start On Load inner: '</span><span class="o">+</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">);</span>
<span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">initialize</span><span class="p">({</span><span class="nx">startOnLoad</span><span class="o">:</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">});</span>
<span class="p">}</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">mermaid</span><span class="p">.</span><span class="nx">ganttConfig</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">initialize</span><span class="p">({</span><span class="nx">gantt</span><span class="o">:</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">ganttConfig</span><span class="p">});</span>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">insertSvg</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">svgCode</span><span class="p">){</span>
<span class="nx">element</span><span class="p">.</span><span class="nx">innerHTML</span> <span class="o">=</span> <span class="nx">svgCode</span><span class="p">;</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">callback</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">callback</span><span class="p">(</span><span class="nx">id</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="k">for</span> <span class="p">(</span><span class="nx">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="nx">i</span> <span class="o"><</span> <span class="nx">nodes</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="nx">i</span><span class="o">++</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">element</span> <span class="o">=</span> <span class="nx">nodes</span><span class="p">[</span><span class="nx">i</span><span class="p">];</span>
<span class="cm">/*! Check if previously processed */</span>
<span class="k">if</span><span class="p">(</span><span class="o">!</span><span class="nx">element</span><span class="p">.</span><span class="nx">getAttribute</span><span class="p">(</span><span class="s2">"data-processed"</span><span class="p">))</span> <span class="p">{</span>
<span class="nx">element</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s2">"data-processed"</span><span class="p">,</span> <span class="kc">true</span><span class="p">);</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">continue</span><span class="p">;</span>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">id</span> <span class="o">=</span> <span class="s1">'mermaidChart'</span> <span class="o">+</span> <span class="nx">nextId</span><span class="o">++</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">he</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'he'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">txt</span> <span class="o">=</span> <span class="nx">element</span><span class="p">.</span><span class="nx">innerHTML</span><span class="p">;</span>
<span class="nx">txt</span> <span class="o">=</span> <span class="nx">txt</span><span class="p">.</span><span class="nx">replace</span><span class="p">(</span><span class="sr">/>/g</span><span class="p">,</span><span class="s1">'&gt;'</span><span class="p">);</span>
<span class="nx">txt</span> <span class="o">=</span> <span class="nx">txt</span><span class="p">.</span><span class="nx">replace</span><span class="p">(</span><span class="sr">/</g</span><span class="p">,</span><span class="s1">'&lt;'</span><span class="p">);</span>
<span class="nx">txt</span> <span class="o">=</span> <span class="nx">he</span><span class="p">.</span><span class="nx">decode</span><span class="p">(</span><span class="nx">txt</span><span class="p">).</span><span class="nx">trim</span><span class="p">();</span>
<span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">render</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span><span class="nx">txt</span><span class="p">,</span><span class="nx">insertSvg</span><span class="p">,</span> <span class="nx">element</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">init</span> <span class="o">=</span> <span class="nx">init</span><span class="p">;</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">parse</span> <span class="o">=</span> <span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">parse</span><span class="p">;</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs"><div class="dox">
<div class="summary"><div class="pilwrap" id="version">
<h2>
<a href="#version" name="version" class="pilcrow">¶</a>
version</h2>
</div>
<p>Function returning version information</p>
</div>
<div class="body">
</div>
<div class="details">
<div class="dox_tag_title">Returns</div>
<div class="dox_tag_detail">
<span class="dox_tag_name"></span>
<span class="dox_type">string</span>
<span>A string containing the version info
</span>
</div>
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">exports</span><span class="p">.</span><span class="nx">version</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(){</span>
<span class="k">return</span> <span class="s1">'v'</span><span class="o">+</span><span class="nx">require</span><span class="p">(</span><span class="s1">'../package.json'</span><span class="p">).</span><span class="nx">version</span><span class="p">;</span>
<span class="p">};</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs"><div class="dox">
<div class="summary"><div class="pilwrap" id="initialize">
<h2>
<a href="#initialize" name="initialize" class="pilcrow">¶</a>
initialize</h2>
</div>
<p>This function overrides the default configuration.</p>
</div>
<div class="body">
</div>
<div class="details">
<div class="dox_tag_title">Params</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">config
</span>
</div>
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">exports</span><span class="p">.</span><span class="nx">initialize</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">config</span><span class="p">){</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'Initializing mermaid'</span><span class="p">);</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">config</span><span class="p">.</span><span class="nx">mermaid</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">config</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span> <span class="o">=</span> <span class="nx">config</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">config</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">htmlLabels</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">htmlLabels</span> <span class="o">=</span> <span class="nx">config</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">htmlLabels</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">initialize</span><span class="p">(</span><span class="nx">config</span><span class="p">);</span>
<span class="p">};</span>
<span class="kd">var</span> <span class="nx">equals</span> <span class="o">=</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">val</span><span class="p">,</span> <span class="nx">variable</span><span class="p">){</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">variable</span> <span class="o">===</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="k">return</span> <span class="kc">false</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">else</span><span class="p">{</span>
<span class="k">return</span> <span class="p">(</span><span class="nx">val</span> <span class="o">===</span> <span class="nx">variable</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">};</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-6" id="section-6">¶</a>
</div>
<div class="dox">
<div class="summary"><p>Global mermaid object. Contains the functions:</p>
<ul>
<li>init</li>
<li>initialize</li>
<li>version</li>
<li>parse</li>
<li>parseError</li>
<li>render</li>
</ul>
</div>
<div class="body">
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">startOnLoad</span><span class="o">:</span> <span class="kc">true</span><span class="p">,</span>
<span class="nx">htmlLabels</span><span class="o">:</span> <span class="kc">true</span><span class="p">,</span>
<span class="nx">init</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">sequenceConfig</span><span class="p">,</span> <span class="nx">nodes</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">init</span><span class="p">.</span><span class="nx">apply</span><span class="p">(</span><span class="kc">null</span><span class="p">,</span> <span class="nx">arguments</span><span class="p">);</span>
<span class="p">},</span>
<span class="nx">initialize</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">config</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">initialize</span><span class="p">(</span><span class="nx">config</span><span class="p">);</span>
<span class="p">},</span>
<span class="nx">version</span><span class="o">:</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">version</span><span class="p">();</span>
<span class="p">},</span>
<span class="nx">parse</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">text</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="nx">text</span><span class="p">);</span>
<span class="p">},</span>
<span class="nx">parseError</span><span class="o">:</span> <span class="kd">function</span><span class="p">(</span><span class="nx">err</span><span class="p">,</span> <span class="nx">hash</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'Mermaid Syntax error:'</span><span class="p">);</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="nx">err</span><span class="p">);</span>
<span class="p">},</span>
<span class="nx">render</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">text</span><span class="p">,</span><span class="nx">callback</span><span class="p">,</span> <span class="nx">element</span><span class="p">){</span>
<span class="k">return</span> <span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">render</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="nx">text</span><span class="p">,</span><span class="nx">callback</span><span class="p">,</span> <span class="nx">element</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">};</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs"><div class="dox">
<div class="summary"><div class="pilwrap" id="parseError">
<h2>
<a href="#parseError" name="parseError" class="pilcrow">¶</a>
parseError</h2>
</div>
<p>This function overrides the default configuration.</p>
</div>
<div class="body">
</div>
<div class="details">
<div class="dox_tag_title">Params</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">config
</span>
</div>
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">exports</span><span class="p">.</span><span class="nx">parseError</span> <span class="o">=</span> <span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">parseError</span><span class="p">;</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs"><div class="dox">
<div class="summary"><div class="pilwrap" id="contentLoaded">
<h2>
<a href="#contentLoaded" name="contentLoaded" class="pilcrow">¶</a>
contentLoaded</h2>
</div>
<p>Callback function that is called when page is loaded. This functions fetches configuration for mermaid rendering and
calls init for rendering the mermaid diagrams on the page.</p>
</div>
<div class="body">
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">exports</span><span class="p">.</span><span class="nx">contentLoaded</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(){</span>
<span class="kd">var</span> <span class="nx">config</span><span class="p">;</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-9" id="section-9">¶</a>
</div>
<p>Check state of start config mermaid namespace</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">mermaid_config</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">equals</span><span class="p">(</span><span class="kc">false</span><span class="p">,</span> <span class="nx">mermaid_config</span><span class="p">.</span><span class="nx">htmlLabels</span><span class="p">))</span> <span class="p">{</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">htmlLabels</span> <span class="o">=</span> <span class="kc">false</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">if</span><span class="p">(</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">)</span> <span class="p">{</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-10" id="section-10">¶</a>
</div>
<p>For backwards compatability reasons also check mermaid_config variable</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">mermaid_config</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">)</span> <span class="p">{</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-11" id="section-11">¶</a>
</div>
<p>Check if property startOnLoad is set</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="k">if</span> <span class="p">(</span><span class="nx">equals</span><span class="p">(</span><span class="kc">true</span><span class="p">,</span> <span class="nx">mermaid_config</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">))</span> <span class="p">{</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">init</span><span class="p">();</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">else</span> <span class="p">{</span>
<span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">initialize</span><span class="p">({</span><span class="nx">startOnLoad</span><span class="o">:</span><span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">});</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-12" id="section-12">¶</a>
</div>
<p>No config found, do check API config</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">config</span> <span class="o">=</span> <span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">getConfig</span><span class="p">();</span>
<span class="k">if</span><span class="p">(</span><span class="nx">config</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">){</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">init</span><span class="p">();</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="nx">log</span><span class="p">.</span><span class="nx">debug</span><span class="p">(</span><span class="s1">'In start, no config'</span><span class="p">);</span>
<span class="nx">config</span> <span class="o">=</span> <span class="nx">mermaidAPI</span><span class="p">.</span><span class="nx">getConfig</span><span class="p">();</span>
<span class="k">if</span><span class="p">(</span><span class="nx">config</span><span class="p">.</span><span class="nx">startOnLoad</span><span class="p">){</span>
<span class="nx">global</span><span class="p">.</span><span class="nx">mermaid</span><span class="p">.</span><span class="nx">init</span><span class="p">();</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="p">};</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nb">document</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-13" id="section-13">¶</a>
</div>
<div class="dox">
<div class="summary"><p>!
Wait for document loaded before starting the execution</p>
</div>
<div class="body">
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nb">document</span><span class="p">.</span><span class="nx">addEventListener</span><span class="p">(</span><span class="s1">'DOMContentLoaded'</span><span class="p">,</span> <span class="kd">function</span><span class="p">(){</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">contentLoaded</span><span class="p">();</span>
<span class="p">},</span> <span class="kc">false</span><span class="p">);</span>
<span class="p">}</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-14" id="section-14">¶</a>
</div>
<p> // Your actual module
return module.exports;
}));</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
</pre></div>
</td>
</tr>
</tbody>
</table>
</div>
</body>
</html>