UNPKG

mermaid

Version:

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

342 lines (299 loc) 35.3 kB
<!DOCTYPE html> <html> <head> <title>etl-status.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/etl-status.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="#etl-status.html">etl-status.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="etl-status.html"> <h1> <a href="#etl-status.html" name="etl-status.html" class="pilcrow">&#182;</a>etl-status.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 D3 Renderer 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.min.js&quot;</span> <span class="na">charset=</span><span class="s">&quot;utf-8&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">body</span> <span class="p">{</span> <span class="k">position</span><span class="o">:</span> <span class="k">fixed</span><span class="p">;</span> <span class="k">top</span><span class="o">:</span> <span class="m">0</span><span class="p">;</span> <span class="k">bottom</span><span class="o">:</span> <span class="m">0</span><span class="p">;</span> <span class="k">left</span><span class="o">:</span> <span class="m">0</span><span class="p">;</span> <span class="k">right</span><span class="o">:</span> <span class="m">0</span><span class="p">;</span> <span class="k">margin</span><span class="o">:</span> <span class="m">0</span><span class="p">;</span> <span class="k">padding</span><span class="o">:</span> <span class="m">0</span><span class="p">;</span> <span class="k">font-family</span><span class="o">:</span> <span class="s2">&quot;Helvetica Neue&quot;</span><span class="o">,</span> <span class="n">Helvetica</span><span class="o">,</span> <span class="n">Arial</span><span class="o">,</span> <span class="n">sans</span><span class="o">-</span><span class="n">serf</span><span class="p">;</span> <span class="k">background</span><span class="o">:</span> <span class="m">#333</span><span class="p">;</span> <span class="p">}</span> <span class="k">@-webkit-keyframes</span> <span class="nt">flash</span> <span class="p">{</span> <span class="nt">0</span><span class="o">%,</span> <span class="nt">50</span><span class="o">%,</span> <span class="nt">100</span><span class="o">%</span> <span class="p">{</span> <span class="k">opacity</span><span class="o">:</span> <span class="m">1</span><span class="p">;</span> <span class="p">}</span> <span class="nt">25</span><span class="o">%,</span> <span class="nt">75</span><span class="o">%</span> <span class="p">{</span> <span class="k">opacity</span><span class="o">:</span> <span class="m">0</span><span class="o">.</span><span class="m">2</span><span class="p">;</span> <span class="p">}</span> <span class="p">}</span> <span class="k">@keyframes</span> <span class="nt">flash</span> <span class="p">{</span> <span class="nt">0</span><span class="o">%,</span> <span class="nt">50</span><span class="o">%,</span> <span class="nt">100</span><span class="o">%</span> <span class="p">{</span> <span class="k">opacity</span><span class="o">:</span> <span class="m">1</span><span class="p">;</span> <span class="p">}</span> <span class="nt">25</span><span class="o">%,</span> <span class="nt">75</span><span class="o">%</span> <span class="p">{</span> <span class="k">opacity</span><span class="o">:</span> <span class="m">0</span><span class="o">.</span><span class="m">2</span><span class="p">;</span> <span class="p">}</span> <span class="p">}</span> <span class="nc">.warn</span> <span class="p">{</span> <span class="o">-</span><span class="n">webkit</span><span class="o">-</span><span class="n">animation</span><span class="o">-</span><span class="n">duration</span><span class="o">:</span> <span class="m">5s</span><span class="p">;</span> <span class="n">animation</span><span class="o">-</span><span class="n">duration</span><span class="o">:</span> <span class="m">5s</span><span class="p">;</span> <span class="o">-</span><span class="n">webkit</span><span class="o">-</span><span class="n">animation</span><span class="o">-</span><span class="n">fill</span><span class="o">-</span><span class="n">mode</span><span class="o">:</span> <span class="k">both</span><span class="p">;</span> <span class="n">animation</span><span class="o">-</span><span class="n">fill</span><span class="o">-</span><span class="n">mode</span><span class="o">:</span> <span class="k">both</span><span class="p">;</span> <span class="o">-</span><span class="n">webkit</span><span class="o">-</span><span class="n">animation</span><span class="o">-</span><span class="n">iteration</span><span class="o">-</span><span class="n">count</span><span class="o">:</span> <span class="m">1</span><span class="p">;</span> <span class="n">animation</span><span class="o">-</span><span class="n">iteration</span><span class="o">-</span><span class="n">count</span><span class="o">:</span> <span class="m">1</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="p">{</span> <span class="k">width</span><span class="o">:</span> <span class="m">100</span><span class="o">%</span><span class="p">;</span> <span class="k">height</span><span class="o">:</span> <span class="m">100</span><span class="o">%</span><span class="p">;</span> <span class="p">}</span> <span class="nt">svg</span> <span class="p">{</span> <span class="k">width</span><span class="o">:</span> <span class="m">100</span><span class="o">%</span><span class="p">;</span> <span class="k">height</span><span class="o">:</span> <span class="m">100</span><span class="o">%</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">.live.map</span> <span class="nt">text</span> <span class="p">{</span> <span class="k">font-weight</span><span class="o">:</span> <span class="m">300</span><span class="p">;</span> <span class="k">font-size</span><span class="o">:</span> <span class="m">14px</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.node</span> <span class="nt">rect</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">stroke</span><span class="o">:</span> <span class="m">#bbb</span><span class="p">;</span> <span class="n">fill</span><span class="o">:</span> <span class="m">#666</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.status</span> <span class="p">{</span> <span class="k">height</span><span class="o">:</span> <span class="m">100</span><span class="o">%</span><span class="p">;</span> <span class="k">width</span><span class="o">:</span> <span class="m">15px</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="k">float</span><span class="o">:</span> <span class="k">left</span><span class="p">;</span> <span class="k">border-top</span><span class="o">-</span><span class="k">left</span><span class="o">-</span><span class="n">radius</span><span class="o">:</span> <span class="m">5px</span><span class="p">;</span> <span class="k">border-bottom</span><span class="o">-</span><span class="k">left</span><span class="o">-</span><span class="n">radius</span><span class="o">:</span> <span class="m">5px</span><span class="p">;</span> <span class="k">margin-right</span><span class="o">:</span> <span class="m">4px</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.running</span> <span class="nc">.status</span> <span class="p">{</span> <span class="k">background-color</span><span class="o">:</span> <span class="m">#7f7</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.running.warn</span> <span class="nc">.status</span> <span class="p">{</span> <span class="k">background-color</span><span class="o">:</span> <span class="m">#ffed68</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.stopped</span> <span class="nc">.status</span> <span class="p">{</span> <span class="k">background-color</span><span class="o">:</span> <span class="m">#f77</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.warn</span> <span class="nc">.queue</span> <span class="p">{</span> <span class="k">color</span><span class="o">:</span> <span class="m">#f77</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.warn</span> <span class="p">{</span> <span class="o">-</span><span class="n">webkit</span><span class="o">-</span><span class="n">animation</span><span class="o">-</span><span class="n">name</span><span class="o">:</span> <span class="n">flash</span><span class="p">;</span> <span class="n">animation</span><span class="o">-</span><span class="n">name</span><span class="o">:</span> <span class="n">flash</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.consumers</span> <span class="p">{</span> <span class="k">margin-right</span><span class="o">:</span> <span class="m">2px</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.consumers</span><span class="o">,</span> <span class="nc">.live.map</span> <span class="nc">.name</span> <span class="p">{</span> <span class="k">margin-top</span><span class="o">:</span> <span class="m">4px</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.consumers</span><span class="nd">:after</span> <span class="p">{</span> <span class="k">content</span><span class="o">:</span> <span class="s2">&quot;x&quot;</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.queue</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="k">float</span><span class="o">:</span> <span class="k">left</span><span class="p">;</span> <span class="k">width</span><span class="o">:</span> <span class="m">130px</span><span class="p">;</span> <span class="k">height</span><span class="o">:</span> <span class="m">20px</span><span class="p">;</span> <span class="k">font-size</span><span class="o">:</span> <span class="m">12px</span><span class="p">;</span> <span class="k">margin-top</span><span class="o">:</span> <span class="m">2px</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.node</span> <span class="nt">g</span> <span class="nt">div</span> <span class="p">{</span> <span class="k">width</span><span class="o">:</span> <span class="m">200px</span><span class="p">;</span> <span class="k">height</span><span class="o">:</span> <span class="m">40px</span><span class="p">;</span> <span class="k">color</span><span class="o">:</span> <span class="m">#fff</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.node</span> <span class="nt">g</span> <span class="nt">div</span> <span class="nt">span</span><span class="nc">.consumers</span> <span class="p">{</span> <span class="k">display</span><span class="o">:</span> <span class="k">inline</span><span class="o">-</span><span class="k">block</span><span class="p">;</span> <span class="k">width</span><span class="o">:</span> <span class="m">20px</span><span class="p">;</span> <span class="p">}</span> <span class="nc">.live.map</span> <span class="nc">.edgeLabel</span> <span class="nt">text</span> <span class="p">{</span> <span class="k">width</span><span class="o">:</span> <span class="m">50px</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="p">}</span> <span class="nc">.live.map</span> <span class="nc">.edgePath</span> <span class="nt">path</span> <span class="p">{</span> <span class="n">stroke</span><span class="o">:</span> <span class="m">#999</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="m">#999</span><span class="p">;</span> <span class="p">}</span> <span class="nt">&lt;/style&gt;</span> <span class="nt">&lt;body&gt;</span> <span class="nt">&lt;div</span> <span class="na">class=</span><span class="s">&quot;live map&quot;</span><span class="nt">&gt;</span> <span class="nt">&lt;svg&gt;&lt;g/&gt;&lt;/svg&gt;</span> <span class="nt">&lt;/div&gt;</span> <span class="nt">&lt;script&gt;</span> <span class="kd">var</span> <span class="nx">workers</span> <span class="o">=</span> <span class="p">{</span> <span class="s2">&quot;identifier&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;consumers&quot;</span><span class="o">:</span> <span class="mi">2</span><span class="p">,</span> <span class="s2">&quot;count&quot;</span><span class="o">:</span> <span class="mi">20</span> <span class="p">},</span> <span class="s2">&quot;lost-and-found&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;consumers&quot;</span><span class="o">:</span> <span class="mi">1</span><span class="p">,</span> <span class="s2">&quot;count&quot;</span><span class="o">:</span> <span class="mi">1</span><span class="p">,</span> <span class="s2">&quot;inputQueue&quot;</span><span class="o">:</span> <span class="s2">&quot;identifier&quot;</span><span class="p">,</span> <span class="s2">&quot;inputThroughput&quot;</span><span class="o">:</span> <span class="mi">50</span> <span class="p">},</span> <span class="s2">&quot;monitor&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;consumers&quot;</span><span class="o">:</span> <span class="mi">1</span><span class="p">,</span> <span class="s2">&quot;count&quot;</span><span class="o">:</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;inputQueue&quot;</span><span class="o">:</span> <span class="s2">&quot;identifier&quot;</span><span class="p">,</span> <span class="s2">&quot;inputThroughput&quot;</span><span class="o">:</span> <span class="mi">50</span> <span class="p">},</span> <span class="s2">&quot;meta-enricher&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;consumers&quot;</span><span class="o">:</span> <span class="mi">4</span><span class="p">,</span> <span class="s2">&quot;count&quot;</span><span class="o">:</span> <span class="mi">9900</span><span class="p">,</span> <span class="s2">&quot;inputQueue&quot;</span><span class="o">:</span> <span class="s2">&quot;identifier&quot;</span><span class="p">,</span> <span class="s2">&quot;inputThroughput&quot;</span><span class="o">:</span> <span class="mi">50</span> <span class="p">},</span> <span class="s2">&quot;geo-enricher&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;consumers&quot;</span><span class="o">:</span> <span class="mi">2</span><span class="p">,</span> <span class="s2">&quot;count&quot;</span><span class="o">:</span> <span class="mi">1</span><span class="p">,</span> <span class="s2">&quot;inputQueue&quot;</span><span class="o">:</span> <span class="s2">&quot;meta-enricher&quot;</span><span class="p">,</span> <span class="s2">&quot;inputThroughput&quot;</span><span class="o">:</span> <span class="mi">50</span> <span class="p">},</span> <span class="s2">&quot;elasticsearch-writer&quot;</span><span class="o">:</span> <span class="p">{</span> <span class="s2">&quot;consumers&quot;</span><span class="o">:</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;count&quot;</span><span class="o">:</span> <span class="mi">9900</span><span class="p">,</span> <span class="s2">&quot;inputQueue&quot;</span><span class="o">:</span> <span class="s2">&quot;geo-enricher&quot;</span><span class="p">,</span> <span class="s2">&quot;inputThroughput&quot;</span><span class="o">:</span> <span class="mi">50</span> <span class="p">}</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">svg</span><span class="p">.</span><span class="nx">select</span><span class="p">(</span><span class="s2">&quot;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="kd">var</span> <span class="nx">render</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">dagreD3</span><span class="p">.</span><span class="nx">render</span><span class="p">();</span> <span class="c1">// Left-to-right layout</span> <span class="kd">var</span> <span class="nx">g</span> <span class="o">=</span> <span class="k">new</span> <span class="nx">dagreD3</span><span class="p">.</span><span class="nx">graphlib</span><span class="p">.</span><span class="nx">Graph</span><span class="p">();</span> <span class="nx">g</span><span class="p">.</span><span class="nx">setGraph</span><span class="p">({</span> <span class="nx">nodesep</span><span class="o">:</span> <span class="mi">70</span><span class="p">,</span> <span class="nx">ranksep</span><span class="o">:</span> <span class="mi">50</span><span class="p">,</span> <span class="nx">rankdir</span><span class="o">:</span> <span class="s2">&quot;LR&quot;</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">marginy</span><span class="o">:</span> <span class="mi">20</span> <span class="p">});</span> <span class="kd">function</span> <span class="nx">draw</span><span class="p">(</span><span class="nx">isUpdate</span><span class="p">)</span> <span class="p">{</span> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">id</span> <span class="k">in</span> <span class="nx">workers</span><span class="p">)</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">worker</span> <span class="o">=</span> <span class="nx">workers</span><span class="p">[</span><span class="nx">id</span><span class="p">];</span> <span class="kd">var</span> <span class="nx">className</span> <span class="o">=</span> <span class="nx">worker</span><span class="p">.</span><span class="nx">consumers</span> <span class="o">?</span> <span class="s2">&quot;running&quot;</span> <span class="o">:</span> <span class="s2">&quot;stopped&quot;</span><span class="p">;</span> <span class="k">if</span> <span class="p">(</span><span class="nx">worker</span><span class="p">.</span><span class="nx">count</span> <span class="o">&gt;</span> <span class="mi">10000</span><span class="p">)</span> <span class="p">{</span> <span class="nx">className</span> <span class="o">+=</span> <span class="s2">&quot; warn&quot;</span><span class="p">;</span> <span class="p">}</span> <span class="kd">var</span> <span class="nx">html</span> <span class="o">=</span> <span class="s2">&quot;&lt;div&gt;&quot;</span><span class="p">;</span> <span class="nx">html</span> <span class="o">+=</span> <span class="s2">&quot;&lt;span class=status&gt;&lt;/span&gt;&quot;</span><span class="p">;</span> <span class="nx">html</span> <span class="o">+=</span> <span class="s2">&quot;&lt;span class=consumers&gt;&quot;</span><span class="o">+</span><span class="nx">worker</span><span class="p">.</span><span class="nx">consumers</span><span class="o">+</span><span class="s2">&quot;&lt;/span&gt;&quot;</span><span class="p">;</span> <span class="nx">html</span> <span class="o">+=</span> <span class="s2">&quot;&lt;span class=name&gt;&quot;</span><span class="o">+</span><span class="nx">id</span><span class="o">+</span><span class="s2">&quot;&lt;/span&gt;&quot;</span><span class="p">;</span> <span class="nx">html</span> <span class="o">+=</span> <span class="s2">&quot;&lt;span class=queue&gt;&lt;span class=counter&gt;&quot;</span><span class="o">+</span><span class="nx">worker</span><span class="p">.</span><span class="nx">count</span><span class="o">+</span><span class="s2">&quot;&lt;/span&gt;&lt;/span&gt;&quot;</span><span class="p">;</span> <span class="nx">html</span> <span class="o">+=</span> <span class="s2">&quot;&lt;/div&gt;&quot;</span><span class="p">;</span> <span class="nx">g</span><span class="p">.</span><span class="nx">setNode</span><span class="p">(</span><span class="nx">id</span><span class="p">,</span> <span class="p">{</span> <span class="nx">labelType</span><span class="o">:</span> <span class="s2">&quot;html&quot;</span><span class="p">,</span> <span class="nx">label</span><span class="o">:</span> <span class="nx">html</span><span class="p">,</span> <span class="nx">rx</span><span class="o">:</span> <span class="mi">5</span><span class="p">,</span> <span class="nx">ry</span><span class="o">:</span> <span class="mi">5</span><span class="p">,</span> <span class="nx">padding</span><span class="o">:</span> <span class="mi">0</span><span class="p">,</span> <span class="kr">class</span><span class="o">:</span> <span class="nx">className</span> <span class="p">});</span> <span class="k">if</span> <span class="p">(</span><span class="nx">worker</span><span class="p">.</span><span class="nx">inputQueue</span><span class="p">)</span> <span class="p">{</span> <span class="nx">g</span><span class="p">.</span><span class="nx">setEdge</span><span class="p">(</span><span class="nx">worker</span><span class="p">.</span><span class="nx">inputQueue</span><span class="p">,</span> <span class="nx">id</span><span class="p">,</span> <span class="p">{</span> <span class="nx">label</span><span class="o">:</span> <span class="nx">worker</span><span class="p">.</span><span class="nx">inputThroughput</span> <span class="o">+</span> <span class="s2">&quot;/s&quot;</span><span class="p">,</span> <span class="nx">width</span><span class="o">:</span> <span class="mi">40</span> <span class="p">});</span> <span class="p">}</span> <span class="p">}</span> <span class="nx">inner</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="c1">// Zoom and scale to fit</span> <span class="kd">var</span> <span class="nx">zoomScale</span> <span class="o">=</span> <span class="nx">zoom</span><span class="p">.</span><span class="nx">scale</span><span class="p">();</span> <span class="kd">var</span> <span class="nx">graphWidth</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">width</span> <span class="o">+</span> <span class="mi">80</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">graphHeight</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">height</span> <span class="o">+</span> <span class="mi">40</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">width</span> <span class="o">=</span> <span class="nb">parseInt</span><span class="p">(</span><span class="nx">svg</span><span class="p">.</span><span class="nx">style</span><span class="p">(</span><span class="s2">&quot;width&quot;</span><span class="p">).</span><span class="nx">replace</span><span class="p">(</span><span class="sr">/px/</span><span class="p">,</span> <span class="s2">&quot;&quot;</span><span class="p">));</span> <span class="kd">var</span> <span class="nx">height</span> <span class="o">=</span> <span class="nb">parseInt</span><span class="p">(</span><span class="nx">svg</span><span class="p">.</span><span class="nx">style</span><span class="p">(</span><span class="s2">&quot;height&quot;</span><span class="p">).</span><span class="nx">replace</span><span class="p">(</span><span class="sr">/px/</span><span class="p">,</span> <span class="s2">&quot;&quot;</span><span class="p">));</span> <span class="nx">zoomScale</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">width</span> <span class="o">/</span> <span class="nx">graphWidth</span><span class="p">,</span> <span class="nx">height</span> <span class="o">/</span> <span class="nx">graphHeight</span><span class="p">);</span> <span class="kd">var</span> <span class="nx">translate</span> <span class="o">=</span> <span class="p">[(</span><span class="nx">width</span><span class="o">/</span><span class="mi">2</span><span class="p">)</span> <span class="o">-</span> <span class="p">((</span><span class="nx">graphWidth</span><span class="o">*</span><span class="nx">zoomScale</span><span class="p">)</span><span class="o">/</span><span class="mi">2</span><span class="p">),</span> <span class="p">(</span><span class="nx">height</span><span class="o">/</span><span class="mi">2</span><span class="p">)</span> <span class="o">-</span> <span class="p">((</span><span class="nx">graphHeight</span><span class="o">*</span><span class="nx">zoomScale</span><span class="p">)</span><span class="o">/</span><span class="mi">2</span><span class="p">)];</span> <span class="nx">zoom</span><span class="p">.</span><span class="nx">translate</span><span class="p">(</span><span class="nx">translate</span><span class="p">);</span> <span class="nx">zoom</span><span class="p">.</span><span class="nx">scale</span><span class="p">(</span><span class="nx">zoomScale</span><span class="p">);</span> <span class="nx">zoom</span><span class="p">.</span><span class="nx">event</span><span class="p">(</span><span class="nx">isUpdate</span> <span class="o">?</span> <span class="nx">svg</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="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="p">}</span> <span class="c1">// Do some mock queue status updates</span> <span class="nx">setInterval</span><span class="p">(</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="kd">var</span> <span class="nx">stoppedWorker1Count</span> <span class="o">=</span> <span class="nx">workers</span><span class="p">[</span><span class="s2">&quot;elasticsearch-writer&quot;</span><span class="p">].</span><span class="nx">count</span><span class="p">;</span> <span class="kd">var</span> <span class="nx">stoppedWorker2Count</span> <span class="o">=</span> <span class="nx">workers</span><span class="p">[</span><span class="s2">&quot;meta-enricher&quot;</span><span class="p">].</span><span class="nx">count</span><span class="p">;</span> <span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">id</span> <span class="k">in</span> <span class="nx">workers</span><span class="p">)</span> <span class="p">{</span> <span class="nx">workers</span><span class="p">[</span><span class="nx">id</span><span class="p">].</span><span class="nx">count</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">ceil</span><span class="p">(</span><span class="nb">Math</span><span class="p">.</span><span class="nx">random</span><span class="p">()</span> <span class="o">*</span> <span class="mi">3</span><span class="p">);</span> <span class="k">if</span> <span class="p">(</span><span class="nx">workers</span><span class="p">[</span><span class="nx">id</span><span class="p">].</span><span class="nx">inputThroughput</span><span class="p">)</span> <span class="nx">workers</span><span class="p">[</span><span class="nx">id</span><span class="p">].</span><span class="nx">inputThroughput</span> <span class="o">=</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">ceil</span><span class="p">(</span><span class="nb">Math</span><span class="p">.</span><span class="nx">random</span><span class="p">()</span> <span class="o">*</span> <span class="mi">250</span><span class="p">);</span> <span class="p">}</span> <span class="nx">workers</span><span class="p">[</span><span class="s2">&quot;elasticsearch-writer&quot;</span><span class="p">].</span><span class="nx">count</span> <span class="o">=</span> <span class="nx">stoppedWorker1Count</span> <span class="o">+</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">ceil</span><span class="p">(</span><span class="nb">Math</span><span class="p">.</span><span class="nx">random</span><span class="p">()</span> <span class="o">*</span> <span class="mi">100</span><span class="p">);</span> <span class="nx">workers</span><span class="p">[</span><span class="s2">&quot;meta-enricher&quot;</span><span class="p">].</span><span class="nx">count</span> <span class="o">=</span> <span class="nx">stoppedWorker2Count</span> <span class="o">+</span> <span class="nb">Math</span><span class="p">.</span><span class="nx">ceil</span><span class="p">(</span><span class="nb">Math</span><span class="p">.</span><span class="nx">random</span><span class="p">()</span> <span class="o">*</span> <span class="mi">100</span><span class="p">);</span> <span class="nx">draw</span><span class="p">(</span><span class="kc">true</span><span class="p">);</span> <span class="p">},</span> <span class="mi">1000</span><span class="p">);</span> <span class="c1">// Do a mock change of worker configuration</span> <span class="nx">setInterval</span><span class="p">(</span><span class="kd">function</span><span class="p">()</span> <span class="p">{</span> <span class="nx">workers</span><span class="p">[</span><span class="s2">&quot;elasticsearch-monitor&quot;</span><span class="p">]</span> <span class="o">=</span> <span class="p">{</span> <span class="s2">&quot;consumers&quot;</span><span class="o">:</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;count&quot;</span><span class="o">:</span> <span class="mi">0</span><span class="p">,</span> <span class="s2">&quot;inputQueue&quot;</span><span class="o">:</span> <span class="s2">&quot;elasticsearch-writer&quot;</span><span class="p">,</span> <span class="s2">&quot;inputThroughput&quot;</span><span class="o">:</span> <span class="mi">50</span> <span class="p">}</span> <span class="p">},</span> <span class="mi">5000</span><span class="p">);</span> <span class="nx">draw</span><span class="p">();</span> <span class="nt">&lt;/script&gt;</span> </pre></div> </td> </tr> </tbody> </table> </div> </body> </html>