sakuya/node_modules/frappe-charts/dist/frappe-charts.min.esm.js.map
2022-04-10 00:37:53 +08:00

1 line
184 KiB
Plaintext

{"version":3,"file":"frappe-charts.min.esm.js","sources":["../node_modules/style-inject/dist/style-inject.es.js","../src/js/utils/dom.js","../src/js/utils/constants.js","../src/js/utils/helpers.js","../src/js/utils/draw-utils.js","../src/js/utils/colors.js","../src/js/utils/draw.js","../src/js/utils/animate.js","../src/js/utils/animation.js","../src/js/utils/export.js","../src/js/utils/date-utils.js","../src/js/objects/ChartComponents.js","../src/js/utils/intervals.js","../src/js/utils/axis-chart-utils.js","../src/js/chart.js","../src/js/objects/SvgTip.js","../src/css/chartsCss.js","../src/js/charts/BaseChart.js","../src/js/charts/AggregationChart.js","../src/js/charts/PercentageChart.js","../src/js/charts/PieChart.js","../src/js/charts/Heatmap.js","../src/js/charts/AxisChart.js","../src/js/charts/DonutChart.js"],"sourcesContent":["function styleInject(css, ref) {\n if ( ref === void 0 ) ref = {};\n var insertAt = ref.insertAt;\n\n if (!css || typeof document === 'undefined') { return; }\n\n var head = document.head || document.getElementsByTagName('head')[0];\n var style = document.createElement('style');\n style.type = 'text/css';\n\n if (insertAt === 'top') {\n if (head.firstChild) {\n head.insertBefore(style, head.firstChild);\n } else {\n head.appendChild(style);\n }\n } else {\n head.appendChild(style);\n }\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n style.appendChild(document.createTextNode(css));\n }\n}\n\nexport default styleInject;\n","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\n// https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement/offsetParent\n// an element's offsetParent property will return null whenever it, or any of its parents,\n// is hidden via the display style property.\nexport function isHidden(el) {\n\treturn (el.offsetParent === null);\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","export const ALL_CHART_TYPES = ['line', 'scatter', 'bar', 'percentage', 'heatmap', 'pie'];\n\nexport const COMPATIBLE_CHARTS = {\n\tbar: ['line', 'scatter', 'percentage', 'pie'],\n\tline: ['scatter', 'bar', 'percentage', 'pie'],\n\tpie: ['line', 'scatter', 'percentage', 'bar'],\n\tpercentage: ['bar', 'line', 'scatter', 'pie'],\n\theatmap: []\n};\n\nexport const DATA_COLOR_DIVISIONS = {\n\tbar: 'datasets',\n\tline: 'datasets',\n\tpie: 'labels',\n\tpercentage: 'labels',\n\theatmap: HEATMAP_DISTRIBUTION_SIZE\n};\n\nexport const BASE_MEASURES = {\n\tmargins: {\n\t\ttop: 10,\n\t\tbottom: 10,\n\t\tleft: 20,\n\t\tright: 20\n\t},\n\tpaddings: {\n\t\ttop: 20,\n\t\tbottom: 40,\n\t\tleft: 30,\n\t\tright: 10\n\t},\n\n\tbaseHeight: 240,\n\ttitleHeight: 20,\n\tlegendHeight: 30,\n\n\ttitleFontSize: 12,\n};\n\nexport function getTopOffset(m) {\n\treturn m.titleHeight + m.margins.top + m.paddings.top;\n}\n\nexport function getLeftOffset(m) {\n\treturn m.margins.left + m.paddings.left;\n}\n\nexport function getExtraHeight(m) {\n\tlet totalExtraHeight = m.margins.top + m.margins.bottom\n\t\t+ m.paddings.top + m.paddings.bottom\n\t\t+ m.titleHeight + m.legendHeight;\n\treturn totalExtraHeight;\n}\n\nexport function getExtraWidth(m) {\n\tlet totalExtraWidth = m.margins.left + m.margins.right\n\t\t+ m.paddings.left + m.paddings.right;\n\n\treturn totalExtraWidth;\n}\n\nexport const INIT_CHART_UPDATE_TIMEOUT = 700;\nexport const CHART_POST_ANIMATE_TIMEOUT = 400;\n\nexport const 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.00;\n\nexport const LINE_CHART_DOT_SIZE = 4;\nexport const DOT_OVERLAY_SIZE_INCR = 4;\n\nexport const PERCENTAGE_BAR_DEFAULT_HEIGHT = 20;\nexport const PERCENTAGE_BAR_DEFAULT_DEPTH = 2;\n\n// Fixed 5-color theme,\n// More colors are difficult to parse visually\nexport const HEATMAP_DISTRIBUTION_SIZE = 5;\n\nexport const HEATMAP_SQUARE_SIZE = 10;\nexport const HEATMAP_GUTTER_SIZE = 2;\n\nexport const DEFAULT_CHAR_WIDTH = 7;\n\nexport const TOOLTIP_POINTER_TRIANGLE_HEIGHT = 5;\n\nconst DEFAULT_CHART_COLORS = ['light-blue', 'blue', 'violet', 'red', 'orange',\n\t'yellow', 'green', 'light-green', 'purple', 'magenta', 'light-grey', 'dark-grey'];\nconst HEATMAP_COLORS_GREEN = ['#ebedf0', '#c6e48b', '#7bc96f', '#239a3b', '#196127'];\nexport const HEATMAP_COLORS_BLUE = ['#ebedf0', '#c0ddf9', '#73b3f3', '#3886e1', '#17459e'];\nexport const HEATMAP_COLORS_YELLOW = ['#ebedf0', '#fdf436', '#ffc700', '#ff9100', '#06001c'];\n\nexport const DEFAULT_COLORS = {\n\tbar: DEFAULT_CHART_COLORS,\n\tline: DEFAULT_CHART_COLORS,\n\tpie: DEFAULT_CHART_COLORS,\n\tpercentage: DEFAULT_CHART_COLORS,\n\theatmap: HEATMAP_COLORS_GREEN,\n\tdonut: DEFAULT_CHART_COLORS\n};\n\n// Universal constants\nexport const ANGLE_RATIO = Math.PI / 180;\nexport const FULL_ANGLE = 360;\n","import { ANGLE_RATIO } from './constants';\n\n/**\n * Returns the value of a number upto 2 decimal places.\n * @param {Number} d Any number\n */\nexport function floatTwo(d) {\n\treturn parseFloat(d.toFixed(2));\n}\n\n/**\n * Returns whether or not two given arrays are equal.\n * @param {Array} arr1 First array\n * @param {Array} arr2 Second array\n */\nexport function arraysEqual(arr1, arr2) {\n\tif(arr1.length !== arr2.length) return false;\n\tlet areEqual = true;\n\tarr1.map((d, i) => {\n\t\tif(arr2[i] !== d) areEqual = false;\n\t});\n\treturn areEqual;\n}\n\n/**\n * Shuffles array in place. ES6 version\n * @param {Array} array An array containing the items.\n */\nexport function shuffle(array) {\n\t// Awesomeness: https://bost.ocks.org/mike/shuffle/\n\t// https://stackoverflow.com/a/2450976/6495043\n\t// https://stackoverflow.com/questions/6274339/how-can-i-shuffle-an-array?noredirect=1&lq=1\n\n\tfor (let i = array.length - 1; i > 0; i--) {\n\t\tlet j = Math.floor(Math.random() * (i + 1));\n\t\t[array[i], array[j]] = [array[j], array[i]];\n\t}\n\n\treturn array;\n}\n\n/**\n * Fill an array with extra points\n * @param {Array} array Array\n * @param {Number} count number of filler elements\n * @param {Object} element element to fill with\n * @param {Boolean} start fill at start?\n */\nexport function fillArray(array, count, element, start=false) {\n\tif(!element) {\n\t\telement = start ? array[0] : array[array.length - 1];\n\t}\n\tlet fillerArray = new Array(Math.abs(count)).fill(element);\n\tarray = start ? fillerArray.concat(array) : array.concat(fillerArray);\n\treturn array;\n}\n\n/**\n * Returns pixel width of string.\n * @param {String} string\n * @param {Number} charWidth Width of single char in pixels\n */\nexport function getStringWidth(string, charWidth) {\n\treturn (string+\"\").length * charWidth;\n}\n\nexport function bindChange(obj, getFn, setFn) {\n\treturn new Proxy(obj, {\n\t\tset: function(target, prop, value) {\n\t\t\tsetFn();\n\t\t\treturn Reflect.set(target, prop, value);\n\t\t},\n\t\tget: function(target, prop) {\n\t\t\tgetFn();\n\t\t\treturn Reflect.get(target, prop);\n\t\t}\n\t});\n}\n\n// https://stackoverflow.com/a/29325222\nexport function getRandomBias(min, max, bias, influence) {\n\tconst range = max - min;\n\tconst biasValue = range * bias + min;\n\tvar rnd = Math.random() * range + min,\t\t// random in range\n\t\tmix = Math.random() * influence;\t\t// random mixer\n\treturn rnd * (1 - mix) + biasValue * mix;\t// mix full range and bias\n}\n\nexport function getPositionByAngle(angle, radius) {\n\treturn {\n\t\tx: Math.sin(angle * ANGLE_RATIO) * radius,\n\t\ty: Math.cos(angle * ANGLE_RATIO) * radius,\n\t};\n}\n\n/**\n * Check if a number is valid for svg attributes\n * @param {object} candidate Candidate to test\n * @param {Boolean} nonNegative flag to treat negative number as invalid\n */\nexport function isValidNumber(candidate, nonNegative=false) {\n\tif (Number.isNaN(candidate)) return false;\n\telse if (candidate === undefined) return false;\n\telse if (!Number.isFinite(candidate)) return false;\n\telse if (nonNegative && candidate < 0) return false;\n\telse return true;\n}\n\n/**\n * Round a number to the closes precision, max max precision 4\n * @param {Number} d Any Number\n */\nexport function round(d) {\n\t// https://floating-point-gui.de/\n\t// https://www.jacklmoore.com/notes/rounding-in-javascript/\n\treturn Number(Math.round(d + 'e4') + 'e-4');\n}\n\n/**\n * Creates a deep clone of an object\n * @param {Object} candidate Any Object\n */\n export function deepClone(candidate) {\n\tlet cloned, value, key;\n \n\tif (candidate instanceof Date) {\n\t return new Date(candidate.getTime());\n\t}\n \n\tif (typeof candidate !== \"object\" || candidate === null) {\n\t return candidate;\n\t}\n \n\tcloned = Array.isArray(candidate) ? [] : {};\n \n\tfor (key in candidate) {\n\t value = candidate[key];\n \n\t cloned[key] = deepClone(value);\n\t}\n \n\treturn cloned;\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\nexport function truncateString(txt, len) {\n\tif (!txt) {\n\t\treturn;\n\t}\n\tif (txt.length > len) {\n\t\treturn txt.slice(0, len-3) + '...';\n\t} else {\n\t\treturn txt;\n\t}\n}\n\nexport function shortenLargeNumber(label) {\n\tlet number;\n\tif (typeof label === 'number') number = label;\n\telse if (typeof label === 'string') {\n\t\tnumber = Number(label);\n\t\tif (Number.isNaN(number)) return label;\n\t}\n\n\t// Using absolute since log wont work for negative numbers\n\tlet p = Math.floor(Math.log10(Math.abs(number)));\n\tif (p <= 2) return number; // Return as is for a 3 digit number of less\n\tlet\tl = Math.floor(p / 3);\n\tlet shortened = (Math.pow(10, p - l * 3) * +(number / Math.pow(10, p)).toFixed(1));\n\n\t// Correct for floating point error upto 2 decimal places\n\treturn Math.round(shortened*100)/100 + ' ' + ['', 'K', 'M', 'B', 'T'][l];\n}\n\n// cubic bezier curve calculation (from example by François Romain)\nexport function getSplineCurvePointsStr(xList, yList) {\n\n\tlet points=[];\n\tfor(let i=0;i<xList.length;i++){\n\t\tpoints.push([xList[i], yList[i]]);\n\t}\n\n\tlet smoothing = 0.2;\n\tlet line = (pointA, pointB) => {\n\t\tlet lengthX = pointB[0] - pointA[0];\n\t\tlet lengthY = pointB[1] - pointA[1];\n\t\treturn {\n\t\t\tlength: Math.sqrt(Math.pow(lengthX, 2) + Math.pow(lengthY, 2)),\n\t\t\tangle: Math.atan2(lengthY, lengthX)\n\t\t};\n\t};\n \n\tlet controlPoint = (current, previous, next, reverse) => {\n\t\tlet p = previous || current;\n\t\tlet n = next || current;\n\t\tlet o = line(p, n);\n\t\tlet angle = o.angle + (reverse ? Math.PI : 0);\n\t\tlet length = o.length * smoothing;\n\t\tlet x = current[0] + Math.cos(angle) * length;\n\t\tlet y = current[1] + Math.sin(angle) * length;\n\t\treturn [x, y];\n\t};\n \n\tlet bezierCommand = (point, i, a) => {\n\t\tlet cps = controlPoint(a[i - 1], a[i - 2], point);\n\t\tlet cpe = controlPoint(point, a[i - 1], a[i + 1], true);\n\t\treturn `C ${cps[0]},${cps[1]} ${cpe[0]},${cpe[1]} ${point[0]},${point[1]}`;\n\t};\n \n\tlet pointStr = (points, command) => {\n\t\treturn points.reduce((acc, point, i, a) => i === 0\n\t\t\t? `${point[0]},${point[1]}`\n\t\t\t: `${acc} ${command(point, i, a)}`, '');\n\t};\n \n\treturn pointStr(points, bezierCommand);\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/32685393\n\tlet HEX_RE = /(^\\s*)(#)((?:[A-Fa-f0-9]{3}){1,2})$/i;\n\tlet RGB_RE = /(^\\s*)(rgb|hsl)(a?)[(]\\s*([\\d.]+\\s*%?)\\s*,\\s*([\\d.]+\\s*%?)\\s*,\\s*([\\d.]+\\s*%?)\\s*(?:,\\s*([\\d.]+)\\s*)?[)]$/i;\n\treturn HEX_RE.test(string) || RGB_RE.test(string);\n}\n\nexport const getColor = (color) => {\n\t// When RGB color, convert to hexadecimal (alpha value is omitted)\n\tif((/rgb[a]{0,1}\\([\\d, ]+\\)/gim).test(color)) {\n\t\treturn (/\\D+(\\d*)\\D+(\\d*)\\D+(\\d*)/gim).exec(color)\n\t\t\t.map((x, i) => (i !== 0 ? Number(x).toString(16) : '#'))\n\t\t\t.reduce((c, ch) => `${c}${ch}`);\n\t}\n\treturn PRESET_COLOR_MAP[color] || color;\n};\n","import { getBarHeightAndYAttr, truncateString, shortenLargeNumber, getSplineCurvePointsStr } from './draw-utils';\nimport { getStringWidth, isValidNumber } 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;\nconst LABEL_MAX_CHARS = 15;\nexport const FONT_SIZE = 10;\nconst BASE_LINE_COLOR = '#dadada';\nconst FONT_FILL = '#555b51';\n\nfunction $(expr, con) {\n\treturn typeof expr === \"string\"? (con || document).querySelector(expr) : expr || null;\n}\n\nexport function createSVG(tag, o) {\n\tvar element = document.createElementNS(\"http://www.w3.org/2000/svg\", tag);\n\n\tfor (var i in o) {\n\t\tvar val = o[i];\n\n\t\tif (i === \"inside\") {\n\t\t\t$(val).appendChild(element);\n\t\t}\n\t\telse if (i === \"around\") {\n\t\t\tvar ref = $(val);\n\t\t\tref.parentNode.insertBefore(element, ref);\n\t\t\telement.appendChild(ref);\n\n\t\t} else if (i === \"styles\") {\n\t\t\tif(typeof val === \"object\") {\n\t\t\t\tObject.keys(val).map(prop => {\n\t\t\t\t\telement.style[prop] = val[prop];\n\t\t\t\t});\n\t\t\t}\n\t\t} else {\n\t\t\tif(i === \"className\") { i = \"class\"; }\n\t\t\tif(i === \"innerHTML\") {\n\t\t\t\telement['textContent'] = val;\n\t\t\t} else {\n\t\t\t\telement.setAttribute(i, val);\n\t\t\t}\n\t\t}\n\t}\n\n\treturn element;\n}\n\nfunction renderVerticalGradient(svgDefElem, gradientId) {\n\treturn createSVG('linearGradient', {\n\t\tinside: svgDefElem,\n\t\tid: gradientId,\n\t\tx1: 0,\n\t\tx2: 0,\n\t\ty1: 0,\n\t\ty2: 1\n\t});\n}\n\nfunction setGradientStop(gradElem, offset, color, opacity) {\n\treturn createSVG('stop', {\n\t\t'inside': gradElem,\n\t\t'style': `stop-color: ${color}`,\n\t\t'offset': offset,\n\t\t'stop-opacity': opacity\n\t});\n}\n\nexport function makeSVGContainer(parent, className, width, height) {\n\treturn createSVG('svg', {\n\t\tclassName: className,\n\t\tinside: parent,\n\t\twidth: width,\n\t\theight: height\n\t});\n}\n\nexport function makeSVGDefs(svgContainer) {\n\treturn createSVG('defs', {\n\t\tinside: svgContainer,\n\t});\n}\n\nexport function makeSVGGroup(className, transform='', parent=undefined) {\n\tlet args = {\n\t\tclassName: className,\n\t\ttransform: transform\n\t};\n\tif(parent) args.inside = parent;\n\treturn createSVG('g', args);\n}\n\nexport function wrapInSVGGroup(elements, className='') {\n\tlet g = createSVG('g', {\n\t\tclassName: className\n\t});\n\telements.forEach(e => g.appendChild(e));\n\treturn g;\n}\n\nexport function makePath(pathStr, className='', stroke='none', fill='none', strokeWidth=2) {\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\t'stroke-width': strokeWidth\n\t\t}\n\t});\n}\n\nexport function makeArcPathStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\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\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeCircleStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, midArc, arcEndY] = [center.x + endPosition.x, center.y * 2, center.y + endPosition.y];\n\treturn `M${center.x} ${center.y}\n\t\tL${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${midArc} z\n\t\tL${arcStartX} ${midArc}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY} z`;\n}\n\nexport function makeArcStrokePathStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\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${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY}`;\n}\n\nexport function makeStrokeCircleStr(startPosition, endPosition, center, radius, clockWise=1, largeArc=0){\n\tlet [arcStartX, arcStartY] = [center.x + startPosition.x, center.y + startPosition.y];\n\tlet [arcEndX, midArc, arcEndY] = [center.x + endPosition.x, radius * 2 + arcStartY, center.y + startPosition.y];\n\n\treturn `M${arcStartX} ${arcStartY}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${midArc}\n\t\tM${arcStartX} ${midArc}\n\t\tA ${radius} ${radius} 0 ${largeArc} ${clockWise ? 1 : 0}\n\t\t${arcEndX} ${arcEndY}`;\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, radius, 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\trx: radius,\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, truncate=false) {\n\tlabel = truncate ? truncateString(label, LABEL_MAX_CHARS) : label;\n\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, truncate=false) {\n\tlabel = truncate ? truncateString(label, LABEL_MAX_CHARS) : label;\n\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\tif (options.shortenNumbers) label = shortenLargeNumber(label);\n\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 (!isValidNumber(y)) y = 0;\n\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\tshortenNumbers: options.shortenNumbers\n\t});\n}\n\nexport function xLine(x, label, height, options={}) {\n\tif (!isValidNumber(x)) x = 0;\n\n\tif(!options.pos) options.pos = 'bottom';\n\tif(!options.offset) options.offset = 0;\n\tif(!options.mode) options.mode = 'span';\n\tif(!options.stroke) options.stroke = BASE_LINE_COLOR;\n\tif(!options.className) options.className = '';\n\n\t// Draw X axis line in span/tick mode with optional label\n\t// \ty2(span)\n\t// \t\t\t\t\t\t|\n\t// \t\t\t\t\t\t|\n\t//\t\t\t\tx line\t|\n\t//\t\t\t\t\t\t|\n\t// \t\t\t\t\t \t|\n\t// ---------------------+-- y2(tick)\n\t//\t\t\t\t\t\t|\n\t//\t\t\t\t\t\t\ty1\n\n\tlet y1 = height + AXIS_TICK_LENGTH;\n\tlet y2 = options.mode === 'span' ? -1 * AXIS_TICK_LENGTH : height;\n\n\tif(options.mode === 'tick' && options.pos === 'top') {\n\t\t// top axis ticks\n\t\ty1 = -1 * AXIS_TICK_LENGTH;\n\t\ty2 = 0;\n\t}\n\n\treturn makeVertLine(x, label, y1, y2, {\n\t\tstroke: options.stroke,\n\t\tclassName: options.className,\n\t\tlineType: options.lineType\n\t});\n}\n\nexport function yMarker(y, label, width, options={}) {\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label, 5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet line = makeHoriLine(y, '', 0, width, {\n\t\tstroke: options.stroke || BASE_LINE_COLOR,\n\t\tclassName: options.className || '',\n\t\tlineType: options.lineType\n\t});\n\n\tline.appendChild(labelSvg);\n\n\treturn line;\n}\n\nexport function yRegion(y1, y2, width, label, options={}) {\n\t// return a group\n\tlet height = y1 - y2;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`, // remove class\n\t\tstyles: {\n\t\t\tfill: `rgba(228, 234, 239, 0.49)`,\n\t\t\tstroke: BASE_LINE_COLOR,\n\t\t\t'stroke-dasharray': `${width}, ${height}`\n\t\t},\n\t\t// 'data-point-index': index,\n\t\tx: 0,\n\t\ty: 0,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tif(!options.labelPos) options.labelPos = 'right';\n\tlet x = options.labelPos === 'left' ? LABEL_MARGIN\n\t\t: width - getStringWidth(label+\"\", 4.5) - LABEL_MARGIN;\n\n\tlet labelSvg = createSVG('text', {\n\t\tclassName: 'chart-label',\n\t\tx: x,\n\t\ty: 0,\n\t\tdy: (FONT_SIZE / -2) + 'px',\n\t\t'font-size': FONT_SIZE + 'px',\n\t\t'text-anchor': 'start',\n\t\tinnerHTML: label+\"\"\n\t});\n\n\tlet region = createSVG('g', {\n\t\ttransform: `translate(0, ${y2})`\n\t});\n\n\tregion.appendChild(rect);\n\tregion.appendChild(labelSvg);\n\n\treturn region;\n}\n\nexport function datasetBar(x, yTop, width, color, label='', index=0, offset=0, meta={}) {\n\tlet [height, y] = getBarHeightAndYAttr(yTop, meta.zeroLine);\n\ty -= offset;\n\n\tif(height === 0) {\n\t\theight = meta.minHeight;\n\t\ty -= meta.minHeight;\n\t}\n\n\t// Preprocess numbers to avoid svg building errors\n\tif (!isValidNumber(x)) x = 0;\n\tif (!isValidNumber(y)) y = 0;\n\tif (!isValidNumber(height, true)) height = 0;\n\tif (!isValidNumber(width, true)) width = 0;\n\n\tlet rect = createSVG('rect', {\n\t\tclassName: `bar mini`,\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tx: x,\n\t\ty: y,\n\t\twidth: width,\n\t\theight: height\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn rect;\n\t} else {\n\t\trect.setAttribute('y', 0);\n\t\trect.setAttribute('x', 0);\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: width/2,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(rect);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function datasetDot(x, y, radius, color, label='', index=0) {\n\tlet dot = createSVG('circle', {\n\t\tstyle: `fill: ${color}`,\n\t\t'data-point-index': index,\n\t\tcx: x,\n\t\tcy: y,\n\t\tr: radius\n\t});\n\n\tlabel += \"\";\n\n\tif(!label && !label.length) {\n\t\treturn dot;\n\t} else {\n\t\tdot.setAttribute('cy', 0);\n\t\tdot.setAttribute('cx', 0);\n\n\t\tlet text = createSVG('text', {\n\t\t\tclassName: 'data-point-value',\n\t\t\tx: 0,\n\t\t\ty: 0,\n\t\t\tdy: (FONT_SIZE / 2 * -1 - radius) + 'px',\n\t\t\t'font-size': FONT_SIZE + 'px',\n\t\t\t'text-anchor': 'middle',\n\t\t\tinnerHTML: label\n\t\t});\n\n\t\tlet group = createSVG('g', {\n\t\t\t'data-point-index': index,\n\t\t\ttransform: `translate(${x}, ${y})`\n\t\t});\n\t\tgroup.appendChild(dot);\n\t\tgroup.appendChild(text);\n\n\t\treturn group;\n\t}\n}\n\nexport function getPaths(xList, yList, color, options={}, meta={}) {\n\tlet pointsList = yList.map((y, i) => (xList[i] + ',' + y));\n\tlet pointsStr = pointsList.join(\"L\");\n\n\t// Spline\n\tif (options.spline)\n\t\tpointsStr = getSplineCurvePointsStr(xList, yList);\n\n\tlet path = makePath(\"M\"+pointsStr, 'line-graph-path', color);\n\n\t// HeatLine\n\tif(options.heatline) {\n\t\tlet gradient_id = makeGradient(meta.svgDefs, color);\n\t\tpath.style.stroke = `url(#${gradient_id})`;\n\t}\n\n\tlet paths = {\n\t\tpath: path\n\t};\n\n\t// Region\n\tif(options.regionFill) {\n\t\tlet gradient_id_region = makeGradient(meta.svgDefs, color, true);\n\n\t\tlet pathStr = \"M\" + `${xList[0]},${meta.zeroLine}L` + pointsStr + `L${xList.slice(-1)[0]},${meta.zeroLine}`;\n\t\tpaths.region = makePath(pathStr, `region-fill`, 'none', `url(#${gradient_id_region})`);\n\t}\n\n\treturn paths;\n}\n\nexport let makeOverlay = {\n\t'bar': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\toverlay.style.fill = '#000000';\n\t\toverlay.style.opacity = '0.4';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'dot': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t},\n\n\t'heat_square': (unit) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet overlay = unit.cloneNode();\n\t\tlet radius = unit.getAttribute('r');\n\t\tlet fill = unit.getAttribute('fill');\n\t\toverlay.setAttribute('r', parseInt(radius) + DOT_OVERLAY_SIZE_INCR);\n\t\toverlay.setAttribute('fill', fill);\n\t\toverlay.style.opacity = '0.6';\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t\treturn overlay;\n\t}\n};\n\nexport let updateOverlay = {\n\t'bar': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'rect') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['x', 'y', 'width', 'height'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'dot': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n\n\t'heat_square': (unit, overlay) => {\n\t\tlet transformValue;\n\t\tif(unit.nodeName !== 'circle') {\n\t\t\ttransformValue = unit.getAttribute('transform');\n\t\t\tunit = unit.childNodes[0];\n\t\t}\n\t\tlet attributes = ['cx', 'cy'];\n\t\tObject.values(unit.attributes)\n\t\t\t.filter(attr => attributes.includes(attr.name) && attr.specified)\n\t\t\t.map(attr => {\n\t\t\t\toverlay.setAttribute(attr.name, attr.nodeValue);\n\t\t\t});\n\n\t\tif(transformValue) {\n\t\t\toverlay.setAttribute('transform', transformValue);\n\t\t}\n\t},\n};\n","import { getBarHeightAndYAttr, getSplineCurvePointsStr } 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, spline) {\n\tlet pathComponents = [];\n\tlet pointsStr = newYList.map((y, i) => (newXList[i] + ',' + y)).join(\"L\");\n\n\tif (spline)\n\t\tpointsStr = getSplineCurvePointsStr(newXList, newYList);\n\n\tconst animPath = [paths.path, {d:\"M\" + pointsStr}, 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 + pointsStr + 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\t\t\n\t\tif (parent) {\n\t\t\tparent.replaceChild(animElement, unit);\n\t\t}\n\t});\n\n\tlet animSvg = svgContainer.cloneNode(true);\n\n\tanimElements.map((animElement, i) => {\n\t\tif (animElement[1]) {\n\t\t\tanimElement[1].replaceChild(newElements[i], animElement[0]);\n\t\t\telements[i][0] = newElements[i];\n\t\t}\n\t});\n\n\treturn animSvg;\n}\n\nexport function runSMILAnimation(parent, svgElement, elementsToAnimate) {\n\tif(elementsToAnimate.length === 0) return;\n\n\tlet animSvgElement = animateSVG(svgElement, elementsToAnimate);\n\tif(svgElement.parentNode == parent) {\n\t\tparent.removeChild(svgElement);\n\t\tparent.appendChild(animSvgElement);\n\n\t}\n\n\t// Replace the new svgElement (data has already been replaced)\n\tsetTimeout(() => {\n\t\tif(animSvgElement.parentNode == parent) {\n\t\t\tparent.removeChild(animSvgElement);\n\t\t\tparent.appendChild(svgElement);\n\t\t}\n\t}, REPLACE_ALL_NEW_DUR);\n}\n","import { $ } from '../utils/dom';\nimport { CSSTEXT } from '../../css/chartsCss';\n\nexport function downloadFile(filename, data) {\n\tvar a = document.createElement('a');\n\ta.style = \"display: none\";\n\tvar blob = new Blob(data, {type: \"image/svg+xml; charset=utf-8\"});\n\tvar url = window.URL.createObjectURL(blob);\n\ta.href = url;\n\ta.download = filename;\n\tdocument.body.appendChild(a);\n\ta.click();\n\tsetTimeout(function(){\n\t\tdocument.body.removeChild(a);\n\t\twindow.URL.revokeObjectURL(url);\n\t}, 300);\n}\n\nexport function prepareForExport(svg) {\n\tlet clone = svg.cloneNode(true);\n\tclone.classList.add('chart-container');\n\tclone.setAttribute('xmlns', \"http://www.w3.org/2000/svg\");\n\tclone.setAttribute('xmlns:xlink', \"http://www.w3.org/1999/xlink\");\n\tlet styleEl = $.create('style', {\n\t\t'innerHTML': CSSTEXT\n\t});\n\tclone.insertBefore(styleEl, clone.firstChild);\n\n\tlet container = $.create('div');\n\tcontainer.appendChild(clone);\n\n\treturn container.innerHTML;\n}\n","// Playing around with dates\n\nexport const NO_OF_YEAR_MONTHS = 12;\nexport const NO_OF_DAYS_IN_WEEK = 7;\nexport const DAYS_IN_YEAR = 375;\nexport const NO_OF_MILLIS = 1000;\nexport const SEC_IN_DAY = 86400;\n\nexport const MONTH_NAMES = [\"January\", \"February\", \"March\", \"April\", \"May\",\n\t\"June\", \"July\", \"August\", \"September\", \"October\", \"November\", \"December\"];\nexport const MONTH_NAMES_SHORT = [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\",\n\t\"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"];\n\nexport const DAY_NAMES_SHORT = [\"Sun\", \"Mon\", \"Tue\", \"Wed\", \"Thu\", \"Fri\", \"Sat\"];\nexport const DAY_NAMES = [\"Sunday\", \"Monday\", \"Tuesday\", \"Wednesday\",\n\t\"Thursday\", \"Friday\", \"Saturday\"];\n\n// https://stackoverflow.com/a/11252167/6495043\nfunction treatAsUtc(date) {\n\tlet result = new Date(date);\n\tresult.setMinutes(result.getMinutes() - result.getTimezoneOffset());\n\treturn result;\n}\n\nexport function getYyyyMmDd(date) {\n\tlet dd = date.getDate();\n\tlet mm = date.getMonth() + 1; // getMonth() is zero-based\n\treturn [\n\t\tdate.getFullYear(),\n\t\t(mm>9 ? '' : '0') + mm,\n\t\t(dd>9 ? '' : '0') + dd\n\t].join('-');\n}\n\nexport function clone(date) {\n\treturn new Date(date.getTime());\n}\n\nexport function timestampSec(date) {\n\treturn date.getTime()/NO_OF_MILLIS;\n}\n\nexport function timestampToMidnight(timestamp, roundAhead = false) {\n\tlet midnightTs = Math.floor(timestamp - (timestamp % SEC_IN_DAY));\n\tif(roundAhead) {\n\t\treturn midnightTs + SEC_IN_DAY;\n\t}\n\treturn midnightTs;\n}\n\n// export function getMonthsBetween(startDate, endDate) {}\n\nexport function getWeeksBetween(startDate, endDate) {\n\tlet weekStartDate = setDayToSunday(startDate);\n\treturn Math.ceil(getDaysBetween(weekStartDate, endDate) / NO_OF_DAYS_IN_WEEK);\n}\n\nexport function getDaysBetween(startDate, endDate) {\n\tlet millisecondsPerDay = SEC_IN_DAY * NO_OF_MILLIS;\n\treturn (treatAsUtc(endDate) - treatAsUtc(startDate)) / millisecondsPerDay;\n}\n\nexport function areInSameMonth(startDate, endDate) {\n\treturn startDate.getMonth() === endDate.getMonth()\n\t\t&& startDate.getFullYear() === endDate.getFullYear();\n}\n\nexport function getMonthName(i, short=false) {\n\tlet monthName = MONTH_NAMES[i];\n\treturn short ? monthName.slice(0, 3) : monthName;\n}\n\nexport function getLastDateInMonth (month, year) {\n\treturn new Date(year, month + 1, 0); // 0: last day in previous month\n}\n\n// mutates\nexport function setDayToSunday(date) {\n\tlet newDate = clone(date);\n\tconst day = newDate.getDay();\n\tif(day !== 0) {\n\t\taddDays(newDate, (-1) * day);\n\t}\n\treturn newDate;\n}\n\n// mutates\nexport function addDays(date, numberOfDays) {\n\tdate.setDate(date.getDate() + numberOfDays);\n}\n","import { makeSVGGroup } from '../utils/draw';\nimport { makeText, makePath, xLine, yLine, yMarker, yRegion, datasetBar, datasetDot, percentageBar, getPaths, heatSquare } from '../utils/draw';\nimport { equilizeNoOfElements } from '../utils/draw-utils';\nimport { translateHoriLine, translateVertLine, animateRegion, animateBar,\n\tanimateDot, animatePath, animatePathStr } from '../utils/animate';\nimport { getMonthName } from '../utils/date-utils';\n\nclass ChartComponent {\n\tconstructor({\n\t\tlayerClass = '',\n\t\tlayerTransform = '',\n\t\tconstants,\n\n\t\tgetData,\n\t\tmakeElements,\n\t\tanimateElements\n\t}) {\n\t\tthis.layerTransform = layerTransform;\n\t\tthis.constants = constants;\n\n\t\tthis.makeElements = makeElements;\n\t\tthis.getData = getData;\n\n\t\tthis.animateElements = animateElements;\n\n\t\tthis.store = [];\n\t\tthis.labels = [];\n\n\t\tthis.layerClass = layerClass;\n\t\tthis.layerClass = typeof(this.layerClass) === 'function'\n\t\t\t? this.layerClass() : this.layerClass;\n\n\t\tthis.refresh();\n\t}\n\n\trefresh(data) {\n\t\tthis.data = data || this.getData();\n\t}\n\n\tsetup(parent) {\n\t\tthis.layer = makeSVGGroup(this.layerClass, this.layerTransform, parent);\n\t}\n\n\tmake() {\n\t\tthis.render(this.data);\n\t\tthis.oldData = this.data;\n\t}\n\n\trender(data) {\n\t\tthis.store = this.makeElements(data);\n\n\t\tthis.layer.textContent = '';\n\t\tthis.store.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t\tthis.labels.forEach(element => {\n\t\t\tthis.layer.appendChild(element);\n\t\t});\n\t}\n\n\tupdate(animate = true) {\n\t\tthis.refresh();\n\t\tlet animateElements = [];\n\t\tif(animate) {\n\t\t\tanimateElements = this.animateElements(this.data) || [];\n\t\t}\n\t\treturn animateElements;\n\t}\n}\n\nlet componentConfigs = {\n\tdonutSlices: {\n\t\tlayerClass: 'donut-slices',\n\t\tmakeElements(data) {\n\t\t\treturn data.sliceStrings.map((s, i) => {\n\t\t\t\tlet slice = makePath(s, 'donut-path', data.colors[i], 'none', data.strokeWidth);\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) => animatePathStr(slice, newData.sliceStrings[i]));\n\t\t},\n\t},\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, shortenNumbers: this.constants.shortenNumbers})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.labels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.labels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tlabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\txAxis: {\n\t\tlayerClass: 'x axis',\n\t\tmakeElements(data) {\n\t\t\treturn data.positions.map((position, i) =>\n\t\t\t\txLine(position, data.calcLabels[i], this.constants.height,\n\t\t\t\t\t{mode: this.constants.mode, pos: this.constants.pos})\n\t\t\t);\n\t\t},\n\n\t\tanimateElements(newData) {\n\t\t\tlet newPos = newData.positions;\n\t\t\tlet newLabels = newData.calcLabels;\n\t\t\tlet oldPos = this.oldData.positions;\n\t\t\tlet oldLabels = this.oldData.calcLabels;\n\n\t\t\t[oldPos, newPos] = equilizeNoOfElements(oldPos, newPos);\n\t\t\t[oldLabels, newLabels] = equilizeNoOfElements(oldLabels, newLabels);\n\n\t\t\tthis.render({\n\t\t\t\tpositions: oldPos,\n\t\t\t\tcalcLabels: newLabels\n\t\t\t});\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateVertLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyMarkers: {\n\t\tlayerClass: 'y-markers',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(m =>\n\t\t\t\tyMarker(m.position, m.label, this.constants.width,\n\t\t\t\t\t{labelPos: m.options.labelPos, mode: 'span', lineType: 'dashed'})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.position);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.position);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tposition: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\treturn this.store.map((line, i) => {\n\t\t\t\treturn translateHoriLine(\n\t\t\t\t\tline, newPos[i], oldPos[i]\n\t\t\t\t);\n\t\t\t});\n\t\t}\n\t},\n\n\tyRegions: {\n\t\tlayerClass: 'y-regions',\n\t\tmakeElements(data) {\n\t\t\treturn data.map(r =>\n\t\t\t\tyRegion(r.startPos, r.endPos, this.constants.width,\n\t\t\t\t\tr.label, {labelPos: r.options.labelPos})\n\t\t\t);\n\t\t},\n\t\tanimateElements(newData) {\n\t\t\t[this.oldData, newData] = equilizeNoOfElements(this.oldData, newData);\n\n\t\t\tlet newPos = newData.map(d => d.endPos);\n\t\t\tlet newLabels = newData.map(d => d.label);\n\t\t\tlet newStarts = newData.map(d => d.startPos);\n\t\t\tlet newOptions = newData.map(d => d.options);\n\n\t\t\tlet oldPos = this.oldData.map(d => d.endPos);\n\t\t\tlet oldStarts = this.oldData.map(d => d.startPos);\n\n\t\t\tthis.render(oldPos.map((pos, i) => {\n\t\t\t\treturn {\n\t\t\t\t\tstartPos: oldStarts[i],\n\t\t\t\t\tendPos: oldPos[i],\n\t\t\t\t\tlabel: newLabels[i],\n\t\t\t\t\toptions: newOptions[i]\n\t\t\t\t};\n\t\t\t}));\n\n\t\t\tlet animateElements = [];\n\n\t\t\tthis.store.map((rectGroup, i) => {\n\t\t\t\tanimateElements = animateElements.concat(animateRegion(\n\t\t\t\t\trectGroup, newStarts[i], newPos[i], oldPos[i]\n\t\t\t\t));\n\t\t\t});\n\n\t\t\treturn animateElements;\n\t\t}\n\t},\n\n\theatDomain: {\n\t\tlayerClass: function() { return 'heat-domain domain-' + this.constants.index; },\n\t\tmakeElements(data) {\n\t\t\tlet {index, colWidth, rowHeight, squareSize, radius, xTranslate} = this.constants;\n\t\t\tlet monthNameHeight = -12;\n\t\t\tlet x = xTranslate, y = 0;\n\n\t\t\tthis.serializedSubDomains = [];\n\n\t\t\tdata.cols.map((week, weekNo) => {\n\t\t\t\tif(weekNo === 1) {\n\t\t\t\t\tthis.labels.push(\n\t\t\t\t\t\tmakeText('domain-name', x, monthNameHeight, getMonthName(index, true).toUpperCase(),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tfontSize: 9\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t)\n\t\t\t\t\t);\n\t\t\t\t}\n\t\t\t\tweek.map((day, i) => {\n\t\t\t\t\tif(day.fill) {\n\t\t\t\t\t\tlet data = {\n\t\t\t\t\t\t\t'data-date': day.yyyyMmDd,\n\t\t\t\t\t\t\t'data-value': day.dataValue,\n\t\t\t\t\t\t\t'data-day': i\n\t\t\t\t\t\t};\n\t\t\t\t\t\tlet square = heatSquare('day', x, y, squareSize, radius, 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\tspline: c.spline\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, this.constants.spline));\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.reverse().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\td.values = vals;\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\tif(allowedSpace <= 0) allowedSpace = 1;\n\tlet allowedLetters = allowedSpace / DEFAULT_CHAR_WIDTH;\n\n\tlet seriesMultiple;\n\tif(isSeries) {\n\t\t// Find the maximum label length for spacing calculations\n\t\tlet maxLabelLength = Math.max(...labels.map(label => label.length));\n\t\tseriesMultiple = Math.ceil(maxLabelLength/allowedLetters);\n\t}\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\tif(i % seriesMultiple !== 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';\nimport DonutChart from './charts/DonutChart';\n\nconst chartTypes = {\n\tbar: AxisChart,\n\tline: AxisChart,\n\t// multiaxis: MultiAxisChart,\n\tpercentage: PercentageChart,\n\theatmap: Heatmap,\n\tpie: PieChart,\n\tdonut: DonutChart,\n};\n\nfunction getChartByType(chartType = 'line', parent, options) {\n\tif (chartType === 'axis-mixed') {\n\t\toptions.type = 'line';\n\t\treturn new AxisChart(parent, options);\n\t}\n\n\tif (!chartTypes[chartType]) {\n\t\tconsole.error(\"Undefined chart type: \" + chartType);\n\t\treturn;\n\t}\n\n\treturn new chartTypes[chartType](parent, options);\n}\n\nclass Chart {\n\tconstructor(parent, options) {\n\t\treturn getChartByType(options.type, parent, options);\n\t}\n}\n\nexport { Chart, PercentageChart, PieChart, Heatmap, AxisChart };","import { $ } from '../utils/dom';\nimport { TOOLTIP_POINTER_TRIANGLE_HEIGHT } from '../utils/constants';\n\nexport default class SvgTip {\n\tconstructor({\n\t\tparent = null,\n\t\tcolors = []\n\t}) {\n\t\tthis.parent = parent;\n\t\tthis.colors = colors;\n\t\tthis.titleName = '';\n\t\tthis.titleValue = '';\n\t\tthis.listValues = [];\n\t\tthis.titleValueFirst = 0;\n\n\t\tthis.x = 0;\n\t\tthis.y = 0;\n\n\t\tthis.top = 0;\n\t\tthis.left = 0;\n\n\t\tthis.setup();\n\t}\n\n\tsetup() {\n\t\tthis.makeTooltip();\n\t}\n\n\trefresh() {\n\t\tthis.fill();\n\t\tthis.calcPosition();\n\t}\n\n\tmakeTooltip() {\n\t\tthis.container = $.create('div', {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'graph-svg-tip comparison',\n\t\t\tinnerHTML: `<span class=\"title\"></span>\n\t\t\t\t<ul class=\"data-point-list\"></ul>\n\t\t\t\t<div class=\"svg-pointer\"></div>`\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 = `<strong>${this.titleValue}</strong>${this.titleName}`;\n\t\t} else {\n\t\t\ttitle = `${this.titleName}<strong>${this.titleValue}</strong>`;\n\t\t}\n\t\tthis.title.innerHTML = title;\n\t\tthis.dataPointList.innerHTML = '';\n\n\t\tthis.listValues.map((set, i) => {\n\t\t\tconst color = this.colors[i] || 'black';\n\t\t\tlet value = set.formatted === 0 || set.formatted ? set.formatted : set.value;\n\n\t\t\tlet li = $.create('li', {\n\t\t\t\tstyles: {\n\t\t\t\t\t'border-top': `3px solid ${color}`\n\t\t\t\t},\n\t\t\t\tinnerHTML: `<strong style=\"display: block;\">${ value === 0 || value ? value : '' }</strong>\n\t\t\t\t\t${set.title ? set.title : '' }`\n\t\t\t});\n\n\t\t\tthis.dataPointList.appendChild(li);\n\t\t});\n\t}\n\n\tcalcPosition() {\n\t\tlet width = this.container.offsetWidth;\n\n\t\tthis.top = this.y - this.container.offsetHeight\n\t\t\t- TOOLTIP_POINTER_TRIANGLE_HEIGHT;\n\t\tthis.left = this.x - width/2;\n\t\tlet maxLeft = this.parent.offsetWidth - width;\n\n\t\tlet pointer = this.container.querySelector('.svg-pointer');\n\n\t\tif(this.left < 0) {\n\t\t\tpointer.style.left = `calc(50% - ${-1 * this.left}px)`;\n\t\t\tthis.left = 0;\n\t\t} else if(this.left > maxLeft) {\n\t\t\tlet delta = this.left - maxLeft;\n\t\t\tlet pointerOffset = `calc(50% + ${delta}px)`;\n\t\t\tpointer.style.left = pointerOffset;\n\n\t\t\tthis.left = maxLeft;\n\t\t} else {\n\t\t\tpointer.style.left = `50%`;\n\t\t}\n\t}\n\n\tsetValues(x, y, title = {}, listValues = [], index = -1) {\n\t\tthis.titleName = title.name;\n\t\tthis.titleValue = title.value;\n\t\tthis.listValues = listValues;\n\t\tthis.x = x;\n\t\tthis.y = y;\n\t\tthis.titleValueFirst = title.valueFirst || 0;\n\t\tthis.index = index;\n\t\tthis.refresh();\n\t}\n\n\thideTip() {\n\t\tthis.container.style.top = '0px';\n\t\tthis.container.style.left = '0px';\n\t\tthis.container.style.opacity = '0';\n\t}\n\n\tshowTip() {\n\t\tthis.container.style.top = this.top + 'px';\n\t\tthis.container.style.left = this.left + 'px';\n\t\tthis.container.style.opacity = '1';\n\t}\n}\n","export const CSSTEXT = \".chart-container{position:relative;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','Roboto','Oxygen','Ubuntu','Cantarell','Fira Sans','Droid Sans','Helvetica Neue',sans-serif}.chart-container .axis,.chart-container .chart-label{fill:#555b51}.chart-container .axis line,.chart-container .chart-label line{stroke:#dadada}.chart-container .dataset-units circle{stroke:#fff;stroke-width:2}.chart-container .dataset-units path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container .dataset-path{stroke-width:2px}.chart-container .path-group path{fill:none;stroke-opacity:1;stroke-width:2px}.chart-container line.dashed{stroke-dasharray:5,3}.chart-container .axis-line .specific-value{text-anchor:start}.chart-container .axis-line .y-line{text-anchor:end}.chart-container .axis-line .x-line{text-anchor:middle}.chart-container .legend-dataset-text{fill:#6c7680;font-weight:600}.graph-svg-tip{position:absolute;z-index:99999;padding:10px;font-size:12px;color:#959da5;text-align:center;background:rgba(0,0,0,.8);border-radius:3px}.graph-svg-tip ul{padding-left:0;display:flex}.graph-svg-tip ol{padding-left:0;display:flex}.graph-svg-tip ul.data-point-list li{min-width:90px;flex:1;font-weight:600}.graph-svg-tip strong{color:#dfe2e5;font-weight:600}.graph-svg-tip .svg-pointer{position:absolute;height:5px;margin:0 0 0 -5px;content:' ';border:5px solid transparent;border-top-color:rgba(0,0,0,.8)}.graph-svg-tip.comparison{padding:0;text-align:left;pointer-events:none}.graph-svg-tip.comparison .title{display:block;padding:10px;margin:0;font-weight:600;line-height:1;pointer-events:none}.graph-svg-tip.comparison ul{margin:0;white-space:nowrap;list-style:none}.graph-svg-tip.comparison li{display:inline-block;padding:5px 10px}\";","import SvgTip from '../objects/SvgTip';\nimport { $, isElementInViewport, getElementContentWidth, isHidden } from '../utils/dom';\nimport { makeSVGContainer, makeSVGDefs, makeSVGGroup, makeText } from '../utils/draw';\nimport { BASE_MEASURES, getExtraHeight, getExtraWidth, getTopOffset, getLeftOffset,\n\tINIT_CHART_UPDATE_TIMEOUT, CHART_POST_ANIMATE_TIMEOUT, DEFAULT_COLORS} from '../utils/constants';\nimport { getColor, isValidColor } from '../utils/colors';\nimport { runSMILAnimation } from '../utils/animation';\nimport { downloadFile, prepareForExport } from '../utils/export';\nimport { deepClone } from '../utils/helpers';\n\nexport default class BaseChart {\n\tconstructor(parent, options) {\n\t\t// deepclone options to avoid making changes to orignal object\n\t\toptions = deepClone(options);\n\n\t\tthis.parent = typeof parent === 'string'\n\t\t\t? document.querySelector(parent)\n\t\t\t: parent;\n\n\t\tif (!(this.parent instanceof HTMLElement)) {\n\t\t\tthrow new Error('No `parent` element to render on was provided.');\n\t\t}\n\n\t\tthis.rawChartArgs = options;\n\n\t\tthis.title = options.title || '';\n\t\tthis.type = options.type || '';\n\n\t\tthis.realData = this.prepareData(options.data);\n\t\tthis.data = this.prepareFirstData(this.realData);\n\n\t\tthis.colors = this.validateColors(options.colors, this.type);\n\n\t\tthis.config = {\n\t\t\tshowTooltip: 1, // calculate\n\t\t\tshowLegend: 1, // calculate\n\t\t\tisNavigable: options.isNavigable || 0,\n\t\t\tanimate: (typeof options.animate !== 'undefined') ? options.animate : 1,\n\t\t\ttruncateLegends: options.truncateLegends || 1\n\t\t};\n\n\t\tthis.measures = JSON.parse(JSON.stringify(BASE_MEASURES));\n\t\tlet m = this.measures;\n\t\tthis.setMeasures(options);\n\t\tif(!this.title.length) { m.titleHeight = 0; }\n\t\tif(!this.config.showLegend) m.legendHeight = 0;\n\t\tthis.argHeight = options.height || m.baseHeight;\n\n\t\tthis.state = {};\n\t\tthis.options = {};\n\n\t\tthis.initTimeout = INIT_CHART_UPDATE_TIMEOUT;\n\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.overlays = [];\n\t\t}\n\n\t\tthis.configure(options);\n\t}\n\n\tprepareData(data) {\n\t\treturn data;\n\t}\n\n\tprepareFirstData(data) {\n\t\treturn data;\n\t}\n\n\tvalidateColors(colors, type) {\n\t\tconst validColors = [];\n\t\tcolors = (colors || []).concat(DEFAULT_COLORS[type]);\n\t\tcolors.forEach((string) => {\n\t\t\tconst color = getColor(string);\n\t\t\tif(!isValidColor(color)) {\n\t\t\t\tconsole.warn('\"' + string + '\" is not a valid color.');\n\t\t\t} else {\n\t\t\t\tvalidColors.push(color);\n\t\t\t}\n\t\t});\n\t\treturn validColors;\n\t}\n\n\tsetMeasures() {\n\t\t// Override measures, including those for title and legend\n\t\t// set config for legend and title\n\t}\n\n\tconfigure() {\n\t\tlet height = this.argHeight;\n\t\tthis.baseHeight = height;\n\t\tthis.height = height - getExtraHeight(this.measures);\n\n\t\t// Bind window events\n\t\tthis.boundDrawFn = () => this.draw(true);\n\t\tif (ResizeObserver) {\n\t\t\tthis.resizeObserver = new ResizeObserver(this.boundDrawFn);\n\t\t\tthis.resizeObserver.observe(this.parent);\n\t\t}\n\t\twindow.addEventListener('resize', this.boundDrawFn);\n\t\twindow.addEventListener('orientationchange', this.boundDrawFn);\n\t}\n\n\tdestroy() {\n\t\tif (this.resizeObserver) this.resizeObserver.disconnect();\n\t\twindow.removeEventListener('resize', this.boundDrawFn);\n\t\twindow.removeEventListener('orientationchange', this.boundDrawFn);\n\t}\n\n\t// Has to be called manually\n\tsetup() {\n\t\tthis.makeContainer();\n\t\tthis.updateWidth();\n\t\tthis.makeTooltip();\n\n\t\tthis.draw(false, true);\n\t}\n\n\tmakeContainer() {\n\t\t// Chart needs a dedicated parent element\n\t\tthis.parent.innerHTML = '';\n\n\t\tlet args = {\n\t\t\tinside: this.parent,\n\t\t\tclassName: 'chart-container'\n\t\t};\n\n\t\tif(this.independentWidth) {\n\t\t\targs.styles = { width: this.independentWidth + 'px' };\n\t\t}\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\tif (onlyWidthChange && isHidden(this.parent)) {\n\t\t\t// Don't update anything if the chart is hidden\n\t\t\treturn;\n\t\t}\n\t\tthis.updateWidth();\n\n\t\tthis.calc(onlyWidthChange);\n\t\tthis.makeChartArea();\n\t\tthis.setupComponents();\n\n\t\tthis.components.forEach(c => c.setup(this.drawArea));\n\t\t// this.components.forEach(c => c.make());\n\t\tthis.render(this.components, false);\n\n\t\tif(init) {\n\t\t\tthis.data = this.realData;\n\t\t\tsetTimeout(() => {this.update(this.data);}, this.initTimeout);\n\t\t}\n\n\t\tthis.renderLegend();\n\n\t\tthis.setupNavigation(init);\n\t}\n\n\tcalc() {} // builds state\n\n\tupdateWidth() {\n\t\tthis.baseWidth = getElementContentWidth(this.parent);\n\t\tthis.width = this.baseWidth - getExtraWidth(this.measures);\n\t}\n\n\tmakeChartArea() {\n\t\tif(this.svg) {\n\t\t\tthis.container.removeChild(this.svg);\n\t\t}\n\t\tlet m = this.measures;\n\n\t\tthis.svg = makeSVGContainer(\n\t\t\tthis.container,\n\t\t\t'frappe-chart chart',\n\t\t\tthis.baseWidth,\n\t\t\tthis.baseHeight\n\t\t);\n\t\tthis.svgDefs = makeSVGDefs(this.svg);\n\n\t\tif(this.title.length) {\n\t\t\tthis.titleEL = makeText(\n\t\t\t\t'title',\n\t\t\t\tm.margins.left,\n\t\t\t\tm.margins.top,\n\t\t\t\tthis.title,\n\t\t\t\t{\n\t\t\t\t\tfontSize: m.titleFontSize,\n\t\t\t\t\tfill: '#666666',\n\t\t\t\t\tdy: m.titleFontSize\n\t\t\t\t}\n\t\t\t);\n\t\t}\n\n\t\tlet top = getTopOffset(m);\n\t\tthis.drawArea = makeSVGGroup(\n\t\t\tthis.type + '-chart chart-draw-area',\n\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t);\n\n\t\tif(this.config.showLegend) {\n\t\t\ttop += this.height + m.paddings.bottom;\n\t\t\tthis.legendArea = makeSVGGroup(\n\t\t\t\t'chart-legend',\n\t\t\t\t`translate(${getLeftOffset(m)}, ${top})`\n\t\t\t);\n\t\t}\n\n\t\tif(this.title.length) { this.svg.appendChild(this.titleEL); }\n\t\tthis.svg.appendChild(this.drawArea);\n\t\tif(this.config.showLegend) { this.svg.appendChild(this.legendArea); }\n\n\t\tthis.updateTipOffset(getLeftOffset(m), getTopOffset(m));\n\t}\n\n\tupdateTipOffset(x, y) {\n\t\tthis.tip.offset = {\n\t\t\tx: x,\n\t\t\ty: y\n\t\t};\n\t}\n\n\tsetupComponents() { this.components = new Map(); }\n\n\tupdate(data) {\n\t\tif(!data) {\n\t\t\tconsole.error('No data to update.');\n\t\t}\n\t\tthis.data = this.prepareData(data);\n\t\tthis.calc(); // builds state\n\t\tthis.render(this.components, this.config.animate);\n\t\tthis.renderLegend();\n\t}\n\n\trender(components=this.components, animate=true) {\n\t\tif(this.config.isNavigable) {\n\t\t\t// Remove all existing overlays\n\t\t\tthis.overlays.map(o => o.parentNode.removeChild(o));\n\t\t\t// ref.parentNode.insertBefore(element, ref);\n\t\t}\n\t\tlet elementsToAnimate = [];\n\t\t// Can decouple to this.refreshComponents() first to save animation timeout\n\t\tcomponents.forEach(c => {\n\t\t\telementsToAnimate = elementsToAnimate.concat(c.update(animate));\n\t\t});\n\t\tif(elementsToAnimate.length > 0) {\n\t\t\trunSMILAnimation(this.container, this.svg, elementsToAnimate);\n\t\t\tsetTimeout(() => {\n\t\t\t\tcomponents.forEach(c => c.make());\n\t\t\t\tthis.updateNav();\n\t\t\t}, CHART_POST_ANIMATE_TIMEOUT);\n\t\t} else {\n\t\t\tcomponents.forEach(c => c.make());\n\t\t\tthis.updateNav();\n\t\t}\n\t}\n\n\tupdateNav() {\n\t\tif(this.config.isNavigable) {\n\t\t\tthis.makeOverlay();\n\t\t\tthis.bindUnits();\n\t\t}\n\t}\n\n\trenderLegend() {}\n\n\tsetupNavigation(init=false) {\n\t\tif(!this.config.isNavigable) return;\n\n\t\tif(init) {\n\t\t\tthis.bindOverlay();\n\n\t\t\tthis.keyActions = {\n\t\t\t\t'13': this.onEnterKey.bind(this),\n\t\t\t\t'37': this.onLeftArrow.bind(this),\n\t\t\t\t'38': this.onUpArrow.bind(this),\n\t\t\t\t'39': this.onRightArrow.bind(this),\n\t\t\t\t'40': this.onDownArrow.bind(this),\n\t\t\t};\n\n\t\t\tdocument.addEventListener('keydown', (e) => {\n\t\t\t\tif(isElementInViewport(this.container)) {\n\t\t\t\t\te = e || window.event;\n\t\t\t\t\tif(this.keyActions[e.keyCode]) {\n\t\t\t\t\t\tthis.keyActions[e.keyCode]();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tmakeOverlay() {}\n\tupdateOverlay() {}\n\tbindOverlay() {}\n\tbindUnits() {}\n\n\tonLeftArrow() {}\n\tonRightArrow() {}\n\tonUpArrow() {}\n\tonDownArrow() {}\n\tonEnterKey() {}\n\n\taddDataPoint() {}\n\tremoveDataPoint() {}\n\n\tgetDataPoint() {}\n\tsetCurrentDataPoint() {}\n\n\tupdateDataset() {}\n\n\texport() {\n\t\tlet chartSvg = prepareForExport(this.svg);\n\t\tdownloadFile(this.title || 'Chart', [chartSvg]);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { truncateString } from '../utils/draw-utils';\nimport { legendDot } from '../utils/draw';\nimport { round } from '../utils/helpers';\nimport { getExtraWidth } from '../utils/constants';\n\nexport default class AggregationChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t}\n\n\tconfigure(args) {\n\t\tsuper.configure(args);\n\n\t\tthis.config.formatTooltipY = (args.tooltipOptions || {}).formatTooltipY;\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(round(d[0]));\n\t\t\ts.labels.push(d[1]);\n\t\t});\n\n\t\ts.grandTotal = s.sliceTotals.reduce((a, b) => a + b, 0);\n\n\t\tthis.center = {\n\t\t\tx: this.width / 2,\n\t\t\ty: this.height / 2\n\t\t};\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.state;\n\t\tthis.legendArea.textContent = '';\n\t\tthis.legendTotals = s.sliceTotals.slice(0, this.config.maxLegendPoints);\n\n\t\tlet count = 0;\n\t\tlet y = 0;\n\t\tthis.legendTotals.map((d, i) => {\n\t\t\tlet barWidth = 150;\n\t\t\tlet divisor = Math.floor(\n\t\t\t\t(this.width - getExtraWidth(this.measures))/barWidth\n\t\t\t);\n\t\t\tif (this.legendTotals.length < divisor) {\n\t\t\t\tbarWidth = this.width/this.legendTotals.length;\n\t\t\t}\n\t\t\tif(count > divisor) {\n\t\t\t\tcount = 0;\n\t\t\t\ty += 20;\n\t\t\t}\n\t\t\tlet x = barWidth * count + 5;\n\t\t\tlet label = this.config.truncateLegends ? truncateString(s.labels[i], barWidth/10) : s.labels[i];\n\t\t\tlet formatted = this.config.formatTooltipY ? this.config.formatTooltipY(d) : d;\n\t\t\tlet dot = legendDot(\n\t\t\t\tx,\n\t\t\t\ty,\n\t\t\t\t5,\n\t\t\t\tthis.colors[i],\n\t\t\t\t`${label}: ${formatted}`,\n\t\t\t\tfalse\n\t\t\t);\n\t\t\tthis.legendArea.appendChild(dot);\n\t\t\tcount++;\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getOffset } from '../utils/dom';\nimport { getComponent } from '../objects/ChartComponents';\nimport { PERCENTAGE_BAR_DEFAULT_HEIGHT, PERCENTAGE_BAR_DEFAULT_DEPTH } from '../utils/constants';\n\nexport default class PercentageChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'percentage';\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.barOptions = options.barOptions || {};\n\n\t\tlet b = this.barOptions;\n\t\tb.height = b.height || PERCENTAGE_BAR_DEFAULT_HEIGHT;\n\t\tb.depth = b.depth || PERCENTAGE_BAR_DEFAULT_DEPTH;\n\n\t\tm.paddings.right = 30;\n\t\tm.legendHeight = 60;\n\t\tm.baseHeight = (b.height + b.depth * 0.5) * 8;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'percentageBars',\n\t\t\t\t{\n\t\t\t\t\tbarHeight: this.barOptions.height,\n\t\t\t\t\tbarDepth: this.barOptions.depth,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xPositions,\n\t\t\t\t\t\twidths: s.widths,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\n\t\ts.xPositions = [];\n\t\ts.widths = [];\n\n\t\tlet xPos = 0;\n\t\ts.sliceTotals.map((value) => {\n\t\t\tlet width = this.width * value / s.grandTotal;\n\t\t\ts.widths.push(width);\n\t\t\ts.xPositions.push(xPos);\n\t\t\txPos += width;\n\t\t});\n\t}\n\n\tmakeDataByIndex() { }\n\n\tbindTooltip() {\n\t\tlet s = this.state;\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet bars = this.components.get('percentageBars').store;\n\t\t\tlet bar = e.target;\n\t\t\tif(bars.includes(bar)) {\n\n\t\t\t\tlet i = bars.indexOf(bar);\n\t\t\t\tlet gOff = getOffset(this.container), pOff = getOffset(bar);\n\n\t\t\t\tlet x = pOff.left - gOff.left + parseInt(bar.getAttribute('width'))/2;\n\t\t\t\tlet y = pOff.top - gOff.top;\n\t\t\t\tlet title = (this.formattedLabels && this.formattedLabels.length>0\n\t\t\t\t\t? this.formattedLabels[i] : this.state.labels[i]) + ': ';\n\t\t\t\tlet fraction = s.sliceTotals[i]/s.grandTotal;\n\n\t\t\t\tthis.tip.setValues(x, y, {name: title, value: (fraction*100).toFixed(1) + \"%\"});\n\t\t\t\tthis.tip.showTip();\n\t\t\t}\n\t\t});\n\t}\n}\n","import AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcPathStr, makeCircleStr } 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\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 largeArc = originDiffAngle > 180 ? 1: 0;\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 =\n\t\t\t\toriginDiffAngle === 360\n\t\t\t\t\t? makeCircleStr(curStart, curEnd, this.center, this.radius, clockWise, largeArc)\n\t\t\t\t\t: makeArcPathStr(curStart, curEnd, this.center, this.radius, clockWise, largeArc);\n\n\t\t\ts.sliceStrings.push(curPath);\n\t\t\ts.slicesProperties.push({\n\t\t\t\tstartPosition,\n\t\t\t\tendPosition,\n\t\t\t\tvalue: total,\n\t\t\t\ttotal: s.grandTotal,\n\t\t\t\tstartAngle,\n\t\t\t\tendAngle,\n\t\t\t\tangle: diffAngle\n\t\t\t});\n\n\t\t});\n\t\tthis.init = 0;\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'pieSlices',\n\t\t\t\t{ },\n\t\t\t\tfunction() {\n\t\t\t\t\treturn {\n\t\t\t\t\t\tsliceStrings: s.sliceStrings,\n\t\t\t\t\t\tcolors: this.colors\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tcalTranslateByAngle(property){\n\t\tconst{radius,hoverRadio} = this;\n\t\tconst position = getPositionByAngle(property.startAngle+(property.angle / 2),radius);\n\t\treturn `translate3d(${(position.x) * hoverRadio}px,${(position.y) * hoverRadio}px,0)`;\n\t}\n\n\thoverSlice(path,i,flag,e){\n\t\tif(!path) return;\n\t\tconst color = this.colors[i];\n\t\tif(flag) {\n\t\t\ttransform(path, this.calTranslateByAngle(this.state.slicesProperties[i]));\n\t\t\tpath.style.fill = lightenDarkenColor(color, 50);\n\t\t\tlet g_off = getOffset(this.svg);\n\t\t\tlet x = e.pageX - g_off.left + 10;\n\t\t\tlet y = e.pageY - g_off.top - 10;\n\t\t\tlet title = (this.formatted_labels && this.formatted_labels.length > 0\n\t\t\t\t? this.formatted_labels[i] : this.state.labels[i]) + ': ';\n\t\t\tlet percent = (this.state.sliceTotals[i] * 100 / this.state.grandTotal).toFixed(1);\n\t\t\tthis.tip.setValues(x, y, {name: title, value: percent + \"%\"});\n\t\t\tthis.tip.showTip();\n\t\t} else {\n\t\t\ttransform(path,'translate3d(0,0,0)');\n\t\t\tthis.tip.hideTip();\n\t\t\tpath.style.fill = color;\n\t\t}\n\t}\n\n\tbindTooltip() {\n\t\tthis.container.addEventListener('mousemove', this.mouseMove);\n\t\tthis.container.addEventListener('mouseleave', this.mouseLeave);\n\t}\n\n\tmouseMove(e){\n\t\tconst target = e.target;\n\t\tlet slices = this.components.get('pieSlices').store;\n\t\tlet prevIndex = this.curActiveSliceIndex;\n\t\tlet prevAcitve = this.curActiveSlice;\n\t\tif(slices.includes(target)) {\n\t\t\tlet i = slices.indexOf(target);\n\t\t\tthis.hoverSlice(prevAcitve, prevIndex,false);\n\t\t\tthis.curActiveSlice = target;\n\t\t\tthis.curActiveSliceIndex = i;\n\t\t\tthis.hoverSlice(target, i, true, e);\n\t\t} else {\n\t\t\tthis.mouseLeave();\n\t\t}\n\t}\n\n\tmouseLeave(){\n\t\tthis.hoverSlice(this.curActiveSlice,this.curActiveSliceIndex,false);\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { makeText, heatSquare } from '../utils/draw';\nimport { DAY_NAMES_SHORT, addDays, areInSameMonth, getLastDateInMonth, setDayToSunday, getYyyyMmDd, getWeeksBetween, getMonthName, clone,\n\tNO_OF_MILLIS, NO_OF_YEAR_MONTHS, NO_OF_DAYS_IN_WEEK } from '../utils/date-utils';\nimport { calcDistribution, getMaxCheckpoint } from '../utils/intervals';\nimport { getExtraHeight, getExtraWidth, HEATMAP_DISTRIBUTION_SIZE, HEATMAP_SQUARE_SIZE,\n\tHEATMAP_GUTTER_SIZE } from '../utils/constants';\n\nconst COL_WIDTH = HEATMAP_SQUARE_SIZE + HEATMAP_GUTTER_SIZE;\nconst ROW_HEIGHT = COL_WIDTH;\n// const DAY_INCR = 1;\n\nexport default class Heatmap extends BaseChart {\n\tconstructor(parent, options) {\n\t\tsuper(parent, options);\n\t\tthis.type = 'heatmap';\n\n\t\tthis.countLabel = options.countLabel || '';\n\n\t\tlet validStarts = ['Sunday', 'Monday'];\n\t\tlet startSubDomain = validStarts.includes(options.startSubDomain)\n\t\t\t? options.startSubDomain : 'Sunday';\n\t\tthis.startSubDomainIndex = validStarts.indexOf(startSubDomain);\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures(options) {\n\t\tlet m = this.measures;\n\t\tthis.discreteDomains = options.discreteDomains === 0 ? 0 : 1;\n\n\t\tm.paddings.top = ROW_HEIGHT * 3;\n\t\tm.paddings.bottom = 0;\n\t\tm.legendHeight = ROW_HEIGHT * 2;\n\t\tm.baseHeight = ROW_HEIGHT * NO_OF_DAYS_IN_WEEK\n\t\t\t+ getExtraHeight(m);\n\n\t\tlet d = this.data;\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tthis.independentWidth = (getWeeksBetween(d.start, d.end)\n\t\t\t+ spacing) * COL_WIDTH + getExtraWidth(m);\n\t}\n\n\tupdateWidth() {\n\t\tlet spacing = this.discreteDomains ? NO_OF_YEAR_MONTHS : 0;\n\t\tlet noOfWeeks = this.state.noOfWeeks ? this.state.noOfWeeks : 52;\n\t\tthis.baseWidth = (noOfWeeks + spacing) * COL_WIDTH\n\t\t\t+ getExtraWidth(this.measures);\n\t}\n\n\tprepareData(data=this.data) {\n\t\tif(data.start && data.end && data.start > data.end) {\n\t\t\tthrow new Error('Start date cannot be greater than end date.');\n\t\t}\n\n\t\tif(!data.start) {\n\t\t\tdata.start = new Date();\n\t\t\tdata.start.setFullYear( data.start.getFullYear() - 1 );\n\t\t}\n\t\tif(!data.end) { data.end = new Date(); }\n\t\tdata.dataPoints = data.dataPoints || {};\n\n\t\tif(parseInt(Object.keys(data.dataPoints)[0]) > 100000) {\n\t\t\tlet points = {};\n\t\t\tObject.keys(data.dataPoints).forEach(timestampSec => {\n\t\t\t\tlet date = new Date(timestampSec * NO_OF_MILLIS);\n\t\t\t\tpoints[getYyyyMmDd(date)] = data.dataPoints[timestampSec];\n\t\t\t});\n\t\t\tdata.dataPoints = points;\n\t\t}\n\n\t\treturn data;\n\t}\n\n\tcalc() {\n\t\tlet s = this.state;\n\n\t\ts.start = clone(this.data.start);\n\t\ts.end = clone(this.data.end);\n\n\t\ts.firstWeekStart = clone(s.start);\n\t\ts.noOfWeeks = getWeeksBetween(s.start, s.end);\n\t\ts.distribution = calcDistribution(\n\t\t\tObject.values(this.data.dataPoints), HEATMAP_DISTRIBUTION_SIZE);\n\n\t\ts.domainConfigs = this.getDomains();\n\t}\n\n\tsetupComponents() {\n\t\tlet s = this.state;\n\t\tlet lessCol = this.discreteDomains ? 0 : 1;\n\n\t\tlet componentConfigs = s.domainConfigs.map((config, i) => [\n\t\t\t'heatDomain',\n\t\t\t{\n\t\t\t\tindex: config.index,\n\t\t\t\tcolWidth: COL_WIDTH,\n\t\t\t\trowHeight: ROW_HEIGHT,\n\t\t\t\tsquareSize: HEATMAP_SQUARE_SIZE,\n\t\t\t\tradius: this.rawChartArgs.radius || 0,\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\t\tlet radius = this.rawChartArgs.radius || 0;\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, radius, color);\n\t\t\tthis.legendArea.appendChild(square);\n\t\t});\n\n\t\tlet moreTextX = x + HEATMAP_DISTRIBUTION_SIZE * (COL_WIDTH + 3) + COL_WIDTH/4;\n\t\tlet moreText = makeText('subdomain-name', moreTextX, y, 'More',\n\t\t\t{\n\t\t\t\tfontSize: HEATMAP_SQUARE_SIZE + 1,\n\t\t\t\tdy: 9\n\t\t\t}\n\t\t);\n\t\tthis.legendArea.appendChild(moreText);\n\t}\n\n\tgetDomains() {\n\t\tlet s = this.state;\n\t\tconst [startMonth, startYear] = [s.start.getMonth(), s.start.getFullYear()];\n\t\tconst [endMonth, endYear] = [s.end.getMonth(), s.end.getFullYear()];\n\n\t\tconst noOfMonths = (endMonth - startMonth + 1) + (endYear - startYear) * 12;\n\n\t\tlet domainConfigs = [];\n\n\t\tlet startOfMonth = clone(s.start);\n\t\tfor(var i = 0; i < noOfMonths; i++) {\n\t\t\tlet endDate = s.end;\n\t\t\tif(!areInSameMonth(startOfMonth, s.end)) {\n\t\t\t\tlet [month, year] = [startOfMonth.getMonth(), startOfMonth.getFullYear()];\n\t\t\t\tendDate = getLastDateInMonth(month, year);\n\t\t\t}\n\t\t\tdomainConfigs.push(this.getDomainConfig(startOfMonth, endDate));\n\n\t\t\taddDays(endDate, 1);\n\t\t\tstartOfMonth = endDate;\n\t\t}\n\n\t\treturn domainConfigs;\n\t}\n\n\tgetDomainConfig(startDate, endDate='') {\n\t\tlet [month, year] = [startDate.getMonth(), startDate.getFullYear()];\n\t\tlet startOfWeek = setDayToSunday(startDate); // TODO: Monday as well\n\t\tendDate = clone(endDate) || getLastDateInMonth(month, year);\n\n\t\tlet domainConfig = {\n\t\t\tindex: month,\n\t\t\tcols: []\n\t\t};\n\n\t\taddDays(endDate, 1);\n\t\tlet noOfMonthWeeks = getWeeksBetween(startOfWeek, endDate);\n\n\t\tlet cols = [], col;\n\t\tfor(var i = 0; i < noOfMonthWeeks; i++) {\n\t\t\tcol = this.getCol(startOfWeek, month);\n\t\t\tcols.push(col);\n\n\t\t\tstartOfWeek = new Date(col[NO_OF_DAYS_IN_WEEK - 1].yyyyMmDd);\n\t\t\taddDays(startOfWeek, 1);\n\t\t}\n\n\t\tif(col[NO_OF_DAYS_IN_WEEK - 1].dataValue !== undefined) {\n\t\t\taddDays(startOfWeek, 1);\n\t\t\tcols.push(this.getCol(startOfWeek, month, true));\n\t\t}\n\n\t\tdomainConfig.cols = cols;\n\n\t\treturn domainConfig;\n\t}\n\n\tgetCol(startDate, month, empty = false) {\n\t\tlet s = this.state;\n\n\t\t// startDate is the start of week\n\t\tlet currentDate = clone(startDate);\n\t\tlet col = [];\n\n\t\tfor(var i = 0; i < NO_OF_DAYS_IN_WEEK; i++, addDays(currentDate, 1)) {\n\t\t\tlet config = {};\n\n\t\t\t// Non-generic adjustment for entire heatmap, needs state\n\t\t\tlet currentDateWithinData = currentDate >= s.start && currentDate <= s.end;\n\n\t\t\tif(empty || currentDate.getMonth() !== month || !currentDateWithinData) {\n\t\t\t\tconfig.yyyyMmDd = getYyyyMmDd(currentDate);\n\t\t\t} else {\n\t\t\t\tconfig = this.getSubDomainConfig(currentDate);\n\t\t\t}\n\t\t\tcol.push(config);\n\t\t}\n\n\t\treturn col;\n\t}\n\n\tgetSubDomainConfig(date) {\n\t\tlet yyyyMmDd = getYyyyMmDd(date);\n\t\tlet dataValue = this.data.dataPoints[yyyyMmDd];\n\t\tlet config = {\n\t\t\tyyyyMmDd: yyyyMmDd,\n\t\t\tdataValue: dataValue || 0,\n\t\t\tfill: this.colors[getMaxCheckpoint(dataValue, this.state.distribution)]\n\t\t};\n\t\treturn config;\n\t}\n}\n","import BaseChart from './BaseChart';\nimport { dataPrep, zeroDataPrep, getShortenedLabels } from '../utils/axis-chart-utils';\nimport { AXIS_LEGEND_BAR_SIZE } from '../utils/constants';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset, fire } from '../utils/dom';\nimport { calcChartIntervals, getIntervalSize, getValueRange, getZeroIndex, scale, getClosestInArray } from '../utils/intervals';\nimport { floatTwo } from '../utils/helpers';\nimport { makeOverlay, updateOverlay, legendBar } from '../utils/draw';\nimport { getTopOffset, getLeftOffset, MIN_BAR_PERCENT_HEIGHT, BAR_CHART_SPACE_RATIO,\n\tLINE_CHART_DOT_SIZE } from '../utils/constants';\n\nexport default class AxisChart extends BaseChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\n\t\tthis.barOptions = args.barOptions || {};\n\t\tthis.lineOptions = args.lineOptions || {};\n\n\t\tthis.type = args.type || 'line';\n\t\tthis.init = 1;\n\n\t\tthis.setup();\n\t}\n\n\tsetMeasures() {\n\t\tif(this.data.datasets.length <= 1) {\n\t\t\tthis.config.showLegend = 0;\n\t\t\tthis.measures.paddings.bottom = 30;\n\t\t}\n\t}\n\n\tconfigure(options) {\n\t\tsuper.configure(options);\n\n\t\toptions.axisOptions = options.axisOptions || {};\n\t\toptions.tooltipOptions = options.tooltipOptions || {};\n\n\t\tthis.config.xAxisMode = options.axisOptions.xAxisMode || 'span';\n\t\tthis.config.yAxisMode = options.axisOptions.yAxisMode || 'span';\n\t\tthis.config.xIsSeries = options.axisOptions.xIsSeries || 0;\n\t\tthis.config.shortenYAxisNumbers = options.axisOptions.shortenYAxisNumbers || 0;\n\n\t\tthis.config.formatTooltipX = options.tooltipOptions.formatTooltipX;\n\t\tthis.config.formatTooltipY = options.tooltipOptions.formatTooltipY;\n\n\t\tthis.config.valuesOverPoints = options.valuesOverPoints;\n\t}\n\n\tprepareData(data=this.data) {\n\t\treturn dataPrep(data, this.type);\n\t}\n\n\tprepareFirstData(data=this.data) {\n\t\treturn zeroDataPrep(data);\n\t}\n\n\tcalc(onlyWidthChange = false) {\n\t\tthis.calcXPositions();\n\t\tif(!onlyWidthChange) {\n\t\t\tthis.calcYAxisParameters(this.getAllYValues(), this.type === 'line');\n\t\t}\n\t\tthis.makeDataByIndex();\n\t}\n\n\tcalcXPositions() {\n\t\tlet s = this.state;\n\t\tlet labels = this.data.labels;\n\t\ts.datasetLength = labels.length;\n\n\t\ts.unitWidth = this.width/(s.datasetLength);\n\t\t// Default, as per bar, and mixed. Only line will be a special case\n\t\ts.xOffset = s.unitWidth/2;\n\n\t\t// // For a pure Line Chart\n\t\t// s.unitWidth = this.width/(s.datasetLength - 1);\n\t\t// s.xOffset = 0;\n\n\t\ts.xAxis = {\n\t\t\tlabels: labels,\n\t\t\tpositions: labels.map((d, i) =>\n\t\t\t\tfloatTwo(s.xOffset + i * s.unitWidth)\n\t\t\t)\n\t\t};\n\t}\n\n\tcalcYAxisParameters(dataValues, withMinimum = 'false') {\n\t\tconst yPts = calcChartIntervals(dataValues, withMinimum);\n\t\tconst scaleMultiplier = this.height / getValueRange(yPts);\n\t\tconst intervalHeight = getIntervalSize(yPts) * scaleMultiplier;\n\t\tconst zeroLine = this.height - (getZeroIndex(yPts) * intervalHeight);\n\n\t\tthis.state.yAxis = {\n\t\t\tlabels: yPts,\n\t\t\tpositions: yPts.map(d => zeroLine - d * scaleMultiplier),\n\t\t\tscaleMultiplier: scaleMultiplier,\n\t\t\tzeroLine: zeroLine,\n\t\t};\n\n\t\t// Dependent if above changes\n\t\tthis.calcDatasetPoints();\n\t\tthis.calcYExtremes();\n\t\tthis.calcYRegions();\n\t}\n\n\tcalcDatasetPoints() {\n\t\tlet s = this.state;\n\t\tlet scaleAll = values => values.map(val => scale(val, s.yAxis));\n\n\t\ts.datasets = this.data.datasets.map((d, i) => {\n\t\t\tlet values = d.values;\n\t\t\tlet cumulativeYs = d.cumulativeYs || [];\n\t\t\treturn {\n\t\t\t\tname: d.name && d.name.replace(/<|>|&/g, (char) => char == '&' ? '&amp;' : char == '<' ? '&lt;' : '&gt;'),\n\t\t\t\tindex: i,\n\t\t\t\tchartType: d.chartType,\n\n\t\t\t\tvalues: values,\n\t\t\t\tyPositions: scaleAll(values),\n\n\t\t\t\tcumulativeYs: cumulativeYs,\n\t\t\t\tcumulativeYPos: scaleAll(cumulativeYs),\n\t\t\t};\n\t\t});\n\t}\n\n\tcalcYExtremes() {\n\t\tlet s = this.state;\n\t\tif(this.barOptions.stacked) {\n\t\t\ts.yExtremes = s.datasets[s.datasets.length - 1].cumulativeYPos;\n\t\t\treturn;\n\t\t}\n\t\ts.yExtremes = new Array(s.datasetLength).fill(9999);\n\t\ts.datasets.map(d => {\n\t\t\td.yPositions.map((pos, j) => {\n\t\t\t\tif(pos < s.yExtremes[j]) {\n\t\t\t\t\ts.yExtremes[j] = pos;\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t}\n\n\tcalcYRegions() {\n\t\tlet s = this.state;\n\t\tif(this.data.yMarkers) {\n\t\t\tthis.state.yMarkers = this.data.yMarkers.map(d => {\n\t\t\t\td.position = scale(d.value, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\t// if(!d.label.includes(':')) {\n\t\t\t\t// \td.label += ': ' + d.value;\n\t\t\t\t// }\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.state.yRegions = this.data.yRegions.map(d => {\n\t\t\t\td.startPos = scale(d.start, s.yAxis);\n\t\t\t\td.endPos = scale(d.end, s.yAxis);\n\t\t\t\tif(!d.options) d.options = {};\n\t\t\t\treturn d;\n\t\t\t});\n\t\t}\n\t}\n\n\tgetAllYValues() {\n\t\tlet key = 'values';\n\n\t\tif(this.barOptions.stacked) {\n\t\t\tkey = 'cumulativeYs';\n\t\t\tlet cumulative = new Array(this.state.datasetLength).fill(0);\n\t\t\tthis.data.datasets.map((d, i) => {\n\t\t\t\tlet values = this.data.datasets[i].values;\n\t\t\t\td[key] = cumulative = cumulative.map((c, i) => c + values[i]);\n\t\t\t});\n\t\t}\n\n\t\tlet allValueLists = this.data.datasets.map(d => d[key]);\n\t\tif(this.data.yMarkers) {\n\t\t\tallValueLists.push(this.data.yMarkers.map(d => d.value));\n\t\t}\n\t\tif(this.data.yRegions) {\n\t\t\tthis.data.yRegions.map(d => {\n\t\t\t\tallValueLists.push([d.end, d.start]);\n\t\t\t});\n\t\t}\n\n\t\treturn [].concat(...allValueLists);\n\t}\n\n\tsetupComponents() {\n\t\tlet componentConfigs = [\n\t\t\t[\n\t\t\t\t'yAxis',\n\t\t\t\t{\n\t\t\t\t\tmode: this.config.yAxisMode,\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tshortenNumbers: this.config.shortenYAxisNumbers\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\tspline: this.lineOptions.spline,\n\t\t\t\t\thideDots: this.lineOptions.hideDots,\n\t\t\t\t\thideLine: this.lineOptions.hideLine,\n\n\t\t\t\t\t// same for all datasets\n\t\t\t\t\tvaluesOverPoints: this.config.valuesOverPoints,\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\tlet s = this.state;\n\t\t\t\t\tlet d = s.datasets[index];\n\t\t\t\t\tlet minLine = s.yAxis.positions[0] < s.yAxis.zeroLine\n\t\t\t\t\t\t? s.yAxis.positions[0] : s.yAxis.zeroLine;\n\n\t\t\t\t\treturn {\n\t\t\t\t\t\txPositions: s.xAxis.positions,\n\t\t\t\t\t\tyPositions: d.yPositions,\n\n\t\t\t\t\t\tvalues: d.values,\n\n\t\t\t\t\t\tzeroLine: minLine,\n\t\t\t\t\t\tradius: this.lineOptions.dotSize || LINE_CHART_DOT_SIZE,\n\t\t\t\t\t};\n\t\t\t\t}.bind(this)\n\t\t\t];\n\t\t});\n\n\t\tlet markerConfigs = [\n\t\t\t[\n\t\t\t\t'yMarkers',\n\t\t\t\t{\n\t\t\t\t\twidth: this.width,\n\t\t\t\t\tpos: 'right'\n\t\t\t\t},\n\t\t\t\tfunction() {\n\t\t\t\t\treturn this.state.yMarkers;\n\t\t\t\t}.bind(this)\n\t\t\t]\n\t\t];\n\n\t\tcomponentConfigs = componentConfigs.concat(barsConfigs, lineConfigs, markerConfigs);\n\n\t\tlet optionals = ['yMarkers', 'yRegions'];\n\t\tthis.dataUnitComponents = [];\n\n\t\tthis.components = new Map(componentConfigs\n\t\t\t.filter(args => !optionals.includes(args[0]) || this.state[args[0]])\n\t\t\t.map(args => {\n\t\t\t\tlet component = getComponent(...args);\n\t\t\t\tif(args[0].includes('lineGraph') || args[0].includes('barGraph')) {\n\t\t\t\t\tthis.dataUnitComponents.push(component);\n\t\t\t\t}\n\t\t\t\treturn [args[0], component];\n\t\t\t}));\n\t}\n\n\tmakeDataByIndex() {\n\t\tthis.dataByIndex = {};\n\n\t\tlet s = this.state;\n\t\tlet formatX = this.config.formatTooltipX;\n\t\tlet formatY = this.config.formatTooltipY;\n\t\tlet titles = s.xAxis.labels;\n\n\t\ttitles.map((label, index) => {\n\t\t\tlet values = this.state.datasets.map((set, i) => {\n\t\t\t\tlet value = set.values[index];\n\t\t\t\treturn {\n\t\t\t\t\ttitle: set.name,\n\t\t\t\t\tvalue: value,\n\t\t\t\t\tyPos: set.yPositions[index],\n\t\t\t\t\tcolor: this.colors[i],\n\t\t\t\t\tformatted: formatY ? formatY(value) : value,\n\t\t\t\t};\n\t\t\t});\n\n\t\t\tthis.dataByIndex[index] = {\n\t\t\t\tlabel: label,\n\t\t\t\tformattedLabel: formatX ? formatX(label) : label,\n\t\t\t\txPos: s.xAxis.positions[index],\n\t\t\t\tvalues: values,\n\t\t\t\tyExtreme: s.yExtremes[index],\n\t\t\t};\n\t\t});\n\t}\n\n\tbindTooltip() {\n\t\t// NOTE: could be in tooltip itself, as it is a given functionality for its parent\n\t\tthis.container.addEventListener('mousemove', (e) => {\n\t\t\tlet m = this.measures;\n\t\t\tlet o = getOffset(this.container);\n\t\t\tlet relX = e.pageX - o.left - getLeftOffset(m);\n\t\t\tlet relY = e.pageY - o.top;\n\n\t\t\tif(relY < this.height + getTopOffset(m)\n\t\t\t\t&& relY > getTopOffset(m)) {\n\t\t\t\tthis.mapTooltipXPosition(relX);\n\t\t\t} else {\n\t\t\t\tthis.tip.hideTip();\n\t\t\t}\n\t\t});\n\t}\n\n\tmapTooltipXPosition(relX) {\n\t\tlet s = this.state;\n\t\tif(!s.yExtremes) return;\n\n\t\tlet index = getClosestInArray(relX, s.xAxis.positions, true);\n\t\tif (index >= 0) {\n\t\t\tlet dbi = this.dataByIndex[index];\n\n\t\t\tthis.tip.setValues(\n\t\t\t\tdbi.xPos + this.tip.offset.x,\n\t\t\t\tdbi.yExtreme + this.tip.offset.y,\n\t\t\t\t{name: dbi.formattedLabel, value: ''},\n\t\t\t\tdbi.values,\n\t\t\t\tindex\n\t\t\t);\n\n\t\t\tthis.tip.showTip();\n\t\t}\n\t}\n\n\trenderLegend() {\n\t\tlet s = this.data;\n\t\tif(s.datasets.length > 1) {\n\t\t\tthis.legendArea.textContent = '';\n\t\t\ts.datasets.map((d, i) => {\n\t\t\t\tlet barWidth = AXIS_LEGEND_BAR_SIZE;\n\t\t\t\t// let rightEndPoint = this.baseWidth - this.measures.margins.left - this.measures.margins.right;\n\t\t\t\t// let multiplier = s.datasets.length - i;\n\t\t\t\tlet rect = legendBar(\n\t\t\t\t\t// rightEndPoint - multiplier * barWidth,\t// To right align\n\t\t\t\t\tbarWidth * i,\n\t\t\t\t\t'0',\n\t\t\t\t\tbarWidth,\n\t\t\t\t\tthis.colors[i],\n\t\t\t\t\td.name,\n\t\t\t\t\tthis.config.truncateLegends);\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 AggregationChart from './AggregationChart';\nimport { getComponent } from '../objects/ChartComponents';\nimport { getOffset } from '../utils/dom';\nimport { getPositionByAngle } from '../utils/helpers';\nimport { makeArcStrokePathStr, makeStrokeCircleStr } from '../utils/draw';\nimport { lightenDarkenColor } from '../utils/colors';\nimport { transform } from '../utils/animation';\nimport { FULL_ANGLE } from '../utils/constants';\n\nexport default class DonutChart extends AggregationChart {\n\tconstructor(parent, args) {\n\t\tsuper(parent, args);\n\t\tthis.type = 'donut';\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\tthis.strokeWidth = args.strokeWidth || 30;\n\t}\n\n\tcalc() {\n\t\tsuper.calc();\n\t\tlet s = this.state;\n\t\tthis.radius =\n\t\t\tthis.height > this.width\n\t\t\t\t? this.center.x - this.strokeWidth / 2\n\t\t\t\t: this.center.y - this.strokeWidth / 2;\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 largeArc = originDiffAngle > 180 ? 1: 0;\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 =\n\t\t\t\toriginDiffAngle === 360\n\t\t\t\t\t? makeStrokeCircleStr(curStart, curEnd, this.center, this.radius, this.clockWise, largeArc)\n\t\t\t\t\t: makeArcStrokePathStr(curStart, curEnd, this.center, this.radius, this.clockWise, largeArc);\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'donutSlices',\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\tstrokeWidth: this.strokeWidth,\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.stroke = 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.stroke = 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('donutSlices').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"],"names":["styleInject","css","ref","insertAt","document","head","getElementsByTagName","style","createElement","type","firstChild","insertBefore","appendChild","styleSheet","cssText","createTextNode","$","expr","con","querySelector","getOffset","element","rect","getBoundingClientRect","top","documentElement","scrollTop","body","left","scrollLeft","isHidden","el","offsetParent","isElementInViewport","bottom","window","innerHeight","clientHeight","right","innerWidth","clientWidth","getElementContentWidth","styles","getComputedStyle","padding","parseFloat","paddingLeft","paddingRight","fire","target","properties","evt","createEvent","initEvent","j","dispatchEvent","getTopOffset","m","titleHeight","margins","paddings","getLeftOffset","getExtraHeight","legendHeight","getExtraWidth","floatTwo","d","toFixed","fillArray","array","count","start","length","fillerArray","Array","Math","abs","fill","concat","getStringWidth","string","charWidth","getPositionByAngle","angle","radius","sin","ANGLE_RATIO","cos","isValidNumber","candidate","nonNegative","Number","isNaN","undefined","isFinite","round","deepClone","cloned","value","key","Date","getTime","isArray","getBarHeightAndYAttr","yTop","zeroLine","height","y","equilizeNoOfElements","array1","array2","extraCount","truncateString","txt","len","slice","shortenLargeNumber","label","number","p","floor","log10","l","shortened","pow","getSplineCurvePointsStr","xList","yList","points","i","push","line","pointA","pointB","lengthX","lengthY","sqrt","atan2","controlPoint","current","previous","next","reverse","o","PI","command","reduce","acc","point","a","cps","cpe","limitColor","r","lightenDarkenColor","color","amt","col","getColor","usePound","num","parseInt","b","g","toString","isValidColor","RGB_RE","test","createSVG","tag","createElementNS","val","parentNode","keys","map","prop","setAttribute","renderVerticalGradient","svgDefElem","gradientId","setGradientStop","gradElem","offset","opacity","makeSVGContainer","parent","className","width","makeSVGDefs","svgContainer","makeSVGGroup","transform","args","inside","makePath","pathStr","makeArcPathStr","startPosition","endPosition","center","clockWise","largeArc","arcStartX","x","arcStartY","arcEndX","arcEndY","makeCircleStr","midArc","makeArcStrokePathStr","makeStrokeCircleStr","makeGradient","lighter","gradientDef","opacities","percentageBar","depth","PERCENTAGE_BAR_DEFAULT_DEPTH","heatSquare","size","data","legendBar","LABEL_MAX_CHARS","text","FONT_SIZE","FONT_FILL","group","legendDot","makeText","content","options","fontSize","dy","textAnchor","makeVertLine","y1","y2","stroke","BASE_LINE_COLOR","LABEL_MARGIN","makeHoriLine","x1","x2","lineType","shortenNumbers","yLine","pos","mode","AXIS_TICK_LENGTH","xLine","yMarker","labelPos","labelSvg","yRegion","region","datasetBar","index","meta","minHeight","datasetDot","dot","getPaths","pointsStr","join","spline","path","heatline","gradient_id","svgDefs","paths","regionFill","gradient_id_region","translate","unit","oldCoord","newCoord","duration","old","STD_EASING","translateVertLine","newX","oldX","MARKER_LINE_ANIM_DUR","translateHoriLine","newY","oldY","animateRegion","rectGroup","newY1","newY2","oldY2","newHeight","childNodes","stroke-dasharray","getAttribute","animateBar","bar","nodeName","UNIT_ANIM_DUR","split","animateDot","cx","cy","animatePath","newXList","newYList","pathComponents","animPath","PATH_ANIM_DUR","regStartPt","regEndPt","animRegion","animatePathStr","oldPath","animateSVGElement","props","dur","easingType","oldValues","animElement","cloneNode","newElement","attributeName","animateElement","currentValue","animAttr","EASING","webkitTransform","msTransform","mozTransform","oTransform","animateSVG","elements","newElements","animElements","replaceChild","animSvg","runSMILAnimation","svgElement","elementsToAnimate","animSvgElement","removeChild","REPLACE_ALL_NEW_DUR","downloadFile","filename","blob","Blob","url","URL","createObjectURL","href","download","click","revokeObjectURL","prepareForExport","svg","clone","classList","add","styleEl","create","CSSTEXT","container","innerHTML","treatAsUtc","date","result","setMinutes","getMinutes","getTimezoneOffset","getYyyyMmDd","dd","getDate","mm","getMonth","getFullYear","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","mantissa","exponent","sig","exp","getChartRangeIntervals","max","min","upperBound","lowerBound","range","noOfParts","partSize","intervals","getChartIntervals","maxValue","minValue","normalMaxValue","normalMinValue","calcChartIntervals","values","getPositiveFirstIntervals","absMinValue","intervalSize","unshift","withMinimum","pseudoMaxValue","pseudoMinValue","getZeroIndex","yPts","interval","getIntervalSize","indexOf","orderedArray","getValueRange","scale","yAxis","scaleMultiplier","getClosestInArray","goal","arr","closest","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","allowedSpace","allowedLetters","DEFAULT_CHAR_WIDTH","seriesMultiple","maxLabelLength","getChartByType","AxisChart","chartTypes","error","BASE_MEASURES","INIT_CHART_UPDATE_TIMEOUT","CHART_POST_ANIMATE_TIMEOUT","DEFAULT_AXIS_CHART_TYPE","AXIS_LEGEND_BAR_SIZE","BAR_CHART_SPACE_RATIO","MIN_BAR_PERCENT_HEIGHT","LINE_CHART_DOT_SIZE","DOT_OVERLAY_SIZE_INCR","PERCENTAGE_BAR_DEFAULT_HEIGHT","HEATMAP_DISTRIBUTION_SIZE","HEATMAP_SQUARE_SIZE","HEATMAP_GUTTER_SIZE","TOOLTIP_POINTER_TRIANGLE_HEIGHT","DEFAULT_CHART_COLORS","HEATMAP_COLORS_GREEN","DEFAULT_COLORS","FULL_ANGLE","SvgTip","colors","titleName","titleValue","listValues","titleValueFirst","setup","makeTooltip","calcPosition","this","hideTip","title","dataPointList","addEventListener","set","_this2","formatted","li","offsetWidth","offsetHeight","maxLeft","pointer","pointerOffset","valueFirst","refresh","PRESET_COLOR_MAP","exec","c","ch","makeOverlay","transformValue","overlay","updateOverlay","attributes","attr","specified","nodeValue","BaseChart","HTMLElement","Error","rawChartArgs","prepareData","prepareFirstData","validateColors","isNavigable","animate","truncateLegends","measures","JSON","parse","stringify","setMeasures","showLegend","argHeight","baseHeight","state","initTimeout","overlays","configure","validColors","forEach","warn","boundDrawFn","_this","draw","ResizeObserver","resizeObserver","observe","disconnect","removeEventListener","makeContainer","updateWidth","independentWidth","tip","bindTooltip","onlyWidthChange","init","calc","makeChartArea","setupComponents","components","drawArea","render","update","renderLegend","setupNavigation","baseWidth","titleEL","titleFontSize","legendArea","updateTipOffset","Map","make","updateNav","bindUnits","bindOverlay","keyActions","onEnterKey","bind","onLeftArrow","onUpArrow","onRightArrow","onDownArrow","e","_this4","event","keyCode","chartSvg","AggregationChart","formatTooltipY","tooltipOptions","maxSlices","maxLegendPoints","s","sliceTotals","allTotals","total","totals","sort","sumOfRemaining","grandTotal","textContent","legendTotals","barWidth","divisor","_this3","NO_OF_YEAR_MONTHS","DAY_NAMES_SHORT","layerClass","layerTransform","makeElements","animateElements","store","layer","oldData","sliceStrings","strokeWidth","transition","newData","xPositions","widths","barHeight","barDepth","positions","position","newPos","newLabels","oldPos","oldLabels","calcLabels","_this5","newOptions","startPos","endPos","_this6","newStarts","oldStarts","colWidth","rowHeight","squareSize","xTranslate","serializedSubDomains","cols","week","weekNo","toUpperCase","yyyyMmDd","dataValue","square","unitType","units","yPositions","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","COL_WIDTH","ROW_HEIGHT","Heatmap","countLabel","validStarts","startSubDomain","startSubDomainIndex","discreteDomains","spacing","noOfWeeks","setFullYear","dataPoints","timestampSec","firstWeekStart","domainConfigs","getDomains","lessCol","dayName","dayText","daySquares","comp","daySquare","dateParts","lessText","moreText","startMonth","startYear","noOfMonths","startOfMonth","getDomainConfig","startOfWeek","domainConfig","noOfMonthWeeks","getCol","empty","currentDate","currentDateWithinData","getSubDomainConfig","lineOptions","axisOptions","xAxisMode","yAxisMode","xIsSeries","shortenYAxisNumbers","formatTooltipX","calcXPositions","calcYAxisParameters","getAllYValues","makeDataByIndex","unitWidth","xOffset","xAxis","dataValues","intervalHeight","calcDatasetPoints","calcYExtremes","calcYRegions","scaleAll","cumulativeYs","replace","char","stacked","yExtremes","cumulativeYPos","cumulative","allValueLists","barDatasets","lineDatasets","barsConfigs","spaceRatio","lineConfigs","minLine","dotSize","markerConfigs","optionals","dataUnitComponents","dataByIndex","formatX","formatY","relX","relY","mapTooltipXPosition","dbi","yExtreme","formattedLabel","overlayGuides","currentIndex","currentUnit","_this7","setCurrentDataPoint","_this9","_this10","getDataPoint","datasetValues","splice","DonutChart","Chart"],"mappings":"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"}