mermaid
Version:
Markdownish syntax for generating flowcharts, sequence diagrams and gantt charts.
475 lines (399 loc) • 74.6 kB
HTML
<!DOCTYPE html>
<html>
<head>
<title>ganttRenderer.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/gantt/ganttRenderer.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="#ganttRenderer.js">ganttRenderer.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="ganttRenderer.js">
<h1>
<a href="#ganttRenderer.js" name="ganttRenderer.js" class="pilcrow">¶</a>ganttRenderer.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>
</td>
<td class="code highlight"><div class="highlight"><pre><span class="kd">var</span> <span class="nx">gantt</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'./parser/gantt'</span><span class="p">).</span><span class="nx">parser</span><span class="p">;</span>
<span class="nx">gantt</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">'./ganttDb'</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">moment</span> <span class="o">=</span> <span class="nx">require</span><span class="p">(</span><span class="s1">'moment'</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">daysInChart</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">titleTopMargin</span><span class="o">:</span> <span class="mi">25</span><span class="p">,</span>
<span class="nx">barHeight</span><span class="o">:</span> <span class="mi">20</span><span class="p">,</span>
<span class="nx">barGap</span><span class="o">:</span> <span class="mi">4</span><span class="p">,</span>
<span class="nx">topPadding</span><span class="o">:</span> <span class="mi">50</span><span class="p">,</span>
<span class="nx">sidePadding</span><span class="o">:</span> <span class="mi">75</span><span class="p">,</span>
<span class="nx">gridLineStartPadding</span><span class="o">:</span> <span class="mi">35</span><span class="p">,</span>
<span class="nx">fontSize</span><span class="o">:</span> <span class="mi">11</span><span class="p">,</span>
<span class="nx">fontFamily</span><span class="o">:</span> <span class="s1">'"Open-Sans", "sans-serif"'</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">setConf</span> <span class="o">=</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">cnf</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">keys</span> <span class="o">=</span> <span class="nb">Object</span><span class="p">.</span><span class="nx">keys</span><span class="p">(</span><span class="nx">cnf</span><span class="p">);</span>
<span class="nx">keys</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">key</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">conf</span><span class="p">[</span><span class="nx">key</span><span class="p">]</span> <span class="o">=</span> <span class="nx">cnf</span><span class="p">[</span><span class="nx">key</span><span class="p">];</span>
<span class="p">});</span>
<span class="p">};</span>
<span class="kd">var</span> <span class="nx">w</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">draw</span> <span class="o">=</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">text</span><span class="p">,</span> <span class="nx">id</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">gantt</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">clear</span><span class="p">();</span>
<span class="nx">gantt</span><span class="p">.</span><span class="nx">parse</span><span class="p">(</span><span class="nx">text</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">elem</span> <span class="o">=</span> <span class="nb">document</span><span class="p">.</span><span class="nx">getElementById</span><span class="p">(</span><span class="nx">id</span><span class="p">);</span>
<span class="nx">w</span> <span class="o">=</span> <span class="nx">elem</span><span class="p">.</span><span class="nx">parentElement</span><span class="p">.</span><span class="nx">offsetWidth</span><span class="p">;</span>
<span class="k">if</span> <span class="p">(</span><span class="k">typeof</span> <span class="nx">w</span> <span class="o">===</span> <span class="s1">'undefined'</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">w</span> <span class="o">=</span> <span class="mi">1200</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">useWidth</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">w</span> <span class="o">=</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">useWidth</span><span class="p">;</span>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">taskArray</span> <span class="o">=</span> <span class="nx">gantt</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getTasks</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>Set height based on number of tasks</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">h</span> <span class="o">=</span> <span class="nx">taskArray</span><span class="p">.</span><span class="nx">length</span> <span class="o">*</span> <span class="p">(</span><span class="nx">conf</span><span class="p">.</span><span class="nx">barHeight</span> <span class="o">+</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">barGap</span><span class="p">)</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">topPadding</span><span class="p">;</span>
<span class="nx">elem</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">'height'</span><span class="p">,</span> <span class="s2">"100%"</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>Set viewBox</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="nx">elem</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">'viewBox'</span><span class="p">,</span><span class="s1">'0 0 '</span><span class="o">+</span><span class="nx">w</span><span class="o">+</span><span class="s1">' '</span><span class="o">+</span><span class="nx">h</span><span class="p">);</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="s1">'#'</span> <span class="o">+</span> <span class="nx">id</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">dateFormat</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">time</span><span class="p">.</span><span class="nx">format</span><span class="p">(</span><span class="s2">"%Y-%m-%d"</span><span class="p">);</span>
<span class="kd">var</span> <span class="nx">startDate</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">min</span><span class="p">(</span><span class="nx">taskArray</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">startTime</span><span class="p">;</span>
<span class="p">});</span>
<span class="kd">var</span> <span class="nx">endDate</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">max</span><span class="p">(</span><span class="nx">taskArray</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">endTime</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-4" id="section-4">¶</a>
</div>
<p>Set timescale</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">timeScale</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">time</span><span class="p">.</span><span class="nx">scale</span><span class="p">()</span>
<span class="p">.</span><span class="nx">domain</span><span class="p">([</span><span class="nx">d3</span><span class="p">.</span><span class="nx">min</span><span class="p">(</span><span class="nx">taskArray</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">startTime</span><span class="p">;</span>
<span class="p">}),</span>
<span class="nx">d3</span><span class="p">.</span><span class="nx">max</span><span class="p">(</span><span class="nx">taskArray</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">endTime</span><span class="p">;</span>
<span class="p">})])</span>
<span class="p">.</span><span class="nx">rangeRound</span><span class="p">([</span><span class="mi">0</span><span class="p">,</span> <span class="nx">w</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-5" id="section-5">¶</a>
</div>
<p>.nice(d3.time.monday);</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="kd">var</span> <span class="nx">categories</span> <span class="o">=</span> <span class="p">[];</span>
<span class="nx">daysInChart</span> <span class="o">=</span> <span class="nx">moment</span><span class="p">.</span><span class="nx">duration</span><span class="p">(</span><span class="nx">endDate</span><span class="o">-</span><span class="nx">startDate</span><span class="p">).</span><span class="nx">asDays</span><span class="p">();</span>
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="nx">i</span> <span class="o"><</span> <span class="nx">taskArray</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="nx">i</span><span class="o">++</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">categories</span><span class="p">.</span><span class="nx">push</span><span class="p">(</span><span class="nx">taskArray</span><span class="p">[</span><span class="nx">i</span><span class="p">].</span><span class="nx">type</span><span class="p">);</span>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">catsUnfiltered</span> <span class="o">=</span> <span class="nx">categories</span><span class="p">;</span> <span class="c1">//for vert labels</span>
<span class="nx">categories</span> <span class="o">=</span> <span class="nx">checkUnique</span><span class="p">(</span><span class="nx">categories</span><span class="p">);</span>
<span class="nx">makeGant</span><span class="p">(</span><span class="nx">taskArray</span><span class="p">,</span> <span class="nx">w</span><span class="p">,</span> <span class="nx">h</span><span class="p">);</span>
<span class="k">if</span><span class="p">(</span><span class="k">typeof</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">useWidth</span> <span class="o">!==</span> <span class="s1">'undefined'</span><span class="p">){</span>
<span class="nx">elem</span><span class="p">.</span><span class="nx">setAttribute</span><span class="p">(</span><span class="s1">'width'</span><span class="p">,</span> <span class="nx">w</span><span class="p">);</span>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">title</span> <span class="o">=</span> <span class="nx">svg</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="p">.</span><span class="nx">text</span><span class="p">(</span><span class="nx">gantt</span><span class="p">.</span><span class="nx">yy</span><span class="p">.</span><span class="nx">getTitle</span><span class="p">())</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">w</span> <span class="o">/</span> <span class="mi">2</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">conf</span><span class="p">.</span><span class="nx">titleTopMargin</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s1">'class'</span><span class="p">,</span> <span class="s1">'titleText'</span><span class="p">);</span>
<span class="kd">function</span> <span class="nx">makeGant</span><span class="p">(</span><span class="nx">tasks</span><span class="p">,</span> <span class="nx">pageWidth</span><span class="p">,</span> <span class="nx">pageHeight</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">barHeight</span> <span class="o">=</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">barHeight</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">gap</span> <span class="o">=</span> <span class="nx">barHeight</span> <span class="o">+</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">barGap</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">topPadding</span> <span class="o">=</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">topPadding</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">sidePadding</span> <span class="o">=</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">sidePadding</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">colorScale</span> <span class="o">=</span> <span class="nx">d3</span><span class="p">.</span><span class="nx">scale</span><span class="p">.</span><span class="nx">linear</span><span class="p">()</span>
<span class="p">.</span><span class="nx">domain</span><span class="p">([</span><span class="mi">0</span><span class="p">,</span> <span class="nx">categories</span><span class="p">.</span><span class="nx">length</span><span class="p">])</span>
<span class="p">.</span><span class="nx">range</span><span class="p">([</span><span class="s2">"#00B9FA"</span><span class="p">,</span> <span class="s2">"#F95002"</span><span class="p">])</span>
<span class="p">.</span><span class="nx">interpolate</span><span class="p">(</span><span class="nx">d3</span><span class="p">.</span><span class="nx">interpolateHcl</span><span class="p">);</span>
<span class="nx">makeGrid</span><span class="p">(</span><span class="nx">sidePadding</span><span class="p">,</span> <span class="nx">topPadding</span><span class="p">,</span> <span class="nx">pageWidth</span><span class="p">,</span> <span class="nx">pageHeight</span><span class="p">);</span>
<span class="nx">drawRects</span><span class="p">(</span><span class="nx">tasks</span><span class="p">,</span> <span class="nx">gap</span><span class="p">,</span> <span class="nx">topPadding</span><span class="p">,</span> <span class="nx">sidePadding</span><span class="p">,</span> <span class="nx">barHeight</span><span class="p">,</span> <span class="nx">colorScale</span><span class="p">,</span> <span class="nx">pageWidth</span><span class="p">,</span> <span class="nx">pageHeight</span><span class="p">);</span>
<span class="nx">vertLabels</span><span class="p">(</span><span class="nx">gap</span><span class="p">,</span> <span class="nx">topPadding</span><span class="p">,</span> <span class="nx">sidePadding</span><span class="p">,</span> <span class="nx">barHeight</span><span class="p">,</span> <span class="nx">colorScale</span><span class="p">);</span>
<span class="nx">drawToday</span><span class="p">(</span><span class="nx">sidePadding</span><span class="p">,</span> <span class="nx">topPadding</span><span class="p">,</span> <span class="nx">pageWidth</span><span class="p">,</span> <span class="nx">pageHeight</span><span class="p">);</span>
<span class="p">}</span>
<span class="kd">function</span> <span class="nx">drawRects</span><span class="p">(</span><span class="nx">theArray</span><span class="p">,</span> <span class="nx">theGap</span><span class="p">,</span> <span class="nx">theTopPad</span><span class="p">,</span> <span class="nx">theSidePad</span><span class="p">,</span> <span class="nx">theBarHeight</span><span class="p">,</span> <span class="nx">theColorScale</span><span class="p">,</span> <span class="nx">w</span><span class="p">,</span> <span class="nx">h</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">bigRects</span> <span class="o">=</span> <span class="nx">svg</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="p">.</span><span class="nx">selectAll</span><span class="p">(</span><span class="s2">"rect"</span><span class="p">)</span>
<span class="p">.</span><span class="nx">data</span><span class="p">(</span><span class="nx">theArray</span><span class="p">)</span>
<span class="p">.</span><span class="nx">enter</span><span class="p">()</span>
<span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s2">"rect"</span><span class="p">)</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="mi">0</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="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">,</span> <span class="nx">i</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">i</span> <span class="o">*</span> <span class="nx">theGap</span> <span class="o">+</span> <span class="nx">theTopPad</span> <span class="o">-</span> <span class="mi">2</span><span class="p">;</span>
<span class="p">})</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"width"</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">w</span> <span class="o">-</span> <span class="nx">theSidePad</span> <span class="o">/</span> <span class="mi">2</span><span class="p">;</span>
<span class="p">})</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"height"</span><span class="p">,</span> <span class="nx">theGap</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s1">'class'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</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">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="nx">i</span> <span class="o"><</span> <span class="nx">categories</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="nx">i</span><span class="o">++</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">categories</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="p">{</span>
<span class="k">return</span> <span class="s1">'section section'</span> <span class="o">+</span> <span class="p">(</span><span class="nx">i</span> <span class="o">%</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">numberSectionStyles</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">return</span> <span class="s1">'section section0'</span><span class="p">;</span>
<span class="p">});</span>
<span class="kd">var</span> <span class="nx">rectangles</span> <span class="o">=</span> <span class="nx">svg</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="p">.</span><span class="nx">selectAll</span><span class="p">(</span><span class="s2">"rect"</span><span class="p">)</span>
<span class="p">.</span><span class="nx">data</span><span class="p">(</span><span class="nx">theArray</span><span class="p">)</span>
<span class="p">.</span><span class="nx">enter</span><span class="p">();</span>
<span class="kd">var</span> <span class="nx">innerRects</span> <span class="o">=</span> <span class="nx">rectangles</span><span class="p">.</span><span class="nx">append</span><span class="p">(</span><span class="s2">"rect"</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"rx"</span><span class="p">,</span> <span class="mi">3</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"ry"</span><span class="p">,</span> <span class="mi">3</span><span class="p">)</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="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">timeScale</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">startTime</span><span class="p">)</span> <span class="o">+</span> <span class="nx">theSidePad</span><span class="p">;</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="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">,</span> <span class="nx">i</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">i</span> <span class="o">*</span> <span class="nx">theGap</span> <span class="o">+</span> <span class="nx">theTopPad</span><span class="p">;</span>
<span class="p">})</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"width"</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="p">(</span><span class="nx">timeScale</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">endTime</span><span class="p">)</span> <span class="o">-</span> <span class="nx">timeScale</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">startTime</span><span class="p">));</span>
<span class="p">})</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"height"</span><span class="p">,</span> <span class="nx">theBarHeight</span><span class="p">)</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s1">'class'</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">res</span> <span class="o">=</span> <span class="s1">'task '</span><span class="p">;</span>
<span class="kd">var</span> <span class="nx">secNum</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="nx">i</span> <span class="o"><</span> <span class="nx">categories</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="nx">i</span><span class="o">++</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">categories</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="p">{</span>
<span class="nx">secNum</span> <span class="o">=</span> <span class="p">(</span><span class="nx">i</span> <span class="o">%</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">numberSectionStyles</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">if</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">active</span><span class="p">){</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">crit</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">res</span> <span class="o">+</span> <span class="s1">' activeCrit'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="k">return</span> <span class="nx">res</span> <span class="o">+</span> <span class="s1">' active'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">done</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">crit</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">res</span> <span class="o">+</span> <span class="s1">' doneCrit'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="k">return</span> <span class="nx">res</span> <span class="o">+</span> <span class="s1">' done'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">crit</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">res</span> <span class="o">+</span> <span class="s1">' crit'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span>
<span class="k">return</span> <span class="nx">res</span> <span class="o">+</span> <span class="s1">' task'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">})</span>
<span class="p">;</span>
<span class="kd">var</span> <span class="nx">rectText</span> <span class="o">=</span> <span class="nx">rectangles</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="p">.</span><span class="nx">text</span><span class="p">(</span><span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">task</span><span class="p">;</span>
<span class="p">})</span>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"font-size"</span><span class="p">,</span><span class="nx">conf</span><span class="p">.</span><span class="nx">fontSize</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>.attr("font-family",conf.fontFamily)</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"x"</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">startX</span> <span class="o">=</span> <span class="nx">timeScale</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">startTime</span><span class="p">),</span>
<span class="nx">endX</span> <span class="o">=</span> <span class="nx">timeScale</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">endTime</span><span class="p">),</span>
<span class="nx">textWidth</span> <span class="o">=</span> <span class="k">this</span><span class="p">.</span><span class="nx">getBBox</span><span class="p">().</span><span class="nx">width</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>Check id text width > width of rectangle</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="k">if</span> <span class="p">(</span><span class="nx">textWidth</span> <span class="o">></span> <span class="p">(</span><span class="nx">endX</span> <span class="o">-</span> <span class="nx">startX</span><span class="p">))</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">endX</span> <span class="o">+</span> <span class="nx">textWidth</span> <span class="o">+</span> <span class="mf">1.5</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">sidePadding</span><span class="o">></span> <span class="nx">w</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">startX</span> <span class="o">+</span> <span class="nx">theSidePad</span> <span class="o">-</span> <span class="mi">5</span><span class="p">;</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">endX</span> <span class="o">+</span> <span class="nx">theSidePad</span> <span class="o">+</span> <span class="mi">5</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">return</span> <span class="p">(</span><span class="nx">endX</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="o">+</span> <span class="nx">startX</span> <span class="o">+</span> <span class="nx">theSidePad</span><span class="p">;</span>
<span class="p">}</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="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">,</span> <span class="nx">i</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">i</span> <span class="o">*</span> <span class="nx">theGap</span> <span class="o">+</span> <span class="p">(</span><span class="nx">conf</span><span class="p">.</span><span class="nx">barHeight</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">conf</span><span class="p">.</span><span class="nx">fontSize</span> <span class="o">/</span> <span class="mi">2</span> <span class="o">-</span> <span class="mi">2</span><span class="p">)</span> <span class="o">+</span> <span class="nx">theTopPad</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-8" id="section-8">¶</a>
</div>
<p>.attr("text-anchor", "middle")</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="p">.</span><span class="nx">attr</span><span class="p">(</span><span class="s2">"text-height"</span><span class="p">,</span> <span class="nx">theBarHeight</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="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">startX</span> <span class="o">=</span> <span class="nx">timeScale</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">startTime</span><span class="p">),</span>
<span class="nx">endX</span> <span class="o">=</span> <span class="nx">timeScale</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">endTime</span><span class="p">),</span>
<span class="nx">textWidth</span> <span class="o">=</span> <span class="k">this</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="kd">var</span> <span class="nx">secNum</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span>
<span class="k">for</span> <span class="p">(</span><span class="kd">var</span> <span class="nx">i</span> <span class="o">=</span> <span class="mi">0</span><span class="p">;</span> <span class="nx">i</span> <span class="o"><</span> <span class="nx">categories</span><span class="p">.</span><span class="nx">length</span><span class="p">;</span> <span class="nx">i</span><span class="o">++</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">type</span> <span class="o">===</span> <span class="nx">categories</span><span class="p">[</span><span class="nx">i</span><span class="p">])</span> <span class="p">{</span>
<span class="nx">secNum</span> <span class="o">=</span> <span class="p">(</span><span class="nx">i</span> <span class="o">%</span> <span class="nx">conf</span><span class="p">.</span><span class="nx">numberSectionStyles</span><span class="p">);</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="kd">var</span> <span class="nx">taskType</span> <span class="o">=</span> <span class="s1">''</span><span class="p">;</span>
<span class="k">if</span><span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">active</span><span class="p">){</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">crit</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">taskType</span> <span class="o">=</span> <span class="s1">'activeCritText'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="nx">taskType</span> <span class="o">=</span> <span class="s1">'activeText'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">done</span><span class="p">)</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">crit</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">taskType</span> <span class="o">=</span> <span class="nx">taskType</span> <span class="o">+</span> <span class="s1">' doneCritText'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="nx">taskType</span> <span class="o">=</span> <span class="nx">taskType</span> <span class="o">+</span> <span class="s1">' doneText'</span><span class="o">+</span><span class="nx">secNum</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span><span class="k">else</span><span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">d</span><span class="p">.</span><span class="nx">crit</span><span class="p">)</span> <span class="p">{</span>
<span class="nx">taskType</span> <span class="o">=</span> <span class="nx">taskType</span> <span class="o">+</span> <span class="s1">' critText'</span><span class="o">+</span><span class="nx">secNum</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-9" id="section-9">¶</a>
</div>
<p>Check id text width > width of rectangle</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="k">if</span> <span class="p">(</span><span class="nx">textWidth</span> <span class="o">></span> <span class="p">(</span><span class="nx">endX</span> <span class="o">-</span> <span class="nx">startX</span><span class="p">))</span> <span class="p">{</span>
<span class="k">if</span> <span class="p">(</span><span class="nx">endX</span> <span class="o">+</span> <span class="nx">textWidth</span> <span class="o">+</span> <span class="mf">1.5</span><span class="o">*</span><span class="nx">conf</span><span class="p">.</span><span class="nx">sidePadding</span> <span class="o">></span> <span class="nx">w</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="s1">'taskTextOutsideLeft taskTextOutside'</span> <span class="o">+</span> <span class="nx">secNum</span> <span class="o">+</span> <span class="s1">' '</span> <span class="o">+</span> <span class="nx">taskType</span><span class="p">;</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">return</span> <span class="s1">'taskTextOutsideRight taskTextOutside'</span> <span class="o">+</span> <span class="nx">secNum</span><span class="o">+</span> <span class="s1">' '</span> <span class="o">+</span> <span class="nx">taskType</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">}</span> <span class="k">else</span> <span class="p">{</span>
<span class="k">return</span> <span class="s1">'taskText taskText'</span> <span class="o">+</span> <span class="nx">secNum</span><span class="o">+</span> <span class="s1">' '</span> <span class="o">+</span> <span class="nx">taskType</span><span class="p">;</span>
<span class="p">}</span>
<span class="p">});</span>
<span class="p">}</span>
<span class="kd">function</span> <span class="nx">makeGrid</span><span class="p">(</span><span class="nx">theSidePad</span><span class="p">,</span> <span class="nx">theTopPad</span><span class="p">,</span> <span class="nx">w</span><span class="p">,</span> <span class="nx">h</span><span class="p">)</span> <span class="p">{</span>
<span class="kd">var</span> <span class="nx">pre</span> <span class="o">=</span> <span class="p">[</span>
<span class="p">[</span><span class="s2">".%L"</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">getMilliseconds</span><span class="p">();</span>
<span class="p">}],</span>
<span class="p">[</span><span class="s2">":%S"</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">getSeconds</span><span class="p">();</span>
<span class="p">}],</span>
</pre></div>
</td>
</tr>
<tr>
<td class="docs">
<div class="pilwrap">
<a class="pilcrow" href="#section-10" id="section-10">¶</a>
</div>
<p>Within a hour</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="p">[</span><span class="s2">"h1 %I:%M"</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">getMinutes</span><span class="p">();</span>
<span class="p">}]];</span>
<span class="kd">var</span> <span class="nx">post</span> <span class="o">=</span> <span class="p">[</span>
<span class="p">[</span><span class="s2">"%Y"</span><span class="p">,</span> <span class="kd">function</span> <span class="p">()</span> <span class="p">{</span>
<span class="k">return</span> <span class="kc">true</span><span class="p">;</span>
<span class="p">}]];</span>
<span class="kd">var</span> <span class="nx">mid</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-11" id="section-11">¶</a>
</div>
<p>Within a day</p>
</td>
<td class="code highlight"><div class="highlight"><pre>
<span class="p">[</span><span class="s2">"%I:%M"</span><span class="p">,</span> <span class="kd">function</span> <span class="p">(</span><span class="nx">d</span><span class="p">)</span> <span class="p">{</span>
<span class="k">return</span> <span class="nx">d</span><span class="p">.</span><span class="nx">getHours</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>
<p>Day within a week (not monday)</p