UNPKG

mermaid

Version:

Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.

230 lines (195 loc) 20.6 kB
<!DOCTYPE html> <html> <head> <title>interactive-demo.html</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/bower_components/dagre-d3/demo/interactive-demo.html", 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="#interactive-demo.html">interactive-demo.html</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="interactive-demo.html"> <h1> <a href="#interactive-demo.html" name="interactive-demo.html" class="pilcrow">&#182;</a>interactive-demo.html </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">&#182;</a> </div> </td> <td class="code highlight"><div class="highlight"><pre><span class="cp">&lt;!doctype html&gt;</span> <span class="nt">&lt;meta</span> <span class="na">charset=</span><span class="s">&quot;utf-8&quot;</span><span class="nt">&gt;</span> <span class="nt">&lt;title&gt;</span>Dagre Interactive Demo<span class="nt">&lt;/title&gt;</span> <span class="nt">&lt;script </span><span class="na">src=</span><span class="s">&quot;http://d3js.org/d3.v3.js&quot;</span><span class="nt">&gt;&lt;/script&gt;</span> <span class="nt">&lt;script </span><span class="na">src=</span><span class="s">&quot;http://cpettitt.github.io/project/graphlib-dot/v0.5.2/graphlib-dot.js&quot;</span><span class="nt">&gt;&lt;/script&gt;</span> <span class="nt">&lt;script </span><span class="na">src=</span><span class="s">&quot;../build/dagre-d3.js&quot;</span><span class="nt">&gt;&lt;/script&gt;</span> <span class="nt">&lt;style&gt;</span> <span class="nt">svg</span> <span class="p">{</span> <span class="k">border</span><span class="o">:</span> <span class="m">1px</span> <span class="k">solid</span> <span class="m">#999</span><span class="p">;</span> <span class="k">overflow</span><span class="o">:</span> <span class="k">hidden</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.node</span> <span class="p">{</span> <span class="k">white-space</span><span class="o">:</span> <span class="k">nowrap</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.node</span> <span class="nt">rect</span><span class="o">,</span> <span class="nc">.node</span> <span class="nt">cicrce</span><span class="o">,</span> <span class="nc">.node</span> <span class="nt">ellipse</span> <span class="p">{</span> <span class="n">stroke</span><span class="o">:</span> <span class="m">#333</span><span class="p">;</span> <span class="n">fill</span><span class="o">:</span> <span class="m">#fff</span><span class="p">;</span> <span class="n">stroke</span><span class="o">-</span><span class="k">width</span><span class="o">:</span> <span class="m">1.5px</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.cluster</span> <span class="nt">rect</span> <span class="p">{</span> <span class="n">stroke</span><span class="o">:</span> <span class="m">#333</span><span class="p">;</span> <span class="n">fill</span><span class="o">:</span> <span class="m">#000</span><span class="p">;</span> <span class="n">fill</span><span class="o">-</span><span class="k">opacity</span><span class="o">:</span> <span class="m">0</span><span class="o">.</span><span class="m">1</span><span class="p">;</span> <span class="n">stroke</span><span class="o">-</span><span class="k">width</span><span class="o">:</span> <span class="m">1.5px</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.edgePath</span> <span class="nt">path</span><span class="nc">.path</span> <span class="p">{</span> <span class="n">stroke</span><span class="o">:</span> <span class="m">#333</span><span class="p">;</span> <span class="n">stroke</span><span class="o">-</span><span class="k">width</span><span class="o">:</span> <span class="m">1.5px</span><span class="p">;</span> <span class="n">fill</span><span class="o">:</span> <span class="k">none</span><span class="p">;</span> <span class="p">}</span> <span class="nt">&lt;/style&gt;</span> <span class="nt">&lt;style&gt;</span> <span class="nt">h1</span><span class="o">,</span> <span class="nt">h2</span> <span class="p">{</span> <span class="k">color</span><span class="o">:</span> <span class="m">#333</span><span class="p">;</span> <span class="p">}</span> <span class="nt">textarea</span> <span class="p">{</span> <span class="k">width</span><span class="o">:</span> <span class="m">800px</span><span class="p">;</span> <span class="p">}</span> <span class="nt">label</span> <span class="p">{</span> <span class="k">margin-top</span><span class="o">:</span> <span class="m">1em</span><span class="p">;</span> <span class="k">display</span><span class="o">:</span> <span class="k">block</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.error</span> <span class="p">{</span> <span class="k">color</span><span class="o">:</span> <span class="nb">red</span><span class="p">;</span> <span class="p">}</span> <span class="nt">&lt;/style&gt;</span> <span class="nt">&lt;body</span> <span class="na">onLoad=</span><span class="s">&quot;tryDraw();&quot;</span><span class="nt">&gt;</span> <span class="nt">&lt;h1&gt;</span>Dagre Interactive Demo<span class="nt">&lt;/h1&gt;</span> <span class="nt">&lt;h2&gt;</span>Input<span class="nt">&lt;/h2&gt;</span> <span class="nt">&lt;form&gt;</span> <span class="nt">&lt;label</span> <span class="na">for=</span><span class="s">&quot;inputGraph&quot;</span><span class="nt">&gt;</span>Graphviz Definition<span class="nt">&lt;/label&gt;</span> <span class="nt">&lt;textarea</span> <span class="na">id=</span><span class="s">&quot;inputGraph&quot;</span> <span class="na">rows=</span><span class="s">&quot;5&quot;</span> <span class="na">style=</span><span class="s">&quot;display: block&quot;</span> <span class="na">onKeyUp=</span><span class="s">&quot;tryDraw();&quot;</span><span class="nt">&gt;</span> /* Example */ digraph { /* Note: HTML labels do not work in IE, which lacks support for <span class="ni">&amp;lt;</span>foreignObject<span class="ni">&amp;gt;</span> tags. */ node [rx=5 ry=5 labelStyle=&quot;font: 300 14px &#39;Helvetica Neue&#39;, Helvetica&quot;] edge [labelStyle=&quot;font: 300 14px &#39;Helvetica Neue&#39;, Helvetica&quot;] A [labelType=&quot;html&quot; label=&quot;A <span class="nt">&lt;span</span> <span class="na">style=</span><span class="s">&#39;font-size:32px&#39;</span><span class="nt">&gt;</span>Big<span class="nt">&lt;/span&gt;</span> <span class="nt">&lt;span</span> <span class="na">style=</span><span class="s">&#39;color:red;&#39;</span><span class="nt">&gt;</span>HTML<span class="nt">&lt;/span&gt;</span> Source!&quot;]; C; E [label=&quot;Bold Red Sink&quot; style=&quot;fill: #f77; font-weight: bold&quot;]; A -<span class="ni">&amp;gt;</span> B -<span class="ni">&amp;gt;</span> C; B -<span class="ni">&amp;gt;</span> D [label=&quot;A blue label&quot; labelStyle=&quot;fill: #55f; font-weight: bold;&quot;]; D -<span class="ni">&amp;gt;</span> E [label=&quot;A thick red edge&quot; style=&quot;stroke: #f77; stroke-width: 2px;&quot; arrowheadStyle=&quot;fill: #f77&quot;]; C -<span class="ni">&amp;gt;</span> E; A -<span class="ni">&amp;gt;</span> D [labelType=&quot;html&quot; label=&quot;A multi-rank <span class="nt">&lt;span</span> <span class="na">style=</span><span class="s">&#39;color:blue;&#39;</span><span class="nt">&gt;</span>HTML<span class="nt">&lt;/span&gt;</span> edge!&quot;]; } <span class="nt">&lt;/textarea&gt;</span> <span class="nt">&lt;a</span> <span class="na">id=</span><span class="s">&quot;graphLink&quot;</span><span class="nt">&gt;</span>Link for this graph<span class="nt">&lt;/a&gt;</span> <span class="nt">&lt;/form&gt;</span> <span class="nt">&lt;h2&gt;</span>Graph Visualization<span class="nt">&lt;/h2&gt;</span> <span class="nt">&lt;svg</span> <span class="na">width=</span><span class="s">800</span> <span class="na">height=</span><span class="s">600</span><span class="nt">&gt;</span> <span class="nt">&lt;g/&gt;</span> <span class="nt">&lt;/svg&gt;</span> <span class="nt">&lt;script&gt;</span> <span class="c1">// Input related code goes here</span> <span class="kd">function</span> <span class="nx">graphToURL</span><span class="p">()</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">elems</span> <span class="o">=</span> <span class="p">[</span><span class="nb">window</span><span class="p">.</span><span class="nx">location</span><span class="p">.</span><span class="nx">protocol</span><span class="p">,</span> <span class="s1">&#39;//&#39;</span><span class="p">,</span> <span class="nb">window</span><span class="p">.</span><span class="nx">location</span><span class="p">.</span><span class="nx">host</span><span class="p">,</span> <span class="nb">window</span><span class="p">.</span><span class="nx">location</span><span class="p">.</span><span class="nx">pathname</span><span class="p">,</span> <span class="s1">&#39;?&#39;</span><span class="p">];</span> <span class="kd">var</span> <span class="nx">queryParams</span> <span class="o">=</span> <span class="p">[];</span> <span class="k">if</span> <span class="p">(</span><span class="nx">debugAlignment</span><span class="p">)</span> <span class="p">{</span> <span class="nx">queryParams</span><span class="p">.</span><span class="nx">push</span><span class="p">(</span><span class="s1">&#39;alignment=&#39;</span> <span class="o">+</span> <span class="nx">debugAlignment</span><span class="p">);</span> <span class="p">}</span> <span class="nx">queryParams</span><span class="p">.</span><span class="nx">push</span><span class="p">(</span><span class="s1">&#39;graph=&#39;</span> <span class="o">+</span> <span class="nb">encodeURIComponent</span><span class="p">(</span><span class="nx">inputGraph</span><span class="p">.</span><span class="nx">value</span><span class="p">));</span> <span class="nx">elems</span><span class="p">.</span><span class="nx">push</span><span class="p">(</span><span class="nx">queryParams</span><span class="p">.</span><span class="nx">join</span><span class="p">(</span><span class="s1">&#39;&amp;&#39;</span><span class="p">));</span> <span class="k">return</span> <span class="nx">elems</span><span class="p">.</span><span class="nx">join</span><span class="p">(</span><span class="s1">&#39;&#39;</span><span class="p">);</span> <span class="p">}</span> <span class="kd">var</span> <span class="nx">inputGraph</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">querySelector</span><span class="p">(</span><span class="s2">&quot;#inputGraph&quot;</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">graphLink</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">select</span><span class="p">(</span><span class="s2">&quot;#graphLink&quot;</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">oldInputGraphValue</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">graphRE</span> <span class="o">=</span> <span class="sr">/[?&amp;]graph=([^&amp;]+)/</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">graphMatch</span> <span class="o">=</span> <span class="nb">window</span><span class="p">.</span><span class="nx">location</span><span class="p">.</span><span class="nx">search</span><span class="p">.</span><span class="nx">match</span><span class="p">(</span><span class="nx">graphRE</span><span class="p">);</span> <span class="k">if</span> <span class="p">(</span><span class="nx">graphMatch</span><span class="p">)</span> <span class="p">{</span> <span class="nx">inputGraph</span><span class="p">.</span><span class="nx">value</span> <span class="o">=</span> <span class="nb">decodeURIComponent</span><span class="p">(</span><span class="nx">graphMatch</span><span class="p">[</span><span class="mi">1</span><span class="p">]);</span> <span class="p">}</span> <span class="kd">var</span> <span class="nx">debugAlignmentRE</span> <span class="o">=</span> <span class="sr">/[?&amp;]alignment=([^&amp;]+)/</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">debugAlignmentMatch</span> <span class="o">=</span> <span class="nb">window</span><span class="p">.</span><span class="nx">location</span><span class="p">.</span><span class="nx">search</span><span class="p">.</span><span class="nx">match</span><span class="p">(</span><span class="nx">debugAlignmentRE</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">debugAlignment</span><span class="p">;</span> <span class="k">if</span> <span class="p">(</span><span class="nx">debugAlignmentMatch</span><span class="p">)</span> <span class="nx">debugAlignment</span> <span class="o">=</span> <span class="nx">debugAlignmentMatch</span><span class="p">[</span><span class="mi">1</span><span class="p">];</span> <span class="c1">// Set up zoom support</span> <span class="kd">var</span> <span class="nx">svg</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">select</span><span class="p">(</span><span class="s2">&quot;svg&quot;</span><span class="p">),</span> <span class="nx">inner</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">select</span><span class="p">(</span><span class="s2">&quot;svg g&quot;</span><span class="p">),</span> <span class="nx">zoom</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">behavior</span><span class="p">.</span><span class="nx">zoom</span><span class="p">().</span><span class="nx">on</span><span class="p">(</span><span class="s2">&quot;zoom&quot;</span><span class="p">,</span> <span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="nx">inner</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">&quot;transform&quot;</span><span class="p">,</span> <span class="s2">&quot;translate(&quot;</span> <span class="o">+</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">event</span><span class="p">.</span><span class="nx">translate</span> <span class="o">+</span> <span class="s2">&quot;)&quot;</span> <span class="o">+</span> <span class="s2">&quot;scale(&quot;</span> <span class="o">+</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">event</span><span class="p">.</span><span class="nx">scale</span> <span class="o">+</span> <span class="s2">&quot;)&quot;</span><span class="p">);</span> <span class="p">});</span> <span class="nx">svg</span><span class="p">.</span><span class="nx">call</span><span class="p">(</span><span class="nx">zoom</span><span class="p">);</span> <span class="c1">// Create and configure the renderer</span> <span class="kd">var</span> <span class="nx">render</span> <span class="o">=</span> <span class="nx">dagreD3</span><span class="p">.</span><span class="nx">render</span><span class="p">();</span> <span class="kd">function</span> <span class="nx">tryDraw</span><span class="p">()</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">g</span><span class="p">;</span> <span class="k">if</span> <span class="p">(</span><span class="nx">oldInputGraphValue</span> <span class="o">!==</span> <span class="nx">inputGraph</span><span class="p">.</span><span class="nx">value</span><span class="p">)</span> <span class="p">{</span> <span class="nx">inputGraph</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s2">&quot;class&quot;</span><span class="p">,</span> <span class="s2">&quot;&quot;</span><span class="p">);</span> <span class="nx">oldInputGraphValue</span> <span class="o">=</span> <span class="nx">inputGraph</span><span class="p">.</span><span class="nx">value</span><span class="p">;</span> <span class="k">try</span> <span class="p">{</span> <span class="nx">g</span> <span class="o">=</span> <span class="nx">graphlibDot</span><span class="p">.</span><span class="nx">read</span><span class="p">(</span><span class="nx">inputGraph</span><span class="p">.</span><span class="nx">value</span><span class="p">);</span> <span class="p">}</span> <span class="k">catch</span> <span class="p">(</span><span class="nx">e</span><span class="p">)</span> <span class="p">{</span> <span class="nx">inputGraph</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s2">&quot;class&quot;</span><span class="p">,</span> <span class="s2">&quot;error&quot;</span><span class="p">);</span> <span class="k">throw</span> <span class="nx">e</span><span class="p">;</span> <span class="p">}</span> <span class="c1">// Save link to new graph</span> <span class="nx">graphLink</span><span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">&quot;href&quot;</span><span class="p">,</span> <span class="nx">graphToURL</span><span class="p">());</span> <span class="c1">// Set margins, if not present</span> <span class="k">if</span> <span class="p">(</span><span class="o">!</span><span class="nx">g</span><span class="p">.</span><span class="nx">graph</span><span class="p">().</span><span class="nx">hasOwnProperty</span><span class="p">(</span><span class="s2">&quot;marginx&quot;</span><span class="p">)</span> <span class="o">&amp;&amp;</span> <span class="o">!</span><span class="nx">g</span><span class="p">.</span><span class="nx">graph</span><span class="p">().</span><span class="nx">hasOwnProperty</span><span class="p">(</span><span class="s2">&quot;marginy&quot;</span><span class="p">))</span> <span class="p">{</span> <span class="nx">g</span><span class="p">.</span><span class="nx">graph</span><span class="p">().</span><span class="nx">marginx</span> <span class="o">=</span> <span class="mi">20</span><span class="p">;</span> <span class="nx">g</span><span class="p">.</span><span class="nx">graph</span><span class="p">().</span><span class="nx">marginy</span> <span class="o">=</span> <span class="mi">20</span><span class="p">;</span> <span class="p">}</span> <span class="nx">g</span><span class="p">.</span><span class="nx">graph</span><span class="p">().</span><span class="nx">transition</span> <span class="o">=</span> <span class="kd">function</span><span class="p">(</span><span class="nx">selection</span><span class="p">)</span> <span class="p">{</span> <span class="k">return</span> <span class="nx">selection</span><span class="p">.</span><span class="nx">transition</span><span class="p">().</span><span class="nx">duration</span><span class="p">(</span><span class="mi">500</span><span class="p">);</span> <span class="p">};</span> <span class="c1">// Render the graph into svg g</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">select</span><span class="p">(</span><span class="s2">&quot;svg g&quot;</span><span class="p">).</span><span class="nx">call</span><span class="p">(</span><span class="nx">render</span><span class="p">,</span> <span class="nx">g</span><span class="p">);</span> <span class="p">}</span> <span class="p">}</span> <span class="nt">&lt;/script&gt;</span> </pre></div> </td> </tr> </tbody> </table> </div> </body> </html>