/** * @preserve CanvasJS HTML5 & JavaScript Charts - v1.7.0 GA - http://canvasjs.com/ * Copyright 2013 fenopix */ (function() { function w(n, t) { n.prototype = yi(t.prototype); n.prototype.constructor = n; n.base = t.prototype } function yi(n) { function t() {} return t.prototype = n, new t } function oi(n, t, i) { return i === "millisecond" ? n.setMilliseconds(n.getMilliseconds() + 1 * t) : i === "second" ? n.setSeconds(n.getSeconds() + 1 * t) : i === "minute" ? n.setMinutes(n.getMinutes() + 1 * t) : i === "hour" ? n.setHours(n.getHours() + 1 * t) : i === "day" ? n.setDate(n.getDate() + 1 * t) : i === "week" ? n.setDate(n.getDate() + 7 * t) : i === "month" ? n.setMonth(n.getMonth() + 1 * t) : i === "year" && n.setFullYear(n.getFullYear() + 1 * t), n } function st(n, t) { return f[t + "Duration"] * n } function v(n, t) { var i = !1; for (n < 0 && (i = !0, n *= -1), n = "" + n, t = t ? t : 1; n.length < t;) n = "0" + n; return i ? "-" + n : n } function ht(n) { if (!n) return n; n = n.replace(/^\s\s*/, ""); for (var t = n.length; /\s/.test(n.charAt(--t));); return n.slice(0, t + 1) } function pi(n) { n.roundRect = function(n, t, i, r, u, f, e, o) { e && (this.fillStyle = e); o && (this.strokeStyle = o); typeof u == "undefined" && (u = 5); this.lineWidth = f; this.beginPath(); this.moveTo(n + u, t); this.lineTo(n + i - u, t); this.quadraticCurveTo(n + i, t, n + i, t + u); this.lineTo(n + i, t + r - u); this.quadraticCurveTo(n + i, t + r, n + i - u, t + r); this.lineTo(n + u, t + r); this.quadraticCurveTo(n, t + r, n, t + r - u); this.lineTo(n, t + u); this.quadraticCurveTo(n, t, n + u, t); this.closePath(); e && this.fill(); o && f > 0 && this.stroke() } } function si(n, t) { return n - t } function wi(n, t) { return n.x - t.x } function u(n) { var t = ((n & 16711680) >> 16).toString(16), i = ((n & 65280) >> 8).toString(16), r = ((n & 255) >> 0).toString(16); return t = t.length < 2 ? "0" + t : t, i = i.length < 2 ? "0" + i : i, r = r.length < 2 ? "0" + r : r, "#" + t + i + r } function bi(n, t, i) { return n << 16 | t << 8 | i } function ki(n) { var i = this.length >>> 0, t = Number(arguments[1]) || 0; for (t = t < 0 ? Math.ceil(t) : Math.floor(t), t < 0 && (t += i); t < i; t++) if (t in this && this[t] === n) return t; return -1 } function di(n) { return n.indexOf || (n.indexOf = ki), n } function pt(n, t, i) { var u, r, f, e, o; if (i = i || "normal", u = n + "_" + t + "_" + i, r = hi[u], isNaN(r)) { try { f = "position:absolute; left:0px; top:-20000px; padding:0px;margin:0px;border:none;white-space:pre;line-height:normal;font-family:" + n + "; font-size:" + t + "px; font-weight:" + i + ";"; g || (e = document.body, g = document.createElement("span"), g.innerHTML = "", o = document.createTextNode("Mpgyi"), g.appendChild(o), e.appendChild(g)); g.style.display = ""; g.setAttribute("style", f); r = Math.round(g.offsetHeight); g.style.display = "none" } catch (s) { r = Math.ceil(t * 1.1) } r = Math.max(r, t); hi[u] = r } return r } function y(n, t) { var i = [], r; if (n = n || "solid", lineDashTypeMap = { solid: [], shortDash: [3, 1], shortDot: [1, 1], shortDashDot: [3, 1, 1, 1], shortDashDotDot: [3, 1, 1, 1, 1, 1], dot: [1, 2], dash: [4, 2], dashDot: [4, 2, 1, 2], longDash: [8, 2], longDashDot: [8, 2, 1, 2], longDashDotDot: [8, 2, 1, 2, 1, 2] }, i = lineDashTypeMap[n], i) for (r = 0; r < i.length; r++) i[r] *= t; else i = []; return i } function s(n, t, i, r) { if (n.addEventListener) n.addEventListener(t, i, r || !1); else if (n.attachEvent) n.attachEvent("on" + t, function(t) { t = t || window.event; t.preventDefault = t.preventDefault || function() { t.returnValue = !1 }; t.stopPropagation = t.stopPropagation || function() { t.cancelBubble = !0 }; i.call(n, t) }); else return !1 } function ci(n, t, i) { var r, f, u; for (n *= l, t *= l, r = i.getImageData(n, t, 2, 2).data, f = !0, u = 0; u < 4; u++) if (r[u] !== r[u + 4] | r[u] !== r[u + 8] | r[u] !== r[u + 12]) { f = !1; break } return f ? bi(r[0], r[1], r[2]) : 0 } function gi(t, i, r) { var u = "", e = t ? t + "FontStyle" : "fontStyle", o = t ? t + "FontWeight" : "fontWeight", s = t ? t + "FontSize" : "fontSize", h = t ? t + "FontFamily" : "fontFamily", c, f; return u += i[e] ? i[e] + " " : r && r[e] ? r[e] + " " : "", u += i[o] ? i[o] + " " : r && r[o] ? r[o] + " " : "", u += i[s] ? i[s] + "px " : r && r[s] ? r[s] + "px " : "", c = i[h] ? i[h] + "" : r && r[h] ? r[h] + "" : "", !n && c ? (f = c.split(",")[0], f[0] !== "'" && f[0] !== '"' && (f = "'" + f + "'"), u += f) : u += c, u } function p(n, t, i) { return n in t ? t[n] : i[n] } function ct(t, i, r) { if (n && !!li) { var u = t.getContext("2d"); bt = u.webkitBackingStorePixelRatio || u.mozBackingStorePixelRatio || u.msBackingStorePixelRatio || u.oBackingStorePixelRatio || u.backingStorePixelRatio || 1; l = ri / bt; t.width = i * l; t.height = r * l; ri !== bt && (t.style.width = i + "px", t.style.height = r + "px", u.scale(l, l)) } else t.width = i, t.height = r } function rt(t, i) { var r = document.createElement("canvas"); return r.setAttribute("class", "canvasjs-chart-canvas"), ct(r, t, i), n || typeof G_vmlCanvasManager == "undefined" || G_vmlCanvasManager.initElement(r), r } function ai(n, t, i) { var u, o, s; if (n && t && i) { var h = i + "." + (t === "jpeg" ? "jpg" : t), c = "image/" + t, f = n.toDataURL(c), l = !1, r = document.createElement("a"); if (r.download = h, r.href = f, r.target = "_blank", typeof Blob != "undefined" && !!new Blob) { var v = f.replace(/^data:[a-z/]*;base64,/, ""), e = atob(v), a = new ArrayBuffer(e.length), y = new Uint8Array(a); for (u = 0; u < e.length; u++) y[u] = e.charCodeAt(u); o = new Blob([a], { type: "image/" + t }); try { window.navigator.msSaveBlob(o, h); l = !0 } catch (p) { r.dataset.downloadurl = [c, r.download, r.href].join(":"); r.href = window.URL.createObjectURL(o) } } if (!l) try { event = document.createEvent("MouseEvents"); event.initMouseEvent("click", !0, !1, window, 0, 0, 0, 0, 0, !1, !1, !1, !1, 0, null); r.dispatchEvent ? r.dispatchEvent(event) : r.fireEvent && r.fireEvent("onclick") } catch (p) { s = window.open(); s.document.write("<\/img>
Please right click on the image and save it to your device<\/div>"); s.document.close() } } } function b(n, t, i) { t.getAttribute("state") !== i && (t.setAttribute("state", i), t.setAttribute("type", "button"), t.style.position = "relative", t.style.margin = "0px 0px 0px 0px", t.style.padding = "3px 4px 0px 4px", t.style.cssFloat = "left", t.setAttribute("title", n._cultureInfo[i + "Text"]), t.innerHTML = "" + n._cultureInfo[i + "Text"] + "") } function ui() { for (var n = null, t = 0; t < arguments.length; t++) n = arguments[t], n.style && (n.style.display = "inline") } function nt() { for (var n = null, t = 0; t < arguments.length; t++) n = arguments[t], n && n.style && (n.style.display = "none") } function h(n, t, i, r) { this._defaultsKey = n; this.parent = r; this._eventListeners = []; var u = {}; i && ut[i] && ut[i][n] && (u = ut[i][n]); this._options = t ? t : {}; this.setOptions(this._options, u) } function t(i, r, u) { var f, e, o; if (this._publicChartReference = u, r = r || {}, t.base.constructor.call(this, "Chart", r, r.theme ? r.theme : "theme1"), f = this, this._containerId = i, this._objectsInitialized = !1, this.ctx = null, this.overlaidCanvasCtx = null, this._indexLabels = [], this._panTimerId = 0, this._lastTouchEventType = "", this._lastTouchData = null, this.isAnimating = !1, this.renderCount = 0, this.animatedRender = !1, this.disableToolTip = !1, this.panEnabled = !1, this._defaultCursor = "default", this.plotArea = { canvas: null, ctx: null, x1: 0, y1: 0, x2: 0, y2: 0, width: 0, height: 0 }, this._dataInRenderedOrder = [], this._container = typeof this._containerId == "string" ? document.getElementById(this._containerId) : this._containerId, !this._container) { window.console && window.console.log('CanvasJS Error: Chart Container with id "' + this._containerId + '" was not found'); return } if (this._container.innerHTML = "", e = 0, o = 0, e = this._options.width ? this.width : this._container.clientWidth > 0 ? this._container.clientWidth : this.width, o = this._options.height ? this.height : this._container.clientHeight > 0 ? this._container.clientHeight : this.height, this.width = e, this.height = o, this.x1 = this.y1 = 0, this.x2 = this.width, this.y2 = this.height, this._selectedColorSet = typeof tt[this.colorSet] != "undefined" ? tt[this.colorSet] : tt.colorSet1, this._canvasJSContainer = document.createElement("div"), this._canvasJSContainer.setAttribute("class", "canvasjs-chart-container"), this._canvasJSContainer.style.position = "relative", this._canvasJSContainer.style.textAlign = "left", this._canvasJSContainer.style.cursor = "auto", n || (this._canvasJSContainer.style.height = "0px"), this._container.appendChild(this._canvasJSContainer), this.canvas = rt(e, o), this.canvas.style.position = "absolute", this.canvas.getContext) this._canvasJSContainer.appendChild(this.canvas), this.ctx = this.canvas.getContext("2d"), this.ctx.textBaseline = "top", pi(this.ctx); else return; n ? this.plotArea.ctx = this.ctx : (this.plotArea.canvas = rt(e, o), this.plotArea.canvas.style.position = "absolute", this.plotArea.canvas.setAttribute("class", "plotAreaCanvas"), this._canvasJSContainer.appendChild(this.plotArea.canvas), this.plotArea.ctx = this.plotArea.canvas.getContext("2d")); this.overlaidCanvas = rt(e, o); this.overlaidCanvas.style.position = "absolute"; this._canvasJSContainer.appendChild(this.overlaidCanvas); this.overlaidCanvasCtx = this.overlaidCanvas.getContext("2d"); this.overlaidCanvasCtx.textBaseline = "top"; this._eventManager = new at(this); s(window, "resize", function() { f._updateSize() && f.render() }); this._toolBar = document.createElement("div"); this._toolBar.setAttribute("class", "canvasjs-chart-toolbar"); this._toolBar.style.cssText = "position: absolute; right: 1px; top: 1px;"; this._canvasJSContainer.appendChild(this._toolBar); this.bounds = { x1: 0, y1: 0, x2: this.width, y2: this.height }; s(this.overlaidCanvas, "click", function(n) { f._mouseEventHandler(n) }); s(this.overlaidCanvas, "mousemove", function(n) { f._mouseEventHandler(n) }); s(this.overlaidCanvas, "mouseup", function(n) { f._mouseEventHandler(n) }); s(this.overlaidCanvas, "mousedown", function(n) { f._mouseEventHandler(n); nt(f._dropdownMenu) }); s(this.overlaidCanvas, "mouseout", function(n) { f._mouseEventHandler(n) }); s(this.overlaidCanvas, window.navigator.msPointerEnabled ? "MSPointerDown" : "touchstart", function(n) { f._touchEventHandler(n) }); s(this.overlaidCanvas, window.navigator.msPointerEnabled ? "MSPointerMove" : "touchmove", function(n) { f._touchEventHandler(n) }); s(this.overlaidCanvas, window.navigator.msPointerEnabled ? "MSPointerUp" : "touchend", function(n) { f._touchEventHandler(n) }); s(this.overlaidCanvas, window.navigator.msPointerEnabled ? "MSPointerCancel" : "touchcancel", function(n) { f._touchEventHandler(n) }); this._creditLink || (this._creditLink = document.createElement("a"), this._creditLink.setAttribute("class", "canvasjs-chart-credit"), this._creditLink.setAttribute("style", "outline:none;margin:0px;position:absolute;right:3px;top:" + (this.height - 14) + "px;color:dimgrey;text-decoration:none;font-size:10px;font-family:Lucida Grande, Lucida Sans Unicode, Arial, sans-serif"), this._creditLink.setAttribute("tabIndex", -1), this._creditLink.setAttribute("target", "_blank")); this._toolTip = new k(this, this._options.toolTip, this.theme); this.data = null; this.axisX = null; this.axisY = null; this.axisY2 = null; this.sessionVariables = { axisX: { internalMinimum: null, internalMaximum: null }, axisY: { internalMinimum: null, internalMaximum: null }, axisY2: { internalMinimum: null, internalMaximum: null } } } function kt(n, t) { for (var f, e, i, o, h, s, c, r = [], u = 0; u < n.length; u++) { if (u == 0) { r.push(n[0]); continue } i = u - 1; f = i === 0 ? 0 : i - 1; e = i === n.length - 1 ? i : i + 1; o = { x: (n[e].x - n[f].x) / t, y: (n[e].y - n[f].y) / t }; h = { x: n[i].x + o.x / 3, y: n[i].y + o.y / 3 }; r[r.length] = h; i = u; f = i === 0 ? 0 : i - 1; e = i === n.length - 1 ? i : i + 1; s = { x: (n[e].x - n[f].x) / t, y: (n[e].y - n[f].y) / t }; c = { x: n[i].x - s.x / 3, y: n[i].y - s.y / 3 }; r[r.length] = c; r[r.length] = n[u] } return r } function ft(n, t, i, r, u) { typeof u == "undefined" && (u = 0); this._padding = u; this._x1 = n; this._y1 = t; this._x2 = i; this._y2 = r; this._topOccupied = this._padding; this._bottomOccupied = this._padding; this._leftOccupied = this._padding; this._rightOccupied = this._padding } function c(n, t) { c.base.constructor.call(this, "TextBlock", t); this.ctx = n; this._isDirty = !0; this._wrappedText = null; this._lineHeight = pt(this.fontFamily, this.fontSize, this.fontWeight) } function lt(n, t) { lt.base.constructor.call(this, "Title", t, n.theme); this.chart = n; this.canvas = n.canvas; this.ctx = this.chart.ctx; typeof this._options.fontSize == "undefined" && (this.fontSize = this.chart.getAutoFontSize(this.fontSize)); this.width = null; this.height = null; this.bounds = { x1: null, y1: null, x2: null, y2: null } } function gt(n, t) { gt.base.constructor.call(this, "Subtitle", t, n.theme); this.chart = n; this.canvas = n.canvas; this.ctx = this.chart.ctx; typeof this._options.fontSize == "undefined" && (this.fontSize = this.chart.getAutoFontSize(this.fontSize)); this.width = null; this.height = null; this.bounds = { x1: null, y1: null, x2: null, y2: null } } function ni(n, t, i) { ni.base.constructor.call(this, "Legend", t, i); this.chart = n; this.canvas = n.canvas; this.ctx = this.chart.ctx; this.ghostCtx = this.chart._eventManager.ghostCtx; this.items = []; this.width = 0; this.height = 0; this.orientation = null; this.dataSeries = []; this.bounds = { x1: null, y1: null, x2: null, y2: null }; typeof this._options.fontSize == "undefined" && (this.fontSize = this.chart.getAutoFontSize(this.fontSize)); this.lineHeight = pt(this.fontFamily, this.fontSize, this.fontWeight); this.horizontalSpacing = this.fontSize } function fi(n, t) { fi.base.constructor.call(this, t); this.chart = n; this.canvas = n.canvas; this.ctx = this.chart.ctx } function d(n, t, i, r, u) { d.base.constructor.call(this, "DataSeries", t, i); this.chart = n; this.canvas = n.canvas; this._ctx = n.canvas.ctx; this.index = r; this.noDataPointsInPlotArea = 0; this.id = u; this.chart._eventManager.objectMap[u] = { id: u, objectType: "dataSeries", dataSeriesIndex: r }; this.dataPointIds = []; this.plotUnit = []; this.axisX = null; this.axisY = null; this.fillOpacity === null && (this.fillOpacity = this.type.match(/area/i) ? .7 : 1); this.axisPlacement = this.getDefaultAxisPlacement(); typeof this._options.indexLabelFontSize == "undefined" && (this.indexLabelFontSize = this.chart.getAutoFontSize(this.indexLabelFontSize)) } function e(n, t, i, r) { if (e.base.constructor.call(this, "Axis", t, n.theme), this.chart = n, this.canvas = n.canvas, this.ctx = n.ctx, this.maxWidth = 0, this.maxHeight = 0, this.intervalstartTimePercent = 0, this.labels = [], this._labels = null, this.dataInfo = { min: Infinity, max: -Infinity, viewPortMin: Infinity, viewPortMax: -Infinity, minDiff: Infinity }, i === "axisX" ? (this.sessionVariables = this.chart.sessionVariables[i], this._options.interval || (this.intervalType = null)) : this.sessionVariables = r === "left" || r === "top" ? this.chart.sessionVariables.axisY : this.chart.sessionVariables.axisY2, typeof this._options.titleFontSize == "undefined" && (this.titleFontSize = this.chart.getAutoFontSize(this.titleFontSize)), typeof this._options.labelFontSize == "undefined" && (this.labelFontSize = this.chart.getAutoFontSize(this.labelFontSize)), this.type = i, i !== "axisX" || t && typeof t.gridThickness != "undefined" || (this.gridThickness = 0), this._position = r, this.lineCoordinates = { x1: null, y1: null, x2: null, y2: null, width: null }, this.labelAngle = (this.labelAngle % 360 + 360) % 360, this.labelAngle > 90 && this.labelAngle <= 270 ? this.labelAngle -= 180 : this.labelAngle > 180 && this.labelAngle <= 270 ? this.labelAngle -= 180 : this.labelAngle > 270 && this.labelAngle <= 360 && (this.labelAngle -= 360), this._options.stripLines && this._options.stripLines.length > 0) { this.stripLines = []; for (var u = 0; u < this._options.stripLines.length; u++) this.stripLines.push(new ti(this.chart, this._options.stripLines[u], n.theme, ++this.chart._eventManager.lastObjectId, this)) } this._titleTextBlock = null; this._absoluteMinimum = null; this._absoluteMaximum = null; this.hasOptionChanged("minimum") && (this.sessionVariables.internalMinimum = this.minimum); this.hasOptionChanged("maximum") && (this.sessionVariables.internalMaximum = this.maximum); this.trackChanges("minimum"); this.trackChanges("maximum") } function ti(n, t, i, r, u) { ti.base.constructor.call(this, "StripLine", t, i, u); this.id = r; this.chart = n; this.ctx = this.chart.ctx; this.label = this.label; this._thicknessType = "pixel"; this.startValue !== null && this.endValue !== null && (this.value = ((this.startValue.getTime ? this.startValue.getTime() : this.startValue) + (this.endValue.getTime ? this.endValue.getTime() : this.endValue)) / 2, this.thickness = Math.max(this.endValue - this.startValue), this._thicknessType = "value") } function k(n, t, i) { k.base.constructor.call(this, "ToolTip", t, i); this.chart = n; this.canvas = n.canvas; this.ctx = this.chart.ctx; this.currentSeriesIndex = -1; this.currentDataPointIndex = -1; this._timerId = 0; this._prevX = NaN; this._prevY = NaN; this._initialize() } function at(n) { var t, i; this.chart = n; this.lastObjectId = 0; t = this; this.objectMap = []; this.rectangularRegionEventSubscriptions = []; this.previousDataPointEventObject = null; this.ghostCanvas = rt(this.chart.width, this.chart.height); this.ghostCtx = this.ghostCanvas.getContext("2d"); i = function(n) { t.mouseEventHandler.call(t, n) }; this.mouseoveredObjectMaps = [] } function vt(n) { var t; n && ot[n] && (t = ot[n]); vt.base.constructor.call(this, "CultureInfo", t) } function ei(n) { this.chart = n; this.ctx = this.chart.plotArea.ctx; this.animations = []; this.animationRequestId = null } var yt = !1, n = !!document.createElement("canvas").getContext, et = { Chart: { width: 500, height: 400, zoomEnabled: !1, backgroundColor: "white", theme: "theme1", animationEnabled: !1, animationDuration: 1200, dataPointMaxWidth: null, colorSet: "colorSet1", culture: "en", creditText: "CanvasJS.com", interactivityEnabled: !0, exportEnabled: !1, exportFileName: "Chart" }, Title: { padding: 0, text: null, verticalAlign: "top", horizontalAlign: "center", fontSize: 20, fontFamily: "Calibri", fontWeight: "normal", fontColor: "black", fontStyle: "normal", borderThickness: 0, borderColor: "black", cornerRadius: 0, backgroundColor: null, margin: 5, wrap: !0, maxWidth: null, dockInsidePlotArea: !1 }, Subtitle: { padding: 0, text: null, verticalAlign: "top", horizontalAlign: "center", fontSize: 14, fontFamily: "Calibri", fontWeight: "normal", fontColor: "black", fontStyle: "normal", borderThickness: 0, borderColor: "black", cornerRadius: 0, backgroundColor: null, margin: 2, wrap: !0, maxWidth: null, dockInsidePlotArea: !1 }, Legend: { name: null, verticalAlign: "center", horizontalAlign: "right", fontSize: 14, fontFamily: "calibri", fontWeight: "normal", fontColor: "black", fontStyle: "normal", cursor: null, itemmouseover: null, itemmouseout: null, itemmousemove: null, itemclick: null, dockInsidePlotArea: !1, reversed: !1, maxWidth: null, maxHeight: null, itemMaxWidth: null, itemWidth: null, itemWrap: !0, itemTextFormatter: null }, ToolTip: { enabled: !0, shared: !1, animationEnabled: !0, content: null, contentFormatter: null, reversed: !1, backgroundColor: null, borderColor: null, borderThickness: 2, cornerRadius: 5, fontSize: 14, fontColor: "#000000", fontFamily: "Calibri, Arial, Georgia, serif;", fontWeight: "normal", fontStyle: "italic" }, Axis: { minimum: null, maximum: null, interval: null, intervalType: null, title: null, titleFontColor: "black", titleFontSize: 20, titleFontFamily: "arial", titleFontWeight: "normal", titleFontStyle: "normal", labelAngle: 0, labelFontFamily: "arial", labelFontColor: "black", labelFontSize: 12, labelFontWeight: "normal", labelFontStyle: "normal", labelAutoFit: !1, labelWrap: !0, labelMaxWidth: null, labelFormatter: null, prefix: "", suffix: "", includeZero: !0, tickLength: 5, tickColor: "black", tickThickness: 1, lineColor: "black", lineThickness: 1, lineDashType: "solid", gridColor: "A0A0A0", gridThickness: 0, gridDashType: "solid", interlacedColor: null, valueFormatString: null, margin: 2, stripLines: [] }, StripLine: { value: null, startValue: null, endValue: null, color: "orange", opacity: null, thickness: 2, lineDashType: "solid", label: "", labelBackgroundColor: "#EEEEEE", labelFontFamily: "arial", labelFontColor: "orange", labelFontSize: 12, labelFontWeight: "normal", labelFontStyle: "normal", labelFormatter: null, showOnTop: !1 }, DataSeries: { name: null, dataPoints: null, label: "", bevelEnabled: !1, highlightEnabled: !0, cursor: null, indexLabel: "", indexLabelPlacement: "auto", indexLabelOrientation: "horizontal", indexLabelFontColor: "black", indexLabelFontSize: 12, indexLabelFontStyle: "normal", indexLabelFontFamily: "Arial", indexLabelFontWeight: "normal", indexLabelBackgroundColor: null, indexLabelLineColor: null, indexLabelLineThickness: 1, indexLabelLineDashType: "solid", indexLabelMaxWidth: null, indexLabelWrap: !0, indexLabelFormatter: null, lineThickness: 2, lineDashType: "solid", color: null, risingColor: "white", fillOpacity: null, startAngle: 0, type: "column", xValueType: "number", axisYType: "primary", xValueFormatString: null, yValueFormatString: null, zValueFormatString: null, percentFormatString: null, showInLegend: null, legendMarkerType: null, legendMarkerColor: null, legendText: null, legendMarkerBorderColor: null, legendMarkerBorderThickness: null, markerType: "circle", markerColor: null, markerSize: null, markerBorderColor: null, markerBorderThickness: null, mouseover: null, mouseout: null, mousemove: null, click: null, toolTipContent: null, visible: !0 }, TextBlock: { x: 0, y: 0, width: null, height: null, maxWidth: null, maxHeight: null, padding: 0, angle: 0, text: "", horizontalAlign: "center", fontSize: 12, fontFamily: "calibri", fontWeight: "normal", fontColor: "black", fontStyle: "normal", borderThickness: 0, borderColor: "black", cornerRadius: 0, backgroundColor: null, textBaseline: "top" }, CultureInfo: { decimalSeparator: ".", digitGroupSeparator: ",", zoomText: "Zoom", panText: "Pan", resetText: "Reset", menuText: "More Options", saveJPGText: "Save as JPG", savePNGText: "Save as PNG", days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], shortDays: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], shortMonths: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"] } }, ot = { en: {} }, tt = { colorSet1: ["#369EAD", "#C24642", "#7F6084", "#86B402", "#A2D1CF", "#C8B631", "#6DBCEB", "#52514E", "#4F81BC", "#A064A1", "#F79647"], colorSet2: ["#4F81BC", "#C0504E", "#9BBB58", "#23BFAA", "#8064A1", "#4AACC5", "#F79647", "#33558B"], colorSet3: ["#8CA1BC", "#36845C", "#017E82", "#8CB9D0", "#708C98", "#94838D", "#F08891", "#0366A7", "#008276", "#EE7757", "#E5BA3A", "#F2990B", "#03557B", "#782970"] }, ut = { theme1: { Chart: { colorSet: "colorSet1" }, Title: { fontFamily: n ? "Calibri, Optima, Candara, Verdana, Geneva, sans-serif" : "calibri", fontSize: 33, fontColor: "#3A3A3A", fontWeight: "bold", verticalAlign: "top", margin: 5 }, Subtitle: { fontFamily: n ? "Calibri, Optima, Candara, Verdana, Geneva, sans-serif" : "calibri", fontSize: 16, fontColor: "#3A3A3A", fontWeight: "bold", verticalAlign: "top", margin: 5 }, Axis: { titleFontSize: 26, titleFontColor: "#666666", titleFontFamily: n ? "Calibri, Optima, Candara, Verdana, Geneva, sans-serif" : "calibri", labelFontFamily: n ? "Calibri, Optima, Candara, Verdana, Geneva, sans-serif" : "calibri", labelFontSize: 18, labelFontColor: "grey", tickColor: "#BBBBBB", tickThickness: 2, gridThickness: 2, gridColor: "#BBBBBB", lineThickness: 2, lineColor: "#BBBBBB" }, Legend: { verticalAlign: "bottom", horizontalAlign: "center", fontFamily: n ? "monospace, sans-serif,arial black" : "calibri" }, DataSeries: { indexLabelFontColor: "grey", indexLabelFontFamily: n ? "Calibri, Optima, Candara, Verdana, Geneva, sans-serif" : "calibri", indexLabelFontSize: 18, indexLabelLineThickness: 1 } }, theme2: { Chart: { colorSet: "colorSet2" }, Title: { fontFamily: "impact, charcoal, arial black, sans-serif", fontSize: 32, fontColor: "#333333", verticalAlign: "top", margin: 5 }, Subtitle: { fontFamily: "impact, charcoal, arial black, sans-serif", fontSize: 14, fontColor: "#333333", verticalAlign: "top", margin: 5 }, Axis: { titleFontSize: 22, titleFontColor: "rgb(98,98,98)", titleFontFamily: n ? "monospace, sans-serif,arial black" : "arial", titleFontWeight: "bold", labelFontFamily: n ? "monospace, Courier New, Courier" : "arial", labelFontSize: 16, labelFontColor: "grey", labelFontWeight: "bold", tickColor: "grey", tickThickness: 2, gridThickness: 2, gridColor: "grey", lineColor: "grey", lineThickness: 0 }, Legend: { verticalAlign: "bottom", horizontalAlign: "center", fontFamily: n ? "monospace, sans-serif,arial black" : "arial" }, DataSeries: { indexLabelFontColor: "grey", indexLabelFontFamily: n ? "Courier New, Courier, monospace" : "arial", indexLabelFontWeight: "bold", indexLabelFontSize: 18, indexLabelLineThickness: 1 } }, theme3: { Chart: { colorSet: "colorSet1" }, Title: { fontFamily: n ? "Candara, Optima, Trebuchet MS, Helvetica Neue, Helvetica, Trebuchet MS, serif" : "calibri", fontSize: 32, fontColor: "#3A3A3A", fontWeight: "bold", verticalAlign: "top", margin: 5 }, Subtitle: { fontFamily: n ? "Candara, Optima, Trebuchet MS, Helvetica Neue, Helvetica, Trebuchet MS, serif" : "calibri", fontSize: 16, fontColor: "#3A3A3A", fontWeight: "bold", verticalAlign: "top", margin: 5 }, Axis: { titleFontSize: 22, titleFontColor: "rgb(98,98,98)", titleFontFamily: n ? "Verdana, Geneva, Calibri, sans-serif" : "calibri", labelFontFamily: n ? "Calibri, Optima, Candara, Verdana, Geneva, sans-serif" : "calibri", labelFontSize: 18, labelFontColor: "grey", tickColor: "grey", tickThickness: 2, gridThickness: 2, gridColor: "grey", lineThickness: 2, lineColor: "grey" }, Legend: { verticalAlign: "bottom", horizontalAlign: "center", fontFamily: n ? "monospace, sans-serif,arial black" : "calibri" }, DataSeries: { bevelEnabled: !0, indexLabelFontColor: "grey", indexLabelFontFamily: n ? "Candara, Optima, Calibri, Verdana, Geneva, sans-serif" : "calibri", indexLabelFontSize: 18, indexLabelLineColor: "lightgrey", indexLabelLineThickness: 2 } } }, f = { numberDuration: 1, yearDuration: 314496e5, monthDuration: 2592e6, weekDuration: 6048e5, dayDuration: 864e5, hourDuration: 36e5, minuteDuration: 6e4, secondDuration: 1e3, millisecondDuration: 1, dayOfWeekFromInt: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"] }, hi = {}, g = null, ii = function() { var n = /D{1,4}|M{1,4}|Y{1,4}|h{1,2}|H{1,2}|m{1,2}|s{1,2}|f{1,3}|t{1,2}|T{1,2}|K|z{1,3}|"[^"]*"|'[^']*'/g, t = ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"], i = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], r = ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"], u = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"], f = /\b(?:[PMCEA][SDP]T|(?:Pacific|Mountain|Central|Eastern|Atlantic) (?:Standard|Daylight|Prevailing) Time|(?:GMT|UTC)(?:[-+]\d{4})?)\b/g, e = /[^-+\dA-Z]/g; return function(o, s, h) { var tt = h ? h.days : t, it = h ? h.months : r, rt = h ? h.shortDays : i, ut = h ? h.shortMonths : u, y = !1; if (o = o && o.getTime ? o : o ? new Date(o) : new Date, isNaN(o)) throw SyntaxError("invalid date"); s.slice(0, 4) === "UTC:" && (s = s.slice(4), y = !0); var c = y ? "getUTC" : "get", k = o[c + "Date"](), d = o[c + "Day"](), p = o[c + "Month"](), w = o[c + "FullYear"](), l = o[c + "Hours"](), g = o[c + "Minutes"](), nt = o[c + "Seconds"](), b = o[c + "Milliseconds"](), a = y ? 0 : o.getTimezoneOffset(); return s.replace(n, function(n) { switch (n) { case "D": return k; case "DD": return v(k, 2); case "DDD": return rt[d]; case "DDDD": return tt[d]; case "M": return p + 1; case "MM": return v(p + 1, 2); case "MMM": return ut[p]; case "MMMM": return it[p]; case "Y": return parseInt(String(w).slice(-2)); case "YY": return v(String(w).slice(-2), 2); case "YYY": return v(String(w).slice(-3), 3); case "YYYY": return v(w, 4); case "h": return l % 12 || 12; case "hh": return v(l % 12 || 12, 2); case "H": return l; case "HH": return v(l, 2); case "m": return g; case "mm": return v(g, 2); case "s": return nt; case "ss": return v(nt, 2); case "f": return String(b).slice(0, 1); case "ff": return v(String(b).slice(0, 2), 2); case "fff": return v(String(b).slice(0, 3), 3); case "t": return l < 12 ? "a" : "p"; case "tt": return l < 12 ? "am" : "pm"; case "T": return l < 12 ? "A" : "P"; case "TT": return l < 12 ? "AM" : "PM"; case "K": return y ? "UTC" : (String(o).match(f) || [""]).pop().replace(e, ""); case "z": return (a > 0 ? "-" : "+") + Math.floor(Math.abs(a) / 60); case "zz": return (a > 0 ? "-" : "+") + v(Math.floor(Math.abs(a) / 60), 2); case "zzz": return (a > 0 ? "-" : "+") + v(Math.floor(Math.abs(a) / 60), 2) + v(Math.abs(a) % 60, 2); default: return n.slice(1, n.length - 1) } }) } }(), it = function(n, t, i) { var w, r, e, nt, s, ft; if (n === null) return ""; n = Number(n); w = n < 0 ? !0 : !1; w && (n *= -1); var at = i ? i.decimalSeparator : ".", b = i ? i.digitGroupSeparator : ",", ot = ""; t = String(t); var a = 1, u = "", y = "", h = -1, k = [], d = [], p = 0, st = 0, g = 0, ht = !1, c = 0; for (y = t.match(/"[^"]*"|'[^']*'|[eE][+-]*[0]+|[,]+[.]|‰|./g), r = null, e = 0; y && e < y.length; e++) { if (r = y[e], r === "." && h < 0) { h = e; continue } else if (r === "%") a *= 100; else if (r === "‰") { a *= 1e3; continue } else if (r[0] === "," && r[r.length - 1] === ".") { a /= Math.pow(1e3, r.length - 1); h = e + r.length - 1; continue } else(r[0] === "E" || r[0] === "e") && r[r.length - 1] === "0" && (ht = !0); h < 0 ? (k.push(r), r === "#" || r === "0" ? p++ : r === "," && g++) : (d.push(r), (r === "#" || r === "0") && st++) } ht && (nt = Math.floor(n), c = (nt === 0 ? "" : String(nt)).length - p, a /= Math.pow(10, c)); n *= a; h < 0 && (h = e); ot = n.toFixed(st); var ct = ot.split("."), f = (ct[0] + "").split(""), tt = (ct[1] + "").split(""); f && f[0] === "0" && f.shift(); for (var lt = 0, it = 0, rt = 0, ut = 0, o = 0; k.length > 0;) if (r = k.pop(), r === "#" || r === "0") if (lt++, lt === p) { if (s = f, f = [], r === "0") for (ft = p - it - (s ? s.length : 0); ft > 0;) s.unshift("0"), ft--; while (s.length > 0) u = s.pop() + u, o++, o % ut == 0 && rt === g && s.length > 0 && (u = b + u); w && (u = "-" + u) } else f.length > 0 ? (u = f.pop() + u, it++, o++) : r === "0" && (u = "0" + u, it++, o++), o % ut == 0 && rt === g && f.length > 0 && (u = b + u); else(r[0] === "E" || r[0] === "e") && r[r.length - 1] === "0" && /[eE][+-]*[0]+/.test(r) ? (r = c < 0 ? r.replace("+", "").replace("-", "") : r.replace("-", ""), u += r.replace(/[0]+/, function(n) { return v(c, n.length) })) : r === "," ? (rt++, ut = o, o = 0, f.length > 0 && (u = b + u)) : u = r.length > 1 && (r[0] === '"' && r[r.length - 1] === '"' || r[0] === "'" && r[r.length - 1] === "'") ? r.slice(1, r.length - 1) + u : r + u; for (var l = "", et = !1; d.length > 0;) r = d.shift(), r === "#" || r === "0" ? tt.length > 0 && Number(tt.join("")) !== 0 ? (l += tt.shift(), et = !0) : r === "0" && (l += "0", et = !0) : r.length > 1 && (r[0] === '"' && r[r.length - 1] === '"' || r[0] === "'" && r[r.length - 1] === "'") ? l += r.slice(1, r.length - 1) : (r[0] === "E" || r[0] === "e") && r[r.length - 1] === "0" && /[eE][+-]*[0]+/.test(r) ? (r = c < 0 ? r.replace("+", "").replace("-", "") : r.replace("-", ""), l += r.replace(/[0]+/, function(n) { return v(c, n.length) })) : l += r; return u + ((et ? at : "") + l) }, wt = function(n) { var t = 0, i = 0; return n = n || window.event, n.offsetX || n.offsetX === 0 ? (t = n.offsetX, i = n.offsetY) : n.layerX || n.layerX == 0 ? (t = n.layerX, i = n.layerY) : (t = n.pageX - n.target.offsetLeft, i = n.pageY - n.target.offsetTop), { x: t, y: i } }, li = !0, ri = window.devicePixelRatio || 1, bt = 1, l = li ? ri / bt : 1, nr = { reset: { image: "" }, pan: { image: "" }, zoom: { image: "" }, menu: { image: "" } }, o, dt; h.prototype.setOptions = function(n, t) { var r, i; if (et[this._defaultsKey]) { r = et[this._defaultsKey]; for (i in r) this[i] = n && i in n ? n[i] : t && i in t ? t[i] : r[i] } else yt && window.console && console.log("defaults not set") }; h.prototype.updateOption = function(n) { !et[this._defaultsKey] && yt && window.console && console.log("defaults not set"); var u = et[this._defaultsKey], t = this._options.theme ? this._options.theme : this.chart && this.chart._options.theme ? this.chart._options.theme : "theme1", i = {}, r = this[n]; return (t && ut[t] && ut[t][this._defaultsKey] && (i = ut[t][this._defaultsKey]), n in u && (r = n in this._options ? this._options[n] : i && n in i ? i[n] : u[n]), r === this[n]) ? !1 : (this[n] = r, !0) }; h.prototype.trackChanges = function(n) { this._options._oldOptions || (this._options._oldOptions = {}); this._options._oldOptions[n] = this._options[n] }; h.prototype.isBeingTracked = function(n) { return this._options._oldOptions || (this._options._oldOptions = {}), this._options._oldOptions[n] ? !0 : !1 }; h.prototype.hasOptionChanged = function(n) { this._options._oldOptions || (this._options._oldOptions = {}); return !(this._options._oldOptions[n] === this._options[n]) }; h.prototype.addEventListener = function(n, t, i) { n && t && (i = i || this, this._eventListeners[n] = this._eventListeners[n] || [], this._eventListeners[n].push({ context: i, eventHandler: t })) }; h.prototype.removeEventListener = function(n, t) { var r, i; if (n && t && this._eventListeners[n]) for (r = this._eventListeners[n], i = 0; i < r.length; i++) if (r[i].eventHandler === t) { r[i].splice(i, 1); break } }; h.prototype.removeAllEventListeners = function() { this._eventListeners = [] }; h.prototype.dispatchEvent = function(n, t) { var r, i; if (n && this._eventListeners[n]) for (t = t || {}, r = this._eventListeners[n], i = 0; i < r.length; i++) r[i].eventHandler.call(r[i].context, t) }; w(t, h); t.prototype._updateOptions = function() { var t = this, i, u, f, r; this.updateOption("width"); this.updateOption("height"); this.updateOption("theme"); this.updateOption("colorSet") && (this._selectedColorSet = typeof tt[this.colorSet] != "undefined" ? tt[this.colorSet] : tt.colorSet1); this.updateOption("backgroundColor"); this.backgroundColor || (this.backgroundColor = "rgba(0,0,0,0)"); this.updateOption("culture"); this._cultureInfo = new vt(this._options.culture); this.updateOption("animationEnabled"); this.animationEnabled = this.animationEnabled && n; this._options.zoomEnabled ? (this._zoomButton || (nt(this._zoomButton = document.createElement("button")), b(this, this._zoomButton, "pan"), this._toolBar.appendChild(this._zoomButton), s(this._zoomButton, "click", function() { t.zoomEnabled ? (t.zoomEnabled = !1, t.panEnabled = !0, b(t, t._zoomButton, "zoom")) : (t.zoomEnabled = !0, t.panEnabled = !1, b(t, t._zoomButton, "pan")); t.render() })), this._resetButton || (nt(this._resetButton = document.createElement("button")), b(this, this._resetButton, "reset"), this._toolBar.appendChild(this._resetButton), s(this._resetButton, "click", function() { t._toolTip.hide(); t.zoomEnabled || t.panEnabled ? (t.zoomEnabled = !0, t.panEnabled = !1, b(t, t._zoomButton, "pan"), t._defaultCursor = "default", t.overlaidCanvas.style.cursor = t._defaultCursor) : (t.zoomEnabled = !1, t.panEnabled = !1); t.sessionVariables.axisX.internalMinimum = t._options.axisX && t._options.axisX.minimum ? t._options.axisX.minimum : null; t.sessionVariables.axisX.internalMaximum = t._options.axisX && t._options.axisX.maximum ? t._options.axisX.maximum : null; t.resetOverlayedCanvas(); nt(t._zoomButton, t._resetButton); t.render() }), this.overlaidCanvas.style.cursor = t._defaultCursor), this.zoomEnabled || this.panEnabled || (this._zoomButton ? (t._zoomButton.getAttribute("state") === t._cultureInfo.zoomText ? (this.panEnabled = !0, this.zoomEnabled = !1) : (this.zoomEnabled = !0, this.panEnabled = !1), ui(t._zoomButton, t._resetButton)) : (this.zoomEnabled = !0, this.panEnabled = !1))) : (this.zoomEnabled = !1, this.panEnabled = !1); typeof this._options.exportFileName != "undefined" && (this.exportFileName = this._options.exportFileName); typeof this._options.exportEnabled != "undefined" && (this.exportEnabled = this._options.exportEnabled); this._menuButton ? this.exportEnabled ? ui(this._menuButton) : nt(this._menuButton) : this.exportEnabled && n && (this._menuButton = document.createElement("button"), b(this, this._menuButton, "menu"), this._toolBar.appendChild(this._menuButton), s(this._menuButton, "click", function() { if (t._dropdownMenu.style.display === "none") { if (t._dropDownCloseTime && (new Date).getTime() - t._dropDownCloseTime.getTime() <= 500) return; t._dropdownMenu.style.display = "block"; t._menuButton.blur(); t._dropdownMenu.focus() } }, !0)); !this._dropdownMenu && this.exportEnabled && n && (this._dropdownMenu = document.createElement("div"), this._dropdownMenu.setAttribute("tabindex", -1), this._dropdownMenu.style.cssText = "position: absolute; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; cursor: pointer;right: 1px;top: 25px;min-width: 120px;outline: 0;border: 1px solid silver;font-size: 14px;font-family: Calibri, Verdana, sans-serif;padding: 5px 0px 5px 0px;text-align: left;background-color: #fff;line-height: 20px;box-shadow: 2px 2px 10px #888888;", t._dropdownMenu.style.display = "none", this._toolBar.appendChild(this._dropdownMenu), s(this._dropdownMenu, "blur", function() { nt(t._dropdownMenu); t._dropDownCloseTime = new Date }, !0), i = document.createElement("div"), i.style.cssText = "padding: 2px 15px 2px 10px", i.innerHTML = this._cultureInfo.saveJPGText, this._dropdownMenu.appendChild(i), s(i, "mouseover", function() { this.style.backgroundColor = "#EEEEEE" }, !0), s(i, "mouseout", function() { this.style.backgroundColor = "transparent" }, !0), s(i, "click", function() { ai(t.canvas, "jpg", t.exportFileName); nt(t._dropdownMenu) }, !0), i = document.createElement("div"), i.style.cssText = "padding: 2px 15px 2px 10px", i.innerHTML = this._cultureInfo.savePNGText, this._dropdownMenu.appendChild(i), s(i, "mouseover", function() { this.style.backgroundColor = "#EEEEEE" }, !0), s(i, "mouseout", function() { this.style.backgroundColor = "transparent" }, !0), s(i, "click", function() { ai(t.canvas, "png", t.exportFileName); nt(t._dropdownMenu) }, !0)); this._toolBar.style.display !== "none" && this._zoomButton && (this.panEnabled ? b(t, t._zoomButton, "zoom") : b(t, t._zoomButton, "pan"), t._resetButton.getAttribute("state") !== t._cultureInfo.resetText && b(t, t._resetButton, "reset")); typeof et.Chart.creditHref == "undefined" ? (this.creditHref = "http://canvasjs.com/", this.creditText = "CanvasJS.com") : (u = this.updateOption("creditText"), f = this.updateOption("creditHref")); (this.renderCount === 0 || u || f) && (this._creditLink.setAttribute("href", this.creditHref), this._creditLink.innerHTML = this.creditText); this.creditHref && this.creditText ? this._creditLink.parentElement || this._canvasJSContainer.appendChild(this._creditLink) : this._creditLink.parentElement && this._canvasJSContainer.removeChild(this._creditLink); this._options.toolTip && this._toolTip._options !== this._options.toolTip && (this._toolTip._options = this._options.toolTip); for (r in this._toolTip._options) this._toolTip._options.hasOwnProperty(r) && this._toolTip.updateOption(r) }; t.prototype._updateSize = function() { var n = 0, t = 0; return (this._options.width ? n = this.width : this.width = n = this._container.clientWidth > 0 ? this._container.clientWidth : this.width, this._options.height ? t = this.height : this.height = t = this._container.clientHeight > 0 ? this._container.clientHeight : this.height, this.canvas.width !== n * l || this.canvas.height !== t * l) ? (ct(this.canvas, n, t), ct(this.overlaidCanvas, n, t), ct(this._eventManager.ghostCanvas, n, t), !0) : !1 }; t.prototype._initialize = function() { var f, u, i, e, r; for (this._animator ? this._animator.cancelAllAnimations() : this._animator = new ei(this), this.removeAllEventListeners(), this.disableToolTip = !1, this.pieDoughnutClickHandler = null, this.animationRequestId && this.cancelRequestAnimFrame.call(window, this.animationRequestId), this._updateOptions(), this.animatedRender = n && this.animationEnabled && this.renderCount === 0, this._updateSize(), this.clearCanvas(), this.ctx.beginPath(), this.axisX = null, this.axisY = null, this.axisY2 = null, this._indexLabels = [], this._dataInRenderedOrder = [], this._events = [], this._eventManager && this._eventManager.reset(), this.plotInfo = { axisPlacement: null, axisXValueType: null, plotTypes: [] }, this.layoutManager = new ft(0, 0, this.width, this.height, 2), this.plotArea.layoutManager && this.plotArea.layoutManager.reset(), this.data = [], f = 0, u = 0; u < this._options.data.length; u++) if ((f++, !this._options.data[u].type || t._supportedChartTypes.indexOf(this._options.data[u].type) >= 0) && (i = new d(this, this._options.data[u], this.theme, f - 1, ++this._eventManager.lastObjectId), i.name === null && (i.name = "DataSeries " + f), i.color === null ? this._options.data.length > 1 ? (i._colorSet = [this._selectedColorSet[i.index % this._selectedColorSet.length]], i.color = this._selectedColorSet[i.index % this._selectedColorSet.length]) : i._colorSet = i.type === "line" || i.type === "stepLine" || i.type === "spline" || i.type === "area" || i.type === "stepArea" || i.type === "splineArea" || i.type === "stackedArea" || i.type === "stackedArea100" || i.type === "rangeArea" || i.type === "rangeSplineArea" || i.type === "candlestick" || i.type === "ohlc" ? [this._selectedColorSet[0]] : this._selectedColorSet : i._colorSet = [i.color], i.markerSize === null && ((i.type === "line" || i.type === "stepLine" || i.type === "spline") && i.dataPoints && i.dataPoints.length < this.width / 16 || i.type === "scatter") && (i.markerSize = 8), (i.type === "bubble" || i.type === "scatter") && i.dataPoints && i.dataPoints.sort(wi), this.data.push(i), e = i.axisPlacement, e === "normal" ? this.plotInfo.axisPlacement === "xySwapped" ? r = 'You cannot combine "' + i.type + '" with bar chart' : this.plotInfo.axisPlacement === "none" ? r = 'You cannot combine "' + i.type + '" with pie chart' : this.plotInfo.axisPlacement === null && (this.plotInfo.axisPlacement = "normal") : e === "xySwapped" ? this.plotInfo.axisPlacement === "normal" ? r = 'You cannot combine "' + i.type + '" with line, area, column or pie chart' : this.plotInfo.axisPlacement === "none" ? r = 'You cannot combine "' + i.type + '" with pie chart' : this.plotInfo.axisPlacement === null && (this.plotInfo.axisPlacement = "xySwapped") : e == "none" && (this.plotInfo.axisPlacement === "normal" ? r = 'You cannot combine "' + i.type + '" with line, area, column or bar chart' : this.plotInfo.axisPlacement === "xySwapped" ? r = 'You cannot combine "' + i.type + '" with bar chart' : this.plotInfo.axisPlacement === null && (this.plotInfo.axisPlacement = "none")), r && window.console)) { window.console.log(r); return } this._objectsInitialized = !0 }; t._supportedChartTypes = di(["line", "stepLine", "spline", "column", "area", "stepArea", "splineArea", "bar", "bubble", "scatter", "stackedColumn", "stackedColumn100", "stackedBar", "stackedBar100", "stackedArea", "stackedArea100", "candlestick", "ohlc", "rangeColumn", "rangeBar", "rangeArea", "rangeSplineArea", "pie", "doughnut", "funnel"]); t.prototype.render = function(n) { var o, s, v, f, h, p, u, y, c, t, i, a, w, b, r; for (n && (this._options = n), this._initialize(), o = [], u = 0; u < this.data.length; u++)(this.plotInfo.axisPlacement === "normal" || this.plotInfo.axisPlacement === "xySwapped") && (this.data[u].axisYType && this.data[u].axisYType !== "primary" ? this.data[u].axisYType === "secondary" && (this.axisY2 || (this.plotInfo.axisPlacement === "normal" ? this.axisY2 = new e(this, this._options.axisY2, "axisY", "right") : this.plotInfo.axisPlacement === "xySwapped" && (this.axisY2 = new e(this, this._options.axisY2, "axisY", "top"))), this.data[u].axisY = this.axisY2) : (this.axisY || (this.plotInfo.axisPlacement === "normal" ? this.axisY = new e(this, this._options.axisY, "axisY", "left") : this.plotInfo.axisPlacement === "xySwapped" && (this.axisY = new e(this, this._options.axisY, "axisY", "bottom"))), this.data[u].axisY = this.axisY), this.axisX || (this.plotInfo.axisPlacement === "normal" ? this.axisX = new e(this, this._options.axisX, "axisX", "bottom") : this.plotInfo.axisPlacement === "xySwapped" && (this.axisX = new e(this, this._options.axisX, "axisX", "left"))), this.data[u].axisX = this.axisX); if (this._processData(), this._options.title && (this._title = new lt(this, this._options.title), this._title.dockInsidePlotArea ? o.push(this._title) : this._title.render()), this._options.subtitles) for (u = 0; u < this._options.subtitles.length; u++) this.subtitles = [], s = new gt(this, this._options.subtitles[u]), this.subtitles.push(s), s.dockInsidePlotArea ? o.push(s) : s.render(); for (this.legend = new ni(this, this._options.legend, this.theme), u = 0; u < this.data.length; u++)(this.data[u].showInLegend || this.data[u].type === "pie" || this.data[u].type === "doughnut") && this.legend.dataSeries.push(this.data[u]); if (this.legend.dockInsidePlotArea ? o.push(this.legend) : this.legend.render(), this.plotInfo.axisPlacement === "normal" || this.plotInfo.axisPlacement === "xySwapped") e.setLayoutAndRender(this.axisX, this.axisY, this.axisY2, this.plotInfo.axisPlacement, this.layoutManager.getFreeSpace()); else if (this.plotInfo.axisPlacement === "none") this.preparePlotArea(); else return; v = 0; for (v in o) o[v].render(); for (f = [], this.animatedRender && (h = rt(this.width, this.height), p = h.getContext("2d"), p.drawImage(this.canvas, 0, 0, this.width, this.height)), u = 0; u < this.plotInfo.plotTypes.length; u++) for (y = this.plotInfo.plotTypes[u], c = 0; c < y.plotUnits.length; c++) { for (t = y.plotUnits[c], i = null, t.targetCanvas = null, this.animatedRender && (t.targetCanvas = rt(this.width, this.height), t.targetCanvasCtx = t.targetCanvas.getContext("2d")), t.type === "line" ? i = this.renderLine(t) : t.type === "stepLine" ? i = this.renderStepLine(t) : t.type === "spline" ? i = this.renderSpline(t) : t.type === "column" ? i = this.renderColumn(t) : t.type === "bar" ? i = this.renderBar(t) : t.type === "area" ? i = this.renderArea(t) : t.type === "stepArea" ? i = this.renderStepArea(t) : t.type === "splineArea" ? i = this.renderSplineArea(t) : t.type === "stackedColumn" ? i = this.renderStackedColumn(t) : t.type === "stackedColumn100" ? i = this.renderStackedColumn100(t) : t.type === "stackedBar" ? i = this.renderStackedBar(t) : t.type === "stackedBar100" ? i = this.renderStackedBar100(t) : t.type === "stackedArea" ? i = this.renderStackedArea(t) : t.type === "stackedArea100" ? i = this.renderStackedArea100(t) : t.type === "bubble" ? i = i = this.renderBubble(t) : t.type === "scatter" ? i = this.renderScatter(t) : t.type === "pie" ? this.renderPie(t) : t.type === "doughnut" ? this.renderPie(t) : t.type === "candlestick" ? i = this.renderCandlestick(t) : t.type === "ohlc" ? i = this.renderCandlestick(t) : t.type === "rangeColumn" ? i = this.renderRangeColumn(t) : t.type === "rangeBar" ? i = this.renderRangeBar(t) : t.type === "rangeArea" ? i = this.renderRangeArea(t) : t.type === "rangeSplineArea" && (i = this.renderRangeSplineArea(t)), a = 0; a < t.dataSeriesIndexes.length; a++) this._dataInRenderedOrder.push(this.data[t.dataSeriesIndexes[a]]); this.animatedRender && i && f.push(i) } this.animatedRender && this._indexLabels.length > 0 && (w = rt(this.width, this.height), b = w.getContext("2d"), f.push(this.renderIndexLabels(b))); r = this; f.length > 0 ? (r.disableToolTip = !0, r._animator.animate(200, r.animationDuration, function(n) { r.ctx.clearRect(0, 0, r.width, r.height); r.ctx.drawImage(h, 0, 0, Math.floor(r.width * l), Math.floor(r.height * l), 0, 0, r.width, r.height); for (var t = 0; t < f.length; t++) i = f[t], n < 1 && typeof i.startTimePercent != "undefined" ? n >= i.startTimePercent && i.animationCallback(i.easingFunction(n - i.startTimePercent, 0, 1, 1 - i.startTimePercent), i) : i.animationCallback(i.easingFunction(n, 0, 1, 1), i); r.dispatchEvent("dataAnimationIterationEnd", { chart: r }) }, function() { var e, n, i, t, u; for (f = [], e = 0, n = 0; n < r.plotInfo.plotTypes.length; n++) for (i = r.plotInfo.plotTypes[n], t = 0; t < i.plotUnits.length; t++) u = i.plotUnits[t], u.targetCanvas = null; h = null; r.disableToolTip = !1 })) : (r._indexLabels.length > 0 && r.renderIndexLabels(), r.dispatchEvent("dataAnimationIterationEnd", { chart: r })); this.attachPlotAreaEventHandlers(); this.zoomEnabled || this.panEnabled || !this._zoomButton || this._zoomButton.style.display === "none" || nt(this._zoomButton, this._resetButton); this._toolTip._updateToolTip(); this.renderCount++; yt && (r = this, setTimeout(function() { var n = document.getElementById("ghostCanvasCopy"), t; n && (ct(n, r.width, r.height), t = n.getContext("2d"), t.drawImage(r._eventManager.ghostCanvas, 0, 0)) }, 2e3)) }; t.prototype.attachPlotAreaEventHandlers = function() { this.attachEvent({ context: this, chart: this, mousedown: this._plotAreaMouseDown, mouseup: this._plotAreaMouseUp, mousemove: this._plotAreaMouseMove, cursor: this.zoomEnabled ? "col-resize" : "move", cursor: this.panEnabled ? "move" : "default", capture: !0, bounds: this.plotArea }) }; t.prototype.categoriseDataSeries = function() { for (var f, i, e, n, r = "", u = 0; u < this.data.length; u++) if ((r = this.data[u], r.dataPoints && r.dataPoints.length !== 0 && r.visible) && t._supportedChartTypes.indexOf(r.type) >= 0) { var i = null, o = !1, f = null, s = !1; for (n = 0; n < this.plotInfo.plotTypes.length; n++) if (this.plotInfo.plotTypes[n].type === r.type) { o = !0; i = this.plotInfo.plotTypes[n]; break } for (o || (i = { type: r.type, totalDataSeries: 0, plotUnits: [] }, this.plotInfo.plotTypes.push(i)), n = 0; n < i.plotUnits.length; n++) if (i.plotUnits[n].axisYType === r.axisYType) { s = !0; f = i.plotUnits[n]; break } s || (f = { type: r.type, previousDataSeriesCount: 0, index: i.plotUnits.length, plotType: i, axisYType: r.axisYType, axisY: r.axisYType === "primary" ? this.axisY : this.axisY2, axisX: this.axisX, dataSeriesIndexes: [], yTotals: [] }, i.plotUnits.push(f)); i.totalDataSeries++; f.dataSeriesIndexes.push(u); r.plotUnit = f } for (u = 0; u < this.plotInfo.plotTypes.length; u++) for (i = this.plotInfo.plotTypes[u], e = 0, n = 0; n < i.plotUnits.length; n++) i.plotUnits[n].previousDataSeriesCount = e, e += i.plotUnits[n].dataSeriesIndexes.length }; t.prototype.assignIdToDataPoints = function() { for (var t, r, i, n = 0; n < this.data.length; n++) if (t = this.data[n], t.dataPoints) for (r = t.dataPoints.length, i = 0; i < r; i++) t.dataPointIds[i] = ++this._eventManager.lastObjectId }; t.prototype._processData = function() { var t, r, i, n; for (this.assignIdToDataPoints(), this.categoriseDataSeries(), t = 0; t < this.plotInfo.plotTypes.length; t++) for (r = this.plotInfo.plotTypes[t], i = 0; i < r.plotUnits.length; i++) n = r.plotUnits[i], n.type === "line" || n.type === "stepLine" || n.type === "spline" || n.type === "column" || n.type === "area" || n.type === "stepArea" || n.type === "splineArea" || n.type === "bar" || n.type === "bubble" || n.type === "scatter" ? this._processMultiseriesPlotUnit(n) : n.type === "stackedColumn" || n.type === "stackedBar" || n.type === "stackedArea" ? this._processStackedPlotUnit(n) : n.type === "stackedColumn100" || n.type === "stackedBar100" || n.type === "stackedArea100" ? this._processStacked100PlotUnit(n) : (n.type === "candlestick" || n.type === "ohlc" || n.type === "rangeColumn" || n.type === "rangeBar" || n.type === "rangeArea" || n.type === "rangeSplineArea") && this._processMultiYPlotUnit(n) }; t.prototype._processMultiseriesPlotUnit = function(n) { var s, v, a, o; if (n.dataSeriesIndexes && !(n.dataSeriesIndexes.length < 1)) { var e = n.axisY.dataInfo, u = n.axisX.dataInfo, r, f, h = !1; for (s = 0; s < n.dataSeriesIndexes.length; s++) { var i = this.data[n.dataSeriesIndexes[s]], t = 0, c = !1, l = !1; for ((i.axisPlacement === "normal" || i.axisPlacement === "xySwapped") && (v = this.sessionVariables.axisX.internalMinimum ? this.sessionVariables.axisX.internalMinimum : this._options.axisX && this._options.axisX.minimum ? this._options.axisX.minimum : -Infinity, a = this.sessionVariables.axisX.internalMaximum ? this.sessionVariables.axisX.internalMaximum : this._options.axisX && this._options.axisX.maximum ? this._options.axisX.maximum : Infinity), (i.dataPoints[t].x && i.dataPoints[t].x.getTime || i.xValueType === "dateTime") && (h = !0), t = 0; t < i.dataPoints.length; t++) { if (typeof i.dataPoints[t].x == "undefined" && (i.dataPoints[t].x = t), i.dataPoints[t].x.getTime ? (h = !0, r = i.dataPoints[t].x.getTime()) : r = i.dataPoints[t].x, f = i.dataPoints[t].y, r < u.min && (u.min = r), r > u.max && (u.max = r), f < e.min && (e.min = f), f > e.max && (e.max = f), t > 0 && (o = r - i.dataPoints[t - 1].x, o < 0 && (o = o * -1), u.minDiff > o && o !== 0 && (u.minDiff = o)), r < v && !c) continue; else if (!c && (c = !0, t > 0)) { t -= 2; continue } if (r > a && !l) l = !0; else if (r > a && l) continue; (i.dataPoints[t].label && (n.axisX.labels[r] = i.dataPoints[t].label), r < u.viewPortMin && (u.viewPortMin = r), r > u.viewPortMax && (u.viewPortMax = r), f !== null) && (f < e.viewPortMin && (e.viewPortMin = f), f > e.viewPortMax && (e.viewPortMax = f)) } this.plotInfo.axisXValueType = i.xValueType = h ? "dateTime" : "number" } } }; t.prototype._processStackedPlotUnit = function(n) { var l, w, p, s, r; if (n.dataSeriesIndexes && !(n.dataSeriesIndexes.length < 1)) { var u = n.axisY.dataInfo, e = n.axisX.dataInfo, i, o, a = !1, h = [], c = []; for (l = 0; l < n.dataSeriesIndexes.length; l++) { var f = this.data[n.dataSeriesIndexes[l]], t = 0, v = !1, y = !1; for ((f.axisPlacement === "normal" || f.axisPlacement === "xySwapped") && (w = this.sessionVariables.axisX.internalMinimum ? this.sessionVariables.axisX.internalMinimum : this._options.axisX && this._options.axisX.minimum ? this._options.axisX.minimum : -Infinity, p = this.sessionVariables.axisX.internalMaximum ? this.sessionVariables.axisX.internalMaximum : this._options.axisX && this._options.axisX.maximum ? this._options.axisX.maximum : Infinity), (f.dataPoints[t].x && f.dataPoints[t].x.getTime || f.xValueType === "dateTime") && (a = !0), t = 0; t < f.dataPoints.length; t++) { if (typeof f.dataPoints[t].x == "undefined" && (f.dataPoints[t].x = t), f.dataPoints[t].x.getTime ? (a = !0, i = f.dataPoints[t].x.getTime()) : i = f.dataPoints[t].x, o = f.dataPoints[t].y, i < e.min && (e.min = i), i > e.max && (e.max = i), t > 0 && (s = i - f.dataPoints[t - 1].x, s < 0 && (s = s * -1), e.minDiff > s && s !== 0 && (e.minDiff = s)), i < w && !v) continue; else if (!v && (v = !0, t > 0)) { t -= 2; continue } if (i > p && !y) y = !0; else if (i > p && y) continue; (f.dataPoints[t].label && (n.axisX.labels[i] = f.dataPoints[t].label), i < e.viewPortMin && (e.viewPortMin = i), i > e.viewPortMax && (e.viewPortMax = i), o !== null) && (n.yTotals[i] = (n.yTotals[i] ? n.yTotals[i] : 0) + Math.abs(o), o >= 0 ? h[i] ? h[i] += o : h[i] = o : c[i] ? c[i] += o : c[i] = o) } this.plotInfo.axisXValueType = f.xValueType = a ? "dateTime" : "number" } for (t in h) isNaN(t) || (r = h[t], r < u.min && (u.min = r), r > u.max && (u.max = r), t < e.viewPortMin || t > e.viewPortMax) || (r < u.viewPortMin && (u.viewPortMin = r), r > u.viewPortMax && (u.viewPortMax = r)); for (t in c) isNaN(t) || (r = c[t], r < u.min && (u.min = r), r > u.max && (u.max = r), t < e.viewPortMin || t > e.viewPortMax) || (r < u.viewPortMin && (u.viewPortMin = r), r > u.viewPortMax && (u.viewPortMax = r)) } }; t.prototype._processStacked100PlotUnit = function(n) { var l, w, p, e; if (n.dataSeriesIndexes && !(n.dataSeriesIndexes.length < 1)) { var u = n.axisY.dataInfo, f = n.axisX.dataInfo, t, o, a = !1, s = !1, h = !1, c = []; for (l = 0; l < n.dataSeriesIndexes.length; l++) { var r = this.data[n.dataSeriesIndexes[l]], i = 0, v = !1, y = !1; for ((r.axisPlacement === "normal" || r.axisPlacement === "xySwapped") && (w = this.sessionVariables.axisX.internalMinimum ? this.sessionVariables.axisX.internalMinimum : this._options.axisX && this._options.axisX.minimum ? this._options.axisX.minimum : -Infinity, p = this.sessionVariables.axisX.internalMaximum ? this.sessionVariables.axisX.internalMaximum : this._options.axisX && this._options.axisX.maximum ? this._options.axisX.maximum : Infinity), (r.dataPoints[i].x && r.dataPoints[i].x.getTime || r.xValueType === "dateTime") && (a = !0), i = 0; i < r.dataPoints.length; i++) { if (typeof r.dataPoints[i].x == "undefined" && (r.dataPoints[i].x = i), r.dataPoints[i].x.getTime ? (a = !0, t = r.dataPoints[i].x.getTime()) : t = r.dataPoints[i].x, o = r.dataPoints[i].y, t < f.min && (f.min = t), t > f.max && (f.max = t), i > 0 && (e = t - r.dataPoints[i - 1].x, e < 0 && (e = e * -1), f.minDiff > e && e !== 0 && (f.minDiff = e)), t < w && !v) continue; else if (!v && (v = !0, i > 0)) { i -= 2; continue } if (t > p && !y) y = !0; else if (t > p && y) continue; (r.dataPoints[i].label && (n.axisX.labels[t] = r.dataPoints[i].label), t < f.viewPortMin && (f.viewPortMin = t), t > f.viewPortMax && (f.viewPortMax = t), o !== null) && (n.yTotals[t] = (n.yTotals[t] ? n.yTotals[t] : 0) + Math.abs(o), o >= 0 ? s = !0 : h = !0, c[t] ? c[t] += Math.abs(o) : c[t] = Math.abs(o)) } this.plotInfo.axisXValueType = r.xValueType = a ? "dateTime" : "number" } s && !h ? (u.max = 99, u.min = 1) : s && h ? (u.max = 99, u.min = -99) : !s && h && (u.max = -1, u.min = -99); u.viewPortMin = u.min; u.viewPortMax = u.max; n.dataPointYSums = c } }; t.prototype._processMultiYPlotUnit = function(n) { var c, p, y, e; if (n.dataSeriesIndexes && !(n.dataSeriesIndexes.length < 1)) { var f = n.axisY.dataInfo, u = n.axisX.dataInfo, r, o, s, h, l = !1; for (c = 0; c < n.dataSeriesIndexes.length; c++) { var i = this.data[n.dataSeriesIndexes[c]], t = 0, a = !1, v = !1; for ((i.axisPlacement === "normal" || i.axisPlacement === "xySwapped") && (p = this.sessionVariables.axisX.internalMinimum ? this.sessionVariables.axisX.internalMinimum : this._options.axisX && this._options.axisX.minimum ? this._options.axisX.minimum : -Infinity, y = this.sessionVariables.axisX.internalMaximum ? this.sessionVariables.axisX.internalMaximum : this._options.axisX && this._options.axisX.maximum ? this._options.axisX.maximum : Infinity), (i.dataPoints[t].x && i.dataPoints[t].x.getTime || i.xValueType === "dateTime") && (l = !0), t = 0; t < i.dataPoints.length; t++) { if (typeof i.dataPoints[t].x == "undefined" && (i.dataPoints[t].x = t), i.dataPoints[t].x.getTime ? (l = !0, r = i.dataPoints[t].x.getTime()) : r = i.dataPoints[t].x, o = i.dataPoints[t].y, o && o.length && (s = Math.min.apply(null, o), h = Math.max.apply(null, o)), r < u.min && (u.min = r), r > u.max && (u.max = r), s < f.min && (f.min = s), h > f.max && (f.max = h), t > 0 && (e = r - i.dataPoints[t - 1].x, e < 0 && (e = e * -1), u.minDiff > e && e !== 0 && (u.minDiff = e)), r < p && !a) continue; else if (!a && (a = !0, t > 0)) { t -= 2; continue } if (r > y && !v) v = !0; else if (r > y && v) continue; (i.dataPoints[t].label && (n.axisX.labels[r] = i.dataPoints[t].label), r < u.viewPortMin && (u.viewPortMin = r), r > u.viewPortMax && (u.viewPortMax = r), o !== null) && (s < f.viewPortMin && (f.viewPortMin = s), h > f.viewPortMax && (f.viewPortMax = h)) } this.plotInfo.axisXValueType = i.xValueType = l ? "dateTime" : "number" } } }; t.prototype.getDataPointAtXY = function(n, t, i) { var u, e, h, o, f, s, r, c; for (i = i || !1, u = [], e = this._dataInRenderedOrder.length - 1; e >= 0; e--) h = this._dataInRenderedOrder[e], o = null, o = h.getDataPointAtXY(n, t, i), o && u.push(o); for (f = null, s = !1, r = 0; r < u.length; r++) if ((u[r].dataSeries.type === "line" || u[r].dataSeries.type === "stepLine" || u[r].dataSeries.type === "area" || u[r].dataSeries.type === "stepArea") && (c = p("markerSize", u[r].dataPoint, u[r].dataSeries) || 8, u[r].distance <= c / 2)) { s = !0; break } for (r = 0; r < u.length; r++) s && u[r].dataSeries.type !== "line" && u[r].dataSeries.type !== "stepLine" && u[r].dataSeries.type !== "area" && u[r].dataSeries.type !== "stepArea" || (f ? u[r].distance <= f.distance && (f = u[r]) : f = u[r]); return f }; t.prototype.getObjectAtXY = function(t, i, r) { var f, e, o, u; if (r = r || !1, f = null, e = this.getDataPointAtXY(t, i, r), e) f = e.dataSeries.dataPointIds[e.dataPointIndex]; else if (n) f = ci(t, i, this._eventManager.ghostCtx); else for (o = 0; o < this.legend.items.length; o++) u = this.legend.items[o], t >= u.x1 && t <= u.x2 && i >= u.y1 && i <= u.y2 && (f = u.id); return f }; t.prototype.getAutoFontSize = function(n, t, i) { t = t || this.width; i = i || this.height; var r = n / 400; return Math.round(Math.min(this.width, this.height) * r) }; t.prototype.resetOverlayedCanvas = function() { this.overlaidCanvasCtx.clearRect(0, 0, this.width, this.height) }; t.prototype.clearCanvas = function() { this.ctx.clearRect(0, 0, this.width, this.height); this.backgroundColor && (this.ctx.fillStyle = this.backgroundColor, this.ctx.fillRect(0, 0, this.width, this.height)) }; t.prototype.attachEvent = function(n) { this._events.push(n) }; t.prototype._touchEventHandler = function(n) { var f, e, h, o; if (n.changedTouches && this.interactivityEnabled) { var i = [], u = n.changedTouches, t = u ? u[0] : n, r = null; switch (n.type) { case "touchstart": case "MSPointerDown": i = ["mousemove", "mousedown"]; this._lastTouchData = wt(t); this._lastTouchData.time = new Date; break; case "touchmove": case "MSPointerMove": i = ["mousemove"]; break; case "touchend": case "MSPointerUp": i = this._lastTouchEventType === "touchstart" || this._lastTouchEventType === "MSPointerDown" ? ["mouseup", "click"] : ["mouseup"]; break; default: return } if (!u || !(u.length > 1)) { r = wt(t); r.time = new Date; try { var s = r.y - this._lastTouchData.y, l = r.x - this._lastTouchData.x, c = r.time - this._lastTouchData.time; Math.abs(s) > 15 && (!!this._lastTouchData.scroll || c < 200) && (this._lastTouchData.scroll = !0, f = window.parent || window, f && f.scrollBy && f.scrollBy(0, -s)) } catch (a) {} if (this._lastTouchEventType = n.type, !!this._lastTouchData.scroll && this.zoomEnabled) { this.isDrag && this.resetOverlayedCanvas(); this.isDrag = !1; return } for (e = 0; e < i.length; e++) h = i[e], o = document.createEvent("MouseEvent"), o.initMouseEvent(h, !0, !0, window, 1, t.screenX, t.screenY, t.clientX, t.clientY, !1, !1, !1, !1, 0, null), t.target.dispatchEvent(o), n.preventManipulation && n.preventManipulation(), n.preventDefault && n.preventDefault() } } }; t.prototype._mouseEventHandler = function(n) { var r, u, i, s, h, f, e, o; if (this.interactivityEnabled) { if (this._ignoreNextEvent) { this._ignoreNextEvent = !1; return } if (n.preventManipulation && n.preventManipulation(), n.preventDefault && n.preventDefault(), typeof n.target == "undefined" && n.srcElement && (n.target = n.srcElement), r = wt(n), u = n.type, n || (h = window.event), n.which ? s = n.which == 3 : n.button && (s = n.button == 2), yt && window.console && (window.console.log(u + " --> x: " + r.x + "; y:" + r.y), s && window.console.log(n.which), u === "mouseup" && window.console.log("mouseup")), !s) { if (t.capturedEventParam) i = t.capturedEventParam, u === "mouseup" && (t.capturedEventParam = null, i.chart.overlaidCanvas.releaseCapture ? i.chart.overlaidCanvas.releaseCapture() : document.body.removeEventListener("mouseup", i.chart._mouseEventHandler, !1)), i.hasOwnProperty(u) && i[u].call(i.context, r.x, r.y); else if (this._events) { for (f = 0; f < this._events.length; f++) if (this._events[f].hasOwnProperty(u)) if (i = this._events[f], e = i.bounds, r.x >= e.x1 && r.x <= e.x2 && r.y >= e.y1 && r.y <= e.y2) { i[u].call(i.context, r.x, r.y); u === "mousedown" && i.capture === !0 ? (t.capturedEventParam = i, this.overlaidCanvas.setCapture ? this.overlaidCanvas.setCapture() : document.body.addEventListener("mouseup", this._mouseEventHandler, !1)) : u === "mouseup" && (i.chart.overlaidCanvas.releaseCapture ? i.chart.overlaidCanvas.releaseCapture() : document.body.removeEventListener("mouseup", this._mouseEventHandler, !1)); break } else i = null; n.target.style.cursor = i && i.cursor ? i.cursor : this._defaultCursor } this._toolTip && this._toolTip.enabled && (o = this.plotArea, (r.x < o.x1 || r.x > o.x2 || r.y < o.y1 || r.y > o.y2) && this._toolTip.hide()); this.isDrag && this.zoomEnabled || !this._eventManager || this._eventManager.mouseEventHandler(n) } } }; t.prototype._plotAreaMouseDown = function(n, t) { this.isDrag = !0; this.dragStartPoint = this.plotInfo.axisPlacement !== "none" ? { x: n, y: t, xMinimum: this.axisX.minimum, xMaximum: this.axisX.maximum } : { x: n, y: t } }; t.prototype._plotAreaMouseUp = function(n, t) { var s, e, r; if ((this.plotInfo.axisPlacement === "normal" || this.plotInfo.axisPlacement === "xySwapped") && this.isDrag) { var o = 0, h = 0, i = this.axisX.lineCoordinates; if (this.plotInfo.axisPlacement === "xySwapped" ? (o = t - this.dragStartPoint.y, h = Math.abs(this.axisX.maximum - this.axisX.minimum) / i.height * o) : (o = this.dragStartPoint.x - n, h = Math.abs(this.axisX.maximum - this.axisX.minimum) / i.width * o), Math.abs(o) > 2) { if (this.panEnabled) s = !1, e = 0, this.axisX.sessionVariables.internalMinimum < this.axisX._absoluteMinimum ? (e = this.axisX._absoluteMinimum - this.axisX.sessionVariables.internalMinimum, this.axisX.sessionVariables.internalMinimum += e, this.axisX.sessionVariables.internalMaximum += e, s = !0) : this.axisX.sessionVariables.internalMaximum > this.axisX._absoluteMaximum && (e = this.axisX.sessionVariables.internalMaximum - this.axisX._absoluteMaximum, this.axisX.sessionVariables.internalMaximum -= e, this.axisX.sessionVariables.internalMinimum -= e, s = !0), s && this.render(); else if (this.zoomEnabled) { if (this.resetOverlayedCanvas(), !this.dragStartPoint) return; if (this.plotInfo.axisPlacement === "xySwapped") { if (r = { y1: Math.min(this.dragStartPoint.y, t), y2: Math.max(this.dragStartPoint.y, t) }, Math.abs(r.y1 - r.y2) > 1) { var i = this.axisX.lineCoordinates, u = this.axisX.maximum - (this.axisX.maximum - this.axisX.minimum) / i.height * (r.y2 - i.y1), f = this.axisX.maximum - (this.axisX.maximum - this.axisX.minimum) / i.height * (r.y1 - i.y1); u = Math.max(u, this.axisX.dataInfo.min); f = Math.min(f, this.axisX.dataInfo.max); Math.abs(f - u) > 2 * Math.abs(this.axisX.dataInfo.minDiff) && (this.axisX.sessionVariables.internalMinimum = u, this.axisX.sessionVariables.internalMaximum = f, this.render()) } } else if (this.plotInfo.axisPlacement === "normal" && (r = { x1: Math.min(this.dragStartPoint.x, n), x2: Math.max(this.dragStartPoint.x, n) }, Math.abs(r.x1 - r.x2) > 1)) { var i = this.axisX.lineCoordinates, u = (this.axisX.maximum - this.axisX.minimum) / i.width * (r.x1 - i.x1) + this.axisX.minimum, f = (this.axisX.maximum - this.axisX.minimum) / i.width * (r.x2 - i.x1) + this.axisX.minimum; u = Math.max(u, this.axisX.dataInfo.min); f = Math.min(f, this.axisX.dataInfo.max); Math.abs(f - u) > 2 * Math.abs(this.axisX.dataInfo.minDiff) && (this.axisX.sessionVariables.internalMinimum = u, this.axisX.sessionVariables.internalMaximum = f, this.render()) } } this._ignoreNextEvent = !0; this.zoomEnabled && this._zoomButton.style.display === "none" && (ui(this._zoomButton, this._resetButton), b(this, this._zoomButton, "pan"), b(this, this._resetButton, "reset")) } } this.isDrag = !1 }; t.prototype._plotAreaMouseMove = function(n, t) { var r, o, u, s; if (this.isDrag && this.plotInfo.axisPlacement !== "none") { var i = 0, f = 0, e = this.axisX.lineCoordinates; this.plotInfo.axisPlacement === "xySwapped" ? (i = t - this.dragStartPoint.y, f = Math.abs(this.axisX.maximum - this.axisX.minimum) / e.height * i) : (i = this.dragStartPoint.x - n, f = Math.abs(this.axisX.maximum - this.axisX.minimum) / e.width * i); Math.abs(i) > 2 && Math.abs(i) < 8 && (this.panEnabled || this.zoomEnabled) ? this._toolTip.hide() : this.panEnabled || this.zoomEnabled || this._toolTip.mouseMoveHandler(n, t); Math.abs(i) > 2 && (this.panEnabled || this.zoomEnabled) && (this.panEnabled ? (this.axisX.sessionVariables.internalMinimum = this.dragStartPoint.xMinimum + f, this.axisX.sessionVariables.internalMaximum = this.dragStartPoint.xMaximum + f, r = 0, this.axisX.sessionVariables.internalMinimum < this.axisX._absoluteMinimum - st(this.axisX.interval, this.axisX.intervalType) ? (r = this.axisX._absoluteMinimum - st(this.axisX.interval, this.axisX.intervalType) - this.axisX.sessionVariables.internalMinimum, this.axisX.sessionVariables.internalMinimum += r, this.axisX.sessionVariables.internalMaximum += r) : this.axisX.sessionVariables.internalMaximum > this.axisX._absoluteMaximum + st(this.axisX.interval, this.axisX.intervalType) && (r = this.axisX.sessionVariables.internalMaximum - (this.axisX._absoluteMaximum + st(this.axisX.interval, this.axisX.intervalType)), this.axisX.sessionVariables.internalMaximum -= r, this.axisX.sessionVariables.internalMinimum -= r), o = this, clearTimeout(this._panTimerId), this._panTimerId = setTimeout(function() { o.render() }, 0)) : this.zoomEnabled && (u = this.plotArea, this.resetOverlayedCanvas(), s = this.overlaidCanvasCtx.globalAlpha, this.overlaidCanvasCtx.globalAlpha = .7, this.overlaidCanvasCtx.fillStyle = "#A0ABB8", this.plotInfo.axisPlacement === "xySwapped" ? this.overlaidCanvasCtx.fillRect(u.x1, this.dragStartPoint.y, u.x2 - u.x1, t - this.dragStartPoint.y) : this.plotInfo.axisPlacement === "normal" && this.overlaidCanvasCtx.fillRect(this.dragStartPoint.x, u.y1, n - this.dragStartPoint.x, u.y2 - u.y1), this.overlaidCanvasCtx.globalAlpha = s)) } else this._toolTip.mouseMoveHandler(n, t) }; t.prototype.preparePlotArea = function() { var t = this.plotArea, i = this.axisY ? this.axisY : this.axisY2, r; !n && (t.x1 > 0 || t.y1 > 0) && t.ctx.translate(t.x1, t.y1); this.axisX && i ? (t.x1 = this.axisX.lineCoordinates.x1 < this.axisX.lineCoordinates.x2 ? this.axisX.lineCoordinates.x1 : i.lineCoordinates.x1, t.y1 = this.axisX.lineCoordinates.y1 < i.lineCoordinates.y1 ? this.axisX.lineCoordinates.y1 : i.lineCoordinates.y1, t.x2 = this.axisX.lineCoordinates.x2 > i.lineCoordinates.x2 ? this.axisX.lineCoordinates.x2 : i.lineCoordinates.x2, t.y2 = this.axisX.lineCoordinates.y2 > this.axisX.lineCoordinates.y1 ? this.axisX.lineCoordinates.y2 : i.lineCoordinates.y2, t.width = t.x2 - t.x1, t.height = t.y2 - t.y1) : (r = this.layoutManager.getFreeSpace(), t.x1 = r.x1, t.x2 = r.x2, t.y1 = r.y1, t.y2 = r.y2, t.width = r.width, t.height = r.height); n || (t.canvas.width = t.width, t.canvas.height = t.height, t.canvas.style.left = t.x1 + "px", t.canvas.style.top = t.y1 + "px", (t.x1 > 0 || t.y1 > 0) && t.ctx.translate(-t.x1, -t.y1)); t.layoutManager = new ft(t.x1, t.y1, t.x2, t.y2, 2) }; t.prototype.getPixelCoordinatesOnPlotArea = function(n, t) { return { x: this.axisX.getPixelCoordinatesOnAxis(n).x, y: this.axisY.getPixelCoordinatesOnAxis(t).y } }; t.prototype.renderIndexLabels = function(n) { for (var nt, ot = n || this.plotArea.ctx, u = this.plotArea, y = 0, w = 0, b = 0, d = 0, g = 0, h = 0, f = 0, l = 0, e = 0, it = 0; it < this._indexLabels.length; it++) { var t = this._indexLabels[it], i = t.chartType.toLowerCase(), a, o, wt, ct = p("indexLabelFontColor", t.dataPoint, t.dataSeries), rt = p("indexLabelFontSize", t.dataPoint, t.dataSeries), lt = p("indexLabelFontFamily", t.dataPoint, t.dataSeries), at = p("indexLabelFontStyle", t.dataPoint, t.dataSeries), vt = p("indexLabelFontWeight", t.dataPoint, t.dataSeries), yt = p("indexLabelBackgroundColor", t.dataPoint, t.dataSeries), st = p("indexLabelMaxWidth", t.dataPoint, t.dataSeries), pt = p("indexLabelWrap", t.dataPoint, t.dataSeries), ut = { percent: null, total: null }, ft = null; if ((t.dataSeries.type.indexOf("stacked") >= 0 || t.dataSeries.type === "pie" || t.dataSeries.type === "doughnut") && (ut = this.getPercentAndTotal(t.dataSeries, t.dataPoint)), (t.dataSeries.indexLabelFormatter || t.dataPoint.indexLabelFormatter) && (ft = { chart: this._options, dataSeries: t.dataSeries, dataPoint: t.dataPoint, index: t.indexKeyword, total: ut.total, percent: ut.percent }), nt = t.dataPoint.indexLabelFormatter ? t.dataPoint.indexLabelFormatter(ft) : t.dataPoint.indexLabel ? this.replaceKeywordsWithValue(t.dataPoint.indexLabel, t.dataPoint, t.dataSeries, null, t.indexKeyword) : t.dataSeries.indexLabelFormatter ? t.dataSeries.indexLabelFormatter(ft) : t.dataSeries.indexLabel ? this.replaceKeywordsWithValue(t.dataSeries.indexLabel, t.dataPoint, t.dataSeries, null, t.indexKeyword) : null, nt !== null && nt !== "") { var s = p("indexLabelPlacement", t.dataPoint, t.dataSeries), et = p("indexLabelOrientation", t.dataPoint, t.dataSeries), wt = 0, k = t.direction, tt = t.dataSeries.axisX, ht = t.dataSeries.axisY, v = new c(ot, { x: 0, y: 0, maxWidth: st ? st : this.width * .5, maxHeight: pt ? rt * 5 : rt * 1.5, angle: et === "horizontal" ? 0 : -90, text: nt, padding: 0, backgroundColor: yt, horizontalAlign: "left", fontSize: rt, fontFamily: lt, fontWeight: vt, fontColor: ct, fontStyle: at, textBaseline: "top" }), bt = v.measureText(); if (i.indexOf("line") >= 0 || i.indexOf("area") >= 0 || i.indexOf("bubble") >= 0 || i.indexOf("scatter") >= 0) { if (t.dataPoint.x < tt.minimum || t.dataPoint.x > tt.maximum || t.dataPoint.y < ht.minimum || t.dataPoint.y > ht.maximum) continue } else if (t.dataPoint.x < tt.minimum || t.dataPoint.x > tt.maximum) continue; f = 2; h = 2; et === "horizontal" ? (l = v.width, e = v.height) : (e = v.width, l = v.height); this.plotInfo.axisPlacement === "normal" ? (i.indexOf("line") >= 0 || i.indexOf("area") >= 0 ? (s = "auto", f = 4) : i.indexOf("stacked") >= 0 ? s === "auto" && (s = "inside") : (i === "bubble" || i === "scatter") && (s = "inside"), a = t.point.x - l / 2, s !== "inside" ? (w = u.y1, b = u.y2, k > 0 ? (o = t.point.y - e - f, o < w && (o = s === "auto" ? Math.max(t.point.y, w) + f : w + f)) : (o = t.point.y + f, o > b - e - f && (o = s === "auto" ? Math.min(t.point.y, b) - e - f : b - e - f))) : (w = Math.max(t.bounds.y1, u.y1), b = Math.min(t.bounds.y2, u.y2), y = i.indexOf("range") >= 0 ? k > 0 ? Math.max(t.bounds.y1, u.y1) + e / 2 + f : Math.min(t.bounds.y2, u.y2) - e / 2 - f : (Math.max(t.bounds.y1, u.y1) + Math.min(t.bounds.y2, u.y2)) / 2, k > 0 ? (o = Math.max(t.point.y, y) - e / 2, o < w && (i === "bubble" || i === "scatter") && (o = Math.max(t.point.y - e - f, u.y1 + f))) : (o = Math.min(t.point.y, y) - e / 2, o > b - e - f && (i === "bubble" || i === "scatter") && (o = Math.min(t.point.y + f, u.y2 - e - f))))) : (i.indexOf("line") >= 0 || i.indexOf("area") >= 0 || i.indexOf("scatter") >= 0 ? (s = "auto", h = 4) : i.indexOf("stacked") >= 0 ? s === "auto" && (s = "inside") : i === "bubble" && (s = "inside"), o = t.point.y - e / 2, s !== "inside" ? (d = u.x1, g = u.x2, k < 0 ? (a = t.point.x - l - h, a < d && (a = s === "auto" ? Math.max(t.point.x, d) + h : d + h)) : (a = t.point.x + h, a > g - l - h && (a = s === "auto" ? Math.min(t.point.x, g) - l - h : g - l - h))) : (d = Math.max(t.bounds.x1, u.x1), g = Math.min(t.bounds.x2, u.x2), y = i.indexOf("range") >= 0 ? k < 0 ? Math.max(t.bounds.x1, u.x1) + l / 2 + h : Math.min(t.bounds.x2, u.x2) - l / 2 - h : (Math.max(t.bounds.x1, u.x1) + Math.min(t.bounds.x2, u.x2)) / 2, a = k < 0 ? Math.max(t.point.x, y) - l / 2 : Math.min(t.point.x, y) - l / 2)); et === "vertical" && (o += e); v.x = a; v.y = o; v.render(!0) } } return { source: ot, dest: this.plotArea.ctx, animationCallback: r.fadeInAnimation, easingFunction: r.easing.easeInQuad, animationBase: 0, startTimePercent: .7 } }; t.prototype.renderLine = function(t) { var i = t.targetCanvasCtx || this.plotArea.ctx, et = t.dataSeriesIndexes.length, o, l, p, w, b, e, s, nt, ut, ft, tt, it, f, h, c, k, d, g, v, rt; if (!(et <= 0)) { for (o = this._eventManager.ghostCtx, i.save(), l = this.plotArea, i.beginPath(), i.rect(l.x1, l.y1, l.width, l.height), i.clip(), p = [], w = 0; w < t.dataSeriesIndexes.length; w++) if (b = t.dataSeriesIndexes[w], e = this.data[b], i.lineWidth = e.lineThickness, s = e.dataPoints, i.setLineDash && i.setLineDash(y(e.lineDashType, e.lineThickness)), nt = e.id, this._eventManager.objectMap[nt] = { objectType: "dataSeries", dataSeriesIndex: b }, ut = u(nt), o.strokeStyle = ut, o.lineWidth = e.lineThickness > 0 ? Math.max(e.lineThickness, 4) : 0, ft = e._colorSet, tt = ft[0], i.strokeStyle = tt, it = !0, f = 0, i.beginPath(), s.length > 0) { for (d = !1, f = 0; f < s.length; f++) if (k = s[f].x.getTime ? s[f].x.getTime() : s[f].x, !(k < t.axisX.dataInfo.viewPortMin) && !(k > t.axisX.dataInfo.viewPortMax)) { if (typeof s[f].y != "number") { f > 0 && (i.stroke(), n && o.stroke()); d = !0; continue } h = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (k - t.axisX.conversionParameters.minimum) + .5 << 0; c = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (s[f].y - t.axisY.conversionParameters.minimum) + .5 << 0; g = e.dataPointIds[f]; this._eventManager.objectMap[g] = { id: g, objectType: "dataPoint", dataSeriesIndex: b, dataPointIndex: f, x1: h, y1: c }; it || d ? (i.beginPath(), i.moveTo(h, c), n && (o.beginPath(), o.moveTo(h, c)), it = !1, d = !1) : (i.lineTo(h, c), n && o.lineTo(h, c), f % 500 == 0 && (i.stroke(), i.beginPath(), i.moveTo(h, c), n && (o.stroke(), o.beginPath(), o.moveTo(h, c)))); (s[f].markerSize > 0 || e.markerSize > 0) && (v = e.getMarkerProperties(f, h, c, i), p.push(v), rt = u(g), n && p.push({ x: h, y: c, ctx: o, type: v.type, size: v.size, color: rt, borderColor: rt, borderThickness: v.borderThickness })); (s[f].indexLabel || e.indexLabel || s[f].indexLabelFormatter || e.indexLabelFormatter) && this._indexLabels.push({ chartType: "line", dataPoint: s[f], dataSeries: e, point: { x: h, y: c }, direction: s[f].y >= 0 ? 1 : -1, color: tt }) } i.stroke(); n && o.stroke() } return a.drawMarkers(p), i.restore(), i.beginPath(), n && o.beginPath(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; t.prototype.renderStepLine = function(t) { var i = t.targetCanvasCtx || this.plotArea.ctx, ot = t.dataSeriesIndexes.length, o, l, p, w, b, e, s, nt, ft, et, tt, it, f, h, c, k, d, rt, g, v, ut; if (!(ot <= 0)) { for (o = this._eventManager.ghostCtx, i.save(), l = this.plotArea, i.beginPath(), i.rect(l.x1, l.y1, l.width, l.height), i.clip(), p = [], w = 0; w < t.dataSeriesIndexes.length; w++) if (b = t.dataSeriesIndexes[w], e = this.data[b], i.lineWidth = e.lineThickness, s = e.dataPoints, i.setLineDash && i.setLineDash(y(e.lineDashType, e.lineThickness)), nt = e.id, this._eventManager.objectMap[nt] = { objectType: "dataSeries", dataSeriesIndex: b }, ft = u(nt), o.strokeStyle = ft, o.lineWidth = e.lineThickness > 0 ? Math.max(e.lineThickness, 4) : 0, et = e._colorSet, tt = et[0], i.strokeStyle = tt, it = !0, f = 0, i.beginPath(), s.length > 0) { for (d = !1, f = 0; f < s.length; f++) if (k = s[f].getTime ? s[f].x.getTime() : s[f].x, !(k < t.axisX.dataInfo.viewPortMin) && !(k > t.axisX.dataInfo.viewPortMax)) { if (typeof s[f].y != "number") { f > 0 && (i.stroke(), n && o.stroke()); d = !0; continue } rt = c; h = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (k - t.axisX.conversionParameters.minimum) + .5 << 0; c = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (s[f].y - t.axisY.conversionParameters.minimum) + .5 << 0; g = e.dataPointIds[f]; this._eventManager.objectMap[g] = { id: g, objectType: "dataPoint", dataSeriesIndex: b, dataPointIndex: f, x1: h, y1: c }; it || d ? (i.beginPath(), i.moveTo(h, c), n && (o.beginPath(), o.moveTo(h, c)), it = !1, d = !1) : (i.lineTo(h, rt), n && o.lineTo(h, rt), i.lineTo(h, c), n && o.lineTo(h, c), f % 500 == 0 && (i.stroke(), i.beginPath(), i.moveTo(h, c), n && (o.stroke(), o.beginPath(), o.moveTo(h, c)))); (s[f].markerSize > 0 || e.markerSize > 0) && (v = e.getMarkerProperties(f, h, c, i), p.push(v), ut = u(g), n && p.push({ x: h, y: c, ctx: o, type: v.type, size: v.size, color: ut, borderColor: ut, borderThickness: v.borderThickness })); (s[f].indexLabel || e.indexLabel || s[f].indexLabelFormatter || e.indexLabelFormatter) && this._indexLabels.push({ chartType: "stepLine", dataPoint: s[f], dataSeries: e, point: { x: h, y: c }, direction: s[f].y >= 0 ? 1 : -1, color: tt }) } i.stroke(); n && o.stroke() } return a.drawMarkers(p), i.restore(), i.beginPath(), n && o.beginPath(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; t.prototype.renderSpline = function(t) { function ft(t) { var r = kt(t, 2), u; if (r.length > 0) { for (i.beginPath(), n && s.beginPath(), i.moveTo(r[0].x, r[0].y), n && s.moveTo(r[0].x, r[0].y), u = 0; u < r.length - 3; u += 3) i.bezierCurveTo(r[u + 1].x, r[u + 1].y, r[u + 2].x, r[u + 2].y, r[u + 3].x, r[u + 3].y), n && s.bezierCurveTo(r[u + 1].x, r[u + 1].y, r[u + 2].x, r[u + 2].y, r[u + 3].x, r[u + 3].y), u > 0 && u % 3e3 == 0 && (i.stroke(), i.beginPath(), i.moveTo(r[u + 3].x, r[u + 3].y), n && (s.stroke(), s.beginPath(), s.moveTo(r[u + 3].x, r[u + 3].y))); i.stroke(); n && s.stroke() } } var i = t.targetCanvasCtx || this.plotArea.ctx, et = t.dataSeriesIndexes.length, s, l, w, b, k, e, o, nt, rt, ut, tt, g, p, it; if (!(et <= 0)) { for (s = this._eventManager.ghostCtx, i.save(), l = this.plotArea, i.beginPath(), i.rect(l.x1, l.y1, l.width, l.height), i.clip(), w = [], b = 0; b < t.dataSeriesIndexes.length; b++) { k = t.dataSeriesIndexes[b]; e = this.data[k]; i.lineWidth = e.lineThickness; o = e.dataPoints; i.setLineDash && i.setLineDash(y(e.lineDashType, e.lineThickness)); nt = e.id; this._eventManager.objectMap[nt] = { objectType: "dataSeries", dataSeriesIndex: k }; rt = u(nt); s.strokeStyle = rt; s.lineWidth = e.lineThickness > 0 ? Math.max(e.lineThickness, 4) : 0; ut = e._colorSet; tt = ut[0]; i.strokeStyle = tt; var f = 0, h, c, d, v = []; if (i.beginPath(), o.length > 0) for (f = 0; f < o.length; f++) if (d = o[f].getTime ? o[f].x.getTime() : o[f].x, !(d < t.axisX.dataInfo.viewPortMin) && !(d > t.axisX.dataInfo.viewPortMax)) { if (typeof o[f].y != "number") { f > 0 && (ft(v), v = []); continue } h = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (d - t.axisX.conversionParameters.minimum) + .5 << 0; c = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (o[f].y - t.axisY.conversionParameters.minimum) + .5 << 0; g = e.dataPointIds[f]; this._eventManager.objectMap[g] = { id: g, objectType: "dataPoint", dataSeriesIndex: k, dataPointIndex: f, x1: h, y1: c }; v[v.length] = { x: h, y: c }; (o[f].markerSize > 0 || e.markerSize > 0) && (p = e.getMarkerProperties(f, h, c, i), w.push(p), it = u(g), n && w.push({ x: h, y: c, ctx: s, type: p.type, size: p.size, color: it, borderColor: it, borderThickness: p.borderThickness })); (o[f].indexLabel || e.indexLabel || o[f].indexLabelFormatter || e.indexLabelFormatter) && this._indexLabels.push({ chartType: "spline", dataPoint: o[f], dataSeries: e, point: { x: h, y: c }, direction: o[f].y >= 0 ? 1 : -1, color: tt }) } ft(v) } return a.drawMarkers(w), i.restore(), i.beginPath(), n && s.beginPath(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; o = function(n, t, i, r, u, f, e, o, s, h, c, l, a) { var v, w, y; typeof a == "undefined" && (a = 1); e = e || 0; o = o || "black"; var k = t, d = r, g = i, nt = u; v = r - t > 15 && u - i > 15 ? 8 : .35 * Math.min(r - t, u - i); var tt = "rgba(255, 255, 255, .4)", b = "rgba(255, 255, 255, 0.1)", p = f; n.beginPath(); n.moveTo(t, i); n.save(); n.fillStyle = p; n.globalAlpha = a; n.fillRect(t, i, r - t, u - i); n.globalAlpha = 1; e > 0 && (w = e % 2 == 0 ? 0 : .5, n.beginPath(), n.lineWidth = e, n.strokeStyle = o, n.moveTo(t, i), n.rect(t - w, i - w, r - t + 2 * w, u - i + 2 * w), n.stroke()); n.restore(); s === !0 && (n.save(), n.beginPath(), n.moveTo(t, i), n.lineTo(t + v, i + v), n.lineTo(r - v, i + v), n.lineTo(r, i), n.closePath(), y = n.createLinearGradient((r + t) / 2, g + v, (r + t) / 2, g), y.addColorStop(0, p), y.addColorStop(1, tt), n.fillStyle = y, n.fill(), n.restore()); h === !0 && (n.save(), n.beginPath(), n.moveTo(t, u), n.lineTo(t + v, u - v), n.lineTo(r - v, u - v), n.lineTo(r, u), n.closePath(), y = n.createLinearGradient((r + t) / 2, nt - v, (r + t) / 2, nt), y.addColorStop(0, p), y.addColorStop(1, tt), n.fillStyle = y, n.fill(), n.restore()); c === !0 && (n.save(), n.beginPath(), n.moveTo(t, i), n.lineTo(t + v, i + v), n.lineTo(t + v, u - v), n.lineTo(t, u), n.closePath(), y = n.createLinearGradient(k + v, (u + i) / 2, k, (u + i) / 2), y.addColorStop(0, p), y.addColorStop(1, b), n.fillStyle = y, n.fill(), n.restore()); l === !0 && (n.save(), n.beginPath(), n.moveTo(r, i), n.lineTo(r - v, i + v), n.lineTo(r - v, u - v), n.lineTo(r, u), y = n.createLinearGradient(d - v, (u + i) / 2, d, (u + i) / 2), y.addColorStop(0, p), y.addColorStop(1, b), n.fillStyle = y, y.addColorStop(0, p), y.addColorStop(1, b), n.fillStyle = y, n.fill(), n.closePath(), n.restore()) }; t.prototype.renderColumn = function(t) { var v = t.targetCanvasCtx || this.plotArea.ctx, st = t.dataSeriesIndexes.length, w, tt, a, y, e, s, ft, k, et, ot; if (!(st <= 0)) { var p = null, h = this.plotArea, i = 0, it, d, b, g = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, nt = this.dataPointMaxWidth ? this.dataPointMaxWidth : Math.min(this.width * .15, this.plotArea.width / t.plotType.totalDataSeries * .9) << 0, rt = t.axisX.dataInfo.minDiff, c = h.width / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(rt) / t.plotType.totalDataSeries * .9 << 0; for (c > nt ? c = nt : rt === Infinity ? c = nt / t.plotType.totalDataSeries * .9 : c < 1 && (c = 1), v.save(), n && this._eventManager.ghostCtx.save(), v.beginPath(), v.rect(h.x1, h.y1, h.width, h.height), v.clip(), n && (this._eventManager.ghostCtx.rect(h.x1, h.y1, h.width, h.height), this._eventManager.ghostCtx.clip()), w = 0; w < t.dataSeriesIndexes.length; w++) { var ut = t.dataSeriesIndexes[w], l = this.data[ut], f = l.dataPoints; if (f.length > 0) for (tt = c > 5 && l.bevelEnabled ? !0 : !1, i = 0; i < f.length; i++)(b = f[i].getTime ? f[i].x.getTime() : f[i].x, b < t.axisX.dataInfo.viewPortMin || b > t.axisX.dataInfo.viewPortMax) || typeof f[i].y == "number" && (it = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (b - t.axisX.conversionParameters.minimum) + .5 << 0, d = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y - t.axisY.conversionParameters.minimum) + .5 << 0, a = it - t.plotType.totalDataSeries * c / 2 + (t.previousDataSeriesCount + w) * c << 0, y = a + c << 0, f[i].y >= 0 ? (e = d, s = g, e > s && (ft = e, e = s, s = e)) : (s = d, e = g, e > s && (ft = e, e = s, s = e)), p = f[i].color ? f[i].color : l._colorSet[i % l._colorSet.length], o(v, a, e, y, s, p, 0, null, tt && f[i].y >= 0, f[i].y < 0 && tt, !1, !1, l.fillOpacity), k = l.dataPointIds[i], this._eventManager.objectMap[k] = { id: k, objectType: "dataPoint", dataSeriesIndex: ut, dataPointIndex: i, x1: a, y1: e, x2: y, y2: s }, p = u(k), n && o(this._eventManager.ghostCtx, a, e, y, s, p, 0, null, !1, !1, !1, !1), (f[i].indexLabel || l.indexLabel || f[i].indexLabelFormatter || l.indexLabelFormatter) && this._indexLabels.push({ chartType: "column", dataPoint: f[i], dataSeries: l, point: { x: a + (y - a) / 2, y: f[i].y >= 0 ? e : s }, direction: f[i].y >= 0 ? 1 : -1, bounds: { x1: a, y1: Math.min(e, s), x2: y, y2: Math.max(e, s) }, color: p })) } return v.restore(), n && this._eventManager.ghostCtx.restore(), et = Math.min(g, t.axisY.boundingRect.y2), ot = { source: v, dest: this.plotArea.ctx, animationCallback: r.yScaleAnimation, easingFunction: r.easing.easeOutQuart, animationBase: et }, ot } }; t.prototype.renderStackedColumn = function(t) { var v = t.targetCanvasCtx || this.plotArea.ctx, ct = t.dataSeriesIndexes.length, k, ft, p, b, s, h, y, d, st, ht; if (!(ct <= 0)) { var w = null, c = this.plotArea, g = [], nt = [], i = 0, tt, it, e, rt = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, ut = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.width * .15 << 0, et = t.axisX.dataInfo.minDiff, l = c.width / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(et) / t.plotType.plotUnits.length * .9 << 0; for (l > ut ? l = ut : et === Infinity ? l = ut : l < 1 && (l = 1), v.save(), n && this._eventManager.ghostCtx.save(), v.beginPath(), v.rect(c.x1, c.y1, c.width, c.height), v.clip(), n && (this._eventManager.ghostCtx.rect(c.x1, c.y1, c.width, c.height), this._eventManager.ghostCtx.clip()), k = 0; k < t.dataSeriesIndexes.length; k++) { var ot = t.dataSeriesIndexes[k], a = this.data[ot], f = a.dataPoints; if (f.length > 0) for (ft = l > 5 && a.bevelEnabled ? !0 : !1, v.strokeStyle = "#4572A7 ", i = 0; i < f.length; i++)(e = f[i].x.getTime ? f[i].x.getTime() : f[i].x, e < t.axisX.dataInfo.viewPortMin || e > t.axisX.dataInfo.viewPortMax) || typeof f[i].y == "number" && (tt = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (e - t.axisX.conversionParameters.minimum) + .5 << 0, it = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y - t.axisY.conversionParameters.minimum), p = tt - t.plotType.plotUnits.length * l / 2 + t.index * l << 0, b = p + l << 0, f[i].y >= 0 ? (y = g[e] ? g[e] : 0, s = it - y, h = rt - y, g[e] = y + (h - s)) : (y = nt[e] ? nt[e] : 0, h = it + y, s = rt + y, nt[e] = y + (h - s)), w = f[i].color ? f[i].color : a._colorSet[i % a._colorSet.length], o(v, p, s, b, h, w, 0, null, ft && f[i].y >= 0, f[i].y < 0 && ft, !1, !1, a.fillOpacity), d = a.dataPointIds[i], this._eventManager.objectMap[d] = { id: d, objectType: "dataPoint", dataSeriesIndex: ot, dataPointIndex: i, x1: p, y1: s, x2: b, y2: h }, w = u(d), n && o(this._eventManager.ghostCtx, p, s, b, h, w, 0, null, !1, !1, !1, !1), (f[i].indexLabel || a.indexLabel || f[i].indexLabelFormatter || a.indexLabelFormatter) && this._indexLabels.push({ chartType: "stackedColumn", dataPoint: f[i], dataSeries: a, point: { x: tt, y: f[i].y >= 0 ? s : h }, direction: f[i].y >= 0 ? 1 : -1, bounds: { x1: p, y1: Math.min(s, h), x2: b, y2: Math.max(s, h) }, color: w })) } return v.restore(), n && this._eventManager.ghostCtx.restore(), st = Math.min(rt, t.axisY.boundingRect.y2), ht = { source: v, dest: this.plotArea.ctx, animationCallback: r.yScaleAnimation, easingFunction: r.easing.easeOutQuart, animationBase: st }, ht } }; t.prototype.renderStackedColumn100 = function(t) { var y = t.targetCanvasCtx || this.plotArea.ctx, lt = t.dataSeriesIndexes.length, k, ft, st, p, b, s, h, v, d, ht, ct; if (!(lt <= 0)) { var w = null, c = this.plotArea, g = [], nt = [], i = 0, tt, it, e, rt = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, ut = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.width * .15 << 0, et = t.axisX.dataInfo.minDiff, l = c.width / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(et) / t.plotType.plotUnits.length * .9 << 0; for (l > ut ? l = ut : et === Infinity ? l = ut : l < 1 && (l = 1), y.save(), n && this._eventManager.ghostCtx.save(), y.beginPath(), y.rect(c.x1, c.y1, c.width, c.height), y.clip(), n && (this._eventManager.ghostCtx.rect(c.x1, c.y1, c.width, c.height), this._eventManager.ghostCtx.clip()), k = 0; k < t.dataSeriesIndexes.length; k++) { var ot = t.dataSeriesIndexes[k], a = this.data[ot], f = a.dataPoints; if (f.length > 0) for (ft = l > 5 && a.bevelEnabled ? !0 : !1, i = 0; i < f.length; i++)(e = f[i].x.getTime ? f[i].x.getTime() : f[i].x, e < t.axisX.dataInfo.viewPortMin || e > t.axisX.dataInfo.viewPortMax) || typeof f[i].y == "number" && (tt = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (e - t.axisX.conversionParameters.minimum) + .5 << 0, st = t.dataPointYSums[e] !== 0 ? f[i].y / t.dataPointYSums[e] * 100 : 0, it = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (st - t.axisY.conversionParameters.minimum), p = tt - t.plotType.plotUnits.length * l / 2 + t.index * l << 0, b = p + l << 0, f[i].y >= 0 ? (v = g[e] ? g[e] : 0, s = it - v, h = rt - v, g[e] = v + (h - s)) : (v = nt[e] ? nt[e] : 0, h = it + v, s = rt + v, nt[e] = v + (h - s)), w = f[i].color ? f[i].color : a._colorSet[i % a._colorSet.length], o(y, p, s, b, h, w, 0, null, ft && f[i].y >= 0, f[i].y < 0 && ft, !1, !1, a.fillOpacity), d = a.dataPointIds[i], this._eventManager.objectMap[d] = { id: d, objectType: "dataPoint", dataSeriesIndex: ot, dataPointIndex: i, x1: p, y1: s, x2: b, y2: h }, w = u(d), n && o(this._eventManager.ghostCtx, p, s, b, h, w, 0, null, !1, !1, !1, !1), (f[i].indexLabel || a.indexLabel || f[i].indexLabelFormatter || a.indexLabelFormatter) && this._indexLabels.push({ chartType: "stackedColumn100", dataPoint: f[i], dataSeries: a, point: { x: tt, y: f[i].y >= 0 ? s : h }, direction: f[i].y >= 0 ? 1 : -1, bounds: { x1: p, y1: Math.min(s, h), x2: b, y2: Math.max(s, h) }, color: w })) } return y.restore(), n && this._eventManager.ghostCtx.restore(), ht = Math.min(rt, t.axisY.boundingRect.y2), ct = { source: y, dest: this.plotArea.ctx, animationCallback: r.yScaleAnimation, easingFunction: r.easing.easeOutQuart, animationBase: ht }, ct } }; t.prototype.renderBar = function(t) { var c = t.targetCanvasCtx || this.plotArea.ctx, ot = t.dataSeriesIndexes.length, w, ut, l, y, a, v, k, ft, et; if (!(ot <= 0)) { var p = null, e = this.plotArea, i = 0, d, tt, b, g = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, nt = this.dataPointMaxWidth ? this.dataPointMaxWidth : Math.min(this.height * .15, this.plotArea.height / t.plotType.totalDataSeries * .9) << 0, it = t.axisX.dataInfo.minDiff, s = e.height / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(it) / t.plotType.totalDataSeries * .9 << 0; for (s > nt ? s = nt : it === Infinity ? s = nt / t.plotType.totalDataSeries * .9 : s < 1 && (s = 1), c.save(), n && this._eventManager.ghostCtx.save(), c.beginPath(), c.rect(e.x1, e.y1, e.width, e.height), c.clip(), n && (this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height), this._eventManager.ghostCtx.clip()), w = 0; w < t.dataSeriesIndexes.length; w++) { var rt = t.dataSeriesIndexes[w], h = this.data[rt], f = h.dataPoints; if (f.length > 0) for (ut = s > 5 && h.bevelEnabled ? !0 : !1, c.strokeStyle = "#4572A7 ", i = 0; i < f.length; i++)(b = f[i].getTime ? f[i].x.getTime() : f[i].x, b < t.axisX.dataInfo.viewPortMin || b > t.axisX.dataInfo.viewPortMax) || typeof f[i].y == "number" && (tt = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (b - t.axisX.conversionParameters.minimum) + .5 << 0, d = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y - t.axisY.conversionParameters.minimum) + .5 << 0, l = tt - t.plotType.totalDataSeries * s / 2 + (t.previousDataSeriesCount + w) * s << 0, y = l + s << 0, f[i].y >= 0 ? (a = g, v = d) : (a = d, v = g), p = f[i].color ? f[i].color : h._colorSet[i % h._colorSet.length], o(c, a, l, v, y, p, 0, null, ut, !1, !1, !1, h.fillOpacity), k = h.dataPointIds[i], this._eventManager.objectMap[k] = { id: k, objectType: "dataPoint", dataSeriesIndex: rt, dataPointIndex: i, x1: a, y1: l, x2: v, y2: y }, p = u(k), n && o(this._eventManager.ghostCtx, a, l, v, y, p, 0, null, !1, !1, !1, !1), (f[i].indexLabel || h.indexLabel || f[i].indexLabelFormatter || h.indexLabelFormatter) && this._indexLabels.push({ chartType: "bar", dataPoint: f[i], dataSeries: h, point: { x: f[i].y >= 0 ? v : a, y: l + (y - l) / 2 }, direction: f[i].y >= 0 ? 1 : -1, bounds: { x1: Math.min(a, v), y1: l, x2: Math.max(a, v), y2: y }, color: p })) } return c.restore(), n && this._eventManager.ghostCtx.restore(), ft = Math.max(g, t.axisX.boundingRect.x2), et = { source: c, dest: this.plotArea.ctx, animationCallback: r.xScaleAnimation, easingFunction: r.easing.easeOutQuart, animationBase: ft }, et } }; t.prototype.renderStackedBar = function(t) { var v = t.targetCanvasCtx || this.plotArea.ctx, ct = t.dataSeriesIndexes.length, k, ot, p, b, s, h, y, d, st, ht; if (!(ct <= 0)) { var w = null, c = this.plotArea, g = [], nt = [], i = 0, tt, it, e, rt = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, ut = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.height * .15 << 0, ft = t.axisX.dataInfo.minDiff, l = c.height / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(ft) / t.plotType.plotUnits.length * .9 << 0; for (l > ut ? l = ut : ft === Infinity ? l = ut : l < 1 && (l = 1), v.save(), n && this._eventManager.ghostCtx.save(), v.beginPath(), v.rect(c.x1, c.y1, c.width, c.height), v.clip(), n && (this._eventManager.ghostCtx.rect(c.x1, c.y1, c.width, c.height), this._eventManager.ghostCtx.clip()), k = 0; k < t.dataSeriesIndexes.length; k++) { var et = t.dataSeriesIndexes[k], a = this.data[et], f = a.dataPoints; if (f.length > 0) for (ot = l > 5 && a.bevelEnabled ? !0 : !1, v.strokeStyle = "#4572A7 ", i = 0; i < f.length; i++)(e = f[i].x.getTime ? f[i].x.getTime() : f[i].x, e < t.axisX.dataInfo.viewPortMin || e > t.axisX.dataInfo.viewPortMax) || typeof f[i].y == "number" && (it = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (e - t.axisX.conversionParameters.minimum) + .5 << 0, tt = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y - t.axisY.conversionParameters.minimum), p = it - t.plotType.plotUnits.length * l / 2 + t.index * l << 0, b = p + l << 0, f[i].y >= 0 ? (y = g[e] ? g[e] : 0, s = rt + y, h = tt + y, g[e] = y + (h - s)) : (y = nt[e] ? nt[e] : 0, s = tt - y, h = rt - y, nt[e] = y + (h - s)), w = f[i].color ? f[i].color : a._colorSet[i % a._colorSet.length], o(v, s, p, h, b, w, 0, null, ot, !1, !1, !1, a.fillOpacity), d = a.dataPointIds[i], this._eventManager.objectMap[d] = { id: d, objectType: "dataPoint", dataSeriesIndex: et, dataPointIndex: i, x1: s, y1: p, x2: h, y2: b }, w = u(d), n && o(this._eventManager.ghostCtx, s, p, h, b, w, 0, null, !1, !1, !1, !1), (f[i].indexLabel || a.indexLabel || f[i].indexLabelFormatter || a.indexLabelFormatter) && this._indexLabels.push({ chartType: "stackedBar", dataPoint: f[i], dataSeries: a, point: { x: f[i].y >= 0 ? h : s, y: it }, direction: f[i].y >= 0 ? 1 : -1, bounds: { x1: Math.min(s, h), y1: p, x2: Math.max(s, h), y2: b }, color: w })) } return v.restore(), n && this._eventManager.ghostCtx.restore(), st = Math.max(rt, t.axisX.boundingRect.x2), ht = { source: v, dest: this.plotArea.ctx, animationCallback: r.xScaleAnimation, easingFunction: r.easing.easeOutQuart, animationBase: st }, ht } }; t.prototype.renderStackedBar100 = function(t) { var v = t.targetCanvasCtx || this.plotArea.ctx, lt = t.dataSeriesIndexes.length, k, ot, st, p, b, s, h, y, d, ht, ct; if (!(lt <= 0)) { var w = null, c = this.plotArea, g = [], nt = [], i = 0, tt, it, e, rt = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, ut = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.height * .15 << 0, ft = t.axisX.dataInfo.minDiff, l = c.height / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(ft) / t.plotType.plotUnits.length * .9 << 0; for (l > ut ? l = ut : ft === Infinity ? l = ut : l < 1 && (l = 1), v.save(), n && this._eventManager.ghostCtx.save(), v.beginPath(), v.rect(c.x1, c.y1, c.width, c.height), v.clip(), n && (this._eventManager.ghostCtx.rect(c.x1, c.y1, c.width, c.height), this._eventManager.ghostCtx.clip()), k = 0; k < t.dataSeriesIndexes.length; k++) { var et = t.dataSeriesIndexes[k], a = this.data[et], f = a.dataPoints; if (f.length > 0) for (ot = l > 5 && a.bevelEnabled ? !0 : !1, v.strokeStyle = "#4572A7 ", i = 0; i < f.length; i++)(e = f[i].x.getTime ? f[i].x.getTime() : f[i].x, e < t.axisX.dataInfo.viewPortMin || e > t.axisX.dataInfo.viewPortMax) || typeof f[i].y == "number" && (it = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (e - t.axisX.conversionParameters.minimum) + .5 << 0, st = t.dataPointYSums[e] !== 0 ? f[i].y / t.dataPointYSums[e] * 100 : 0, tt = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (st - t.axisY.conversionParameters.minimum), p = it - t.plotType.plotUnits.length * l / 2 + t.index * l << 0, b = p + l << 0, f[i].y >= 0 ? (y = g[e] ? g[e] : 0, s = rt + y, h = tt + y, g[e] = y + (h - s)) : (y = nt[e] ? nt[e] : 0, s = tt - y, h = rt - y, nt[e] = y + (h - s)), w = f[i].color ? f[i].color : a._colorSet[i % a._colorSet.length], o(v, s, p, h, b, w, 0, null, ot, !1, !1, !1, a.fillOpacity), d = a.dataPointIds[i], this._eventManager.objectMap[d] = { id: d, objectType: "dataPoint", dataSeriesIndex: et, dataPointIndex: i, x1: s, y1: p, x2: h, y2: b }, w = u(d), n && o(this._eventManager.ghostCtx, s, p, h, b, w, 0, null, !1, !1, !1, !1), (f[i].indexLabel || a.indexLabel || f[i].indexLabelFormatter || a.indexLabelFormatter) && this._indexLabels.push({ chartType: "stackedBar100", dataPoint: f[i], dataSeries: a, point: { x: f[i].y >= 0 ? h : s, y: it }, direction: f[i].y >= 0 ? 1 : -1, bounds: { x1: Math.min(s, h), y1: p, x2: Math.max(s, h), y2: b }, color: w })) } return v.restore(), n && this._eventManager.ghostCtx.restore(), ht = Math.max(rt, t.axisX.boundingRect.x2), ct = { source: v, dest: this.plotArea.ctx, animationCallback: r.xScaleAnimation, easingFunction: r.easing.easeOutQuart, animationBase: ht }, ct } }; t.prototype.renderArea = function(t) { function ut() { p && (o.lineThickness > 0 && i.stroke(), t.axisY.minimum <= 0 && t.axisY.maximum >= 0 ? v = lt : t.axisY.maximum < 0 ? v = ct.y1 : t.axisY.minimum > 0 && (v = ht.y2), i.lineTo(s, v), i.lineTo(p.x, v), i.closePath(), i.globalAlpha = o.fillOpacity, i.fill(), i.globalAlpha = 1, n && (e.lineTo(s, v), e.lineTo(p.x, v), e.closePath(), e.fill()), i.beginPath(), i.moveTo(s, c), e.beginPath(), e.moveTo(s, c), p = { x: s, y: c }) } var i = t.targetCanvasCtx || this.plotArea.ctx, st = t.dataSeriesIndexes.length, k, et, g, nt, tt, w, rt; if (!(st <= 0)) { var e = this._eventManager.ghostCtx, ht = t.axisX.lineCoordinates, ct = t.axisY.lineCoordinates, b = [], l = this.plotArea; for (i.save(), n && e.save(), i.beginPath(), i.rect(l.x1, l.y1, l.width, l.height), i.clip(), n && (e.beginPath(), e.rect(l.x1, l.y1, l.width, l.height), e.clip()), k = 0; k < t.dataSeriesIndexes.length; k++) { var it = t.dataSeriesIndexes[k], o = this.data[it], h = o.dataPoints, ft = o.id; this._eventManager.objectMap[ft] = { objectType: "dataSeries", dataSeriesIndex: it }; et = u(ft); e.fillStyle = et; b = []; var ot = !0, f = 0, s, c, d, lt = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) + .5 << 0, v, p = null; if (h.length > 0) { for (g = o._colorSet[f % o._colorSet.length], i.fillStyle = g, i.strokeStyle = g, i.lineWidth = o.lineThickness, i.setLineDash && i.setLineDash(y(o.lineDashType, o.lineThickness)), nt = !0; f < h.length; f++) if (d = h[f].x.getTime ? h[f].x.getTime() : h[f].x, !(d < t.axisX.dataInfo.viewPortMin) && !(d > t.axisX.dataInfo.viewPortMax)) { if (typeof h[f].y != "number") { ut(); nt = !0; continue } s = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (d - t.axisX.conversionParameters.minimum) + .5 << 0; c = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (h[f].y - t.axisY.conversionParameters.minimum) + .5 << 0; ot || nt ? (i.beginPath(), i.moveTo(s, c), p = { x: s, y: c }, n && (e.beginPath(), e.moveTo(s, c)), ot = !1, nt = !1) : (i.lineTo(s, c), n && e.lineTo(s, c), f % 250 == 0 && ut()); tt = o.dataPointIds[f]; this._eventManager.objectMap[tt] = { id: tt, objectType: "dataPoint", dataSeriesIndex: it, dataPointIndex: f, x1: s, y1: c }; h[f].markerSize !== 0 && (h[f].markerSize > 0 || o.markerSize > 0) && (w = o.getMarkerProperties(f, s, c, i), b.push(w), rt = u(tt), n && b.push({ x: s, y: c, ctx: e, type: w.type, size: w.size, color: rt, borderColor: rt, borderThickness: w.borderThickness })); (h[f].indexLabel || o.indexLabel || h[f].indexLabelFormatter || o.indexLabelFormatter) && this._indexLabels.push({ chartType: "area", dataPoint: h[f], dataSeries: o, point: { x: s, y: c }, direction: h[f].y >= 0 ? 1 : -1, color: g }) } ut(); a.drawMarkers(b) } } return i.restore(), n && this._eventManager.ghostCtx.restore(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; t.prototype.renderSplineArea = function(t) { function ft() { var r = kt(d, 2), u; if (r.length > 0) { for (i.beginPath(), i.moveTo(r[0].x, r[0].y), n && (o.beginPath(), o.moveTo(r[0].x, r[0].y)), u = 0; u < r.length - 3; u += 3) i.bezierCurveTo(r[u + 1].x, r[u + 1].y, r[u + 2].x, r[u + 2].y, r[u + 3].x, r[u + 3].y), n && o.bezierCurveTo(r[u + 1].x, r[u + 1].y, r[u + 2].x, r[u + 2].y, r[u + 3].x, r[u + 3].y); e.lineThickness > 0 && i.stroke(); t.axisY.minimum <= 0 && t.axisY.maximum >= 0 ? c = ht : t.axisY.maximum < 0 ? c = st.y1 : t.axisY.minimum > 0 && (c = ot.y2); tt = { x: r[0].x, y: r[0].y }; i.lineTo(r[r.length - 1].x, c); i.lineTo(tt.x, c); i.closePath(); i.globalAlpha = e.fillOpacity; i.fill(); i.globalAlpha = 1; n && (o.lineTo(r[r.length - 1].x, c), o.lineTo(tt.x, c), o.closePath(), o.fill()) } } var i = t.targetCanvasCtx || this.plotArea.ctx, et = t.dataSeriesIndexes.length, b, ut, g, p, it; if (!(et <= 0)) { var o = this._eventManager.ghostCtx, ot = t.axisX.lineCoordinates, st = t.axisY.lineCoordinates, w = [], h = this.plotArea; for (i.save(), n && o.save(), i.beginPath(), i.rect(h.x1, h.y1, h.width, h.height), i.clip(), n && (o.beginPath(), o.rect(h.x1, h.y1, h.width, h.height), o.clip()), b = 0; b < t.dataSeriesIndexes.length; b++) { var nt = t.dataSeriesIndexes[b], e = this.data[nt], s = e.dataPoints, rt = e.id; this._eventManager.objectMap[rt] = { objectType: "dataSeries", dataSeriesIndex: nt }; ut = u(rt); o.fillStyle = ut; w = []; var f = 0, l, v, k, ht = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) + .5 << 0, c, tt = null, d = []; if (s.length > 0) { for (color = e._colorSet[f % e._colorSet.length], i.fillStyle = color, i.strokeStyle = color, i.lineWidth = e.lineThickness, i.setLineDash && i.setLineDash(y(e.lineDashType, e.lineThickness)); f < s.length; f++) if (k = s[f].x.getTime ? s[f].x.getTime() : s[f].x, !(k < t.axisX.dataInfo.viewPortMin) && !(k > t.axisX.dataInfo.viewPortMax)) { if (typeof s[f].y != "number") { f > 0 && (ft(), d = []); continue } l = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (k - t.axisX.conversionParameters.minimum) + .5 << 0; v = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (s[f].y - t.axisY.conversionParameters.minimum) + .5 << 0; g = e.dataPointIds[f]; this._eventManager.objectMap[g] = { id: g, objectType: "dataPoint", dataSeriesIndex: nt, dataPointIndex: f, x1: l, y1: v }; d[d.length] = { x: l, y: v }; s[f].markerSize !== 0 && (s[f].markerSize > 0 || e.markerSize > 0) && (p = e.getMarkerProperties(f, l, v, i), w.push(p), it = u(g), n && w.push({ x: l, y: v, ctx: o, type: p.type, size: p.size, color: it, borderColor: it, borderThickness: p.borderThickness })); (s[f].indexLabel || e.indexLabel || s[f].indexLabelFormatter || e.indexLabelFormatter) && this._indexLabels.push({ chartType: "splineArea", dataPoint: s[f], dataSeries: e, point: { x: l, y: v }, direction: s[f].y >= 0 ? 1 : -1, color: color }) } ft(); a.drawMarkers(w) } } return i.restore(), n && this._eventManager.ghostCtx.restore(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; t.prototype.renderStepArea = function(t) { function ft() { p && (s.lineThickness > 0 && i.stroke(), t.axisY.minimum <= 0 && t.axisY.maximum >= 0 ? v = at : t.axisY.maximum < 0 ? v = lt.y1 : t.axisY.minimum > 0 && (v = ct.y2), i.lineTo(e, v), i.lineTo(p.x, v), i.closePath(), i.globalAlpha = s.fillOpacity, i.fill(), i.globalAlpha = 1, n && (o.lineTo(e, v), o.lineTo(p.x, v), o.closePath(), o.fill()), i.beginPath(), i.moveTo(e, h), o.beginPath(), o.moveTo(e, h), p = { x: e, y: h }) } var i = t.targetCanvasCtx || this.plotArea.ctx, ht = t.dataSeriesIndexes.length, k, ot, g, rt, nt, w, ut; if (!(ht <= 0)) { var o = this._eventManager.ghostCtx, ct = t.axisX.lineCoordinates, lt = t.axisY.lineCoordinates, b = [], l = this.plotArea; for (i.save(), n && o.save(), i.beginPath(), i.rect(l.x1, l.y1, l.width, l.height), i.clip(), n && (o.beginPath(), o.rect(l.x1, l.y1, l.width, l.height), o.clip()), k = 0; k < t.dataSeriesIndexes.length; k++) { var tt = t.dataSeriesIndexes[k], s = this.data[tt], c = s.dataPoints, et = s.id; this._eventManager.objectMap[et] = { objectType: "dataSeries", dataSeriesIndex: tt }; ot = u(et); o.fillStyle = ot; b = []; var st = !0, f = 0, e, h, d, at = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) + .5 << 0, v, p = null, it = !1; if (c.length > 0) { for (g = s._colorSet[f % s._colorSet.length], i.fillStyle = g, i.strokeStyle = g, i.lineWidth = s.lineThickness, i.setLineDash && i.setLineDash(y(s.lineDashType, s.lineThickness)); f < c.length; f++) if (d = c[f].x.getTime ? c[f].x.getTime() : c[f].x, !(d < t.axisX.dataInfo.viewPortMin) && !(d > t.axisX.dataInfo.viewPortMax)) { if (rt = h, typeof c[f].y != "number") { ft(); it = !0; continue } e = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (d - t.axisX.conversionParameters.minimum) + .5 << 0; h = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (c[f].y - t.axisY.conversionParameters.minimum) + .5 << 0; st || it ? (i.beginPath(), i.moveTo(e, h), p = { x: e, y: h }, n && (o.beginPath(), o.moveTo(e, h)), st = !1, it = !1) : (i.lineTo(e, rt), n && o.lineTo(e, rt), i.lineTo(e, h), n && o.lineTo(e, h), f % 250 == 0 && ft()); nt = s.dataPointIds[f]; this._eventManager.objectMap[nt] = { id: nt, objectType: "dataPoint", dataSeriesIndex: tt, dataPointIndex: f, x1: e, y1: h }; c[f].markerSize !== 0 && (c[f].markerSize > 0 || s.markerSize > 0) && (w = s.getMarkerProperties(f, e, h, i), b.push(w), ut = u(nt), n && b.push({ x: e, y: h, ctx: o, type: w.type, size: w.size, color: ut, borderColor: ut, borderThickness: w.borderThickness })); (c[f].indexLabel || s.indexLabel || c[f].indexLabelFormatter || s.indexLabelFormatter) && this._indexLabels.push({ chartType: "stepArea", dataPoint: c[f], dataSeries: s, point: { x: e, y: h }, direction: c[f].y >= 0 ? 1 : -1, color: g }) } ft(); a.drawMarkers(b) } } return i.restore(), n && this._eventManager.ghostCtx.restore(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; t.prototype.renderStackedArea = function(t) { var i = t.targetCanvasCtx || this.plotArea.ctx, lt = t.dataSeriesIndexes.length, w, ct, v, rt, nt, l; if (!(lt <= 0)) { var tt = null, ut = [], p = this.plotArea, ft = [], d = [], s = 0, h, o, c, et = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, at = t.axisX.dataInfo.minDiff, e = this._eventManager.ghostCtx; for (n && e.beginPath(), i.save(), n && e.save(), i.beginPath(), i.rect(p.x1, p.y1, p.width, p.height), i.clip(), n && (e.beginPath(), e.rect(p.x1, p.y1, p.width, p.height), e.clip()), xValuePresent = [], w = 0; w < t.dataSeriesIndexes.length; w++) { var it = t.dataSeriesIndexes[w], f = this.data[it], b = f.dataPoints, g; for (f.dataPointIndexes = [], s = 0; s < b.length; s++) g = b[s].x.getTime ? b[s].x.getTime() : b[s].x, f.dataPointIndexes[g] = s, xValuePresent[g] || (d.push(g), xValuePresent[g] = !0); d.sort(si) } for (w = 0; w < t.dataSeriesIndexes.length; w++) { var it = t.dataSeriesIndexes[w], f = this.data[it], b = f.dataPoints, st = !0, k = [], ht = f.id; if (this._eventManager.objectMap[ht] = { objectType: "dataSeries", dataSeriesIndex: it }, ct = u(ht), e.fillStyle = ct, d.length > 0) { for (tt = f._colorSet[0], i.fillStyle = tt, i.strokeStyle = tt, i.lineWidth = f.lineThickness, i.setLineDash && i.setLineDash(y(f.lineDashType, f.lineThickness)), s = 0; s < d.length; s++) if ((c = d[s], v = null, v = f.dataPointIndexes[c] >= 0 ? b[f.dataPointIndexes[c]] : { x: c, y: 0 }, !(c < t.axisX.dataInfo.viewPortMin) && !(c > t.axisX.dataInfo.viewPortMax)) && typeof v.y == "number") { var h = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (c - t.axisX.conversionParameters.minimum) + .5 << 0, o = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (v.y - t.axisY.conversionParameters.minimum), ot = ft[c] ? ft[c] : 0; if (o = o - ot, k.push({ x: h, y: et - ot }), ft[c] = et - o, st) i.beginPath(), i.moveTo(h, o), n && (e.beginPath(), e.moveTo(h, o)), st = !1; else if (i.lineTo(h, o), n && e.lineTo(h, o), s % 250 == 0) { for (f.lineThickness > 0 && i.stroke(); k.length > 0;) l = k.pop(), i.lineTo(l.x, l.y), n && e.lineTo(l.x, l.y); i.closePath(); i.globalAlpha = f.fillOpacity; i.fill(); i.globalAlpha = 1; i.beginPath(); i.moveTo(h, o); n && (e.closePath(), e.fill(), e.beginPath(), e.moveTo(h, o)); k.push({ x: h, y: et - ot }) } f.dataPointIndexes[c] >= 0 && (rt = f.dataPointIds[f.dataPointIndexes[c]], this._eventManager.objectMap[rt] = { id: rt, objectType: "dataPoint", dataSeriesIndex: it, dataPointIndex: f.dataPointIndexes[c], x1: h, y1: o }); f.dataPointIndexes[c] >= 0 && v.markerSize !== 0 && (v.markerSize > 0 || f.markerSize > 0) && (nt = f.getMarkerProperties(s, h, o, i), ut.push(nt), markerColor = u(rt), n && ut.push({ x: h, y: o, ctx: e, type: nt.type, size: nt.size, color: markerColor, borderColor: markerColor, borderThickness: nt.borderThickness })); (v.indexLabel || f.indexLabel || v.indexLabelFormatter || f.indexLabelFormatter) && this._indexLabels.push({ chartType: "stackedArea", dataPoint: v, dataSeries: f, point: { x: h, y: o }, direction: b[s].y >= 0 ? 1 : -1, color: tt }) } for (f.lineThickness > 0 && i.stroke(); k.length > 0;) l = k.pop(), i.lineTo(l.x, l.y), n && e.lineTo(l.x, l.y); i.closePath(); i.globalAlpha = f.fillOpacity; i.fill(); i.globalAlpha = 1; i.beginPath(); i.moveTo(h, o); n && (e.closePath(), e.fill(), e.beginPath(), e.moveTo(h, o)) } delete f.dataPointIndexes } return a.drawMarkers(ut), i.restore(), n && e.restore(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; t.prototype.renderStackedArea100 = function(t) { var i = t.targetCanvasCtx || this.plotArea.ctx, yt = t.dataSeriesIndexes.length, w, at, k, wt, p, vt, ut, tt, l; if (!(yt <= 0)) { var it = null, v = this.plotArea, ft = [], et = [], g = [], s = 0, c, h, o, ot = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, st = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.width * .15 << 0, pt = t.axisX.dataInfo.minDiff, d = v.width / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(pt) * .9 << 0, e = this._eventManager.ghostCtx; for (i.save(), n && e.save(), i.beginPath(), i.rect(v.x1, v.y1, v.width, v.height), i.clip(), n && (e.beginPath(), e.rect(v.x1, v.y1, v.width, v.height), e.clip()), xValuePresent = [], w = 0; w < t.dataSeriesIndexes.length; w++) { var rt = t.dataSeriesIndexes[w], f = this.data[rt], b = f.dataPoints, nt; for (f.dataPointIndexes = [], s = 0; s < b.length; s++) nt = b[s].x.getTime ? b[s].x.getTime() : b[s].x, f.dataPointIndexes[nt] = s, xValuePresent[nt] || (g.push(nt), xValuePresent[nt] = !0); g.sort(si) } for (w = 0; w < t.dataSeriesIndexes.length; w++) { var rt = t.dataSeriesIndexes[w], f = this.data[rt], b = f.dataPoints, ct = !0, lt = f.id; if (this._eventManager.objectMap[lt] = { objectType: "dataSeries", dataSeriesIndex: rt }, at = u(lt), e.fillStyle = at, b.length == 1 && (d = st), d < 1 ? d = 1 : d > st && (d = st), k = [], g.length > 0) { for (it = f._colorSet[s % f._colorSet.length], i.fillStyle = it, i.strokeStyle = it, i.lineWidth = f.lineThickness, i.setLineDash && i.setLineDash(y(f.lineDashType, f.lineThickness)), wt = d > 5 ? !1 : !1, s = 0; s < g.length; s++) if ((o = g[s], p = null, p = f.dataPointIndexes[o] >= 0 ? b[f.dataPointIndexes[o]] : { x: o, y: 0 }, !(o < t.axisX.dataInfo.viewPortMin) && !(o > t.axisX.dataInfo.viewPortMax)) && typeof p.y == "number") { vt = t.dataPointYSums[o] !== 0 ? p.y / t.dataPointYSums[o] * 100 : 0; var c = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (o - t.axisX.conversionParameters.minimum) + .5 << 0, h = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (vt - t.axisY.conversionParameters.minimum), ht = et[o] ? et[o] : 0; if (h = h - ht, k.push({ x: c, y: ot - ht }), et[o] = ot - h, ct) i.beginPath(), i.moveTo(c, h), n && (e.beginPath(), e.moveTo(c, h)), ct = !1; else if (i.lineTo(c, h), n && e.lineTo(c, h), s % 250 == 0) { for (f.lineThickness > 0 && i.stroke(); k.length > 0;) l = k.pop(), i.lineTo(l.x, l.y), n && e.lineTo(l.x, l.y); i.closePath(); i.globalAlpha = f.fillOpacity; i.fill(); i.globalAlpha = 1; i.beginPath(); i.moveTo(c, h); n && (e.closePath(), e.fill(), e.beginPath(), e.moveTo(c, h)); k.push({ x: c, y: ot - ht }) } f.dataPointIndexes[o] >= 0 && (ut = f.dataPointIds[f.dataPointIndexes[o]], this._eventManager.objectMap[ut] = { id: ut, objectType: "dataPoint", dataSeriesIndex: rt, dataPointIndex: f.dataPointIndexes[o], x1: c, y1: h }); f.dataPointIndexes[o] >= 0 && p.markerSize !== 0 && (p.markerSize > 0 || f.markerSize > 0) && (tt = f.getMarkerProperties(s, c, h, i), ft.push(tt), markerColor = u(ut), n && ft.push({ x: c, y: h, ctx: e, type: tt.type, size: tt.size, color: markerColor, borderColor: markerColor, borderThickness: tt.borderThickness })); (p.indexLabel || f.indexLabel || p.indexLabelFormatter || f.indexLabelFormatter) && this._indexLabels.push({ chartType: "stackedArea100", dataPoint: p, dataSeries: f, point: { x: c, y: h }, direction: b[s].y >= 0 ? 1 : -1, color: it }) } for (f.lineThickness > 0 && i.stroke(); k.length > 0;) l = k.pop(), i.lineTo(l.x, l.y), n && e.lineTo(l.x, l.y); i.closePath(); i.globalAlpha = f.fillOpacity; i.fill(); i.globalAlpha = 1; i.beginPath(); i.moveTo(c, h); n && (e.closePath(), e.fill(), e.beginPath(), e.moveTo(c, h)) } delete f.dataPointIndexes } return a.drawMarkers(ft), i.restore(), n && e.restore(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; t.prototype.renderBubble = function(t) { var o = t.targetCanvasCtx || this.plotArea.ctx, ut = t.dataSeriesIndexes.length, k, p, d, it, c, i, g, rt; if (!(ut <= 0)) { var s = this.plotArea, i = 0, v, y, h, ht = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, nt = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.width * .15 << 0, et = t.axisX.dataInfo.minDiff, b = s.width / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(et) / ut * .9 << 0; for (o.save(), n && this._eventManager.ghostCtx.save(), o.beginPath(), o.rect(s.x1, s.y1, s.width, s.height), o.clip(), n && (this._eventManager.ghostCtx.rect(s.x1, s.y1, s.width, s.height), this._eventManager.ghostCtx.clip()), k = -Infinity, p = Infinity, c = 0; c < t.dataSeriesIndexes.length; c++) { var tt = t.dataSeriesIndexes[c], l = this.data[tt], f = l.dataPoints, w = 0; for (i = 0; i < f.length; i++)(h = h = f[i].getTime ? f[i].x.getTime() : f[i].x, h < t.axisX.dataInfo.viewPortMin || h > t.axisX.dataInfo.viewPortMax) || typeof f[i].z != "undefined" && (w = f[i].z, w > k && (k = w), w < p && (p = w)) } for (d = Math.PI * 25, it = Math.max(Math.pow(Math.min(s.height, s.width) * .25 / 2, 2) * Math.PI, d), c = 0; c < t.dataSeriesIndexes.length; c++) { var tt = t.dataSeriesIndexes[c], l = this.data[tt], f = l.dataPoints; if (f.length == 1 && (b = nt), b < 1 ? b = 1 : b > nt && (b = nt), f.length > 0) for (o.strokeStyle = "#4572A7 ", i = 0; i < f.length; i++) if ((h = h = f[i].getTime ? f[i].x.getTime() : f[i].x, !(h < t.axisX.dataInfo.viewPortMin) && !(h > t.axisX.dataInfo.viewPortMax)) && typeof f[i].y == "number") { v = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (h - t.axisX.conversionParameters.minimum) + .5 << 0; y = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y - t.axisY.conversionParameters.minimum) + .5 << 0; var w = f[i].z, ot = k === p ? it / 2 : d + (it - d) / (k - p) * (w - p), st = Math.max(Math.sqrt(ot / Math.PI) << 0, 1), ft = st * 2, e = l.getMarkerProperties(i, o); e.size = ft; o.globalAlpha = l.fillOpacity; a.drawMarker(v, y, o, e.type, e.size, e.color, e.borderColor, e.borderThickness); o.globalAlpha = 1; g = l.dataPointIds[i]; this._eventManager.objectMap[g] = { id: g, objectType: "dataPoint", dataSeriesIndex: tt, dataPointIndex: i, x1: v, y1: y, size: ft }; rt = u(g); n && a.drawMarker(v, y, this._eventManager.ghostCtx, e.type, e.size, rt, rt, e.borderThickness); (f[i].indexLabel || l.indexLabel || f[i].indexLabelFormatter || l.indexLabelFormatter) && this._indexLabels.push({ chartType: "bubble", dataPoint: f[i], dataSeries: l, point: { x: v, y: y }, direction: 1, bounds: { x1: v - e.size / 2, y1: y - e.size / 2, x2: v + e.size / 2, y2: y + e.size / 2 }, color: null }) } } return o.restore(), n && this._eventManager.ghostCtx.restore(), { source: o, dest: this.plotArea.ctx, animationCallback: r.fadeInAnimation, easingFunction: r.easing.easeInQuad, animationBase: 0 } } }; t.prototype.renderScatter = function(t) { var s = t.targetCanvasCtx || this.plotArea.ctx, nt = t.dataSeriesIndexes.length, p, f, i, w, g; if (!(nt <= 0)) { var o = this.plotArea, f = 0, h, c, v, rt = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, b = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.width * .15 << 0, it = t.axisX.dataInfo.minDiff, y = o.width / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(it) / nt * .9 << 0; for (s.save(), n && this._eventManager.ghostCtx.save(), s.beginPath(), s.rect(o.x1, o.y1, o.width, o.height), s.clip(), n && (this._eventManager.ghostCtx.rect(o.x1, o.y1, o.width, o.height), this._eventManager.ghostCtx.clip()), p = 0; p < t.dataSeriesIndexes.length; p++) { var tt = t.dataSeriesIndexes[p], l = this.data[tt], e = l.dataPoints; if (e.length == 1 && (y = b), y < 1 ? y = 1 : y > b && (y = b), e.length > 0) { s.strokeStyle = "#4572A7 "; var ut = Math.pow(Math.min(o.height, o.width) * .3 / 2, 2) * Math.PI, k = 0, d = 0; for (f = 0; f < e.length; f++)(v = v = e[f].getTime ? e[f].x.getTime() : e[f].x, v < t.axisX.dataInfo.viewPortMin || v > t.axisX.dataInfo.viewPortMax) || typeof e[f].y == "number" && ((h = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (v - t.axisX.conversionParameters.minimum) + .5 << 0, c = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (e[f].y - t.axisY.conversionParameters.minimum) + .5 << 0, i = l.getMarkerProperties(f, h, c, s), s.globalAlpha = l.fillOpacity, a.drawMarker(i.x, i.y, i.ctx, i.type, i.size, i.color, i.borderColor, i.borderThickness), s.globalAlpha = 1, Math.sqrt((k - h) * (k - h) + (d - c) * (d - c)) < Math.min(i.size, 5) && e.length > Math.min(this.plotArea.width, this.plotArea.height)) || (w = l.dataPointIds[f], this._eventManager.objectMap[w] = { id: w, objectType: "dataPoint", dataSeriesIndex: tt, dataPointIndex: f, x1: h, y1: c }, g = u(w), n && a.drawMarker(i.x, i.y, this._eventManager.ghostCtx, i.type, i.size, g, g, i.borderThickness), (e[f].indexLabel || l.indexLabel || e[f].indexLabelFormatter || l.indexLabelFormatter) && this._indexLabels.push({ chartType: "scatter", dataPoint: e[f], dataSeries: l, point: { x: h, y: c }, direction: 1, bounds: { x1: h - i.size / 2, y1: c - i.size / 2, x2: h + i.size / 2, y2: c + i.size / 2 }, color: null }), k = h, d = c)) } } return s.restore(), n && this._eventManager.ghostCtx.restore(), { source: s, dest: this.plotArea.ctx, animationCallback: r.fadeInAnimation, easingFunction: r.easing.easeInQuad, animationBase: 0 } } }; t.prototype.renderCandlestick = function(t) { var i = t.targetCanvasCtx || this.plotArea.ctx, f = this._eventManager.ghostCtx, st = t.dataSeriesIndexes.length, it, ft, p, g; if (!(st <= 0)) { var y = null, w = this.plotArea, e = 0, h, c, b, d, l, tt, ht = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, ut = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.width * .015, et = t.axisX.dataInfo.minDiff, k = w.width / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(et) * .7 << 0; for (k > ut ? k = ut : et === Infinity ? k = ut : k < 1 && (k = 1), i.save(), n && f.save(), i.beginPath(), i.rect(w.x1, w.y1, w.width, w.height), i.clip(), n && (f.rect(w.x1, w.y1, w.width, w.height), f.clip()), it = 0; it < t.dataSeriesIndexes.length; it++) { var ot = t.dataSeriesIndexes[it], a = this.data[ot], s = a.dataPoints; if (s.length > 0) for (ft = k > 5 && a.bevelEnabled ? !0 : !1, e = 0; e < s.length; e++) if ((tt = s[e].getTime ? s[e].x.getTime() : s[e].x, !(tt < t.axisX.dataInfo.viewPortMin) && !(tt > t.axisX.dataInfo.viewPortMax)) && s[e].y !== null && s[e].y.length && typeof s[e].y[0] == "number" && typeof s[e].y[1] == "number" && typeof s[e].y[2] == "number" && typeof s[e].y[3] == "number") { h = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (tt - t.axisX.conversionParameters.minimum) + .5 << 0; c = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (s[e].y[0] - t.axisY.conversionParameters.minimum) + .5 << 0; b = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (s[e].y[1] - t.axisY.conversionParameters.minimum) + .5 << 0; d = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (s[e].y[2] - t.axisY.conversionParameters.minimum) + .5 << 0; l = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (s[e].y[3] - t.axisY.conversionParameters.minimum) + .5 << 0; p = h - k / 2 << 0; g = p + k << 0; y = s[e].color ? s[e].color : a._colorSet[0]; var nt = Math.round(Math.max(1, k * .15)), v = nt % 2 == 0 ? 0 : .5, rt = a.dataPointIds[e]; this._eventManager.objectMap[rt] = { id: rt, objectType: "dataPoint", dataSeriesIndex: ot, dataPointIndex: e, x1: p, y1: c, x2: g, y2: b, x3: h, y3: d, x4: h, y4: l, borderThickness: nt, color: y }; i.strokeStyle = y; i.beginPath(); i.lineWidth = nt; f.lineWidth = Math.max(nt, 4); a.type === "candlestick" ? (i.moveTo(h - v, b), i.lineTo(h - v, Math.min(c, l)), i.stroke(), i.moveTo(h - v, Math.max(c, l)), i.lineTo(h - v, d), i.stroke(), o(i, p, Math.min(c, l), g, Math.max(c, l), s[e].y[0] <= s[e].y[3] ? a.risingColor : y, nt, y, ft, ft, !1, !1, a.fillOpacity), n && (y = u(rt), f.strokeStyle = y, f.moveTo(h - v, b), f.lineTo(h - v, Math.min(c, l)), f.stroke(), f.moveTo(h - v, Math.max(c, l)), f.lineTo(h - v, d), f.stroke(), o(f, p, Math.min(c, l), g, Math.max(c, l), y, 0, null, !1, !1, !1, !1))) : a.type === "ohlc" && (i.moveTo(h - v, b), i.lineTo(h - v, d), i.stroke(), i.beginPath(), i.moveTo(h, c), i.lineTo(p, c), i.stroke(), i.beginPath(), i.moveTo(h, l), i.lineTo(g, l), i.stroke(), n && (y = u(rt), f.strokeStyle = y, f.moveTo(h - v, b), f.lineTo(h - v, d), f.stroke(), f.beginPath(), f.moveTo(h, c), f.lineTo(p, c), f.stroke(), f.beginPath(), f.moveTo(h, l), f.lineTo(g, l), f.stroke())); (s[e].indexLabel || a.indexLabel || s[e].indexLabelFormatter || a.indexLabelFormatter) && this._indexLabels.push({ chartType: a.type, dataPoint: s[e], dataSeries: a, point: { x: p + (g - p) / 2, y: b }, direction: 1, bounds: { x1: p, y1: Math.min(b, d), x2: g, y2: Math.max(b, d) }, color: y }) } } return i.restore(), n && f.restore(), { source: i, dest: this.plotArea.ctx, animationCallback: r.fadeInAnimation, easingFunction: r.easing.easeInQuad, animationBase: 0 } } }; t.prototype.renderRangeColumn = function(t) { var y = t.targetCanvasCtx || this.plotArea.ctx, ft = t.dataSeriesIndexes.length, w, g, h, v, e, s, rt, k, ut; if (!(ft <= 0)) { var p = null, l = this.plotArea, i = 0, nt, e, s, b, et = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, d = this.dataPointMaxWidth ? this.dataPointMaxWidth : this.width * .03, tt = t.axisX.dataInfo.minDiff, a = l.width / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(tt) / t.plotType.totalDataSeries * .9 << 0; for (a > d ? a = d : tt === Infinity ? a = d / t.plotType.totalDataSeries * .9 : a < 1 && (a = 1), y.save(), n && this._eventManager.ghostCtx.save(), y.beginPath(), y.rect(l.x1, l.y1, l.width, l.height), y.clip(), n && (this._eventManager.ghostCtx.rect(l.x1, l.y1, l.width, l.height), this._eventManager.ghostCtx.clip()), w = 0; w < t.dataSeriesIndexes.length; w++) { var it = t.dataSeriesIndexes[w], c = this.data[it], f = c.dataPoints; if (f.length > 0) for (g = a > 5 && c.bevelEnabled ? !0 : !1, i = 0; i < f.length; i++)(b = f[i].getTime ? f[i].x.getTime() : f[i].x, b < t.axisX.dataInfo.viewPortMin || b > t.axisX.dataInfo.viewPortMax) || f[i].y !== null && f[i].y.length && typeof f[i].y[0] == "number" && typeof f[i].y[1] == "number" && (nt = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (b - t.axisX.conversionParameters.minimum) + .5 << 0, e = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y[0] - t.axisY.conversionParameters.minimum) + .5 << 0, s = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y[1] - t.axisY.conversionParameters.minimum) + .5 << 0, h = nt - t.plotType.totalDataSeries * a / 2 + (t.previousDataSeriesCount + w) * a << 0, v = h + a << 0, p = f[i].color ? f[i].color : c._colorSet[i % c._colorSet.length], e > s && (rt = e, e = s, s = rt), k = c.dataPointIds[i], this._eventManager.objectMap[k] = { id: k, objectType: "dataPoint", dataSeriesIndex: it, dataPointIndex: i, x1: h, y1: e, x2: v, y2: s }, ut = 0, o(y, h, e, v, s, p, ut, p, g, g, !1, !1, c.fillOpacity), p = u(k), n && o(this._eventManager.ghostCtx, h, e, v, s, p, 0, null, !1, !1, !1, !1), (f[i].indexLabel || c.indexLabel || f[i].indexLabelFormatter || c.indexLabelFormatter) && (this._indexLabels.push({ chartType: "rangeColumn", dataPoint: f[i], dataSeries: c, indexKeyword: 0, point: { x: h + (v - h) / 2, y: f[i].y[1] >= f[i].y[0] ? s : e }, direction: f[i].y[1] >= f[i].y[0] ? -1 : 1, bounds: { x1: h, y1: Math.min(e, s), x2: v, y2: Math.max(e, s) }, color: p }), this._indexLabels.push({ chartType: "rangeColumn", dataPoint: f[i], dataSeries: c, indexKeyword: 1, point: { x: h + (v - h) / 2, y: f[i].y[1] >= f[i].y[0] ? e : s }, direction: f[i].y[1] >= f[i].y[0] ? 1 : -1, bounds: { x1: h, y1: Math.min(e, s), x2: v, y2: Math.max(e, s) }, color: p }))) } return y.restore(), n && this._eventManager.ghostCtx.restore(), { source: y, dest: this.plotArea.ctx, animationCallback: r.fadeInAnimation, easingFunction: r.easing.easeInQuad, animationBase: 0 } } }; t.prototype.renderRangeBar = function(t) { var v = t.targetCanvasCtx || this.plotArea.ctx, ut = t.dataSeriesIndexes.length, w, it, h, y, rt, k; if (!(ut <= 0)) { var p = null, l = this.plotArea, i = 0, e, s, g, b, ft = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) << 0, d = this.dataPointMaxWidth ? this.dataPointMaxWidth : Math.min(this.height * .15, this.plotArea.height / t.plotType.totalDataSeries * .9) << 0, nt = t.axisX.dataInfo.minDiff, a = l.height / Math.abs(t.axisX.maximum - t.axisX.minimum) * Math.abs(nt) / t.plotType.totalDataSeries * .9 << 0; for (a > d ? a = d : nt === Infinity ? a = d / t.plotType.totalDataSeries * .9 : a < 1 && (a = 1), v.save(), n && this._eventManager.ghostCtx.save(), v.beginPath(), v.rect(l.x1, l.y1, l.width, l.height), v.clip(), n && (this._eventManager.ghostCtx.rect(l.x1, l.y1, l.width, l.height), this._eventManager.ghostCtx.clip()), w = 0; w < t.dataSeriesIndexes.length; w++) { var tt = t.dataSeriesIndexes[w], c = this.data[tt], f = c.dataPoints; if (f.length > 0) for (it = a > 5 && c.bevelEnabled ? !0 : !1, v.strokeStyle = "#4572A7 ", i = 0; i < f.length; i++)(b = f[i].getTime ? f[i].x.getTime() : f[i].x, b < t.axisX.dataInfo.viewPortMin || b > t.axisX.dataInfo.viewPortMax) || f[i].y !== null && f[i].y.length && typeof f[i].y[0] == "number" && typeof f[i].y[1] == "number" && (e = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y[0] - t.axisY.conversionParameters.minimum) + .5 << 0, s = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (f[i].y[1] - t.axisY.conversionParameters.minimum) + .5 << 0, g = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (b - t.axisX.conversionParameters.minimum) + .5 << 0, h = g - t.plotType.totalDataSeries * a / 2 + (t.previousDataSeriesCount + w) * a << 0, y = h + a << 0, e > s && (rt = e, e = s, s = rt), p = f[i].color ? f[i].color : c._colorSet[i % c._colorSet.length], o(v, e, h, s, y, p, 0, null, it, !1, !1, !1, c.fillOpacity), k = c.dataPointIds[i], this._eventManager.objectMap[k] = { id: k, objectType: "dataPoint", dataSeriesIndex: tt, dataPointIndex: i, x1: e, y1: h, x2: s, y2: y }, p = u(k), n && o(this._eventManager.ghostCtx, e, h, s, y, p, 0, null, !1, !1, !1, !1), (f[i].indexLabel || c.indexLabel || f[i].indexLabelFormatter || c.indexLabelFormatter) && (this._indexLabels.push({ chartType: "rangeBar", dataPoint: f[i], dataSeries: c, indexKeyword: 0, point: { x: f[i].y[1] >= f[i].y[0] ? e : s, y: h + (y - h) / 2 }, direction: f[i].y[1] >= f[i].y[0] ? -1 : 1, bounds: { x1: Math.min(e, s), y1: h, x2: Math.max(e, s), y2: y }, color: p }), this._indexLabels.push({ chartType: "rangeBar", dataPoint: f[i], dataSeries: c, indexKeyword: 1, point: { x: f[i].y[1] >= f[i].y[0] ? s : e, y: h + (y - h) / 2 }, direction: f[i].y[1] >= f[i].y[0] ? 1 : -1, bounds: { x1: Math.min(e, s), y1: h, x2: Math.max(e, s), y2: y }, color: p }))) } return v.restore(), n && this._eventManager.ghostCtx.restore(), { source: v, dest: this.plotArea.ctx, animationCallback: r.fadeInAnimation, easingFunction: r.easing.easeInQuad, animationBase: 0 } } }; t.prototype.renderRangeArea = function(t) { function ft() { var n, t; if (ut) { for (n = null, s.lineThickness > 0 && i.stroke(), t = v.length - 1; t >= 0; t--) n = v[t], i.lineTo(n.x, n.y), h.lineTo(n.x, n.y); if (i.closePath(), i.globalAlpha = s.fillOpacity, i.fill(), i.globalAlpha = 1, h.fill(), s.lineThickness > 0) { for (i.beginPath(), i.moveTo(n.x, n.y), t = 0; t < v.length; t++) n = v[t], i.lineTo(n.x, n.y); i.stroke() } i.beginPath(); i.moveTo(o, c); h.beginPath(); h.moveTo(o, c); ut = { x: o, y: c }; v = []; v.push({ x: o, y: w }) } } var i = t.targetCanvasCtx || this.plotArea.ctx, ht = t.dataSeriesIndexes.length, nt, ot, d, it, g, l, k; if (!(ht <= 0)) { var h = this._eventManager.ghostCtx, ct = t.axisX.lineCoordinates, lt = t.axisY.lineCoordinates, b = [], p = this.plotArea; for (i.save(), n && h.save(), i.beginPath(), i.rect(p.x1, p.y1, p.width, p.height), i.clip(), n && (h.beginPath(), h.rect(p.x1, p.y1, p.width, p.height), h.clip()), nt = 0; nt < t.dataSeriesIndexes.length; nt++) { var v = [], rt = t.dataSeriesIndexes[nt], s = this.data[rt], e = s.dataPoints, et = s.id; this._eventManager.objectMap[et] = { objectType: "dataSeries", dataSeriesIndex: rt }; ot = u(et); h.fillStyle = ot; b = []; var st = !0, f = 0, o, c, w, tt, at = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) + .5 << 0, ut = null; if (e.length > 0) { for (d = s._colorSet[f % s._colorSet.length], i.fillStyle = d, i.strokeStyle = d, i.lineWidth = s.lineThickness, i.setLineDash && i.setLineDash(y(s.lineDashType, s.lineThickness)), it = !0; f < e.length; f++) if (tt = e[f].x.getTime ? e[f].x.getTime() : e[f].x, !(tt < t.axisX.dataInfo.viewPortMin) && !(tt > t.axisX.dataInfo.viewPortMax)) { if (e[f].y === null || !e[f].y.length || typeof e[f].y[0] != "number" || typeof e[f].y[1] != "number") { ft(); it = !0; continue } o = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (tt - t.axisX.conversionParameters.minimum) + .5 << 0; c = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (e[f].y[0] - t.axisY.conversionParameters.minimum) + .5 << 0; w = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (e[f].y[1] - t.axisY.conversionParameters.minimum) + .5 << 0; st || it ? (i.beginPath(), i.moveTo(o, c), ut = { x: o, y: c }, v = [], v.push({ x: o, y: w }), n && (h.beginPath(), h.moveTo(o, c)), st = !1, it = !1) : (i.lineTo(o, c), v.push({ x: o, y: w }), n && h.lineTo(o, c), f % 250 == 0 && ft()); g = s.dataPointIds[f]; this._eventManager.objectMap[g] = { id: g, objectType: "dataPoint", dataSeriesIndex: rt, dataPointIndex: f, x1: o, y1: c, y2: w }; e[f].markerSize !== 0 && (e[f].markerSize > 0 || s.markerSize > 0) && (l = s.getMarkerProperties(f, o, w, i), b.push(l), k = u(g), n && b.push({ x: o, y: w, ctx: h, type: l.type, size: l.size, color: k, borderColor: k, borderThickness: l.borderThickness }), l = s.getMarkerProperties(f, o, c, i), b.push(l), k = u(g), n && b.push({ x: o, y: c, ctx: h, type: l.type, size: l.size, color: k, borderColor: k, borderThickness: l.borderThickness })); (e[f].indexLabel || s.indexLabel || e[f].indexLabelFormatter || s.indexLabelFormatter) && (this._indexLabels.push({ chartType: "rangeArea", dataPoint: e[f], dataSeries: s, indexKeyword: 0, point: { x: o, y: c }, direction: e[f].y[0] <= e[f].y[1] ? -1 : 1, color: d }), this._indexLabels.push({ chartType: "rangeArea", dataPoint: e[f], dataSeries: s, indexKeyword: 1, point: { x: o, y: w }, direction: e[f].y[0] <= e[f].y[1] ? 1 : -1, color: d })) } ft(); a.drawMarkers(b) } } return i.restore(), n && this._eventManager.ghostCtx.restore(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; t.prototype.renderRangeSplineArea = function(t) { function ft() { var t = kt(tt, 2), r; if (t.length > 0) { for (i.beginPath(), i.moveTo(t[0].x, t[0].y), n && (s.beginPath(), s.moveTo(t[0].x, t[0].y)), r = 0; r < t.length - 3; r += 3) i.bezierCurveTo(t[r + 1].x, t[r + 1].y, t[r + 2].x, t[r + 2].y, t[r + 3].x, t[r + 3].y), n && s.bezierCurveTo(t[r + 1].x, t[r + 1].y, t[r + 2].x, t[r + 2].y, t[r + 3].x, t[r + 3].y); for (o.lineThickness > 0 && i.stroke(), t = kt(h, 2), i.lineTo(h[h.length - 1].x, h[h.length - 1].y), r = t.length - 1; r > 2; r -= 3) i.bezierCurveTo(t[r - 1].x, t[r - 1].y, t[r - 2].x, t[r - 2].y, t[r - 3].x, t[r - 3].y), n && s.bezierCurveTo(t[r - 1].x, t[r - 1].y, t[r - 2].x, t[r - 2].y, t[r - 3].x, t[r - 3].y); if (i.closePath(), i.globalAlpha = o.fillOpacity, i.fill(), i.globalAlpha = 1, o.lineThickness > 0) { for (i.beginPath(), i.moveTo(h[h.length - 1].x, h[h.length - 1].y), r = t.length - 1; r > 2; r -= 3) i.bezierCurveTo(t[r - 1].x, t[r - 1].y, t[r - 2].x, t[r - 2].y, t[r - 3].x, t[r - 3].y), n && s.bezierCurveTo(t[r - 1].x, t[r - 1].y, t[r - 2].x, t[r - 2].y, t[r - 3].x, t[r - 3].y); i.stroke() } i.beginPath(); n && (s.closePath(), s.fill()) } } var i = t.targetCanvasCtx || this.plotArea.ctx, et = t.dataSeriesIndexes.length, g, ut, d, l, k; if (!(et <= 0)) { var s = this._eventManager.ghostCtx, ot = t.axisX.lineCoordinates, st = t.axisY.lineCoordinates, p = [], v = this.plotArea; for (i.save(), n && s.save(), i.beginPath(), i.rect(v.x1, v.y1, v.width, v.height), i.clip(), n && (s.beginPath(), s.rect(v.x1, v.y1, v.width, v.height), s.clip()), g = 0; g < t.dataSeriesIndexes.length; g++) { var it = t.dataSeriesIndexes[g], o = this.data[it], e = o.dataPoints, rt = o.id; this._eventManager.objectMap[rt] = { objectType: "dataSeries", dataSeriesIndex: it }; ut = u(rt); s.fillStyle = ut; p = []; var f = 0, c, w, b, nt, ht = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (0 - t.axisY.conversionParameters.minimum) + .5 << 0, tt = [], h = []; if (e.length > 0) { for (color = o._colorSet[f % o._colorSet.length], i.fillStyle = color, i.strokeStyle = color, i.lineWidth = o.lineThickness, i.setLineDash && i.setLineDash(y(o.lineDashType, o.lineThickness)); f < e.length; f++) if (nt = e[f].x.getTime ? e[f].x.getTime() : e[f].x, !(nt < t.axisX.dataInfo.viewPortMin) && !(nt > t.axisX.dataInfo.viewPortMax)) { if (e[f].y === null || !e[f].y.length || typeof e[f].y[0] != "number" || typeof e[f].y[1] != "number") { f > 0 && (ft(), tt = [], h = []); continue } c = t.axisX.conversionParameters.reference + t.axisX.conversionParameters.pixelPerUnit * (nt - t.axisX.conversionParameters.minimum) + .5 << 0; w = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (e[f].y[0] - t.axisY.conversionParameters.minimum) + .5 << 0; b = t.axisY.conversionParameters.reference + t.axisY.conversionParameters.pixelPerUnit * (e[f].y[1] - t.axisY.conversionParameters.minimum) + .5 << 0; d = o.dataPointIds[f]; this._eventManager.objectMap[d] = { id: d, objectType: "dataPoint", dataSeriesIndex: it, dataPointIndex: f, x1: c, y1: w, y2: b }; tt[tt.length] = { x: c, y: w }; h[h.length] = { x: c, y: b }; e[f].markerSize !== 0 && (e[f].markerSize > 0 || o.markerSize > 0) && (l = o.getMarkerProperties(f, c, w, i), p.push(l), k = u(d), n && p.push({ x: c, y: w, ctx: s, type: l.type, size: l.size, color: k, borderColor: k, borderThickness: l.borderThickness }), l = o.getMarkerProperties(f, c, b, i), p.push(l), k = u(d), n && p.push({ x: c, y: b, ctx: s, type: l.type, size: l.size, color: k, borderColor: k, borderThickness: l.borderThickness })); (e[f].indexLabel || o.indexLabel || e[f].indexLabelFormatter || o.indexLabelFormatter) && (this._indexLabels.push({ chartType: "splineArea", dataPoint: e[f], dataSeries: o, indexKeyword: 0, point: { x: c, y: w }, direction: e[f].y[0] <= e[f].y[1] ? -1 : 1, color: color }), this._indexLabels.push({ chartType: "splineArea", dataPoint: e[f], dataSeries: o, indexKeyword: 1, point: { x: c, y: b }, direction: e[f].y[0] <= e[f].y[1] ? 1 : -1, color: color })) } ft(); a.drawMarkers(p) } } return i.restore(), n && this._eventManager.ghostCtx.restore(), { source: i, dest: this.plotArea.ctx, animationCallback: r.xClipAnimation, easingFunction: r.easing.linear, animationBase: 0 } } }; dt = function(t, i, r, u, f, e, o, s) { var h, c, l; typeof s == "undefined" && (s = 1); n || (h = Number((o % (2 * Math.PI)).toFixed(8)), c = Number((e % (2 * Math.PI)).toFixed(8)), c === h && (o -= .0001)); t.save(); t.globalAlpha = s; f === "pie" ? (t.beginPath(), t.moveTo(i.x, i.y), t.arc(i.x, i.y, r, e, o, !1), t.fillStyle = u, t.strokeStyle = "white", t.lineWidth = 2, t.closePath(), t.fill()) : f === "doughnut" && (l = .6, t.beginPath(), t.arc(i.x, i.y, r, e, o, !1), t.arc(i.x, i.y, l * r, o, e, !0), t.closePath(), t.fillStyle = u, t.strokeStyle = "white", t.lineWidth = 2, t.fill()); t.globalAlpha = 1; t.restore() }; t.prototype.renderPie = function(n) { function et() { var w, b, tt, a, n; if (i && e) { var y = 0, p = 0, d = 0, g = 0; for (o = 0; o < e.length; o++) { var h = e[o], nt = i.dataPointIds[o], n = { id: nt, objectType: "dataPoint", dataPointIndex: o, dataSeriesIndex: 0 }; t.push(n); w = { percent: null, total: null }; b = null; w = r.getPercentAndTotal(i, h); (i.indexLabelFormatter || h.indexLabelFormatter) && (b = { chart: r._options, dataSeries: i, dataPoint: h, total: w.total, percent: w.percent }); tt = h.indexLabelFormatter ? h.indexLabelFormatter(b) : h.indexLabel ? r.replaceKeywordsWithValue(h.indexLabel, h, i, o) : i.indexLabelFormatter ? i.indexLabelFormatter(b) : i.indexLabel ? r.replaceKeywordsWithValue(i.indexLabel, h, i, o) : h.label ? h.label : ""; r._eventManager.objectMap[nt] = n; n.center = { x: u.x, y: u.y }; n.y = h.y; n.radius = s; n.indexLabelText = tt; n.indexLabelPlacement = i.indexLabelPlacement; n.indexLabelLineColor = h.indexLabelLineColor ? h.indexLabelLineColor : i.indexLabelLineColor ? i.indexLabelLineColor : h.color ? h.color : i._colorSet[o % i._colorSet.length]; n.indexLabelLineThickness = h.indexLabelLineThickness ? h.indexLabelLineThickness : i.indexLabelLineThickness; n.indexLabelLineDashType = h.indexLabelLineDashType ? h.indexLabelLineDashType : i.indexLabelLineDashType; n.indexLabelFontColor = h.indexLabelFontColor ? h.indexLabelFontColor : i.indexLabelFontColor; n.indexLabelFontStyle = h.indexLabelFontStyle ? h.indexLabelFontStyle : i.indexLabelFontStyle; n.indexLabelFontWeight = h.indexLabelFontWeight ? h.indexLabelFontWeight : i.indexLabelFontWeight; n.indexLabelFontSize = h.indexLabelFontSize ? h.indexLabelFontSize : i.indexLabelFontSize; n.indexLabelFontFamily = h.indexLabelFontFamily ? h.indexLabelFontFamily : i.indexLabelFontFamily; n.indexLabelBackgroundColor = h.indexLabelBackgroundColor ? h.indexLabelBackgroundColor : i.indexLabelBackgroundColor ? i.indexLabelBackgroundColor : null; n.indexLabelMaxWidth = h.indexLabelMaxWidth ? h.indexLabelMaxWidth : i.indexLabelMaxWidth ? i.indexLabelMaxWidth : f.width * .33; n.indexLabelWrap = typeof h.indexLabelWrap != "undefined" ? h.indexLabelWrap : i.indexLabelWrap; n.startAngle = o === 0 ? i.startAngle ? i.startAngle / 180 * Math.PI : 0 : t[o - 1].endAngle; n.startAngle = (n.startAngle + 2 * Math.PI) % (2 * Math.PI); n.endAngle = n.startAngle + 2 * Math.PI / k * Math.abs(h.y); a = (n.endAngle + n.startAngle) / 2; a = (a + 2 * Math.PI) % (2 * Math.PI); n.midAngle = a; n.midAngle > Math.PI / 2 - l && n.midAngle < Math.PI / 2 + l ? ((y === 0 || t[d].midAngle > n.midAngle) && (d = o), y++) : n.midAngle > 3 * Math.PI / 2 - l && n.midAngle < 3 * Math.PI / 2 + l && ((p === 0 || t[g].midAngle > n.midAngle) && (g = o), p++); n.hemisphere = a > Math.PI / 2 && a <= 3 * Math.PI / 2 ? "left" : "right"; n.indexLabelTextBlock = new c(r.plotArea.ctx, { fontSize: n.indexLabelFontSize, fontFamily: n.indexLabelFontFamily, fontColor: n.indexLabelFontColor, fontStyle: n.indexLabelFontStyle, fontWeight: n.indexLabelFontWeight, horizontalAlign: "left", backgroundColor: n.indexLabelBackgroundColor, maxWidth: n.indexLabelMaxWidth, maxHeight: n.indexLabelWrap ? n.indexLabelFontSize * 5 : n.indexLabelFontSize * 1.5, text: n.indexLabelText, padding: 0, textBaseline: "top" }); n.indexLabelTextBlock.measureText() } var it = 0, rt = 0, v = !1; for (o = 0; o < e.length; o++) n = t[(d + o) % e.length], y > 1 && n.midAngle > Math.PI / 2 - l && n.midAngle < Math.PI / 2 + l && (it <= y / 2 && !v ? (n.hemisphere = "right", it++) : (n.hemisphere = "left", v = !0)); for (v = !1, o = 0; o < e.length; o++) n = t[(g + o) % e.length], p > 1 && n.midAngle > 3 * Math.PI / 2 - l && n.midAngle < 3 * Math.PI / 2 + l && (rt <= p / 2 && !v ? (n.hemisphere = "left", rt++) : (n.hemisphere = "right", v = !0)) } } function ot() { var u = r.plotArea.ctx, l, f, a, n, o, h, c; for (u.fillStyle = "black", u.strokeStyle = "grey", l = 16, u.textBaseline = "middle", u.lineJoin = "round", f = 0, a = 0, f = 0; f < e.length; f++)(n = t[f], n.indexLabelText) && (n.indexLabelTextBlock.y -= n.indexLabelTextBlock.height / 2, o = 0, o = n.hemisphere === "left" ? i.indexLabelPlacement !== "inside" ? -(n.indexLabelTextBlock.width + v) : -n.indexLabelTextBlock.width / 2 : i.indexLabelPlacement !== "inside" ? v : -n.indexLabelTextBlock.width / 2, n.indexLabelTextBlock.x += o, n.indexLabelTextBlock.render(!0), n.indexLabelTextBlock.x -= o, n.indexLabelTextBlock.y += n.indexLabelTextBlock.height / 2, n.indexLabelPlacement !== "inside" && (h = n.center.x + s * Math.cos(n.midAngle), c = n.center.y + s * Math.sin(n.midAngle), u.strokeStyle = n.indexLabelLineColor, u.lineWidth = n.indexLabelLineThickness, u.setLineDash && u.setLineDash(y(n.indexLabelLineDashType, n.indexLabelLineThickness)), u.beginPath(), u.moveTo(h, c), u.lineTo(n.indexLabelTextBlock.x, n.indexLabelTextBlock.y), u.lineTo(n.indexLabelTextBlock.x + (n.hemisphere === "left" ? -v : v), n.indexLabelTextBlock.y), u.stroke()), u.lineJoin = "miter") } function st(n) { var s = r.plotArea.ctx, h, u, a; for (s.clearRect(f.x1, f.y1, f.width, f.height), s.fillStyle = r.backgroundColor, s.fillRect(f.x1, f.y1, f.width, f.height), h = t[0].startAngle + 2 * Math.PI * n, u = 0; u < e.length; u++) { var c = u === 0 ? t[u].startAngle : o, o = c + (t[u].endAngle - t[u].startAngle), l = !1; if (o > h && (o = h, l = !0), a = e[u].color ? e[u].color : i._colorSet[u % i._colorSet.length], o > c && dt(r.plotArea.ctx, t[u].center, t[u].radius, a, i.type, c, o, i.fillOpacity), l) break } } function rt(n) { var c = r.plotArea.ctx, o, l, a, h, w; for (c.clearRect(f.x1, f.y1, f.width, f.height), c.fillStyle = r.backgroundColor, c.fillRect(f.x1, f.y1, f.width, f.height), o = 0; o < e.length; o++) if (l = t[o].startAngle, a = t[o].endAngle, a > l) { var v = s * .07 * Math.cos(t[o].midAngle), y = s * .07 * Math.sin(t[o].midAngle), p = !1; e[o].exploded ? (Math.abs(t[o].center.x - (u.x + v)) > 1e-9 || Math.abs(t[o].center.y - (u.y + y)) > 1e-9) && (t[o].center.x = u.x + v * n, t[o].center.y = u.y + y * n, p = !0) : (Math.abs(t[o].center.x - u.x) > 0 || Math.abs(t[o].center.y - u.y) > 0) && (t[o].center.x = u.x + v * (1 - n), t[o].center.y = u.y + y * (1 - n), p = !0); p && (h = {}, h.dataSeries = i, h.dataPoint = i.dataPoints[o], h.index = o, r._toolTip.highlightObjects([h])); w = e[o].color ? e[o].color : i._colorSet[o % i._colorSet.length]; dt(r.plotArea.ctx, t[o].center, t[o].radius, w, i.type, l, a, i.fillOpacity) } ot() } function ht(n, t) { var i = { x1: n.indexLabelTextBlock.x, y1: n.indexLabelTextBlock.y - n.indexLabelTextBlock.height / 2, x2: n.indexLabelTextBlock.x + n.indexLabelTextBlock.width, y2: n.indexLabelTextBlock.y + n.indexLabelTextBlock.height / 2 }, r = { x1: t.indexLabelTextBlock.x, y1: t.indexLabelTextBlock.y - t.indexLabelTextBlock.height / 2, x2: t.indexLabelTextBlock.x + t.indexLabelTextBlock.width, y2: t.indexLabelTextBlock.y + t.indexLabelTextBlock.height / 2 }; return i.x2 < r.x1 - v || i.x1 > r.x2 + v || i.y1 > r.y2 + v || i.y2 < r.y1 - v ? !1 : !0 } function b(n, t) { var i = { y: n.indexLabelTextBlock.y, y1: n.indexLabelTextBlock.y - n.indexLabelTextBlock.height / 2, y2: n.indexLabelTextBlock.y + n.indexLabelTextBlock.height / 2 }, r = { y: t.indexLabelTextBlock.y, y1: t.indexLabelTextBlock.y - t.indexLabelTextBlock.height / 2, y2: t.indexLabelTextBlock.y + t.indexLabelTextBlock.height / 2 }; return r.y > i.y ? r.y1 - i.y2 : i.y1 - r.y2 } function d(n) { for (var i = null, r = 1; r < e.length; r++) if (i = (n + r + t.length) % t.length, t[i].hemisphere !== t[n].hemisphere) { i = null; break } else if (t[i].indexLabelText && i !== n && (b(t[i], t[n]) < 0 || (t[n].hemisphere === "right" ? t[i].indexLabelTextBlock.y >= t[n].indexLabelTextBlock.y : t[i].indexLabelTextBlock.y <= t[n].indexLabelTextBlock.y))) break; else i = null; return i } function ct(n) { for (var i = null, r = 1; r < e.length; r++) if (i = (n - r + t.length) % t.length, t[i].hemisphere !== t[n].hemisphere) { i = null; break } else if (t[i].indexLabelText && t[i].hemisphere === t[n].hemisphere && i !== n && (b(t[i], t[n]) < 0 || (t[n].hemisphere === "right" ? t[i].indexLabelTextBlock.y <= t[n].indexLabelTextBlock.y : t[i].indexLabelTextBlock.y >= t[n].indexLabelTextBlock.y))) break; else i = null; return i } function p(n, i) { var r, ut, st, b, v, ft, o; i = i || 0; var k = 0, rt = u.y - h * 1, et = u.y + h * 1; if (n >= 0 && n < e.length) { if (r = t[n], i < 0 && r.indexLabelTextBlock.y < rt || i > 0 && r.indexLabelTextBlock.y > et) return 0; var f = i, ot = 0, ht = 0, lt = 0, at = 0, vt = 0; f < 0 ? r.indexLabelTextBlock.y - r.indexLabelTextBlock.height / 2 > rt && r.indexLabelTextBlock.y - r.indexLabelTextBlock.height / 2 + f < rt && (f = -(rt - (r.indexLabelTextBlock.y - r.indexLabelTextBlock.height / 2 + f))) : r.indexLabelTextBlock.y + r.indexLabelTextBlock.height / 2 < rt && r.indexLabelTextBlock.y + r.indexLabelTextBlock.height / 2 + f > et && (f = r.indexLabelTextBlock.y + r.indexLabelTextBlock.height / 2 + f - et); ut = r.indexLabelTextBlock.y + f; st = 0; st = r.hemisphere === "right" ? u.x + Math.sqrt(Math.pow(h, 2) - Math.pow(ut - u.y, 2)) : u.x - Math.sqrt(Math.pow(h, 2) - Math.pow(ut - u.y, 2)); ht = u.x + s * Math.cos(r.midAngle); lt = u.y + s * Math.sin(r.midAngle); ot = Math.sqrt(Math.pow(st - ht, 2) + Math.pow(ut - lt, 2)); vt = Math.acos(s / h); at = Math.acos((h * h + s * s - ot * ot) / (2 * s * h)); f = at < vt ? ut - r.indexLabelTextBlock.y : 0; var yt = ct(n), pt = d(n), c, v, y = 0, g = 0; if (f < 0 ? (c = r.hemisphere === "right" ? yt : pt, k = f, c !== null && (b = -f, v = r.indexLabelTextBlock.y - r.indexLabelTextBlock.height / 2 - (t[c].indexLabelTextBlock.y + t[c].indexLabelTextBlock.height / 2), v - b < w && (y = -b, tt++, g = p(c, y), +g.toFixed(a) > +y.toFixed(a) && (k = v > w ? -(v - w) : -(b - (g - y)))))) : f > 0 && (c = r.hemisphere === "right" ? pt : yt, k = f, c !== null && (b = f, v = t[c].indexLabelTextBlock.y - t[c].indexLabelTextBlock.height / 2 - (r.indexLabelTextBlock.y + r.indexLabelTextBlock.height / 2), v - b < w && (y = b, tt++, g = p(c, y), +g.toFixed(a) < +y.toFixed(a) && (k = v > w ? v - w : b - (y - g))))), k) { if (ft = r.indexLabelTextBlock.y + k, o = 0, o = r.hemisphere === "right" ? u.x + Math.sqrt(Math.pow(h, 2) - Math.pow(ft - u.y, 2)) : u.x - Math.sqrt(Math.pow(h, 2) - Math.pow(ft - u.y, 2)), r.midAngle > Math.PI / 2 - l && r.midAngle < Math.PI / 2 + l) { var wt = (n - 1 + t.length) % t.length, nt = t[wt], it = t[(n + 1 + t.length) % t.length]; r.hemisphere === "left" && nt.hemisphere === "right" && o > nt.indexLabelTextBlock.x ? o = nt.indexLabelTextBlock.x - 15 : r.hemisphere === "right" && it.hemisphere === "left" && o < it.indexLabelTextBlock.x && (o = it.indexLabelTextBlock.x + 15) } else if (r.midAngle > 3 * Math.PI / 2 - l && r.midAngle < 3 * Math.PI / 2 + l) { var wt = (n - 1 + t.length) % t.length, nt = t[wt], it = t[(n + 1 + t.length) % t.length]; r.hemisphere === "right" && nt.hemisphere === "left" && o < nt.indexLabelTextBlock.x ? o = nt.indexLabelTextBlock.x + 15 : r.hemisphere === "left" && it.hemisphere === "right" && o > it.indexLabelTextBlock.x && (o = it.indexLabelTextBlock.x - 15) } r.indexLabelTextBlock.y = ft; r.indexLabelTextBlock.x = o; r.indexLabelAngle = Math.atan2(r.indexLabelTextBlock.y - u.y, r.indexLabelTextBlock.x - u.x) } } return k } function lt() { var yt = r.plotArea.ctx, gt, tt, rt, l, kt, wt, n, ni, ti, dt, et, g, ot, nt, c, vt, lt; yt.fillStyle = "grey"; yt.strokeStyle = "grey"; gt = 16; yt.font = gt + "px Arial"; yt.textBaseline = "middle"; for (var o = 0, pt = 0, k = 0, pt = 0; pt < 10 && (pt < 1 || k > 0); pt++) { if (s -= k, k = 0, i.indexLabelPlacement !== "inside") { for (h = s * it, o = 0; o < e.length; o++) n = t[o], n.indexLabelTextBlock.x = u.x + h * Math.cos(n.midAngle), n.indexLabelTextBlock.y = u.y + h * Math.sin(n.midAngle), n.indexLabelAngle = n.midAngle, n.radius = s; for (o = 0; o < e.length; o++) if ((n = t[o], rt = d(o), rt !== null) && (tt = t[o], lt = t[rt], l = 0, l = b(tt, lt) - w, l < 0)) { for (kt = 0, wt = 0, c = 0; c < e.length; c++) c !== o && t[c].hemisphere === n.hemisphere && (t[c].indexLabelTextBlock.y < n.indexLabelTextBlock.y ? kt++ : wt++); var at = l / (kt + wt || 1) * wt, y = -1 * (l - at), ut = 0, ft = 0; n.hemisphere === "right" ? (ut = p(o, at), y = -1 * (l - ut), ft = p(rt, y), +ft.toFixed(a) < +y.toFixed(a) && +ut.toFixed(a) <= +at.toFixed(a) && p(o, -(y - ft))) : (ut = p(rt, at), y = -1 * (l - ut), ft = p(o, y), +ft.toFixed(a) < +y.toFixed(a) && +ut.toFixed(a) <= +at.toFixed(a) && p(rt, -(y - ft))) } } else for (o = 0; o < e.length; o++) n = t[o], h = i.type === "pie" ? s * .7 : s * .8, ni = u.x + h * Math.cos(n.midAngle), ti = u.y + h * Math.sin(n.midAngle), n.indexLabelTextBlock.x = ni, n.indexLabelTextBlock.y = ti; for (o = 0; o < e.length; o++)(n = t[o], dt = n.indexLabelTextBlock.measureText(), dt.height !== 0 && dt.width !== 0) && (et = 0, g = 0, et = n.hemisphere === "right" ? (f.x2 - (n.indexLabelTextBlock.x + n.indexLabelTextBlock.width + v)) * -1 : f.x1 - (n.indexLabelTextBlock.x - n.indexLabelTextBlock.width - v), et > 0 && (Math.abs(n.indexLabelTextBlock.y - n.indexLabelTextBlock.height / 2 - u.y) < s || Math.abs(n.indexLabelTextBlock.y + n.indexLabelTextBlock.height / 2 - u.y) < s) && (g = et / Math.abs(Math.cos(n.indexLabelAngle)), g > 9 && (g = g * .3), g > k && (k = g)), ot = 0, nt = 0, ot = n.indexLabelAngle > 0 && n.indexLabelAngle < Math.PI ? (f.y2 - (n.indexLabelTextBlock.y + n.indexLabelTextBlock.height / 2 + 5)) * -1 : f.y1 - (n.indexLabelTextBlock.y - n.indexLabelTextBlock.height / 2 - 5), ot > 0 && Math.abs(n.indexLabelTextBlock.x - u.x) < s && (nt = ot / Math.abs(Math.sin(n.indexLabelAngle)), nt > 9 && (nt = nt * .3), nt > k && (k = nt))); function r(n, i, r) { for (var f, o = [], s = 0, u = i;; u = (u + 1 + e.length) % e.length) if (o.push(t[u]), u === r) break; for (o.sort(function(n, t) { return n.y - t.y }), u = 0; u < o.length; u++) if (f = o[u], s < n) s += f.indexLabelTextBlock.height, f.indexLabelTextBlock.text = "", f.indexLabelText = "", f.indexLabelTextBlock.measureText(); else break } var st = -1, bt = -1, ct = 0; for (c = 0; c < e.length; c++)(tt = t[c], tt.indexLabelText) && (vt = d(c), vt !== null) && (lt = t[vt], l = 0, l = b(tt, lt), l < 0 && ht(tt, lt) ? (st < 0 && (st = c), vt !== st && (bt = vt), ct += -l) : ct > 0 && (r(ct, st, bt), st = -1, bt = -1, ct = 0)); ct > 0 && r(ct, st, bt) } } function g() { var t, n; if (r.plotArea.layoutManager.reset(), r._title && (r._title.dockInsidePlotArea || r._title.horizontalAlign === "center" && r._title.verticalAlign === "center") && r._title.render(), r.subtitles) for (t = 0; t < r.subtitles.length; t++) n = r.subtitles[t], (n.dockInsidePlotArea || n.horizontalAlign === "center" && n.verticalAlign === "center") && n.render(); r.legend && (r.legend.dockInsidePlotArea || r.legend.horizontalAlign === "center" && r.legend.verticalAlign === "center") && r.legend.render() } var r = this, ut = n.dataSeriesIndexes.length, o; if (!(ut <= 0)) { var ft = n.dataSeriesIndexes[0], i = this.data[ft], e = i.dataPoints, v = 10, nt = 500, f = this.plotArea, tt = 0, t = [], w = 2, it = 1.3, l = 20 / 180 * Math.PI, a = 6, u = { x: (f.x2 + f.x1) / 2, y: (f.y2 + f.y1) / 2 }, s = i.indexLabelPlacement === "inside" ? Math.min(f.width, f.height) * .92 / 2 : Math.min(f.width, f.height) * .8 / 2, at = s * .6, h = s * it, vt = s, k = 0; for (o = 0; o < e.length; o++) k += Math.abs(e[o].y); k !== 0 && (this.pieDoughnutClickHandler = function(n) { if (!r.isAnimating) { var u = n.dataPointIndex, t = n.dataPoint, i = this, f = i.dataPointIds[u]; t.exploded = t.exploded ? !1 : !0; i.dataPoints.length > 1 && r._animator.animate(0, nt, function(n) { rt(n); g() }); return } }, et(), lt(), this.disableToolTip = !0, this._animator.animate(0, this.animatedRender ? this.animationDuration : 0, function(n) { st(n); g() }, function() { r.disableToolTip = !1; r._animator.animate(0, r.animatedRender ? nt : 0, function(n) { rt(n); g() }) })) } }; t.prototype.animationRequestId = null; t.prototype.requestAnimFrame = function() { return window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function(n) { window.setTimeout(n, 1e3 / 60) } }(); t.prototype.cancelRequestAnimFrame = function() { return window.cancelAnimationFrame || window.webkitCancelRequestAnimationFrame || window.mozCancelRequestAnimationFrame || window.oCancelRequestAnimationFrame || window.msCancelRequestAnimationFrame || clearTimeout }(); ft.prototype.registerSpace = function(n, t) { n === "top" ? this._topOccupied += t.height : n === "bottom" ? this._bottomOccupied += t.height : n === "left" ? this._leftOccupied += t.width : n === "right" && (this._rightOccupied += t.width) }; ft.prototype.unRegisterSpace = function(n, t) { n === "top" ? this._topOccupied -= t.height : n === "bottom" ? this._bottomOccupied -= t.height : n === "left" ? this._leftOccupied -= t.width : n === "right" && (this._rightOccupied -= t.width) }; ft.prototype.getFreeSpace = function() { return { x1: this._x1 + this._leftOccupied, y1: this._y1 + this._topOccupied, x2: this._x2 - this._rightOccupied, y2: this._y2 - this._bottomOccupied, width: this._x2 - this._x1 - this._rightOccupied - this._leftOccupied, height: this._y2 - this._y1 - this._bottomOccupied - this._topOccupied } }; ft.prototype.reset = function() { this._topOccupied = this._padding; this._bottomOccupied = this._padding; this._leftOccupied = this._padding; this._rightOccupied = this._padding }; w(c, h); c.prototype.render = function(n) { var f, i, u; n && this.ctx.save(); f = this.ctx.font; this.ctx.textBaseline = this.textBaseline; i = 0; this._isDirty && this.measureText(this.ctx); this.ctx.translate(this.x, this.y + i); this.textBaseline === "middle" && (i = -this._lineHeight / 2); this.ctx.font = this._getFontString(); this.ctx.rotate(Math.PI / 180 * this.angle); var r = 0, e = this.padding, t = null; for ((this.borderThickness > 0 && this.borderColor || this.backgroundColor) && this.ctx.roundRect(0, i, this.width, this.height, this.cornerRadius, this.borderThickness, this.backgroundColor, this.borderColor), this.ctx.fillStyle = this.fontColor, u = 0; u < this._wrappedText.lines.length; u++) t = this._wrappedText.lines[u], this.horizontalAlign === "right" ? r = this.width - t.width - this.padding : this.horizontalAlign === "left" ? r = this.padding : this.horizontalAlign === "center" && (r = (this.width - this.padding * 2) / 2 - t.width / 2 + this.padding), this.ctx.fillText(t.text, r, e), e += t.height; this.ctx.font = f; n && this.ctx.restore() }; c.prototype.setText = function(n) { this.text = n; this._isDirty = !0; this._wrappedText = null }; c.prototype.measureText = function() { if (this.maxWidth === null) throw "Please set maxWidth and height for TextBlock"; return this._wrapText(this.ctx), this._isDirty = !1, { width: this.width, height: this.height } }; c.prototype._getLineWithWidth = function(n, t, i) { var r, h, e; if (n = String(n), i = i || !1, !n) return { text: "", width: 0 }; var u = 0, o = 0, s = n.length - 1, f = Infinity; for (this.ctx.font = this._getFontString(); o <= s;) if (f = Math.floor((o + s) / 2), r = n.substr(0, f + 1), u = this.ctx.measureText(r).width, u < t) o = f + 1; else if (u > t) s = f - 1; else break; return u > t && r.length > 1 && (r = r.substr(0, r.length - 1), u = this.ctx.measureText(r).width), h = !0, (r.length === n.length || n[r.length] === " ") && (h = !1), h && (e = r.split(" "), e.length > 1 && e.pop(), r = e.join(" "), u = this.ctx.measureText(r).width), { text: r, width: u } }; c.prototype._wrapText = function() { var t = new String(ht(String(this.text))), u = [], e = this.ctx.font, i = 0, r = 0, n; for (this.ctx.font = this._getFontString(); t.length > 0;) { var o = this.maxWidth - this.padding * 2, f = this.maxHeight - this.padding * 2, n = this._getLineWithWidth(t, o, !1); n.height = this._lineHeight; u.push(n); r = Math.max(r, n.width); i += n.height; t = ht(t.slice(n.text.length, t.length)); f && i > f && (n = u.pop(), i -= n.height) } this._wrappedText = { lines: u, width: r, height: i }; this.width = r + this.padding * 2; this.height = i + this.padding * 2; this.ctx.font = e }; c.prototype._getFontString = function() { return gi("", this, null) }; w(lt, h); lt.prototype.render = function() { var e, i; if (this.text) { var o = this.dockInsidePlotArea ? this.chart.plotArea : this.chart, n = o.layoutManager.getFreeSpace(), u = n.x1, f = n.y1, h = 0, s = 0, t = 2, a = this.chart._menuButton && this.chart.exportEnabled && this.verticalAlign === "top" ? 22 : 0, l, r; this.verticalAlign === "top" || this.verticalAlign === "bottom" ? (this.maxWidth === null && (this.maxWidth = n.width - t * 2 - a * (this.horizontalAlign === "center" ? 2 : 1)), s = n.height * .5 - this.margin - t, h = 0) : this.verticalAlign === "center" && (this.horizontalAlign === "left" || this.horizontalAlign === "right" ? (this.maxWidth === null && (this.maxWidth = n.height - t * 2), s = n.width * .5 - this.margin - t) : this.horizontalAlign === "center" && (this.maxWidth === null && (this.maxWidth = n.width - t * 2), s = n.height * .5 - t * 2)); this.wrap || (s = Math.min(s, Math.max(this.fontSize * 1.5, this.fontSize + this.padding * 2.5))); e = new c(this.ctx, { fontSize: this.fontSize, fontFamily: this.fontFamily, fontColor: this.fontColor, fontStyle: this.fontStyle, fontWeight: this.fontWeight, horizontalAlign: this.horizontalAlign, verticalAlign: this.verticalAlign, borderColor: this.borderColor, borderThickness: this.borderThickness, backgroundColor: this.backgroundColor, maxWidth: this.maxWidth, maxHeight: s, cornerRadius: this.cornerRadius, text: this.text, padding: this.padding, textBaseline: "top" }); i = e.measureText(); this.verticalAlign === "top" || this.verticalAlign === "bottom" ? (this.verticalAlign === "top" ? (f = n.y1 + t, r = "top") : this.verticalAlign === "bottom" && (f = n.y2 - t - i.height, r = "bottom"), this.horizontalAlign === "left" ? u = n.x1 + t : this.horizontalAlign === "center" ? u = n.x1 + n.width / 2 - i.width / 2 : this.horizontalAlign === "right" && (u = n.x2 - t - i.width - a), l = this.horizontalAlign, this.width = i.width, this.height = i.height) : this.verticalAlign === "center" && (this.horizontalAlign === "left" ? (u = n.x1 + t, f = n.y2 - t - (this.maxWidth / 2 - i.width / 2), h = -90, r = "left", this.width = i.height, this.height = i.width) : this.horizontalAlign === "right" ? (u = n.x2 - t, f = n.y1 + t + (this.maxWidth / 2 - i.width / 2), h = 90, r = "right", this.width = i.height, this.height = i.width) : this.horizontalAlign === "center" && (f = o.y1 + (o.height / 2 - i.height / 2), u = o.x1 + (o.width / 2 - i.width / 2), r = "center", this.width = i.width, this.height = i.height), l = "center"); e.x = u; e.y = f; e.angle = h; e.horizontalAlign = l; e.render(!0); o.layoutManager.registerSpace(r, { width: this.width + (r === "left" || r === "right" ? this.margin + t : 0), height: this.height + (r === "top" || r === "bottom" ? this.margin + t : 0) }); this.bounds = { x1: u, y1: f, x2: u + this.width, y2: f + this.height }; this.ctx.textBaseline = "top" } }; w(gt, h); gt.prototype.render = lt.prototype.render; w(ni, h); ni.prototype.render = function() { var ot = this.dockInsidePlotArea ? this.chart.plotArea : this.chart, f = ot.layoutManager.getFreeSpace(), ft = null, w = 0, b = 0, s = 0, h = 0, y = [], k = [], t, p, n, it, e, r, v, nt, at; for (this.verticalAlign === "top" || this.verticalAlign === "bottom" ? (this.orientation = "horizontal", ft = this.verticalAlign, s = this.maxWidth !== null ? this.maxWidth : f.width * .7, h = this.maxHeight !== null ? this.maxHeight : f.height * .5) : this.verticalAlign === "center" && (this.orientation = "vertical", ft = this.horizontalAlign, s = this.maxWidth !== null ? this.maxWidth : f.width * .5, h = this.maxHeight !== null ? this.maxHeight : f.height * .7), e = 0; e < this.dataSeries.length; e++) { if (t = this.dataSeries[e], t.type !== "pie" && t.type !== "doughnut" && t.type !== "funnel") { var st = t.legendMarkerType ? t.legendMarkerType : (t.type === "line" || t.type === "stepLine" || t.type === "spline" || t.type === "scatter" || t.type === "bubble") && t.markerType ? t.markerType : d.getDefaultLegendMarker(t.type), g = t.legendText ? t.legendText : this.itemTextFormatter ? this.itemTextFormatter({ chart: this.chart, legend: this._options, dataSeries: t, dataPoint: null }) : t.name, ht = t.legendMarkerColor ? t.legendMarkerColor : t.markerColor ? t.markerColor : t._colorSet[0], o = !t.markerSize && (t.type === "line" || t.type === "stepLine" || t.type === "spline") ? 0 : this.lineHeight * .6, ct = t.legendMarkerBorderColor ? t.legendMarkerBorderColor : t.markerBorderColor, lt = t.legendMarkerBorderThickness ? t.legendMarkerBorderThickness : t.markerBorderThickness ? Math.max(1, Math.round(o * .2)) : 0, vt = t._colorSet[0]; g = this.chart.replaceKeywordsWithValue(g, t.dataPoints[0], t, e); n = { markerType: st, markerColor: ht, text: g, textBlock: null, chartType: t.type, markerSize: o, lineColor: t._colorSet[0], dataSeriesIndex: t.index, dataPointIndex: null, markerBorderColor: ct, markerBorderThickness: lt }; y.push(n) } else for (p = 0; p < t.dataPoints.length; p++) { var i = t.dataPoints[p], st = i.legendMarkerType ? i.legendMarkerType : t.legendMarkerType ? t.legendMarkerType : d.getDefaultLegendMarker(t.type), g = i.legendText ? i.legendText : t.legendText ? t.legendText : this.itemTextFormatter ? this.itemTextFormatter({ chart: this.chart, legend: this._options, dataSeries: t, dataPoint: i }) : i.name ? i.name : "DataPoint: " + (p + 1), ht = i.legendMarkerColor ? i.legendMarkerColor : t.legendMarkerColor ? t.legendMarkerColor : i.color ? i.color : t.color ? t.color : t._colorSet[p % t._colorSet.length], o = this.lineHeight * .6, ct = i.legendMarkerBorderColor ? i.legendMarkerBorderColor : t.legendMarkerBorderColor ? t.legendMarkerBorderColor : i.markerBorderColor ? i.markerBorderColor : t.markerBorderColor, lt = i.legendMarkerBorderThickness ? i.legendMarkerBorderThickness : t.legendMarkerBorderThickness ? t.legendMarkerBorderThickness : i.markerBorderThickness || t.markerBorderThickness ? Math.max(1, Math.round(o * .2)) : 0; g = this.chart.replaceKeywordsWithValue(g, i, t, p); n = { markerType: st, markerColor: ht, text: g, textBlock: null, chartType: t.type, markerSize: o, dataSeriesIndex: e, dataPointIndex: p, markerBorderColor: ct, markerBorderThickness: lt }; (i.showInLegend || t.showInLegend && i.showInLegend !== !1) && y.push(n) } n = null } if (this.reversed === !0 && y.reverse(), y.length > 0) { var r = null, et = 0, l = 0, v = 0; for (l = this.itemWidth !== null ? this.itemMaxWidth !== null ? Math.min(this.itemWidth, this.itemMaxWidth, s) : Math.min(this.itemWidth, s) : this.itemMaxWidth !== null ? Math.min(this.itemMaxWidth, s) : s, o = o === 0 ? this.lineHeight * .6 : o, l = l - (o + this.horizontalSpacing * .1), e = 0; e < y.length; e++)(n = y[e], (n.chartType === "line" || n.chartType === "spline" || n.chartType === "stepLine") && (l = l - 2 * this.lineHeight * .1), h <= 0 || typeof h == "undefined" || l <= 0 || typeof l == "undefined") || (this.orientation === "horizontal" ? (n.textBlock = new c(this.ctx, { x: 0, y: 0, maxWidth: l, maxHeight: this.itemWrap ? h : this.lineHeight, angle: 0, text: n.text, horizontalAlign: "left", fontSize: this.fontSize, fontFamily: this.fontFamily, fontWeight: this.fontWeight, fontColor: this.fontColor, fontStyle: this.fontStyle, textBaseline: "top" }), n.textBlock.measureText(), this.itemWidth !== null && (n.textBlock.width = this.itemWidth - (o + this.horizontalSpacing * .1 + (n.chartType === "line" || n.chartType === "spline" || n.chartType === "stepLine" ? 2 * this.lineHeight * .1 : 0))), (!r || r.width + Math.round(n.textBlock.width + this.horizontalSpacing * .1 + o + (r.width === 0 ? 0 : this.horizontalSpacing) + (n.chartType === "line" || n.chartType === "spline" || n.chartType === "stepLine" ? 2 * this.lineHeight * .1 : 0)) > s) && (r = { items: [], width: 0 }, k.push(r), this.height += v, v = 0), v = Math.max(v, n.textBlock.height), n.textBlock.x = r.width, n.textBlock.y = 0, r.width += Math.round(n.textBlock.width + this.horizontalSpacing * .1 + o + (r.width === 0 ? 0 : this.horizontalSpacing) + (n.chartType === "line" || n.chartType === "spline" || n.chartType === "stepLine" ? 2 * this.lineHeight * .1 : 0)), r.items.push(n), this.width = Math.max(r.width, this.width)) : (n.textBlock = new c(this.ctx, { x: 0, y: 0, maxWidth: l, maxHeight: this.itemWrap === !0 ? h : this.fontSize * 1.5, angle: 0, text: n.text, horizontalAlign: "left", fontSize: this.fontSize, fontFamily: this.fontFamily, fontWeight: this.fontWeight, fontColor: this.fontColor, fontStyle: this.fontStyle, textBaseline: "top" }), n.textBlock.measureText(), this.itemWidth !== null && (n.textBlock.width = this.itemWidth - (o + this.horizontalSpacing * .1 + (n.chartType === "line" || n.chartType === "spline" || n.chartType === "stepLine" ? 2 * this.lineHeight * .1 : 0))), this.height <= h ? (r = { items: [], width: 0 }, k.push(r)) : (r = k[et], et = (et + 1) % k.length), this.height += n.textBlock.height, n.textBlock.x = r.width, n.textBlock.y = 0, r.width += Math.round(n.textBlock.width + this.horizontalSpacing * .1 + o + (r.width === 0 ? 0 : this.horizontalSpacing) + (n.chartType === "line" || n.chartType === "spline" || n.chartType === "stepLine" ? 2 * this.lineHeight * .1 : 0)), r.items.push(n), this.width = Math.max(r.width, this.width))); this.itemWrap === !1 ? this.height = k.length * this.lineHeight : this.height += v; this.height = Math.min(h, this.height); this.width = Math.min(s, this.width) } for (this.verticalAlign === "top" ? (b = this.horizontalAlign === "left" ? f.x1 : this.horizontalAlign === "right" ? f.x2 - this.width : f.x1 + f.width / 2 - this.width / 2, w = f.y1) : this.verticalAlign === "center" ? (b = this.horizontalAlign === "left" ? f.x1 : this.horizontalAlign === "right" ? f.x2 - this.width : f.x1 + f.width / 2 - this.width / 2, w = f.y1 + f.height / 2 - this.height / 2) : this.verticalAlign === "bottom" && (b = this.horizontalAlign === "left" ? f.x1 : this.horizontalAlign === "right" ? f.x2 - this.width : f.x1 + f.width / 2 - this.width / 2, w = f.y2 - this.height), this.items = y, e = 0; e < this.items.length; e++) n = y[e], n.id = ++this.chart._eventManager.lastObjectId, this.chart._eventManager.objectMap[n.id] = { id: n.id, objectType: "legendItem", legendItemIndex: e, dataSeriesIndex: n.dataSeriesIndex, dataPointIndex: n.dataPointIndex }; for (it = 0, e = 0; e < k.length; e++) { for (r = k[e], v = 0, nt = 0; nt < r.items.length; nt++) { var n = r.items[nt], tt = n.textBlock.x + b + (nt === 0 ? o * .2 : this.horizontalSpacing), rt = w + it, ut = tt; this.chart.data[n.dataSeriesIndex].visible || (this.ctx.globalAlpha = .5); this.ctx.save(); this.ctx.rect(b, w, s, h); this.ctx.clip(); (n.chartType === "line" || n.chartType === "stepLine" || n.chartType === "spline") && (this.ctx.strokeStyle = n.lineColor, this.ctx.lineWidth = Math.ceil(this.lineHeight / 8), this.ctx.beginPath(), this.ctx.moveTo(tt - this.lineHeight * .1, rt + this.lineHeight / 2), this.ctx.lineTo(tt + this.lineHeight * .7, rt + this.lineHeight / 2), this.ctx.stroke(), ut -= this.lineHeight * .1); a.drawMarker(tt + o / 2, rt + this.lineHeight / 2, this.ctx, n.markerType, n.markerSize, n.markerColor, n.markerBorderColor, n.markerBorderThickness); n.textBlock.x = tt + this.horizontalSpacing * .1 + o; (n.chartType === "line" || n.chartType === "stepLine" || n.chartType === "spline") && (n.textBlock.x = n.textBlock.x + this.lineHeight * .1); n.textBlock.y = rt; n.textBlock.render(!0); this.ctx.restore(); v = nt > 0 ? Math.max(v, n.textBlock.height) : n.textBlock.height; this.chart.data[n.dataSeriesIndex].visible || (this.ctx.globalAlpha = 1); at = u(n.id); this.ghostCtx.fillStyle = at; this.ghostCtx.beginPath(); this.ghostCtx.fillRect(ut, n.textBlock.y, n.textBlock.x + n.textBlock.width - ut, n.textBlock.height); n.x1 = this.chart._eventManager.objectMap[n.id].x1 = ut; n.y1 = this.chart._eventManager.objectMap[n.id].y1 = n.textBlock.y; n.x2 = this.chart._eventManager.objectMap[n.id].x2 = n.textBlock.x + n.textBlock.width; n.y2 = this.chart._eventManager.objectMap[n.id].y2 = n.textBlock.y + n.textBlock.height } it = it + v } ot.layoutManager.registerSpace(ft, { width: this.width + 2 + 2, height: this.height + 5 + 5 }); this.bounds = { x1: b, y1: w, x2: b + this.width, y2: w + this.height } }; w(fi, h); fi.prototype.render = function() { var n = this.chart.layoutManager.getFreeSpace(); this.ctx.fillStyle = "red"; this.ctx.fillRect(n.x1, n.y1, n.x2, n.y2) }; w(d, h); d.prototype.getDefaultAxisPlacement = function() { var n = this.type; return n === "column" || n === "line" || n === "stepLine" || n === "spline" || n === "area" || n === "stepArea" || n === "splineArea" || n === "stackedColumn" || n === "stackedLine" || n === "bubble" || n === "scatter" || n === "stackedArea" || n === "stackedColumn100" || n === "stackedLine100" || n === "stackedArea100" || n === "candlestick" || n === "ohlc" || n === "rangeColumn" || n === "rangeArea" || n === "rangeSplineArea" ? "normal" : n === "bar" || n === "stackedBar" || n === "stackedBar100" || n === "rangeBar" ? "xySwapped" : n === "pie" || n === "doughnut" || n === "funnel" ? "none" : (window.console.log("Unknown Chart Type: " + n), null) }; d.getDefaultLegendMarker = function(n) { return n === "column" || n === "stackedColumn" || n === "stackedLine" || n === "bar" || n === "stackedBar" || n === "stackedBar100" || n === "bubble" || n === "scatter" || n === "stackedColumn100" || n === "stackedLine100" || n === "stepArea" || n === "candlestick" || n === "ohlc" || n === "rangeColumn" || n === "rangeBar" || n === "rangeArea" || n === "rangeSplineArea" ? "square" : n === "line" || n === "stepLine" || n === "spline" || n === "pie" || n === "doughnut" || n === "funnel" ? "circle" : n === "area" || n === "splineArea" || n === "stackedArea" || n === "stackedArea100" ? "triangle" : (window.console.log("Unknown Chart Type: " + n), null) }; d.prototype.getDataPointAtX = function(n, t) { var s, h, c; if (!this.dataPoints || this.dataPoints.length === 0) return null; var i = { dataPoint: null, distance: Infinity, index: NaN }, o = null, r = 0, u = 0, f = 1, l = Infinity, a = 0, v = 0, y = 1e3, e = 0; for (this.chart.plotInfo.axisPlacement !== "none" && (s = this.dataPoints[this.dataPoints.length - 1].x - this.dataPoints[0].x, e = s > 0 ? Math.min(Math.max((this.dataPoints.length - 1) / s * (n - this.dataPoints[0].x) >> 0, 0), this.dataPoints.length) : 0);;) { if (u = f > 0 ? e + r : e - r, u >= 0 && u < this.dataPoints.length) { if (o = this.dataPoints[u], h = Math.abs(o.x - n), h < i.distance && (i.dataPoint = o, i.distance = h, i.index = u), c = Math.abs(o.x - n), c <= l ? l = c : f > 0 ? a++ : v++, a > y && v > y) break } else if (e - r < 0 && e + r >= this.dataPoints.length) break; f === -1 ? (r++, f = 1) : f = -1 } return t || i.dataPoint.x !== n ? t && i.dataPoint !== null ? i : null : i }; d.prototype.getDataPointAtXY = function(n, t, i) { var et, ut, nt, a, h, d, ot, tt, v, y, w; if (!this.dataPoints || this.dataPoints.length === 0) return null; i = i || !1; var e = [], b = 0, f = 0, l = 1, s = !1, g = Infinity, it = 0, rt = 0, ft = 1e3, k = 0; for (this.chart.plotInfo.axisPlacement !== "none" && (et = this.chart.axisX.getXValueAt({ x: n, y: t }), ut = this.dataPoints[this.dataPoints.length - 1].x - this.dataPoints[0].x, k = ut > 0 ? Math.min(Math.max((this.dataPoints.length - 1) / ut * (et - this.dataPoints[0].x) >> 0, 0), this.dataPoints.length) : 0);;) { if (f = l > 0 ? k + b : k - b, f >= 0 && f < this.dataPoints.length) { var st = this.dataPointIds[f], r = this.chart._eventManager.objectMap[st], o = this.dataPoints[f], u = null; if (r) { switch (this.type) { case "column": case "stackedColumn": case "stackedColumn100": case "bar": case "stackedBar": case "stackedBar100": case "rangeColumn": case "rangeBar": n >= r.x1 && n <= r.x2 && t >= r.y1 && t <= r.y2 && (e.push({ dataPoint: o, dataPointIndex: f, dataSeries: this, distance: Math.min(Math.abs(r.x1 - n), Math.abs(r.x2 - n), Math.abs(r.y1 - t), Math.abs(r.y2 - t)) }), s = !0); break; case "line": case "stepLine": case "spline": case "area": case "stepArea": case "stackedArea": case "stackedArea100": case "splineArea": case "scatter": h = p("markerSize", o, this) || 4; nt = i ? 20 : h; u = Math.sqrt(Math.pow(r.x1 - n, 2) + Math.pow(r.y1 - t, 2)); u <= nt && e.push({ dataPoint: o, dataPointIndex: f, dataSeries: this, distance: u }); a = Math.abs(r.x1 - n); a <= g ? g = a : l > 0 ? it++ : rt++; u <= h / 2 && (s = !0); break; case "rangeArea": case "rangeSplineArea": h = p("markerSize", o, this) || 4; nt = i ? 20 : h; u = Math.min(Math.sqrt(Math.pow(r.x1 - n, 2) + Math.pow(r.y1 - t, 2)), Math.sqrt(Math.pow(r.x1 - n, 2) + Math.pow(r.y2 - t, 2))); u <= nt && e.push({ dataPoint: o, dataPointIndex: f, dataSeries: this, distance: u }); a = Math.abs(r.x1 - n); a <= g ? g = a : l > 0 ? it++ : rt++; u <= h / 2 && (s = !0); break; case "bubble": h = r.size; u = Math.sqrt(Math.pow(r.x1 - n, 2) + Math.pow(r.y1 - t, 2)); u <= h / 2 && (e.push({ dataPoint: o, dataPointIndex: f, dataSeries: this, distance: u }), s = !0); break; case "pie": case "doughnut": if (d = r.center, ot = this.type === "doughnut" ? .6 * r.radius : 0, u = Math.sqrt(Math.pow(d.x - n, 2) + Math.pow(d.y - t, 2)), u < r.radius && u > ot) { var ht = t - d.y, ct = n - d.x, c = Math.atan2(ht, ct); c < 0 && (c += Math.PI * 2); c = Number(((c / Math.PI * 180 % 360 + 360) % 360).toFixed(12)); tt = Number(((r.startAngle / Math.PI * 180 % 360 + 360) % 360).toFixed(12)); v = Number(((r.endAngle / Math.PI * 180 % 360 + 360) % 360).toFixed(12)); v === 0 && r.endAngle > 1 && (v = 360); tt >= v && o.y !== 0 && (v += 360, c < tt && (c += 360)); c > tt && c < v && (e.push({ dataPoint: o, dataPointIndex: f, dataSeries: this, distance: 0 }), s = !0) } break; case "candlestick": (n >= r.x1 - r.borderThickness / 2 && n <= r.x2 + r.borderThickness / 2 && t >= r.y2 - r.borderThickness / 2 && t <= r.y3 + r.borderThickness / 2 || Math.abs(r.x2 - n + r.x1 - n) < r.borderThickness && t >= r.y1 && t <= r.y4) && (e.push({ dataPoint: o, dataPointIndex: f, dataSeries: this, distance: Math.min(Math.abs(r.x1 - n), Math.abs(r.x2 - n), Math.abs(r.y2 - t), Math.abs(r.y3 - t)) }), s = !0); break; case "ohlc": (Math.abs(r.x2 - n + r.x1 - n) < r.borderThickness && t >= r.y2 && t <= r.y3 || n >= r.x1 && n <= (r.x2 + r.x1) / 2 && t >= r.y1 - r.borderThickness / 2 && t <= r.y1 + r.borderThickness / 2 || n >= (r.x1 + r.x2) / 2 && n <= r.x2 && t >= r.y4 - r.borderThickness / 2 && t <= r.y4 + r.borderThickness / 2) && (e.push({ dataPoint: o, dataPointIndex: f, dataSeries: this, distance: Math.min(Math.abs(r.x1 - n), Math.abs(r.x2 - n), Math.abs(r.y2 - t), Math.abs(r.y3 - t)) }), s = !0) } if (s || it > ft && rt > ft) break } } else if (k - b < 0 && k + b >= this.dataPoints.length) break; l === -1 ? (b++, l = 1) : l = -1 } for (y = null, w = 0; w < e.length; w++) y ? e[w].distance <= y.distance && (y = e[w]) : y = e[w]; return y }; d.prototype.getMarkerProperties = function(n, t, i, r) { var u = this.dataPoints, f = this, e = u[n].markerColor ? u[n].markerColor : f.markerColor ? f.markerColor : u[n].color ? u[n].color : f.color ? f.color : f._colorSet[n % f._colorSet.length], o = u[n].markerBorderColor ? u[n].markerBorderColor : f.markerBorderColor ? f.markerBorderColor : null, s = u[n].markerBorderThickness ? u[n].markerBorderThickness : f.markerBorderThickness ? f.markerBorderThickness : null, h = u[n].markerType ? u[n].markerType : f.markerType, c = u[n].markerSize ? u[n].markerSize : f.markerSize; return { x: t, y: i, ctx: r, type: h, size: c, color: e, borderColor: o, borderThickness: s } }; w(e, h); e.prototype.createLabels = function() { var i, n = 0, f, r = 0, u = 0, e = 0, s, o, t; if (this._position === "bottom" || this._position === "top" ? (e = this.lineCoordinates.width / Math.abs(this.maximum - this.minimum) * this.interval, r = this.labelAutoFit ? typeof this._options.labelMaxWidth == "undefined" ? e * .9 >> 0 : this.labelMaxWidth : typeof this._options.labelMaxWidth == "undefined" ? this.chart.width * .7 >> 0 : this.labelMaxWidth, u = typeof this._options.labelWrap == "undefined" || this.labelWrap ? this.chart.height * .5 >> 0 : this.labelFontSize * 1.5) : (this._position === "left" || this._position === "right") && (e = this.lineCoordinates.height / Math.abs(this.maximum - this.minimum) * this.interval, r = this.labelAutoFit ? typeof this._options.labelMaxWidth == "undefined" ? this.chart.width * .3 >> 0 : this.labelMaxWidth : typeof this._options.labelMaxWidth == "undefined" ? this.chart.width * .5 >> 0 : this.labelMaxWidth, u = typeof this._options.labelWrap == "undefined" || this.labelWrap ? e * 2 >> 0 : this.labelFontSize * 1.5), this.type === "axisX" && this.chart.plotInfo.axisXValueType === "dateTime") for (f = oi(new Date(this.maximum), this.interval, this.intervalType), n = this.intervalstartTimePercent; n < f; oi(n, this.interval, this.intervalType)) s = n.getTime(), o = this.labelFormatter ? this.labelFormatter({ chart: this.chart, axis: this._options, value: n, label: this.labels[n] ? this.labels[n] : null }) : this.type === "axisX" && this.labels[s] ? this.labels[s] : ii(n, this.valueFormatString, this.chart._cultureInfo), i = new c(this.ctx, { x: 0, y: 0, maxWidth: r, maxHeight: u, angle: this.labelAngle, text: this.prefix + o + this.suffix, horizontalAlign: "left", fontSize: this.labelFontSize, fontFamily: this.labelFontFamily, fontWeight: this.labelFontWeight, fontColor: this.labelFontColor, fontStyle: this.labelFontStyle, textBaseline: "middle" }), this._labels.push({ position: n.getTime(), textBlock: i, effectiveHeight: null }); else { if (f = this.maximum, this.labels && this.labels.length) { var l = Math.ceil(this.interval), a = Math.ceil(this.intervalstartTimePercent), h = !1; for (n = a; n < this.maximum; n += l) if (this.labels[n]) h = !0; else { h = !1; break } h && (this.interval = l, this.intervalstartTimePercent = a) } for (n = this.intervalstartTimePercent; n <= f; n = parseFloat((n + this.interval).toFixed(14))) o = this.labelFormatter ? this.labelFormatter({ chart: this.chart, axis: this._options, value: n, label: this.labels[n] ? this.labels[n] : null }) : this.type === "axisX" && this.labels[n] ? this.labels[n] : it(n, this.valueFormatString, this.chart._cultureInfo), i = new c(this.ctx, { x: 0, y: 0, maxWidth: r, maxHeight: u, angle: this.labelAngle, text: this.prefix + o + this.suffix, horizontalAlign: "left", fontSize: this.labelFontSize, fontFamily: this.labelFontFamily, fontWeight: this.labelFontWeight, fontColor: this.labelFontColor, fontStyle: this.labelFontStyle, textBaseline: "middle", borderThickness: 0 }), this._labels.push({ position: n, textBlock: i, effectiveHeight: null }) } for (n = 0; n < this.stripLines.length; n++) t = this.stripLines[n], i = new c(this.ctx, { x: 0, y: 0, backgroundColor: t.labelBackgroundColor, maxWidth: r, maxHeight: u, angle: this.labelAngle, text: t.labelFormatter ? t.labelFormatter({ chart: this.chart, axis: this, stripLine: t }) : t.label, horizontalAlign: "left", fontSize: t.labelFontSize, fontFamily: t.labelFontFamily, fontWeight: t.labelFontWeight, fontColor: t._options.labelFontColor || t.color, fontStyle: t.labelFontStyle, textBaseline: "middle", borderThickness: 0 }), this._labels.push({ position: t.value, textBlock: i, effectiveHeight: null, stripLine: t }) }; e.prototype.createLabelsAndCalculateWidth = function() { var t = 0, u, f; if (this._labels = [], this._position === "left" || this._position === "right") for (this.createLabels(), i = 0; i < this._labels.length; i++) { var e = this._labels[i].textBlock, r = e.measureText(), n = 0; n = this.labelAngle === 0 ? r.width : r.width * Math.cos(Math.PI / 180 * Math.abs(this.labelAngle)) + r.height / 2 * Math.sin(Math.PI / 180 * Math.abs(this.labelAngle)); t < n && (t = n); this._labels[i].effectiveWidth = n } return u = this.title ? pt(this.titleFontFamily, this.titleFontSize, this.titleFontWeight) + 2 : 0, f = u + t + this.tickLength + 5, f }; e.prototype.createLabelsAndCalculateHeight = function() { var r = 0, u, n, i, t, f; if (this._labels = [], n = 0, this.createLabels(), this._position === "bottom" || this._position === "top") for (n = 0; n < this._labels.length; n++) u = this._labels[n].textBlock, i = u.measureText(), t = 0, t = this.labelAngle === 0 ? i.height : i.width * Math.sin(Math.PI / 180 * Math.abs(this.labelAngle)) + i.height / 2 * Math.cos(Math.PI / 180 * Math.abs(this.labelAngle)), r < t && (r = t), this._labels[n].effectiveHeight = t; return f = this.title ? pt(this.titleFontFamily, this.titleFontSize, this.titleFontWeight) + 2 : 0, f + r + this.tickLength + 5 }; e.setLayoutAndRender = function(n, t, i, r, u) { var e, o, f, s, b = n.chart, c = b.ctx, a, v, k, y, p, w, d, g, h; n.calculateAxisParameters(); t && t.calculateAxisParameters(); i && i.calculateAxisParameters(); t && i && typeof t._options.maximum == "undefined" && typeof t._options.minimum == "undefined" && typeof t._options.interval == "undefined" && typeof i._options.maximum == "undefined" && typeof i._options.minimum == "undefined" && typeof i._options.interval == "undefined" && (a = (t.maximum - t.minimum) / t.interval, v = (i.maximum - i.minimum) / i.interval, a > v ? i.maximum = i.interval * a + i.minimum : v > a && (t.maximum = t.interval * v + t.minimum)); var nt = t ? t.lineThickness ? t.lineThickness : 0 : 0, tt = i ? i.lineThickness ? i.lineThickness : 0 : 0, it = t ? t.gridThickness ? t.gridThickness : 0 : 0, rt = i ? i.gridThickness ? i.gridThickness : 0 : 0, l = t ? t.margin : 0, ut = t ? t.margin : 0; r === "normal" ? (n.lineCoordinates = {}, k = Math.ceil(t ? t.createLabelsAndCalculateWidth() : 0), e = Math.round(u.x1 + k + l), n.lineCoordinates.x1 = e, y = Math.ceil(i ? i.createLabelsAndCalculateWidth() : 0), f = Math.round(u.x2 - y > n.chart.width - 10 ? n.chart.width - 10 : u.x2 - y), n.lineCoordinates.x2 = f, n.lineCoordinates.width = Math.abs(f - e), p = Math.ceil(n.createLabelsAndCalculateHeight()), o = Math.round(u.y2 - p - n.margin), s = Math.round(u.y2 - n.margin), n.lineCoordinates.y1 = o, n.lineCoordinates.y2 = o, n.boundingRect = { x1: e, y1: o, x2: f, y2: s, width: f - e, height: s - o }, t && (e = Math.round(u.x1 + t.margin), o = Math.round(u.y1 < 10 ? 10 : u.y1), f = Math.round(u.x1 + k + t.margin), s = Math.round(u.y2 - p - n.margin), t.lineCoordinates = { x1: f, y1: o, x2: f, y2: s, height: Math.abs(s - o) }, t.boundingRect = { x1: e, y1: o, x2: f, y2: s, width: f - e, height: s - o }), i && (e = Math.round(n.lineCoordinates.x2), o = Math.round(u.y1 < 10 ? 10 : u.y1), f = Math.round(e + y + i.margin), s = Math.round(u.y2 - p - n.margin), i.lineCoordinates = { x1: e, y1: o, x2: e, y2: s, height: Math.abs(s - o) }, i.boundingRect = { x1: e, y1: o, x2: f, y2: s, width: f - e, height: s - o }), n.calculateValueToPixelconversionParameters(), t && t.calculateValueToPixelconversionParameters(), i && i.calculateValueToPixelconversionParameters(), c.save(), c.rect(5, n.boundingRect.y1, n.chart.width - 10, n.boundingRect.height), c.clip(), n.renderLabelsTicksAndTitle(), c.restore(), t && t.renderLabelsTicksAndTitle(), i && i.renderLabelsTicksAndTitle(), b.preparePlotArea(), h = n.chart.plotArea, c.save(), c.rect(h.x1, h.y1, Math.abs(h.x2 - h.x1), Math.abs(h.y2 - h.y1)), c.clip(), n.renderStripLinesOfThicknessType("value"), t && t.renderStripLinesOfThicknessType("value"), i && i.renderStripLinesOfThicknessType("value"), n.renderInterlacedColors(), t && t.renderInterlacedColors(), i && i.renderInterlacedColors(), c.restore(), n.renderGrid(), t && t.renderGrid(), i && i.renderGrid(), n.renderAxisLine(), t && t.renderAxisLine(), i && i.renderAxisLine(), n.renderStripLinesOfThicknessType("pixel"), t && t.renderStripLinesOfThicknessType("pixel"), i && i.renderStripLinesOfThicknessType("pixel")) : (w = Math.ceil(n.createLabelsAndCalculateWidth()), t && (t.lineCoordinates = {}, e = Math.round(u.x1 + w + n.margin), f = Math.round(u.x2 > t.chart.width - 10 ? t.chart.width - 10 : u.x2), t.lineCoordinates.x1 = e, t.lineCoordinates.x2 = f, t.lineCoordinates.width = Math.abs(f - e)), i && (i.lineCoordinates = {}, e = Math.round(u.x1 + w + n.margin), f = Math.round(u.x2 > i.chart.width - 10 ? i.chart.width - 10 : u.x2), i.lineCoordinates.x1 = e, i.lineCoordinates.x2 = f, i.lineCoordinates.width = Math.abs(f - e)), d = Math.ceil(t ? t.createLabelsAndCalculateHeight() : 0), g = Math.ceil(i ? i.createLabelsAndCalculateHeight() : 0), t && (o = Math.round(u.y2 - d - t.margin), s = Math.round(u.y2 - l > t.chart.height - 10 ? t.chart.height - 10 : u.y2 - l), t.lineCoordinates.y1 = o, t.lineCoordinates.y2 = o, t.boundingRect = { x1: e, y1: o, x2: f, y2: s, width: f - e, height: d }), i && (o = Math.round(u.y1 + i.margin), s = u.y1 + i.margin + g, i.lineCoordinates.y1 = s, i.lineCoordinates.y2 = s, i.boundingRect = { x1: e, y1: o, x2: f, y2: s, width: f - e, height: g }), e = Math.round(u.x1 + n.margin), o = Math.round(i ? i.lineCoordinates.y2 : u.y1 < 10 ? 10 : u.y1), f = Math.round(u.x1 + w + n.margin), s = Math.round(t ? t.lineCoordinates.y1 : u.y2 - l > n.chart.height - 10 ? n.chart.height - 10 : u.y2 - l), n.lineCoordinates = { x1: f, y1: o, x2: f, y2: s, height: Math.abs(s - o) }, n.boundingRect = { x1: e, y1: o, x2: f, y2: s, width: f - e, height: s - o }, n.calculateValueToPixelconversionParameters(), t && t.calculateValueToPixelconversionParameters(), i && i.calculateValueToPixelconversionParameters(), t && t.renderLabelsTicksAndTitle(), i && i.renderLabelsTicksAndTitle(), n.renderLabelsTicksAndTitle(), b.preparePlotArea(), h = n.chart.plotArea, c.save(), c.rect(h.x1, h.y1, Math.abs(h.x2 - h.x1), Math.abs(h.y2 - h.y1)), c.clip(), n.renderStripLinesOfThicknessType("value"), t && t.renderStripLinesOfThicknessType("value"), i && i.renderStripLinesOfThicknessType("value"), n.renderInterlacedColors(), t && t.renderInterlacedColors(), i && i.renderInterlacedColors(), c.restore(), n.renderGrid(), t && t.renderGrid(), i && i.renderGrid(), n.renderAxisLine(), t && t.renderAxisLine(), i && i.renderAxisLine(), n.renderStripLinesOfThicknessType("pixel"), t && t.renderStripLinesOfThicknessType("pixel"), i && i.renderStripLinesOfThicknessType("pixel")) }; e.prototype.renderLabelsTicksAndTitle = function() { var u = !1, o = 0, l = 1, s = 0, v = this.conversionParameters.pixelPerUnit * this.interval, h, r, f, a, t, i, n, e; if (this.labelAngle !== 0 && this.labelAngle !== 360 && (l = 1.2), typeof this._options.interval == "undefined") { if (this._position === "bottom" || this._position === "top") { for (n = 0; n < this._labels.length; n++)(t = this._labels[n], t.position < this.minimum || t.stripLine) || (h = t.textBlock.width * Math.cos(Math.PI / 180 * this.labelAngle) + t.textBlock.height * Math.sin(Math.PI / 180 * this.labelAngle), o += h); o > this.lineCoordinates.width * l && (u = !0) } if (this._position === "left" || this._position === "right") { for (n = 0; n < this._labels.length; n++)(t = this._labels[n], t.position < this.minimum || t.stripLine) || (h = t.textBlock.height * Math.cos(Math.PI / 180 * this.labelAngle) + t.textBlock.width * Math.sin(Math.PI / 180 * this.labelAngle), o += h); o > this.lineCoordinates.height * l && (u = !0) } } if (this._position === "bottom") { for (n = 0, n = 0; n < this._labels.length; n++)(t = this._labels[n], t.position < this.minimum || t.position > this.maximum) || (i = this.getPixelCoordinatesOnAxis(t.position), (this.tickThickness && !this._labels[n].stripLine || this._labels[n].stripLine && this._labels[n].stripLine._thicknessType === "pixel") && (this._labels[n].stripLine ? (r = this._labels[n].stripLine, this.ctx.lineWidth = r.thickness, this.ctx.strokeStyle = r.color) : (this.ctx.lineWidth = this.tickThickness, this.ctx.strokeStyle = this.tickColor), f = this.ctx.lineWidth % 2 == 1 ? (i.x << 0) + .5 : i.x << 0, this.ctx.beginPath(), this.ctx.moveTo(f, i.y << 0), this.ctx.lineTo(f, i.y + this.tickLength << 0), this.ctx.stroke()), !u || s++ % 2 == 0 || this._labels[n].stripLine) && (t.textBlock.angle === 0 ? (i.x -= t.textBlock.width / 2, i.y += this.tickLength + t.textBlock.fontSize / 2) : (i.x -= this.labelAngle < 0 ? t.textBlock.width * Math.cos(Math.PI / 180 * this.labelAngle) : 0, i.y += this.tickLength + Math.abs(this.labelAngle < 0 ? t.textBlock.width * Math.sin(Math.PI / 180 * this.labelAngle) - 5 : 5)), t.textBlock.x = i.x, t.textBlock.y = i.y, t.textBlock.render(!0)); this.title && (this._titleTextBlock = new c(this.ctx, { x: this.lineCoordinates.x1, y: this.boundingRect.y2 - this.titleFontSize - 5, maxWidth: this.lineCoordinates.width, maxHeight: this.titleFontSize * 1.5, angle: 0, text: this.title, horizontalAlign: "center", fontSize: this.titleFontSize, fontFamily: this.titleFontFamily, fontWeight: this.titleFontWeight, fontColor: this.titleFontColor, fontStyle: this.titleFontStyle, textBaseline: "top" }), this._titleTextBlock.measureText(), this._titleTextBlock.x = this.lineCoordinates.x1 + this.lineCoordinates.width / 2 - this._titleTextBlock.width / 2, this._titleTextBlock.y = this.boundingRect.y2 - this._titleTextBlock.height - 3, this._titleTextBlock.render(!0)) } else if (this._position === "top") { for (n = 0, n = 0; n < this._labels.length; n++)(t = this._labels[n], t.position < this.minimum || t.position > this.maximum) || (i = this.getPixelCoordinatesOnAxis(t.position), (this.tickThickness && !this._labels[n].stripLine || this._labels[n].stripLine && this._labels[n].stripLine._thicknessType === "pixel") && (this._labels[n].stripLine ? (r = this._labels[n].stripLine, this.ctx.lineWidth = r.thickness, this.ctx.strokeStyle = r.color) : (this.ctx.lineWidth = this.tickThickness, this.ctx.strokeStyle = this.tickColor), f = this.ctx.lineWidth % 2 == 1 ? (i.x << 0) + .5 : i.x << 0, this.ctx.beginPath(), this.ctx.moveTo(f, i.y << 0), this.ctx.lineTo(f, i.y - this.tickLength << 0), this.ctx.stroke()), !u || s++ % 2 == 0 || this._labels[n].stripLine) && (t.textBlock.angle === 0 ? (i.x -= t.textBlock.width / 2, i.y -= this.tickLength + t.textBlock.height / 2) : (i.x -= this.labelAngle > 0 ? t.textBlock.width * Math.cos(Math.PI / 180 * this.labelAngle) : 0, i.y -= this.tickLength + Math.abs(this.labelAngle > 0 ? t.textBlock.width * Math.sin(Math.PI / 180 * this.labelAngle) + 5 : 5)), t.textBlock.x = i.x, t.textBlock.y = i.y, t.textBlock.render(!0)); this.title && (this._titleTextBlock = new c(this.ctx, { x: this.lineCoordinates.x1, y: this.boundingRect.y1 + 1, maxWidth: this.lineCoordinates.width, maxHeight: this.titleFontSize * 1.5, angle: 0, text: this.title, horizontalAlign: "center", fontSize: this.titleFontSize, fontFamily: this.titleFontFamily, fontWeight: this.titleFontWeight, fontColor: this.titleFontColor, fontStyle: this.titleFontStyle, textBaseline: "top" }), this._titleTextBlock.measureText(), this._titleTextBlock.x = this.lineCoordinates.x1 + this.lineCoordinates.width / 2 - this._titleTextBlock.width / 2, this._titleTextBlock.render(!0)) } else if (this._position === "left") { for (n = 0; n < this._labels.length; n++)(t = this._labels[n], t.position < this.minimum || t.position > this.maximum) || (i = this.getPixelCoordinatesOnAxis(t.position), (this.tickThickness && !this._labels[n].stripLine || this._labels[n].stripLine && this._labels[n].stripLine._thicknessType === "pixel") && (this._labels[n].stripLine ? (r = this._labels[n].stripLine, this.ctx.lineWidth = r.thickness, this.ctx.strokeStyle = r.color) : (this.ctx.lineWidth = this.tickThickness, this.ctx.strokeStyle = this.tickColor), e = this.ctx.lineWidth % 2 == 1 ? (i.y << 0) + .5 : i.y << 0, this.ctx.beginPath(), this.ctx.moveTo(i.x << 0, e), this.ctx.lineTo(i.x - this.tickLength << 0, e), this.ctx.stroke()), !u || s++ % 2 == 0 || this._labels[n].stripLine) && (t.textBlock.x = i.x - t.textBlock.width * Math.cos(Math.PI / 180 * this.labelAngle) - this.tickLength - 5, t.textBlock.y = this.labelAngle === 0 ? i.y : i.y - t.textBlock.width * Math.sin(Math.PI / 180 * this.labelAngle), t.textBlock.render(!0)); this.title && (this._titleTextBlock = new c(this.ctx, { x: this.boundingRect.x1 + 1, y: this.lineCoordinates.y2, maxWidth: this.lineCoordinates.height, maxHeight: this.titleFontSize * 1.5, angle: -90, text: this.title, horizontalAlign: "center", fontSize: this.titleFontSize, fontFamily: this.titleFontFamily, fontWeight: this.titleFontWeight, fontColor: this.titleFontColor, fontStyle: this.titleFontStyle, textBaseline: "top" }), a = this._titleTextBlock.measureText(), this._titleTextBlock.y = this.lineCoordinates.height / 2 + this._titleTextBlock.width / 2 + this.lineCoordinates.y1, this._titleTextBlock.render(!0)) } else if (this._position === "right") { for (n = 0; n < this._labels.length; n++)(t = this._labels[n], t.position < this.minimum || t.position > this.maximum) || (i = this.getPixelCoordinatesOnAxis(t.position), (this.tickThickness && !this._labels[n].stripLine || this._labels[n].stripLine && this._labels[n].stripLine._thicknessType === "pixel") && (this._labels[n].stripLine ? (r = this._labels[n].stripLine, this.ctx.lineWidth = r.thickness, this.ctx.strokeStyle = r.color) : (this.ctx.lineWidth = this.tickThickness, this.ctx.strokeStyle = this.tickColor), e = this.ctx.lineWidth % 2 == 1 ? (i.y << 0) + .5 : i.y << 0, this.ctx.beginPath(), this.ctx.moveTo(i.x << 0, e), this.ctx.lineTo(i.x + this.tickLength << 0, e), this.ctx.stroke()), !u || s++ % 2 == 0 || this._labels[n].stripLine) && (t.textBlock.x = i.x + this.tickLength + 5, t.textBlock.y = this.labelAngle === 0 ? i.y : i.y, t.textBlock.render(!0)); this.title && (this._titleTextBlock = new c(this.ctx, { x: this.boundingRect.x2 - 1, y: this.lineCoordinates.y2, maxWidth: this.lineCoordinates.height, maxHeight: this.titleFontSize * 1.5, angle: 90, text: this.title, horizontalAlign: "center", fontSize: this.titleFontSize, fontFamily: this.titleFontFamily, fontWeight: this.titleFontWeight, fontColor: this.titleFontColor, fontStyle: this.titleFontStyle, textBaseline: "top" }), this._titleTextBlock.measureText(), this._titleTextBlock.y = this.lineCoordinates.height / 2 - this._titleTextBlock.width / 2 + this.lineCoordinates.y1, this._titleTextBlock.render(!0)) } }; e.prototype.renderInterlacedColors = function() { var u = this.chart.plotArea.ctx, t, f, i = this.chart.plotArea, n = 0, r = !0; if ((this._position === "bottom" || this._position === "top") && this.interlacedColor) for (u.fillStyle = this.interlacedColor, n = 0; n < this._labels.length; n++) this._labels[n].stripLine || (r ? (t = this.getPixelCoordinatesOnAxis(this._labels[n].position), f = n + 1 >= this._labels.length - 1 ? this.getPixelCoordinatesOnAxis(this.maximum) : this.getPixelCoordinatesOnAxis(this._labels[n + 1].position), u.fillRect(t.x, i.y1, Math.abs(f.x - t.x), Math.abs(i.y1 - i.y2)), r = !1) : r = !0); else if ((this._position === "left" || this._position === "right") && this.interlacedColor) for (u.fillStyle = this.interlacedColor, n = 0; n < this._labels.length; n++) this._labels[n].stripLine || (r ? (f = this.getPixelCoordinatesOnAxis(this._labels[n].position), t = n + 1 >= this._labels.length - 1 ? this.getPixelCoordinatesOnAxis(this.maximum) : this.getPixelCoordinatesOnAxis(this._labels[n + 1].position), u.fillRect(i.x1, t.y, Math.abs(i.x1 - i.x2), Math.abs(t.y - f.y)), r = !1) : r = !0); u.beginPath() }; e.prototype.renderStripLinesOfThicknessType = function(n) { var r, i, t; if (this.stripLines && this.stripLines.length > 0 && n) for (r = this, i = 0, i = 0; i < this.stripLines.length; i++)(t = this.stripLines[i], t._thicknessType === n) && (n === "pixel" && (t.value < this.minimum || t.value > this.maximum) || (t.showOnTop ? this.chart.addEventListener("dataAnimationIterationEnd", t.render, t) : t.render())) }; e.prototype.renderGrid = function() { var n, i, r, u, t, f; if (this.gridThickness && this.gridThickness > 0) if (n = this.chart.ctx, r = this.chart.plotArea, n.lineWidth = this.gridThickness, n.strokeStyle = this.gridColor, n.setLineDash && n.setLineDash(y(this.gridDashType, this.gridThickness)), this._position === "bottom" || this._position === "top") for (t = 0; t < this._labels.length && !this._labels[t].stripLine; t++) this._labels[t].position < this.minimum || this._labels[t].position > this.maximum || (n.beginPath(), i = this.getPixelCoordinatesOnAxis(this._labels[t].position), u = n.lineWidth % 2 == 1 ? (i.x << 0) + .5 : i.x << 0, n.moveTo(u, r.y1 << 0), n.lineTo(u, r.y2 << 0), n.stroke()); else if (this._position === "left" || this._position === "right") for (t = 0; t < this._labels.length && !this._labels[t].stripLine; t++) t === 0 && this.type === "axisY" && this.chart.axisX && this.chart.axisX.lineThickness || this._labels[t].position < this.minimum || this._labels[t].position > this.maximum || (n.beginPath(), i = this.getPixelCoordinatesOnAxis(this._labels[t].position), f = n.lineWidth % 2 == 1 ? (i.y << 0) + .5 : i.y << 0, n.moveTo(r.x1 << 0, f), n.lineTo(r.x2 << 0, f), n.stroke()) }; e.prototype.renderAxisLine = function() { var n = this.chart.ctx, t, i; this._position === "bottom" || this._position === "top" ? this.lineThickness && (n.lineWidth = this.lineThickness, n.strokeStyle = this.lineColor ? this.lineColor : "black", n.setLineDash && n.setLineDash(y(this.lineDashType, this.lineThickness)), t = this.lineThickness % 2 == 1 ? (this.lineCoordinates.y1 << 0) + .5 : this.lineCoordinates.y1 << 0, n.beginPath(), n.moveTo(this.lineCoordinates.x1, t), n.lineTo(this.lineCoordinates.x2, t), n.stroke()) : (this._position === "left" || this._position === "right") && this.lineThickness && (n.lineWidth = this.lineThickness, n.strokeStyle = this.lineColor, n.setLineDash && n.setLineDash(y(this.lineDashType, this.lineThickness)), i = this.lineThickness % 2 == 1 ? (this.lineCoordinates.x1 << 0) + .5 : this.lineCoordinates.x1 << 0, n.beginPath(), n.moveTo(i, this.lineCoordinates.y1), n.lineTo(i, this.lineCoordinates.y2), n.stroke()) }; e.prototype.getPixelCoordinatesOnAxis = function(n) { var t = {}, r = this.lineCoordinates.width, u = this.lineCoordinates.height, i; return (this._position === "bottom" || this._position === "top") && (i = r / Math.abs(this.maximum - this.minimum), t.x = this.lineCoordinates.x1 + i * (n - this.minimum), t.y = this.lineCoordinates.y1), (this._position === "left" || this._position === "right") && (i = u / Math.abs(this.maximum - this.minimum), t.y = this.lineCoordinates.y2 - i * (n - this.minimum), t.x = this.lineCoordinates.x2), t }; e.prototype.getXValueAt = function(n) { if (!n) return null; var t = null; return this._position === "left" ? t = (this.chart.axisX.maximum - this.chart.axisX.minimum) / this.chart.axisX.lineCoordinates.height * (this.chart.axisX.lineCoordinates.y2 - n.y) + this.chart.axisX.minimum : this._position === "bottom" && (t = (this.chart.axisX.maximum - this.chart.axisX.minimum) / this.chart.axisX.lineCoordinates.width * (n.x - this.chart.axisX.lineCoordinates.x1) + this.chart.axisX.minimum), t }; e.prototype.calculateValueToPixelconversionParameters = function() { var n = { pixelPerUnit: null, minimum: null, reference: null }, t = this.lineCoordinates.width, i = this.lineCoordinates.height; n.minimum = this.minimum; (this._position === "bottom" || this._position === "top") && (n.pixelPerUnit = t / Math.abs(this.maximum - this.minimum), n.reference = this.lineCoordinates.x1); (this._position === "left" || this._position === "right") && (n.pixelPerUnit = -1 * i / Math.abs(this.maximum - this.minimum), n.reference = this.lineCoordinates.y2); this.conversionParameters = n }; e.prototype.calculateAxisParameters = function() { var h = this.chart.layoutManager.getFreeSpace(), l = !1, t, r, i, o, n, u, s, c; if (this._position === "bottom" || this._position === "top" ? (this.maxWidth = h.width, this.maxHeight = h.height) : (this.maxWidth = h.height, this.maxHeight = h.width), t = this.type === "axisX" ? this.maxWidth < 500 ? 8 : Math.max(6, Math.floor(this.maxWidth / 62)) : Math.max(Math.floor(this.maxWidth / 40), 2), u = 0, this.type === "axisX" ? (r = this.sessionVariables.internalMinimum !== null ? this.sessionVariables.internalMinimum : this.dataInfo.viewPortMin, i = this.sessionVariables.internalMaximum !== null ? this.sessionVariables.internalMaximum : this.dataInfo.viewPortMax, i - r == 0 && (u = typeof this._options.interval == "undefined" ? .4 : this._options.interval, i += u, r -= u), this.dataInfo.minDiff !== Infinity ? o = this.dataInfo.minDiff : i - r > 1 ? o = Math.abs(i - r) * .5 : (o = 1, this.chart.plotInfo.axisXValueType === "dateTime" && (l = !0))) : this.type === "axisY" && (r = typeof this._options.minimum == "undefined" || this._options.minimum === null ? this.dataInfo.viewPortMin : this._options.minimum, i = typeof this._options.maximum == "undefined" || this._options.maximum === null ? this.dataInfo.viewPortMax : this._options.maximum, isFinite(r) || isFinite(i) ? r === 0 && i === 0 ? (i += 9, r = 0) : i - r == 0 ? (u = Math.min(Math.abs(Math.abs(i) * .01), 5), i += u, r -= u) : r > i ? (u = Math.min(Math.abs(Math.abs(i - r) * .01), 5), i >= 0 ? r = i - u : i = r + u) : (u = Math.min(Math.abs(Math.abs(i - r) * .01), .05), i !== 0 && (i += u), r !== 0 && (r -= u)) : (i = typeof this._options.interval == "undefined" ? -Infinity : this._options.interval, r = 0), this.includeZero && (typeof this._options.minimum == "undefined" || this._options.minimum === null) && r > 0 && (r = 0), this.includeZero && (typeof this._options.maximum == "undefined" || this._options.maximum === null) && i < 0 && (i = 0)), this.type === "axisX" && this.chart.plotInfo.axisXValueType === "dateTime" ? (n = i - r, this.intervalType || (n / 1 <= t ? (this.interval = 1, this.intervalType = "millisecond") : n / 2 <= t ? (this.interval = 2, this.intervalType = "millisecond") : n / 5 <= t ? (this.interval = 5, this.intervalType = "millisecond") : n / 10 <= t ? (this.interval = 10, this.intervalType = "millisecond") : n / 20 <= t ? (this.interval = 20, this.intervalType = "millisecond") : n / 50 <= t ? (this.interval = 50, this.intervalType = "millisecond") : n / 100 <= t ? (this.interval = 100, this.intervalType = "millisecond") : n / 200 <= t ? (this.interval = 200, this.intervalType = "millisecond") : n / 250 <= t ? (this.interval = 250, this.intervalType = "millisecond") : n / 300 <= t ? (this.interval = 300, this.intervalType = "millisecond") : n / 400 <= t ? (this.interval = 400, this.intervalType = "millisecond") : n / 500 <= t ? (this.interval = 500, this.intervalType = "millisecond") : n / (f.secondDuration * 1) <= t ? (this.interval = 1, this.intervalType = "second") : n / (f.secondDuration * 2) <= t ? (this.interval = 2, this.intervalType = "second") : n / (f.secondDuration * 5) <= t ? (this.interval = 5, this.intervalType = "second") : n / (f.secondDuration * 10) <= t ? (this.interval = 10, this.intervalType = "second") : n / (f.secondDuration * 15) <= t ? (this.interval = 15, this.intervalType = "second") : n / (f.secondDuration * 20) <= t ? (this.interval = 20, this.intervalType = "second") : n / (f.secondDuration * 30) <= t ? (this.interval = 30, this.intervalType = "second") : n / (f.minuteDuration * 1) <= t ? (this.interval = 1, this.intervalType = "minute") : n / (f.minuteDuration * 2) <= t ? (this.interval = 2, this.intervalType = "minute") : n / (f.minuteDuration * 5) <= t ? (this.interval = 5, this.intervalType = "minute") : n / (f.minuteDuration * 10) <= t ? (this.interval = 10, this.intervalType = "minute") : n / (f.minuteDuration * 15) <= t ? (this.interval = 15, this.intervalType = "minute") : n / (f.minuteDuration * 20) <= t ? (this.interval = 20, this.intervalType = "minute") : n / (f.minuteDuration * 30) <= t ? (this.interval = 30, this.intervalType = "minute") : n / (f.hourDuration * 1) <= t ? (this.interval = 1, this.intervalType = "hour") : n / (f.hourDuration * 2) <= t ? (this.interval = 2, this.intervalType = "hour") : n / (f.hourDuration * 3) <= t ? (this.interval = 3, this.intervalType = "hour") : n / (f.hourDuration * 6) <= t ? (this.interval = 6, this.intervalType = "hour") : n / (f.dayDuration * 1) <= t ? (this.interval = 1, this.intervalType = "day") : n / (f.dayDuration * 2) <= t ? (this.interval = 2, this.intervalType = "day") : n / (f.dayDuration * 4) <= t ? (this.interval = 4, this.intervalType = "day") : n / (f.weekDuration * 1) <= t ? (this.interval = 1, this.intervalType = "week") : n / (f.weekDuration * 2) <= t ? (this.interval = 2, this.intervalType = "week") : n / (f.weekDuration * 3) <= t ? (this.interval = 3, this.intervalType = "week") : n / (f.monthDuration * 1) <= t ? (this.interval = 1, this.intervalType = "month") : n / (f.monthDuration * 2) <= t ? (this.interval = 2, this.intervalType = "month") : n / (f.monthDuration * 3) <= t ? (this.interval = 3, this.intervalType = "month") : n / (f.monthDuration * 6) <= t ? (this.interval = 6, this.intervalType = "month") : n / (f.yearDuration * 1) <= t ? (this.interval = 1, this.intervalType = "year") : n / (f.yearDuration * 2) <= t ? (this.interval = 2, this.intervalType = "year") : n / (f.yearDuration * 4) <= t ? (this.interval = 4, this.intervalType = "year") : (this.interval = Math.floor(e.getNiceNumber(n / (t - 1), !0) / f.yearDuration), this.intervalType = "year")), this.minimum = this.sessionVariables.internalMinimum !== null ? this.sessionVariables.internalMinimum : r - o / 2, this.maximum = this.sessionVariables.internalMaximum !== null ? this.sessionVariables.internalMaximum : i + o / 2, this.valueFormatString || (l ? this.valueFormatString = "MMM DD YYYY HH:mm" : this.intervalType === "year" ? this.valueFormatString = "YYYY" : this.intervalType === "month" ? this.valueFormatString = "MMM YYYY" : this.intervalType === "week" ? this.valueFormatString = "MMM DD YYYY" : this.intervalType === "day" ? this.valueFormatString = "MMM DD YYYY" : this.intervalType === "hour" ? this.valueFormatString = "hh:mm TT" : this.intervalType === "minute" ? this.valueFormatString = "hh:mm TT" : this.intervalType === "second" ? this.valueFormatString = "hh:mm:ss TT" : this.intervalType === "millisecond" && (this.valueFormatString = "fff'ms'")), this.intervalstartTimePercent = this.getLabelStartPoint(new Date(this.minimum), this.intervalType, this.interval)) : (this.intervalType = "number", n = e.getNiceNumber(i - r, !1), this.interval = this._options && this._options.interval ? this._options.interval : e.getNiceNumber(n / (t - 1), !0), this.minimum = this.sessionVariables.internalMinimum !== null ? this.sessionVariables.internalMinimum : Math.floor(r / this.interval) * this.interval, this.maximum = this.sessionVariables.internalMaximum !== null ? this.sessionVariables.internalMaximum : Math.ceil(i / this.interval) * this.interval, this.maximum === 0 && this.minimum === 0 && (this._options.minimum === 0 ? this.maximum += 10 : this._options.maximum === 0 && (this.minimum -= 10), this._options && typeof this._options.interval == "undefined" && (this.interval = e.getNiceNumber((this.maximum - this.minimum) / (t - 1), !0))), this.type === "axisX" ? (this.sessionVariables.internalMinimum !== null || (this.minimum = r - o / 2), this.sessionVariables.internalMaximum !== null || (this.maximum = i + o / 2), this.intervalstartTimePercent = Math.floor((this.minimum + this.interval * .2) / this.interval) * this.interval) : this.type === "axisY" && (this.intervalstartTimePercent = this.minimum)), this.type === "axisX" && (this._absoluteMinimum = this._options && typeof this._options.minimum != "undefined" ? this._options.minimum : this.dataInfo.min - o / 2, this._absoluteMaximum = this._options && typeof this._options.maximum != "undefined" ? this._options.maximum : this.dataInfo.max + o / 2), !this.valueFormatString && (this.valueFormatString = "#,##0.##", n = Math.abs(this.maximum - this.minimum), n < 1 && (s = Math.floor(Math.abs(Math.log(n) / Math.LN10)) + 2, (isNaN(s) || !isFinite(s)) && (s = 2), s > 2))) for (c = 0; c < s - 2; c++) this.valueFormatString += "#" }; e.getNiceNumber = function(n, t) { var r = Math.floor(Math.log(n) / Math.LN10), i = n / Math.pow(10, r), u; return u = t ? i < 1.5 ? 1 : i < 3 ? 2 : i < 7 ? 5 : 10 : i <= 1 ? 1 : i <= 2 ? 2 : i <= 5 ? 5 : 10, Number((u * Math.pow(10, r)).toFixed(20)) }; e.prototype.getLabelStartPoint = function() { var t = st(this.interval, this.intervalType), i = Math.floor(this.minimum / t) * t, n = new Date(i); return this.intervalType === "millisecond" || (this.intervalType === "second" ? n.getMilliseconds() > 0 && (n.setSeconds(n.getSeconds() + 1), n.setMilliseconds(0)) : this.intervalType === "minute" ? (n.getSeconds() > 0 || n.getMilliseconds() > 0) && (n.setMinutes(n.getMinutes() + 1), n.setSeconds(0), n.setMilliseconds(0)) : this.intervalType === "hour" ? (n.getMinutes() > 0 || n.getSeconds() > 0 || n.getMilliseconds() > 0) && (n.setHours(n.getHours() + 1), n.setMinutes(0), n.setSeconds(0), n.setMilliseconds(0)) : this.intervalType === "day" ? (n.getHours() > 0 || n.getMinutes() > 0 || n.getSeconds() > 0 || n.getMilliseconds() > 0) && (n.setDate(n.getDate() + 1), n.setHours(0), n.setMinutes(0), n.setSeconds(0), n.setMilliseconds(0)) : this.intervalType === "week" ? (n.getDay() > 0 || n.getHours() > 0 || n.getMinutes() > 0 || n.getSeconds() > 0 || n.getMilliseconds() > 0) && (n.setDate(n.getDate() + (7 - n.getDay())), n.setHours(0), n.setMinutes(0), n.setSeconds(0), n.setMilliseconds(0)) : this.intervalType === "month" ? (n.getDate() > 1 || n.getHours() > 0 || n.getMinutes() > 0 || n.getSeconds() > 0 || n.getMilliseconds() > 0) && (n.setMonth(n.getMonth() + 1), n.setDate(1), n.setHours(0), n.setMinutes(0), n.setSeconds(0), n.setMilliseconds(0)) : this.intervalType === "year" && (n.getMonth() > 0 || n.getDate() > 1 || n.getHours() > 0 || n.getMinutes() > 0 || n.getSeconds() > 0 || n.getMilliseconds() > 0) && (n.setFullYear(n.getFullYear() + 1), n.setMonth(0), n.setDate(1), n.setHours(0), n.setMinutes(0), n.setSeconds(0), n.setMilliseconds(0))), n }; w(ti, h); ti.prototype.render = function() { var n = this.parent.getPixelCoordinatesOnAxis(this.value), t = Math.abs(this._thicknessType === "pixel" ? this.thickness : this.parent.conversionParameters.pixelPerUnit * this.thickness), o, s, l, i, r, f, e, h, c; t > 0 && (o = this.opacity === null ? 1 : this.opacity, this.ctx.strokeStyle = this.color, this.ctx.beginPath(), s = this.ctx.globalAlpha, this.ctx.globalAlpha = o, l = u(this.id), this.ctx.lineWidth = t, this.ctx.setLineDash && this.ctx.setLineDash(y(this.lineDashType, t)), this.parent._position === "bottom" || this.parent._position === "top" ? (h = this.ctx.lineWidth % 2 == 1 ? (n.x << 0) + .5 : n.x << 0, i = r = h, f = this.chart.plotArea.y1, e = this.chart.plotArea.y2) : (this.parent._position === "left" || this.parent._position === "right") && (c = this.ctx.lineWidth % 2 == 1 ? (n.y << 0) + .5 : n.y << 0, f = e = c, i = this.chart.plotArea.x1, r = this.chart.plotArea.x2), this.ctx.moveTo(i, f), this.ctx.lineTo(r, e), this.ctx.stroke(), this.ctx.globalAlpha = s) }; w(k, h); k.prototype._initialize = function() { if (this.enabled) { this.container = document.createElement("div"); this.container.setAttribute("class", "canvasjs-chart-tooltip"); this.container.style.position = "absolute"; this.container.style.height = "auto"; this.container.style.boxShadow = "1px 1px 2px 2px rgba(0,0,0,0.1)"; this.container.style.zIndex = "1000"; this.container.style.display = "none"; var t = '
= 0 && (f.dataSeries = this.chart.data[e], f.dataPoint.y !== null && o.push(f)); if (o.length === 0) return; for (o.sort(function(n, t) { return n.distance - t.distance }), p = o[0], e = 0; e < o.length; e++) o[e].dataPoint.x.valueOf() === p.dataPoint.x.valueOf() && r.push(o[e]); o = null } else { if (a = this.chart.getDataPointAtXY(t, i, !0), a) this.currentDataPointIndex = a.dataPointIndex, this.currentSeriesIndex = a.dataSeries.index; else if (n) if (v = ci(t, i, this.chart._eventManager.ghostCtx), v > 0 && typeof this.chart._eventManager.objectMap[v] != "undefined") { if (eventObject = this.chart._eventManager.objectMap[v], eventObject.objectType === "legendItem") return; this.currentSeriesIndex = eventObject.dataSeriesIndex; this.currentDataPointIndex = eventObject.dataPointIndex >= 0 ? eventObject.dataPointIndex : -1 } else this.currentDataPointIndex = -1; else this.currentDataPointIndex = -1; if (this.currentSeriesIndex >= 0) { if (u = this.chart.data[this.currentSeriesIndex], f = {}, this.currentDataPointIndex >= 0) l = u.dataPoints[this.currentDataPointIndex], f.dataSeries = u, f.dataPoint = l, f.index = this.currentDataPointIndex, f.distance = Math.abs(l.x - h); else if (this.enabled && (u.type === "line" || u.type === "stepLine" || u.type === "spline" || u.type === "area" || u.type === "stepArea" || u.type === "splineArea" || u.type === "stackedArea" || u.type === "stackedArea100" || u.type === "rangeArea" || u.type === "rangeSplineArea" || u.type === "candlestick" || u.type === "ohlc")) h = (this.chart.axisX.maximum - this.chart.axisX.minimum) / this.chart.axisX.lineCoordinates.width * (t - this.chart.axisX.lineCoordinates.x1) + this.chart.axisX.minimum.valueOf(), f = u.getDataPointAtX(h, !0), f.dataSeries = u, this.currentDataPointIndex = f.index, l = f.dataPoint; else return; f.dataPoint.y !== null && r.push(f) } } if (r.length > 0 && (this.highlightObjects(r), this.enabled)) if (c = "", c = this.getToolTipInnerHTML({ entries: r }), c !== null) { this.contentDiv.innerHTML = c; this.contentDiv.innerHTML = c; y = !1; this.container.style.display === "none" && (y = !0, this.container.style.display = "block"); try { this.contentDiv.style.background = this.backgroundColor ? this.backgroundColor : n ? "rgba(255,255,255,.9)" : "rgb(255,255,255)"; this.contentDiv.style.borderRightColor = this.contentDiv.style.borderLeftColor = this.contentDiv.style.borderColor = this.borderColor ? this.borderColor : r[0].dataPoint.color ? r[0].dataPoint.color : r[0].dataSeries.color ? r[0].dataSeries.color : r[0].dataSeries._colorSet[r[0].index % r[0].dataSeries._colorSet.length]; this.contentDiv.style.borderWidth = this.borderThickness || this.borderThickness === 0 ? this.borderThickness + "px" : "2px"; this.contentDiv.style.borderRadius = this.cornerRadius || this.cornerRadius === 0 ? this.cornerRadius + "px" : "5px"; this.container.style.borderRadius = this.contentDiv.style.borderRadius; this.contentDiv.style.fontSize = this.fontSize || this.fontSize === 0 ? this.fontSize + "px" : "14px"; this.contentDiv.style.color = this.fontColor ? this.fontColor : "#000000"; this.contentDiv.style.fontFamily = this.fontFamily ? this.fontFamily : "Calibri, Arial, Georgia, serif;"; this.contentDiv.style.fontWeight = this.fontWeight ? this.fontWeight : "normal"; this.contentDiv.style.fontStyle = this.fontStyle ? this.fontStyle : n ? "italic" : "normal" } catch (w) {} toolTipLeft = r[0].dataSeries.type === "pie" || r[0].dataSeries.type === "doughnut" || r[0].dataSeries.type === "funnel" || r[0].dataSeries.type === "bar" || r[0].dataSeries.type === "rangeBar" || r[0].dataSeries.type === "stackedBar" || r[0].dataSeries.type === "stackedBar100" ? t - 10 - this.container.clientWidth : (this.chart.axisX.lineCoordinates.width / Math.abs(this.chart.axisX.maximum - this.chart.axisX.minimum) * Math.abs(r[0].dataPoint.x - this.chart.axisX.minimum) + this.chart.axisX.lineCoordinates.x1 + .5 - this.container.clientWidth << 0) - 10; toolTipLeft < 0 && (toolTipLeft += this.container.clientWidth + 20); toolTipLeft + this.container.clientWidth > this.chart._container.clientWidth && (toolTipLeft = Math.max(0, this.chart._container.clientWidth - this.container.clientWidth)); toolTipLeft += "px"; s = r.length !== 1 || this.shared || r[0].dataSeries.type !== "line" && r[0].dataSeries.type !== "stepLine" && r[0].dataSeries.type !== "spline" && r[0].dataSeries.type !== "area" && r[0].dataSeries.type !== "stepArea" && r[0].dataSeries.type !== "splineArea" && r[0].dataSeries.type !== "stackedArea" && r[0].dataSeries.type !== "stackedArea100" ? r[0].dataSeries.type === "bar" || r[0].dataSeries.type === "rangeBar" || r[0].dataSeries.type === "stackedBar" || r[0].dataSeries.type === "stackedBar100" ? r[0].dataSeries.axisX.lineCoordinates.y2 - r[0].dataSeries.axisX.lineCoordinates.height / Math.abs(r[0].dataSeries.axisX.maximum - r[0].dataSeries.axisX.minimum) * Math.abs(r[0].dataPoint.x - r[0].dataSeries.axisX.minimum) + .5 << 0 : i : r[0].dataSeries.axisY.lineCoordinates.y2 - r[0].dataSeries.axisY.lineCoordinates.height / Math.abs(r[0].dataSeries.axisY.maximum - r[0].dataSeries.axisY.minimum) * Math.abs(r[0].dataPoint.y - r[0].dataSeries.axisY.minimum) + .5 << 0; s = -s + 10; s + this.container.clientHeight + 5 > 0 && (s -= s + this.container.clientHeight + 5 - 0); s += "px"; this.container.style.left = toolTipLeft; this.container.style.bottom = s; !this.animationEnabled || y ? this.disableAnimation() : this.enableAnimation() } else this.hide(!1) } }; k.prototype.highlightObjects = function(n) { var i = this.chart.overlaidCanvasCtx, l, f, e, s, t, u; for (this.chart.resetOverlayedCanvas(), i.save(), l = this.chart.plotArea, f = 0, e = 0; e < n.length; e++) if (s = n[e], t = this.chart._eventManager.objectMap[s.dataSeries.dataPointIds[s.index]], t && t.objectType && t.objectType === "dataPoint") { var r = this.chart.data[t.dataSeriesIndex], c = r.dataPoints[t.dataPointIndex], h = t.dataPointIndex; c.highlightEnabled !== !1 && (r.highlightEnabled === !0 || c.highlightEnabled === !0) && (r.type === "line" || r.type === "stepLine" || r.type === "spline" || r.type === "scatter" || r.type === "area" || r.type === "stepArea" || r.type === "splineArea" || r.type === "stackedArea" || r.type === "stackedArea100" || r.type === "rangeArea" || r.type === "rangeSplineArea" ? (u = r.getMarkerProperties(h, t.x1, t.y1, this.chart.overlaidCanvasCtx), u.size = Math.max(u.size * 1.5 << 0, 10), u.borderColor = u.borderColor || "#FFFFFF", u.borderThickness = u.borderThickness || Math.ceil(u.size * .1), a.drawMarkers([u]), typeof t.y2 != "undefined" && (u = r.getMarkerProperties(h, t.x1, t.y2, this.chart.overlaidCanvasCtx), u.size = Math.max(u.size * 1.5 << 0, 10), u.borderColor = u.borderColor || "#FFFFFF", u.borderThickness = u.borderThickness || Math.ceil(u.size * .1), a.drawMarkers([u]))) : r.type === "bubble" ? (u = r.getMarkerProperties(h, t.x1, t.y1, this.chart.overlaidCanvasCtx), u.size = t.size, u.color = "white", u.borderColor = "white", i.globalAlpha = .3, a.drawMarkers([u]), i.globalAlpha = 1) : r.type === "column" || r.type === "stackedColumn" || r.type === "stackedColumn100" || r.type === "bar" || r.type === "rangeBar" || r.type === "stackedBar" || r.type === "stackedBar100" || r.type === "rangeColumn" ? o(i, t.x1, t.y1, t.x2, t.y2, "white", 0, null, !1, !1, !1, !1, .3) : r.type === "pie" || r.type === "doughnut" ? dt(i, t.center, t.radius, "white", r.type, t.startAngle, t.endAngle, .3) : r.type === "candlestick" ? (i.globalAlpha = 1, i.strokeStyle = t.color, i.lineWidth = t.borderThickness * 2, f = i.lineWidth % 2 == 0 ? 0 : .5, i.beginPath(), i.moveTo(t.x3 - f, t.y2), i.lineTo(t.x3 - f, Math.min(t.y1, t.y4)), i.stroke(), i.beginPath(), i.moveTo(t.x3 - f, Math.max(t.y1, t.y4)), i.lineTo(t.x3 - f, t.y3), i.stroke(), o(i, t.x1, Math.min(t.y1, t.y4), t.x2, Math.max(t.y1, t.y4), "transparent", t.borderThickness * 2, t.color, !1, !1, !1, !1), i.globalAlpha = 1) : r.type === "ohlc" && (i.globalAlpha = 1, i.strokeStyle = t.color, i.lineWidth = t.borderThickness * 2, f = i.lineWidth % 2 == 0 ? 0 : .5, i.beginPath(), i.moveTo(t.x3 - f, t.y2), i.lineTo(t.x3 - f, t.y3), i.stroke(), i.beginPath(), i.moveTo(t.x3, t.y1), i.lineTo(t.x1, t.y1), i.stroke(), i.beginPath(), i.moveTo(t.x3, t.y4), i.lineTo(t.x2, t.y4), i.stroke(), i.globalAlpha = 1)) } i.globalAlpha = 1; i.beginPath(); return }; k.prototype.getToolTipInnerHTML = function(n) { for (var c, s, f = n.entries, r = null, t = null, i = null, o = 0, u = "", h = !0, e = 0; e < f.length; e++) if (f[e].dataSeries.toolTipContent || f[e].dataPoint.toolTipContent) { h = !1; break } if (h && (this.content && typeof this.content == "function" || this.contentFormatter)) c = { chart: this.chart, toolTip: this._options, entries: f }, r = this.contentFormatter ? this.contentFormatter(c) : this.content(c); else if (this.shared && this.chart.plotInfo.axisPlacement !== "none") { for (s = "", e = 0; e < f.length; e++)(t = f[e].dataSeries, i = f[e].dataPoint, o = f[e].index, u = "", e === 0 && h && !this.content && (s += typeof this.chart.axisX.labels[i.x] != "undefined" ? this.chart.axisX.labels[i.x] : "{x}", s += "<\/br>", s = this.chart.replaceKeywordsWithValue(s, i, t, o)), i.toolTipContent !== null && (typeof i.toolTipContent != "undefined" || t._options.toolTipContent !== null)) && (t.type === "line" || t.type === "stepLine" || t.type === "spline" || t.type === "area" || t.type === "stepArea" || t.type === "splineArea" || t.type === "column" || t.type === "bar" || t.type === "scatter" || t.type === "stackedColumn" || t.type === "stackedColumn100" || t.type === "stackedBar" || t.type === "stackedBar100" || t.type === "stackedArea" || t.type === "stackedArea100" ? u += i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "{name}:<\/span>  {y}" : t.type === "bubble" ? u += i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "{name}:<\/span>  {y},   {z}" : t.type === "pie" || t.type === "doughnut" || t.type === "funnel" ? u += i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "  {y}" : t.type === "rangeColumn" || t.type === "rangeBar" || t.type === "rangeArea" || t.type === "rangeSplineArea" ? u += i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "{name}:<\/span>  {y[0]}, {y[1]}" : (t.type === "candlestick" || t.type === "ohlc") && (u += i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "{name}:<\/span>
Open:   {y[0]}
High:    {y[1]}
Low:   {y[2]}
Close:   {y[3]}"), r === null && (r = ""), this.reversed === !0 ? (r = this.chart.replaceKeywordsWithValue(u, i, t, o) + r, e < f.length - 1 && (r = "<\/br>" + r)) : (r += this.chart.replaceKeywordsWithValue(u, i, t, o), e < f.length - 1 && (r += "<\/br>"))); r !== null && (r = s + r) } else { if (t = f[0].dataSeries, i = f[0].dataPoint, o = f[0].index, i.toolTipContent === null || typeof i.toolTipContent == "undefined" && t._options.toolTipContent === null) return null; t.type === "line" || t.type === "stepLine" || t.type === "spline" || t.type === "area" || t.type === "stepArea" || t.type === "splineArea" || t.type === "column" || t.type === "bar" || t.type === "scatter" || t.type === "stackedColumn" || t.type === "stackedColumn100" || t.type === "stackedBar" || t.type === "stackedBar100" || t.type === "stackedArea" || t.type === "stackedArea100" ? u = i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "" + (i.label ? "{label}" : "{x}") + " :<\/span>  {y}" : t.type === "bubble" ? u = i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "" + (i.label ? "{label}" : "{x}") + ":<\/span>  {y},   {z}" : t.type === "pie" || t.type === "doughnut" || t.type === "funnel" ? u = i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : (i.name ? "{name}:  " : i.label ? "{label}:  " : "") + "{y}" : t.type === "rangeColumn" || t.type === "rangeBar" || t.type === "rangeArea" || t.type === "rangeSplineArea" ? u = i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "" + (i.label ? "{label}" : "{x}") + " :<\/span>  {y[0]},  {y[1]}" : (t.type === "candlestick" || t.type === "ohlc") && (u = i.toolTipContent ? i.toolTipContent : t.toolTipContent ? t.toolTipContent : this.content && typeof this.content != "function" ? this.content : "" + (i.label ? "{label}" : "{x}") + "<\/span>
Open:   {y[0]}
High:    {y[1]}
Low:     {y[2]}
Close:   {y[3]}"); r === null && (r = ""); r += this.chart.replaceKeywordsWithValue(u, i, t, o) } return r }; k.prototype.enableAnimation = function() { this.container.style.WebkitTransition || (this.container.style.WebkitTransition = "left .2s ease-out, bottom .2s ease-out", this.container.style.MozTransition = "left .2s ease-out, bottom .2s ease-out", this.container.style.MsTransition = "left .2s ease-out, bottom .2s ease-out", this.container.style.transition = "left .2s ease-out, bottom .2s ease-out") }; k.prototype.disableAnimation = function() { this.container.style.WebkitTransition && (this.container.style.WebkitTransition = "", this.container.style.MozTransition = "", this.container.style.MsTransition = "", this.container.style.transition = "") }; k.prototype.hide = function(n) { this.enabled && (n = typeof n == "undefined" ? !0 : n, this.container.style.display = "none", this.currentSeriesIndex = -1, this._prevX = NaN, this._prevY = NaN, n && this.chart.resetOverlayedCanvas()) }; t.prototype.getPercentAndTotal = function(n, t) { var u = null, r = null, f = null; if (n.type.indexOf("stacked") >= 0) r = 0, u = t.x.getTime ? t.x.getTime() : t.x, u in n.plotUnit.yTotals && (r = n.plotUnit.yTotals[u], f = isNaN(t.y) ? 0 : r === 0 ? 0 : t.y / r * 100); else if (n.type === "pie" || n.type === "doughnut") { for (r = 0, i = 0; i < n.dataPoints.length; i++) isNaN(n.dataPoints[i].y) || (r += n.dataPoints[i].y); f = isNaN(t.y) ? 0 : t.y / r * 100 } return { percent: f, total: r } }; t.prototype.replaceKeywordsWithValue = function(n, t, i, r, u) { var f = this, e, o, l, a; if (u = typeof u == "undefined" ? 0 : u, (i.type.indexOf("stacked") >= 0 || i.type === "pie" || i.type === "doughnut") && (n.indexOf("#percent") >= 0 || n.indexOf("#total") >= 0)) { var s = "#percent", c = "#total", h = this.getPercentAndTotal(i, t); c = h.total ? h.total : c; s = isNaN(h.percent) ? s : h.percent; do { if (e = "", i.percentFormatString) e = i.percentFormatString; else for (e = "#,##0.", o = Math.max(Math.ceil(Math.log(1 / Math.abs(s)) / Math.LN10), 2), (isNaN(o) || !isFinite(o)) && (o = 2), l = 0; l < o; l++) e += "#"; n = n.replace("#percent", it(s, e, f._cultureInfo)); n = n.replace("#total", it(c, i.yValueFormatString ? i.yValueFormatString : "#,##0.########")) } while (n.indexOf("#percent") >= 0 || n.indexOf("#total") >= 0) } return a = function(n) { var e, h, s, c, o; if (n[0] === '"' && n[n.length - 1] === '"' || n[0] === "'" && n[n.length - 1] === "'") return n.slice(1, n.length - 1); e = ht(n.slice(1, n.length - 1)); e = e.replace("#index", u); h = null; try { s = e.match(/(.*?)\s*\[\s*(.*?)\s*\]/); s && s.length > 0 && (h = ht(s[2]), e = ht(s[1])) } catch (l) {} if (c = null, e === "color") return t.color ? t.color : i.color ? i.color : i._colorSet[r % i._colorSet.length]; if (t.hasOwnProperty(e)) c = t; else if (i.hasOwnProperty(e)) c = i; else return ""; return o = c[e], h !== null && (o = o[h]), e === "x" ? f.axisX && f.plotInfo.axisXValueType === "dateTime" ? ii(o, t.xValueFormatString ? t.xValueFormatString : i.xValueFormatString ? i.xValueFormatString : f.axisX && f.axisX.valueFormatString ? f.axisX.valueFormatString : "DD MMM YY", f._cultureInfo) : it(o, t.xValueFormatString ? t.xValueFormatString : i.xValueFormatString ? i.xValueFormatString : "#,##0.########", f._cultureInfo) : e === "y" ? it(o, t.yValueFormatString ? t.yValueFormatString : i.yValueFormatString ? i.yValueFormatString : "#,##0.########", f._cultureInfo) : e === "z" ? it(o, t.zValueFormatString ? t.zValueFormatString : i.zValueFormatString ? i.zValueFormatString : "#,##0.########", f._cultureInfo) : o }, n.replace(/\{.*?\}|"[^"]*"|'[^']*'/g, a) }; at.prototype.reset = function() { this.lastObjectId = 0; this.objectMap = []; this.rectangularRegionEventSubscriptions = []; this.previousDataPointEventObject = null; this.eventObjects = []; n && (this.ghostCtx.clearRect(0, 0, this.chart.width, this.chart.height), this.ghostCtx.beginPath()) }; at.prototype.getNewObjectTrackingId = function() { return ++this.lastObjectId }; at.prototype.mouseEventHandler = function(n) { var t, r, o, h, c, i, l, e; if (n.type === "mousemove" || n.type === "click") { var u = [], f = wt(n), s = null; if (s = this.chart.getObjectAtXY(f.x, f.y, !1), s && typeof this.objectMap[s] != "undefined") if (t = this.objectMap[s], t.objectType === "dataPoint") { var r = this.chart.data[t.dataSeriesIndex], o = r.dataPoints[t.dataPointIndex], a = t.dataPointIndex; t.eventParameter = { x: f.x, y: f.y, dataPoint: o, dataSeries: r._options, dataPointIndex: a, dataSeriesIndex: r.index, chart: this.chart._publicChartReference }; t.eventContext = { context: o, userContext: o, mouseover: "mouseover", mousemove: "mousemove", mouseout: "mouseout", click: "click" }; u.push(t); t = this.objectMap[r.id]; t.eventParameter = { x: f.x, y: f.y, dataPoint: o, dataSeries: r._options, dataPointIndex: a, dataSeriesIndex: r.index, chart: this.chart._publicChartReference }; t.eventContext = { context: r, userContext: r._options, mouseover: "mouseover", mousemove: "mousemove", mouseout: "mouseout", click: "click" }; u.push(this.objectMap[r.id]) } else t.objectType === "legendItem" && (r = this.chart.data[t.dataSeriesIndex], o = t.dataPointIndex !== null ? r.dataPoints[t.dataPointIndex] : null, t.eventParameter = { x: f.x, y: f.y, dataSeries: r._options, dataPoint: o, dataPointIndex: t.dataPointIndex, dataSeriesIndex: t.dataSeriesIndex, chart: this.chart._publicChartReference }, t.eventContext = { context: this.chart.legend, userContext: this.chart.legend._options, mouseover: "itemmouseover", mousemove: "itemmousemove", mouseout: "itemmouseout", click: "itemclick" }, u.push(t)); for (h = [], i = 0; i < this.mouseoveredObjectMaps.length; i++) { for (c = !0, e = 0; e < u.length; e++) if (u[e].id === this.mouseoveredObjectMaps[i].id) { c = !1; break } c ? this.fireEvent(this.mouseoveredObjectMaps[i], "mouseout", n) : h.push(this.mouseoveredObjectMaps[i]) } for (this.mouseoveredObjectMaps = h, i = 0; i < u.length; i++) { for (l = !1, e = 0; e < this.mouseoveredObjectMaps.length; e++) if (u[i].id === this.mouseoveredObjectMaps[e].id) { l = !0; break } l || (this.fireEvent(u[i], "mouseover", n), this.mouseoveredObjectMaps.push(u[i])); n.type === "click" ? this.fireEvent(u[i], "click", n) : n.type === "mousemove" && this.fireEvent(u[i], "mousemove", n) } } }; at.prototype.fireEvent = function(n, t, i) { if (n && t) { var f = n.eventParameter, u = n.eventContext, r = n.eventContext.userContext; r && u && r[u[t]] && r[u[t]].call(r, f); t !== "mouseout" ? r.cursor && r.cursor !== i.target.style.cursor && (i.target.style.cursor = r.cursor) : (i.target.style.cursor = this.chart._defaultCursor, delete n.eventParameter, delete n.eventContext); t === "click" && n.objectType === "dataPoint" && this.chart.pieDoughnutClickHandler && this.chart.pieDoughnutClickHandler.call(this.chart.data[n.dataSeriesIndex], f) } }; w(vt, h); ei.prototype.animate = function(n, t, i, u, f) { var h = this, s; for (this.chart.isAnimating = !0, f = f || r.easing.linear, i && this.animations.push({ startTime: (new Date).getTime() + (n ? n : 0), duration: t, animationCallback: i, onComplete: u }), s = []; this.animations.length > 0;) { var o = this.animations.shift(), c = (new Date).getTime(), e = 0; o.startTime <= c && (e = f(Math.min(c - o.startTime, o.duration), 0, 1, o.duration), e = Math.min(e, 1), (isNaN(e) || !isFinite(e)) && (e = 1)); e < 1 && s.push(o); o.animationCallback(e); e >= 1 && o.onComplete && o.onComplete() } this.animations = s; this.animations.length > 0 ? this.animationRequestId = this.chart.requestAnimFrame.call(window, function() { h.animate.call(h) }) : this.chart.isAnimating = !1 }; ei.prototype.cancelAllAnimations = function() { this.animations = []; this.animationRequestId && this.chart.cancelRequestAnimFrame.call(window, this.animationRequestId); this.animationRequestId = null; this.chart.isAnimating = !1 }; var r = { yScaleAnimation: function(n, t) { if (n !== 0) { var i = t.dest, r = t.source.canvas, u = t.animationBase, f = u - u * n; i.drawImage(r, 0, 0, r.width, r.height, 0, f, i.canvas.width / l, n * i.canvas.height / l) } }, xScaleAnimation: function(n, t) { if (n !== 0) { var i = t.dest, r = t.source.canvas, u = t.animationBase, f = u - u * n; i.drawImage(r, 0, 0, r.width, r.height, f, 0, n * i.canvas.width / l, i.canvas.height / l) } }, xClipAnimation: function(n, t) { if (n !== 0) { var r = t.dest, i = t.source.canvas; r.save(); n > 0 && r.drawImage(i, 0, 0, i.width * n, i.height, 0, 0, i.width * n / l, i.height / l); r.restore() } }, fadeInAnimation: function(n, t) { if (n !== 0) { var i = t.dest, r = t.source.canvas; i.save(); i.globalAlpha = n; i.drawImage(r, 0, 0, r.width, r.height, 0, 0, i.canvas.width / l, i.canvas.height / l); i.restore() } }, easing: { linear: function(n, t, i, r) { return i * n / r + t }, easeOutQuad: function(n, t, i, r) { return -i * (n /= r) * (n - 2) + t }, easeOutQuart: function(n, t, i, r) { return -i * ((n = n / r - 1) * n * n * n - 1) + t }, easeInQuad: function(n, t, i, r) { return i * (n /= r) * n + t }, easeInQuart: function(n, t, i, r) { return i * (n /= r) * n * n * n + t } } }, a = { drawMarker: function(n, t, i, r, u, f, e, o) { if (i) { var s = 1; i.fillStyle = f ? f : "#000000"; i.strokeStyle = e ? e : "#000000"; i.lineWidth = o ? o : 0; r === "circle" ? (i.moveTo(n, t), i.beginPath(), i.arc(n, t, u / 2, 0, Math.PI * 2, !1), f && i.fill(), o && (e ? i.stroke() : (s = i.globalAlpha, i.globalAlpha = .15, i.strokeStyle = "black", i.stroke(), i.globalAlpha = s))) : r === "square" ? (i.beginPath(), i.rect(n - u / 2, t - u / 2, u, u), f && i.fill(), o && (e ? i.stroke() : (s = i.globalAlpha, i.globalAlpha = .15, i.strokeStyle = "black", i.stroke(), i.globalAlpha = s))) : r === "triangle" ? (i.beginPath(), i.moveTo(n - u / 2, t + u / 2), i.lineTo(n + u / 2, t + u / 2), i.lineTo(n, t - u / 2), i.closePath(), f && i.fill(), o && (e ? i.stroke() : (s = i.globalAlpha, i.globalAlpha = .15, i.strokeStyle = "black", i.stroke(), i.globalAlpha = s)), i.beginPath()) : r === "cross" && (i.strokeStyle = f, o = u / 4, i.lineWidth = o, i.beginPath(), i.moveTo(n - u / 2, t - u / 2), i.lineTo(n + u / 2, t + u / 2), i.stroke(), i.moveTo(n + u / 2, t - u / 2), i.lineTo(n - u / 2, t + u / 2), i.stroke()) } }, drawMarkers: function(n) { for (var t, i = 0; i < n.length; i++) t = n[i], a.drawMarker(t.x, t.y, t.ctx, t.type, t.size, t.color, t.borderColor, t.borderThickness) } }, vi = { Chart: function(n, i) { var r = new t(n, i, this); this.render = function() { r.render(this.options) }; this.options = r._options }, addColorSet: function(n, t) { tt[n] = t }, addCultureInfo: function(n, t) { ot[n] = t }, formatNumber: function(n, t, i) { if (i = i || "en", t = t || "#,##0.##", ot[i]) return it(n, t, new vt(i)); throw "Unknown Culture Name"; }, formatDate: function(n, t, i) { if (i = i || "en", t = t || "DD MMM YYYY", ot[i]) return ii(n, t, new vt(i)); throw "Unknown Culture Name"; } }; vi.Chart.version = "v1.7.0 GA"; window.CanvasJS = vi })();