mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.
512 lines (448 loc) • 82.7 kB
HTML
<!DOCTYPE html>
<html>
<head>
<title>sequenceRenderer.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/diagrams/sequenceDiagram/sequenceRenderer.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="#sequenceRenderer.js">sequenceRenderer.js</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="sequenceRenderer.js">
<h1>
<a href="#sequenceRenderer.js" name="sequenceRenderer.js" class="pilcrow">¶</a>sequenceRenderer.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>
<div class="dox">
<div class="summary"><p>Created by knut on 14-11-23.</p>
</div>
<div class="body">
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre><span class="kd">var</span> <span class="nx">sq</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./parser/sequenceDiagram'</span><span class="p">).</span><span class="nx">parser</span><span class="p">;</span>
<span class="nx">sq</span><span class="p">.</span><span class="nx">yy</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./sequenceDb'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">svgDraw</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./svgDraw'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">d3</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'../../d3'</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="kd">var</span> <span class="nx">conf</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">diagramMarginX</span><span class="o">:</span><span class="mi">50</span><span class="p">,</span>
<span class="nx">diagramMarginY</span><span class="o">:</span><span class="mi">10</span><span class="p">,</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-2" id="section-2">¶</a>
</div>
<p>Margin between actors</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">actorMargin</span><span class="o">:</span><span class="mi">50</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>Width of actor moxes</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">width</span><span class="o">:</span><span class="mi">150</span><span class="p">,</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-4" id="section-4">¶</a>
</div>
<p>Height of actor boxes</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">height</span><span class="o">:</span><span class="mi">65</span><span class="p">,</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-5" id="section-5">¶</a>
</div>
<p>Margin around loop boxes</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">boxMargin</span><span class="o">:</span><span class="mi">10</span><span class="p">,</span>
<span class="nx">boxTextMargin</span><span class="o">:</span><span class="mi">5</span><span class="p">,</span>
<span class="nx">noteMargin</span><span class="o">:</span><span class="mi">10</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>
<p>Space between messages</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">messageMargin</span><span class="o">:</span><span class="mi">35</span><span class="p">,</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-7" id="section-7">¶</a>
</div>
<p>mirror actors under diagram</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">mirrorActors</span><span class="o">:</span><span class="kc">false</span><span class="p">,</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-8" id="section-8">¶</a>
</div>
<p>Depending on css styling this might need adjustment
Prolongs the edge of the diagram downwards</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">bottomMarginAdj</span><span class="o">:</span><span class="mi">1</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>var bb = getBBox("path");</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">data</span><span class="o">:</span><span class="p">{</span>
<span class="nx">startx</span><span class="o">:</span><span class="kc">undefined</span><span class="p">,</span>
<span class="nx">stopx</span> <span class="o">:</span><span class="kc">undefined</span><span class="p">,</span>
<span class="nx">starty</span><span class="o">:</span><span class="kc">undefined</span><span class="p">,</span>
<span class="nx">stopy</span> <span class="o">:</span><span class="kc">undefined</span><span class="p">,</span>
<span class="p">},</span>
<span class="nx">verticalPos</span><span class="o">:</span><span class="mi">0</span><span class="p">,</span>
<span class="nx">list</span><span class="o">:</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="k">this</span><span class="p">.</span><span class="nx">list</span> <span class="o">=</span> <span class="p">[];</span>
<span class="k">this</span><span class="p">.</span><span class="nx">data</span> <span class="o">=</span> <span class="p">{</span>
<span class="nx">startx</span><span class="o">:</span><span class="kc">undefined</span><span class="p">,</span>
<span class="nx">stopx</span> <span class="o">:</span><span class="kc">undefined</span><span class="p">,</span>
<span class="nx">starty</span><span class="o">:</span><span class="kc">undefined</span><span class="p">,</span>
<span class="nx">stopy</span> <span class="o">:</span><span class="kc">undefined</span><span class="p">,</span>
<span class="p">};</span>
<span class="k">this</span><span class="p">.</span><span class="nx">verticalPos</span> <span class="o">=</span><span class="mi">0</span><span class="p">;</span>
<span class="p">},</span>
<span class="nx">updateVal</span> <span class="o">:</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">obj</span><span class="p">,</span><span class="nx">key</span><span class="p">,</span><span class="nx">val</span><span class="p">,</span><span class="nx">fun</span><span class="p">){</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">obj</span><span class="p">[</span><span class="nx">key</span><span class="p">]</span> <span class="o">===</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">obj</span><span class="p">[</span><span class="nx">key</span><span class="p">]</span> <span class="o">=</span> <span class="nx">val</span><span class="p">;</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="nx">obj</span><span class="p">[</span><span class="nx">key</span><span class="p">]</span> <span class="o">=</span> <span class="nx">fun</span><span class="p">(</span><span class="nx">val</span><span class="p">,</span><span class="nx">obj</span><span class="p">[</span><span class="nx">key</span><span class="p">]);</span>
<span class="p">}</span>
<span class="p">},</span>
<span class="nx">updateLoops</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">startx</span><span class="p">,</span><span class="nx">starty</span><span class="p">,</span><span class="nx">stopx</span><span class="p">,</span><span class="nx">stopy</span><span class="p">){</span>
<span class="kd">var</span> <span class="nx">_self</span> <span class="o">=</span> <span class="k">this</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">cnt</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
<span class="k">this</span><span class="p">.</span><span class="nx">list</span><span class="p">.</span><span class="nx">forEach</span><span class="p">(</span><span class="kd">function</span><span class="p">(</span><span class="nx">loop</span><span class="p">){</span>
<span class="nx">cnt</span><span class="o">++</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>The loop list is a stack so the biggest margins in the beginning of the list</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">n</span> <span class="o">=</span> <span class="nx">_self</span><span class="p">.</span><span class="nx">list</span><span class="p">.</span><span class="nx">length</span><span class="o">-</span><span class="nx">cnt</span><span class="o">+</span><span class="mi">1</span><span class="p">;</span>
<span class="nx">_self</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">loop</span><span class="p">,</span> <span class="s1">'startx'</span><span class="p">,</span><span class="nx">startx</span> <span class="o">-</span> <span class="nx">n</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">boxMargin</span><span class="p">,</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">min</span><span class="p">);</span>
<span class="nx">_self</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">loop</span><span class="p">,</span> <span class="s1">'starty'</span><span class="p">,</span><span class="nx">starty</span> <span class="o">-</span> <span class="nx">n</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">boxMargin</span><span class="p">,</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">min</span><span class="p">);</span>
<span class="nx">_self</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">loop</span><span class="p">,</span> <span class="s1">'stopx'</span> <span class="p">,</span><span class="nx">stopx</span> <span class="o">+</span> <span class="nx">n</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">boxMargin</span><span class="p">,</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">);</span>
<span class="nx">_self</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">loop</span><span class="p">,</span> <span class="s1">'stopy'</span> <span class="p">,</span><span class="nx">stopy</span> <span class="o">+</span> <span class="nx">n</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">boxMargin</span><span class="p">,</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">);</span>
<span class="nx">_self</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">data</span><span class="p">,</span><span class="s1">'startx'</span><span class="p">,</span><span class="nx">startx</span> <span class="o">-</span> <span class="nx">n</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">boxMargin</span> <span class="p">,</span><span class="nb">Math</span><span class="p">.</span><span class="nx">min</span><span class="p">);</span>
<span class="nx">_self</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">data</span><span class="p">,</span><span class="s1">'starty'</span><span class="p">,</span><span class="nx">starty</span> <span class="o">-</span> <span class="nx">n</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">boxMargin</span> <span class="p">,</span><span class="nb">Math</span><span class="p">.</span><span class="nx">min</span><span class="p">);</span>
<span class="nx">_self</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">data</span><span class="p">,</span><span class="s1">'stopx'</span> <span class="p">,</span><span class="nx">stopx</span> <span class="o">+</span> <span class="nx">n</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">boxMargin</span> <span class="p">,</span><span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">);</span>
<span class="nx">_self</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">data</span><span class="p">,</span><span class="s1">'stopy'</span> <span class="p">,</span><span class="nx">stopy</span> <span class="o">+</span> <span class="nx">n</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">boxMargin</span> <span class="p">,</span><span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">);</span>
<span class="p">});</span>
<span class="p">},</span>
<span class="nx">insert</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">startx</span><span class="p">,</span><span class="nx">starty</span><span class="p">,</span><span class="nx">stopx</span><span class="p">,</span><span class="nx">stopy</span><span class="p">){</span>
<span class="kd">var</span> <span class="nx">_startx</span><span class="p">,</span> <span class="nx">_starty</span><span class="p">,</span> <span class="nx">_stopx</span><span class="p">,</span> <span class="nx">_stopy</span><span class="p">;</span>
<span class="nx">_startx</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">min</span><span class="p">(</span><span class="nx">startx</span><span class="p">,</span><span class="nx">stopx</span><span class="p">);</span>
<span class="nx">_stopx</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">(</span><span class="nx">startx</span><span class="p">,</span><span class="nx">stopx</span><span class="p">);</span>
<span class="nx">_starty</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">min</span><span class="p">(</span><span class="nx">starty</span><span class="p">,</span><span class="nx">stopy</span><span class="p">);</span>
<span class="nx">_stopy</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">(</span><span class="nx">starty</span><span class="p">,</span><span class="nx">stopy</span><span class="p">);</span>
<span class="k">this</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">data</span><span class="p">,</span><span class="s1">'startx'</span><span class="p">,</span><span class="nx">_startx</span><span class="p">,</span><span class="nb">Math</span><span class="p">.</span><span class="nx">min</span><span class="p">);</span>
<span class="k">this</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">data</span><span class="p">,</span><span class="s1">'starty'</span><span class="p">,</span><span class="nx">_starty</span><span class="p">,</span><span class="nb">Math</span><span class="p">.</span><span class="nx">min</span><span class="p">);</span>
<span class="k">this</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">data</span><span class="p">,</span><span class="s1">'stopx'</span> <span class="p">,</span><span class="nx">_stopx</span> <span class="p">,</span><span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">);</span>
<span class="k">this</span><span class="p">.</span><span class="nx">updateVal</span><span class="p">(</span><span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">data</span><span class="p">,</span><span class="s1">'stopy'</span> <span class="p">,</span><span class="nx">_stopy</span> <span class="p">,</span><span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">);</span>
<span class="k">this</span><span class="p">.</span><span class="nx">updateLoops</span><span class="p">(</span><span class="nx">_startx</span><span class="p">,</span><span class="nx">_starty</span><span class="p">,</span><span class="nx">_stopx</span><span class="p">,</span><span class="nx">_stopy</span><span class="p">);</span>
<span class="p">},</span>
<span class="nx">newLoop</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">title</span><span class="p">){</span>
<span class="k">this</span><span class="p">.</span><span class="nx">list</span><span class="p">.</span><span class="nx">push</span><span class="p">({</span><span class="nx">startx</span><span class="o">:</span><span class="kc">undefined</span><span class="p">,</span><span class="nx">starty</span><span class="o">:</span><span class="k">this</span><span class="p">.</span><span class="nx">verticalPos</span><span class="p">,</span><span class="nx">stopx</span><span class="o">:</span><span class="kc">undefined</span><span class="p">,</span><span class="nx">stopy</span><span class="o">:</span><span class="kc">undefined</span><span class="p">,</span> <span class="nx">title</span><span class="o">:</span><span class="nx">title</span><span class="p">});</span>
<span class="p">},</span>
<span class="nx">endLoop</span><span class="o">:</span><span class="kd">function</span><span class="p">(){</span>
<span class="kd">var</span> <span class="nx">loop</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">list</span><span class="p">.</span><span class="nx">pop</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>loop.stopy = exports.bounds.getVerticalPos();</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="k">return</span> <span class="nx">loop</span><span class="p">;</span>
<span class="p">},</span>
<span class="nx">addElseToLoop</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">message</span><span class="p">){</span>
<span class="kd">var</span> <span class="nx">loop</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">list</span><span class="p">.</span><span class="nx">pop</span><span class="p">();</span>
<span class="nx">loop</span><span class="p">.</span><span class="nx">elsey</span> <span class="o">=</span> <span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">getVerticalPos</span><span class="p">();</span>
<span class="nx">loop</span><span class="p">.</span><span class="nx">elseText</span> <span class="o">=</span> <span class="nx">message</span><span class="p">;</span>
<span class="k">this</span><span class="p">.</span><span class="nx">list</span><span class="p">.</span><span class="nx">push</span><span class="p">(</span><span class="nx">loop</span><span class="p">);</span>
<span class="p">},</span>
<span class="nx">bumpVerticalPos</span><span class="o">:</span><span class="kd">function</span><span class="p">(</span><span class="nx">bump</span><span class="p">){</span>
<span class="k">this</span><span class="p">.</span><span class="nx">verticalPos</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">verticalPos</span> <span class="o">+</span> <span class="nx">bump</span><span class="p">;</span>
<span class="k">this</span><span class="p">.</span><span class="nx">data</span><span class="p">.</span><span class="nx">stopy</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">verticalPos</span><span class="p">;</span>
<span class="p">},</span>
<span class="nx">getVerticalPos</span><span class="o">:</span><span class="kd">function</span><span class="p">(){</span>
<span class="k">return</span> <span class="k">this</span><span class="p">.</span><span class="nx">verticalPos</span><span class="p">;</span>
<span class="p">},</span>
<span class="nx">getBounds</span><span class="o">:</span><span class="kd">function</span><span class="p">(){</span>
<span class="k">return</span> <span class="k">this</span><span class="p">.</span><span class="nx">data</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-12" id="section-12">¶</a>
</div>
<div class="dox">
<div class="summary"><p>Draws an actor in the diagram with the attaced line</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">center</span>
<span><ul>
<li>The center of the the actor</li>
</ul>
</span>
</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">pos</span>
<span>The position if the actor in the liost of actors
</span>
</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">description</span>
<span>The text in the box
</span>
</div>
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">drawNote</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">elem</span><span class="p">,</span> <span class="nx">startx</span><span class="p">,</span> <span class="nx">verticalPos</span><span class="p">,</span> <span class="nx">msg</span><span class="p">){</span>
<span class="kd">var</span> <span class="nx">rect</span> <span class="o">=</span> <span class="nx">svgDraw</span><span class="p">.</span><span class="nx">getNoteRect</span><span class="p">();</span>
<span class="nx">rect</span><span class="p">.</span><span class="nx">x</span> <span class="o">=</span> <span class="nx">startx</span><span class="p">;</span>
<span class="nx">rect</span><span class="p">.</span><span class="nx">y</span> <span class="o">=</span> <span class="nx">verticalPos</span><span class="p">;</span>
<span class="nx">rect</span><span class="p">.</span><span class="nx">width</span> <span class="o">=</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">width</span><span class="p">;</span>
<span class="nx">rect</span><span class="p">.</span><span class="kr">class</span> <span class="o">=</span> <span class="s1">'note'</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">g</span> <span class="o">=</span> <span class="nx">elem</span><span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s1">'g'</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">rectElem</span> <span class="o">=</span> <span class="nx">svgDraw</span><span class="p">.</span><span class="nx">drawRect</span><span class="p">(</span><span class="nx">g</span><span class="p">,</span> <span class="nx">rect</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">textObj</span> <span class="o">=</span> <span class="nx">svgDraw</span><span class="p">.</span><span class="nx">getTextObj</span><span class="p">();</span>
<span class="nx">textObj</span><span class="p">.</span><span class="nx">x</span> <span class="o">=</span> <span class="nx">startx</span><span class="p">;</span>
<span class="nx">textObj</span><span class="p">.</span><span class="nx">y</span> <span class="o">=</span> <span class="nx">verticalPos</span><span class="o">-</span><span class="mi">13</span><span class="p">;</span>
<span class="nx">textObj</span><span class="p">.</span><span class="nx">textMargin</span> <span class="o">=</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">noteMargin</span><span class="p">;</span>
<span class="nx">textObj</span><span class="p">.</span><span class="nx">dy</span> <span class="o">=</span> <span class="s1">'1em'</span><span class="p">;</span>
<span class="nx">textObj</span><span class="p">.</span><span class="nx">text</span> <span class="o">=</span> <span class="nx">msg</span><span class="p">.</span><span class="nx">message</span><span class="p">;</span>
<span class="nx">textObj</span><span class="p">.</span><span class="kr">class</span> <span class="o">=</span> <span class="s1">'noteText'</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">textElem</span> <span class="o">=</span> <span class="nx">svgDraw</span><span class="p">.</span><span class="nx">drawText</span><span class="p">(</span><span class="nx">g</span><span class="p">,</span><span class="nx">textObj</span><span class="p">,</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">width</span><span class="o">-</span><span class="nx">conf</span><span class="p">.</span><span class="nx">noteMargin</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">textHeight</span> <span class="o">=</span> <span class="nx">textElem</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">0</span><span class="p">].</span><span class="nx">getBBox</span><span class="p">().</span><span class="nx">height</span><span class="p">;</span>
<span class="k">if</span><span class="p">(</span><span class="nx">textHeight</span> <span class="o">></span> <span class="nx">conf</span><span class="p">.</span><span class="nx">width</span><span class="p">){</span>
<span class="nx">textElem</span><span class="p">.</span><span class="nx">remove</span><span class="p">();</span>
<span class="nx">g</span> <span class="o">=</span> <span class="nx">elem</span><span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s2">"g"</span><span class="p">);</span>
<span class="nx">textElem</span> <span class="o">=</span> <span class="nx">svgDraw</span><span class="p">.</span><span class="nx">drawText</span><span class="p">(</span><span class="nx">g</span><span class="p">,</span><span class="nx">textObj</span><span class="p">,</span> <span class="mi">2</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">width</span><span class="p">);</span>
<span class="nx">textHeight</span> <span class="o">=</span> <span class="nx">textElem</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">0</span><span class="p">].</span><span class="nx">getBBox</span><span class="p">().</span><span class="nx">height</span><span class="p">;</span>
<span class="nx">rectElem</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s1">'width'</span><span class="p">,</span><span class="mi">2</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">width</span><span class="p">);</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">insert</span><span class="p">(</span><span class="nx">startx</span><span class="p">,</span> <span class="nx">verticalPos</span><span class="p">,</span> <span class="nx">startx</span> <span class="o">+</span> <span class="mi">2</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">width</span><span class="p">,</span> <span class="nx">verticalPos</span> <span class="o">+</span> <span class="mi">2</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">noteMargin</span> <span class="o">+</span> <span class="nx">textHeight</span><span class="p">);</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">insert</span><span class="p">(</span><span class="nx">startx</span><span class="p">,</span> <span class="nx">verticalPos</span><span class="p">,</span> <span class="nx">startx</span> <span class="o">+</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">width</span><span class="p">,</span> <span class="nx">verticalPos</span> <span class="o">+</span> <span class="mi">2</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">noteMargin</span> <span class="o">+</span> <span class="nx">textHeight</span><span class="p">);</span>
<span class="p">}</span>
<span class="nx">rectElem</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s1">'height'</span><span class="p">,</span><span class="nx">textHeight</span><span class="o">+</span> <span class="mi">2</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">noteMargin</span><span class="p">);</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">bumpVerticalPos</span><span class="p">(</span><span class="nx">textHeight</span><span class="o">+</span> <span class="mi">2</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">noteMargin</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-13" id="section-13">¶</a>
</div>
<div class="dox">
<div class="summary"><p>Draws a message</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">elem</span>
</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">startx</span>
</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">stopx</span>
</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">verticalPos</span>
</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">txtCenter</span>
</div>
<div class="dox_tag_detail">
<span class="dox_tag_name">msg
</span>
</div>
</div>
</div>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">drawMessage</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">elem</span><span class="p">,</span> <span class="nx">startx</span><span class="p">,</span> <span class="nx">stopx</span><span class="p">,</span> <span class="nx">verticalPos</span><span class="p">,</span> <span class="nx">msg</span><span class="p">){</span>
<span class="kd">var</span> <span class="nx">g</span> <span class="o">=</span> <span class="nx">elem</span><span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s2">"g"</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">txtCenter</span> <span class="o">=</span> <span class="nx">startx</span> <span class="o">+</span> <span class="p">(</span><span class="nx">stopx</span><span class="o">-</span><span class="nx">startx</span><span class="p">)</span><span class="o">/</span><span class="mi">2</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">textElem</span> <span class="o">=</span> <span class="nx">g</span><span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s2">"text"</span><span class="p">)</span> <span class="c1">// text label for the x axis</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"x"</span><span class="p">,</span> <span class="nx">txtCenter</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"y"</span><span class="p">,</span> <span class="nx">verticalPos</span> <span class="o">-</span> <span class="mi">7</span><span class="p">)</span>
<span class="p">.</span><span class="nx">style</span><span class="p">(</span><span class="s2">"text-anchor"</span><span class="p">,</span> <span class="s2">"middle"</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"class"</span><span class="p">,</span> <span class="s2">"messageText"</span><span class="p">)</span>
<span class="p">.</span><span class="nx">text</span><span class="p">(</span><span class="nx">msg</span><span class="p">.</span><span class="nx">message</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">textWidth</span><span class="p">;</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">textElem</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">0</span><span class="p">].</span><span class="nx">getBBox</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">textWidth</span> <span class="o">=</span> <span class="nx">textElem</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">0</span><span class="p">].</span><span class="nx">getBBox</span><span class="p">().</span><span class="nx">width</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">else</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>textWidth = getBBox(textElem).width; //.getComputedTextLength()</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">textWidth</span> <span class="o">=</span> <span class="nx">textElem</span><span class="p">[</span><span class="mi">0</span><span class="p">][</span><span class="mi">0</span><span class="p">].</span><span class="nx">getBoundingClientRect</span><span class="p">();</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-15" id="section-15">¶</a>
</div>
<p>textWidth = textElem[0][0].getComputedTextLength(); </p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">line</span><span class="p">;</span>
<span class="k">if</span><span class="p">(</span><span class="nx">startx</span><span class="o">===</span><span class="nx">stopx</span><span class="p">){</span>
<span class="nx">line</span> <span class="o">=</span> <span class="nx">g</span><span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s2">"path"</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s1">'d'</span><span class="p">,</span> <span class="s1">'M '</span> <span class="o">+</span><span class="nx">startx</span><span class="o">+</span> <span class="s1">','</span><span class="o">+</span><span class="nx">verticalPos</span><span class="o">+</span><span class="s1">' C '</span> <span class="o">+</span><span class="p">(</span><span class="nx">startx</span><span class="o">+</span><span class="mi">60</span><span class="p">)</span><span class="o">+</span> <span class="s1">','</span><span class="o">+</span><span class="p">(</span><span class="nx">verticalPos</span><span class="o">-</span><span class="mi">10</span><span class="p">)</span><span class="o">+</span><span class="s1">' '</span> <span class="o">+</span><span class="p">(</span><span class="nx">startx</span><span class="o">+</span><span class="mi">60</span><span class="p">)</span><span class="o">+</span> <span class="s1">','</span> <span class="o">+</span>
<span class="p">(</span><span class="nx">verticalPos</span><span class="o">+</span><span class="mi">30</span><span class="p">)</span><span class="o">+</span><span class="s1">' '</span> <span class="o">+</span><span class="nx">startx</span><span class="o">+</span> <span class="s1">','</span><span class="o">+</span><span class="p">(</span><span class="nx">verticalPos</span><span class="o">+</span><span class="mi">20</span><span class="p">));</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">bumpVerticalPos</span><span class="p">(</span><span class="mi">30</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">dx</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">max</span><span class="p">(</span><span class="nx">textWidth</span><span class="o">/</span><span class="mi">2</span><span class="p">,</span><span class="mi">100</span><span class="p">);</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">insert</span><span class="p">(</span><span class="nx">startx</span><span class="o">-</span><span class="nx">dx</span><span class="p">,</span> <span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">getVerticalPos</span><span class="p">()</span> <span class="o">-</span><span class="mi">10</span><span class="p">,</span> <span class="nx">stopx</span><span class="o">+</span><span class="nx">dx</span><span class="p">,</span> <span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">getVerticalPos</span><span class="p">());</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="nx">line</span> <span class="o">=</span> <span class="nx">g</span><span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s2">"line"</span><span class="p">);</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"x1"</span><span class="p">,</span> <span class="nx">startx</span><span class="p">);</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"y1"</span><span class="p">,</span> <span class="nx">verticalPos</span><span class="p">);</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"x2"</span><span class="p">,</span> <span class="nx">stopx</span><span class="p">);</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"y2"</span><span class="p">,</span> <span class="nx">verticalPos</span><span class="p">);</span>
<span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">insert</span><span class="p">(</span><span class="nx">startx</span><span class="p">,</span> <span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">getVerticalPos</span><span class="p">()</span> <span class="o">-</span><span class="mi">10</span><span class="p">,</span> <span class="nx">stopx</span><span class="p">,</span> <span class="nx">exports</span><span class="p">.</span><span class="nx">bounds</span><span class="p">.</span><span class="nx">getVerticalPos</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-16" id="section-16">¶</a>
</div>
<p>Make an SVG Container
Draw the line</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="k">if</span> <span class="p">(</span><span class="nx">msg</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">sq</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">LINETYPE</span><span class="p">.</span><span class="nx">DOTTED</span> <span class="o">||</span> <span class="nx">msg</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">sq</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">LINETYPE</span><span class="p">.</span><span class="nx">DOTTED_CROSS</span> <span class="o">||</span> <span class="nx">msg</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">sq</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">LINETYPE</span><span class="p">.</span><span class="nx">DOTTED_OPEN</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">style</span><span class="p">(</span><span class="s2">"stroke-dasharray"</span><span class="p">,</span> <span class="p">(</span><span class="s2">"3, 3"</span><span class="p">));</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"class"</span><span class="p">,</span> <span class="s2">"messageLine1"</span><span class="p">);</span>
<span class="p">}</span>
<span class="k">else</span> <span class="p">{</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"class"</span><span class="p">,</span> <span class="s2">"messageLine0"</span><span class="p">);</span>
<span class="p">}</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"stroke-width"</span><span class="p">,</span> <span class="mi">2</span><span class="p">);</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"stroke"</span><span class="p">,</span> <span class="s2">"black"</span><span class="p">);</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">style</span><span class="p">(</span><span class="s2">"fill"</span><span class="p">,</span> <span class="s2">"none"</span><span class="p">);</span> <span class="c1">// remove any fill colour</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">msg</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">sq</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">LINETYPE</span><span class="p">.</span><span class="nx">SOLID</span> <span class="o">||</span> <span class="nx">msg</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">sq</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">LINETYPE</span><span class="p">.</span><span class="nx">DOTTED</span><span class="p">){</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"marker-end"</span><span class="p">,</span> <span class="s2">"url(#arrowhead)"</span><span class="p">);</span>
<span class="p">}</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">msg</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">sq</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">LINETYPE</span><span class="p">.</span><span class="nx">SOLID_CROSS</span> <span class="o">||</span> <span class="nx">msg</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">sq</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">LINETYPE</span><span class="p">.</span><span class="nx">DOTTED_CROSS</span><span class="p">){</span>
<span class="nx">line</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"marker-end"</span><span class="p">,</span> <span class="s2">"url(#crosshead)"</span><span class="p">);</span>
<span class="p">}</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">drawActors</span> <spa