diff --git a/.babelrc b/.babelrc index 6080ece..d7d13bf 100644 --- a/.babelrc +++ b/.babelrc @@ -1,4 +1,15 @@ { - "presets": ["env"], - "plugins": ["external-helpers"] + "presets": [ + ["latest", { + "es2015": { + "modules": false + } + }] + ], + "plugins": ["external-helpers"], + "env": { + "test": { + "presets": ["env"] + } + } } diff --git a/Makefile b/Makefile index 73e51c2..d950d83 100644 --- a/Makefile +++ b/Makefile @@ -8,8 +8,13 @@ TESTDIR = $(SRCDIR)/test NODEMOD = $(BASEDIR)/node_modules NODEBIN = $(NODEMOD)/.bin +build: + $(NODEBIN)/rollup \ + --config $(BASEDIR)/rollup.config.js + test: - $(NODEBIN)/mocha \ - --recursive \ - --compilers js:babel-core/register \ + NODE_ENV=test \ + $(NODEBIN)/mocha \ + --recursive \ + --require $(NODEMOD)/babel-register \ $(TESTDIR) diff --git a/dist/frappe-charts.min.iife.js.map b/dist/frappe-charts.min.iife.js.map index f23b6a4..28c5cdc 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/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/utils/constants.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 === \"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, commonClass, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`.${commonClass}.${activeClass}`);\n\n\tforEachNode($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","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","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(parent, className, transform='') {\n\treturn createSVG('g', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\ttransform: transform\n\t});\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\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: width - getStringWidth(label, 5) - LABEL_MARGIN,\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) {\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\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN,\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\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 || meta.minHeight // TODO: correct y for positive min 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\t// TODO: use zeroLine OR minimum\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(parent, this.layerClass, this.layerTransform);\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(marker =>\n\t\t\t\tyMarker(marker.position, marker.label, this.constants.width,\n\t\t\t\t\t{pos:'right', 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\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};\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(region =>\n\t\t\t\tyRegion(region.startPos, region.endPos, this.constants.width,\n\t\t\t\t\tregion.label)\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\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};\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),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 11\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 { DEFAULT_AXIS_CHART_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\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\t\t//\n\n\t\t// Set type\n\t\tif(!d.chartType ) {\n\t\t\tif(!AXIS_DATASET_CHART_TYPES.includes(type)) type === DEFAULT_AXIS_CHART_TYPE;\n\t\t\td.chartType = type;\n\t\t}\n\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\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 };","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_CHART_TOP_MARGIN = 10;\nexport const BASE_CHART_LEFT_MARGIN = 20;\nexport const BASE_CHART_RIGHT_MARGIN = 20;\n\nexport const Y_AXIS_LEFT_MARGIN = 60;\nexport const Y_AXIS_RIGHT_MARGIN = 40;\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const DEFAULT_AXIS_CHART_TYPE = 'line';\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 0.5;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.01;\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_LEFT_MARGIN = 50;\nexport const HEATMAP_TOP_MARGIN = 25;\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\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: `${ set.value === 0 || set.value ? set.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}.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, AXIS_TICK_LENGTH } from '../utils/draw';\nimport { BASE_CHART_TOP_MARGIN, BASE_CHART_LEFT_MARGIN,\n\tBASE_CHART_RIGHT_MARGIN, INIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS,\n\tALL_CHART_TYPES, COMPATIBLE_CHARTS, DATA_COLOR_DIVISIONS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\nimport { Chart } from '../chart';\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.argHeight = options.height || 240;\n\t\tthis.type = options.type || '';\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: options.showLegend || 1,\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\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\tconfigure() {\n\t\tthis.setMargins();\n\n\t\t// Bind window events\n\t\twindow.addEventListener('resize', () => this.boundDrawFn);\n\t\twindow.addEventListener('orientationchange', () => this.boundDrawFn);\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\tsetMargins() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - 70;\n\t\tthis.topMargin = BASE_CHART_TOP_MARGIN;\n\n\t\t// Horizontal margins\n\t\tthis.leftMargin = BASE_CHART_LEFT_MARGIN;\n\t\tthis.rightMargin = BASE_CHART_RIGHT_MARGIN;\n\t}\n\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\tsetupComponents() {\n\t\tthis.components = new Map();\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}\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.calc(onlyWidthChange);\n\t\tthis.updateWidth();\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\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - (this.leftMargin + this.rightMargin);\n\t}\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\tprepareData(data=this.data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn data;\n\t}\n\n\tcalc() {} // builds state\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\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\n\t\tlet titleAreaHeight = 0;\n\t\tlet legendAreaHeight = 0;\n\t\tif(this.title.length) {\n\t\t\ttitleAreaHeight = 40;\n\t\t}\n\t\tif(this.config.showLegend) {\n\t\t\tlegendAreaHeight = 30;\n\t\t}\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 + titleAreaHeight + legendAreaHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\t// console.log(this.baseHeight, titleAreaHeight, legendAreaHeight);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tthis.leftMargin - AXIS_TICK_LENGTH * 6,\n\t\t\t\tthis.topMargin,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: 12,\n\t\t\t\t\tfill: '#666666'\n\t\t\t\t}\n\t\t\t);\n\t\t\tthis.svg.appendChild(this.titleEL);\n\t\t}\n\n\t\tlet top = this.topMargin + titleAreaHeight;\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.svg,\n\t\t\tthis.type + '-chart',\n\t\t\t`translate(${this.leftMargin}, ${top})`\n\t\t);\n\n\t\ttop = this.baseHeight - titleAreaHeight;\n\t\tthis.legendArea = makeSVGGroup(\n\t\t\tthis.svg,\n\t\t\t'chart-legend',\n\t\t\t`translate(${this.leftMargin}, ${top})`\n\t\t);\n\n\t\tthis.updateTipOffset(this.leftMargin, this.topMargin + titleAreaHeight);\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\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\tgetDifferentChart(type) {\n\t\tconst currentType = this.type;\n\t\tlet args = this.rawChartArgs;\n\t\tif(type === currentType) return;\n\n\t\tif(!ALL_CHART_TYPES.includes(type)) {\n\t\t\tconsole.error(`'${type}' is not a valid chart type.`);\n\t\t}\n\n\t\tif(!COMPATIBLE_CHARTS[currentType].includes(type)) {\n\t\t\tconsole.error(`'${currentType}' chart cannot be converted to a '${type}' chart.`);\n\t\t}\n\n\t\t// whether the new chart can use the existing colors\n\t\tconst useColor = DATA_COLOR_DIVISIONS[currentType] === DATA_COLOR_DIVISIONS[type];\n\n\t\t// Okay, this is anticlimactic\n\t\t// this function will need to actually be 'changeChartType(type)'\n\t\t// that will update only the required elements, but for now ...\n\n\t\targs.type = type;\n\t\targs.colors = useColor ? args.colors : undefined;\n\n\t\treturn new Chart(this.parent, args);\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents(){\n\t\twindow.removeEventListener('resize', () => this.boundDrawFn);\n\t\twindow.removeEventListener('orientationchange', () => this.boundDrawFn);\n\t}\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';\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\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet rect = legendDot(\n\t\t\t\tbarWidth * i + 5,\n\t\t\t\t'0',\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(rect);\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\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.barOptions.height = this.barOptions.height\n\t\t\t|| PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tthis.barOptions.depth = this.barOptions.depth\n\t\t\t|| PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tthis.setup();\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 { HEATMAP_TOP_MARGIN, HEATMAP_LEFT_MARGIN, 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\tconfigure(options) {\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\t\tsuper.configure(options);\n\t}\n\n\tsetMargins() {\n\t\tsuper.setMargins();\n\t\tthis.leftMargin = HEATMAP_LEFT_MARGIN;\n\t\tthis.topMargin = HEATMAP_TOP_MARGIN;\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 + this.rightMargin + this.leftMargin;\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.baseWidth = (this.state.noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ this.rightMargin + this.leftMargin;\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) {\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 { Y_AXIS_LEFT_MARGIN, Y_AXIS_RIGHT_MARGIN, 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 { MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO, LINE_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.type = args.type || 'line';\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\targs.axisOptions = args.axisOptions || {};\n\t\targs.tooltipOptions = args.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = args.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = args.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = args.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = args.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = args.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = args.valuesOverPoints;\n\t}\n\n\tsetMargins() {\n\t\tsuper.setMargins();\n\t\tthis.leftMargin = Y_AXIS_LEFT_MARGIN;\n\t\tthis.rightMargin = Y_AXIS_RIGHT_MARGIN;\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) return;\n\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\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\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\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 * (1 - 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\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: s.yAxis.zeroLine,\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\n\t\t// let formatY = this.config.formatTooltipY;\n\t\tlet formatX = this.config.formatTooltipX;\n\n\t\tlet titles = s.xAxis.labels;\n\t\tif(formatX && formatX(titles[0])) {\n\t\t\ttitles = titles.map(d=>formatX(d));\n\t\t}\n\n\t\t// formatY = formatY && formatY(s.yAxis.labels[0]) ? formatY : 0;\n\n\t\t// yVal = formatY ? formatY(set.values[i]) : set.values[i]\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 o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - this.leftMargin;\n\t\t\tlet relY = e.pageY - o.top - this.topMargin;\n\n\t\t\tif(relY < this.height + this.topMargin * 2) {\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\n\t\tthis.tip.setValues(\n\t\t\ts.xAxis.positions[index] + this.tip.offset.x,\n\t\t\ts.yExtremes[index] + this.tip.offset.y,\n\t\t\t{name: s.xAxis.labels[index], value: ''},\n\t\t\tthis.data.datasets.map((set, i) => {\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: set.values[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t};\n\t\t\t}),\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\tthis.legendArea.textContent = '';\n\n\t\tif(s.datasets.length > 1) {\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.leftMargin - this.rightMargin;\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.0.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","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","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","args","key","legendBar","label","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","undefined","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","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","transform","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","vals","chartType","AXIS_DATASET_CHART_TYPES","yRegions","end","zeroDataPrep","realData","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedLetters","DEFAULT_CHAR_WIDTH","getChartByType","AxisChart","chartTypes","error","ALL_CHART_TYPES","COMPATIBLE_CHARTS","DATA_COLOR_DIVISIONS","HEATMAP_DISTRIBUTION_SIZE","INIT_CHART_UPDATE_TIMEOUT","PERCENTAGE_BAR_DEFAULT_HEIGHT","DEFAULT_CHART_COLORS","DEFAULT_COLORS","PI","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","title","dataPointList","addEventListener","set","_this2","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BaseChart","HTMLElement","Error","rawChartArgs","argHeight","prepareData","prepareFirstData","validateColors","showLegend","isNavigable","state","initTimeout","overlays","configure","setMargins","_this","boundDrawFn","validColors","forEach","warn","baseHeight","topMargin","leftMargin","rightMargin","makeContainer","updateWidth","draw","components","Map","independentWidth","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","c","drawArea","render","update","renderLegend","setupNavigation","baseWidth","animate","make","updateNav","bindUnits","titleAreaHeight","legendAreaHeight","titleEL","legendArea","updateTipOffset","bindOverlay","keyActions","onEnterKey","bind","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","e","_this4","event","keyCode","currentType","useColor","Chart","removeEventListener","_this5","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","_this3","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","marker","startPos","endPos","_this6","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","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","spacing","HEATMAP_SQUARE_SIZE","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","COL_WIDTH","moreText","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","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","titles","relX","mapTooltipXPosition","overlayGuides","currentIndex","currentUnit","_this7","setCurrentDataPoint","_this9","_this10","getDataPoint","datasetValues","splice","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/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/utils/constants.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 === \"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, commonClass, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`.${commonClass}.${activeClass}`);\n\n\tforEachNode($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","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","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(parent, className, transform='') {\n\treturn createSVG('g', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\ttransform: transform\n\t});\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\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: width - getStringWidth(label, 5) - LABEL_MARGIN,\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) {\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\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN,\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\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 || meta.minHeight // TODO: correct y for positive min 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\t// TODO: use zeroLine OR minimum\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(parent, this.layerClass, this.layerTransform);\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(marker =>\n\t\t\t\tyMarker(marker.position, marker.label, this.constants.width,\n\t\t\t\t\t{pos:'right', 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\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};\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(region =>\n\t\t\t\tyRegion(region.startPos, region.endPos, this.constants.width,\n\t\t\t\t\tregion.label)\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\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};\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),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 11\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 { DEFAULT_AXIS_CHART_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\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\t\t//\n\n\t\t// Set type\n\t\tif(!d.chartType ) {\n\t\t\tif(!AXIS_DATASET_CHART_TYPES.includes(type)) type === DEFAULT_AXIS_CHART_TYPE;\n\t\t\td.chartType = type;\n\t\t}\n\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\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 };","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_CHART_TOP_MARGIN = 10;\nexport const BASE_CHART_LEFT_MARGIN = 20;\nexport const BASE_CHART_RIGHT_MARGIN = 20;\n\nexport const Y_AXIS_LEFT_MARGIN = 60;\nexport const Y_AXIS_RIGHT_MARGIN = 40;\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const DEFAULT_AXIS_CHART_TYPE = 'line';\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 0.5;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.01;\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_LEFT_MARGIN = 50;\nexport const HEATMAP_TOP_MARGIN = 25;\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\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: `${ set.value === 0 || set.value ? set.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}.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, AXIS_TICK_LENGTH } from '../utils/draw';\nimport { BASE_CHART_TOP_MARGIN, BASE_CHART_LEFT_MARGIN,\n\tBASE_CHART_RIGHT_MARGIN, INIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS,\n\tALL_CHART_TYPES, COMPATIBLE_CHARTS, DATA_COLOR_DIVISIONS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\nimport { Chart } from '../chart';\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.argHeight = options.height || 240;\n\t\tthis.type = options.type || '';\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: options.showLegend || 1,\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\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\tconfigure() {\n\t\tthis.setMargins();\n\n\t\t// Bind window events\n\t\twindow.addEventListener('resize', () => this.boundDrawFn);\n\t\twindow.addEventListener('orientationchange', () => this.boundDrawFn);\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\tsetMargins() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - 70;\n\t\tthis.topMargin = BASE_CHART_TOP_MARGIN;\n\n\t\t// Horizontal margins\n\t\tthis.leftMargin = BASE_CHART_LEFT_MARGIN;\n\t\tthis.rightMargin = BASE_CHART_RIGHT_MARGIN;\n\t}\n\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\tsetupComponents() {\n\t\tthis.components = new Map();\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}\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.calc(onlyWidthChange);\n\t\tthis.updateWidth();\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\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - (this.leftMargin + this.rightMargin);\n\t}\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\tprepareData(data=this.data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn data;\n\t}\n\n\tcalc() {} // builds state\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\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\n\t\tlet titleAreaHeight = 0;\n\t\tlet legendAreaHeight = 0;\n\t\tif(this.title.length) {\n\t\t\ttitleAreaHeight = 40;\n\t\t}\n\t\tif(this.config.showLegend) {\n\t\t\tlegendAreaHeight = 30;\n\t\t}\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 + titleAreaHeight + legendAreaHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\t// console.log(this.baseHeight, titleAreaHeight, legendAreaHeight);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tthis.leftMargin - AXIS_TICK_LENGTH * 6,\n\t\t\t\tthis.topMargin,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: 12,\n\t\t\t\t\tfill: '#666666'\n\t\t\t\t}\n\t\t\t);\n\t\t\tthis.svg.appendChild(this.titleEL);\n\t\t}\n\n\t\tlet top = this.topMargin + titleAreaHeight;\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.svg,\n\t\t\tthis.type + '-chart',\n\t\t\t`translate(${this.leftMargin}, ${top})`\n\t\t);\n\n\t\ttop = this.baseHeight - titleAreaHeight;\n\t\tthis.legendArea = makeSVGGroup(\n\t\t\tthis.svg,\n\t\t\t'chart-legend',\n\t\t\t`translate(${this.leftMargin}, ${top})`\n\t\t);\n\n\t\tthis.updateTipOffset(this.leftMargin, this.topMargin + titleAreaHeight);\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\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\tgetDifferentChart(type) {\n\t\tconst currentType = this.type;\n\t\tlet args = this.rawChartArgs;\n\t\tif(type === currentType) return;\n\n\t\tif(!ALL_CHART_TYPES.includes(type)) {\n\t\t\tconsole.error(`'${type}' is not a valid chart type.`);\n\t\t}\n\n\t\tif(!COMPATIBLE_CHARTS[currentType].includes(type)) {\n\t\t\tconsole.error(`'${currentType}' chart cannot be converted to a '${type}' chart.`);\n\t\t}\n\n\t\t// whether the new chart can use the existing colors\n\t\tconst useColor = DATA_COLOR_DIVISIONS[currentType] === DATA_COLOR_DIVISIONS[type];\n\n\t\t// Okay, this is anticlimactic\n\t\t// this function will need to actually be 'changeChartType(type)'\n\t\t// that will update only the required elements, but for now ...\n\n\t\targs.type = type;\n\t\targs.colors = useColor ? args.colors : undefined;\n\n\t\treturn new Chart(this.parent, args);\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents(){\n\t\twindow.removeEventListener('resize', () => this.boundDrawFn);\n\t\twindow.removeEventListener('orientationchange', () => this.boundDrawFn);\n\t}\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';\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\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet rect = legendDot(\n\t\t\t\tbarWidth * i + 5,\n\t\t\t\t'0',\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(rect);\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\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.barOptions.height = this.barOptions.height\n\t\t\t|| PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tthis.barOptions.depth = this.barOptions.depth\n\t\t\t|| PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tthis.setup();\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 { HEATMAP_TOP_MARGIN, HEATMAP_LEFT_MARGIN, 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\tconfigure(options) {\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\t\tsuper.configure(options);\n\t}\n\n\tsetMargins() {\n\t\tsuper.setMargins();\n\t\tthis.leftMargin = HEATMAP_LEFT_MARGIN;\n\t\tthis.topMargin = HEATMAP_TOP_MARGIN;\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 + this.rightMargin + this.leftMargin;\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.baseWidth = (this.state.noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ this.rightMargin + this.leftMargin;\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) {\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 { Y_AXIS_LEFT_MARGIN, Y_AXIS_RIGHT_MARGIN, 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 { MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO, LINE_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.type = args.type || 'line';\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\targs.axisOptions = args.axisOptions || {};\n\t\targs.tooltipOptions = args.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = args.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = args.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = args.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = args.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = args.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = args.valuesOverPoints;\n\t}\n\n\tsetMargins() {\n\t\tsuper.setMargins();\n\t\tthis.leftMargin = Y_AXIS_LEFT_MARGIN;\n\t\tthis.rightMargin = Y_AXIS_RIGHT_MARGIN;\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) return;\n\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\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\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\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 * (1 - 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\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: s.yAxis.zeroLine,\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\n\t\t// let formatY = this.config.formatTooltipY;\n\t\tlet formatX = this.config.formatTooltipX;\n\n\t\tlet titles = s.xAxis.labels;\n\t\tif(formatX && formatX(titles[0])) {\n\t\t\ttitles = titles.map(d=>formatX(d));\n\t\t}\n\n\t\t// formatY = formatY && formatY(s.yAxis.labels[0]) ? formatY : 0;\n\n\t\t// yVal = formatY ? formatY(set.values[i]) : set.values[i]\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 o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - this.leftMargin;\n\t\t\tlet relY = e.pageY - o.top - this.topMargin;\n\n\t\t\tif(relY < this.height + this.topMargin * 2) {\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\n\t\tthis.tip.setValues(\n\t\t\ts.xAxis.positions[index] + this.tip.offset.x,\n\t\t\ts.yExtremes[index] + this.tip.offset.y,\n\t\t\t{name: s.xAxis.labels[index], value: ''},\n\t\t\tthis.data.datasets.map((set, i) => {\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: set.values[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t};\n\t\t\t}),\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\tthis.legendArea.textContent = '';\n\n\t\tif(s.datasets.length > 1) {\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.leftMargin - this.rightMargin;\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.0.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","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","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","args","key","legendBar","label","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","undefined","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","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","transform","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","vals","chartType","AXIS_DATASET_CHART_TYPES","yRegions","end","zeroDataPrep","realData","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedLetters","DEFAULT_CHAR_WIDTH","getChartByType","AxisChart","chartTypes","error","ALL_CHART_TYPES","COMPATIBLE_CHARTS","DATA_COLOR_DIVISIONS","HEATMAP_DISTRIBUTION_SIZE","INIT_CHART_UPDATE_TIMEOUT","PERCENTAGE_BAR_DEFAULT_HEIGHT","DEFAULT_CHART_COLORS","DEFAULT_COLORS","PI","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","title","dataPointList","addEventListener","set","_this2","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BaseChart","HTMLElement","Error","rawChartArgs","argHeight","prepareData","prepareFirstData","validateColors","showLegend","isNavigable","state","initTimeout","overlays","configure","setMargins","_this","boundDrawFn","validColors","forEach","warn","baseHeight","topMargin","leftMargin","rightMargin","makeContainer","updateWidth","draw","components","Map","independentWidth","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","c","drawArea","render","update","renderLegend","setupNavigation","baseWidth","animate","make","updateNav","bindUnits","titleAreaHeight","legendAreaHeight","titleEL","legendArea","updateTipOffset","bindOverlay","keyActions","onEnterKey","bind","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","e","_this4","event","keyCode","currentType","useColor","Chart","removeEventListener","_this5","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","_this3","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","marker","startPos","endPos","_this6","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","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","spacing","HEATMAP_SQUARE_SIZE","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","COL_WIDTH","moreText","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","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","titles","relX","mapTooltipXPosition","overlayGuides","currentIndex","currentUnit","_this7","setCurrentDataPoint","_this9","_this10","getDataPoint","datasetValues","splice","frappe","NAME","VERSION","Charts"],"mappings":"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"} \ No newline at end of file diff --git a/docs/assets/js/frappe-charts.min.js.map b/docs/assets/js/frappe-charts.min.js.map index ec648bf..66c11ef 100644 --- a/docs/assets/js/frappe-charts.min.js.map +++ b/docs/assets/js/frappe-charts.min.js.map @@ -1 +1 @@ -{"version":3,"file":"frappe-charts.min.js","sources":["../../../src/js/utils/dom.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/utils/constants.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 === \"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, commonClass, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`.${commonClass}.${activeClass}`);\n\n\tforEachNode($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","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","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(parent, className, transform='') {\n\treturn createSVG('g', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\ttransform: transform\n\t});\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\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: width - getStringWidth(label, 5) - LABEL_MARGIN,\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) {\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\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN,\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\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 || meta.minHeight // TODO: correct y for positive min 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\t// TODO: use zeroLine OR minimum\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(parent, this.layerClass, this.layerTransform);\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(marker =>\n\t\t\t\tyMarker(marker.position, marker.label, this.constants.width,\n\t\t\t\t\t{pos:'right', 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\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};\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(region =>\n\t\t\t\tyRegion(region.startPos, region.endPos, this.constants.width,\n\t\t\t\t\tregion.label)\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\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};\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),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 11\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 { DEFAULT_AXIS_CHART_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\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\t\t//\n\n\t\t// Set type\n\t\tif(!d.chartType ) {\n\t\t\tif(!AXIS_DATASET_CHART_TYPES.includes(type)) type === DEFAULT_AXIS_CHART_TYPE;\n\t\t\td.chartType = type;\n\t\t}\n\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\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 };","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_CHART_TOP_MARGIN = 10;\nexport const BASE_CHART_LEFT_MARGIN = 20;\nexport const BASE_CHART_RIGHT_MARGIN = 20;\n\nexport const Y_AXIS_LEFT_MARGIN = 60;\nexport const Y_AXIS_RIGHT_MARGIN = 40;\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const DEFAULT_AXIS_CHART_TYPE = 'line';\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 0.5;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.01;\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_LEFT_MARGIN = 50;\nexport const HEATMAP_TOP_MARGIN = 25;\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\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: `${ set.value === 0 || set.value ? set.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}.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, AXIS_TICK_LENGTH } from '../utils/draw';\nimport { BASE_CHART_TOP_MARGIN, BASE_CHART_LEFT_MARGIN,\n\tBASE_CHART_RIGHT_MARGIN, INIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS,\n\tALL_CHART_TYPES, COMPATIBLE_CHARTS, DATA_COLOR_DIVISIONS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\nimport { Chart } from '../chart';\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.argHeight = options.height || 240;\n\t\tthis.type = options.type || '';\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: options.showLegend || 1,\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\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\tconfigure() {\n\t\tthis.setMargins();\n\n\t\t// Bind window events\n\t\twindow.addEventListener('resize', () => this.boundDrawFn);\n\t\twindow.addEventListener('orientationchange', () => this.boundDrawFn);\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\tsetMargins() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - 70;\n\t\tthis.topMargin = BASE_CHART_TOP_MARGIN;\n\n\t\t// Horizontal margins\n\t\tthis.leftMargin = BASE_CHART_LEFT_MARGIN;\n\t\tthis.rightMargin = BASE_CHART_RIGHT_MARGIN;\n\t}\n\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\tsetupComponents() {\n\t\tthis.components = new Map();\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}\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.calc(onlyWidthChange);\n\t\tthis.updateWidth();\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\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - (this.leftMargin + this.rightMargin);\n\t}\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\tprepareData(data=this.data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn data;\n\t}\n\n\tcalc() {} // builds state\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\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\n\t\tlet titleAreaHeight = 0;\n\t\tlet legendAreaHeight = 0;\n\t\tif(this.title.length) {\n\t\t\ttitleAreaHeight = 40;\n\t\t}\n\t\tif(this.config.showLegend) {\n\t\t\tlegendAreaHeight = 30;\n\t\t}\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 + titleAreaHeight + legendAreaHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\t// console.log(this.baseHeight, titleAreaHeight, legendAreaHeight);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tthis.leftMargin - AXIS_TICK_LENGTH * 6,\n\t\t\t\tthis.topMargin,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: 12,\n\t\t\t\t\tfill: '#666666'\n\t\t\t\t}\n\t\t\t);\n\t\t\tthis.svg.appendChild(this.titleEL);\n\t\t}\n\n\t\tlet top = this.topMargin + titleAreaHeight;\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.svg,\n\t\t\tthis.type + '-chart',\n\t\t\t`translate(${this.leftMargin}, ${top})`\n\t\t);\n\n\t\ttop = this.baseHeight - titleAreaHeight;\n\t\tthis.legendArea = makeSVGGroup(\n\t\t\tthis.svg,\n\t\t\t'chart-legend',\n\t\t\t`translate(${this.leftMargin}, ${top})`\n\t\t);\n\n\t\tthis.updateTipOffset(this.leftMargin, this.topMargin + titleAreaHeight);\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\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\tgetDifferentChart(type) {\n\t\tconst currentType = this.type;\n\t\tlet args = this.rawChartArgs;\n\t\tif(type === currentType) return;\n\n\t\tif(!ALL_CHART_TYPES.includes(type)) {\n\t\t\tconsole.error(`'${type}' is not a valid chart type.`);\n\t\t}\n\n\t\tif(!COMPATIBLE_CHARTS[currentType].includes(type)) {\n\t\t\tconsole.error(`'${currentType}' chart cannot be converted to a '${type}' chart.`);\n\t\t}\n\n\t\t// whether the new chart can use the existing colors\n\t\tconst useColor = DATA_COLOR_DIVISIONS[currentType] === DATA_COLOR_DIVISIONS[type];\n\n\t\t// Okay, this is anticlimactic\n\t\t// this function will need to actually be 'changeChartType(type)'\n\t\t// that will update only the required elements, but for now ...\n\n\t\targs.type = type;\n\t\targs.colors = useColor ? args.colors : undefined;\n\n\t\treturn new Chart(this.parent, args);\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents(){\n\t\twindow.removeEventListener('resize', () => this.boundDrawFn);\n\t\twindow.removeEventListener('orientationchange', () => this.boundDrawFn);\n\t}\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';\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\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet rect = legendDot(\n\t\t\t\tbarWidth * i + 5,\n\t\t\t\t'0',\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(rect);\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\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.barOptions.height = this.barOptions.height\n\t\t\t|| PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tthis.barOptions.depth = this.barOptions.depth\n\t\t\t|| PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tthis.setup();\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 { HEATMAP_TOP_MARGIN, HEATMAP_LEFT_MARGIN, 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\tconfigure(options) {\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\t\tsuper.configure(options);\n\t}\n\n\tsetMargins() {\n\t\tsuper.setMargins();\n\t\tthis.leftMargin = HEATMAP_LEFT_MARGIN;\n\t\tthis.topMargin = HEATMAP_TOP_MARGIN;\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 + this.rightMargin + this.leftMargin;\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.baseWidth = (this.state.noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ this.rightMargin + this.leftMargin;\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) {\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 { Y_AXIS_LEFT_MARGIN, Y_AXIS_RIGHT_MARGIN, 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 { MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO, LINE_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.type = args.type || 'line';\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\targs.axisOptions = args.axisOptions || {};\n\t\targs.tooltipOptions = args.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = args.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = args.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = args.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = args.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = args.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = args.valuesOverPoints;\n\t}\n\n\tsetMargins() {\n\t\tsuper.setMargins();\n\t\tthis.leftMargin = Y_AXIS_LEFT_MARGIN;\n\t\tthis.rightMargin = Y_AXIS_RIGHT_MARGIN;\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) return;\n\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\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\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\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 * (1 - 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\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: s.yAxis.zeroLine,\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\n\t\t// let formatY = this.config.formatTooltipY;\n\t\tlet formatX = this.config.formatTooltipX;\n\n\t\tlet titles = s.xAxis.labels;\n\t\tif(formatX && formatX(titles[0])) {\n\t\t\ttitles = titles.map(d=>formatX(d));\n\t\t}\n\n\t\t// formatY = formatY && formatY(s.yAxis.labels[0]) ? formatY : 0;\n\n\t\t// yVal = formatY ? formatY(set.values[i]) : set.values[i]\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 o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - this.leftMargin;\n\t\t\tlet relY = e.pageY - o.top - this.topMargin;\n\n\t\t\tif(relY < this.height + this.topMargin * 2) {\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\n\t\tthis.tip.setValues(\n\t\t\ts.xAxis.positions[index] + this.tip.offset.x,\n\t\t\ts.yExtremes[index] + this.tip.offset.y,\n\t\t\t{name: s.xAxis.labels[index], value: ''},\n\t\t\tthis.data.datasets.map((set, i) => {\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: set.values[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t};\n\t\t\t}),\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\tthis.legendArea.textContent = '';\n\n\t\tif(s.datasets.length > 1) {\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.leftMargin - this.rightMargin;\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.0.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","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","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","args","key","legendBar","label","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","undefined","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","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","transform","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","vals","chartType","AXIS_DATASET_CHART_TYPES","yRegions","end","zeroDataPrep","realData","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedLetters","DEFAULT_CHAR_WIDTH","getChartByType","AxisChart","chartTypes","error","ALL_CHART_TYPES","COMPATIBLE_CHARTS","DATA_COLOR_DIVISIONS","HEATMAP_DISTRIBUTION_SIZE","INIT_CHART_UPDATE_TIMEOUT","PERCENTAGE_BAR_DEFAULT_HEIGHT","DEFAULT_CHART_COLORS","DEFAULT_COLORS","PI","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","title","dataPointList","addEventListener","set","_this2","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BaseChart","HTMLElement","Error","rawChartArgs","argHeight","prepareData","prepareFirstData","validateColors","showLegend","isNavigable","state","initTimeout","overlays","configure","setMargins","_this","boundDrawFn","validColors","forEach","warn","baseHeight","topMargin","leftMargin","rightMargin","makeContainer","updateWidth","draw","components","Map","independentWidth","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","c","drawArea","render","update","renderLegend","setupNavigation","baseWidth","animate","make","updateNav","bindUnits","titleAreaHeight","legendAreaHeight","titleEL","legendArea","updateTipOffset","bindOverlay","keyActions","onEnterKey","bind","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","e","_this4","event","keyCode","currentType","useColor","Chart","removeEventListener","_this5","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","_this3","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","marker","startPos","endPos","_this6","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","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","spacing","HEATMAP_SQUARE_SIZE","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","COL_WIDTH","moreText","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","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","titles","relX","mapTooltipXPosition","overlayGuides","currentIndex","currentUnit","_this7","setCurrentDataPoint","_this9","_this10","getDataPoint","datasetValues","splice","frappe","NAME","VERSION","Charts"],"mappings":"kCAAO,SAASA,GAAEC,EAAMC,SACA,gBAATD,IAAoBC,GAAOC,UAAUC,cAAcH,GAAQA,GAAQ,KA4ClF,QAAgBI,GAAUC,MACrBC,GAAOD,EAAQE,mCAKbD,EAAKE,KAAON,SAASO,gBAAgBC,WAAaR,SAASS,KAAKD,gBAC/DJ,EAAKM,MAAQV,SAASO,gBAAgBI,YAAcX,SAASS,KAAKE,aAI1E,QAAgBC,GAAoBC,MAE/BT,GAAOS,EAAGR,8BAGbD,GAAKE,KAAO,GACNF,EAAKM,MAAQ,GACbN,EAAKU,SAAWC,OAAOC,aAAehB,SAASO,gBAAgBU,iBAC1DC,QAAUH,OAAOI,YAAcnB,SAASO,gBAAgBa,aAIrE,QAAgBC,GAAuBlB,MAClCmB,GAASP,OAAOQ,iBAAiBpB,GACjCqB,EAAUC,WAAWH,EAAOI,aAC/BD,WAAWH,EAAOK,oBAEZxB,GAAQiB,YAAcI,EA2B9B,QAAgBI,GAAKC,EAAQC,EAAMC,MAC9BC,GAAMhC,SAASiC,YAAY,gBAE3BC,UAAUJ,GAAM,GAAM,OAErB,GAAIK,KAAKJ,KACTI,GAAKJ,EAAWI,SAGdN,GAAOO,cAAcJ,GCvGtB,QAASK,GAASC,SACjBb,YAAWa,EAAEC,QAAQ,IAyC7B,QAAgBC,GAAUC,EAAOC,EAAOvC,MAASwC,0DAC5CxC,OACOwC,EAAQF,EAAM,GAAKA,EAAMA,EAAMG,OAAS,OAE/CC,GAAc,GAAIC,OAAMC,KAAKC,IAAIN,IAAQO,KAAK9C,YAC1CwC,EAAQE,EAAYK,OAAOT,GAASA,EAAMS,OAAOL,GAS1D,QAAgBM,GAAeC,EAAQC,UAC9BD,EAAO,IAAIR,OAASS,EAyB7B,QAAgBC,GAAmBC,EAAOC,YAErCT,KAAKU,IAAIF,EAAQG,IAAeF,IAChCT,KAAKY,IAAIJ,EAAQG,IAAeF,WCzFrBI,GAAqBC,EAAMC,MACtCC,UAAQC,eACRH,IAAQC,KACFA,EAAWD,IAChBA,MAEKA,EAAOC,IACZA,IAGGC,EAAQC,GAGjB,QAAgBC,GAAqBC,EAAQC,MAC5CC,0DAAaD,EAAOvB,OAASsB,EAAOtB,aAGjCwB,GAAa,IACN5B,EAAU0B,EAAQE,KAElB5B,EAAU2B,EAAQC,IAEpBF,EAAQC,GCPjB,QAASE,GAAWC,SACfA,GAAI,IAAY,IACXA,EAAI,EAAU,EAChBA,EAGR,QAAgBC,GAAmBC,EAAOC,MACrCC,GAAMC,GAASH,GACfI,GAAW,CACD,MAAVF,EAAI,OACDA,EAAIG,MAAM,MACL,MAERC,GAAMC,SAASL,EAAI,IACnBJ,EAAID,GAAYS,GAAO,IAAML,GAC7BO,EAAIX,GAAaS,GAAO,EAAK,KAAUL,GACvCQ,EAAIZ,GAAkB,IAANS,GAAkBL,UAC9BG,EAAS,IAAI,KAAOK,EAAKD,GAAK,EAAMV,GAAK,IAAKY,SAAS,IAGhE,QAAgBC,GAAa/B,8CAEgBgC,KAAKhC,GC5BlD,QAASvD,GAAEC,EAAMC,SACO,gBAATD,IAAoBC,GAAOC,UAAUC,cAAcH,GAAQA,GAAQ,KAGlF,QAAgBuF,GAAUC,EAAKC,MAC1BpF,GAAUH,SAASwF,gBAAgB,6BAA8BF,OAEhE,GAAIG,KAAKF,GAAG,IACZG,GAAMH,EAAEE,MAEF,WAANA,IACDC,GAAKC,YAAYxF,OAEf,IAAU,WAANsF,EAAgB,IACpBG,GAAM/F,EAAE6F,KACRG,WAAWC,aAAa3F,EAASyF,KAC7BD,YAAYC,OAEJ,WAANH,EACQ,qBAARC,iBAAAA,YACFK,KAAKL,GAAKM,IAAI,cACZC,MAAMC,GAAQR,EAAIQ,MAInB,cAANT,MAAyB,SACnB,cAANA,IACF,YAAyBC,IAEjBS,aAAaV,EAAGC,UAKpBvF,GAGR,QAASiG,GAAuBC,EAAYC,SACpCjB,GAAU,yBACRgB,KACJC,KACA,KACA,KACA,KACA,IAIN,QAASC,GAAgBC,EAAUC,EAAQjC,EAAOkC,SAC1CrB,GAAU,eACNmB,uBACchC,SACdiC,iBACMC,IAIlB,QAAgBC,GAAiBC,EAAQC,EAAWC,EAAO/C,SACnDsB,GAAU,iBACLwB,SACHD,QACDE,SACC/C,IAIV,QAAgBgD,GAAYC,SACpB3B,GAAU,eACR2B,IAIV,QAAgBC,GAAaL,EAAQC,SAC7BxB,GAAU,eACLwB,SACHD,mEAHgD,KAgB1D,QAAgBM,GAASC,SACjB9B,GAAU,yEAD0B,KAGvC8B,wEAHkD,mEAAa,UAWpE,QAAgBC,GAAeC,EAAeC,EAAaC,EAAQ/D,MAAQgE,0DAAU,EAC/EC,EAAyBF,EAAOG,EAAIL,EAAcK,EAAvCC,EAA0CJ,EAAOvD,EAAIqD,EAAcrD,EAC9E4D,EAAqBL,EAAOG,EAAIJ,EAAYI,EAAnCG,EAAsCN,EAAOvD,EAAIsD,EAAYtD,YAEhEuD,EAAOG,MAAKH,EAAOvD,YAC1ByD,MAAaE,aACZnE,MAAUA,WAAcgE,EAAY,EAAI,YAC1CI,MAAWC,OAGf,QAAgBC,GAAazB,EAAY7B,MAAOuD,2DAC3CzB,EAAY,sBAA6B9B,EAAQ,KAAMuD,EAAU,UAAY,WAC7EC,EAAc5B,EAAuBC,EAAYC,GACjD2B,GAAa,EAAG,GAAK,UACtBF,QACW,GAAK,GAAK,MAGRC,EAAa,KAAMxD,EAAOyD,EAAU,MACpCD,EAAa,MAAOxD,EAAOyD,EAAU,MACrCD,EAAa,OAAQxD,EAAOyD,EAAU,IAE/C3B,EAGR,QAAgB4B,GAAcR,EAAG1D,EAAG8C,EAAO/C,MAC1CoE,0DAAMC,GAA8BnF,yDAAK,aAkBlCoC,GAAU,kBAfL,mBACRqC,IACA1D,QACI8C,SACC/C,OACFd,iBAEKsB,EAAmBtB,GAAO,8BAGVc,EAAS+C,QAAUA,OAAU/C,iBACvCoE,KAOnB,QAAgBE,GAAWxB,EAAWa,EAAG1D,EAAGsE,MAAMrF,0DAAK,OAAQsF,4DAC1DC,aACQ3B,IACRa,IACA1D,QACIsE,SACCA,OACFrF,iBAGA8C,KAAKwC,GAAMvC,IAAI,cAChByC,GAAOF,EAAKE,KAGXpD,EAAU,OAAQmD,GAG1B,QAAgBE,GAAUhB,EAAG1D,EAAGsE,MAAMrF,0DAAK,OAAQ0F,eAC9CH,aACQ,eACR,IACA,QACIF,SACC,WACFrF,GAEH2F,EAAOvD,EAAU,kBACT,wBACR,IACA,KACc,EAAZwD,GAAiB,iBACI,IAAZA,GAAmB,mBAClB,aACTC,aACKH,IAGRI,EAAQ1D,EAAU,4BACGqC,OAAM1D,iBAEzB2B,YAAYN,EAAU,OAAQmD,MAC9B7C,YAAYiD,GAEXG,EAGR,QAAgBC,GAAUtB,EAAG1D,EAAGsE,MAAMrF,0DAAK,OAAQ0F,eAC9CH,aACQ,gBACP,KACA,IACDF,OACGrF,GAEH2F,EAAOvD,EAAU,kBACT,wBACR,IACA,KACEwD,GAAa,QACbA,GAAU,EAAK,iBACM,IAAZA,GAAmB,mBAClB,aACTC,aACKH,IAGRI,EAAQ1D,EAAU,4BACGqC,OAAM1D,iBAEzB2B,YAAYN,EAAU,SAAUmD,MAChC7C,YAAYiD,GAEXG,EAGR,QAAgBE,GAASpC,EAAWa,EAAG1D,EAAGkF,MAASC,6DAC9CC,EAAWD,EAAQC,UAAYP,SAI5BxD,GAAU,kBACLwB,IACRa,IACA1D,UANoBqF,KAAfF,EAAQG,GAAmBH,EAAQG,GAAMF,EAAW,GAOnD,iBACIA,EAAW,UAPdD,EAAQlG,MAAQ6F,iBACVK,EAAQI,YAAc,kBAS3BL,IAIb,QAASM,GAAa9B,EAAGiB,EAAOc,EAAIC,MAAIP,4DACnCA,GAAQQ,SAAQR,EAAQQ,OAASC,OACjCC,GAAIxE,EAAU,kBACN,iBAAmB8D,EAAQtC,aAClC,KACA,KACA4C,KACAC,iBAEKP,EAAQQ,UAIdf,EAAOvD,EAAU,UACjB,IACAoE,EAAKC,EAAKD,EAAKK,GAAeL,EAAKK,GAAejB,MACjDA,GAAY,iBACHA,GAAY,mBACV,mBACJF,EAAQ,KAGhBoB,EAAO1E,EAAU,4BACKqC,oBAGrB/B,YAAYkE,KACZlE,YAAYiD,GAEVmB,EAGR,QAASC,GAAahG,EAAG2E,EAAOsB,EAAIC,MAAIf,4DACnCA,GAAQQ,SAAQR,EAAQQ,OAASC,IACjCT,EAAQgB,WAAUhB,EAAQgB,SAAW,OAIrCN,GAAIxE,EAAU,kBAHF,mBAAqB8D,EAAQtC,WACtB,WAArBsC,EAAQgB,SAAwB,SAAU,OAIvCF,KACAC,KACA,KACA,iBAEKf,EAAQQ,UAIdf,EAAOvD,EAAU,UACjB4E,EAAKC,EAAKD,EAAKH,GAAeG,EAAKH,KACnC,KACEjB,GAAY,EAAI,EAAK,iBACbA,GAAY,mBACVoB,EAAKC,EAAK,MAAQ,kBACtBvB,EAAM,KAGdoB,EAAO1E,EAAU,+BACOrB,uBACT,UAGP,KAAT4E,GAAuB,MAATA,MACX3C,MAAM0D,OAAS,2BAGhBhE,YAAYkE,KACZlE,YAAYiD,GAEVmB,EAGR,QAAgBK,GAAMpG,EAAG2E,EAAO7B,MAAOqC,4DAClCA,GAAQkB,MAAKlB,EAAQkB,IAAM,QAC3BlB,EAAQ1C,SAAQ0C,EAAQ1C,OAAS,GACjC0C,EAAQmB,OAAMnB,EAAQmB,KAAO,QAC7BnB,EAAQQ,SAAQR,EAAQQ,OAASC,IACjCT,EAAQtC,YAAWsC,EAAQtC,UAAY,OAEvCoD,IAAM,EAAIM,GACVL,EAAsB,SAAjBf,EAAQmB,KAAkBxD,EAAQyD,GAAmB,QAE1C,SAAjBpB,EAAQmB,MAAmC,UAAhBnB,EAAQkB,QAChCvD,EAAQyD,KACRzD,MAKAqC,EAAQ1C,UACR0C,EAAQ1C,OAEPuD,EAAahG,EAAG2E,EAAOsB,EAAIC,UACzBf,EAAQQ,iBACLR,EAAQtC,mBACTsC,EAAQgB,WAIpB,QAAgBK,GAAM9C,EAAGiB,EAAO5E,MAAQoF,4DACnCA,GAAQkB,MAAKlB,EAAQkB,IAAM,UAC3BlB,EAAQ1C,SAAQ0C,EAAQ1C,OAAS,GACjC0C,EAAQmB,OAAMnB,EAAQmB,KAAO,QAC7BnB,EAAQQ,SAAQR,EAAQQ,OAASC,IACjCT,EAAQtC,YAAWsC,EAAQtC,UAAY,OAavC4C,GAAK1F,EAASwG,GACdb,EAAsB,SAAjBP,EAAQmB,MAAmB,EAAIC,GAAmBxG,QAEvC,SAAjBoF,EAAQmB,MAAmC,QAAhBnB,EAAQkB,SAE/B,EAAIE,KACL,GAGCf,EAAa9B,EAAGiB,EAAOc,EAAIC,UACzBP,EAAQQ,iBACLR,EAAQtC,mBACTsC,EAAQgB,WAIpB,QAAgBM,GAAQzG,EAAG2E,EAAO7B,MAAOqC,6DACpCuB,EAAWrF,EAAU,kBACb,gBACRyB,EAAQ3D,EAAewF,EAAO,GAAKmB,KACnC,KACEjB,IAAa,EAAK,iBACVA,GAAY,mBACV,kBACJF,EAAM,KAGdoB,EAAOC,EAAahG,EAAG,GAAI,EAAG8C,UACzBqC,EAAQQ,QAAUC,aACfT,EAAQtC,WAAa,YACtBsC,EAAQgB,oBAGdxE,YAAY+E,GAEVX,EAGR,QAAgBY,GAAQlB,EAAIC,EAAI5C,EAAO6B,MAElC5E,GAAS0F,EAAKC,EAEdtJ,EAAOiF,EAAU,6EAIXuE,sBACe9C,OAAU/C,KAG/B,IACA,QACI+C,SACC/C,IAGL2G,EAAWrF,EAAU,kBACb,gBACRyB,EAAQ3D,EAAewF,EAAM,GAAI,KAAOmB,KACxC,KACEjB,IAAa,EAAK,iBACVA,GAAY,mBACV,kBACJF,EAAM,KAGdiC,EAASvF,EAAU,+BACKqE,iBAGrB/D,YAAYvF,KACZuF,YAAY+E,GAEZE,EAGR,QAAgBC,GAAWnD,EAAG7D,EAAMiD,EAAOtC,MAAOmE,0DAAM,GAAImC,yDAAM,EAAGrE,yDAAO,EAAGsE,8DAC5DnH,EAAqBC,EAAMkH,EAAKjH,oBAA7CC,OAAQC,OAGT5D,EAAOiF,EAAU,4CAEJb,qBACIsG,IACjBpD,OANCjB,QAQGK,SACC/C,GAAUgH,EAAKC,mBAGf,KAEKrC,EAAM/F,OAEb,GACDuD,aAAa,IAAK,KAClBA,aAAa,IAAK,MACnByC,GAAOvD,EAAU,kBACT,qBACRyB,EAAM,IACN,KACE+B,GAAY,GAAK,EAAK,iBACdA,GAAY,mBACV,mBACJF,IAGRI,EAAQ1D,EAAU,wBACDyF,yBACIpD,OAAM1D,iBAEzB2B,YAAYvF,KACZuF,YAAYiD,GAEXG,QArBA3I,GAyBT,QAAgB6K,GAAWvD,EAAG1D,EAAGR,EAAQgB,MAAOmE,0DAAM,GAAImC,yDAAM,EAC3DI,EAAM7F,EAAU,yBACHb,qBACIsG,KAChBpD,KACA1D,IACDR,WAGK,KAEKmF,EAAM/F,OAEb,GACFuD,aAAa,KAAM,KACnBA,aAAa,KAAM,MAEnByC,GAAOvD,EAAU,kBACT,qBACR,IACA,KACEwD,GAAY,GAAK,EAAIrF,EAAU,iBACvBqF,GAAY,mBACV,mBACJF,IAGRI,EAAQ1D,EAAU,wBACDyF,yBACIpD,OAAM1D,iBAEzB2B,YAAYuF,KACZvF,YAAYiD,GAEXG,QAtBAmC,GA0BT,QAAgBC,GAASC,EAAOC,EAAO7G,MAAO2E,6DAAY4B,4DAErDO,EADaD,EAAMrF,IAAI,SAAChC,EAAGyB,SAAO2F,GAAM3F,GAAK,IAAMzB,IAC5BuH,KAAK,KAC5BC,EAAOtE,EAAS,IAAIoE,EAAW,kBAAmB9G,MAGnD2E,EAAQsC,SAAU,IAChBC,GAAc5D,EAAaiD,EAAKY,QAASnH,KACxCyB,MAAM0D,eAAiB+B,SAGzBE,SACGJ,MAIJrC,EAAQ0C,WAAY,IAClBC,GAAqBhE,EAAaiD,EAAKY,QAASnH,GAAO,GAGvD2C,EAAU,IAASiE,EAAM,OAAML,EAAKjH,aAAcwH,MAAgBF,EAAMvG,OAAO,GAAG,OAAMkG,EAAKjH,WAC3F8G,OAAS1D,EAASC,gBAAwB,eAAgB2E,aAG1DF,GC1hBR,QAAgBG,GAAUC,EAAMC,EAAUC,EAAUC,MAC/CC,GAA0B,gBAAbH,GAAwBA,EAAWA,EAASV,KAAK,aAEjES,GACCK,UAAWH,EAASX,KAAK,OAC1BY,EACAG,GACA,aACCD,UAAWD,IAId,QAAgBG,GAAkB/B,EAAOgC,EAAMC,SACvCV,GAAUvB,GAAQiC,EAAM,IAAKD,EAAM,GAAIE,IAG/C,QAAgBC,GAAkBvC,EAAOwC,EAAMC,SACvCd,GAAU3B,GAAQ,EAAGyC,IAAQ,EAAGD,GAAOF,IAG/C,QAAgBI,GAAcC,EAAWC,EAAOC,EAAOC,MAClDC,GAAYH,EAAQC,EACpB7M,EAAO2M,EAAUK,WAAW,WAG/BhN,GACE2D,OAAQoJ,EAAWE,mBAHVjN,EAAKkN,aAAa,cAGyBH,GACtDT,GACAJ,IAGeP,EAAUgB,GAAY,EAAGG,IAAS,EAAGD,GAAQP,KAI9D,QAAgBa,GAAWC,EAAK9F,EAAG7D,EAAMiD,MAAOL,0DAAO,IACpC7C,EAAqBC,8DAAWC,oBAA7CC,OAAQC,iBACRyC,EACe,SAAjB+G,EAAIC,WACKD,EAAIJ,WAAW,IAGxBtG,MAAOA,EAAO/C,OAAQA,GACvB2J,GACApB,IAIeP,EAAUyB,EADRA,EAAIF,aAAa,aAAaK,MAAM,KAAK,GAAG9I,MAAM,GAAI,IAC3B6C,EAAG1D,GAAI0I,OAG3Cc,GAAM1G,MAAOA,EAAO/C,OAAQA,EAAQ2D,EAAGA,EAAG1D,EAAGA,GAAI0J,GAAepB,KAK3E,QAAgBsB,GAAW1C,EAAKxD,EAAG1D,SACd,WAAjBkH,EAAIuC,UAEU1B,EAAUb,EADRA,EAAIoC,aAAa,aAAaK,MAAM,KAAK,GAAG9I,MAAM,GAAI,IAC3B6C,EAAG1D,GAAI0I,OAG3CxB,GAAM2C,GAAInG,EAAGoG,GAAI9J,GAAI0J,GAAepB,KAK/C,QAAgByB,GAAYnC,EAAOoC,EAAUC,EAAUnK,MAClDoK,MAGA/G,EADY8G,EAASjI,IAAI,SAAChC,EAAGyB,SAAOuI,GAASvI,GAAK,IAAMzB,IACpCuH,KAAK,KAEvB4C,GAAYvC,EAAMJ,MAAOlJ,EAAE,IAAI6E,GAAUiH,GAAe9B,SAC/C+B,KAAKF,GAEjBvC,EAAMhB,OAAQ,IACZ0D,GAAgBN,EAAS,OAAMlK,MAC/ByK,MAAeP,EAASnJ,OAAO,GAAG,QAAOf,EAEvC0K,GACL5C,EAAMhB,QACLtI,EAAE,IAAMgM,EAAanH,EAAUoH,GAChCH,GACA9B,MAEc+B,KAAKG,SAGdN,GAGR,QAAgBO,GAAeC,EAASvH,UAC/BuH,GAAUpM,EAAG6E,GAAUuG,GAAepB,ICzF/C,QAASqC,GAAkBxO,EAASyO,EAAOC,MAAKC,0DAAW,SAAUhN,6DAAKuH,GAAW0F,4DAEhFC,EAAc7O,EAAQ8O,WAAU,GAChCC,EAAa/O,EAAQ8O,WAAU,OAE/B,GAAIE,KAAiBP,GAAO,IAC3BQ,YACiB,cAAlBD,EACenP,SAASwF,gBAAgB,6BAA8B,oBAEvDxF,SAASwF,gBAAgB,6BAA8B,cAErE6J,GAAeN,EAAUI,IAAkBhP,EAAQmN,aAAa6B,GAChEG,EAAQV,EAAMO,GAEdI,iBACYJ,OACTE,KACFC,QACG,SACFT,EAAI,IAAO,WACRQ,EAAe,IAAMC,aACjBE,GAAOV,YACT,eACA,cACJ,SAGJhN,OACF,KAAmBA,OAGf,GAAI2D,KAAK8J,KACEpJ,aAAaV,EAAG8J,EAAS9J,MAG7BE,YAAYyJ,GAErBtN,IACSqE,aAAagJ,eAA4BG,SAEzCnJ,aAAagJ,EAAeG,UAIjCN,EAAaE,GAGtB,QAAgB7C,GAAUlM,EAAS8F,KAC1BA,MAAMoG,UAAYpG,IAClBA,MAAMwJ,gBAAkBxJ,IACxBA,MAAMyJ,YAAczJ,IACpBA,MAAM0J,aAAe1J,IACrBA,MAAM2J,WAAa3J,EAG5B,QAAS4J,GAAW7I,EAAc8I,MAC7BC,MACAC,OAEKhK,IAAI,eACRgG,GAAO7L,EAAQ,GACfyG,EAASoF,EAAKnG,WAEdmJ,SAAaE,WAET,GAAKlD,QACe2C,kBAAqBxO,8BAErCkO,KAAKa,KACJb,MAAMW,EAAapI,MAEzBqJ,aAAajB,EAAahD,QAG9BkE,GAAUlJ,EAAaiI,WAAU,YAExBjJ,IAAI,SAACgJ,EAAavJ,KAClB,GAAGwK,aAAaF,EAAYtK,GAAIuJ,EAAY,MAC/CvJ,GAAG,GAAKsK,EAAYtK,KAGvByK,EAGR,QAAgBC,GAAiBvJ,EAAQwJ,EAAYC,MACpB,IAA7BA,EAAkBzN,WAEjB0N,GAAiBT,EAAWO,EAAYC,EACzCD,GAAWvK,YAAce,MACpB2J,YAAYH,KACZzK,YAAY2K,eAKT,WACPA,EAAezK,YAAce,MACxB2J,YAAYD,KACZ3K,YAAYyK,KAElBI,KC/GG,QAASC,GAAaC,EAAUnI,MAClCoI,GAAI3Q,SAAS4Q,cAAc,OAC7B3K,MAAQ,mBACN4K,GAAO,GAAIC,MAAKvI,GAAOzG,KAAM,iCAC7BiP,EAAMhQ,OAAOiQ,IAAIC,gBAAgBJ,KACnCK,KAAOH,IACPI,SAAWT,WACJjQ,KAAKkF,YAAYgL,KACxBS,mBACS,oBACD3Q,KAAK8P,YAAYI,UACnBK,IAAIK,gBAAgBN,IACzB,KAGJ,QAAgBO,GAAiBC,MAC5BC,GAAQD,EAAItC,WAAU,KACpBwC,UAAUC,IAAI,qBACdvL,aAAa,QAAS,gCACtBA,aAAa,cAAe,mCAC9BwL,GAAU9R,EAAE+R,OAAO,mBACTC,OAER/L,aAAa6L,EAASH,EAAMM,eAE9BC,GAAYlS,EAAE+R,OAAO,gBACfjM,YAAY6L,GAEfO,EAAUC,UCblB,QAASC,GAAWC,MACfC,GAAS,GAAIC,MAAKF,YACfG,WAAWF,EAAOG,aAAeH,EAAOI,qBACxCJ,EAGR,QAAgBK,GAAYN,MACvBO,GAAKP,EAAKQ,UACVC,EAAKT,EAAKU,WAAa,SAE1BV,EAAKW,eACJF,EAAG,EAAI,GAAK,KAAOA,GACnBF,EAAG,EAAI,GAAK,KAAOA,GACnBlH,KAAK,KAGR,QAAgBiG,IAAMU,SACd,IAAIE,MAAKF,EAAKY,WAiBtB,QAAgBC,IAAgBC,EAAWC,MACtCC,GAAgBC,GAAeH,SAC5BjQ,MAAKqQ,KAAKC,GAAeH,EAAeD,GAAWK,IAG3D,QAAgBD,IAAeL,EAAWC,MACrCM,GAAqBC,GAAaC,UAC9BxB,EAAWgB,GAAWhB,EAAWe,IAAcO,EAGxD,QAAgBG,IAAeV,EAAWC,SAClCD,GAAUJ,aAAeK,EAAQL,YACpCI,EAAUH,gBAAkBI,EAAQJ,cAGzC,QAAgBc,IAAalO,MAAGmO,2DAC3BC,EAAYC,GAAYrO,SACrBmO,GAAQC,EAAUhP,MAAM,EAAG,GAAKgP,EAGxC,QAAgBE,IAAoBC,EAAOC,SACnC,IAAI7B,MAAK6B,EAAMD,EAAQ,EAAG,GAIlC,QAAgBb,IAAejB,MAC1BgC,GAAU1C,GAAMU,GACdiC,EAAMD,EAAQE,eACT,KAARD,MACMD,GAAW,EAAKC,GAElBD,EAIR,QAAgBG,IAAQnC,EAAMoC,KACxBC,QAAQrC,EAAKQ,UAAY4B,GC0U/B,QAAgBE,IAAaC,EAAMC,EAAWC,MACzC5O,GAAO6O,OAAO7O,KAAK8O,IAAkBC,OAAO,kBAAKL,GAAKM,SAASC,KAC/DC,EAASJ,GAAiB9O,EAAK,kBAC5BmP,OAAOD,aACFP,UACFC,IAEH,GAAIQ,IAAeF,GCva3B,QAASG,IAAU1N,MAKX,IAAJA,SACM,EAAG,MAET2N,MAAM3N,UACA4N,UAAW,iBAAkBC,SAAU,QAE5CC,GAAM9N,EAAI,EAAI,GAAK,MACnB+N,SAAS/N,UACJ4N,SAAgB,iBAANE,EAAwBD,SAAU,OAGjDxS,KAAKC,IAAI0E,MACTgO,GAAM3S,KAAK4S,MAAM5S,KAAK6S,MAAMlO,WAGxB8N,GAFE9N,EAAE3E,KAAK8S,IAAI,GAAIH,IAENA,GAGpB,QAASI,IAAuBC,MAAKC,0DAAI,EACpCC,EAAalT,KAAKqQ,KAAK2C,GACvBG,EAAanT,KAAK4S,MAAMK,GACxBG,EAAQF,EAAaC,EAErBE,EAAYD,EACZE,EAAW,CAGZF,GAAQ,IACPA,EAAQ,GAAM,UAGKD,KAEVC,EAAM,IACP,GAITA,GAAS,MAEAA,KADC,IAKA,IAAVA,MACU,IACD,OAIR,GADAG,MACI7Q,EAAI,EAAGA,GAAK2Q,EAAW3Q,MACpB4I,KAAK6H,EAAaG,EAAW5Q,SAEjC6Q,GAGR,QAASC,IAAkBC,MAAUC,0DAAS,IACZrB,GAAUoB,aAAtCE,OAAgBnB,OACjBoB,EAAiBF,EAAWA,EAAS1T,KAAK8S,IAAI,GAAIN,GAAW,EAK7De,EAAYR,KAFCY,EAAenU,QAAQ,GAEeoU,YAC3CL,EAAUtQ,IAAI,kBAASsJ,GAAQvM,KAAK8S,IAAI,GAAIN,KAIzD,QAAgBqB,IAAmBC,WAYzBC,GAA0BN,EAAUO,OAOxC,GANAT,GAAYC,GAAkBC,GAE9BQ,EAAeV,EAAU,GAAKA,EAAU,GAGxChH,EAAQ,EACJ7J,EAAI,EAAG6J,EAAQyH,EAAatR,OAC1BuR,IACCC,SAAU,EAAK3H,SAEnBgH,MAvBkCY,2DAMtCV,EAAWzT,KAAKgT,kBAAOc,IACvBJ,EAAW1T,KAAKiT,kBAAOa,IAGTP,QAkBfE,GAAY,GAAKC,GAAY,EACpBrB,GAAUoB,GAAU,KAC3BU,EAGSX,GAAkBC,EAAUC,GAF5BF,GAAkBC,OAQ3B,IAAGA,EAAW,GAAKC,EAAW,EAAG,IAOjCM,GAAchU,KAAKC,IAAIyT,EAExBD,IAAYO,GACH3B,GAAUoB,GAAU,KACnBM,EAA0BN,EAAUO,KAGrC3B,GAAU2B,GAAa,KACfD,EAA0BC,EAAaP,GACjCxQ,IAAI,mBAAW,EAAN1D,SAO/B,IAAGkU,GAAY,GAAKC,GAAY,EAAG,IAInCU,GAAiBpU,KAAKC,IAAIyT,GAC1BW,EAAiBrU,KAAKC,IAAIwT,EAEnBpB,IAAU+B,GAAgB,QACjCD,EAGSX,GAAkBY,EAAgBC,GAFlCb,GAAkBY,IAKTE,UAAUrR,IAAI,mBAAW,EAAN1D,UAGnCgU,GAGR,QAAgBgB,IAAaC,MAExBC,GAAWC,GAAgBF,SAC5BA,GAAKG,QAAQ,IAAM,EAGTH,EAAKG,QAAQ,GAChBH,EAAK,GAAK,GAIL,EADJA,EAAK,GACUC,GAKX,EADJD,EAAKA,EAAK3U,OAAS,GACJ4U,GAAYD,EAAK3U,OAAS,GAiBrD,QAAgB6U,IAAgBE,SACxBA,GAAa,GAAKA,EAAa,GAGvC,QAAgBC,IAAcD,SACtBA,GAAaA,EAAa/U,OAAO,GAAK+U,EAAa,GAG3D,QAAgBE,IAAMnS,EAAKoS,SACnBzV,GAASyV,EAAMhU,SAAW4B,EAAMoS,EAAMC,iBAY9C,QAAgBC,IAAkBC,EAAMC,MAAKpN,2DACxCqN,EAAUD,EAAIE,OAAO,SAASC,EAAMC,SAC/BvV,MAAKC,IAAIsV,EAAOL,GAAQlV,KAAKC,IAAIqV,EAAOJ,GAAQK,EAAOD,UAGzDvN,GAAQoN,EAAIR,QAAQS,GAAWA,EAGvC,QAAgBI,IAAiB1B,EAAQ2B,OASpC,GALAC,GAAe1V,KAAKgT,kBAAOc,IAE3B6B,EAAmB,GAAKF,EAAmB,GAC3CG,KAEIlT,EAAI,EAAGA,EAAI+S,EAAkB/S,IAAK,IACrCmT,GAAaH,GAAgBC,EAAmBjT,KACvC4I,KAAKuK,SAGZD,GAGR,QAAgBE,IAAiBvJ,EAAOqJ,SAChCA,GAAa7D,OAAO,kBAAKxS,GAAIgN,IAAO1M,OC1OrC,QAASkW,IAASvQ,EAAMzG,KACzBiX,OAASxQ,EAAKwQ,cAEfC,GAAgBzQ,EAAKwQ,OAAOnW,OAG5BqW,EAAW1Q,EAAK0Q,SAChBC,EAAY,GAAIpW,OAAMkW,GAAe/V,KAAK,SAC1CgW,gBAGMC,OAIDlT,IAAI,eAER1D,EAAEuU,OAEC,IAEFsC,GAAO7W,EAAEuU,YACNsC,EAAKnT,IAAI,kBAASqP,OAAM3P,GAAa,EAANA,KAG9B9C,OAASoW,EACTG,EAAKtU,MAAM,EAAGmU,GAEdxW,EAAU2W,EAAMH,EAAgBG,EAAKvW,OAAQ,UAVnDiU,OAASqC,CAkBR5W,GAAE8W,YACDC,GAAyBtE,SAASjT,KACpCsX,UAAYtX,KASbyG,EAAK+Q,YACFA,SAAStT,IAAI,eACd1D,EAAEiX,IAAMjX,EAAEK,MAAO,QACCL,EAAEiX,IAAKjX,EAAEK,SAA1BA,aAAS4W,YAKRhR,EAGR,QAAgBiR,IAAaC,MACxBT,GAAgBS,EAASV,OAAOnW,OAChCsW,EAAY,GAAIpW,OAAMkW,GAAe/V,KAAK,GAE1CyW,UACKD,EAASV,OAAOlU,MAAM,GAAI,YACxB4U,EAASR,SAASjT,IAAI,wBAExB,UACEkT,EAAUrU,MAAM,GAAI,aACjBvC,EAAE8W,oBAKbK,GAASE,aACFA,iBAEA,QACA,MAKPF,EAASH,aACFA,iBAEA,MACF,QACE,MAKHI,EAGR,QAAgBE,IAAmBC,MAAYd,6DAAWe,6DAErDC,EADeF,EAAad,EAAOnW,OACHoX,SAEnBjB,GAAO/S,IAAI,SAAC2C,EAAOlD,aAC1B,IACA7C,OAASmX,IAEbD,EAQArU,EADY1C,KAAKqQ,KAAKzK,EAAM/F,OAAOmX,IAClB,MACX,MARNA,EAAe,EAAI,EACbpR,EAAM9D,MAAM,EAAGkV,EAAe,GAAK,OAEnCpR,EAAM9D,MAAM,EAAGkV,GAAkB,MASrCpR,ICtGT,QAASsR,SAAeb,0DAAY,OAAQxS,eAAQuC,qBACjC,eAAdiQ,KACKtX,KAAO,OACR,GAAIoY,IAAUtT,EAAQuC,IAGzBgR,GAAWf,GAKT,GAAIe,IAAWf,GAAWxS,EAAQuC,gBAJhCiR,MAAM,yBAA2BhB,ssJZV3CvZ,GAAE+R,OAAS,SAACtM,EAAKC,MACZpF,GAAUH,SAAS4Q,cAActL,OAEhC,GAAIG,KAAKF,GAAG,IACZG,GAAMH,EAAEE,MAEF,WAANA,IACDC,GAAKC,YAAYxF,OAEf,IAAU,WAANsF,EAAgB,IACpBG,GAAM/F,EAAE6F,KACRG,WAAWC,aAAa3F,EAASyF,KAC7BD,YAAYC,OAEJ,WAANH,EACQ,qBAARC,iBAAAA,YACFK,KAAKL,GAAKM,IAAI,cACZC,MAAMC,GAAQR,EAAIQ,KAGlBT,IAAKtF,KACPsF,GAAKC,IAGLS,aAAaV,EAAGC,SAInBvF,Ga1CD,IAAMka,KAAmB,OAAQ,UAAW,MAAO,aAAc,UAAW,OAEtEC,SACN,OAAQ,UAAW,aAAc,aAChC,UAAW,MAAO,aAAc,YACjC,OAAQ,UAAW,aAAc,mBAC1B,MAAO,OAAQ,UAAW,mBAI3BC,QACP,gBACC,eACD,oBACO,iBACHC,IAUGC,GAA4B,IAI5BpB,IAA4B,OAAQ,OAUpCqB,GAAgC,GAChCtS,GAA+B,EAI/BoS,GAA4B,EAQ5BR,GAAqB,EAI5BW,IAAwB,aAAc,OAAQ,SAAU,MAAO,SACpE,SAAU,QAAS,cAAe,SAAU,UAAW,aAAc,aAKzDC,QACPD,QACCA,OACDA,cACOA,YARiB,UAAW,UAAW,UAAW,UAAW,YAa7DjX,GAAcX,KAAK8X,GAAK,ICpEhBC,oCAEnBlU,OAAAA,aAAS,WACTmU,OAAAA,kCAEKnU,OAASA,OACTmU,OAASA,OACTC,UAAY,QACZC,WAAa,QACbC,mBACAC,gBAAkB,OAElBzT,EAAI,OACJ1D,EAAI,OAEJ1D,IAAM,OACNI,KAAO,OAEP0a,wDAIAC,qDAIApY,YACAqY,qEAIAvJ,UAAYlS,EAAE+R,OAAO,cACjB2J,KAAK3U,iBACF,8JAKP4U,eAEAC,MAAQF,KAAKxJ,UAAU9R,cAAc,eACrCyb,cAAgBH,KAAKxJ,UAAU9R,cAAc,yBAE7C2G,OAAO+U,iBAAiB,aAAc,aACrCH,sDAKFC,QACDF,MAAKzQ,YACFiH,UAAU5L,aAAa,mBAAoBoV,KAAKzQ,SAEnDyQ,KAAKJ,2BACYI,KAAKN,uBAAsBM,KAAKP,UAExCO,KAAKP,qBAAoBO,KAAKN,4BAErCQ,MAAMzJ,UAAYyJ,OAClBC,cAAc1J,UAAY,QAE1BkJ,WAAWlV,IAAI,SAAC4V,EAAKnW,MACnBjB,GAAQqX,EAAKd,OAAOtV,IAAM,QAE5BqW,EAAKjc,EAAE+R,OAAO,wCAEWpN,iDAEiC,IAAdoX,EAAItM,OAAesM,EAAItM,MAAQsM,EAAItM,MAAQ,6BACvFsM,EAAIH,MAAQG,EAAIH,MAAQ,QAGvBC,cAAc/V,YAAYmW,+CAK5BhV,GAAQyU,KAAKxJ,UAAUgK,iBAEtBzb,IAAMib,KAAKvX,EAAIuX,KAAKxJ,UAAUiK,aD5BU,OC8BxCtb,KAAO6a,KAAK7T,EAAIZ,EAAM,KACvBmV,GAAUV,KAAK3U,OAAOmV,YAAcjV,EAEpCoV,EAAUX,KAAKxJ,UAAU9R,cAAc,mBAExCsb,KAAK7a,KAAO,IACNuF,MAAMvF,oBAAsB,EAAI6a,KAAK7a,gBACxCA,KAAO,MACN,IAAG6a,KAAK7a,KAAOub,EAAS,IAE1BE,kBADQZ,KAAK7a,KAAOub,WAEhBhW,MAAMvF,KAAOyb,OAEhBzb,KAAOub,SAEJhW,MAAMvF,6CAINgH,EAAG1D,MAAGyX,6DAAYP,4DAAiBpQ,0DAAS,OAChDkQ,UAAYS,EAAMhH,UAClBwG,WAAaQ,EAAMnM,WACnB4L,WAAaA,OACbxT,EAAIA,OACJ1D,EAAIA,OACJmX,gBAAkBM,EAAMW,YAAc,OACtCtR,MAAQA,OACRuR,iDAIAtK,UAAU9L,MAAM3F,IAAM,WACtByR,UAAU9L,MAAMvF,KAAO,WACvBqR,UAAU9L,MAAMS,QAAU,2CAI1BqL,UAAU9L,MAAM3F,IAAMib,KAAKjb,IAAM,UACjCyR,UAAU9L,MAAMvF,KAAO6a,KAAK7a,KAAO,UACnCqR,UAAU9L,MAAMS,QAAU,aX3H3B4V,iBACS,eACN,iBACE,cACH,iBACG,iBACA,gBACD,wBACM,iBACL,kBACC,gBACF,eACD,uBACM,sBACD,WA4BD3X,GAAW,SAACH,SACjB8X,IAAiB9X,IAAUA,GCtCtB+F,GAAmB,EAC1BT,GAAe,EACRjB,GAAY,GACnBe,GAAkB,UAClBd,GAAY,UA6hBPyT,QACH,SAACvQ,MACHwQ,SACiB,UAAlBxQ,EAAKyB,aACUzB,EAAKsB,aAAa,eAC5BtB,EAAKoB,WAAW,OAEpBqP,GAAUzQ,EAAKiD,qBACXhJ,MAAMhD,KAAO,YACbgD,MAAMS,QAAU,MAErB8V,KACMrW,aAAa,YAAaqW,GAE5BC,OAGD,SAACzQ,MACHwQ,SACiB,YAAlBxQ,EAAKyB,aACUzB,EAAKsB,aAAa,eAC5BtB,EAAKoB,WAAW,OAEpBqP,GAAUzQ,EAAKiD,YACfzL,EAASwI,EAAKsB,aAAa,KAC3BrK,EAAO+I,EAAKsB,aAAa,iBACrBnH,aAAa,IAAKpB,SAASvB,GS3hBA,KT4hB3B2C,aAAa,OAAQlD,KACrBgD,MAAMS,QAAU,MAErB8V,KACMrW,aAAa,YAAaqW,GAE5BC,eAGO,SAACzQ,MACXwQ,SACiB,YAAlBxQ,EAAKyB,aACUzB,EAAKsB,aAAa,eAC5BtB,EAAKoB,WAAW,OAEpBqP,GAAUzQ,EAAKiD,YACfzL,EAASwI,EAAKsB,aAAa,KAC3BrK,EAAO+I,EAAKsB,aAAa,iBACrBnH,aAAa,IAAKpB,SAASvB,GS9iBA,KT+iB3B2C,aAAa,OAAQlD,KACrBgD,MAAMS,QAAU,MAErB8V,KACMrW,aAAa,YAAaqW,GAE5BC,IAIEC,QACH,SAAC1Q,EAAMyQ,MACTD,SACiB,UAAlBxQ,EAAKyB,aACUzB,EAAKsB,aAAa,eAC5BtB,EAAKoB,WAAW,OAEpBuP,IAAc,IAAK,IAAK,QAAS,iBAC9B9F,OAAO7K,EAAK2Q,YACjB7H,OAAO,kBAAQ6H,GAAW5H,SAAS6H,EAAKnI,OAASmI,EAAKC,YACtD7W,IAAI,cACIG,aAAayW,EAAKnI,KAAMmI,EAAKE,aAGpCN,KACMrW,aAAa,YAAaqW,QAI7B,SAACxQ,EAAMyQ,MACTD,SACiB,YAAlBxQ,EAAKyB,aACUzB,EAAKsB,aAAa,eAC5BtB,EAAKoB,WAAW,OAEpBuP,IAAc,KAAM,aACjB9F,OAAO7K,EAAK2Q,YACjB7H,OAAO,kBAAQ6H,GAAW5H,SAAS6H,EAAKnI,OAASmI,EAAKC,YACtD7W,IAAI,cACIG,aAAayW,EAAKnI,KAAMmI,EAAKE,aAGpCN,KACMrW,aAAa,YAAaqW,gBAIrB,SAACxQ,EAAMyQ,MACjBD,SACiB,YAAlBxQ,EAAKyB,aACUzB,EAAKsB,aAAa,eAC5BtB,EAAKoB,WAAW,OAEpBuP,IAAc,KAAM,aACjB9F,OAAO7K,EAAK2Q,YACjB7H,OAAO,kBAAQ6H,GAAW5H,SAAS6H,EAAKnI,OAASmI,EAAKC,YACtD7W,IAAI,cACIG,aAAayW,EAAKnI,KAAMmI,EAAKE,aAGpCN,KACMrW,aAAa,YAAaqW,KC/oBxB9O,GAAgB,IAChBU,GAAgB,IAChB1B,GAAuBgB,GACvB8C,GAAsB,IAEtBlE,GAAa,SCHpBkD,SACC,yBACE,iBAEA,wBACC,uBACE,iBSVCqC,GAAU,uoDCWFkL,yBACRnW,EAAQuC,sBAEdvC,OAA2B,gBAAXA,GAClB5G,SAASC,cAAc2G,GACvBA,IAEG2U,KAAK3U,iBAAkBoW,mBACtB,IAAIC,OAAM,uDAGZC,aAAe/T,OAEfsS,MAAQtS,EAAQsS,OAAS,QACzB0B,UAAYhU,EAAQpF,QAAU,SAC9BjC,KAAOqH,EAAQrH,MAAQ,QAEvB2X,SAAW8B,KAAK6B,YAAYjU,EAAQZ,WACpCA,KAAOgT,KAAK8B,iBAAiB9B,KAAK9B,eAElCsB,OAASQ,KAAK+B,eAAenU,EAAQ4R,OAAQQ,KAAKzZ,WAElDmT,oBACS,aACD9L,EAAQoU,YAAc,cACrBpU,EAAQqU,aAAe,UAC3B,QAELC,cACAtU,gBAEAuU,YAAcjD,GAEhBc,KAAKtG,OAAOuI,mBACTG,kBAGDC,UAAUzU,kEAIV0U,oBAGElC,iBAAiB,SAAU,iBAAMmC,GAAKC,qBACtCpC,iBAAiB,oBAAqB,iBAAMmC,GAAKC,qDAG1ChD,EAAQjZ,MAChBkc,gBACIjD,OAAc7X,OAAO0X,GAAe9Y,KACvCmc,QAAQ,SAAC7a,MACToB,GAAQG,GAASvB,EACnB+B,GAAaX,KAGJ6J,KAAK7J,WAFT0Z,KAAK,IAAM9a,EAAS,6BAKvB4a,0CAIHja,GAASwX,KAAK4B,eACbgB,WAAapa,OACbA,OAASA,EAAS,QAClBqa,UH3D8B,QG8D9BC,WH7D+B,QG8D/BC,YH7DgC,wCGiEhCC,qBACAC,mBACAnD,mBAEAoD,MAAK,GAAO,kDAIZC,WAAa,GAAIC,kDAKjB/X,OAAOoL,UAAY,MAEpBxJ,WACK+S,KAAK3U,iBACF,kBAGT2U,MAAKqD,qBACFtd,QAAWwF,MAAOyU,KAAKqD,iBAAmB,YAG3C7M,UAAYlS,EAAE+R,OAAO,MAAOpJ,8CAI5BqW,IAAM,GAAI/D,YACNS,KAAKxJ,iBACLwJ,KAAKR,cAET+D,+FAKDC,0DAAuBC,+DACtBC,KAAKF,QACLP,mBACAU,qBACAC,uBAEAT,WAAWT,QAAQ,kBAAKmB,GAAEhE,MAAMS,EAAKwD,iBAErCC,OAAO/D,KAAKmD,YAAY,GAE1BM,SACGzW,KAAOgT,KAAK9B,oBACN,aAAY8F,OAAO1D,EAAKtT,OAASgT,KAAKmC,mBAG7C8B,oBAEAC,gBAAgBT,8CAIhBU,UAAYre,EAAuBka,KAAK3U,aACxCE,MAAQyU,KAAKmE,WAAanE,KAAK8C,WAAa9C,KAAK+C,4CAGhD/V,GACFA,WACK6R,MAAM,2BAEV7R,KAAOgT,KAAK6B,YAAY7U,QACxB0W,YACAK,6GAGW/D,KAAKhT,8GAIAgT,KAAKhT,iFAMpBmW,yDAAWnD,KAAKmD,WAAYiB,4DAC/BpE,MAAKtG,OAAOuI,kBAETG,SAAS3X,IAAI,kBAAKT,GAAEM,WAAW0K,YAAYhL,QAG7C8K,QAEO4N,QAAQ,cACE5N,EAAkBnN,OAAOkc,EAAEG,OAAOI,MAEpDtP,EAAkBzN,OAAS,KACZ2Y,KAAKxJ,UAAWwJ,KAAKhK,IAAKlB,cAChC,aACC4N,QAAQ,kBAAKmB,GAAEQ,WACrBC,aH3JiC,SG8J5B5B,QAAQ,kBAAKmB,GAAEQ,cACrBC,iDAKHtE,KAAKtG,OAAOuI,mBACTjB,mBACAuD,qDAKHvE,KAAKhK,UACFQ,UAAUxB,YAAYgL,KAAKhK,QAG7BwO,GAAkB,EAClBC,EAAmB,CACpBzE,MAAKE,MAAM7Y,WACK,IAEhB2Y,KAAKtG,OAAOsI,eACK,SAGfhM,IAAM5K,EACV4U,KAAKxJ,UACL,qBACAwJ,KAAKmE,UACLnE,KAAK4C,WAAa4B,EAAkBC,QAEhCrU,QAAU5E,EAAYwU,KAAKhK,KAI7BgK,KAAKE,MAAM7Y,cACRqd,QAAUhX,EACd,QACAsS,KAAK8C,WAAgC,EAAnB9T,GAClBgR,KAAK6C,UACL7C,KAAKE,gBAEM,QACJ,iBAGHlK,IAAI5L,YAAY4V,KAAK0E,aAGvB3f,GAAMib,KAAK6C,UAAY2B,OACtBV,SAAWpY,EACfsU,KAAKhK,IACLgK,KAAKzZ,KAAO,sBACCyZ,KAAK8C,gBAAe/d,SAG5Bib,KAAK4C,WAAa4B,OACnBG,WAAajZ,EACjBsU,KAAKhK,IACL,4BACagK,KAAK8C,gBAAe/d,YAG7B6f,gBAAgB5E,KAAK8C,WAAY9C,KAAK6C,UAAY2B,2CAGxCrY,EAAG1D,QACb6a,IAAIpY,UACLiB,IACA1D,gGAMWgb,yDACXzD,MAAKtG,OAAOuI,aAEbwB,SACGoB,mBAEAC,eACE9E,KAAK+E,WAAWC,KAAKhF,SACrBA,KAAKiF,YAAYD,KAAKhF,SACtBA,KAAKkF,UAAUF,KAAKhF,SACpBA,KAAKmF,aAAaH,KAAKhF,SACvBA,KAAKoF,YAAYJ,KAAKhF,gBAGpBI,iBAAiB,UAAW,SAACiF,GAClChgB,EAAoBigB,EAAK9O,eACvB6O,GAAK7f,OAAO+f,MACbD,EAAKR,WAAWO,EAAEG,YACfV,WAAWO,EAAEG,ymBA0BLjf,MACXkf,GAAczF,KAAKzZ,KACrB0G,EAAO+S,KAAK2B,gBACbpb,IAASkf,GAER3G,GAAgBtF,SAASjT,YACpBsY,UAAUtY,kCAGfwY,GAAkB0G,GAAajM,SAASjT,YACnCsY,UAAU4G,uCAAgDlf,iBAI7Dmf,GAAW1G,GAAqByG,KAAiBzG,GAAqBzY,YAMvEA,KAAOA,IACPiZ,OAASkG,EAAWzY,EAAKuS,WAAS1R,GAEhC,GAAI6X,IAAM3F,KAAK3U,OAAQ4B,+CAIzBiW,MAAK,kEAIH0C,oBAAoB,SAAU,iBAAMC,GAAKrD,qBACzCoD,oBAAoB,oBAAqB,iBAAMC,GAAKrD,kDAIvDsD,GAAW/P,EAAiBiK,KAAKhK,OACxBgK,KAAKE,OAAS,SAAU4F,aClVlBC,0BACR1a,EAAQ4B,+EACb5B,EAAQ4B,yDAGLA,4FACOA,QAEXyM,OAAOsM,UAAY/Y,EAAK+Y,WAAa,QACrCtM,OAAOuM,gBAAkBhZ,EAAKgZ,iBAAmB,6CAIlDC,EAAIlG,KAAKkC,MACT8D,EAAYhG,KAAKtG,OAAOsM,YAC1BG,kBAEEC,GAAYpG,KAAKhT,KAAKwQ,OAAO/S,IAAI,SAAC2C,EAAOlD,MACxCmc,GAAQ,WACPrZ,KAAK0Q,SAASjT,IAAI,eACb4a,EAAE/J,OAAOpR,MAEXmc,EAAOjZ,KACbmM,OAAO,kBAAcxS,GAAE,GAAK,IAE3Buf,EAASF,KACVA,EAAU/e,OAAS2e,EAAW,GAEtBO,KAAK,SAACnR,EAAG3L,SAAeA,GAAE,GAAK2L,EAAE,OAElCgR,EAAU9c,MAAM,EAAG0c,EAAU,MAGlCQ,GAAiB,CAFLJ,GAAU9c,MAAM0c,EAAU,GAGhCvb,IAAI,eAAwB1D,EAAE,OACjC+L,MAAM0T,EAAgB,cACxBhH,OAAOwG,EAAU,GAAK,SAG1BxI,YACK/S,IAAI,cACR0b,YAAYrT,KAAK/L,EAAE,MACnByW,OAAO1K,KAAK/L,EAAE,QAGf0f,WAAaP,EAAEC,YAAYtJ,OAAO,SAACzH,EAAG3L,SAAM2L,GAAI3L,GAAG,QAEhDuC,UACDgU,KAAKzU,MAAQ,IACbyU,KAAKxX,OAAS,qDAKd0d,EAAIlG,KAAKkC,WACRyC,WAAW+B,YAAc,QAEzBC,aAAeT,EAAEC,YAAY7c,MAAM,EAAG0W,KAAKtG,OAAOuM,sBAElDU,aAAalc,IAAI,SAAC1D,EAAGmD,MAErBrF,GAAO4I,EADI,IAEHvD,EAAI,EACf,IACA,EACA0c,EAAKpH,OAAOtV,GACTgc,EAAE1I,OAAOtT,QAAOnD,KAEf4d,WAAWva,YAAYvF,YApEe2c,ITAjCzJ,GAAqB,EAErBG,GAAe,IACfD,GAAa,MAEbM,IAAe,UAAW,WAAY,QAAS,QAAS,MACpE,OAAQ,OAAQ,SAAU,YAAa,UAAW,WAAY,YAIlDsO,IAAmB,MAAO,MAAO,MAAO,MAAO,MAAO,MAAO,OCNpEjN,oCAEJkN,WAAAA,aAAa,SACbC,eAAAA,aAAiB,KACjB5N,IAAAA,UAEAC,IAAAA,QACA4N,IAAAA,aACAC,IAAAA,gCAEKF,eAAiBA,OACjB5N,UAAYA,OAEZ6N,aAAeA,OACf5N,QAAUA,OAEV6N,gBAAkBA,OAElBC,cACA1J,eAEAsJ,WAAaA,OACbA,WAAyC,kBAArB9G,MAAK8G,WAC3B9G,KAAK8G,aAAe9G,KAAK8G,gBAEvBhG,qDAGE9T,QACFA,KAAOA,GAAQgT,KAAK5G,wCAGpB/N,QACA8b,MAAQzb,EAAaL,EAAQ2U,KAAK8G,WAAY9G,KAAK+G,oDAInDhD,OAAO/D,KAAKhT,WACZoa,QAAUpH,KAAKhT,oCAGdA,mBACDka,MAAQlH,KAAKgH,aAAaha,QAE1Bma,MAAMT,YAAc,QACpBQ,MAAMxE,QAAQ,cACbyE,MAAM/c,YAAYxF,UAEnB4Y,OAAOkF,QAAQ,cACdyE,MAAM/c,YAAYxF,yCAIlBwf,mEACDtD,aACDmG,YACD7C,OACgBpE,KAAKiH,gBAAgBjH,KAAKhT,WAEtCia,WAIL3N,0BAEU,mCACCtM,SACLA,GAAKqa,aAAa5c,IAAI,SAACyb,EAAGhc,MAC5BZ,GAAQqC,EAASua,EAAG,WAAY,OAAQlZ,EAAKwS,OAAOtV,aAClDQ,MAAM4c,WAAa,iBAClBhe,8BAIOie,SACRvH,MAAKkH,MAAMzc,IAAI,SAACnB,EAAOY,SAC7BgJ,GAAe5J,EAAOie,EAAQF,aAAand,mCAKjC,wCACC8C,oBACLA,GAAKwa,WAAW/c,IAAI,SAAC0B,EAAGjC,SAEpByC,GAAcR,EADhB,EACsBa,EAAKya,OAAOvd,GACzCoW,EAAKnH,UAAUuO,UAAWpH,EAAKnH,UAAUwO,SAAU3a,EAAKwS,OAAOtV,gCAKlDqd,MACZA,EAAS,6BAID,+BACCva,oBACLA,GAAK4a,UAAUnd,IAAI,SAACod,EAAU3d,SACpC2E,GAAMgZ,EAAU7a,EAAKwQ,OAAOtT,GAAI0c,EAAKzN,UAAU5N,OAC7CwD,KAAM6X,EAAKzN,UAAUpK,KAAMD,IAAK8X,EAAKzN,UAAUrK,kCAInCyY,MACXO,GAASP,EAAQK,UACjBG,EAAYR,EAAQ/J,OACpBwK,EAAShI,KAAKoH,QAAQQ,UACtBK,EAAYjI,KAAKoH,QAAQ5J,SAEV9U,EAAqBsf,EAAQF,iCACvBpf,EAAqBuf,EAAWF,uCAEpDhE,kBACOiE,SACHD,IAGF/H,KAAKkH,MAAMzc,IAAI,SAAC+D,EAAMtE,SACrBkH,GACN5C,EAAMsZ,EAAO5d,GAAI8d,EAAO9d,0BAOf,+BACC8C,oBACLA,GAAK4a,UAAUnd,IAAI,SAACod,EAAU3d,SACpC+E,GAAM4Y,EAAU7a,EAAKkb,WAAWhe,GAAIob,EAAKnM,UAAU3Q,QACjDuG,KAAMuW,EAAKnM,UAAUpK,KAAMD,IAAKwW,EAAKnM,UAAUrK,kCAInCyY,MACXO,GAASP,EAAQK,UACjBG,EAAYR,EAAQW,WACpBF,EAAShI,KAAKoH,QAAQQ,UACtBK,EAAYjI,KAAKoH,QAAQc,aAEVxf,EAAqBsf,EAAQF,iCACvBpf,EAAqBuf,EAAWF,uCAEpDhE,kBACOiE,aACCD,IAGN/H,KAAKkH,MAAMzc,IAAI,SAAC+D,EAAMtE,SACrB8G,GACNxC,EAAMsZ,EAAO5d,GAAI8d,EAAO9d,6BAOf,kCACC8C,oBACLA,GAAKvC,IAAI,kBACfyE,GAAQiZ,EAAON,SAAUM,EAAO/a,MAAOyY,EAAK1M,UAAU5N,OACpDuD,IAAI,QAASC,KAAM,OAAQH,SAAU,uCAGzB2Y,SACW7e,EAAqBsX,KAAKoH,QAASG,kBAAvDH,gBAEFU,YAAiBrd,IAAI,kBAAK1D,GAAE8gB,WAC5BE,EAAYR,EAAQ9c,IAAI,kBAAK1D,GAAEqG,QAE/B4a,EAAShI,KAAKoH,QAAQ3c,IAAI,kBAAK1D,GAAE8gB,uBAEhC9D,OAAOiE,EAAOvd,IAAI,SAACqE,EAAK5E,mBAEjB8d,EAAO9d,SACV6d,EAAU7d,OAIZ8V,KAAKkH,MAAMzc,IAAI,SAAC+D,EAAMtE,SACrBkH,GACN5C,EAAMsZ,EAAO5d,GAAI8d,EAAO9d,6BAOf,kCACC8C,oBACLA,GAAKvC,IAAI,kBACf2E,GAAQC,EAAO+Y,SAAU/Y,EAAOgZ,OAAQC,EAAKnP,UAAU5N,MACtD8D,EAAOjC,mCAGMma,SACW7e,EAAqBsX,KAAKoH,QAASG,kBAAvDH,gBAEFU,YAAiBrd,IAAI,kBAAK1D,GAAEshB,SAC5BN,EAAYR,EAAQ9c,IAAI,kBAAK1D,GAAEqG,QAC/Bmb,EAAYhB,EAAQ9c,IAAI,kBAAK1D,GAAEqhB,WAE/BJ,EAAShI,KAAKoH,QAAQ3c,IAAI,kBAAK1D,GAAEshB,SACjCG,EAAYxI,KAAKoH,QAAQ3c,IAAI,kBAAK1D,GAAEqhB,gBAEnCrE,OAAOiE,EAAOvd,IAAI,SAACqE,EAAK5E,mBAEjBse,EAAUte,UACZ8d,EAAO9d,SACR6d,EAAU7d,UAIf+c,kBAECC,MAAMzc,IAAI,SAAC+G,EAAWtH,KACR+c,EAAgBtf,OAAO4J,EACxCC,EAAW+W,EAAUre,GAAI4d,EAAO5d,GAAI8d,EAAO9d,OAItC+c,2BAKI,iBAAoB,sBAAwBjH,KAAK7G,UAAU5J,6BAC1DvC,gBAC+CgT,KAAK7G,UAA3D5J,IAAAA,MAAOkZ,IAAAA,SAAUC,IAAAA,UAAWC,IAAAA,WAE7Bxc,IAFyCyc,WAEzBngB,EAAI,cAEnBogB,0BAEAC,KAAKre,IAAI,SAACse,EAAMC,GACN,IAAXA,KACGxL,OAAO1K,KACXpF,EAAS,cAAevB,GARL,GAQyBiM,GAAa7I,GAAO,aAEpD,QAKT9E,IAAI,SAACmO,EAAK1O,MACX0O,EAAIlR,KAAM,IACRsF,gBACU4L,EAAIqQ,sBACHrQ,EAAIsQ,qBACNhf,GAETif,EAASrc,EAAW,MAAOX,EAAG1D,EAAGkgB,EAAY/P,EAAIlR,KAAMsF,KACtD6b,qBAAqB/V,KAAKqW,MAE3BT,MAEF,KACCD,IAGCzI,KAAK6I,+CAGGtB,MACZA,EAAS,gCAKD,iBAAoB,sCAAwCvH,KAAK7G,UAAU5J,6BAC1EvC,MACR6W,GAAI7D,KAAK7G,sBACRiQ,SAAW,WACXC,MAAQrc,EAAKsc,WAAW7e,IAAI,SAAChC,EAAG7B,SAC7B0I,GACNtC,EAAKwa,WAAW5gB,GAChB6B,EACAuE,EAAKuc,SACL1F,EAAE5a,MACF+D,EAAKwQ,OAAO5W,GACZA,EACAoG,EAAKwc,QAAQ5iB,aAEFoG,EAAKzE,mBACJyE,EAAKyc,oBACL5F,EAAEpU,cAITuQ,KAAKqJ,gCAEG9B,MACXmC,GAAUnC,EAAQC,WAClBmC,EAAUpC,EAAQ+B,WAClBM,EAAarC,EAAQiC,QACrBzB,EAAYR,EAAQ/J,OAEpBqM,EAAU7J,KAAKoH,QAAQI,WACvBsC,EAAU9J,KAAKoH,QAAQkC,WACvBS,EAAa/J,KAAKoH,QAAQoC,QAC1BvB,EAAYjI,KAAKoH,QAAQ5J,SAER9U,EAAqBmhB,EAASH,iCAC9BhhB,EAAqBohB,EAASH,iCACxBjhB,EAAqBqhB,EAAYH,iCACnClhB,EAAqBuf,EAAWF,gCAEpDhE,mBACQ8F,aACAC,UACHC,SACDhC,WAEE/H,KAAKoH,QAAQ7e,mBACZyX,KAAKoH,QAAQqC,mBACdzJ,KAAKoH,QAAQmC,cAGpBtC,kBAECC,MAAMzc,IAAI,SAACwH,EAAK/H,KACF+c,EAAgBtf,OAAOqK,EACxCC,EAAKyX,EAAQxf,GAAIyf,EAAQzf,GAAIqd,EAAQgC,SAAUK,EAAW1f,IACzD3B,SAAUgf,EAAQhf,cAId0e,0BAKI,iBAAoB,sCAAwCjH,KAAK7G,UAAU5J,6BAC1EvC,MACR6W,GAAI7D,KAAK7G,sBACRiQ,SAAW,WACX/Y,SACDwT,EAAEmG,gBACA3Z,MAAQT,EACZ5C,EAAKwa,WACLxa,EAAKsc,WACLzF,EAAE5a,gBAES4a,EAAE3T,oBACA2T,EAAEvT,qBAGLuT,EAAEzT,iBACDpD,EAAKzE,iBAKb8gB,SACDxF,EAAEoG,gBACAZ,MAAQrc,EAAKsc,WAAW7e,IAAI,SAAChC,EAAG7B,SAC7B8I,GACN1C,EAAKwa,WAAW5gB,GAChB6B,EACAuE,EAAK/E,OACL4b,EAAE5a,MACD4a,EAAEqG,iBAAmBld,EAAKsO,OAAO1U,GAAK,GACvCA,MAKIyS,OAAOiC,OAAO0E,KAAK3P,OAAO1I,OAAOqY,KAAKqJ,iCAE9B9B,MACXmC,GAAUnC,EAAQC,WAClBmC,EAAUpC,EAAQ+B,WAClBa,EAAY5C,EAAQjM,OAEpBuO,EAAU7J,KAAKoH,QAAQI,WACvBsC,EAAU9J,KAAKoH,QAAQkC,WACvB9V,EAAYwM,KAAKoH,QAAQ9L,SAER5S,EAAqBmhB,EAASH,iCAC9BhhB,EAAqBohB,EAASH,iCAC1BjhB,EAAqB8K,EAAW2W,gCAEpDpG,mBACQ8F,aACAC,SACJK,WAEEnK,KAAKoH,QAAQ7e,gBACfyX,KAAKoH,QAAQnf,YAGlBgf,YAED5N,QAAO7O,KAAKwV,KAAK3P,OAAOhJ,WACR4f,EAAgBtf,OAAO6K,EACxCwN,KAAK3P,MAAOqZ,EAASC,EAASpC,EAAQhf,YAGrCyX,KAAKqJ,MAAMhiB,aACRgiB,MAAM5e,IAAI,SAACkF,EAAKzF,KACF+c,EAAgBtf,OAAO0K,EACxC1C,EAAK+Z,EAAQxf,GAAIyf,EAAQzf,OAIrB+c,KSxZWmD,0BACR/e,EAAQ4B,8EACb5B,EAAQ4B,aACT1G,KAAO,eAEP8jB,WAAapd,EAAKod,iBAClBA,WAAW7hB,OAAS+Z,EAAK8H,WAAW7hB,QACrC2W,KACCkL,WAAWzd,MAAQ2V,EAAK8H,WAAWzd,OACpCC,KAECgT,0EAIDqG,GAAIlG,KAAKkC,MAET5I,IAEF,4BAEY0G,KAAKqK,WAAW7hB,gBACjBwX,KAAKqK,WAAWzd,OAE3B,6BAEcsZ,EAAEsB,kBACNtB,EAAEuB,cACFzH,KAAKR,SAEbwF,KAAKhF,aAIJmD,WAAa,GAAIC,KAAI9J,EACxB7O,IAAI,eACA6f,GAAYrR,mBAAgBhM,WACxBA,EAAK,GAAIqd,wIAMfpE,GAAIlG,KAAKkC,QAEXsF,gBACAC,aAEE8C,GAAO,IACTpE,YAAY1b,IAAI,SAACsJ,MACdxI,GAAQ+U,EAAK/U,MAAQwI,EAAQmS,EAAEO,aACjCgB,OAAO3U,KAAKvH,KACZic,WAAW1U,KAAKyX,MACVhf,gGAOL2a,EAAIlG,KAAKkC,WACR1L,UAAU4J,iBAAiB,YAAa,SAACiF,MACzCmF,GAAO5D,EAAKzD,WAAWsH,IAAI,kBAAkBvD,MAC7CjV,EAAMoT,EAAE/e,UACTkkB,EAAKhR,SAASvH,GAAM,IAElB/H,GAAIsgB,EAAKrO,QAAQlK,GACjByY,EAAO/lB,EAAUiiB,EAAKpQ,WAAYmU,EAAOhmB,EAAUsN,GAEnD9F,EAAIwe,EAAKxlB,KAAOulB,EAAKvlB,KAAOqE,SAASyI,EAAIF,aAAa,UAAU,EAChEtJ,EAAIkiB,EAAK5lB,IAAM2lB,EAAK3lB,IACpBmb,GAAS0G,EAAKgE,iBAAmBhE,EAAKgE,gBAAgBvjB,OAAO,EAC9Duf,EAAKgE,gBAAgB1gB,GAAK0c,EAAK1E,MAAM1E,OAAOtT,IAAM,KACjD2gB,EAAW3E,EAAEC,YAAYjc,GAAGgc,EAAEO,aAE7BnD,IAAIwH,UAAU3e,EAAG1D,GAAIyQ,KAAMgH,EAAOnM,OAAiB,IAAT8W,GAAc7jB,QAAQ,GAAK,QACrEsc,IAAIyH,oBA5EgChF,ICIxBiF,0BACR3f,EAAQ4B,8EACb5B,EAAQ4B,aACT1G,KAAO,QACP4b,YAAc,IACdsB,KAAO,IAEP5D,+DAGI5S,4FACOA,QACXge,UAAYjL,KAAKiL,UAAUjG,KAAKhF,WAChCkL,WAAalL,KAAKkL,WAAWlG,KAAKhF,WAElCmL,WAAale,EAAKke,YAAc,QAChCzR,OAAO0R,WAAane,EAAKme,YAAc,OAEvCnf,UAAYgB,EAAKhB,YAAa,oIAK/Bia,GAAIlG,KAAKkC,WACRja,OAAU+X,KAAKxX,OAASwX,KAAKzU,MAAQyU,KAAKhU,OAAOG,EAAI6T,KAAKhU,OAAOvD,KAE9DR,GAAsB+X,KAAtB/X,OAAQgE,EAAc+T,KAAd/T,UAEVof,EAAuBnF,EAAEoF,uBAC7BjE,kBACAiE,uBACEC,GAAW,IAAMvL,KAAKtG,OAAO0R,aAE/BjF,YAAY1b,IAAI,SAAC4b,EAAOnc,MACnBkhB,GAAaG,EACbC,EAAmBnF,EAAQH,EAAEO,WN4BZ,IM3BjBgF,EAAYxf,GAAauf,EAAkBA,EAC3CE,EAAWH,GAAsBE,EACjC3f,EAAgB/D,EAAmBqjB,EAAYnjB,GAC/C8D,EAAchE,EAAmB2jB,EAAUzjB,GAE3C0jB,EAAerL,EAAKmD,MAAQ4H,EAAqBnhB,GAEnD0hB,SAASC,QACVvL,GAAKmD,QACIkI,EAAeA,EAAa7f,cAAgBA,IAC9C6f,EAAeA,EAAa5f,YAAcD,MAExCA,IACFC,MAEJ+f,GAAUjgB,EAAe+f,EAAUC,EAAQvL,EAAKtU,OAAQsU,EAAKrY,OAAQqY,EAAKrU,aAE9Eob,aAAavU,KAAKgZ,KAClBR,iBAAiBxY,0CAGXuT,QACAH,EAAEO,yCAGFgF,WAIJhI,KAAO,+CAIRyC,GAAIlG,KAAKkC,MAET5I,IAEF,eAEA,+BAEgB4M,EAAEmB,oBACRrH,KAAKR,SAEbwF,KAAKhF,aAIJmD,WAAa,GAAIC,KAAI9J,EACxB7O,IAAI,eACA6f,GAAYrR,mBAAgBhM,WACxBA,EAAK,GAAIqd,kDAIAyB,MACb9jB,GAAqB+X,KAArB/X,OAAOkjB,EAAcnL,KAAdmL,WACPtD,EAAW9f,EAAmBgkB,EAASX,WAAYW,EAAS/jB,MAAQ,EAAGC,wBACtD4f,EAAS1b,EAAKgf,QAAiBtD,EAASpf,EAAK0iB,6CAG1Dlb,EAAK/F,EAAE8hB,EAAK3G,MAClBpV,MACEhH,GAAQ+W,KAAKR,OAAOtV,MACvB8hB,EAAM,GACE/b,EAAM+P,KAAKiM,oBAAoBjM,KAAKkC,MAAMoJ,iBAAiBphB,OAChEQ,MAAMhD,KAAOsB,EAAmBC,EAAO,OACxCijB,GAAQvnB,EAAUqb,KAAKhK,KACvB7J,EAAIkZ,EAAE8G,MAAQD,EAAM/mB,KAAO,GAC3BsD,EAAI4c,EAAE+G,MAAQF,EAAMnnB,IAAM,GAC1Bmb,GAASF,KAAKqM,kBAAoBrM,KAAKqM,iBAAiBhlB,OAAS,EAClE2Y,KAAKqM,iBAAiBniB,GAAK8V,KAAKkC,MAAM1E,OAAOtT,IAAM,KAClDoiB,GAAuC,IAA5BtM,KAAKkC,MAAMiE,YAAYjc,GAAW8V,KAAKkC,MAAMuE,YAAYzf,QAAQ,QAC3Esc,IAAIwH,UAAU3e,EAAG1D,GAAIyQ,KAAMgH,EAAOnM,MAAOuY,EAAU,WACnDhJ,IAAIyH,iBAEC9a,EAAK,2BACVqT,IAAIrD,YACJvV,MAAMhD,KAAOuB,8CAKduN,UAAU4J,iBAAiB,YAAaJ,KAAKiL,gBAC7CzU,UAAU4J,iBAAiB,aAAcJ,KAAKkL,8CAG1C7F,MACH/e,GAAS+e,EAAE/e,OACbimB,EAASvM,KAAKmD,WAAWsH,IAAI,aAAavD,MAC1CsF,EAAYxM,KAAKyM,oBACjBC,EAAa1M,KAAK2M,kBACnBJ,EAAO/S,SAASlT,GAAS,IACvB4D,GAAIqiB,EAAOpQ,QAAQ7V,QAClBsmB,WAAWF,EAAYF,GAAU,QACjCG,eAAiBrmB,OACjBmmB,oBAAsBviB,OACtB0iB,WAAWtmB,EAAQ4D,GAAG,EAAMmb,aAE5B6F,uDAKD0B,WAAW5M,KAAK2M,eAAe3M,KAAKyM,qBAAoB,UA5IzB1G,ICIjB8G,0BACRxhB,EAAQuC,8EACbvC,EAAQuC,MACTrH,KAAO,YAEPumB,WAAalf,EAAQkf,YAAc,MAEpCC,IAAe,SAAU,UACzBC,EAAiBD,EAAYvT,SAAS5L,EAAQof,gBAC/Cpf,EAAQof,eAAiB,kBACvBC,oBAAsBF,EAAY5Q,QAAQ6Q,KAE1CnN,+DAGIjS,QACJsf,gBAA8C,IAA5Btf,EAAQsf,gBAAwB,EAAI,2FAC3Ctf,wIAKXkV,WPW4B,QOV5BD,UPW2B,MOT5B9b,GAAIiZ,KAAKhT,KACTmgB,EAAUnN,KAAKkN,gBZrCY,GYqC0B,OACpD7J,iBA/BW+J,IA+BS5V,GAAgBzQ,EAAEK,MAAOL,EAAEiX,KACjDmP,GAAuBnN,KAAK+C,YAAc/C,KAAK8C,oDAI9CqK,GAAUnN,KAAKkN,gBZ3CY,GY2C0B,OACpD/I,UArCWiJ,IAqCEpN,KAAKkC,MAAMmL,UAAYF,GACtCnN,KAAK+C,YAAc/C,KAAK8C,oDAGhB9V,0DAAKgT,KAAKhT,QAClBA,EAAK5F,OAAS4F,EAAKgR,KAAOhR,EAAK5F,MAAQ4F,EAAKgR,SACxC,IAAI0D,OAAM,kDAGb1U,EAAK5F,UACHA,MAAQ,GAAIyP,QACZzP,MAAMkmB,YAAatgB,EAAK5F,MAAMkQ,cAAgB,IAEhDtK,EAAKgR,QAAYA,IAAM,GAAInH,SAC1B0W,WAAavgB,EAAKugB,eAEpB/jB,SAAS6P,OAAO7O,KAAKwC,EAAKugB,YAAY,IAAM,IAAQ,IAClDC,aACGhjB,KAAKwC,EAAKugB,YAAY7K,QAAQ,eAChC/L,GAAO,GAAIE,MAAK4W,EAAevV,MAC5BjB,EAAYN,IAAS3J,EAAKugB,WAAWE,OAExCF,WAAaC,QAGZxgB,qCAIHkZ,GAAIlG,KAAKkC,QAEX9a,MAAQ6O,GAAM+J,KAAKhT,KAAK5F,SACxB4W,IAAM/H,GAAM+J,KAAKhT,KAAKgR,OAEtB0P,eAAiBzX,GAAMiQ,EAAE9e,SACzBimB,UAAY7V,GAAgB0O,EAAE9e,MAAO8e,EAAElI,OACvCZ,aAAeJ,GAChB3D,OAAOiC,OAAO0E,KAAKhT,KAAKugB,YAAatO,MAEpC0O,cAAgB3N,KAAK4N,kEAInB1H,EAAIlG,KAAKkC,MACT2L,EAAU7N,KAAKkN,gBAAkB,EAAI,EAErC5T,EAAmB4M,EAAEyH,cAAcljB,IAAI,SAACiP,EAAQxP,UACnD,oBAEQwP,EAAOnK,eAtFA6d,aAAAA,cPwCiB,cOxCjBA,GA0FFlH,EAAEyH,cACZpU,OAAO,SAACG,EAAQ9S,SAAMA,GAAIsD,IAC1BO,IAAI,kBAAUiP,GAAOoP,KAAKzhB,OAASwmB,IACnChR,OAAO,SAACzH,EAAG3L,SAAM2L,GAAI3L,GAAG,IAG3B,iBACQyc,GAAEyH,cAAczjB,IACtB8a,gBAIE7B,WAAa,GAAIC,KAAI9J,EACxB7O,IAAI,SAACwC,EAAM/C,MACPogB,GAAYrR,mBAAgBhM,WACxBA,EAAK,GAAK,IAAM/C,EAAGogB,SAIzB7hB,GAAI,KACQia,QAAQ,SAACoL,EAAS5jB,OAC7B,EAAG,EAAG,GAAGsP,SAAStP,GAAI,IACrB6jB,GAAUrgB,EAAS,kBAAkB,EAAcjF,EAAGqlB,YPxE3B,MO2EzB,aACQ,UAGThK,SAAS1Z,YAAY2jB,MAvHZX,oCA6HVpgB,GACFA,WACK6R,MAAM,2BAGV7R,KAAOgT,KAAK6B,YAAY7U,QACxBkW,YACAK,oEAIA/M,UAAU4J,iBAAiB,YAAa,SAACiF,KACxClC,WAAWT,QAAQ,eACnBsL,GAAaC,EAAK/G,MAClBgH,EAAY7I,EAAE/e,UACf0nB,EAAWxU,SAAS0U,GAAY,IAE9B/mB,GAAQ+mB,EAAUnc,aAAa,cAC/Boc,EAAYD,EAAUnc,aAAa,aAAaK,MAAM,KAEtDqG,EAAQL,GAAa5O,SAAS2kB,EAAU,IAAI,GAAG,GAE/CzD,EAAO9D,EAAKpQ,UAAU1R,wBAAyB6lB,EAAOuD,EAAUppB,wBAEhEyG,EAAQ/B,SAAS6b,EAAE/e,OAAOyL,aAAa,UACvC5F,EAAIwe,EAAKxlB,KAAOulB,EAAKvlB,KAAOoG,EAAM,EAClC9C,EAAIkiB,EAAK5lB,IAAM2lB,EAAK3lB,IACpBgP,EAAQ5M,EAAQ,IAAMyf,EAAKkG,WAC3B5T,EAAO,OAAST,EAAQ,IAAM0V,EAAU,GAAK,KAAOA,EAAU,KAE7D7K,IAAIwH,UAAU3e,EAAG1D,GAAIyQ,KAAMA,EAAMnF,MAAOA,EAAO8M,WAAY,SAC3DyC,IAAIyH,sEAOPpG,WAAW+B,YAAc,MAC1Bva,GAAI,EAGJiiB,EAAW1gB,EAAS,iBAAkBvB,EAvK1BihB,GAuKgC,iBAEpCA,MACN,MAGDiB,QACA1J,WAAWva,YAAYgkB,QAEvB5O,OAAOlW,MAAM,EAAG2V,IAA2BxU,IAAI,SAACxB,EAAOiB,MACrDif,GAASrc,EAAW,sBAAuBX,EAAI,GAAkBjC,EAjLxDkjB,GPwCiB,GO0IPnkB,KACpB0b,WAAWva,YAAY+e,QAIzBmF,GAAW5gB,EAAS,iBADRvB,KAAI8S,GAA8CoP,EAtLlDjB,GAuLwC,iBAE5CA,MACN,SAGDzI,WAAWva,YAAYkkB,4CAaxB,GATApI,GAAIlG,KAAKkC,SACoBgE,EAAE9e,MAAMiQ,WAAY6O,EAAE9e,MAAMkQ,eAAtDiX,OAAYC,UACUtI,EAAElI,IAAI3G,WAAY6O,EAAElI,IAAI1G,eAE/CmX,OAAyBF,EAAa,EAA6B,SAAbC,GAExDb,KAEAe,EAAezY,GAAMiQ,EAAE9e,OACnB8C,EAAI,EAAGA,EAAIukB,EAAYvkB,IAAK,IAC/BwN,GAAUwO,EAAElI,QACZ7F,GAAeuW,EAAcxI,EAAElI,KAAM,QACnB0Q,EAAarX,WAAYqX,EAAapX,iBACjDkB,gBAEG1F,KAAKkN,KAAK2O,gBAAgBD,EAAchX,OAE9CA,EAAS,KACFA,QAGTiW,2CAGQlW,MAAWC,0DAAQ,MACbD,EAAUJ,WAAYI,EAAUH,eAAhDmB,OAAOC,OACRkW,EAAchX,GAAeH,GAG7BoX,SACIpW,gBAHExC,GAAMyB,IAAYc,GAAmBC,EAAOC,GAOrC,OAIb,GAHAoW,GAAiBtX,GAAgBoX,EAAalX,GAE9CoR,KAAW3f,SACPe,EAAI,EAAGA,EAAI4kB,EAAgB5kB,MAC5B8V,KAAK+O,OAAOH,EAAanW,KAC1B3F,KAAK3J,QAEI,GAAI0N,MAAK1N,EAAI4O,GAAqB,GAAGkR,UAC9B,SAGnB9f,GAAI4O,GAAqB,GAAGmR,eACtB0F,EAAa,KAChB9b,KAAKkN,KAAK+O,OAAOH,EAAanW,GAAO,OAG9BqQ,KAAOA,EAEb+F,iCAGDpX,EAAWgB,OAOb,GAPoBuW,2DACpB9I,EAAIlG,KAAKkC,MAGT+M,EAAchZ,GAAMwB,GACpBtO,KAEIe,EAAI,EAAGA,EAAI6N,GAAoB7N,IAAK4O,GAAQmW,EAAa,GAAI,IAChEvV,MAGAwV,EAAwBD,GAAe/I,EAAE9e,OAAS6nB,GAAe/I,EAAElI,GAEpEgR,IAASC,EAAY5X,aAAeoB,IAAUyW,IACzCjG,SAAWhS,EAAYgY,KAErBjP,KAAKmP,mBAAmBF,KAE9Bnc,KAAK4G,SAGHvQ,8CAGWwN,MACdsS,GAAWhS,EAAYN,GACvBuS,EAAYlJ,KAAKhT,KAAKugB,WAAWtE,mBAE1BA,YACCC,GAAa,OAClBlJ,KAAKR,OAAOlC,GAAiB4L,EAAWlJ,KAAKkC,MAAM9E,uBAnRvBoE,ICHhB7C,0BACRtT,EAAQ4B,8EACb5B,EAAQ4B,aAETod,WAAapd,EAAKod,iBAClB+E,YAAcniB,EAAKmiB,kBAEnB7oB,KAAO0G,EAAK1G,MAAQ,SACpBkd,KAAO,IAEP5D,+DAGI5S,4FACOA,KAEXoiB,YAAcpiB,EAAKoiB,kBACnBC,eAAiBriB,EAAKqiB,wBAEtB5V,OAAO6V,UAAYtiB,EAAKoiB,YAAYE,WAAa,YACjD7V,OAAO8V,UAAYviB,EAAKoiB,YAAYG,WAAa,YACjD9V,OAAO+V,UAAYxiB,EAAKoiB,YAAYI,WAAa,OAEjD/V,OAAOgW,eAAiBziB,EAAKqiB,eAAeI,oBAC5ChW,OAAOiW,eAAiB1iB,EAAKqiB,eAAeK,oBAE5CjW,OAAOwQ,iBAAmBjd,EAAKid,sJAK/BpH,WRnB2B,QQoB3BC,YRnB4B,+CQuB1BxF,2DADSyC,KAAKhT,KACCgT,KAAKzZ,uDAIpB0X,2DADc+B,KAAKhT,wCAItBwW,gEACCoM,iBACFpM,SACEqM,oBAAoB7P,KAAK8P,gBAA+B,SAAd9P,KAAKzZ,WAC/CwpB,+DAID7J,GAAIlG,KAAKkC,MACT1E,EAASwC,KAAKhT,KAAKwQ,SACrBC,cAAgBD,EAAOnW,SAEvB2oB,UAAYhQ,KAAKzU,MAAO2a,EAAEzI,gBAE1BwS,QAAU/J,EAAE8J,UAAU,IAMtBE,cACO1S,YACGA,EAAO/S,IAAI,SAAC1D,EAAGmD,SACzBpD,GAASof,EAAE+J,QAAU/lB,EAAIgc,EAAE8J,0DAKVG,MACbnU,GAAOX,GAAmB8U,yDADa,SAEvC3T,EAAkBwD,KAAKxX,OAAS6T,GAAcL,GAC9CoU,EAAiBlU,GAAgBF,GAAQQ,EACzCjU,EAAWyX,KAAKxX,OAAUuT,GAAaC,GAAQoU,OAEhDlO,MAAM3F,cACFP,YACGA,EAAKvR,IAAI,kBAAKlC,GAAWxB,EAAIyV,oBACvBA,WACPjU,QAIN8nB,yBACAC,qBACAC,8DAIDrK,GAAIlG,KAAKkC,MACTsO,EAAW,kBAAUlV,GAAO7Q,IAAI,kBAAO6R,IAAMnS,EAAK+b,EAAE3J,YAEtDmB,SAAWsC,KAAKhT,KAAK0Q,SAASjT,IAAI,SAAC1D,EAAGmD,MACnCoR,GAASvU,EAAEuU,OACXmV,EAAe1pB,EAAE0pB,6BAEd1pB,EAAEmS,WACDhP,YACInD,EAAE8W,iBAELvC,aACIkV,EAASlV,gBAEPmV,iBACED,EAASC,iDAMvBvK,GAAIlG,KAAKkC,SACVlC,KAAKqK,WAAWqG,sBAChBC,UAAYzK,EAAExI,SAASwI,EAAExI,SAASrW,OAAS,GAAGupB,kBAG/CD,UAAY,GAAIppB,OAAM2e,EAAEzI,eAAe/V,KAAK,QAC5CgW,SAASjT,IAAI,cACZ6e,WAAW7e,IAAI,SAACqE,EAAKlI,GACnBkI,EAAMoX,EAAEyK,UAAU/pB,OAClB+pB,UAAU/pB,GAAKkI,iDAOhBoX,GAAIlG,KAAKkC,KACVlC,MAAKhT,KAAKoR,gBACP8D,MAAM9D,SAAW4B,KAAKhT,KAAKoR,SAAS3T,IAAI,qBAC1Cod,SAAWvL,GAAMvV,EAAEgN,MAAOmS,EAAE3J,OAIvBxV,KAGNiZ,KAAKhT,KAAK+Q,gBACPmE,MAAMnE,SAAWiC,KAAKhT,KAAK+Q,SAAStT,IAAI,qBAC1C2d,SAAW9L,GAAMvV,EAAEK,MAAO8e,EAAE3J,SAC5B8L,OAAS/L,GAAMvV,EAAEiX,IAAKkI,EAAE3J,OACnBxV,0DAMLmG,EAAM,YAEP8S,KAAKqK,WAAWqG,QAAS,GACrB,kBACFG,GAAa,GAAItpB,OAAMyY,KAAKkC,MAAMzE,eAAe/V,KAAK,QACrDsF,KAAK0Q,SAASjT,IAAI,SAAC1D,EAAGmD,MACtBoR,GAASgF,EAAKtT,KAAK0Q,SAASxT,GAAGoR,SACjCpO,GAAO2jB,EAAaA,EAAWpmB,IAAI,SAACoZ,EAAG3Z,SAAM2Z,GAAIvI,EAAOpR,UAIxD4mB,GAAgB9Q,KAAKhT,KAAK0Q,SAASjT,IAAI,kBAAK1D,GAAEmG,WAC/C8S,MAAKhT,KAAKoR,YACEtL,KAAKkN,KAAKhT,KAAKoR,SAAS3T,IAAI,kBAAK1D,GAAEgN,SAE/CiM,KAAKhT,KAAK+Q,eACP/Q,KAAK+Q,SAAStT,IAAI,cACRqI,MAAM/L,EAAEiX,IAAKjX,EAAEK,iBAIrBO,kBAAUmpB,yDAIhBxX,IAEF,cAEO0G,KAAKtG,OAAO8V,gBACXxP,KAAKzU,OAGb,iBACQyU,MAAKkC,MAAM3F,OACjByI,KAAKhF,QAIP,cAEOA,KAAKtG,OAAO6V,iBACVvP,KAAKxX,QAGd,cACK0d,GAAIlG,KAAKkC,eACXgO,MAAMhI,WAAa7J,GAAmB2B,KAAKzU,MAC5C2a,EAAEgK,MAAM1S,OAAQwC,KAAKtG,OAAO+V,WAEtBvJ,EAAEgK,OACRlL,KAAKhF,QAIP,kBAEQA,KAAKzU,UACP,SAEN,iBACQyU,MAAKkC,MAAMnE,UACjBiH,KAAKhF,QAIL+Q,EAAc/Q,KAAKkC,MAAMxE,SAASnE,OAAO,kBAAqB,QAAhBxS,EAAE8W,YAChDmT,EAAehR,KAAKkC,MAAMxE,SAASnE,OAAO,kBAAqB,SAAhBxS,EAAE8W,YAEjDoT,EAAcF,EAAYtmB,IAAI,eAC7B8E,GAAQxI,EAAEwI,aAEb,YAAmBxI,EAAEwI,aAEbA,QACAqX,EAAKpH,OAAOjQ,WACVqX,EAAKyD,WAAWqG,yBAGP9J,EAAKlN,OAAOwQ,2BR3MG,IQ4MtBtD,EAAKpe,QAEjB,cACK0d,GAAIlG,KAAKkC,MACTnb,EAAImf,EAAExI,SAASnO,GACfmhB,EAAU1Q,KAAKqK,WAAWqG,QAE1BQ,EAAalR,KAAKqK,WAAW6G,YRpND,GQqN5BzH,EAAYvD,EAAE8J,WAAa,EAAIkB,GAC/B3H,EAAWE,GAAWiH,EAAU,EAAIK,EAAY1pB,QAEhDmgB,EAAatB,EAAEgK,MAAMtI,UAAUnd,IAAI,kBAAK0B,GAAIsd,EAAU,GACtDiH,OACUlJ,EAAW/c,IAAI,kBAAK0mB,GAAI5H,EAAWha,QAG7CiO,GAAS,GAAIjW,OAAM2e,EAAEzI,eAAe/V,KAAK,GAC1CsY,MAAKtG,OAAOwQ,qBACXwG,GAAW3pB,EAAEwI,QAAU2W,EAAExI,SAASrW,OAAS,EACpCN,EAAE0pB,aAEF1pB,EAAEuU,WAITkO,GAAU,GAAIjiB,OAAM2e,EAAEzI,eAAe/V,KAAK,SAC3CgpB,OACQ3pB,EAAEuiB,WAAW7e,IAAI,SAAChC,EAAG7B,SAAM6B,GAAI1B,EAAE6pB,eAAehqB,kBAI9C4gB,aACAzgB,EAAEuiB,mBACLE,SAEDhM,WAEE0I,EAAE3J,MAAMhU,mBACPkhB,WACDF,IAEVvE,WAIAoM,EAAcJ,EAAavmB,IAAI,eAC9B8E,GAAQxI,EAAEwI,aAEb,aAAoBxI,EAAEwI,aAEdA,QACAqX,EAAKpH,OAAOjQ,WACVqX,EAAKxW,iBACJwW,EAAKwI,YAAYlf,oBACf0W,EAAKwI,YAAY9e,oBACnBsW,EAAKwI,YAAYnF,kBACjBrD,EAAKwI,YAAYpF,0BAGTpD,EAAKlN,OAAOwQ,kBAE/B,cACKhE,GAAIlG,KAAKkC,MACTnb,EAAImf,EAAExI,SAASnO,qBAGN2W,EAAEgK,MAAMtI,qBACR7gB,EAAEuiB,kBAENviB,EAAEuU,gBAEA4K,EAAE3J,MAAMhU,gBACVyX,KAAKoP,YAAYiC,SRlRI,IQoR7BrM,WAIAsM,IAEF,kBAEQtR,KAAKzU,UACP,SAEN,iBACQyU,MAAKkC,MAAM9D,UACjB4G,KAAKhF,UAIU1G,EAAiB3R,OAAOspB,EAAaG,EAAaE,MAEjEC,IAAa,WAAY,iBACxBC,2BAEArO,WAAa,GAAIC,KAAI9J,EACxBC,OAAO,mBAASgY,EAAU/X,SAASvM,EAAK,KAAO2Z,EAAK1E,MAAMjV,EAAK,MAC/DxC,IAAI,eACA6f,GAAYrR,mBAAgBhM,WAC7BA,EAAK,GAAGuM,SAAS,cAAgBvM,EAAK,GAAGuM,SAAS,gBAC/CgY,mBAAmB1e,KAAKwX,IAEtBrd,EAAK,GAAIqd,qDAKdmH,kBAEDvL,GAAIlG,KAAKkC,MAGTwP,EAAU1R,KAAKtG,OAAOgW,eAEtBiC,EAASzL,EAAEgK,MAAM1S,MAClBkU,IAAWA,EAAQC,EAAO,QACnBA,EAAOlnB,IAAI,kBAAGinB,GAAQ3qB,4DAU3ByP,UAAU4J,iBAAiB,YAAa,SAACiF,MACzCrb,GAAIrF,EAAU2gB,EAAK9O,WACnBob,EAAOvM,EAAE8G,MAAQniB,EAAE7E,KAAOmgB,EAAKxC,UACxBuC,GAAE+G,MAAQpiB,EAAEjF,IAAMugB,EAAKzC,UAExByC,EAAK9c,OAA0B,EAAjB8c,EAAKzC,YACvBgP,oBAAoBD,KAEpBtO,IAAIrD,wDAKQ2R,cACf1L,EAAIlG,KAAKkC,SACTgE,EAAEyK,cAEFphB,GAAQkN,GAAkBmV,EAAM1L,EAAEgK,MAAMtI,WAAW,QAElDtE,IAAIwH,UACR5E,EAAEgK,MAAMtI,UAAUrY,GAASyQ,KAAKsD,IAAIpY,OAAOiB,EAC3C+Z,EAAEyK,UAAUphB,GAASyQ,KAAKsD,IAAIpY,OAAOzC,GACpCyQ,KAAMgN,EAAEgK,MAAM1S,OAAOjO,GAAQwE,MAAO,IACrCiM,KAAKhT,KAAK0Q,SAASjT,IAAI,SAAC4V,EAAKnW,gBAEpBmW,EAAInH,WACJmH,EAAI/E,OAAO/L,SACXsW,EAAKrG,OAAOtV,MAGrBqF,QAGI+T,IAAIyH,6DAIL7E,EAAIlG,KAAKhT,UACR2X,WAAW+B,YAAc,GAE3BR,EAAExI,SAASrW,OAAS,KACpBqW,SAASjT,IAAI,SAAC1D,EAAGmD,MAIdrF,GAAOsI,ER3XqB,IQ6XpBjD,EACX,IR9X+B,IQgY/Boe,EAAK9I,OAAOtV,GACZnD,EAAEmS,QACEyL,WAAWva,YAAYvF,yDAS3Bmb,KAAKyD,sBACFA,KAAO,EAGVzD,MAAK8R,oBACFA,cAAcpP,QAAQ,eACtB1Y,GAAIN,EAAEwX,UACR5W,WAAW0K,YAAYhL,UAItB8nB,cAAgB9R,KAAKwR,mBAAmB/mB,IAAI,wBAEzCoZ,EAAEuF,qBACCtb,SACF+V,EAAEwF,aAIoBvb,KAA5BkS,KAAKkC,MAAM6P,oBACR7P,MAAM6P,aAAe/R,KAAKkC,MAAMzE,cAAgB,QAIjDqU,cAAcrnB,IAAI,eAClBunB,GAAcjrB,EAAEsiB,MAAM4I,EAAK/P,MAAM6P,gBAEnC7Q,QAAUF,GAAYja,EAAER,MAAMyrB,KAC3BlO,SAAS1Z,YAAYrD,EAAEma,yDAK1BlB,KAAK8R,oBACFA,cAAcpP,QAAQ,eACtB1Y,GAAIN,EAAEwX,UACR5W,WAAW0K,YAAYhL,2DAMtBqB,OAAO+U,iBAAiB,cAAe,aACtCe,sEAKDqQ,mBAAmB/mB,IAAI,cACzB4e,MAAM5e,IAAI,cACN2V,iBAAiB,QAAS,cAC1B7Q,GAAQkB,EAAKsB,aAAa,sBACzBmgB,oBAAoB3iB,cAMvB+T,IAAI9M,UAAU4J,iBAAiB,QAAS,cACxC7Q,GAAQ4iB,EAAK7O,IAAI9M,UAAUzE,aAAa,sBACvCmgB,oBAAoB3iB,6DAKrBuiB,cAAcrnB,IAAI,eAClBunB,GAAcjrB,EAAEsiB,MAAM+I,EAAKlQ,MAAM6P,iBACvBhrB,EAAER,MAAMyrB,EAAajrB,EAAEma,sDAKjCgR,oBAAoBlS,KAAKkC,MAAM6P,aAAe,+CAI9CG,oBAAoBlS,KAAKkC,MAAM6P,aAAe,6CAGvCxiB,0DAAMyQ,KAAKkC,MAAM6P,aACzB7L,EAAIlG,KAAKkC,mBAEL3S,QACA2W,EAAEgK,MAAM1S,OAAOjO,UACd2W,EAAExI,SAASjT,IAAI,kBAAK1D,GAAEuU,OAAO/L,kDAKnBA,MACf2W,GAAIlG,KAAKkC,SACL1Y,SAAS+F,IACN,IAAGA,EAAQ,GACnBA,GAAS2W,EAAEgK,MAAM1S,OAAOnW,SAAQkI,EAAQ2W,EAAEgK,MAAM1S,OAAOnW,OAAS,GAChEkI,IAAU2W,EAAE6L,iBACbA,aAAexiB,IACZyQ,KAAK3U,OAAQ,cAAe2U,KAAKqS,sDAM1BjlB,EAAOklB,MAAe/iB,0DAAMyQ,KAAKkC,MAAMzE,0GAChCrQ,EAAOklB,EAAe/iB,QACpCvC,KAAKwQ,OAAO+U,OAAOhjB,EAAO,EAAGnC,QAC7BJ,KAAK0Q,SAASjT,IAAI,SAAC1D,EAAGmD,KACxBoR,OAAOiX,OAAOhjB,EAAO,EAAG+iB,EAAcpoB,WAEpC8Z,OAAOhE,KAAKhT,mDAGFuC,0DAAQyQ,KAAKkC,MAAMzE,cAAc,CAC5CuC,MAAKhT,KAAKwQ,OAAOnW,QAAU,mGAGTkI,QACjBvC,KAAKwQ,OAAO+U,OAAOhjB,EAAO,QAC1BvC,KAAK0Q,SAASjT,IAAI,cACpB6Q,OAAOiX,OAAOhjB,EAAO,UAEnByU,OAAOhE,KAAKhT,6CAGJslB,MAAe/iB,0DAAM,OAC7BvC,KAAK0Q,SAASnO,GAAO+L,OAASgX,OAC9BtO,OAAOhE,KAAKhT,6CAKH0Q,QACT1Q,KAAK0Q,SAASjT,IAAI,SAAC1D,EAAGmD,GACvBwT,EAASxT,OACToR,OAASoC,EAASxT,WAGjB8Z,OAAOhE,KAAKhT,aAxiBoBwU,ITFjC5C,QACAD,QACCA,cAEMyL,WACHyC,OACJ7B,IAiBArF,GACL,WAAYta,EAAQuC,qBACZ8Q,GAAe9Q,EAAQrH,KAAM8E,EAAQuC,wFU/B1C4kB,YAEJA,IAAOC,KAAU,gBACjBD,GAAOE,QAAU,QAEjBF,GAAiBnZ,OAAOM,UAAY6Y,GAAQG"} \ No newline at end of file +{"version":3,"file":"frappe-charts.min.js","sources":["../../../src/js/utils/dom.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/utils/constants.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 === \"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, commonClass, activeClass='active', index = -1) {\n\tlet $children = $parent.querySelectorAll(`.${commonClass}.${activeClass}`);\n\n\tforEachNode($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","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","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(parent, className, transform='') {\n\treturn createSVG('g', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\ttransform: transform\n\t});\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\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: width - getStringWidth(label, 5) - LABEL_MARGIN,\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) {\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\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN,\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\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 || meta.minHeight // TODO: correct y for positive min 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\t// TODO: use zeroLine OR minimum\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(parent, this.layerClass, this.layerTransform);\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(marker =>\n\t\t\t\tyMarker(marker.position, marker.label, this.constants.width,\n\t\t\t\t\t{pos:'right', 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\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};\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(region =>\n\t\t\t\tyRegion(region.startPos, region.endPos, this.constants.width,\n\t\t\t\t\tregion.label)\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\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};\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),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 11\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 { DEFAULT_AXIS_CHART_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\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\t\t//\n\n\t\t// Set type\n\t\tif(!d.chartType ) {\n\t\t\tif(!AXIS_DATASET_CHART_TYPES.includes(type)) type === DEFAULT_AXIS_CHART_TYPE;\n\t\t\td.chartType = type;\n\t\t}\n\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\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 };","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_CHART_TOP_MARGIN = 10;\nexport const BASE_CHART_LEFT_MARGIN = 20;\nexport const BASE_CHART_RIGHT_MARGIN = 20;\n\nexport const Y_AXIS_LEFT_MARGIN = 60;\nexport const Y_AXIS_RIGHT_MARGIN = 40;\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const DEFAULT_AXIS_CHART_TYPE = 'line';\nexport const AXIS_DATASET_CHART_TYPES = ['line', 'bar'];\n\nexport const AXIS_LEGEND_BAR_SIZE = 100;\n\nexport const BAR_CHART_SPACE_RATIO = 0.5;\nexport const MIN_BAR_PERCENT_HEIGHT = 0.01;\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_LEFT_MARGIN = 50;\nexport const HEATMAP_TOP_MARGIN = 25;\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\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: `${ set.value === 0 || set.value ? set.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}.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, AXIS_TICK_LENGTH } from '../utils/draw';\nimport { BASE_CHART_TOP_MARGIN, BASE_CHART_LEFT_MARGIN,\n\tBASE_CHART_RIGHT_MARGIN, INIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS,\n\tALL_CHART_TYPES, COMPATIBLE_CHARTS, DATA_COLOR_DIVISIONS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\nimport { Chart } from '../chart';\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.argHeight = options.height || 240;\n\t\tthis.type = options.type || '';\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: options.showLegend || 1,\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: 1\n\t\t};\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\tconfigure() {\n\t\tthis.setMargins();\n\n\t\t// Bind window events\n\t\twindow.addEventListener('resize', () => this.boundDrawFn);\n\t\twindow.addEventListener('orientationchange', () => this.boundDrawFn);\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\tsetMargins() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - 70;\n\t\tthis.topMargin = BASE_CHART_TOP_MARGIN;\n\n\t\t// Horizontal margins\n\t\tthis.leftMargin = BASE_CHART_LEFT_MARGIN;\n\t\tthis.rightMargin = BASE_CHART_RIGHT_MARGIN;\n\t}\n\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\tsetupComponents() {\n\t\tthis.components = new Map();\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}\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.calc(onlyWidthChange);\n\t\tthis.updateWidth();\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\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - (this.leftMargin + this.rightMargin);\n\t}\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\tprepareData(data=this.data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn data;\n\t}\n\n\tcalc() {} // builds state\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\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\n\t\tlet titleAreaHeight = 0;\n\t\tlet legendAreaHeight = 0;\n\t\tif(this.title.length) {\n\t\t\ttitleAreaHeight = 40;\n\t\t}\n\t\tif(this.config.showLegend) {\n\t\t\tlegendAreaHeight = 30;\n\t\t}\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 + titleAreaHeight + legendAreaHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\t// console.log(this.baseHeight, titleAreaHeight, legendAreaHeight);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tthis.leftMargin - AXIS_TICK_LENGTH * 6,\n\t\t\t\tthis.topMargin,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: 12,\n\t\t\t\t\tfill: '#666666'\n\t\t\t\t}\n\t\t\t);\n\t\t\tthis.svg.appendChild(this.titleEL);\n\t\t}\n\n\t\tlet top = this.topMargin + titleAreaHeight;\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.svg,\n\t\t\tthis.type + '-chart',\n\t\t\t`translate(${this.leftMargin}, ${top})`\n\t\t);\n\n\t\ttop = this.baseHeight - titleAreaHeight;\n\t\tthis.legendArea = makeSVGGroup(\n\t\t\tthis.svg,\n\t\t\t'chart-legend',\n\t\t\t`translate(${this.leftMargin}, ${top})`\n\t\t);\n\n\t\tthis.updateTipOffset(this.leftMargin, this.topMargin + titleAreaHeight);\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\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\tgetDifferentChart(type) {\n\t\tconst currentType = this.type;\n\t\tlet args = this.rawChartArgs;\n\t\tif(type === currentType) return;\n\n\t\tif(!ALL_CHART_TYPES.includes(type)) {\n\t\t\tconsole.error(`'${type}' is not a valid chart type.`);\n\t\t}\n\n\t\tif(!COMPATIBLE_CHARTS[currentType].includes(type)) {\n\t\t\tconsole.error(`'${currentType}' chart cannot be converted to a '${type}' chart.`);\n\t\t}\n\n\t\t// whether the new chart can use the existing colors\n\t\tconst useColor = DATA_COLOR_DIVISIONS[currentType] === DATA_COLOR_DIVISIONS[type];\n\n\t\t// Okay, this is anticlimactic\n\t\t// this function will need to actually be 'changeChartType(type)'\n\t\t// that will update only the required elements, but for now ...\n\n\t\targs.type = type;\n\t\targs.colors = useColor ? args.colors : undefined;\n\n\t\treturn new Chart(this.parent, args);\n\t}\n\n\tboundDrawFn() {\n\t\tthis.draw(true);\n\t}\n\n\tunbindWindowEvents(){\n\t\twindow.removeEventListener('resize', () => this.boundDrawFn);\n\t\twindow.removeEventListener('orientationchange', () => this.boundDrawFn);\n\t}\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';\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\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 110;\n\t\t\tlet rect = legendDot(\n\t\t\t\tbarWidth * i + 5,\n\t\t\t\t'0',\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(rect);\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\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.barOptions.height = this.barOptions.height\n\t\t\t|| PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tthis.barOptions.depth = this.barOptions.depth\n\t\t\t|| PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tthis.setup();\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 { HEATMAP_TOP_MARGIN, HEATMAP_LEFT_MARGIN, 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\tconfigure(options) {\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\t\tsuper.configure(options);\n\t}\n\n\tsetMargins() {\n\t\tsuper.setMargins();\n\t\tthis.leftMargin = HEATMAP_LEFT_MARGIN;\n\t\tthis.topMargin = HEATMAP_TOP_MARGIN;\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 + this.rightMargin + this.leftMargin;\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.baseWidth = (this.state.noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ this.rightMargin + this.leftMargin;\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) {\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 { Y_AXIS_LEFT_MARGIN, Y_AXIS_RIGHT_MARGIN, 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 { MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO, LINE_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.type = args.type || 'line';\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\targs.axisOptions = args.axisOptions || {};\n\t\targs.tooltipOptions = args.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = args.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = args.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = args.axisOptions.xIsSeries || 0;\n\n\t\tthis.config.formatTooltipX = args.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = args.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = args.valuesOverPoints;\n\t}\n\n\tsetMargins() {\n\t\tsuper.setMargins();\n\t\tthis.leftMargin = Y_AXIS_LEFT_MARGIN;\n\t\tthis.rightMargin = Y_AXIS_RIGHT_MARGIN;\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) return;\n\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\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\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\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 * (1 - 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\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: s.yAxis.zeroLine,\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\n\t\t// let formatY = this.config.formatTooltipY;\n\t\tlet formatX = this.config.formatTooltipX;\n\n\t\tlet titles = s.xAxis.labels;\n\t\tif(formatX && formatX(titles[0])) {\n\t\t\ttitles = titles.map(d=>formatX(d));\n\t\t}\n\n\t\t// formatY = formatY && formatY(s.yAxis.labels[0]) ? formatY : 0;\n\n\t\t// yVal = formatY ? formatY(set.values[i]) : set.values[i]\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 o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - this.leftMargin;\n\t\t\tlet relY = e.pageY - o.top - this.topMargin;\n\n\t\t\tif(relY < this.height + this.topMargin * 2) {\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\n\t\tthis.tip.setValues(\n\t\t\ts.xAxis.positions[index] + this.tip.offset.x,\n\t\t\ts.yExtremes[index] + this.tip.offset.y,\n\t\t\t{name: s.xAxis.labels[index], value: ''},\n\t\t\tthis.data.datasets.map((set, i) => {\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: set.values[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t};\n\t\t\t}),\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\tthis.legendArea.textContent = '';\n\n\t\tif(s.datasets.length > 1) {\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.leftMargin - this.rightMargin;\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.0.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","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","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","args","key","legendBar","label","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","undefined","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","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","transform","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","vals","chartType","AXIS_DATASET_CHART_TYPES","yRegions","end","zeroDataPrep","realData","zeroData","yMarkers","getShortenedLabels","chartWidth","isSeries","allowedLetters","DEFAULT_CHAR_WIDTH","getChartByType","AxisChart","chartTypes","error","ALL_CHART_TYPES","COMPATIBLE_CHARTS","DATA_COLOR_DIVISIONS","HEATMAP_DISTRIBUTION_SIZE","INIT_CHART_UPDATE_TIMEOUT","PERCENTAGE_BAR_DEFAULT_HEIGHT","DEFAULT_CHART_COLORS","DEFAULT_COLORS","PI","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","title","dataPointList","addEventListener","set","_this2","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BaseChart","HTMLElement","Error","rawChartArgs","argHeight","prepareData","prepareFirstData","validateColors","showLegend","isNavigable","state","initTimeout","overlays","configure","setMargins","_this","boundDrawFn","validColors","forEach","warn","baseHeight","topMargin","leftMargin","rightMargin","makeContainer","updateWidth","draw","components","Map","independentWidth","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","c","drawArea","render","update","renderLegend","setupNavigation","baseWidth","animate","make","updateNav","bindUnits","titleAreaHeight","legendAreaHeight","titleEL","legendArea","updateTipOffset","bindOverlay","keyActions","onEnterKey","bind","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","e","_this4","event","keyCode","currentType","useColor","Chart","removeEventListener","_this5","chartSvg","AggregationChart","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","_this3","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","marker","startPos","endPos","_this6","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","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","spacing","HEATMAP_SQUARE_SIZE","noOfWeeks","setFullYear","dataPoints","points","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","COL_WIDTH","moreText","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","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","titles","relX","mapTooltipXPosition","overlayGuides","currentIndex","currentUnit","_this7","setCurrentDataPoint","_this9","_this10","getDataPoint","datasetValues","splice","frappe","NAME","VERSION","Charts"],"mappings":"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"} \ No newline at end of file diff --git a/package.json b/package.json index b200dba..f4ef51d 100644 --- a/package.json +++ b/package.json @@ -34,11 +34,13 @@ "homepage": "https://github.com/frappe/charts#readme", "devDependencies": { "autoprefixer": "^8.2.0", + "@babel/preset-env": "^7.0.0-beta.42", "babel-core": "^6.26.0", "babel-plugin-external-helpers": "^6.22.0", "babel-preset-env": "^1.6.1", "babel-preset-latest": "^6.24.1", "clean-css": "^4.1.11", + "babel-register": "^6.26.0", "cssnano": "^3.10.0", "eslint": "^4.18.2", "fs": "0.0.1-security", diff --git a/yarn.lock b/yarn.lock index 7d34484..0189f72 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2,6 +2,474 @@ # yarn lockfile v1 +"@babel/code-frame@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.0.0-beta.42.tgz#a9c83233fa7cd06b39dc77adbb908616ff4f1962" + dependencies: + "@babel/highlight" "7.0.0-beta.42" + +"@babel/generator@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.0.0-beta.42.tgz#777bb50f39c94a7e57f73202d833141f8159af33" + dependencies: + "@babel/types" "7.0.0-beta.42" + jsesc "^2.5.1" + lodash "^4.2.0" + source-map "^0.5.0" + trim-right "^1.0.1" + +"@babel/helper-annotate-as-pure@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.0.0-beta.42.tgz#f2b0a3be684018b55fc308eb5408326f78479085" + dependencies: + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-builder-binary-assignment-operator-visitor@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.0.0-beta.42.tgz#7305281eb996954c47f87ec7710e2a9a8edd8077" + dependencies: + "@babel/helper-explode-assignable-expression" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-call-delegate@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-call-delegate/-/helper-call-delegate-7.0.0-beta.42.tgz#53294eb8c5e6e53af3efda4293ff3c1237772d37" + dependencies: + "@babel/helper-hoist-variables" "7.0.0-beta.42" + "@babel/traverse" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-define-map@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-define-map/-/helper-define-map-7.0.0-beta.42.tgz#e5aa10bd7eed2c23cc2873e5d15fbb4b40a30620" + dependencies: + "@babel/helper-function-name" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + lodash "^4.2.0" + +"@babel/helper-explode-assignable-expression@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.0.0-beta.42.tgz#ae05c9e7ef9a085b0080b9e4f7a076851a2b17b5" + dependencies: + "@babel/traverse" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-function-name@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.0.0-beta.42.tgz#b38b8f4f85168d1812c543dd700b5d549b0c4658" + dependencies: + "@babel/helper-get-function-arity" "7.0.0-beta.42" + "@babel/template" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-get-function-arity@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.0.0-beta.42.tgz#ad072e32f912c033053fc80478169aeadc22191e" + dependencies: + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-hoist-variables@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.0.0-beta.42.tgz#6e51d75192923d96972a24c223b81126a7fabca1" + dependencies: + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-module-imports@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.0.0-beta.42.tgz#4de334b42fa889d560f15122f66c3bfe1f30cb77" + dependencies: + "@babel/types" "7.0.0-beta.42" + lodash "^4.2.0" + +"@babel/helper-module-transforms@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.0.0-beta.42.tgz#4d260cc786e712e8440bef58dae28040b77a6183" + dependencies: + "@babel/helper-module-imports" "7.0.0-beta.42" + "@babel/helper-simple-access" "7.0.0-beta.42" + "@babel/helper-split-export-declaration" "7.0.0-beta.42" + "@babel/template" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + lodash "^4.2.0" + +"@babel/helper-optimise-call-expression@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.0.0-beta.42.tgz#9ba770079001672a578fe833190cf03f973568b1" + dependencies: + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-plugin-utils@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.0.0-beta.42.tgz#9aa8b3e5dc72abea6b4f686712a7363cb29ea057" + +"@babel/helper-regex@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-regex/-/helper-regex-7.0.0-beta.42.tgz#ba01d0cd94786561e2afeb8c8b0e544aa034a1e1" + dependencies: + lodash "^4.2.0" + +"@babel/helper-remap-async-to-generator@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.0.0-beta.42.tgz#c27dd7789f3a9973493a67a7914ac9253e879071" + dependencies: + "@babel/helper-annotate-as-pure" "7.0.0-beta.42" + "@babel/helper-wrap-function" "7.0.0-beta.42" + "@babel/template" "7.0.0-beta.42" + "@babel/traverse" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-replace-supers@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.0.0-beta.42.tgz#fd984b6022982b71a1237d82d932ab69ff988aa4" + dependencies: + "@babel/helper-optimise-call-expression" "7.0.0-beta.42" + "@babel/template" "7.0.0-beta.42" + "@babel/traverse" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-simple-access@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.0.0-beta.42.tgz#9d32bed186b0bc365115c600817e791c22d72c74" + dependencies: + "@babel/template" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + lodash "^4.2.0" + +"@babel/helper-split-export-declaration@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.0.0-beta.42.tgz#0d0d5254220a9cc4e7e226240306b939dc210ee7" + dependencies: + "@babel/types" "7.0.0-beta.42" + +"@babel/helper-wrap-function@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/helper-wrap-function/-/helper-wrap-function-7.0.0-beta.42.tgz#5ffc6576902aa2a10fe6666e063bd45029c36db3" + dependencies: + "@babel/helper-function-name" "7.0.0-beta.42" + "@babel/template" "7.0.0-beta.42" + "@babel/traverse" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + +"@babel/highlight@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.0.0-beta.42.tgz#a502a1c0d6f99b2b0e81d468a1b0c0e81e3f3623" + dependencies: + chalk "^2.0.0" + esutils "^2.0.2" + js-tokens "^3.0.0" + +"@babel/plugin-proposal-async-generator-functions@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.0.0-beta.42.tgz#81465d19b6f5559092d9be4d11d6351131d08696" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-remap-async-to-generator" "7.0.0-beta.42" + "@babel/plugin-syntax-async-generators" "7.0.0-beta.42" + +"@babel/plugin-proposal-object-rest-spread@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.0.0-beta.42.tgz#56ebd55a8268165cb7cb43a5a232b60f5435a822" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/plugin-syntax-object-rest-spread" "7.0.0-beta.42" + +"@babel/plugin-proposal-optional-catch-binding@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.0.0-beta.42.tgz#d885ba187d2ce6bbae0c227a67a38389c6f930f8" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/plugin-syntax-optional-catch-binding" "7.0.0-beta.42" + +"@babel/plugin-proposal-unicode-property-regex@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.0.0-beta.42.tgz#84f209398368c194c217edd8131420e0ddb79661" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-regex" "7.0.0-beta.42" + regexpu-core "^4.1.3" + +"@babel/plugin-syntax-async-generators@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.0.0-beta.42.tgz#deccff2f01c2ed280493b0ba256b14df232ca299" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-syntax-object-rest-spread@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.0.0-beta.42.tgz#aa789865abe78a4895d4a0be9de4d34b1a1d5063" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-syntax-optional-catch-binding@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.0.0-beta.42.tgz#d3ebfaa463f42f5a35be5cbd2f27c1fc3bf96c1b" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-arrow-functions@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.0.0-beta.42.tgz#b918eb8760c38d6503a1a9858fa073786b60ab2b" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-async-to-generator@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.0.0-beta.42.tgz#c74e278b9722efeb7f2c7da5fbff7540c4a7f353" + dependencies: + "@babel/helper-module-imports" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-remap-async-to-generator" "7.0.0-beta.42" + +"@babel/plugin-transform-block-scoped-functions@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.0.0-beta.42.tgz#34742dcf409106038e413e0d64b90e98df15f9eb" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-block-scoping@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.0.0-beta.42.tgz#272c5cc2b46613ebcd2e19491b19263c36d2c3f4" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + lodash "^4.2.0" + +"@babel/plugin-transform-classes@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-classes/-/plugin-transform-classes-7.0.0-beta.42.tgz#3b9fdb2e36f9f16b011a2ddc4ebb610e3dc9edfb" + dependencies: + "@babel/helper-annotate-as-pure" "7.0.0-beta.42" + "@babel/helper-define-map" "7.0.0-beta.42" + "@babel/helper-function-name" "7.0.0-beta.42" + "@babel/helper-optimise-call-expression" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-replace-supers" "7.0.0-beta.42" + "@babel/helper-split-export-declaration" "7.0.0-beta.42" + globals "^11.1.0" + +"@babel/plugin-transform-computed-properties@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.0.0-beta.42.tgz#153662309475099c6948827fc86edbd7fb26f09d" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-destructuring@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.0.0-beta.42.tgz#1aaca42a00d9ef2b0307557c748f32e83ac44899" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-dotall-regex@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.0.0-beta.42.tgz#af7ead30c1b6c3ea8a53973cfcfdbda9edc3c967" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-regex" "7.0.0-beta.42" + regexpu-core "^4.1.3" + +"@babel/plugin-transform-duplicate-keys@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.0.0-beta.42.tgz#9678ab9480c6120e9b08014371c010bed481485a" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-exponentiation-operator@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.0.0-beta.42.tgz#fe637583e8d00ff6d63461e274a63dd2f373baf5" + dependencies: + "@babel/helper-builder-binary-assignment-operator-visitor" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-for-of@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.0.0-beta.42.tgz#acf51c5986050e1aff054c8d2a95ef3f6bec153e" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-function-name@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.0.0-beta.42.tgz#1eb004a9abde01010d47ec7629d46b1e4e2c6228" + dependencies: + "@babel/helper-function-name" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-literals@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-literals/-/plugin-transform-literals-7.0.0-beta.42.tgz#61a34a82d757be4ddf937eda4b2d6c36b63b9c4e" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-modules-amd@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.0.0-beta.42.tgz#f4c634f49b5051abf6cefcbae100b41ba1369eb6" + dependencies: + "@babel/helper-module-transforms" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-modules-commonjs@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.0.0-beta.42.tgz#bdfb30e194c8841ec3ddd8a011974102d0d74afc" + dependencies: + "@babel/helper-module-transforms" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-simple-access" "7.0.0-beta.42" + +"@babel/plugin-transform-modules-systemjs@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.0.0-beta.42.tgz#424e25542b4d6ea6ea5f933df6ec9c345358b070" + dependencies: + "@babel/helper-hoist-variables" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-modules-umd@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.0.0-beta.42.tgz#2fbad368c83471c76f8dcace98492e4e3fdddc76" + dependencies: + "@babel/helper-module-transforms" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-new-target@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.0.0-beta.42.tgz#8b309b67b6a92fd1ab6cb93bea0fa12359795c20" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-object-super@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.0.0-beta.42.tgz#f19ae6007ff675ea0f52499d09f73ae9f96db1a0" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-replace-supers" "7.0.0-beta.42" + +"@babel/plugin-transform-parameters@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.0.0-beta.42.tgz#58434afb01afb0a3aa82402142807fb70eb3fb56" + dependencies: + "@babel/helper-call-delegate" "7.0.0-beta.42" + "@babel/helper-get-function-arity" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-regenerator@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.0.0-beta.42.tgz#af164751340a7e513c53e614c6f1f90279e459ef" + dependencies: + regenerator-transform "^0.12.3" + +"@babel/plugin-transform-shorthand-properties@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.0.0-beta.42.tgz#fb0b66f4afd4a5a67d9d84a85cbf6f7fef0a7b4f" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-spread@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-spread/-/plugin-transform-spread-7.0.0-beta.42.tgz#4d7dde45c95e55d418477e1ea95dd6d9b71f15e4" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-sticky-regex@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.0.0-beta.42.tgz#b0a5585ec24013dd6f0b1b8cc7a73423c4bc082f" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-regex" "7.0.0-beta.42" + +"@babel/plugin-transform-template-literals@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.0.0-beta.42.tgz#7f05c5c003da8e485462cfc36f9d482b0a9a75df" + dependencies: + "@babel/helper-annotate-as-pure" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-typeof-symbol@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.0.0-beta.42.tgz#7d93fcd194db78b839488cddddefbaa46032e327" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + +"@babel/plugin-transform-unicode-regex@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.0.0-beta.42.tgz#1e7bdcf678d9a9066d06e6d334ab41ca11ca00ad" + dependencies: + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/helper-regex" "7.0.0-beta.42" + regexpu-core "^4.1.3" + +"@babel/preset-env@^7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/preset-env/-/preset-env-7.0.0-beta.42.tgz#671e688057c010b22a7811b965f7da5d79c472d3" + dependencies: + "@babel/helper-module-imports" "7.0.0-beta.42" + "@babel/helper-plugin-utils" "7.0.0-beta.42" + "@babel/plugin-proposal-async-generator-functions" "7.0.0-beta.42" + "@babel/plugin-proposal-object-rest-spread" "7.0.0-beta.42" + "@babel/plugin-proposal-optional-catch-binding" "7.0.0-beta.42" + "@babel/plugin-proposal-unicode-property-regex" "7.0.0-beta.42" + "@babel/plugin-syntax-async-generators" "7.0.0-beta.42" + "@babel/plugin-syntax-object-rest-spread" "7.0.0-beta.42" + "@babel/plugin-syntax-optional-catch-binding" "7.0.0-beta.42" + "@babel/plugin-transform-arrow-functions" "7.0.0-beta.42" + "@babel/plugin-transform-async-to-generator" "7.0.0-beta.42" + "@babel/plugin-transform-block-scoped-functions" "7.0.0-beta.42" + "@babel/plugin-transform-block-scoping" "7.0.0-beta.42" + "@babel/plugin-transform-classes" "7.0.0-beta.42" + "@babel/plugin-transform-computed-properties" "7.0.0-beta.42" + "@babel/plugin-transform-destructuring" "7.0.0-beta.42" + "@babel/plugin-transform-dotall-regex" "7.0.0-beta.42" + "@babel/plugin-transform-duplicate-keys" "7.0.0-beta.42" + "@babel/plugin-transform-exponentiation-operator" "7.0.0-beta.42" + "@babel/plugin-transform-for-of" "7.0.0-beta.42" + "@babel/plugin-transform-function-name" "7.0.0-beta.42" + "@babel/plugin-transform-literals" "7.0.0-beta.42" + "@babel/plugin-transform-modules-amd" "7.0.0-beta.42" + "@babel/plugin-transform-modules-commonjs" "7.0.0-beta.42" + "@babel/plugin-transform-modules-systemjs" "7.0.0-beta.42" + "@babel/plugin-transform-modules-umd" "7.0.0-beta.42" + "@babel/plugin-transform-new-target" "7.0.0-beta.42" + "@babel/plugin-transform-object-super" "7.0.0-beta.42" + "@babel/plugin-transform-parameters" "7.0.0-beta.42" + "@babel/plugin-transform-regenerator" "7.0.0-beta.42" + "@babel/plugin-transform-shorthand-properties" "7.0.0-beta.42" + "@babel/plugin-transform-spread" "7.0.0-beta.42" + "@babel/plugin-transform-sticky-regex" "7.0.0-beta.42" + "@babel/plugin-transform-template-literals" "7.0.0-beta.42" + "@babel/plugin-transform-typeof-symbol" "7.0.0-beta.42" + "@babel/plugin-transform-unicode-regex" "7.0.0-beta.42" + browserslist "^3.0.0" + invariant "^2.2.2" + semver "^5.3.0" + +"@babel/template@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.0.0-beta.42.tgz#7186d4e70d44cdec975049ba0a73bdaf5cdee052" + dependencies: + "@babel/code-frame" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + babylon "7.0.0-beta.42" + lodash "^4.2.0" + +"@babel/traverse@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.0.0-beta.42.tgz#f4bf4d1e33d41baf45205e2d0463591d57326285" + dependencies: + "@babel/code-frame" "7.0.0-beta.42" + "@babel/generator" "7.0.0-beta.42" + "@babel/helper-function-name" "7.0.0-beta.42" + "@babel/helper-split-export-declaration" "7.0.0-beta.42" + "@babel/types" "7.0.0-beta.42" + babylon "7.0.0-beta.42" + debug "^3.1.0" + globals "^11.1.0" + invariant "^2.2.0" + lodash "^4.2.0" + +"@babel/types@7.0.0-beta.42": + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.0.0-beta.42.tgz#1e2118767684880f6963801b272fd2b3348efacc" + dependencies: + esutils "^2.0.2" + lodash "^4.2.0" + to-fast-properties "^2.0.0" + abbrev@1: version "1.1.1" resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" @@ -706,6 +1174,10 @@ babel-types@^6.19.0, babel-types@^6.24.1, babel-types@^6.26.0: lodash "^4.17.4" to-fast-properties "^1.0.3" +babylon@7.0.0-beta.42: + version "7.0.0-beta.42" + resolved "https://registry.yarnpkg.com/babylon/-/babylon-7.0.0-beta.42.tgz#67cfabcd4f3ec82999d29031ccdea89d0ba99657" + babylon@^6.18.0: version "6.18.0" resolved "https://registry.yarnpkg.com/babylon/-/babylon-6.18.0.tgz#af2f3b88fa6f5c1e4c634d1a0f8eac4f55b395e3" @@ -789,6 +1261,13 @@ browserslist@^2.0.0, browserslist@^2.1.2, browserslist@^2.11.3: caniuse-lite "^1.0.30000792" electron-to-chromium "^1.3.30" +browserslist@^3.0.0: + version "3.2.3" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-3.2.3.tgz#ad36e56a43daeacf4d2b7bb16441b7ac30be4510" + dependencies: + caniuse-lite "^1.0.30000819" + electron-to-chromium "^1.3.40" + builtin-modules@^1.0.0: version "1.1.1" resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-1.1.1.tgz#270f076c5a72c02f5b65a47df94c5fe3a278892f" @@ -848,6 +1327,10 @@ caniuse-lite@^1.0.0, caniuse-lite@^1.0.30000792, caniuse-lite@^1.0.30000805: version "1.0.30000815" resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30000815.tgz#3a4258e6850362185adb11b0d754a48402d35bf6" +caniuse-lite@^1.0.30000819: + version "1.0.30000820" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30000820.tgz#6e36ee75187a2c83d26d6504a1af47cc580324d2" + caseless@~0.11.0: version "0.11.0" resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.11.0.tgz#715b96ea9841593cc33067923f5ec60ebda4f7d7" @@ -1239,6 +1722,10 @@ electron-to-chromium@^1.2.7, electron-to-chromium@^1.3.30: version "1.3.39" resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.39.tgz#d7a4696409ca0995e2750156da612c221afad84d" +electron-to-chromium@^1.3.40: + version "1.3.40" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.40.tgz#1fbd6d97befd72b8a6f921dc38d22413d2f6fddf" + error-ex@^1.2.0, error-ex@^1.3.1: version "1.3.1" resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.1.tgz#f855a86ce61adc4e8621c3cda21e7a7612c3a8dc" @@ -1636,6 +2123,10 @@ globals@^11.0.1: version "11.3.0" resolved "https://registry.yarnpkg.com/globals/-/globals-11.3.0.tgz#e04fdb7b9796d8adac9c8f64c14837b2313378b0" +globals@^11.1.0: + version "11.4.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-11.4.0.tgz#b85c793349561c16076a3c13549238a27945f1bc" + globals@^9.18.0: version "9.18.0" resolved "https://registry.yarnpkg.com/globals/-/globals-9.18.0.tgz#aa3896b3e69b487f17e31ed2143d69a8e30c2d8a" @@ -1851,7 +2342,7 @@ inquirer@^3.0.6: strip-ansi "^4.0.0" through "^2.3.6" -invariant@^2.2.2: +invariant@^2.2.0, invariant@^2.2.2: version "2.2.4" resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.4.tgz#610f3c92c9359ce1db616e538008d23ff35158e6" dependencies: @@ -2083,6 +2574,10 @@ jsesc@^1.3.0: version "1.3.0" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-1.3.0.tgz#46c3fec8c1892b12b0833db9bc7622176dbab34b" +jsesc@^2.5.1: + version "2.5.1" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.1.tgz#e421a2a8e20d6b0819df28908f782526b96dd1fe" + jsesc@~0.5.0: version "0.5.0" resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" @@ -2229,7 +2724,7 @@ lodash.uniq@^4.5.0: version "4.5.0" resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773" -lodash@^4.0.0, lodash@^4.17.4, lodash@^4.3.0, lodash@~4.17.4: +lodash@^4.0.0, lodash@^4.17.4, lodash@^4.2.0, lodash@^4.3.0, lodash@~4.17.4: version "4.17.5" resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.5.tgz#99a92d65c0272debe8c96b6057bc8fbfa3bed511" @@ -3282,7 +3777,13 @@ reduce-function-call@^1.0.1, reduce-function-call@^1.0.2: dependencies: balanced-match "^0.4.2" -regenerate@^1.2.1: +regenerate-unicode-properties@^5.1.1: + version "5.1.3" + resolved "https://registry.yarnpkg.com/regenerate-unicode-properties/-/regenerate-unicode-properties-5.1.3.tgz#54f5891543468f36f2274b67c6bc4c033c27b308" + dependencies: + regenerate "^1.3.3" + +regenerate@^1.2.1, regenerate@^1.3.3: version "1.3.3" resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.3.3.tgz#0c336d3980553d755c39b586ae3b20aa49c82b7f" @@ -3298,6 +3799,12 @@ regenerator-transform@^0.10.0: babel-types "^6.19.0" private "^0.1.6" +regenerator-transform@^0.12.3: + version "0.12.3" + resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.12.3.tgz#459adfb64f6a27164ab991b7873f45ab969eca8b" + dependencies: + private "^0.1.6" + regex-cache@^0.4.2: version "0.4.4" resolved "https://registry.yarnpkg.com/regex-cache/-/regex-cache-0.4.4.tgz#75bdc58a2a1496cec48a12835bc54c8d562336dd" @@ -3316,16 +3823,37 @@ regexpu-core@^2.0.0: regjsgen "^0.2.0" regjsparser "^0.1.4" +regexpu-core@^4.1.3: + version "4.1.3" + resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-4.1.3.tgz#fb81616dbbc2a917a7419b33f8379144f51eb8d0" + dependencies: + regenerate "^1.3.3" + regenerate-unicode-properties "^5.1.1" + regjsgen "^0.3.0" + regjsparser "^0.2.1" + unicode-match-property-ecmascript "^1.0.3" + unicode-match-property-value-ecmascript "^1.0.1" + regjsgen@^0.2.0: version "0.2.0" resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.2.0.tgz#6c016adeac554f75823fe37ac05b92d5a4edb1f7" +regjsgen@^0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.3.0.tgz#0ee4a3e9276430cda25f1e789ea6c15b87b0cb43" + regjsparser@^0.1.4: version "0.1.5" resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.1.5.tgz#7ee8f84dc6fa792d3fd0ae228d24bd949ead205c" dependencies: jsesc "~0.5.0" +regjsparser@^0.2.1: + version "0.2.1" + resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.2.1.tgz#c3787553faf04e775c302102ef346d995000ec1c" + dependencies: + jsesc "~0.5.0" + remove-trailing-separator@^1.0.1: version "1.1.0" resolved "https://registry.yarnpkg.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz#c24bce2a283adad5bc3f58e0d48249b92379d8ef" @@ -3681,7 +4209,7 @@ source-map@^0.4.2: dependencies: amdefine ">=0.0.4" -source-map@^0.5.3, source-map@^0.5.6, source-map@^0.5.7, source-map@~0.5.1: +source-map@^0.5.0, source-map@^0.5.3, source-map@^0.5.6, source-map@^0.5.7, source-map@~0.5.1: version "0.5.7" resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" @@ -3904,6 +4432,10 @@ to-fast-properties@^1.0.3: version "1.0.3" resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-1.0.3.tgz#b83571fa4d8c25b82e231b06e3a3055de4ca1a47" +to-fast-properties@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" + tough-cookie@~2.3.0, tough-cookie@~2.3.3: version "2.3.4" resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.3.4.tgz#ec60cee38ac675063ffc97a5c18970578ee83655" @@ -3976,6 +4508,25 @@ ultron@1.0.x: version "1.0.2" resolved "https://registry.yarnpkg.com/ultron/-/ultron-1.0.2.tgz#ace116ab557cd197386a4e88f4685378c8b2e4fa" +unicode-canonical-property-names-ecmascript@^1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.3.tgz#f6119f417467593c0086357c85546b6ad5abc583" + +unicode-match-property-ecmascript@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.3.tgz#db9b1cb4ffc67e0c5583780b1b59370e4cbe97b9" + dependencies: + unicode-canonical-property-names-ecmascript "^1.0.2" + unicode-property-aliases-ecmascript "^1.0.3" + +unicode-match-property-value-ecmascript@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.0.1.tgz#fea059120a016f403afd3bf586162b4db03e0604" + +unicode-property-aliases-ecmascript@^1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.0.3.tgz#ac3522583b9e630580f916635333e00c5ead690d" + uniq@^1.0.1: version "1.0.1" resolved "https://registry.yarnpkg.com/uniq/-/uniq-1.0.1.tgz#b31c5ae8254844a3a8281541ce2b04b865a734ff"