diff --git a/dist/frappe-charts.esm.js b/dist/frappe-charts.esm.js
index 073a9f7..6eb4198 100644
--- a/dist/frappe-charts.esm.js
+++ b/dist/frappe-charts.esm.js
@@ -982,7 +982,7 @@ function getPaths(xList, yList, color, options={}, meta={}) {
};
// Region
- if(options.regionFill) {
+ if(options.areaFill) {
let gradient_id_region = makeGradient(meta.svgDefs, color, true);
let pathStr = "M" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;
@@ -2177,7 +2177,7 @@ let componentConfigs = {
c.color,
{
heatline: c.heatline,
- regionFill: c.regionFill
+ areaFill: c.areaFill
},
{
svgDefs: c.svgDefs,
@@ -3406,7 +3406,7 @@ class AxisChart extends BaseChart {
color: this.colors[index],
svgDefs: this.svgDefs,
heatline: this.lineOptions.heatline,
- regionFill: this.lineOptions.regionFill,
+ areaFill: this.lineOptions.areaFill,
hideDots: this.lineOptions.hideDots,
hideLine: this.lineOptions.hideLine,
diff --git a/dist/frappe-charts.min.cjs.js b/dist/frappe-charts.min.cjs.js
index 95a53d8..021f99b 100644
--- a/dist/frappe-charts.min.cjs.js
+++ b/dist/frappe-charts.min.cjs.js
@@ -1198,7 +1198,7 @@ function getPaths(xList, yList, color) {
};
// Region
- if (options.regionFill) {
+ if (options.areaFill) {
var gradient_id_region = makeGradient(meta.svgDefs, color, true);
var pathStr = "M" + (xList[0] + ',' + meta.zeroLine + 'L') + pointsStr + ('L' + xList.slice(-1)[0] + ',' + meta.zeroLine);
@@ -2578,7 +2578,7 @@ var componentConfigs = {
if (!c.hideLine) {
this.paths = getPaths(data.xPositions, data.yPositions, c.color, {
heatline: c.heatline,
- regionFill: c.regionFill
+ areaFill: c.areaFill
}, {
svgDefs: c.svgDefs,
zeroLine: data.zeroLine
@@ -3978,7 +3978,7 @@ var AxisChart = function (_BaseChart) {
color: _this3.colors[index],
svgDefs: _this3.svgDefs,
heatline: _this3.lineOptions.heatline,
- regionFill: _this3.lineOptions.regionFill,
+ areaFill: _this3.lineOptions.areaFill,
hideDots: _this3.lineOptions.hideDots,
hideLine: _this3.lineOptions.hideLine,
diff --git a/dist/frappe-charts.min.cjs.js.map b/dist/frappe-charts.min.cjs.js.map
index deb96cc..00bfa93 100644
--- a/dist/frappe-charts.min.cjs.js.map
+++ b/dist/frappe-charts.min.cjs.js.map
@@ -1 +1 @@
-{"version":3,"file":"frappe-charts.min.cjs.js","sources":["../src/js/utils/dom.js","../src/js/utils/constants.js","../src/js/objects/SvgTip.js","../src/js/utils/helpers.js","../src/js/utils/draw-utils.js","../src/js/utils/colors.js","../src/js/utils/draw.js","../src/js/utils/animate.js","../src/js/utils/animation.js","../src/css/chartsCss.js","../src/js/utils/export.js","../src/js/charts/BaseChart.js","../src/js/charts/AggregationChart.js","../src/js/utils/date-utils.js","../src/js/objects/ChartComponents.js","../src/js/charts/PercentageChart.js","../src/js/charts/PieChart.js","../src/js/utils/intervals.js","../src/js/charts/Heatmap.js","../src/js/utils/axis-chart-utils.js","../src/js/charts/AxisChart.js","../src/js/chart.js"],"sourcesContent":["export function $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function findNodeIndex(node)\n{\n\tvar i = 0;\n\twhile (node.previousSibling) {\n\t\tnode = node.previousSibling;\n\t\ti++;\n\t}\n\treturn i;\n}\n\n$.create = (tag, o) => {\n\tvar element = document.createElement(tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"onClick\" ) {\n\t\t\telement.addEventListener('click', val);\n\n\t\t} else if (i === \"onInput\" ) {\n\t\t\telement.addEventListener('input', function(e) {\n\t\t\t\tval(element.value);\n\t\t\t});\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (i in element ) {\n\t\t\telement[i] = val;\n\t\t}\n\t\telse {\n\t\t\telement.setAttribute(i, val);\n\t\t}\n\t}\n\n\treturn element;\n};\n\nexport function getOffset(element) {\n\tlet rect = element.getBoundingClientRect();\n\treturn {\n\t\t// https://stackoverflow.com/a/7436602/6495043\n\t\t// rect.top varies with scroll, so we add whatever has been\n\t\t// scrolled to it to get absolute distance from actual page top\n\t\ttop: rect.top + (document.documentElement.scrollTop || document.body.scrollTop),\n\t\tleft: rect.left + (document.documentElement.scrollLeft || document.body.scrollLeft)\n\t};\n}\n\nexport function isElementInViewport(el) {\n\t// Although straightforward: https://stackoverflow.com/a/7557433/6495043\n\tvar rect = el.getBoundingClientRect();\n\n\treturn (\n\t\trect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */\n rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */\n\t);\n}\n\nexport function getElementContentWidth(element) {\n\tvar styles = window.getComputedStyle(element);\n\tvar padding = parseFloat(styles.paddingLeft) +\n\t\tparseFloat(styles.paddingRight);\n\n\treturn element.clientWidth - padding;\n}\n\nexport function bind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function (event) {\n\t\t\t\telement.addEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function unbind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function(event) {\n\t\t\t\telement.removeEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function fire(target, type, properties) {\n\tvar evt = document.createEvent(\"HTMLEvents\");\n\n\tevt.initEvent(type, true, true );\n\n\tfor (var j in properties) {\n\t\tevt[j] = properties[j];\n\t}\n\n\treturn target.dispatchEvent(evt);\n}\n\n// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/\nexport function forEachNode(nodeList, callback, scope) {\n\tif(!nodeList) return;\n\tfor (var i = 0; i < nodeList.length; i++) {\n\t\tcallback.call(scope, nodeList[i], i);\n\t}\n}\n\nexport function activate($parent, $child, commonSelector, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`${commonSelector}.${activeClass}`);\n\n\tif (typeof $child === 'string') {\n\t\t$child = $parent.querySelector($child);\n\t}\n\n\tthis.forEachNode($children, (node, i) => {\n\t\tif(index >= 0 && i <= index) return;\n\t\tnode.classList.remove(activeClass);\n\t})\n\n\t$child.classList.add(activeClass);\n}\n\nexport function insertAfter(newNode, referenceNode) {\n referenceNode.parentNode.insertBefore(newNode, referenceNode.nextSibling);\n}\n","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const AXIS_CHART_DEFAULT_TYPE = 'line';\nexport const AXIS_CHART_MIXED_TYPE = 'axis-mixed';\nexport const AXIS_CHART_TYPES = ['line', 'bar', 'axis-mixed'];\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_CHART_OPTIONS = {\n\tbarOptions: {\n\t\tspaceRatio: 1,\n\t}\n}\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 1;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.02;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `\n\t\t\t\t
\n\t\t\t\t`\n\t\t});\n\t\tthis.hideTip();\n\n\t\tthis.title = this.container.querySelector('.title');\n\t\tthis.dataPointList = this.container.querySelector('.data-point-list');\n\n\t\tthis.parent.addEventListener('mouseleave', () => {\n\t\t\tthis.hideTip();\n\t\t});\n\t}\n\n\tfill() {\n\t\tlet title;\n\t\tif(this.index) {\n\t\t\tthis.container.setAttribute('data-point-index', this.index);\n\t\t}\n\t\tif(this.titleValueFirst) {\n\t\t\ttitle = `${this.titleValue}${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}${this.titleValue}`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `${ value === 0 || value ? value : '' }\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\nexport function toTitleCase(str) {\n return str.replace(/\\w*/g, function(txt){return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();});\n}\n","import { fillArray } from './helpers';\n\nexport function getBarHeightAndYAttr(yTop, zeroLine) {\n\tlet height, y;\n\tif (yTop <= zeroLine) {\n\t\theight = zeroLine - yTop;\n\t\ty = yTop;\n\t} else {\n\t\theight = yTop - zeroLine;\n\t\ty = zeroLine;\n\t}\n\n\treturn [height, y];\n}\n\nexport function equilizeNoOfElements(array1, array2,\n\textraCount = array2.length - array1.length) {\n\n\t// Doesn't work if either has zero elements.\n\tif(extraCount > 0) {\n\t\tarray1 = fillArray(array1, extraCount);\n\t} else {\n\t\tarray2 = fillArray(array2, extraCount);\n\t}\n\treturn [array1, array2];\n}\n","const PRESET_COLOR_MAP = {\n\t'light-blue': '#7cd6fd',\n\t'blue': '#5e64ff',\n\t'violet': '#743ee2',\n\t'red': '#ff5858',\n\t'orange': '#ffa00a',\n\t'yellow': '#feef72',\n\t'green': '#28a745',\n\t'light-green': '#98d85b',\n\t'purple': '#b554ff',\n\t'magenta': '#ffa3ef',\n\t'black': '#36114C',\n\t'grey': '#bdd3e6',\n\t'light-grey': '#f0f4f7',\n\t'dark-grey': '#b8c2cc'\n};\n\nfunction limitColor(r){\n\tif (r > 255) return 255;\n\telse if (r < 0) return 0;\n\treturn r;\n}\n\nexport function lightenDarkenColor(color, amt) {\n\tlet col = getColor(color);\n\tlet usePound = false;\n\tif (col[0] == \"#\") {\n\t\tcol = col.slice(1);\n\t\tusePound = true;\n\t}\n\tlet num = parseInt(col,16);\n\tlet r = limitColor((num >> 16) + amt);\n\tlet b = limitColor(((num >> 8) & 0x00FF) + amt);\n\tlet g = limitColor((num & 0x0000FF) + amt);\n\treturn (usePound?\"#\":\"\") + (g | (b << 8) | (r << 16)).toString(16);\n}\n\nexport function isValidColor(string) {\n\t// https://stackoverflow.com/a/8027444/6495043\n\treturn /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(string);\n}\n\nexport const getColor = (color) => {\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\nimport { getStringWidth } from './helpers';\nimport { DOT_OVERLAY_SIZE_INCR, PERCENTAGE_BAR_DEFAULT_DEPTH } from './constants';\nimport { lightenDarkenColor } from './colors';\n\nexport const AXIS_TICK_LENGTH = 6;\nconst LABEL_MARGIN = 4;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none') {\n\treturn createSVG('path', {\n\t\tclassName: className,\n\t\td: pathStr,\n\t\tstyles: {\n\t\t\tstroke: stroke,\n\t\t\tfill: fill\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 0 ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeGradient(svgDefElem, color, lighter = false) {\n\tlet gradientId ='path-fill-gradient' + '-' + color + '-' +(lighter ? 'lighter' : 'default');\n\tlet gradientDef = renderVerticalGradient(svgDefElem, gradientId);\n\tlet opacities = [1, 0.6, 0.2];\n\tif(lighter) {\n\t\topacities = [0.4, 0.2, 0];\n\t}\n\n\tsetGradientStop(gradientDef, \"0%\", color, opacities[0]);\n\tsetGradientStop(gradientDef, \"50%\", color, opacities[1]);\n\tsetGradientStop(gradientDef, \"100%\", color, opacities[2]);\n\n\treturn gradientId;\n}\n\nexport function percentageBar(x, y, width, height,\n\tdepth=PERCENTAGE_BAR_DEFAULT_DEPTH, fill='none') {\n\n\tlet args = {\n\t\tclassName: 'percentage-bar',\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height,\n\t\tfill: fill,\n\t\tstyles: {\n\t\t\t'stroke': lightenDarkenColor(fill, -25),\n\t\t\t// Diabolically good: https://stackoverflow.com/a/9000859\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/stroke-dasharray\n\t\t\t'stroke-dasharray': `0, ${height + width}, ${width}, ${height}`,\n\t\t\t'stroke-width': depth\n\t\t},\n\t};\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function heatSquare(className, x, y, size, fill='none', data={}) {\n\tlet args = {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: size,\n\t\theight: size,\n\t\tfill: fill\n\t};\n\n\tObject.keys(data).map(key => {\n\t\targs[key] = data[key];\n\t});\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function legendBar(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-bar',\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: size,\n\t\theight: '2px',\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE * 2) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"rect\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function legendDot(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-dot',\n\t\tcx: 0,\n\t\tcy: 0,\n\t\tr: size,\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdx: (FONT_SIZE) + 'px',\n\t\tdy: (FONT_SIZE/3) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"circle\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function makeText(className, x, y, content, options = {}) {\n\tlet fontSize = options.fontSize || FONT_SIZE;\n\tlet dy = options.dy !== undefined ? options.dy : (fontSize / 2);\n\tlet fill = options.fill || FONT_FILL;\n\tlet textAnchor = options.textAnchor || 'start';\n\treturn createSVG('text', {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\tdy: dy + 'px',\n\t\t'font-size': fontSize + 'px',\n\t\tfill: fill,\n\t\t'text-anchor': textAnchor,\n\t\tinnerHTML: content\n\t});\n}\n\nfunction makeVertLine(x, label, y1, y2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tlet l = createSVG('line', {\n\t\tclassName: 'line-vertical ' + options.className,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: y1,\n\t\ty2: y2,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: 0,\n\t\ty: y1 > y2 ? y1 + LABEL_MARGIN : y1 - LABEL_MARGIN - FONT_SIZE,\n\t\tdy: FONT_SIZE + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'middle',\n\t\tinnerHTML: label + \"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(${ x }, 0)`\n\t});\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nfunction makeHoriLine(y, label, x1, x2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.lineType) options.lineType = '';\n\tlet className = 'line-horizontal ' + options.className +\n\t\t(options.lineType === \"dashed\" ? \"dashed\": \"\");\n\n\tlet l = createSVG('line', {\n\t\tclassName: className,\n\t\tx1: x1,\n\t\tx2: x2,\n\t\ty1: 0,\n\t\ty2: 0,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: x1 < x2 ? x1 - LABEL_MARGIN : x1 + LABEL_MARGIN,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / 2 - 2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': x1 < x2 ? 'end' : 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(0, ${y})`,\n\t\t'stroke-opacity': 1\n\t});\n\n\tif(text === 0 || text === '0') {\n\t\tline.style.stroke = \"rgba(27, 31, 35, 0.6)\";\n\t}\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nexport function yLine(y, label, width, options={}) {\n\tif(!options.pos) options.pos = 'left';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\tlet x1 = -1 * AXIS_TICK_LENGTH;\n\tlet x2 = options.mode === 'span' ? width + AXIS_TICK_LENGTH : 0;\n\n\tif(options.mode === 'tick' && options.pos === 'right') {\n\t\tx1 = width + AXIS_TICK_LENGTH;\n\t\tx2 = width;\n\t}\n\n\t// let offset = options.pos === 'left' ? -1 * options.offset : options.offset;\n\n\tx1 += options.offset;\n\tx2 += options.offset;\n\n\treturn makeHoriLine(y, label, x1, x2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.regionFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\n\nexport const UNIT_ANIM_DUR = 350;\nexport const PATH_ANIM_DUR = 350;\nexport const MARKER_LINE_ANIM_DUR = UNIT_ANIM_DUR;\nexport const REPLACE_ALL_NEW_DUR = 250;\n\nexport const STD_EASING = 'easein';\n\nexport function translate(unit, oldCoord, newCoord, duration) {\n\tlet old = typeof oldCoord === 'string' ? oldCoord : oldCoord.join(', ');\n\treturn [\n\t\tunit,\n\t\t{transform: newCoord.join(', ')},\n\t\tduration,\n\t\tSTD_EASING,\n\t\t\"translate\",\n\t\t{transform: old}\n\t];\n}\n\nexport function translateVertLine(xLine, newX, oldX) {\n\treturn translate(xLine, [oldX, 0], [newX, 0], MARKER_LINE_ANIM_DUR);\n}\n\nexport function translateHoriLine(yLine, newY, oldY) {\n\treturn translate(yLine, [0, oldY], [0, newY], MARKER_LINE_ANIM_DUR);\n}\n\nexport function animateRegion(rectGroup, newY1, newY2, oldY2) {\n\tlet newHeight = newY1 - newY2;\n\tlet rect = rectGroup.childNodes[0];\n\tlet width = rect.getAttribute(\"width\");\n\tlet rectAnim = [\n\t\trect,\n\t\t{ height: newHeight, 'stroke-dasharray': `${width}, ${newHeight}` },\n\t\tMARKER_LINE_ANIM_DUR,\n\t\tSTD_EASING\n\t];\n\n\tlet groupAnim = translate(rectGroup, [0, oldY2], [0, newY2], MARKER_LINE_ANIM_DUR);\n\treturn [rectAnim, groupAnim];\n}\n\nexport function animateBar(bar, x, yTop, width, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\tif(bar.nodeName !== 'rect') {\n\t\tlet rect = bar.childNodes[0];\n\t\tlet rectAnim = [\n\t\t\trect,\n\t\t\t{width: width, height: height},\n\t\t\tUNIT_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\n\t\tlet oldCoordStr = bar.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(bar, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [rectAnim, groupAnim];\n\t} else {\n\t\treturn [[bar, {width: width, height: height, x: x, y: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// bar.animate({height: args.newHeight, y: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animateDot(dot, x, y) {\n\tif(dot.nodeName !== 'circle') {\n\t\tlet oldCoordStr = dot.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(dot, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [groupAnim];\n\t} else {\n\t\treturn [[dot, {cx: x, cy: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// dot.animate({cy: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animatePath(paths, newXList, newYList, zeroLine) {\n\tlet pathComponents = [];\n\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y));\n\tlet pathStr = pointsStr.join(\"L\");\n\n\tconst animPath = [paths.path, {d:\"M\"+pathStr}, PATH_ANIM_DUR, STD_EASING];\n\tpathComponents.push(animPath);\n\n\tif(paths.region) {\n\t\tlet regStartPt = `${newXList[0]},${zeroLine}L`;\n\t\tlet regEndPt = `L${newXList.slice(-1)[0]}, ${zeroLine}`;\n\n\t\tconst animRegion = [\n\t\t\tpaths.region,\n\t\t\t{d:\"M\" + regStartPt + pathStr + regEndPt},\n\t\t\tPATH_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\t\tpathComponents.push(animRegion);\n\t}\n\n\treturn pathComponents;\n}\n\nexport function animatePathStr(oldPath, pathStr) {\n\treturn [oldPath, {d: pathStr}, UNIT_ANIM_DUR, STD_EASING];\n}\n","// Leveraging SMIL Animations\n\nimport { REPLACE_ALL_NEW_DUR } from './animate';\n\nconst EASING = {\n\tease: \"0.25 0.1 0.25 1\",\n\tlinear: \"0 0 1 1\",\n\t// easein: \"0.42 0 1 1\",\n\teasein: \"0.1 0.8 0.2 1\",\n\teaseout: \"0 0 0.58 1\",\n\teaseinout: \"0.42 0 0.58 1\"\n};\n\nfunction animateSVGElement(element, props, dur, easingType=\"linear\", type=undefined, oldValues={}) {\n\n\tlet animElement = element.cloneNode(true);\n\tlet newElement = element.cloneNode(true);\n\n\tfor(var attributeName in props) {\n\t\tlet animateElement;\n\t\tif(attributeName === 'transform') {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animateTransform\");\n\t\t} else {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animate\");\n\t\t}\n\t\tlet currentValue = oldValues[attributeName] || element.getAttribute(attributeName);\n\t\tlet value = props[attributeName];\n\n\t\tlet animAttr = {\n\t\t\tattributeName: attributeName,\n\t\t\tfrom: currentValue,\n\t\t\tto: value,\n\t\t\tbegin: \"0s\",\n\t\t\tdur: dur/1000 + \"s\",\n\t\t\tvalues: currentValue + \";\" + value,\n\t\t\tkeySplines: EASING[easingType],\n\t\t\tkeyTimes: \"0;1\",\n\t\t\tcalcMode: \"spline\",\n\t\t\tfill: 'freeze'\n\t\t};\n\n\t\tif(type) {\n\t\t\tanimAttr[\"type\"] = type;\n\t\t}\n\n\t\tfor (var i in animAttr) {\n\t\t\tanimateElement.setAttribute(i, animAttr[i]);\n\t\t}\n\n\t\tanimElement.appendChild(animateElement);\n\n\t\tif(type) {\n\t\t\tnewElement.setAttribute(attributeName, `translate(${value})`);\n\t\t} else {\n\t\t\tnewElement.setAttribute(attributeName, value);\n\t\t}\n\t}\n\n\treturn [animElement, newElement];\n}\n\nexport function transform(element, style) { // eslint-disable-line no-unused-vars\n\telement.style.transform = style;\n\telement.style.webkitTransform = style;\n\telement.style.msTransform = style;\n\telement.style.mozTransform = style;\n\telement.style.oTransform = style;\n}\n\nfunction animateSVG(svgContainer, elements) {\n\tlet newElements = [];\n\tlet animElements = [];\n\n\telements.map(element => {\n\t\tlet unit = element[0];\n\t\tlet parent = unit.parentNode;\n\n\t\tlet animElement, newElement;\n\n\t\telement[0] = unit;\n\t\t[animElement, newElement] = animateSVGElement(...element);\n\n\t\tnewElements.push(newElement);\n\t\tanimElements.push([animElement, parent]);\n\n\t\tparent.replaceChild(animElement, unit);\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\telements[i][0] = newElements[i];\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\n\nlet BOUND_DRAW_FN;\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || 'line';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tBOUND_DRAW_FN = this.boundDrawFn.bind(this);\n\t\twindow.addEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents() {\n\t\twindow.removeEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t\tthis.parent.style.overflow = 'auto';\n\t\t}\n\n\t\tthis.container = $.create('div', args);\n\t}\n\n\tmakeTooltip() {\n\t\tthis.tip = new SvgTip({\n\t\t\tparent: this.container,\n\t\t\tcolors: this.colors\n\t\t});\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {}\n\n\tdraw(onlyWidthChange=false, init=false) {\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { legendDot } from '../utils/draw';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.maxSlices = args.maxSlices || 20;\n\t\tthis.config.maxLegendPoints = args.maxLegendPoints || 20;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\t\tlet maxSlices = this.config.maxSlices;\n\t\ts.sliceTotals = [];\n\n\t\tlet allTotals = this.data.labels.map((label, i) => {\n\t\t\tlet total = 0;\n\t\t\tthis.data.datasets.map(e => {\n\t\t\t\ttotal += e.values[i];\n\t\t\t});\n\t\t\treturn [total, label];\n\t\t}).filter(d => { return d[0] >= 0; }); // keep only positive results\n\n\t\tlet totals = allTotals;\n\t\tif(allTotals.length > maxSlices) {\n\t\t\t// Prune and keep a grey area for rest as per maxSlices\n\t\t\tallTotals.sort((a, b) => { return b[0] - a[0]; });\n\n\t\t\ttotals = allTotals.slice(0, maxSlices-1);\n\t\t\tlet remaining = allTotals.slice(maxSlices-1);\n\n\t\t\tlet sumOfRemaining = 0;\n\t\t\tremaining.map(d => {sumOfRemaining += d[0];});\n\t\t\ttotals.push([sumOfRemaining, 'Rest']);\n\t\t\tthis.colors[maxSlices-1] = 'grey';\n\t\t}\n\n\t\ts.labels = [];\n\t\ttotals.map(d => {\n\t\t\ts.sliceTotals.push(d[0]);\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${s.labels[i]}: ${d}`\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport { makeText, makePath, xLine, yLine, yMarker, yRegion, datasetBar, datasetDot, percentageBar, getPaths, heatSquare } from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport { translateHoriLine, translateVertLine, animateRegion, animateBar,\n\tanimateDot, animatePath, animatePathStr } from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n\tconstructor({\n\t\tlayerClass = '',\n\t\tlayerTransform = '',\n\t\tconstants,\n\n\t\tgetData,\n\t\tmakeElements,\n\t\tanimateElements\n\t}) {\n\t\tthis.layerTransform = layerTransform;\n\t\tthis.constants = constants;\n\n\t\tthis.makeElements = makeElements;\n\t\tthis.getData = getData;\n\n\t\tthis.animateElements = animateElements;\n\n\t\tthis.store = [];\n\t\tthis.labels = [];\n\n\t\tthis.layerClass = layerClass;\n\t\tthis.layerClass = typeof(this.layerClass) === 'function'\n\t\t\t? this.layerClass() : this.layerClass;\n\n\t\tthis.refresh();\n\t}\n\n\trefresh(data) {\n\t\tthis.data = data || this.getData();\n\t}\n\n\tsetup(parent) {\n\t\tthis.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n\t}\n\n\tmake() {\n\t\tthis.render(this.data);\n\t\tthis.oldData = this.data;\n\t}\n\n\trender(data) {\n\t\tthis.store = this.makeElements(data);\n\n\t\tthis.layer.textContent = '';\n\t\tthis.store.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t\tthis.labels.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t}\n\n\tupdate(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tpieSlices: {\n\t\tlayerClass: 'pie-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) =>{\n\t\t\t\tlet slice = makePath(s, 'pie-path', 'none', data.colors[i]);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) =>\n\t\t\t\tanimatePathStr(slice, newData.sliceStrings[i])\n\t\t\t);\n\t\t}\n\t},\n\tpercentageBars: {\n\t\tlayerClass: 'percentage-bars',\n\t\tmakeElements(data) {\n\t\t\treturn data.xPositions.map((x, i) =>{\n\t\t\t\tlet y = 0;\n\t\t\t\tlet bar = percentageBar(x, y, data.widths[i],\n\t\t\t\t\tthis.constants.barHeight, this.constants.barDepth, data.colors[i]);\n\t\t\t\treturn bar;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\tyAxis: {\n\t\tlayerClass: 'y axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\tyLine(position, data.labels[i], this.constants.width,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.labels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tlabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(m =>\n\t\t\t\tyMarker(m.position, m.label, this.constants.width,\n\t\t\t\t\t{labelPos: m.options.labelPos, mode: 'span', lineType: 'dashed'})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, day.fill, data);\n\t\t\t\t\t\tthis.serializedSubDomains.push(square);\n\t\t\t\t\t}\n\t\t\t\t\ty += rowHeight;\n\t\t\t\t});\n\t\t\t\ty = 0;\n\t\t\t\tx += colWidth;\n\t\t\t});\n\n\t\t\treturn this.serializedSubDomains;\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\n\tbarGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-bars dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'bar';\n\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\treturn datasetBar(\n\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\ty,\n\t\t\t\t\tdata.barWidth,\n\t\t\t\t\tc.color,\n\t\t\t\t\tdata.labels[j],\n\t\t\t\t\tj,\n\t\t\t\t\tdata.offsets[j],\n\t\t\t\t\t{\n\t\t\t\t\t\tzeroLine: data.zeroLine,\n\t\t\t\t\t\tbarsWidth: data.barsWidth,\n\t\t\t\t\t\tminHeight: c.minHeight\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t});\n\t\t\treturn this.units;\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newOffsets = newData.offsets;\n\t\t\tlet newLabels = newData.labels;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldOffsets = this.oldData.offsets;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldOffsets, newOffsets] = equilizeNoOfElements(oldOffsets, newOffsets);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\toffsets: oldOffsets,\n\t\t\t\tlabels: newLabels,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tbarsWidth: this.oldData.barsWidth,\n\t\t\t\tbarWidth: this.oldData.barWidth,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((bar, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateBar(\n\t\t\t\t\tbar, newXPos[i], newYPos[i], newData.barWidth, newOffsets[i],\n\t\t\t\t\t{zeroLine: newData.zeroLine}\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\tlineGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-line dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'dot';\n\t\t\tthis.paths = {};\n\t\t\tif(!c.hideLine) {\n\t\t\t\tthis.paths = getPaths(\n\t\t\t\t\tdata.xPositions,\n\t\t\t\t\tdata.yPositions,\n\t\t\t\t\tc.color,\n\t\t\t\t\t{\n\t\t\t\t\t\theatline: c.heatline,\n\t\t\t\t\t\tregionFill: c.regionFill\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tsvgDefs: c.svgDefs,\n\t\t\t\t\t\tzeroLine: data.zeroLine\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.units = [];\n\t\t\tif(!c.hideDots) {\n\t\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\t\treturn datasetDot(\n\t\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\t\ty,\n\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\tc.color,\n\t\t\t\t\t\t(c.valuesOverPoints ? data.values[j] : ''),\n\t\t\t\t\t\tj\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn Object.values(this.paths).concat(this.units);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newValues = newData.values;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldValues = this.oldData.values;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldValues, newValues] = equilizeNoOfElements(oldValues, newValues);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\tvalues: newValues,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tradius: this.oldData.radius,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tif(Object.keys(this.paths).length) {\n\t\t\t\tanimateElements = animateElements.concat(animatePath(\n\t\t\t\t\tthis.paths, newXPos, newYPos, newData.zeroLine));\n\t\t\t}\n\n\t\t\tif(this.units.length) {\n\t\t\t\tthis.units.map((dot, i) => {\n\t\t\t\t\tanimateElements = animateElements.concat(animateDot(\n\t\t\t\t\t\tdot, newXPos[i], newYPos[i]));\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn animateElements;\n\t\t}\n\t}\n};\n\nexport function getComponent(name, constants, getData) {\n\tlet keys = Object.keys(componentConfigs).filter(k => name.includes(k));\n\tlet config = componentConfigs[keys[0]];\n\tObject.assign(config, {\n\t\tconstants: constants,\n\t\tgetData: getData\n\t});\n\treturn new ChartComponent(config);\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 80;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class PieChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'pie';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius = (this.height > this.width ? this.center.x : this.center.y);\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath = makeArcPathStr(curStart, curEnd, this.center, this.radius, this.clockWise);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import { floatTwo } from './helpers';\n\nfunction normalize(x) {\n\t// Calculates mantissa and exponent of a number\n\t// Returns normalized number and exponent\n\t// https://stackoverflow.com/q/9383593/6495043\n\n\tif(x===0) {\n\t\treturn [0, 0];\n\t}\n\tif(isNaN(x)) {\n\t\treturn {mantissa: -6755399441055744, exponent: 972};\n\t}\n\tvar sig = x > 0 ? 1 : -1;\n\tif(!isFinite(x)) {\n\t\treturn {mantissa: sig * 4503599627370496, exponent: 972};\n\t}\n\n\tx = Math.abs(x);\n\tvar exp = Math.floor(Math.log10(x));\n\tvar man = x/Math.pow(10, exp);\n\n\treturn [sig * man, exp];\n}\n\nfunction getChartRangeIntervals(max, min=0) {\n\tlet upperBound = Math.ceil(max);\n\tlet lowerBound = Math.floor(min);\n\tlet range = upperBound - lowerBound;\n\n\tlet noOfParts = range;\n\tlet partSize = 1;\n\n\t// To avoid too many partitions\n\tif(range > 5) {\n\t\tif(range % 2 !== 0) {\n\t\t\tupperBound++;\n\t\t\t// Recalc range\n\t\t\trange = upperBound - lowerBound;\n\t\t}\n\t\tnoOfParts = range/2;\n\t\tpartSize = 2;\n\t}\n\n\t// Special case: 1 and 2\n\tif(range <= 2) {\n\t\tnoOfParts = 4;\n\t\tpartSize = range/noOfParts;\n\t}\n\n\t// Special case: 0\n\tif(range === 0) {\n\t\tnoOfParts = 5;\n\t\tpartSize = 1;\n\t}\n\n\tlet intervals = [];\n\tfor(var i = 0; i <= noOfParts; i++){\n\t\tintervals.push(lowerBound + partSize * i);\n\t}\n\treturn intervals;\n}\n\nfunction getChartIntervals(maxValue, minValue=0) {\n\tlet [normalMaxValue, exponent] = normalize(maxValue);\n\tlet normalMinValue = minValue ? minValue/Math.pow(10, exponent): 0;\n\n\t// Allow only 7 significant digits\n\tnormalMaxValue = normalMaxValue.toFixed(6);\n\n\tlet intervals = getChartRangeIntervals(normalMaxValue, normalMinValue);\n\tintervals = intervals.map(value => value * Math.pow(10, exponent));\n\treturn intervals;\n}\n\nexport function calcChartIntervals(values, withMinimum=false) {\n\t//*** Where the magic happens ***\n\n\t// Calculates best-fit y intervals from given values\n\t// and returns the interval array\n\n\tlet maxValue = Math.max(...values);\n\tlet minValue = Math.min(...values);\n\n\t// Exponent to be used for pretty print\n\tlet exponent = 0, intervals = []; // eslint-disable-line no-unused-vars\n\n\tfunction getPositiveFirstIntervals(maxValue, absMinValue) {\n\t\tlet intervals = getChartIntervals(maxValue);\n\n\t\tlet intervalSize = intervals[1] - intervals[0];\n\n\t\t// Then unshift the negative values\n\t\tlet value = 0;\n\t\tfor(var i = 1; value < absMinValue; i++) {\n\t\t\tvalue += intervalSize;\n\t\t\tintervals.unshift((-1) * value);\n\t\t}\n\t\treturn intervals;\n\t}\n\n\t// CASE I: Both non-negative\n\n\tif(maxValue >= 0 && minValue >= 0) {\n\t\texponent = normalize(maxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(maxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(maxValue, minValue);\n\t\t}\n\t}\n\n\t// CASE II: Only minValue negative\n\n\telse if(maxValue > 0 && minValue < 0) {\n\t\t// `withMinimum` irrelevant in this case,\n\t\t// We'll be handling both sides of zero separately\n\t\t// (both starting from zero)\n\t\t// Because ceil() and floor() behave differently\n\t\t// in those two regions\n\n\t\tlet absMinValue = Math.abs(minValue);\n\n\t\tif(maxValue >= absMinValue) {\n\t\t\texponent = normalize(maxValue)[1];\n\t\t\tintervals = getPositiveFirstIntervals(maxValue, absMinValue);\n\t\t} else {\n\t\t\t// Mirror: maxValue => absMinValue, then change sign\n\t\t\texponent = normalize(absMinValue)[1];\n\t\t\tlet posIntervals = getPositiveFirstIntervals(absMinValue, maxValue);\n\t\t\tintervals = posIntervals.map(d => d * (-1));\n\t\t}\n\n\t}\n\n\t// CASE III: Both non-positive\n\n\telse if(maxValue <= 0 && minValue <= 0) {\n\t\t// Mirrored Case I:\n\t\t// Work with positives, then reverse the sign and array\n\n\t\tlet pseudoMaxValue = Math.abs(minValue);\n\t\tlet pseudoMinValue = Math.abs(maxValue);\n\n\t\texponent = normalize(pseudoMaxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue, pseudoMinValue);\n\t\t}\n\n\t\tintervals = intervals.reverse().map(d => d * (-1));\n\t}\n\n\treturn intervals;\n}\n\nexport function getZeroIndex(yPts) {\n\tlet zeroIndex;\n\tlet interval = getIntervalSize(yPts);\n\tif(yPts.indexOf(0) >= 0) {\n\t\t// the range has a given zero\n\t\t// zero-line on the chart\n\t\tzeroIndex = yPts.indexOf(0);\n\t} else if(yPts[0] > 0) {\n\t\t// Minimum value is positive\n\t\t// zero-line is off the chart: below\n\t\tlet min = yPts[0];\n\t\tzeroIndex = (-1) * min / interval;\n\t} else {\n\t\t// Maximum value is negative\n\t\t// zero-line is off the chart: above\n\t\tlet max = yPts[yPts.length - 1];\n\t\tzeroIndex = (-1) * max / interval + (yPts.length - 1);\n\t}\n\treturn zeroIndex;\n}\n\nexport function getRealIntervals(max, noOfIntervals, min = 0, asc = 1) {\n\tlet range = max - min;\n\tlet part = range * 1.0 / noOfIntervals;\n\tlet intervals = [];\n\n\tfor(var i = 0; i <= noOfIntervals; i++) {\n\t\tintervals.push(min + part * i);\n\t}\n\n\treturn asc ? intervals : intervals.reverse();\n}\n\nexport function getIntervalSize(orderedArray) {\n\treturn orderedArray[1] - orderedArray[0];\n}\n\nexport function getValueRange(orderedArray) {\n\treturn orderedArray[orderedArray.length-1] - orderedArray[0];\n}\n\nexport function scale(val, yAxis) {\n\treturn floatTwo(yAxis.zeroLine - val * yAxis.scaleMultiplier);\n}\n\nexport function isInRange(val, min, max) {\n\treturn val > min && val < max;\n}\n\nexport function isInRange2D(coord, minCoord, maxCoord) {\n\treturn isInRange(coord[0], minCoord[0], maxCoord[0])\n\t\t&& isInRange(coord[1], minCoord[1], maxCoord[1]);\n}\n\nexport function getClosestInArray(goal, arr, index = false) {\n\tlet closest = arr.reduce(function(prev, curr) {\n\t\treturn (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);\n\t});\n\n\treturn index ? arr.indexOf(closest) : closest;\n}\n\nexport function calcDistribution(values, distributionSize) {\n\t// Assume non-negative values,\n\t// implying distribution minimum at zero\n\n\tlet dataMaxValue = Math.max(...values);\n\n\tlet distributionStep = 1 / (distributionSize - 1);\n\tlet distribution = [];\n\n\tfor(var i = 0; i < distributionSize; i++) {\n\t\tlet checkpoint = dataMaxValue * (distributionStep * i);\n\t\tdistribution.push(checkpoint);\n\t}\n\n\treturn distribution;\n}\n\nexport function getMaxCheckpoint(value, distribution) {\n\treturn distribution.filter(d => d < value).length;\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\txTranslate: s.domainConfigs\n\t\t\t\t\t.filter((config, j) => j < i)\n\t\t\t\t\t.map(config => config.cols.length - lessCol)\n\t\t\t\t\t.reduce((a, b) => a + b, 0)\n\t\t\t\t\t* COL_WIDTH\n\t\t\t},\n\t\t\tfunction() {\n\t\t\t\treturn s.domainConfigs[i];\n\t\t\t}.bind(this)\n\n\t\t]);\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map((args, i) => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0] + '-' + i, component];\n\t\t\t})\n\t\t);\n\n\t\tlet y = 0;\n\t\tDAY_NAMES_SHORT.forEach((dayName, i) => {\n\t\t\tif([1, 3, 5].includes(i)) {\n\t\t\t\tlet dayText = makeText('subdomain-name', -COL_WIDTH/2, y, dayName,\n\t\t\t\t\t{\n\t\t\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\t\t\tdy: 8,\n\t\t\t\t\t\ttextAnchor: 'end'\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tthis.drawArea.appendChild(dayText);\n\t\t\t}\n\t\t\ty += ROW_HEIGHT;\n\t\t});\n\t}\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\n\t\tthis.data = this.prepareData(data);\n\t\tthis.draw();\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tthis.components.forEach(comp => {\n\t\t\t\tlet daySquares = comp.store;\n\t\t\t\tlet daySquare = e.target;\n\t\t\t\tif(daySquares.includes(daySquare)) {\n\n\t\t\t\t\tlet count = daySquare.getAttribute('data-value');\n\t\t\t\t\tlet dateParts = daySquare.getAttribute('data-date').split('-');\n\n\t\t\t\t\tlet month = getMonthName(parseInt(dateParts[1])-1, true);\n\n\t\t\t\t\tlet gOff = this.container.getBoundingClientRect(), pOff = daySquare.getBoundingClientRect();\n\n\t\t\t\t\tlet width = parseInt(e.target.getAttribute('width'));\n\t\t\t\t\tlet x = pOff.left - gOff.left + width/2;\n\t\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\t\tlet value = count + ' ' + this.countLabel;\n\t\t\t\t\tlet name = ' on ' + month + ' ' + dateParts[0] + ', ' + dateParts[2];\n\n\t\t\t\t\tthis.tip.setValues(x, y, {name: name, value: value, valueFirst: 1}, []);\n\t\t\t\t\tthis.tip.showTip();\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\trenderLegend() {\n\t\tthis.legendArea.textContent = '';\n\t\tlet x = 0;\n\t\tlet y = ROW_HEIGHT;\n\n\t\tlet lessText = makeText('subdomain-name', x, y, 'Less',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tx = (COL_WIDTH * 2) + COL_WIDTH/2;\n\t\tthis.legendArea.appendChild(lessText);\n\n\t\tthis.colors.slice(0, HEATMAP_DISTRIBUTION_SIZE).map((color, i) => {\n\t\t\tconst square = heatSquare('heatmap-legend-unit', x + (COL_WIDTH + 3) * i,\n\t\t\t\ty, HEATMAP_SQUARE_SIZE, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import { fillArray } from '../utils/helpers';\nimport { AXIS_CHART_DEFAULT_TYPE, AXIS_CHART_MIXED_TYPE, AXIS_DATASET_CHART_TYPES, DEFAULT_CHAR_WIDTH } from '../utils/constants';\n\nexport function dataPrep(data, type) {\n\tdata.labels = data.labels || [];\n\n\tlet datasetLength = data.labels.length;\n\n\t// Datasets\n\tlet datasets = data.datasets;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\tif(!datasets) {\n\t\t// default\n\t\tdatasets = [{\n\t\t\tvalues: zeroArray\n\t\t}];\n\t}\n\n\tlet overridingType;\n\tif(AXIS_DATASET_CHART_TYPES.includes(type)) {\n\t\toverridingType = type;\n\t};\n\n\tdatasets.map(d=> {\n\t\t// Set values\n\t\tif(!d.values) {\n\t\t\td.values = zeroArray;\n\t\t} else {\n\t\t\t// Check for non values\n\t\t\tlet vals = d.values;\n\t\t\tvals = vals.map(val => (!isNaN(val) ? val : 0));\n\n\t\t\t// Trim or extend\n\t\t\tif(vals.length > datasetLength) {\n\t\t\t\tvals = vals.slice(0, datasetLength);\n\t\t\t} else {\n\t\t\t\tvals = fillArray(vals, datasetLength - vals.length, 0);\n\t\t\t}\n\t\t}\n\n\t\t// Set labels\n\n\t\t// Set type\n\t\tif(overridingType) {\n\t\t\td.chartType = overridingType;\n\t\t} else if(!d.chartType) {\n\t\t\td.chartType = AXIS_CHART_DEFAULT_TYPE;\n\t\t}\n\t});\n\n\t// Markers\n\n\t// Regions\n\t// data.yRegions = data.yRegions || [];\n\tif(data.yRegions) {\n\t\tdata.yRegions.map(d => {\n\t\t\tif(d.end < d.start) {\n\t\t\t\t[d.start, d.end] = [d.end, d.start];\n\t\t\t}\n\t\t});\n\t}\n\n\treturn data;\n}\n\nexport function zeroDataPrep(realData) {\n\tlet datasetLength = realData.labels.length;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\n\tlet zeroData = {\n\t\tlabels: realData.labels.slice(0, -1),\n\t\tdatasets: realData.datasets.map(d => {\n\t\t\treturn {\n\t\t\t\tname: '',\n\t\t\t\tvalues: zeroArray.slice(0, -1),\n\t\t\t\tchartType: d.chartType\n\t\t\t};\n\t\t}),\n\t};\n\n\tif(realData.yMarkers) {\n\t\tzeroData.yMarkers = [\n\t\t\t{\n\t\t\t\tvalue: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\tif(realData.yRegions) {\n\t\tzeroData.yRegions = [\n\t\t\t{\n\t\t\t\tstart: 0,\n\t\t\t\tend: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\treturn zeroData;\n}\n\nexport function getShortenedLabels(chartWidth, labels=[], isSeries=true) {\n\tlet allowedSpace = chartWidth / labels.length;\n\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet calcLabels = labels.map((label, i) => {\n\t\tlabel += \"\";\n\t\tif(label.length > allowedLetters) {\n\n\t\t\tif(!isSeries) {\n\t\t\t\tif(allowedLetters-3 > 0) {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters-3) + \" ...\";\n\t\t\t\t} else {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters) + '..';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlet multiple = Math.ceil(label.length/allowedLetters);\n\t\t\t\tif(i % multiple !== 0) {\n\t\t\t\t\tlabel = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn label;\n\t});\n\n\treturn calcLabels;\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n\t\tsuper.configure(options);\n\n\t\toptions.axisOptions = options.axisOptions || {};\n\t\toptions.tooltipOptions = options.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = options.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = options.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = options.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\tcalcYAxisParameters(dataValues, withMinimum = 'false') {\n\t\tconst yPts = calcChartIntervals(dataValues, withMinimum);\n\t\tconst scaleMultiplier = this.height / getValueRange(yPts);\n\t\tconst intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n\t\tconst zeroLine = this.height - (getZeroIndex(yPts) * intervalHeight);\n\n\t\tthis.state.yAxis = {\n\t\t\tlabels: yPts,\n\t\t\tpositions: yPts.map(d => zeroLine - d * scaleMultiplier),\n\t\t\tscaleMultiplier: scaleMultiplier,\n\t\t\tzeroLine: zeroLine,\n\t\t};\n\n\t\t// Dependent if above changes\n\t\tthis.calcDatasetPoints();\n\t\tthis.calcYExtremes();\n\t\tthis.calcYRegions();\n\t}\n\n\tcalcDatasetPoints() {\n\t\tlet s = this.state;\n\t\tlet scaleAll = values => values.map(val => scale(val, s.yAxis));\n\n\t\ts.datasets = this.data.datasets.map((d, i) => {\n\t\t\tlet values = d.values;\n\t\t\tlet cumulativeYs = d.cumulativeYs || [];\n\t\t\treturn {\n\t\t\t\tname: d.name,\n\t\t\t\tindex: i,\n\t\t\t\tchartType: d.chartType,\n\n\t\t\t\tvalues: values,\n\t\t\t\tyPositions: scaleAll(values),\n\n\t\t\t\tcumulativeYs: cumulativeYs,\n\t\t\t\tcumulativeYPos: scaleAll(cumulativeYs),\n\t\t\t};\n\t\t});\n\t}\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n\tgetAllYValues() {\n\t\tlet key = 'values';\n\n\t\tif(this.barOptions.stacked) {\n\t\t\tkey = 'cumulativeYs';\n\t\t\tlet cumulative = new Array(this.state.datasetLength).fill(0);\n\t\t\tthis.data.datasets.map((d, i) => {\n\t\t\t\tlet values = this.data.datasets[i].values;\n\t\t\t\td[key] = cumulative = cumulative.map((c, i) => c + values[i]);\n\t\t\t});\n\t\t}\n\n\t\tlet allValueLists = this.data.datasets.map(d => d[key]);\n\t\tif(this.data.yMarkers) {\n\t\t\tallValueLists.push(this.data.yMarkers.map(d => d.value));\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.data.yRegions.map(d => {\n\t\t\t\tallValueLists.push([d.end, d.start]);\n\t\t\t});\n\t\t}\n\n\t\treturn [].concat(...allValueLists);\n\t}\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'yAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.yAxisMode,\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'xAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.xAxisMode,\n\t\t\t\t\theight: this.height,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\ts.xAxis.calcLabels = getShortenedLabels(this.width,\n\t\t\t\t\t\ts.xAxis.labels, this.config.xIsSeries);\n\n\t\t\t\t\treturn s.xAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'yRegions',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yRegions;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\t\t];\n\n\t\tlet barDatasets = this.state.datasets.filter(d => d.chartType === 'bar');\n\t\tlet lineDatasets = this.state.datasets.filter(d => d.chartType === 'line');\n\n\t\tlet barsConfigs = barDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'barGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tstacked: this.barOptions.stacked,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t\tminHeight: this.height * MIN_BAR_PERCENT_HEIGHT,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet stacked = this.barOptions.stacked;\n\n\t\t\t\t\tlet spaceRatio = this.barOptions.spaceRatio || BAR_CHART_SPACE_RATIO;\n\t\t\t\t\tlet barsWidth = s.unitWidth/2 * (2 - spaceRatio);\n\t\t\t\t\tlet barWidth = barsWidth/(stacked ? 1 : barDatasets.length);\n\n\t\t\t\t\tlet xPositions = s.xAxis.positions.map(x => x - barsWidth/2);\n\t\t\t\t\tif(!stacked) {\n\t\t\t\t\t\txPositions = xPositions.map(p => p + barWidth * index);\n\t\t\t\t\t}\n\n\t\t\t\t\tlet labels = new Array(s.datasetLength).fill('');\n\t\t\t\t\tif(this.config.valuesOverPoints) {\n\t\t\t\t\t\tif(stacked && d.index === s.datasets.length - 1) {\n\t\t\t\t\t\t\tlabels = d.cumulativeYs;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tlabels = d.values;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet offsets = new Array(s.datasetLength).fill(0);\n\t\t\t\t\tif(stacked) {\n\t\t\t\t\t\toffsets = d.yPositions.map((y, j) => y - d.cumulativeYPos[j]);\n\t\t\t\t\t}\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: xPositions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\t\t\t\t\t\toffsets: offsets,\n\t\t\t\t\t\t// values: d.values,\n\t\t\t\t\t\tlabels: labels,\n\n\t\t\t\t\t\tzeroLine: s.yAxis.zeroLine,\n\t\t\t\t\t\tbarsWidth: barsWidth,\n\t\t\t\t\t\tbarWidth: barWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet lineConfigs = lineDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'lineGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tsvgDefs: this.svgDefs,\n\t\t\t\t\theatline: this.lineOptions.heatline,\n\t\t\t\t\tregionFill: this.lineOptions.regionFill,\n\t\t\t\t\thideDots: this.lineOptions.hideDots,\n\t\t\t\t\thideLine: this.lineOptions.hideLine,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet minLine = s.yAxis.positions[0] < s.yAxis.zeroLine\n\t\t\t\t\t\t? s.yAxis.positions[0] : s.yAxis.zeroLine;\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xAxis.positions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\n\t\t\t\t\t\tvalues: d.values,\n\n\t\t\t\t\t\tzeroLine: minLine,\n\t\t\t\t\t\tradius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tlet dbi = this.dataByIndex[index];\n\n\t\tthis.tip.setValues(\n\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\tdbi.values,\n\t\t\tindex\n\t\t);\n\n\t\tthis.tip.showTip();\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name);\n\t\t\t\tthis.legendArea.appendChild(rect);\n\t\t\t});\n\t\t}\n\t}\n\n\n\n\t// Overlay\n\tmakeOverlay() {\n\t\tif(this.init) {\n\t\t\tthis.init = 0;\n\t\t\treturn;\n\t\t}\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\n\t\tthis.overlayGuides = this.dataUnitComponents.map(c => {\n\t\t\treturn {\n\t\t\t\ttype: c.unitType,\n\t\t\t\toverlay: undefined,\n\t\t\t\tunits: c.units,\n\t\t\t};\n\t\t});\n\n\t\tif(this.state.currentIndex === undefined) {\n\t\t\tthis.state.currentIndex = this.state.datasetLength - 1;\n\t\t}\n\n\t\t// Render overlays\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\n\t\t\td.overlay = makeOverlay[d.type](currentUnit);\n\t\t\tthis.drawArea.appendChild(d.overlay);\n\t\t});\n\t}\n\n\tupdateOverlayGuides() {\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\t}\n\n\tbindOverlay() {\n\t\tthis.parent.addEventListener('data-select', () => {\n\t\t\tthis.updateOverlay();\n\t\t});\n\t}\n\n\tbindUnits() {\n\t\tthis.dataUnitComponents.map(c => {\n\t\t\tc.units.map(unit => {\n\t\t\t\tunit.addEventListener('click', () => {\n\t\t\t\t\tlet index = unit.getAttribute('data-point-index');\n\t\t\t\t\tthis.setCurrentDataPoint(index);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\t// Note: Doesn't work as tooltip is absolutely positioned\n\t\tthis.tip.container.addEventListener('click', () => {\n\t\t\tlet index = this.tip.container.getAttribute('data-point-index');\n\t\t\tthis.setCurrentDataPoint(index);\n\t\t});\n\t}\n\n\tupdateOverlay() {\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\t\t\tupdateOverlay[d.type](currentUnit, d.overlay);\n\t\t});\n\t}\n\n\tonLeftArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex - 1);\n\t}\n\n\tonRightArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex + 1);\n\t}\n\n\tgetDataPoint(index=this.state.currentIndex) {\n\t\tlet s = this.state;\n\t\tlet data_point = {\n\t\t\tindex: index,\n\t\t\tlabel: s.xAxis.labels[index],\n\t\t\tvalues: s.datasets.map(d => d.values[index])\n\t\t};\n\t\treturn data_point;\n\t}\n\n\tsetCurrentDataPoint(index) {\n\t\tlet s = this.state;\n\t\tindex = parseInt(index);\n\t\tif(index < 0) index = 0;\n\t\tif(index >= s.xAxis.labels.length) index = s.xAxis.labels.length - 1;\n\t\tif(index === s.currentIndex) return;\n\t\ts.currentIndex = index;\n\t\tfire(this.parent, \"data-select\", this.getDataPoint());\n\t}\n\n\n\n\t// API\n\taddDataPoint(label, datasetValues, index=this.state.datasetLength) {\n\t\tsuper.addDataPoint(label, datasetValues, index);\n\t\tthis.data.labels.splice(index, 0, label);\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\td.values.splice(index, 0, datasetValues[i]);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tremoveDataPoint(index = this.state.datasetLength-1) {\n\t\tif (this.data.labels.length <= 1) {\n\t\t\treturn;\n\t\t}\n\t\tsuper.removeDataPoint(index);\n\t\tthis.data.labels.splice(index, 1);\n\t\tthis.data.datasets.map(d => {\n\t\t\td.values.splice(index, 1);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tupdateDataset(datasetValues, index=0) {\n\t\tthis.data.datasets[index].values = datasetValues;\n\t\tthis.update(this.data);\n\t}\n\t// addDataset(dataset, index) {}\n\t// removeDataset(index = 0) {}\n\n\tupdateDatasets(datasets) {\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\tif(datasets[i]) {\n\t\t\t\td.values = datasets[i];\n\t\t\t}\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\t// updateDataPoint(dataPoint, index = 0) {}\n\t// addDataPoint(dataPoint, index = 0) {}\n\t// removeDataPoint(index = 0) {}\n}\n","import '../css/charts.scss';\n\n// import MultiAxisChart from './charts/MultiAxisChart';\nimport PercentageChart from './charts/PercentageChart';\nimport PieChart from './charts/PieChart';\nimport Heatmap from './charts/Heatmap';\nimport AxisChart from './charts/AxisChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };"],"names":["$","expr","con","document","querySelector","create","tag","o","element","createElement","i","val","appendChild","ref","parentNode","insertBefore","addEventListener","e","value","keys","map","style","prop","setAttribute","getOffset","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isElementInViewport","el","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","type","properties","evt","createEvent","initEvent","j","dispatchEvent","BASE_MEASURES","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","totalExtraHeight","legendHeight","getExtraWidth","totalExtraWidth","INIT_CHART_UPDATE_TIMEOUT","CHART_POST_ANIMATE_TIMEOUT","AXIS_CHART_DEFAULT_TYPE","AXIS_DATASET_CHART_TYPES","AXIS_LEGEND_BAR_SIZE","BAR_CHART_SPACE_RATIO","MIN_BAR_PERCENT_HEIGHT","LINE_CHART_DOT_SIZE","DOT_OVERLAY_SIZE_INCR","PERCENTAGE_BAR_DEFAULT_HEIGHT","PERCENTAGE_BAR_DEFAULT_DEPTH","HEATMAP_DISTRIBUTION_SIZE","HEATMAP_SQUARE_SIZE","HEATMAP_GUTTER_SIZE","DEFAULT_CHAR_WIDTH","TOOLTIP_POINTER_TRIANGLE_HEIGHT","DEFAULT_CHART_COLORS","HEATMAP_COLORS_GREEN","DEFAULT_COLORS","ANGLE_RATIO","Math","PI","FULL_ANGLE","SvgTip","parent","colors","titleName","titleValue","listValues","titleValueFirst","x","y","setup","makeTooltip","fill","calcPosition","container","hideTip","title","dataPointList","index","innerHTML","set","color","formatted","li","width","offsetWidth","offsetHeight","maxLeft","pointer","delta","pointerOffset","name","valueFirst","refresh","opacity","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","abs","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","cos","getBarHeightAndYAttr","yTop","zeroLine","height","equilizeNoOfElements","array1","array2","extraCount","PRESET_COLOR_MAP","limitColor","r","lightenDarkenColor","amt","col","getColor","usePound","slice","num","parseInt","b","g","toString","isValidColor","test","AXIS_TICK_LENGTH","LABEL_MARGIN","FONT_SIZE","BASE_LINE_COLOR","FONT_FILL","createSVG","createElementNS","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","makeSVGContainer","className","makeSVGDefs","svgContainer","makeSVGGroup","transform","undefined","args","inside","makePath","pathStr","stroke","makeArcPathStr","startPosition","endPosition","center","clockWise","arcStartX","arcStartY","arcEndX","arcEndY","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","heatSquare","size","data","key","legendBar","label","text","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","l","line","makeHoriLine","x1","x2","lineType","yLine","pos","mode","xLine","yMarker","labelPos","labelSvg","yRegion","region","datasetBar","meta","minHeight","datasetDot","dot","getPaths","xList","yList","pointsList","pointsStr","join","path","heatline","gradient_id","svgDefs","paths","regionFill","gradient_id_region","makeOverlay","unit","transformValue","nodeName","getAttribute","childNodes","overlay","cloneNode","updateOverlay","attributes","values","filter","includes","attr","specified","nodeValue","UNIT_ANIM_DUR","PATH_ANIM_DUR","MARKER_LINE_ANIM_DUR","REPLACE_ALL_NEW_DUR","STD_EASING","translate","oldCoord","newCoord","duration","old","translateVertLine","newX","oldX","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","rectAnim","groupAnim","animateBar","bar","oldCoordStr","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","push","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","EASING","animateSVGElement","props","dur","easingType","oldValues","animElement","newElement","attributeName","animateElement","currentValue","animAttr","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","CSSTEXT","downloadFile","filename","a","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","firstChild","BOUND_DRAW_FN","BaseChart","HTMLElement","Error","rawChartArgs","realData","prepareData","prepareFirstData","validateColors","config","isNavigable","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","bind","draw","removeEventListener","makeContainer","updateWidth","independentWidth","overflow","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","c","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","error","animate","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","event","keyCode","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","labels","total","datasets","totals","sort","remaining","sumOfRemaining","grandTotal","reduce","textContent","legendTotals","barWidth","divisor","floor","NO_OF_YEAR_MONTHS","NO_OF_DAYS_IN_WEEK","NO_OF_MILLIS","SEC_IN_DAY","MONTH_NAMES","DAY_NAMES_SHORT","treatAsUtc","date","result","Date","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","getTime","getWeeksBetween","startDate","endDate","weekStartDate","setDayToSunday","ceil","getDaysBetween","millisecondsPerDay","areInSameMonth","getMonthName","short","monthName","getLastDateInMonth","month","year","newDate","day","getDay","addDays","numberOfDays","setDate","ChartComponent","layerClass","layerTransform","constants","getData","makeElements","animateElements","store","layer","oldData","componentConfigs","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","newOptions","startPos","endPos","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","monthNameHeight","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","offsets","barsWidth","newXPos","newYPos","newOffsets","oldXPos","oldYPos","oldOffsets","hideLine","hideDots","valuesOverPoints","Object","newValues","getComponent","k","assign","PercentageChart","barOptions","component","xPos","bars","get","indexOf","gOff","pOff","formattedLabels","fraction","setValues","showTip","PieChart","mouseMove","mouseLeave","hoverRadio","startAngle","prevSlicesProperties","slicesProperties","curAngle","originDiffAngle","diffAngle","endAngle","prevProperty","curStart","curEnd","curPath","property","flag","calTranslateByAngle","g_off","pageX","pageY","formatted_labels","percent","slices","prevIndex","curActiveSliceIndex","prevAcitve","curActiveSlice","hoverSlice","normalize","isNaN","mantissa","exponent","sig","isFinite","exp","log10","man","pow","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","withMinimum","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","posIntervals","pseudoMaxValue","pseudoMinValue","reverse","getZeroIndex","yPts","zeroIndex","interval","getIntervalSize","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","prev","curr","calcDistribution","distributionSize","dataMaxValue","distributionStep","distribution","checkpoint","getMaxCheckpoint","COL_WIDTH","ROW_HEIGHT","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","spacing","end","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","moreTextX","moreText","startMonth","startYear","endMonth","endYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","dataPrep","datasetLength","zeroArray","overridingType","vals","chartType","yRegions","zeroDataPrep","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedSpace","allowedLetters","multiple","AxisChart","lineOptions","axisOptions","tooltipOptions","xAxisMode","yAxisMode","xIsSeries","formatTooltipX","formatTooltipY","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","xAxis","dataValues","intervalHeight","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","cumulativeYs","stacked","yExtremes","cumulativeYPos","cumulative","allValueLists","barDatasets","lineDatasets","barsConfigs","spaceRatio","p","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","titles","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","setCurrentDataPoint","data_point","getDataPoint","datasetValues","splice","chartTypes","getChartByType","Chart"],"mappings":"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"}
\ No newline at end of file
+{"version":3,"file":"frappe-charts.min.cjs.js","sources":["../src/js/utils/dom.js","../src/js/utils/constants.js","../src/js/objects/SvgTip.js","../src/js/utils/helpers.js","../src/js/utils/draw-utils.js","../src/js/utils/colors.js","../src/js/utils/draw.js","../src/js/utils/animate.js","../src/js/utils/animation.js","../src/css/chartsCss.js","../src/js/utils/export.js","../src/js/charts/BaseChart.js","../src/js/charts/AggregationChart.js","../src/js/utils/date-utils.js","../src/js/objects/ChartComponents.js","../src/js/charts/PercentageChart.js","../src/js/charts/PieChart.js","../src/js/utils/intervals.js","../src/js/charts/Heatmap.js","../src/js/utils/axis-chart-utils.js","../src/js/charts/AxisChart.js","../src/js/chart.js"],"sourcesContent":["export function $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function findNodeIndex(node)\n{\n\tvar i = 0;\n\twhile (node.previousSibling) {\n\t\tnode = node.previousSibling;\n\t\ti++;\n\t}\n\treturn i;\n}\n\n$.create = (tag, o) => {\n\tvar element = document.createElement(tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"onClick\" ) {\n\t\t\telement.addEventListener('click', val);\n\n\t\t} else if (i === \"onInput\" ) {\n\t\t\telement.addEventListener('input', function(e) {\n\t\t\t\tval(element.value);\n\t\t\t});\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (i in element ) {\n\t\t\telement[i] = val;\n\t\t}\n\t\telse {\n\t\t\telement.setAttribute(i, val);\n\t\t}\n\t}\n\n\treturn element;\n};\n\nexport function getOffset(element) {\n\tlet rect = element.getBoundingClientRect();\n\treturn {\n\t\t// https://stackoverflow.com/a/7436602/6495043\n\t\t// rect.top varies with scroll, so we add whatever has been\n\t\t// scrolled to it to get absolute distance from actual page top\n\t\ttop: rect.top + (document.documentElement.scrollTop || document.body.scrollTop),\n\t\tleft: rect.left + (document.documentElement.scrollLeft || document.body.scrollLeft)\n\t};\n}\n\nexport function isElementInViewport(el) {\n\t// Although straightforward: https://stackoverflow.com/a/7557433/6495043\n\tvar rect = el.getBoundingClientRect();\n\n\treturn (\n\t\trect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */\n rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */\n\t);\n}\n\nexport function getElementContentWidth(element) {\n\tvar styles = window.getComputedStyle(element);\n\tvar padding = parseFloat(styles.paddingLeft) +\n\t\tparseFloat(styles.paddingRight);\n\n\treturn element.clientWidth - padding;\n}\n\nexport function bind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function (event) {\n\t\t\t\telement.addEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function unbind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function(event) {\n\t\t\t\telement.removeEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function fire(target, type, properties) {\n\tvar evt = document.createEvent(\"HTMLEvents\");\n\n\tevt.initEvent(type, true, true );\n\n\tfor (var j in properties) {\n\t\tevt[j] = properties[j];\n\t}\n\n\treturn target.dispatchEvent(evt);\n}\n\n// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/\nexport function forEachNode(nodeList, callback, scope) {\n\tif(!nodeList) return;\n\tfor (var i = 0; i < nodeList.length; i++) {\n\t\tcallback.call(scope, nodeList[i], i);\n\t}\n}\n\nexport function activate($parent, $child, commonSelector, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`${commonSelector}.${activeClass}`);\n\n\tif (typeof $child === 'string') {\n\t\t$child = $parent.querySelector($child);\n\t}\n\n\tthis.forEachNode($children, (node, i) => {\n\t\tif(index >= 0 && i <= index) return;\n\t\tnode.classList.remove(activeClass);\n\t})\n\n\t$child.classList.add(activeClass);\n}\n\nexport function insertAfter(newNode, referenceNode) {\n referenceNode.parentNode.insertBefore(newNode, referenceNode.nextSibling);\n}\n","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const AXIS_CHART_DEFAULT_TYPE = 'line';\nexport const AXIS_CHART_MIXED_TYPE = 'axis-mixed';\nexport const AXIS_CHART_TYPES = ['line', 'bar', 'axis-mixed'];\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_CHART_OPTIONS = {\n\tbarOptions: {\n\t\tspaceRatio: 1,\n\t}\n}\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 1;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.02;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `\n\t\t\t\t\n\t\t\t\t`\n\t\t});\n\t\tthis.hideTip();\n\n\t\tthis.title = this.container.querySelector('.title');\n\t\tthis.dataPointList = this.container.querySelector('.data-point-list');\n\n\t\tthis.parent.addEventListener('mouseleave', () => {\n\t\t\tthis.hideTip();\n\t\t});\n\t}\n\n\tfill() {\n\t\tlet title;\n\t\tif(this.index) {\n\t\t\tthis.container.setAttribute('data-point-index', this.index);\n\t\t}\n\t\tif(this.titleValueFirst) {\n\t\t\ttitle = `${this.titleValue}${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}${this.titleValue}`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `${ value === 0 || value ? value : '' }\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\nexport function toTitleCase(str) {\n return str.replace(/\\w*/g, function(txt){return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();});\n}\n","import { fillArray } from './helpers';\n\nexport function getBarHeightAndYAttr(yTop, zeroLine) {\n\tlet height, y;\n\tif (yTop <= zeroLine) {\n\t\theight = zeroLine - yTop;\n\t\ty = yTop;\n\t} else {\n\t\theight = yTop - zeroLine;\n\t\ty = zeroLine;\n\t}\n\n\treturn [height, y];\n}\n\nexport function equilizeNoOfElements(array1, array2,\n\textraCount = array2.length - array1.length) {\n\n\t// Doesn't work if either has zero elements.\n\tif(extraCount > 0) {\n\t\tarray1 = fillArray(array1, extraCount);\n\t} else {\n\t\tarray2 = fillArray(array2, extraCount);\n\t}\n\treturn [array1, array2];\n}\n","const PRESET_COLOR_MAP = {\n\t'light-blue': '#7cd6fd',\n\t'blue': '#5e64ff',\n\t'violet': '#743ee2',\n\t'red': '#ff5858',\n\t'orange': '#ffa00a',\n\t'yellow': '#feef72',\n\t'green': '#28a745',\n\t'light-green': '#98d85b',\n\t'purple': '#b554ff',\n\t'magenta': '#ffa3ef',\n\t'black': '#36114C',\n\t'grey': '#bdd3e6',\n\t'light-grey': '#f0f4f7',\n\t'dark-grey': '#b8c2cc'\n};\n\nfunction limitColor(r){\n\tif (r > 255) return 255;\n\telse if (r < 0) return 0;\n\treturn r;\n}\n\nexport function lightenDarkenColor(color, amt) {\n\tlet col = getColor(color);\n\tlet usePound = false;\n\tif (col[0] == \"#\") {\n\t\tcol = col.slice(1);\n\t\tusePound = true;\n\t}\n\tlet num = parseInt(col,16);\n\tlet r = limitColor((num >> 16) + amt);\n\tlet b = limitColor(((num >> 8) & 0x00FF) + amt);\n\tlet g = limitColor((num & 0x0000FF) + amt);\n\treturn (usePound?\"#\":\"\") + (g | (b << 8) | (r << 16)).toString(16);\n}\n\nexport function isValidColor(string) {\n\t// https://stackoverflow.com/a/8027444/6495043\n\treturn /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(string);\n}\n\nexport const getColor = (color) => {\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\nimport { getStringWidth } from './helpers';\nimport { DOT_OVERLAY_SIZE_INCR, PERCENTAGE_BAR_DEFAULT_DEPTH } from './constants';\nimport { lightenDarkenColor } from './colors';\n\nexport const AXIS_TICK_LENGTH = 6;\nconst LABEL_MARGIN = 4;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none') {\n\treturn createSVG('path', {\n\t\tclassName: className,\n\t\td: pathStr,\n\t\tstyles: {\n\t\t\tstroke: stroke,\n\t\t\tfill: fill\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 0 ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeGradient(svgDefElem, color, lighter = false) {\n\tlet gradientId ='path-fill-gradient' + '-' + color + '-' +(lighter ? 'lighter' : 'default');\n\tlet gradientDef = renderVerticalGradient(svgDefElem, gradientId);\n\tlet opacities = [1, 0.6, 0.2];\n\tif(lighter) {\n\t\topacities = [0.4, 0.2, 0];\n\t}\n\n\tsetGradientStop(gradientDef, \"0%\", color, opacities[0]);\n\tsetGradientStop(gradientDef, \"50%\", color, opacities[1]);\n\tsetGradientStop(gradientDef, \"100%\", color, opacities[2]);\n\n\treturn gradientId;\n}\n\nexport function percentageBar(x, y, width, height,\n\tdepth=PERCENTAGE_BAR_DEFAULT_DEPTH, fill='none') {\n\n\tlet args = {\n\t\tclassName: 'percentage-bar',\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height,\n\t\tfill: fill,\n\t\tstyles: {\n\t\t\t'stroke': lightenDarkenColor(fill, -25),\n\t\t\t// Diabolically good: https://stackoverflow.com/a/9000859\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/stroke-dasharray\n\t\t\t'stroke-dasharray': `0, ${height + width}, ${width}, ${height}`,\n\t\t\t'stroke-width': depth\n\t\t},\n\t};\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function heatSquare(className, x, y, size, fill='none', data={}) {\n\tlet args = {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: size,\n\t\theight: size,\n\t\tfill: fill\n\t};\n\n\tObject.keys(data).map(key => {\n\t\targs[key] = data[key];\n\t});\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function legendBar(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-bar',\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: size,\n\t\theight: '2px',\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE * 2) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"rect\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function legendDot(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-dot',\n\t\tcx: 0,\n\t\tcy: 0,\n\t\tr: size,\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdx: (FONT_SIZE) + 'px',\n\t\tdy: (FONT_SIZE/3) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"circle\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function makeText(className, x, y, content, options = {}) {\n\tlet fontSize = options.fontSize || FONT_SIZE;\n\tlet dy = options.dy !== undefined ? options.dy : (fontSize / 2);\n\tlet fill = options.fill || FONT_FILL;\n\tlet textAnchor = options.textAnchor || 'start';\n\treturn createSVG('text', {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\tdy: dy + 'px',\n\t\t'font-size': fontSize + 'px',\n\t\tfill: fill,\n\t\t'text-anchor': textAnchor,\n\t\tinnerHTML: content\n\t});\n}\n\nfunction makeVertLine(x, label, y1, y2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tlet l = createSVG('line', {\n\t\tclassName: 'line-vertical ' + options.className,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: y1,\n\t\ty2: y2,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: 0,\n\t\ty: y1 > y2 ? y1 + LABEL_MARGIN : y1 - LABEL_MARGIN - FONT_SIZE,\n\t\tdy: FONT_SIZE + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'middle',\n\t\tinnerHTML: label + \"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(${ x }, 0)`\n\t});\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nfunction makeHoriLine(y, label, x1, x2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.lineType) options.lineType = '';\n\tlet className = 'line-horizontal ' + options.className +\n\t\t(options.lineType === \"dashed\" ? \"dashed\": \"\");\n\n\tlet l = createSVG('line', {\n\t\tclassName: className,\n\t\tx1: x1,\n\t\tx2: x2,\n\t\ty1: 0,\n\t\ty2: 0,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: x1 < x2 ? x1 - LABEL_MARGIN : x1 + LABEL_MARGIN,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / 2 - 2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': x1 < x2 ? 'end' : 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(0, ${y})`,\n\t\t'stroke-opacity': 1\n\t});\n\n\tif(text === 0 || text === '0') {\n\t\tline.style.stroke = \"rgba(27, 31, 35, 0.6)\";\n\t}\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nexport function yLine(y, label, width, options={}) {\n\tif(!options.pos) options.pos = 'left';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\tlet x1 = -1 * AXIS_TICK_LENGTH;\n\tlet x2 = options.mode === 'span' ? width + AXIS_TICK_LENGTH : 0;\n\n\tif(options.mode === 'tick' && options.pos === 'right') {\n\t\tx1 = width + AXIS_TICK_LENGTH;\n\t\tx2 = width;\n\t}\n\n\t// let offset = options.pos === 'left' ? -1 * options.offset : options.offset;\n\n\tx1 += options.offset;\n\tx2 += options.offset;\n\n\treturn makeHoriLine(y, label, x1, x2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.areaFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\n\nexport const UNIT_ANIM_DUR = 350;\nexport const PATH_ANIM_DUR = 350;\nexport const MARKER_LINE_ANIM_DUR = UNIT_ANIM_DUR;\nexport const REPLACE_ALL_NEW_DUR = 250;\n\nexport const STD_EASING = 'easein';\n\nexport function translate(unit, oldCoord, newCoord, duration) {\n\tlet old = typeof oldCoord === 'string' ? oldCoord : oldCoord.join(', ');\n\treturn [\n\t\tunit,\n\t\t{transform: newCoord.join(', ')},\n\t\tduration,\n\t\tSTD_EASING,\n\t\t\"translate\",\n\t\t{transform: old}\n\t];\n}\n\nexport function translateVertLine(xLine, newX, oldX) {\n\treturn translate(xLine, [oldX, 0], [newX, 0], MARKER_LINE_ANIM_DUR);\n}\n\nexport function translateHoriLine(yLine, newY, oldY) {\n\treturn translate(yLine, [0, oldY], [0, newY], MARKER_LINE_ANIM_DUR);\n}\n\nexport function animateRegion(rectGroup, newY1, newY2, oldY2) {\n\tlet newHeight = newY1 - newY2;\n\tlet rect = rectGroup.childNodes[0];\n\tlet width = rect.getAttribute(\"width\");\n\tlet rectAnim = [\n\t\trect,\n\t\t{ height: newHeight, 'stroke-dasharray': `${width}, ${newHeight}` },\n\t\tMARKER_LINE_ANIM_DUR,\n\t\tSTD_EASING\n\t];\n\n\tlet groupAnim = translate(rectGroup, [0, oldY2], [0, newY2], MARKER_LINE_ANIM_DUR);\n\treturn [rectAnim, groupAnim];\n}\n\nexport function animateBar(bar, x, yTop, width, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\tif(bar.nodeName !== 'rect') {\n\t\tlet rect = bar.childNodes[0];\n\t\tlet rectAnim = [\n\t\t\trect,\n\t\t\t{width: width, height: height},\n\t\t\tUNIT_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\n\t\tlet oldCoordStr = bar.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(bar, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [rectAnim, groupAnim];\n\t} else {\n\t\treturn [[bar, {width: width, height: height, x: x, y: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// bar.animate({height: args.newHeight, y: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animateDot(dot, x, y) {\n\tif(dot.nodeName !== 'circle') {\n\t\tlet oldCoordStr = dot.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(dot, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [groupAnim];\n\t} else {\n\t\treturn [[dot, {cx: x, cy: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// dot.animate({cy: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animatePath(paths, newXList, newYList, zeroLine) {\n\tlet pathComponents = [];\n\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y));\n\tlet pathStr = pointsStr.join(\"L\");\n\n\tconst animPath = [paths.path, {d:\"M\"+pathStr}, PATH_ANIM_DUR, STD_EASING];\n\tpathComponents.push(animPath);\n\n\tif(paths.region) {\n\t\tlet regStartPt = `${newXList[0]},${zeroLine}L`;\n\t\tlet regEndPt = `L${newXList.slice(-1)[0]}, ${zeroLine}`;\n\n\t\tconst animRegion = [\n\t\t\tpaths.region,\n\t\t\t{d:\"M\" + regStartPt + pathStr + regEndPt},\n\t\t\tPATH_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\t\tpathComponents.push(animRegion);\n\t}\n\n\treturn pathComponents;\n}\n\nexport function animatePathStr(oldPath, pathStr) {\n\treturn [oldPath, {d: pathStr}, UNIT_ANIM_DUR, STD_EASING];\n}\n","// Leveraging SMIL Animations\n\nimport { REPLACE_ALL_NEW_DUR } from './animate';\n\nconst EASING = {\n\tease: \"0.25 0.1 0.25 1\",\n\tlinear: \"0 0 1 1\",\n\t// easein: \"0.42 0 1 1\",\n\teasein: \"0.1 0.8 0.2 1\",\n\teaseout: \"0 0 0.58 1\",\n\teaseinout: \"0.42 0 0.58 1\"\n};\n\nfunction animateSVGElement(element, props, dur, easingType=\"linear\", type=undefined, oldValues={}) {\n\n\tlet animElement = element.cloneNode(true);\n\tlet newElement = element.cloneNode(true);\n\n\tfor(var attributeName in props) {\n\t\tlet animateElement;\n\t\tif(attributeName === 'transform') {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animateTransform\");\n\t\t} else {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animate\");\n\t\t}\n\t\tlet currentValue = oldValues[attributeName] || element.getAttribute(attributeName);\n\t\tlet value = props[attributeName];\n\n\t\tlet animAttr = {\n\t\t\tattributeName: attributeName,\n\t\t\tfrom: currentValue,\n\t\t\tto: value,\n\t\t\tbegin: \"0s\",\n\t\t\tdur: dur/1000 + \"s\",\n\t\t\tvalues: currentValue + \";\" + value,\n\t\t\tkeySplines: EASING[easingType],\n\t\t\tkeyTimes: \"0;1\",\n\t\t\tcalcMode: \"spline\",\n\t\t\tfill: 'freeze'\n\t\t};\n\n\t\tif(type) {\n\t\t\tanimAttr[\"type\"] = type;\n\t\t}\n\n\t\tfor (var i in animAttr) {\n\t\t\tanimateElement.setAttribute(i, animAttr[i]);\n\t\t}\n\n\t\tanimElement.appendChild(animateElement);\n\n\t\tif(type) {\n\t\t\tnewElement.setAttribute(attributeName, `translate(${value})`);\n\t\t} else {\n\t\t\tnewElement.setAttribute(attributeName, value);\n\t\t}\n\t}\n\n\treturn [animElement, newElement];\n}\n\nexport function transform(element, style) { // eslint-disable-line no-unused-vars\n\telement.style.transform = style;\n\telement.style.webkitTransform = style;\n\telement.style.msTransform = style;\n\telement.style.mozTransform = style;\n\telement.style.oTransform = style;\n}\n\nfunction animateSVG(svgContainer, elements) {\n\tlet newElements = [];\n\tlet animElements = [];\n\n\telements.map(element => {\n\t\tlet unit = element[0];\n\t\tlet parent = unit.parentNode;\n\n\t\tlet animElement, newElement;\n\n\t\telement[0] = unit;\n\t\t[animElement, newElement] = animateSVGElement(...element);\n\n\t\tnewElements.push(newElement);\n\t\tanimElements.push([animElement, parent]);\n\n\t\tparent.replaceChild(animElement, unit);\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\telements[i][0] = newElements[i];\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\n\nlet BOUND_DRAW_FN;\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || 'line';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tBOUND_DRAW_FN = this.boundDrawFn.bind(this);\n\t\twindow.addEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents() {\n\t\twindow.removeEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t\tthis.parent.style.overflow = 'auto';\n\t\t}\n\n\t\tthis.container = $.create('div', args);\n\t}\n\n\tmakeTooltip() {\n\t\tthis.tip = new SvgTip({\n\t\t\tparent: this.container,\n\t\t\tcolors: this.colors\n\t\t});\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {}\n\n\tdraw(onlyWidthChange=false, init=false) {\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { legendDot } from '../utils/draw';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.maxSlices = args.maxSlices || 20;\n\t\tthis.config.maxLegendPoints = args.maxLegendPoints || 20;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\t\tlet maxSlices = this.config.maxSlices;\n\t\ts.sliceTotals = [];\n\n\t\tlet allTotals = this.data.labels.map((label, i) => {\n\t\t\tlet total = 0;\n\t\t\tthis.data.datasets.map(e => {\n\t\t\t\ttotal += e.values[i];\n\t\t\t});\n\t\t\treturn [total, label];\n\t\t}).filter(d => { return d[0] >= 0; }); // keep only positive results\n\n\t\tlet totals = allTotals;\n\t\tif(allTotals.length > maxSlices) {\n\t\t\t// Prune and keep a grey area for rest as per maxSlices\n\t\t\tallTotals.sort((a, b) => { return b[0] - a[0]; });\n\n\t\t\ttotals = allTotals.slice(0, maxSlices-1);\n\t\t\tlet remaining = allTotals.slice(maxSlices-1);\n\n\t\t\tlet sumOfRemaining = 0;\n\t\t\tremaining.map(d => {sumOfRemaining += d[0];});\n\t\t\ttotals.push([sumOfRemaining, 'Rest']);\n\t\t\tthis.colors[maxSlices-1] = 'grey';\n\t\t}\n\n\t\ts.labels = [];\n\t\ttotals.map(d => {\n\t\t\ts.sliceTotals.push(d[0]);\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${s.labels[i]}: ${d}`\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport { makeText, makePath, xLine, yLine, yMarker, yRegion, datasetBar, datasetDot, percentageBar, getPaths, heatSquare } from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport { translateHoriLine, translateVertLine, animateRegion, animateBar,\n\tanimateDot, animatePath, animatePathStr } from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n\tconstructor({\n\t\tlayerClass = '',\n\t\tlayerTransform = '',\n\t\tconstants,\n\n\t\tgetData,\n\t\tmakeElements,\n\t\tanimateElements\n\t}) {\n\t\tthis.layerTransform = layerTransform;\n\t\tthis.constants = constants;\n\n\t\tthis.makeElements = makeElements;\n\t\tthis.getData = getData;\n\n\t\tthis.animateElements = animateElements;\n\n\t\tthis.store = [];\n\t\tthis.labels = [];\n\n\t\tthis.layerClass = layerClass;\n\t\tthis.layerClass = typeof(this.layerClass) === 'function'\n\t\t\t? this.layerClass() : this.layerClass;\n\n\t\tthis.refresh();\n\t}\n\n\trefresh(data) {\n\t\tthis.data = data || this.getData();\n\t}\n\n\tsetup(parent) {\n\t\tthis.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n\t}\n\n\tmake() {\n\t\tthis.render(this.data);\n\t\tthis.oldData = this.data;\n\t}\n\n\trender(data) {\n\t\tthis.store = this.makeElements(data);\n\n\t\tthis.layer.textContent = '';\n\t\tthis.store.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t\tthis.labels.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t}\n\n\tupdate(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tpieSlices: {\n\t\tlayerClass: 'pie-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) =>{\n\t\t\t\tlet slice = makePath(s, 'pie-path', 'none', data.colors[i]);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) =>\n\t\t\t\tanimatePathStr(slice, newData.sliceStrings[i])\n\t\t\t);\n\t\t}\n\t},\n\tpercentageBars: {\n\t\tlayerClass: 'percentage-bars',\n\t\tmakeElements(data) {\n\t\t\treturn data.xPositions.map((x, i) =>{\n\t\t\t\tlet y = 0;\n\t\t\t\tlet bar = percentageBar(x, y, data.widths[i],\n\t\t\t\t\tthis.constants.barHeight, this.constants.barDepth, data.colors[i]);\n\t\t\t\treturn bar;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\tyAxis: {\n\t\tlayerClass: 'y axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\tyLine(position, data.labels[i], this.constants.width,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.labels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tlabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(m =>\n\t\t\t\tyMarker(m.position, m.label, this.constants.width,\n\t\t\t\t\t{labelPos: m.options.labelPos, mode: 'span', lineType: 'dashed'})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, day.fill, data);\n\t\t\t\t\t\tthis.serializedSubDomains.push(square);\n\t\t\t\t\t}\n\t\t\t\t\ty += rowHeight;\n\t\t\t\t});\n\t\t\t\ty = 0;\n\t\t\t\tx += colWidth;\n\t\t\t});\n\n\t\t\treturn this.serializedSubDomains;\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\n\tbarGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-bars dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'bar';\n\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\treturn datasetBar(\n\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\ty,\n\t\t\t\t\tdata.barWidth,\n\t\t\t\t\tc.color,\n\t\t\t\t\tdata.labels[j],\n\t\t\t\t\tj,\n\t\t\t\t\tdata.offsets[j],\n\t\t\t\t\t{\n\t\t\t\t\t\tzeroLine: data.zeroLine,\n\t\t\t\t\t\tbarsWidth: data.barsWidth,\n\t\t\t\t\t\tminHeight: c.minHeight\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t});\n\t\t\treturn this.units;\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newOffsets = newData.offsets;\n\t\t\tlet newLabels = newData.labels;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldOffsets = this.oldData.offsets;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldOffsets, newOffsets] = equilizeNoOfElements(oldOffsets, newOffsets);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\toffsets: oldOffsets,\n\t\t\t\tlabels: newLabels,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tbarsWidth: this.oldData.barsWidth,\n\t\t\t\tbarWidth: this.oldData.barWidth,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((bar, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateBar(\n\t\t\t\t\tbar, newXPos[i], newYPos[i], newData.barWidth, newOffsets[i],\n\t\t\t\t\t{zeroLine: newData.zeroLine}\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\tlineGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-line dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'dot';\n\t\t\tthis.paths = {};\n\t\t\tif(!c.hideLine) {\n\t\t\t\tthis.paths = getPaths(\n\t\t\t\t\tdata.xPositions,\n\t\t\t\t\tdata.yPositions,\n\t\t\t\t\tc.color,\n\t\t\t\t\t{\n\t\t\t\t\t\theatline: c.heatline,\n\t\t\t\t\t\tareaFill: c.areaFill\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tsvgDefs: c.svgDefs,\n\t\t\t\t\t\tzeroLine: data.zeroLine\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.units = [];\n\t\t\tif(!c.hideDots) {\n\t\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\t\treturn datasetDot(\n\t\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\t\ty,\n\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\tc.color,\n\t\t\t\t\t\t(c.valuesOverPoints ? data.values[j] : ''),\n\t\t\t\t\t\tj\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn Object.values(this.paths).concat(this.units);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newValues = newData.values;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldValues = this.oldData.values;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldValues, newValues] = equilizeNoOfElements(oldValues, newValues);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\tvalues: newValues,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tradius: this.oldData.radius,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tif(Object.keys(this.paths).length) {\n\t\t\t\tanimateElements = animateElements.concat(animatePath(\n\t\t\t\t\tthis.paths, newXPos, newYPos, newData.zeroLine));\n\t\t\t}\n\n\t\t\tif(this.units.length) {\n\t\t\t\tthis.units.map((dot, i) => {\n\t\t\t\t\tanimateElements = animateElements.concat(animateDot(\n\t\t\t\t\t\tdot, newXPos[i], newYPos[i]));\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn animateElements;\n\t\t}\n\t}\n};\n\nexport function getComponent(name, constants, getData) {\n\tlet keys = Object.keys(componentConfigs).filter(k => name.includes(k));\n\tlet config = componentConfigs[keys[0]];\n\tObject.assign(config, {\n\t\tconstants: constants,\n\t\tgetData: getData\n\t});\n\treturn new ChartComponent(config);\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 80;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class PieChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'pie';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius = (this.height > this.width ? this.center.x : this.center.y);\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath = makeArcPathStr(curStart, curEnd, this.center, this.radius, this.clockWise);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import { floatTwo } from './helpers';\n\nfunction normalize(x) {\n\t// Calculates mantissa and exponent of a number\n\t// Returns normalized number and exponent\n\t// https://stackoverflow.com/q/9383593/6495043\n\n\tif(x===0) {\n\t\treturn [0, 0];\n\t}\n\tif(isNaN(x)) {\n\t\treturn {mantissa: -6755399441055744, exponent: 972};\n\t}\n\tvar sig = x > 0 ? 1 : -1;\n\tif(!isFinite(x)) {\n\t\treturn {mantissa: sig * 4503599627370496, exponent: 972};\n\t}\n\n\tx = Math.abs(x);\n\tvar exp = Math.floor(Math.log10(x));\n\tvar man = x/Math.pow(10, exp);\n\n\treturn [sig * man, exp];\n}\n\nfunction getChartRangeIntervals(max, min=0) {\n\tlet upperBound = Math.ceil(max);\n\tlet lowerBound = Math.floor(min);\n\tlet range = upperBound - lowerBound;\n\n\tlet noOfParts = range;\n\tlet partSize = 1;\n\n\t// To avoid too many partitions\n\tif(range > 5) {\n\t\tif(range % 2 !== 0) {\n\t\t\tupperBound++;\n\t\t\t// Recalc range\n\t\t\trange = upperBound - lowerBound;\n\t\t}\n\t\tnoOfParts = range/2;\n\t\tpartSize = 2;\n\t}\n\n\t// Special case: 1 and 2\n\tif(range <= 2) {\n\t\tnoOfParts = 4;\n\t\tpartSize = range/noOfParts;\n\t}\n\n\t// Special case: 0\n\tif(range === 0) {\n\t\tnoOfParts = 5;\n\t\tpartSize = 1;\n\t}\n\n\tlet intervals = [];\n\tfor(var i = 0; i <= noOfParts; i++){\n\t\tintervals.push(lowerBound + partSize * i);\n\t}\n\treturn intervals;\n}\n\nfunction getChartIntervals(maxValue, minValue=0) {\n\tlet [normalMaxValue, exponent] = normalize(maxValue);\n\tlet normalMinValue = minValue ? minValue/Math.pow(10, exponent): 0;\n\n\t// Allow only 7 significant digits\n\tnormalMaxValue = normalMaxValue.toFixed(6);\n\n\tlet intervals = getChartRangeIntervals(normalMaxValue, normalMinValue);\n\tintervals = intervals.map(value => value * Math.pow(10, exponent));\n\treturn intervals;\n}\n\nexport function calcChartIntervals(values, withMinimum=false) {\n\t//*** Where the magic happens ***\n\n\t// Calculates best-fit y intervals from given values\n\t// and returns the interval array\n\n\tlet maxValue = Math.max(...values);\n\tlet minValue = Math.min(...values);\n\n\t// Exponent to be used for pretty print\n\tlet exponent = 0, intervals = []; // eslint-disable-line no-unused-vars\n\n\tfunction getPositiveFirstIntervals(maxValue, absMinValue) {\n\t\tlet intervals = getChartIntervals(maxValue);\n\n\t\tlet intervalSize = intervals[1] - intervals[0];\n\n\t\t// Then unshift the negative values\n\t\tlet value = 0;\n\t\tfor(var i = 1; value < absMinValue; i++) {\n\t\t\tvalue += intervalSize;\n\t\t\tintervals.unshift((-1) * value);\n\t\t}\n\t\treturn intervals;\n\t}\n\n\t// CASE I: Both non-negative\n\n\tif(maxValue >= 0 && minValue >= 0) {\n\t\texponent = normalize(maxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(maxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(maxValue, minValue);\n\t\t}\n\t}\n\n\t// CASE II: Only minValue negative\n\n\telse if(maxValue > 0 && minValue < 0) {\n\t\t// `withMinimum` irrelevant in this case,\n\t\t// We'll be handling both sides of zero separately\n\t\t// (both starting from zero)\n\t\t// Because ceil() and floor() behave differently\n\t\t// in those two regions\n\n\t\tlet absMinValue = Math.abs(minValue);\n\n\t\tif(maxValue >= absMinValue) {\n\t\t\texponent = normalize(maxValue)[1];\n\t\t\tintervals = getPositiveFirstIntervals(maxValue, absMinValue);\n\t\t} else {\n\t\t\t// Mirror: maxValue => absMinValue, then change sign\n\t\t\texponent = normalize(absMinValue)[1];\n\t\t\tlet posIntervals = getPositiveFirstIntervals(absMinValue, maxValue);\n\t\t\tintervals = posIntervals.map(d => d * (-1));\n\t\t}\n\n\t}\n\n\t// CASE III: Both non-positive\n\n\telse if(maxValue <= 0 && minValue <= 0) {\n\t\t// Mirrored Case I:\n\t\t// Work with positives, then reverse the sign and array\n\n\t\tlet pseudoMaxValue = Math.abs(minValue);\n\t\tlet pseudoMinValue = Math.abs(maxValue);\n\n\t\texponent = normalize(pseudoMaxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue, pseudoMinValue);\n\t\t}\n\n\t\tintervals = intervals.reverse().map(d => d * (-1));\n\t}\n\n\treturn intervals;\n}\n\nexport function getZeroIndex(yPts) {\n\tlet zeroIndex;\n\tlet interval = getIntervalSize(yPts);\n\tif(yPts.indexOf(0) >= 0) {\n\t\t// the range has a given zero\n\t\t// zero-line on the chart\n\t\tzeroIndex = yPts.indexOf(0);\n\t} else if(yPts[0] > 0) {\n\t\t// Minimum value is positive\n\t\t// zero-line is off the chart: below\n\t\tlet min = yPts[0];\n\t\tzeroIndex = (-1) * min / interval;\n\t} else {\n\t\t// Maximum value is negative\n\t\t// zero-line is off the chart: above\n\t\tlet max = yPts[yPts.length - 1];\n\t\tzeroIndex = (-1) * max / interval + (yPts.length - 1);\n\t}\n\treturn zeroIndex;\n}\n\nexport function getRealIntervals(max, noOfIntervals, min = 0, asc = 1) {\n\tlet range = max - min;\n\tlet part = range * 1.0 / noOfIntervals;\n\tlet intervals = [];\n\n\tfor(var i = 0; i <= noOfIntervals; i++) {\n\t\tintervals.push(min + part * i);\n\t}\n\n\treturn asc ? intervals : intervals.reverse();\n}\n\nexport function getIntervalSize(orderedArray) {\n\treturn orderedArray[1] - orderedArray[0];\n}\n\nexport function getValueRange(orderedArray) {\n\treturn orderedArray[orderedArray.length-1] - orderedArray[0];\n}\n\nexport function scale(val, yAxis) {\n\treturn floatTwo(yAxis.zeroLine - val * yAxis.scaleMultiplier);\n}\n\nexport function isInRange(val, min, max) {\n\treturn val > min && val < max;\n}\n\nexport function isInRange2D(coord, minCoord, maxCoord) {\n\treturn isInRange(coord[0], minCoord[0], maxCoord[0])\n\t\t&& isInRange(coord[1], minCoord[1], maxCoord[1]);\n}\n\nexport function getClosestInArray(goal, arr, index = false) {\n\tlet closest = arr.reduce(function(prev, curr) {\n\t\treturn (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);\n\t});\n\n\treturn index ? arr.indexOf(closest) : closest;\n}\n\nexport function calcDistribution(values, distributionSize) {\n\t// Assume non-negative values,\n\t// implying distribution minimum at zero\n\n\tlet dataMaxValue = Math.max(...values);\n\n\tlet distributionStep = 1 / (distributionSize - 1);\n\tlet distribution = [];\n\n\tfor(var i = 0; i < distributionSize; i++) {\n\t\tlet checkpoint = dataMaxValue * (distributionStep * i);\n\t\tdistribution.push(checkpoint);\n\t}\n\n\treturn distribution;\n}\n\nexport function getMaxCheckpoint(value, distribution) {\n\treturn distribution.filter(d => d < value).length;\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\txTranslate: s.domainConfigs\n\t\t\t\t\t.filter((config, j) => j < i)\n\t\t\t\t\t.map(config => config.cols.length - lessCol)\n\t\t\t\t\t.reduce((a, b) => a + b, 0)\n\t\t\t\t\t* COL_WIDTH\n\t\t\t},\n\t\t\tfunction() {\n\t\t\t\treturn s.domainConfigs[i];\n\t\t\t}.bind(this)\n\n\t\t]);\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map((args, i) => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0] + '-' + i, component];\n\t\t\t})\n\t\t);\n\n\t\tlet y = 0;\n\t\tDAY_NAMES_SHORT.forEach((dayName, i) => {\n\t\t\tif([1, 3, 5].includes(i)) {\n\t\t\t\tlet dayText = makeText('subdomain-name', -COL_WIDTH/2, y, dayName,\n\t\t\t\t\t{\n\t\t\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\t\t\tdy: 8,\n\t\t\t\t\t\ttextAnchor: 'end'\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tthis.drawArea.appendChild(dayText);\n\t\t\t}\n\t\t\ty += ROW_HEIGHT;\n\t\t});\n\t}\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\n\t\tthis.data = this.prepareData(data);\n\t\tthis.draw();\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tthis.components.forEach(comp => {\n\t\t\t\tlet daySquares = comp.store;\n\t\t\t\tlet daySquare = e.target;\n\t\t\t\tif(daySquares.includes(daySquare)) {\n\n\t\t\t\t\tlet count = daySquare.getAttribute('data-value');\n\t\t\t\t\tlet dateParts = daySquare.getAttribute('data-date').split('-');\n\n\t\t\t\t\tlet month = getMonthName(parseInt(dateParts[1])-1, true);\n\n\t\t\t\t\tlet gOff = this.container.getBoundingClientRect(), pOff = daySquare.getBoundingClientRect();\n\n\t\t\t\t\tlet width = parseInt(e.target.getAttribute('width'));\n\t\t\t\t\tlet x = pOff.left - gOff.left + width/2;\n\t\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\t\tlet value = count + ' ' + this.countLabel;\n\t\t\t\t\tlet name = ' on ' + month + ' ' + dateParts[0] + ', ' + dateParts[2];\n\n\t\t\t\t\tthis.tip.setValues(x, y, {name: name, value: value, valueFirst: 1}, []);\n\t\t\t\t\tthis.tip.showTip();\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\trenderLegend() {\n\t\tthis.legendArea.textContent = '';\n\t\tlet x = 0;\n\t\tlet y = ROW_HEIGHT;\n\n\t\tlet lessText = makeText('subdomain-name', x, y, 'Less',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tx = (COL_WIDTH * 2) + COL_WIDTH/2;\n\t\tthis.legendArea.appendChild(lessText);\n\n\t\tthis.colors.slice(0, HEATMAP_DISTRIBUTION_SIZE).map((color, i) => {\n\t\t\tconst square = heatSquare('heatmap-legend-unit', x + (COL_WIDTH + 3) * i,\n\t\t\t\ty, HEATMAP_SQUARE_SIZE, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import { fillArray } from '../utils/helpers';\nimport { AXIS_CHART_DEFAULT_TYPE, AXIS_CHART_MIXED_TYPE, AXIS_DATASET_CHART_TYPES, DEFAULT_CHAR_WIDTH } from '../utils/constants';\n\nexport function dataPrep(data, type) {\n\tdata.labels = data.labels || [];\n\n\tlet datasetLength = data.labels.length;\n\n\t// Datasets\n\tlet datasets = data.datasets;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\tif(!datasets) {\n\t\t// default\n\t\tdatasets = [{\n\t\t\tvalues: zeroArray\n\t\t}];\n\t}\n\n\tlet overridingType;\n\tif(AXIS_DATASET_CHART_TYPES.includes(type)) {\n\t\toverridingType = type;\n\t};\n\n\tdatasets.map(d=> {\n\t\t// Set values\n\t\tif(!d.values) {\n\t\t\td.values = zeroArray;\n\t\t} else {\n\t\t\t// Check for non values\n\t\t\tlet vals = d.values;\n\t\t\tvals = vals.map(val => (!isNaN(val) ? val : 0));\n\n\t\t\t// Trim or extend\n\t\t\tif(vals.length > datasetLength) {\n\t\t\t\tvals = vals.slice(0, datasetLength);\n\t\t\t} else {\n\t\t\t\tvals = fillArray(vals, datasetLength - vals.length, 0);\n\t\t\t}\n\t\t}\n\n\t\t// Set labels\n\n\t\t// Set type\n\t\tif(overridingType) {\n\t\t\td.chartType = overridingType;\n\t\t} else if(!d.chartType) {\n\t\t\td.chartType = AXIS_CHART_DEFAULT_TYPE;\n\t\t}\n\t});\n\n\t// Markers\n\n\t// Regions\n\t// data.yRegions = data.yRegions || [];\n\tif(data.yRegions) {\n\t\tdata.yRegions.map(d => {\n\t\t\tif(d.end < d.start) {\n\t\t\t\t[d.start, d.end] = [d.end, d.start];\n\t\t\t}\n\t\t});\n\t}\n\n\treturn data;\n}\n\nexport function zeroDataPrep(realData) {\n\tlet datasetLength = realData.labels.length;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\n\tlet zeroData = {\n\t\tlabels: realData.labels.slice(0, -1),\n\t\tdatasets: realData.datasets.map(d => {\n\t\t\treturn {\n\t\t\t\tname: '',\n\t\t\t\tvalues: zeroArray.slice(0, -1),\n\t\t\t\tchartType: d.chartType\n\t\t\t};\n\t\t}),\n\t};\n\n\tif(realData.yMarkers) {\n\t\tzeroData.yMarkers = [\n\t\t\t{\n\t\t\t\tvalue: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\tif(realData.yRegions) {\n\t\tzeroData.yRegions = [\n\t\t\t{\n\t\t\t\tstart: 0,\n\t\t\t\tend: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\treturn zeroData;\n}\n\nexport function getShortenedLabels(chartWidth, labels=[], isSeries=true) {\n\tlet allowedSpace = chartWidth / labels.length;\n\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet calcLabels = labels.map((label, i) => {\n\t\tlabel += \"\";\n\t\tif(label.length > allowedLetters) {\n\n\t\t\tif(!isSeries) {\n\t\t\t\tif(allowedLetters-3 > 0) {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters-3) + \" ...\";\n\t\t\t\t} else {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters) + '..';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlet multiple = Math.ceil(label.length/allowedLetters);\n\t\t\t\tif(i % multiple !== 0) {\n\t\t\t\t\tlabel = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn label;\n\t});\n\n\treturn calcLabels;\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n\t\tsuper.configure(options);\n\n\t\toptions.axisOptions = options.axisOptions || {};\n\t\toptions.tooltipOptions = options.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = options.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = options.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = options.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\tcalcYAxisParameters(dataValues, withMinimum = 'false') {\n\t\tconst yPts = calcChartIntervals(dataValues, withMinimum);\n\t\tconst scaleMultiplier = this.height / getValueRange(yPts);\n\t\tconst intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n\t\tconst zeroLine = this.height - (getZeroIndex(yPts) * intervalHeight);\n\n\t\tthis.state.yAxis = {\n\t\t\tlabels: yPts,\n\t\t\tpositions: yPts.map(d => zeroLine - d * scaleMultiplier),\n\t\t\tscaleMultiplier: scaleMultiplier,\n\t\t\tzeroLine: zeroLine,\n\t\t};\n\n\t\t// Dependent if above changes\n\t\tthis.calcDatasetPoints();\n\t\tthis.calcYExtremes();\n\t\tthis.calcYRegions();\n\t}\n\n\tcalcDatasetPoints() {\n\t\tlet s = this.state;\n\t\tlet scaleAll = values => values.map(val => scale(val, s.yAxis));\n\n\t\ts.datasets = this.data.datasets.map((d, i) => {\n\t\t\tlet values = d.values;\n\t\t\tlet cumulativeYs = d.cumulativeYs || [];\n\t\t\treturn {\n\t\t\t\tname: d.name,\n\t\t\t\tindex: i,\n\t\t\t\tchartType: d.chartType,\n\n\t\t\t\tvalues: values,\n\t\t\t\tyPositions: scaleAll(values),\n\n\t\t\t\tcumulativeYs: cumulativeYs,\n\t\t\t\tcumulativeYPos: scaleAll(cumulativeYs),\n\t\t\t};\n\t\t});\n\t}\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n\tgetAllYValues() {\n\t\tlet key = 'values';\n\n\t\tif(this.barOptions.stacked) {\n\t\t\tkey = 'cumulativeYs';\n\t\t\tlet cumulative = new Array(this.state.datasetLength).fill(0);\n\t\t\tthis.data.datasets.map((d, i) => {\n\t\t\t\tlet values = this.data.datasets[i].values;\n\t\t\t\td[key] = cumulative = cumulative.map((c, i) => c + values[i]);\n\t\t\t});\n\t\t}\n\n\t\tlet allValueLists = this.data.datasets.map(d => d[key]);\n\t\tif(this.data.yMarkers) {\n\t\t\tallValueLists.push(this.data.yMarkers.map(d => d.value));\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.data.yRegions.map(d => {\n\t\t\t\tallValueLists.push([d.end, d.start]);\n\t\t\t});\n\t\t}\n\n\t\treturn [].concat(...allValueLists);\n\t}\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'yAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.yAxisMode,\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'xAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.xAxisMode,\n\t\t\t\t\theight: this.height,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\ts.xAxis.calcLabels = getShortenedLabels(this.width,\n\t\t\t\t\t\ts.xAxis.labels, this.config.xIsSeries);\n\n\t\t\t\t\treturn s.xAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'yRegions',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yRegions;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\t\t];\n\n\t\tlet barDatasets = this.state.datasets.filter(d => d.chartType === 'bar');\n\t\tlet lineDatasets = this.state.datasets.filter(d => d.chartType === 'line');\n\n\t\tlet barsConfigs = barDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'barGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tstacked: this.barOptions.stacked,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t\tminHeight: this.height * MIN_BAR_PERCENT_HEIGHT,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet stacked = this.barOptions.stacked;\n\n\t\t\t\t\tlet spaceRatio = this.barOptions.spaceRatio || BAR_CHART_SPACE_RATIO;\n\t\t\t\t\tlet barsWidth = s.unitWidth/2 * (2 - spaceRatio);\n\t\t\t\t\tlet barWidth = barsWidth/(stacked ? 1 : barDatasets.length);\n\n\t\t\t\t\tlet xPositions = s.xAxis.positions.map(x => x - barsWidth/2);\n\t\t\t\t\tif(!stacked) {\n\t\t\t\t\t\txPositions = xPositions.map(p => p + barWidth * index);\n\t\t\t\t\t}\n\n\t\t\t\t\tlet labels = new Array(s.datasetLength).fill('');\n\t\t\t\t\tif(this.config.valuesOverPoints) {\n\t\t\t\t\t\tif(stacked && d.index === s.datasets.length - 1) {\n\t\t\t\t\t\t\tlabels = d.cumulativeYs;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tlabels = d.values;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet offsets = new Array(s.datasetLength).fill(0);\n\t\t\t\t\tif(stacked) {\n\t\t\t\t\t\toffsets = d.yPositions.map((y, j) => y - d.cumulativeYPos[j]);\n\t\t\t\t\t}\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: xPositions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\t\t\t\t\t\toffsets: offsets,\n\t\t\t\t\t\t// values: d.values,\n\t\t\t\t\t\tlabels: labels,\n\n\t\t\t\t\t\tzeroLine: s.yAxis.zeroLine,\n\t\t\t\t\t\tbarsWidth: barsWidth,\n\t\t\t\t\t\tbarWidth: barWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet lineConfigs = lineDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'lineGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tsvgDefs: this.svgDefs,\n\t\t\t\t\theatline: this.lineOptions.heatline,\n\t\t\t\t\tareaFill: this.lineOptions.areaFill,\n\t\t\t\t\thideDots: this.lineOptions.hideDots,\n\t\t\t\t\thideLine: this.lineOptions.hideLine,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet minLine = s.yAxis.positions[0] < s.yAxis.zeroLine\n\t\t\t\t\t\t? s.yAxis.positions[0] : s.yAxis.zeroLine;\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xAxis.positions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\n\t\t\t\t\t\tvalues: d.values,\n\n\t\t\t\t\t\tzeroLine: minLine,\n\t\t\t\t\t\tradius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tlet dbi = this.dataByIndex[index];\n\n\t\tthis.tip.setValues(\n\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\tdbi.values,\n\t\t\tindex\n\t\t);\n\n\t\tthis.tip.showTip();\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name);\n\t\t\t\tthis.legendArea.appendChild(rect);\n\t\t\t});\n\t\t}\n\t}\n\n\n\n\t// Overlay\n\tmakeOverlay() {\n\t\tif(this.init) {\n\t\t\tthis.init = 0;\n\t\t\treturn;\n\t\t}\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\n\t\tthis.overlayGuides = this.dataUnitComponents.map(c => {\n\t\t\treturn {\n\t\t\t\ttype: c.unitType,\n\t\t\t\toverlay: undefined,\n\t\t\t\tunits: c.units,\n\t\t\t};\n\t\t});\n\n\t\tif(this.state.currentIndex === undefined) {\n\t\t\tthis.state.currentIndex = this.state.datasetLength - 1;\n\t\t}\n\n\t\t// Render overlays\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\n\t\t\td.overlay = makeOverlay[d.type](currentUnit);\n\t\t\tthis.drawArea.appendChild(d.overlay);\n\t\t});\n\t}\n\n\tupdateOverlayGuides() {\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\t}\n\n\tbindOverlay() {\n\t\tthis.parent.addEventListener('data-select', () => {\n\t\t\tthis.updateOverlay();\n\t\t});\n\t}\n\n\tbindUnits() {\n\t\tthis.dataUnitComponents.map(c => {\n\t\t\tc.units.map(unit => {\n\t\t\t\tunit.addEventListener('click', () => {\n\t\t\t\t\tlet index = unit.getAttribute('data-point-index');\n\t\t\t\t\tthis.setCurrentDataPoint(index);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\t// Note: Doesn't work as tooltip is absolutely positioned\n\t\tthis.tip.container.addEventListener('click', () => {\n\t\t\tlet index = this.tip.container.getAttribute('data-point-index');\n\t\t\tthis.setCurrentDataPoint(index);\n\t\t});\n\t}\n\n\tupdateOverlay() {\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\t\t\tupdateOverlay[d.type](currentUnit, d.overlay);\n\t\t});\n\t}\n\n\tonLeftArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex - 1);\n\t}\n\n\tonRightArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex + 1);\n\t}\n\n\tgetDataPoint(index=this.state.currentIndex) {\n\t\tlet s = this.state;\n\t\tlet data_point = {\n\t\t\tindex: index,\n\t\t\tlabel: s.xAxis.labels[index],\n\t\t\tvalues: s.datasets.map(d => d.values[index])\n\t\t};\n\t\treturn data_point;\n\t}\n\n\tsetCurrentDataPoint(index) {\n\t\tlet s = this.state;\n\t\tindex = parseInt(index);\n\t\tif(index < 0) index = 0;\n\t\tif(index >= s.xAxis.labels.length) index = s.xAxis.labels.length - 1;\n\t\tif(index === s.currentIndex) return;\n\t\ts.currentIndex = index;\n\t\tfire(this.parent, \"data-select\", this.getDataPoint());\n\t}\n\n\n\n\t// API\n\taddDataPoint(label, datasetValues, index=this.state.datasetLength) {\n\t\tsuper.addDataPoint(label, datasetValues, index);\n\t\tthis.data.labels.splice(index, 0, label);\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\td.values.splice(index, 0, datasetValues[i]);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tremoveDataPoint(index = this.state.datasetLength-1) {\n\t\tif (this.data.labels.length <= 1) {\n\t\t\treturn;\n\t\t}\n\t\tsuper.removeDataPoint(index);\n\t\tthis.data.labels.splice(index, 1);\n\t\tthis.data.datasets.map(d => {\n\t\t\td.values.splice(index, 1);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tupdateDataset(datasetValues, index=0) {\n\t\tthis.data.datasets[index].values = datasetValues;\n\t\tthis.update(this.data);\n\t}\n\t// addDataset(dataset, index) {}\n\t// removeDataset(index = 0) {}\n\n\tupdateDatasets(datasets) {\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\tif(datasets[i]) {\n\t\t\t\td.values = datasets[i];\n\t\t\t}\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\t// updateDataPoint(dataPoint, index = 0) {}\n\t// addDataPoint(dataPoint, index = 0) {}\n\t// removeDataPoint(index = 0) {}\n}\n","import '../css/charts.scss';\n\n// import MultiAxisChart from './charts/MultiAxisChart';\nimport PercentageChart from './charts/PercentageChart';\nimport PieChart from './charts/PieChart';\nimport Heatmap from './charts/Heatmap';\nimport AxisChart from './charts/AxisChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };"],"names":["$","expr","con","document","querySelector","create","tag","o","element","createElement","i","val","appendChild","ref","parentNode","insertBefore","addEventListener","e","value","keys","map","style","prop","setAttribute","getOffset","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isElementInViewport","el","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","type","properties","evt","createEvent","initEvent","j","dispatchEvent","BASE_MEASURES","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","totalExtraHeight","legendHeight","getExtraWidth","totalExtraWidth","INIT_CHART_UPDATE_TIMEOUT","CHART_POST_ANIMATE_TIMEOUT","AXIS_CHART_DEFAULT_TYPE","AXIS_DATASET_CHART_TYPES","AXIS_LEGEND_BAR_SIZE","BAR_CHART_SPACE_RATIO","MIN_BAR_PERCENT_HEIGHT","LINE_CHART_DOT_SIZE","DOT_OVERLAY_SIZE_INCR","PERCENTAGE_BAR_DEFAULT_HEIGHT","PERCENTAGE_BAR_DEFAULT_DEPTH","HEATMAP_DISTRIBUTION_SIZE","HEATMAP_SQUARE_SIZE","HEATMAP_GUTTER_SIZE","DEFAULT_CHAR_WIDTH","TOOLTIP_POINTER_TRIANGLE_HEIGHT","DEFAULT_CHART_COLORS","HEATMAP_COLORS_GREEN","DEFAULT_COLORS","ANGLE_RATIO","Math","PI","FULL_ANGLE","SvgTip","parent","colors","titleName","titleValue","listValues","titleValueFirst","x","y","setup","makeTooltip","fill","calcPosition","container","hideTip","title","dataPointList","index","innerHTML","set","color","formatted","li","width","offsetWidth","offsetHeight","maxLeft","pointer","delta","pointerOffset","name","valueFirst","refresh","opacity","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","abs","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","cos","getBarHeightAndYAttr","yTop","zeroLine","height","equilizeNoOfElements","array1","array2","extraCount","PRESET_COLOR_MAP","limitColor","r","lightenDarkenColor","amt","col","getColor","usePound","slice","num","parseInt","b","g","toString","isValidColor","test","AXIS_TICK_LENGTH","LABEL_MARGIN","FONT_SIZE","BASE_LINE_COLOR","FONT_FILL","createSVG","createElementNS","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","makeSVGContainer","className","makeSVGDefs","svgContainer","makeSVGGroup","transform","undefined","args","inside","makePath","pathStr","stroke","makeArcPathStr","startPosition","endPosition","center","clockWise","arcStartX","arcStartY","arcEndX","arcEndY","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","heatSquare","size","data","key","legendBar","label","text","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","l","line","makeHoriLine","x1","x2","lineType","yLine","pos","mode","xLine","yMarker","labelPos","labelSvg","yRegion","region","datasetBar","meta","minHeight","datasetDot","dot","getPaths","xList","yList","pointsList","pointsStr","join","path","heatline","gradient_id","svgDefs","paths","areaFill","gradient_id_region","makeOverlay","unit","transformValue","nodeName","getAttribute","childNodes","overlay","cloneNode","updateOverlay","attributes","values","filter","includes","attr","specified","nodeValue","UNIT_ANIM_DUR","PATH_ANIM_DUR","MARKER_LINE_ANIM_DUR","REPLACE_ALL_NEW_DUR","STD_EASING","translate","oldCoord","newCoord","duration","old","translateVertLine","newX","oldX","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","rectAnim","groupAnim","animateBar","bar","oldCoordStr","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","push","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","EASING","animateSVGElement","props","dur","easingType","oldValues","animElement","newElement","attributeName","animateElement","currentValue","animAttr","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","CSSTEXT","downloadFile","filename","a","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","firstChild","BOUND_DRAW_FN","BaseChart","HTMLElement","Error","rawChartArgs","realData","prepareData","prepareFirstData","validateColors","config","isNavigable","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","bind","draw","removeEventListener","makeContainer","updateWidth","independentWidth","overflow","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","c","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","error","animate","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","event","keyCode","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","labels","total","datasets","totals","sort","remaining","sumOfRemaining","grandTotal","reduce","textContent","legendTotals","barWidth","divisor","floor","NO_OF_YEAR_MONTHS","NO_OF_DAYS_IN_WEEK","NO_OF_MILLIS","SEC_IN_DAY","MONTH_NAMES","DAY_NAMES_SHORT","treatAsUtc","date","result","Date","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","getTime","getWeeksBetween","startDate","endDate","weekStartDate","setDayToSunday","ceil","getDaysBetween","millisecondsPerDay","areInSameMonth","getMonthName","short","monthName","getLastDateInMonth","month","year","newDate","day","getDay","addDays","numberOfDays","setDate","ChartComponent","layerClass","layerTransform","constants","getData","makeElements","animateElements","store","layer","oldData","componentConfigs","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","newOptions","startPos","endPos","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","monthNameHeight","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","offsets","barsWidth","newXPos","newYPos","newOffsets","oldXPos","oldYPos","oldOffsets","hideLine","hideDots","valuesOverPoints","Object","newValues","getComponent","k","assign","PercentageChart","barOptions","component","xPos","bars","get","indexOf","gOff","pOff","formattedLabels","fraction","setValues","showTip","PieChart","mouseMove","mouseLeave","hoverRadio","startAngle","prevSlicesProperties","slicesProperties","curAngle","originDiffAngle","diffAngle","endAngle","prevProperty","curStart","curEnd","curPath","property","flag","calTranslateByAngle","g_off","pageX","pageY","formatted_labels","percent","slices","prevIndex","curActiveSliceIndex","prevAcitve","curActiveSlice","hoverSlice","normalize","isNaN","mantissa","exponent","sig","isFinite","exp","log10","man","pow","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","withMinimum","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","posIntervals","pseudoMaxValue","pseudoMinValue","reverse","getZeroIndex","yPts","zeroIndex","interval","getIntervalSize","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","prev","curr","calcDistribution","distributionSize","dataMaxValue","distributionStep","distribution","checkpoint","getMaxCheckpoint","COL_WIDTH","ROW_HEIGHT","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","spacing","end","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","moreTextX","moreText","startMonth","startYear","endMonth","endYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","dataPrep","datasetLength","zeroArray","overridingType","vals","chartType","yRegions","zeroDataPrep","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedSpace","allowedLetters","multiple","AxisChart","lineOptions","axisOptions","tooltipOptions","xAxisMode","yAxisMode","xIsSeries","formatTooltipX","formatTooltipY","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","xAxis","dataValues","intervalHeight","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","cumulativeYs","stacked","yExtremes","cumulativeYPos","cumulative","allValueLists","barDatasets","lineDatasets","barsConfigs","spaceRatio","p","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","titles","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","setCurrentDataPoint","data_point","getDataPoint","datasetValues","splice","chartTypes","getChartByType","Chart"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/frappe-charts.min.esm.js b/dist/frappe-charts.min.esm.js
index d200314..2748de4 100644
--- a/dist/frappe-charts.min.esm.js
+++ b/dist/frappe-charts.min.esm.js
@@ -1194,7 +1194,7 @@ function getPaths(xList, yList, color) {
};
// Region
- if (options.regionFill) {
+ if (options.areaFill) {
var gradient_id_region = makeGradient(meta.svgDefs, color, true);
var pathStr = "M" + (xList[0] + ',' + meta.zeroLine + 'L') + pointsStr + ('L' + xList.slice(-1)[0] + ',' + meta.zeroLine);
@@ -2574,7 +2574,7 @@ var componentConfigs = {
if (!c.hideLine) {
this.paths = getPaths(data.xPositions, data.yPositions, c.color, {
heatline: c.heatline,
- regionFill: c.regionFill
+ areaFill: c.areaFill
}, {
svgDefs: c.svgDefs,
zeroLine: data.zeroLine
@@ -3974,7 +3974,7 @@ var AxisChart = function (_BaseChart) {
color: _this3.colors[index],
svgDefs: _this3.svgDefs,
heatline: _this3.lineOptions.heatline,
- regionFill: _this3.lineOptions.regionFill,
+ areaFill: _this3.lineOptions.areaFill,
hideDots: _this3.lineOptions.hideDots,
hideLine: _this3.lineOptions.hideLine,
diff --git a/dist/frappe-charts.min.esm.js.map b/dist/frappe-charts.min.esm.js.map
index d5e2675..14fee5c 100644
--- a/dist/frappe-charts.min.esm.js.map
+++ b/dist/frappe-charts.min.esm.js.map
@@ -1 +1 @@
-{"version":3,"file":"frappe-charts.min.esm.js","sources":["../src/js/utils/dom.js","../src/js/utils/constants.js","../src/js/objects/SvgTip.js","../src/js/utils/helpers.js","../src/js/utils/draw-utils.js","../src/js/utils/colors.js","../src/js/utils/draw.js","../src/js/utils/animate.js","../src/js/utils/animation.js","../src/css/chartsCss.js","../src/js/utils/export.js","../src/js/charts/BaseChart.js","../src/js/charts/AggregationChart.js","../src/js/utils/date-utils.js","../src/js/objects/ChartComponents.js","../src/js/charts/PercentageChart.js","../src/js/charts/PieChart.js","../src/js/utils/intervals.js","../src/js/charts/Heatmap.js","../src/js/utils/axis-chart-utils.js","../src/js/charts/AxisChart.js","../src/js/chart.js"],"sourcesContent":["export function $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function findNodeIndex(node)\n{\n\tvar i = 0;\n\twhile (node.previousSibling) {\n\t\tnode = node.previousSibling;\n\t\ti++;\n\t}\n\treturn i;\n}\n\n$.create = (tag, o) => {\n\tvar element = document.createElement(tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"onClick\" ) {\n\t\t\telement.addEventListener('click', val);\n\n\t\t} else if (i === \"onInput\" ) {\n\t\t\telement.addEventListener('input', function(e) {\n\t\t\t\tval(element.value);\n\t\t\t});\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (i in element ) {\n\t\t\telement[i] = val;\n\t\t}\n\t\telse {\n\t\t\telement.setAttribute(i, val);\n\t\t}\n\t}\n\n\treturn element;\n};\n\nexport function getOffset(element) {\n\tlet rect = element.getBoundingClientRect();\n\treturn {\n\t\t// https://stackoverflow.com/a/7436602/6495043\n\t\t// rect.top varies with scroll, so we add whatever has been\n\t\t// scrolled to it to get absolute distance from actual page top\n\t\ttop: rect.top + (document.documentElement.scrollTop || document.body.scrollTop),\n\t\tleft: rect.left + (document.documentElement.scrollLeft || document.body.scrollLeft)\n\t};\n}\n\nexport function isElementInViewport(el) {\n\t// Although straightforward: https://stackoverflow.com/a/7557433/6495043\n\tvar rect = el.getBoundingClientRect();\n\n\treturn (\n\t\trect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */\n rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */\n\t);\n}\n\nexport function getElementContentWidth(element) {\n\tvar styles = window.getComputedStyle(element);\n\tvar padding = parseFloat(styles.paddingLeft) +\n\t\tparseFloat(styles.paddingRight);\n\n\treturn element.clientWidth - padding;\n}\n\nexport function bind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function (event) {\n\t\t\t\telement.addEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function unbind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function(event) {\n\t\t\t\telement.removeEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function fire(target, type, properties) {\n\tvar evt = document.createEvent(\"HTMLEvents\");\n\n\tevt.initEvent(type, true, true );\n\n\tfor (var j in properties) {\n\t\tevt[j] = properties[j];\n\t}\n\n\treturn target.dispatchEvent(evt);\n}\n\n// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/\nexport function forEachNode(nodeList, callback, scope) {\n\tif(!nodeList) return;\n\tfor (var i = 0; i < nodeList.length; i++) {\n\t\tcallback.call(scope, nodeList[i], i);\n\t}\n}\n\nexport function activate($parent, $child, commonSelector, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`${commonSelector}.${activeClass}`);\n\n\tif (typeof $child === 'string') {\n\t\t$child = $parent.querySelector($child);\n\t}\n\n\tthis.forEachNode($children, (node, i) => {\n\t\tif(index >= 0 && i <= index) return;\n\t\tnode.classList.remove(activeClass);\n\t})\n\n\t$child.classList.add(activeClass);\n}\n\nexport function insertAfter(newNode, referenceNode) {\n referenceNode.parentNode.insertBefore(newNode, referenceNode.nextSibling);\n}\n","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const AXIS_CHART_DEFAULT_TYPE = 'line';\nexport const AXIS_CHART_MIXED_TYPE = 'axis-mixed';\nexport const AXIS_CHART_TYPES = ['line', 'bar', 'axis-mixed'];\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_CHART_OPTIONS = {\n\tbarOptions: {\n\t\tspaceRatio: 1,\n\t}\n}\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 1;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.02;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `\n\t\t\t\t\n\t\t\t\t`\n\t\t});\n\t\tthis.hideTip();\n\n\t\tthis.title = this.container.querySelector('.title');\n\t\tthis.dataPointList = this.container.querySelector('.data-point-list');\n\n\t\tthis.parent.addEventListener('mouseleave', () => {\n\t\t\tthis.hideTip();\n\t\t});\n\t}\n\n\tfill() {\n\t\tlet title;\n\t\tif(this.index) {\n\t\t\tthis.container.setAttribute('data-point-index', this.index);\n\t\t}\n\t\tif(this.titleValueFirst) {\n\t\t\ttitle = `${this.titleValue}${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}${this.titleValue}`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `${ value === 0 || value ? value : '' }\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\nexport function toTitleCase(str) {\n return str.replace(/\\w*/g, function(txt){return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();});\n}\n","import { fillArray } from './helpers';\n\nexport function getBarHeightAndYAttr(yTop, zeroLine) {\n\tlet height, y;\n\tif (yTop <= zeroLine) {\n\t\theight = zeroLine - yTop;\n\t\ty = yTop;\n\t} else {\n\t\theight = yTop - zeroLine;\n\t\ty = zeroLine;\n\t}\n\n\treturn [height, y];\n}\n\nexport function equilizeNoOfElements(array1, array2,\n\textraCount = array2.length - array1.length) {\n\n\t// Doesn't work if either has zero elements.\n\tif(extraCount > 0) {\n\t\tarray1 = fillArray(array1, extraCount);\n\t} else {\n\t\tarray2 = fillArray(array2, extraCount);\n\t}\n\treturn [array1, array2];\n}\n","const PRESET_COLOR_MAP = {\n\t'light-blue': '#7cd6fd',\n\t'blue': '#5e64ff',\n\t'violet': '#743ee2',\n\t'red': '#ff5858',\n\t'orange': '#ffa00a',\n\t'yellow': '#feef72',\n\t'green': '#28a745',\n\t'light-green': '#98d85b',\n\t'purple': '#b554ff',\n\t'magenta': '#ffa3ef',\n\t'black': '#36114C',\n\t'grey': '#bdd3e6',\n\t'light-grey': '#f0f4f7',\n\t'dark-grey': '#b8c2cc'\n};\n\nfunction limitColor(r){\n\tif (r > 255) return 255;\n\telse if (r < 0) return 0;\n\treturn r;\n}\n\nexport function lightenDarkenColor(color, amt) {\n\tlet col = getColor(color);\n\tlet usePound = false;\n\tif (col[0] == \"#\") {\n\t\tcol = col.slice(1);\n\t\tusePound = true;\n\t}\n\tlet num = parseInt(col,16);\n\tlet r = limitColor((num >> 16) + amt);\n\tlet b = limitColor(((num >> 8) & 0x00FF) + amt);\n\tlet g = limitColor((num & 0x0000FF) + amt);\n\treturn (usePound?\"#\":\"\") + (g | (b << 8) | (r << 16)).toString(16);\n}\n\nexport function isValidColor(string) {\n\t// https://stackoverflow.com/a/8027444/6495043\n\treturn /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(string);\n}\n\nexport const getColor = (color) => {\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\nimport { getStringWidth } from './helpers';\nimport { DOT_OVERLAY_SIZE_INCR, PERCENTAGE_BAR_DEFAULT_DEPTH } from './constants';\nimport { lightenDarkenColor } from './colors';\n\nexport const AXIS_TICK_LENGTH = 6;\nconst LABEL_MARGIN = 4;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none') {\n\treturn createSVG('path', {\n\t\tclassName: className,\n\t\td: pathStr,\n\t\tstyles: {\n\t\t\tstroke: stroke,\n\t\t\tfill: fill\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 0 ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeGradient(svgDefElem, color, lighter = false) {\n\tlet gradientId ='path-fill-gradient' + '-' + color + '-' +(lighter ? 'lighter' : 'default');\n\tlet gradientDef = renderVerticalGradient(svgDefElem, gradientId);\n\tlet opacities = [1, 0.6, 0.2];\n\tif(lighter) {\n\t\topacities = [0.4, 0.2, 0];\n\t}\n\n\tsetGradientStop(gradientDef, \"0%\", color, opacities[0]);\n\tsetGradientStop(gradientDef, \"50%\", color, opacities[1]);\n\tsetGradientStop(gradientDef, \"100%\", color, opacities[2]);\n\n\treturn gradientId;\n}\n\nexport function percentageBar(x, y, width, height,\n\tdepth=PERCENTAGE_BAR_DEFAULT_DEPTH, fill='none') {\n\n\tlet args = {\n\t\tclassName: 'percentage-bar',\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height,\n\t\tfill: fill,\n\t\tstyles: {\n\t\t\t'stroke': lightenDarkenColor(fill, -25),\n\t\t\t// Diabolically good: https://stackoverflow.com/a/9000859\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/stroke-dasharray\n\t\t\t'stroke-dasharray': `0, ${height + width}, ${width}, ${height}`,\n\t\t\t'stroke-width': depth\n\t\t},\n\t};\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function heatSquare(className, x, y, size, fill='none', data={}) {\n\tlet args = {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: size,\n\t\theight: size,\n\t\tfill: fill\n\t};\n\n\tObject.keys(data).map(key => {\n\t\targs[key] = data[key];\n\t});\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function legendBar(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-bar',\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: size,\n\t\theight: '2px',\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE * 2) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"rect\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function legendDot(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-dot',\n\t\tcx: 0,\n\t\tcy: 0,\n\t\tr: size,\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdx: (FONT_SIZE) + 'px',\n\t\tdy: (FONT_SIZE/3) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"circle\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function makeText(className, x, y, content, options = {}) {\n\tlet fontSize = options.fontSize || FONT_SIZE;\n\tlet dy = options.dy !== undefined ? options.dy : (fontSize / 2);\n\tlet fill = options.fill || FONT_FILL;\n\tlet textAnchor = options.textAnchor || 'start';\n\treturn createSVG('text', {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\tdy: dy + 'px',\n\t\t'font-size': fontSize + 'px',\n\t\tfill: fill,\n\t\t'text-anchor': textAnchor,\n\t\tinnerHTML: content\n\t});\n}\n\nfunction makeVertLine(x, label, y1, y2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tlet l = createSVG('line', {\n\t\tclassName: 'line-vertical ' + options.className,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: y1,\n\t\ty2: y2,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: 0,\n\t\ty: y1 > y2 ? y1 + LABEL_MARGIN : y1 - LABEL_MARGIN - FONT_SIZE,\n\t\tdy: FONT_SIZE + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'middle',\n\t\tinnerHTML: label + \"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(${ x }, 0)`\n\t});\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nfunction makeHoriLine(y, label, x1, x2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.lineType) options.lineType = '';\n\tlet className = 'line-horizontal ' + options.className +\n\t\t(options.lineType === \"dashed\" ? \"dashed\": \"\");\n\n\tlet l = createSVG('line', {\n\t\tclassName: className,\n\t\tx1: x1,\n\t\tx2: x2,\n\t\ty1: 0,\n\t\ty2: 0,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: x1 < x2 ? x1 - LABEL_MARGIN : x1 + LABEL_MARGIN,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / 2 - 2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': x1 < x2 ? 'end' : 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(0, ${y})`,\n\t\t'stroke-opacity': 1\n\t});\n\n\tif(text === 0 || text === '0') {\n\t\tline.style.stroke = \"rgba(27, 31, 35, 0.6)\";\n\t}\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nexport function yLine(y, label, width, options={}) {\n\tif(!options.pos) options.pos = 'left';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\tlet x1 = -1 * AXIS_TICK_LENGTH;\n\tlet x2 = options.mode === 'span' ? width + AXIS_TICK_LENGTH : 0;\n\n\tif(options.mode === 'tick' && options.pos === 'right') {\n\t\tx1 = width + AXIS_TICK_LENGTH;\n\t\tx2 = width;\n\t}\n\n\t// let offset = options.pos === 'left' ? -1 * options.offset : options.offset;\n\n\tx1 += options.offset;\n\tx2 += options.offset;\n\n\treturn makeHoriLine(y, label, x1, x2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.regionFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\n\nexport const UNIT_ANIM_DUR = 350;\nexport const PATH_ANIM_DUR = 350;\nexport const MARKER_LINE_ANIM_DUR = UNIT_ANIM_DUR;\nexport const REPLACE_ALL_NEW_DUR = 250;\n\nexport const STD_EASING = 'easein';\n\nexport function translate(unit, oldCoord, newCoord, duration) {\n\tlet old = typeof oldCoord === 'string' ? oldCoord : oldCoord.join(', ');\n\treturn [\n\t\tunit,\n\t\t{transform: newCoord.join(', ')},\n\t\tduration,\n\t\tSTD_EASING,\n\t\t\"translate\",\n\t\t{transform: old}\n\t];\n}\n\nexport function translateVertLine(xLine, newX, oldX) {\n\treturn translate(xLine, [oldX, 0], [newX, 0], MARKER_LINE_ANIM_DUR);\n}\n\nexport function translateHoriLine(yLine, newY, oldY) {\n\treturn translate(yLine, [0, oldY], [0, newY], MARKER_LINE_ANIM_DUR);\n}\n\nexport function animateRegion(rectGroup, newY1, newY2, oldY2) {\n\tlet newHeight = newY1 - newY2;\n\tlet rect = rectGroup.childNodes[0];\n\tlet width = rect.getAttribute(\"width\");\n\tlet rectAnim = [\n\t\trect,\n\t\t{ height: newHeight, 'stroke-dasharray': `${width}, ${newHeight}` },\n\t\tMARKER_LINE_ANIM_DUR,\n\t\tSTD_EASING\n\t];\n\n\tlet groupAnim = translate(rectGroup, [0, oldY2], [0, newY2], MARKER_LINE_ANIM_DUR);\n\treturn [rectAnim, groupAnim];\n}\n\nexport function animateBar(bar, x, yTop, width, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\tif(bar.nodeName !== 'rect') {\n\t\tlet rect = bar.childNodes[0];\n\t\tlet rectAnim = [\n\t\t\trect,\n\t\t\t{width: width, height: height},\n\t\t\tUNIT_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\n\t\tlet oldCoordStr = bar.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(bar, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [rectAnim, groupAnim];\n\t} else {\n\t\treturn [[bar, {width: width, height: height, x: x, y: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// bar.animate({height: args.newHeight, y: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animateDot(dot, x, y) {\n\tif(dot.nodeName !== 'circle') {\n\t\tlet oldCoordStr = dot.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(dot, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [groupAnim];\n\t} else {\n\t\treturn [[dot, {cx: x, cy: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// dot.animate({cy: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animatePath(paths, newXList, newYList, zeroLine) {\n\tlet pathComponents = [];\n\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y));\n\tlet pathStr = pointsStr.join(\"L\");\n\n\tconst animPath = [paths.path, {d:\"M\"+pathStr}, PATH_ANIM_DUR, STD_EASING];\n\tpathComponents.push(animPath);\n\n\tif(paths.region) {\n\t\tlet regStartPt = `${newXList[0]},${zeroLine}L`;\n\t\tlet regEndPt = `L${newXList.slice(-1)[0]}, ${zeroLine}`;\n\n\t\tconst animRegion = [\n\t\t\tpaths.region,\n\t\t\t{d:\"M\" + regStartPt + pathStr + regEndPt},\n\t\t\tPATH_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\t\tpathComponents.push(animRegion);\n\t}\n\n\treturn pathComponents;\n}\n\nexport function animatePathStr(oldPath, pathStr) {\n\treturn [oldPath, {d: pathStr}, UNIT_ANIM_DUR, STD_EASING];\n}\n","// Leveraging SMIL Animations\n\nimport { REPLACE_ALL_NEW_DUR } from './animate';\n\nconst EASING = {\n\tease: \"0.25 0.1 0.25 1\",\n\tlinear: \"0 0 1 1\",\n\t// easein: \"0.42 0 1 1\",\n\teasein: \"0.1 0.8 0.2 1\",\n\teaseout: \"0 0 0.58 1\",\n\teaseinout: \"0.42 0 0.58 1\"\n};\n\nfunction animateSVGElement(element, props, dur, easingType=\"linear\", type=undefined, oldValues={}) {\n\n\tlet animElement = element.cloneNode(true);\n\tlet newElement = element.cloneNode(true);\n\n\tfor(var attributeName in props) {\n\t\tlet animateElement;\n\t\tif(attributeName === 'transform') {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animateTransform\");\n\t\t} else {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animate\");\n\t\t}\n\t\tlet currentValue = oldValues[attributeName] || element.getAttribute(attributeName);\n\t\tlet value = props[attributeName];\n\n\t\tlet animAttr = {\n\t\t\tattributeName: attributeName,\n\t\t\tfrom: currentValue,\n\t\t\tto: value,\n\t\t\tbegin: \"0s\",\n\t\t\tdur: dur/1000 + \"s\",\n\t\t\tvalues: currentValue + \";\" + value,\n\t\t\tkeySplines: EASING[easingType],\n\t\t\tkeyTimes: \"0;1\",\n\t\t\tcalcMode: \"spline\",\n\t\t\tfill: 'freeze'\n\t\t};\n\n\t\tif(type) {\n\t\t\tanimAttr[\"type\"] = type;\n\t\t}\n\n\t\tfor (var i in animAttr) {\n\t\t\tanimateElement.setAttribute(i, animAttr[i]);\n\t\t}\n\n\t\tanimElement.appendChild(animateElement);\n\n\t\tif(type) {\n\t\t\tnewElement.setAttribute(attributeName, `translate(${value})`);\n\t\t} else {\n\t\t\tnewElement.setAttribute(attributeName, value);\n\t\t}\n\t}\n\n\treturn [animElement, newElement];\n}\n\nexport function transform(element, style) { // eslint-disable-line no-unused-vars\n\telement.style.transform = style;\n\telement.style.webkitTransform = style;\n\telement.style.msTransform = style;\n\telement.style.mozTransform = style;\n\telement.style.oTransform = style;\n}\n\nfunction animateSVG(svgContainer, elements) {\n\tlet newElements = [];\n\tlet animElements = [];\n\n\telements.map(element => {\n\t\tlet unit = element[0];\n\t\tlet parent = unit.parentNode;\n\n\t\tlet animElement, newElement;\n\n\t\telement[0] = unit;\n\t\t[animElement, newElement] = animateSVGElement(...element);\n\n\t\tnewElements.push(newElement);\n\t\tanimElements.push([animElement, parent]);\n\n\t\tparent.replaceChild(animElement, unit);\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\telements[i][0] = newElements[i];\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\n\nlet BOUND_DRAW_FN;\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || 'line';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tBOUND_DRAW_FN = this.boundDrawFn.bind(this);\n\t\twindow.addEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents() {\n\t\twindow.removeEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t\tthis.parent.style.overflow = 'auto';\n\t\t}\n\n\t\tthis.container = $.create('div', args);\n\t}\n\n\tmakeTooltip() {\n\t\tthis.tip = new SvgTip({\n\t\t\tparent: this.container,\n\t\t\tcolors: this.colors\n\t\t});\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {}\n\n\tdraw(onlyWidthChange=false, init=false) {\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { legendDot } from '../utils/draw';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.maxSlices = args.maxSlices || 20;\n\t\tthis.config.maxLegendPoints = args.maxLegendPoints || 20;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\t\tlet maxSlices = this.config.maxSlices;\n\t\ts.sliceTotals = [];\n\n\t\tlet allTotals = this.data.labels.map((label, i) => {\n\t\t\tlet total = 0;\n\t\t\tthis.data.datasets.map(e => {\n\t\t\t\ttotal += e.values[i];\n\t\t\t});\n\t\t\treturn [total, label];\n\t\t}).filter(d => { return d[0] >= 0; }); // keep only positive results\n\n\t\tlet totals = allTotals;\n\t\tif(allTotals.length > maxSlices) {\n\t\t\t// Prune and keep a grey area for rest as per maxSlices\n\t\t\tallTotals.sort((a, b) => { return b[0] - a[0]; });\n\n\t\t\ttotals = allTotals.slice(0, maxSlices-1);\n\t\t\tlet remaining = allTotals.slice(maxSlices-1);\n\n\t\t\tlet sumOfRemaining = 0;\n\t\t\tremaining.map(d => {sumOfRemaining += d[0];});\n\t\t\ttotals.push([sumOfRemaining, 'Rest']);\n\t\t\tthis.colors[maxSlices-1] = 'grey';\n\t\t}\n\n\t\ts.labels = [];\n\t\ttotals.map(d => {\n\t\t\ts.sliceTotals.push(d[0]);\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${s.labels[i]}: ${d}`\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport { makeText, makePath, xLine, yLine, yMarker, yRegion, datasetBar, datasetDot, percentageBar, getPaths, heatSquare } from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport { translateHoriLine, translateVertLine, animateRegion, animateBar,\n\tanimateDot, animatePath, animatePathStr } from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n\tconstructor({\n\t\tlayerClass = '',\n\t\tlayerTransform = '',\n\t\tconstants,\n\n\t\tgetData,\n\t\tmakeElements,\n\t\tanimateElements\n\t}) {\n\t\tthis.layerTransform = layerTransform;\n\t\tthis.constants = constants;\n\n\t\tthis.makeElements = makeElements;\n\t\tthis.getData = getData;\n\n\t\tthis.animateElements = animateElements;\n\n\t\tthis.store = [];\n\t\tthis.labels = [];\n\n\t\tthis.layerClass = layerClass;\n\t\tthis.layerClass = typeof(this.layerClass) === 'function'\n\t\t\t? this.layerClass() : this.layerClass;\n\n\t\tthis.refresh();\n\t}\n\n\trefresh(data) {\n\t\tthis.data = data || this.getData();\n\t}\n\n\tsetup(parent) {\n\t\tthis.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n\t}\n\n\tmake() {\n\t\tthis.render(this.data);\n\t\tthis.oldData = this.data;\n\t}\n\n\trender(data) {\n\t\tthis.store = this.makeElements(data);\n\n\t\tthis.layer.textContent = '';\n\t\tthis.store.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t\tthis.labels.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t}\n\n\tupdate(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tpieSlices: {\n\t\tlayerClass: 'pie-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) =>{\n\t\t\t\tlet slice = makePath(s, 'pie-path', 'none', data.colors[i]);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) =>\n\t\t\t\tanimatePathStr(slice, newData.sliceStrings[i])\n\t\t\t);\n\t\t}\n\t},\n\tpercentageBars: {\n\t\tlayerClass: 'percentage-bars',\n\t\tmakeElements(data) {\n\t\t\treturn data.xPositions.map((x, i) =>{\n\t\t\t\tlet y = 0;\n\t\t\t\tlet bar = percentageBar(x, y, data.widths[i],\n\t\t\t\t\tthis.constants.barHeight, this.constants.barDepth, data.colors[i]);\n\t\t\t\treturn bar;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\tyAxis: {\n\t\tlayerClass: 'y axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\tyLine(position, data.labels[i], this.constants.width,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.labels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tlabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(m =>\n\t\t\t\tyMarker(m.position, m.label, this.constants.width,\n\t\t\t\t\t{labelPos: m.options.labelPos, mode: 'span', lineType: 'dashed'})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, day.fill, data);\n\t\t\t\t\t\tthis.serializedSubDomains.push(square);\n\t\t\t\t\t}\n\t\t\t\t\ty += rowHeight;\n\t\t\t\t});\n\t\t\t\ty = 0;\n\t\t\t\tx += colWidth;\n\t\t\t});\n\n\t\t\treturn this.serializedSubDomains;\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\n\tbarGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-bars dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'bar';\n\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\treturn datasetBar(\n\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\ty,\n\t\t\t\t\tdata.barWidth,\n\t\t\t\t\tc.color,\n\t\t\t\t\tdata.labels[j],\n\t\t\t\t\tj,\n\t\t\t\t\tdata.offsets[j],\n\t\t\t\t\t{\n\t\t\t\t\t\tzeroLine: data.zeroLine,\n\t\t\t\t\t\tbarsWidth: data.barsWidth,\n\t\t\t\t\t\tminHeight: c.minHeight\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t});\n\t\t\treturn this.units;\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newOffsets = newData.offsets;\n\t\t\tlet newLabels = newData.labels;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldOffsets = this.oldData.offsets;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldOffsets, newOffsets] = equilizeNoOfElements(oldOffsets, newOffsets);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\toffsets: oldOffsets,\n\t\t\t\tlabels: newLabels,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tbarsWidth: this.oldData.barsWidth,\n\t\t\t\tbarWidth: this.oldData.barWidth,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((bar, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateBar(\n\t\t\t\t\tbar, newXPos[i], newYPos[i], newData.barWidth, newOffsets[i],\n\t\t\t\t\t{zeroLine: newData.zeroLine}\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\tlineGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-line dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'dot';\n\t\t\tthis.paths = {};\n\t\t\tif(!c.hideLine) {\n\t\t\t\tthis.paths = getPaths(\n\t\t\t\t\tdata.xPositions,\n\t\t\t\t\tdata.yPositions,\n\t\t\t\t\tc.color,\n\t\t\t\t\t{\n\t\t\t\t\t\theatline: c.heatline,\n\t\t\t\t\t\tregionFill: c.regionFill\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tsvgDefs: c.svgDefs,\n\t\t\t\t\t\tzeroLine: data.zeroLine\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.units = [];\n\t\t\tif(!c.hideDots) {\n\t\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\t\treturn datasetDot(\n\t\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\t\ty,\n\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\tc.color,\n\t\t\t\t\t\t(c.valuesOverPoints ? data.values[j] : ''),\n\t\t\t\t\t\tj\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn Object.values(this.paths).concat(this.units);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newValues = newData.values;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldValues = this.oldData.values;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldValues, newValues] = equilizeNoOfElements(oldValues, newValues);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\tvalues: newValues,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tradius: this.oldData.radius,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tif(Object.keys(this.paths).length) {\n\t\t\t\tanimateElements = animateElements.concat(animatePath(\n\t\t\t\t\tthis.paths, newXPos, newYPos, newData.zeroLine));\n\t\t\t}\n\n\t\t\tif(this.units.length) {\n\t\t\t\tthis.units.map((dot, i) => {\n\t\t\t\t\tanimateElements = animateElements.concat(animateDot(\n\t\t\t\t\t\tdot, newXPos[i], newYPos[i]));\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn animateElements;\n\t\t}\n\t}\n};\n\nexport function getComponent(name, constants, getData) {\n\tlet keys = Object.keys(componentConfigs).filter(k => name.includes(k));\n\tlet config = componentConfigs[keys[0]];\n\tObject.assign(config, {\n\t\tconstants: constants,\n\t\tgetData: getData\n\t});\n\treturn new ChartComponent(config);\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 80;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class PieChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'pie';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius = (this.height > this.width ? this.center.x : this.center.y);\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath = makeArcPathStr(curStart, curEnd, this.center, this.radius, this.clockWise);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import { floatTwo } from './helpers';\n\nfunction normalize(x) {\n\t// Calculates mantissa and exponent of a number\n\t// Returns normalized number and exponent\n\t// https://stackoverflow.com/q/9383593/6495043\n\n\tif(x===0) {\n\t\treturn [0, 0];\n\t}\n\tif(isNaN(x)) {\n\t\treturn {mantissa: -6755399441055744, exponent: 972};\n\t}\n\tvar sig = x > 0 ? 1 : -1;\n\tif(!isFinite(x)) {\n\t\treturn {mantissa: sig * 4503599627370496, exponent: 972};\n\t}\n\n\tx = Math.abs(x);\n\tvar exp = Math.floor(Math.log10(x));\n\tvar man = x/Math.pow(10, exp);\n\n\treturn [sig * man, exp];\n}\n\nfunction getChartRangeIntervals(max, min=0) {\n\tlet upperBound = Math.ceil(max);\n\tlet lowerBound = Math.floor(min);\n\tlet range = upperBound - lowerBound;\n\n\tlet noOfParts = range;\n\tlet partSize = 1;\n\n\t// To avoid too many partitions\n\tif(range > 5) {\n\t\tif(range % 2 !== 0) {\n\t\t\tupperBound++;\n\t\t\t// Recalc range\n\t\t\trange = upperBound - lowerBound;\n\t\t}\n\t\tnoOfParts = range/2;\n\t\tpartSize = 2;\n\t}\n\n\t// Special case: 1 and 2\n\tif(range <= 2) {\n\t\tnoOfParts = 4;\n\t\tpartSize = range/noOfParts;\n\t}\n\n\t// Special case: 0\n\tif(range === 0) {\n\t\tnoOfParts = 5;\n\t\tpartSize = 1;\n\t}\n\n\tlet intervals = [];\n\tfor(var i = 0; i <= noOfParts; i++){\n\t\tintervals.push(lowerBound + partSize * i);\n\t}\n\treturn intervals;\n}\n\nfunction getChartIntervals(maxValue, minValue=0) {\n\tlet [normalMaxValue, exponent] = normalize(maxValue);\n\tlet normalMinValue = minValue ? minValue/Math.pow(10, exponent): 0;\n\n\t// Allow only 7 significant digits\n\tnormalMaxValue = normalMaxValue.toFixed(6);\n\n\tlet intervals = getChartRangeIntervals(normalMaxValue, normalMinValue);\n\tintervals = intervals.map(value => value * Math.pow(10, exponent));\n\treturn intervals;\n}\n\nexport function calcChartIntervals(values, withMinimum=false) {\n\t//*** Where the magic happens ***\n\n\t// Calculates best-fit y intervals from given values\n\t// and returns the interval array\n\n\tlet maxValue = Math.max(...values);\n\tlet minValue = Math.min(...values);\n\n\t// Exponent to be used for pretty print\n\tlet exponent = 0, intervals = []; // eslint-disable-line no-unused-vars\n\n\tfunction getPositiveFirstIntervals(maxValue, absMinValue) {\n\t\tlet intervals = getChartIntervals(maxValue);\n\n\t\tlet intervalSize = intervals[1] - intervals[0];\n\n\t\t// Then unshift the negative values\n\t\tlet value = 0;\n\t\tfor(var i = 1; value < absMinValue; i++) {\n\t\t\tvalue += intervalSize;\n\t\t\tintervals.unshift((-1) * value);\n\t\t}\n\t\treturn intervals;\n\t}\n\n\t// CASE I: Both non-negative\n\n\tif(maxValue >= 0 && minValue >= 0) {\n\t\texponent = normalize(maxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(maxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(maxValue, minValue);\n\t\t}\n\t}\n\n\t// CASE II: Only minValue negative\n\n\telse if(maxValue > 0 && minValue < 0) {\n\t\t// `withMinimum` irrelevant in this case,\n\t\t// We'll be handling both sides of zero separately\n\t\t// (both starting from zero)\n\t\t// Because ceil() and floor() behave differently\n\t\t// in those two regions\n\n\t\tlet absMinValue = Math.abs(minValue);\n\n\t\tif(maxValue >= absMinValue) {\n\t\t\texponent = normalize(maxValue)[1];\n\t\t\tintervals = getPositiveFirstIntervals(maxValue, absMinValue);\n\t\t} else {\n\t\t\t// Mirror: maxValue => absMinValue, then change sign\n\t\t\texponent = normalize(absMinValue)[1];\n\t\t\tlet posIntervals = getPositiveFirstIntervals(absMinValue, maxValue);\n\t\t\tintervals = posIntervals.map(d => d * (-1));\n\t\t}\n\n\t}\n\n\t// CASE III: Both non-positive\n\n\telse if(maxValue <= 0 && minValue <= 0) {\n\t\t// Mirrored Case I:\n\t\t// Work with positives, then reverse the sign and array\n\n\t\tlet pseudoMaxValue = Math.abs(minValue);\n\t\tlet pseudoMinValue = Math.abs(maxValue);\n\n\t\texponent = normalize(pseudoMaxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue, pseudoMinValue);\n\t\t}\n\n\t\tintervals = intervals.reverse().map(d => d * (-1));\n\t}\n\n\treturn intervals;\n}\n\nexport function getZeroIndex(yPts) {\n\tlet zeroIndex;\n\tlet interval = getIntervalSize(yPts);\n\tif(yPts.indexOf(0) >= 0) {\n\t\t// the range has a given zero\n\t\t// zero-line on the chart\n\t\tzeroIndex = yPts.indexOf(0);\n\t} else if(yPts[0] > 0) {\n\t\t// Minimum value is positive\n\t\t// zero-line is off the chart: below\n\t\tlet min = yPts[0];\n\t\tzeroIndex = (-1) * min / interval;\n\t} else {\n\t\t// Maximum value is negative\n\t\t// zero-line is off the chart: above\n\t\tlet max = yPts[yPts.length - 1];\n\t\tzeroIndex = (-1) * max / interval + (yPts.length - 1);\n\t}\n\treturn zeroIndex;\n}\n\nexport function getRealIntervals(max, noOfIntervals, min = 0, asc = 1) {\n\tlet range = max - min;\n\tlet part = range * 1.0 / noOfIntervals;\n\tlet intervals = [];\n\n\tfor(var i = 0; i <= noOfIntervals; i++) {\n\t\tintervals.push(min + part * i);\n\t}\n\n\treturn asc ? intervals : intervals.reverse();\n}\n\nexport function getIntervalSize(orderedArray) {\n\treturn orderedArray[1] - orderedArray[0];\n}\n\nexport function getValueRange(orderedArray) {\n\treturn orderedArray[orderedArray.length-1] - orderedArray[0];\n}\n\nexport function scale(val, yAxis) {\n\treturn floatTwo(yAxis.zeroLine - val * yAxis.scaleMultiplier);\n}\n\nexport function isInRange(val, min, max) {\n\treturn val > min && val < max;\n}\n\nexport function isInRange2D(coord, minCoord, maxCoord) {\n\treturn isInRange(coord[0], minCoord[0], maxCoord[0])\n\t\t&& isInRange(coord[1], minCoord[1], maxCoord[1]);\n}\n\nexport function getClosestInArray(goal, arr, index = false) {\n\tlet closest = arr.reduce(function(prev, curr) {\n\t\treturn (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);\n\t});\n\n\treturn index ? arr.indexOf(closest) : closest;\n}\n\nexport function calcDistribution(values, distributionSize) {\n\t// Assume non-negative values,\n\t// implying distribution minimum at zero\n\n\tlet dataMaxValue = Math.max(...values);\n\n\tlet distributionStep = 1 / (distributionSize - 1);\n\tlet distribution = [];\n\n\tfor(var i = 0; i < distributionSize; i++) {\n\t\tlet checkpoint = dataMaxValue * (distributionStep * i);\n\t\tdistribution.push(checkpoint);\n\t}\n\n\treturn distribution;\n}\n\nexport function getMaxCheckpoint(value, distribution) {\n\treturn distribution.filter(d => d < value).length;\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\txTranslate: s.domainConfigs\n\t\t\t\t\t.filter((config, j) => j < i)\n\t\t\t\t\t.map(config => config.cols.length - lessCol)\n\t\t\t\t\t.reduce((a, b) => a + b, 0)\n\t\t\t\t\t* COL_WIDTH\n\t\t\t},\n\t\t\tfunction() {\n\t\t\t\treturn s.domainConfigs[i];\n\t\t\t}.bind(this)\n\n\t\t]);\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map((args, i) => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0] + '-' + i, component];\n\t\t\t})\n\t\t);\n\n\t\tlet y = 0;\n\t\tDAY_NAMES_SHORT.forEach((dayName, i) => {\n\t\t\tif([1, 3, 5].includes(i)) {\n\t\t\t\tlet dayText = makeText('subdomain-name', -COL_WIDTH/2, y, dayName,\n\t\t\t\t\t{\n\t\t\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\t\t\tdy: 8,\n\t\t\t\t\t\ttextAnchor: 'end'\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tthis.drawArea.appendChild(dayText);\n\t\t\t}\n\t\t\ty += ROW_HEIGHT;\n\t\t});\n\t}\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\n\t\tthis.data = this.prepareData(data);\n\t\tthis.draw();\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tthis.components.forEach(comp => {\n\t\t\t\tlet daySquares = comp.store;\n\t\t\t\tlet daySquare = e.target;\n\t\t\t\tif(daySquares.includes(daySquare)) {\n\n\t\t\t\t\tlet count = daySquare.getAttribute('data-value');\n\t\t\t\t\tlet dateParts = daySquare.getAttribute('data-date').split('-');\n\n\t\t\t\t\tlet month = getMonthName(parseInt(dateParts[1])-1, true);\n\n\t\t\t\t\tlet gOff = this.container.getBoundingClientRect(), pOff = daySquare.getBoundingClientRect();\n\n\t\t\t\t\tlet width = parseInt(e.target.getAttribute('width'));\n\t\t\t\t\tlet x = pOff.left - gOff.left + width/2;\n\t\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\t\tlet value = count + ' ' + this.countLabel;\n\t\t\t\t\tlet name = ' on ' + month + ' ' + dateParts[0] + ', ' + dateParts[2];\n\n\t\t\t\t\tthis.tip.setValues(x, y, {name: name, value: value, valueFirst: 1}, []);\n\t\t\t\t\tthis.tip.showTip();\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\trenderLegend() {\n\t\tthis.legendArea.textContent = '';\n\t\tlet x = 0;\n\t\tlet y = ROW_HEIGHT;\n\n\t\tlet lessText = makeText('subdomain-name', x, y, 'Less',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tx = (COL_WIDTH * 2) + COL_WIDTH/2;\n\t\tthis.legendArea.appendChild(lessText);\n\n\t\tthis.colors.slice(0, HEATMAP_DISTRIBUTION_SIZE).map((color, i) => {\n\t\t\tconst square = heatSquare('heatmap-legend-unit', x + (COL_WIDTH + 3) * i,\n\t\t\t\ty, HEATMAP_SQUARE_SIZE, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import { fillArray } from '../utils/helpers';\nimport { AXIS_CHART_DEFAULT_TYPE, AXIS_CHART_MIXED_TYPE, AXIS_DATASET_CHART_TYPES, DEFAULT_CHAR_WIDTH } from '../utils/constants';\n\nexport function dataPrep(data, type) {\n\tdata.labels = data.labels || [];\n\n\tlet datasetLength = data.labels.length;\n\n\t// Datasets\n\tlet datasets = data.datasets;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\tif(!datasets) {\n\t\t// default\n\t\tdatasets = [{\n\t\t\tvalues: zeroArray\n\t\t}];\n\t}\n\n\tlet overridingType;\n\tif(AXIS_DATASET_CHART_TYPES.includes(type)) {\n\t\toverridingType = type;\n\t};\n\n\tdatasets.map(d=> {\n\t\t// Set values\n\t\tif(!d.values) {\n\t\t\td.values = zeroArray;\n\t\t} else {\n\t\t\t// Check for non values\n\t\t\tlet vals = d.values;\n\t\t\tvals = vals.map(val => (!isNaN(val) ? val : 0));\n\n\t\t\t// Trim or extend\n\t\t\tif(vals.length > datasetLength) {\n\t\t\t\tvals = vals.slice(0, datasetLength);\n\t\t\t} else {\n\t\t\t\tvals = fillArray(vals, datasetLength - vals.length, 0);\n\t\t\t}\n\t\t}\n\n\t\t// Set labels\n\n\t\t// Set type\n\t\tif(overridingType) {\n\t\t\td.chartType = overridingType;\n\t\t} else if(!d.chartType) {\n\t\t\td.chartType = AXIS_CHART_DEFAULT_TYPE;\n\t\t}\n\t});\n\n\t// Markers\n\n\t// Regions\n\t// data.yRegions = data.yRegions || [];\n\tif(data.yRegions) {\n\t\tdata.yRegions.map(d => {\n\t\t\tif(d.end < d.start) {\n\t\t\t\t[d.start, d.end] = [d.end, d.start];\n\t\t\t}\n\t\t});\n\t}\n\n\treturn data;\n}\n\nexport function zeroDataPrep(realData) {\n\tlet datasetLength = realData.labels.length;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\n\tlet zeroData = {\n\t\tlabels: realData.labels.slice(0, -1),\n\t\tdatasets: realData.datasets.map(d => {\n\t\t\treturn {\n\t\t\t\tname: '',\n\t\t\t\tvalues: zeroArray.slice(0, -1),\n\t\t\t\tchartType: d.chartType\n\t\t\t};\n\t\t}),\n\t};\n\n\tif(realData.yMarkers) {\n\t\tzeroData.yMarkers = [\n\t\t\t{\n\t\t\t\tvalue: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\tif(realData.yRegions) {\n\t\tzeroData.yRegions = [\n\t\t\t{\n\t\t\t\tstart: 0,\n\t\t\t\tend: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\treturn zeroData;\n}\n\nexport function getShortenedLabels(chartWidth, labels=[], isSeries=true) {\n\tlet allowedSpace = chartWidth / labels.length;\n\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet calcLabels = labels.map((label, i) => {\n\t\tlabel += \"\";\n\t\tif(label.length > allowedLetters) {\n\n\t\t\tif(!isSeries) {\n\t\t\t\tif(allowedLetters-3 > 0) {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters-3) + \" ...\";\n\t\t\t\t} else {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters) + '..';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlet multiple = Math.ceil(label.length/allowedLetters);\n\t\t\t\tif(i % multiple !== 0) {\n\t\t\t\t\tlabel = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn label;\n\t});\n\n\treturn calcLabels;\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n\t\tsuper.configure(options);\n\n\t\toptions.axisOptions = options.axisOptions || {};\n\t\toptions.tooltipOptions = options.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = options.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = options.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = options.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\tcalcYAxisParameters(dataValues, withMinimum = 'false') {\n\t\tconst yPts = calcChartIntervals(dataValues, withMinimum);\n\t\tconst scaleMultiplier = this.height / getValueRange(yPts);\n\t\tconst intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n\t\tconst zeroLine = this.height - (getZeroIndex(yPts) * intervalHeight);\n\n\t\tthis.state.yAxis = {\n\t\t\tlabels: yPts,\n\t\t\tpositions: yPts.map(d => zeroLine - d * scaleMultiplier),\n\t\t\tscaleMultiplier: scaleMultiplier,\n\t\t\tzeroLine: zeroLine,\n\t\t};\n\n\t\t// Dependent if above changes\n\t\tthis.calcDatasetPoints();\n\t\tthis.calcYExtremes();\n\t\tthis.calcYRegions();\n\t}\n\n\tcalcDatasetPoints() {\n\t\tlet s = this.state;\n\t\tlet scaleAll = values => values.map(val => scale(val, s.yAxis));\n\n\t\ts.datasets = this.data.datasets.map((d, i) => {\n\t\t\tlet values = d.values;\n\t\t\tlet cumulativeYs = d.cumulativeYs || [];\n\t\t\treturn {\n\t\t\t\tname: d.name,\n\t\t\t\tindex: i,\n\t\t\t\tchartType: d.chartType,\n\n\t\t\t\tvalues: values,\n\t\t\t\tyPositions: scaleAll(values),\n\n\t\t\t\tcumulativeYs: cumulativeYs,\n\t\t\t\tcumulativeYPos: scaleAll(cumulativeYs),\n\t\t\t};\n\t\t});\n\t}\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n\tgetAllYValues() {\n\t\tlet key = 'values';\n\n\t\tif(this.barOptions.stacked) {\n\t\t\tkey = 'cumulativeYs';\n\t\t\tlet cumulative = new Array(this.state.datasetLength).fill(0);\n\t\t\tthis.data.datasets.map((d, i) => {\n\t\t\t\tlet values = this.data.datasets[i].values;\n\t\t\t\td[key] = cumulative = cumulative.map((c, i) => c + values[i]);\n\t\t\t});\n\t\t}\n\n\t\tlet allValueLists = this.data.datasets.map(d => d[key]);\n\t\tif(this.data.yMarkers) {\n\t\t\tallValueLists.push(this.data.yMarkers.map(d => d.value));\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.data.yRegions.map(d => {\n\t\t\t\tallValueLists.push([d.end, d.start]);\n\t\t\t});\n\t\t}\n\n\t\treturn [].concat(...allValueLists);\n\t}\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'yAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.yAxisMode,\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'xAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.xAxisMode,\n\t\t\t\t\theight: this.height,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\ts.xAxis.calcLabels = getShortenedLabels(this.width,\n\t\t\t\t\t\ts.xAxis.labels, this.config.xIsSeries);\n\n\t\t\t\t\treturn s.xAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'yRegions',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yRegions;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\t\t];\n\n\t\tlet barDatasets = this.state.datasets.filter(d => d.chartType === 'bar');\n\t\tlet lineDatasets = this.state.datasets.filter(d => d.chartType === 'line');\n\n\t\tlet barsConfigs = barDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'barGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tstacked: this.barOptions.stacked,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t\tminHeight: this.height * MIN_BAR_PERCENT_HEIGHT,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet stacked = this.barOptions.stacked;\n\n\t\t\t\t\tlet spaceRatio = this.barOptions.spaceRatio || BAR_CHART_SPACE_RATIO;\n\t\t\t\t\tlet barsWidth = s.unitWidth/2 * (2 - spaceRatio);\n\t\t\t\t\tlet barWidth = barsWidth/(stacked ? 1 : barDatasets.length);\n\n\t\t\t\t\tlet xPositions = s.xAxis.positions.map(x => x - barsWidth/2);\n\t\t\t\t\tif(!stacked) {\n\t\t\t\t\t\txPositions = xPositions.map(p => p + barWidth * index);\n\t\t\t\t\t}\n\n\t\t\t\t\tlet labels = new Array(s.datasetLength).fill('');\n\t\t\t\t\tif(this.config.valuesOverPoints) {\n\t\t\t\t\t\tif(stacked && d.index === s.datasets.length - 1) {\n\t\t\t\t\t\t\tlabels = d.cumulativeYs;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tlabels = d.values;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet offsets = new Array(s.datasetLength).fill(0);\n\t\t\t\t\tif(stacked) {\n\t\t\t\t\t\toffsets = d.yPositions.map((y, j) => y - d.cumulativeYPos[j]);\n\t\t\t\t\t}\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: xPositions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\t\t\t\t\t\toffsets: offsets,\n\t\t\t\t\t\t// values: d.values,\n\t\t\t\t\t\tlabels: labels,\n\n\t\t\t\t\t\tzeroLine: s.yAxis.zeroLine,\n\t\t\t\t\t\tbarsWidth: barsWidth,\n\t\t\t\t\t\tbarWidth: barWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet lineConfigs = lineDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'lineGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tsvgDefs: this.svgDefs,\n\t\t\t\t\theatline: this.lineOptions.heatline,\n\t\t\t\t\tregionFill: this.lineOptions.regionFill,\n\t\t\t\t\thideDots: this.lineOptions.hideDots,\n\t\t\t\t\thideLine: this.lineOptions.hideLine,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet minLine = s.yAxis.positions[0] < s.yAxis.zeroLine\n\t\t\t\t\t\t? s.yAxis.positions[0] : s.yAxis.zeroLine;\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xAxis.positions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\n\t\t\t\t\t\tvalues: d.values,\n\n\t\t\t\t\t\tzeroLine: minLine,\n\t\t\t\t\t\tradius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tlet dbi = this.dataByIndex[index];\n\n\t\tthis.tip.setValues(\n\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\tdbi.values,\n\t\t\tindex\n\t\t);\n\n\t\tthis.tip.showTip();\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name);\n\t\t\t\tthis.legendArea.appendChild(rect);\n\t\t\t});\n\t\t}\n\t}\n\n\n\n\t// Overlay\n\tmakeOverlay() {\n\t\tif(this.init) {\n\t\t\tthis.init = 0;\n\t\t\treturn;\n\t\t}\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\n\t\tthis.overlayGuides = this.dataUnitComponents.map(c => {\n\t\t\treturn {\n\t\t\t\ttype: c.unitType,\n\t\t\t\toverlay: undefined,\n\t\t\t\tunits: c.units,\n\t\t\t};\n\t\t});\n\n\t\tif(this.state.currentIndex === undefined) {\n\t\t\tthis.state.currentIndex = this.state.datasetLength - 1;\n\t\t}\n\n\t\t// Render overlays\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\n\t\t\td.overlay = makeOverlay[d.type](currentUnit);\n\t\t\tthis.drawArea.appendChild(d.overlay);\n\t\t});\n\t}\n\n\tupdateOverlayGuides() {\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\t}\n\n\tbindOverlay() {\n\t\tthis.parent.addEventListener('data-select', () => {\n\t\t\tthis.updateOverlay();\n\t\t});\n\t}\n\n\tbindUnits() {\n\t\tthis.dataUnitComponents.map(c => {\n\t\t\tc.units.map(unit => {\n\t\t\t\tunit.addEventListener('click', () => {\n\t\t\t\t\tlet index = unit.getAttribute('data-point-index');\n\t\t\t\t\tthis.setCurrentDataPoint(index);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\t// Note: Doesn't work as tooltip is absolutely positioned\n\t\tthis.tip.container.addEventListener('click', () => {\n\t\t\tlet index = this.tip.container.getAttribute('data-point-index');\n\t\t\tthis.setCurrentDataPoint(index);\n\t\t});\n\t}\n\n\tupdateOverlay() {\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\t\t\tupdateOverlay[d.type](currentUnit, d.overlay);\n\t\t});\n\t}\n\n\tonLeftArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex - 1);\n\t}\n\n\tonRightArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex + 1);\n\t}\n\n\tgetDataPoint(index=this.state.currentIndex) {\n\t\tlet s = this.state;\n\t\tlet data_point = {\n\t\t\tindex: index,\n\t\t\tlabel: s.xAxis.labels[index],\n\t\t\tvalues: s.datasets.map(d => d.values[index])\n\t\t};\n\t\treturn data_point;\n\t}\n\n\tsetCurrentDataPoint(index) {\n\t\tlet s = this.state;\n\t\tindex = parseInt(index);\n\t\tif(index < 0) index = 0;\n\t\tif(index >= s.xAxis.labels.length) index = s.xAxis.labels.length - 1;\n\t\tif(index === s.currentIndex) return;\n\t\ts.currentIndex = index;\n\t\tfire(this.parent, \"data-select\", this.getDataPoint());\n\t}\n\n\n\n\t// API\n\taddDataPoint(label, datasetValues, index=this.state.datasetLength) {\n\t\tsuper.addDataPoint(label, datasetValues, index);\n\t\tthis.data.labels.splice(index, 0, label);\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\td.values.splice(index, 0, datasetValues[i]);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tremoveDataPoint(index = this.state.datasetLength-1) {\n\t\tif (this.data.labels.length <= 1) {\n\t\t\treturn;\n\t\t}\n\t\tsuper.removeDataPoint(index);\n\t\tthis.data.labels.splice(index, 1);\n\t\tthis.data.datasets.map(d => {\n\t\t\td.values.splice(index, 1);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tupdateDataset(datasetValues, index=0) {\n\t\tthis.data.datasets[index].values = datasetValues;\n\t\tthis.update(this.data);\n\t}\n\t// addDataset(dataset, index) {}\n\t// removeDataset(index = 0) {}\n\n\tupdateDatasets(datasets) {\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\tif(datasets[i]) {\n\t\t\t\td.values = datasets[i];\n\t\t\t}\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\t// updateDataPoint(dataPoint, index = 0) {}\n\t// addDataPoint(dataPoint, index = 0) {}\n\t// removeDataPoint(index = 0) {}\n}\n","import '../css/charts.scss';\n\n// import MultiAxisChart from './charts/MultiAxisChart';\nimport PercentageChart from './charts/PercentageChart';\nimport PieChart from './charts/PieChart';\nimport Heatmap from './charts/Heatmap';\nimport AxisChart from './charts/AxisChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };"],"names":["$","expr","con","document","querySelector","create","tag","o","element","createElement","i","val","appendChild","ref","parentNode","insertBefore","addEventListener","e","value","keys","map","style","prop","setAttribute","getOffset","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isElementInViewport","el","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","type","properties","evt","createEvent","initEvent","j","dispatchEvent","BASE_MEASURES","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","totalExtraHeight","legendHeight","getExtraWidth","totalExtraWidth","INIT_CHART_UPDATE_TIMEOUT","CHART_POST_ANIMATE_TIMEOUT","AXIS_CHART_DEFAULT_TYPE","AXIS_DATASET_CHART_TYPES","AXIS_LEGEND_BAR_SIZE","BAR_CHART_SPACE_RATIO","MIN_BAR_PERCENT_HEIGHT","LINE_CHART_DOT_SIZE","DOT_OVERLAY_SIZE_INCR","PERCENTAGE_BAR_DEFAULT_HEIGHT","PERCENTAGE_BAR_DEFAULT_DEPTH","HEATMAP_DISTRIBUTION_SIZE","HEATMAP_SQUARE_SIZE","HEATMAP_GUTTER_SIZE","DEFAULT_CHAR_WIDTH","TOOLTIP_POINTER_TRIANGLE_HEIGHT","DEFAULT_CHART_COLORS","HEATMAP_COLORS_GREEN","DEFAULT_COLORS","ANGLE_RATIO","Math","PI","FULL_ANGLE","SvgTip","parent","colors","titleName","titleValue","listValues","titleValueFirst","x","y","setup","makeTooltip","fill","calcPosition","container","hideTip","title","dataPointList","index","innerHTML","set","color","formatted","li","width","offsetWidth","offsetHeight","maxLeft","pointer","delta","pointerOffset","name","valueFirst","refresh","opacity","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","abs","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","cos","getBarHeightAndYAttr","yTop","zeroLine","height","equilizeNoOfElements","array1","array2","extraCount","PRESET_COLOR_MAP","limitColor","r","lightenDarkenColor","amt","col","getColor","usePound","slice","num","parseInt","b","g","toString","isValidColor","test","AXIS_TICK_LENGTH","LABEL_MARGIN","FONT_SIZE","BASE_LINE_COLOR","FONT_FILL","createSVG","createElementNS","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","makeSVGContainer","className","makeSVGDefs","svgContainer","makeSVGGroup","transform","undefined","args","inside","makePath","pathStr","stroke","makeArcPathStr","startPosition","endPosition","center","clockWise","arcStartX","arcStartY","arcEndX","arcEndY","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","heatSquare","size","data","key","legendBar","label","text","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","l","line","makeHoriLine","x1","x2","lineType","yLine","pos","mode","xLine","yMarker","labelPos","labelSvg","yRegion","region","datasetBar","meta","minHeight","datasetDot","dot","getPaths","xList","yList","pointsList","pointsStr","join","path","heatline","gradient_id","svgDefs","paths","regionFill","gradient_id_region","makeOverlay","unit","transformValue","nodeName","getAttribute","childNodes","overlay","cloneNode","updateOverlay","attributes","values","filter","includes","attr","specified","nodeValue","UNIT_ANIM_DUR","PATH_ANIM_DUR","MARKER_LINE_ANIM_DUR","REPLACE_ALL_NEW_DUR","STD_EASING","translate","oldCoord","newCoord","duration","old","translateVertLine","newX","oldX","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","rectAnim","groupAnim","animateBar","bar","oldCoordStr","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","push","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","EASING","animateSVGElement","props","dur","easingType","oldValues","animElement","newElement","attributeName","animateElement","currentValue","animAttr","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","CSSTEXT","downloadFile","filename","a","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","firstChild","BOUND_DRAW_FN","BaseChart","HTMLElement","Error","rawChartArgs","realData","prepareData","prepareFirstData","validateColors","config","isNavigable","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","bind","draw","removeEventListener","makeContainer","updateWidth","independentWidth","overflow","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","c","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","error","animate","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","event","keyCode","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","labels","total","datasets","totals","sort","remaining","sumOfRemaining","grandTotal","reduce","textContent","legendTotals","barWidth","divisor","floor","NO_OF_YEAR_MONTHS","NO_OF_DAYS_IN_WEEK","NO_OF_MILLIS","SEC_IN_DAY","MONTH_NAMES","DAY_NAMES_SHORT","treatAsUtc","date","result","Date","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","getTime","getWeeksBetween","startDate","endDate","weekStartDate","setDayToSunday","ceil","getDaysBetween","millisecondsPerDay","areInSameMonth","getMonthName","short","monthName","getLastDateInMonth","month","year","newDate","day","getDay","addDays","numberOfDays","setDate","ChartComponent","layerClass","layerTransform","constants","getData","makeElements","animateElements","store","layer","oldData","componentConfigs","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","newOptions","startPos","endPos","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","monthNameHeight","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","offsets","barsWidth","newXPos","newYPos","newOffsets","oldXPos","oldYPos","oldOffsets","hideLine","hideDots","valuesOverPoints","Object","newValues","getComponent","k","assign","PercentageChart","barOptions","component","xPos","bars","get","indexOf","gOff","pOff","formattedLabels","fraction","setValues","showTip","PieChart","mouseMove","mouseLeave","hoverRadio","startAngle","prevSlicesProperties","slicesProperties","curAngle","originDiffAngle","diffAngle","endAngle","prevProperty","curStart","curEnd","curPath","property","flag","calTranslateByAngle","g_off","pageX","pageY","formatted_labels","percent","slices","prevIndex","curActiveSliceIndex","prevAcitve","curActiveSlice","hoverSlice","normalize","isNaN","mantissa","exponent","sig","isFinite","exp","log10","man","pow","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","withMinimum","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","posIntervals","pseudoMaxValue","pseudoMinValue","reverse","getZeroIndex","yPts","zeroIndex","interval","getIntervalSize","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","prev","curr","calcDistribution","distributionSize","dataMaxValue","distributionStep","distribution","checkpoint","getMaxCheckpoint","COL_WIDTH","ROW_HEIGHT","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","spacing","end","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","moreTextX","moreText","startMonth","startYear","endMonth","endYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","dataPrep","datasetLength","zeroArray","overridingType","vals","chartType","yRegions","zeroDataPrep","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedSpace","allowedLetters","multiple","AxisChart","lineOptions","axisOptions","tooltipOptions","xAxisMode","yAxisMode","xIsSeries","formatTooltipX","formatTooltipY","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","xAxis","dataValues","intervalHeight","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","cumulativeYs","stacked","yExtremes","cumulativeYPos","cumulative","allValueLists","barDatasets","lineDatasets","barsConfigs","spaceRatio","p","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","titles","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","setCurrentDataPoint","data_point","getDataPoint","datasetValues","splice","chartTypes","getChartByType","Chart"],"mappings":"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"}
\ No newline at end of file
+{"version":3,"file":"frappe-charts.min.esm.js","sources":["../src/js/utils/dom.js","../src/js/utils/constants.js","../src/js/objects/SvgTip.js","../src/js/utils/helpers.js","../src/js/utils/draw-utils.js","../src/js/utils/colors.js","../src/js/utils/draw.js","../src/js/utils/animate.js","../src/js/utils/animation.js","../src/css/chartsCss.js","../src/js/utils/export.js","../src/js/charts/BaseChart.js","../src/js/charts/AggregationChart.js","../src/js/utils/date-utils.js","../src/js/objects/ChartComponents.js","../src/js/charts/PercentageChart.js","../src/js/charts/PieChart.js","../src/js/utils/intervals.js","../src/js/charts/Heatmap.js","../src/js/utils/axis-chart-utils.js","../src/js/charts/AxisChart.js","../src/js/chart.js"],"sourcesContent":["export function $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function findNodeIndex(node)\n{\n\tvar i = 0;\n\twhile (node.previousSibling) {\n\t\tnode = node.previousSibling;\n\t\ti++;\n\t}\n\treturn i;\n}\n\n$.create = (tag, o) => {\n\tvar element = document.createElement(tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"onClick\" ) {\n\t\t\telement.addEventListener('click', val);\n\n\t\t} else if (i === \"onInput\" ) {\n\t\t\telement.addEventListener('input', function(e) {\n\t\t\t\tval(element.value);\n\t\t\t});\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (i in element ) {\n\t\t\telement[i] = val;\n\t\t}\n\t\telse {\n\t\t\telement.setAttribute(i, val);\n\t\t}\n\t}\n\n\treturn element;\n};\n\nexport function getOffset(element) {\n\tlet rect = element.getBoundingClientRect();\n\treturn {\n\t\t// https://stackoverflow.com/a/7436602/6495043\n\t\t// rect.top varies with scroll, so we add whatever has been\n\t\t// scrolled to it to get absolute distance from actual page top\n\t\ttop: rect.top + (document.documentElement.scrollTop || document.body.scrollTop),\n\t\tleft: rect.left + (document.documentElement.scrollLeft || document.body.scrollLeft)\n\t};\n}\n\nexport function isElementInViewport(el) {\n\t// Although straightforward: https://stackoverflow.com/a/7557433/6495043\n\tvar rect = el.getBoundingClientRect();\n\n\treturn (\n\t\trect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */\n rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */\n\t);\n}\n\nexport function getElementContentWidth(element) {\n\tvar styles = window.getComputedStyle(element);\n\tvar padding = parseFloat(styles.paddingLeft) +\n\t\tparseFloat(styles.paddingRight);\n\n\treturn element.clientWidth - padding;\n}\n\nexport function bind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function (event) {\n\t\t\t\telement.addEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function unbind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function(event) {\n\t\t\t\telement.removeEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function fire(target, type, properties) {\n\tvar evt = document.createEvent(\"HTMLEvents\");\n\n\tevt.initEvent(type, true, true );\n\n\tfor (var j in properties) {\n\t\tevt[j] = properties[j];\n\t}\n\n\treturn target.dispatchEvent(evt);\n}\n\n// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/\nexport function forEachNode(nodeList, callback, scope) {\n\tif(!nodeList) return;\n\tfor (var i = 0; i < nodeList.length; i++) {\n\t\tcallback.call(scope, nodeList[i], i);\n\t}\n}\n\nexport function activate($parent, $child, commonSelector, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`${commonSelector}.${activeClass}`);\n\n\tif (typeof $child === 'string') {\n\t\t$child = $parent.querySelector($child);\n\t}\n\n\tthis.forEachNode($children, (node, i) => {\n\t\tif(index >= 0 && i <= index) return;\n\t\tnode.classList.remove(activeClass);\n\t})\n\n\t$child.classList.add(activeClass);\n}\n\nexport function insertAfter(newNode, referenceNode) {\n referenceNode.parentNode.insertBefore(newNode, referenceNode.nextSibling);\n}\n","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const AXIS_CHART_DEFAULT_TYPE = 'line';\nexport const AXIS_CHART_MIXED_TYPE = 'axis-mixed';\nexport const AXIS_CHART_TYPES = ['line', 'bar', 'axis-mixed'];\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_CHART_OPTIONS = {\n\tbarOptions: {\n\t\tspaceRatio: 1,\n\t}\n}\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 1;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.02;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `\n\t\t\t\t\n\t\t\t\t`\n\t\t});\n\t\tthis.hideTip();\n\n\t\tthis.title = this.container.querySelector('.title');\n\t\tthis.dataPointList = this.container.querySelector('.data-point-list');\n\n\t\tthis.parent.addEventListener('mouseleave', () => {\n\t\t\tthis.hideTip();\n\t\t});\n\t}\n\n\tfill() {\n\t\tlet title;\n\t\tif(this.index) {\n\t\t\tthis.container.setAttribute('data-point-index', this.index);\n\t\t}\n\t\tif(this.titleValueFirst) {\n\t\t\ttitle = `${this.titleValue}${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}${this.titleValue}`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `${ value === 0 || value ? value : '' }\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\nexport function toTitleCase(str) {\n return str.replace(/\\w*/g, function(txt){return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();});\n}\n","import { fillArray } from './helpers';\n\nexport function getBarHeightAndYAttr(yTop, zeroLine) {\n\tlet height, y;\n\tif (yTop <= zeroLine) {\n\t\theight = zeroLine - yTop;\n\t\ty = yTop;\n\t} else {\n\t\theight = yTop - zeroLine;\n\t\ty = zeroLine;\n\t}\n\n\treturn [height, y];\n}\n\nexport function equilizeNoOfElements(array1, array2,\n\textraCount = array2.length - array1.length) {\n\n\t// Doesn't work if either has zero elements.\n\tif(extraCount > 0) {\n\t\tarray1 = fillArray(array1, extraCount);\n\t} else {\n\t\tarray2 = fillArray(array2, extraCount);\n\t}\n\treturn [array1, array2];\n}\n","const PRESET_COLOR_MAP = {\n\t'light-blue': '#7cd6fd',\n\t'blue': '#5e64ff',\n\t'violet': '#743ee2',\n\t'red': '#ff5858',\n\t'orange': '#ffa00a',\n\t'yellow': '#feef72',\n\t'green': '#28a745',\n\t'light-green': '#98d85b',\n\t'purple': '#b554ff',\n\t'magenta': '#ffa3ef',\n\t'black': '#36114C',\n\t'grey': '#bdd3e6',\n\t'light-grey': '#f0f4f7',\n\t'dark-grey': '#b8c2cc'\n};\n\nfunction limitColor(r){\n\tif (r > 255) return 255;\n\telse if (r < 0) return 0;\n\treturn r;\n}\n\nexport function lightenDarkenColor(color, amt) {\n\tlet col = getColor(color);\n\tlet usePound = false;\n\tif (col[0] == \"#\") {\n\t\tcol = col.slice(1);\n\t\tusePound = true;\n\t}\n\tlet num = parseInt(col,16);\n\tlet r = limitColor((num >> 16) + amt);\n\tlet b = limitColor(((num >> 8) & 0x00FF) + amt);\n\tlet g = limitColor((num & 0x0000FF) + amt);\n\treturn (usePound?\"#\":\"\") + (g | (b << 8) | (r << 16)).toString(16);\n}\n\nexport function isValidColor(string) {\n\t// https://stackoverflow.com/a/8027444/6495043\n\treturn /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(string);\n}\n\nexport const getColor = (color) => {\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\nimport { getStringWidth } from './helpers';\nimport { DOT_OVERLAY_SIZE_INCR, PERCENTAGE_BAR_DEFAULT_DEPTH } from './constants';\nimport { lightenDarkenColor } from './colors';\n\nexport const AXIS_TICK_LENGTH = 6;\nconst LABEL_MARGIN = 4;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none') {\n\treturn createSVG('path', {\n\t\tclassName: className,\n\t\td: pathStr,\n\t\tstyles: {\n\t\t\tstroke: stroke,\n\t\t\tfill: fill\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 0 ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeGradient(svgDefElem, color, lighter = false) {\n\tlet gradientId ='path-fill-gradient' + '-' + color + '-' +(lighter ? 'lighter' : 'default');\n\tlet gradientDef = renderVerticalGradient(svgDefElem, gradientId);\n\tlet opacities = [1, 0.6, 0.2];\n\tif(lighter) {\n\t\topacities = [0.4, 0.2, 0];\n\t}\n\n\tsetGradientStop(gradientDef, \"0%\", color, opacities[0]);\n\tsetGradientStop(gradientDef, \"50%\", color, opacities[1]);\n\tsetGradientStop(gradientDef, \"100%\", color, opacities[2]);\n\n\treturn gradientId;\n}\n\nexport function percentageBar(x, y, width, height,\n\tdepth=PERCENTAGE_BAR_DEFAULT_DEPTH, fill='none') {\n\n\tlet args = {\n\t\tclassName: 'percentage-bar',\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height,\n\t\tfill: fill,\n\t\tstyles: {\n\t\t\t'stroke': lightenDarkenColor(fill, -25),\n\t\t\t// Diabolically good: https://stackoverflow.com/a/9000859\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/stroke-dasharray\n\t\t\t'stroke-dasharray': `0, ${height + width}, ${width}, ${height}`,\n\t\t\t'stroke-width': depth\n\t\t},\n\t};\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function heatSquare(className, x, y, size, fill='none', data={}) {\n\tlet args = {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: size,\n\t\theight: size,\n\t\tfill: fill\n\t};\n\n\tObject.keys(data).map(key => {\n\t\targs[key] = data[key];\n\t});\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function legendBar(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-bar',\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: size,\n\t\theight: '2px',\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE * 2) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"rect\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function legendDot(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-dot',\n\t\tcx: 0,\n\t\tcy: 0,\n\t\tr: size,\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdx: (FONT_SIZE) + 'px',\n\t\tdy: (FONT_SIZE/3) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"circle\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function makeText(className, x, y, content, options = {}) {\n\tlet fontSize = options.fontSize || FONT_SIZE;\n\tlet dy = options.dy !== undefined ? options.dy : (fontSize / 2);\n\tlet fill = options.fill || FONT_FILL;\n\tlet textAnchor = options.textAnchor || 'start';\n\treturn createSVG('text', {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\tdy: dy + 'px',\n\t\t'font-size': fontSize + 'px',\n\t\tfill: fill,\n\t\t'text-anchor': textAnchor,\n\t\tinnerHTML: content\n\t});\n}\n\nfunction makeVertLine(x, label, y1, y2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tlet l = createSVG('line', {\n\t\tclassName: 'line-vertical ' + options.className,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: y1,\n\t\ty2: y2,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: 0,\n\t\ty: y1 > y2 ? y1 + LABEL_MARGIN : y1 - LABEL_MARGIN - FONT_SIZE,\n\t\tdy: FONT_SIZE + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'middle',\n\t\tinnerHTML: label + \"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(${ x }, 0)`\n\t});\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nfunction makeHoriLine(y, label, x1, x2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.lineType) options.lineType = '';\n\tlet className = 'line-horizontal ' + options.className +\n\t\t(options.lineType === \"dashed\" ? \"dashed\": \"\");\n\n\tlet l = createSVG('line', {\n\t\tclassName: className,\n\t\tx1: x1,\n\t\tx2: x2,\n\t\ty1: 0,\n\t\ty2: 0,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: x1 < x2 ? x1 - LABEL_MARGIN : x1 + LABEL_MARGIN,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / 2 - 2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': x1 < x2 ? 'end' : 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(0, ${y})`,\n\t\t'stroke-opacity': 1\n\t});\n\n\tif(text === 0 || text === '0') {\n\t\tline.style.stroke = \"rgba(27, 31, 35, 0.6)\";\n\t}\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nexport function yLine(y, label, width, options={}) {\n\tif(!options.pos) options.pos = 'left';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\tlet x1 = -1 * AXIS_TICK_LENGTH;\n\tlet x2 = options.mode === 'span' ? width + AXIS_TICK_LENGTH : 0;\n\n\tif(options.mode === 'tick' && options.pos === 'right') {\n\t\tx1 = width + AXIS_TICK_LENGTH;\n\t\tx2 = width;\n\t}\n\n\t// let offset = options.pos === 'left' ? -1 * options.offset : options.offset;\n\n\tx1 += options.offset;\n\tx2 += options.offset;\n\n\treturn makeHoriLine(y, label, x1, x2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.areaFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\n\nexport const UNIT_ANIM_DUR = 350;\nexport const PATH_ANIM_DUR = 350;\nexport const MARKER_LINE_ANIM_DUR = UNIT_ANIM_DUR;\nexport const REPLACE_ALL_NEW_DUR = 250;\n\nexport const STD_EASING = 'easein';\n\nexport function translate(unit, oldCoord, newCoord, duration) {\n\tlet old = typeof oldCoord === 'string' ? oldCoord : oldCoord.join(', ');\n\treturn [\n\t\tunit,\n\t\t{transform: newCoord.join(', ')},\n\t\tduration,\n\t\tSTD_EASING,\n\t\t\"translate\",\n\t\t{transform: old}\n\t];\n}\n\nexport function translateVertLine(xLine, newX, oldX) {\n\treturn translate(xLine, [oldX, 0], [newX, 0], MARKER_LINE_ANIM_DUR);\n}\n\nexport function translateHoriLine(yLine, newY, oldY) {\n\treturn translate(yLine, [0, oldY], [0, newY], MARKER_LINE_ANIM_DUR);\n}\n\nexport function animateRegion(rectGroup, newY1, newY2, oldY2) {\n\tlet newHeight = newY1 - newY2;\n\tlet rect = rectGroup.childNodes[0];\n\tlet width = rect.getAttribute(\"width\");\n\tlet rectAnim = [\n\t\trect,\n\t\t{ height: newHeight, 'stroke-dasharray': `${width}, ${newHeight}` },\n\t\tMARKER_LINE_ANIM_DUR,\n\t\tSTD_EASING\n\t];\n\n\tlet groupAnim = translate(rectGroup, [0, oldY2], [0, newY2], MARKER_LINE_ANIM_DUR);\n\treturn [rectAnim, groupAnim];\n}\n\nexport function animateBar(bar, x, yTop, width, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\tif(bar.nodeName !== 'rect') {\n\t\tlet rect = bar.childNodes[0];\n\t\tlet rectAnim = [\n\t\t\trect,\n\t\t\t{width: width, height: height},\n\t\t\tUNIT_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\n\t\tlet oldCoordStr = bar.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(bar, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [rectAnim, groupAnim];\n\t} else {\n\t\treturn [[bar, {width: width, height: height, x: x, y: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// bar.animate({height: args.newHeight, y: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animateDot(dot, x, y) {\n\tif(dot.nodeName !== 'circle') {\n\t\tlet oldCoordStr = dot.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(dot, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [groupAnim];\n\t} else {\n\t\treturn [[dot, {cx: x, cy: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// dot.animate({cy: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animatePath(paths, newXList, newYList, zeroLine) {\n\tlet pathComponents = [];\n\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y));\n\tlet pathStr = pointsStr.join(\"L\");\n\n\tconst animPath = [paths.path, {d:\"M\"+pathStr}, PATH_ANIM_DUR, STD_EASING];\n\tpathComponents.push(animPath);\n\n\tif(paths.region) {\n\t\tlet regStartPt = `${newXList[0]},${zeroLine}L`;\n\t\tlet regEndPt = `L${newXList.slice(-1)[0]}, ${zeroLine}`;\n\n\t\tconst animRegion = [\n\t\t\tpaths.region,\n\t\t\t{d:\"M\" + regStartPt + pathStr + regEndPt},\n\t\t\tPATH_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\t\tpathComponents.push(animRegion);\n\t}\n\n\treturn pathComponents;\n}\n\nexport function animatePathStr(oldPath, pathStr) {\n\treturn [oldPath, {d: pathStr}, UNIT_ANIM_DUR, STD_EASING];\n}\n","// Leveraging SMIL Animations\n\nimport { REPLACE_ALL_NEW_DUR } from './animate';\n\nconst EASING = {\n\tease: \"0.25 0.1 0.25 1\",\n\tlinear: \"0 0 1 1\",\n\t// easein: \"0.42 0 1 1\",\n\teasein: \"0.1 0.8 0.2 1\",\n\teaseout: \"0 0 0.58 1\",\n\teaseinout: \"0.42 0 0.58 1\"\n};\n\nfunction animateSVGElement(element, props, dur, easingType=\"linear\", type=undefined, oldValues={}) {\n\n\tlet animElement = element.cloneNode(true);\n\tlet newElement = element.cloneNode(true);\n\n\tfor(var attributeName in props) {\n\t\tlet animateElement;\n\t\tif(attributeName === 'transform') {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animateTransform\");\n\t\t} else {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animate\");\n\t\t}\n\t\tlet currentValue = oldValues[attributeName] || element.getAttribute(attributeName);\n\t\tlet value = props[attributeName];\n\n\t\tlet animAttr = {\n\t\t\tattributeName: attributeName,\n\t\t\tfrom: currentValue,\n\t\t\tto: value,\n\t\t\tbegin: \"0s\",\n\t\t\tdur: dur/1000 + \"s\",\n\t\t\tvalues: currentValue + \";\" + value,\n\t\t\tkeySplines: EASING[easingType],\n\t\t\tkeyTimes: \"0;1\",\n\t\t\tcalcMode: \"spline\",\n\t\t\tfill: 'freeze'\n\t\t};\n\n\t\tif(type) {\n\t\t\tanimAttr[\"type\"] = type;\n\t\t}\n\n\t\tfor (var i in animAttr) {\n\t\t\tanimateElement.setAttribute(i, animAttr[i]);\n\t\t}\n\n\t\tanimElement.appendChild(animateElement);\n\n\t\tif(type) {\n\t\t\tnewElement.setAttribute(attributeName, `translate(${value})`);\n\t\t} else {\n\t\t\tnewElement.setAttribute(attributeName, value);\n\t\t}\n\t}\n\n\treturn [animElement, newElement];\n}\n\nexport function transform(element, style) { // eslint-disable-line no-unused-vars\n\telement.style.transform = style;\n\telement.style.webkitTransform = style;\n\telement.style.msTransform = style;\n\telement.style.mozTransform = style;\n\telement.style.oTransform = style;\n}\n\nfunction animateSVG(svgContainer, elements) {\n\tlet newElements = [];\n\tlet animElements = [];\n\n\telements.map(element => {\n\t\tlet unit = element[0];\n\t\tlet parent = unit.parentNode;\n\n\t\tlet animElement, newElement;\n\n\t\telement[0] = unit;\n\t\t[animElement, newElement] = animateSVGElement(...element);\n\n\t\tnewElements.push(newElement);\n\t\tanimElements.push([animElement, parent]);\n\n\t\tparent.replaceChild(animElement, unit);\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\telements[i][0] = newElements[i];\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\n\nlet BOUND_DRAW_FN;\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || 'line';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tBOUND_DRAW_FN = this.boundDrawFn.bind(this);\n\t\twindow.addEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents() {\n\t\twindow.removeEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t\tthis.parent.style.overflow = 'auto';\n\t\t}\n\n\t\tthis.container = $.create('div', args);\n\t}\n\n\tmakeTooltip() {\n\t\tthis.tip = new SvgTip({\n\t\t\tparent: this.container,\n\t\t\tcolors: this.colors\n\t\t});\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {}\n\n\tdraw(onlyWidthChange=false, init=false) {\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { legendDot } from '../utils/draw';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.maxSlices = args.maxSlices || 20;\n\t\tthis.config.maxLegendPoints = args.maxLegendPoints || 20;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\t\tlet maxSlices = this.config.maxSlices;\n\t\ts.sliceTotals = [];\n\n\t\tlet allTotals = this.data.labels.map((label, i) => {\n\t\t\tlet total = 0;\n\t\t\tthis.data.datasets.map(e => {\n\t\t\t\ttotal += e.values[i];\n\t\t\t});\n\t\t\treturn [total, label];\n\t\t}).filter(d => { return d[0] >= 0; }); // keep only positive results\n\n\t\tlet totals = allTotals;\n\t\tif(allTotals.length > maxSlices) {\n\t\t\t// Prune and keep a grey area for rest as per maxSlices\n\t\t\tallTotals.sort((a, b) => { return b[0] - a[0]; });\n\n\t\t\ttotals = allTotals.slice(0, maxSlices-1);\n\t\t\tlet remaining = allTotals.slice(maxSlices-1);\n\n\t\t\tlet sumOfRemaining = 0;\n\t\t\tremaining.map(d => {sumOfRemaining += d[0];});\n\t\t\ttotals.push([sumOfRemaining, 'Rest']);\n\t\t\tthis.colors[maxSlices-1] = 'grey';\n\t\t}\n\n\t\ts.labels = [];\n\t\ttotals.map(d => {\n\t\t\ts.sliceTotals.push(d[0]);\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${s.labels[i]}: ${d}`\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport { makeText, makePath, xLine, yLine, yMarker, yRegion, datasetBar, datasetDot, percentageBar, getPaths, heatSquare } from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport { translateHoriLine, translateVertLine, animateRegion, animateBar,\n\tanimateDot, animatePath, animatePathStr } from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n\tconstructor({\n\t\tlayerClass = '',\n\t\tlayerTransform = '',\n\t\tconstants,\n\n\t\tgetData,\n\t\tmakeElements,\n\t\tanimateElements\n\t}) {\n\t\tthis.layerTransform = layerTransform;\n\t\tthis.constants = constants;\n\n\t\tthis.makeElements = makeElements;\n\t\tthis.getData = getData;\n\n\t\tthis.animateElements = animateElements;\n\n\t\tthis.store = [];\n\t\tthis.labels = [];\n\n\t\tthis.layerClass = layerClass;\n\t\tthis.layerClass = typeof(this.layerClass) === 'function'\n\t\t\t? this.layerClass() : this.layerClass;\n\n\t\tthis.refresh();\n\t}\n\n\trefresh(data) {\n\t\tthis.data = data || this.getData();\n\t}\n\n\tsetup(parent) {\n\t\tthis.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n\t}\n\n\tmake() {\n\t\tthis.render(this.data);\n\t\tthis.oldData = this.data;\n\t}\n\n\trender(data) {\n\t\tthis.store = this.makeElements(data);\n\n\t\tthis.layer.textContent = '';\n\t\tthis.store.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t\tthis.labels.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t}\n\n\tupdate(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tpieSlices: {\n\t\tlayerClass: 'pie-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) =>{\n\t\t\t\tlet slice = makePath(s, 'pie-path', 'none', data.colors[i]);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) =>\n\t\t\t\tanimatePathStr(slice, newData.sliceStrings[i])\n\t\t\t);\n\t\t}\n\t},\n\tpercentageBars: {\n\t\tlayerClass: 'percentage-bars',\n\t\tmakeElements(data) {\n\t\t\treturn data.xPositions.map((x, i) =>{\n\t\t\t\tlet y = 0;\n\t\t\t\tlet bar = percentageBar(x, y, data.widths[i],\n\t\t\t\t\tthis.constants.barHeight, this.constants.barDepth, data.colors[i]);\n\t\t\t\treturn bar;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\tyAxis: {\n\t\tlayerClass: 'y axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\tyLine(position, data.labels[i], this.constants.width,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.labels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tlabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(m =>\n\t\t\t\tyMarker(m.position, m.label, this.constants.width,\n\t\t\t\t\t{labelPos: m.options.labelPos, mode: 'span', lineType: 'dashed'})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, day.fill, data);\n\t\t\t\t\t\tthis.serializedSubDomains.push(square);\n\t\t\t\t\t}\n\t\t\t\t\ty += rowHeight;\n\t\t\t\t});\n\t\t\t\ty = 0;\n\t\t\t\tx += colWidth;\n\t\t\t});\n\n\t\t\treturn this.serializedSubDomains;\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\n\tbarGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-bars dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'bar';\n\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\treturn datasetBar(\n\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\ty,\n\t\t\t\t\tdata.barWidth,\n\t\t\t\t\tc.color,\n\t\t\t\t\tdata.labels[j],\n\t\t\t\t\tj,\n\t\t\t\t\tdata.offsets[j],\n\t\t\t\t\t{\n\t\t\t\t\t\tzeroLine: data.zeroLine,\n\t\t\t\t\t\tbarsWidth: data.barsWidth,\n\t\t\t\t\t\tminHeight: c.minHeight\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t});\n\t\t\treturn this.units;\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newOffsets = newData.offsets;\n\t\t\tlet newLabels = newData.labels;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldOffsets = this.oldData.offsets;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldOffsets, newOffsets] = equilizeNoOfElements(oldOffsets, newOffsets);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\toffsets: oldOffsets,\n\t\t\t\tlabels: newLabels,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tbarsWidth: this.oldData.barsWidth,\n\t\t\t\tbarWidth: this.oldData.barWidth,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((bar, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateBar(\n\t\t\t\t\tbar, newXPos[i], newYPos[i], newData.barWidth, newOffsets[i],\n\t\t\t\t\t{zeroLine: newData.zeroLine}\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\tlineGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-line dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'dot';\n\t\t\tthis.paths = {};\n\t\t\tif(!c.hideLine) {\n\t\t\t\tthis.paths = getPaths(\n\t\t\t\t\tdata.xPositions,\n\t\t\t\t\tdata.yPositions,\n\t\t\t\t\tc.color,\n\t\t\t\t\t{\n\t\t\t\t\t\theatline: c.heatline,\n\t\t\t\t\t\tareaFill: c.areaFill\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tsvgDefs: c.svgDefs,\n\t\t\t\t\t\tzeroLine: data.zeroLine\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.units = [];\n\t\t\tif(!c.hideDots) {\n\t\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\t\treturn datasetDot(\n\t\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\t\ty,\n\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\tc.color,\n\t\t\t\t\t\t(c.valuesOverPoints ? data.values[j] : ''),\n\t\t\t\t\t\tj\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn Object.values(this.paths).concat(this.units);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newValues = newData.values;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldValues = this.oldData.values;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldValues, newValues] = equilizeNoOfElements(oldValues, newValues);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\tvalues: newValues,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tradius: this.oldData.radius,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tif(Object.keys(this.paths).length) {\n\t\t\t\tanimateElements = animateElements.concat(animatePath(\n\t\t\t\t\tthis.paths, newXPos, newYPos, newData.zeroLine));\n\t\t\t}\n\n\t\t\tif(this.units.length) {\n\t\t\t\tthis.units.map((dot, i) => {\n\t\t\t\t\tanimateElements = animateElements.concat(animateDot(\n\t\t\t\t\t\tdot, newXPos[i], newYPos[i]));\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn animateElements;\n\t\t}\n\t}\n};\n\nexport function getComponent(name, constants, getData) {\n\tlet keys = Object.keys(componentConfigs).filter(k => name.includes(k));\n\tlet config = componentConfigs[keys[0]];\n\tObject.assign(config, {\n\t\tconstants: constants,\n\t\tgetData: getData\n\t});\n\treturn new ChartComponent(config);\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 80;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class PieChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'pie';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius = (this.height > this.width ? this.center.x : this.center.y);\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath = makeArcPathStr(curStart, curEnd, this.center, this.radius, this.clockWise);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import { floatTwo } from './helpers';\n\nfunction normalize(x) {\n\t// Calculates mantissa and exponent of a number\n\t// Returns normalized number and exponent\n\t// https://stackoverflow.com/q/9383593/6495043\n\n\tif(x===0) {\n\t\treturn [0, 0];\n\t}\n\tif(isNaN(x)) {\n\t\treturn {mantissa: -6755399441055744, exponent: 972};\n\t}\n\tvar sig = x > 0 ? 1 : -1;\n\tif(!isFinite(x)) {\n\t\treturn {mantissa: sig * 4503599627370496, exponent: 972};\n\t}\n\n\tx = Math.abs(x);\n\tvar exp = Math.floor(Math.log10(x));\n\tvar man = x/Math.pow(10, exp);\n\n\treturn [sig * man, exp];\n}\n\nfunction getChartRangeIntervals(max, min=0) {\n\tlet upperBound = Math.ceil(max);\n\tlet lowerBound = Math.floor(min);\n\tlet range = upperBound - lowerBound;\n\n\tlet noOfParts = range;\n\tlet partSize = 1;\n\n\t// To avoid too many partitions\n\tif(range > 5) {\n\t\tif(range % 2 !== 0) {\n\t\t\tupperBound++;\n\t\t\t// Recalc range\n\t\t\trange = upperBound - lowerBound;\n\t\t}\n\t\tnoOfParts = range/2;\n\t\tpartSize = 2;\n\t}\n\n\t// Special case: 1 and 2\n\tif(range <= 2) {\n\t\tnoOfParts = 4;\n\t\tpartSize = range/noOfParts;\n\t}\n\n\t// Special case: 0\n\tif(range === 0) {\n\t\tnoOfParts = 5;\n\t\tpartSize = 1;\n\t}\n\n\tlet intervals = [];\n\tfor(var i = 0; i <= noOfParts; i++){\n\t\tintervals.push(lowerBound + partSize * i);\n\t}\n\treturn intervals;\n}\n\nfunction getChartIntervals(maxValue, minValue=0) {\n\tlet [normalMaxValue, exponent] = normalize(maxValue);\n\tlet normalMinValue = minValue ? minValue/Math.pow(10, exponent): 0;\n\n\t// Allow only 7 significant digits\n\tnormalMaxValue = normalMaxValue.toFixed(6);\n\n\tlet intervals = getChartRangeIntervals(normalMaxValue, normalMinValue);\n\tintervals = intervals.map(value => value * Math.pow(10, exponent));\n\treturn intervals;\n}\n\nexport function calcChartIntervals(values, withMinimum=false) {\n\t//*** Where the magic happens ***\n\n\t// Calculates best-fit y intervals from given values\n\t// and returns the interval array\n\n\tlet maxValue = Math.max(...values);\n\tlet minValue = Math.min(...values);\n\n\t// Exponent to be used for pretty print\n\tlet exponent = 0, intervals = []; // eslint-disable-line no-unused-vars\n\n\tfunction getPositiveFirstIntervals(maxValue, absMinValue) {\n\t\tlet intervals = getChartIntervals(maxValue);\n\n\t\tlet intervalSize = intervals[1] - intervals[0];\n\n\t\t// Then unshift the negative values\n\t\tlet value = 0;\n\t\tfor(var i = 1; value < absMinValue; i++) {\n\t\t\tvalue += intervalSize;\n\t\t\tintervals.unshift((-1) * value);\n\t\t}\n\t\treturn intervals;\n\t}\n\n\t// CASE I: Both non-negative\n\n\tif(maxValue >= 0 && minValue >= 0) {\n\t\texponent = normalize(maxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(maxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(maxValue, minValue);\n\t\t}\n\t}\n\n\t// CASE II: Only minValue negative\n\n\telse if(maxValue > 0 && minValue < 0) {\n\t\t// `withMinimum` irrelevant in this case,\n\t\t// We'll be handling both sides of zero separately\n\t\t// (both starting from zero)\n\t\t// Because ceil() and floor() behave differently\n\t\t// in those two regions\n\n\t\tlet absMinValue = Math.abs(minValue);\n\n\t\tif(maxValue >= absMinValue) {\n\t\t\texponent = normalize(maxValue)[1];\n\t\t\tintervals = getPositiveFirstIntervals(maxValue, absMinValue);\n\t\t} else {\n\t\t\t// Mirror: maxValue => absMinValue, then change sign\n\t\t\texponent = normalize(absMinValue)[1];\n\t\t\tlet posIntervals = getPositiveFirstIntervals(absMinValue, maxValue);\n\t\t\tintervals = posIntervals.map(d => d * (-1));\n\t\t}\n\n\t}\n\n\t// CASE III: Both non-positive\n\n\telse if(maxValue <= 0 && minValue <= 0) {\n\t\t// Mirrored Case I:\n\t\t// Work with positives, then reverse the sign and array\n\n\t\tlet pseudoMaxValue = Math.abs(minValue);\n\t\tlet pseudoMinValue = Math.abs(maxValue);\n\n\t\texponent = normalize(pseudoMaxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue, pseudoMinValue);\n\t\t}\n\n\t\tintervals = intervals.reverse().map(d => d * (-1));\n\t}\n\n\treturn intervals;\n}\n\nexport function getZeroIndex(yPts) {\n\tlet zeroIndex;\n\tlet interval = getIntervalSize(yPts);\n\tif(yPts.indexOf(0) >= 0) {\n\t\t// the range has a given zero\n\t\t// zero-line on the chart\n\t\tzeroIndex = yPts.indexOf(0);\n\t} else if(yPts[0] > 0) {\n\t\t// Minimum value is positive\n\t\t// zero-line is off the chart: below\n\t\tlet min = yPts[0];\n\t\tzeroIndex = (-1) * min / interval;\n\t} else {\n\t\t// Maximum value is negative\n\t\t// zero-line is off the chart: above\n\t\tlet max = yPts[yPts.length - 1];\n\t\tzeroIndex = (-1) * max / interval + (yPts.length - 1);\n\t}\n\treturn zeroIndex;\n}\n\nexport function getRealIntervals(max, noOfIntervals, min = 0, asc = 1) {\n\tlet range = max - min;\n\tlet part = range * 1.0 / noOfIntervals;\n\tlet intervals = [];\n\n\tfor(var i = 0; i <= noOfIntervals; i++) {\n\t\tintervals.push(min + part * i);\n\t}\n\n\treturn asc ? intervals : intervals.reverse();\n}\n\nexport function getIntervalSize(orderedArray) {\n\treturn orderedArray[1] - orderedArray[0];\n}\n\nexport function getValueRange(orderedArray) {\n\treturn orderedArray[orderedArray.length-1] - orderedArray[0];\n}\n\nexport function scale(val, yAxis) {\n\treturn floatTwo(yAxis.zeroLine - val * yAxis.scaleMultiplier);\n}\n\nexport function isInRange(val, min, max) {\n\treturn val > min && val < max;\n}\n\nexport function isInRange2D(coord, minCoord, maxCoord) {\n\treturn isInRange(coord[0], minCoord[0], maxCoord[0])\n\t\t&& isInRange(coord[1], minCoord[1], maxCoord[1]);\n}\n\nexport function getClosestInArray(goal, arr, index = false) {\n\tlet closest = arr.reduce(function(prev, curr) {\n\t\treturn (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);\n\t});\n\n\treturn index ? arr.indexOf(closest) : closest;\n}\n\nexport function calcDistribution(values, distributionSize) {\n\t// Assume non-negative values,\n\t// implying distribution minimum at zero\n\n\tlet dataMaxValue = Math.max(...values);\n\n\tlet distributionStep = 1 / (distributionSize - 1);\n\tlet distribution = [];\n\n\tfor(var i = 0; i < distributionSize; i++) {\n\t\tlet checkpoint = dataMaxValue * (distributionStep * i);\n\t\tdistribution.push(checkpoint);\n\t}\n\n\treturn distribution;\n}\n\nexport function getMaxCheckpoint(value, distribution) {\n\treturn distribution.filter(d => d < value).length;\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\txTranslate: s.domainConfigs\n\t\t\t\t\t.filter((config, j) => j < i)\n\t\t\t\t\t.map(config => config.cols.length - lessCol)\n\t\t\t\t\t.reduce((a, b) => a + b, 0)\n\t\t\t\t\t* COL_WIDTH\n\t\t\t},\n\t\t\tfunction() {\n\t\t\t\treturn s.domainConfigs[i];\n\t\t\t}.bind(this)\n\n\t\t]);\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map((args, i) => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0] + '-' + i, component];\n\t\t\t})\n\t\t);\n\n\t\tlet y = 0;\n\t\tDAY_NAMES_SHORT.forEach((dayName, i) => {\n\t\t\tif([1, 3, 5].includes(i)) {\n\t\t\t\tlet dayText = makeText('subdomain-name', -COL_WIDTH/2, y, dayName,\n\t\t\t\t\t{\n\t\t\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\t\t\tdy: 8,\n\t\t\t\t\t\ttextAnchor: 'end'\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tthis.drawArea.appendChild(dayText);\n\t\t\t}\n\t\t\ty += ROW_HEIGHT;\n\t\t});\n\t}\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\n\t\tthis.data = this.prepareData(data);\n\t\tthis.draw();\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tthis.components.forEach(comp => {\n\t\t\t\tlet daySquares = comp.store;\n\t\t\t\tlet daySquare = e.target;\n\t\t\t\tif(daySquares.includes(daySquare)) {\n\n\t\t\t\t\tlet count = daySquare.getAttribute('data-value');\n\t\t\t\t\tlet dateParts = daySquare.getAttribute('data-date').split('-');\n\n\t\t\t\t\tlet month = getMonthName(parseInt(dateParts[1])-1, true);\n\n\t\t\t\t\tlet gOff = this.container.getBoundingClientRect(), pOff = daySquare.getBoundingClientRect();\n\n\t\t\t\t\tlet width = parseInt(e.target.getAttribute('width'));\n\t\t\t\t\tlet x = pOff.left - gOff.left + width/2;\n\t\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\t\tlet value = count + ' ' + this.countLabel;\n\t\t\t\t\tlet name = ' on ' + month + ' ' + dateParts[0] + ', ' + dateParts[2];\n\n\t\t\t\t\tthis.tip.setValues(x, y, {name: name, value: value, valueFirst: 1}, []);\n\t\t\t\t\tthis.tip.showTip();\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\trenderLegend() {\n\t\tthis.legendArea.textContent = '';\n\t\tlet x = 0;\n\t\tlet y = ROW_HEIGHT;\n\n\t\tlet lessText = makeText('subdomain-name', x, y, 'Less',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tx = (COL_WIDTH * 2) + COL_WIDTH/2;\n\t\tthis.legendArea.appendChild(lessText);\n\n\t\tthis.colors.slice(0, HEATMAP_DISTRIBUTION_SIZE).map((color, i) => {\n\t\t\tconst square = heatSquare('heatmap-legend-unit', x + (COL_WIDTH + 3) * i,\n\t\t\t\ty, HEATMAP_SQUARE_SIZE, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import { fillArray } from '../utils/helpers';\nimport { AXIS_CHART_DEFAULT_TYPE, AXIS_CHART_MIXED_TYPE, AXIS_DATASET_CHART_TYPES, DEFAULT_CHAR_WIDTH } from '../utils/constants';\n\nexport function dataPrep(data, type) {\n\tdata.labels = data.labels || [];\n\n\tlet datasetLength = data.labels.length;\n\n\t// Datasets\n\tlet datasets = data.datasets;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\tif(!datasets) {\n\t\t// default\n\t\tdatasets = [{\n\t\t\tvalues: zeroArray\n\t\t}];\n\t}\n\n\tlet overridingType;\n\tif(AXIS_DATASET_CHART_TYPES.includes(type)) {\n\t\toverridingType = type;\n\t};\n\n\tdatasets.map(d=> {\n\t\t// Set values\n\t\tif(!d.values) {\n\t\t\td.values = zeroArray;\n\t\t} else {\n\t\t\t// Check for non values\n\t\t\tlet vals = d.values;\n\t\t\tvals = vals.map(val => (!isNaN(val) ? val : 0));\n\n\t\t\t// Trim or extend\n\t\t\tif(vals.length > datasetLength) {\n\t\t\t\tvals = vals.slice(0, datasetLength);\n\t\t\t} else {\n\t\t\t\tvals = fillArray(vals, datasetLength - vals.length, 0);\n\t\t\t}\n\t\t}\n\n\t\t// Set labels\n\n\t\t// Set type\n\t\tif(overridingType) {\n\t\t\td.chartType = overridingType;\n\t\t} else if(!d.chartType) {\n\t\t\td.chartType = AXIS_CHART_DEFAULT_TYPE;\n\t\t}\n\t});\n\n\t// Markers\n\n\t// Regions\n\t// data.yRegions = data.yRegions || [];\n\tif(data.yRegions) {\n\t\tdata.yRegions.map(d => {\n\t\t\tif(d.end < d.start) {\n\t\t\t\t[d.start, d.end] = [d.end, d.start];\n\t\t\t}\n\t\t});\n\t}\n\n\treturn data;\n}\n\nexport function zeroDataPrep(realData) {\n\tlet datasetLength = realData.labels.length;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\n\tlet zeroData = {\n\t\tlabels: realData.labels.slice(0, -1),\n\t\tdatasets: realData.datasets.map(d => {\n\t\t\treturn {\n\t\t\t\tname: '',\n\t\t\t\tvalues: zeroArray.slice(0, -1),\n\t\t\t\tchartType: d.chartType\n\t\t\t};\n\t\t}),\n\t};\n\n\tif(realData.yMarkers) {\n\t\tzeroData.yMarkers = [\n\t\t\t{\n\t\t\t\tvalue: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\tif(realData.yRegions) {\n\t\tzeroData.yRegions = [\n\t\t\t{\n\t\t\t\tstart: 0,\n\t\t\t\tend: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\treturn zeroData;\n}\n\nexport function getShortenedLabels(chartWidth, labels=[], isSeries=true) {\n\tlet allowedSpace = chartWidth / labels.length;\n\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet calcLabels = labels.map((label, i) => {\n\t\tlabel += \"\";\n\t\tif(label.length > allowedLetters) {\n\n\t\t\tif(!isSeries) {\n\t\t\t\tif(allowedLetters-3 > 0) {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters-3) + \" ...\";\n\t\t\t\t} else {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters) + '..';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlet multiple = Math.ceil(label.length/allowedLetters);\n\t\t\t\tif(i % multiple !== 0) {\n\t\t\t\t\tlabel = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn label;\n\t});\n\n\treturn calcLabels;\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n\t\tsuper.configure(options);\n\n\t\toptions.axisOptions = options.axisOptions || {};\n\t\toptions.tooltipOptions = options.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = options.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = options.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = options.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\tcalcYAxisParameters(dataValues, withMinimum = 'false') {\n\t\tconst yPts = calcChartIntervals(dataValues, withMinimum);\n\t\tconst scaleMultiplier = this.height / getValueRange(yPts);\n\t\tconst intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n\t\tconst zeroLine = this.height - (getZeroIndex(yPts) * intervalHeight);\n\n\t\tthis.state.yAxis = {\n\t\t\tlabels: yPts,\n\t\t\tpositions: yPts.map(d => zeroLine - d * scaleMultiplier),\n\t\t\tscaleMultiplier: scaleMultiplier,\n\t\t\tzeroLine: zeroLine,\n\t\t};\n\n\t\t// Dependent if above changes\n\t\tthis.calcDatasetPoints();\n\t\tthis.calcYExtremes();\n\t\tthis.calcYRegions();\n\t}\n\n\tcalcDatasetPoints() {\n\t\tlet s = this.state;\n\t\tlet scaleAll = values => values.map(val => scale(val, s.yAxis));\n\n\t\ts.datasets = this.data.datasets.map((d, i) => {\n\t\t\tlet values = d.values;\n\t\t\tlet cumulativeYs = d.cumulativeYs || [];\n\t\t\treturn {\n\t\t\t\tname: d.name,\n\t\t\t\tindex: i,\n\t\t\t\tchartType: d.chartType,\n\n\t\t\t\tvalues: values,\n\t\t\t\tyPositions: scaleAll(values),\n\n\t\t\t\tcumulativeYs: cumulativeYs,\n\t\t\t\tcumulativeYPos: scaleAll(cumulativeYs),\n\t\t\t};\n\t\t});\n\t}\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n\tgetAllYValues() {\n\t\tlet key = 'values';\n\n\t\tif(this.barOptions.stacked) {\n\t\t\tkey = 'cumulativeYs';\n\t\t\tlet cumulative = new Array(this.state.datasetLength).fill(0);\n\t\t\tthis.data.datasets.map((d, i) => {\n\t\t\t\tlet values = this.data.datasets[i].values;\n\t\t\t\td[key] = cumulative = cumulative.map((c, i) => c + values[i]);\n\t\t\t});\n\t\t}\n\n\t\tlet allValueLists = this.data.datasets.map(d => d[key]);\n\t\tif(this.data.yMarkers) {\n\t\t\tallValueLists.push(this.data.yMarkers.map(d => d.value));\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.data.yRegions.map(d => {\n\t\t\t\tallValueLists.push([d.end, d.start]);\n\t\t\t});\n\t\t}\n\n\t\treturn [].concat(...allValueLists);\n\t}\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'yAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.yAxisMode,\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'xAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.xAxisMode,\n\t\t\t\t\theight: this.height,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\ts.xAxis.calcLabels = getShortenedLabels(this.width,\n\t\t\t\t\t\ts.xAxis.labels, this.config.xIsSeries);\n\n\t\t\t\t\treturn s.xAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'yRegions',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yRegions;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\t\t];\n\n\t\tlet barDatasets = this.state.datasets.filter(d => d.chartType === 'bar');\n\t\tlet lineDatasets = this.state.datasets.filter(d => d.chartType === 'line');\n\n\t\tlet barsConfigs = barDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'barGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tstacked: this.barOptions.stacked,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t\tminHeight: this.height * MIN_BAR_PERCENT_HEIGHT,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet stacked = this.barOptions.stacked;\n\n\t\t\t\t\tlet spaceRatio = this.barOptions.spaceRatio || BAR_CHART_SPACE_RATIO;\n\t\t\t\t\tlet barsWidth = s.unitWidth/2 * (2 - spaceRatio);\n\t\t\t\t\tlet barWidth = barsWidth/(stacked ? 1 : barDatasets.length);\n\n\t\t\t\t\tlet xPositions = s.xAxis.positions.map(x => x - barsWidth/2);\n\t\t\t\t\tif(!stacked) {\n\t\t\t\t\t\txPositions = xPositions.map(p => p + barWidth * index);\n\t\t\t\t\t}\n\n\t\t\t\t\tlet labels = new Array(s.datasetLength).fill('');\n\t\t\t\t\tif(this.config.valuesOverPoints) {\n\t\t\t\t\t\tif(stacked && d.index === s.datasets.length - 1) {\n\t\t\t\t\t\t\tlabels = d.cumulativeYs;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tlabels = d.values;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet offsets = new Array(s.datasetLength).fill(0);\n\t\t\t\t\tif(stacked) {\n\t\t\t\t\t\toffsets = d.yPositions.map((y, j) => y - d.cumulativeYPos[j]);\n\t\t\t\t\t}\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: xPositions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\t\t\t\t\t\toffsets: offsets,\n\t\t\t\t\t\t// values: d.values,\n\t\t\t\t\t\tlabels: labels,\n\n\t\t\t\t\t\tzeroLine: s.yAxis.zeroLine,\n\t\t\t\t\t\tbarsWidth: barsWidth,\n\t\t\t\t\t\tbarWidth: barWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet lineConfigs = lineDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'lineGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tsvgDefs: this.svgDefs,\n\t\t\t\t\theatline: this.lineOptions.heatline,\n\t\t\t\t\tareaFill: this.lineOptions.areaFill,\n\t\t\t\t\thideDots: this.lineOptions.hideDots,\n\t\t\t\t\thideLine: this.lineOptions.hideLine,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet minLine = s.yAxis.positions[0] < s.yAxis.zeroLine\n\t\t\t\t\t\t? s.yAxis.positions[0] : s.yAxis.zeroLine;\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xAxis.positions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\n\t\t\t\t\t\tvalues: d.values,\n\n\t\t\t\t\t\tzeroLine: minLine,\n\t\t\t\t\t\tradius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tlet dbi = this.dataByIndex[index];\n\n\t\tthis.tip.setValues(\n\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\tdbi.values,\n\t\t\tindex\n\t\t);\n\n\t\tthis.tip.showTip();\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name);\n\t\t\t\tthis.legendArea.appendChild(rect);\n\t\t\t});\n\t\t}\n\t}\n\n\n\n\t// Overlay\n\tmakeOverlay() {\n\t\tif(this.init) {\n\t\t\tthis.init = 0;\n\t\t\treturn;\n\t\t}\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\n\t\tthis.overlayGuides = this.dataUnitComponents.map(c => {\n\t\t\treturn {\n\t\t\t\ttype: c.unitType,\n\t\t\t\toverlay: undefined,\n\t\t\t\tunits: c.units,\n\t\t\t};\n\t\t});\n\n\t\tif(this.state.currentIndex === undefined) {\n\t\t\tthis.state.currentIndex = this.state.datasetLength - 1;\n\t\t}\n\n\t\t// Render overlays\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\n\t\t\td.overlay = makeOverlay[d.type](currentUnit);\n\t\t\tthis.drawArea.appendChild(d.overlay);\n\t\t});\n\t}\n\n\tupdateOverlayGuides() {\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\t}\n\n\tbindOverlay() {\n\t\tthis.parent.addEventListener('data-select', () => {\n\t\t\tthis.updateOverlay();\n\t\t});\n\t}\n\n\tbindUnits() {\n\t\tthis.dataUnitComponents.map(c => {\n\t\t\tc.units.map(unit => {\n\t\t\t\tunit.addEventListener('click', () => {\n\t\t\t\t\tlet index = unit.getAttribute('data-point-index');\n\t\t\t\t\tthis.setCurrentDataPoint(index);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\t// Note: Doesn't work as tooltip is absolutely positioned\n\t\tthis.tip.container.addEventListener('click', () => {\n\t\t\tlet index = this.tip.container.getAttribute('data-point-index');\n\t\t\tthis.setCurrentDataPoint(index);\n\t\t});\n\t}\n\n\tupdateOverlay() {\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\t\t\tupdateOverlay[d.type](currentUnit, d.overlay);\n\t\t});\n\t}\n\n\tonLeftArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex - 1);\n\t}\n\n\tonRightArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex + 1);\n\t}\n\n\tgetDataPoint(index=this.state.currentIndex) {\n\t\tlet s = this.state;\n\t\tlet data_point = {\n\t\t\tindex: index,\n\t\t\tlabel: s.xAxis.labels[index],\n\t\t\tvalues: s.datasets.map(d => d.values[index])\n\t\t};\n\t\treturn data_point;\n\t}\n\n\tsetCurrentDataPoint(index) {\n\t\tlet s = this.state;\n\t\tindex = parseInt(index);\n\t\tif(index < 0) index = 0;\n\t\tif(index >= s.xAxis.labels.length) index = s.xAxis.labels.length - 1;\n\t\tif(index === s.currentIndex) return;\n\t\ts.currentIndex = index;\n\t\tfire(this.parent, \"data-select\", this.getDataPoint());\n\t}\n\n\n\n\t// API\n\taddDataPoint(label, datasetValues, index=this.state.datasetLength) {\n\t\tsuper.addDataPoint(label, datasetValues, index);\n\t\tthis.data.labels.splice(index, 0, label);\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\td.values.splice(index, 0, datasetValues[i]);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tremoveDataPoint(index = this.state.datasetLength-1) {\n\t\tif (this.data.labels.length <= 1) {\n\t\t\treturn;\n\t\t}\n\t\tsuper.removeDataPoint(index);\n\t\tthis.data.labels.splice(index, 1);\n\t\tthis.data.datasets.map(d => {\n\t\t\td.values.splice(index, 1);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tupdateDataset(datasetValues, index=0) {\n\t\tthis.data.datasets[index].values = datasetValues;\n\t\tthis.update(this.data);\n\t}\n\t// addDataset(dataset, index) {}\n\t// removeDataset(index = 0) {}\n\n\tupdateDatasets(datasets) {\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\tif(datasets[i]) {\n\t\t\t\td.values = datasets[i];\n\t\t\t}\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\t// updateDataPoint(dataPoint, index = 0) {}\n\t// addDataPoint(dataPoint, index = 0) {}\n\t// removeDataPoint(index = 0) {}\n}\n","import '../css/charts.scss';\n\n// import MultiAxisChart from './charts/MultiAxisChart';\nimport PercentageChart from './charts/PercentageChart';\nimport PieChart from './charts/PieChart';\nimport Heatmap from './charts/Heatmap';\nimport AxisChart from './charts/AxisChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };"],"names":["$","expr","con","document","querySelector","create","tag","o","element","createElement","i","val","appendChild","ref","parentNode","insertBefore","addEventListener","e","value","keys","map","style","prop","setAttribute","getOffset","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isElementInViewport","el","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","type","properties","evt","createEvent","initEvent","j","dispatchEvent","BASE_MEASURES","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","totalExtraHeight","legendHeight","getExtraWidth","totalExtraWidth","INIT_CHART_UPDATE_TIMEOUT","CHART_POST_ANIMATE_TIMEOUT","AXIS_CHART_DEFAULT_TYPE","AXIS_DATASET_CHART_TYPES","AXIS_LEGEND_BAR_SIZE","BAR_CHART_SPACE_RATIO","MIN_BAR_PERCENT_HEIGHT","LINE_CHART_DOT_SIZE","DOT_OVERLAY_SIZE_INCR","PERCENTAGE_BAR_DEFAULT_HEIGHT","PERCENTAGE_BAR_DEFAULT_DEPTH","HEATMAP_DISTRIBUTION_SIZE","HEATMAP_SQUARE_SIZE","HEATMAP_GUTTER_SIZE","DEFAULT_CHAR_WIDTH","TOOLTIP_POINTER_TRIANGLE_HEIGHT","DEFAULT_CHART_COLORS","HEATMAP_COLORS_GREEN","DEFAULT_COLORS","ANGLE_RATIO","Math","PI","FULL_ANGLE","SvgTip","parent","colors","titleName","titleValue","listValues","titleValueFirst","x","y","setup","makeTooltip","fill","calcPosition","container","hideTip","title","dataPointList","index","innerHTML","set","color","formatted","li","width","offsetWidth","offsetHeight","maxLeft","pointer","delta","pointerOffset","name","valueFirst","refresh","opacity","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","abs","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","cos","getBarHeightAndYAttr","yTop","zeroLine","height","equilizeNoOfElements","array1","array2","extraCount","PRESET_COLOR_MAP","limitColor","r","lightenDarkenColor","amt","col","getColor","usePound","slice","num","parseInt","b","g","toString","isValidColor","test","AXIS_TICK_LENGTH","LABEL_MARGIN","FONT_SIZE","BASE_LINE_COLOR","FONT_FILL","createSVG","createElementNS","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","makeSVGContainer","className","makeSVGDefs","svgContainer","makeSVGGroup","transform","undefined","args","inside","makePath","pathStr","stroke","makeArcPathStr","startPosition","endPosition","center","clockWise","arcStartX","arcStartY","arcEndX","arcEndY","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","heatSquare","size","data","key","legendBar","label","text","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","l","line","makeHoriLine","x1","x2","lineType","yLine","pos","mode","xLine","yMarker","labelPos","labelSvg","yRegion","region","datasetBar","meta","minHeight","datasetDot","dot","getPaths","xList","yList","pointsList","pointsStr","join","path","heatline","gradient_id","svgDefs","paths","areaFill","gradient_id_region","makeOverlay","unit","transformValue","nodeName","getAttribute","childNodes","overlay","cloneNode","updateOverlay","attributes","values","filter","includes","attr","specified","nodeValue","UNIT_ANIM_DUR","PATH_ANIM_DUR","MARKER_LINE_ANIM_DUR","REPLACE_ALL_NEW_DUR","STD_EASING","translate","oldCoord","newCoord","duration","old","translateVertLine","newX","oldX","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","rectAnim","groupAnim","animateBar","bar","oldCoordStr","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","push","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","EASING","animateSVGElement","props","dur","easingType","oldValues","animElement","newElement","attributeName","animateElement","currentValue","animAttr","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","CSSTEXT","downloadFile","filename","a","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","firstChild","BOUND_DRAW_FN","BaseChart","HTMLElement","Error","rawChartArgs","realData","prepareData","prepareFirstData","validateColors","config","isNavigable","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","bind","draw","removeEventListener","makeContainer","updateWidth","independentWidth","overflow","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","c","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","error","animate","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","event","keyCode","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","labels","total","datasets","totals","sort","remaining","sumOfRemaining","grandTotal","reduce","textContent","legendTotals","barWidth","divisor","floor","NO_OF_YEAR_MONTHS","NO_OF_DAYS_IN_WEEK","NO_OF_MILLIS","SEC_IN_DAY","MONTH_NAMES","DAY_NAMES_SHORT","treatAsUtc","date","result","Date","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","getTime","getWeeksBetween","startDate","endDate","weekStartDate","setDayToSunday","ceil","getDaysBetween","millisecondsPerDay","areInSameMonth","getMonthName","short","monthName","getLastDateInMonth","month","year","newDate","day","getDay","addDays","numberOfDays","setDate","ChartComponent","layerClass","layerTransform","constants","getData","makeElements","animateElements","store","layer","oldData","componentConfigs","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","newOptions","startPos","endPos","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","monthNameHeight","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","offsets","barsWidth","newXPos","newYPos","newOffsets","oldXPos","oldYPos","oldOffsets","hideLine","hideDots","valuesOverPoints","Object","newValues","getComponent","k","assign","PercentageChart","barOptions","component","xPos","bars","get","indexOf","gOff","pOff","formattedLabels","fraction","setValues","showTip","PieChart","mouseMove","mouseLeave","hoverRadio","startAngle","prevSlicesProperties","slicesProperties","curAngle","originDiffAngle","diffAngle","endAngle","prevProperty","curStart","curEnd","curPath","property","flag","calTranslateByAngle","g_off","pageX","pageY","formatted_labels","percent","slices","prevIndex","curActiveSliceIndex","prevAcitve","curActiveSlice","hoverSlice","normalize","isNaN","mantissa","exponent","sig","isFinite","exp","log10","man","pow","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","withMinimum","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","posIntervals","pseudoMaxValue","pseudoMinValue","reverse","getZeroIndex","yPts","zeroIndex","interval","getIntervalSize","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","prev","curr","calcDistribution","distributionSize","dataMaxValue","distributionStep","distribution","checkpoint","getMaxCheckpoint","COL_WIDTH","ROW_HEIGHT","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","spacing","end","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","moreTextX","moreText","startMonth","startYear","endMonth","endYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","dataPrep","datasetLength","zeroArray","overridingType","vals","chartType","yRegions","zeroDataPrep","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedSpace","allowedLetters","multiple","AxisChart","lineOptions","axisOptions","tooltipOptions","xAxisMode","yAxisMode","xIsSeries","formatTooltipX","formatTooltipY","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","xAxis","dataValues","intervalHeight","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","cumulativeYs","stacked","yExtremes","cumulativeYPos","cumulative","allValueLists","barDatasets","lineDatasets","barsConfigs","spaceRatio","p","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","titles","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","setCurrentDataPoint","data_point","getDataPoint","datasetValues","splice","chartTypes","getChartByType","Chart"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/frappe-charts.min.iife.js b/dist/frappe-charts.min.iife.js
index 653af55..3f9eb47 100644
--- a/dist/frappe-charts.min.iife.js
+++ b/dist/frappe-charts.min.iife.js
@@ -1,2 +1,2 @@
-var frappe=function(){"use strict";function t(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function e(t){var e=t.getBoundingClientRect();return{top:e.top+(document.documentElement.scrollTop||document.body.scrollTop),left:e.left+(document.documentElement.scrollLeft||document.body.scrollLeft)}}function i(t){var e=t.getBoundingClientRect();return e.top>=0&&e.left>=0&&e.bottom<=(window.innerHeight||document.documentElement.clientHeight)&&e.right<=(window.innerWidth||document.documentElement.clientWidth)}function n(t){var e=window.getComputedStyle(t),i=parseFloat(e.paddingLeft)+parseFloat(e.paddingRight);return t.clientWidth-i}function a(t,e,i){var n=document.createEvent("HTMLEvents");n.initEvent(e,!0,!0);for(var a in i)n[a]=i[a];return t.dispatchEvent(n)}function s(t){return t.titleHeight+t.margins.top+t.paddings.top}function r(t){return t.margins.left+t.paddings.left}function o(t){return t.margins.top+t.margins.bottom+t.paddings.top+t.paddings.bottom+t.titleHeight+t.legendHeight}function l(t){return t.margins.left+t.margins.right+t.paddings.left+t.paddings.right}function u(t){return parseFloat(t.toFixed(2))}function h(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]&&arguments[3];i||(i=n?t[0]:t[t.length-1]);var a=new Array(Math.abs(e)).fill(i);return t=n?a.concat(t):t.concat(a)}function c(t,e){return(t+"").length*e}function d(t,e){return{x:Math.sin(t*Bt)*e,y:Math.cos(t*Bt)*e}}function p(t,e){var i=void 0,n=void 0;return t<=e?(i=e-t,n=t):(i=t-e,n=e),[i,n]}function f(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length-t.length;return i>0?t=h(t,i):e=h(e,i),[t,e]}function v(t){return t>255?255:t<0?0:t}function g(t,e){var i=qt(t),n=!1;"#"==i[0]&&(i=i.slice(1),n=!0);var a=parseInt(i,16),s=v((a>>16)+e),r=v((a>>8&255)+e),o=v((255&a)+e);return(n?"#":"")+(o|r<<8|s<<16).toString(16)}function y(t){return/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(t)}function m(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function b(t,e){var i=document.createElementNS("http://www.w3.org/2000/svg",t);for(var n in e){var a=e[n];if("inside"===n)m(a).appendChild(i);else if("around"===n){var s=m(a);s.parentNode.insertBefore(i,s),i.appendChild(s)}else"styles"===n?"object"===(void 0===a?"undefined":Dt(a))&&Object.keys(a).map(function(t){i.style[t]=a[t]}):("className"===n&&(n="class"),"innerHTML"===n?i.textContent=a:i.setAttribute(n,a))}return i}function x(t,e){return b("linearGradient",{inside:t,id:e,x1:0,x2:0,y1:0,y2:1})}function k(t,e,i,n){return b("stop",{inside:t,style:"stop-color: "+i,offset:e,"stop-opacity":n})}function w(t,e,i,n){return b("svg",{className:e,inside:t,width:i,height:n})}function A(t){return b("defs",{inside:t})}function P(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,n={className:t,transform:e};return i&&(n.inside=i),b("g",n)}function C(t){return b("path",{className:arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",d:t,styles:{stroke:arguments.length>2&&void 0!==arguments[2]?arguments[2]:"none",fill:arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none"}})}function L(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=i.x+t.x,r=i.y+t.y,o=i.x+e.x,l=i.y+e.y;return"M"+i.x+" "+i.y+"\n\t\tL"+s+" "+r+"\n\t\tA "+n+" "+n+" 0 0 "+(a?1:0)+"\n\t\t"+o+" "+l+" z"}function T(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n="path-fill-gradient-"+e+"-"+(i?"lighter":"default"),a=x(t,n),s=[1,.6,.2];return i&&(s=[.4,.2,0]),k(a,"0%",e,s[0]),k(a,"50%",e,s[1]),k(a,"100%",e,s[2]),n}function D(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:It,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"none";return b("rect",{className:"percentage-bar",x:t,y:e,width:i,height:n,fill:s,styles:{stroke:g(s,-25),"stroke-dasharray":"0, "+(n+i)+", "+i+", "+n,"stroke-width":a}})}function O(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"none",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},r={className:t,x:e,y:i,width:n,height:n,fill:a};return Object.keys(s).map(function(t){r[t]=s[t]}),b("rect",r)}function M(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4],s={className:"legend-bar",x:0,y:0,width:i,height:"2px",fill:n},r=b("text",{className:"legend-dataset-text",x:0,y:0,dy:2*Kt+"px","font-size":1.2*Kt+"px","text-anchor":"start",fill:Qt,innerHTML:a}),o=b("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(b("rect",s)),o.appendChild(r),o}function N(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4],s={className:"legend-dot",cx:0,cy:0,r:i,fill:n},r=b("text",{className:"legend-dataset-text",x:0,y:0,dx:Kt+"px",dy:Kt/3+"px","font-size":1.2*Kt+"px","text-anchor":"start",fill:Qt,innerHTML:a}),o=b("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(b("circle",s)),o.appendChild(r),o}function E(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=a.fontSize||Kt;return b("text",{className:t,x:e,y:i,dy:(void 0!==a.dy?a.dy:s/2)+"px","font-size":s+"px",fill:a.fill||Qt,"text-anchor":a.textAnchor||"start",innerHTML:n})}function S(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=$t);var s=b("line",{className:"line-vertical "+a.className,x1:0,x2:0,y1:i,y2:n,styles:{stroke:a.stroke}}),r=b("text",{x:0,y:i>n?i+Jt:i-Jt-Kt,dy:Kt+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:e+""}),o=b("g",{transform:"translate("+t+", 0)"});return o.appendChild(s),o.appendChild(r),o}function _(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=$t),a.lineType||(a.lineType="");var s=b("line",{className:"line-horizontal "+a.className+("dashed"===a.lineType?"dashed":""),x1:i,x2:n,y1:0,y2:0,styles:{stroke:a.stroke}}),r=b("text",{x:i3&&void 0!==arguments[3]?arguments[3]:{};n.pos||(n.pos="left"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=$t),n.className||(n.className="");var a=-1*Xt,s="span"===n.mode?i+Xt:0;return"tick"===n.mode&&"right"===n.pos&&(a=i+Xt,s=i),a+=n.offset,s+=n.offset,_(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType})}function H(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};n.pos||(n.pos="bottom"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=$t),n.className||(n.className="");var a=i+Xt,s="span"===n.mode?-1*Xt:i;return"tick"===n.mode&&"top"===n.pos&&(a=-1*Xt,s=0),S(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType})}function F(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};n.labelPos||(n.labelPos="right");var a=b("text",{className:"chart-label",x:"left"===n.labelPos?Jt:i-c(e,5)-Jt,y:0,dy:Kt/-2+"px","font-size":Kt+"px","text-anchor":"start",innerHTML:e+""}),s=_(t,"",0,i,{stroke:n.stroke||$t,className:n.className||"",lineType:n.lineType});return s.appendChild(a),s}function j(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=t-e,r=b("rect",{className:"bar mini",styles:{fill:"rgba(228, 234, 239, 0.49)",stroke:$t,"stroke-dasharray":i+", "+s},x:0,y:0,width:i,height:s});a.labelPos||(a.labelPos="right");var o=b("text",{className:"chart-label",x:"left"===a.labelPos?Jt:i-c(n+"",4.5)-Jt,y:0,dy:Kt/-2+"px","font-size":Kt+"px","text-anchor":"start",innerHTML:n+""}),l=b("g",{transform:"translate(0, "+e+")"});return l.appendChild(r),l.appendChild(o),l}function W(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,o=arguments.length>7&&void 0!==arguments[7]?arguments[7]:{},l=p(e,o.zeroLine),u=_t(l,2),h=u[0],c=u[1];c-=r,0===h&&(h=o.minHeight,c-=o.minHeight);var d=b("rect",{className:"bar mini",style:"fill: "+n,"data-point-index":s,x:t,y:c,width:i,height:h});if((a+="")||a.length){d.setAttribute("y",0),d.setAttribute("x",0);var f=b("text",{className:"data-point-value",x:i/2,y:0,dy:Kt/2*-1+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:a}),v=b("g",{"data-point-index":s,transform:"translate("+t+", "+c+")"});return v.appendChild(d),v.appendChild(f),v}return d}function I(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=b("circle",{style:"fill: "+n,"data-point-index":s,cx:t,cy:e,r:i});if((a+="")||a.length){r.setAttribute("cy",0),r.setAttribute("cx",0);var o=b("text",{className:"data-point-value",x:0,y:0,dy:Kt/2*-1-i+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:a}),l=b("g",{"data-point-index":s,transform:"translate("+t+", "+e+")"});return l.appendChild(r),l.appendChild(o),l}return r}function R(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=e.map(function(e,i){return t[i]+","+e}).join("L"),r=C("M"+s,"line-graph-path",i);if(n.heatline){var o=T(a.svgDefs,i);r.style.stroke="url(#"+o+")"}var l={path:r};if(n.regionFill){var u=T(a.svgDefs,i,!0),h="M"+t[0]+","+a.zeroLine+"L"+s+"L"+t.slice(-1)[0]+","+a.zeroLine;l.region=C(h,"region-fill","none","url(#"+u+")")}return l}function Y(t,e,i,n){var a="string"==typeof e?e:e.join(", ");return[t,{transform:i.join(", ")},n,se,"translate",{transform:a}]}function V(t,e,i){return Y(t,[i,0],[e,0],ne)}function B(t,e,i){return Y(t,[0,i],[0,e],ne)}function U(t,e,i,n){var a=e-i,s=t.childNodes[0];return[[s,{height:a,"stroke-dasharray":s.getAttribute("width")+", "+a},ne,se],Y(t,[0,n],[0,i],ne)]}function G(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,s=p(i,(arguments.length>5&&void 0!==arguments[5]?arguments[5]:{}).zeroLine),r=_t(s,2),o=r[0],l=r[1];return l-=a,"rect"!==t.nodeName?[[t.childNodes[0],{width:n,height:o},ee,se],Y(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,l],ne)]:[[t,{width:n,height:o,x:e,y:l},ee,se]]}function q(t,e,i){return"circle"!==t.nodeName?[Y(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,i],ne)]:[[t,{cx:e,cy:i},ee,se]]}function X(t,e,i,n){var a=[],s=i.map(function(t,i){return e[i]+","+t}).join("L"),r=[t.path,{d:"M"+s},ie,se];if(a.push(r),t.region){var o=e[0]+","+n+"L",l="L"+e.slice(-1)[0]+", "+n,u=[t.region,{d:"M"+o+s+l},ie,se];a.push(u)}return a}function J(t,e){return[t,{d:e},ee,se]}function K(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"linear",a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:void 0,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},r=t.cloneNode(!0),o=t.cloneNode(!0);for(var l in e){var u=void 0;u="transform"===l?document.createElementNS("http://www.w3.org/2000/svg","animateTransform"):document.createElementNS("http://www.w3.org/2000/svg","animate");var h=s[l]||t.getAttribute(l),c=e[l],d={attributeName:l,from:h,to:c,begin:"0s",dur:i/1e3+"s",values:h+";"+c,keySplines:re[n],keyTimes:"0;1",calcMode:"spline",fill:"freeze"};a&&(d.type=a);for(var p in d)u.setAttribute(p,d[p]);r.appendChild(u),a?o.setAttribute(l,"translate("+c+")"):o.setAttribute(l,c)}return[r,o]}function $(t,e){t.style.transform=e,t.style.webkitTransform=e,t.style.msTransform=e,t.style.mozTransform=e,t.style.oTransform=e}function Q(t,e){var i=[],n=[];e.map(function(t){var e=t[0],a=e.parentNode,s=void 0,r=void 0;t[0]=e;var o=K.apply(void 0,zt(t)),l=_t(o,2);s=l[0],r=l[1],i.push(r),n.push([s,a]),a.replaceChild(s,e)});var a=t.cloneNode(!0);return n.map(function(t,n){t[1].replaceChild(i[n],t[0]),e[n][0]=i[n]}),a}function Z(t,e,i){if(0!==i.length){var n=Q(e,i);e.parentNode==t&&(t.removeChild(e),t.appendChild(n)),setTimeout(function(){n.parentNode==t&&(t.removeChild(n),t.appendChild(e))},ae)}}function tt(t,e){var i=document.createElement("a");i.style="display: none";var n=new Blob(e,{type:"image/svg+xml; charset=utf-8"}),a=window.URL.createObjectURL(n);i.href=a,i.download=t,document.body.appendChild(i),i.click(),setTimeout(function(){document.body.removeChild(i),window.URL.revokeObjectURL(a)},300)}function et(e){var i=e.cloneNode(!0);i.classList.add("chart-container"),i.setAttribute("xmlns","http://www.w3.org/2000/svg"),i.setAttribute("xmlns:xlink","http://www.w3.org/1999/xlink");var n=t.create("style",{innerHTML:oe});i.insertBefore(n,i.firstChild);var a=t.create("div");return a.appendChild(i),a.innerHTML}function it(t){var e=new Date(t);return e.setMinutes(e.getMinutes()-e.getTimezoneOffset()),e}function nt(t){var e=t.getDate(),i=t.getMonth()+1;return[t.getFullYear(),(i>9?"":"0")+i,(e>9?"":"0")+e].join("-")}function at(t){return new Date(t.getTime())}function st(t,e){var i=ht(t);return Math.ceil(rt(i,e)/ce)}function rt(t,e){var i=pe*de;return(it(e)-it(t))/i}function ot(t,e){return t.getMonth()===e.getMonth()&&t.getFullYear()===e.getFullYear()}function lt(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1],i=fe[t];return e?i.slice(0,3):i}function ut(t,e){return new Date(e,t+1,0)}function ht(t){var e=at(t),i=e.getDay();return 0!==i&&ct(e,-1*i),e}function ct(t,e){t.setDate(t.getDate()+e)}function dt(t,e,i){var n=Object.keys(ye).filter(function(e){return t.includes(e)}),a=ye[n[0]];return Object.assign(a,{constants:e,getData:i}),new ge(a)}function pt(t){if(0===t)return[0,0];if(isNaN(t))return{mantissa:-6755399441055744,exponent:972};var e=t>0?1:-1;if(!isFinite(t))return{mantissa:4503599627370496*e,exponent:972};t=Math.abs(t);var i=Math.floor(Math.log10(t));return[e*(t/Math.pow(10,i)),i]}function ft(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=Math.ceil(t),n=Math.floor(e),a=i-n,s=a,r=1;a>5&&(a%2!=0&&(a=++i-n),s=a/2,r=2),a<=2&&(r=a/(s=4)),0===a&&(s=5,r=1);for(var o=[],l=0;l<=s;l++)o.push(n+r*l);return o}function vt(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=pt(t),n=_t(i,2),a=n[0],s=n[1],r=e?e/Math.pow(10,s):0,o=ft(a=a.toFixed(6),r);return o=o.map(function(t){return t*Math.pow(10,s)})}function gt(t){function e(t,e){for(var i=vt(t),n=i[1]-i[0],a=0,s=1;a1&&void 0!==arguments[1]&&arguments[1],n=Math.max.apply(Math,zt(t)),a=Math.min.apply(Math,zt(t)),s=[];if(n>=0&&a>=0)pt(n)[1],s=i?vt(n,a):vt(n);else if(n>0&&a<0){var r=Math.abs(a);n>=r?(pt(n)[1],s=e(n,r)):(pt(r)[1],s=e(r,n).map(function(t){return-1*t}))}else if(n<=0&&a<=0){var o=Math.abs(a),l=Math.abs(n);pt(o)[1],s=(s=i?vt(o,l):vt(o)).reverse().map(function(t){return-1*t})}return s}function yt(t){var e=mt(t);return t.indexOf(0)>=0?t.indexOf(0):t[0]>0?-1*t[0]/e:-1*t[t.length-1]/e+(t.length-1)}function mt(t){return t[1]-t[0]}function bt(t){return t[t.length-1]-t[0]}function xt(t,e){return u(e.zeroLine-t*e.scaleMultiplier)}function kt(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n=e.reduce(function(e,i){return Math.abs(i-t)i?e.slice(0,i):h(e,i-e.length,0)}else t.values=a;s?t.chartType=s:t.chartType||(t.chartType=jt)}),t.yRegions&&t.yRegions.map(function(t){if(t.end1&&void 0!==arguments[1]?arguments[1]:[],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=t/e.length;n<=0&&(n=1);var a=n/Rt;return e.map(function(t,e){return(t+="").length>a&&(i?e%Math.ceil(t.length/a)!=0&&(t=""):t=a-3>0?t.slice(0,a-3)+" ...":t.slice(0,a)+".."),t})}function Tt(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"line",e=arguments[1],i=arguments[2];return"axis-mixed"===t?(i.type="line",new ke(e,i)):we[t]?new we[t](e,i):void console.error("Undefined chart type: "+t)}!function(t,e){void 0===e&&(e={});var i=e.insertAt;if(t&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css","top"===i&&n.firstChild?n.insertBefore(a,n.firstChild):n.appendChild(a),a.styleSheet?a.styleSheet.cssText=t:a.appendChild(document.createTextNode(t))}}('.chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:1;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ol,.graph-svg-tip ul{padding-left:0;display:-webkit-box;display:-ms-flexbox;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:" ";border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}',{});var Dt="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},Ot=(function(){function t(t){this.value=t}function e(e){function i(t,e){return new Promise(function(i,a){var o={key:t,arg:e,resolve:i,reject:a,next:null};r?r=r.next=o:(s=r=o,n(t,e))})}function n(i,s){try{var r=e[i](s),o=r.value;o instanceof t?Promise.resolve(o.value).then(function(t){n("next",t)},function(t){n("throw",t)}):a(r.done?"return":"normal",r.value)}catch(t){a("throw",t)}}function a(t,e){switch(t){case"return":s.resolve({value:e,done:!0});break;case"throw":s.reject(e);break;default:s.resolve({value:e,done:!1})}(s=s.next)?n(s.key,s.arg):r=null}var s,r;this._invoke=i,"function"!=typeof e.return&&(this.return=void 0)}"function"==typeof Symbol&&Symbol.asyncIterator&&(e.prototype[Symbol.asyncIterator]=function(){return this}),e.prototype.next=function(t){return this._invoke("next",t)},e.prototype.throw=function(t){return this._invoke("throw",t)},e.prototype.return=function(t){return this._invoke("return",t)}}(),function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}),Mt=function(){function t(t,e){for(var i=0;i\n\t\t\t\t\n\t\t\t\t'}),this.hideTip(),this.title=this.container.querySelector(".title"),this.dataPointList=this.container.querySelector(".data-point-list"),this.parent.addEventListener("mouseleave",function(){e.hideTip()})}},{key:"fill",value:function(){var e=this,i=void 0;this.index&&this.container.setAttribute("data-point-index",this.index),i=this.titleValueFirst?""+this.titleValue+""+this.titleName:this.titleName+""+this.titleValue+"",this.title.innerHTML=i,this.dataPointList.innerHTML="",this.listValues.map(function(i,n){var a=e.colors[n]||"black",s=0===i.formatted||i.formatted?i.formatted:i.value,r=t.create("li",{styles:{"border-top":"3px solid "+a},innerHTML:''+(0===s||s?s:"")+"\n\t\t\t\t\t"+(i.title?i.title:"")});e.dataPointList.appendChild(r)})}},{key:"calcPosition",value:function(){var t=this.container.offsetWidth;this.top=this.y-this.container.offsetHeight-5,this.left=this.x-t/2;var e=this.parent.offsetWidth-t,i=this.container.querySelector(".svg-pointer");if(this.left<0)i.style.left="calc(50% - "+-1*this.left+"px)",this.left=0;else if(this.left>e){var n="calc(50% + "+(this.left-e)+"px)";i.style.left=n,this.left=e}else i.style.left="50%"}},{key:"setValues",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:-1;this.titleName=i.name,this.titleValue=i.value,this.listValues=n,this.x=t,this.y=e,this.titleValueFirst=i.valueFirst||0,this.index=a,this.refresh()}},{key:"hideTip",value:function(){this.container.style.top="0px",this.container.style.left="0px",this.container.style.opacity="0"}},{key:"showTip",value:function(){this.container.style.top=this.top+"px",this.container.style.left=this.left+"px",this.container.style.opacity="1"}}]),e}(),Gt={"light-blue":"#7cd6fd",blue:"#5e64ff",violet:"#743ee2",red:"#ff5858",orange:"#ffa00a",yellow:"#feef72",green:"#28a745","light-green":"#98d85b",purple:"#b554ff",magenta:"#ffa3ef",black:"#36114C",grey:"#bdd3e6","light-grey":"#f0f4f7","dark-grey":"#b8c2cc"},qt=function(t){return Gt[t]||t},Xt=6,Jt=4,Kt=10,$t="#dadada",Qt="#555b51",Zt={bar:function(t){var e=void 0;"rect"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode();return i.style.fill="#000000",i.style.opacity="0.4",e&&i.setAttribute("transform",e),i},dot:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i},heat_square:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i}},te={bar:function(t,e){var i=void 0;"rect"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["x","y","width","height"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},dot:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},heat_square:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)}},ee=350,ie=350,ne=ee,ae=250,se="easein",re={ease:"0.25 0.1 0.25 1",linear:"0 0 1 1",easein:"0.1 0.8 0.2 1",easeout:"0 0 0.58 1",easeinout:"0.42 0 0.58 1"},oe=".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}",le=void 0,ue=function(){function e(t,i){if(Ot(this,e),this.parent="string"==typeof t?document.querySelector(t):t,!(this.parent instanceof HTMLElement))throw new Error("No `parent` element to render on was provided.");this.rawChartArgs=i,this.title=i.title||"",this.type=i.type||"line",this.realData=this.prepareData(i.data),this.data=this.prepareFirstData(this.realData),this.colors=this.validateColors(i.colors,this.type),this.config={showTooltip:1,showLegend:1,isNavigable:i.isNavigable||0,animate:1},this.measures=JSON.parse(JSON.stringify(Ht));var n=this.measures;this.setMeasures(i),this.title.length||(n.titleHeight=0),this.config.showLegend||(n.legendHeight=0),this.argHeight=i.height||n.baseHeight,this.state={},this.options={},this.initTimeout=Ft,this.config.isNavigable&&(this.overlays=[]),this.configure(i)}return Mt(e,[{key:"prepareData",value:function(t){return t}},{key:"prepareFirstData",value:function(t){return t}},{key:"validateColors",value:function(t,e){var i=[];return(t=(t||[]).concat(Vt[e])).forEach(function(t){var e=qt(t);y(e)?i.push(e):console.warn('"'+t+'" is not a valid color.')}),i}},{key:"setMeasures",value:function(){}},{key:"configure",value:function(){var t=this.argHeight;this.baseHeight=t,this.height=t-o(this.measures),le=this.boundDrawFn.bind(this),window.addEventListener("resize",le),window.addEventListener("orientationchange",this.boundDrawFn.bind(this))}},{key:"boundDrawFn",value:function(){this.draw(!0)}},{key:"unbindWindowEvents",value:function(){window.removeEventListener("resize",le),window.removeEventListener("orientationchange",this.boundDrawFn.bind(this))}},{key:"setup",value:function(){this.makeContainer(),this.updateWidth(),this.makeTooltip(),this.draw(!1,!0)}},{key:"makeContainer",value:function(){this.parent.innerHTML="";var e={inside:this.parent,className:"chart-container"};this.independentWidth&&(e.styles={width:this.independentWidth+"px"},this.parent.style.overflow="auto"),this.container=t.create("div",e)}},{key:"makeTooltip",value:function(){this.tip=new Ut({parent:this.container,colors:this.colors}),this.bindTooltip()}},{key:"bindTooltip",value:function(){}},{key:"draw",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],i=arguments.length>1&&void 0!==arguments[1]&&arguments[1];this.updateWidth(),this.calc(e),this.makeChartArea(),this.setupComponents(),this.components.forEach(function(e){return e.setup(t.drawArea)}),this.render(this.components,!1),i&&(this.data=this.realData,setTimeout(function(){t.update(t.data)},this.initTimeout)),this.renderLegend(),this.setupNavigation(i)}},{key:"calc",value:function(){}},{key:"updateWidth",value:function(){this.baseWidth=n(this.parent),this.width=this.baseWidth-l(this.measures)}},{key:"makeChartArea",value:function(){this.svg&&this.container.removeChild(this.svg);var t=this.measures;this.svg=w(this.container,"frappe-chart chart",this.baseWidth,this.baseHeight),this.svgDefs=A(this.svg),this.title.length&&(this.titleEL=E("title",t.margins.left,t.margins.top,this.title,{fontSize:t.titleFontSize,fill:"#666666",dy:t.titleFontSize}));var e=s(t);this.drawArea=P(this.type+"-chart chart-draw-area","translate("+r(t)+", "+e+")"),this.config.showLegend&&(e+=this.height+t.paddings.bottom,this.legendArea=P("chart-legend","translate("+r(t)+", "+e+")")),this.title.length&&this.svg.appendChild(this.titleEL),this.svg.appendChild(this.drawArea),this.config.showLegend&&this.svg.appendChild(this.legendArea),this.updateTipOffset(r(t),s(t))}},{key:"updateTipOffset",value:function(t,e){this.tip.offset={x:t,y:e}}},{key:"setupComponents",value:function(){this.components=new Map}},{key:"update",value:function(t){t||console.error("No data to update."),this.data=this.prepareData(t),this.calc(),this.render()}},{key:"render",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.components,i=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.config.isNavigable&&this.overlays.map(function(t){return t.parentNode.removeChild(t)});var n=[];e.forEach(function(t){n=n.concat(t.update(i))}),n.length>0?(Z(this.container,this.svg,n),setTimeout(function(){e.forEach(function(t){return t.make()}),t.updateNav()},400)):(e.forEach(function(t){return t.make()}),this.updateNav())}},{key:"updateNav",value:function(){this.config.isNavigable&&(this.makeOverlay(),this.bindUnits())}},{key:"renderLegend",value:function(){}},{key:"setupNavigation",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.config.isNavigable&&e&&(this.bindOverlay(),this.keyActions={13:this.onEnterKey.bind(this),37:this.onLeftArrow.bind(this),38:this.onUpArrow.bind(this),39:this.onRightArrow.bind(this),40:this.onDownArrow.bind(this)},document.addEventListener("keydown",function(e){i(t.container)&&(e=e||window.event,t.keyActions[e.keyCode]&&t.keyActions[e.keyCode]())}))}},{key:"makeOverlay",value:function(){}},{key:"updateOverlay",value:function(){}},{key:"bindOverlay",value:function(){}},{key:"bindUnits",value:function(){}},{key:"onLeftArrow",value:function(){}},{key:"onRightArrow",value:function(){}},{key:"onUpArrow",value:function(){}},{key:"onDownArrow",value:function(){}},{key:"onEnterKey",value:function(){}},{key:"addDataPoint",value:function(){}},{key:"removeDataPoint",value:function(){}},{key:"getDataPoint",value:function(){}},{key:"setCurrentDataPoint",value:function(){}},{key:"updateDataset",value:function(){}},{key:"export",value:function(){var t=et(this.svg);tt(this.title||"Chart",[t])}}]),e}(),he=function(t){function e(t,i){return Ot(this,e),St(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i))}return Et(e,t),Mt(e,[{key:"configure",value:function(t){Nt(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"configure",this).call(this,t),this.config.maxSlices=t.maxSlices||20,this.config.maxLegendPoints=t.maxLegendPoints||20}},{key:"calc",value:function(){var t=this,e=this.state,i=this.config.maxSlices;e.sliceTotals=[];var n=this.data.labels.map(function(e,i){var n=0;return t.data.datasets.map(function(t){n+=t.values[i]}),[n,e]}).filter(function(t){return t[0]>=0}),a=n;if(n.length>i){n.sort(function(t,e){return e[0]-t[0]}),a=n.slice(0,i-1);var s=0;n.slice(i-1).map(function(t){s+=t[0]}),a.push([s,"Rest"]),this.colors[i-1]="grey"}e.labels=[],a.map(function(t){e.sliceTotals.push(t[0]),e.labels.push(t[1])}),e.grandTotal=e.sliceTotals.reduce(function(t,e){return t+e},0),this.center={x:this.width/2,y:this.height/2}}},{key:"renderLegend",value:function(){var t=this,e=this.state;this.legendArea.textContent="",this.legendTotals=e.sliceTotals.slice(0,this.config.maxLegendPoints);var i=0,n=0;this.legendTotals.map(function(a,s){var r=Math.floor((t.width-l(t.measures))/110);i>r&&(i=0,n+=20);var o=N(110*i+5,n,5,t.colors[s],e.labels[s]+": "+a);t.legendArea.appendChild(o),i++})}}]),e}(ue),ce=7,de=1e3,pe=86400,fe=["January","February","March","April","May","June","July","August","September","October","November","December"],ve=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],ge=function(){function t(e){var i=e.layerClass,n=void 0===i?"":i,a=e.layerTransform,s=void 0===a?"":a,r=e.constants,o=e.getData,l=e.makeElements,u=e.animateElements;Ot(this,t),this.layerTransform=s,this.constants=r,this.makeElements=l,this.getData=o,this.animateElements=u,this.store=[],this.labels=[],this.layerClass=n,this.layerClass="function"==typeof this.layerClass?this.layerClass():this.layerClass,this.refresh()}return Mt(t,[{key:"refresh",value:function(t){this.data=t||this.getData()}},{key:"setup",value:function(t){this.layer=P(this.layerClass,this.layerTransform,t)}},{key:"make",value:function(){this.render(this.data),this.oldData=this.data}},{key:"render",value:function(t){var e=this;this.store=this.makeElements(t),this.layer.textContent="",this.store.forEach(function(t){e.layer.appendChild(t)}),this.labels.forEach(function(t){e.layer.appendChild(t)})}},{key:"update",value:function(){var t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];this.refresh();var e=[];return t&&(e=this.animateElements(this.data)||[]),e}}]),t}(),ye={pieSlices:{layerClass:"pie-slices",makeElements:function(t){return t.sliceStrings.map(function(e,i){var n=C(e,"pie-path","none",t.colors[i]);return n.style.transition="transform .3s;",n})},animateElements:function(t){return this.store.map(function(e,i){return J(e,t.sliceStrings[i])})}},percentageBars:{layerClass:"percentage-bars",makeElements:function(t){var e=this;return t.xPositions.map(function(i,n){return D(i,0,t.widths[n],e.constants.barHeight,e.constants.barDepth,t.colors[n])})},animateElements:function(t){if(t)return[]}},yAxis:{layerClass:"y axis",makeElements:function(t){var e=this;return t.positions.map(function(i,n){return z(i,t.labels[n],e.constants.width,{mode:e.constants.mode,pos:e.constants.pos})})},animateElements:function(t){var e=t.positions,i=t.labels,n=this.oldData.positions,a=this.oldData.labels,s=f(n,e),r=_t(s,2);n=r[0],e=r[1];var o=f(a,i),l=_t(o,2);return a=l[0],i=l[1],this.render({positions:n,labels:i}),this.store.map(function(t,i){return B(t,e[i],n[i])})}},xAxis:{layerClass:"x axis",makeElements:function(t){var e=this;return t.positions.map(function(i,n){return H(i,t.calcLabels[n],e.constants.height,{mode:e.constants.mode,pos:e.constants.pos})})},animateElements:function(t){var e=t.positions,i=t.calcLabels,n=this.oldData.positions,a=this.oldData.calcLabels,s=f(n,e),r=_t(s,2);n=r[0],e=r[1];var o=f(a,i),l=_t(o,2);return a=l[0],i=l[1],this.render({positions:n,calcLabels:i}),this.store.map(function(t,i){return V(t,e[i],n[i])})}},yMarkers:{layerClass:"y-markers",makeElements:function(t){var e=this;return t.map(function(t){return F(t.position,t.label,e.constants.width,{labelPos:t.options.labelPos,mode:"span",lineType:"dashed"})})},animateElements:function(t){var e=f(this.oldData,t),i=_t(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.position}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.options}),r=this.oldData.map(function(t){return t.position});return this.render(r.map(function(t,e){return{position:r[e],label:a[e],options:s[e]}})),this.store.map(function(t,e){return B(t,n[e],r[e])})}},yRegions:{layerClass:"y-regions",makeElements:function(t){var e=this;return t.map(function(t){return j(t.startPos,t.endPos,e.constants.width,t.label,{labelPos:t.options.labelPos})})},animateElements:function(t){var e=f(this.oldData,t),i=_t(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.endPos}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.startPos}),r=t.map(function(t){return t.options}),o=this.oldData.map(function(t){return t.endPos}),l=this.oldData.map(function(t){return t.startPos});this.render(o.map(function(t,e){return{startPos:l[e],endPos:o[e],label:a[e],options:r[e]}}));var u=[];return this.store.map(function(t,e){u=u.concat(U(t,s[e],n[e],o[e]))}),u}},heatDomain:{layerClass:function(){return"heat-domain domain-"+this.constants.index},makeElements:function(t){var e=this,i=this.constants,n=i.index,a=i.colWidth,s=i.rowHeight,r=i.squareSize,o=i.xTranslate,l=0;return this.serializedSubDomains=[],t.cols.map(function(t,i){1===i&&e.labels.push(E("domain-name",o,-12,lt(n,!0).toUpperCase(),{fontSize:9})),t.map(function(t,i){if(t.fill){var n={"data-date":t.yyyyMmDd,"data-value":t.dataValue,"data-day":i},a=O("day",o,l,r,t.fill,n);e.serializedSubDomains.push(a)}l+=s}),l=0,o+=a}),this.serializedSubDomains},animateElements:function(t){if(t)return[]}},barGraph:{layerClass:function(){return"dataset-units dataset-bars dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="bar",this.units=t.yPositions.map(function(i,n){return W(t.xPositions[n],i,t.barWidth,e.color,t.labels[n],n,t.offsets[n],{zeroLine:t.zeroLine,barsWidth:t.barsWidth,minHeight:e.minHeight})}),this.units},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.offsets,a=t.labels,s=this.oldData.xPositions,r=this.oldData.yPositions,o=this.oldData.offsets,l=this.oldData.labels,u=f(s,e),h=_t(u,2);s=h[0],e=h[1];var c=f(r,i),d=_t(c,2);r=d[0],i=d[1];var p=f(o,n),v=_t(p,2);o=v[0],n=v[1];var g=f(l,a),y=_t(g,2);l=y[0],a=y[1],this.render({xPositions:s,yPositions:r,offsets:o,labels:a,zeroLine:this.oldData.zeroLine,barsWidth:this.oldData.barsWidth,barWidth:this.oldData.barWidth});var m=[];return this.store.map(function(a,s){m=m.concat(G(a,e[s],i[s],t.barWidth,n[s],{zeroLine:t.zeroLine}))}),m}},lineGraph:{layerClass:function(){return"dataset-units dataset-line dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="dot",this.paths={},e.hideLine||(this.paths=R(t.xPositions,t.yPositions,e.color,{heatline:e.heatline,regionFill:e.regionFill},{svgDefs:e.svgDefs,zeroLine:t.zeroLine})),this.units=[],e.hideDots||(this.units=t.yPositions.map(function(i,n){return I(t.xPositions[n],i,t.radius,e.color,e.valuesOverPoints?t.values[n]:"",n)})),Object.values(this.paths).concat(this.units)},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.values,a=this.oldData.xPositions,s=this.oldData.yPositions,r=this.oldData.values,o=f(a,e),l=_t(o,2);a=l[0],e=l[1];var u=f(s,i),h=_t(u,2);s=h[0],i=h[1];var c=f(r,n),d=_t(c,2);r=d[0],n=d[1],this.render({xPositions:a,yPositions:s,values:n,zeroLine:this.oldData.zeroLine,radius:this.oldData.radius});var p=[];return Object.keys(this.paths).length&&(p=p.concat(X(this.paths,e,i,t.zeroLine))),this.units.length&&this.units.map(function(t,n){p=p.concat(q(t,e[n],i[n]))}),p}}},me=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="percentage",n.setup(),n}return Et(i,t),Mt(i,[{key:"setMeasures",value:function(t){var e=this.measures;this.barOptions=t.barOptions||{};var i=this.barOptions;i.height=i.height||20,i.depth=i.depth||It,e.paddings.right=30,e.legendHeight=80,e.baseHeight=8*(i.height+.5*i.depth)}},{key:"setupComponents",value:function(){var t=this.state,e=[["percentageBars",{barHeight:this.barOptions.height,barDepth:this.barOptions.depth},function(){return{xPositions:t.xPositions,widths:t.widths,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=dt.apply(void 0,zt(t));return[t[0],e]}))}},{key:"calc",value:function(){var t=this;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;e.xPositions=[],e.widths=[];var n=0;e.sliceTotals.map(function(i){var a=t.width*i/e.grandTotal;e.widths.push(a),e.xPositions.push(n),n+=a})}},{key:"makeDataByIndex",value:function(){}},{key:"bindTooltip",value:function(){var t=this,i=this.state;this.container.addEventListener("mousemove",function(n){var a=t.components.get("percentageBars").store,s=n.target;if(a.includes(s)){var r=a.indexOf(s),o=e(t.container),l=e(s),u=l.left-o.left+parseInt(s.getAttribute("width"))/2,h=l.top-o.top,c=(t.formattedLabels&&t.formattedLabels.length>0?t.formattedLabels[r]:t.state.labels[r])+": ",d=i.sliceTotals[r]/i.grandTotal;t.tip.setValues(u,h,{name:c,value:(100*d).toFixed(1)+"%"}),t.tip.showTip()}})}}]),i}(he),be=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="pie",n.initTimeout=0,n.init=1,n.setup(),n}return Et(i,t),Mt(i,[{key:"configure",value:function(t){Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),this.mouseMove=this.mouseMove.bind(this),this.mouseLeave=this.mouseLeave.bind(this),this.hoverRadio=t.hoverRadio||.1,this.config.startAngle=t.startAngle||0,this.clockWise=t.clockWise||!1}},{key:"calc",value:function(){var t=this;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;this.radius=this.height>this.width?this.center.x:this.center.y;var n=this.radius,a=this.clockWise,s=e.slicesProperties||[];e.sliceStrings=[],e.slicesProperties=[];var r=180-this.config.startAngle;e.sliceTotals.map(function(i,o){var l=r,u=i/e.grandTotal*360,h=a?-u:u,c=r+=h,p=d(l,n),f=d(c,n),v=t.init&&s[o],g=void 0,y=void 0;t.init?(g=v?v.startPosition:p,y=v?v.endPosition:p):(g=p,y=f);var m=L(g,y,t.center,t.radius,t.clockWise);e.sliceStrings.push(m),e.slicesProperties.push({startPosition:p,endPosition:f,value:i,total:e.grandTotal,startAngle:l,endAngle:c,angle:h})}),this.init=0}},{key:"setupComponents",value:function(){var t=this.state,e=[["pieSlices",{},function(){return{sliceStrings:t.sliceStrings,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=dt.apply(void 0,zt(t));return[t[0],e]}))}},{key:"calTranslateByAngle",value:function(t){var e=this.radius,i=this.hoverRadio,n=d(t.startAngle+t.angle/2,e);return"translate3d("+n.x*i+"px,"+n.y*i+"px,0)"}},{key:"hoverSlice",value:function(t,i,n,a){if(t){var s=this.colors[i];if(n){$(t,this.calTranslateByAngle(this.state.slicesProperties[i])),t.style.fill=g(s,50);var r=e(this.svg),o=a.pageX-r.left+10,l=a.pageY-r.top-10,u=(this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels[i]:this.state.labels[i])+": ",h=(100*this.state.sliceTotals[i]/this.state.grandTotal).toFixed(1);this.tip.setValues(o,l,{name:u,value:h+"%"}),this.tip.showTip()}else $(t,"translate3d(0,0,0)"),this.tip.hideTip(),t.style.fill=s}}},{key:"bindTooltip",value:function(){this.container.addEventListener("mousemove",this.mouseMove),this.container.addEventListener("mouseleave",this.mouseLeave)}},{key:"mouseMove",value:function(t){var e=t.target,i=this.components.get("pieSlices").store,n=this.curActiveSliceIndex,a=this.curActiveSlice;if(i.includes(e)){var s=i.indexOf(e);this.hoverSlice(a,n,!1),this.curActiveSlice=e,this.curActiveSliceIndex=s,this.hoverSlice(e,s,!0,t)}else this.mouseLeave()}},{key:"mouseLeave",value:function(){this.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,!1)}}]),i}(he),xe=function(t){function e(t,i){Ot(this,e);var n=St(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i));n.type="heatmap",n.countLabel=i.countLabel||"";var a=["Sunday","Monday"],s=a.includes(i.startSubDomain)?i.startSubDomain:"Sunday";return n.startSubDomainIndex=a.indexOf(s),n.setup(),n}return Et(e,t),Mt(e,[{key:"setMeasures",value:function(t){var e=this.measures;this.discreteDomains=0===t.discreteDomains?0:1,e.paddings.top=36,e.paddings.bottom=0,e.legendHeight=24,e.baseHeight=12*ce+o(e);var i=this.data,n=this.discreteDomains?12:0;this.independentWidth=12*(st(i.start,i.end)+n)+l(e)}},{key:"updateWidth",value:function(){var t=this.discreteDomains?12:0,e=this.state.noOfWeeks?this.state.noOfWeeks:52;this.baseWidth=12*(e+t)+l(this.measures)}},{key:"prepareData",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data;if(t.start&&t.end&&t.start>t.end)throw new Error("Start date cannot be greater than end date.");if(t.start||(t.start=new Date,t.start.setFullYear(t.start.getFullYear()-1)),t.end||(t.end=new Date),t.dataPoints=t.dataPoints||{},parseInt(Object.keys(t.dataPoints)[0])>1e5){var e={};Object.keys(t.dataPoints).forEach(function(i){var n=new Date(i*de);e[nt(n)]=t.dataPoints[i]}),t.dataPoints=e}return t}},{key:"calc",value:function(){var t=this.state;t.start=at(this.data.start),t.end=at(this.data.end),t.firstWeekStart=at(t.start),t.noOfWeeks=st(t.start,t.end),t.distribution=wt(Object.values(this.data.dataPoints),5),t.domainConfigs=this.getDomains()}},{key:"setupComponents",value:function(){var t=this,e=this.state,i=this.discreteDomains?0:1,n=e.domainConfigs.map(function(n,a){return["heatDomain",{index:n.index,colWidth:12,rowHeight:12,squareSize:10,xTranslate:12*e.domainConfigs.filter(function(t,e){return e1&&void 0!==arguments[1]?arguments[1]:"",i=[t.getMonth(),t.getFullYear()],n=i[0],a=i[1],s=ht(t),r={index:n,cols:[]};ct(e=at(e)||ut(n,a),1);for(var o=st(s,e),l=[],u=void 0,h=0;h2&&void 0!==arguments[2]&&arguments[2],n=this.state,a=at(t),s=[],r=0;r=n.start&&a<=n.end;i||a.getMonth()!==e||!l?o.yyyyMmDd=nt(a):o=this.getSubDomainConfig(a),s.push(o)}return s}},{key:"getSubDomainConfig",value:function(t){var e=nt(t),i=this.data.dataPoints[e];return{yyyyMmDd:e,dataValue:i||0,fill:this.colors[At(i,this.state.distribution)]}}}]),e}(ue),ke=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.barOptions=e.barOptions||{},n.lineOptions=e.lineOptions||{},n.init=1,n.setup(),n}return Et(i,t),Mt(i,[{key:"setMeasures",value:function(){this.data.datasets.length<=1&&(this.config.showLegend=0,this.measures.paddings.bottom=30)}},{key:"configure",value:function(t){Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),t.axisOptions=t.axisOptions||{},t.tooltipOptions=t.tooltipOptions||{},this.config.xAxisMode=t.axisOptions.xAxisMode||"span",this.config.yAxisMode=t.axisOptions.yAxisMode||"span",this.config.xIsSeries=t.axisOptions.xIsSeries||0,this.config.formatTooltipX=t.tooltipOptions.formatTooltipX,this.config.formatTooltipY=t.tooltipOptions.formatTooltipY,this.config.valuesOverPoints=t.valuesOverPoints}},{key:"prepareData",value:function(){return Pt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data,this.type)}},{key:"prepareFirstData",value:function(){return Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data)}},{key:"calc",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.calcXPositions(),t||this.calcYAxisParameters(this.getAllYValues(),"line"===this.type),this.makeDataByIndex()}},{key:"calcXPositions",value:function(){var t=this.state,e=this.data.labels;t.datasetLength=e.length,t.unitWidth=this.width/t.datasetLength,t.xOffset=t.unitWidth/2,t.xAxis={labels:e,positions:e.map(function(e,i){return u(t.xOffset+i*t.unitWidth)})}}},{key:"calcYAxisParameters",value:function(t){var e=gt(t,arguments.length>1&&void 0!==arguments[1]?arguments[1]:"false"),i=this.height/bt(e),n=mt(e)*i,a=this.height-yt(e)*n;this.state.yAxis={labels:e,positions:e.map(function(t){return a-t*i}),scaleMultiplier:i,zeroLine:a},this.calcDatasetPoints(),this.calcYExtremes(),this.calcYRegions()}},{key:"calcDatasetPoints",value:function(){var t=this.state,e=function(e){return e.map(function(e){return xt(e,t.yAxis)})};t.datasets=this.data.datasets.map(function(t,i){var n=t.values,a=t.cumulativeYs||[];return{name:t.name,index:i,chartType:t.chartType,values:n,yPositions:e(n),cumulativeYs:a,cumulativeYPos:e(a)}})}},{key:"calcYExtremes",value:function(){var t=this.state;if(this.barOptions.stacked)return void(t.yExtremes=t.datasets[t.datasets.length-1].cumulativeYPos);t.yExtremes=new Array(t.datasetLength).fill(9999),t.datasets.map(function(e){e.yPositions.map(function(e,i){es(n)?t.mapTooltipXPosition(o):t.tip.hideTip()})}},{key:"mapTooltipXPosition",value:function(t){var e=this.state;if(e.yExtremes){var i=kt(t,e.xAxis.positions,!0),n=this.dataByIndex[i];this.tip.setValues(n.xPos+this.tip.offset.x,n.yExtreme+this.tip.offset.y,{name:n.formattedLabel,value:""},n.values,i),this.tip.showTip()}}},{key:"renderLegend",value:function(){var t=this,e=this.data;e.datasets.length>1&&(this.legendArea.textContent="",e.datasets.map(function(e,i){var n=M(100*i,"0",100,t.colors[i],e.name);t.legendArea.appendChild(n)}))}},{key:"makeOverlay",value:function(){var t=this;if(this.init)return void(this.init=0);this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)}),this.overlayGuides=this.dataUnitComponents.map(function(t){return{type:t.unitType,overlay:void 0,units:t.units}}),void 0===this.state.currentIndex&&(this.state.currentIndex=this.state.datasetLength-1),this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];e.overlay=Zt[e.type](i),t.drawArea.appendChild(e.overlay)})}},{key:"updateOverlayGuides",value:function(){this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)})}},{key:"bindOverlay",value:function(){var t=this;this.parent.addEventListener("data-select",function(){t.updateOverlay()})}},{key:"bindUnits",value:function(){var t=this;this.dataUnitComponents.map(function(e){e.units.map(function(e){e.addEventListener("click",function(){var i=e.getAttribute("data-point-index");t.setCurrentDataPoint(i)})})}),this.tip.container.addEventListener("click",function(){var e=t.tip.container.getAttribute("data-point-index");t.setCurrentDataPoint(e)})}},{key:"updateOverlay",value:function(){var t=this;this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];te[e.type](i,e.overlay)})}},{key:"onLeftArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex-1)}},{key:"onRightArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex+1)}},{key:"getDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.currentIndex,e=this.state;return{index:t,label:e.xAxis.labels[t],values:e.datasets.map(function(e){return e.values[t]})}}},{key:"setCurrentDataPoint",value:function(t){var e=this.state;(t=parseInt(t))<0&&(t=0),t>=e.xAxis.labels.length&&(t=e.xAxis.labels.length-1),t!==e.currentIndex&&(e.currentIndex=t,a(this.parent,"data-select",this.getDataPoint()))}},{key:"addDataPoint",value:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.state.datasetLength;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"addDataPoint",this).call(this,t,e,n),this.data.labels.splice(n,0,t),this.data.datasets.map(function(t,i){t.values.splice(n,0,e[i])}),this.update(this.data)}},{key:"removeDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.datasetLength-1;this.data.labels.length<=1||(Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"removeDataPoint",this).call(this,t),this.data.labels.splice(t,1),this.data.datasets.map(function(e){e.values.splice(t,1)}),this.update(this.data))}},{key:"updateDataset",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;this.data.datasets[e].values=t,this.update(this.data)}},{key:"updateDatasets",value:function(t){this.data.datasets.map(function(e,i){t[i]&&(e.values=t[i])}),this.update(this.data)}}]),i}(ue),we={bar:ke,line:ke,percentage:me,heatmap:xe,pie:be},Ae=function t(e,i){return Ot(this,t),Tt(i.type,e,i)},Pe=Object.freeze({Chart:Ae,PercentageChart:me,PieChart:be,Heatmap:xe,AxisChart:ke}),Ce={};return Ce.NAME="Frappe Charts",Ce.VERSION="1.1.0",Ce=Object.assign({},Ce,Pe)}();
+var frappe=function(){"use strict";function t(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function e(t){var e=t.getBoundingClientRect();return{top:e.top+(document.documentElement.scrollTop||document.body.scrollTop),left:e.left+(document.documentElement.scrollLeft||document.body.scrollLeft)}}function i(t){var e=t.getBoundingClientRect();return e.top>=0&&e.left>=0&&e.bottom<=(window.innerHeight||document.documentElement.clientHeight)&&e.right<=(window.innerWidth||document.documentElement.clientWidth)}function n(t){var e=window.getComputedStyle(t),i=parseFloat(e.paddingLeft)+parseFloat(e.paddingRight);return t.clientWidth-i}function a(t,e,i){var n=document.createEvent("HTMLEvents");n.initEvent(e,!0,!0);for(var a in i)n[a]=i[a];return t.dispatchEvent(n)}function s(t){return t.titleHeight+t.margins.top+t.paddings.top}function r(t){return t.margins.left+t.paddings.left}function o(t){return t.margins.top+t.margins.bottom+t.paddings.top+t.paddings.bottom+t.titleHeight+t.legendHeight}function l(t){return t.margins.left+t.margins.right+t.paddings.left+t.paddings.right}function u(t){return parseFloat(t.toFixed(2))}function h(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]&&arguments[3];i||(i=n?t[0]:t[t.length-1]);var a=new Array(Math.abs(e)).fill(i);return t=n?a.concat(t):t.concat(a)}function c(t,e){return(t+"").length*e}function d(t,e){return{x:Math.sin(t*Bt)*e,y:Math.cos(t*Bt)*e}}function p(t,e){var i=void 0,n=void 0;return t<=e?(i=e-t,n=t):(i=t-e,n=e),[i,n]}function f(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length-t.length;return i>0?t=h(t,i):e=h(e,i),[t,e]}function v(t){return t>255?255:t<0?0:t}function g(t,e){var i=qt(t),n=!1;"#"==i[0]&&(i=i.slice(1),n=!0);var a=parseInt(i,16),s=v((a>>16)+e),r=v((a>>8&255)+e),o=v((255&a)+e);return(n?"#":"")+(o|r<<8|s<<16).toString(16)}function y(t){return/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(t)}function m(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function b(t,e){var i=document.createElementNS("http://www.w3.org/2000/svg",t);for(var n in e){var a=e[n];if("inside"===n)m(a).appendChild(i);else if("around"===n){var s=m(a);s.parentNode.insertBefore(i,s),i.appendChild(s)}else"styles"===n?"object"===(void 0===a?"undefined":Dt(a))&&Object.keys(a).map(function(t){i.style[t]=a[t]}):("className"===n&&(n="class"),"innerHTML"===n?i.textContent=a:i.setAttribute(n,a))}return i}function x(t,e){return b("linearGradient",{inside:t,id:e,x1:0,x2:0,y1:0,y2:1})}function k(t,e,i,n){return b("stop",{inside:t,style:"stop-color: "+i,offset:e,"stop-opacity":n})}function w(t,e,i,n){return b("svg",{className:e,inside:t,width:i,height:n})}function A(t){return b("defs",{inside:t})}function P(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,n={className:t,transform:e};return i&&(n.inside=i),b("g",n)}function C(t){return b("path",{className:arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",d:t,styles:{stroke:arguments.length>2&&void 0!==arguments[2]?arguments[2]:"none",fill:arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none"}})}function L(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=i.x+t.x,r=i.y+t.y,o=i.x+e.x,l=i.y+e.y;return"M"+i.x+" "+i.y+"\n\t\tL"+s+" "+r+"\n\t\tA "+n+" "+n+" 0 0 "+(a?1:0)+"\n\t\t"+o+" "+l+" z"}function T(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n="path-fill-gradient-"+e+"-"+(i?"lighter":"default"),a=x(t,n),s=[1,.6,.2];return i&&(s=[.4,.2,0]),k(a,"0%",e,s[0]),k(a,"50%",e,s[1]),k(a,"100%",e,s[2]),n}function D(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:It,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"none";return b("rect",{className:"percentage-bar",x:t,y:e,width:i,height:n,fill:s,styles:{stroke:g(s,-25),"stroke-dasharray":"0, "+(n+i)+", "+i+", "+n,"stroke-width":a}})}function O(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"none",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},r={className:t,x:e,y:i,width:n,height:n,fill:a};return Object.keys(s).map(function(t){r[t]=s[t]}),b("rect",r)}function M(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4],s={className:"legend-bar",x:0,y:0,width:i,height:"2px",fill:n},r=b("text",{className:"legend-dataset-text",x:0,y:0,dy:2*Kt+"px","font-size":1.2*Kt+"px","text-anchor":"start",fill:Qt,innerHTML:a}),o=b("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(b("rect",s)),o.appendChild(r),o}function N(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4],s={className:"legend-dot",cx:0,cy:0,r:i,fill:n},r=b("text",{className:"legend-dataset-text",x:0,y:0,dx:Kt+"px",dy:Kt/3+"px","font-size":1.2*Kt+"px","text-anchor":"start",fill:Qt,innerHTML:a}),o=b("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(b("circle",s)),o.appendChild(r),o}function E(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=a.fontSize||Kt;return b("text",{className:t,x:e,y:i,dy:(void 0!==a.dy?a.dy:s/2)+"px","font-size":s+"px",fill:a.fill||Qt,"text-anchor":a.textAnchor||"start",innerHTML:n})}function S(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=$t);var s=b("line",{className:"line-vertical "+a.className,x1:0,x2:0,y1:i,y2:n,styles:{stroke:a.stroke}}),r=b("text",{x:0,y:i>n?i+Jt:i-Jt-Kt,dy:Kt+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:e+""}),o=b("g",{transform:"translate("+t+", 0)"});return o.appendChild(s),o.appendChild(r),o}function _(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=$t),a.lineType||(a.lineType="");var s=b("line",{className:"line-horizontal "+a.className+("dashed"===a.lineType?"dashed":""),x1:i,x2:n,y1:0,y2:0,styles:{stroke:a.stroke}}),r=b("text",{x:i3&&void 0!==arguments[3]?arguments[3]:{};n.pos||(n.pos="left"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=$t),n.className||(n.className="");var a=-1*Xt,s="span"===n.mode?i+Xt:0;return"tick"===n.mode&&"right"===n.pos&&(a=i+Xt,s=i),a+=n.offset,s+=n.offset,_(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType})}function H(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};n.pos||(n.pos="bottom"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=$t),n.className||(n.className="");var a=i+Xt,s="span"===n.mode?-1*Xt:i;return"tick"===n.mode&&"top"===n.pos&&(a=-1*Xt,s=0),S(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType})}function F(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};n.labelPos||(n.labelPos="right");var a=b("text",{className:"chart-label",x:"left"===n.labelPos?Jt:i-c(e,5)-Jt,y:0,dy:Kt/-2+"px","font-size":Kt+"px","text-anchor":"start",innerHTML:e+""}),s=_(t,"",0,i,{stroke:n.stroke||$t,className:n.className||"",lineType:n.lineType});return s.appendChild(a),s}function j(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=t-e,r=b("rect",{className:"bar mini",styles:{fill:"rgba(228, 234, 239, 0.49)",stroke:$t,"stroke-dasharray":i+", "+s},x:0,y:0,width:i,height:s});a.labelPos||(a.labelPos="right");var o=b("text",{className:"chart-label",x:"left"===a.labelPos?Jt:i-c(n+"",4.5)-Jt,y:0,dy:Kt/-2+"px","font-size":Kt+"px","text-anchor":"start",innerHTML:n+""}),l=b("g",{transform:"translate(0, "+e+")"});return l.appendChild(r),l.appendChild(o),l}function W(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,o=arguments.length>7&&void 0!==arguments[7]?arguments[7]:{},l=p(e,o.zeroLine),u=_t(l,2),h=u[0],c=u[1];c-=r,0===h&&(h=o.minHeight,c-=o.minHeight);var d=b("rect",{className:"bar mini",style:"fill: "+n,"data-point-index":s,x:t,y:c,width:i,height:h});if((a+="")||a.length){d.setAttribute("y",0),d.setAttribute("x",0);var f=b("text",{className:"data-point-value",x:i/2,y:0,dy:Kt/2*-1+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:a}),v=b("g",{"data-point-index":s,transform:"translate("+t+", "+c+")"});return v.appendChild(d),v.appendChild(f),v}return d}function I(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=b("circle",{style:"fill: "+n,"data-point-index":s,cx:t,cy:e,r:i});if((a+="")||a.length){r.setAttribute("cy",0),r.setAttribute("cx",0);var o=b("text",{className:"data-point-value",x:0,y:0,dy:Kt/2*-1-i+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:a}),l=b("g",{"data-point-index":s,transform:"translate("+t+", "+e+")"});return l.appendChild(r),l.appendChild(o),l}return r}function R(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=e.map(function(e,i){return t[i]+","+e}).join("L"),r=C("M"+s,"line-graph-path",i);if(n.heatline){var o=T(a.svgDefs,i);r.style.stroke="url(#"+o+")"}var l={path:r};if(n.areaFill){var u=T(a.svgDefs,i,!0),h="M"+t[0]+","+a.zeroLine+"L"+s+"L"+t.slice(-1)[0]+","+a.zeroLine;l.region=C(h,"region-fill","none","url(#"+u+")")}return l}function Y(t,e,i,n){var a="string"==typeof e?e:e.join(", ");return[t,{transform:i.join(", ")},n,se,"translate",{transform:a}]}function V(t,e,i){return Y(t,[i,0],[e,0],ne)}function B(t,e,i){return Y(t,[0,i],[0,e],ne)}function U(t,e,i,n){var a=e-i,s=t.childNodes[0];return[[s,{height:a,"stroke-dasharray":s.getAttribute("width")+", "+a},ne,se],Y(t,[0,n],[0,i],ne)]}function G(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,s=p(i,(arguments.length>5&&void 0!==arguments[5]?arguments[5]:{}).zeroLine),r=_t(s,2),o=r[0],l=r[1];return l-=a,"rect"!==t.nodeName?[[t.childNodes[0],{width:n,height:o},ee,se],Y(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,l],ne)]:[[t,{width:n,height:o,x:e,y:l},ee,se]]}function q(t,e,i){return"circle"!==t.nodeName?[Y(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,i],ne)]:[[t,{cx:e,cy:i},ee,se]]}function X(t,e,i,n){var a=[],s=i.map(function(t,i){return e[i]+","+t}).join("L"),r=[t.path,{d:"M"+s},ie,se];if(a.push(r),t.region){var o=e[0]+","+n+"L",l="L"+e.slice(-1)[0]+", "+n,u=[t.region,{d:"M"+o+s+l},ie,se];a.push(u)}return a}function J(t,e){return[t,{d:e},ee,se]}function K(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"linear",a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:void 0,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},r=t.cloneNode(!0),o=t.cloneNode(!0);for(var l in e){var u=void 0;u="transform"===l?document.createElementNS("http://www.w3.org/2000/svg","animateTransform"):document.createElementNS("http://www.w3.org/2000/svg","animate");var h=s[l]||t.getAttribute(l),c=e[l],d={attributeName:l,from:h,to:c,begin:"0s",dur:i/1e3+"s",values:h+";"+c,keySplines:re[n],keyTimes:"0;1",calcMode:"spline",fill:"freeze"};a&&(d.type=a);for(var p in d)u.setAttribute(p,d[p]);r.appendChild(u),a?o.setAttribute(l,"translate("+c+")"):o.setAttribute(l,c)}return[r,o]}function $(t,e){t.style.transform=e,t.style.webkitTransform=e,t.style.msTransform=e,t.style.mozTransform=e,t.style.oTransform=e}function Q(t,e){var i=[],n=[];e.map(function(t){var e=t[0],a=e.parentNode,s=void 0,r=void 0;t[0]=e;var o=K.apply(void 0,zt(t)),l=_t(o,2);s=l[0],r=l[1],i.push(r),n.push([s,a]),a.replaceChild(s,e)});var a=t.cloneNode(!0);return n.map(function(t,n){t[1].replaceChild(i[n],t[0]),e[n][0]=i[n]}),a}function Z(t,e,i){if(0!==i.length){var n=Q(e,i);e.parentNode==t&&(t.removeChild(e),t.appendChild(n)),setTimeout(function(){n.parentNode==t&&(t.removeChild(n),t.appendChild(e))},ae)}}function tt(t,e){var i=document.createElement("a");i.style="display: none";var n=new Blob(e,{type:"image/svg+xml; charset=utf-8"}),a=window.URL.createObjectURL(n);i.href=a,i.download=t,document.body.appendChild(i),i.click(),setTimeout(function(){document.body.removeChild(i),window.URL.revokeObjectURL(a)},300)}function et(e){var i=e.cloneNode(!0);i.classList.add("chart-container"),i.setAttribute("xmlns","http://www.w3.org/2000/svg"),i.setAttribute("xmlns:xlink","http://www.w3.org/1999/xlink");var n=t.create("style",{innerHTML:oe});i.insertBefore(n,i.firstChild);var a=t.create("div");return a.appendChild(i),a.innerHTML}function it(t){var e=new Date(t);return e.setMinutes(e.getMinutes()-e.getTimezoneOffset()),e}function nt(t){var e=t.getDate(),i=t.getMonth()+1;return[t.getFullYear(),(i>9?"":"0")+i,(e>9?"":"0")+e].join("-")}function at(t){return new Date(t.getTime())}function st(t,e){var i=ht(t);return Math.ceil(rt(i,e)/ce)}function rt(t,e){var i=pe*de;return(it(e)-it(t))/i}function ot(t,e){return t.getMonth()===e.getMonth()&&t.getFullYear()===e.getFullYear()}function lt(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1],i=fe[t];return e?i.slice(0,3):i}function ut(t,e){return new Date(e,t+1,0)}function ht(t){var e=at(t),i=e.getDay();return 0!==i&&ct(e,-1*i),e}function ct(t,e){t.setDate(t.getDate()+e)}function dt(t,e,i){var n=Object.keys(ye).filter(function(e){return t.includes(e)}),a=ye[n[0]];return Object.assign(a,{constants:e,getData:i}),new ge(a)}function pt(t){if(0===t)return[0,0];if(isNaN(t))return{mantissa:-6755399441055744,exponent:972};var e=t>0?1:-1;if(!isFinite(t))return{mantissa:4503599627370496*e,exponent:972};t=Math.abs(t);var i=Math.floor(Math.log10(t));return[e*(t/Math.pow(10,i)),i]}function ft(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=Math.ceil(t),n=Math.floor(e),a=i-n,s=a,r=1;a>5&&(a%2!=0&&(a=++i-n),s=a/2,r=2),a<=2&&(r=a/(s=4)),0===a&&(s=5,r=1);for(var o=[],l=0;l<=s;l++)o.push(n+r*l);return o}function vt(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=pt(t),n=_t(i,2),a=n[0],s=n[1],r=e?e/Math.pow(10,s):0,o=ft(a=a.toFixed(6),r);return o=o.map(function(t){return t*Math.pow(10,s)})}function gt(t){function e(t,e){for(var i=vt(t),n=i[1]-i[0],a=0,s=1;a1&&void 0!==arguments[1]&&arguments[1],n=Math.max.apply(Math,zt(t)),a=Math.min.apply(Math,zt(t)),s=[];if(n>=0&&a>=0)pt(n)[1],s=i?vt(n,a):vt(n);else if(n>0&&a<0){var r=Math.abs(a);n>=r?(pt(n)[1],s=e(n,r)):(pt(r)[1],s=e(r,n).map(function(t){return-1*t}))}else if(n<=0&&a<=0){var o=Math.abs(a),l=Math.abs(n);pt(o)[1],s=(s=i?vt(o,l):vt(o)).reverse().map(function(t){return-1*t})}return s}function yt(t){var e=mt(t);return t.indexOf(0)>=0?t.indexOf(0):t[0]>0?-1*t[0]/e:-1*t[t.length-1]/e+(t.length-1)}function mt(t){return t[1]-t[0]}function bt(t){return t[t.length-1]-t[0]}function xt(t,e){return u(e.zeroLine-t*e.scaleMultiplier)}function kt(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n=e.reduce(function(e,i){return Math.abs(i-t)i?e.slice(0,i):h(e,i-e.length,0)}else t.values=a;s?t.chartType=s:t.chartType||(t.chartType=jt)}),t.yRegions&&t.yRegions.map(function(t){if(t.end1&&void 0!==arguments[1]?arguments[1]:[],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=t/e.length;n<=0&&(n=1);var a=n/Rt;return e.map(function(t,e){return(t+="").length>a&&(i?e%Math.ceil(t.length/a)!=0&&(t=""):t=a-3>0?t.slice(0,a-3)+" ...":t.slice(0,a)+".."),t})}function Tt(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"line",e=arguments[1],i=arguments[2];return"axis-mixed"===t?(i.type="line",new ke(e,i)):we[t]?new we[t](e,i):void console.error("Undefined chart type: "+t)}!function(t,e){void 0===e&&(e={});var i=e.insertAt;if(t&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css","top"===i&&n.firstChild?n.insertBefore(a,n.firstChild):n.appendChild(a),a.styleSheet?a.styleSheet.cssText=t:a.appendChild(document.createTextNode(t))}}('.chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:1;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ol,.graph-svg-tip ul{padding-left:0;display:-webkit-box;display:-ms-flexbox;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:" ";border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}',{});var Dt="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},Ot=(function(){function t(t){this.value=t}function e(e){function i(t,e){return new Promise(function(i,a){var o={key:t,arg:e,resolve:i,reject:a,next:null};r?r=r.next=o:(s=r=o,n(t,e))})}function n(i,s){try{var r=e[i](s),o=r.value;o instanceof t?Promise.resolve(o.value).then(function(t){n("next",t)},function(t){n("throw",t)}):a(r.done?"return":"normal",r.value)}catch(t){a("throw",t)}}function a(t,e){switch(t){case"return":s.resolve({value:e,done:!0});break;case"throw":s.reject(e);break;default:s.resolve({value:e,done:!1})}(s=s.next)?n(s.key,s.arg):r=null}var s,r;this._invoke=i,"function"!=typeof e.return&&(this.return=void 0)}"function"==typeof Symbol&&Symbol.asyncIterator&&(e.prototype[Symbol.asyncIterator]=function(){return this}),e.prototype.next=function(t){return this._invoke("next",t)},e.prototype.throw=function(t){return this._invoke("throw",t)},e.prototype.return=function(t){return this._invoke("return",t)}}(),function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}),Mt=function(){function t(t,e){for(var i=0;i\n\t\t\t\t\n\t\t\t\t'}),this.hideTip(),this.title=this.container.querySelector(".title"),this.dataPointList=this.container.querySelector(".data-point-list"),this.parent.addEventListener("mouseleave",function(){e.hideTip()})}},{key:"fill",value:function(){var e=this,i=void 0;this.index&&this.container.setAttribute("data-point-index",this.index),i=this.titleValueFirst?""+this.titleValue+""+this.titleName:this.titleName+""+this.titleValue+"",this.title.innerHTML=i,this.dataPointList.innerHTML="",this.listValues.map(function(i,n){var a=e.colors[n]||"black",s=0===i.formatted||i.formatted?i.formatted:i.value,r=t.create("li",{styles:{"border-top":"3px solid "+a},innerHTML:''+(0===s||s?s:"")+"\n\t\t\t\t\t"+(i.title?i.title:"")});e.dataPointList.appendChild(r)})}},{key:"calcPosition",value:function(){var t=this.container.offsetWidth;this.top=this.y-this.container.offsetHeight-5,this.left=this.x-t/2;var e=this.parent.offsetWidth-t,i=this.container.querySelector(".svg-pointer");if(this.left<0)i.style.left="calc(50% - "+-1*this.left+"px)",this.left=0;else if(this.left>e){var n="calc(50% + "+(this.left-e)+"px)";i.style.left=n,this.left=e}else i.style.left="50%"}},{key:"setValues",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:-1;this.titleName=i.name,this.titleValue=i.value,this.listValues=n,this.x=t,this.y=e,this.titleValueFirst=i.valueFirst||0,this.index=a,this.refresh()}},{key:"hideTip",value:function(){this.container.style.top="0px",this.container.style.left="0px",this.container.style.opacity="0"}},{key:"showTip",value:function(){this.container.style.top=this.top+"px",this.container.style.left=this.left+"px",this.container.style.opacity="1"}}]),e}(),Gt={"light-blue":"#7cd6fd",blue:"#5e64ff",violet:"#743ee2",red:"#ff5858",orange:"#ffa00a",yellow:"#feef72",green:"#28a745","light-green":"#98d85b",purple:"#b554ff",magenta:"#ffa3ef",black:"#36114C",grey:"#bdd3e6","light-grey":"#f0f4f7","dark-grey":"#b8c2cc"},qt=function(t){return Gt[t]||t},Xt=6,Jt=4,Kt=10,$t="#dadada",Qt="#555b51",Zt={bar:function(t){var e=void 0;"rect"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode();return i.style.fill="#000000",i.style.opacity="0.4",e&&i.setAttribute("transform",e),i},dot:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i},heat_square:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i}},te={bar:function(t,e){var i=void 0;"rect"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["x","y","width","height"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},dot:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},heat_square:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)}},ee=350,ie=350,ne=ee,ae=250,se="easein",re={ease:"0.25 0.1 0.25 1",linear:"0 0 1 1",easein:"0.1 0.8 0.2 1",easeout:"0 0 0.58 1",easeinout:"0.42 0 0.58 1"},oe=".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}",le=void 0,ue=function(){function e(t,i){if(Ot(this,e),this.parent="string"==typeof t?document.querySelector(t):t,!(this.parent instanceof HTMLElement))throw new Error("No `parent` element to render on was provided.");this.rawChartArgs=i,this.title=i.title||"",this.type=i.type||"line",this.realData=this.prepareData(i.data),this.data=this.prepareFirstData(this.realData),this.colors=this.validateColors(i.colors,this.type),this.config={showTooltip:1,showLegend:1,isNavigable:i.isNavigable||0,animate:1},this.measures=JSON.parse(JSON.stringify(Ht));var n=this.measures;this.setMeasures(i),this.title.length||(n.titleHeight=0),this.config.showLegend||(n.legendHeight=0),this.argHeight=i.height||n.baseHeight,this.state={},this.options={},this.initTimeout=Ft,this.config.isNavigable&&(this.overlays=[]),this.configure(i)}return Mt(e,[{key:"prepareData",value:function(t){return t}},{key:"prepareFirstData",value:function(t){return t}},{key:"validateColors",value:function(t,e){var i=[];return(t=(t||[]).concat(Vt[e])).forEach(function(t){var e=qt(t);y(e)?i.push(e):console.warn('"'+t+'" is not a valid color.')}),i}},{key:"setMeasures",value:function(){}},{key:"configure",value:function(){var t=this.argHeight;this.baseHeight=t,this.height=t-o(this.measures),le=this.boundDrawFn.bind(this),window.addEventListener("resize",le),window.addEventListener("orientationchange",this.boundDrawFn.bind(this))}},{key:"boundDrawFn",value:function(){this.draw(!0)}},{key:"unbindWindowEvents",value:function(){window.removeEventListener("resize",le),window.removeEventListener("orientationchange",this.boundDrawFn.bind(this))}},{key:"setup",value:function(){this.makeContainer(),this.updateWidth(),this.makeTooltip(),this.draw(!1,!0)}},{key:"makeContainer",value:function(){this.parent.innerHTML="";var e={inside:this.parent,className:"chart-container"};this.independentWidth&&(e.styles={width:this.independentWidth+"px"},this.parent.style.overflow="auto"),this.container=t.create("div",e)}},{key:"makeTooltip",value:function(){this.tip=new Ut({parent:this.container,colors:this.colors}),this.bindTooltip()}},{key:"bindTooltip",value:function(){}},{key:"draw",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],i=arguments.length>1&&void 0!==arguments[1]&&arguments[1];this.updateWidth(),this.calc(e),this.makeChartArea(),this.setupComponents(),this.components.forEach(function(e){return e.setup(t.drawArea)}),this.render(this.components,!1),i&&(this.data=this.realData,setTimeout(function(){t.update(t.data)},this.initTimeout)),this.renderLegend(),this.setupNavigation(i)}},{key:"calc",value:function(){}},{key:"updateWidth",value:function(){this.baseWidth=n(this.parent),this.width=this.baseWidth-l(this.measures)}},{key:"makeChartArea",value:function(){this.svg&&this.container.removeChild(this.svg);var t=this.measures;this.svg=w(this.container,"frappe-chart chart",this.baseWidth,this.baseHeight),this.svgDefs=A(this.svg),this.title.length&&(this.titleEL=E("title",t.margins.left,t.margins.top,this.title,{fontSize:t.titleFontSize,fill:"#666666",dy:t.titleFontSize}));var e=s(t);this.drawArea=P(this.type+"-chart chart-draw-area","translate("+r(t)+", "+e+")"),this.config.showLegend&&(e+=this.height+t.paddings.bottom,this.legendArea=P("chart-legend","translate("+r(t)+", "+e+")")),this.title.length&&this.svg.appendChild(this.titleEL),this.svg.appendChild(this.drawArea),this.config.showLegend&&this.svg.appendChild(this.legendArea),this.updateTipOffset(r(t),s(t))}},{key:"updateTipOffset",value:function(t,e){this.tip.offset={x:t,y:e}}},{key:"setupComponents",value:function(){this.components=new Map}},{key:"update",value:function(t){t||console.error("No data to update."),this.data=this.prepareData(t),this.calc(),this.render()}},{key:"render",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.components,i=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.config.isNavigable&&this.overlays.map(function(t){return t.parentNode.removeChild(t)});var n=[];e.forEach(function(t){n=n.concat(t.update(i))}),n.length>0?(Z(this.container,this.svg,n),setTimeout(function(){e.forEach(function(t){return t.make()}),t.updateNav()},400)):(e.forEach(function(t){return t.make()}),this.updateNav())}},{key:"updateNav",value:function(){this.config.isNavigable&&(this.makeOverlay(),this.bindUnits())}},{key:"renderLegend",value:function(){}},{key:"setupNavigation",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.config.isNavigable&&e&&(this.bindOverlay(),this.keyActions={13:this.onEnterKey.bind(this),37:this.onLeftArrow.bind(this),38:this.onUpArrow.bind(this),39:this.onRightArrow.bind(this),40:this.onDownArrow.bind(this)},document.addEventListener("keydown",function(e){i(t.container)&&(e=e||window.event,t.keyActions[e.keyCode]&&t.keyActions[e.keyCode]())}))}},{key:"makeOverlay",value:function(){}},{key:"updateOverlay",value:function(){}},{key:"bindOverlay",value:function(){}},{key:"bindUnits",value:function(){}},{key:"onLeftArrow",value:function(){}},{key:"onRightArrow",value:function(){}},{key:"onUpArrow",value:function(){}},{key:"onDownArrow",value:function(){}},{key:"onEnterKey",value:function(){}},{key:"addDataPoint",value:function(){}},{key:"removeDataPoint",value:function(){}},{key:"getDataPoint",value:function(){}},{key:"setCurrentDataPoint",value:function(){}},{key:"updateDataset",value:function(){}},{key:"export",value:function(){var t=et(this.svg);tt(this.title||"Chart",[t])}}]),e}(),he=function(t){function e(t,i){return Ot(this,e),St(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i))}return Et(e,t),Mt(e,[{key:"configure",value:function(t){Nt(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"configure",this).call(this,t),this.config.maxSlices=t.maxSlices||20,this.config.maxLegendPoints=t.maxLegendPoints||20}},{key:"calc",value:function(){var t=this,e=this.state,i=this.config.maxSlices;e.sliceTotals=[];var n=this.data.labels.map(function(e,i){var n=0;return t.data.datasets.map(function(t){n+=t.values[i]}),[n,e]}).filter(function(t){return t[0]>=0}),a=n;if(n.length>i){n.sort(function(t,e){return e[0]-t[0]}),a=n.slice(0,i-1);var s=0;n.slice(i-1).map(function(t){s+=t[0]}),a.push([s,"Rest"]),this.colors[i-1]="grey"}e.labels=[],a.map(function(t){e.sliceTotals.push(t[0]),e.labels.push(t[1])}),e.grandTotal=e.sliceTotals.reduce(function(t,e){return t+e},0),this.center={x:this.width/2,y:this.height/2}}},{key:"renderLegend",value:function(){var t=this,e=this.state;this.legendArea.textContent="",this.legendTotals=e.sliceTotals.slice(0,this.config.maxLegendPoints);var i=0,n=0;this.legendTotals.map(function(a,s){var r=Math.floor((t.width-l(t.measures))/110);i>r&&(i=0,n+=20);var o=N(110*i+5,n,5,t.colors[s],e.labels[s]+": "+a);t.legendArea.appendChild(o),i++})}}]),e}(ue),ce=7,de=1e3,pe=86400,fe=["January","February","March","April","May","June","July","August","September","October","November","December"],ve=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],ge=function(){function t(e){var i=e.layerClass,n=void 0===i?"":i,a=e.layerTransform,s=void 0===a?"":a,r=e.constants,o=e.getData,l=e.makeElements,u=e.animateElements;Ot(this,t),this.layerTransform=s,this.constants=r,this.makeElements=l,this.getData=o,this.animateElements=u,this.store=[],this.labels=[],this.layerClass=n,this.layerClass="function"==typeof this.layerClass?this.layerClass():this.layerClass,this.refresh()}return Mt(t,[{key:"refresh",value:function(t){this.data=t||this.getData()}},{key:"setup",value:function(t){this.layer=P(this.layerClass,this.layerTransform,t)}},{key:"make",value:function(){this.render(this.data),this.oldData=this.data}},{key:"render",value:function(t){var e=this;this.store=this.makeElements(t),this.layer.textContent="",this.store.forEach(function(t){e.layer.appendChild(t)}),this.labels.forEach(function(t){e.layer.appendChild(t)})}},{key:"update",value:function(){var t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];this.refresh();var e=[];return t&&(e=this.animateElements(this.data)||[]),e}}]),t}(),ye={pieSlices:{layerClass:"pie-slices",makeElements:function(t){return t.sliceStrings.map(function(e,i){var n=C(e,"pie-path","none",t.colors[i]);return n.style.transition="transform .3s;",n})},animateElements:function(t){return this.store.map(function(e,i){return J(e,t.sliceStrings[i])})}},percentageBars:{layerClass:"percentage-bars",makeElements:function(t){var e=this;return t.xPositions.map(function(i,n){return D(i,0,t.widths[n],e.constants.barHeight,e.constants.barDepth,t.colors[n])})},animateElements:function(t){if(t)return[]}},yAxis:{layerClass:"y axis",makeElements:function(t){var e=this;return t.positions.map(function(i,n){return z(i,t.labels[n],e.constants.width,{mode:e.constants.mode,pos:e.constants.pos})})},animateElements:function(t){var e=t.positions,i=t.labels,n=this.oldData.positions,a=this.oldData.labels,s=f(n,e),r=_t(s,2);n=r[0],e=r[1];var o=f(a,i),l=_t(o,2);return a=l[0],i=l[1],this.render({positions:n,labels:i}),this.store.map(function(t,i){return B(t,e[i],n[i])})}},xAxis:{layerClass:"x axis",makeElements:function(t){var e=this;return t.positions.map(function(i,n){return H(i,t.calcLabels[n],e.constants.height,{mode:e.constants.mode,pos:e.constants.pos})})},animateElements:function(t){var e=t.positions,i=t.calcLabels,n=this.oldData.positions,a=this.oldData.calcLabels,s=f(n,e),r=_t(s,2);n=r[0],e=r[1];var o=f(a,i),l=_t(o,2);return a=l[0],i=l[1],this.render({positions:n,calcLabels:i}),this.store.map(function(t,i){return V(t,e[i],n[i])})}},yMarkers:{layerClass:"y-markers",makeElements:function(t){var e=this;return t.map(function(t){return F(t.position,t.label,e.constants.width,{labelPos:t.options.labelPos,mode:"span",lineType:"dashed"})})},animateElements:function(t){var e=f(this.oldData,t),i=_t(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.position}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.options}),r=this.oldData.map(function(t){return t.position});return this.render(r.map(function(t,e){return{position:r[e],label:a[e],options:s[e]}})),this.store.map(function(t,e){return B(t,n[e],r[e])})}},yRegions:{layerClass:"y-regions",makeElements:function(t){var e=this;return t.map(function(t){return j(t.startPos,t.endPos,e.constants.width,t.label,{labelPos:t.options.labelPos})})},animateElements:function(t){var e=f(this.oldData,t),i=_t(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.endPos}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.startPos}),r=t.map(function(t){return t.options}),o=this.oldData.map(function(t){return t.endPos}),l=this.oldData.map(function(t){return t.startPos});this.render(o.map(function(t,e){return{startPos:l[e],endPos:o[e],label:a[e],options:r[e]}}));var u=[];return this.store.map(function(t,e){u=u.concat(U(t,s[e],n[e],o[e]))}),u}},heatDomain:{layerClass:function(){return"heat-domain domain-"+this.constants.index},makeElements:function(t){var e=this,i=this.constants,n=i.index,a=i.colWidth,s=i.rowHeight,r=i.squareSize,o=i.xTranslate,l=0;return this.serializedSubDomains=[],t.cols.map(function(t,i){1===i&&e.labels.push(E("domain-name",o,-12,lt(n,!0).toUpperCase(),{fontSize:9})),t.map(function(t,i){if(t.fill){var n={"data-date":t.yyyyMmDd,"data-value":t.dataValue,"data-day":i},a=O("day",o,l,r,t.fill,n);e.serializedSubDomains.push(a)}l+=s}),l=0,o+=a}),this.serializedSubDomains},animateElements:function(t){if(t)return[]}},barGraph:{layerClass:function(){return"dataset-units dataset-bars dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="bar",this.units=t.yPositions.map(function(i,n){return W(t.xPositions[n],i,t.barWidth,e.color,t.labels[n],n,t.offsets[n],{zeroLine:t.zeroLine,barsWidth:t.barsWidth,minHeight:e.minHeight})}),this.units},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.offsets,a=t.labels,s=this.oldData.xPositions,r=this.oldData.yPositions,o=this.oldData.offsets,l=this.oldData.labels,u=f(s,e),h=_t(u,2);s=h[0],e=h[1];var c=f(r,i),d=_t(c,2);r=d[0],i=d[1];var p=f(o,n),v=_t(p,2);o=v[0],n=v[1];var g=f(l,a),y=_t(g,2);l=y[0],a=y[1],this.render({xPositions:s,yPositions:r,offsets:o,labels:a,zeroLine:this.oldData.zeroLine,barsWidth:this.oldData.barsWidth,barWidth:this.oldData.barWidth});var m=[];return this.store.map(function(a,s){m=m.concat(G(a,e[s],i[s],t.barWidth,n[s],{zeroLine:t.zeroLine}))}),m}},lineGraph:{layerClass:function(){return"dataset-units dataset-line dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="dot",this.paths={},e.hideLine||(this.paths=R(t.xPositions,t.yPositions,e.color,{heatline:e.heatline,areaFill:e.areaFill},{svgDefs:e.svgDefs,zeroLine:t.zeroLine})),this.units=[],e.hideDots||(this.units=t.yPositions.map(function(i,n){return I(t.xPositions[n],i,t.radius,e.color,e.valuesOverPoints?t.values[n]:"",n)})),Object.values(this.paths).concat(this.units)},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.values,a=this.oldData.xPositions,s=this.oldData.yPositions,r=this.oldData.values,o=f(a,e),l=_t(o,2);a=l[0],e=l[1];var u=f(s,i),h=_t(u,2);s=h[0],i=h[1];var c=f(r,n),d=_t(c,2);r=d[0],n=d[1],this.render({xPositions:a,yPositions:s,values:n,zeroLine:this.oldData.zeroLine,radius:this.oldData.radius});var p=[];return Object.keys(this.paths).length&&(p=p.concat(X(this.paths,e,i,t.zeroLine))),this.units.length&&this.units.map(function(t,n){p=p.concat(q(t,e[n],i[n]))}),p}}},me=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="percentage",n.setup(),n}return Et(i,t),Mt(i,[{key:"setMeasures",value:function(t){var e=this.measures;this.barOptions=t.barOptions||{};var i=this.barOptions;i.height=i.height||20,i.depth=i.depth||It,e.paddings.right=30,e.legendHeight=80,e.baseHeight=8*(i.height+.5*i.depth)}},{key:"setupComponents",value:function(){var t=this.state,e=[["percentageBars",{barHeight:this.barOptions.height,barDepth:this.barOptions.depth},function(){return{xPositions:t.xPositions,widths:t.widths,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=dt.apply(void 0,zt(t));return[t[0],e]}))}},{key:"calc",value:function(){var t=this;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;e.xPositions=[],e.widths=[];var n=0;e.sliceTotals.map(function(i){var a=t.width*i/e.grandTotal;e.widths.push(a),e.xPositions.push(n),n+=a})}},{key:"makeDataByIndex",value:function(){}},{key:"bindTooltip",value:function(){var t=this,i=this.state;this.container.addEventListener("mousemove",function(n){var a=t.components.get("percentageBars").store,s=n.target;if(a.includes(s)){var r=a.indexOf(s),o=e(t.container),l=e(s),u=l.left-o.left+parseInt(s.getAttribute("width"))/2,h=l.top-o.top,c=(t.formattedLabels&&t.formattedLabels.length>0?t.formattedLabels[r]:t.state.labels[r])+": ",d=i.sliceTotals[r]/i.grandTotal;t.tip.setValues(u,h,{name:c,value:(100*d).toFixed(1)+"%"}),t.tip.showTip()}})}}]),i}(he),be=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="pie",n.initTimeout=0,n.init=1,n.setup(),n}return Et(i,t),Mt(i,[{key:"configure",value:function(t){Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),this.mouseMove=this.mouseMove.bind(this),this.mouseLeave=this.mouseLeave.bind(this),this.hoverRadio=t.hoverRadio||.1,this.config.startAngle=t.startAngle||0,this.clockWise=t.clockWise||!1}},{key:"calc",value:function(){var t=this;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;this.radius=this.height>this.width?this.center.x:this.center.y;var n=this.radius,a=this.clockWise,s=e.slicesProperties||[];e.sliceStrings=[],e.slicesProperties=[];var r=180-this.config.startAngle;e.sliceTotals.map(function(i,o){var l=r,u=i/e.grandTotal*360,h=a?-u:u,c=r+=h,p=d(l,n),f=d(c,n),v=t.init&&s[o],g=void 0,y=void 0;t.init?(g=v?v.startPosition:p,y=v?v.endPosition:p):(g=p,y=f);var m=L(g,y,t.center,t.radius,t.clockWise);e.sliceStrings.push(m),e.slicesProperties.push({startPosition:p,endPosition:f,value:i,total:e.grandTotal,startAngle:l,endAngle:c,angle:h})}),this.init=0}},{key:"setupComponents",value:function(){var t=this.state,e=[["pieSlices",{},function(){return{sliceStrings:t.sliceStrings,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=dt.apply(void 0,zt(t));return[t[0],e]}))}},{key:"calTranslateByAngle",value:function(t){var e=this.radius,i=this.hoverRadio,n=d(t.startAngle+t.angle/2,e);return"translate3d("+n.x*i+"px,"+n.y*i+"px,0)"}},{key:"hoverSlice",value:function(t,i,n,a){if(t){var s=this.colors[i];if(n){$(t,this.calTranslateByAngle(this.state.slicesProperties[i])),t.style.fill=g(s,50);var r=e(this.svg),o=a.pageX-r.left+10,l=a.pageY-r.top-10,u=(this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels[i]:this.state.labels[i])+": ",h=(100*this.state.sliceTotals[i]/this.state.grandTotal).toFixed(1);this.tip.setValues(o,l,{name:u,value:h+"%"}),this.tip.showTip()}else $(t,"translate3d(0,0,0)"),this.tip.hideTip(),t.style.fill=s}}},{key:"bindTooltip",value:function(){this.container.addEventListener("mousemove",this.mouseMove),this.container.addEventListener("mouseleave",this.mouseLeave)}},{key:"mouseMove",value:function(t){var e=t.target,i=this.components.get("pieSlices").store,n=this.curActiveSliceIndex,a=this.curActiveSlice;if(i.includes(e)){var s=i.indexOf(e);this.hoverSlice(a,n,!1),this.curActiveSlice=e,this.curActiveSliceIndex=s,this.hoverSlice(e,s,!0,t)}else this.mouseLeave()}},{key:"mouseLeave",value:function(){this.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,!1)}}]),i}(he),xe=function(t){function e(t,i){Ot(this,e);var n=St(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i));n.type="heatmap",n.countLabel=i.countLabel||"";var a=["Sunday","Monday"],s=a.includes(i.startSubDomain)?i.startSubDomain:"Sunday";return n.startSubDomainIndex=a.indexOf(s),n.setup(),n}return Et(e,t),Mt(e,[{key:"setMeasures",value:function(t){var e=this.measures;this.discreteDomains=0===t.discreteDomains?0:1,e.paddings.top=36,e.paddings.bottom=0,e.legendHeight=24,e.baseHeight=12*ce+o(e);var i=this.data,n=this.discreteDomains?12:0;this.independentWidth=12*(st(i.start,i.end)+n)+l(e)}},{key:"updateWidth",value:function(){var t=this.discreteDomains?12:0,e=this.state.noOfWeeks?this.state.noOfWeeks:52;this.baseWidth=12*(e+t)+l(this.measures)}},{key:"prepareData",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data;if(t.start&&t.end&&t.start>t.end)throw new Error("Start date cannot be greater than end date.");if(t.start||(t.start=new Date,t.start.setFullYear(t.start.getFullYear()-1)),t.end||(t.end=new Date),t.dataPoints=t.dataPoints||{},parseInt(Object.keys(t.dataPoints)[0])>1e5){var e={};Object.keys(t.dataPoints).forEach(function(i){var n=new Date(i*de);e[nt(n)]=t.dataPoints[i]}),t.dataPoints=e}return t}},{key:"calc",value:function(){var t=this.state;t.start=at(this.data.start),t.end=at(this.data.end),t.firstWeekStart=at(t.start),t.noOfWeeks=st(t.start,t.end),t.distribution=wt(Object.values(this.data.dataPoints),5),t.domainConfigs=this.getDomains()}},{key:"setupComponents",value:function(){var t=this,e=this.state,i=this.discreteDomains?0:1,n=e.domainConfigs.map(function(n,a){return["heatDomain",{index:n.index,colWidth:12,rowHeight:12,squareSize:10,xTranslate:12*e.domainConfigs.filter(function(t,e){return e1&&void 0!==arguments[1]?arguments[1]:"",i=[t.getMonth(),t.getFullYear()],n=i[0],a=i[1],s=ht(t),r={index:n,cols:[]};ct(e=at(e)||ut(n,a),1);for(var o=st(s,e),l=[],u=void 0,h=0;h2&&void 0!==arguments[2]&&arguments[2],n=this.state,a=at(t),s=[],r=0;r=n.start&&a<=n.end;i||a.getMonth()!==e||!l?o.yyyyMmDd=nt(a):o=this.getSubDomainConfig(a),s.push(o)}return s}},{key:"getSubDomainConfig",value:function(t){var e=nt(t),i=this.data.dataPoints[e];return{yyyyMmDd:e,dataValue:i||0,fill:this.colors[At(i,this.state.distribution)]}}}]),e}(ue),ke=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.barOptions=e.barOptions||{},n.lineOptions=e.lineOptions||{},n.init=1,n.setup(),n}return Et(i,t),Mt(i,[{key:"setMeasures",value:function(){this.data.datasets.length<=1&&(this.config.showLegend=0,this.measures.paddings.bottom=30)}},{key:"configure",value:function(t){Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),t.axisOptions=t.axisOptions||{},t.tooltipOptions=t.tooltipOptions||{},this.config.xAxisMode=t.axisOptions.xAxisMode||"span",this.config.yAxisMode=t.axisOptions.yAxisMode||"span",this.config.xIsSeries=t.axisOptions.xIsSeries||0,this.config.formatTooltipX=t.tooltipOptions.formatTooltipX,this.config.formatTooltipY=t.tooltipOptions.formatTooltipY,this.config.valuesOverPoints=t.valuesOverPoints}},{key:"prepareData",value:function(){return Pt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data,this.type)}},{key:"prepareFirstData",value:function(){return Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data)}},{key:"calc",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.calcXPositions(),t||this.calcYAxisParameters(this.getAllYValues(),"line"===this.type),this.makeDataByIndex()}},{key:"calcXPositions",value:function(){var t=this.state,e=this.data.labels;t.datasetLength=e.length,t.unitWidth=this.width/t.datasetLength,t.xOffset=t.unitWidth/2,t.xAxis={labels:e,positions:e.map(function(e,i){return u(t.xOffset+i*t.unitWidth)})}}},{key:"calcYAxisParameters",value:function(t){var e=gt(t,arguments.length>1&&void 0!==arguments[1]?arguments[1]:"false"),i=this.height/bt(e),n=mt(e)*i,a=this.height-yt(e)*n;this.state.yAxis={labels:e,positions:e.map(function(t){return a-t*i}),scaleMultiplier:i,zeroLine:a},this.calcDatasetPoints(),this.calcYExtremes(),this.calcYRegions()}},{key:"calcDatasetPoints",value:function(){var t=this.state,e=function(e){return e.map(function(e){return xt(e,t.yAxis)})};t.datasets=this.data.datasets.map(function(t,i){var n=t.values,a=t.cumulativeYs||[];return{name:t.name,index:i,chartType:t.chartType,values:n,yPositions:e(n),cumulativeYs:a,cumulativeYPos:e(a)}})}},{key:"calcYExtremes",value:function(){var t=this.state;if(this.barOptions.stacked)return void(t.yExtremes=t.datasets[t.datasets.length-1].cumulativeYPos);t.yExtremes=new Array(t.datasetLength).fill(9999),t.datasets.map(function(e){e.yPositions.map(function(e,i){es(n)?t.mapTooltipXPosition(o):t.tip.hideTip()})}},{key:"mapTooltipXPosition",value:function(t){var e=this.state;if(e.yExtremes){var i=kt(t,e.xAxis.positions,!0),n=this.dataByIndex[i];this.tip.setValues(n.xPos+this.tip.offset.x,n.yExtreme+this.tip.offset.y,{name:n.formattedLabel,value:""},n.values,i),this.tip.showTip()}}},{key:"renderLegend",value:function(){var t=this,e=this.data;e.datasets.length>1&&(this.legendArea.textContent="",e.datasets.map(function(e,i){var n=M(100*i,"0",100,t.colors[i],e.name);t.legendArea.appendChild(n)}))}},{key:"makeOverlay",value:function(){var t=this;if(this.init)return void(this.init=0);this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)}),this.overlayGuides=this.dataUnitComponents.map(function(t){return{type:t.unitType,overlay:void 0,units:t.units}}),void 0===this.state.currentIndex&&(this.state.currentIndex=this.state.datasetLength-1),this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];e.overlay=Zt[e.type](i),t.drawArea.appendChild(e.overlay)})}},{key:"updateOverlayGuides",value:function(){this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)})}},{key:"bindOverlay",value:function(){var t=this;this.parent.addEventListener("data-select",function(){t.updateOverlay()})}},{key:"bindUnits",value:function(){var t=this;this.dataUnitComponents.map(function(e){e.units.map(function(e){e.addEventListener("click",function(){var i=e.getAttribute("data-point-index");t.setCurrentDataPoint(i)})})}),this.tip.container.addEventListener("click",function(){var e=t.tip.container.getAttribute("data-point-index");t.setCurrentDataPoint(e)})}},{key:"updateOverlay",value:function(){var t=this;this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];te[e.type](i,e.overlay)})}},{key:"onLeftArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex-1)}},{key:"onRightArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex+1)}},{key:"getDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.currentIndex,e=this.state;return{index:t,label:e.xAxis.labels[t],values:e.datasets.map(function(e){return e.values[t]})}}},{key:"setCurrentDataPoint",value:function(t){var e=this.state;(t=parseInt(t))<0&&(t=0),t>=e.xAxis.labels.length&&(t=e.xAxis.labels.length-1),t!==e.currentIndex&&(e.currentIndex=t,a(this.parent,"data-select",this.getDataPoint()))}},{key:"addDataPoint",value:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.state.datasetLength;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"addDataPoint",this).call(this,t,e,n),this.data.labels.splice(n,0,t),this.data.datasets.map(function(t,i){t.values.splice(n,0,e[i])}),this.update(this.data)}},{key:"removeDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.datasetLength-1;this.data.labels.length<=1||(Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"removeDataPoint",this).call(this,t),this.data.labels.splice(t,1),this.data.datasets.map(function(e){e.values.splice(t,1)}),this.update(this.data))}},{key:"updateDataset",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;this.data.datasets[e].values=t,this.update(this.data)}},{key:"updateDatasets",value:function(t){this.data.datasets.map(function(e,i){t[i]&&(e.values=t[i])}),this.update(this.data)}}]),i}(ue),we={bar:ke,line:ke,percentage:me,heatmap:xe,pie:be},Ae=function t(e,i){return Ot(this,t),Tt(i.type,e,i)},Pe=Object.freeze({Chart:Ae,PercentageChart:me,PieChart:be,Heatmap:xe,AxisChart:ke}),Ce={};return Ce.NAME="Frappe Charts",Ce.VERSION="1.1.0",Ce=Object.assign({},Ce,Pe)}();
//# sourceMappingURL=frappe-charts.min.iife.js.map
diff --git a/dist/frappe-charts.min.iife.js.map b/dist/frappe-charts.min.iife.js.map
index 3201752..cc39994 100644
--- a/dist/frappe-charts.min.iife.js.map
+++ b/dist/frappe-charts.min.iife.js.map
@@ -1 +1 @@
-{"version":3,"file":"frappe-charts.min.iife.js","sources":["../src/js/utils/dom.js","../src/js/utils/constants.js","../src/js/utils/helpers.js","../src/js/utils/draw-utils.js","../src/js/utils/colors.js","../src/js/utils/draw.js","../src/js/utils/animate.js","../src/js/utils/animation.js","../src/js/utils/export.js","../src/js/utils/date-utils.js","../src/js/objects/ChartComponents.js","../src/js/utils/intervals.js","../src/js/utils/axis-chart-utils.js","../src/js/chart.js","../src/js/objects/SvgTip.js","../src/css/chartsCss.js","../src/js/charts/BaseChart.js","../src/js/charts/AggregationChart.js","../src/js/charts/PercentageChart.js","../src/js/charts/PieChart.js","../src/js/charts/Heatmap.js","../src/js/charts/AxisChart.js","../src/js/index.js"],"sourcesContent":["export function $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function findNodeIndex(node)\n{\n\tvar i = 0;\n\twhile (node.previousSibling) {\n\t\tnode = node.previousSibling;\n\t\ti++;\n\t}\n\treturn i;\n}\n\n$.create = (tag, o) => {\n\tvar element = document.createElement(tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"onClick\" ) {\n\t\t\telement.addEventListener('click', val);\n\n\t\t} else if (i === \"onInput\" ) {\n\t\t\telement.addEventListener('input', function(e) {\n\t\t\t\tval(element.value);\n\t\t\t});\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (i in element ) {\n\t\t\telement[i] = val;\n\t\t}\n\t\telse {\n\t\t\telement.setAttribute(i, val);\n\t\t}\n\t}\n\n\treturn element;\n};\n\nexport function getOffset(element) {\n\tlet rect = element.getBoundingClientRect();\n\treturn {\n\t\t// https://stackoverflow.com/a/7436602/6495043\n\t\t// rect.top varies with scroll, so we add whatever has been\n\t\t// scrolled to it to get absolute distance from actual page top\n\t\ttop: rect.top + (document.documentElement.scrollTop || document.body.scrollTop),\n\t\tleft: rect.left + (document.documentElement.scrollLeft || document.body.scrollLeft)\n\t};\n}\n\nexport function isElementInViewport(el) {\n\t// Although straightforward: https://stackoverflow.com/a/7557433/6495043\n\tvar rect = el.getBoundingClientRect();\n\n\treturn (\n\t\trect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */\n rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */\n\t);\n}\n\nexport function getElementContentWidth(element) {\n\tvar styles = window.getComputedStyle(element);\n\tvar padding = parseFloat(styles.paddingLeft) +\n\t\tparseFloat(styles.paddingRight);\n\n\treturn element.clientWidth - padding;\n}\n\nexport function bind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function (event) {\n\t\t\t\telement.addEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function unbind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function(event) {\n\t\t\t\telement.removeEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function fire(target, type, properties) {\n\tvar evt = document.createEvent(\"HTMLEvents\");\n\n\tevt.initEvent(type, true, true );\n\n\tfor (var j in properties) {\n\t\tevt[j] = properties[j];\n\t}\n\n\treturn target.dispatchEvent(evt);\n}\n\n// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/\nexport function forEachNode(nodeList, callback, scope) {\n\tif(!nodeList) return;\n\tfor (var i = 0; i < nodeList.length; i++) {\n\t\tcallback.call(scope, nodeList[i], i);\n\t}\n}\n\nexport function activate($parent, $child, commonSelector, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`${commonSelector}.${activeClass}`);\n\n\tif (typeof $child === 'string') {\n\t\t$child = $parent.querySelector($child);\n\t}\n\n\tthis.forEachNode($children, (node, i) => {\n\t\tif(index >= 0 && i <= index) return;\n\t\tnode.classList.remove(activeClass);\n\t})\n\n\t$child.classList.add(activeClass);\n}\n\nexport function insertAfter(newNode, referenceNode) {\n referenceNode.parentNode.insertBefore(newNode, referenceNode.nextSibling);\n}\n","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const AXIS_CHART_DEFAULT_TYPE = 'line';\nexport const AXIS_CHART_MIXED_TYPE = 'axis-mixed';\nexport const AXIS_CHART_TYPES = ['line', 'bar', 'axis-mixed'];\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_CHART_OPTIONS = {\n\tbarOptions: {\n\t\tspaceRatio: 1,\n\t}\n}\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 1;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.02;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\nexport function toTitleCase(str) {\n return str.replace(/\\w*/g, function(txt){return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();});\n}\n","import { fillArray } from './helpers';\n\nexport function getBarHeightAndYAttr(yTop, zeroLine) {\n\tlet height, y;\n\tif (yTop <= zeroLine) {\n\t\theight = zeroLine - yTop;\n\t\ty = yTop;\n\t} else {\n\t\theight = yTop - zeroLine;\n\t\ty = zeroLine;\n\t}\n\n\treturn [height, y];\n}\n\nexport function equilizeNoOfElements(array1, array2,\n\textraCount = array2.length - array1.length) {\n\n\t// Doesn't work if either has zero elements.\n\tif(extraCount > 0) {\n\t\tarray1 = fillArray(array1, extraCount);\n\t} else {\n\t\tarray2 = fillArray(array2, extraCount);\n\t}\n\treturn [array1, array2];\n}\n","const PRESET_COLOR_MAP = {\n\t'light-blue': '#7cd6fd',\n\t'blue': '#5e64ff',\n\t'violet': '#743ee2',\n\t'red': '#ff5858',\n\t'orange': '#ffa00a',\n\t'yellow': '#feef72',\n\t'green': '#28a745',\n\t'light-green': '#98d85b',\n\t'purple': '#b554ff',\n\t'magenta': '#ffa3ef',\n\t'black': '#36114C',\n\t'grey': '#bdd3e6',\n\t'light-grey': '#f0f4f7',\n\t'dark-grey': '#b8c2cc'\n};\n\nfunction limitColor(r){\n\tif (r > 255) return 255;\n\telse if (r < 0) return 0;\n\treturn r;\n}\n\nexport function lightenDarkenColor(color, amt) {\n\tlet col = getColor(color);\n\tlet usePound = false;\n\tif (col[0] == \"#\") {\n\t\tcol = col.slice(1);\n\t\tusePound = true;\n\t}\n\tlet num = parseInt(col,16);\n\tlet r = limitColor((num >> 16) + amt);\n\tlet b = limitColor(((num >> 8) & 0x00FF) + amt);\n\tlet g = limitColor((num & 0x0000FF) + amt);\n\treturn (usePound?\"#\":\"\") + (g | (b << 8) | (r << 16)).toString(16);\n}\n\nexport function isValidColor(string) {\n\t// https://stackoverflow.com/a/8027444/6495043\n\treturn /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(string);\n}\n\nexport const getColor = (color) => {\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\nimport { getStringWidth } from './helpers';\nimport { DOT_OVERLAY_SIZE_INCR, PERCENTAGE_BAR_DEFAULT_DEPTH } from './constants';\nimport { lightenDarkenColor } from './colors';\n\nexport const AXIS_TICK_LENGTH = 6;\nconst LABEL_MARGIN = 4;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none') {\n\treturn createSVG('path', {\n\t\tclassName: className,\n\t\td: pathStr,\n\t\tstyles: {\n\t\t\tstroke: stroke,\n\t\t\tfill: fill\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 0 ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeGradient(svgDefElem, color, lighter = false) {\n\tlet gradientId ='path-fill-gradient' + '-' + color + '-' +(lighter ? 'lighter' : 'default');\n\tlet gradientDef = renderVerticalGradient(svgDefElem, gradientId);\n\tlet opacities = [1, 0.6, 0.2];\n\tif(lighter) {\n\t\topacities = [0.4, 0.2, 0];\n\t}\n\n\tsetGradientStop(gradientDef, \"0%\", color, opacities[0]);\n\tsetGradientStop(gradientDef, \"50%\", color, opacities[1]);\n\tsetGradientStop(gradientDef, \"100%\", color, opacities[2]);\n\n\treturn gradientId;\n}\n\nexport function percentageBar(x, y, width, height,\n\tdepth=PERCENTAGE_BAR_DEFAULT_DEPTH, fill='none') {\n\n\tlet args = {\n\t\tclassName: 'percentage-bar',\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height,\n\t\tfill: fill,\n\t\tstyles: {\n\t\t\t'stroke': lightenDarkenColor(fill, -25),\n\t\t\t// Diabolically good: https://stackoverflow.com/a/9000859\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/stroke-dasharray\n\t\t\t'stroke-dasharray': `0, ${height + width}, ${width}, ${height}`,\n\t\t\t'stroke-width': depth\n\t\t},\n\t};\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function heatSquare(className, x, y, size, fill='none', data={}) {\n\tlet args = {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: size,\n\t\theight: size,\n\t\tfill: fill\n\t};\n\n\tObject.keys(data).map(key => {\n\t\targs[key] = data[key];\n\t});\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function legendBar(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-bar',\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: size,\n\t\theight: '2px',\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE * 2) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"rect\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function legendDot(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-dot',\n\t\tcx: 0,\n\t\tcy: 0,\n\t\tr: size,\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdx: (FONT_SIZE) + 'px',\n\t\tdy: (FONT_SIZE/3) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"circle\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function makeText(className, x, y, content, options = {}) {\n\tlet fontSize = options.fontSize || FONT_SIZE;\n\tlet dy = options.dy !== undefined ? options.dy : (fontSize / 2);\n\tlet fill = options.fill || FONT_FILL;\n\tlet textAnchor = options.textAnchor || 'start';\n\treturn createSVG('text', {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\tdy: dy + 'px',\n\t\t'font-size': fontSize + 'px',\n\t\tfill: fill,\n\t\t'text-anchor': textAnchor,\n\t\tinnerHTML: content\n\t});\n}\n\nfunction makeVertLine(x, label, y1, y2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tlet l = createSVG('line', {\n\t\tclassName: 'line-vertical ' + options.className,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: y1,\n\t\ty2: y2,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: 0,\n\t\ty: y1 > y2 ? y1 + LABEL_MARGIN : y1 - LABEL_MARGIN - FONT_SIZE,\n\t\tdy: FONT_SIZE + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'middle',\n\t\tinnerHTML: label + \"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(${ x }, 0)`\n\t});\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nfunction makeHoriLine(y, label, x1, x2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.lineType) options.lineType = '';\n\tlet className = 'line-horizontal ' + options.className +\n\t\t(options.lineType === \"dashed\" ? \"dashed\": \"\");\n\n\tlet l = createSVG('line', {\n\t\tclassName: className,\n\t\tx1: x1,\n\t\tx2: x2,\n\t\ty1: 0,\n\t\ty2: 0,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: x1 < x2 ? x1 - LABEL_MARGIN : x1 + LABEL_MARGIN,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / 2 - 2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': x1 < x2 ? 'end' : 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(0, ${y})`,\n\t\t'stroke-opacity': 1\n\t});\n\n\tif(text === 0 || text === '0') {\n\t\tline.style.stroke = \"rgba(27, 31, 35, 0.6)\";\n\t}\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nexport function yLine(y, label, width, options={}) {\n\tif(!options.pos) options.pos = 'left';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\tlet x1 = -1 * AXIS_TICK_LENGTH;\n\tlet x2 = options.mode === 'span' ? width + AXIS_TICK_LENGTH : 0;\n\n\tif(options.mode === 'tick' && options.pos === 'right') {\n\t\tx1 = width + AXIS_TICK_LENGTH;\n\t\tx2 = width;\n\t}\n\n\t// let offset = options.pos === 'left' ? -1 * options.offset : options.offset;\n\n\tx1 += options.offset;\n\tx2 += options.offset;\n\n\treturn makeHoriLine(y, label, x1, x2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.regionFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\n\nexport const UNIT_ANIM_DUR = 350;\nexport const PATH_ANIM_DUR = 350;\nexport const MARKER_LINE_ANIM_DUR = UNIT_ANIM_DUR;\nexport const REPLACE_ALL_NEW_DUR = 250;\n\nexport const STD_EASING = 'easein';\n\nexport function translate(unit, oldCoord, newCoord, duration) {\n\tlet old = typeof oldCoord === 'string' ? oldCoord : oldCoord.join(', ');\n\treturn [\n\t\tunit,\n\t\t{transform: newCoord.join(', ')},\n\t\tduration,\n\t\tSTD_EASING,\n\t\t\"translate\",\n\t\t{transform: old}\n\t];\n}\n\nexport function translateVertLine(xLine, newX, oldX) {\n\treturn translate(xLine, [oldX, 0], [newX, 0], MARKER_LINE_ANIM_DUR);\n}\n\nexport function translateHoriLine(yLine, newY, oldY) {\n\treturn translate(yLine, [0, oldY], [0, newY], MARKER_LINE_ANIM_DUR);\n}\n\nexport function animateRegion(rectGroup, newY1, newY2, oldY2) {\n\tlet newHeight = newY1 - newY2;\n\tlet rect = rectGroup.childNodes[0];\n\tlet width = rect.getAttribute(\"width\");\n\tlet rectAnim = [\n\t\trect,\n\t\t{ height: newHeight, 'stroke-dasharray': `${width}, ${newHeight}` },\n\t\tMARKER_LINE_ANIM_DUR,\n\t\tSTD_EASING\n\t];\n\n\tlet groupAnim = translate(rectGroup, [0, oldY2], [0, newY2], MARKER_LINE_ANIM_DUR);\n\treturn [rectAnim, groupAnim];\n}\n\nexport function animateBar(bar, x, yTop, width, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\tif(bar.nodeName !== 'rect') {\n\t\tlet rect = bar.childNodes[0];\n\t\tlet rectAnim = [\n\t\t\trect,\n\t\t\t{width: width, height: height},\n\t\t\tUNIT_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\n\t\tlet oldCoordStr = bar.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(bar, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [rectAnim, groupAnim];\n\t} else {\n\t\treturn [[bar, {width: width, height: height, x: x, y: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// bar.animate({height: args.newHeight, y: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animateDot(dot, x, y) {\n\tif(dot.nodeName !== 'circle') {\n\t\tlet oldCoordStr = dot.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(dot, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [groupAnim];\n\t} else {\n\t\treturn [[dot, {cx: x, cy: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// dot.animate({cy: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animatePath(paths, newXList, newYList, zeroLine) {\n\tlet pathComponents = [];\n\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y));\n\tlet pathStr = pointsStr.join(\"L\");\n\n\tconst animPath = [paths.path, {d:\"M\"+pathStr}, PATH_ANIM_DUR, STD_EASING];\n\tpathComponents.push(animPath);\n\n\tif(paths.region) {\n\t\tlet regStartPt = `${newXList[0]},${zeroLine}L`;\n\t\tlet regEndPt = `L${newXList.slice(-1)[0]}, ${zeroLine}`;\n\n\t\tconst animRegion = [\n\t\t\tpaths.region,\n\t\t\t{d:\"M\" + regStartPt + pathStr + regEndPt},\n\t\t\tPATH_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\t\tpathComponents.push(animRegion);\n\t}\n\n\treturn pathComponents;\n}\n\nexport function animatePathStr(oldPath, pathStr) {\n\treturn [oldPath, {d: pathStr}, UNIT_ANIM_DUR, STD_EASING];\n}\n","// Leveraging SMIL Animations\n\nimport { REPLACE_ALL_NEW_DUR } from './animate';\n\nconst EASING = {\n\tease: \"0.25 0.1 0.25 1\",\n\tlinear: \"0 0 1 1\",\n\t// easein: \"0.42 0 1 1\",\n\teasein: \"0.1 0.8 0.2 1\",\n\teaseout: \"0 0 0.58 1\",\n\teaseinout: \"0.42 0 0.58 1\"\n};\n\nfunction animateSVGElement(element, props, dur, easingType=\"linear\", type=undefined, oldValues={}) {\n\n\tlet animElement = element.cloneNode(true);\n\tlet newElement = element.cloneNode(true);\n\n\tfor(var attributeName in props) {\n\t\tlet animateElement;\n\t\tif(attributeName === 'transform') {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animateTransform\");\n\t\t} else {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animate\");\n\t\t}\n\t\tlet currentValue = oldValues[attributeName] || element.getAttribute(attributeName);\n\t\tlet value = props[attributeName];\n\n\t\tlet animAttr = {\n\t\t\tattributeName: attributeName,\n\t\t\tfrom: currentValue,\n\t\t\tto: value,\n\t\t\tbegin: \"0s\",\n\t\t\tdur: dur/1000 + \"s\",\n\t\t\tvalues: currentValue + \";\" + value,\n\t\t\tkeySplines: EASING[easingType],\n\t\t\tkeyTimes: \"0;1\",\n\t\t\tcalcMode: \"spline\",\n\t\t\tfill: 'freeze'\n\t\t};\n\n\t\tif(type) {\n\t\t\tanimAttr[\"type\"] = type;\n\t\t}\n\n\t\tfor (var i in animAttr) {\n\t\t\tanimateElement.setAttribute(i, animAttr[i]);\n\t\t}\n\n\t\tanimElement.appendChild(animateElement);\n\n\t\tif(type) {\n\t\t\tnewElement.setAttribute(attributeName, `translate(${value})`);\n\t\t} else {\n\t\t\tnewElement.setAttribute(attributeName, value);\n\t\t}\n\t}\n\n\treturn [animElement, newElement];\n}\n\nexport function transform(element, style) { // eslint-disable-line no-unused-vars\n\telement.style.transform = style;\n\telement.style.webkitTransform = style;\n\telement.style.msTransform = style;\n\telement.style.mozTransform = style;\n\telement.style.oTransform = style;\n}\n\nfunction animateSVG(svgContainer, elements) {\n\tlet newElements = [];\n\tlet animElements = [];\n\n\telements.map(element => {\n\t\tlet unit = element[0];\n\t\tlet parent = unit.parentNode;\n\n\t\tlet animElement, newElement;\n\n\t\telement[0] = unit;\n\t\t[animElement, newElement] = animateSVGElement(...element);\n\n\t\tnewElements.push(newElement);\n\t\tanimElements.push([animElement, parent]);\n\n\t\tparent.replaceChild(animElement, unit);\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\telements[i][0] = newElements[i];\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport { makeText, makePath, xLine, yLine, yMarker, yRegion, datasetBar, datasetDot, percentageBar, getPaths, heatSquare } from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport { translateHoriLine, translateVertLine, animateRegion, animateBar,\n\tanimateDot, animatePath, animatePathStr } from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n\tconstructor({\n\t\tlayerClass = '',\n\t\tlayerTransform = '',\n\t\tconstants,\n\n\t\tgetData,\n\t\tmakeElements,\n\t\tanimateElements\n\t}) {\n\t\tthis.layerTransform = layerTransform;\n\t\tthis.constants = constants;\n\n\t\tthis.makeElements = makeElements;\n\t\tthis.getData = getData;\n\n\t\tthis.animateElements = animateElements;\n\n\t\tthis.store = [];\n\t\tthis.labels = [];\n\n\t\tthis.layerClass = layerClass;\n\t\tthis.layerClass = typeof(this.layerClass) === 'function'\n\t\t\t? this.layerClass() : this.layerClass;\n\n\t\tthis.refresh();\n\t}\n\n\trefresh(data) {\n\t\tthis.data = data || this.getData();\n\t}\n\n\tsetup(parent) {\n\t\tthis.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n\t}\n\n\tmake() {\n\t\tthis.render(this.data);\n\t\tthis.oldData = this.data;\n\t}\n\n\trender(data) {\n\t\tthis.store = this.makeElements(data);\n\n\t\tthis.layer.textContent = '';\n\t\tthis.store.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t\tthis.labels.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t}\n\n\tupdate(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tpieSlices: {\n\t\tlayerClass: 'pie-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) =>{\n\t\t\t\tlet slice = makePath(s, 'pie-path', 'none', data.colors[i]);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) =>\n\t\t\t\tanimatePathStr(slice, newData.sliceStrings[i])\n\t\t\t);\n\t\t}\n\t},\n\tpercentageBars: {\n\t\tlayerClass: 'percentage-bars',\n\t\tmakeElements(data) {\n\t\t\treturn data.xPositions.map((x, i) =>{\n\t\t\t\tlet y = 0;\n\t\t\t\tlet bar = percentageBar(x, y, data.widths[i],\n\t\t\t\t\tthis.constants.barHeight, this.constants.barDepth, data.colors[i]);\n\t\t\t\treturn bar;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\tyAxis: {\n\t\tlayerClass: 'y axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\tyLine(position, data.labels[i], this.constants.width,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.labels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tlabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(m =>\n\t\t\t\tyMarker(m.position, m.label, this.constants.width,\n\t\t\t\t\t{labelPos: m.options.labelPos, mode: 'span', lineType: 'dashed'})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, day.fill, data);\n\t\t\t\t\t\tthis.serializedSubDomains.push(square);\n\t\t\t\t\t}\n\t\t\t\t\ty += rowHeight;\n\t\t\t\t});\n\t\t\t\ty = 0;\n\t\t\t\tx += colWidth;\n\t\t\t});\n\n\t\t\treturn this.serializedSubDomains;\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\n\tbarGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-bars dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'bar';\n\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\treturn datasetBar(\n\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\ty,\n\t\t\t\t\tdata.barWidth,\n\t\t\t\t\tc.color,\n\t\t\t\t\tdata.labels[j],\n\t\t\t\t\tj,\n\t\t\t\t\tdata.offsets[j],\n\t\t\t\t\t{\n\t\t\t\t\t\tzeroLine: data.zeroLine,\n\t\t\t\t\t\tbarsWidth: data.barsWidth,\n\t\t\t\t\t\tminHeight: c.minHeight\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t});\n\t\t\treturn this.units;\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newOffsets = newData.offsets;\n\t\t\tlet newLabels = newData.labels;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldOffsets = this.oldData.offsets;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldOffsets, newOffsets] = equilizeNoOfElements(oldOffsets, newOffsets);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\toffsets: oldOffsets,\n\t\t\t\tlabels: newLabels,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tbarsWidth: this.oldData.barsWidth,\n\t\t\t\tbarWidth: this.oldData.barWidth,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((bar, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateBar(\n\t\t\t\t\tbar, newXPos[i], newYPos[i], newData.barWidth, newOffsets[i],\n\t\t\t\t\t{zeroLine: newData.zeroLine}\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\tlineGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-line dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'dot';\n\t\t\tthis.paths = {};\n\t\t\tif(!c.hideLine) {\n\t\t\t\tthis.paths = getPaths(\n\t\t\t\t\tdata.xPositions,\n\t\t\t\t\tdata.yPositions,\n\t\t\t\t\tc.color,\n\t\t\t\t\t{\n\t\t\t\t\t\theatline: c.heatline,\n\t\t\t\t\t\tregionFill: c.regionFill\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tsvgDefs: c.svgDefs,\n\t\t\t\t\t\tzeroLine: data.zeroLine\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.units = [];\n\t\t\tif(!c.hideDots) {\n\t\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\t\treturn datasetDot(\n\t\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\t\ty,\n\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\tc.color,\n\t\t\t\t\t\t(c.valuesOverPoints ? data.values[j] : ''),\n\t\t\t\t\t\tj\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn Object.values(this.paths).concat(this.units);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newValues = newData.values;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldValues = this.oldData.values;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldValues, newValues] = equilizeNoOfElements(oldValues, newValues);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\tvalues: newValues,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tradius: this.oldData.radius,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tif(Object.keys(this.paths).length) {\n\t\t\t\tanimateElements = animateElements.concat(animatePath(\n\t\t\t\t\tthis.paths, newXPos, newYPos, newData.zeroLine));\n\t\t\t}\n\n\t\t\tif(this.units.length) {\n\t\t\t\tthis.units.map((dot, i) => {\n\t\t\t\t\tanimateElements = animateElements.concat(animateDot(\n\t\t\t\t\t\tdot, newXPos[i], newYPos[i]));\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn animateElements;\n\t\t}\n\t}\n};\n\nexport function getComponent(name, constants, getData) {\n\tlet keys = Object.keys(componentConfigs).filter(k => name.includes(k));\n\tlet config = componentConfigs[keys[0]];\n\tObject.assign(config, {\n\t\tconstants: constants,\n\t\tgetData: getData\n\t});\n\treturn new ChartComponent(config);\n}\n","import { floatTwo } from './helpers';\n\nfunction normalize(x) {\n\t// Calculates mantissa and exponent of a number\n\t// Returns normalized number and exponent\n\t// https://stackoverflow.com/q/9383593/6495043\n\n\tif(x===0) {\n\t\treturn [0, 0];\n\t}\n\tif(isNaN(x)) {\n\t\treturn {mantissa: -6755399441055744, exponent: 972};\n\t}\n\tvar sig = x > 0 ? 1 : -1;\n\tif(!isFinite(x)) {\n\t\treturn {mantissa: sig * 4503599627370496, exponent: 972};\n\t}\n\n\tx = Math.abs(x);\n\tvar exp = Math.floor(Math.log10(x));\n\tvar man = x/Math.pow(10, exp);\n\n\treturn [sig * man, exp];\n}\n\nfunction getChartRangeIntervals(max, min=0) {\n\tlet upperBound = Math.ceil(max);\n\tlet lowerBound = Math.floor(min);\n\tlet range = upperBound - lowerBound;\n\n\tlet noOfParts = range;\n\tlet partSize = 1;\n\n\t// To avoid too many partitions\n\tif(range > 5) {\n\t\tif(range % 2 !== 0) {\n\t\t\tupperBound++;\n\t\t\t// Recalc range\n\t\t\trange = upperBound - lowerBound;\n\t\t}\n\t\tnoOfParts = range/2;\n\t\tpartSize = 2;\n\t}\n\n\t// Special case: 1 and 2\n\tif(range <= 2) {\n\t\tnoOfParts = 4;\n\t\tpartSize = range/noOfParts;\n\t}\n\n\t// Special case: 0\n\tif(range === 0) {\n\t\tnoOfParts = 5;\n\t\tpartSize = 1;\n\t}\n\n\tlet intervals = [];\n\tfor(var i = 0; i <= noOfParts; i++){\n\t\tintervals.push(lowerBound + partSize * i);\n\t}\n\treturn intervals;\n}\n\nfunction getChartIntervals(maxValue, minValue=0) {\n\tlet [normalMaxValue, exponent] = normalize(maxValue);\n\tlet normalMinValue = minValue ? minValue/Math.pow(10, exponent): 0;\n\n\t// Allow only 7 significant digits\n\tnormalMaxValue = normalMaxValue.toFixed(6);\n\n\tlet intervals = getChartRangeIntervals(normalMaxValue, normalMinValue);\n\tintervals = intervals.map(value => value * Math.pow(10, exponent));\n\treturn intervals;\n}\n\nexport function calcChartIntervals(values, withMinimum=false) {\n\t//*** Where the magic happens ***\n\n\t// Calculates best-fit y intervals from given values\n\t// and returns the interval array\n\n\tlet maxValue = Math.max(...values);\n\tlet minValue = Math.min(...values);\n\n\t// Exponent to be used for pretty print\n\tlet exponent = 0, intervals = []; // eslint-disable-line no-unused-vars\n\n\tfunction getPositiveFirstIntervals(maxValue, absMinValue) {\n\t\tlet intervals = getChartIntervals(maxValue);\n\n\t\tlet intervalSize = intervals[1] - intervals[0];\n\n\t\t// Then unshift the negative values\n\t\tlet value = 0;\n\t\tfor(var i = 1; value < absMinValue; i++) {\n\t\t\tvalue += intervalSize;\n\t\t\tintervals.unshift((-1) * value);\n\t\t}\n\t\treturn intervals;\n\t}\n\n\t// CASE I: Both non-negative\n\n\tif(maxValue >= 0 && minValue >= 0) {\n\t\texponent = normalize(maxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(maxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(maxValue, minValue);\n\t\t}\n\t}\n\n\t// CASE II: Only minValue negative\n\n\telse if(maxValue > 0 && minValue < 0) {\n\t\t// `withMinimum` irrelevant in this case,\n\t\t// We'll be handling both sides of zero separately\n\t\t// (both starting from zero)\n\t\t// Because ceil() and floor() behave differently\n\t\t// in those two regions\n\n\t\tlet absMinValue = Math.abs(minValue);\n\n\t\tif(maxValue >= absMinValue) {\n\t\t\texponent = normalize(maxValue)[1];\n\t\t\tintervals = getPositiveFirstIntervals(maxValue, absMinValue);\n\t\t} else {\n\t\t\t// Mirror: maxValue => absMinValue, then change sign\n\t\t\texponent = normalize(absMinValue)[1];\n\t\t\tlet posIntervals = getPositiveFirstIntervals(absMinValue, maxValue);\n\t\t\tintervals = posIntervals.map(d => d * (-1));\n\t\t}\n\n\t}\n\n\t// CASE III: Both non-positive\n\n\telse if(maxValue <= 0 && minValue <= 0) {\n\t\t// Mirrored Case I:\n\t\t// Work with positives, then reverse the sign and array\n\n\t\tlet pseudoMaxValue = Math.abs(minValue);\n\t\tlet pseudoMinValue = Math.abs(maxValue);\n\n\t\texponent = normalize(pseudoMaxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue, pseudoMinValue);\n\t\t}\n\n\t\tintervals = intervals.reverse().map(d => d * (-1));\n\t}\n\n\treturn intervals;\n}\n\nexport function getZeroIndex(yPts) {\n\tlet zeroIndex;\n\tlet interval = getIntervalSize(yPts);\n\tif(yPts.indexOf(0) >= 0) {\n\t\t// the range has a given zero\n\t\t// zero-line on the chart\n\t\tzeroIndex = yPts.indexOf(0);\n\t} else if(yPts[0] > 0) {\n\t\t// Minimum value is positive\n\t\t// zero-line is off the chart: below\n\t\tlet min = yPts[0];\n\t\tzeroIndex = (-1) * min / interval;\n\t} else {\n\t\t// Maximum value is negative\n\t\t// zero-line is off the chart: above\n\t\tlet max = yPts[yPts.length - 1];\n\t\tzeroIndex = (-1) * max / interval + (yPts.length - 1);\n\t}\n\treturn zeroIndex;\n}\n\nexport function getRealIntervals(max, noOfIntervals, min = 0, asc = 1) {\n\tlet range = max - min;\n\tlet part = range * 1.0 / noOfIntervals;\n\tlet intervals = [];\n\n\tfor(var i = 0; i <= noOfIntervals; i++) {\n\t\tintervals.push(min + part * i);\n\t}\n\n\treturn asc ? intervals : intervals.reverse();\n}\n\nexport function getIntervalSize(orderedArray) {\n\treturn orderedArray[1] - orderedArray[0];\n}\n\nexport function getValueRange(orderedArray) {\n\treturn orderedArray[orderedArray.length-1] - orderedArray[0];\n}\n\nexport function scale(val, yAxis) {\n\treturn floatTwo(yAxis.zeroLine - val * yAxis.scaleMultiplier);\n}\n\nexport function isInRange(val, min, max) {\n\treturn val > min && val < max;\n}\n\nexport function isInRange2D(coord, minCoord, maxCoord) {\n\treturn isInRange(coord[0], minCoord[0], maxCoord[0])\n\t\t&& isInRange(coord[1], minCoord[1], maxCoord[1]);\n}\n\nexport function getClosestInArray(goal, arr, index = false) {\n\tlet closest = arr.reduce(function(prev, curr) {\n\t\treturn (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);\n\t});\n\n\treturn index ? arr.indexOf(closest) : closest;\n}\n\nexport function calcDistribution(values, distributionSize) {\n\t// Assume non-negative values,\n\t// implying distribution minimum at zero\n\n\tlet dataMaxValue = Math.max(...values);\n\n\tlet distributionStep = 1 / (distributionSize - 1);\n\tlet distribution = [];\n\n\tfor(var i = 0; i < distributionSize; i++) {\n\t\tlet checkpoint = dataMaxValue * (distributionStep * i);\n\t\tdistribution.push(checkpoint);\n\t}\n\n\treturn distribution;\n}\n\nexport function getMaxCheckpoint(value, distribution) {\n\treturn distribution.filter(d => d < value).length;\n}\n","import { fillArray } from '../utils/helpers';\nimport { AXIS_CHART_DEFAULT_TYPE, AXIS_CHART_MIXED_TYPE, AXIS_DATASET_CHART_TYPES, DEFAULT_CHAR_WIDTH } from '../utils/constants';\n\nexport function dataPrep(data, type) {\n\tdata.labels = data.labels || [];\n\n\tlet datasetLength = data.labels.length;\n\n\t// Datasets\n\tlet datasets = data.datasets;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\tif(!datasets) {\n\t\t// default\n\t\tdatasets = [{\n\t\t\tvalues: zeroArray\n\t\t}];\n\t}\n\n\tlet overridingType;\n\tif(AXIS_DATASET_CHART_TYPES.includes(type)) {\n\t\toverridingType = type;\n\t};\n\n\tdatasets.map(d=> {\n\t\t// Set values\n\t\tif(!d.values) {\n\t\t\td.values = zeroArray;\n\t\t} else {\n\t\t\t// Check for non values\n\t\t\tlet vals = d.values;\n\t\t\tvals = vals.map(val => (!isNaN(val) ? val : 0));\n\n\t\t\t// Trim or extend\n\t\t\tif(vals.length > datasetLength) {\n\t\t\t\tvals = vals.slice(0, datasetLength);\n\t\t\t} else {\n\t\t\t\tvals = fillArray(vals, datasetLength - vals.length, 0);\n\t\t\t}\n\t\t}\n\n\t\t// Set labels\n\n\t\t// Set type\n\t\tif(overridingType) {\n\t\t\td.chartType = overridingType;\n\t\t} else if(!d.chartType) {\n\t\t\td.chartType = AXIS_CHART_DEFAULT_TYPE;\n\t\t}\n\t});\n\n\t// Markers\n\n\t// Regions\n\t// data.yRegions = data.yRegions || [];\n\tif(data.yRegions) {\n\t\tdata.yRegions.map(d => {\n\t\t\tif(d.end < d.start) {\n\t\t\t\t[d.start, d.end] = [d.end, d.start];\n\t\t\t}\n\t\t});\n\t}\n\n\treturn data;\n}\n\nexport function zeroDataPrep(realData) {\n\tlet datasetLength = realData.labels.length;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\n\tlet zeroData = {\n\t\tlabels: realData.labels.slice(0, -1),\n\t\tdatasets: realData.datasets.map(d => {\n\t\t\treturn {\n\t\t\t\tname: '',\n\t\t\t\tvalues: zeroArray.slice(0, -1),\n\t\t\t\tchartType: d.chartType\n\t\t\t};\n\t\t}),\n\t};\n\n\tif(realData.yMarkers) {\n\t\tzeroData.yMarkers = [\n\t\t\t{\n\t\t\t\tvalue: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\tif(realData.yRegions) {\n\t\tzeroData.yRegions = [\n\t\t\t{\n\t\t\t\tstart: 0,\n\t\t\t\tend: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\treturn zeroData;\n}\n\nexport function getShortenedLabels(chartWidth, labels=[], isSeries=true) {\n\tlet allowedSpace = chartWidth / labels.length;\n\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet calcLabels = labels.map((label, i) => {\n\t\tlabel += \"\";\n\t\tif(label.length > allowedLetters) {\n\n\t\t\tif(!isSeries) {\n\t\t\t\tif(allowedLetters-3 > 0) {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters-3) + \" ...\";\n\t\t\t\t} else {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters) + '..';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlet multiple = Math.ceil(label.length/allowedLetters);\n\t\t\t\tif(i % multiple !== 0) {\n\t\t\t\t\tlabel = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn label;\n\t});\n\n\treturn calcLabels;\n}\n","import '../css/charts.scss';\n\n// import MultiAxisChart from './charts/MultiAxisChart';\nimport PercentageChart from './charts/PercentageChart';\nimport PieChart from './charts/PieChart';\nimport Heatmap from './charts/Heatmap';\nimport AxisChart from './charts/AxisChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `\n\t\t\t\t\n\t\t\t\t`\n\t\t});\n\t\tthis.hideTip();\n\n\t\tthis.title = this.container.querySelector('.title');\n\t\tthis.dataPointList = this.container.querySelector('.data-point-list');\n\n\t\tthis.parent.addEventListener('mouseleave', () => {\n\t\t\tthis.hideTip();\n\t\t});\n\t}\n\n\tfill() {\n\t\tlet title;\n\t\tif(this.index) {\n\t\t\tthis.container.setAttribute('data-point-index', this.index);\n\t\t}\n\t\tif(this.titleValueFirst) {\n\t\t\ttitle = `${this.titleValue}${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}${this.titleValue}`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `${ value === 0 || value ? value : '' }\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\n\nlet BOUND_DRAW_FN;\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || 'line';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tBOUND_DRAW_FN = this.boundDrawFn.bind(this);\n\t\twindow.addEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents() {\n\t\twindow.removeEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t\tthis.parent.style.overflow = 'auto';\n\t\t}\n\n\t\tthis.container = $.create('div', args);\n\t}\n\n\tmakeTooltip() {\n\t\tthis.tip = new SvgTip({\n\t\t\tparent: this.container,\n\t\t\tcolors: this.colors\n\t\t});\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {}\n\n\tdraw(onlyWidthChange=false, init=false) {\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { legendDot } from '../utils/draw';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.maxSlices = args.maxSlices || 20;\n\t\tthis.config.maxLegendPoints = args.maxLegendPoints || 20;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\t\tlet maxSlices = this.config.maxSlices;\n\t\ts.sliceTotals = [];\n\n\t\tlet allTotals = this.data.labels.map((label, i) => {\n\t\t\tlet total = 0;\n\t\t\tthis.data.datasets.map(e => {\n\t\t\t\ttotal += e.values[i];\n\t\t\t});\n\t\t\treturn [total, label];\n\t\t}).filter(d => { return d[0] >= 0; }); // keep only positive results\n\n\t\tlet totals = allTotals;\n\t\tif(allTotals.length > maxSlices) {\n\t\t\t// Prune and keep a grey area for rest as per maxSlices\n\t\t\tallTotals.sort((a, b) => { return b[0] - a[0]; });\n\n\t\t\ttotals = allTotals.slice(0, maxSlices-1);\n\t\t\tlet remaining = allTotals.slice(maxSlices-1);\n\n\t\t\tlet sumOfRemaining = 0;\n\t\t\tremaining.map(d => {sumOfRemaining += d[0];});\n\t\t\ttotals.push([sumOfRemaining, 'Rest']);\n\t\t\tthis.colors[maxSlices-1] = 'grey';\n\t\t}\n\n\t\ts.labels = [];\n\t\ttotals.map(d => {\n\t\t\ts.sliceTotals.push(d[0]);\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${s.labels[i]}: ${d}`\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 80;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class PieChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'pie';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius = (this.height > this.width ? this.center.x : this.center.y);\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath = makeArcPathStr(curStart, curEnd, this.center, this.radius, this.clockWise);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\txTranslate: s.domainConfigs\n\t\t\t\t\t.filter((config, j) => j < i)\n\t\t\t\t\t.map(config => config.cols.length - lessCol)\n\t\t\t\t\t.reduce((a, b) => a + b, 0)\n\t\t\t\t\t* COL_WIDTH\n\t\t\t},\n\t\t\tfunction() {\n\t\t\t\treturn s.domainConfigs[i];\n\t\t\t}.bind(this)\n\n\t\t]);\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map((args, i) => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0] + '-' + i, component];\n\t\t\t})\n\t\t);\n\n\t\tlet y = 0;\n\t\tDAY_NAMES_SHORT.forEach((dayName, i) => {\n\t\t\tif([1, 3, 5].includes(i)) {\n\t\t\t\tlet dayText = makeText('subdomain-name', -COL_WIDTH/2, y, dayName,\n\t\t\t\t\t{\n\t\t\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\t\t\tdy: 8,\n\t\t\t\t\t\ttextAnchor: 'end'\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tthis.drawArea.appendChild(dayText);\n\t\t\t}\n\t\t\ty += ROW_HEIGHT;\n\t\t});\n\t}\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\n\t\tthis.data = this.prepareData(data);\n\t\tthis.draw();\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tthis.components.forEach(comp => {\n\t\t\t\tlet daySquares = comp.store;\n\t\t\t\tlet daySquare = e.target;\n\t\t\t\tif(daySquares.includes(daySquare)) {\n\n\t\t\t\t\tlet count = daySquare.getAttribute('data-value');\n\t\t\t\t\tlet dateParts = daySquare.getAttribute('data-date').split('-');\n\n\t\t\t\t\tlet month = getMonthName(parseInt(dateParts[1])-1, true);\n\n\t\t\t\t\tlet gOff = this.container.getBoundingClientRect(), pOff = daySquare.getBoundingClientRect();\n\n\t\t\t\t\tlet width = parseInt(e.target.getAttribute('width'));\n\t\t\t\t\tlet x = pOff.left - gOff.left + width/2;\n\t\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\t\tlet value = count + ' ' + this.countLabel;\n\t\t\t\t\tlet name = ' on ' + month + ' ' + dateParts[0] + ', ' + dateParts[2];\n\n\t\t\t\t\tthis.tip.setValues(x, y, {name: name, value: value, valueFirst: 1}, []);\n\t\t\t\t\tthis.tip.showTip();\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\trenderLegend() {\n\t\tthis.legendArea.textContent = '';\n\t\tlet x = 0;\n\t\tlet y = ROW_HEIGHT;\n\n\t\tlet lessText = makeText('subdomain-name', x, y, 'Less',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tx = (COL_WIDTH * 2) + COL_WIDTH/2;\n\t\tthis.legendArea.appendChild(lessText);\n\n\t\tthis.colors.slice(0, HEATMAP_DISTRIBUTION_SIZE).map((color, i) => {\n\t\t\tconst square = heatSquare('heatmap-legend-unit', x + (COL_WIDTH + 3) * i,\n\t\t\t\ty, HEATMAP_SQUARE_SIZE, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n\t\tsuper.configure(options);\n\n\t\toptions.axisOptions = options.axisOptions || {};\n\t\toptions.tooltipOptions = options.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = options.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = options.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = options.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\tcalcYAxisParameters(dataValues, withMinimum = 'false') {\n\t\tconst yPts = calcChartIntervals(dataValues, withMinimum);\n\t\tconst scaleMultiplier = this.height / getValueRange(yPts);\n\t\tconst intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n\t\tconst zeroLine = this.height - (getZeroIndex(yPts) * intervalHeight);\n\n\t\tthis.state.yAxis = {\n\t\t\tlabels: yPts,\n\t\t\tpositions: yPts.map(d => zeroLine - d * scaleMultiplier),\n\t\t\tscaleMultiplier: scaleMultiplier,\n\t\t\tzeroLine: zeroLine,\n\t\t};\n\n\t\t// Dependent if above changes\n\t\tthis.calcDatasetPoints();\n\t\tthis.calcYExtremes();\n\t\tthis.calcYRegions();\n\t}\n\n\tcalcDatasetPoints() {\n\t\tlet s = this.state;\n\t\tlet scaleAll = values => values.map(val => scale(val, s.yAxis));\n\n\t\ts.datasets = this.data.datasets.map((d, i) => {\n\t\t\tlet values = d.values;\n\t\t\tlet cumulativeYs = d.cumulativeYs || [];\n\t\t\treturn {\n\t\t\t\tname: d.name,\n\t\t\t\tindex: i,\n\t\t\t\tchartType: d.chartType,\n\n\t\t\t\tvalues: values,\n\t\t\t\tyPositions: scaleAll(values),\n\n\t\t\t\tcumulativeYs: cumulativeYs,\n\t\t\t\tcumulativeYPos: scaleAll(cumulativeYs),\n\t\t\t};\n\t\t});\n\t}\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n\tgetAllYValues() {\n\t\tlet key = 'values';\n\n\t\tif(this.barOptions.stacked) {\n\t\t\tkey = 'cumulativeYs';\n\t\t\tlet cumulative = new Array(this.state.datasetLength).fill(0);\n\t\t\tthis.data.datasets.map((d, i) => {\n\t\t\t\tlet values = this.data.datasets[i].values;\n\t\t\t\td[key] = cumulative = cumulative.map((c, i) => c + values[i]);\n\t\t\t});\n\t\t}\n\n\t\tlet allValueLists = this.data.datasets.map(d => d[key]);\n\t\tif(this.data.yMarkers) {\n\t\t\tallValueLists.push(this.data.yMarkers.map(d => d.value));\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.data.yRegions.map(d => {\n\t\t\t\tallValueLists.push([d.end, d.start]);\n\t\t\t});\n\t\t}\n\n\t\treturn [].concat(...allValueLists);\n\t}\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'yAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.yAxisMode,\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'xAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.xAxisMode,\n\t\t\t\t\theight: this.height,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\ts.xAxis.calcLabels = getShortenedLabels(this.width,\n\t\t\t\t\t\ts.xAxis.labels, this.config.xIsSeries);\n\n\t\t\t\t\treturn s.xAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'yRegions',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yRegions;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\t\t];\n\n\t\tlet barDatasets = this.state.datasets.filter(d => d.chartType === 'bar');\n\t\tlet lineDatasets = this.state.datasets.filter(d => d.chartType === 'line');\n\n\t\tlet barsConfigs = barDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'barGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tstacked: this.barOptions.stacked,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t\tminHeight: this.height * MIN_BAR_PERCENT_HEIGHT,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet stacked = this.barOptions.stacked;\n\n\t\t\t\t\tlet spaceRatio = this.barOptions.spaceRatio || BAR_CHART_SPACE_RATIO;\n\t\t\t\t\tlet barsWidth = s.unitWidth/2 * (2 - spaceRatio);\n\t\t\t\t\tlet barWidth = barsWidth/(stacked ? 1 : barDatasets.length);\n\n\t\t\t\t\tlet xPositions = s.xAxis.positions.map(x => x - barsWidth/2);\n\t\t\t\t\tif(!stacked) {\n\t\t\t\t\t\txPositions = xPositions.map(p => p + barWidth * index);\n\t\t\t\t\t}\n\n\t\t\t\t\tlet labels = new Array(s.datasetLength).fill('');\n\t\t\t\t\tif(this.config.valuesOverPoints) {\n\t\t\t\t\t\tif(stacked && d.index === s.datasets.length - 1) {\n\t\t\t\t\t\t\tlabels = d.cumulativeYs;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tlabels = d.values;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet offsets = new Array(s.datasetLength).fill(0);\n\t\t\t\t\tif(stacked) {\n\t\t\t\t\t\toffsets = d.yPositions.map((y, j) => y - d.cumulativeYPos[j]);\n\t\t\t\t\t}\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: xPositions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\t\t\t\t\t\toffsets: offsets,\n\t\t\t\t\t\t// values: d.values,\n\t\t\t\t\t\tlabels: labels,\n\n\t\t\t\t\t\tzeroLine: s.yAxis.zeroLine,\n\t\t\t\t\t\tbarsWidth: barsWidth,\n\t\t\t\t\t\tbarWidth: barWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet lineConfigs = lineDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'lineGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tsvgDefs: this.svgDefs,\n\t\t\t\t\theatline: this.lineOptions.heatline,\n\t\t\t\t\tregionFill: this.lineOptions.regionFill,\n\t\t\t\t\thideDots: this.lineOptions.hideDots,\n\t\t\t\t\thideLine: this.lineOptions.hideLine,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet minLine = s.yAxis.positions[0] < s.yAxis.zeroLine\n\t\t\t\t\t\t? s.yAxis.positions[0] : s.yAxis.zeroLine;\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xAxis.positions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\n\t\t\t\t\t\tvalues: d.values,\n\n\t\t\t\t\t\tzeroLine: minLine,\n\t\t\t\t\t\tradius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tlet dbi = this.dataByIndex[index];\n\n\t\tthis.tip.setValues(\n\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\tdbi.values,\n\t\t\tindex\n\t\t);\n\n\t\tthis.tip.showTip();\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name);\n\t\t\t\tthis.legendArea.appendChild(rect);\n\t\t\t});\n\t\t}\n\t}\n\n\n\n\t// Overlay\n\tmakeOverlay() {\n\t\tif(this.init) {\n\t\t\tthis.init = 0;\n\t\t\treturn;\n\t\t}\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\n\t\tthis.overlayGuides = this.dataUnitComponents.map(c => {\n\t\t\treturn {\n\t\t\t\ttype: c.unitType,\n\t\t\t\toverlay: undefined,\n\t\t\t\tunits: c.units,\n\t\t\t};\n\t\t});\n\n\t\tif(this.state.currentIndex === undefined) {\n\t\t\tthis.state.currentIndex = this.state.datasetLength - 1;\n\t\t}\n\n\t\t// Render overlays\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\n\t\t\td.overlay = makeOverlay[d.type](currentUnit);\n\t\t\tthis.drawArea.appendChild(d.overlay);\n\t\t});\n\t}\n\n\tupdateOverlayGuides() {\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\t}\n\n\tbindOverlay() {\n\t\tthis.parent.addEventListener('data-select', () => {\n\t\t\tthis.updateOverlay();\n\t\t});\n\t}\n\n\tbindUnits() {\n\t\tthis.dataUnitComponents.map(c => {\n\t\t\tc.units.map(unit => {\n\t\t\t\tunit.addEventListener('click', () => {\n\t\t\t\t\tlet index = unit.getAttribute('data-point-index');\n\t\t\t\t\tthis.setCurrentDataPoint(index);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\t// Note: Doesn't work as tooltip is absolutely positioned\n\t\tthis.tip.container.addEventListener('click', () => {\n\t\t\tlet index = this.tip.container.getAttribute('data-point-index');\n\t\t\tthis.setCurrentDataPoint(index);\n\t\t});\n\t}\n\n\tupdateOverlay() {\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\t\t\tupdateOverlay[d.type](currentUnit, d.overlay);\n\t\t});\n\t}\n\n\tonLeftArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex - 1);\n\t}\n\n\tonRightArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex + 1);\n\t}\n\n\tgetDataPoint(index=this.state.currentIndex) {\n\t\tlet s = this.state;\n\t\tlet data_point = {\n\t\t\tindex: index,\n\t\t\tlabel: s.xAxis.labels[index],\n\t\t\tvalues: s.datasets.map(d => d.values[index])\n\t\t};\n\t\treturn data_point;\n\t}\n\n\tsetCurrentDataPoint(index) {\n\t\tlet s = this.state;\n\t\tindex = parseInt(index);\n\t\tif(index < 0) index = 0;\n\t\tif(index >= s.xAxis.labels.length) index = s.xAxis.labels.length - 1;\n\t\tif(index === s.currentIndex) return;\n\t\ts.currentIndex = index;\n\t\tfire(this.parent, \"data-select\", this.getDataPoint());\n\t}\n\n\n\n\t// API\n\taddDataPoint(label, datasetValues, index=this.state.datasetLength) {\n\t\tsuper.addDataPoint(label, datasetValues, index);\n\t\tthis.data.labels.splice(index, 0, label);\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\td.values.splice(index, 0, datasetValues[i]);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tremoveDataPoint(index = this.state.datasetLength-1) {\n\t\tif (this.data.labels.length <= 1) {\n\t\t\treturn;\n\t\t}\n\t\tsuper.removeDataPoint(index);\n\t\tthis.data.labels.splice(index, 1);\n\t\tthis.data.datasets.map(d => {\n\t\t\td.values.splice(index, 1);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tupdateDataset(datasetValues, index=0) {\n\t\tthis.data.datasets[index].values = datasetValues;\n\t\tthis.update(this.data);\n\t}\n\t// addDataset(dataset, index) {}\n\t// removeDataset(index = 0) {}\n\n\tupdateDatasets(datasets) {\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\tif(datasets[i]) {\n\t\t\t\td.values = datasets[i];\n\t\t\t}\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\t// updateDataPoint(dataPoint, index = 0) {}\n\t// addDataPoint(dataPoint, index = 0) {}\n\t// removeDataPoint(index = 0) {}\n}\n","import * as Charts from './chart';\n\nlet frappe = { };\n\nfrappe.NAME = 'Frappe Charts';\nfrappe.VERSION = '1.1.0';\n\nfrappe = Object.assign({ }, frappe, Charts);\n\nexport default frappe;"],"names":["$","expr","con","document","querySelector","getOffset","element","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isElementInViewport","el","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","type","properties","evt","createEvent","initEvent","j","dispatchEvent","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","legendHeight","getExtraWidth","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","Math","abs","fill","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","ANGLE_RATIO","cos","getBarHeightAndYAttr","yTop","zeroLine","height","y","equilizeNoOfElements","array1","array2","extraCount","limitColor","r","lightenDarkenColor","color","amt","col","getColor","usePound","slice","num","parseInt","b","g","toString","isValidColor","test","createSVG","tag","o","createElementNS","i","val","appendChild","ref","parentNode","insertBefore","keys","map","style","prop","setAttribute","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","opacity","makeSVGContainer","parent","className","width","makeSVGDefs","svgContainer","makeSVGGroup","transform","undefined","args","inside","makePath","pathStr","makeArcPathStr","startPosition","endPosition","center","clockWise","arcStartX","x","arcStartY","arcEndX","arcEndY","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","PERCENTAGE_BAR_DEFAULT_DEPTH","heatSquare","size","data","key","legendBar","label","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","stroke","BASE_LINE_COLOR","l","LABEL_MARGIN","line","makeHoriLine","x1","x2","lineType","yLine","pos","mode","AXIS_TICK_LENGTH","xLine","yMarker","labelPos","labelSvg","yRegion","region","datasetBar","index","meta","minHeight","datasetDot","dot","getPaths","xList","yList","pointsStr","join","path","heatline","gradient_id","svgDefs","paths","regionFill","gradient_id_region","translate","unit","oldCoord","newCoord","duration","old","STD_EASING","translateVertLine","newX","oldX","MARKER_LINE_ANIM_DUR","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","childNodes","stroke-dasharray","getAttribute","animateBar","bar","nodeName","UNIT_ANIM_DUR","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","PATH_ANIM_DUR","push","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","animateSVGElement","props","dur","easingType","oldValues","animElement","cloneNode","newElement","attributeName","animateElement","currentValue","value","animAttr","EASING","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","REPLACE_ALL_NEW_DUR","downloadFile","filename","a","createElement","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","create","CSSTEXT","firstChild","container","innerHTML","treatAsUtc","date","result","Date","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","getTime","getWeeksBetween","startDate","endDate","weekStartDate","setDayToSunday","ceil","getDaysBetween","NO_OF_DAYS_IN_WEEK","millisecondsPerDay","SEC_IN_DAY","NO_OF_MILLIS","areInSameMonth","getMonthName","short","monthName","MONTH_NAMES","getLastDateInMonth","month","year","newDate","day","getDay","addDays","numberOfDays","setDate","getComponent","name","constants","getData","Object","componentConfigs","filter","includes","k","config","assign","ChartComponent","normalize","isNaN","mantissa","exponent","sig","isFinite","exp","floor","log10","pow","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","values","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","withMinimum","pseudoMaxValue","pseudoMinValue","reverse","getZeroIndex","yPts","interval","getIntervalSize","indexOf","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","reduce","prev","curr","calcDistribution","distributionSize","dataMaxValue","distributionStep","distribution","checkpoint","getMaxCheckpoint","dataPrep","labels","datasetLength","datasets","zeroArray","overridingType","AXIS_DATASET_CHART_TYPES","vals","chartType","AXIS_CHART_DEFAULT_TYPE","yRegions","end","zeroDataPrep","realData","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedSpace","allowedLetters","DEFAULT_CHAR_WIDTH","getChartByType","AxisChart","chartTypes","error","addEventListener","e","BASE_MEASURES","INIT_CHART_UPDATE_TIMEOUT","DEFAULT_CHART_COLORS","DEFAULT_COLORS","PI","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","title","dataPointList","set","_this2","formatted","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BOUND_DRAW_FN","BaseChart","HTMLElement","Error","rawChartArgs","prepareData","prepareFirstData","validateColors","isNavigable","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","bind","draw","removeEventListener","makeContainer","updateWidth","independentWidth","overflow","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","c","_this","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","animate","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","_this3","event","keyCode","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","divisor","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","_this4","_this5","newOptions","startPos","endPos","_this6","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","barWidth","offsets","barsWidth","newXPos","newYPos","newOffsets","oldXPos","oldYPos","oldOffsets","hideLine","hideDots","valuesOverPoints","newValues","PercentageChart","barOptions","component","xPos","bars","get","gOff","pOff","formattedLabels","fraction","setValues","showTip","PieChart","mouseMove","mouseLeave","hoverRadio","startAngle","prevSlicesProperties","slicesProperties","curAngle","originDiffAngle","diffAngle","endAngle","prevProperty","curStart","curEnd","curPath","property","flag","calTranslateByAngle","g_off","pageX","pageY","formatted_labels","percent","slices","prevIndex","curActiveSliceIndex","prevAcitve","curActiveSlice","hoverSlice","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","ROW_HEIGHT","HEATMAP_SQUARE_SIZE","spacing","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","COL_WIDTH","moreText","HEATMAP_DISTRIBUTION_SIZE","startMonth","startYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","lineOptions","axisOptions","tooltipOptions","xAxisMode","yAxisMode","xIsSeries","formatTooltipX","formatTooltipY","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","xAxis","dataValues","intervalHeight","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","cumulativeYs","stacked","yExtremes","cumulativeYPos","cumulative","allValueLists","barDatasets","lineDatasets","barsConfigs","spaceRatio","p","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","_this7","setCurrentDataPoint","_this9","_this10","getDataPoint","datasetValues","splice","Chart","frappe","NAME","VERSION","Charts"],"mappings":"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"}
\ No newline at end of file
+{"version":3,"file":"frappe-charts.min.iife.js","sources":["../src/js/utils/dom.js","../src/js/utils/constants.js","../src/js/utils/helpers.js","../src/js/utils/draw-utils.js","../src/js/utils/colors.js","../src/js/utils/draw.js","../src/js/utils/animate.js","../src/js/utils/animation.js","../src/js/utils/export.js","../src/js/utils/date-utils.js","../src/js/objects/ChartComponents.js","../src/js/utils/intervals.js","../src/js/utils/axis-chart-utils.js","../src/js/chart.js","../src/js/objects/SvgTip.js","../src/css/chartsCss.js","../src/js/charts/BaseChart.js","../src/js/charts/AggregationChart.js","../src/js/charts/PercentageChart.js","../src/js/charts/PieChart.js","../src/js/charts/Heatmap.js","../src/js/charts/AxisChart.js","../src/js/index.js"],"sourcesContent":["export function $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function findNodeIndex(node)\n{\n\tvar i = 0;\n\twhile (node.previousSibling) {\n\t\tnode = node.previousSibling;\n\t\ti++;\n\t}\n\treturn i;\n}\n\n$.create = (tag, o) => {\n\tvar element = document.createElement(tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"onClick\" ) {\n\t\t\telement.addEventListener('click', val);\n\n\t\t} else if (i === \"onInput\" ) {\n\t\t\telement.addEventListener('input', function(e) {\n\t\t\t\tval(element.value);\n\t\t\t});\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else if (i in element ) {\n\t\t\telement[i] = val;\n\t\t}\n\t\telse {\n\t\t\telement.setAttribute(i, val);\n\t\t}\n\t}\n\n\treturn element;\n};\n\nexport function getOffset(element) {\n\tlet rect = element.getBoundingClientRect();\n\treturn {\n\t\t// https://stackoverflow.com/a/7436602/6495043\n\t\t// rect.top varies with scroll, so we add whatever has been\n\t\t// scrolled to it to get absolute distance from actual page top\n\t\ttop: rect.top + (document.documentElement.scrollTop || document.body.scrollTop),\n\t\tleft: rect.left + (document.documentElement.scrollLeft || document.body.scrollLeft)\n\t};\n}\n\nexport function isElementInViewport(el) {\n\t// Although straightforward: https://stackoverflow.com/a/7557433/6495043\n\tvar rect = el.getBoundingClientRect();\n\n\treturn (\n\t\trect.top >= 0 &&\n rect.left >= 0 &&\n rect.bottom <= (window.innerHeight || document.documentElement.clientHeight) && /*or $(window).height() */\n rect.right <= (window.innerWidth || document.documentElement.clientWidth) /*or $(window).width() */\n\t);\n}\n\nexport function getElementContentWidth(element) {\n\tvar styles = window.getComputedStyle(element);\n\tvar padding = parseFloat(styles.paddingLeft) +\n\t\tparseFloat(styles.paddingRight);\n\n\treturn element.clientWidth - padding;\n}\n\nexport function bind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function (event) {\n\t\t\t\telement.addEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function unbind(element, o){\n\tif (element) {\n\t\tfor (var event in o) {\n\t\t\tvar callback = o[event];\n\n\t\t\tevent.split(/\\s+/).forEach(function(event) {\n\t\t\t\telement.removeEventListener(event, callback);\n\t\t\t});\n\t\t}\n\t}\n}\n\nexport function fire(target, type, properties) {\n\tvar evt = document.createEvent(\"HTMLEvents\");\n\n\tevt.initEvent(type, true, true );\n\n\tfor (var j in properties) {\n\t\tevt[j] = properties[j];\n\t}\n\n\treturn target.dispatchEvent(evt);\n}\n\n// https://css-tricks.com/snippets/javascript/loop-queryselectorall-matches/\nexport function forEachNode(nodeList, callback, scope) {\n\tif(!nodeList) return;\n\tfor (var i = 0; i < nodeList.length; i++) {\n\t\tcallback.call(scope, nodeList[i], i);\n\t}\n}\n\nexport function activate($parent, $child, commonSelector, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`${commonSelector}.${activeClass}`);\n\n\tif (typeof $child === 'string') {\n\t\t$child = $parent.querySelector($child);\n\t}\n\n\tthis.forEachNode($children, (node, i) => {\n\t\tif(index >= 0 && i <= index) return;\n\t\tnode.classList.remove(activeClass);\n\t})\n\n\t$child.classList.add(activeClass);\n}\n\nexport function insertAfter(newNode, referenceNode) {\n referenceNode.parentNode.insertBefore(newNode, referenceNode.nextSibling);\n}\n","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const AXIS_CHART_DEFAULT_TYPE = 'line';\nexport const AXIS_CHART_MIXED_TYPE = 'axis-mixed';\nexport const AXIS_CHART_TYPES = ['line', 'bar', 'axis-mixed'];\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_CHART_OPTIONS = {\n\tbarOptions: {\n\t\tspaceRatio: 1,\n\t}\n}\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 1;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.02;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\nexport function toTitleCase(str) {\n return str.replace(/\\w*/g, function(txt){return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();});\n}\n","import { fillArray } from './helpers';\n\nexport function getBarHeightAndYAttr(yTop, zeroLine) {\n\tlet height, y;\n\tif (yTop <= zeroLine) {\n\t\theight = zeroLine - yTop;\n\t\ty = yTop;\n\t} else {\n\t\theight = yTop - zeroLine;\n\t\ty = zeroLine;\n\t}\n\n\treturn [height, y];\n}\n\nexport function equilizeNoOfElements(array1, array2,\n\textraCount = array2.length - array1.length) {\n\n\t// Doesn't work if either has zero elements.\n\tif(extraCount > 0) {\n\t\tarray1 = fillArray(array1, extraCount);\n\t} else {\n\t\tarray2 = fillArray(array2, extraCount);\n\t}\n\treturn [array1, array2];\n}\n","const PRESET_COLOR_MAP = {\n\t'light-blue': '#7cd6fd',\n\t'blue': '#5e64ff',\n\t'violet': '#743ee2',\n\t'red': '#ff5858',\n\t'orange': '#ffa00a',\n\t'yellow': '#feef72',\n\t'green': '#28a745',\n\t'light-green': '#98d85b',\n\t'purple': '#b554ff',\n\t'magenta': '#ffa3ef',\n\t'black': '#36114C',\n\t'grey': '#bdd3e6',\n\t'light-grey': '#f0f4f7',\n\t'dark-grey': '#b8c2cc'\n};\n\nfunction limitColor(r){\n\tif (r > 255) return 255;\n\telse if (r < 0) return 0;\n\treturn r;\n}\n\nexport function lightenDarkenColor(color, amt) {\n\tlet col = getColor(color);\n\tlet usePound = false;\n\tif (col[0] == \"#\") {\n\t\tcol = col.slice(1);\n\t\tusePound = true;\n\t}\n\tlet num = parseInt(col,16);\n\tlet r = limitColor((num >> 16) + amt);\n\tlet b = limitColor(((num >> 8) & 0x00FF) + amt);\n\tlet g = limitColor((num & 0x0000FF) + amt);\n\treturn (usePound?\"#\":\"\") + (g | (b << 8) | (r << 16)).toString(16);\n}\n\nexport function isValidColor(string) {\n\t// https://stackoverflow.com/a/8027444/6495043\n\treturn /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(string);\n}\n\nexport const getColor = (color) => {\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\nimport { getStringWidth } from './helpers';\nimport { DOT_OVERLAY_SIZE_INCR, PERCENTAGE_BAR_DEFAULT_DEPTH } from './constants';\nimport { lightenDarkenColor } from './colors';\n\nexport const AXIS_TICK_LENGTH = 6;\nconst LABEL_MARGIN = 4;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none') {\n\treturn createSVG('path', {\n\t\tclassName: className,\n\t\td: pathStr,\n\t\tstyles: {\n\t\t\tstroke: stroke,\n\t\t\tfill: fill\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, arcEndY] = [center.x + endPosition.x, center.y + endPosition.y];\n\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 0 ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeGradient(svgDefElem, color, lighter = false) {\n\tlet gradientId ='path-fill-gradient' + '-' + color + '-' +(lighter ? 'lighter' : 'default');\n\tlet gradientDef = renderVerticalGradient(svgDefElem, gradientId);\n\tlet opacities = [1, 0.6, 0.2];\n\tif(lighter) {\n\t\topacities = [0.4, 0.2, 0];\n\t}\n\n\tsetGradientStop(gradientDef, \"0%\", color, opacities[0]);\n\tsetGradientStop(gradientDef, \"50%\", color, opacities[1]);\n\tsetGradientStop(gradientDef, \"100%\", color, opacities[2]);\n\n\treturn gradientId;\n}\n\nexport function percentageBar(x, y, width, height,\n\tdepth=PERCENTAGE_BAR_DEFAULT_DEPTH, fill='none') {\n\n\tlet args = {\n\t\tclassName: 'percentage-bar',\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height,\n\t\tfill: fill,\n\t\tstyles: {\n\t\t\t'stroke': lightenDarkenColor(fill, -25),\n\t\t\t// Diabolically good: https://stackoverflow.com/a/9000859\n\t\t\t// https://developer.mozilla.org/en-US/docs/Web/SVG/Attribute/stroke-dasharray\n\t\t\t'stroke-dasharray': `0, ${height + width}, ${width}, ${height}`,\n\t\t\t'stroke-width': depth\n\t\t},\n\t};\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function heatSquare(className, x, y, size, fill='none', data={}) {\n\tlet args = {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: size,\n\t\theight: size,\n\t\tfill: fill\n\t};\n\n\tObject.keys(data).map(key => {\n\t\targs[key] = data[key];\n\t});\n\n\treturn createSVG(\"rect\", args);\n}\n\nexport function legendBar(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-bar',\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: size,\n\t\theight: '2px',\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE * 2) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"rect\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function legendDot(x, y, size, fill='none', label) {\n\tlet args = {\n\t\tclassName: 'legend-dot',\n\t\tcx: 0,\n\t\tcy: 0,\n\t\tr: size,\n\t\tfill: fill\n\t};\n\tlet text = createSVG('text', {\n\t\tclassName: 'legend-dataset-text',\n\t\tx: 0,\n\t\ty: 0,\n\t\tdx: (FONT_SIZE) + 'px',\n\t\tdy: (FONT_SIZE/3) + 'px',\n\t\t'font-size': (FONT_SIZE * 1.2) + 'px',\n\t\t'text-anchor': 'start',\n\t\tfill: FONT_FILL,\n\t\tinnerHTML: label\n\t});\n\n\tlet group = createSVG('g', {\n\t\ttransform: `translate(${x}, ${y})`\n\t});\n\tgroup.appendChild(createSVG(\"circle\", args));\n\tgroup.appendChild(text);\n\n\treturn group;\n}\n\nexport function makeText(className, x, y, content, options = {}) {\n\tlet fontSize = options.fontSize || FONT_SIZE;\n\tlet dy = options.dy !== undefined ? options.dy : (fontSize / 2);\n\tlet fill = options.fill || FONT_FILL;\n\tlet textAnchor = options.textAnchor || 'start';\n\treturn createSVG('text', {\n\t\tclassName: className,\n\t\tx: x,\n\t\ty: y,\n\t\tdy: dy + 'px',\n\t\t'font-size': fontSize + 'px',\n\t\tfill: fill,\n\t\t'text-anchor': textAnchor,\n\t\tinnerHTML: content\n\t});\n}\n\nfunction makeVertLine(x, label, y1, y2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tlet l = createSVG('line', {\n\t\tclassName: 'line-vertical ' + options.className,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: y1,\n\t\ty2: y2,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: 0,\n\t\ty: y1 > y2 ? y1 + LABEL_MARGIN : y1 - LABEL_MARGIN - FONT_SIZE,\n\t\tdy: FONT_SIZE + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'middle',\n\t\tinnerHTML: label + \"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(${ x }, 0)`\n\t});\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nfunction makeHoriLine(y, label, x1, x2, options={}) {\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.lineType) options.lineType = '';\n\tlet className = 'line-horizontal ' + options.className +\n\t\t(options.lineType === \"dashed\" ? \"dashed\": \"\");\n\n\tlet l = createSVG('line', {\n\t\tclassName: className,\n\t\tx1: x1,\n\t\tx2: x2,\n\t\ty1: 0,\n\t\ty2: 0,\n\t\tstyles: {\n\t\t\tstroke: options.stroke\n\t\t}\n\t});\n\n\tlet text = createSVG('text', {\n\t\tx: x1 < x2 ? x1 - LABEL_MARGIN : x1 + LABEL_MARGIN,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / 2 - 2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': x1 < x2 ? 'end' : 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = createSVG('g', {\n\t\ttransform: `translate(0, ${y})`,\n\t\t'stroke-opacity': 1\n\t});\n\n\tif(text === 0 || text === '0') {\n\t\tline.style.stroke = \"rgba(27, 31, 35, 0.6)\";\n\t}\n\n\tline.appendChild(l);\n\tline.appendChild(text);\n\n\treturn line;\n}\n\nexport function yLine(y, label, width, options={}) {\n\tif(!options.pos) options.pos = 'left';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\tlet x1 = -1 * AXIS_TICK_LENGTH;\n\tlet x2 = options.mode === 'span' ? width + AXIS_TICK_LENGTH : 0;\n\n\tif(options.mode === 'tick' && options.pos === 'right') {\n\t\tx1 = width + AXIS_TICK_LENGTH;\n\t\tx2 = width;\n\t}\n\n\t// let offset = options.pos === 'left' ? -1 * options.offset : options.offset;\n\n\tx1 += options.offset;\n\tx2 += options.offset;\n\n\treturn makeHoriLine(y, label, x1, x2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.areaFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr } from './draw-utils';\n\nexport const UNIT_ANIM_DUR = 350;\nexport const PATH_ANIM_DUR = 350;\nexport const MARKER_LINE_ANIM_DUR = UNIT_ANIM_DUR;\nexport const REPLACE_ALL_NEW_DUR = 250;\n\nexport const STD_EASING = 'easein';\n\nexport function translate(unit, oldCoord, newCoord, duration) {\n\tlet old = typeof oldCoord === 'string' ? oldCoord : oldCoord.join(', ');\n\treturn [\n\t\tunit,\n\t\t{transform: newCoord.join(', ')},\n\t\tduration,\n\t\tSTD_EASING,\n\t\t\"translate\",\n\t\t{transform: old}\n\t];\n}\n\nexport function translateVertLine(xLine, newX, oldX) {\n\treturn translate(xLine, [oldX, 0], [newX, 0], MARKER_LINE_ANIM_DUR);\n}\n\nexport function translateHoriLine(yLine, newY, oldY) {\n\treturn translate(yLine, [0, oldY], [0, newY], MARKER_LINE_ANIM_DUR);\n}\n\nexport function animateRegion(rectGroup, newY1, newY2, oldY2) {\n\tlet newHeight = newY1 - newY2;\n\tlet rect = rectGroup.childNodes[0];\n\tlet width = rect.getAttribute(\"width\");\n\tlet rectAnim = [\n\t\trect,\n\t\t{ height: newHeight, 'stroke-dasharray': `${width}, ${newHeight}` },\n\t\tMARKER_LINE_ANIM_DUR,\n\t\tSTD_EASING\n\t];\n\n\tlet groupAnim = translate(rectGroup, [0, oldY2], [0, newY2], MARKER_LINE_ANIM_DUR);\n\treturn [rectAnim, groupAnim];\n}\n\nexport function animateBar(bar, x, yTop, width, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\tif(bar.nodeName !== 'rect') {\n\t\tlet rect = bar.childNodes[0];\n\t\tlet rectAnim = [\n\t\t\trect,\n\t\t\t{width: width, height: height},\n\t\t\tUNIT_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\n\t\tlet oldCoordStr = bar.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(bar, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [rectAnim, groupAnim];\n\t} else {\n\t\treturn [[bar, {width: width, height: height, x: x, y: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// bar.animate({height: args.newHeight, y: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animateDot(dot, x, y) {\n\tif(dot.nodeName !== 'circle') {\n\t\tlet oldCoordStr = dot.getAttribute(\"transform\").split(\"(\")[1].slice(0, -1);\n\t\tlet groupAnim = translate(dot, oldCoordStr, [x, y], MARKER_LINE_ANIM_DUR);\n\t\treturn [groupAnim];\n\t} else {\n\t\treturn [[dot, {cx: x, cy: y}, UNIT_ANIM_DUR, STD_EASING]];\n\t}\n\t// dot.animate({cy: yTop}, UNIT_ANIM_DUR, mina.easein);\n}\n\nexport function animatePath(paths, newXList, newYList, zeroLine) {\n\tlet pathComponents = [];\n\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y));\n\tlet pathStr = pointsStr.join(\"L\");\n\n\tconst animPath = [paths.path, {d:\"M\"+pathStr}, PATH_ANIM_DUR, STD_EASING];\n\tpathComponents.push(animPath);\n\n\tif(paths.region) {\n\t\tlet regStartPt = `${newXList[0]},${zeroLine}L`;\n\t\tlet regEndPt = `L${newXList.slice(-1)[0]}, ${zeroLine}`;\n\n\t\tconst animRegion = [\n\t\t\tpaths.region,\n\t\t\t{d:\"M\" + regStartPt + pathStr + regEndPt},\n\t\t\tPATH_ANIM_DUR,\n\t\t\tSTD_EASING\n\t\t];\n\t\tpathComponents.push(animRegion);\n\t}\n\n\treturn pathComponents;\n}\n\nexport function animatePathStr(oldPath, pathStr) {\n\treturn [oldPath, {d: pathStr}, UNIT_ANIM_DUR, STD_EASING];\n}\n","// Leveraging SMIL Animations\n\nimport { REPLACE_ALL_NEW_DUR } from './animate';\n\nconst EASING = {\n\tease: \"0.25 0.1 0.25 1\",\n\tlinear: \"0 0 1 1\",\n\t// easein: \"0.42 0 1 1\",\n\teasein: \"0.1 0.8 0.2 1\",\n\teaseout: \"0 0 0.58 1\",\n\teaseinout: \"0.42 0 0.58 1\"\n};\n\nfunction animateSVGElement(element, props, dur, easingType=\"linear\", type=undefined, oldValues={}) {\n\n\tlet animElement = element.cloneNode(true);\n\tlet newElement = element.cloneNode(true);\n\n\tfor(var attributeName in props) {\n\t\tlet animateElement;\n\t\tif(attributeName === 'transform') {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animateTransform\");\n\t\t} else {\n\t\t\tanimateElement = document.createElementNS(\"http://www.w3.org/2000/svg\", \"animate\");\n\t\t}\n\t\tlet currentValue = oldValues[attributeName] || element.getAttribute(attributeName);\n\t\tlet value = props[attributeName];\n\n\t\tlet animAttr = {\n\t\t\tattributeName: attributeName,\n\t\t\tfrom: currentValue,\n\t\t\tto: value,\n\t\t\tbegin: \"0s\",\n\t\t\tdur: dur/1000 + \"s\",\n\t\t\tvalues: currentValue + \";\" + value,\n\t\t\tkeySplines: EASING[easingType],\n\t\t\tkeyTimes: \"0;1\",\n\t\t\tcalcMode: \"spline\",\n\t\t\tfill: 'freeze'\n\t\t};\n\n\t\tif(type) {\n\t\t\tanimAttr[\"type\"] = type;\n\t\t}\n\n\t\tfor (var i in animAttr) {\n\t\t\tanimateElement.setAttribute(i, animAttr[i]);\n\t\t}\n\n\t\tanimElement.appendChild(animateElement);\n\n\t\tif(type) {\n\t\t\tnewElement.setAttribute(attributeName, `translate(${value})`);\n\t\t} else {\n\t\t\tnewElement.setAttribute(attributeName, value);\n\t\t}\n\t}\n\n\treturn [animElement, newElement];\n}\n\nexport function transform(element, style) { // eslint-disable-line no-unused-vars\n\telement.style.transform = style;\n\telement.style.webkitTransform = style;\n\telement.style.msTransform = style;\n\telement.style.mozTransform = style;\n\telement.style.oTransform = style;\n}\n\nfunction animateSVG(svgContainer, elements) {\n\tlet newElements = [];\n\tlet animElements = [];\n\n\telements.map(element => {\n\t\tlet unit = element[0];\n\t\tlet parent = unit.parentNode;\n\n\t\tlet animElement, newElement;\n\n\t\telement[0] = unit;\n\t\t[animElement, newElement] = animateSVGElement(...element);\n\n\t\tnewElements.push(newElement);\n\t\tanimElements.push([animElement, parent]);\n\n\t\tparent.replaceChild(animElement, unit);\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\telements[i][0] = newElements[i];\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport { makeText, makePath, xLine, yLine, yMarker, yRegion, datasetBar, datasetDot, percentageBar, getPaths, heatSquare } from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport { translateHoriLine, translateVertLine, animateRegion, animateBar,\n\tanimateDot, animatePath, animatePathStr } from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n\tconstructor({\n\t\tlayerClass = '',\n\t\tlayerTransform = '',\n\t\tconstants,\n\n\t\tgetData,\n\t\tmakeElements,\n\t\tanimateElements\n\t}) {\n\t\tthis.layerTransform = layerTransform;\n\t\tthis.constants = constants;\n\n\t\tthis.makeElements = makeElements;\n\t\tthis.getData = getData;\n\n\t\tthis.animateElements = animateElements;\n\n\t\tthis.store = [];\n\t\tthis.labels = [];\n\n\t\tthis.layerClass = layerClass;\n\t\tthis.layerClass = typeof(this.layerClass) === 'function'\n\t\t\t? this.layerClass() : this.layerClass;\n\n\t\tthis.refresh();\n\t}\n\n\trefresh(data) {\n\t\tthis.data = data || this.getData();\n\t}\n\n\tsetup(parent) {\n\t\tthis.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n\t}\n\n\tmake() {\n\t\tthis.render(this.data);\n\t\tthis.oldData = this.data;\n\t}\n\n\trender(data) {\n\t\tthis.store = this.makeElements(data);\n\n\t\tthis.layer.textContent = '';\n\t\tthis.store.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t\tthis.labels.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t}\n\n\tupdate(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tpieSlices: {\n\t\tlayerClass: 'pie-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) =>{\n\t\t\t\tlet slice = makePath(s, 'pie-path', 'none', data.colors[i]);\n\t\t\t\tslice.style.transition = 'transform .3s;';\n\t\t\t\treturn slice;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\treturn this.store.map((slice, i) =>\n\t\t\t\tanimatePathStr(slice, newData.sliceStrings[i])\n\t\t\t);\n\t\t}\n\t},\n\tpercentageBars: {\n\t\tlayerClass: 'percentage-bars',\n\t\tmakeElements(data) {\n\t\t\treturn data.xPositions.map((x, i) =>{\n\t\t\t\tlet y = 0;\n\t\t\t\tlet bar = percentageBar(x, y, data.widths[i],\n\t\t\t\t\tthis.constants.barHeight, this.constants.barDepth, data.colors[i]);\n\t\t\t\treturn bar;\n\t\t\t});\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\tyAxis: {\n\t\tlayerClass: 'y axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\tyLine(position, data.labels[i], this.constants.width,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.labels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tlabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(m =>\n\t\t\t\tyMarker(m.position, m.label, this.constants.width,\n\t\t\t\t\t{labelPos: m.options.labelPos, mode: 'span', lineType: 'dashed'})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, day.fill, data);\n\t\t\t\t\t\tthis.serializedSubDomains.push(square);\n\t\t\t\t\t}\n\t\t\t\t\ty += rowHeight;\n\t\t\t\t});\n\t\t\t\ty = 0;\n\t\t\t\tx += colWidth;\n\t\t\t});\n\n\t\t\treturn this.serializedSubDomains;\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tif(newData) return [];\n\t\t}\n\t},\n\n\tbarGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-bars dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'bar';\n\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\treturn datasetBar(\n\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\ty,\n\t\t\t\t\tdata.barWidth,\n\t\t\t\t\tc.color,\n\t\t\t\t\tdata.labels[j],\n\t\t\t\t\tj,\n\t\t\t\t\tdata.offsets[j],\n\t\t\t\t\t{\n\t\t\t\t\t\tzeroLine: data.zeroLine,\n\t\t\t\t\t\tbarsWidth: data.barsWidth,\n\t\t\t\t\t\tminHeight: c.minHeight\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t});\n\t\t\treturn this.units;\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newOffsets = newData.offsets;\n\t\t\tlet newLabels = newData.labels;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldOffsets = this.oldData.offsets;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldOffsets, newOffsets] = equilizeNoOfElements(oldOffsets, newOffsets);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\toffsets: oldOffsets,\n\t\t\t\tlabels: newLabels,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tbarsWidth: this.oldData.barsWidth,\n\t\t\t\tbarWidth: this.oldData.barWidth,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((bar, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateBar(\n\t\t\t\t\tbar, newXPos[i], newYPos[i], newData.barWidth, newOffsets[i],\n\t\t\t\t\t{zeroLine: newData.zeroLine}\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\tlineGraph: {\n\t\tlayerClass: function() { return 'dataset-units dataset-line dataset-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet c = this.constants;\n\t\t\tthis.unitType = 'dot';\n\t\t\tthis.paths = {};\n\t\t\tif(!c.hideLine) {\n\t\t\t\tthis.paths = getPaths(\n\t\t\t\t\tdata.xPositions,\n\t\t\t\t\tdata.yPositions,\n\t\t\t\t\tc.color,\n\t\t\t\t\t{\n\t\t\t\t\t\theatline: c.heatline,\n\t\t\t\t\t\tareaFill: c.areaFill\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tsvgDefs: c.svgDefs,\n\t\t\t\t\t\tzeroLine: data.zeroLine\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tthis.units = [];\n\t\t\tif(!c.hideDots) {\n\t\t\t\tthis.units = data.yPositions.map((y, j) => {\n\t\t\t\t\treturn datasetDot(\n\t\t\t\t\t\tdata.xPositions[j],\n\t\t\t\t\t\ty,\n\t\t\t\t\t\tdata.radius,\n\t\t\t\t\t\tc.color,\n\t\t\t\t\t\t(c.valuesOverPoints ? data.values[j] : ''),\n\t\t\t\t\t\tj\n\t\t\t\t\t);\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn Object.values(this.paths).concat(this.units);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\tlet newXPos = newData.xPositions;\n\t\t\tlet newYPos = newData.yPositions;\n\t\t\tlet newValues = newData.values;\n\n\t\t\tlet oldXPos = this.oldData.xPositions;\n\t\t\tlet oldYPos = this.oldData.yPositions;\n\t\t\tlet oldValues = this.oldData.values;\n\n\t\t\t[oldXPos, newXPos] = equilizeNoOfElements(oldXPos, newXPos);\n\t\t\t[oldYPos, newYPos] = equilizeNoOfElements(oldYPos, newYPos);\n\t\t\t[oldValues, newValues] = equilizeNoOfElements(oldValues, newValues);\n\n\t\t\tthis.render({\n\t\t\t\txPositions: oldXPos,\n\t\t\t\tyPositions: oldYPos,\n\t\t\t\tvalues: newValues,\n\n\t\t\t\tzeroLine: this.oldData.zeroLine,\n\t\t\t\tradius: this.oldData.radius,\n\t\t\t});\n\n\t\t\tlet animateElements = [];\n\n\t\t\tif(Object.keys(this.paths).length) {\n\t\t\t\tanimateElements = animateElements.concat(animatePath(\n\t\t\t\t\tthis.paths, newXPos, newYPos, newData.zeroLine));\n\t\t\t}\n\n\t\t\tif(this.units.length) {\n\t\t\t\tthis.units.map((dot, i) => {\n\t\t\t\t\tanimateElements = animateElements.concat(animateDot(\n\t\t\t\t\t\tdot, newXPos[i], newYPos[i]));\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn animateElements;\n\t\t}\n\t}\n};\n\nexport function getComponent(name, constants, getData) {\n\tlet keys = Object.keys(componentConfigs).filter(k => name.includes(k));\n\tlet config = componentConfigs[keys[0]];\n\tObject.assign(config, {\n\t\tconstants: constants,\n\t\tgetData: getData\n\t});\n\treturn new ChartComponent(config);\n}\n","import { floatTwo } from './helpers';\n\nfunction normalize(x) {\n\t// Calculates mantissa and exponent of a number\n\t// Returns normalized number and exponent\n\t// https://stackoverflow.com/q/9383593/6495043\n\n\tif(x===0) {\n\t\treturn [0, 0];\n\t}\n\tif(isNaN(x)) {\n\t\treturn {mantissa: -6755399441055744, exponent: 972};\n\t}\n\tvar sig = x > 0 ? 1 : -1;\n\tif(!isFinite(x)) {\n\t\treturn {mantissa: sig * 4503599627370496, exponent: 972};\n\t}\n\n\tx = Math.abs(x);\n\tvar exp = Math.floor(Math.log10(x));\n\tvar man = x/Math.pow(10, exp);\n\n\treturn [sig * man, exp];\n}\n\nfunction getChartRangeIntervals(max, min=0) {\n\tlet upperBound = Math.ceil(max);\n\tlet lowerBound = Math.floor(min);\n\tlet range = upperBound - lowerBound;\n\n\tlet noOfParts = range;\n\tlet partSize = 1;\n\n\t// To avoid too many partitions\n\tif(range > 5) {\n\t\tif(range % 2 !== 0) {\n\t\t\tupperBound++;\n\t\t\t// Recalc range\n\t\t\trange = upperBound - lowerBound;\n\t\t}\n\t\tnoOfParts = range/2;\n\t\tpartSize = 2;\n\t}\n\n\t// Special case: 1 and 2\n\tif(range <= 2) {\n\t\tnoOfParts = 4;\n\t\tpartSize = range/noOfParts;\n\t}\n\n\t// Special case: 0\n\tif(range === 0) {\n\t\tnoOfParts = 5;\n\t\tpartSize = 1;\n\t}\n\n\tlet intervals = [];\n\tfor(var i = 0; i <= noOfParts; i++){\n\t\tintervals.push(lowerBound + partSize * i);\n\t}\n\treturn intervals;\n}\n\nfunction getChartIntervals(maxValue, minValue=0) {\n\tlet [normalMaxValue, exponent] = normalize(maxValue);\n\tlet normalMinValue = minValue ? minValue/Math.pow(10, exponent): 0;\n\n\t// Allow only 7 significant digits\n\tnormalMaxValue = normalMaxValue.toFixed(6);\n\n\tlet intervals = getChartRangeIntervals(normalMaxValue, normalMinValue);\n\tintervals = intervals.map(value => value * Math.pow(10, exponent));\n\treturn intervals;\n}\n\nexport function calcChartIntervals(values, withMinimum=false) {\n\t//*** Where the magic happens ***\n\n\t// Calculates best-fit y intervals from given values\n\t// and returns the interval array\n\n\tlet maxValue = Math.max(...values);\n\tlet minValue = Math.min(...values);\n\n\t// Exponent to be used for pretty print\n\tlet exponent = 0, intervals = []; // eslint-disable-line no-unused-vars\n\n\tfunction getPositiveFirstIntervals(maxValue, absMinValue) {\n\t\tlet intervals = getChartIntervals(maxValue);\n\n\t\tlet intervalSize = intervals[1] - intervals[0];\n\n\t\t// Then unshift the negative values\n\t\tlet value = 0;\n\t\tfor(var i = 1; value < absMinValue; i++) {\n\t\t\tvalue += intervalSize;\n\t\t\tintervals.unshift((-1) * value);\n\t\t}\n\t\treturn intervals;\n\t}\n\n\t// CASE I: Both non-negative\n\n\tif(maxValue >= 0 && minValue >= 0) {\n\t\texponent = normalize(maxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(maxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(maxValue, minValue);\n\t\t}\n\t}\n\n\t// CASE II: Only minValue negative\n\n\telse if(maxValue > 0 && minValue < 0) {\n\t\t// `withMinimum` irrelevant in this case,\n\t\t// We'll be handling both sides of zero separately\n\t\t// (both starting from zero)\n\t\t// Because ceil() and floor() behave differently\n\t\t// in those two regions\n\n\t\tlet absMinValue = Math.abs(minValue);\n\n\t\tif(maxValue >= absMinValue) {\n\t\t\texponent = normalize(maxValue)[1];\n\t\t\tintervals = getPositiveFirstIntervals(maxValue, absMinValue);\n\t\t} else {\n\t\t\t// Mirror: maxValue => absMinValue, then change sign\n\t\t\texponent = normalize(absMinValue)[1];\n\t\t\tlet posIntervals = getPositiveFirstIntervals(absMinValue, maxValue);\n\t\t\tintervals = posIntervals.map(d => d * (-1));\n\t\t}\n\n\t}\n\n\t// CASE III: Both non-positive\n\n\telse if(maxValue <= 0 && minValue <= 0) {\n\t\t// Mirrored Case I:\n\t\t// Work with positives, then reverse the sign and array\n\n\t\tlet pseudoMaxValue = Math.abs(minValue);\n\t\tlet pseudoMinValue = Math.abs(maxValue);\n\n\t\texponent = normalize(pseudoMaxValue)[1];\n\t\tif(!withMinimum) {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue);\n\t\t} else {\n\t\t\tintervals = getChartIntervals(pseudoMaxValue, pseudoMinValue);\n\t\t}\n\n\t\tintervals = intervals.reverse().map(d => d * (-1));\n\t}\n\n\treturn intervals;\n}\n\nexport function getZeroIndex(yPts) {\n\tlet zeroIndex;\n\tlet interval = getIntervalSize(yPts);\n\tif(yPts.indexOf(0) >= 0) {\n\t\t// the range has a given zero\n\t\t// zero-line on the chart\n\t\tzeroIndex = yPts.indexOf(0);\n\t} else if(yPts[0] > 0) {\n\t\t// Minimum value is positive\n\t\t// zero-line is off the chart: below\n\t\tlet min = yPts[0];\n\t\tzeroIndex = (-1) * min / interval;\n\t} else {\n\t\t// Maximum value is negative\n\t\t// zero-line is off the chart: above\n\t\tlet max = yPts[yPts.length - 1];\n\t\tzeroIndex = (-1) * max / interval + (yPts.length - 1);\n\t}\n\treturn zeroIndex;\n}\n\nexport function getRealIntervals(max, noOfIntervals, min = 0, asc = 1) {\n\tlet range = max - min;\n\tlet part = range * 1.0 / noOfIntervals;\n\tlet intervals = [];\n\n\tfor(var i = 0; i <= noOfIntervals; i++) {\n\t\tintervals.push(min + part * i);\n\t}\n\n\treturn asc ? intervals : intervals.reverse();\n}\n\nexport function getIntervalSize(orderedArray) {\n\treturn orderedArray[1] - orderedArray[0];\n}\n\nexport function getValueRange(orderedArray) {\n\treturn orderedArray[orderedArray.length-1] - orderedArray[0];\n}\n\nexport function scale(val, yAxis) {\n\treturn floatTwo(yAxis.zeroLine - val * yAxis.scaleMultiplier);\n}\n\nexport function isInRange(val, min, max) {\n\treturn val > min && val < max;\n}\n\nexport function isInRange2D(coord, minCoord, maxCoord) {\n\treturn isInRange(coord[0], minCoord[0], maxCoord[0])\n\t\t&& isInRange(coord[1], minCoord[1], maxCoord[1]);\n}\n\nexport function getClosestInArray(goal, arr, index = false) {\n\tlet closest = arr.reduce(function(prev, curr) {\n\t\treturn (Math.abs(curr - goal) < Math.abs(prev - goal) ? curr : prev);\n\t});\n\n\treturn index ? arr.indexOf(closest) : closest;\n}\n\nexport function calcDistribution(values, distributionSize) {\n\t// Assume non-negative values,\n\t// implying distribution minimum at zero\n\n\tlet dataMaxValue = Math.max(...values);\n\n\tlet distributionStep = 1 / (distributionSize - 1);\n\tlet distribution = [];\n\n\tfor(var i = 0; i < distributionSize; i++) {\n\t\tlet checkpoint = dataMaxValue * (distributionStep * i);\n\t\tdistribution.push(checkpoint);\n\t}\n\n\treturn distribution;\n}\n\nexport function getMaxCheckpoint(value, distribution) {\n\treturn distribution.filter(d => d < value).length;\n}\n","import { fillArray } from '../utils/helpers';\nimport { AXIS_CHART_DEFAULT_TYPE, AXIS_CHART_MIXED_TYPE, AXIS_DATASET_CHART_TYPES, DEFAULT_CHAR_WIDTH } from '../utils/constants';\n\nexport function dataPrep(data, type) {\n\tdata.labels = data.labels || [];\n\n\tlet datasetLength = data.labels.length;\n\n\t// Datasets\n\tlet datasets = data.datasets;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\tif(!datasets) {\n\t\t// default\n\t\tdatasets = [{\n\t\t\tvalues: zeroArray\n\t\t}];\n\t}\n\n\tlet overridingType;\n\tif(AXIS_DATASET_CHART_TYPES.includes(type)) {\n\t\toverridingType = type;\n\t};\n\n\tdatasets.map(d=> {\n\t\t// Set values\n\t\tif(!d.values) {\n\t\t\td.values = zeroArray;\n\t\t} else {\n\t\t\t// Check for non values\n\t\t\tlet vals = d.values;\n\t\t\tvals = vals.map(val => (!isNaN(val) ? val : 0));\n\n\t\t\t// Trim or extend\n\t\t\tif(vals.length > datasetLength) {\n\t\t\t\tvals = vals.slice(0, datasetLength);\n\t\t\t} else {\n\t\t\t\tvals = fillArray(vals, datasetLength - vals.length, 0);\n\t\t\t}\n\t\t}\n\n\t\t// Set labels\n\n\t\t// Set type\n\t\tif(overridingType) {\n\t\t\td.chartType = overridingType;\n\t\t} else if(!d.chartType) {\n\t\t\td.chartType = AXIS_CHART_DEFAULT_TYPE;\n\t\t}\n\t});\n\n\t// Markers\n\n\t// Regions\n\t// data.yRegions = data.yRegions || [];\n\tif(data.yRegions) {\n\t\tdata.yRegions.map(d => {\n\t\t\tif(d.end < d.start) {\n\t\t\t\t[d.start, d.end] = [d.end, d.start];\n\t\t\t}\n\t\t});\n\t}\n\n\treturn data;\n}\n\nexport function zeroDataPrep(realData) {\n\tlet datasetLength = realData.labels.length;\n\tlet zeroArray = new Array(datasetLength).fill(0);\n\n\tlet zeroData = {\n\t\tlabels: realData.labels.slice(0, -1),\n\t\tdatasets: realData.datasets.map(d => {\n\t\t\treturn {\n\t\t\t\tname: '',\n\t\t\t\tvalues: zeroArray.slice(0, -1),\n\t\t\t\tchartType: d.chartType\n\t\t\t};\n\t\t}),\n\t};\n\n\tif(realData.yMarkers) {\n\t\tzeroData.yMarkers = [\n\t\t\t{\n\t\t\t\tvalue: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\tif(realData.yRegions) {\n\t\tzeroData.yRegions = [\n\t\t\t{\n\t\t\t\tstart: 0,\n\t\t\t\tend: 0,\n\t\t\t\tlabel: ''\n\t\t\t}\n\t\t];\n\t}\n\n\treturn zeroData;\n}\n\nexport function getShortenedLabels(chartWidth, labels=[], isSeries=true) {\n\tlet allowedSpace = chartWidth / labels.length;\n\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet calcLabels = labels.map((label, i) => {\n\t\tlabel += \"\";\n\t\tif(label.length > allowedLetters) {\n\n\t\t\tif(!isSeries) {\n\t\t\t\tif(allowedLetters-3 > 0) {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters-3) + \" ...\";\n\t\t\t\t} else {\n\t\t\t\t\tlabel = label.slice(0, allowedLetters) + '..';\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tlet multiple = Math.ceil(label.length/allowedLetters);\n\t\t\t\tif(i % multiple !== 0) {\n\t\t\t\t\tlabel = \"\";\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn label;\n\t});\n\n\treturn calcLabels;\n}\n","import '../css/charts.scss';\n\n// import MultiAxisChart from './charts/MultiAxisChart';\nimport PercentageChart from './charts/PercentageChart';\nimport PieChart from './charts/PieChart';\nimport Heatmap from './charts/Heatmap';\nimport AxisChart from './charts/AxisChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `\n\t\t\t\t\n\t\t\t\t`\n\t\t});\n\t\tthis.hideTip();\n\n\t\tthis.title = this.container.querySelector('.title');\n\t\tthis.dataPointList = this.container.querySelector('.data-point-list');\n\n\t\tthis.parent.addEventListener('mouseleave', () => {\n\t\t\tthis.hideTip();\n\t\t});\n\t}\n\n\tfill() {\n\t\tlet title;\n\t\tif(this.index) {\n\t\t\tthis.container.setAttribute('data-point-index', this.index);\n\t\t}\n\t\tif(this.titleValueFirst) {\n\t\t\ttitle = `${this.titleValue}${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}${this.titleValue}`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `${ value === 0 || value ? value : '' }\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\n\nlet BOUND_DRAW_FN;\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || 'line';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tBOUND_DRAW_FN = this.boundDrawFn.bind(this);\n\t\twindow.addEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents() {\n\t\twindow.removeEventListener('resize', BOUND_DRAW_FN);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn.bind(this));\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t\tthis.parent.style.overflow = 'auto';\n\t\t}\n\n\t\tthis.container = $.create('div', args);\n\t}\n\n\tmakeTooltip() {\n\t\tthis.tip = new SvgTip({\n\t\t\tparent: this.container,\n\t\t\tcolors: this.colors\n\t\t});\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {}\n\n\tdraw(onlyWidthChange=false, init=false) {\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { legendDot } from '../utils/draw';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.maxSlices = args.maxSlices || 20;\n\t\tthis.config.maxLegendPoints = args.maxLegendPoints || 20;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\t\tlet maxSlices = this.config.maxSlices;\n\t\ts.sliceTotals = [];\n\n\t\tlet allTotals = this.data.labels.map((label, i) => {\n\t\t\tlet total = 0;\n\t\t\tthis.data.datasets.map(e => {\n\t\t\t\ttotal += e.values[i];\n\t\t\t});\n\t\t\treturn [total, label];\n\t\t}).filter(d => { return d[0] >= 0; }); // keep only positive results\n\n\t\tlet totals = allTotals;\n\t\tif(allTotals.length > maxSlices) {\n\t\t\t// Prune and keep a grey area for rest as per maxSlices\n\t\t\tallTotals.sort((a, b) => { return b[0] - a[0]; });\n\n\t\t\ttotals = allTotals.slice(0, maxSlices-1);\n\t\t\tlet remaining = allTotals.slice(maxSlices-1);\n\n\t\t\tlet sumOfRemaining = 0;\n\t\t\tremaining.map(d => {sumOfRemaining += d[0];});\n\t\t\ttotals.push([sumOfRemaining, 'Rest']);\n\t\t\tthis.colors[maxSlices-1] = 'grey';\n\t\t}\n\n\t\ts.labels = [];\n\t\ttotals.map(d => {\n\t\t\ts.sliceTotals.push(d[0]);\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${s.labels[i]}: ${d}`\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 80;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class PieChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'pie';\n\t\tthis.initTimeout = 0;\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\t\tthis.mouseMove = this.mouseMove.bind(this);\n\t\tthis.mouseLeave = this.mouseLeave.bind(this);\n\n\t\tthis.hoverRadio = args.hoverRadio || 0.1;\n\t\tthis.config.startAngle = args.startAngle || 0;\n\n\t\tthis.clockWise = args.clockWise || false;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius = (this.height > this.width ? this.center.x : this.center.y);\n\n\t\tconst { radius, clockWise } = this;\n\n\t\tconst prevSlicesProperties = s.slicesProperties || [];\n\t\ts.sliceStrings = [];\n\t\ts.slicesProperties = [];\n\t\tlet curAngle = 180 - this.config.startAngle;\n\n\t\ts.sliceTotals.map((total, i) => {\n\t\t\tconst startAngle = curAngle;\n\t\t\tconst originDiffAngle = (total / s.grandTotal) * FULL_ANGLE;\n\t\t\tconst diffAngle = clockWise ? -originDiffAngle : originDiffAngle;\n\t\t\tconst endAngle = curAngle = curAngle + diffAngle;\n\t\t\tconst startPosition = getPositionByAngle(startAngle, radius);\n\t\t\tconst endPosition = getPositionByAngle(endAngle, radius);\n\n\t\t\tconst prevProperty = this.init && prevSlicesProperties[i];\n\n\t\t\tlet curStart,curEnd;\n\t\t\tif(this.init) {\n\t\t\t\tcurStart = prevProperty ? prevProperty.startPosition : startPosition;\n\t\t\t\tcurEnd = prevProperty ? prevProperty.endPosition : startPosition;\n\t\t\t} else {\n\t\t\t\tcurStart = startPosition;\n\t\t\t\tcurEnd = endPosition;\n\t\t\t}\n\t\t\tconst curPath = makeArcPathStr(curStart, curEnd, this.center, this.radius, this.clockWise);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\txTranslate: s.domainConfigs\n\t\t\t\t\t.filter((config, j) => j < i)\n\t\t\t\t\t.map(config => config.cols.length - lessCol)\n\t\t\t\t\t.reduce((a, b) => a + b, 0)\n\t\t\t\t\t* COL_WIDTH\n\t\t\t},\n\t\t\tfunction() {\n\t\t\t\treturn s.domainConfigs[i];\n\t\t\t}.bind(this)\n\n\t\t]);\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map((args, i) => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0] + '-' + i, component];\n\t\t\t})\n\t\t);\n\n\t\tlet y = 0;\n\t\tDAY_NAMES_SHORT.forEach((dayName, i) => {\n\t\t\tif([1, 3, 5].includes(i)) {\n\t\t\t\tlet dayText = makeText('subdomain-name', -COL_WIDTH/2, y, dayName,\n\t\t\t\t\t{\n\t\t\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\t\t\tdy: 8,\n\t\t\t\t\t\ttextAnchor: 'end'\n\t\t\t\t\t}\n\t\t\t\t);\n\t\t\t\tthis.drawArea.appendChild(dayText);\n\t\t\t}\n\t\t\ty += ROW_HEIGHT;\n\t\t});\n\t}\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\n\t\tthis.data = this.prepareData(data);\n\t\tthis.draw();\n\t\tthis.bindTooltip();\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tthis.components.forEach(comp => {\n\t\t\t\tlet daySquares = comp.store;\n\t\t\t\tlet daySquare = e.target;\n\t\t\t\tif(daySquares.includes(daySquare)) {\n\n\t\t\t\t\tlet count = daySquare.getAttribute('data-value');\n\t\t\t\t\tlet dateParts = daySquare.getAttribute('data-date').split('-');\n\n\t\t\t\t\tlet month = getMonthName(parseInt(dateParts[1])-1, true);\n\n\t\t\t\t\tlet gOff = this.container.getBoundingClientRect(), pOff = daySquare.getBoundingClientRect();\n\n\t\t\t\t\tlet width = parseInt(e.target.getAttribute('width'));\n\t\t\t\t\tlet x = pOff.left - gOff.left + width/2;\n\t\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\t\tlet value = count + ' ' + this.countLabel;\n\t\t\t\t\tlet name = ' on ' + month + ' ' + dateParts[0] + ', ' + dateParts[2];\n\n\t\t\t\t\tthis.tip.setValues(x, y, {name: name, value: value, valueFirst: 1}, []);\n\t\t\t\t\tthis.tip.showTip();\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\trenderLegend() {\n\t\tthis.legendArea.textContent = '';\n\t\tlet x = 0;\n\t\tlet y = ROW_HEIGHT;\n\n\t\tlet lessText = makeText('subdomain-name', x, y, 'Less',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tx = (COL_WIDTH * 2) + COL_WIDTH/2;\n\t\tthis.legendArea.appendChild(lessText);\n\n\t\tthis.colors.slice(0, HEATMAP_DISTRIBUTION_SIZE).map((color, i) => {\n\t\t\tconst square = heatSquare('heatmap-legend-unit', x + (COL_WIDTH + 3) * i,\n\t\t\t\ty, HEATMAP_SQUARE_SIZE, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n\t\tsuper.configure(options);\n\n\t\toptions.axisOptions = options.axisOptions || {};\n\t\toptions.tooltipOptions = options.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = options.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = options.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = options.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\tcalcYAxisParameters(dataValues, withMinimum = 'false') {\n\t\tconst yPts = calcChartIntervals(dataValues, withMinimum);\n\t\tconst scaleMultiplier = this.height / getValueRange(yPts);\n\t\tconst intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n\t\tconst zeroLine = this.height - (getZeroIndex(yPts) * intervalHeight);\n\n\t\tthis.state.yAxis = {\n\t\t\tlabels: yPts,\n\t\t\tpositions: yPts.map(d => zeroLine - d * scaleMultiplier),\n\t\t\tscaleMultiplier: scaleMultiplier,\n\t\t\tzeroLine: zeroLine,\n\t\t};\n\n\t\t// Dependent if above changes\n\t\tthis.calcDatasetPoints();\n\t\tthis.calcYExtremes();\n\t\tthis.calcYRegions();\n\t}\n\n\tcalcDatasetPoints() {\n\t\tlet s = this.state;\n\t\tlet scaleAll = values => values.map(val => scale(val, s.yAxis));\n\n\t\ts.datasets = this.data.datasets.map((d, i) => {\n\t\t\tlet values = d.values;\n\t\t\tlet cumulativeYs = d.cumulativeYs || [];\n\t\t\treturn {\n\t\t\t\tname: d.name,\n\t\t\t\tindex: i,\n\t\t\t\tchartType: d.chartType,\n\n\t\t\t\tvalues: values,\n\t\t\t\tyPositions: scaleAll(values),\n\n\t\t\t\tcumulativeYs: cumulativeYs,\n\t\t\t\tcumulativeYPos: scaleAll(cumulativeYs),\n\t\t\t};\n\t\t});\n\t}\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n\tgetAllYValues() {\n\t\tlet key = 'values';\n\n\t\tif(this.barOptions.stacked) {\n\t\t\tkey = 'cumulativeYs';\n\t\t\tlet cumulative = new Array(this.state.datasetLength).fill(0);\n\t\t\tthis.data.datasets.map((d, i) => {\n\t\t\t\tlet values = this.data.datasets[i].values;\n\t\t\t\td[key] = cumulative = cumulative.map((c, i) => c + values[i]);\n\t\t\t});\n\t\t}\n\n\t\tlet allValueLists = this.data.datasets.map(d => d[key]);\n\t\tif(this.data.yMarkers) {\n\t\t\tallValueLists.push(this.data.yMarkers.map(d => d.value));\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.data.yRegions.map(d => {\n\t\t\t\tallValueLists.push([d.end, d.start]);\n\t\t\t});\n\t\t}\n\n\t\treturn [].concat(...allValueLists);\n\t}\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'yAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.yAxisMode,\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'xAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.xAxisMode,\n\t\t\t\t\theight: this.height,\n\t\t\t\t\t// pos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\ts.xAxis.calcLabels = getShortenedLabels(this.width,\n\t\t\t\t\t\ts.xAxis.labels, this.config.xIsSeries);\n\n\t\t\t\t\treturn s.xAxis;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\n\t\t\t[\n\t\t\t\t'yRegions',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yRegions;\n\t\t\t\t}.bind(this)\n\t\t\t],\n\t\t];\n\n\t\tlet barDatasets = this.state.datasets.filter(d => d.chartType === 'bar');\n\t\tlet lineDatasets = this.state.datasets.filter(d => d.chartType === 'line');\n\n\t\tlet barsConfigs = barDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'barGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tstacked: this.barOptions.stacked,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t\tminHeight: this.height * MIN_BAR_PERCENT_HEIGHT,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet stacked = this.barOptions.stacked;\n\n\t\t\t\t\tlet spaceRatio = this.barOptions.spaceRatio || BAR_CHART_SPACE_RATIO;\n\t\t\t\t\tlet barsWidth = s.unitWidth/2 * (2 - spaceRatio);\n\t\t\t\t\tlet barWidth = barsWidth/(stacked ? 1 : barDatasets.length);\n\n\t\t\t\t\tlet xPositions = s.xAxis.positions.map(x => x - barsWidth/2);\n\t\t\t\t\tif(!stacked) {\n\t\t\t\t\t\txPositions = xPositions.map(p => p + barWidth * index);\n\t\t\t\t\t}\n\n\t\t\t\t\tlet labels = new Array(s.datasetLength).fill('');\n\t\t\t\t\tif(this.config.valuesOverPoints) {\n\t\t\t\t\t\tif(stacked && d.index === s.datasets.length - 1) {\n\t\t\t\t\t\t\tlabels = d.cumulativeYs;\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\tlabels = d.values;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tlet offsets = new Array(s.datasetLength).fill(0);\n\t\t\t\t\tif(stacked) {\n\t\t\t\t\t\toffsets = d.yPositions.map((y, j) => y - d.cumulativeYPos[j]);\n\t\t\t\t\t}\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: xPositions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\t\t\t\t\t\toffsets: offsets,\n\t\t\t\t\t\t// values: d.values,\n\t\t\t\t\t\tlabels: labels,\n\n\t\t\t\t\t\tzeroLine: s.yAxis.zeroLine,\n\t\t\t\t\t\tbarsWidth: barsWidth,\n\t\t\t\t\t\tbarWidth: barWidth,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet lineConfigs = lineDatasets.map(d => {\n\t\t\tlet index = d.index;\n\t\t\treturn [\n\t\t\t\t'lineGraph' + '-' + d.index,\n\t\t\t\t{\n\t\t\t\t\tindex: index,\n\t\t\t\t\tcolor: this.colors[index],\n\t\t\t\t\tsvgDefs: this.svgDefs,\n\t\t\t\t\theatline: this.lineOptions.heatline,\n\t\t\t\t\tareaFill: this.lineOptions.areaFill,\n\t\t\t\t\thideDots: this.lineOptions.hideDots,\n\t\t\t\t\thideLine: this.lineOptions.hideLine,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet minLine = s.yAxis.positions[0] < s.yAxis.zeroLine\n\t\t\t\t\t\t? s.yAxis.positions[0] : s.yAxis.zeroLine;\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xAxis.positions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\n\t\t\t\t\t\tvalues: d.values,\n\n\t\t\t\t\t\tzeroLine: minLine,\n\t\t\t\t\t\tradius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tlet dbi = this.dataByIndex[index];\n\n\t\tthis.tip.setValues(\n\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\tdbi.values,\n\t\t\tindex\n\t\t);\n\n\t\tthis.tip.showTip();\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name);\n\t\t\t\tthis.legendArea.appendChild(rect);\n\t\t\t});\n\t\t}\n\t}\n\n\n\n\t// Overlay\n\tmakeOverlay() {\n\t\tif(this.init) {\n\t\t\tthis.init = 0;\n\t\t\treturn;\n\t\t}\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\n\t\tthis.overlayGuides = this.dataUnitComponents.map(c => {\n\t\t\treturn {\n\t\t\t\ttype: c.unitType,\n\t\t\t\toverlay: undefined,\n\t\t\t\tunits: c.units,\n\t\t\t};\n\t\t});\n\n\t\tif(this.state.currentIndex === undefined) {\n\t\t\tthis.state.currentIndex = this.state.datasetLength - 1;\n\t\t}\n\n\t\t// Render overlays\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\n\t\t\td.overlay = makeOverlay[d.type](currentUnit);\n\t\t\tthis.drawArea.appendChild(d.overlay);\n\t\t});\n\t}\n\n\tupdateOverlayGuides() {\n\t\tif(this.overlayGuides) {\n\t\t\tthis.overlayGuides.forEach(g => {\n\t\t\t\tlet o = g.overlay;\n\t\t\t\to.parentNode.removeChild(o);\n\t\t\t});\n\t\t}\n\t}\n\n\tbindOverlay() {\n\t\tthis.parent.addEventListener('data-select', () => {\n\t\t\tthis.updateOverlay();\n\t\t});\n\t}\n\n\tbindUnits() {\n\t\tthis.dataUnitComponents.map(c => {\n\t\t\tc.units.map(unit => {\n\t\t\t\tunit.addEventListener('click', () => {\n\t\t\t\t\tlet index = unit.getAttribute('data-point-index');\n\t\t\t\t\tthis.setCurrentDataPoint(index);\n\t\t\t\t});\n\t\t\t});\n\t\t});\n\n\t\t// Note: Doesn't work as tooltip is absolutely positioned\n\t\tthis.tip.container.addEventListener('click', () => {\n\t\t\tlet index = this.tip.container.getAttribute('data-point-index');\n\t\t\tthis.setCurrentDataPoint(index);\n\t\t});\n\t}\n\n\tupdateOverlay() {\n\t\tthis.overlayGuides.map(d => {\n\t\t\tlet currentUnit = d.units[this.state.currentIndex];\n\t\t\tupdateOverlay[d.type](currentUnit, d.overlay);\n\t\t});\n\t}\n\n\tonLeftArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex - 1);\n\t}\n\n\tonRightArrow() {\n\t\tthis.setCurrentDataPoint(this.state.currentIndex + 1);\n\t}\n\n\tgetDataPoint(index=this.state.currentIndex) {\n\t\tlet s = this.state;\n\t\tlet data_point = {\n\t\t\tindex: index,\n\t\t\tlabel: s.xAxis.labels[index],\n\t\t\tvalues: s.datasets.map(d => d.values[index])\n\t\t};\n\t\treturn data_point;\n\t}\n\n\tsetCurrentDataPoint(index) {\n\t\tlet s = this.state;\n\t\tindex = parseInt(index);\n\t\tif(index < 0) index = 0;\n\t\tif(index >= s.xAxis.labels.length) index = s.xAxis.labels.length - 1;\n\t\tif(index === s.currentIndex) return;\n\t\ts.currentIndex = index;\n\t\tfire(this.parent, \"data-select\", this.getDataPoint());\n\t}\n\n\n\n\t// API\n\taddDataPoint(label, datasetValues, index=this.state.datasetLength) {\n\t\tsuper.addDataPoint(label, datasetValues, index);\n\t\tthis.data.labels.splice(index, 0, label);\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\td.values.splice(index, 0, datasetValues[i]);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tremoveDataPoint(index = this.state.datasetLength-1) {\n\t\tif (this.data.labels.length <= 1) {\n\t\t\treturn;\n\t\t}\n\t\tsuper.removeDataPoint(index);\n\t\tthis.data.labels.splice(index, 1);\n\t\tthis.data.datasets.map(d => {\n\t\t\td.values.splice(index, 1);\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\tupdateDataset(datasetValues, index=0) {\n\t\tthis.data.datasets[index].values = datasetValues;\n\t\tthis.update(this.data);\n\t}\n\t// addDataset(dataset, index) {}\n\t// removeDataset(index = 0) {}\n\n\tupdateDatasets(datasets) {\n\t\tthis.data.datasets.map((d, i) => {\n\t\t\tif(datasets[i]) {\n\t\t\t\td.values = datasets[i];\n\t\t\t}\n\t\t});\n\t\tthis.update(this.data);\n\t}\n\n\t// updateDataPoint(dataPoint, index = 0) {}\n\t// addDataPoint(dataPoint, index = 0) {}\n\t// removeDataPoint(index = 0) {}\n}\n","import * as Charts from './chart';\n\nlet frappe = { };\n\nfrappe.NAME = 'Frappe Charts';\nfrappe.VERSION = '1.1.0';\n\nfrappe = Object.assign({ }, frappe, Charts);\n\nexport default frappe;"],"names":["$","expr","con","document","querySelector","getOffset","element","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isElementInViewport","el","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","type","properties","evt","createEvent","initEvent","j","dispatchEvent","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","legendHeight","getExtraWidth","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","Math","abs","fill","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","ANGLE_RATIO","cos","getBarHeightAndYAttr","yTop","zeroLine","height","y","equilizeNoOfElements","array1","array2","extraCount","limitColor","r","lightenDarkenColor","color","amt","col","getColor","usePound","slice","num","parseInt","b","g","toString","isValidColor","test","createSVG","tag","o","createElementNS","i","val","appendChild","ref","parentNode","insertBefore","keys","map","style","prop","setAttribute","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","opacity","makeSVGContainer","parent","className","width","makeSVGDefs","svgContainer","makeSVGGroup","transform","undefined","args","inside","makePath","pathStr","makeArcPathStr","startPosition","endPosition","center","clockWise","arcStartX","x","arcStartY","arcEndX","arcEndY","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","PERCENTAGE_BAR_DEFAULT_DEPTH","heatSquare","size","data","key","legendBar","label","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","stroke","BASE_LINE_COLOR","l","LABEL_MARGIN","line","makeHoriLine","x1","x2","lineType","yLine","pos","mode","AXIS_TICK_LENGTH","xLine","yMarker","labelPos","labelSvg","yRegion","region","datasetBar","index","meta","minHeight","datasetDot","dot","getPaths","xList","yList","pointsStr","join","path","heatline","gradient_id","svgDefs","paths","areaFill","gradient_id_region","translate","unit","oldCoord","newCoord","duration","old","STD_EASING","translateVertLine","newX","oldX","MARKER_LINE_ANIM_DUR","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","childNodes","stroke-dasharray","getAttribute","animateBar","bar","nodeName","UNIT_ANIM_DUR","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","PATH_ANIM_DUR","push","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","animateSVGElement","props","dur","easingType","oldValues","animElement","cloneNode","newElement","attributeName","animateElement","currentValue","value","animAttr","EASING","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","REPLACE_ALL_NEW_DUR","downloadFile","filename","a","createElement","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","create","CSSTEXT","firstChild","container","innerHTML","treatAsUtc","date","result","Date","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","getTime","getWeeksBetween","startDate","endDate","weekStartDate","setDayToSunday","ceil","getDaysBetween","NO_OF_DAYS_IN_WEEK","millisecondsPerDay","SEC_IN_DAY","NO_OF_MILLIS","areInSameMonth","getMonthName","short","monthName","MONTH_NAMES","getLastDateInMonth","month","year","newDate","day","getDay","addDays","numberOfDays","setDate","getComponent","name","constants","getData","Object","componentConfigs","filter","includes","k","config","assign","ChartComponent","normalize","isNaN","mantissa","exponent","sig","isFinite","exp","floor","log10","pow","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","values","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","withMinimum","pseudoMaxValue","pseudoMinValue","reverse","getZeroIndex","yPts","interval","getIntervalSize","indexOf","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","reduce","prev","curr","calcDistribution","distributionSize","dataMaxValue","distributionStep","distribution","checkpoint","getMaxCheckpoint","dataPrep","labels","datasetLength","datasets","zeroArray","overridingType","AXIS_DATASET_CHART_TYPES","vals","chartType","AXIS_CHART_DEFAULT_TYPE","yRegions","end","zeroDataPrep","realData","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedSpace","allowedLetters","DEFAULT_CHAR_WIDTH","getChartByType","AxisChart","chartTypes","error","addEventListener","e","BASE_MEASURES","INIT_CHART_UPDATE_TIMEOUT","DEFAULT_CHART_COLORS","DEFAULT_COLORS","PI","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","title","dataPointList","set","_this2","formatted","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BOUND_DRAW_FN","BaseChart","HTMLElement","Error","rawChartArgs","prepareData","prepareFirstData","validateColors","isNavigable","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","bind","draw","removeEventListener","makeContainer","updateWidth","independentWidth","overflow","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","c","_this","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","animate","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","_this3","event","keyCode","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","divisor","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","_this4","_this5","newOptions","startPos","endPos","_this6","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","barWidth","offsets","barsWidth","newXPos","newYPos","newOffsets","oldXPos","oldYPos","oldOffsets","hideLine","hideDots","valuesOverPoints","newValues","PercentageChart","barOptions","component","xPos","bars","get","gOff","pOff","formattedLabels","fraction","setValues","showTip","PieChart","mouseMove","mouseLeave","hoverRadio","startAngle","prevSlicesProperties","slicesProperties","curAngle","originDiffAngle","diffAngle","endAngle","prevProperty","curStart","curEnd","curPath","property","flag","calTranslateByAngle","g_off","pageX","pageY","formatted_labels","percent","slices","prevIndex","curActiveSliceIndex","prevAcitve","curActiveSlice","hoverSlice","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","ROW_HEIGHT","HEATMAP_SQUARE_SIZE","spacing","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","COL_WIDTH","moreText","HEATMAP_DISTRIBUTION_SIZE","startMonth","startYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","lineOptions","axisOptions","tooltipOptions","xAxisMode","yAxisMode","xIsSeries","formatTooltipX","formatTooltipY","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","xAxis","dataValues","intervalHeight","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","cumulativeYs","stacked","yExtremes","cumulativeYPos","cumulative","allValueLists","barDatasets","lineDatasets","barsConfigs","spaceRatio","p","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","_this7","setCurrentDataPoint","_this9","_this10","getDataPoint","datasetValues","splice","Chart","frappe","NAME","VERSION","Charts"],"mappings":"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"}
\ No newline at end of file
diff --git a/docs/_sidebar.md b/docs/_sidebar.md
index 34d8947..d85d7f8 100644
--- a/docs/_sidebar.md
+++ b/docs/_sidebar.md
@@ -3,7 +3,7 @@
* Axis charts
* [A basic chart](basic/basic_chart.md)
- * [Trends and Region Charts](basic/trends_regions.md)
+ * [Area and Trends Charts](basic/trends_regions.md)
* [Annotations and Tooltip format](basic/annotations.md)
* [Stacked and Mixed Charts](basic/stacked_and_mixed.md)
diff --git a/docs/assets/js/demoConfig.js b/docs/assets/js/demoConfig.js
index 0bb4155..849cdcc 100644
--- a/docs/assets/js/demoConfig.js
+++ b/docs/assets/js/demoConfig.js
@@ -135,7 +135,7 @@ export const demoSections = [
height: 300,
colors: ['#ff6c03'],
lineOptions: {
- regionFill: 1
+ areaFill: 1
}
},
actions: [
@@ -187,12 +187,12 @@ export const demoSections = [
name: "lineOptions",
path: ["lineOptions"],
type: "map",
- mapKeys: ['hideLine', 'hideDots', 'heatline', 'regionFill'],
+ mapKeys: ['hideLine', 'hideDots', 'heatline', 'areaFill'],
states: {
"Line": [0, 1, 0, 0],
"Dots": [1, 0, 0, 0],
"HeatLine": [0, 1, 1, 0],
- "Region": [0, 1, 0, 1]
+ "Area": [0, 1, 0, 1]
},
activeState: "HeatLine"
}
@@ -363,7 +363,7 @@ export const demoSections = [
hideLine: 0, // default: 0
hideDots: 1, // default: 0
heatline: 1, // default: 0
- regionFill: 1 // default: 0
+ areaFill: 1 // default: 0
}
axisOptions: {
diff --git a/docs/basic/basic_chart.md b/docs/basic/basic_chart.md
index 9b1b7ea..1ce774f 100644
--- a/docs/basic/basic_chart.md
+++ b/docs/basic/basic_chart.md
@@ -1,6 +1,6 @@
-## What is it
+## Axis chart: what is it
-A chart is generally a 2D rendition of data. For example, for a set of values across items, the data could look like:
+An axis chart is generally a 2D rendition of data, where a set of values corresponds to every point in a dataset. That's why, data is the most important component for a chart. For example, for some values across items, the data could look like:
```js
data = {
labels: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat", "Sun"],
@@ -50,6 +50,7 @@ data: {
]
}
```
+Notice that this case demonstrates why the `colors` option is an array. We'll see more about it ahead.
+
+## Plotting Trends
+Line charts great to show trends data. One of the reason trends are interesting is because the data involved usually involves a large number of data points. For so many points, we'd really like to keep the plot as less detailed as we can, while also using the already present color to advantage. Let's see how we can change some properties of a default line chart can reduce clutter.
+## Continuity
+The X axis (often the time axis) is usually continuous. That means we can reduce the redundancy of rendering every X label by allowing for only a few periodic ones. We can do this by setting the `xIsSeries` property in `axisOptions` to `true`.
-## Combinations
+```js
+axisOptions: {
+ xIsSeries: true // default: false
+},
+```
+This results only some of the X ticks having a label.
+
+
+
+The line plot in the above plot could still be simplified. For example, to maintain uniformity, we could opt out of showing the dots at all, with `hideDots`.
```js
lineOptions: {
- dotSize: 8 // default: 4
+ hideDots: 1 // default: 0
},
```
+
+
+
+Or you could just choose to show only the dots instead.
+```js
+lineOptions: {
+ hideLine: 1 // default: 0
+},
+```
+
+
+Needless to say, turning both of them on would be too amusing to be of any use :)
+
+A subtle way to show gradation of values is to render a change in color with the magnitude of the values. The property that does this is called `heatline`.
+```js
+lineOptions: {
+ heatline: 1 // default: 0
+},
+```
+
+
+## Combinations
Here's a demo using different combinations of the line options.
-
+
+
Next up, we'll play around with more than one datasets play out in charts.
diff --git a/docs/data.js b/docs/data.js
index f7887d9..d1d7d1b 100644
--- a/docs/data.js
+++ b/docs/data.js
@@ -25,5 +25,21 @@ const sampleData = {
{ values: [300, 250, 720, 560, 370, 610, 690, 410,
370, 480, 620, 260, 170, 510, 630, 710, 560, 370, 610, 260, 170] }
]
+ },
+ "trends-data": {
+ labels: [1967, 1968, 1969, 1970, 1971, 1972, 1973, 1974, 1975, 1976,
+ 1977, 1978, 1979, 1980, 1981, 1982, 1983, 1984, 1985, 1986,
+ 1987, 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996,
+ 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006,
+ 2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016] ,
+ datasets: [
+ {
+ values: [132.9, 150.0, 149.4, 148.0, 94.4, 97.6, 54.1, 49.2, 22.5, 18.4,
+ 39.3, 131.0, 220.1, 218.9, 198.9, 162.4, 91.0, 60.5, 20.6, 14.8,
+ 33.9, 123.0, 211.1, 191.8, 203.3, 133.0, 76.1, 44.9, 25.1, 11.6,
+ 28.9, 88.3, 136.3, 173.9, 170.4, 163.6, 99.3, 65.3, 45.8, 24.7,
+ 12.6, 4.2, 4.8, 24.9, 80.8, 84.5, 94.0, 113.3, 69.8, 39.8]
+ }
+ ]
}
}
diff --git a/docs/frappe-charts.min.iife.js b/docs/frappe-charts.min.iife.js
index 1c1e918..3f9eb47 100644
--- a/docs/frappe-charts.min.iife.js
+++ b/docs/frappe-charts.min.iife.js
@@ -1,2740 +1,2 @@
-var frappe = function () {
- "use strict";
-
- function t(t, e) {
- return "string" == typeof t ? (e || document).querySelector(t) : t || null
- }
-
- function e(t) {
- var e = t.getBoundingClientRect();
- return {
- top: e.top + (document.documentElement.scrollTop || document.body.scrollTop),
- left: e.left + (document.documentElement.scrollLeft || document.body.scrollLeft)
- }
- }
-
- function i(t) {
- var e = t.getBoundingClientRect();
- return e.top >= 0 && e.left >= 0 && e.bottom <= (window.innerHeight || document.documentElement.clientHeight) && e.right <= (window.innerWidth || document.documentElement.clientWidth)
- }
-
- function n(t) {
- var e = window.getComputedStyle(t),
- i = parseFloat(e.paddingLeft) + parseFloat(e.paddingRight);
- return t.clientWidth - i
- }
-
- function a(t, e, i) {
- var n = document.createEvent("HTMLEvents");
- n.initEvent(e, !0, !0);
- for (var a in i) n[a] = i[a];
- return t.dispatchEvent(n)
- }
-
- function s(t) {
- return t.titleHeight + t.margins.top + t.paddings.top
- }
-
- function r(t) {
- return t.margins.left + t.paddings.left
- }
-
- function o(t) {
- return t.margins.top + t.margins.bottom + t.paddings.top + t.paddings.bottom + t.titleHeight + t.legendHeight
- }
-
- function l(t) {
- return t.margins.left + t.margins.right + t.paddings.left + t.paddings.right
- }
-
- function u(t) {
- return parseFloat(t.toFixed(2))
- }
-
- function h(t, e, i) {
- var n = arguments.length > 3 && void 0 !== arguments[3] && arguments[3];
- i || (i = n ? t[0] : t[t.length - 1]);
- var a = new Array(Math.abs(e)).fill(i);
- return t = n ? a.concat(t) : t.concat(a)
- }
-
- function c(t, e) {
- return (t + "").length * e
- }
-
- function d(t, e) {
- return {
- x: Math.sin(t * Bt) * e,
- y: Math.cos(t * Bt) * e
- }
- }
-
- function p(t, e) {
- var i = void 0,
- n = void 0;
- return t <= e ? (i = e - t, n = t) : (i = t - e, n = e), [i, n]
- }
-
- function f(t, e) {
- var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : e.length - t.length;
- return i > 0 ? t = h(t, i) : e = h(e, i), [t, e]
- }
-
- function v(t) {
- return t > 255 ? 255 : t < 0 ? 0 : t
- }
-
- function g(t, e) {
- var i = qt(t),
- n = !1;
- "#" == i[0] && (i = i.slice(1), n = !0);
- var a = parseInt(i, 16),
- s = v((a >> 16) + e),
- r = v((a >> 8 & 255) + e),
- o = v((255 & a) + e);
- return (n ? "#" : "") + (o | r << 8 | s << 16).toString(16)
- }
-
- function y(t) {
- return /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(t)
- }
-
- function m(t, e) {
- return "string" == typeof t ? (e || document).querySelector(t) : t || null
- }
-
- function b(t, e) {
- var i = document.createElementNS("http://www.w3.org/2000/svg", t);
- for (var n in e) {
- var a = e[n];
- if ("inside" === n) m(a).appendChild(i);
- else if ("around" === n) {
- var s = m(a);
- s.parentNode.insertBefore(i, s), i.appendChild(s)
- } else "styles" === n ? "object" === (void 0 === a ? "undefined" : Dt(a)) && Object.keys(a).map(function (t) {
- i.style[t] = a[t]
- }) : ("className" === n && (n = "class"), "innerHTML" === n ? i.textContent = a : i.setAttribute(n, a))
- }
- return i
- }
-
- function x(t, e) {
- return b("linearGradient", {
- inside: t,
- id: e,
- x1: 0,
- x2: 0,
- y1: 0,
- y2: 1
- })
- }
-
- function k(t, e, i, n) {
- return b("stop", {
- inside: t,
- style: "stop-color: " + i,
- offset: e,
- "stop-opacity": n
- })
- }
-
- function w(t, e, i, n) {
- return b("svg", {
- className: e,
- inside: t,
- width: i,
- height: n
- })
- }
-
- function A(t) {
- return b("defs", {
- inside: t
- })
- }
-
- function P(t) {
- var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : "",
- i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : void 0,
- n = {
- className: t,
- transform: e
- };
- return i && (n.inside = i), b("g", n)
- }
-
- function C(t) {
- return b("path", {
- className: arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : "",
- d: t,
- styles: {
- stroke: arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : "none",
- fill: arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : "none"
- }
- })
- }
-
- function L(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : 1,
- s = i.x + t.x,
- r = i.y + t.y,
- o = i.x + e.x,
- l = i.y + e.y;
- return "M" + i.x + " " + i.y + "\n\t\tL" + s + " " + r + "\n\t\tA " + n + " " + n + " 0 0 " + (a ? 1 : 0) + "\n\t\t" + o + " " + l + " z"
- }
-
- function T(t, e) {
- var i = arguments.length > 2 && void 0 !== arguments[2] && arguments[2],
- n = "path-fill-gradient-" + e + "-" + (i ? "lighter" : "default"),
- a = x(t, n),
- s = [1, .6, .2];
- return i && (s = [.4, .2, 0]), k(a, "0%", e, s[0]), k(a, "50%", e, s[1]), k(a, "100%", e, s[2]), n
- }
-
- function D(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : It,
- s = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : "none";
- return b("rect", {
- className: "percentage-bar",
- x: t,
- y: e,
- width: i,
- height: n,
- fill: s,
- styles: {
- stroke: g(s, -25),
- "stroke-dasharray": "0, " + (n + i) + ", " + i + ", " + n,
- "stroke-width": a
- }
- })
- }
-
- function O(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : "none",
- s = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : {},
- r = {
- className: t,
- x: e,
- y: i,
- width: n,
- height: n,
- fill: a
- };
- return Object.keys(s).map(function (t) {
- r[t] = s[t]
- }), b("rect", r)
- }
-
- function M(t, e, i) {
- var n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : "none",
- a = arguments[4],
- s = {
- className: "legend-bar",
- x: 0,
- y: 0,
- width: i,
- height: "2px",
- fill: n
- },
- r = b("text", {
- className: "legend-dataset-text",
- x: 0,
- y: 0,
- dy: 2 * Kt + "px",
- "font-size": 1.2 * Kt + "px",
- "text-anchor": "start",
- fill: Qt,
- innerHTML: a
- }),
- o = b("g", {
- transform: "translate(" + t + ", " + e + ")"
- });
- return o.appendChild(b("rect", s)), o.appendChild(r), o
- }
-
- function N(t, e, i) {
- var n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : "none",
- a = arguments[4],
- s = {
- className: "legend-dot",
- cx: 0,
- cy: 0,
- r: i,
- fill: n
- },
- r = b("text", {
- className: "legend-dataset-text",
- x: 0,
- y: 0,
- dx: Kt + "px",
- dy: Kt / 3 + "px",
- "font-size": 1.2 * Kt + "px",
- "text-anchor": "start",
- fill: Qt,
- innerHTML: a
- }),
- o = b("g", {
- transform: "translate(" + t + ", " + e + ")"
- });
- return o.appendChild(b("circle", s)), o.appendChild(r), o
- }
-
- function E(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : {},
- s = a.fontSize || Kt;
- return b("text", {
- className: t,
- x: e,
- y: i,
- dy: (void 0 !== a.dy ? a.dy : s / 2) + "px",
- "font-size": s + "px",
- fill: a.fill || Qt,
- "text-anchor": a.textAnchor || "start",
- innerHTML: n
- })
- }
-
- function S(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : {};
- a.stroke || (a.stroke = $t);
- var s = b("line", {
- className: "line-vertical " + a.className,
- x1: 0,
- x2: 0,
- y1: i,
- y2: n,
- styles: {
- stroke: a.stroke
- }
- }),
- r = b("text", {
- x: 0,
- y: i > n ? i + Jt : i - Jt - Kt,
- dy: Kt + "px",
- "font-size": Kt + "px",
- "text-anchor": "middle",
- innerHTML: e + ""
- }),
- o = b("g", {
- transform: "translate(" + t + ", 0)"
- });
- return o.appendChild(s), o.appendChild(r), o
- }
-
- function _(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : {};
- a.stroke || (a.stroke = $t), a.lineType || (a.lineType = "");
- var s = b("line", {
- className: "line-horizontal " + a.className + ("dashed" === a.lineType ? "dashed" : ""),
- x1: i,
- x2: n,
- y1: 0,
- y2: 0,
- styles: {
- stroke: a.stroke
- }
- }),
- r = b("text", {
- x: i < n ? i - Jt : i + Jt,
- y: 0,
- dy: Kt / 2 - 2 + "px",
- "font-size": Kt + "px",
- "text-anchor": i < n ? "end" : "start",
- innerHTML: e + ""
- }),
- o = b("g", {
- transform: "translate(0, " + t + ")",
- "stroke-opacity": 1
- });
- return 0 !== r && "0" !== r || (o.style.stroke = "rgba(27, 31, 35, 0.6)"), o.appendChild(s), o.appendChild(r), o
- }
-
- function z(t, e, i) {
- var n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : {};
- n.pos || (n.pos = "left"), n.offset || (n.offset = 0), n.mode || (n.mode = "span"), n.stroke || (n.stroke = $t), n.className || (n.className = "");
- var a = -1 * Xt,
- s = "span" === n.mode ? i + Xt : 0;
- return "tick" === n.mode && "right" === n.pos && (a = i + Xt, s = i), a += n.offset, s += n.offset, _(t, e, a, s, {
- stroke: n.stroke,
- className: n.className,
- lineType: n.lineType
- })
- }
-
- function H(t, e, i) {
- var n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : {};
- n.pos || (n.pos = "bottom"), n.offset || (n.offset = 0), n.mode || (n.mode = "span"), n.stroke || (n.stroke = $t), n.className || (n.className = "");
- var a = i + Xt,
- s = "span" === n.mode ? -1 * Xt : i;
- return "tick" === n.mode && "top" === n.pos && (a = -1 * Xt, s = 0), S(t, e, a, s, {
- stroke: n.stroke,
- className: n.className,
- lineType: n.lineType
- })
- }
-
- function F(t, e, i) {
- var n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : {};
- n.labelPos || (n.labelPos = "right");
- var a = b("text", {
- className: "chart-label",
- x: "left" === n.labelPos ? Jt : i - c(e, 5) - Jt,
- y: 0,
- dy: Kt / -2 + "px",
- "font-size": Kt + "px",
- "text-anchor": "start",
- innerHTML: e + ""
- }),
- s = _(t, "", 0, i, {
- stroke: n.stroke || $t,
- className: n.className || "",
- lineType: n.lineType
- });
- return s.appendChild(a), s
- }
-
- function j(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : {},
- s = t - e,
- r = b("rect", {
- className: "bar mini",
- styles: {
- fill: "rgba(228, 234, 239, 0.49)",
- stroke: $t,
- "stroke-dasharray": i + ", " + s
- },
- x: 0,
- y: 0,
- width: i,
- height: s
- });
- a.labelPos || (a.labelPos = "right");
- var o = b("text", {
- className: "chart-label",
- x: "left" === a.labelPos ? Jt : i - c(n + "", 4.5) - Jt,
- y: 0,
- dy: Kt / -2 + "px",
- "font-size": Kt + "px",
- "text-anchor": "start",
- innerHTML: n + ""
- }),
- l = b("g", {
- transform: "translate(0, " + e + ")"
- });
- return l.appendChild(r), l.appendChild(o), l
- }
-
- function W(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : "",
- s = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : 0,
- r = arguments.length > 6 && void 0 !== arguments[6] ? arguments[6] : 0,
- o = arguments.length > 7 && void 0 !== arguments[7] ? arguments[7] : {},
- l = p(e, o.zeroLine),
- u = _t(l, 2),
- h = u[0],
- c = u[1];
- c -= r, 0 === h && (h = o.minHeight, c -= o.minHeight);
- var d = b("rect", {
- className: "bar mini",
- style: "fill: " + n,
- "data-point-index": s,
- x: t,
- y: c,
- width: i,
- height: h
- });
- if ((a += "") || a.length) {
- d.setAttribute("y", 0), d.setAttribute("x", 0);
- var f = b("text", {
- className: "data-point-value",
- x: i / 2,
- y: 0,
- dy: Kt / 2 * -1 + "px",
- "font-size": Kt + "px",
- "text-anchor": "middle",
- innerHTML: a
- }),
- v = b("g", {
- "data-point-index": s,
- transform: "translate(" + t + ", " + c + ")"
- });
- return v.appendChild(d), v.appendChild(f), v
- }
- return d
- }
-
- function I(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : "",
- s = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : 0,
- r = b("circle", {
- style: "fill: " + n,
- "data-point-index": s,
- cx: t,
- cy: e,
- r: i
- });
- if ((a += "") || a.length) {
- r.setAttribute("cy", 0), r.setAttribute("cx", 0);
- var o = b("text", {
- className: "data-point-value",
- x: 0,
- y: 0,
- dy: Kt / 2 * -1 - i + "px",
- "font-size": Kt + "px",
- "text-anchor": "middle",
- innerHTML: a
- }),
- l = b("g", {
- "data-point-index": s,
- transform: "translate(" + t + ", " + e + ")"
- });
- return l.appendChild(r), l.appendChild(o), l
- }
- return r
- }
-
- function R(t, e, i) {
- var n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : {},
- a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : {},
- s = e.map(function (e, i) {
- return t[i] + "," + e
- }).join("L"),
- r = C("M" + s, "line-graph-path", i);
- if (n.heatline) {
- var o = T(a.svgDefs, i);
- r.style.stroke = "url(#" + o + ")"
- }
- var l = {
- path: r
- };
- if (n.regionFill) {
- var u = T(a.svgDefs, i, !0),
- h = "M" + t[0] + "," + a.zeroLine + "L" + s + "L" + t.slice(-1)[0] + "," + a.zeroLine;
- l.region = C(h, "region-fill", "none", "url(#" + u + ")")
- }
- return l
- }
-
- function Y(t, e, i, n) {
- var a = "string" == typeof e ? e : e.join(", ");
- return [t, {
- transform: i.join(", ")
- }, n, se, "translate", {
- transform: a
- }]
- }
-
- function V(t, e, i) {
- return Y(t, [i, 0], [e, 0], ne)
- }
-
- function B(t, e, i) {
- return Y(t, [0, i], [0, e], ne)
- }
-
- function U(t, e, i, n) {
- var a = e - i,
- s = t.childNodes[0];
- return [
- [s, {
- height: a,
- "stroke-dasharray": s.getAttribute("width") + ", " + a
- }, ne, se], Y(t, [0, n], [0, i], ne)
- ]
- }
-
- function G(t, e, i, n) {
- var a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : 0,
- s = p(i, (arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : {}).zeroLine),
- r = _t(s, 2),
- o = r[0],
- l = r[1];
- return l -= a, "rect" !== t.nodeName ? [
- [t.childNodes[0], {
- width: n,
- height: o
- }, ee, se], Y(t, t.getAttribute("transform").split("(")[1].slice(0, -1), [e, l], ne)
- ] : [
- [t, {
- width: n,
- height: o,
- x: e,
- y: l
- }, ee, se]
- ]
- }
-
- function q(t, e, i) {
- return "circle" !== t.nodeName ? [Y(t, t.getAttribute("transform").split("(")[1].slice(0, -1), [e, i], ne)] : [
- [t, {
- cx: e,
- cy: i
- }, ee, se]
- ]
- }
-
- function X(t, e, i, n) {
- var a = [],
- s = i.map(function (t, i) {
- return e[i] + "," + t
- }).join("L"),
- r = [t.path, {
- d: "M" + s
- }, ie, se];
- if (a.push(r), t.region) {
- var o = e[0] + "," + n + "L",
- l = "L" + e.slice(-1)[0] + ", " + n,
- u = [t.region, {
- d: "M" + o + s + l
- }, ie, se];
- a.push(u)
- }
- return a
- }
-
- function J(t, e) {
- return [t, {
- d: e
- }, ee, se]
- }
-
- function K(t, e, i) {
- var n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : "linear",
- a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : void 0,
- s = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : {},
- r = t.cloneNode(!0),
- o = t.cloneNode(!0);
- for (var l in e) {
- var u = void 0;
- u = "transform" === l ? document.createElementNS("http://www.w3.org/2000/svg", "animateTransform") : document.createElementNS("http://www.w3.org/2000/svg", "animate");
- var h = s[l] || t.getAttribute(l),
- c = e[l],
- d = {
- attributeName: l,
- from: h,
- to: c,
- begin: "0s",
- dur: i / 1e3 + "s",
- values: h + ";" + c,
- keySplines: re[n],
- keyTimes: "0;1",
- calcMode: "spline",
- fill: "freeze"
- };
- a && (d.type = a);
- for (var p in d) u.setAttribute(p, d[p]);
- r.appendChild(u), a ? o.setAttribute(l, "translate(" + c + ")") : o.setAttribute(l, c)
- }
- return [r, o]
- }
-
- function $(t, e) {
- t.style.transform = e, t.style.webkitTransform = e, t.style.msTransform = e, t.style.mozTransform = e, t.style.oTransform = e
- }
-
- function Q(t, e) {
- var i = [],
- n = [];
- e.map(function (t) {
- var e = t[0],
- a = e.parentNode,
- s = void 0,
- r = void 0;
- t[0] = e;
- var o = K.apply(void 0, zt(t)),
- l = _t(o, 2);
- s = l[0], r = l[1], i.push(r), n.push([s, a]), a.replaceChild(s, e)
- });
- var a = t.cloneNode(!0);
- return n.map(function (t, n) {
- t[1].replaceChild(i[n], t[0]), e[n][0] = i[n]
- }), a
- }
-
- function Z(t, e, i) {
- if (0 !== i.length) {
- var n = Q(e, i);
- e.parentNode == t && (t.removeChild(e), t.appendChild(n)), setTimeout(function () {
- n.parentNode == t && (t.removeChild(n), t.appendChild(e))
- }, ae)
- }
- }
-
- function tt(t, e) {
- var i = document.createElement("a");
- i.style = "display: none";
- var n = new Blob(e, {
- type: "image/svg+xml; charset=utf-8"
- }),
- a = window.URL.createObjectURL(n);
- i.href = a, i.download = t, document.body.appendChild(i), i.click(), setTimeout(function () {
- document.body.removeChild(i), window.URL.revokeObjectURL(a)
- }, 300)
- }
-
- function et(e) {
- var i = e.cloneNode(!0);
- i.classList.add("chart-container"), i.setAttribute("xmlns", "http://www.w3.org/2000/svg"), i.setAttribute("xmlns:xlink", "http://www.w3.org/1999/xlink");
- var n = t.create("style", {
- innerHTML: oe
- });
- i.insertBefore(n, i.firstChild);
- var a = t.create("div");
- return a.appendChild(i), a.innerHTML
- }
-
- function it(t) {
- var e = new Date(t);
- return e.setMinutes(e.getMinutes() - e.getTimezoneOffset()), e
- }
-
- function nt(t) {
- var e = t.getDate(),
- i = t.getMonth() + 1;
- return [t.getFullYear(), (i > 9 ? "" : "0") + i, (e > 9 ? "" : "0") + e].join("-")
- }
-
- function at(t) {
- return new Date(t.getTime())
- }
-
- function st(t, e) {
- var i = ht(t);
- return Math.ceil(rt(i, e) / ce)
- }
-
- function rt(t, e) {
- var i = pe * de;
- return (it(e) - it(t)) / i
- }
-
- function ot(t, e) {
- return t.getMonth() === e.getMonth() && t.getFullYear() === e.getFullYear()
- }
-
- function lt(t) {
- var e = arguments.length > 1 && void 0 !== arguments[1] && arguments[1],
- i = fe[t];
- return e ? i.slice(0, 3) : i
- }
-
- function ut(t, e) {
- return new Date(e, t + 1, 0)
- }
-
- function ht(t) {
- var e = at(t),
- i = e.getDay();
- return 0 !== i && ct(e, -1 * i), e
- }
-
- function ct(t, e) {
- t.setDate(t.getDate() + e)
- }
-
- function dt(t, e, i) {
- var n = Object.keys(ye).filter(function (e) {
- return t.includes(e)
- }),
- a = ye[n[0]];
- return Object.assign(a, {
- constants: e,
- getData: i
- }), new ge(a)
- }
-
- function pt(t) {
- if (0 === t) return [0, 0];
- if (isNaN(t)) return {
- mantissa: -6755399441055744,
- exponent: 972
- };
- var e = t > 0 ? 1 : -1;
- if (!isFinite(t)) return {
- mantissa: 4503599627370496 * e,
- exponent: 972
- };
- t = Math.abs(t);
- var i = Math.floor(Math.log10(t));
- return [e * (t / Math.pow(10, i)), i]
- }
-
- function ft(t) {
- var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : 0,
- i = Math.ceil(t),
- n = Math.floor(e),
- a = i - n,
- s = a,
- r = 1;
- a > 5 && (a % 2 != 0 && (a = ++i - n), s = a / 2, r = 2), a <= 2 && (r = a / (s = 4)), 0 === a && (s = 5, r = 1);
- for (var o = [], l = 0; l <= s; l++) o.push(n + r * l);
- return o
- }
-
- function vt(t) {
- var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : 0,
- i = pt(t),
- n = _t(i, 2),
- a = n[0],
- s = n[1],
- r = e ? e / Math.pow(10, s) : 0,
- o = ft(a = a.toFixed(6), r);
- return o = o.map(function (t) {
- return t * Math.pow(10, s)
- })
- }
-
- function gt(t) {
- function e(t, e) {
- for (var i = vt(t), n = i[1] - i[0], a = 0, s = 1; a < e; s++) a += n, i.unshift(-1 * a);
- return i
- }
- var i = arguments.length > 1 && void 0 !== arguments[1] && arguments[1],
- n = Math.max.apply(Math, zt(t)),
- a = Math.min.apply(Math, zt(t)),
- s = [];
- if (n >= 0 && a >= 0) pt(n)[1], s = i ? vt(n, a) : vt(n);
- else if (n > 0 && a < 0) {
- var r = Math.abs(a);
- n >= r ? (pt(n)[1], s = e(n, r)) : (pt(r)[1], s = e(r, n).map(function (t) {
- return -1 * t
- }))
- } else if (n <= 0 && a <= 0) {
- var o = Math.abs(a),
- l = Math.abs(n);
- pt(o)[1], s = (s = i ? vt(o, l) : vt(o)).reverse().map(function (t) {
- return -1 * t
- })
- }
- return s
- }
-
- function yt(t) {
- var e = mt(t);
- return t.indexOf(0) >= 0 ? t.indexOf(0) : t[0] > 0 ? -1 * t[0] / e : -1 * t[t.length - 1] / e + (t.length - 1)
- }
-
- function mt(t) {
- return t[1] - t[0]
- }
-
- function bt(t) {
- return t[t.length - 1] - t[0]
- }
-
- function xt(t, e) {
- return u(e.zeroLine - t * e.scaleMultiplier)
- }
-
- function kt(t, e) {
- var i = arguments.length > 2 && void 0 !== arguments[2] && arguments[2],
- n = e.reduce(function (e, i) {
- return Math.abs(i - t) < Math.abs(e - t) ? i : e
- });
- return i ? e.indexOf(n) : n
- }
-
- function wt(t, e) {
- for (var i = Math.max.apply(Math, zt(t)), n = 1 / (e - 1), a = [], s = 0; s < e; s++) {
- var r = i * (n * s);
- a.push(r)
- }
- return a
- }
-
- function At(t, e) {
- return e.filter(function (e) {
- return e < t
- }).length
- }
-
- function Pt(t, e) {
- t.labels = t.labels || [];
- var i = t.labels.length,
- n = t.datasets,
- a = new Array(i).fill(0);
- n || (n = [{
- values: a
- }]);
- var s = void 0;
- return Wt.includes(e) && (s = e), n.map(function (t) {
- if (t.values) {
- var e = t.values;
- e = (e = e.map(function (t) {
- return isNaN(t) ? 0 : t
- })).length > i ? e.slice(0, i) : h(e, i - e.length, 0)
- } else t.values = a;
- s ? t.chartType = s : t.chartType || (t.chartType = jt)
- }), t.yRegions && t.yRegions.map(function (t) {
- if (t.end < t.start) {
- var e = [t.end, t.start];
- t.start = e[0], t.end = e[1]
- }
- }), t
- }
-
- function Ct(t) {
- var e = t.labels.length,
- i = new Array(e).fill(0),
- n = {
- labels: t.labels.slice(0, -1),
- datasets: t.datasets.map(function (t) {
- return {
- name: "",
- values: i.slice(0, -1),
- chartType: t.chartType
- }
- })
- };
- return t.yMarkers && (n.yMarkers = [{
- value: 0,
- label: ""
- }]), t.yRegions && (n.yRegions = [{
- start: 0,
- end: 0,
- label: ""
- }]), n
- }
-
- function Lt(t) {
- var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : [],
- i = !(arguments.length > 2 && void 0 !== arguments[2]) || arguments[2],
- n = t / e.length;
- n <= 0 && (n = 1);
- var a = n / Rt;
- return e.map(function (t, e) {
- return (t += "").length > a && (i ? e % Math.ceil(t.length / a) != 0 && (t = "") : t = a - 3 > 0 ? t.slice(0, a - 3) + " ..." : t.slice(0, a) + ".."), t
- })
- }
-
- function Tt() {
- var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : "line",
- e = arguments[1],
- i = arguments[2];
- return "axis-mixed" === t ? (i.type = "line", new ke(e, i)) : we[t] ? new we[t](e, i) : void console.error("Undefined chart type: " + t)
- }! function (t, e) {
- void 0 === e && (e = {});
- var i = e.insertAt;
- if (t && "undefined" != typeof document) {
- var n = document.head || document.getElementsByTagName("head")[0],
- a = document.createElement("style");
- a.type = "text/css", "top" === i && n.firstChild ? n.insertBefore(a, n.firstChild) : n.appendChild(a), a.styleSheet ? a.styleSheet.cssText = t : a.appendChild(document.createTextNode(t))
- }
- }('.chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:1;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ol,.graph-svg-tip ul{padding-left:0;display:-webkit-box;display:-ms-flexbox;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:" ";border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}', {});
- var Dt = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (t) {
- return typeof t
- } : function (t) {
- return t && "function" == typeof Symbol && t.constructor === Symbol && t !== Symbol.prototype ? "symbol" : typeof t
- },
- Ot = (function () {
- function t(t) {
- this.value = t
- }
-
- function e(e) {
- function i(t, e) {
- return new Promise(function (i, a) {
- var o = {
- key: t,
- arg: e,
- resolve: i,
- reject: a,
- next: null
- };
- r ? r = r.next = o : (s = r = o, n(t, e))
- })
- }
-
- function n(i, s) {
- try {
- var r = e[i](s),
- o = r.value;
- o instanceof t ? Promise.resolve(o.value).then(function (t) {
- n("next", t)
- }, function (t) {
- n("throw", t)
- }) : a(r.done ? "return" : "normal", r.value)
- } catch (t) {
- a("throw", t)
- }
- }
-
- function a(t, e) {
- switch (t) {
- case "return":
- s.resolve({
- value: e,
- done: !0
- });
- break;
- case "throw":
- s.reject(e);
- break;
- default:
- s.resolve({
- value: e,
- done: !1
- })
- }(s = s.next) ? n(s.key, s.arg): r = null
- }
- var s, r;
- this._invoke = i, "function" != typeof e.return && (this.return = void 0)
- }
- "function" == typeof Symbol && Symbol.asyncIterator && (e.prototype[Symbol.asyncIterator] = function () {
- return this
- }), e.prototype.next = function (t) {
- return this._invoke("next", t)
- }, e.prototype.throw = function (t) {
- return this._invoke("throw", t)
- }, e.prototype.return = function (t) {
- return this._invoke("return", t)
- }
- }(), function (t, e) {
- if (!(t instanceof e)) throw new TypeError("Cannot call a class as a function")
- }),
- Mt = function () {
- function t(t, e) {
- for (var i = 0; i < e.length; i++) {
- var n = e[i];
- n.enumerable = n.enumerable || !1, n.configurable = !0, "value" in n && (n.writable = !0), Object.defineProperty(t, n.key, n)
- }
- }
- return function (e, i, n) {
- return i && t(e.prototype, i), n && t(e, n), e
- }
- }(),
- Nt = function t(e, i, n) {
- null === e && (e = Function.prototype);
- var a = Object.getOwnPropertyDescriptor(e, i);
- if (void 0 === a) {
- var s = Object.getPrototypeOf(e);
- return null === s ? void 0 : t(s, i, n)
- }
- if ("value" in a) return a.value;
- var r = a.get;
- if (void 0 !== r) return r.call(n)
- },
- Et = function (t, e) {
- if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function, not " + typeof e);
- t.prototype = Object.create(e && e.prototype, {
- constructor: {
- value: t,
- enumerable: !1,
- writable: !0,
- configurable: !0
- }
- }), e && (Object.setPrototypeOf ? Object.setPrototypeOf(t, e) : t.__proto__ = e)
- },
- St = function (t, e) {
- if (!t) throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
- return !e || "object" != typeof e && "function" != typeof e ? t : e
- },
- _t = function () {
- function t(t, e) {
- var i = [],
- n = !0,
- a = !1,
- s = void 0;
- try {
- for (var r, o = t[Symbol.iterator](); !(n = (r = o.next()).done) && (i.push(r.value), !e || i.length !== e); n = !0);
- } catch (t) {
- a = !0, s = t
- } finally {
- try {
- !n && o.return && o.return()
- } finally {
- if (a) throw s
- }
- }
- return i
- }
- return function (e, i) {
- if (Array.isArray(e)) return e;
- if (Symbol.iterator in Object(e)) return t(e, i);
- throw new TypeError("Invalid attempt to destructure non-iterable instance")
- }
- }(),
- zt = function (t) {
- if (Array.isArray(t)) {
- for (var e = 0, i = Array(t.length); e < t.length; e++) i[e] = t[e];
- return i
- }
- return Array.from(t)
- };
- t.create = function (e, i) {
- var n = document.createElement(e);
- for (var a in i) {
- var s = i[a];
- if ("inside" === a) t(s).appendChild(n);
- else if ("around" === a) {
- var r = t(s);
- r.parentNode.insertBefore(n, r), n.appendChild(r)
- } else "onClick" === a ? n.addEventListener("click", s) : "onInput" === a ? n.addEventListener("input", function (t) {
- s(n.value)
- }) : "styles" === a ? "object" === (void 0 === s ? "undefined" : Dt(s)) && Object.keys(s).map(function (t) {
- n.style[t] = s[t]
- }) : a in n ? n[a] = s : n.setAttribute(a, s)
- }
- return n
- };
- var Ht = {
- margins: {
- top: 10,
- bottom: 10,
- left: 20,
- right: 20
- },
- paddings: {
- top: 20,
- bottom: 40,
- left: 30,
- right: 10
- },
- baseHeight: 240,
- titleHeight: 20,
- legendHeight: 30,
- titleFontSize: 12
- },
- Ft = 700,
- jt = "line",
- Wt = ["line", "bar"],
- It = 2,
- Rt = 7,
- Yt = ["light-blue", "blue", "violet", "red", "orange", "yellow", "green", "light-green", "purple", "magenta", "light-grey", "dark-grey"],
- Vt = {
- bar: Yt,
- line: Yt,
- pie: Yt,
- percentage: Yt,
- heatmap: ["#ebedf0", "#c6e48b", "#7bc96f", "#239a3b", "#196127"]
- },
- Bt = Math.PI / 180,
- Ut = function () {
- function e(t) {
- var i = t.parent,
- n = void 0 === i ? null : i,
- a = t.colors,
- s = void 0 === a ? [] : a;
- Ot(this, e), this.parent = n, this.colors = s, this.titleName = "", this.titleValue = "", this.listValues = [], this.titleValueFirst = 0, this.x = 0, this.y = 0, this.top = 0, this.left = 0, this.setup()
- }
- return Mt(e, [{
- key: "setup",
- value: function () {
- this.makeTooltip()
- }
- }, {
- key: "refresh",
- value: function () {
- this.fill(), this.calcPosition()
- }
- }, {
- key: "makeTooltip",
- value: function () {
- var e = this;
- this.container = t.create("div", {
- inside: this.parent,
- className: "graph-svg-tip comparison",
- innerHTML: '\n\t\t\t\t\n\t\t\t\t'
- }), this.hideTip(), this.title = this.container.querySelector(".title"), this.dataPointList = this.container.querySelector(".data-point-list"), this.parent.addEventListener("mouseleave", function () {
- e.hideTip()
- })
- }
- }, {
- key: "fill",
- value: function () {
- var e = this,
- i = void 0;
- this.index && this.container.setAttribute("data-point-index", this.index), i = this.titleValueFirst ? "" + this.titleValue + "" + this.titleName : this.titleName + "" + this.titleValue + "", this.title.innerHTML = i, this.dataPointList.innerHTML = "", this.listValues.map(function (i, n) {
- var a = e.colors[n] || "black",
- s = 0 === i.formatted || i.formatted ? i.formatted : i.value,
- r = t.create("li", {
- styles: {
- "border-top": "3px solid " + a
- },
- innerHTML: '' + (0 === s || s ? s : "") + "\n\t\t\t\t\t" + (i.title ? i.title : "")
- });
- e.dataPointList.appendChild(r)
- })
- }
- }, {
- key: "calcPosition",
- value: function () {
- var t = this.container.offsetWidth;
- this.top = this.y - this.container.offsetHeight - 5, this.left = this.x - t / 2;
- var e = this.parent.offsetWidth - t,
- i = this.container.querySelector(".svg-pointer");
- if (this.left < 0) i.style.left = "calc(50% - " + -1 * this.left + "px)", this.left = 0;
- else if (this.left > e) {
- var n = "calc(50% + " + (this.left - e) + "px)";
- i.style.left = n, this.left = e
- } else i.style.left = "50%"
- }
- }, {
- key: "setValues",
- value: function (t, e) {
- var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : {},
- n = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : [],
- a = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : -1;
- this.titleName = i.name, this.titleValue = i.value, this.listValues = n, this.x = t, this.y = e, this.titleValueFirst = i.valueFirst || 0, this.index = a, this.refresh()
- }
- }, {
- key: "hideTip",
- value: function () {
- this.container.style.top = "0px", this.container.style.left = "0px", this.container.style.opacity = "0"
- }
- }, {
- key: "showTip",
- value: function () {
- this.container.style.top = this.top + "px", this.container.style.left = this.left + "px", this.container.style.opacity = "1"
- }
- }]), e
- }(),
- Gt = {
- "light-blue": "#7cd6fd",
- blue: "#5e64ff",
- violet: "#743ee2",
- red: "#ff5858",
- orange: "#ffa00a",
- yellow: "#feef72",
- green: "#28a745",
- "light-green": "#98d85b",
- purple: "#b554ff",
- magenta: "#ffa3ef",
- black: "#36114C",
- grey: "#bdd3e6",
- "light-grey": "#f0f4f7",
- "dark-grey": "#b8c2cc"
- },
- qt = function (t) {
- return Gt[t] || t
- },
- Xt = 6,
- Jt = 4,
- Kt = 10,
- $t = "#dadada",
- Qt = "#555b51",
- Zt = {
- bar: function (t) {
- var e = void 0;
- "rect" !== t.nodeName && (e = t.getAttribute("transform"), t = t.childNodes[0]);
- var i = t.cloneNode();
- return i.style.fill = "#000000", i.style.opacity = "0.4", e && i.setAttribute("transform", e), i
- },
- dot: function (t) {
- var e = void 0;
- "circle" !== t.nodeName && (e = t.getAttribute("transform"), t = t.childNodes[0]);
- var i = t.cloneNode(),
- n = t.getAttribute("r"),
- a = t.getAttribute("fill");
- return i.setAttribute("r", parseInt(n) + 4), i.setAttribute("fill", a), i.style.opacity = "0.6", e && i.setAttribute("transform", e), i
- },
- heat_square: function (t) {
- var e = void 0;
- "circle" !== t.nodeName && (e = t.getAttribute("transform"), t = t.childNodes[0]);
- var i = t.cloneNode(),
- n = t.getAttribute("r"),
- a = t.getAttribute("fill");
- return i.setAttribute("r", parseInt(n) + 4), i.setAttribute("fill", a), i.style.opacity = "0.6", e && i.setAttribute("transform", e), i
- }
- },
- te = {
- bar: function (t, e) {
- var i = void 0;
- "rect" !== t.nodeName && (i = t.getAttribute("transform"), t = t.childNodes[0]);
- var n = ["x", "y", "width", "height"];
- Object.values(t.attributes).filter(function (t) {
- return n.includes(t.name) && t.specified
- }).map(function (t) {
- e.setAttribute(t.name, t.nodeValue)
- }), i && e.setAttribute("transform", i)
- },
- dot: function (t, e) {
- var i = void 0;
- "circle" !== t.nodeName && (i = t.getAttribute("transform"), t = t.childNodes[0]);
- var n = ["cx", "cy"];
- Object.values(t.attributes).filter(function (t) {
- return n.includes(t.name) && t.specified
- }).map(function (t) {
- e.setAttribute(t.name, t.nodeValue)
- }), i && e.setAttribute("transform", i)
- },
- heat_square: function (t, e) {
- var i = void 0;
- "circle" !== t.nodeName && (i = t.getAttribute("transform"), t = t.childNodes[0]);
- var n = ["cx", "cy"];
- Object.values(t.attributes).filter(function (t) {
- return n.includes(t.name) && t.specified
- }).map(function (t) {
- e.setAttribute(t.name, t.nodeValue)
- }), i && e.setAttribute("transform", i)
- }
- },
- ee = 350,
- ie = 350,
- ne = ee,
- ae = 250,
- se = "easein",
- re = {
- ease: "0.25 0.1 0.25 1",
- linear: "0 0 1 1",
- easein: "0.1 0.8 0.2 1",
- easeout: "0 0 0.58 1",
- easeinout: "0.42 0 0.58 1"
- },
- oe = ".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}",
- le = void 0,
- ue = function () {
- function e(t, i) {
- if (Ot(this, e), this.parent = "string" == typeof t ? document.querySelector(t) : t, !(this.parent instanceof HTMLElement)) throw new Error("No `parent` element to render on was provided.");
- this.rawChartArgs = i, this.title = i.title || "", this.type = i.type || "line", this.realData = this.prepareData(i.data), this.data = this.prepareFirstData(this.realData), this.colors = this.validateColors(i.colors, this.type), this.config = {
- showTooltip: 1,
- showLegend: 1,
- isNavigable: i.isNavigable || 0,
- animate: 1
- }, this.measures = JSON.parse(JSON.stringify(Ht));
- var n = this.measures;
- this.setMeasures(i), this.title.length || (n.titleHeight = 0), this.config.showLegend || (n.legendHeight = 0), this.argHeight = i.height || n.baseHeight, this.state = {}, this.options = {}, this.initTimeout = Ft, this.config.isNavigable && (this.overlays = []), this.configure(i)
- }
- return Mt(e, [{
- key: "prepareData",
- value: function (t) {
- return t
- }
- }, {
- key: "prepareFirstData",
- value: function (t) {
- return t
- }
- }, {
- key: "validateColors",
- value: function (t, e) {
- var i = [];
- return (t = (t || []).concat(Vt[e])).forEach(function (t) {
- var e = qt(t);
- y(e) ? i.push(e) : console.warn('"' + t + '" is not a valid color.')
- }), i
- }
- }, {
- key: "setMeasures",
- value: function () {}
- }, {
- key: "configure",
- value: function () {
- var t = this.argHeight;
- this.baseHeight = t, this.height = t - o(this.measures), le = this.boundDrawFn.bind(this), window.addEventListener("resize", le), window.addEventListener("orientationchange", this.boundDrawFn.bind(this))
- }
- }, {
- key: "boundDrawFn",
- value: function () {
- this.draw(!0)
- }
- }, {
- key: "unbindWindowEvents",
- value: function () {
- window.removeEventListener("resize", le), window.removeEventListener("orientationchange", this.boundDrawFn.bind(this))
- }
- }, {
- key: "setup",
- value: function () {
- this.makeContainer(), this.updateWidth(), this.makeTooltip(), this.draw(!1, !0)
- }
- }, {
- key: "makeContainer",
- value: function () {
- this.parent.innerHTML = "";
- var e = {
- inside: this.parent,
- className: "chart-container"
- };
- this.independentWidth && (e.styles = {
- width: this.independentWidth + "px"
- }, this.parent.style.overflow = "auto"), this.container = t.create("div", e)
- }
- }, {
- key: "makeTooltip",
- value: function () {
- this.tip = new Ut({
- parent: this.container,
- colors: this.colors
- }), this.bindTooltip()
- }
- }, {
- key: "bindTooltip",
- value: function () {}
- }, {
- key: "draw",
- value: function () {
- var t = this,
- e = arguments.length > 0 && void 0 !== arguments[0] && arguments[0],
- i = arguments.length > 1 && void 0 !== arguments[1] && arguments[1];
- this.updateWidth(), this.calc(e), this.makeChartArea(), this.setupComponents(), this.components.forEach(function (e) {
- return e.setup(t.drawArea)
- }), this.render(this.components, !1), i && (this.data = this.realData, setTimeout(function () {
- t.update(t.data)
- }, this.initTimeout)), this.renderLegend(), this.setupNavigation(i)
- }
- }, {
- key: "calc",
- value: function () {}
- }, {
- key: "updateWidth",
- value: function () {
- this.baseWidth = n(this.parent), this.width = this.baseWidth - l(this.measures)
- }
- }, {
- key: "makeChartArea",
- value: function () {
- this.svg && this.container.removeChild(this.svg);
- var t = this.measures;
- this.svg = w(this.container, "frappe-chart chart", this.baseWidth, this.baseHeight), this.svgDefs = A(this.svg), this.title.length && (this.titleEL = E("title", t.margins.left, t.margins.top, this.title, {
- fontSize: t.titleFontSize,
- fill: "#666666",
- dy: t.titleFontSize
- }));
- var e = s(t);
- this.drawArea = P(this.type + "-chart chart-draw-area", "translate(" + r(t) + ", " + e + ")"), this.config.showLegend && (e += this.height + t.paddings.bottom, this.legendArea = P("chart-legend", "translate(" + r(t) + ", " + e + ")")), this.title.length && this.svg.appendChild(this.titleEL), this.svg.appendChild(this.drawArea), this.config.showLegend && this.svg.appendChild(this.legendArea), this.updateTipOffset(r(t), s(t))
- }
- }, {
- key: "updateTipOffset",
- value: function (t, e) {
- this.tip.offset = {
- x: t,
- y: e
- }
- }
- }, {
- key: "setupComponents",
- value: function () {
- this.components = new Map
- }
- }, {
- key: "update",
- value: function (t) {
- t || console.error("No data to update."), this.data = this.prepareData(t), this.calc(), this.render()
- }
- }, {
- key: "render",
- value: function () {
- var t = this,
- e = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : this.components,
- i = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1];
- this.config.isNavigable && this.overlays.map(function (t) {
- return t.parentNode.removeChild(t)
- });
- var n = [];
- e.forEach(function (t) {
- n = n.concat(t.update(i))
- }), n.length > 0 ? (Z(this.container, this.svg, n), setTimeout(function () {
- e.forEach(function (t) {
- return t.make()
- }), t.updateNav()
- }, 400)) : (e.forEach(function (t) {
- return t.make()
- }), this.updateNav())
- }
- }, {
- key: "updateNav",
- value: function () {
- this.config.isNavigable && (this.makeOverlay(), this.bindUnits())
- }
- }, {
- key: "renderLegend",
- value: function () {}
- }, {
- key: "setupNavigation",
- value: function () {
- var t = this,
- e = arguments.length > 0 && void 0 !== arguments[0] && arguments[0];
- this.config.isNavigable && e && (this.bindOverlay(), this.keyActions = {
- 13: this.onEnterKey.bind(this),
- 37: this.onLeftArrow.bind(this),
- 38: this.onUpArrow.bind(this),
- 39: this.onRightArrow.bind(this),
- 40: this.onDownArrow.bind(this)
- }, document.addEventListener("keydown", function (e) {
- i(t.container) && (e = e || window.event, t.keyActions[e.keyCode] && t.keyActions[e.keyCode]())
- }))
- }
- }, {
- key: "makeOverlay",
- value: function () {}
- }, {
- key: "updateOverlay",
- value: function () {}
- }, {
- key: "bindOverlay",
- value: function () {}
- }, {
- key: "bindUnits",
- value: function () {}
- }, {
- key: "onLeftArrow",
- value: function () {}
- }, {
- key: "onRightArrow",
- value: function () {}
- }, {
- key: "onUpArrow",
- value: function () {}
- }, {
- key: "onDownArrow",
- value: function () {}
- }, {
- key: "onEnterKey",
- value: function () {}
- }, {
- key: "addDataPoint",
- value: function () {}
- }, {
- key: "removeDataPoint",
- value: function () {}
- }, {
- key: "getDataPoint",
- value: function () {}
- }, {
- key: "setCurrentDataPoint",
- value: function () {}
- }, {
- key: "updateDataset",
- value: function () {}
- }, {
- key: "export",
- value: function () {
- var t = et(this.svg);
- tt(this.title || "Chart", [t])
- }
- }]), e
- }(),
- he = function (t) {
- function e(t, i) {
- return Ot(this, e), St(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, t, i))
- }
- return Et(e, t), Mt(e, [{
- key: "configure",
- value: function (t) {
- Nt(e.prototype.__proto__ || Object.getPrototypeOf(e.prototype), "configure", this).call(this, t), this.config.maxSlices = t.maxSlices || 20, this.config.maxLegendPoints = t.maxLegendPoints || 20
- }
- }, {
- key: "calc",
- value: function () {
- var t = this,
- e = this.state,
- i = this.config.maxSlices;
- e.sliceTotals = [];
- var n = this.data.labels.map(function (e, i) {
- var n = 0;
- return t.data.datasets.map(function (t) {
- n += t.values[i]
- }), [n, e]
- }).filter(function (t) {
- return t[0] >= 0
- }),
- a = n;
- if (n.length > i) {
- n.sort(function (t, e) {
- return e[0] - t[0]
- }), a = n.slice(0, i - 1);
- var s = 0;
- n.slice(i - 1).map(function (t) {
- s += t[0]
- }), a.push([s, "Rest"]), this.colors[i - 1] = "grey"
- }
- e.labels = [], a.map(function (t) {
- e.sliceTotals.push(t[0]), e.labels.push(t[1])
- }), e.grandTotal = e.sliceTotals.reduce(function (t, e) {
- return t + e
- }, 0), this.center = {
- x: this.width / 2,
- y: this.height / 2
- }
- }
- }, {
- key: "renderLegend",
- value: function () {
- var t = this,
- e = this.state;
- this.legendArea.textContent = "", this.legendTotals = e.sliceTotals.slice(0, this.config.maxLegendPoints);
- var i = 0,
- n = 0;
- this.legendTotals.map(function (a, s) {
- var r = Math.floor((t.width - l(t.measures)) / 110);
- i > r && (i = 0, n += 20);
- var o = N(110 * i + 5, n, 5, t.colors[s], e.labels[s] + ": " + a);
- t.legendArea.appendChild(o), i++
- })
- }
- }]), e
- }(ue),
- ce = 7,
- de = 1e3,
- pe = 86400,
- fe = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
- ve = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
- ge = function () {
- function t(e) {
- var i = e.layerClass,
- n = void 0 === i ? "" : i,
- a = e.layerTransform,
- s = void 0 === a ? "" : a,
- r = e.constants,
- o = e.getData,
- l = e.makeElements,
- u = e.animateElements;
- Ot(this, t), this.layerTransform = s, this.constants = r, this.makeElements = l, this.getData = o, this.animateElements = u, this.store = [], this.labels = [], this.layerClass = n, this.layerClass = "function" == typeof this.layerClass ? this.layerClass() : this.layerClass, this.refresh()
- }
- return Mt(t, [{
- key: "refresh",
- value: function (t) {
- this.data = t || this.getData()
- }
- }, {
- key: "setup",
- value: function (t) {
- this.layer = P(this.layerClass, this.layerTransform, t)
- }
- }, {
- key: "make",
- value: function () {
- this.render(this.data), this.oldData = this.data
- }
- }, {
- key: "render",
- value: function (t) {
- var e = this;
- this.store = this.makeElements(t), this.layer.textContent = "", this.store.forEach(function (t) {
- e.layer.appendChild(t)
- }), this.labels.forEach(function (t) {
- e.layer.appendChild(t)
- })
- }
- }, {
- key: "update",
- value: function () {
- var t = !(arguments.length > 0 && void 0 !== arguments[0]) || arguments[0];
- this.refresh();
- var e = [];
- return t && (e = this.animateElements(this.data) || []), e
- }
- }]), t
- }(),
- ye = {
- pieSlices: {
- layerClass: "pie-slices",
- makeElements: function (t) {
- return t.sliceStrings.map(function (e, i) {
- var n = C(e, "pie-path", "none", t.colors[i]);
- return n.style.transition = "transform .3s;", n
- })
- },
- animateElements: function (t) {
- return this.store.map(function (e, i) {
- return J(e, t.sliceStrings[i])
- })
- }
- },
- percentageBars: {
- layerClass: "percentage-bars",
- makeElements: function (t) {
- var e = this;
- return t.xPositions.map(function (i, n) {
- return D(i, 0, t.widths[n], e.constants.barHeight, e.constants.barDepth, t.colors[n])
- })
- },
- animateElements: function (t) {
- if (t) return []
- }
- },
- yAxis: {
- layerClass: "y axis",
- makeElements: function (t) {
- var e = this;
- return t.positions.map(function (i, n) {
- return z(i, t.labels[n], e.constants.width, {
- mode: e.constants.mode,
- pos: e.constants.pos
- })
- })
- },
- animateElements: function (t) {
- var e = t.positions,
- i = t.labels,
- n = this.oldData.positions,
- a = this.oldData.labels,
- s = f(n, e),
- r = _t(s, 2);
- n = r[0], e = r[1];
- var o = f(a, i),
- l = _t(o, 2);
- return a = l[0], i = l[1], this.render({
- positions: n,
- labels: i
- }), this.store.map(function (t, i) {
- return B(t, e[i], n[i])
- })
- }
- },
- xAxis: {
- layerClass: "x axis",
- makeElements: function (t) {
- var e = this;
- return t.positions.map(function (i, n) {
- return H(i, t.calcLabels[n], e.constants.height, {
- mode: e.constants.mode,
- pos: e.constants.pos
- })
- })
- },
- animateElements: function (t) {
- var e = t.positions,
- i = t.calcLabels,
- n = this.oldData.positions,
- a = this.oldData.calcLabels,
- s = f(n, e),
- r = _t(s, 2);
- n = r[0], e = r[1];
- var o = f(a, i),
- l = _t(o, 2);
- return a = l[0], i = l[1], this.render({
- positions: n,
- calcLabels: i
- }), this.store.map(function (t, i) {
- return V(t, e[i], n[i])
- })
- }
- },
- yMarkers: {
- layerClass: "y-markers",
- makeElements: function (t) {
- var e = this;
- return t.map(function (t) {
- return F(t.position, t.label, e.constants.width, {
- labelPos: t.options.labelPos,
- mode: "span",
- lineType: "dashed"
- })
- })
- },
- animateElements: function (t) {
- var e = f(this.oldData, t),
- i = _t(e, 2);
- this.oldData = i[0];
- var n = (t = i[1]).map(function (t) {
- return t.position
- }),
- a = t.map(function (t) {
- return t.label
- }),
- s = t.map(function (t) {
- return t.options
- }),
- r = this.oldData.map(function (t) {
- return t.position
- });
- return this.render(r.map(function (t, e) {
- return {
- position: r[e],
- label: a[e],
- options: s[e]
- }
- })), this.store.map(function (t, e) {
- return B(t, n[e], r[e])
- })
- }
- },
- yRegions: {
- layerClass: "y-regions",
- makeElements: function (t) {
- var e = this;
- return t.map(function (t) {
- return j(t.startPos, t.endPos, e.constants.width, t.label, {
- labelPos: t.options.labelPos
- })
- })
- },
- animateElements: function (t) {
- var e = f(this.oldData, t),
- i = _t(e, 2);
- this.oldData = i[0];
- var n = (t = i[1]).map(function (t) {
- return t.endPos
- }),
- a = t.map(function (t) {
- return t.label
- }),
- s = t.map(function (t) {
- return t.startPos
- }),
- r = t.map(function (t) {
- return t.options
- }),
- o = this.oldData.map(function (t) {
- return t.endPos
- }),
- l = this.oldData.map(function (t) {
- return t.startPos
- });
- this.render(o.map(function (t, e) {
- return {
- startPos: l[e],
- endPos: o[e],
- label: a[e],
- options: r[e]
- }
- }));
- var u = [];
- return this.store.map(function (t, e) {
- u = u.concat(U(t, s[e], n[e], o[e]))
- }), u
- }
- },
- heatDomain: {
- layerClass: function () {
- return "heat-domain domain-" + this.constants.index
- },
- makeElements: function (t) {
- var e = this,
- i = this.constants,
- n = i.index,
- a = i.colWidth,
- s = i.rowHeight,
- r = i.squareSize,
- o = i.xTranslate,
- l = 0;
- return this.serializedSubDomains = [], t.cols.map(function (t, i) {
- 1 === i && e.labels.push(E("domain-name", o, -12, lt(n, !0).toUpperCase(), {
- fontSize: 9
- })), t.map(function (t, i) {
- if (t.fill) {
- var n = {
- "data-date": t.yyyyMmDd,
- "data-value": t.dataValue,
- "data-day": i
- },
- a = O("day", o, l, r, t.fill, n);
- e.serializedSubDomains.push(a)
- }
- l += s
- }), l = 0, o += a
- }), this.serializedSubDomains
- },
- animateElements: function (t) {
- if (t) return []
- }
- },
- barGraph: {
- layerClass: function () {
- return "dataset-units dataset-bars dataset-" + this.constants.index
- },
- makeElements: function (t) {
- var e = this.constants;
- return this.unitType = "bar", this.units = t.yPositions.map(function (i, n) {
- return W(t.xPositions[n], i, t.barWidth, e.color, t.labels[n], n, t.offsets[n], {
- zeroLine: t.zeroLine,
- barsWidth: t.barsWidth,
- minHeight: e.minHeight
- })
- }), this.units
- },
- animateElements: function (t) {
- var e = t.xPositions,
- i = t.yPositions,
- n = t.offsets,
- a = t.labels,
- s = this.oldData.xPositions,
- r = this.oldData.yPositions,
- o = this.oldData.offsets,
- l = this.oldData.labels,
- u = f(s, e),
- h = _t(u, 2);
- s = h[0], e = h[1];
- var c = f(r, i),
- d = _t(c, 2);
- r = d[0], i = d[1];
- var p = f(o, n),
- v = _t(p, 2);
- o = v[0], n = v[1];
- var g = f(l, a),
- y = _t(g, 2);
- l = y[0], a = y[1], this.render({
- xPositions: s,
- yPositions: r,
- offsets: o,
- labels: a,
- zeroLine: this.oldData.zeroLine,
- barsWidth: this.oldData.barsWidth,
- barWidth: this.oldData.barWidth
- });
- var m = [];
- return this.store.map(function (a, s) {
- m = m.concat(G(a, e[s], i[s], t.barWidth, n[s], {
- zeroLine: t.zeroLine
- }))
- }), m
- }
- },
- lineGraph: {
- layerClass: function () {
- return "dataset-units dataset-line dataset-" + this.constants.index
- },
- makeElements: function (t) {
- var e = this.constants;
- return this.unitType = "dot", this.paths = {}, e.hideLine || (this.paths = R(t.xPositions, t.yPositions, e.color, {
- heatline: e.heatline,
- regionFill: e.regionFill
- }, {
- svgDefs: e.svgDefs,
- zeroLine: t.zeroLine
- })), this.units = [], e.hideDots || (this.units = t.yPositions.map(function (i, n) {
- return I(t.xPositions[n], i, t.radius, e.color, e.valuesOverPoints ? t.values[n] : "", n)
- })), Object.values(this.paths).concat(this.units)
- },
- animateElements: function (t) {
- var e = t.xPositions,
- i = t.yPositions,
- n = t.values,
- a = this.oldData.xPositions,
- s = this.oldData.yPositions,
- r = this.oldData.values,
- o = f(a, e),
- l = _t(o, 2);
- a = l[0], e = l[1];
- var u = f(s, i),
- h = _t(u, 2);
- s = h[0], i = h[1];
- var c = f(r, n),
- d = _t(c, 2);
- r = d[0], n = d[1], this.render({
- xPositions: a,
- yPositions: s,
- values: n,
- zeroLine: this.oldData.zeroLine,
- radius: this.oldData.radius
- });
- var p = [];
- return Object.keys(this.paths).length && (p = p.concat(X(this.paths, e, i, t.zeroLine))), this.units.length && this.units.map(function (t, n) {
- p = p.concat(q(t, e[n], i[n]))
- }), p
- }
- }
- },
- me = function (t) {
- function i(t, e) {
- Ot(this, i);
- var n = St(this, (i.__proto__ || Object.getPrototypeOf(i)).call(this, t, e));
- return n.type = "percentage", n.setup(), n
- }
- return Et(i, t), Mt(i, [{
- key: "setMeasures",
- value: function (t) {
- var e = this.measures;
- this.barOptions = t.barOptions || {};
- var i = this.barOptions;
- i.height = i.height || 20, i.depth = i.depth || It, e.paddings.right = 30, e.legendHeight = 80, e.baseHeight = 8 * (i.height + .5 * i.depth)
- }
- }, {
- key: "setupComponents",
- value: function () {
- var t = this.state,
- e = [
- ["percentageBars", {
- barHeight: this.barOptions.height,
- barDepth: this.barOptions.depth
- }, function () {
- return {
- xPositions: t.xPositions,
- widths: t.widths,
- colors: this.colors
- }
- }.bind(this)]
- ];
- this.components = new Map(e.map(function (t) {
- var e = dt.apply(void 0, zt(t));
- return [t[0], e]
- }))
- }
- }, {
- key: "calc",
- value: function () {
- var t = this;
- Nt(i.prototype.__proto__ || Object.getPrototypeOf(i.prototype), "calc", this).call(this);
- var e = this.state;
- e.xPositions = [], e.widths = [];
- var n = 0;
- e.sliceTotals.map(function (i) {
- var a = t.width * i / e.grandTotal;
- e.widths.push(a), e.xPositions.push(n), n += a
- })
- }
- }, {
- key: "makeDataByIndex",
- value: function () {}
- }, {
- key: "bindTooltip",
- value: function () {
- var t = this,
- i = this.state;
- this.container.addEventListener("mousemove", function (n) {
- var a = t.components.get("percentageBars").store,
- s = n.target;
- if (a.includes(s)) {
- var r = a.indexOf(s),
- o = e(t.container),
- l = e(s),
- u = l.left - o.left + parseInt(s.getAttribute("width")) / 2,
- h = l.top - o.top,
- c = (t.formattedLabels && t.formattedLabels.length > 0 ? t.formattedLabels[r] : t.state.labels[r]) + ": ",
- d = i.sliceTotals[r] / i.grandTotal;
- t.tip.setValues(u, h, {
- name: c,
- value: (100 * d).toFixed(1) + "%"
- }), t.tip.showTip()
- }
- })
- }
- }]), i
- }(he),
- be = function (t) {
- function i(t, e) {
- Ot(this, i);
- var n = St(this, (i.__proto__ || Object.getPrototypeOf(i)).call(this, t, e));
- return n.type = "pie", n.initTimeout = 0, n.init = 1, n.setup(), n
- }
- return Et(i, t), Mt(i, [{
- key: "configure",
- value: function (t) {
- Nt(i.prototype.__proto__ || Object.getPrototypeOf(i.prototype), "configure", this).call(this, t), this.mouseMove = this.mouseMove.bind(this), this.mouseLeave = this.mouseLeave.bind(this), this.hoverRadio = t.hoverRadio || .1, this.config.startAngle = t.startAngle || 0, this.clockWise = t.clockWise || !1
- }
- }, {
- key: "calc",
- value: function () {
- var t = this;
- Nt(i.prototype.__proto__ || Object.getPrototypeOf(i.prototype), "calc", this).call(this);
- var e = this.state;
- this.radius = this.height > this.width ? this.center.x : this.center.y;
- var n = this.radius,
- a = this.clockWise,
- s = e.slicesProperties || [];
- e.sliceStrings = [], e.slicesProperties = [];
- var r = 180 - this.config.startAngle;
- e.sliceTotals.map(function (i, o) {
- var l = r,
- u = i / e.grandTotal * 360,
- h = a ? -u : u,
- c = r += h,
- p = d(l, n),
- f = d(c, n),
- v = t.init && s[o],
- g = void 0,
- y = void 0;
- t.init ? (g = v ? v.startPosition : p, y = v ? v.endPosition : p) : (g = p, y = f);
- var m = L(g, y, t.center, t.radius, t.clockWise);
- e.sliceStrings.push(m), e.slicesProperties.push({
- startPosition: p,
- endPosition: f,
- value: i,
- total: e.grandTotal,
- startAngle: l,
- endAngle: c,
- angle: h
- })
- }), this.init = 0
- }
- }, {
- key: "setupComponents",
- value: function () {
- var t = this.state,
- e = [
- ["pieSlices", {}, function () {
- return {
- sliceStrings: t.sliceStrings,
- colors: this.colors
- }
- }.bind(this)]
- ];
- this.components = new Map(e.map(function (t) {
- var e = dt.apply(void 0, zt(t));
- return [t[0], e]
- }))
- }
- }, {
- key: "calTranslateByAngle",
- value: function (t) {
- var e = this.radius,
- i = this.hoverRadio,
- n = d(t.startAngle + t.angle / 2, e);
- return "translate3d(" + n.x * i + "px," + n.y * i + "px,0)"
- }
- }, {
- key: "hoverSlice",
- value: function (t, i, n, a) {
- if (t) {
- var s = this.colors[i];
- if (n) {
- $(t, this.calTranslateByAngle(this.state.slicesProperties[i])), t.style.fill = g(s, 50);
- var r = e(this.svg),
- o = a.pageX - r.left + 10,
- l = a.pageY - r.top - 10,
- u = (this.formatted_labels && this.formatted_labels.length > 0 ? this.formatted_labels[i] : this.state.labels[i]) + ": ",
- h = (100 * this.state.sliceTotals[i] / this.state.grandTotal).toFixed(1);
- this.tip.setValues(o, l, {
- name: u,
- value: h + "%"
- }), this.tip.showTip()
- } else $(t, "translate3d(0,0,0)"), this.tip.hideTip(), t.style.fill = s
- }
- }
- }, {
- key: "bindTooltip",
- value: function () {
- this.container.addEventListener("mousemove", this.mouseMove), this.container.addEventListener("mouseleave", this.mouseLeave)
- }
- }, {
- key: "mouseMove",
- value: function (t) {
- var e = t.target,
- i = this.components.get("pieSlices").store,
- n = this.curActiveSliceIndex,
- a = this.curActiveSlice;
- if (i.includes(e)) {
- var s = i.indexOf(e);
- this.hoverSlice(a, n, !1), this.curActiveSlice = e, this.curActiveSliceIndex = s, this.hoverSlice(e, s, !0, t)
- } else this.mouseLeave()
- }
- }, {
- key: "mouseLeave",
- value: function () {
- this.hoverSlice(this.curActiveSlice, this.curActiveSliceIndex, !1)
- }
- }]), i
- }(he),
- xe = function (t) {
- function e(t, i) {
- Ot(this, e);
- var n = St(this, (e.__proto__ || Object.getPrototypeOf(e)).call(this, t, i));
- n.type = "heatmap", n.countLabel = i.countLabel || "";
- var a = ["Sunday", "Monday"],
- s = a.includes(i.startSubDomain) ? i.startSubDomain : "Sunday";
- return n.startSubDomainIndex = a.indexOf(s), n.setup(), n
- }
- return Et(e, t), Mt(e, [{
- key: "setMeasures",
- value: function (t) {
- var e = this.measures;
- this.discreteDomains = 0 === t.discreteDomains ? 0 : 1, e.paddings.top = 36, e.paddings.bottom = 0, e.legendHeight = 24, e.baseHeight = 12 * ce + o(e);
- var i = this.data,
- n = this.discreteDomains ? 12 : 0;
- this.independentWidth = 12 * (st(i.start, i.end) + n) + l(e)
- }
- }, {
- key: "updateWidth",
- value: function () {
- var t = this.discreteDomains ? 12 : 0,
- e = this.state.noOfWeeks ? this.state.noOfWeeks : 52;
- this.baseWidth = 12 * (e + t) + l(this.measures)
- }
- }, {
- key: "prepareData",
- value: function () {
- var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : this.data;
- if (t.start && t.end && t.start > t.end) throw new Error("Start date cannot be greater than end date.");
- if (t.start || (t.start = new Date, t.start.setFullYear(t.start.getFullYear() - 1)), t.end || (t.end = new Date), t.dataPoints = t.dataPoints || {}, parseInt(Object.keys(t.dataPoints)[0]) > 1e5) {
- var e = {};
- Object.keys(t.dataPoints).forEach(function (i) {
- var n = new Date(i * de);
- e[nt(n)] = t.dataPoints[i]
- }), t.dataPoints = e
- }
- return t
- }
- }, {
- key: "calc",
- value: function () {
- var t = this.state;
- t.start = at(this.data.start), t.end = at(this.data.end), t.firstWeekStart = at(t.start), t.noOfWeeks = st(t.start, t.end), t.distribution = wt(Object.values(this.data.dataPoints), 5), t.domainConfigs = this.getDomains()
- }
- }, {
- key: "setupComponents",
- value: function () {
- var t = this,
- e = this.state,
- i = this.discreteDomains ? 0 : 1,
- n = e.domainConfigs.map(function (n, a) {
- return ["heatDomain", {
- index: n.index,
- colWidth: 12,
- rowHeight: 12,
- squareSize: 10,
- xTranslate: 12 * e.domainConfigs.filter(function (t, e) {
- return e < a
- }).map(function (t) {
- return t.cols.length - i
- }).reduce(function (t, e) {
- return t + e
- }, 0)
- }, function () {
- return e.domainConfigs[a]
- }.bind(t)]
- });
- this.components = new Map(n.map(function (t, e) {
- var i = dt.apply(void 0, zt(t));
- return [t[0] + "-" + e, i]
- }));
- var a = 0;
- ve.forEach(function (e, i) {
- if ([1, 3, 5].includes(i)) {
- var n = E("subdomain-name", -6, a, e, {
- fontSize: 10,
- dy: 8,
- textAnchor: "end"
- });
- t.drawArea.appendChild(n)
- }
- a += 12
- })
- }
- }, {
- key: "update",
- value: function (t) {
- t || console.error("No data to update."), this.data = this.prepareData(t), this.draw(), this.bindTooltip()
- }
- }, {
- key: "bindTooltip",
- value: function () {
- var t = this;
- this.container.addEventListener("mousemove", function (e) {
- t.components.forEach(function (i) {
- var n = i.store,
- a = e.target;
- if (n.includes(a)) {
- var s = a.getAttribute("data-value"),
- r = a.getAttribute("data-date").split("-"),
- o = lt(parseInt(r[1]) - 1, !0),
- l = t.container.getBoundingClientRect(),
- u = a.getBoundingClientRect(),
- h = parseInt(e.target.getAttribute("width")),
- c = u.left - l.left + h / 2,
- d = u.top - l.top,
- p = s + " " + t.countLabel,
- f = " on " + o + " " + r[0] + ", " + r[2];
- t.tip.setValues(c, d, {
- name: f,
- value: p,
- valueFirst: 1
- }, []), t.tip.showTip()
- }
- })
- })
- }
- }, {
- key: "renderLegend",
- value: function () {
- var t = this;
- this.legendArea.textContent = "";
- var e = 0,
- i = E("subdomain-name", e, 12, "Less", {
- fontSize: 11,
- dy: 9
- });
- e = 30, this.legendArea.appendChild(i), this.colors.slice(0, 5).map(function (i, n) {
- var a = O("heatmap-legend-unit", e + 15 * n, 12, 10, i);
- t.legendArea.appendChild(a)
- });
- var n = E("subdomain-name", e + 75 + 3, 12, "More", {
- fontSize: 11,
- dy: 9
- });
- this.legendArea.appendChild(n)
- }
- }, {
- key: "getDomains",
- value: function () {
- for (var t = this.state, e = [t.start.getMonth(), t.start.getFullYear()], i = e[0], n = e[1], a = [t.end.getMonth(), t.end.getFullYear()], s = a[0] - i + 1 + 12 * (a[1] - n), r = [], o = at(t.start), l = 0; l < s; l++) {
- var u = t.end;
- if (!ot(o, t.end)) {
- var h = [o.getMonth(), o.getFullYear()];
- u = ut(h[0], h[1])
- }
- r.push(this.getDomainConfig(o, u)), ct(u, 1), o = u
- }
- return r
- }
- }, {
- key: "getDomainConfig",
- value: function (t) {
- var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : "",
- i = [t.getMonth(), t.getFullYear()],
- n = i[0],
- a = i[1],
- s = ht(t),
- r = {
- index: n,
- cols: []
- };
- ct(e = at(e) || ut(n, a), 1);
- for (var o = st(s, e), l = [], u = void 0, h = 0; h < o; h++) u = this.getCol(s, n), l.push(u), ct(s = new Date(u[ce - 1].yyyyMmDd), 1);
- return void 0 !== u[ce - 1].dataValue && (ct(s, 1), l.push(this.getCol(s, n, !0))), r.cols = l, r
- }
- }, {
- key: "getCol",
- value: function (t, e) {
- for (var i = arguments.length > 2 && void 0 !== arguments[2] && arguments[2], n = this.state, a = at(t), s = [], r = 0; r < ce; r++, ct(a, 1)) {
- var o = {},
- l = a >= n.start && a <= n.end;
- i || a.getMonth() !== e || !l ? o.yyyyMmDd = nt(a) : o = this.getSubDomainConfig(a), s.push(o)
- }
- return s
- }
- }, {
- key: "getSubDomainConfig",
- value: function (t) {
- var e = nt(t),
- i = this.data.dataPoints[e];
- return {
- yyyyMmDd: e,
- dataValue: i || 0,
- fill: this.colors[At(i, this.state.distribution)]
- }
- }
- }]), e
- }(ue),
- ke = function (t) {
- function i(t, e) {
- Ot(this, i);
- var n = St(this, (i.__proto__ || Object.getPrototypeOf(i)).call(this, t, e));
- return n.barOptions = e.barOptions || {}, n.lineOptions = e.lineOptions || {}, n.init = 1, n.setup(), n
- }
- return Et(i, t), Mt(i, [{
- key: "setMeasures",
- value: function () {
- this.data.datasets.length <= 1 && (this.config.showLegend = 0, this.measures.paddings.bottom = 30)
- }
- }, {
- key: "configure",
- value: function (t) {
- Nt(i.prototype.__proto__ || Object.getPrototypeOf(i.prototype), "configure", this).call(this, t), t.axisOptions = t.axisOptions || {}, t.tooltipOptions = t.tooltipOptions || {}, this.config.xAxisMode = t.axisOptions.xAxisMode || "span", this.config.yAxisMode = t.axisOptions.yAxisMode || "span", this.config.xIsSeries = t.axisOptions.xIsSeries || 0, this.config.formatTooltipX = t.tooltipOptions.formatTooltipX, this.config.formatTooltipY = t.tooltipOptions.formatTooltipY, this.config.valuesOverPoints = t.valuesOverPoints
- }
- }, {
- key: "prepareData",
- value: function () {
- return Pt(arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : this.data, this.type)
- }
- }, {
- key: "prepareFirstData",
- value: function () {
- return Ct(arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : this.data)
- }
- }, {
- key: "calc",
- value: function () {
- var t = arguments.length > 0 && void 0 !== arguments[0] && arguments[0];
- this.calcXPositions(), t || this.calcYAxisParameters(this.getAllYValues(), "line" === this.type), this.makeDataByIndex()
- }
- }, {
- key: "calcXPositions",
- value: function () {
- var t = this.state,
- e = this.data.labels;
- t.datasetLength = e.length, t.unitWidth = this.width / t.datasetLength, t.xOffset = t.unitWidth / 2, t.xAxis = {
- labels: e,
- positions: e.map(function (e, i) {
- return u(t.xOffset + i * t.unitWidth)
- })
- }
- }
- }, {
- key: "calcYAxisParameters",
- value: function (t) {
- var e = gt(t, arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : "false"),
- i = this.height / bt(e),
- n = mt(e) * i,
- a = this.height - yt(e) * n;
- this.state.yAxis = {
- labels: e,
- positions: e.map(function (t) {
- return a - t * i
- }),
- scaleMultiplier: i,
- zeroLine: a
- }, this.calcDatasetPoints(), this.calcYExtremes(), this.calcYRegions()
- }
- }, {
- key: "calcDatasetPoints",
- value: function () {
- var t = this.state,
- e = function (e) {
- return e.map(function (e) {
- return xt(e, t.yAxis)
- })
- };
- t.datasets = this.data.datasets.map(function (t, i) {
- var n = t.values,
- a = t.cumulativeYs || [];
- return {
- name: t.name,
- index: i,
- chartType: t.chartType,
- values: n,
- yPositions: e(n),
- cumulativeYs: a,
- cumulativeYPos: e(a)
- }
- })
- }
- }, {
- key: "calcYExtremes",
- value: function () {
- var t = this.state;
- if (this.barOptions.stacked) return void(t.yExtremes = t.datasets[t.datasets.length - 1].cumulativeYPos);
- t.yExtremes = new Array(t.datasetLength).fill(9999), t.datasets.map(function (e) {
- e.yPositions.map(function (e, i) {
- e < t.yExtremes[i] && (t.yExtremes[i] = e)
- })
- })
- }
- }, {
- key: "calcYRegions",
- value: function () {
- var t = this.state;
- this.data.yMarkers && (this.state.yMarkers = this.data.yMarkers.map(function (e) {
- return e.position = xt(e.value, t.yAxis), e.options || (e.options = {}), e
- })), this.data.yRegions && (this.state.yRegions = this.data.yRegions.map(function (e) {
- return e.startPos = xt(e.start, t.yAxis), e.endPos = xt(e.end, t.yAxis), e.options || (e.options = {}), e
- }))
- }
- }, {
- key: "getAllYValues",
- value: function () {
- var t, e = this,
- i = "values";
- if (this.barOptions.stacked) {
- i = "cumulativeYs";
- var n = new Array(this.state.datasetLength).fill(0);
- this.data.datasets.map(function (t, a) {
- var s = e.data.datasets[a].values;
- t[i] = n = n.map(function (t, e) {
- return t + s[e]
- })
- })
- }
- var a = this.data.datasets.map(function (t) {
- return t[i]
- });
- return this.data.yMarkers && a.push(this.data.yMarkers.map(function (t) {
- return t.value
- })), this.data.yRegions && this.data.yRegions.map(function (t) {
- a.push([t.end, t.start])
- }), (t = []).concat.apply(t, zt(a))
- }
- }, {
- key: "setupComponents",
- value: function () {
- var t = this,
- e = [
- ["yAxis", {
- mode: this.config.yAxisMode,
- width: this.width
- }, function () {
- return this.state.yAxis
- }.bind(this)],
- ["xAxis", {
- mode: this.config.xAxisMode,
- height: this.height
- }, function () {
- var t = this.state;
- return t.xAxis.calcLabels = Lt(this.width, t.xAxis.labels, this.config.xIsSeries), t.xAxis
- }.bind(this)],
- ["yRegions", {
- width: this.width,
- pos: "right"
- }, function () {
- return this.state.yRegions
- }.bind(this)]
- ],
- i = this.state.datasets.filter(function (t) {
- return "bar" === t.chartType
- }),
- n = this.state.datasets.filter(function (t) {
- return "line" === t.chartType
- }),
- a = i.map(function (e) {
- var n = e.index;
- return ["barGraph-" + e.index, {
- index: n,
- color: t.colors[n],
- stacked: t.barOptions.stacked,
- valuesOverPoints: t.config.valuesOverPoints,
- minHeight: .02 * t.height
- }, function () {
- var t = this.state,
- e = t.datasets[n],
- a = this.barOptions.stacked,
- s = this.barOptions.spaceRatio || 1,
- r = t.unitWidth / 2 * (2 - s),
- o = r / (a ? 1 : i.length),
- l = t.xAxis.positions.map(function (t) {
- return t - r / 2
- });
- a || (l = l.map(function (t) {
- return t + o * n
- }));
- var u = new Array(t.datasetLength).fill("");
- this.config.valuesOverPoints && (u = a && e.index === t.datasets.length - 1 ? e.cumulativeYs : e.values);
- var h = new Array(t.datasetLength).fill(0);
- return a && (h = e.yPositions.map(function (t, i) {
- return t - e.cumulativeYPos[i]
- })), {
- xPositions: l,
- yPositions: e.yPositions,
- offsets: h,
- labels: u,
- zeroLine: t.yAxis.zeroLine,
- barsWidth: r,
- barWidth: o
- }
- }.bind(t)]
- }),
- s = n.map(function (e) {
- var i = e.index;
- return ["lineGraph-" + e.index, {
- index: i,
- color: t.colors[i],
- svgDefs: t.svgDefs,
- heatline: t.lineOptions.heatline,
- regionFill: t.lineOptions.regionFill,
- hideDots: t.lineOptions.hideDots,
- hideLine: t.lineOptions.hideLine,
- valuesOverPoints: t.config.valuesOverPoints
- }, function () {
- var t = this.state,
- e = t.datasets[i],
- n = t.yAxis.positions[0] < t.yAxis.zeroLine ? t.yAxis.positions[0] : t.yAxis.zeroLine;
- return {
- xPositions: t.xAxis.positions,
- yPositions: e.yPositions,
- values: e.values,
- zeroLine: n,
- radius: this.lineOptions.dotSize || 4
- }
- }.bind(t)]
- }),
- r = [
- ["yMarkers", {
- width: this.width,
- pos: "right"
- }, function () {
- return this.state.yMarkers
- }.bind(this)]
- ];
- e = e.concat(a, s, r);
- var o = ["yMarkers", "yRegions"];
- this.dataUnitComponents = [], this.components = new Map(e.filter(function (e) {
- return !o.includes(e[0]) || t.state[e[0]]
- }).map(function (e) {
- var i = dt.apply(void 0, zt(e));
- return (e[0].includes("lineGraph") || e[0].includes("barGraph")) && t.dataUnitComponents.push(i), [e[0], i]
- }))
- }
- }, {
- key: "makeDataByIndex",
- value: function () {
- var t = this;
- this.dataByIndex = {};
- var e = this.state,
- i = this.config.formatTooltipX,
- n = this.config.formatTooltipY;
- e.xAxis.labels.map(function (a, s) {
- var r = t.state.datasets.map(function (e, i) {
- var a = e.values[s];
- return {
- title: e.name,
- value: a,
- yPos: e.yPositions[s],
- color: t.colors[i],
- formatted: n ? n(a) : a
- }
- });
- t.dataByIndex[s] = {
- label: a,
- formattedLabel: i ? i(a) : a,
- xPos: e.xAxis.positions[s],
- values: r,
- yExtreme: e.yExtremes[s]
- }
- })
- }
- }, {
- key: "bindTooltip",
- value: function () {
- var t = this;
- this.container.addEventListener("mousemove", function (i) {
- var n = t.measures,
- a = e(t.container),
- o = i.pageX - a.left - r(n),
- l = i.pageY - a.top;
- l < t.height + s(n) && l > s(n) ? t.mapTooltipXPosition(o) : t.tip.hideTip()
- })
- }
- }, {
- key: "mapTooltipXPosition",
- value: function (t) {
- var e = this.state;
- if (e.yExtremes) {
- var i = kt(t, e.xAxis.positions, !0),
- n = this.dataByIndex[i];
- this.tip.setValues(n.xPos + this.tip.offset.x, n.yExtreme + this.tip.offset.y, {
- name: n.formattedLabel,
- value: ""
- }, n.values, i), this.tip.showTip()
- }
- }
- }, {
- key: "renderLegend",
- value: function () {
- var t = this,
- e = this.data;
- e.datasets.length > 1 && (this.legendArea.textContent = "", e.datasets.map(function (e, i) {
- var n = M(100 * i, "0", 100, t.colors[i], e.name);
- t.legendArea.appendChild(n)
- }))
- }
- }, {
- key: "makeOverlay",
- value: function () {
- var t = this;
- if (this.init) return void(this.init = 0);
- this.overlayGuides && this.overlayGuides.forEach(function (t) {
- var e = t.overlay;
- e.parentNode.removeChild(e)
- }), this.overlayGuides = this.dataUnitComponents.map(function (t) {
- return {
- type: t.unitType,
- overlay: void 0,
- units: t.units
- }
- }), void 0 === this.state.currentIndex && (this.state.currentIndex = this.state.datasetLength - 1), this.overlayGuides.map(function (e) {
- var i = e.units[t.state.currentIndex];
- e.overlay = Zt[e.type](i), t.drawArea.appendChild(e.overlay)
- })
- }
- }, {
- key: "updateOverlayGuides",
- value: function () {
- this.overlayGuides && this.overlayGuides.forEach(function (t) {
- var e = t.overlay;
- e.parentNode.removeChild(e)
- })
- }
- }, {
- key: "bindOverlay",
- value: function () {
- var t = this;
- this.parent.addEventListener("data-select", function () {
- t.updateOverlay()
- })
- }
- }, {
- key: "bindUnits",
- value: function () {
- var t = this;
- this.dataUnitComponents.map(function (e) {
- e.units.map(function (e) {
- e.addEventListener("click", function () {
- var i = e.getAttribute("data-point-index");
- t.setCurrentDataPoint(i)
- })
- })
- }), this.tip.container.addEventListener("click", function () {
- var e = t.tip.container.getAttribute("data-point-index");
- t.setCurrentDataPoint(e)
- })
- }
- }, {
- key: "updateOverlay",
- value: function () {
- var t = this;
- this.overlayGuides.map(function (e) {
- var i = e.units[t.state.currentIndex];
- te[e.type](i, e.overlay)
- })
- }
- }, {
- key: "onLeftArrow",
- value: function () {
- this.setCurrentDataPoint(this.state.currentIndex - 1)
- }
- }, {
- key: "onRightArrow",
- value: function () {
- this.setCurrentDataPoint(this.state.currentIndex + 1)
- }
- }, {
- key: "getDataPoint",
- value: function () {
- var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : this.state.currentIndex,
- e = this.state;
- return {
- index: t,
- label: e.xAxis.labels[t],
- values: e.datasets.map(function (e) {
- return e.values[t]
- })
- }
- }
- }, {
- key: "setCurrentDataPoint",
- value: function (t) {
- var e = this.state;
- (t = parseInt(t)) < 0 && (t = 0), t >= e.xAxis.labels.length && (t = e.xAxis.labels.length - 1), t !== e.currentIndex && (e.currentIndex = t, a(this.parent, "data-select", this.getDataPoint()))
- }
- }, {
- key: "addDataPoint",
- value: function (t, e) {
- var n = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : this.state.datasetLength;
- Nt(i.prototype.__proto__ || Object.getPrototypeOf(i.prototype), "addDataPoint", this).call(this, t, e, n), this.data.labels.splice(n, 0, t), this.data.datasets.map(function (t, i) {
- t.values.splice(n, 0, e[i])
- }), this.update(this.data)
- }
- }, {
- key: "removeDataPoint",
- value: function () {
- var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : this.state.datasetLength - 1;
- this.data.labels.length <= 1 || (Nt(i.prototype.__proto__ || Object.getPrototypeOf(i.prototype), "removeDataPoint", this).call(this, t), this.data.labels.splice(t, 1), this.data.datasets.map(function (e) {
- e.values.splice(t, 1)
- }), this.update(this.data))
- }
- }, {
- key: "updateDataset",
- value: function (t) {
- var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : 0;
- this.data.datasets[e].values = t, this.update(this.data)
- }
- }, {
- key: "updateDatasets",
- value: function (t) {
- this.data.datasets.map(function (e, i) {
- t[i] && (e.values = t[i])
- }), this.update(this.data)
- }
- }]), i
- }(ue),
- we = {
- bar: ke,
- line: ke,
- percentage: me,
- heatmap: xe,
- pie: be
- },
- Ae = function t(e, i) {
- return Ot(this, t), Tt(i.type, e, i)
- },
- Pe = Object.freeze({
- Chart: Ae,
- PercentageChart: me,
- PieChart: be,
- Heatmap: xe,
- AxisChart: ke
- }),
- Ce = {};
- return Ce.NAME = "Frappe Charts", Ce.VERSION = "1.1.0", Ce = Object.assign({}, Ce, Pe)
-}();
+var frappe=function(){"use strict";function t(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function e(t){var e=t.getBoundingClientRect();return{top:e.top+(document.documentElement.scrollTop||document.body.scrollTop),left:e.left+(document.documentElement.scrollLeft||document.body.scrollLeft)}}function i(t){var e=t.getBoundingClientRect();return e.top>=0&&e.left>=0&&e.bottom<=(window.innerHeight||document.documentElement.clientHeight)&&e.right<=(window.innerWidth||document.documentElement.clientWidth)}function n(t){var e=window.getComputedStyle(t),i=parseFloat(e.paddingLeft)+parseFloat(e.paddingRight);return t.clientWidth-i}function a(t,e,i){var n=document.createEvent("HTMLEvents");n.initEvent(e,!0,!0);for(var a in i)n[a]=i[a];return t.dispatchEvent(n)}function s(t){return t.titleHeight+t.margins.top+t.paddings.top}function r(t){return t.margins.left+t.paddings.left}function o(t){return t.margins.top+t.margins.bottom+t.paddings.top+t.paddings.bottom+t.titleHeight+t.legendHeight}function l(t){return t.margins.left+t.margins.right+t.paddings.left+t.paddings.right}function u(t){return parseFloat(t.toFixed(2))}function h(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]&&arguments[3];i||(i=n?t[0]:t[t.length-1]);var a=new Array(Math.abs(e)).fill(i);return t=n?a.concat(t):t.concat(a)}function c(t,e){return(t+"").length*e}function d(t,e){return{x:Math.sin(t*Bt)*e,y:Math.cos(t*Bt)*e}}function p(t,e){var i=void 0,n=void 0;return t<=e?(i=e-t,n=t):(i=t-e,n=e),[i,n]}function f(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:e.length-t.length;return i>0?t=h(t,i):e=h(e,i),[t,e]}function v(t){return t>255?255:t<0?0:t}function g(t,e){var i=qt(t),n=!1;"#"==i[0]&&(i=i.slice(1),n=!0);var a=parseInt(i,16),s=v((a>>16)+e),r=v((a>>8&255)+e),o=v((255&a)+e);return(n?"#":"")+(o|r<<8|s<<16).toString(16)}function y(t){return/(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)/i.test(t)}function m(t,e){return"string"==typeof t?(e||document).querySelector(t):t||null}function b(t,e){var i=document.createElementNS("http://www.w3.org/2000/svg",t);for(var n in e){var a=e[n];if("inside"===n)m(a).appendChild(i);else if("around"===n){var s=m(a);s.parentNode.insertBefore(i,s),i.appendChild(s)}else"styles"===n?"object"===(void 0===a?"undefined":Dt(a))&&Object.keys(a).map(function(t){i.style[t]=a[t]}):("className"===n&&(n="class"),"innerHTML"===n?i.textContent=a:i.setAttribute(n,a))}return i}function x(t,e){return b("linearGradient",{inside:t,id:e,x1:0,x2:0,y1:0,y2:1})}function k(t,e,i,n){return b("stop",{inside:t,style:"stop-color: "+i,offset:e,"stop-opacity":n})}function w(t,e,i,n){return b("svg",{className:e,inside:t,width:i,height:n})}function A(t){return b("defs",{inside:t})}function P(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:void 0,n={className:t,transform:e};return i&&(n.inside=i),b("g",n)}function C(t){return b("path",{className:arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",d:t,styles:{stroke:arguments.length>2&&void 0!==arguments[2]?arguments[2]:"none",fill:arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none"}})}function L(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:1,s=i.x+t.x,r=i.y+t.y,o=i.x+e.x,l=i.y+e.y;return"M"+i.x+" "+i.y+"\n\t\tL"+s+" "+r+"\n\t\tA "+n+" "+n+" 0 0 "+(a?1:0)+"\n\t\t"+o+" "+l+" z"}function T(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n="path-fill-gradient-"+e+"-"+(i?"lighter":"default"),a=x(t,n),s=[1,.6,.2];return i&&(s=[.4,.2,0]),k(a,"0%",e,s[0]),k(a,"50%",e,s[1]),k(a,"100%",e,s[2]),n}function D(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:It,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:"none";return b("rect",{className:"percentage-bar",x:t,y:e,width:i,height:n,fill:s,styles:{stroke:g(s,-25),"stroke-dasharray":"0, "+(n+i)+", "+i+", "+n,"stroke-width":a}})}function O(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"none",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},r={className:t,x:e,y:i,width:n,height:n,fill:a};return Object.keys(s).map(function(t){r[t]=s[t]}),b("rect",r)}function M(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4],s={className:"legend-bar",x:0,y:0,width:i,height:"2px",fill:n},r=b("text",{className:"legend-dataset-text",x:0,y:0,dy:2*Kt+"px","font-size":1.2*Kt+"px","text-anchor":"start",fill:Qt,innerHTML:a}),o=b("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(b("rect",s)),o.appendChild(r),o}function N(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"none",a=arguments[4],s={className:"legend-dot",cx:0,cy:0,r:i,fill:n},r=b("text",{className:"legend-dataset-text",x:0,y:0,dx:Kt+"px",dy:Kt/3+"px","font-size":1.2*Kt+"px","text-anchor":"start",fill:Qt,innerHTML:a}),o=b("g",{transform:"translate("+t+", "+e+")"});return o.appendChild(b("circle",s)),o.appendChild(r),o}function E(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=a.fontSize||Kt;return b("text",{className:t,x:e,y:i,dy:(void 0!==a.dy?a.dy:s/2)+"px","font-size":s+"px",fill:a.fill||Qt,"text-anchor":a.textAnchor||"start",innerHTML:n})}function S(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=$t);var s=b("line",{className:"line-vertical "+a.className,x1:0,x2:0,y1:i,y2:n,styles:{stroke:a.stroke}}),r=b("text",{x:0,y:i>n?i+Jt:i-Jt-Kt,dy:Kt+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:e+""}),o=b("g",{transform:"translate("+t+", 0)"});return o.appendChild(s),o.appendChild(r),o}function _(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{};a.stroke||(a.stroke=$t),a.lineType||(a.lineType="");var s=b("line",{className:"line-horizontal "+a.className+("dashed"===a.lineType?"dashed":""),x1:i,x2:n,y1:0,y2:0,styles:{stroke:a.stroke}}),r=b("text",{x:i3&&void 0!==arguments[3]?arguments[3]:{};n.pos||(n.pos="left"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=$t),n.className||(n.className="");var a=-1*Xt,s="span"===n.mode?i+Xt:0;return"tick"===n.mode&&"right"===n.pos&&(a=i+Xt,s=i),a+=n.offset,s+=n.offset,_(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType})}function H(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};n.pos||(n.pos="bottom"),n.offset||(n.offset=0),n.mode||(n.mode="span"),n.stroke||(n.stroke=$t),n.className||(n.className="");var a=i+Xt,s="span"===n.mode?-1*Xt:i;return"tick"===n.mode&&"top"===n.pos&&(a=-1*Xt,s=0),S(t,e,a,s,{stroke:n.stroke,className:n.className,lineType:n.lineType})}function F(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};n.labelPos||(n.labelPos="right");var a=b("text",{className:"chart-label",x:"left"===n.labelPos?Jt:i-c(e,5)-Jt,y:0,dy:Kt/-2+"px","font-size":Kt+"px","text-anchor":"start",innerHTML:e+""}),s=_(t,"",0,i,{stroke:n.stroke||$t,className:n.className||"",lineType:n.lineType});return s.appendChild(a),s}function j(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=t-e,r=b("rect",{className:"bar mini",styles:{fill:"rgba(228, 234, 239, 0.49)",stroke:$t,"stroke-dasharray":i+", "+s},x:0,y:0,width:i,height:s});a.labelPos||(a.labelPos="right");var o=b("text",{className:"chart-label",x:"left"===a.labelPos?Jt:i-c(n+"",4.5)-Jt,y:0,dy:Kt/-2+"px","font-size":Kt+"px","text-anchor":"start",innerHTML:n+""}),l=b("g",{transform:"translate(0, "+e+")"});return l.appendChild(r),l.appendChild(o),l}function W(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=arguments.length>6&&void 0!==arguments[6]?arguments[6]:0,o=arguments.length>7&&void 0!==arguments[7]?arguments[7]:{},l=p(e,o.zeroLine),u=_t(l,2),h=u[0],c=u[1];c-=r,0===h&&(h=o.minHeight,c-=o.minHeight);var d=b("rect",{className:"bar mini",style:"fill: "+n,"data-point-index":s,x:t,y:c,width:i,height:h});if((a+="")||a.length){d.setAttribute("y",0),d.setAttribute("x",0);var f=b("text",{className:"data-point-value",x:i/2,y:0,dy:Kt/2*-1+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:a}),v=b("g",{"data-point-index":s,transform:"translate("+t+", "+c+")"});return v.appendChild(d),v.appendChild(f),v}return d}function I(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:"",s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:0,r=b("circle",{style:"fill: "+n,"data-point-index":s,cx:t,cy:e,r:i});if((a+="")||a.length){r.setAttribute("cy",0),r.setAttribute("cx",0);var o=b("text",{className:"data-point-value",x:0,y:0,dy:Kt/2*-1-i+"px","font-size":Kt+"px","text-anchor":"middle",innerHTML:a}),l=b("g",{"data-point-index":s,transform:"translate("+t+", "+e+")"});return l.appendChild(r),l.appendChild(o),l}return r}function R(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:{},s=e.map(function(e,i){return t[i]+","+e}).join("L"),r=C("M"+s,"line-graph-path",i);if(n.heatline){var o=T(a.svgDefs,i);r.style.stroke="url(#"+o+")"}var l={path:r};if(n.areaFill){var u=T(a.svgDefs,i,!0),h="M"+t[0]+","+a.zeroLine+"L"+s+"L"+t.slice(-1)[0]+","+a.zeroLine;l.region=C(h,"region-fill","none","url(#"+u+")")}return l}function Y(t,e,i,n){var a="string"==typeof e?e:e.join(", ");return[t,{transform:i.join(", ")},n,se,"translate",{transform:a}]}function V(t,e,i){return Y(t,[i,0],[e,0],ne)}function B(t,e,i){return Y(t,[0,i],[0,e],ne)}function U(t,e,i,n){var a=e-i,s=t.childNodes[0];return[[s,{height:a,"stroke-dasharray":s.getAttribute("width")+", "+a},ne,se],Y(t,[0,n],[0,i],ne)]}function G(t,e,i,n){var a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:0,s=p(i,(arguments.length>5&&void 0!==arguments[5]?arguments[5]:{}).zeroLine),r=_t(s,2),o=r[0],l=r[1];return l-=a,"rect"!==t.nodeName?[[t.childNodes[0],{width:n,height:o},ee,se],Y(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,l],ne)]:[[t,{width:n,height:o,x:e,y:l},ee,se]]}function q(t,e,i){return"circle"!==t.nodeName?[Y(t,t.getAttribute("transform").split("(")[1].slice(0,-1),[e,i],ne)]:[[t,{cx:e,cy:i},ee,se]]}function X(t,e,i,n){var a=[],s=i.map(function(t,i){return e[i]+","+t}).join("L"),r=[t.path,{d:"M"+s},ie,se];if(a.push(r),t.region){var o=e[0]+","+n+"L",l="L"+e.slice(-1)[0]+", "+n,u=[t.region,{d:"M"+o+s+l},ie,se];a.push(u)}return a}function J(t,e){return[t,{d:e},ee,se]}function K(t,e,i){var n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:"linear",a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:void 0,s=arguments.length>5&&void 0!==arguments[5]?arguments[5]:{},r=t.cloneNode(!0),o=t.cloneNode(!0);for(var l in e){var u=void 0;u="transform"===l?document.createElementNS("http://www.w3.org/2000/svg","animateTransform"):document.createElementNS("http://www.w3.org/2000/svg","animate");var h=s[l]||t.getAttribute(l),c=e[l],d={attributeName:l,from:h,to:c,begin:"0s",dur:i/1e3+"s",values:h+";"+c,keySplines:re[n],keyTimes:"0;1",calcMode:"spline",fill:"freeze"};a&&(d.type=a);for(var p in d)u.setAttribute(p,d[p]);r.appendChild(u),a?o.setAttribute(l,"translate("+c+")"):o.setAttribute(l,c)}return[r,o]}function $(t,e){t.style.transform=e,t.style.webkitTransform=e,t.style.msTransform=e,t.style.mozTransform=e,t.style.oTransform=e}function Q(t,e){var i=[],n=[];e.map(function(t){var e=t[0],a=e.parentNode,s=void 0,r=void 0;t[0]=e;var o=K.apply(void 0,zt(t)),l=_t(o,2);s=l[0],r=l[1],i.push(r),n.push([s,a]),a.replaceChild(s,e)});var a=t.cloneNode(!0);return n.map(function(t,n){t[1].replaceChild(i[n],t[0]),e[n][0]=i[n]}),a}function Z(t,e,i){if(0!==i.length){var n=Q(e,i);e.parentNode==t&&(t.removeChild(e),t.appendChild(n)),setTimeout(function(){n.parentNode==t&&(t.removeChild(n),t.appendChild(e))},ae)}}function tt(t,e){var i=document.createElement("a");i.style="display: none";var n=new Blob(e,{type:"image/svg+xml; charset=utf-8"}),a=window.URL.createObjectURL(n);i.href=a,i.download=t,document.body.appendChild(i),i.click(),setTimeout(function(){document.body.removeChild(i),window.URL.revokeObjectURL(a)},300)}function et(e){var i=e.cloneNode(!0);i.classList.add("chart-container"),i.setAttribute("xmlns","http://www.w3.org/2000/svg"),i.setAttribute("xmlns:xlink","http://www.w3.org/1999/xlink");var n=t.create("style",{innerHTML:oe});i.insertBefore(n,i.firstChild);var a=t.create("div");return a.appendChild(i),a.innerHTML}function it(t){var e=new Date(t);return e.setMinutes(e.getMinutes()-e.getTimezoneOffset()),e}function nt(t){var e=t.getDate(),i=t.getMonth()+1;return[t.getFullYear(),(i>9?"":"0")+i,(e>9?"":"0")+e].join("-")}function at(t){return new Date(t.getTime())}function st(t,e){var i=ht(t);return Math.ceil(rt(i,e)/ce)}function rt(t,e){var i=pe*de;return(it(e)-it(t))/i}function ot(t,e){return t.getMonth()===e.getMonth()&&t.getFullYear()===e.getFullYear()}function lt(t){var e=arguments.length>1&&void 0!==arguments[1]&&arguments[1],i=fe[t];return e?i.slice(0,3):i}function ut(t,e){return new Date(e,t+1,0)}function ht(t){var e=at(t),i=e.getDay();return 0!==i&&ct(e,-1*i),e}function ct(t,e){t.setDate(t.getDate()+e)}function dt(t,e,i){var n=Object.keys(ye).filter(function(e){return t.includes(e)}),a=ye[n[0]];return Object.assign(a,{constants:e,getData:i}),new ge(a)}function pt(t){if(0===t)return[0,0];if(isNaN(t))return{mantissa:-6755399441055744,exponent:972};var e=t>0?1:-1;if(!isFinite(t))return{mantissa:4503599627370496*e,exponent:972};t=Math.abs(t);var i=Math.floor(Math.log10(t));return[e*(t/Math.pow(10,i)),i]}function ft(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=Math.ceil(t),n=Math.floor(e),a=i-n,s=a,r=1;a>5&&(a%2!=0&&(a=++i-n),s=a/2,r=2),a<=2&&(r=a/(s=4)),0===a&&(s=5,r=1);for(var o=[],l=0;l<=s;l++)o.push(n+r*l);return o}function vt(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=pt(t),n=_t(i,2),a=n[0],s=n[1],r=e?e/Math.pow(10,s):0,o=ft(a=a.toFixed(6),r);return o=o.map(function(t){return t*Math.pow(10,s)})}function gt(t){function e(t,e){for(var i=vt(t),n=i[1]-i[0],a=0,s=1;a1&&void 0!==arguments[1]&&arguments[1],n=Math.max.apply(Math,zt(t)),a=Math.min.apply(Math,zt(t)),s=[];if(n>=0&&a>=0)pt(n)[1],s=i?vt(n,a):vt(n);else if(n>0&&a<0){var r=Math.abs(a);n>=r?(pt(n)[1],s=e(n,r)):(pt(r)[1],s=e(r,n).map(function(t){return-1*t}))}else if(n<=0&&a<=0){var o=Math.abs(a),l=Math.abs(n);pt(o)[1],s=(s=i?vt(o,l):vt(o)).reverse().map(function(t){return-1*t})}return s}function yt(t){var e=mt(t);return t.indexOf(0)>=0?t.indexOf(0):t[0]>0?-1*t[0]/e:-1*t[t.length-1]/e+(t.length-1)}function mt(t){return t[1]-t[0]}function bt(t){return t[t.length-1]-t[0]}function xt(t,e){return u(e.zeroLine-t*e.scaleMultiplier)}function kt(t,e){var i=arguments.length>2&&void 0!==arguments[2]&&arguments[2],n=e.reduce(function(e,i){return Math.abs(i-t)i?e.slice(0,i):h(e,i-e.length,0)}else t.values=a;s?t.chartType=s:t.chartType||(t.chartType=jt)}),t.yRegions&&t.yRegions.map(function(t){if(t.end1&&void 0!==arguments[1]?arguments[1]:[],i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=t/e.length;n<=0&&(n=1);var a=n/Rt;return e.map(function(t,e){return(t+="").length>a&&(i?e%Math.ceil(t.length/a)!=0&&(t=""):t=a-3>0?t.slice(0,a-3)+" ...":t.slice(0,a)+".."),t})}function Tt(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"line",e=arguments[1],i=arguments[2];return"axis-mixed"===t?(i.type="line",new ke(e,i)):we[t]?new we[t](e,i):void console.error("Undefined chart type: "+t)}!function(t,e){void 0===e&&(e={});var i=e.insertAt;if(t&&"undefined"!=typeof document){var n=document.head||document.getElementsByTagName("head")[0],a=document.createElement("style");a.type="text/css","top"===i&&n.firstChild?n.insertBefore(a,n.firstChild):n.appendChild(a),a.styleSheet?a.styleSheet.cssText=t:a.appendChild(document.createTextNode(t))}}('.chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:1;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ol,.graph-svg-tip ul{padding-left:0;display:-webkit-box;display:-ms-flexbox;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;-webkit-box-flex:1;-ms-flex:1;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:" ";border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}',{});var Dt="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},Ot=(function(){function t(t){this.value=t}function e(e){function i(t,e){return new Promise(function(i,a){var o={key:t,arg:e,resolve:i,reject:a,next:null};r?r=r.next=o:(s=r=o,n(t,e))})}function n(i,s){try{var r=e[i](s),o=r.value;o instanceof t?Promise.resolve(o.value).then(function(t){n("next",t)},function(t){n("throw",t)}):a(r.done?"return":"normal",r.value)}catch(t){a("throw",t)}}function a(t,e){switch(t){case"return":s.resolve({value:e,done:!0});break;case"throw":s.reject(e);break;default:s.resolve({value:e,done:!1})}(s=s.next)?n(s.key,s.arg):r=null}var s,r;this._invoke=i,"function"!=typeof e.return&&(this.return=void 0)}"function"==typeof Symbol&&Symbol.asyncIterator&&(e.prototype[Symbol.asyncIterator]=function(){return this}),e.prototype.next=function(t){return this._invoke("next",t)},e.prototype.throw=function(t){return this._invoke("throw",t)},e.prototype.return=function(t){return this._invoke("return",t)}}(),function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}),Mt=function(){function t(t,e){for(var i=0;i\n\t\t\t\t\n\t\t\t\t'}),this.hideTip(),this.title=this.container.querySelector(".title"),this.dataPointList=this.container.querySelector(".data-point-list"),this.parent.addEventListener("mouseleave",function(){e.hideTip()})}},{key:"fill",value:function(){var e=this,i=void 0;this.index&&this.container.setAttribute("data-point-index",this.index),i=this.titleValueFirst?""+this.titleValue+""+this.titleName:this.titleName+""+this.titleValue+"",this.title.innerHTML=i,this.dataPointList.innerHTML="",this.listValues.map(function(i,n){var a=e.colors[n]||"black",s=0===i.formatted||i.formatted?i.formatted:i.value,r=t.create("li",{styles:{"border-top":"3px solid "+a},innerHTML:''+(0===s||s?s:"")+"\n\t\t\t\t\t"+(i.title?i.title:"")});e.dataPointList.appendChild(r)})}},{key:"calcPosition",value:function(){var t=this.container.offsetWidth;this.top=this.y-this.container.offsetHeight-5,this.left=this.x-t/2;var e=this.parent.offsetWidth-t,i=this.container.querySelector(".svg-pointer");if(this.left<0)i.style.left="calc(50% - "+-1*this.left+"px)",this.left=0;else if(this.left>e){var n="calc(50% + "+(this.left-e)+"px)";i.style.left=n,this.left=e}else i.style.left="50%"}},{key:"setValues",value:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=arguments.length>3&&void 0!==arguments[3]?arguments[3]:[],a=arguments.length>4&&void 0!==arguments[4]?arguments[4]:-1;this.titleName=i.name,this.titleValue=i.value,this.listValues=n,this.x=t,this.y=e,this.titleValueFirst=i.valueFirst||0,this.index=a,this.refresh()}},{key:"hideTip",value:function(){this.container.style.top="0px",this.container.style.left="0px",this.container.style.opacity="0"}},{key:"showTip",value:function(){this.container.style.top=this.top+"px",this.container.style.left=this.left+"px",this.container.style.opacity="1"}}]),e}(),Gt={"light-blue":"#7cd6fd",blue:"#5e64ff",violet:"#743ee2",red:"#ff5858",orange:"#ffa00a",yellow:"#feef72",green:"#28a745","light-green":"#98d85b",purple:"#b554ff",magenta:"#ffa3ef",black:"#36114C",grey:"#bdd3e6","light-grey":"#f0f4f7","dark-grey":"#b8c2cc"},qt=function(t){return Gt[t]||t},Xt=6,Jt=4,Kt=10,$t="#dadada",Qt="#555b51",Zt={bar:function(t){var e=void 0;"rect"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode();return i.style.fill="#000000",i.style.opacity="0.4",e&&i.setAttribute("transform",e),i},dot:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i},heat_square:function(t){var e=void 0;"circle"!==t.nodeName&&(e=t.getAttribute("transform"),t=t.childNodes[0]);var i=t.cloneNode(),n=t.getAttribute("r"),a=t.getAttribute("fill");return i.setAttribute("r",parseInt(n)+4),i.setAttribute("fill",a),i.style.opacity="0.6",e&&i.setAttribute("transform",e),i}},te={bar:function(t,e){var i=void 0;"rect"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["x","y","width","height"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},dot:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)},heat_square:function(t,e){var i=void 0;"circle"!==t.nodeName&&(i=t.getAttribute("transform"),t=t.childNodes[0]);var n=["cx","cy"];Object.values(t.attributes).filter(function(t){return n.includes(t.name)&&t.specified}).map(function(t){e.setAttribute(t.name,t.nodeValue)}),i&&e.setAttribute("transform",i)}},ee=350,ie=350,ne=ee,ae=250,se="easein",re={ease:"0.25 0.1 0.25 1",linear:"0 0 1 1",easein:"0.1 0.8 0.2 1",easeout:"0 0 0.58 1",easeinout:"0.42 0 0.58 1"},oe=".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}",le=void 0,ue=function(){function e(t,i){if(Ot(this,e),this.parent="string"==typeof t?document.querySelector(t):t,!(this.parent instanceof HTMLElement))throw new Error("No `parent` element to render on was provided.");this.rawChartArgs=i,this.title=i.title||"",this.type=i.type||"line",this.realData=this.prepareData(i.data),this.data=this.prepareFirstData(this.realData),this.colors=this.validateColors(i.colors,this.type),this.config={showTooltip:1,showLegend:1,isNavigable:i.isNavigable||0,animate:1},this.measures=JSON.parse(JSON.stringify(Ht));var n=this.measures;this.setMeasures(i),this.title.length||(n.titleHeight=0),this.config.showLegend||(n.legendHeight=0),this.argHeight=i.height||n.baseHeight,this.state={},this.options={},this.initTimeout=Ft,this.config.isNavigable&&(this.overlays=[]),this.configure(i)}return Mt(e,[{key:"prepareData",value:function(t){return t}},{key:"prepareFirstData",value:function(t){return t}},{key:"validateColors",value:function(t,e){var i=[];return(t=(t||[]).concat(Vt[e])).forEach(function(t){var e=qt(t);y(e)?i.push(e):console.warn('"'+t+'" is not a valid color.')}),i}},{key:"setMeasures",value:function(){}},{key:"configure",value:function(){var t=this.argHeight;this.baseHeight=t,this.height=t-o(this.measures),le=this.boundDrawFn.bind(this),window.addEventListener("resize",le),window.addEventListener("orientationchange",this.boundDrawFn.bind(this))}},{key:"boundDrawFn",value:function(){this.draw(!0)}},{key:"unbindWindowEvents",value:function(){window.removeEventListener("resize",le),window.removeEventListener("orientationchange",this.boundDrawFn.bind(this))}},{key:"setup",value:function(){this.makeContainer(),this.updateWidth(),this.makeTooltip(),this.draw(!1,!0)}},{key:"makeContainer",value:function(){this.parent.innerHTML="";var e={inside:this.parent,className:"chart-container"};this.independentWidth&&(e.styles={width:this.independentWidth+"px"},this.parent.style.overflow="auto"),this.container=t.create("div",e)}},{key:"makeTooltip",value:function(){this.tip=new Ut({parent:this.container,colors:this.colors}),this.bindTooltip()}},{key:"bindTooltip",value:function(){}},{key:"draw",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0],i=arguments.length>1&&void 0!==arguments[1]&&arguments[1];this.updateWidth(),this.calc(e),this.makeChartArea(),this.setupComponents(),this.components.forEach(function(e){return e.setup(t.drawArea)}),this.render(this.components,!1),i&&(this.data=this.realData,setTimeout(function(){t.update(t.data)},this.initTimeout)),this.renderLegend(),this.setupNavigation(i)}},{key:"calc",value:function(){}},{key:"updateWidth",value:function(){this.baseWidth=n(this.parent),this.width=this.baseWidth-l(this.measures)}},{key:"makeChartArea",value:function(){this.svg&&this.container.removeChild(this.svg);var t=this.measures;this.svg=w(this.container,"frappe-chart chart",this.baseWidth,this.baseHeight),this.svgDefs=A(this.svg),this.title.length&&(this.titleEL=E("title",t.margins.left,t.margins.top,this.title,{fontSize:t.titleFontSize,fill:"#666666",dy:t.titleFontSize}));var e=s(t);this.drawArea=P(this.type+"-chart chart-draw-area","translate("+r(t)+", "+e+")"),this.config.showLegend&&(e+=this.height+t.paddings.bottom,this.legendArea=P("chart-legend","translate("+r(t)+", "+e+")")),this.title.length&&this.svg.appendChild(this.titleEL),this.svg.appendChild(this.drawArea),this.config.showLegend&&this.svg.appendChild(this.legendArea),this.updateTipOffset(r(t),s(t))}},{key:"updateTipOffset",value:function(t,e){this.tip.offset={x:t,y:e}}},{key:"setupComponents",value:function(){this.components=new Map}},{key:"update",value:function(t){t||console.error("No data to update."),this.data=this.prepareData(t),this.calc(),this.render()}},{key:"render",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.components,i=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];this.config.isNavigable&&this.overlays.map(function(t){return t.parentNode.removeChild(t)});var n=[];e.forEach(function(t){n=n.concat(t.update(i))}),n.length>0?(Z(this.container,this.svg,n),setTimeout(function(){e.forEach(function(t){return t.make()}),t.updateNav()},400)):(e.forEach(function(t){return t.make()}),this.updateNav())}},{key:"updateNav",value:function(){this.config.isNavigable&&(this.makeOverlay(),this.bindUnits())}},{key:"renderLegend",value:function(){}},{key:"setupNavigation",value:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.config.isNavigable&&e&&(this.bindOverlay(),this.keyActions={13:this.onEnterKey.bind(this),37:this.onLeftArrow.bind(this),38:this.onUpArrow.bind(this),39:this.onRightArrow.bind(this),40:this.onDownArrow.bind(this)},document.addEventListener("keydown",function(e){i(t.container)&&(e=e||window.event,t.keyActions[e.keyCode]&&t.keyActions[e.keyCode]())}))}},{key:"makeOverlay",value:function(){}},{key:"updateOverlay",value:function(){}},{key:"bindOverlay",value:function(){}},{key:"bindUnits",value:function(){}},{key:"onLeftArrow",value:function(){}},{key:"onRightArrow",value:function(){}},{key:"onUpArrow",value:function(){}},{key:"onDownArrow",value:function(){}},{key:"onEnterKey",value:function(){}},{key:"addDataPoint",value:function(){}},{key:"removeDataPoint",value:function(){}},{key:"getDataPoint",value:function(){}},{key:"setCurrentDataPoint",value:function(){}},{key:"updateDataset",value:function(){}},{key:"export",value:function(){var t=et(this.svg);tt(this.title||"Chart",[t])}}]),e}(),he=function(t){function e(t,i){return Ot(this,e),St(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i))}return Et(e,t),Mt(e,[{key:"configure",value:function(t){Nt(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"configure",this).call(this,t),this.config.maxSlices=t.maxSlices||20,this.config.maxLegendPoints=t.maxLegendPoints||20}},{key:"calc",value:function(){var t=this,e=this.state,i=this.config.maxSlices;e.sliceTotals=[];var n=this.data.labels.map(function(e,i){var n=0;return t.data.datasets.map(function(t){n+=t.values[i]}),[n,e]}).filter(function(t){return t[0]>=0}),a=n;if(n.length>i){n.sort(function(t,e){return e[0]-t[0]}),a=n.slice(0,i-1);var s=0;n.slice(i-1).map(function(t){s+=t[0]}),a.push([s,"Rest"]),this.colors[i-1]="grey"}e.labels=[],a.map(function(t){e.sliceTotals.push(t[0]),e.labels.push(t[1])}),e.grandTotal=e.sliceTotals.reduce(function(t,e){return t+e},0),this.center={x:this.width/2,y:this.height/2}}},{key:"renderLegend",value:function(){var t=this,e=this.state;this.legendArea.textContent="",this.legendTotals=e.sliceTotals.slice(0,this.config.maxLegendPoints);var i=0,n=0;this.legendTotals.map(function(a,s){var r=Math.floor((t.width-l(t.measures))/110);i>r&&(i=0,n+=20);var o=N(110*i+5,n,5,t.colors[s],e.labels[s]+": "+a);t.legendArea.appendChild(o),i++})}}]),e}(ue),ce=7,de=1e3,pe=86400,fe=["January","February","March","April","May","June","July","August","September","October","November","December"],ve=["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],ge=function(){function t(e){var i=e.layerClass,n=void 0===i?"":i,a=e.layerTransform,s=void 0===a?"":a,r=e.constants,o=e.getData,l=e.makeElements,u=e.animateElements;Ot(this,t),this.layerTransform=s,this.constants=r,this.makeElements=l,this.getData=o,this.animateElements=u,this.store=[],this.labels=[],this.layerClass=n,this.layerClass="function"==typeof this.layerClass?this.layerClass():this.layerClass,this.refresh()}return Mt(t,[{key:"refresh",value:function(t){this.data=t||this.getData()}},{key:"setup",value:function(t){this.layer=P(this.layerClass,this.layerTransform,t)}},{key:"make",value:function(){this.render(this.data),this.oldData=this.data}},{key:"render",value:function(t){var e=this;this.store=this.makeElements(t),this.layer.textContent="",this.store.forEach(function(t){e.layer.appendChild(t)}),this.labels.forEach(function(t){e.layer.appendChild(t)})}},{key:"update",value:function(){var t=!(arguments.length>0&&void 0!==arguments[0])||arguments[0];this.refresh();var e=[];return t&&(e=this.animateElements(this.data)||[]),e}}]),t}(),ye={pieSlices:{layerClass:"pie-slices",makeElements:function(t){return t.sliceStrings.map(function(e,i){var n=C(e,"pie-path","none",t.colors[i]);return n.style.transition="transform .3s;",n})},animateElements:function(t){return this.store.map(function(e,i){return J(e,t.sliceStrings[i])})}},percentageBars:{layerClass:"percentage-bars",makeElements:function(t){var e=this;return t.xPositions.map(function(i,n){return D(i,0,t.widths[n],e.constants.barHeight,e.constants.barDepth,t.colors[n])})},animateElements:function(t){if(t)return[]}},yAxis:{layerClass:"y axis",makeElements:function(t){var e=this;return t.positions.map(function(i,n){return z(i,t.labels[n],e.constants.width,{mode:e.constants.mode,pos:e.constants.pos})})},animateElements:function(t){var e=t.positions,i=t.labels,n=this.oldData.positions,a=this.oldData.labels,s=f(n,e),r=_t(s,2);n=r[0],e=r[1];var o=f(a,i),l=_t(o,2);return a=l[0],i=l[1],this.render({positions:n,labels:i}),this.store.map(function(t,i){return B(t,e[i],n[i])})}},xAxis:{layerClass:"x axis",makeElements:function(t){var e=this;return t.positions.map(function(i,n){return H(i,t.calcLabels[n],e.constants.height,{mode:e.constants.mode,pos:e.constants.pos})})},animateElements:function(t){var e=t.positions,i=t.calcLabels,n=this.oldData.positions,a=this.oldData.calcLabels,s=f(n,e),r=_t(s,2);n=r[0],e=r[1];var o=f(a,i),l=_t(o,2);return a=l[0],i=l[1],this.render({positions:n,calcLabels:i}),this.store.map(function(t,i){return V(t,e[i],n[i])})}},yMarkers:{layerClass:"y-markers",makeElements:function(t){var e=this;return t.map(function(t){return F(t.position,t.label,e.constants.width,{labelPos:t.options.labelPos,mode:"span",lineType:"dashed"})})},animateElements:function(t){var e=f(this.oldData,t),i=_t(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.position}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.options}),r=this.oldData.map(function(t){return t.position});return this.render(r.map(function(t,e){return{position:r[e],label:a[e],options:s[e]}})),this.store.map(function(t,e){return B(t,n[e],r[e])})}},yRegions:{layerClass:"y-regions",makeElements:function(t){var e=this;return t.map(function(t){return j(t.startPos,t.endPos,e.constants.width,t.label,{labelPos:t.options.labelPos})})},animateElements:function(t){var e=f(this.oldData,t),i=_t(e,2);this.oldData=i[0];var n=(t=i[1]).map(function(t){return t.endPos}),a=t.map(function(t){return t.label}),s=t.map(function(t){return t.startPos}),r=t.map(function(t){return t.options}),o=this.oldData.map(function(t){return t.endPos}),l=this.oldData.map(function(t){return t.startPos});this.render(o.map(function(t,e){return{startPos:l[e],endPos:o[e],label:a[e],options:r[e]}}));var u=[];return this.store.map(function(t,e){u=u.concat(U(t,s[e],n[e],o[e]))}),u}},heatDomain:{layerClass:function(){return"heat-domain domain-"+this.constants.index},makeElements:function(t){var e=this,i=this.constants,n=i.index,a=i.colWidth,s=i.rowHeight,r=i.squareSize,o=i.xTranslate,l=0;return this.serializedSubDomains=[],t.cols.map(function(t,i){1===i&&e.labels.push(E("domain-name",o,-12,lt(n,!0).toUpperCase(),{fontSize:9})),t.map(function(t,i){if(t.fill){var n={"data-date":t.yyyyMmDd,"data-value":t.dataValue,"data-day":i},a=O("day",o,l,r,t.fill,n);e.serializedSubDomains.push(a)}l+=s}),l=0,o+=a}),this.serializedSubDomains},animateElements:function(t){if(t)return[]}},barGraph:{layerClass:function(){return"dataset-units dataset-bars dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="bar",this.units=t.yPositions.map(function(i,n){return W(t.xPositions[n],i,t.barWidth,e.color,t.labels[n],n,t.offsets[n],{zeroLine:t.zeroLine,barsWidth:t.barsWidth,minHeight:e.minHeight})}),this.units},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.offsets,a=t.labels,s=this.oldData.xPositions,r=this.oldData.yPositions,o=this.oldData.offsets,l=this.oldData.labels,u=f(s,e),h=_t(u,2);s=h[0],e=h[1];var c=f(r,i),d=_t(c,2);r=d[0],i=d[1];var p=f(o,n),v=_t(p,2);o=v[0],n=v[1];var g=f(l,a),y=_t(g,2);l=y[0],a=y[1],this.render({xPositions:s,yPositions:r,offsets:o,labels:a,zeroLine:this.oldData.zeroLine,barsWidth:this.oldData.barsWidth,barWidth:this.oldData.barWidth});var m=[];return this.store.map(function(a,s){m=m.concat(G(a,e[s],i[s],t.barWidth,n[s],{zeroLine:t.zeroLine}))}),m}},lineGraph:{layerClass:function(){return"dataset-units dataset-line dataset-"+this.constants.index},makeElements:function(t){var e=this.constants;return this.unitType="dot",this.paths={},e.hideLine||(this.paths=R(t.xPositions,t.yPositions,e.color,{heatline:e.heatline,areaFill:e.areaFill},{svgDefs:e.svgDefs,zeroLine:t.zeroLine})),this.units=[],e.hideDots||(this.units=t.yPositions.map(function(i,n){return I(t.xPositions[n],i,t.radius,e.color,e.valuesOverPoints?t.values[n]:"",n)})),Object.values(this.paths).concat(this.units)},animateElements:function(t){var e=t.xPositions,i=t.yPositions,n=t.values,a=this.oldData.xPositions,s=this.oldData.yPositions,r=this.oldData.values,o=f(a,e),l=_t(o,2);a=l[0],e=l[1];var u=f(s,i),h=_t(u,2);s=h[0],i=h[1];var c=f(r,n),d=_t(c,2);r=d[0],n=d[1],this.render({xPositions:a,yPositions:s,values:n,zeroLine:this.oldData.zeroLine,radius:this.oldData.radius});var p=[];return Object.keys(this.paths).length&&(p=p.concat(X(this.paths,e,i,t.zeroLine))),this.units.length&&this.units.map(function(t,n){p=p.concat(q(t,e[n],i[n]))}),p}}},me=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="percentage",n.setup(),n}return Et(i,t),Mt(i,[{key:"setMeasures",value:function(t){var e=this.measures;this.barOptions=t.barOptions||{};var i=this.barOptions;i.height=i.height||20,i.depth=i.depth||It,e.paddings.right=30,e.legendHeight=80,e.baseHeight=8*(i.height+.5*i.depth)}},{key:"setupComponents",value:function(){var t=this.state,e=[["percentageBars",{barHeight:this.barOptions.height,barDepth:this.barOptions.depth},function(){return{xPositions:t.xPositions,widths:t.widths,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=dt.apply(void 0,zt(t));return[t[0],e]}))}},{key:"calc",value:function(){var t=this;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;e.xPositions=[],e.widths=[];var n=0;e.sliceTotals.map(function(i){var a=t.width*i/e.grandTotal;e.widths.push(a),e.xPositions.push(n),n+=a})}},{key:"makeDataByIndex",value:function(){}},{key:"bindTooltip",value:function(){var t=this,i=this.state;this.container.addEventListener("mousemove",function(n){var a=t.components.get("percentageBars").store,s=n.target;if(a.includes(s)){var r=a.indexOf(s),o=e(t.container),l=e(s),u=l.left-o.left+parseInt(s.getAttribute("width"))/2,h=l.top-o.top,c=(t.formattedLabels&&t.formattedLabels.length>0?t.formattedLabels[r]:t.state.labels[r])+": ",d=i.sliceTotals[r]/i.grandTotal;t.tip.setValues(u,h,{name:c,value:(100*d).toFixed(1)+"%"}),t.tip.showTip()}})}}]),i}(he),be=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.type="pie",n.initTimeout=0,n.init=1,n.setup(),n}return Et(i,t),Mt(i,[{key:"configure",value:function(t){Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),this.mouseMove=this.mouseMove.bind(this),this.mouseLeave=this.mouseLeave.bind(this),this.hoverRadio=t.hoverRadio||.1,this.config.startAngle=t.startAngle||0,this.clockWise=t.clockWise||!1}},{key:"calc",value:function(){var t=this;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"calc",this).call(this);var e=this.state;this.radius=this.height>this.width?this.center.x:this.center.y;var n=this.radius,a=this.clockWise,s=e.slicesProperties||[];e.sliceStrings=[],e.slicesProperties=[];var r=180-this.config.startAngle;e.sliceTotals.map(function(i,o){var l=r,u=i/e.grandTotal*360,h=a?-u:u,c=r+=h,p=d(l,n),f=d(c,n),v=t.init&&s[o],g=void 0,y=void 0;t.init?(g=v?v.startPosition:p,y=v?v.endPosition:p):(g=p,y=f);var m=L(g,y,t.center,t.radius,t.clockWise);e.sliceStrings.push(m),e.slicesProperties.push({startPosition:p,endPosition:f,value:i,total:e.grandTotal,startAngle:l,endAngle:c,angle:h})}),this.init=0}},{key:"setupComponents",value:function(){var t=this.state,e=[["pieSlices",{},function(){return{sliceStrings:t.sliceStrings,colors:this.colors}}.bind(this)]];this.components=new Map(e.map(function(t){var e=dt.apply(void 0,zt(t));return[t[0],e]}))}},{key:"calTranslateByAngle",value:function(t){var e=this.radius,i=this.hoverRadio,n=d(t.startAngle+t.angle/2,e);return"translate3d("+n.x*i+"px,"+n.y*i+"px,0)"}},{key:"hoverSlice",value:function(t,i,n,a){if(t){var s=this.colors[i];if(n){$(t,this.calTranslateByAngle(this.state.slicesProperties[i])),t.style.fill=g(s,50);var r=e(this.svg),o=a.pageX-r.left+10,l=a.pageY-r.top-10,u=(this.formatted_labels&&this.formatted_labels.length>0?this.formatted_labels[i]:this.state.labels[i])+": ",h=(100*this.state.sliceTotals[i]/this.state.grandTotal).toFixed(1);this.tip.setValues(o,l,{name:u,value:h+"%"}),this.tip.showTip()}else $(t,"translate3d(0,0,0)"),this.tip.hideTip(),t.style.fill=s}}},{key:"bindTooltip",value:function(){this.container.addEventListener("mousemove",this.mouseMove),this.container.addEventListener("mouseleave",this.mouseLeave)}},{key:"mouseMove",value:function(t){var e=t.target,i=this.components.get("pieSlices").store,n=this.curActiveSliceIndex,a=this.curActiveSlice;if(i.includes(e)){var s=i.indexOf(e);this.hoverSlice(a,n,!1),this.curActiveSlice=e,this.curActiveSliceIndex=s,this.hoverSlice(e,s,!0,t)}else this.mouseLeave()}},{key:"mouseLeave",value:function(){this.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,!1)}}]),i}(he),xe=function(t){function e(t,i){Ot(this,e);var n=St(this,(e.__proto__||Object.getPrototypeOf(e)).call(this,t,i));n.type="heatmap",n.countLabel=i.countLabel||"";var a=["Sunday","Monday"],s=a.includes(i.startSubDomain)?i.startSubDomain:"Sunday";return n.startSubDomainIndex=a.indexOf(s),n.setup(),n}return Et(e,t),Mt(e,[{key:"setMeasures",value:function(t){var e=this.measures;this.discreteDomains=0===t.discreteDomains?0:1,e.paddings.top=36,e.paddings.bottom=0,e.legendHeight=24,e.baseHeight=12*ce+o(e);var i=this.data,n=this.discreteDomains?12:0;this.independentWidth=12*(st(i.start,i.end)+n)+l(e)}},{key:"updateWidth",value:function(){var t=this.discreteDomains?12:0,e=this.state.noOfWeeks?this.state.noOfWeeks:52;this.baseWidth=12*(e+t)+l(this.measures)}},{key:"prepareData",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data;if(t.start&&t.end&&t.start>t.end)throw new Error("Start date cannot be greater than end date.");if(t.start||(t.start=new Date,t.start.setFullYear(t.start.getFullYear()-1)),t.end||(t.end=new Date),t.dataPoints=t.dataPoints||{},parseInt(Object.keys(t.dataPoints)[0])>1e5){var e={};Object.keys(t.dataPoints).forEach(function(i){var n=new Date(i*de);e[nt(n)]=t.dataPoints[i]}),t.dataPoints=e}return t}},{key:"calc",value:function(){var t=this.state;t.start=at(this.data.start),t.end=at(this.data.end),t.firstWeekStart=at(t.start),t.noOfWeeks=st(t.start,t.end),t.distribution=wt(Object.values(this.data.dataPoints),5),t.domainConfigs=this.getDomains()}},{key:"setupComponents",value:function(){var t=this,e=this.state,i=this.discreteDomains?0:1,n=e.domainConfigs.map(function(n,a){return["heatDomain",{index:n.index,colWidth:12,rowHeight:12,squareSize:10,xTranslate:12*e.domainConfigs.filter(function(t,e){return e1&&void 0!==arguments[1]?arguments[1]:"",i=[t.getMonth(),t.getFullYear()],n=i[0],a=i[1],s=ht(t),r={index:n,cols:[]};ct(e=at(e)||ut(n,a),1);for(var o=st(s,e),l=[],u=void 0,h=0;h2&&void 0!==arguments[2]&&arguments[2],n=this.state,a=at(t),s=[],r=0;r=n.start&&a<=n.end;i||a.getMonth()!==e||!l?o.yyyyMmDd=nt(a):o=this.getSubDomainConfig(a),s.push(o)}return s}},{key:"getSubDomainConfig",value:function(t){var e=nt(t),i=this.data.dataPoints[e];return{yyyyMmDd:e,dataValue:i||0,fill:this.colors[At(i,this.state.distribution)]}}}]),e}(ue),ke=function(t){function i(t,e){Ot(this,i);var n=St(this,(i.__proto__||Object.getPrototypeOf(i)).call(this,t,e));return n.barOptions=e.barOptions||{},n.lineOptions=e.lineOptions||{},n.init=1,n.setup(),n}return Et(i,t),Mt(i,[{key:"setMeasures",value:function(){this.data.datasets.length<=1&&(this.config.showLegend=0,this.measures.paddings.bottom=30)}},{key:"configure",value:function(t){Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"configure",this).call(this,t),t.axisOptions=t.axisOptions||{},t.tooltipOptions=t.tooltipOptions||{},this.config.xAxisMode=t.axisOptions.xAxisMode||"span",this.config.yAxisMode=t.axisOptions.yAxisMode||"span",this.config.xIsSeries=t.axisOptions.xIsSeries||0,this.config.formatTooltipX=t.tooltipOptions.formatTooltipX,this.config.formatTooltipY=t.tooltipOptions.formatTooltipY,this.config.valuesOverPoints=t.valuesOverPoints}},{key:"prepareData",value:function(){return Pt(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data,this.type)}},{key:"prepareFirstData",value:function(){return Ct(arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.data)}},{key:"calc",value:function(){var t=arguments.length>0&&void 0!==arguments[0]&&arguments[0];this.calcXPositions(),t||this.calcYAxisParameters(this.getAllYValues(),"line"===this.type),this.makeDataByIndex()}},{key:"calcXPositions",value:function(){var t=this.state,e=this.data.labels;t.datasetLength=e.length,t.unitWidth=this.width/t.datasetLength,t.xOffset=t.unitWidth/2,t.xAxis={labels:e,positions:e.map(function(e,i){return u(t.xOffset+i*t.unitWidth)})}}},{key:"calcYAxisParameters",value:function(t){var e=gt(t,arguments.length>1&&void 0!==arguments[1]?arguments[1]:"false"),i=this.height/bt(e),n=mt(e)*i,a=this.height-yt(e)*n;this.state.yAxis={labels:e,positions:e.map(function(t){return a-t*i}),scaleMultiplier:i,zeroLine:a},this.calcDatasetPoints(),this.calcYExtremes(),this.calcYRegions()}},{key:"calcDatasetPoints",value:function(){var t=this.state,e=function(e){return e.map(function(e){return xt(e,t.yAxis)})};t.datasets=this.data.datasets.map(function(t,i){var n=t.values,a=t.cumulativeYs||[];return{name:t.name,index:i,chartType:t.chartType,values:n,yPositions:e(n),cumulativeYs:a,cumulativeYPos:e(a)}})}},{key:"calcYExtremes",value:function(){var t=this.state;if(this.barOptions.stacked)return void(t.yExtremes=t.datasets[t.datasets.length-1].cumulativeYPos);t.yExtremes=new Array(t.datasetLength).fill(9999),t.datasets.map(function(e){e.yPositions.map(function(e,i){es(n)?t.mapTooltipXPosition(o):t.tip.hideTip()})}},{key:"mapTooltipXPosition",value:function(t){var e=this.state;if(e.yExtremes){var i=kt(t,e.xAxis.positions,!0),n=this.dataByIndex[i];this.tip.setValues(n.xPos+this.tip.offset.x,n.yExtreme+this.tip.offset.y,{name:n.formattedLabel,value:""},n.values,i),this.tip.showTip()}}},{key:"renderLegend",value:function(){var t=this,e=this.data;e.datasets.length>1&&(this.legendArea.textContent="",e.datasets.map(function(e,i){var n=M(100*i,"0",100,t.colors[i],e.name);t.legendArea.appendChild(n)}))}},{key:"makeOverlay",value:function(){var t=this;if(this.init)return void(this.init=0);this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)}),this.overlayGuides=this.dataUnitComponents.map(function(t){return{type:t.unitType,overlay:void 0,units:t.units}}),void 0===this.state.currentIndex&&(this.state.currentIndex=this.state.datasetLength-1),this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];e.overlay=Zt[e.type](i),t.drawArea.appendChild(e.overlay)})}},{key:"updateOverlayGuides",value:function(){this.overlayGuides&&this.overlayGuides.forEach(function(t){var e=t.overlay;e.parentNode.removeChild(e)})}},{key:"bindOverlay",value:function(){var t=this;this.parent.addEventListener("data-select",function(){t.updateOverlay()})}},{key:"bindUnits",value:function(){var t=this;this.dataUnitComponents.map(function(e){e.units.map(function(e){e.addEventListener("click",function(){var i=e.getAttribute("data-point-index");t.setCurrentDataPoint(i)})})}),this.tip.container.addEventListener("click",function(){var e=t.tip.container.getAttribute("data-point-index");t.setCurrentDataPoint(e)})}},{key:"updateOverlay",value:function(){var t=this;this.overlayGuides.map(function(e){var i=e.units[t.state.currentIndex];te[e.type](i,e.overlay)})}},{key:"onLeftArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex-1)}},{key:"onRightArrow",value:function(){this.setCurrentDataPoint(this.state.currentIndex+1)}},{key:"getDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.currentIndex,e=this.state;return{index:t,label:e.xAxis.labels[t],values:e.datasets.map(function(e){return e.values[t]})}}},{key:"setCurrentDataPoint",value:function(t){var e=this.state;(t=parseInt(t))<0&&(t=0),t>=e.xAxis.labels.length&&(t=e.xAxis.labels.length-1),t!==e.currentIndex&&(e.currentIndex=t,a(this.parent,"data-select",this.getDataPoint()))}},{key:"addDataPoint",value:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:this.state.datasetLength;Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"addDataPoint",this).call(this,t,e,n),this.data.labels.splice(n,0,t),this.data.datasets.map(function(t,i){t.values.splice(n,0,e[i])}),this.update(this.data)}},{key:"removeDataPoint",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:this.state.datasetLength-1;this.data.labels.length<=1||(Nt(i.prototype.__proto__||Object.getPrototypeOf(i.prototype),"removeDataPoint",this).call(this,t),this.data.labels.splice(t,1),this.data.datasets.map(function(e){e.values.splice(t,1)}),this.update(this.data))}},{key:"updateDataset",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0;this.data.datasets[e].values=t,this.update(this.data)}},{key:"updateDatasets",value:function(t){this.data.datasets.map(function(e,i){t[i]&&(e.values=t[i])}),this.update(this.data)}}]),i}(ue),we={bar:ke,line:ke,percentage:me,heatmap:xe,pie:be},Ae=function t(e,i){return Ot(this,t),Tt(i.type,e,i)},Pe=Object.freeze({Chart:Ae,PercentageChart:me,PieChart:be,Heatmap:xe,AxisChart:ke}),Ce={};return Ce.NAME="Frappe Charts",Ce.VERSION="1.1.0",Ce=Object.assign({},Ce,Pe)}();
//# sourceMappingURL=frappe-charts.min.iife.js.map
diff --git a/docs/getting_started/quick_start.md b/docs/getting_started/quick_start.md
index 92393a0..aea9ac8 100644
--- a/docs/getting_started/quick_start.md
+++ b/docs/getting_started/quick_start.md
@@ -48,3 +48,10 @@ const chart = new frappe.Chart("#chart", { // or a DOM element,
## Demo
Here's a demo to try out yourself:
+
+ See the Pen Frappe Charts Demo
+ by Prateeksha Singh (@pratu16x7) on
+ CodePen.
+
+
diff --git a/docs/index.html b/docs/index.html
index 3fe93e8..c555c19 100644
--- a/docs/index.html
+++ b/docs/index.html
@@ -125,8 +125,6 @@
};
-
-
diff --git a/docs/index.js b/docs/index.js
index b73af12..79fdcc6 100644
--- a/docs/index.js
+++ b/docs/index.js
@@ -1,6 +1,5 @@
import { docsBuilder } from './assets/js/docsBuilder';
import { Chart } from "../dist/frappe-charts.min.esm";
-import { demoRegistry } from './demoRegistry';
import { $, insertAfter } from '../src/js/utils/dom';
import { fireballOver25, fireball_2_5, fireball_5_25 } from './assets/js/data';
diff --git a/docs/index.min.js b/docs/index.min.js
index db37970..217d02b 100644
--- a/docs/index.min.js
+++ b/docs/index.min.js
@@ -1700,7 +1700,7 @@ function getPaths(xList, yList, color) {
};
// Region
- if (options.regionFill) {
+ if (options.areaFill) {
var gradient_id_region = makeGradient(meta.svgDefs, color, true);
var pathStr = "M" + (xList[0] + ',' + meta.zeroLine + 'L') + pointsStr + ('L' + xList.slice(-1)[0] + ',' + meta.zeroLine);
@@ -3205,7 +3205,7 @@ var componentConfigs = {
if (!c.hideLine) {
this.paths = getPaths(data.xPositions, data.yPositions, c.color, {
heatline: c.heatline,
- regionFill: c.regionFill
+ areaFill: c.areaFill
}, {
svgDefs: c.svgDefs,
zeroLine: data.zeroLine
@@ -4782,7 +4782,7 @@ var AxisChart = function (_BaseChart) {
color: _this3.colors[index],
svgDefs: _this3.svgDefs,
heatline: _this3.lineOptions.heatline,
- regionFill: _this3.lineOptions.regionFill,
+ areaFill: _this3.lineOptions.areaFill,
hideDots: _this3.lineOptions.hideDots,
hideLine: _this3.lineOptions.hideLine,
@@ -5493,7 +5493,7 @@ var demoSections = [{
height: 300,
colors: ['#ff6c03'],
lineOptions: {
- regionFill: 1
+ areaFill: 1
}
},
actions: [{
@@ -5535,7 +5535,7 @@ var demoSections = [{
name: "lineOptions",
path: ["lineOptions"],
type: "map",
- mapKeys: ['hideLine', 'hideDots', 'heatline', 'regionFill'],
+ mapKeys: ['hideLine', 'hideDots', 'heatline', 'areaFill'],
states: {
"Line": [0, 1, 0, 0],
"Dots": [1, 0, 0, 0],
@@ -5625,7 +5625,7 @@ var demoSections = [{
contentBlocks: [{
type: "code",
lang: "javascript",
- content: '\n ...\n {\n data: {\n labels: [],\n datasets: [],\n yRegions: [],\n yMarkers: []\n }\n title: \'\',\n colors: [],\n height: 200,\n\n tooltipOptions: {\n formatTooltipX: d => (d + \'\').toUpperCase(),\n formatTooltipY: d => d + \' pts\',\n }\n\n // Axis charts\n isNavigable: 1, // default: 0\n valuesOverPoints: 1, // default: 0\n barOptions: {\n spaceRatio: 1 // default: 0.5\n stacked: 1 // default: 0\n }\n\n lineOptions: {\n dotSize: 6, // default: 4\n hideLine: 0, // default: 0\n hideDots: 1, // default: 0\n heatline: 1, // default: 0\n regionFill: 1 // default: 0\n }\n\n axisOptions: {\n yAxisMode: \'span\', // Axis lines, default\n xAxisMode: \'tick\', // No axis lines, only short ticks\n xIsSeries: 1 // Allow skipping x values for space\n // default: 0\n },\n\n // Pie/Percentage charts\n maxLegendPoints: 6, // default: 20\n maxSlices: 10, // default: 20\n\n // Percentage chart\n barOptions: {\n height: 15 // default: 20\n depth: 5 // default: 2\n }\n\n // Heatmap\n discreteDomains: 1, // default: 1\n }\n ...\n\n // Updating values\n chart.update(data);\n\n // Axis charts:\n chart.addDataPoint(label, valueFromEachDataset, index)\n chart.removeDataPoint(index)\n chart.updateDataset(datasetValues, index)\n\n // Exporting\n chart.export();\n\n // Unbind window-resize events\n chart.unbindWindowEvents();\n\n '
+ content: '\n ...\n {\n data: {\n labels: [],\n datasets: [],\n yRegions: [],\n yMarkers: []\n }\n title: \'\',\n colors: [],\n height: 200,\n\n tooltipOptions: {\n formatTooltipX: d => (d + \'\').toUpperCase(),\n formatTooltipY: d => d + \' pts\',\n }\n\n // Axis charts\n isNavigable: 1, // default: 0\n valuesOverPoints: 1, // default: 0\n barOptions: {\n spaceRatio: 1 // default: 0.5\n stacked: 1 // default: 0\n }\n\n lineOptions: {\n dotSize: 6, // default: 4\n hideLine: 0, // default: 0\n hideDots: 1, // default: 0\n heatline: 1, // default: 0\n areaFill: 1 // default: 0\n }\n\n axisOptions: {\n yAxisMode: \'span\', // Axis lines, default\n xAxisMode: \'tick\', // No axis lines, only short ticks\n xIsSeries: 1 // Allow skipping x values for space\n // default: 0\n },\n\n // Pie/Percentage charts\n maxLegendPoints: 6, // default: 20\n maxSlices: 10, // default: 20\n\n // Percentage chart\n barOptions: {\n height: 15 // default: 20\n depth: 5 // default: 2\n }\n\n // Heatmap\n discreteDomains: 1, // default: 1\n }\n ...\n\n // Updating values\n chart.update(data);\n\n // Axis charts:\n chart.addDataPoint(label, valueFromEachDataset, index)\n chart.removeDataPoint(index)\n chart.updateDataset(datasetValues, index)\n\n // Exporting\n chart.export();\n\n // Unbind window-resize events\n chart.unbindWindowEvents();\n\n '
}]
}, {
title: "Install",
@@ -5662,44 +5662,4 @@ if (document.querySelectorAll('#line-composite-1').length && !document.querySele
});
}
-window.$docsify = {
- name: 'frappe-charts',
- // repo: 'https://github.com/frappe/charts',
- loadSidebar: true,
- subMaxLevel: 2,
- executeScript: true
- // plugins: [
- // function(hook, vm) {
- // hook.doneEach(function() {
- // let demos = document.querySelectorAll('.demo')
-
- // for (var i = 0; i < demos.length; ++i) {
- // let el = demos[i];
- // let id = el.getAttribute("id");
- // dbd.makeSection(el, demoRegistry[id]);
- // }
-
- // });
-
- // // hook.ready(function() {
- // // let scripts = document.querySelectorAll('script');
- // // for (var i = 0; i < scripts.length; ++i) {
- // // let el = scripts[i];
- // // let id = el.getAttribute("id");
-
- // // let demoDiv = $.create('div', {className: `${id}`});
- // // insertAfter(demoDiv, el);
- // // console.log(demoStore);
- // // dbd.makeSection(demoDiv, demoStore[id]);
- // // }
- // // });
- // }
- // ]
-};
-
-document.querySelector("#docs-link").addEventListener('click', function () {
- document.querySelector("#home-page").classList.add("hide");
- document.querySelector("main").classList.remove("hide");
-});
-
}());
diff --git a/src/js/charts/AxisChart.js b/src/js/charts/AxisChart.js
index 6249173..621fcbe 100644
--- a/src/js/charts/AxisChart.js
+++ b/src/js/charts/AxisChart.js
@@ -294,7 +294,7 @@ export default class AxisChart extends BaseChart {
color: this.colors[index],
svgDefs: this.svgDefs,
heatline: this.lineOptions.heatline,
- regionFill: this.lineOptions.regionFill,
+ areaFill: this.lineOptions.areaFill,
hideDots: this.lineOptions.hideDots,
hideLine: this.lineOptions.hideLine,
diff --git a/src/js/objects/ChartComponents.js b/src/js/objects/ChartComponents.js
index 83f929f..bab0d89 100644
--- a/src/js/objects/ChartComponents.js
+++ b/src/js/objects/ChartComponents.js
@@ -354,7 +354,7 @@ let componentConfigs = {
c.color,
{
heatline: c.heatline,
- regionFill: c.regionFill
+ areaFill: c.areaFill
},
{
svgDefs: c.svgDefs,
diff --git a/src/js/utils/draw.js b/src/js/utils/draw.js
index ebfd260..d12bc6f 100644
--- a/src/js/utils/draw.js
+++ b/src/js/utils/draw.js
@@ -551,7 +551,7 @@ export function getPaths(xList, yList, color, options={}, meta={}) {
};
// Region
- if(options.regionFill) {
+ if(options.areaFill) {
let gradient_id_region = makeGradient(meta.svgDefs, color, true);
let pathStr = "M" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;