TIF_E41211408/public/assets/assetLanding/js/canvasjs.min.js

22994 lines
829 KiB
JavaScript

/*
CanvasJS HTML5 & JavaScript Charts - v2.3.1 GA - https://canvasjs.com/
Copyright 2018 fenopix
--------------------- License Information --------------------
CanvasJS is a commercial product which requires purchase of license. Without a commercial license you can use it for evaluation purposes for upto 30 days. Please refer to the following link for further details.
https://canvasjs.com/license/
*/
/*eslint-disable*/
/*jshint ignore:start*/
(function () {
function qa(k, p) {
k.prototype = eb(p.prototype);
k.prototype.constructor = k;
k.base = p.prototype;
}
function eb(k) {
function p() {}
p.prototype = k;
return new p();
}
function Ya(k, p, D) {
"millisecond" === D
? k.setMilliseconds(k.getMilliseconds() + 1 * p)
: "second" === D
? k.setSeconds(k.getSeconds() + 1 * p)
: "minute" === D
? k.setMinutes(k.getMinutes() + 1 * p)
: "hour" === D
? k.setHours(k.getHours() + 1 * p)
: "day" === D
? k.setDate(k.getDate() + 1 * p)
: "week" === D
? k.setDate(k.getDate() + 7 * p)
: "month" === D
? k.setMonth(k.getMonth() + 1 * p)
: "year" === D && k.setFullYear(k.getFullYear() + 1 * p);
return k;
}
function $(k, p) {
var D = !1;
0 > k && ((D = !0), (k *= -1));
k = "" + k;
for (p = p ? p : 1; k.length < p; ) k = "0" + k;
return D ? "-" + k : k;
}
function Ia(k) {
if (!k) return k;
k = k.replace(/^\s\s*/, "");
for (var p = /\s/, D = k.length; p.test(k.charAt(--D)); );
return k.slice(0, D + 1);
}
function Ea(k) {
k.roundRect = function (k, D, r, u, H, F, z, v) {
z && (this.fillStyle = z);
v && (this.strokeStyle = v);
"undefined" === typeof H && (H = 5);
this.lineWidth = F;
this.beginPath();
this.moveTo(k + H, D);
this.lineTo(k + r - H, D);
this.quadraticCurveTo(k + r, D, k + r, D + H);
this.lineTo(k + r, D + u - H);
this.quadraticCurveTo(k + r, D + u, k + r - H, D + u);
this.lineTo(k + H, D + u);
this.quadraticCurveTo(k, D + u, k, D + u - H);
this.lineTo(k, D + H);
this.quadraticCurveTo(k, D, k + H, D);
this.closePath();
z && this.fill();
v && 0 < F && this.stroke();
};
}
function Sa(k, p) {
return k - p;
}
function Ta(k, p, D) {
if (k && p && D) {
D = D + "." + p;
var r = "image/" + p;
k = k.toDataURL(r);
var u = !1,
H = document.createElement("a");
H.download = D;
H.href = k;
if ("undefined" !== typeof Blob && new Blob()) {
for (
var F = k.replace(/^data:[a-z\/]*;base64,/, ""),
F = atob(F),
z = new ArrayBuffer(F.length),
z = new Uint8Array(z),
v = 0;
v < F.length;
v++
)
z[v] = F.charCodeAt(v);
p = new Blob([z.buffer], { type: "image/" + p });
try {
window.navigator.msSaveBlob(p, D), (u = !0);
} catch (L) {
(H.dataset.downloadurl = [r, H.download, H.href].join(":")),
(H.href = window.URL.createObjectURL(p));
}
}
if (!u)
try {
(event = document.createEvent("MouseEvents")),
event.initMouseEvent(
"click",
!0,
!1,
window,
0,
0,
0,
0,
0,
!1,
!1,
!1,
!1,
0,
null
),
H.dispatchEvent
? H.dispatchEvent(event)
: H.fireEvent && H.fireEvent("onclick");
} catch (E) {
(p = window.open()),
p.document.write(
"<img src='" +
k +
"'></img><div>Please right click on the image and save it to your device</div>"
),
p.document.close();
}
}
}
function N(k) {
var p = ((k & 16711680) >> 16).toString(16),
D = ((k & 65280) >> 8).toString(16);
k = ((k & 255) >> 0).toString(16);
p = 2 > p.length ? "0" + p : p;
D = 2 > D.length ? "0" + D : D;
k = 2 > k.length ? "0" + k : k;
return "#" + p + D + k;
}
function fb(k, p) {
var D = this.length >>> 0,
r = Number(p) || 0,
r = 0 > r ? Math.ceil(r) : Math.floor(r);
for (0 > r && (r += D); r < D; r++)
if (r in this && this[r] === k) return r;
return -1;
}
function u(k) {
return null === k || "undefined" === typeof k;
}
function Fa(k) {
k.indexOf || (k.indexOf = fb);
return k;
}
function gb(k) {
if (U.fSDec)
k[ja("`eeDwdouMhrudods")](ja("e`u`@ohl`uhnoHuds`uhnoDoe"), function () {
U._fTWm && U._fTWm(k);
});
}
function Za(k, p, D) {
D = D || "normal";
var r = k + "_" + p + "_" + D,
u = $a[r];
if (isNaN(u)) {
try {
k =
"position:absolute; left:0px; top:-20000px; padding:0px;margin:0px;border:none;white-space:pre;line-height:normal;font-family:" +
k +
"; font-size:" +
p +
"px; font-weight:" +
D +
";";
if (!xa) {
var H = document.body;
xa = document.createElement("span");
xa.innerHTML = "";
var F = document.createTextNode("Mpgyi");
xa.appendChild(F);
H.appendChild(xa);
}
xa.style.display = "";
xa.setAttribute("style", k);
u = Math.round(xa.offsetHeight);
xa.style.display = "none";
} catch (z) {
u = Math.ceil(1.1 * p);
}
u = Math.max(u, p);
$a[r] = u;
}
return u;
}
function R(k, p) {
var D = [];
if (
(D = {
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],
}[k || "solid"])
)
for (var r = 0; r < D.length; r++) D[r] *= p;
else D = [];
return D;
}
function O(k, p, D, r, u) {
r = r || [];
u = u || !1;
r.push([k, p, D, u]);
return k.addEventListener
? (k.addEventListener(p, D, u), D)
: k.attachEvent
? ((r = function (p) {
p = p || window.event;
p.preventDefault =
p.preventDefault ||
function () {
p.returnValue = !1;
};
p.stopPropagation =
p.stopPropagation ||
function () {
p.cancelBubble = !0;
};
D.call(k, p);
}),
k.attachEvent("on" + p, r),
r)
: !1;
}
function ab(k, p, D) {
k *= W;
p *= W;
k = D.getImageData(k, p, 2, 2).data;
p = !0;
for (D = 0; 4 > D; D++)
if ((k[D] !== k[D + 4]) | (k[D] !== k[D + 8]) | (k[D] !== k[D + 12])) {
p = !1;
break;
}
return p ? (k[0] << 16) | (k[1] << 8) | k[2] : 0;
}
function na(k, p, D) {
return k in p ? p[k] : D[k];
}
function Oa(k, p, D) {
if (r && bb) {
var u = k.getContext("2d");
Pa =
u.webkitBackingStorePixelRatio ||
u.mozBackingStorePixelRatio ||
u.msBackingStorePixelRatio ||
u.oBackingStorePixelRatio ||
u.backingStorePixelRatio ||
1;
W = Ua / Pa;
k.width = p * W;
k.height = D * W;
Ua !== Pa &&
((k.style.width = p + "px"),
(k.style.height = D + "px"),
u.scale(W, W));
} else (k.width = p), (k.height = D);
}
function hb(k) {
if (!ib) {
var p = !1,
D = !1;
"undefined" === typeof ra.Chart.creditHref
? ((k.creditHref = ja("iuuqr;..b`ow`rkr/bnl.")),
(k.creditText = ja("B`ow`rKR/bnl")))
: ((p = k.updateOption("creditText")),
(D = k.updateOption("creditHref")));
if (k.creditHref && k.creditText) {
k._creditLink ||
((k._creditLink = document.createElement("a")),
k._creditLink.setAttribute("class", "canvasjs-chart-credit"),
k._creditLink.setAttribute("title", "JavaScript Charts"),
k._creditLink.setAttribute(
"style",
"outline:none;margin:0px;position:absolute;right:2px;top:" +
(k.height - 14) +
"px;color:dimgrey;text-decoration:none;font-size:11px;font-family: Calibri, Lucida Grande, Lucida Sans Unicode, Arial, sans-serif"
),
k._creditLink.setAttribute("tabIndex", -1),
k._creditLink.setAttribute("target", "_blank"));
if (0 === k.renderCount || p || D)
k._creditLink.setAttribute("href", k.creditHref),
(k._creditLink.innerHTML = k.creditText);
k._creditLink && k.creditHref && k.creditText
? (k._creditLink.parentElement ||
k._canvasJSContainer.appendChild(k._creditLink),
(k._creditLink.style.top = k.height - 14 + "px"))
: k._creditLink.parentElement &&
k._canvasJSContainer.removeChild(k._creditLink);
}
}
}
function ta(k, p) {
Ja && ((this.canvasCount |= 0), window.console.log(++this.canvasCount));
var D = document.createElement("canvas");
D.setAttribute("class", "canvasjs-chart-canvas");
Oa(D, k, p);
r ||
"undefined" === typeof G_vmlCanvasManager ||
G_vmlCanvasManager.initElement(D);
return D;
}
function sa(k, p, D) {
for (var r in D) p.style[r] = D[r];
}
function ua(k, p, D) {
p.getAttribute("state") ||
((p.style.backgroundColor = k.toolbar.backgroundColor),
(p.style.color = k.toolbar.fontColor),
(p.style.border = "none"),
sa(k, p, {
WebkitUserSelect: "none",
MozUserSelect: "none",
msUserSelect: "none",
userSelect: "none",
}));
p.getAttribute("state") !== D &&
(p.setAttribute("state", D),
p.setAttribute("type", "button"),
sa(k, p, {
padding: "5px 12px",
cursor: "pointer",
float: "left",
width: "40px",
height: "25px",
outline: "0px",
verticalAlign: "baseline",
lineHeight: "0",
}),
p.setAttribute("title", k._cultureInfo[D + "Text"]),
(p.innerHTML =
"<img style='height:95%; pointer-events: none;' src='" +
jb[D].image +
"' alt='" +
k._cultureInfo[D + "Text"] +
"' />"));
}
function Qa() {
for (var k = null, p = 0; p < arguments.length; p++)
(k = arguments[p]), k.style && (k.style.display = "inline");
}
function va() {
for (var k = null, p = 0; p < arguments.length; p++)
(k = arguments[p]) && k.style && (k.style.display = "none");
}
function V(k, p, D, r, v) {
this._defaultsKey = k;
this._themeOptionsKey = p;
this._index = r;
this.parent = v;
this._eventListeners = [];
k = {};
this.theme && u(p) && u(r)
? (k = u(ya[this.theme]) ? ya.light1 : ya[this.theme])
: this.parent &&
this.parent.themeOptions &&
this.parent.themeOptions[p] &&
(null === r
? (k = this.parent.themeOptions[p])
: 0 < this.parent.themeOptions[p].length &&
((r = Math.min(this.parent.themeOptions[p].length - 1, r)),
(k = this.parent.themeOptions[p][r])));
this.themeOptions = k;
this.options = D ? D : { _isPlaceholder: !0 };
this.setOptions(this.options, k);
}
function Ga(k, p, r, u, v) {
"undefined" === typeof v && (v = 0);
this._padding = v;
this._x1 = k;
this._y1 = p;
this._x2 = r;
this._y2 = u;
this._rightOccupied =
this._leftOccupied =
this._bottomOccupied =
this._topOccupied =
this._padding;
}
function ka(k, p) {
ka.base.constructor.call(this, "TextBlock", null, p, null, null);
this.ctx = k;
this._isDirty = !0;
this._wrappedText = null;
this._initialize();
}
function Va(k, p) {
Va.base.constructor.call(this, "Toolbar", "toolbar", p, null, k);
this.chart = k;
this.canvas = k.canvas;
this.ctx = this.chart.ctx;
this.optionsName = "toolbar";
}
function Aa(k, p) {
Aa.base.constructor.call(this, "Title", "title", p, null, k);
this.chart = k;
this.canvas = k.canvas;
this.ctx = this.chart.ctx;
this.optionsName = "title";
if (u(this.options.margin) && k.options.subtitles)
for (var r = k.options.subtitles, za = 0; za < r.length; za++)
if (
((u(r[za].horizontalAlign) && "center" === this.horizontalAlign) ||
r[za].horizontalAlign === this.horizontalAlign) &&
((u(r[za].verticalAlign) && "top" === this.verticalAlign) ||
r[za].verticalAlign === this.verticalAlign) &&
!r[za].dockInsidePlotArea === !this.dockInsidePlotArea
) {
this.margin = 0;
break;
}
"undefined" === typeof this.options.fontSize &&
(this.fontSize = this.chart.getAutoFontSize(this.fontSize));
this.height = this.width = null;
this.bounds = { x1: null, y1: null, x2: null, y2: null };
}
function Ka(k, p, r) {
Ka.base.constructor.call(this, "Subtitle", "subtitles", p, r, k);
this.chart = k;
this.canvas = k.canvas;
this.ctx = this.chart.ctx;
this.optionsName = "subtitles";
this.isOptionsInArray = !0;
"undefined" === typeof this.options.fontSize &&
(this.fontSize = this.chart.getAutoFontSize(this.fontSize));
this.height = this.width = null;
this.bounds = { x1: null, y1: null, x2: null, y2: null };
}
function Wa() {
this.pool = [];
}
function La(k) {
var p;
k && Ma[k] && (p = Ma[k]);
La.base.constructor.call(this, "CultureInfo", null, p, null, null);
}
var Ja = !1,
U = {},
r = !!document.createElement("canvas").getContext,
ra = {
Chart: {
width: 500,
height: 400,
zoomEnabled: !1,
zoomType: "x",
backgroundColor: "white",
theme: "light1",
animationEnabled: !1,
animationDuration: 1200,
dataPointWidth: null,
dataPointMinWidth: null,
dataPointMaxWidth: null,
colorSet: "colorSet1",
culture: "en",
creditHref: "",
creditText: "CanvasJS",
interactivityEnabled: !0,
exportEnabled: !1,
exportFileName: "Chart",
rangeChanging: null,
rangeChanged: null,
publicProperties: {
title: "readWrite",
subtitles: "readWrite",
toolbar: "readWrite",
toolTip: "readWrite",
legend: "readWrite",
axisX: "readWrite",
axisY: "readWrite",
axisX2: "readWrite",
axisY2: "readWrite",
data: "readWrite",
options: "readWrite",
bounds: "readOnly",
container: "readOnly",
},
},
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: r ? "transparent" : null,
margin: 5,
wrap: !0,
maxWidth: null,
dockInsidePlotArea: !1,
publicProperties: {
options: "readWrite",
bounds: "readOnly",
chart: "readOnly",
},
},
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,
publicProperties: {
options: "readWrite",
bounds: "readOnly",
chart: "readOnly",
},
},
Toolbar: {
backgroundColor: "white",
backgroundColorOnHover: "#2196f3",
borderColor: "#2196f3",
borderThickness: 1,
fontColor: "black",
fontColorOnHover: "white",
publicProperties: { options: "readWrite", chart: "readOnly" },
},
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,
backgroundColor: r ? "transparent" : null,
borderColor: r ? "transparent" : null,
borderThickness: 0,
cornerRadius: 0,
maxWidth: null,
maxHeight: null,
markerMargin: null,
itemMaxWidth: null,
itemWidth: null,
itemWrap: !0,
itemTextFormatter: null,
publicProperties: {
options: "readWrite",
bounds: "readOnly",
chart: "readOnly",
},
},
ToolTip: {
enabled: !0,
shared: !1,
animationEnabled: !0,
content: null,
contentFormatter: null,
reversed: !1,
backgroundColor: r ? "rgba(255,255,255,.9)" : "rgb(255,255,255)",
borderColor: null,
borderThickness: 2,
cornerRadius: 5,
fontSize: 14,
fontColor: "black",
fontFamily: "Calibri, Arial, Georgia, serif;",
fontWeight: "normal",
fontStyle: "italic",
publicProperties: { options: "readWrite", chart: "readOnly" },
},
Axis: {
minimum: null,
maximum: null,
viewportMinimum: null,
viewportMaximum: null,
interval: null,
intervalType: null,
reversed: !1,
logarithmic: !1,
logarithmBase: 10,
title: null,
titleFontColor: "black",
titleFontSize: 20,
titleFontFamily: "arial",
titleFontWeight: "normal",
titleFontStyle: "normal",
titleWrap: !0,
titleMaxWidth: null,
titleBackgroundColor: r ? "transparent" : null,
titleBorderColor: r ? "transparent" : null,
titleBorderThickness: 0,
titleCornerRadius: 0,
labelAngle: 0,
labelFontFamily: "arial",
labelFontColor: "black",
labelFontSize: 12,
labelFontWeight: "normal",
labelFontStyle: "normal",
labelAutoFit: !0,
labelWrap: !0,
labelMaxWidth: null,
labelFormatter: null,
labelBackgroundColor: r ? "transparent" : null,
labelBorderColor: r ? "transparent" : null,
labelBorderThickness: 0,
labelCornerRadius: 0,
labelPlacement: "outside",
prefix: "",
suffix: "",
includeZero: !0,
tickLength: 5,
tickColor: "black",
tickThickness: 1,
lineColor: "black",
lineThickness: 1,
lineDashType: "solid",
gridColor: "A0A0A0",
gridThickness: 0,
gridDashType: "solid",
interlacedColor: r ? "transparent" : null,
valueFormatString: null,
margin: 2,
publicProperties: {
options: "readWrite",
stripLines: "readWrite",
scaleBreaks: "readWrite",
crosshair: "readWrite",
bounds: "readOnly",
chart: "readOnly",
},
},
StripLine: {
value: null,
startValue: null,
endValue: null,
color: "orange",
opacity: null,
thickness: 2,
lineDashType: "solid",
label: "",
labelPlacement: "inside",
labelAlign: "far",
labelWrap: !0,
labelMaxWidth: null,
labelBackgroundColor: null,
labelBorderColor: r ? "transparent" : null,
labelBorderThickness: 0,
labelCornerRadius: 0,
labelFontFamily: "arial",
labelFontColor: "orange",
labelFontSize: 12,
labelFontWeight: "normal",
labelFontStyle: "normal",
labelFormatter: null,
showOnTop: !1,
publicProperties: {
options: "readWrite",
axis: "readOnly",
bounds: "readOnly",
chart: "readOnly",
},
},
ScaleBreaks: {
autoCalculate: !1,
collapsibleThreshold: "25%",
maxNumberOfAutoBreaks: 2,
spacing: 8,
type: "straight",
color: "#FFFFFF",
fillOpacity: 0.9,
lineThickness: 2,
lineColor: "#E16E6E",
lineDashType: "solid",
publicProperties: {
options: "readWrite",
customBreaks: "readWrite",
axis: "readOnly",
autoBreaks: "readOnly",
bounds: "readOnly",
chart: "readOnly",
},
},
Break: {
startValue: null,
endValue: null,
spacing: 8,
type: "straight",
color: "#FFFFFF",
fillOpacity: 0.9,
lineThickness: 2,
lineColor: "#E16E6E",
lineDashType: "solid",
publicProperties: {
options: "readWrite",
scaleBreaks: "readOnly",
bounds: "readOnly",
chart: "readOnly",
},
},
Crosshair: {
enabled: !1,
snapToDataPoint: !1,
color: "grey",
opacity: null,
thickness: 2,
lineDashType: "solid",
label: "",
labelWrap: !0,
labelMaxWidth: null,
labelBackgroundColor: r ? "grey" : null,
labelBorderColor: r ? "grey" : null,
labelBorderThickness: 0,
labelCornerRadius: 0,
labelFontFamily: r
? "Calibri, Optima, Candara, Verdana, Geneva, sans-serif"
: "calibri",
labelFontSize: 12,
labelFontColor: "#fff",
labelFontWeight: "normal",
labelFontStyle: "normal",
labelFormatter: null,
valueFormatString: null,
publicProperties: {
options: "readWrite",
axis: "readOnly",
bounds: "readOnly",
chart: "readOnly",
},
},
DataSeries: {
name: null,
dataPoints: null,
label: "",
bevelEnabled: !1,
highlightEnabled: !0,
cursor: "default",
indexLabel: "",
indexLabelPlacement: "auto",
indexLabelOrientation: "horizontal",
indexLabelFontColor: "black",
indexLabelFontSize: 12,
indexLabelFontStyle: "normal",
indexLabelFontFamily: "Arial",
indexLabelFontWeight: "normal",
indexLabelBackgroundColor: null,
indexLabelLineColor: "gray",
indexLabelLineThickness: 1,
indexLabelLineDashType: "solid",
indexLabelMaxWidth: null,
indexLabelWrap: !0,
indexLabelFormatter: null,
lineThickness: 2,
lineDashType: "solid",
connectNullData: !1,
nullDataLineDashType: "dash",
color: null,
lineColor: null,
risingColor: "white",
fallingColor: "red",
fillOpacity: null,
startAngle: 0,
radius: null,
innerRadius: null,
neckHeight: null,
neckWidth: null,
reversed: !1,
valueRepresents: null,
linkedDataSeriesIndex: null,
whiskerThickness: 2,
whiskerDashType: "solid",
whiskerColor: null,
whiskerLength: null,
stemThickness: 2,
stemColor: null,
stemDashType: "solid",
upperBoxColor: "white",
lowerBoxColor: "white",
type: "column",
xValueType: "number",
axisXType: "primary",
axisYType: "primary",
axisXIndex: 0,
axisYIndex: 0,
xValueFormatString: null,
yValueFormatString: null,
zValueFormatString: null,
percentFormatString: null,
showInLegend: null,
legendMarkerType: null,
legendMarkerColor: null,
legendText: null,
legendMarkerBorderColor: r ? "transparent" : null,
legendMarkerBorderThickness: 0,
markerType: "circle",
markerColor: null,
markerSize: null,
markerBorderColor: r ? "transparent" : null,
markerBorderThickness: 0,
mouseover: null,
mouseout: null,
mousemove: null,
click: null,
toolTipContent: null,
visible: !0,
publicProperties: {
options: "readWrite",
axisX: "readWrite",
axisY: "readWrite",
chart: "readOnly",
},
},
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 JPEG",
savePNGText: "Save as PNG",
printText: "Print",
days: "Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(
" "
),
shortDays: "Sun Mon Tue Wed Thu Fri Sat".split(" "),
months:
"January February March April May June July August September October November December".split(
" "
),
shortMonths: "Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec".split(
" "
),
},
},
Ma = { en: {} },
v = r ? "Trebuchet MS, Helvetica, sans-serif" : "Arial",
Ha = r ? "Impact, Charcoal, sans-serif" : "Arial",
Ba = {
colorSet1:
"#4F81BC #C0504E #9BBB58 #23BFAA #8064A1 #4AACC5 #F79647 #7F6084 #77A033 #33558B #E59566".split(
" "
),
colorSet2:
"#6D78AD #51CDA0 #DF7970 #4C9CA0 #AE7D99 #C9D45C #5592AD #DF874D #52BCA8 #8E7AA3 #E3CB64 #C77B85 #C39762 #8DD17E #B57952 #FCC26C".split(
" "
),
colorSet3:
"#8CA1BC #36845C #017E82 #8CB9D0 #708C98 #94838D #F08891 #0366A7 #008276 #EE7757 #E5BA3A #F2990B #03557B #782970".split(
" "
),
},
I,
fa,
Q,
ha,
ga;
fa = "#333333";
Q = "#000000";
I = "#666666";
ga = ha = "#000000";
var X = 20,
E = 14,
Xa = {
colorSet: "colorSet1",
backgroundColor: "#FFFFFF",
title: {
fontFamily: Ha,
fontSize: 32,
fontColor: fa,
fontWeight: "normal",
verticalAlign: "top",
margin: 5,
},
subtitles: [
{
fontFamily: Ha,
fontSize: E,
fontColor: fa,
fontWeight: "normal",
verticalAlign: "top",
margin: 5,
},
],
data: [
{
indexLabelFontFamily: v,
indexLabelFontSize: E,
indexLabelFontColor: fa,
indexLabelFontWeight: "normal",
indexLabelLineThickness: 1,
},
],
axisX: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: fa,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 0,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#EEEEEE",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#BBBBBB",
lineThickness: 1,
lineDashType: "solid",
},
},
],
axisX2: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: fa,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 0,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#EEEEEE",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#BBBBBB",
lineThickness: 1,
lineDashType: "solid",
},
},
],
axisY: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: fa,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 1,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#EEEEEE",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#BBBBBB",
lineThickness: 1,
lineDashType: "solid",
},
},
],
axisY2: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: fa,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 1,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#EEEEEE",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#BBBBBB",
lineThickness: 1,
lineDashType: "solid",
},
},
],
legend: {
fontFamily: v,
fontSize: 14,
fontColor: fa,
fontWeight: "bold",
verticalAlign: "bottom",
horizontalAlign: "center",
},
toolTip: {
fontFamily: v,
fontSize: 14,
fontStyle: "normal",
cornerRadius: 0,
borderThickness: 1,
},
};
Q = fa = "#F5F5F5";
I = "#FFFFFF";
ha = "#40BAF1";
ga = "#F5F5F5";
var X = 20,
E = 14,
cb = {
colorSet: "colorSet2",
title: {
fontFamily: v,
fontSize: 33,
fontColor: "#3A3A3A",
fontWeight: "bold",
verticalAlign: "top",
margin: 5,
},
subtitles: [
{
fontFamily: v,
fontSize: E,
fontColor: "#3A3A3A",
fontWeight: "normal",
verticalAlign: "top",
margin: 5,
},
],
data: [
{
indexLabelFontFamily: v,
indexLabelFontSize: E,
indexLabelFontColor: "#666666",
indexLabelFontWeight: "normal",
indexLabelLineThickness: 1,
},
],
axisX: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: "#666666",
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#666666",
labelFontWeight: "normal",
lineThickness: 1,
lineColor: "#BBBBBB",
tickThickness: 1,
tickColor: "#BBBBBB",
gridThickness: 1,
gridColor: "#BBBBBB",
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FFA500",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FFA500",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#EEEEEE",
labelFontWeight: "normal",
labelBackgroundColor: "black",
color: "black",
thickness: 1,
lineDashType: "dot",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#BBBBBB",
lineThickness: 1,
lineDashType: "solid",
},
},
],
axisX2: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: "#666666",
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#666666",
labelFontWeight: "normal",
lineThickness: 1,
lineColor: "#BBBBBB",
tickColor: "#BBBBBB",
tickThickness: 1,
gridThickness: 1,
gridColor: "#BBBBBB",
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FFA500",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FFA500",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#EEEEEE",
labelFontWeight: "normal",
labelBackgroundColor: "black",
color: "black",
thickness: 1,
lineDashType: "dot",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#BBBBBB",
lineThickness: 1,
lineDashType: "solid",
},
},
],
axisY: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: "#666666",
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#666666",
labelFontWeight: "normal",
lineThickness: 0,
lineColor: "#BBBBBB",
tickColor: "#BBBBBB",
tickThickness: 1,
gridThickness: 1,
gridColor: "#BBBBBB",
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FFA500",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FFA500",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#EEEEEE",
labelFontWeight: "normal",
labelBackgroundColor: "black",
color: "black",
thickness: 1,
lineDashType: "dot",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#BBBBBB",
lineThickness: 1,
lineDashType: "solid",
},
},
],
axisY2: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: "#666666",
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#666666",
labelFontWeight: "normal",
lineThickness: 0,
lineColor: "#BBBBBB",
tickColor: "#BBBBBB",
tickThickness: 1,
gridThickness: 1,
gridColor: "#BBBBBB",
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FFA500",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FFA500",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#EEEEEE",
labelFontWeight: "normal",
labelBackgroundColor: "black",
color: "black",
thickness: 1,
lineDashType: "dot",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#BBBBBB",
lineThickness: 1,
lineDashType: "solid",
},
},
],
legend: {
fontFamily: v,
fontSize: 14,
fontColor: "#3A3A3A",
fontWeight: "bold",
verticalAlign: "bottom",
horizontalAlign: "center",
},
toolTip: {
fontFamily: v,
fontSize: 14,
fontStyle: "normal",
cornerRadius: 0,
borderThickness: 1,
},
};
Q = fa = "#F5F5F5";
I = "#FFFFFF";
ha = "#40BAF1";
ga = "#F5F5F5";
X = 20;
E = 14;
Ha = {
colorSet: "colorSet12",
backgroundColor: "#2A2A2A",
title: {
fontFamily: Ha,
fontSize: 32,
fontColor: fa,
fontWeight: "normal",
verticalAlign: "top",
margin: 5,
},
subtitles: [
{
fontFamily: Ha,
fontSize: E,
fontColor: fa,
fontWeight: "normal",
verticalAlign: "top",
margin: 5,
},
],
toolbar: {
backgroundColor: "#666666",
backgroundColorOnHover: "#FF7372",
borderColor: "#FF7372",
borderThickness: 1,
fontColor: "#F5F5F5",
fontColorOnHover: "#F5F5F5",
},
data: [
{
indexLabelFontFamily: v,
indexLabelFontSize: E,
indexLabelFontColor: Q,
indexLabelFontWeight: "normal",
indexLabelLineThickness: 1,
},
],
axisX: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: Q,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 0,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#000000",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#777777",
lineThickness: 1,
lineDashType: "solid",
color: "#111111",
},
},
],
axisX2: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: Q,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 0,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#000000",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#777777",
lineThickness: 1,
lineDashType: "solid",
color: "#111111",
},
},
],
axisY: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: Q,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 1,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#000000",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#777777",
lineThickness: 1,
lineDashType: "solid",
color: "#111111",
},
},
],
axisY2: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: Q,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 1,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#000000",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#777777",
lineThickness: 1,
lineDashType: "solid",
color: "#111111",
},
},
],
legend: {
fontFamily: v,
fontSize: 14,
fontColor: fa,
fontWeight: "bold",
verticalAlign: "bottom",
horizontalAlign: "center",
},
toolTip: {
fontFamily: v,
fontSize: 14,
fontStyle: "normal",
cornerRadius: 0,
borderThickness: 1,
fontColor: Q,
backgroundColor: "rgba(0, 0, 0, .7)",
},
};
I = "#FFFFFF";
Q = fa = "#FAFAFA";
ha = "#40BAF1";
ga = "#F5F5F5";
var X = 20,
E = 14,
ya = {
light1: Xa,
light2: cb,
dark1: Ha,
dark2: {
colorSet: "colorSet2",
backgroundColor: "#32373A",
title: {
fontFamily: v,
fontSize: 32,
fontColor: fa,
fontWeight: "normal",
verticalAlign: "top",
margin: 5,
},
subtitles: [
{
fontFamily: v,
fontSize: E,
fontColor: fa,
fontWeight: "normal",
verticalAlign: "top",
margin: 5,
},
],
toolbar: {
backgroundColor: "#666666",
backgroundColorOnHover: "#FF7372",
borderColor: "#FF7372",
borderThickness: 1,
fontColor: "#F5F5F5",
fontColorOnHover: "#F5F5F5",
},
data: [
{
indexLabelFontFamily: v,
indexLabelFontSize: E,
indexLabelFontColor: Q,
indexLabelFontWeight: "normal",
indexLabelLineThickness: 1,
},
],
axisX: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: Q,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 0,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#000000",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#777777",
lineThickness: 1,
lineDashType: "solid",
color: "#111111",
},
},
],
axisX2: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: Q,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 1,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 0,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#000000",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#777777",
lineThickness: 1,
lineDashType: "solid",
color: "#111111",
},
},
],
axisY: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: Q,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 0,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 1,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#000000",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#777777",
lineThickness: 1,
lineDashType: "solid",
color: "#111111",
},
},
],
axisY2: [
{
titleFontFamily: v,
titleFontSize: X,
titleFontColor: Q,
titleFontWeight: "normal",
labelFontFamily: v,
labelFontSize: E,
labelFontColor: Q,
labelFontWeight: "normal",
lineThickness: 0,
lineColor: I,
tickThickness: 1,
tickColor: I,
gridThickness: 1,
gridColor: I,
stripLines: [
{
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#FF7300",
labelFontWeight: "normal",
labelBackgroundColor: null,
color: "#FF7300",
thickness: 1,
},
],
crosshair: {
labelFontFamily: v,
labelFontSize: E,
labelFontColor: "#000000",
labelFontWeight: "normal",
labelBackgroundColor: ga,
color: ha,
thickness: 1,
lineDashType: "dash",
},
scaleBreaks: {
type: "zigzag",
spacing: "2%",
lineColor: "#777777",
lineThickness: 1,
lineDashType: "solid",
color: "#111111",
},
},
],
legend: {
fontFamily: v,
fontSize: 14,
fontColor: fa,
fontWeight: "bold",
verticalAlign: "bottom",
horizontalAlign: "center",
},
toolTip: {
fontFamily: v,
fontSize: 14,
fontStyle: "normal",
cornerRadius: 0,
borderThickness: 1,
fontColor: Q,
backgroundColor: "rgba(0, 0, 0, .7)",
},
},
theme1: Xa,
theme2: cb,
theme3: Xa,
},
S = {
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".split(" "),
};
(function () {
U.fSDec = function (k) {
for (var p = "", r = 0; r < k.length; r++)
p += String.fromCharCode(
Math.ceil(k.length / 57 / 5) ^ k.charCodeAt(r)
);
return p;
};
U.obj = {
trVs: "Ush`m!Wdsrhno",
fntStr:
"qy!B`mhcsh-!Mtbhe`!Fs`oed-!Mtbhe`!R`or!Tohbned-!@sh`m-!r`or,rdshg",
txtBl: "udyuC`rdmhod",
fnt: "gnou",
fSy: "ghmmRuxmd",
fTx: "ghmmUdyu",
grClr: "fsdx",
cntx: "buy",
tp: "unq",
};
delete ra[U.fSDec("Bi`su")][U.fSDec("bsdehuIsdg")];
U.pro = { sCH: ra[U.fSDec("Bi`su")][U.fSDec("bsdehuIsdg")] };
U._fTWm = function (k) {
if ("undefined" === typeof U.pro.sCH && !db)
try {
var p = k[U.fSDec(U.obj.cntx)];
p[U.fSDec(U.obj.txtBl)] = U.fSDec(U.obj.tp);
p[U.fSDec(U.obj.fnt)] = 11 + U.fSDec(U.obj.fntStr);
p[U.fSDec(U.obj.fSy)] = U.fSDec(U.obj.grClr);
p[U.fSDec(U.obj.fTx)](U.fSDec(U.obj.trVs), 2, k.height - 11 - 2);
} catch (r) {}
};
})();
var $a = {},
xa = null,
kb = 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));
},
lb = function (k, p, r) {
p = Math.min(this.width, this.height);
return Math.max(
"theme4" === this.theme ? 0 : 300 <= p ? 12 : 10,
Math.round(p * (k / 400))
);
},
Ca = (function () {
var k =
/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,
p = "Sunday Monday Tuesday Wednesday Thursday Friday Saturday".split(
" "
),
r = "Sun Mon Tue Wed Thu Fri Sat".split(" "),
u =
"January February March April May June July August September October November December".split(
" "
),
v = "Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec".split(" "),
H =
/\b(?:[PMCEA][SDP]T|(?:Pacific|Mountain|Central|Eastern|Atlantic) (?:Standard|Daylight|Prevailing) Time|(?:GMT|UTC)(?:[-+]\d{4})?)\b/g,
F = /[^-+\dA-Z]/g;
return function (z, E, L) {
var R = L ? L.days : p,
I = L ? L.months : u,
N = L ? L.shortDays : r,
O = L ? L.shortMonths : v;
L = "";
var S = !1;
z = z && z.getTime ? z : z ? new Date(z) : new Date();
if (isNaN(z)) throw SyntaxError("invalid date");
"UTC:" === E.slice(0, 4) && ((E = E.slice(4)), (S = !0));
L = S ? "getUTC" : "get";
var U = z[L + "Date"](),
V = z[L + "Day"](),
M = z[L + "Month"](),
Q = z[L + "FullYear"](),
a = z[L + "Hours"](),
d = z[L + "Minutes"](),
b = z[L + "Seconds"](),
c = z[L + "Milliseconds"](),
e = S ? 0 : z.getTimezoneOffset();
return (L = E.replace(k, function (g) {
switch (g) {
case "D":
return U;
case "DD":
return $(U, 2);
case "DDD":
return N[V];
case "DDDD":
return R[V];
case "M":
return M + 1;
case "MM":
return $(M + 1, 2);
case "MMM":
return O[M];
case "MMMM":
return I[M];
case "Y":
return parseInt(String(Q).slice(-2));
case "YY":
return $(String(Q).slice(-2), 2);
case "YYY":
return $(String(Q).slice(-3), 3);
case "YYYY":
return $(Q, 4);
case "h":
return a % 12 || 12;
case "hh":
return $(a % 12 || 12, 2);
case "H":
return a;
case "HH":
return $(a, 2);
case "m":
return d;
case "mm":
return $(d, 2);
case "s":
return b;
case "ss":
return $(b, 2);
case "f":
return String(c).slice(0, 1);
case "ff":
return $(String(c).slice(0, 2), 2);
case "fff":
return $(String(c).slice(0, 3), 3);
case "t":
return 12 > a ? "a" : "p";
case "tt":
return 12 > a ? "am" : "pm";
case "T":
return 12 > a ? "A" : "P";
case "TT":
return 12 > a ? "AM" : "PM";
case "K":
return S
? "UTC"
: (String(z).match(H) || [""]).pop().replace(F, "");
case "z":
return (0 < e ? "-" : "+") + Math.floor(Math.abs(e) / 60);
case "zz":
return (0 < e ? "-" : "+") + $(Math.floor(Math.abs(e) / 60), 2);
case "zzz":
return (
(0 < e ? "-" : "+") +
$(Math.floor(Math.abs(e) / 60), 2) +
$(Math.abs(e) % 60, 2)
);
default:
return g.slice(1, g.length - 1);
}
}));
};
})(),
ba = function (k, p, r) {
if (null === k) return "";
if (!isFinite(k)) return k;
k = Number(k);
var u = 0 > k ? !0 : !1;
u && (k *= -1);
var v = r ? r.decimalSeparator : ".",
H = r ? r.digitGroupSeparator : ",",
F = "";
p = String(p);
var F = 1,
z = (r = ""),
E = -1,
L = [],
R = [],
I = 0,
N = 0,
S = 0,
O = !1,
U = 0,
z = p.match(/"[^"]*"|'[^']*'|[eE][+-]*[0]+|[,]+[.]|\u2030|./g);
p = null;
for (var Q = 0; z && Q < z.length; Q++)
if (((p = z[Q]), "." === p && 0 > E)) E = Q;
else {
if ("%" === p) F *= 100;
else if ("\u2030" === p) {
F *= 1e3;
continue;
} else if ("," === p[0] && "." === p[p.length - 1]) {
F /= Math.pow(1e3, p.length - 1);
E = Q + p.length - 1;
continue;
} else
("E" !== p[0] && "e" !== p[0]) ||
"0" !== p[p.length - 1] ||
(O = !0);
0 > E
? (L.push(p), "#" === p || "0" === p ? I++ : "," === p && S++)
: (R.push(p), ("#" !== p && "0" !== p) || N++);
}
O &&
((p = Math.floor(k)),
(z = -Math.floor(Math.log(k) / Math.LN10 + 1)),
(U = 0 === k ? 0 : 0 === p ? -(I + z) : String(p).length - I),
(F /= Math.pow(10, U)));
0 > E && (E = Q);
F = (k * F).toFixed(N);
p = F.split(".");
F = (p[0] + "").split("");
k = (p[1] + "").split("");
F && "0" === F[0] && F.shift();
for (O = z = Q = N = E = 0; 0 < L.length; )
if (((p = L.pop()), "#" === p || "0" === p))
if ((E++, E === I)) {
var M = F,
F = [];
if ("0" === p)
for (p = I - N - (M ? M.length : 0); 0 < p; ) M.unshift("0"), p--;
for (; 0 < M.length; )
(r = M.pop() + r),
O++,
0 === O % z && Q === S && 0 < M.length && (r = H + r);
} else
0 < F.length
? ((r = F.pop() + r), N++, O++)
: "0" === p && ((r = "0" + r), N++, O++),
0 === O % z && Q === S && 0 < F.length && (r = H + r);
else
("E" !== p[0] && "e" !== p[0]) ||
"0" !== p[p.length - 1] ||
!/[eE][+-]*[0]+/.test(p)
? "," === p
? (Q++, (z = O), (O = 0), 0 < F.length && (r = H + r))
: (r =
1 < p.length &&
(('"' === p[0] && '"' === p[p.length - 1]) ||
("'" === p[0] && "'" === p[p.length - 1]))
? p.slice(1, p.length - 1) + r
: p + r)
: ((p =
0 > U
? p.replace("+", "").replace("-", "")
: p.replace("-", "")),
(r += p.replace(/[0]+/, function (k) {
return $(U, k.length);
})));
H = "";
for (L = !1; 0 < R.length; )
(p = R.shift()),
"#" === p || "0" === p
? 0 < k.length && 0 !== Number(k.join(""))
? ((H += k.shift()), (L = !0))
: "0" === p && ((H += "0"), (L = !0))
: 1 < p.length &&
(('"' === p[0] && '"' === p[p.length - 1]) ||
("'" === p[0] && "'" === p[p.length - 1]))
? (H += p.slice(1, p.length - 1))
: ("E" !== p[0] && "e" !== p[0]) ||
"0" !== p[p.length - 1] ||
!/[eE][+-]*[0]+/.test(p)
? (H += p)
: ((p =
0 > U
? p.replace("+", "").replace("-", "")
: p.replace("-", "")),
(H += p.replace(/[0]+/, function (k) {
return $(U, k.length);
})));
r += (L ? v : "") + H;
return u ? "-" + r : r;
},
Ra = function (k) {
var p = 0,
r = 0;
k = k || window.event;
k.offsetX || 0 === k.offsetX
? ((p = k.offsetX), (r = k.offsetY))
: k.layerX || 0 == k.layerX
? ((p = k.layerX), (r = k.layerY))
: ((p = k.pageX - k.target.offsetLeft),
(r = k.pageY - k.target.offsetTop));
return { x: p, y: r };
},
bb = !0,
Ua = window.devicePixelRatio || 1,
Pa = 1,
W = bb ? Ua / Pa : 1,
ea = function (k, p, r, u, v, H, F, z, E, L, R, N, O) {
"undefined" === typeof O && (O = 1);
F = F || 0;
z = z || "black";
var I = 15 < u - p && 15 < v - r ? 8 : 0.35 * Math.min(u - p, v - r);
k.beginPath();
k.moveTo(p, r);
k.save();
k.fillStyle = H;
k.globalAlpha = O;
k.fillRect(p, r, u - p, v - r);
k.globalAlpha = 1;
0 < F &&
((O = 0 === F % 2 ? 0 : 0.5),
k.beginPath(),
(k.lineWidth = F),
(k.strokeStyle = z),
k.moveTo(p, r),
k.rect(p - O, r - O, u - p + 2 * O, v - r + 2 * O),
k.stroke());
k.restore();
!0 === E &&
(k.save(),
k.beginPath(),
k.moveTo(p, r),
k.lineTo(p + I, r + I),
k.lineTo(u - I, r + I),
k.lineTo(u, r),
k.closePath(),
(F = k.createLinearGradient((u + p) / 2, r + I, (u + p) / 2, r)),
F.addColorStop(0, H),
F.addColorStop(1, "rgba(255, 255, 255, .4)"),
(k.fillStyle = F),
k.fill(),
k.restore());
!0 === L &&
(k.save(),
k.beginPath(),
k.moveTo(p, v),
k.lineTo(p + I, v - I),
k.lineTo(u - I, v - I),
k.lineTo(u, v),
k.closePath(),
(F = k.createLinearGradient((u + p) / 2, v - I, (u + p) / 2, v)),
F.addColorStop(0, H),
F.addColorStop(1, "rgba(255, 255, 255, .4)"),
(k.fillStyle = F),
k.fill(),
k.restore());
!0 === R &&
(k.save(),
k.beginPath(),
k.moveTo(p, r),
k.lineTo(p + I, r + I),
k.lineTo(p + I, v - I),
k.lineTo(p, v),
k.closePath(),
(F = k.createLinearGradient(p + I, (v + r) / 2, p, (v + r) / 2)),
F.addColorStop(0, H),
F.addColorStop(1, "rgba(255, 255, 255, 0.1)"),
(k.fillStyle = F),
k.fill(),
k.restore());
!0 === N &&
(k.save(),
k.beginPath(),
k.moveTo(u, r),
k.lineTo(u - I, r + I),
k.lineTo(u - I, v - I),
k.lineTo(u, v),
(F = k.createLinearGradient(u - I, (v + r) / 2, u, (v + r) / 2)),
F.addColorStop(0, H),
F.addColorStop(1, "rgba(255, 255, 255, 0.1)"),
(k.fillStyle = F),
F.addColorStop(0, H),
F.addColorStop(1, "rgba(255, 255, 255, 0.1)"),
(k.fillStyle = F),
k.fill(),
k.closePath(),
k.restore());
},
ja = function (k) {
for (var p = "", r = 0; r < k.length; r++)
p += String.fromCharCode(
Math.ceil(k.length / 57 / 5) ^ k.charCodeAt(r)
);
return p;
},
db =
window &&
window[ja("mnb`uhno")] &&
window[ja("mnb`uhno")].href &&
window[ja("mnb`uhno")].href.indexOf &&
(-1 !== window[ja("mnb`uhno")].href.indexOf(ja("b`ow`rkr/bnl")) ||
-1 !== window[ja("mnb`uhno")].href.indexOf(ja("gdonqhy/bnl")) ||
-1 !== window[ja("mnb`uhno")].href.indexOf(ja("gheemd"))),
ib = db && -1 === window[ja("mnb`uhno")].href.indexOf(ja("gheemd")),
jb = {
reset: {
image:
"",
},
pan: {
image:
"",
},
zoom: {
image:
"",
},
menu: {
image:
"",
},
handle: {
image:
"",
},
};
V.prototype.setOptions = function (k, p) {
if (ra[this._defaultsKey]) {
var r = ra[this._defaultsKey],
u;
for (u in r)
"publicProperties" !== u &&
r.hasOwnProperty(u) &&
(this[u] = k && u in k ? k[u] : p && u in p ? p[u] : r[u]);
} else Ja && window.console && console.log("defaults not set");
};
V.prototype.get = function (k) {
var p = ra[this._defaultsKey];
if ("options" === k)
return this.options && this.options._isPlaceholder ? null : this.options;
if (
p.hasOwnProperty(k) ||
(p.publicProperties && p.publicProperties.hasOwnProperty(k))
)
return this[k];
window.console &&
window.console.log(
'Property "' + k + "\" doesn't exist. Please check for typo."
);
};
V.prototype.set = function (k, p, r) {
r = "undefined" === typeof r ? !0 : r;
var u = ra[this._defaultsKey];
if ("options" === k) this.createUserOptions(p);
else if (
u.hasOwnProperty(k) ||
(u.publicProperties &&
u.publicProperties.hasOwnProperty(k) &&
"readWrite" === u.publicProperties[k])
)
this.options._isPlaceholder && this.createUserOptions(),
(this.options[k] = p);
else {
window.console &&
(u.publicProperties &&
u.publicProperties.hasOwnProperty(k) &&
"readOnly" === u.publicProperties[k]
? window.console.log('Property "' + k + '" is read-only.')
: window.console.log(
'Property "' + k + "\" doesn't exist. Please check for typo."
));
return;
}
r && (this.stockChart || this.chart || this).render();
};
V.prototype.addTo = function (k, p, r, u) {
u = "undefined" === typeof u ? !0 : u;
var v = ra[this._defaultsKey];
v.hasOwnProperty(k) ||
(v.publicProperties &&
v.publicProperties.hasOwnProperty(k) &&
"readWrite" === v.publicProperties[k])
? (this.options._isPlaceholder && this.createUserOptions(),
"undefined" === typeof this.options[k] && (this.options[k] = []),
(k = this.options[k]),
(r = "undefined" === typeof r || null === r ? k.length : r),
k.splice(r, 0, p),
u && (this.chart || this).render())
: window.console &&
(v.publicProperties &&
v.publicProperties.hasOwnProperty(k) &&
"readOnly" === v.publicProperties[k]
? window.console.log('Property "' + k + '" is read-only.')
: window.console.log(
'Property "' + k + "\" doesn't exist. Please check for typo."
));
};
V.prototype.createUserOptions = function (k) {
if ("undefined" !== typeof k || this.options._isPlaceholder)
if (
(this.parent.options._isPlaceholder && this.parent.createUserOptions(),
this.isOptionsInArray)
) {
this.parent.options[this.optionsName] ||
(this.parent.options[this.optionsName] = []);
var p = this.parent.options[this.optionsName],
r = p.length;
this.options._isPlaceholder || (Fa(p), (r = p.indexOf(this.options)));
this.options = "undefined" === typeof k ? {} : k;
p[r] = this.options;
} else
(this.options = "undefined" === typeof k ? {} : k),
(k = this.parent.options),
this.optionsName
? (p = this.optionsName)
: (p = this._defaultsKey) && 0 !== p.length
? ((r = p.charAt(0).toLowerCase()),
1 < p.length && (r = r.concat(p.slice(1))),
(p = r))
: (p = void 0),
(k[p] = this.options);
};
V.prototype.remove = function (k) {
k = "undefined" === typeof k ? !0 : k;
if (this.isOptionsInArray) {
var p = this.parent.options[this.optionsName];
Fa(p);
var r = p.indexOf(this.options);
0 <= r && p.splice(r, 1);
} else delete this.parent.options[this.optionsName];
k && (this.chart || this).render();
};
V.prototype.updateOption = function (k) {
!ra[this._defaultsKey] &&
Ja &&
window.console &&
console.log("defaults not set");
var p = ra[this._defaultsKey],
r = {},
v = this[k],
E = this._themeOptionsKey,
H = this._index;
this.theme && u(E) && u(H)
? (r = u(ya[this.theme]) ? ya.light1 : ya[this.theme])
: this.parent &&
this.parent.themeOptions &&
this.parent.themeOptions[E] &&
(null === H
? (r = this.parent.themeOptions[E])
: 0 < this.parent.themeOptions[E].length &&
((r = Math.min(this.parent.themeOptions[E].length - 1, H)),
(r = this.parent.themeOptions[E][r])));
this.themeOptions = r;
k in p &&
(v = k in this.options ? this.options[k] : r && k in r ? r[k] : p[k]);
if (v === this[k]) return !1;
this[k] = v;
return !0;
};
V.prototype.trackChanges = function (k) {
if (!this.sessionVariables) throw "Session Variable Store not set";
this.sessionVariables[k] = this.options[k];
};
V.prototype.isBeingTracked = function (k) {
this.options._oldOptions || (this.options._oldOptions = {});
return this.options._oldOptions[k] ? !0 : !1;
};
V.prototype.hasOptionChanged = function (k) {
if (!this.sessionVariables) throw "Session Variable Store not set";
return this.sessionVariables[k] !== this.options[k];
};
V.prototype.addEventListener = function (k, p, r) {
k &&
p &&
((this._eventListeners[k] = this._eventListeners[k] || []),
this._eventListeners[k].push({ context: r || this, eventHandler: p }));
};
V.prototype.removeEventListener = function (k, p) {
if (k && p && this._eventListeners[k])
for (var r = this._eventListeners[k], u = 0; u < r.length; u++)
if (r[u].eventHandler === p) {
r[u].splice(u, 1);
break;
}
};
V.prototype.removeAllEventListeners = function () {
this._eventListeners = [];
};
V.prototype.dispatchEvent = function (k, p, r) {
if (k && this._eventListeners[k]) {
p = p || {};
for (var u = this._eventListeners[k], v = 0; v < u.length; v++)
u[v].eventHandler.call(u[v].context, p);
}
"function" === typeof this[k] && this[k].call(r || this.chart, p);
};
Ga.prototype.registerSpace = function (k, p) {
"top" === k
? (this._topOccupied += p.height)
: "bottom" === k
? (this._bottomOccupied += p.height)
: "left" === k
? (this._leftOccupied += p.width)
: "right" === k && (this._rightOccupied += p.width);
};
Ga.prototype.unRegisterSpace = function (k, p) {
"top" === k
? (this._topOccupied -= p.height)
: "bottom" === k
? (this._bottomOccupied -= p.height)
: "left" === k
? (this._leftOccupied -= p.width)
: "right" === k && (this._rightOccupied -= p.width);
};
Ga.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,
};
};
Ga.prototype.reset = function () {
this._rightOccupied =
this._leftOccupied =
this._bottomOccupied =
this._topOccupied =
this._padding;
};
qa(ka, V);
ka.prototype._initialize = function () {
u(this.padding) || "object" !== typeof this.padding
? (this.topPadding =
this.rightPadding =
this.bottomPadding =
this.leftPadding =
Number(this.padding) | 0)
: ((this.topPadding = u(this.padding.top)
? 0
: Number(this.padding.top) | 0),
(this.rightPadding = u(this.padding.right)
? 0
: Number(this.padding.right) | 0),
(this.bottomPadding = u(this.padding.bottom)
? 0
: Number(this.padding.bottom) | 0),
(this.leftPadding = u(this.padding.left)
? 0
: Number(this.padding.left) | 0));
};
ka.prototype.render = function (k) {
if (0 !== this.fontSize) {
k && this.ctx.save();
var p = this.ctx.font;
this.ctx.textBaseline = this.textBaseline;
var r = 0;
this._isDirty && this.measureText(this.ctx);
this.ctx.translate(this.x, this.y + r);
"middle" === this.textBaseline && (r = -this._lineHeight / 2);
this.ctx.font = this._getFontString();
this.ctx.rotate((Math.PI / 180) * this.angle);
var u = 0,
v = this.topPadding,
H = null;
this.ctx.roundRect || Ea(this.ctx);
((0 < this.borderThickness && this.borderColor) ||
this.backgroundColor) &&
this.ctx.roundRect(
0,
r,
this.width,
this.height,
this.cornerRadius,
this.borderThickness,
this.backgroundColor,
this.borderColor
);
this.ctx.fillStyle = this.fontColor;
for (r = 0; r < this._wrappedText.lines.length; r++)
(H = this._wrappedText.lines[r]),
"right" === this.horizontalAlign
? (u =
(this.width - (this.leftPadding + this.rightPadding)) / 2 -
H.width / 2 +
this.leftPadding)
: "left" === this.horizontalAlign
? (u = this.leftPadding)
: "center" === this.horizontalAlign &&
(u =
(this.width - (this.leftPadding + this.rightPadding)) / 2 -
H.width / 2 +
this.leftPadding),
this.ctx.fillText(H.text, u, v),
(v += H.height);
this.ctx.font = p;
k && this.ctx.restore();
}
};
ka.prototype.setText = function (k) {
this.text = k;
this._isDirty = !0;
this._wrappedText = null;
};
ka.prototype.measureText = function () {
this._lineHeight = Za(this.fontFamily, this.fontSize, this.fontWeight);
if (null === this.maxWidth)
throw "Please set maxWidth and height for TextBlock";
this._wrapText(this.ctx);
this._isDirty = !1;
return { width: this.width, height: this.height };
};
ka.prototype._getLineWithWidth = function (k, p, r) {
k = String(k);
if (!k) return { text: "", width: 0 };
var u = (r = 0),
v = k.length - 1,
H = Infinity;
for (this.ctx.font = this._getFontString(); u <= v; ) {
var H = Math.floor((u + v) / 2),
F = k.substr(0, H + 1);
r = this.ctx.measureText(F).width;
if (r < p) u = H + 1;
else if (r > p) v = H - 1;
else break;
}
r > p &&
1 < F.length &&
((F = F.substr(0, F.length - 1)), (r = this.ctx.measureText(F).width));
p = !0;
if (F.length === k.length || " " === k[F.length]) p = !1;
p &&
((k = F.split(" ")),
1 < k.length && k.pop(),
(F = k.join(" ")),
(r = this.ctx.measureText(F).width));
return { text: F, width: r };
};
ka.prototype._wrapText = function () {
var k = new String(Ia(String(this.text))),
p = [],
r = this.ctx.font,
u = 0,
v = 0;
this.ctx.font = this._getFontString();
if (0 === this.frontSize) v = u = 0;
else
for (; 0 < k.length; ) {
var H = this.maxHeight - (this.topPadding + this.bottomPadding),
F = this._getLineWithWidth(
k,
this.maxWidth - (this.leftPadding + this.rightPadding),
!1
);
F.height = this._lineHeight;
p.push(F);
var z = v,
v = Math.max(v, F.width),
u = u + F.height,
k = Ia(k.slice(F.text.length, k.length));
H && u > H && ((F = p.pop()), (u -= F.height), (v = z));
}
this._wrappedText = { lines: p, width: v, height: u };
this.width = v + (this.leftPadding + this.rightPadding);
this.height = u + (this.topPadding + this.bottomPadding);
this.ctx.font = r;
};
ka.prototype._getFontString = function () {
var k;
k = "" + (this.fontStyle ? this.fontStyle + " " : "");
k += this.fontWeight ? this.fontWeight + " " : "";
k += this.fontSize ? this.fontSize + "px " : "";
var p = this.fontFamily ? this.fontFamily + "" : "";
!r &&
p &&
((p = p.split(",")[0]),
"'" !== p[0] && '"' !== p[0] && (p = "'" + p + "'"));
return (k += p);
};
qa(Va, V);
qa(Aa, V);
Aa.prototype.setLayout = function () {
if (this.text) {
var k = this.dockInsidePlotArea ? this.chart.plotArea : this.chart,
p = k.layoutManager.getFreeSpace(),
r = p.x1,
v = p.y1,
E = 0,
H = 0,
F =
this.chart._menuButton &&
this.chart.exportEnabled &&
"top" === this.verticalAlign
? 22
: 0,
z,
I;
"top" === this.verticalAlign || "bottom" === this.verticalAlign
? (null === this.maxWidth &&
(this.maxWidth =
p.width - 4 - F * ("center" === this.horizontalAlign ? 2 : 1)),
(H = 0.5 * p.height - this.margin - 2),
(E = 0))
: "center" === this.verticalAlign &&
("left" === this.horizontalAlign || "right" === this.horizontalAlign
? (null === this.maxWidth && (this.maxWidth = p.height - 4),
(H = 0.5 * p.width - this.margin - 2))
: "center" === this.horizontalAlign &&
(null === this.maxWidth && (this.maxWidth = p.width - 4),
(H = 0.5 * p.height - 4)));
var L;
u(this.padding) || "number" !== typeof this.padding
? u(this.padding) ||
"object" !== typeof this.padding ||
((L = this.padding.top
? this.padding.top
: this.padding.bottom
? this.padding.bottom
: 0),
(L += this.padding.bottom
? this.padding.bottom
: this.padding.top
? this.padding.top
: 0),
(L *= 1.25))
: (L = 2.5 * this.padding);
this.wrap ||
(H = Math.min(H, Math.max(1.5 * this.fontSize, this.fontSize + L)));
H = new ka(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: H,
cornerRadius: this.cornerRadius,
text: this.text,
padding: this.padding,
textBaseline: "top",
});
L = H.measureText();
"top" === this.verticalAlign || "bottom" === this.verticalAlign
? ("top" === this.verticalAlign
? ((v = p.y1 + 2), (I = "top"))
: "bottom" === this.verticalAlign &&
((v = p.y2 - 2 - L.height), (I = "bottom")),
"left" === this.horizontalAlign
? (r = p.x1 + 2)
: "center" === this.horizontalAlign
? (r = p.x1 + p.width / 2 - L.width / 2)
: "right" === this.horizontalAlign && (r = p.x2 - 2 - L.width - F),
(z = this.horizontalAlign),
(this.width = L.width),
(this.height = L.height))
: "center" === this.verticalAlign &&
("left" === this.horizontalAlign
? ((r = p.x1 + 2),
(v = p.y2 - 2 - (this.maxWidth / 2 - L.width / 2)),
(E = -90),
(I = "left"),
(this.width = L.height),
(this.height = L.width))
: "right" === this.horizontalAlign
? ((r = p.x2 - 2),
(v = p.y1 + 2 + (this.maxWidth / 2 - L.width / 2)),
(E = 90),
(I = "right"),
(this.width = L.height),
(this.height = L.width))
: "center" === this.horizontalAlign &&
((v = k.y1 + (k.height / 2 - L.height / 2)),
(r = k.x1 + (k.width / 2 - L.width / 2)),
(I = "center"),
(this.width = L.width),
(this.height = L.height)),
(z = "center"));
H.x = r;
H.y = v;
H.angle = E;
H.horizontalAlign = z;
this._textBlock = H;
k.layoutManager.registerSpace(I, {
width:
this.width + ("left" === I || "right" === I ? this.margin + 2 : 0),
height:
this.height + ("top" === I || "bottom" === I ? this.margin + 2 : 0),
});
this.bounds = { x1: r, y1: v, x2: r + this.width, y2: v + this.height };
this.ctx.textBaseline = "top";
}
};
Aa.prototype.render = function () {
this._textBlock && this._textBlock.render(!0);
};
qa(Ka, V);
Ka.prototype.setLayout = Aa.prototype.setLayout;
Ka.prototype.render = Aa.prototype.render;
Wa.prototype.get = function (k, p) {
var r = null;
0 < this.pool.length
? ((r = this.pool.pop()), Oa(r, k, p))
: (r = ta(k, p));
return r;
};
Wa.prototype.release = function (k) {
this.pool.push(k);
};
qa(La, V);
var Na = {
addTheme: function (k, p) {
ya[k] = p;
},
addColorSet: function (k, p) {
Ba[k] = p;
},
addCultureInfo: function (k, p) {
Ma[k] = p;
},
formatNumber: function (k, p, r) {
r = r || "en";
if (Ma[r]) return ba(k, p || "#,##0.##", new La(r));
throw "Unknown Culture Name";
},
formatDate: function (k, p, r) {
r = r || "en";
if (Ma[r]) return Ca(k, p || "DD MMM YYYY", new La(r));
throw "Unknown Culture Name";
},
};
"undefined" !== typeof module && "undefined" !== typeof module.exports
? (module.exports = Na)
: "function" === typeof define && define.amd
? define([], function () {
return Na;
})
: (window.CanvasJS = Na);
Na.Chart = (function () {
function k(a, d) {
return a.x - d.x;
}
function p(a, d) {
d = d || {};
this.theme = u(d.theme) || u(ya[d.theme]) ? "light1" : d.theme;
p.base.constructor.call(this, "Chart", null, d, null, null);
var b = this;
this._containerId = a;
this._objectsInitialized = !1;
this.overlaidCanvasCtx = this.ctx = null;
this._indexLabels = [];
this._panTimerId = 0;
this._lastTouchEventType = "";
this._lastTouchData = null;
this.isAnimating = !1;
this.renderCount = 0;
this.disableToolTip = this.animatedRender = !1;
this.canvasPool = new Wa();
this.allDOMEventHandlers = [];
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 = [];
if (
(this.container =
"string" === typeof this._containerId
? document.getElementById(this._containerId)
: this._containerId)
) {
this.container.innerHTML = "";
var c = 0,
e = 0,
c = this.options.width
? this.width
: 0 < this.container.clientWidth
? this.container.clientWidth
: this.width,
e = this.options.height
? this.height
: 0 < this.container.clientHeight
? this.container.clientHeight
: this.height;
this.width = c;
this.height = e;
this.x1 = this.y1 = 0;
this.x2 = this.width;
this.y2 = this.height;
this._selectedColorSet =
"undefined" !== typeof Ba[this.colorSet]
? Ba[this.colorSet]
: Ba.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";
r || (this._canvasJSContainer.style.height = "0px");
this.container.appendChild(this._canvasJSContainer);
this.canvas = ta(c, e);
this._preRenderCanvas = ta(c, e);
this.canvas.style.position = "absolute";
this.canvas.style.WebkitUserSelect = "none";
this.canvas.style.MozUserSelect = "none";
this.canvas.style.msUserSelect = "none";
this.canvas.style.userSelect = "none";
this.canvas.getContext &&
(this._canvasJSContainer.appendChild(this.canvas),
(this.ctx = this.canvas.getContext("2d")),
(this.ctx.textBaseline = "top"),
Ea(this.ctx),
(this._preRenderCtx = this._preRenderCanvas.getContext("2d")),
(this._preRenderCtx.textBaseline = "top"),
Ea(this._preRenderCtx),
r
? (this.plotArea.ctx = this.ctx)
: ((this.plotArea.canvas = ta(c, e)),
(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 = ta(c, e)),
(this.overlaidCanvas.style.position = "absolute"),
(this.overlaidCanvas.style.webkitTapHighlightColor = "transparent"),
(this.overlaidCanvas.style.WebkitUserSelect = "none"),
(this.overlaidCanvas.style.MozUserSelect = "none"),
(this.overlaidCanvas.style.msUserSelect = "none"),
(this.overlaidCanvas.style.userSelect = "none"),
this.overlaidCanvas.getContext &&
(this._canvasJSContainer.appendChild(this.overlaidCanvas),
(this.overlaidCanvasCtx = this.overlaidCanvas.getContext("2d")),
(this.overlaidCanvasCtx.textBaseline = "top"),
Ea(this.overlaidCanvasCtx)),
(this._eventManager = new ha(this)),
(this.windowResizeHandler = O(
window,
"resize",
function () {
b._updateSize() && b.render();
},
this.allDOMEventHandlers
)),
(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 }),
O(
this.overlaidCanvas,
"click",
function (a) {
b._mouseEventHandler(a);
},
this.allDOMEventHandlers
),
O(
this.overlaidCanvas,
"mousemove",
function (a) {
b._mouseEventHandler(a);
},
this.allDOMEventHandlers
),
O(
this.overlaidCanvas,
"mouseup",
function (a) {
b._mouseEventHandler(a);
},
this.allDOMEventHandlers
),
O(
this.overlaidCanvas,
"mousedown",
function (a) {
b._mouseEventHandler(a);
va(b._dropdownMenu);
},
this.allDOMEventHandlers
),
O(
this.overlaidCanvas,
"mouseout",
function (a) {
b._mouseEventHandler(a);
},
this.allDOMEventHandlers
),
O(
this.overlaidCanvas,
window.navigator.msPointerEnabled ? "MSPointerDown" : "touchstart",
function (a) {
b._touchEventHandler(a);
},
this.allDOMEventHandlers
),
O(
this.overlaidCanvas,
window.navigator.msPointerEnabled ? "MSPointerMove" : "touchmove",
function (a) {
b._touchEventHandler(a);
},
this.allDOMEventHandlers
),
O(
this.overlaidCanvas,
window.navigator.msPointerEnabled ? "MSPointerUp" : "touchend",
function (a) {
b._touchEventHandler(a);
},
this.allDOMEventHandlers
),
O(
this.overlaidCanvas,
window.navigator.msPointerEnabled
? "MSPointerCancel"
: "touchcancel",
function (a) {
b._touchEventHandler(a);
},
this.allDOMEventHandlers
),
(this.toolTip = new $(this, this.options.toolTip)),
(this.data = null),
(this.axisX = []),
(this.axisX2 = []),
(this.axisY = []),
(this.axisY2 = []),
(this.sessionVariables = {
axisX: [],
axisX2: [],
axisY: [],
axisY2: [],
}));
} else
window.console &&
window.console.log(
'CanvasJS Error: Chart Container with id "' +
this._containerId +
'" was not found'
);
}
function v(a, d) {
for (var b = [], c, e = 0; e < a.length; e++)
if (0 == e) b.push(a[0]);
else {
var g, m, l;
l = e - 1;
g = 0 === l ? 0 : l - 1;
m = l === a.length - 1 ? l : l + 1;
c =
(Math.abs(
(a[m].x - a[g].x) /
(0 === a[m].x - a[l].x ? 0.01 : a[m].x - a[l].x)
) *
(d - 1)) /
2 +
1;
var w = (a[m].x - a[g].x) / c;
c = (a[m].y - a[g].y) / c;
b[b.length] =
(a[l].x > a[g].x && 0 < w) || (a[l].x < a[g].x && 0 > w)
? { x: a[l].x + w / 3, y: a[l].y + c / 3 }
: { x: a[l].x, y: a[l].y + c / 9 };
l = e;
g = 0 === l ? 0 : l - 1;
m = l === a.length - 1 ? l : l + 1;
c =
(Math.abs(
(a[m].x - a[g].x) /
(0 === a[l].x - a[g].x ? 0.01 : a[l].x - a[g].x)
) *
(d - 1)) /
2 +
1;
w = (a[m].x - a[g].x) / c;
c = (a[m].y - a[g].y) / c;
b[b.length] =
(a[l].x > a[g].x && 0 < w) || (a[l].x < a[g].x && 0 > w)
? { x: a[l].x - w / 3, y: a[l].y - c / 3 }
: { x: a[l].x, y: a[l].y - c / 9 };
b[b.length] = a[e];
}
return b;
}
function E(a, d, b, c, e, g, m, l, w, h) {
var s = 0;
h ? ((m.color = g), (l.color = g)) : (h = 1);
s = w ? Math.abs(e - b) : Math.abs(c - d);
s =
0 < m.trimLength
? Math.abs((s * m.trimLength) / 100)
: Math.abs(s - m.length);
w ? ((b += s / 2), (e -= s / 2)) : ((d += s / 2), (c -= s / 2));
var s = 1 === Math.round(m.thickness) % 2 ? 0.5 : 0,
q = 1 === Math.round(l.thickness) % 2 ? 0.5 : 0;
a.save();
a.globalAlpha = h;
a.strokeStyle = l.color || g;
a.lineWidth = l.thickness || 2;
a.setLineDash && a.setLineDash(R(l.dashType, l.thickness));
a.beginPath();
w && 0 < l.thickness
? (a.moveTo(c - m.thickness / 2, Math.round((b + e) / 2) - q),
a.lineTo(d + m.thickness / 2, Math.round((b + e) / 2) - q))
: 0 < l.thickness &&
(a.moveTo(Math.round((d + c) / 2) - q, b + m.thickness / 2),
a.lineTo(Math.round((d + c) / 2) - q, e - m.thickness / 2));
a.stroke();
a.strokeStyle = m.color || g;
a.lineWidth = m.thickness || 2;
a.setLineDash && a.setLineDash(R(m.dashType, m.thickness));
a.beginPath();
w && 0 < m.thickness
? (a.moveTo(c - s, b),
a.lineTo(c - s, e),
a.moveTo(d + s, b),
a.lineTo(d + s, e))
: 0 < m.thickness &&
(a.moveTo(d, b + s),
a.lineTo(c, b + s),
a.moveTo(d, e - s),
a.lineTo(c, e - s));
a.stroke();
a.restore();
}
function I(a, d, b, c, e) {
if (null === a || "undefined" === typeof a)
return "undefined" === typeof b ? d : b;
a =
parseFloat(a.toString()) *
(0 <= a.toString().indexOf("%") ? d / 100 : 1);
"undefined" !== typeof c &&
((a = Math.min(c, a)),
"undefined" !== typeof e && (a = Math.max(e, a)));
return !isNaN(a) && a <= d && 0 <= a
? a
: "undefined" === typeof b
? d
: b;
}
function H(a, d) {
H.base.constructor.call(this, "Legend", "legend", d, null, a);
this.chart = a;
this.canvas = a.canvas;
this.ctx = this.chart.ctx;
this.ghostCtx = this.chart._eventManager.ghostCtx;
this.items = [];
this.optionsName = "legend";
this.height = this.width = 0;
this.orientation = null;
this.dataSeries = [];
this.bounds = { x1: null, y1: null, x2: null, y2: null };
"undefined" === typeof this.options.fontSize &&
(this.fontSize = this.chart.getAutoFontSize(this.fontSize));
this.lineHeight = Za(this.fontFamily, this.fontSize, this.fontWeight);
this.horizontalSpacing = this.fontSize;
}
function F(a, d, b, c) {
F.base.constructor.call(this, "DataSeries", "data", d, b, a);
this.chart = a;
this.canvas = a.canvas;
this._ctx = a.canvas.ctx;
this.index = b;
this.noDataPointsInPlotArea = 0;
this.id = c;
this.chart._eventManager.objectMap[c] = {
id: c,
objectType: "dataSeries",
dataSeriesIndex: b,
};
a = d.dataPoints ? d.dataPoints.length : 0;
this.dataPointEOs = [];
for (d = 0; d < a; d++) this.dataPointEOs[d] = {};
this.dataPointIds = [];
this.plotUnit = [];
this.axisY = this.axisX = null;
this.optionsName = "data";
this.isOptionsInArray = !0;
null === this.fillOpacity &&
(this.type.match(/area/i)
? (this.fillOpacity = 0.7)
: (this.fillOpacity = 1));
this.axisPlacement = this.getDefaultAxisPlacement();
"undefined" === typeof this.options.indexLabelFontSize &&
(this.indexLabelFontSize = this.chart.getAutoFontSize(
this.indexLabelFontSize
));
}
function z(a, d, b, c, e, g) {
z.base.constructor.call(this, "Axis", d, b, c, a);
this.chart = a;
this.canvas = a.canvas;
this.ctx = a.ctx;
this.intervalStartPosition = this.maxHeight = this.maxWidth = 0;
this.labels = [];
this.dataSeries = [];
this._stripLineLabels = this._ticks = this._labels = null;
this.dataInfo = {
min: Infinity,
max: -Infinity,
viewPortMin: Infinity,
viewPortMax: -Infinity,
minDiff: Infinity,
};
this.isOptionsInArray = !0;
"axisX" === e
? ("left" === g || "bottom" === g
? ((this.optionsName = "axisX"),
u(this.chart.sessionVariables.axisX[c]) &&
(this.chart.sessionVariables.axisX[c] = {}),
(this.sessionVariables = this.chart.sessionVariables.axisX[c]))
: ((this.optionsName = "axisX2"),
u(this.chart.sessionVariables.axisX2[c]) &&
(this.chart.sessionVariables.axisX2[c] = {}),
(this.sessionVariables = this.chart.sessionVariables.axisX2[c])),
this.options.interval || (this.intervalType = null))
: "left" === g || "bottom" === g
? ((this.optionsName = "axisY"),
u(this.chart.sessionVariables.axisY[c]) &&
(this.chart.sessionVariables.axisY[c] = {}),
(this.sessionVariables = this.chart.sessionVariables.axisY[c]))
: ((this.optionsName = "axisY2"),
u(this.chart.sessionVariables.axisY2[c]) &&
(this.chart.sessionVariables.axisY2[c] = {}),
(this.sessionVariables = this.chart.sessionVariables.axisY2[c]));
"undefined" === typeof this.options.titleFontSize &&
(this.titleFontSize = this.chart.getAutoFontSize(this.titleFontSize));
"undefined" === typeof this.options.labelFontSize &&
(this.labelFontSize = this.chart.getAutoFontSize(this.labelFontSize));
this.type = e;
"axisX" !== e ||
(b && "undefined" !== typeof b.gridThickness) ||
(this.gridThickness = 0);
this._position = g;
this.lineCoordinates = {
x1: null,
y1: null,
x2: null,
y2: null,
width: null,
};
this.labelAngle = ((this.labelAngle % 360) + 360) % 360;
90 < this.labelAngle && 270 > this.labelAngle
? (this.labelAngle -= 180)
: 270 <= this.labelAngle &&
360 >= this.labelAngle &&
(this.labelAngle -= 360);
this.options.scaleBreaks &&
(this.scaleBreaks = new Q(
this.chart,
this.options.scaleBreaks,
++this.chart._eventManager.lastObjectId,
this
));
this.stripLines = [];
if (this.options.stripLines && 0 < this.options.stripLines.length)
for (a = 0; a < this.options.stripLines.length; a++)
this.stripLines.push(
new X(
this.chart,
this.options.stripLines[a],
a,
++this.chart._eventManager.lastObjectId,
this
)
);
this.options.crosshair &&
(this.crosshair = new fa(this.chart, this.options.crosshair, this));
this._titleTextBlock = null;
this.hasOptionChanged("viewportMinimum") &&
null === this.viewportMinimum &&
((this.options.viewportMinimum = void 0),
(this.sessionVariables.viewportMinimum = null));
this.hasOptionChanged("viewportMinimum") ||
isNaN(this.sessionVariables.newViewportMinimum) ||
null === this.sessionVariables.newViewportMinimum
? (this.sessionVariables.newViewportMinimum = null)
: (this.viewportMinimum = this.sessionVariables.newViewportMinimum);
this.hasOptionChanged("viewportMaximum") &&
null === this.viewportMaximum &&
((this.options.viewportMaximum = void 0),
(this.sessionVariables.viewportMaximum = null));
this.hasOptionChanged("viewportMaximum") ||
isNaN(this.sessionVariables.newViewportMaximum) ||
null === this.sessionVariables.newViewportMaximum
? (this.sessionVariables.newViewportMaximum = null)
: (this.viewportMaximum = this.sessionVariables.newViewportMaximum);
null !== this.minimum &&
null !== this.viewportMinimum &&
(this.viewportMinimum = Math.max(this.viewportMinimum, this.minimum));
null !== this.maximum &&
null !== this.viewportMaximum &&
(this.viewportMaximum = Math.min(this.viewportMaximum, this.maximum));
this.trackChanges("viewportMinimum");
this.trackChanges("viewportMaximum");
}
function Q(a, d, b, c) {
Q.base.constructor.call(this, "ScaleBreaks", "scaleBreaks", d, null, c);
this.id = b;
this.chart = a;
this.ctx = this.chart.ctx;
this.axis = c;
this.optionsName = "scaleBreaks";
this.isOptionsInArray = !1;
this._appliedBreaks = [];
this.customBreaks = [];
this.autoBreaks = [];
"string" === typeof this.spacing
? ((this.spacing = parseFloat(this.spacing)),
(this.spacing = isNaN(this.spacing)
? 8
: (10 < this.spacing ? 10 : this.spacing) + "%"))
: "number" !== typeof this.spacing && (this.spacing = 8);
this.autoCalculate &&
(this.maxNumberOfAutoBreaks = Math.min(this.maxNumberOfAutoBreaks, 5));
if (this.options.customBreaks && 0 < this.options.customBreaks.length) {
for (a = 0; a < this.options.customBreaks.length; a++)
this.customBreaks.push(
new L(
this.chart,
"customBreaks",
this.options.customBreaks[a],
a,
++this.chart._eventManager.lastObjectId,
this
)
),
"number" === typeof this.customBreaks[a].startValue &&
"number" === typeof this.customBreaks[a].endValue &&
this.customBreaks[a].endValue !==
this.customBreaks[a].startValue &&
this._appliedBreaks.push(this.customBreaks[a]);
this._appliedBreaks.sort(function (a, c) {
return a.startValue - c.startValue;
});
for (a = 0; a < this._appliedBreaks.length - 1; a++)
this._appliedBreaks[a].endValue >=
this._appliedBreaks[a + 1].startValue &&
((this._appliedBreaks[a].endValue = Math.max(
this._appliedBreaks[a].endValue,
this._appliedBreaks[a + 1].endValue
)),
window.console &&
window.console.log(
"CanvasJS Error: Breaks " +
a +
" and " +
(a + 1) +
" are overlapping."
),
this._appliedBreaks.splice(a, 2),
a--);
}
}
function L(a, d, b, c, e, g) {
L.base.constructor.call(this, "Break", d, b, c, g);
this.id = e;
this.chart = a;
this.ctx = this.chart.ctx;
this.scaleBreaks = g;
this.optionsName = d;
this.isOptionsInArray = !0;
this.type = b.type ? this.type : g.type;
this.fillOpacity = u(b.fillOpacity) ? g.fillOpacity : this.fillOpacity;
this.lineThickness = u(b.lineThickness)
? g.lineThickness
: this.lineThickness;
this.color = b.color ? this.color : g.color;
this.lineColor = b.lineColor ? this.lineColor : g.lineColor;
this.lineDashType = b.lineDashType ? this.lineDashType : g.lineDashType;
!u(this.startValue) &&
this.startValue.getTime &&
(this.startValue = this.startValue.getTime());
!u(this.endValue) &&
this.endValue.getTime &&
(this.endValue = this.endValue.getTime());
"number" === typeof this.startValue &&
"number" === typeof this.endValue &&
this.endValue < this.startValue &&
((a = this.startValue),
(this.startValue = this.endValue),
(this.endValue = a));
this.spacing = "undefined" === typeof b.spacing ? g.spacing : b.spacing;
"string" === typeof this.options.spacing
? ((this.spacing = parseFloat(this.spacing)),
(this.spacing = isNaN(this.spacing)
? 0
: (10 < this.spacing ? 10 : this.spacing) + "%"))
: "number" !== typeof this.options.spacing &&
(this.spacing = g.spacing);
this.size = g.parent.logarithmic ? 1 : 0;
}
function X(a, d, b, c, e) {
X.base.constructor.call(this, "StripLine", "stripLines", d, b, e);
this.id = c;
this.chart = a;
this.ctx = this.chart.ctx;
this.label = this.label;
this.axis = e;
this.optionsName = "stripLines";
this.isOptionsInArray = !0;
this._thicknessType = "pixel";
null !== this.startValue &&
null !== this.endValue &&
((this.value = e.logarithmic
? Math.sqrt(
(this.startValue.getTime
? this.startValue.getTime()
: this.startValue) *
(this.endValue.getTime
? this.endValue.getTime()
: this.endValue)
)
: ((this.startValue.getTime
? this.startValue.getTime()
: this.startValue) +
(this.endValue.getTime
? this.endValue.getTime()
: this.endValue)) /
2),
(this._thicknessType = null));
}
function fa(a, d, b) {
fa.base.constructor.call(this, "Crosshair", "crosshair", d, null, b);
this.chart = a;
this.ctx = this.chart.ctx;
this.axis = b;
this.optionsName = "crosshair";
this._thicknessType = "pixel";
}
function $(a, d) {
$.base.constructor.call(this, "ToolTip", "toolTip", d, null, a);
this.chart = a;
this.canvas = a.canvas;
this.ctx = this.chart.ctx;
this.currentDataPointIndex = this.currentSeriesIndex = -1;
this._prevY = this._prevX = NaN;
this.containerTransitionDuration = 0.1;
this.mozContainerTransition = this.getContainerTransition(
this.containerTransitionDuration
);
this.optionsName = "toolTip";
this._initialize();
}
function ha(a) {
this.chart = a;
this.lastObjectId = 0;
this.objectMap = [];
this.rectangularRegionEventSubscriptions = [];
this.previousDataPointEventObject = null;
this.ghostCanvas = ta(this.chart.width, this.chart.height);
this.ghostCtx = this.ghostCanvas.getContext("2d");
this.mouseoveredObjectMaps = [];
}
function ga(a) {
this.chart = a;
this.ctx = this.chart.plotArea.ctx;
this.animations = [];
this.animationRequestId = null;
}
qa(p, V);
p.prototype.destroy = function () {
var a = this.allDOMEventHandlers;
this._animator && this._animator.cancelAllAnimations();
this._panTimerId && clearTimeout(this._panTimerId);
for (var d = 0; d < a.length; d++) {
var b = a[d][0],
c = a[d][1],
e = a[d][2],
g = a[d][3],
g = g || !1;
b.removeEventListener
? b.removeEventListener(c, e, g)
: b.detachEvent && b.detachEvent("on" + c, e);
}
this.allDOMEventHandlers = [];
for (
this.removeAllEventListeners();
this._canvasJSContainer && this._canvasJSContainer.hasChildNodes();
)
this._canvasJSContainer.removeChild(this._canvasJSContainer.lastChild);
for (; this.container && this.container.hasChildNodes(); )
this.container.removeChild(this.container.lastChild);
for (; this._dropdownMenu && this._dropdownMenu.hasChildNodes(); )
this._dropdownMenu.removeChild(this._dropdownMenu.lastChild);
this.overlaidCanvas =
this.canvas =
this.container =
this._canvasJSContainer =
null;
this._toolBar =
this._dropdownMenu =
this._menuButton =
this._resetButton =
this._zoomButton =
this._breaksCanvas =
this._preRenderCanvas =
this.toolTip.container =
null;
};
p.prototype._updateOptions = function () {
var a = this;
this.updateOption("width");
this.updateOption("height");
this.updateOption("dataPointWidth");
this.updateOption("dataPointMinWidth");
this.updateOption("dataPointMaxWidth");
this.updateOption("interactivityEnabled");
this.updateOption("theme");
this.updateOption("colorSet") &&
(this._selectedColorSet =
"undefined" !== typeof Ba[this.colorSet]
? Ba[this.colorSet]
: Ba.colorSet1);
this.updateOption("backgroundColor");
this.backgroundColor || (this.backgroundColor = "rgba(0,0,0,0)");
this.updateOption("culture");
this._cultureInfo = new La(this.options.culture);
this.updateOption("animationEnabled");
this.animationEnabled = this.animationEnabled && r;
this.updateOption("animationDuration");
this.updateOption("rangeChanging");
this.updateOption("rangeChanged");
this.updateOption("exportEnabled");
this.updateOption("exportFileName");
this.updateOption("zoomType");
if (this.options.zoomEnabled) {
if (!this._zoomButton) {
var d = !1;
va((this._zoomButton = document.createElement("button")));
ua(this, this._zoomButton, "pan");
this._toolBar.appendChild(this._zoomButton);
this._zoomButton.style.borderRight =
this.toolbar.borderThickness +
"px solid " +
this.toolbar.borderColor;
O(
this._zoomButton,
"touchstart",
function (a) {
d = !0;
},
this.allDOMEventHandlers
);
O(
this._zoomButton,
"click",
function () {
a.zoomEnabled
? ((a.zoomEnabled = !1),
(a.panEnabled = !0),
ua(a, a._zoomButton, "zoom"))
: ((a.zoomEnabled = !0),
(a.panEnabled = !1),
ua(a, a._zoomButton, "pan"));
a.render();
},
this.allDOMEventHandlers
);
O(
this._zoomButton,
"mouseover",
function () {
d
? (d = !1)
: (sa(a, a._zoomButton, {
backgroundColor: a.toolbar.backgroundColorOnHover,
color: a.toolbar.fontColorOnHover,
transition: "0.4s",
WebkitTransition: "0.4s",
}),
0 >= navigator.userAgent.search("MSIE") &&
sa(a, a._zoomButton.childNodes[0], {
WebkitFilter: "invert(100%)",
filter: "invert(100%)",
}));
},
this.allDOMEventHandlers
);
O(
this._zoomButton,
"mouseout",
function () {
d ||
(sa(a, a._zoomButton, {
backgroundColor: a.toolbar.backgroundColor,
color: a.toolbar.fontColor,
transition: "0.4s",
WebkitTransition: "0.4s",
}),
0 >= navigator.userAgent.search("MSIE") &&
sa(a, a._zoomButton.childNodes[0], {
WebkitFilter: "invert(0%)",
filter: "invert(0%)",
}));
},
this.allDOMEventHandlers
);
}
this._resetButton ||
((d = !1),
va((this._resetButton = document.createElement("button"))),
ua(this, this._resetButton, "reset"),
(this._resetButton.style.borderRight =
(this.exportEnabled ? this.toolbar.borderThickness : 0) +
"px solid " +
this.toolbar.borderColor),
this._toolBar.appendChild(this._resetButton),
O(
this._resetButton,
"touchstart",
function (a) {
d = !0;
},
this.allDOMEventHandlers
),
O(
this._resetButton,
"click",
function () {
a.toolTip.hide();
a.zoomEnabled || a.panEnabled
? ((a.zoomEnabled = !0),
(a.panEnabled = !1),
ua(a, a._zoomButton, "pan"),
(a._defaultCursor = "default"),
(a.overlaidCanvas.style.cursor = a._defaultCursor))
: ((a.zoomEnabled = !1), (a.panEnabled = !1));
if (a.sessionVariables.axisX)
for (var c = 0; c < a.sessionVariables.axisX.length; c++)
(a.sessionVariables.axisX[c].newViewportMinimum = null),
(a.sessionVariables.axisX[c].newViewportMaximum = null);
if (a.sessionVariables.axisX2)
for (c = 0; c < a.sessionVariables.axisX2.length; c++)
(a.sessionVariables.axisX2[c].newViewportMinimum = null),
(a.sessionVariables.axisX2[c].newViewportMaximum = null);
if (a.sessionVariables.axisY)
for (c = 0; c < a.sessionVariables.axisY.length; c++)
(a.sessionVariables.axisY[c].newViewportMinimum = null),
(a.sessionVariables.axisY[c].newViewportMaximum = null);
if (a.sessionVariables.axisY2)
for (c = 0; c < a.sessionVariables.axisY2.length; c++)
(a.sessionVariables.axisY2[c].newViewportMinimum = null),
(a.sessionVariables.axisY2[c].newViewportMaximum = null);
a.resetOverlayedCanvas();
va(a._zoomButton, a._resetButton);
a._dispatchRangeEvent("rangeChanging", "reset");
a.render();
a._dispatchRangeEvent("rangeChanged", "reset");
a.syncCharts && a.syncCharts(null, null);
},
this.allDOMEventHandlers
),
O(
this._resetButton,
"mouseover",
function () {
d ||
(sa(a, a._resetButton, {
backgroundColor: a.toolbar.backgroundColorOnHover,
color: a.toolbar.hoverFfontColorOnHoverontColor,
transition: "0.4s",
WebkitTransition: "0.4s",
}),
0 >= navigator.userAgent.search("MSIE") &&
sa(a, a._resetButton.childNodes[0], {
WebkitFilter: "invert(100%)",
filter: "invert(100%)",
}));
},
this.allDOMEventHandlers
),
O(
this._resetButton,
"mouseout",
function () {
d ||
(sa(a, a._resetButton, {
backgroundColor: a.toolbar.backgroundColor,
color: a.toolbar.fontColor,
transition: "0.4s",
WebkitTransition: "0.4s",
}),
0 >= navigator.userAgent.search("MSIE") &&
sa(a, a._resetButton.childNodes[0], {
WebkitFilter: "invert(0%)",
filter: "invert(0%)",
}));
},
this.allDOMEventHandlers
),
(this.overlaidCanvas.style.cursor = a._defaultCursor));
this.zoomEnabled ||
this.panEnabled ||
(this._zoomButton
? (a._zoomButton.getAttribute("state") === a._cultureInfo.zoomText
? ((this.panEnabled = !0), (this.zoomEnabled = !1))
: ((this.zoomEnabled = !0), (this.panEnabled = !1)),
Qa(a._zoomButton, a._resetButton))
: ((this.zoomEnabled = !0), (this.panEnabled = !1)));
} else this.panEnabled = this.zoomEnabled = !1;
this._menuButton
? this.exportEnabled
? Qa(this._menuButton)
: va(this._menuButton)
: this.exportEnabled &&
r &&
((d = !1),
(this._menuButton = document.createElement("button")),
ua(this, this._menuButton, "menu"),
this._toolBar.appendChild(this._menuButton),
O(
this._menuButton,
"touchstart",
function (a) {
d = !0;
},
this.allDOMEventHandlers
),
O(
this._menuButton,
"click",
function () {
"none" !== a._dropdownMenu.style.display ||
(a._dropDownCloseTime &&
500 >=
new Date().getTime() - a._dropDownCloseTime.getTime()) ||
((a._dropdownMenu.style.display = "block"),
a._menuButton.blur(),
a._dropdownMenu.focus());
},
this.allDOMEventHandlers,
!0
),
O(
this._menuButton,
"mouseover",
function () {
d ||
(sa(a, a._menuButton, {
backgroundColor: a.toolbar.backgroundColorOnHover,
color: a.toolbar.fontColorOnHover,
}),
0 >= navigator.userAgent.search("MSIE") &&
sa(a, a._menuButton.childNodes[0], {
WebkitFilter: "invert(100%)",
filter: "invert(100%)",
}));
},
this.allDOMEventHandlers,
!0
),
O(
this._menuButton,
"mouseout",
function () {
d ||
(sa(a, a._menuButton, {
backgroundColor: a.toolbar.backgroundColor,
color: a.toolbar.fontColor,
}),
0 >= navigator.userAgent.search("MSIE") &&
sa(a, a._menuButton.childNodes[0], {
WebkitFilter: "invert(0%)",
filter: "invert(0%)",
}));
},
this.allDOMEventHandlers,
!0
));
if (!this._dropdownMenu && this.exportEnabled && r) {
d = !1;
this._dropdownMenu = document.createElement("div");
this._dropdownMenu.setAttribute("tabindex", -1);
var b = -1 !== this.theme.indexOf("dark") ? "black" : "#888888";
this._dropdownMenu.style.cssText =
"position: absolute; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; cursor: pointer;right: 0px;top: 25px;min-width: 120px;outline: 0;font-size: 14px; font-family: Arial, Helvetica, sans-serif;padding: 5px 0px 5px 0px;text-align: left;line-height: 10px;background-color:" +
this.toolbar.backgroundColor +
";box-shadow: 2px 2px 10px " +
b;
a._dropdownMenu.style.display = "none";
this._toolBar.appendChild(this._dropdownMenu);
O(
this._dropdownMenu,
"blur",
function () {
va(a._dropdownMenu);
a._dropDownCloseTime = new Date();
},
this.allDOMEventHandlers,
!0
);
b = document.createElement("div");
b.style.cssText = "padding: 12px 8px 12px 8px";
b.innerHTML = this._cultureInfo.printText;
b.style.backgroundColor = this.toolbar.backgroundColor;
b.style.color = this.toolbar.fontColor;
this._dropdownMenu.appendChild(b);
O(
b,
"touchstart",
function (a) {
d = !0;
},
this.allDOMEventHandlers
);
O(
b,
"mouseover",
function () {
d ||
((this.style.backgroundColor = a.toolbar.backgroundColorOnHover),
(this.style.color = a.toolbar.fontColorOnHover));
},
this.allDOMEventHandlers,
!0
);
O(
b,
"mouseout",
function () {
d ||
((this.style.backgroundColor = a.toolbar.backgroundColor),
(this.style.color = a.toolbar.fontColor));
},
this.allDOMEventHandlers,
!0
);
O(
b,
"click",
function () {
a.print();
va(a._dropdownMenu);
},
this.allDOMEventHandlers,
!0
);
b = document.createElement("div");
b.style.cssText = "padding: 12px 8px 12px 8px";
b.innerHTML = this._cultureInfo.saveJPGText;
b.style.backgroundColor = this.toolbar.backgroundColor;
b.style.color = this.toolbar.fontColor;
this._dropdownMenu.appendChild(b);
O(
b,
"touchstart",
function (a) {
d = !0;
},
this.allDOMEventHandlers
);
O(
b,
"mouseover",
function () {
d ||
((this.style.backgroundColor = a.toolbar.backgroundColorOnHover),
(this.style.color = a.toolbar.fontColorOnHover));
},
this.allDOMEventHandlers,
!0
);
O(
b,
"mouseout",
function () {
d ||
((this.style.backgroundColor = a.toolbar.backgroundColor),
(this.style.color = a.toolbar.fontColor));
},
this.allDOMEventHandlers,
!0
);
O(
b,
"click",
function () {
Ta(a.canvas, "jpeg", a.exportFileName);
va(a._dropdownMenu);
},
this.allDOMEventHandlers,
!0
);
b = document.createElement("div");
b.style.cssText = "padding: 12px 8px 12px 8px";
b.innerHTML = this._cultureInfo.savePNGText;
b.style.backgroundColor = this.toolbar.backgroundColor;
b.style.color = this.toolbar.fontColor;
this._dropdownMenu.appendChild(b);
O(
b,
"touchstart",
function (a) {
d = !0;
},
this.allDOMEventHandlers
);
O(
b,
"mouseover",
function () {
d ||
((this.style.backgroundColor = a.toolbar.backgroundColorOnHover),
(this.style.color = a.toolbar.fontColorOnHover));
},
this.allDOMEventHandlers,
!0
);
O(
b,
"mouseout",
function () {
d ||
((this.style.backgroundColor = a.toolbar.backgroundColor),
(this.style.color = a.toolbar.fontColor));
},
this.allDOMEventHandlers,
!0
);
O(
b,
"click",
function () {
Ta(a.canvas, "png", a.exportFileName);
va(a._dropdownMenu);
},
this.allDOMEventHandlers,
!0
);
}
"none" !== this._toolBar.style.display &&
this._zoomButton &&
(this.panEnabled
? ua(a, a._zoomButton, "zoom")
: ua(a, a._zoomButton, "pan"),
a._resetButton.getAttribute("state") !== a._cultureInfo.resetText &&
ua(a, a._resetButton, "reset"));
this.options.toolTip &&
this.toolTip.options !== this.options.toolTip &&
(this.toolTip.options = this.options.toolTip);
for (var c in this.toolTip.options)
this.toolTip.options.hasOwnProperty(c) && this.toolTip.updateOption(c);
};
p.prototype._updateSize = function () {
var a;
a = [
this.canvas,
this._preRenderCanvas,
this.overlaidCanvas,
this._eventManager.ghostCanvas,
];
var d = 0,
b = 0;
this.options.width
? (d = this.width)
: (this.width = d =
0 < this.container.clientWidth
? this.container.clientWidth
: this.width);
this.options.height
? (b = this.height)
: (this.height = b =
0 < this.container.clientHeight
? this.container.clientHeight
: this.height);
if (this.canvas.width !== d * W || this.canvas.height !== b * W) {
for (var c = 0; c < a.length; c++) Oa(a[c], d, b);
a = !0;
} else a = !1;
return a;
};
p.prototype._initialize = function () {
this.isNavigator =
u(this.parent) ||
u(this.parent._defaultsKey) ||
"Navigator" !== this.parent._defaultsKey
? !1
: !0;
this.toolbar = new Va(this, this.options.toolbar);
this._animator
? this._animator.cancelAllAnimations()
: (this._animator = new ga(this));
this.removeAllEventListeners();
this.disableToolTip = !1;
this._axes = [];
this.funnelPyramidClickHandler = this.pieDoughnutClickHandler = null;
this._updateOptions();
this.animatedRender =
r && this.animationEnabled && 0 === this.renderCount;
this._updateSize();
this.clearCanvas();
this.ctx.beginPath();
this.axisX = [];
this.axisX2 = [];
this.axisY = [];
this.axisY2 = [];
this._indexLabels = [];
this._dataInRenderedOrder = [];
this._events = [];
this._eventManager && this._eventManager.reset();
this.plotInfo = { axisPlacement: null, plotTypes: [] };
this.layoutManager = new Ga(
0,
0,
this.width,
this.height,
this.isNavigator ? 0 : 2
);
this.plotArea.layoutManager && this.plotArea.layoutManager.reset();
this.data = [];
var a = 0,
d = null;
if (this.options.data) {
for (var b = 0; b < this.options.data.length; b++)
if (
(a++,
!this.options.data[b].type ||
0 <= p._supportedChartTypes.indexOf(this.options.data[b].type))
) {
var c = new F(
this,
this.options.data[b],
a - 1,
++this._eventManager.lastObjectId
);
"error" === c.type &&
((c.linkedDataSeriesIndex = u(
this.options.data[b].linkedDataSeriesIndex
)
? b - 1
: this.options.data[b].linkedDataSeriesIndex),
0 > c.linkedDataSeriesIndex ||
c.linkedDataSeriesIndex >= this.options.data.length ||
"number" !== typeof c.linkedDataSeriesIndex ||
"error" === this.options.data[c.linkedDataSeriesIndex].type) &&
(c.linkedDataSeriesIndex = null);
null === c.name && (c.name = "DataSeries " + a);
null === c.color
? 1 < this.options.data.length
? ((c._colorSet = [
this._selectedColorSet[
c.index % this._selectedColorSet.length
],
]),
(c.color =
this._selectedColorSet[
c.index % this._selectedColorSet.length
]))
: (c._colorSet =
"line" === c.type ||
"stepLine" === c.type ||
"spline" === c.type ||
"area" === c.type ||
"stepArea" === c.type ||
"splineArea" === c.type ||
"stackedArea" === c.type ||
"stackedArea100" === c.type ||
"rangeArea" === c.type ||
"rangeSplineArea" === c.type ||
"candlestick" === c.type ||
"ohlc" === c.type ||
"waterfall" === c.type ||
"boxAndWhisker" === c.type
? [this._selectedColorSet[0]]
: this._selectedColorSet)
: (c._colorSet = [c.color]);
null === c.markerSize &&
((("line" === c.type ||
"stepLine" === c.type ||
"spline" === c.type ||
0 <= c.type.toLowerCase().indexOf("area")) &&
c.dataPoints &&
c.dataPoints.length < this.width / 16) ||
"scatter" === c.type) &&
(c.markerSize = 8);
("bubble" !== c.type && "scatter" !== c.type) ||
!c.dataPoints ||
(c.dataPoints.some
? c.dataPoints.some(function (a) {
return a.x;
}) && c.dataPoints.sort(k)
: c.dataPoints.sort(k));
this.data.push(c);
var e = c.axisPlacement,
d = d || e,
g;
"normal" === e
? "xySwapped" === this.plotInfo.axisPlacement
? (g = 'You cannot combine "' + c.type + '" with bar chart')
: "none" === this.plotInfo.axisPlacement
? (g = 'You cannot combine "' + c.type + '" with pie chart')
: null === this.plotInfo.axisPlacement &&
(this.plotInfo.axisPlacement = "normal")
: "xySwapped" === e
? "normal" === this.plotInfo.axisPlacement
? (g =
'You cannot combine "' +
c.type +
'" with line, area, column or pie chart')
: "none" === this.plotInfo.axisPlacement
? (g = 'You cannot combine "' + c.type + '" with pie chart')
: null === this.plotInfo.axisPlacement &&
(this.plotInfo.axisPlacement = "xySwapped")
: "none" === e
? "normal" === this.plotInfo.axisPlacement
? (g =
'You cannot combine "' +
c.type +
'" with line, area, column or bar chart')
: "xySwapped" === this.plotInfo.axisPlacement
? (g = 'You cannot combine "' + c.type + '" with bar chart')
: null === this.plotInfo.axisPlacement &&
(this.plotInfo.axisPlacement = "none")
: null === e &&
"none" === this.plotInfo.axisPlacement &&
(g = 'You cannot combine "' + c.type + '" with pie chart');
if (g && window.console) {
window.console.log(g);
return;
}
}
for (b = 0; b < this.data.length; b++) {
if ("none" == d && "error" === this.data[b].type && window.console) {
window.console.log(
'You cannot combine "' + c.type + '" with error chart'
);
return;
}
"error" === this.data[b].type &&
((this.data[b].axisPlacement = this.plotInfo.axisPlacement =
d || "normal"),
(this.data[b]._linkedSeries =
null === this.data[b].linkedDataSeriesIndex
? null
: this.data[this.data[b].linkedDataSeriesIndex]));
}
}
this._objectsInitialized = !0;
this._plotAreaElements = [];
};
p._supportedChartTypes = Fa(
"line stepLine spline column area stepArea splineArea bar bubble scatter stackedColumn stackedColumn100 stackedBar stackedBar100 stackedArea stackedArea100 candlestick ohlc boxAndWhisker rangeColumn error rangeBar rangeArea rangeSplineArea pie doughnut funnel pyramid waterfall".split(
" "
)
);
p.prototype.setLayout = function () {
for (var a = this._plotAreaElements, d = 0; d < this.data.length; d++)
if (
"normal" === this.plotInfo.axisPlacement ||
"xySwapped" === this.plotInfo.axisPlacement
) {
if (!this.data[d].axisYType || "primary" === this.data[d].axisYType)
if (this.options.axisY && 0 < this.options.axisY.length) {
if (!this.axisY.length)
for (var b = 0; b < this.options.axisY.length; b++)
"normal" === this.plotInfo.axisPlacement
? this._axes.push(
(this.axisY[b] = new z(
this,
"axisY",
this.options.axisY[b],
b,
"axisY",
"left"
))
)
: "xySwapped" === this.plotInfo.axisPlacement &&
this._axes.push(
(this.axisY[b] = new z(
this,
"axisY",
this.options.axisY[b],
b,
"axisY",
"bottom"
))
);
this.data[d].axisY =
this.axisY[
0 <= this.data[d].axisYIndex &&
this.data[d].axisYIndex < this.axisY.length
? this.data[d].axisYIndex
: 0
];
this.axisY[
0 <= this.data[d].axisYIndex &&
this.data[d].axisYIndex < this.axisY.length
? this.data[d].axisYIndex
: 0
].dataSeries.push(this.data[d]);
} else
this.axisY.length ||
("normal" === this.plotInfo.axisPlacement
? this._axes.push(
(this.axisY[0] = new z(
this,
"axisY",
this.options.axisY,
0,
"axisY",
"left"
))
)
: "xySwapped" === this.plotInfo.axisPlacement &&
this._axes.push(
(this.axisY[0] = new z(
this,
"axisY",
this.options.axisY,
0,
"axisY",
"bottom"
))
)),
(this.data[d].axisY = this.axisY[0]),
this.axisY[0].dataSeries.push(this.data[d]);
if ("secondary" === this.data[d].axisYType)
if (this.options.axisY2 && 0 < this.options.axisY2.length) {
if (!this.axisY2.length)
for (b = 0; b < this.options.axisY2.length; b++)
"normal" === this.plotInfo.axisPlacement
? this._axes.push(
(this.axisY2[b] = new z(
this,
"axisY2",
this.options.axisY2[b],
b,
"axisY",
"right"
))
)
: "xySwapped" === this.plotInfo.axisPlacement &&
this._axes.push(
(this.axisY2[b] = new z(
this,
"axisY2",
this.options.axisY2[b],
b,
"axisY",
"top"
))
);
this.data[d].axisY =
this.axisY2[
0 <= this.data[d].axisYIndex &&
this.data[d].axisYIndex < this.axisY2.length
? this.data[d].axisYIndex
: 0
];
this.axisY2[
0 <= this.data[d].axisYIndex &&
this.data[d].axisYIndex < this.axisY2.length
? this.data[d].axisYIndex
: 0
].dataSeries.push(this.data[d]);
} else
this.axisY2.length ||
("normal" === this.plotInfo.axisPlacement
? this._axes.push(
(this.axisY2[0] = new z(
this,
"axisY2",
this.options.axisY2,
0,
"axisY",
"right"
))
)
: "xySwapped" === this.plotInfo.axisPlacement &&
this._axes.push(
(this.axisY2[0] = new z(
this,
"axisY2",
this.options.axisY2,
0,
"axisY",
"top"
))
)),
(this.data[d].axisY = this.axisY2[0]),
this.axisY2[0].dataSeries.push(this.data[d]);
if (!this.data[d].axisXType || "primary" === this.data[d].axisXType)
if (this.options.axisX && 0 < this.options.axisX.length) {
if (!this.axisX.length)
for (b = 0; b < this.options.axisX.length; b++)
"normal" === this.plotInfo.axisPlacement
? this._axes.push(
(this.axisX[b] = new z(
this,
"axisX",
this.options.axisX[b],
b,
"axisX",
"bottom"
))
)
: "xySwapped" === this.plotInfo.axisPlacement &&
this._axes.push(
(this.axisX[b] = new z(
this,
"axisX",
this.options.axisX[b],
b,
"axisX",
"left"
))
);
this.data[d].axisX =
this.axisX[
0 <= this.data[d].axisXIndex &&
this.data[d].axisXIndex < this.axisX.length
? this.data[d].axisXIndex
: 0
];
this.axisX[
0 <= this.data[d].axisXIndex &&
this.data[d].axisXIndex < this.axisX.length
? this.data[d].axisXIndex
: 0
].dataSeries.push(this.data[d]);
} else
this.axisX.length ||
("normal" === this.plotInfo.axisPlacement
? this._axes.push(
(this.axisX[0] = new z(
this,
"axisX",
this.options.axisX,
0,
"axisX",
"bottom"
))
)
: "xySwapped" === this.plotInfo.axisPlacement &&
this._axes.push(
(this.axisX[0] = new z(
this,
"axisX",
this.options.axisX,
0,
"axisX",
"left"
))
)),
(this.data[d].axisX = this.axisX[0]),
this.axisX[0].dataSeries.push(this.data[d]);
if ("secondary" === this.data[d].axisXType)
if (this.options.axisX2 && 0 < this.options.axisX2.length) {
if (!this.axisX2.length)
for (b = 0; b < this.options.axisX2.length; b++)
"normal" === this.plotInfo.axisPlacement
? this._axes.push(
(this.axisX2[b] = new z(
this,
"axisX2",
this.options.axisX2[b],
b,
"axisX",
"top"
))
)
: "xySwapped" === this.plotInfo.axisPlacement &&
this._axes.push(
(this.axisX2[b] = new z(
this,
"axisX2",
this.options.axisX2[b],
b,
"axisX",
"right"
))
);
this.data[d].axisX =
this.axisX2[
0 <= this.data[d].axisXIndex &&
this.data[d].axisXIndex < this.axisX2.length
? this.data[d].axisXIndex
: 0
];
this.axisX2[
0 <= this.data[d].axisXIndex &&
this.data[d].axisXIndex < this.axisX2.length
? this.data[d].axisXIndex
: 0
].dataSeries.push(this.data[d]);
} else
this.axisX2.length ||
("normal" === this.plotInfo.axisPlacement
? this._axes.push(
(this.axisX2[0] = new z(
this,
"axisX2",
this.options.axisX2,
0,
"axisX",
"top"
))
)
: "xySwapped" === this.plotInfo.axisPlacement &&
this._axes.push(
(this.axisX2[0] = new z(
this,
"axisX2",
this.options.axisX2,
0,
"axisX",
"right"
))
)),
(this.data[d].axisX = this.axisX2[0]),
this.axisX2[0].dataSeries.push(this.data[d]);
}
if (this.axisY) {
for (b = 1; b < this.axisY.length; b++)
"undefined" === typeof this.axisY[b].options.gridThickness &&
(this.axisY[b].gridThickness = 0);
for (b = 0; b < this.axisY.length - 1; b++)
"undefined" === typeof this.axisY[b].options.margin &&
(this.axisY[b].margin = 10);
}
if (this.axisY2) {
for (b = 1; b < this.axisY2.length; b++)
"undefined" === typeof this.axisY2[b].options.gridThickness &&
(this.axisY2[b].gridThickness = 0);
for (b = 0; b < this.axisY2.length - 1; b++)
"undefined" === typeof this.axisY2[b].options.margin &&
(this.axisY2[b].margin = 10);
}
this.axisY &&
0 < this.axisY.length &&
this.axisY2 &&
0 < this.axisY2.length &&
(0 < this.axisY[0].gridThickness &&
"undefined" === typeof this.axisY2[0].options.gridThickness
? (this.axisY2[0].gridThickness = 0)
: 0 < this.axisY2[0].gridThickness &&
"undefined" === typeof this.axisY[0].options.gridThickness &&
(this.axisY[0].gridThickness = 0));
if (this.axisX)
for (b = 0; b < this.axisX.length; b++)
"undefined" === typeof this.axisX[b].options.gridThickness &&
(this.axisX[b].gridThickness = 0);
if (this.axisX2)
for (b = 0; b < this.axisX2.length; b++)
"undefined" === typeof this.axisX2[b].options.gridThickness &&
(this.axisX2[b].gridThickness = 0);
this.axisX &&
0 < this.axisX.length &&
this.axisX2 &&
0 < this.axisX2.length &&
(0 < this.axisX[0].gridThickness &&
"undefined" === typeof this.axisX2[0].options.gridThickness
? (this.axisX2[0].gridThickness = 0)
: 0 < this.axisX2[0].gridThickness &&
"undefined" === typeof this.axisX[0].options.gridThickness &&
(this.axisX[0].gridThickness = 0));
b = !1;
if (0 < this._axes.length && (this.zoomEnabled || this.panEnabled))
for (d = 0; d < this._axes.length; d++)
if (
null !== this._axes[d].viewportMinimum ||
null !== this._axes[d].viewportMaximum
) {
b = !0;
break;
}
b
? (Qa(this._zoomButton, this._resetButton),
(this._toolBar.style.border =
this.toolbar.borderThickness +
"px solid " +
this.toolbar.borderColor),
(this._zoomButton.style.borderRight =
this.toolbar.borderThickness +
"px solid " +
this.toolbar.borderColor),
(this._resetButton.style.borderRight =
(this.exportEnabled ? this.toolbar.borderThickness : 0) +
"px solid " +
this.toolbar.borderColor))
: (va(this._zoomButton, this._resetButton),
(this._toolBar.style.border =
this.toolbar.borderThickness + "px solid transparent"),
this.options.zoomEnabled &&
((this.zoomEnabled = !0), (this.panEnabled = !1)));
gb(this);
this._processData();
this.options.title &&
((this.title = new Aa(this, this.options.title)),
this.title.dockInsidePlotArea
? a.push(this.title)
: this.title.setLayout());
this.subtitles = [];
if (this.options.subtitles)
for (d = 0; d < this.options.subtitles.length; d++)
(b = new Ka(this, this.options.subtitles[d], d)),
this.subtitles.push(b),
b.dockInsidePlotArea ? a.push(b) : b.setLayout();
this.legend = new H(this, this.options.legend);
for (d = 0; d < this.data.length; d++)
(this.data[d].showInLegend ||
"pie" === this.data[d].type ||
"doughnut" === this.data[d].type ||
"funnel" === this.data[d].type ||
"pyramid" === this.data[d].type) &&
this.legend.dataSeries.push(this.data[d]);
this.legend.dockInsidePlotArea
? a.push(this.legend)
: this.legend.setLayout();
for (d = 0; d < this._axes.length; d++)
if (
this._axes[d].scaleBreaks &&
this._axes[d].scaleBreaks._appliedBreaks.length
) {
r
? ((this._breaksCanvas = ta(this.width, this.height, !0)),
(this._breaksCanvasCtx = this._breaksCanvas.getContext("2d")))
: ((this._breaksCanvas = this.canvas),
(this._breaksCanvasCtx = this.ctx));
break;
}
this._preRenderCanvas = u(this._preRenderCanvas)
? ta(this.width, this.height)
: this._preRenderCanvas;
this._preRenderCtx = this._preRenderCanvas.getContext("2d");
("normal" !== this.plotInfo.axisPlacement &&
"xySwapped" !== this.plotInfo.axisPlacement) ||
z.setLayout(
this.axisX,
this.axisX2,
this.axisY,
this.axisY2,
this.plotInfo.axisPlacement,
this.layoutManager.getFreeSpace()
);
};
p.prototype.renderElements = function () {
var a = this._plotAreaElements;
this.title && !this.title.dockInsidePlotArea && this.title.render();
for (var d = 0; d < this.subtitles.length; d++)
this.subtitles[d].dockInsidePlotArea || this.subtitles[d].render();
this.legend.dockInsidePlotArea || this.legend.render();
if (
"normal" === this.plotInfo.axisPlacement ||
"xySwapped" === this.plotInfo.axisPlacement
)
z.render(
this.axisX,
this.axisX2,
this.axisY,
this.axisY2,
this.plotInfo.axisPlacement
);
else if ("none" === this.plotInfo.axisPlacement) this.preparePlotArea();
else return;
for (d = 0; d < a.length; d++) a[d].setLayout(), a[d].render();
var b = [];
if (this.animatedRender) {
var c = ta(this.width, this.height);
c.getContext("2d").drawImage(
this.canvas,
0,
0,
this.width,
this.height
);
}
hb(this);
var a = this.ctx.miterLimit,
e;
this.ctx.miterLimit = 3;
r &&
this._breaksCanvas &&
(this._preRenderCtx.drawImage(
this.canvas,
0,
0,
this.width,
this.height
),
this._preRenderCtx.drawImage(
this._breaksCanvas,
0,
0,
this.width,
this.height
),
(this._breaksCanvasCtx.globalCompositeOperation = "source-atop"),
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
this._preRenderCtx.clearRect(0, 0, this.width, this.height));
for (d = 0; d < this.plotInfo.plotTypes.length; d++)
for (
var g = this.plotInfo.plotTypes[d], m = 0;
m < g.plotUnits.length;
m++
) {
var l = g.plotUnits[m],
w = null;
l.targetCanvas = null;
this.animatedRender &&
((l.targetCanvas = ta(this.width, this.height)),
(l.targetCanvasCtx = l.targetCanvas.getContext("2d")),
(e = l.targetCanvasCtx.miterLimit),
(l.targetCanvasCtx.miterLimit = 3));
"line" === l.type
? (w = this.renderLine(l))
: "stepLine" === l.type
? (w = this.renderStepLine(l))
: "spline" === l.type
? (w = this.renderSpline(l))
: "column" === l.type
? (w = this.renderColumn(l))
: "bar" === l.type
? (w = this.renderBar(l))
: "area" === l.type
? (w = this.renderArea(l))
: "stepArea" === l.type
? (w = this.renderStepArea(l))
: "splineArea" === l.type
? (w = this.renderSplineArea(l))
: "stackedColumn" === l.type
? (w = this.renderStackedColumn(l))
: "stackedColumn100" === l.type
? (w = this.renderStackedColumn100(l))
: "stackedBar" === l.type
? (w = this.renderStackedBar(l))
: "stackedBar100" === l.type
? (w = this.renderStackedBar100(l))
: "stackedArea" === l.type
? (w = this.renderStackedArea(l))
: "stackedArea100" === l.type
? (w = this.renderStackedArea100(l))
: "bubble" === l.type
? (w = w = this.renderBubble(l))
: "scatter" === l.type
? (w = this.renderScatter(l))
: "pie" === l.type
? this.renderPie(l)
: "doughnut" === l.type
? this.renderPie(l)
: "funnel" === l.type
? (w = this.renderFunnel(l))
: "pyramid" === l.type
? (w = this.renderFunnel(l))
: "candlestick" === l.type
? (w = this.renderCandlestick(l))
: "ohlc" === l.type
? (w = this.renderCandlestick(l))
: "rangeColumn" === l.type
? (w = this.renderRangeColumn(l))
: "error" === l.type
? (w = this.renderError(l))
: "rangeBar" === l.type
? (w = this.renderRangeBar(l))
: "rangeArea" === l.type
? (w = this.renderRangeArea(l))
: "rangeSplineArea" === l.type
? (w = this.renderRangeSplineArea(l))
: "waterfall" === l.type
? (w = this.renderWaterfall(l))
: "boxAndWhisker" === l.type && (w = this.renderBoxAndWhisker(l));
for (var h = 0; h < l.dataSeriesIndexes.length; h++)
this._dataInRenderedOrder.push(this.data[l.dataSeriesIndexes[h]]);
this.animatedRender &&
((l.targetCanvasCtx.miterLimit = e), w && b.push(w));
}
this.ctx.miterLimit = a;
this.animatedRender &&
this._breaksCanvasCtx &&
b.push({
source: this._breaksCanvasCtx,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
startTimePercent: 0.7,
});
this.animatedRender &&
0 < this._indexLabels.length &&
((e = ta(this.width, this.height).getContext("2d")),
b.push(this.renderIndexLabels(e)));
var s = this;
if (0 < b.length)
(s.disableToolTip = !0),
s._animator.animate(
200,
s.animationDuration,
function (a) {
s.ctx.clearRect(0, 0, s.width, s.height);
s.ctx.drawImage(
c,
0,
0,
Math.floor(s.width * W),
Math.floor(s.height * W),
0,
0,
s.width,
s.height
);
for (var e = 0; e < b.length; e++)
(w = b[e]),
1 > a && "undefined" !== typeof w.startTimePercent
? a >= w.startTimePercent &&
w.animationCallback(
w.easingFunction(
a - w.startTimePercent,
0,
1,
1 - w.startTimePercent
),
w
)
: w.animationCallback(w.easingFunction(a, 0, 1, 1), w);
s.dispatchEvent("dataAnimationIterationEnd", { chart: s });
},
function () {
b = [];
for (var a = 0; a < s.plotInfo.plotTypes.length; a++)
for (
var e = s.plotInfo.plotTypes[a], d = 0;
d < e.plotUnits.length;
d++
)
e.plotUnits[d].targetCanvas = null;
c = null;
s.disableToolTip = !1;
}
);
else {
if (s._breaksCanvas)
if (r)
s.plotArea.ctx.drawImage(
s._breaksCanvas,
0,
0,
this.width,
this.height
);
else for (h = 0; h < s._axes.length; h++) s._axes[h].createMask();
0 < s._indexLabels.length && s.renderIndexLabels();
s.dispatchEvent("dataAnimationIterationEnd", { chart: s });
}
this.attachPlotAreaEventHandlers();
this.zoomEnabled ||
this.panEnabled ||
!this._zoomButton ||
"none" === this._zoomButton.style.display ||
va(this._zoomButton, this._resetButton);
this.toolTip._updateToolTip();
this.renderCount++;
Ja &&
((s = this),
setTimeout(function () {
var a = document.getElementById("ghostCanvasCopy");
a &&
(Oa(a, s.width, s.height),
a.getContext("2d").drawImage(s._eventManager.ghostCanvas, 0, 0));
}, 2e3));
this._breaksCanvas &&
(delete this._breaksCanvas, delete this._breaksCanvasCtx);
for (h = 0; h < this._axes.length; h++)
this._axes[h].maskCanvas &&
(delete this._axes[h].maskCanvas, delete this._axes[h].maskCtx);
};
p.prototype.render = function (a) {
a && (this.options = a);
this._initialize();
this.setLayout();
this.renderElements();
};
p.prototype.attachPlotAreaEventHandlers = function () {
this.attachEvent({
context: this,
chart: this,
mousedown: this._plotAreaMouseDown,
mouseup: this._plotAreaMouseUp,
mousemove: this._plotAreaMouseMove,
cursor: this.panEnabled ? "move" : "default",
capture: !0,
bounds: this.plotArea,
});
};
p.prototype.categoriseDataSeries = function () {
for (var a = "", d = 0; d < this.data.length; d++)
if (
((a = this.data[d]),
a.dataPoints &&
0 !== a.dataPoints.length &&
a.visible &&
0 <= p._supportedChartTypes.indexOf(a.type))
) {
for (
var b = null, c = !1, e = null, g = !1, m = 0;
m < this.plotInfo.plotTypes.length;
m++
)
if (this.plotInfo.plotTypes[m].type === a.type) {
c = !0;
b = this.plotInfo.plotTypes[m];
break;
}
c ||
((b = { type: a.type, totalDataSeries: 0, plotUnits: [] }),
this.plotInfo.plotTypes.push(b));
for (m = 0; m < b.plotUnits.length; m++)
if (
b.plotUnits[m].axisYType === a.axisYType &&
b.plotUnits[m].axisXType === a.axisXType &&
b.plotUnits[m].axisYIndex === a.axisYIndex &&
b.plotUnits[m].axisXIndex === a.axisXIndex
) {
g = !0;
e = b.plotUnits[m];
break;
}
g ||
((e = {
type: a.type,
previousDataSeriesCount: 0,
index: b.plotUnits.length,
plotType: b,
axisXType: a.axisXType,
axisYType: a.axisYType,
axisYIndex: a.axisYIndex,
axisXIndex: a.axisXIndex,
axisY:
"primary" === a.axisYType
? this.axisY[
0 <= a.axisYIndex && a.axisYIndex < this.axisY.length
? a.axisYIndex
: 0
]
: this.axisY2[
0 <= a.axisYIndex && a.axisYIndex < this.axisY2.length
? a.axisYIndex
: 0
],
axisX:
"primary" === a.axisXType
? this.axisX[
0 <= a.axisXIndex && a.axisXIndex < this.axisX.length
? a.axisXIndex
: 0
]
: this.axisX2[
0 <= a.axisXIndex && a.axisXIndex < this.axisX2.length
? a.axisXIndex
: 0
],
dataSeriesIndexes: [],
yTotals: [],
}),
b.plotUnits.push(e));
b.totalDataSeries++;
e.dataSeriesIndexes.push(d);
a.plotUnit = e;
}
for (d = 0; d < this.plotInfo.plotTypes.length; d++)
for (
b = this.plotInfo.plotTypes[d], m = a = 0;
m < b.plotUnits.length;
m++
)
(b.plotUnits[m].previousDataSeriesCount = a),
(a += b.plotUnits[m].dataSeriesIndexes.length);
};
p.prototype.assignIdToDataPoints = function () {
for (var a = 0; a < this.data.length; a++) {
var d = this.data[a];
if (d.dataPoints)
for (var b = d.dataPoints.length, c = 0; c < b; c++)
d.dataPointIds[c] = ++this._eventManager.lastObjectId;
}
};
p.prototype._processData = function () {
this.assignIdToDataPoints();
this.categoriseDataSeries();
for (var a = 0; a < this.plotInfo.plotTypes.length; a++)
for (
var d = this.plotInfo.plotTypes[a], b = 0;
b < d.plotUnits.length;
b++
) {
var c = d.plotUnits[b];
"line" === c.type ||
"stepLine" === c.type ||
"spline" === c.type ||
"column" === c.type ||
"area" === c.type ||
"stepArea" === c.type ||
"splineArea" === c.type ||
"bar" === c.type ||
"bubble" === c.type ||
"scatter" === c.type
? this._processMultiseriesPlotUnit(c)
: "stackedColumn" === c.type ||
"stackedBar" === c.type ||
"stackedArea" === c.type
? this._processStackedPlotUnit(c)
: "stackedColumn100" === c.type ||
"stackedBar100" === c.type ||
"stackedArea100" === c.type
? this._processStacked100PlotUnit(c)
: "candlestick" === c.type ||
"ohlc" === c.type ||
"rangeColumn" === c.type ||
"rangeBar" === c.type ||
"rangeArea" === c.type ||
"rangeSplineArea" === c.type ||
"error" === c.type ||
"boxAndWhisker" === c.type
? this._processMultiYPlotUnit(c)
: "waterfall" === c.type && this._processSpecificPlotUnit(c);
}
this.calculateAutoBreaks();
};
p.prototype._processMultiseriesPlotUnit = function (a) {
if (a.dataSeriesIndexes && !(1 > a.dataSeriesIndexes.length))
for (
var d = a.axisY.dataInfo, b = a.axisX.dataInfo, c, e, g = !1, m = 0;
m < a.dataSeriesIndexes.length;
m++
) {
var l = this.data[a.dataSeriesIndexes[m]],
w = 0,
h = !1,
s = !1,
q;
if ("normal" === l.axisPlacement || "xySwapped" === l.axisPlacement)
var n = a.axisX.sessionVariables.newViewportMinimum
? a.axisX.sessionVariables.newViewportMinimum
: this.options.axisX && this.options.axisX.viewportMinimum
? this.options.axisX.viewportMinimum
: this.options.axisX && this.options.axisX.minimum
? this.options.axisX.minimum
: a.axisX.logarithmic
? 0
: -Infinity,
f = a.axisX.sessionVariables.newViewportMaximum
? a.axisX.sessionVariables.newViewportMaximum
: this.options.axisX && this.options.axisX.viewportMaximum
? this.options.axisX.viewportMaximum
: this.options.axisX && this.options.axisX.maximum
? this.options.axisX.maximum
: Infinity;
if (
(l.dataPoints[w].x && l.dataPoints[w].x.getTime) ||
"dateTime" === l.xValueType
)
g = !0;
for (w = 0; w < l.dataPoints.length; w++) {
"undefined" === typeof l.dataPoints[w].x &&
(l.dataPoints[w].x = w + (a.axisX.logarithmic ? 1 : 0));
l.dataPoints[w].x.getTime
? ((g = !0), (c = l.dataPoints[w].x.getTime()))
: (c = l.dataPoints[w].x);
e = l.dataPoints[w].y;
c < b.min && (b.min = c);
c > b.max && (b.max = c);
e < d.min && "number" === typeof e && (d.min = e);
e > d.max && "number" === typeof e && (d.max = e);
if (0 < w) {
if (a.axisX.logarithmic) {
var B = c / l.dataPoints[w - 1].x;
1 > B && (B = 1 / B);
b.minDiff > B && 1 !== B && (b.minDiff = B);
} else
(B = c - l.dataPoints[w - 1].x),
0 > B && (B *= -1),
b.minDiff > B && 0 !== B && (b.minDiff = B);
null !== e &&
null !== l.dataPoints[w - 1].y &&
(a.axisY.logarithmic
? ((B = e / l.dataPoints[w - 1].y),
1 > B && (B = 1 / B),
d.minDiff > B && 1 !== B && (d.minDiff = B))
: ((B = e - l.dataPoints[w - 1].y),
0 > B && (B *= -1),
d.minDiff > B && 0 !== B && (d.minDiff = B)));
}
if (c < n && !h) null !== e && (q = c);
else {
if (!h && ((h = !0), 0 < w)) {
w -= 2;
continue;
}
if (c > f && !s) s = !0;
else if (c > f && s) continue;
l.dataPoints[w].label &&
(a.axisX.labels[c] = l.dataPoints[w].label);
c < b.viewPortMin && (b.viewPortMin = c);
c > b.viewPortMax && (b.viewPortMax = c);
null === e
? b.viewPortMin === c && q < c && (b.viewPortMin = q)
: (e < d.viewPortMin &&
"number" === typeof e &&
(d.viewPortMin = e),
e > d.viewPortMax &&
"number" === typeof e &&
(d.viewPortMax = e));
}
}
l.axisX.valueType = l.xValueType = g ? "dateTime" : "number";
}
};
p.prototype._processStackedPlotUnit = function (a) {
if (a.dataSeriesIndexes && !(1 > a.dataSeriesIndexes.length)) {
for (
var d = a.axisY.dataInfo,
b = a.axisX.dataInfo,
c,
e,
g = !1,
m = [],
l = [],
w = Infinity,
h = -Infinity,
s = 0;
s < a.dataSeriesIndexes.length;
s++
) {
var q = this.data[a.dataSeriesIndexes[s]],
n = 0,
f = !1,
B = !1,
k;
if ("normal" === q.axisPlacement || "xySwapped" === q.axisPlacement)
var p = a.axisX.sessionVariables.newViewportMinimum
? a.axisX.sessionVariables.newViewportMinimum
: this.options.axisX && this.options.axisX.viewportMinimum
? this.options.axisX.viewportMinimum
: this.options.axisX && this.options.axisX.minimum
? this.options.axisX.minimum
: -Infinity,
t = a.axisX.sessionVariables.newViewportMaximum
? a.axisX.sessionVariables.newViewportMaximum
: this.options.axisX && this.options.axisX.viewportMaximum
? this.options.axisX.viewportMaximum
: this.options.axisX && this.options.axisX.maximum
? this.options.axisX.maximum
: Infinity;
if (
(q.dataPoints[n].x && q.dataPoints[n].x.getTime) ||
"dateTime" === q.xValueType
)
g = !0;
for (n = 0; n < q.dataPoints.length; n++) {
"undefined" === typeof q.dataPoints[n].x &&
(q.dataPoints[n].x = n + (a.axisX.logarithmic ? 1 : 0));
q.dataPoints[n].x.getTime
? ((g = !0), (c = q.dataPoints[n].x.getTime()))
: (c = q.dataPoints[n].x);
e = u(q.dataPoints[n].y) ? 0 : q.dataPoints[n].y;
c < b.min && (b.min = c);
c > b.max && (b.max = c);
if (0 < n) {
if (a.axisX.logarithmic) {
var r = c / q.dataPoints[n - 1].x;
1 > r && (r = 1 / r);
b.minDiff > r && 1 !== r && (b.minDiff = r);
} else
(r = c - q.dataPoints[n - 1].x),
0 > r && (r *= -1),
b.minDiff > r && 0 !== r && (b.minDiff = r);
null !== e &&
null !== q.dataPoints[n - 1].y &&
(a.axisY.logarithmic
? 0 < e &&
((r = e / q.dataPoints[n - 1].y),
1 > r && (r = 1 / r),
d.minDiff > r && 1 !== r && (d.minDiff = r))
: ((r = e - q.dataPoints[n - 1].y),
0 > r && (r *= -1),
d.minDiff > r && 0 !== r && (d.minDiff = r)));
}
if (c < p && !f) null !== q.dataPoints[n].y && (k = c);
else {
if (!f && ((f = !0), 0 < n)) {
n -= 2;
continue;
}
if (c > t && !B) B = !0;
else if (c > t && B) continue;
q.dataPoints[n].label &&
(a.axisX.labels[c] = q.dataPoints[n].label);
c < b.viewPortMin && (b.viewPortMin = c);
c > b.viewPortMax && (b.viewPortMax = c);
null === q.dataPoints[n].y
? b.viewPortMin === c && k < c && (b.viewPortMin = k)
: ((a.yTotals[c] = (a.yTotals[c] ? a.yTotals[c] : 0) + e),
0 <= e
? m[c]
? (m[c] += e)
: ((m[c] = e), (w = Math.min(e, w)))
: l[c]
? (l[c] += e)
: ((l[c] = e), (h = Math.max(e, h))));
}
}
a.axisY.scaleBreaks &&
a.axisY.scaleBreaks.autoCalculate &&
1 <= a.axisY.scaleBreaks.maxNumberOfAutoBreaks &&
(d.dataPointYPositiveSums
? (d.dataPointYPositiveSums.push.apply(
d.dataPointYPositiveSums,
m
),
d.dataPointYNegativeSums.push.apply(
d.dataPointYPositiveSums,
l
))
: ((d.dataPointYPositiveSums = m),
(d.dataPointYNegativeSums = l)));
q.axisX.valueType = q.xValueType = g ? "dateTime" : "number";
}
for (n in m)
m.hasOwnProperty(n) &&
!isNaN(n) &&
((a = m[n]),
a < d.min && (d.min = Math.min(a, w)),
a > d.max && (d.max = a),
n < b.viewPortMin ||
n > b.viewPortMax ||
(a < d.viewPortMin && (d.viewPortMin = Math.min(a, w)),
a > d.viewPortMax && (d.viewPortMax = a)));
for (n in l)
l.hasOwnProperty(n) &&
!isNaN(n) &&
((a = l[n]),
a < d.min && (d.min = a),
a > d.max && (d.max = Math.max(a, h)),
n < b.viewPortMin ||
n > b.viewPortMax ||
(a < d.viewPortMin && (d.viewPortMin = a),
a > d.viewPortMax && (d.viewPortMax = Math.max(a, h))));
}
};
p.prototype._processStacked100PlotUnit = function (a) {
if (a.dataSeriesIndexes && !(1 > a.dataSeriesIndexes.length)) {
for (
var d = a.axisY.dataInfo,
b = a.axisX.dataInfo,
c,
e,
g = !1,
m = !1,
l = !1,
w = [],
h = 0;
h < a.dataSeriesIndexes.length;
h++
) {
var s = this.data[a.dataSeriesIndexes[h]],
q = 0,
n = !1,
f = !1,
B;
if ("normal" === s.axisPlacement || "xySwapped" === s.axisPlacement)
var k = a.axisX.sessionVariables.newViewportMinimum
? a.axisX.sessionVariables.newViewportMinimum
: this.options.axisX && this.options.axisX.viewportMinimum
? this.options.axisX.viewportMinimum
: this.options.axisX && this.options.axisX.minimum
? this.options.axisX.minimum
: -Infinity,
r = a.axisX.sessionVariables.newViewportMaximum
? a.axisX.sessionVariables.newViewportMaximum
: this.options.axisX && this.options.axisX.viewportMaximum
? this.options.axisX.viewportMaximum
: this.options.axisX && this.options.axisX.maximum
? this.options.axisX.maximum
: Infinity;
if (
(s.dataPoints[q].x && s.dataPoints[q].x.getTime) ||
"dateTime" === s.xValueType
)
g = !0;
for (q = 0; q < s.dataPoints.length; q++) {
"undefined" === typeof s.dataPoints[q].x &&
(s.dataPoints[q].x = q + (a.axisX.logarithmic ? 1 : 0));
s.dataPoints[q].x.getTime
? ((g = !0), (c = s.dataPoints[q].x.getTime()))
: (c = s.dataPoints[q].x);
e = u(s.dataPoints[q].y) ? null : s.dataPoints[q].y;
c < b.min && (b.min = c);
c > b.max && (b.max = c);
if (0 < q) {
if (a.axisX.logarithmic) {
var t = c / s.dataPoints[q - 1].x;
1 > t && (t = 1 / t);
b.minDiff > t && 1 !== t && (b.minDiff = t);
} else
(t = c - s.dataPoints[q - 1].x),
0 > t && (t *= -1),
b.minDiff > t && 0 !== t && (b.minDiff = t);
u(e) ||
null === s.dataPoints[q - 1].y ||
(a.axisY.logarithmic
? 0 < e &&
((t = e / s.dataPoints[q - 1].y),
1 > t && (t = 1 / t),
d.minDiff > t && 1 !== t && (d.minDiff = t))
: ((t = e - s.dataPoints[q - 1].y),
0 > t && (t *= -1),
d.minDiff > t && 0 !== t && (d.minDiff = t)));
}
if (c < k && !n) null !== e && (B = c);
else {
if (!n && ((n = !0), 0 < q)) {
q -= 2;
continue;
}
if (c > r && !f) f = !0;
else if (c > r && f) continue;
s.dataPoints[q].label &&
(a.axisX.labels[c] = s.dataPoints[q].label);
c < b.viewPortMin && (b.viewPortMin = c);
c > b.viewPortMax && (b.viewPortMax = c);
null === e
? b.viewPortMin === c && B < c && (b.viewPortMin = B)
: ((a.yTotals[c] = (a.yTotals[c] ? a.yTotals[c] : 0) + e),
0 <= e ? (m = !0) : 0 > e && (l = !0),
(w[c] = w[c] ? w[c] + Math.abs(e) : Math.abs(e)));
}
}
s.axisX.valueType = s.xValueType = g ? "dateTime" : "number";
}
a.axisY.logarithmic
? ((d.max = u(d.viewPortMax)
? 99 * Math.pow(a.axisY.logarithmBase, -0.05)
: Math.max(
d.viewPortMax,
99 * Math.pow(a.axisY.logarithmBase, -0.05)
)),
(d.min = u(d.viewPortMin) ? 1 : Math.min(d.viewPortMin, 1)))
: m && !l
? ((d.max = u(d.viewPortMax) ? 99 : Math.max(d.viewPortMax, 99)),
(d.min = u(d.viewPortMin) ? 1 : Math.min(d.viewPortMin, 1)))
: m && l
? ((d.max = u(d.viewPortMax) ? 99 : Math.max(d.viewPortMax, 99)),
(d.min = u(d.viewPortMin) ? -99 : Math.min(d.viewPortMin, -99)))
: !m &&
l &&
((d.max = u(d.viewPortMax) ? -1 : Math.max(d.viewPortMax, -1)),
(d.min = u(d.viewPortMin) ? -99 : Math.min(d.viewPortMin, -99)));
d.viewPortMin = d.min;
d.viewPortMax = d.max;
a.dataPointYSums = w;
}
};
p.prototype._processMultiYPlotUnit = function (a) {
if (a.dataSeriesIndexes && !(1 > a.dataSeriesIndexes.length))
for (
var d = a.axisY.dataInfo,
b = a.axisX.dataInfo,
c,
e,
g,
m,
l = !1,
w = 0;
w < a.dataSeriesIndexes.length;
w++
) {
var h = this.data[a.dataSeriesIndexes[w]],
s = 0,
q = !1,
n = !1,
f,
B,
k;
if ("normal" === h.axisPlacement || "xySwapped" === h.axisPlacement)
var r = a.axisX.sessionVariables.newViewportMinimum
? a.axisX.sessionVariables.newViewportMinimum
: this.options.axisX && this.options.axisX.viewportMinimum
? this.options.axisX.viewportMinimum
: this.options.axisX && this.options.axisX.minimum
? this.options.axisX.minimum
: a.axisX.logarithmic
? 0
: -Infinity,
t = a.axisX.sessionVariables.newViewportMaximum
? a.axisX.sessionVariables.newViewportMaximum
: this.options.axisX && this.options.axisX.viewportMaximum
? this.options.axisX.viewportMaximum
: this.options.axisX && this.options.axisX.maximum
? this.options.axisX.maximum
: Infinity;
if (
(h.dataPoints[s].x && h.dataPoints[s].x.getTime) ||
"dateTime" === h.xValueType
)
l = !0;
for (s = 0; s < h.dataPoints.length; s++) {
"undefined" === typeof h.dataPoints[s].x &&
(h.dataPoints[s].x = s + (a.axisX.logarithmic ? 1 : 0));
h.dataPoints[s].x.getTime
? ((l = !0), (c = h.dataPoints[s].x.getTime()))
: (c = h.dataPoints[s].x);
if ((e = h.dataPoints[s].y) && e.length) {
g = Math.min.apply(null, e);
m = Math.max.apply(null, e);
B = !0;
for (var p = 0; p < e.length; p++) null === e.k && (B = !1);
B && (q || (k = f), (f = c));
}
c < b.min && (b.min = c);
c > b.max && (b.max = c);
g < d.min && (d.min = g);
m > d.max && (d.max = m);
0 < s &&
(a.axisX.logarithmic
? ((B = c / h.dataPoints[s - 1].x),
1 > B && (B = 1 / B),
b.minDiff > B && 1 !== B && (b.minDiff = B))
: ((B = c - h.dataPoints[s - 1].x),
0 > B && (B *= -1),
b.minDiff > B && 0 !== B && (b.minDiff = B)),
e &&
null !== e[0] &&
h.dataPoints[s - 1].y &&
null !== h.dataPoints[s - 1].y[0] &&
(a.axisY.logarithmic
? ((B = e[0] / h.dataPoints[s - 1].y[0]),
1 > B && (B = 1 / B),
d.minDiff > B && 1 !== B && (d.minDiff = B))
: ((B = e[0] - h.dataPoints[s - 1].y[0]),
0 > B && (B *= -1),
d.minDiff > B && 0 !== B && (d.minDiff = B))));
if (!(c < r) || q) {
if (!q && ((q = !0), 0 < s)) {
s -= 2;
f = k;
continue;
}
if (c > t && !n) n = !0;
else if (c > t && n) continue;
h.dataPoints[s].label &&
(a.axisX.labels[c] = h.dataPoints[s].label);
c < b.viewPortMin && (b.viewPortMin = c);
c > b.viewPortMax && (b.viewPortMax = c);
if (b.viewPortMin === c && e)
for (p = 0; p < e.length; p++)
if (null === e[p] && f < c) {
b.viewPortMin = f;
break;
}
null === e
? b.viewPortMin === c && f < c && (b.viewPortMin = f)
: (g < d.viewPortMin && (d.viewPortMin = g),
m > d.viewPortMax && (d.viewPortMax = m));
}
}
h.axisX.valueType = h.xValueType = l ? "dateTime" : "number";
}
};
p.prototype._processSpecificPlotUnit = function (a) {
if (
"waterfall" === a.type &&
a.dataSeriesIndexes &&
!(1 > a.dataSeriesIndexes.length)
)
for (
var d = a.axisY.dataInfo, b = a.axisX.dataInfo, c, e, g = !1, m = 0;
m < a.dataSeriesIndexes.length;
m++
) {
var l = this.data[a.dataSeriesIndexes[m]],
w = 0,
h = !1,
s = !1,
q = (c = 0);
if ("normal" === l.axisPlacement || "xySwapped" === l.axisPlacement)
var n = a.axisX.sessionVariables.newViewportMinimum
? a.axisX.sessionVariables.newViewportMinimum
: this.options.axisX && this.options.axisX.viewportMinimum
? this.options.axisX.viewportMinimum
: this.options.axisX && this.options.axisX.minimum
? this.options.axisX.minimum
: a.axisX.logarithmic
? 0
: -Infinity,
f = a.axisX.sessionVariables.newViewportMaximum
? a.axisX.sessionVariables.newViewportMaximum
: this.options.axisX && this.options.axisX.viewportMaximum
? this.options.axisX.viewportMaximum
: this.options.axisX && this.options.axisX.maximum
? this.options.axisX.maximum
: Infinity;
if (
(l.dataPoints[w].x && l.dataPoints[w].x.getTime) ||
"dateTime" === l.xValueType
)
g = !0;
for (w = 0; w < l.dataPoints.length; w++)
"undefined" !== typeof l.dataPoints[w].isCumulativeSum &&
!0 === l.dataPoints[w].isCumulativeSum
? ((l.dataPointEOs[w].cumulativeSumYStartValue = 0),
(l.dataPointEOs[w].cumulativeSum =
0 === w ? 0 : l.dataPointEOs[w - 1].cumulativeSum),
(l.dataPoints[w].y =
0 === w ? 0 : l.dataPointEOs[w - 1].cumulativeSum))
: "undefined" !== typeof l.dataPoints[w].isIntermediateSum &&
!0 === l.dataPoints[w].isIntermediateSum
? ((l.dataPointEOs[w].cumulativeSumYStartValue = q),
(l.dataPointEOs[w].cumulativeSum =
0 === w ? 0 : l.dataPointEOs[w - 1].cumulativeSum),
(l.dataPoints[w].y = 0 === w ? 0 : c),
(q = 0 === w ? 0 : l.dataPointEOs[w - 1].cumulativeSum),
(c = 0))
: ((e =
"number" !== typeof l.dataPoints[w].y
? 0
: l.dataPoints[w].y),
(l.dataPointEOs[w].cumulativeSumYStartValue =
0 === w ? 0 : l.dataPointEOs[w - 1].cumulativeSum),
(l.dataPointEOs[w].cumulativeSum =
0 === w ? e : l.dataPointEOs[w - 1].cumulativeSum + e),
(c += e));
for (w = 0; w < l.dataPoints.length; w++)
if (
("undefined" === typeof l.dataPoints[w].x &&
(l.dataPoints[w].x = w + (a.axisX.logarithmic ? 1 : 0)),
l.dataPoints[w].x.getTime
? ((g = !0), (c = l.dataPoints[w].x.getTime()))
: (c = l.dataPoints[w].x),
(e = l.dataPoints[w].y),
c < b.min && (b.min = c),
c > b.max && (b.max = c),
l.dataPointEOs[w].cumulativeSum < d.min &&
(d.min = l.dataPointEOs[w].cumulativeSum),
l.dataPointEOs[w].cumulativeSum > d.max &&
(d.max = l.dataPointEOs[w].cumulativeSum),
0 < w &&
(a.axisX.logarithmic
? ((q = c / l.dataPoints[w - 1].x),
1 > q && (q = 1 / q),
b.minDiff > q && 1 !== q && (b.minDiff = q))
: ((q = c - l.dataPoints[w - 1].x),
0 > q && (q *= -1),
b.minDiff > q && 0 !== q && (b.minDiff = q)),
null !== e &&
null !== l.dataPoints[w - 1].y &&
(a.axisY.logarithmic
? ((e =
l.dataPointEOs[w].cumulativeSum /
l.dataPointEOs[w - 1].cumulativeSum),
1 > e && (e = 1 / e),
d.minDiff > e && 1 !== e && (d.minDiff = e))
: ((e =
l.dataPointEOs[w].cumulativeSum -
l.dataPointEOs[w - 1].cumulativeSum),
0 > e && (e *= -1),
d.minDiff > e && 0 !== e && (d.minDiff = e)))),
!(c < n) || h)
) {
if (!h && ((h = !0), 0 < w)) {
w -= 2;
continue;
}
if (c > f && !s) s = !0;
else if (c > f && s) continue;
l.dataPoints[w].label &&
(a.axisX.labels[c] = l.dataPoints[w].label);
c < b.viewPortMin && (b.viewPortMin = c);
c > b.viewPortMax && (b.viewPortMax = c);
0 < w &&
(l.dataPointEOs[w - 1].cumulativeSum < d.viewPortMin &&
(d.viewPortMin = l.dataPointEOs[w - 1].cumulativeSum),
l.dataPointEOs[w - 1].cumulativeSum > d.viewPortMax &&
(d.viewPortMax = l.dataPointEOs[w - 1].cumulativeSum));
l.dataPointEOs[w].cumulativeSum < d.viewPortMin &&
(d.viewPortMin = l.dataPointEOs[w].cumulativeSum);
l.dataPointEOs[w].cumulativeSum > d.viewPortMax &&
(d.viewPortMax = l.dataPointEOs[w].cumulativeSum);
}
l.axisX.valueType = l.xValueType = g ? "dateTime" : "number";
}
};
p.prototype.calculateAutoBreaks = function () {
function a(a, c, b, e) {
if (e)
return (
(b = Math.pow(Math.min((b * a) / c, c / a), 0.2)),
1 >= b && (b = Math.pow(1 > a ? 1 / a : Math.min(c / a, a), 0.25)),
{ startValue: a * b, endValue: c / b }
);
b = 0.2 * Math.min(b - c + a, c - a);
0 >= b && (b = 0.25 * Math.min(c - a, Math.abs(a)));
return { startValue: a + b, endValue: c - b };
}
function d(a) {
if (a.dataSeriesIndexes && !(1 > a.dataSeriesIndexes.length)) {
var c =
a.axisX.scaleBreaks &&
a.axisX.scaleBreaks.autoCalculate &&
1 <= a.axisX.scaleBreaks.maxNumberOfAutoBreaks,
b =
a.axisY.scaleBreaks &&
a.axisY.scaleBreaks.autoCalculate &&
1 <= a.axisY.scaleBreaks.maxNumberOfAutoBreaks;
if (c || b)
for (
var d = a.axisY.dataInfo,
f = a.axisX.dataInfo,
g,
h = f.min,
l = f.max,
m = d.min,
n = d.max,
f = f._dataRanges,
d = d._dataRanges,
q,
w = 0,
s = 0;
s < a.dataSeriesIndexes.length;
s++
) {
var k = e.data[a.dataSeriesIndexes[s]];
if (!(4 > k.dataPoints.length))
for (w = 0; w < k.dataPoints.length; w++)
if (
(c &&
((q =
((l + 1 - h) *
Math.max(
parseFloat(
a.axisX.scaleBreaks.collapsibleThreshold
) || 10,
10
)) /
100),
(g = k.dataPoints[w].x.getTime
? k.dataPoints[w].x.getTime()
: k.dataPoints[w].x),
(q = Math.floor((g - h) / q)),
g < f[q].min && (f[q].min = g),
g > f[q].max && (f[q].max = g)),
b)
) {
var r =
((n + 1 - m) *
Math.max(
parseFloat(
a.axisY.scaleBreaks.collapsibleThreshold
) || 10,
10
)) /
100;
if (
(g =
"waterfall" === a.type
? k.dataPointEOs[w].cumulativeSum
: k.dataPoints[w].y) &&
g.length
)
for (var p = 0; p < g.length; p++)
(q = Math.floor((g[p] - m) / r)),
g[p] < d[q].min && (d[q].min = g[p]),
g[p] > d[q].max && (d[q].max = g[p]);
else
u(g) ||
((q = Math.floor((g - m) / r)),
g < d[q].min && (d[q].min = g),
g > d[q].max && (d[q].max = g));
}
}
}
}
function b(a) {
if (
a.dataSeriesIndexes &&
!(1 > a.dataSeriesIndexes.length) &&
a.axisX.scaleBreaks &&
a.axisX.scaleBreaks.autoCalculate &&
1 <= a.axisX.scaleBreaks.maxNumberOfAutoBreaks
)
for (
var c = a.axisX.dataInfo,
b = c.min,
d = c.max,
f = c._dataRanges,
g,
h = 0,
l = 0;
l < a.dataSeriesIndexes.length;
l++
) {
var m = e.data[a.dataSeriesIndexes[l]];
if (!(4 > m.dataPoints.length))
for (h = 0; h < m.dataPoints.length; h++)
(g =
((d + 1 - b) *
Math.max(
parseFloat(a.axisX.scaleBreaks.collapsibleThreshold) ||
10,
10
)) /
100),
(c = m.dataPoints[h].x.getTime
? m.dataPoints[h].x.getTime()
: m.dataPoints[h].x),
(g = Math.floor((c - b) / g)),
c < f[g].min && (f[g].min = c),
c > f[g].max && (f[g].max = c);
}
}
for (var c, e = this, g = !1, m = 0; m < this._axes.length; m++)
if (
this._axes[m].scaleBreaks &&
this._axes[m].scaleBreaks.autoCalculate &&
1 <= this._axes[m].scaleBreaks.maxNumberOfAutoBreaks
) {
g = !0;
this._axes[m].dataInfo._dataRanges = [];
for (
var l = 0;
l <
100 /
Math.max(
parseFloat(this._axes[m].scaleBreaks.collapsibleThreshold) ||
10,
10
);
l++
)
this._axes[m].dataInfo._dataRanges.push({
min: Infinity,
max: -Infinity,
});
}
if (g) {
for (m = 0; m < this.plotInfo.plotTypes.length; m++)
for (
g = this.plotInfo.plotTypes[m], l = 0;
l < g.plotUnits.length;
l++
)
(c = g.plotUnits[l]),
"line" === c.type ||
"stepLine" === c.type ||
"spline" === c.type ||
"column" === c.type ||
"area" === c.type ||
"stepArea" === c.type ||
"splineArea" === c.type ||
"bar" === c.type ||
"bubble" === c.type ||
"scatter" === c.type ||
"candlestick" === c.type ||
"ohlc" === c.type ||
"rangeColumn" === c.type ||
"rangeBar" === c.type ||
"rangeArea" === c.type ||
"rangeSplineArea" === c.type ||
"waterfall" === c.type ||
"error" === c.type ||
"boxAndWhisker" === c.type
? d(c)
: 0 <= c.type.indexOf("stacked") && b(c);
for (m = 0; m < this._axes.length; m++)
if (this._axes[m].dataInfo._dataRanges) {
var w = this._axes[m].dataInfo.min;
c =
((this._axes[m].dataInfo.max + 1 - w) *
Math.max(
parseFloat(this._axes[m].scaleBreaks.collapsibleThreshold) ||
10,
10
)) /
100;
var h = this._axes[m].dataInfo._dataRanges,
s,
q,
g = [];
if (this._axes[m].dataInfo.dataPointYPositiveSums) {
var n = this._axes[m].dataInfo.dataPointYPositiveSums;
s = h;
for (l in n)
if (n.hasOwnProperty(l) && !isNaN(l) && ((q = n[l]), !u(q))) {
var f = Math.floor((q - w) / c);
q < s[f].min && (s[f].min = q);
q > s[f].max && (s[f].max = q);
}
delete this._axes[m].dataInfo.dataPointYPositiveSums;
}
if (this._axes[m].dataInfo.dataPointYNegativeSums) {
n = this._axes[m].dataInfo.dataPointYNegativeSums;
s = h;
for (l in n)
n.hasOwnProperty(l) &&
!isNaN(l) &&
((q = -1 * n[l]),
u(q) ||
((f = Math.floor((q - w) / c)),
q < s[f].min && (s[f].min = q),
q > s[f].max && (s[f].max = q)));
delete this._axes[m].dataInfo.dataPointYNegativeSums;
}
for (l = 0; l < h.length - 1; l++)
if (((s = h[l].max), isFinite(s)))
for (; l < h.length - 1; )
if (((w = h[l + 1].min), isFinite(w))) {
q = w - s;
q > c && g.push({ diff: q, start: s, end: w });
break;
} else l++;
if (this._axes[m].scaleBreaks.customBreaks)
for (
l = 0;
l < this._axes[m].scaleBreaks.customBreaks.length;
l++
)
for (c = 0; c < g.length; c++)
if (
(this._axes[m].scaleBreaks.customBreaks[l].startValue <=
g[c].start &&
g[c].start <=
this._axes[m].scaleBreaks.customBreaks[l].endValue) ||
(this._axes[m].scaleBreaks.customBreaks[l].startValue <=
g[c].start &&
g[c].start <=
this._axes[m].scaleBreaks.customBreaks[l].endValue) ||
(g[c].start <=
this._axes[m].scaleBreaks.customBreaks[l].startValue &&
this._axes[m].scaleBreaks.customBreaks[l].startValue <=
g[c].end) ||
(g[c].start <=
this._axes[m].scaleBreaks.customBreaks[l].endValue &&
this._axes[m].scaleBreaks.customBreaks[l].endValue <=
g[c].end)
)
g.splice(c, 1), c--;
g.sort(function (a, c) {
return c.diff - a.diff;
});
for (
l = 0;
l <
Math.min(
g.length,
this._axes[m].scaleBreaks.maxNumberOfAutoBreaks
);
l++
)
(c = a(
g[l].start,
g[l].end,
this._axes[m].logarithmic
? this._axes[m].dataInfo.max / this._axes[m].dataInfo.min
: this._axes[m].dataInfo.max - this._axes[m].dataInfo.min,
this._axes[m].logarithmic
)),
this._axes[m].scaleBreaks.autoBreaks.push(
new L(
this,
"autoBreaks",
c,
l,
++this._eventManager.lastObjectId,
this._axes[m].scaleBreaks
)
),
this._axes[m].scaleBreaks._appliedBreaks.push(
this._axes[m].scaleBreaks.autoBreaks[
this._axes[m].scaleBreaks.autoBreaks.length - 1
]
);
this._axes[m].scaleBreaks._appliedBreaks.sort(function (a, c) {
return a.startValue - c.startValue;
});
}
}
};
p.prototype.getDataPointAtXY = function (a, d, b) {
b = b || !1;
for (var c = [], e = this._dataInRenderedOrder.length - 1; 0 <= e; e--) {
var g = null;
(g = this._dataInRenderedOrder[e].getDataPointAtXY(a, d, b)) &&
c.push(g);
}
a = null;
d = !1;
for (b = 0; b < c.length; b++)
if (
"line" === c[b].dataSeries.type ||
"stepLine" === c[b].dataSeries.type ||
"area" === c[b].dataSeries.type ||
"stepArea" === c[b].dataSeries.type
)
if (
((e = na("markerSize", c[b].dataPoint, c[b].dataSeries) || 8),
c[b].distance <= e / 2)
) {
d = !0;
break;
}
for (b = 0; b < c.length; b++)
(d &&
"line" !== c[b].dataSeries.type &&
"stepLine" !== c[b].dataSeries.type &&
"area" !== c[b].dataSeries.type &&
"stepArea" !== c[b].dataSeries.type) ||
(a ? c[b].distance <= a.distance && (a = c[b]) : (a = c[b]));
return a;
};
p.prototype.getObjectAtXY = function (a, d, b) {
var c = null;
if ((b = this.getDataPointAtXY(a, d, b || !1)))
c = b.dataSeries.dataPointIds[b.dataPointIndex];
else if (r) c = ab(a, d, this._eventManager.ghostCtx);
else
for (b = 0; b < this.legend.items.length; b++) {
var e = this.legend.items[b];
a >= e.x1 && a <= e.x2 && d >= e.y1 && d <= e.y2 && (c = e.id);
}
return c;
};
p.prototype.getAutoFontSize = lb;
p.prototype.resetOverlayedCanvas = function () {
this.overlaidCanvasCtx.clearRect(0, 0, this.width, this.height);
};
p.prototype.clearCanvas = kb;
p.prototype.attachEvent = function (a) {
this._events.push(a);
};
p.prototype._touchEventHandler = function (a) {
if (a.changedTouches && this.interactivityEnabled) {
var d = [],
b = a.changedTouches,
c = b ? b[0] : a,
e = null;
switch (a.type) {
case "touchstart":
case "MSPointerDown":
d = ["mousemove", "mousedown"];
this._lastTouchData = Ra(c);
this._lastTouchData.time = new Date();
break;
case "touchmove":
case "MSPointerMove":
d = ["mousemove"];
break;
case "touchend":
case "MSPointerUp":
var g =
this._lastTouchData && this._lastTouchData.time
? new Date() - this._lastTouchData.time
: 0,
d =
"touchstart" === this._lastTouchEventType ||
"MSPointerDown" === this._lastTouchEventType ||
300 > g
? ["mouseup", "click"]
: ["mouseup"];
break;
default:
return;
}
if (!(b && 1 < b.length)) {
e = Ra(c);
e.time = new Date();
try {
var m = e.y - this._lastTouchData.y,
g = e.time - this._lastTouchData.time;
if (
(1 < Math.abs(m) && this._lastTouchData.scroll) ||
(5 < Math.abs(m) && 250 > g)
)
this._lastTouchData.scroll = !0;
} catch (l) {}
this._lastTouchEventType = a.type;
if (this._lastTouchData.scroll && this.zoomEnabled)
this.isDrag && this.resetOverlayedCanvas(), (this.isDrag = !1);
else
for (b = 0; b < d.length; b++)
if (
((e = d[b]),
(m = document.createEvent("MouseEvent")),
m.initMouseEvent(
e,
!0,
!0,
window,
1,
c.screenX,
c.screenY,
c.clientX,
c.clientY,
!1,
!1,
!1,
!1,
0,
null
),
c.target.dispatchEvent(m),
(!u(this._lastTouchData.scroll) &&
!this._lastTouchData.scroll) ||
(!this._lastTouchData.scroll && 250 < g) ||
"click" === e)
)
a.preventManipulation && a.preventManipulation(),
a.preventDefault && a.preventDefault();
}
}
};
p.prototype._dispatchRangeEvent = function (a, d) {
var b = { chart: this };
b.type = a;
b.trigger = d;
var c = [];
this.axisX && 0 < this.axisX.length && c.push("axisX");
this.axisX2 && 0 < this.axisX2.length && c.push("axisX2");
this.axisY && 0 < this.axisY.length && c.push("axisY");
this.axisY2 && 0 < this.axisY2.length && c.push("axisY2");
for (var e = 0; e < c.length; e++)
if ((u(b[c[e]]) && (b[c[e]] = []), "axisY" === c[e]))
for (var g = 0; g < this.axisY.length; g++)
b[c[e]].push({
viewportMinimum:
this[c[e]][g].sessionVariables.newViewportMinimum,
viewportMaximum:
this[c[e]][g].sessionVariables.newViewportMaximum,
});
else if ("axisY2" === c[e])
for (g = 0; g < this.axisY2.length; g++)
b[c[e]].push({
viewportMinimum:
this[c[e]][g].sessionVariables.newViewportMinimum,
viewportMaximum:
this[c[e]][g].sessionVariables.newViewportMaximum,
});
else if ("axisX" === c[e])
for (g = 0; g < this.axisX.length; g++)
b[c[e]].push({
viewportMinimum:
this[c[e]][g].sessionVariables.newViewportMinimum,
viewportMaximum:
this[c[e]][g].sessionVariables.newViewportMaximum,
});
else if ("axisX2" === c[e])
for (g = 0; g < this.axisX2.length; g++)
b[c[e]].push({
viewportMinimum:
this[c[e]][g].sessionVariables.newViewportMinimum,
viewportMaximum:
this[c[e]][g].sessionVariables.newViewportMaximum,
});
this.dispatchEvent(a, b, this);
};
p.prototype._mouseEventHandler = function (a) {
"undefined" === typeof a.target &&
a.srcElement &&
(a.target = a.srcElement);
var d = Ra(a),
b = a.type,
c,
e;
a.which ? (e = 3 == a.which) : a.button && (e = 2 == a.button);
p.capturedEventParam &&
((c = p.capturedEventParam),
"mouseup" === b &&
((p.capturedEventParam = null),
c.chart.overlaidCanvas.releaseCapture
? c.chart.overlaidCanvas.releaseCapture()
: document.documentElement.removeEventListener(
"mouseup",
c.chart._mouseEventHandler,
!1
)),
c.hasOwnProperty(b) &&
("mouseup" !== b || c.chart.overlaidCanvas.releaseCapture
? (a.target !== c.chart.overlaidCanvas && r) ||
c[b].call(c.context, d.x, d.y)
: a.target !== c.chart.overlaidCanvas && (c.chart.isDrag = !1)));
if (this.interactivityEnabled)
if (this._ignoreNextEvent) this._ignoreNextEvent = !1;
else if (
(a.preventManipulation && a.preventManipulation(),
a.preventDefault && a.preventDefault(),
Ja &&
window.console &&
(window.console.log(b + " --\x3e x: " + d.x + "; y:" + d.y),
e && window.console.log(a.which),
"mouseup" === b && window.console.log("mouseup")),
!e)
) {
if (!p.capturedEventParam && this._events) {
for (var g = 0; g < this._events.length; g++)
if (this._events[g].hasOwnProperty(b))
if (
((c = this._events[g]),
(e = c.bounds),
d.x >= e.x1 && d.x <= e.x2 && d.y >= e.y1 && d.y <= e.y2)
) {
c[b].call(c.context, d.x, d.y);
"mousedown" === b && !0 === c.capture
? ((p.capturedEventParam = c),
this.overlaidCanvas.setCapture
? this.overlaidCanvas.setCapture()
: document.documentElement.addEventListener(
"mouseup",
this._mouseEventHandler,
!1
))
: "mouseup" === b &&
(c.chart.overlaidCanvas.releaseCapture
? c.chart.overlaidCanvas.releaseCapture()
: document.documentElement.removeEventListener(
"mouseup",
this._mouseEventHandler,
!1
));
break;
} else c = null;
a.target.style.cursor =
c && c.cursor ? c.cursor : this._defaultCursor;
}
b = this.plotArea;
if (d.x < b.x1 || d.x > b.x2 || d.y < b.y1 || d.y > b.y2)
this.toolTip && this.toolTip.enabled
? this.toolTip.hide()
: this.resetOverlayedCanvas();
(this.isDrag && this.zoomEnabled) ||
!this._eventManager ||
this._eventManager.mouseEventHandler(a);
}
};
p.prototype._plotAreaMouseDown = function (a, d) {
this.isDrag = !0;
this.dragStartPoint = { x: a, y: d };
};
p.prototype._plotAreaMouseUp = function (a, d) {
if (
("normal" === this.plotInfo.axisPlacement ||
"xySwapped" === this.plotInfo.axisPlacement) &&
this.isDrag
) {
var b = d - this.dragStartPoint.y,
c = a - this.dragStartPoint.x,
e = 0 <= this.zoomType.indexOf("x"),
g = 0 <= this.zoomType.indexOf("y"),
m = !1;
this.resetOverlayedCanvas();
if ("xySwapped" === this.plotInfo.axisPlacement)
var l = g,
g = e,
e = l;
if (this.panEnabled || this.zoomEnabled) {
if (this.panEnabled)
for (e = g = 0; e < this._axes.length; e++)
(b = this._axes[e]),
b.logarithmic
? b.viewportMinimum < b.minimum
? ((g = b.minimum / b.viewportMinimum),
(b.sessionVariables.newViewportMinimum =
b.viewportMinimum * g),
(b.sessionVariables.newViewportMaximum =
b.viewportMaximum * g),
(m = !0))
: b.viewportMaximum > b.maximum &&
((g = b.viewportMaximum / b.maximum),
(b.sessionVariables.newViewportMinimum =
b.viewportMinimum / g),
(b.sessionVariables.newViewportMaximum =
b.viewportMaximum / g),
(m = !0))
: b.viewportMinimum < b.minimum
? ((g = b.minimum - b.viewportMinimum),
(b.sessionVariables.newViewportMinimum =
b.viewportMinimum + g),
(b.sessionVariables.newViewportMaximum =
b.viewportMaximum + g),
(m = !0))
: b.viewportMaximum > b.maximum &&
((g = b.viewportMaximum - b.maximum),
(b.sessionVariables.newViewportMinimum =
b.viewportMinimum - g),
(b.sessionVariables.newViewportMaximum =
b.viewportMaximum - g),
(m = !0));
else if (
(!e || 2 < Math.abs(c)) &&
(!g || 2 < Math.abs(b)) &&
this.zoomEnabled
) {
if (!this.dragStartPoint) return;
b = e ? this.dragStartPoint.x : this.plotArea.x1;
c = g ? this.dragStartPoint.y : this.plotArea.y1;
e = e ? a : this.plotArea.x2;
g = g ? d : this.plotArea.y2;
2 < Math.abs(b - e) &&
2 < Math.abs(c - g) &&
this._zoomPanToSelectedRegion(b, c, e, g) &&
(m = !0);
}
m &&
((this._ignoreNextEvent = !0),
this._dispatchRangeEvent("rangeChanging", "zoom"),
this.render(),
this._dispatchRangeEvent("rangeChanged", "zoom"),
m &&
this.zoomEnabled &&
"none" === this._zoomButton.style.display &&
(Qa(this._zoomButton, this._resetButton),
ua(this, this._zoomButton, "pan"),
ua(this, this._resetButton, "reset")));
}
}
this.isDrag = !1;
if ("none" !== this.plotInfo.axisPlacement) {
this.resetOverlayedCanvas();
if (this.axisX && 0 < this.axisX.length)
for (m = 0; m < this.axisX.length; m++)
this.axisX[m].crosshair &&
this.axisX[m].crosshair.enabled &&
this.axisX[m].renderCrosshair(a, d);
if (this.axisX2 && 0 < this.axisX2.length)
for (m = 0; m < this.axisX2.length; m++)
this.axisX2[m].crosshair &&
this.axisX2[m].crosshair.enabled &&
this.axisX2[m].renderCrosshair(a, d);
if (this.axisY && 0 < this.axisY.length)
for (m = 0; m < this.axisY.length; m++)
this.axisY[m].crosshair &&
this.axisY[m].crosshair.enabled &&
this.axisY[m].renderCrosshair(a, d);
if (this.axisY2 && 0 < this.axisY2.length)
for (m = 0; m < this.axisY2.length; m++)
this.axisY2[m].crosshair &&
this.axisY2[m].crosshair.enabled &&
this.axisY2[m].renderCrosshair(a, d);
}
};
p.prototype._plotAreaMouseMove = function (a, d) {
if (this.isDrag && "none" !== this.plotInfo.axisPlacement) {
var b = 0,
c = 0,
e = (b = null),
e = 0 <= this.zoomType.indexOf("x"),
g = 0 <= this.zoomType.indexOf("y"),
m = this;
"xySwapped" === this.plotInfo.axisPlacement &&
((b = g), (g = e), (e = b));
b = this.dragStartPoint.x - a;
c = this.dragStartPoint.y - d;
2 < Math.abs(b) &&
8 > Math.abs(b) &&
(this.panEnabled || this.zoomEnabled)
? this.toolTip.hide()
: this.panEnabled ||
this.zoomEnabled ||
this.toolTip.mouseMoveHandler(a, d);
if (
(!e || 2 < Math.abs(b) || !g || 2 < Math.abs(c)) &&
(this.panEnabled || this.zoomEnabled)
)
if (this.panEnabled)
(e = {
x1: e ? this.plotArea.x1 + b : this.plotArea.x1,
y1: g ? this.plotArea.y1 + c : this.plotArea.y1,
x2: e ? this.plotArea.x2 + b : this.plotArea.x2,
y2: g ? this.plotArea.y2 + c : this.plotArea.y2,
}),
clearTimeout(m._panTimerId),
(m._panTimerId = setTimeout(
(function (c, b, e, f) {
return function () {
m._zoomPanToSelectedRegion(c, b, e, f, !0) &&
(m._dispatchRangeEvent("rangeChanging", "pan"),
m.render(),
m._dispatchRangeEvent("rangeChanged", "pan"),
(m.dragStartPoint.x = a),
(m.dragStartPoint.y = d));
};
})(e.x1, e.y1, e.x2, e.y2),
0
));
else if (this.zoomEnabled) {
this.resetOverlayedCanvas();
b = this.overlaidCanvasCtx.globalAlpha;
this.overlaidCanvasCtx.fillStyle = "#A89896";
var c = e ? this.dragStartPoint.x : this.plotArea.x1,
l = g ? this.dragStartPoint.y : this.plotArea.y1,
w = e
? a - this.dragStartPoint.x
: this.plotArea.x2 - this.plotArea.x1,
h = g
? d - this.dragStartPoint.y
: this.plotArea.y2 - this.plotArea.y1;
this.validateRegion(
c,
l,
e ? a : this.plotArea.x2 - this.plotArea.x1,
g ? d : this.plotArea.y2 - this.plotArea.y1,
"xy" !== this.zoomType
).isValid &&
(this.resetOverlayedCanvas(),
(this.overlaidCanvasCtx.fillStyle = "#99B2B5"));
this.overlaidCanvasCtx.globalAlpha = 0.7;
this.overlaidCanvasCtx.fillRect(c, l, w, h);
this.overlaidCanvasCtx.globalAlpha = b;
}
} else if (
(this.toolTip.mouseMoveHandler(a, d),
"none" !== this.plotInfo.axisPlacement)
) {
if (this.axisX && 0 < this.axisX.length)
for (e = 0; e < this.axisX.length; e++)
this.axisX[e].crosshair &&
this.axisX[e].crosshair.enabled &&
this.axisX[e].renderCrosshair(a, d);
if (this.axisX2 && 0 < this.axisX2.length)
for (e = 0; e < this.axisX2.length; e++)
this.axisX2[e].crosshair &&
this.axisX2[e].crosshair.enabled &&
this.axisX2[e].renderCrosshair(a, d);
if (this.axisY && 0 < this.axisY.length)
for (e = 0; e < this.axisY.length; e++)
this.axisY[e].crosshair &&
this.axisY[e].crosshair.enabled &&
this.axisY[e].renderCrosshair(a, d);
if (this.axisY2 && 0 < this.axisY2.length)
for (e = 0; e < this.axisY2.length; e++)
this.axisY2[e].crosshair &&
this.axisY2[e].crosshair.enabled &&
this.axisY2[e].renderCrosshair(a, d);
}
};
p.prototype._zoomPanToSelectedRegion = function (a, d, b, c, e) {
a = this.validateRegion(a, d, b, c, e);
d = a.axesWithValidRange;
b = a.axesRanges;
if (a.isValid)
for (c = 0; c < d.length; c++)
(e = b[c]),
d[c].setViewPortRange(e.val1, e.val2),
this.syncCharts && this.syncCharts(e.val1, e.val2);
return a.isValid;
};
p.prototype.validateRegion = function (a, d, b, c, e) {
e = e || !1;
for (
var g = 0 <= this.zoomType.indexOf("x"),
m = 0 <= this.zoomType.indexOf("y"),
l = !1,
w = [],
h = [],
s = [],
q = 0;
q < this._axes.length;
q++
)
(("axisX" === this._axes[q].type && g) ||
("axisY" === this._axes[q].type && m)) &&
h.push(this._axes[q]);
for (m = 0; m < h.length; m++) {
var q = h[m],
g = !1,
n = q.convertPixelToValue({ x: a, y: d }),
f = q.convertPixelToValue({ x: b, y: c });
if (n > f)
var B = f,
f = n,
n = B;
if (q.scaleBreaks)
for (B = 0; !g && B < q.scaleBreaks._appliedBreaks.length; B++)
g =
q.scaleBreaks._appliedBreaks[B].startValue <= n &&
q.scaleBreaks._appliedBreaks[B].endValue >= f;
if (isFinite(q.dataInfo.minDiff))
if (
((B = q.getApparentDifference(n, f, null, !0)),
!(
g ||
(!(
this.panEnabled &&
q.scaleBreaks &&
q.scaleBreaks._appliedBreaks.length
) &&
((q.logarithmic && B < Math.pow(q.dataInfo.minDiff, 3)) ||
(!q.logarithmic && B < 3 * Math.abs(q.dataInfo.minDiff)))) ||
n < q.minimum ||
f > q.maximum
))
)
w.push(q), s.push({ val1: n, val2: f }), (l = !0);
else if (!e) {
l = !1;
break;
}
}
return { isValid: l, axesWithValidRange: w, axesRanges: s };
};
p.prototype.preparePlotArea = function () {
var a = this.plotArea;
!r && (0 < a.x1 || 0 < a.y1) && a.ctx.translate(a.x1, a.y1);
if (
(this.axisX[0] || this.axisX2[0]) &&
(this.axisY[0] || this.axisY2[0])
) {
var d = this.axisX[0]
? this.axisX[0].lineCoordinates
: this.axisX2[0].lineCoordinates;
if (this.axisY && 0 < this.axisY.length && this.axisY[0]) {
var b = this.axisY[0];
a.x1 = d.x1 < d.x2 ? d.x1 : b.lineCoordinates.x1;
a.y1 = d.y1 < b.lineCoordinates.y1 ? d.y1 : b.lineCoordinates.y1;
a.x2 = d.x2 > b.lineCoordinates.x2 ? d.x2 : b.lineCoordinates.x2;
a.y2 = d.y2 > d.y1 ? d.y2 : b.lineCoordinates.y2;
a.width = a.x2 - a.x1;
a.height = a.y2 - a.y1;
}
this.axisY2 &&
0 < this.axisY2.length &&
this.axisY2[0] &&
((b = this.axisY2[0]),
(a.x1 = d.x1 < d.x2 ? d.x1 : b.lineCoordinates.x1),
(a.y1 = d.y1 < b.lineCoordinates.y1 ? d.y1 : b.lineCoordinates.y1),
(a.x2 = d.x2 > b.lineCoordinates.x2 ? d.x2 : b.lineCoordinates.x2),
(a.y2 = d.y2 > d.y1 ? d.y2 : b.lineCoordinates.y2),
(a.width = a.x2 - a.x1),
(a.height = a.y2 - a.y1));
} else
(d = this.layoutManager.getFreeSpace()),
(a.x1 = d.x1),
(a.x2 = d.x2),
(a.y1 = d.y1),
(a.y2 = d.y2),
(a.width = d.width),
(a.height = d.height);
r ||
((a.canvas.width = a.width),
(a.canvas.height = a.height),
(a.canvas.style.left = a.x1 + "px"),
(a.canvas.style.top = a.y1 + "px"),
(0 < a.x1 || 0 < a.y1) && a.ctx.translate(-a.x1, -a.y1));
a.layoutManager = new Ga(a.x1, a.y1, a.x2, a.y2, 2);
};
p.prototype.renderIndexLabels = function (a) {
var d = a || this.plotArea.ctx,
b = this.plotArea,
c = 0,
e = 0,
g = 0,
m = 0,
l = (c = m = e = g = 0),
w = 0;
for (a = 0; a < this._indexLabels.length; a++) {
var h = this._indexLabels[a],
s = h.chartType.toLowerCase(),
q,
n,
l = na("indexLabelFontColor", h.dataPoint, h.dataSeries),
w = na("indexLabelFontSize", h.dataPoint, h.dataSeries);
q = na("indexLabelFontFamily", h.dataPoint, h.dataSeries);
n = na("indexLabelFontStyle", h.dataPoint, h.dataSeries);
var m = na("indexLabelFontWeight", h.dataPoint, h.dataSeries),
f = na("indexLabelBackgroundColor", h.dataPoint, h.dataSeries),
e = na("indexLabelMaxWidth", h.dataPoint, h.dataSeries),
g = na("indexLabelWrap", h.dataPoint, h.dataSeries),
B = na("indexLabelLineDashType", h.dataPoint, h.dataSeries),
k = na("indexLabelLineColor", h.dataPoint, h.dataSeries),
p = u(h.dataPoint.indexLabelLineThickness)
? u(h.dataSeries.options.indexLabelLineThickness)
? 0
: h.dataSeries.options.indexLabelLineThickness
: h.dataPoint.indexLabelLineThickness,
c =
0 < p
? Math.min(
10,
("normal" === this.plotInfo.axisPlacement
? this.plotArea.height
: this.plotArea.width) << 0
)
: 0,
t = { percent: null, total: null },
C = null;
if (
0 <= h.dataSeries.type.indexOf("stacked") ||
"pie" === h.dataSeries.type ||
"doughnut" === h.dataSeries.type
)
t = this.getPercentAndTotal(h.dataSeries, h.dataPoint);
if (h.dataSeries.indexLabelFormatter || h.dataPoint.indexLabelFormatter)
C = {
chart: this,
dataSeries: h.dataSeries,
dataPoint: h.dataPoint,
index: h.indexKeyword,
total: t.total,
percent: t.percent,
};
var x = h.dataPoint.indexLabelFormatter
? h.dataPoint.indexLabelFormatter(C)
: h.dataPoint.indexLabel
? this.replaceKeywordsWithValue(
h.dataPoint.indexLabel,
h.dataPoint,
h.dataSeries,
null,
h.indexKeyword
)
: h.dataSeries.indexLabelFormatter
? h.dataSeries.indexLabelFormatter(C)
: h.dataSeries.indexLabel
? this.replaceKeywordsWithValue(
h.dataSeries.indexLabel,
h.dataPoint,
h.dataSeries,
null,
h.indexKeyword
)
: null;
if (null !== x && "" !== x) {
var t = na("indexLabelPlacement", h.dataPoint, h.dataSeries),
C = na("indexLabelOrientation", h.dataPoint, h.dataSeries),
ma = h.direction,
y = h.dataSeries.axisX,
A = h.dataSeries.axisY,
v = !1,
f = new ka(d, {
x: 0,
y: 0,
maxWidth: e ? e : 0.5 * this.width,
maxHeight: g ? 5 * w : 1.5 * w,
angle: "horizontal" === C ? 0 : -90,
text: x,
padding: 0,
backgroundColor: f,
horizontalAlign: "left",
fontSize: w,
fontFamily: q,
fontWeight: m,
fontColor: l,
fontStyle: n,
textBaseline: "top",
});
f.measureText();
h.dataSeries.indexLabelMaxWidth = f.maxWidth;
if ("stackedarea100" === s) {
if (
h.point.x < b.x1 ||
h.point.x > b.x2 ||
h.point.y < b.y1 - 1 ||
h.point.y > b.y2 + 1
)
continue;
} else if ("rangearea" === s || "rangesplinearea" === s) {
if (
h.dataPoint.x < y.viewportMinimum ||
h.dataPoint.x > y.viewportMaximum ||
Math.max.apply(null, h.dataPoint.y) < A.viewportMinimum ||
Math.min.apply(null, h.dataPoint.y) > A.viewportMaximum
)
continue;
} else if (
0 <= s.indexOf("line") ||
0 <= s.indexOf("area") ||
0 <= s.indexOf("bubble") ||
0 <= s.indexOf("scatter")
) {
if (
h.dataPoint.x < y.viewportMinimum ||
h.dataPoint.x > y.viewportMaximum ||
h.dataPoint.y < A.viewportMinimum ||
h.dataPoint.y > A.viewportMaximum
)
continue;
} else if (
0 <= s.indexOf("column") ||
"waterfall" === s ||
("error" === s && !h.axisSwapped)
) {
if (
h.dataPoint.x < y.viewportMinimum ||
h.dataPoint.x > y.viewportMaximum ||
h.bounds.y1 > b.y2 ||
h.bounds.y2 < b.y1
)
continue;
} else if (0 <= s.indexOf("bar") || "error" === s) {
if (
h.dataPoint.x < y.viewportMinimum ||
h.dataPoint.x > y.viewportMaximum ||
h.bounds.x1 > b.x2 ||
h.bounds.x2 < b.x1
)
continue;
} else if ("candlestick" === s || "ohlc" === s) {
if (
h.dataPoint.x < y.viewportMinimum ||
h.dataPoint.x > y.viewportMaximum ||
Math.max.apply(null, h.dataPoint.y) < A.viewportMinimum ||
Math.min.apply(null, h.dataPoint.y) > A.viewportMaximum
)
continue;
} else if (
h.dataPoint.x < y.viewportMinimum ||
h.dataPoint.x > y.viewportMaximum
)
continue;
e = m = 2;
"horizontal" === C
? ((l = f.width), (w = f.height))
: ((w = f.width), (l = f.height));
if ("normal" === this.plotInfo.axisPlacement) {
if (0 <= s.indexOf("line") || 0 <= s.indexOf("area"))
(t = "auto"), (m = 4);
else if (0 <= s.indexOf("stacked")) "auto" === t && (t = "inside");
else if ("bubble" === s || "scatter" === s) t = "inside";
q = h.point.x - l / 2;
"inside" !== t
? ((e = b.y1),
(g = b.y2),
0 < ma
? ((n = h.point.y - w - m - c),
n < e &&
((n =
"auto" === t
? Math.max(h.point.y, e) + m + c
: e + m + c),
(v = n + w > h.point.y)))
: ((n = h.point.y + m + c),
n > g - w - m - c &&
((n =
"auto" === t
? Math.min(h.point.y, g) - w - m - c
: g - w - m - c),
(v = n < h.point.y))))
: ((e = Math.max(h.bounds.y1, b.y1)),
(g = Math.min(h.bounds.y2, b.y2)),
(c =
0 <= s.indexOf("range") || "error" === s
? 0 < ma
? Math.max(h.bounds.y1, b.y1) + w / 2 + m
: Math.min(h.bounds.y2, b.y2) - w / 2 - m
: (Math.max(h.bounds.y1, b.y1) +
Math.min(h.bounds.y2, b.y2)) /
2),
0 < ma
? ((n = Math.max(h.point.y, c) - w / 2),
n < e &&
("bubble" === s || "scatter" === s) &&
(n = Math.max(h.point.y - w - m, b.y1 + m)))
: ((n = Math.min(h.point.y, c) - w / 2),
n > g - w - m &&
("bubble" === s || "scatter" === s) &&
(n = Math.min(h.point.y + m, b.y2 - w - m))),
(n = Math.min(n, g - w)));
} else
0 <= s.indexOf("line") ||
0 <= s.indexOf("area") ||
0 <= s.indexOf("scatter")
? ((t = "auto"), (e = 4))
: 0 <= s.indexOf("stacked")
? "auto" === t && (t = "inside")
: "bubble" === s && (t = "inside"),
(n = h.point.y - w / 2),
"inside" !== t
? ((m = b.x1),
(g = b.x2),
0 > ma
? ((q = h.point.x - l - e - c),
q < m &&
((q =
"auto" === t
? Math.max(h.point.x, m) + e + c
: m + e + c),
(v = q + l > h.point.x)))
: ((q = h.point.x + e + c),
q > g - l - e - c &&
((q =
"auto" === t
? Math.min(h.point.x, g) - l - e - c
: g - l - e - c),
(v = q < h.point.x))))
: ((m = Math.max(h.bounds.x1, b.x1)),
Math.min(h.bounds.x2, b.x2),
(c =
0 <= s.indexOf("range") || "error" === s
? 0 > ma
? Math.max(h.bounds.x1, b.x1) + l / 2 + e
: Math.min(h.bounds.x2, b.x2) - l / 2 - e
: (Math.max(h.bounds.x1, b.x1) +
Math.min(h.bounds.x2, b.x2)) /
2),
(q =
0 > ma
? Math.max(h.point.x, c) - l / 2
: Math.min(h.point.x, c) - l / 2),
(q = Math.max(q, m)));
"vertical" === C && (n += w);
f.x = q;
f.y = n;
f.render(!0);
p &&
"inside" !== t &&
((0 > s.indexOf("bar") &&
("error" !== s || !h.axisSwapped) &&
h.point.x > b.x1 &&
h.point.x < b.x2) ||
!v) &&
((0 > s.indexOf("column") &&
("error" !== s || h.axisSwapped) &&
h.point.y > b.y1 &&
h.point.y < b.y2) ||
!v) &&
((d.lineWidth = p),
(d.strokeStyle = k ? k : "gray"),
d.setLineDash && d.setLineDash(R(B, p)),
d.beginPath(),
d.moveTo(h.point.x, h.point.y),
0 <= s.indexOf("bar") || ("error" === s && h.axisSwapped)
? d.lineTo(
q + (0 < h.direction ? 0 : l),
n + ("horizontal" === C ? w : -w) / 2
)
: 0 <= s.indexOf("column") || ("error" === s && !h.axisSwapped)
? d.lineTo(
q + l / 2,
n +
((0 < h.direction ? w : -w) +
("horizontal" === C ? w : -w)) /
2
)
: d.lineTo(
q + l / 2,
n +
((n < h.point.y ? w : -w) + ("horizontal" === C ? w : -w)) /
2
),
d.stroke());
}
}
d = {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
startTimePercent: 0.7,
};
for (a = 0; a < this._indexLabels.length; a++)
(h = this._indexLabels[a]),
(f = na("indexLabelBackgroundColor", h.dataPoint, h.dataSeries)),
(h.dataSeries.indexLabelBackgroundColor = u(f)
? r
? "transparent"
: null
: f);
return d;
};
p.prototype.renderLine = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = this._eventManager.ghostCtx;
b.save();
var e = this.plotArea;
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
for (var g = [], m, l = 0; l < a.dataSeriesIndexes.length; l++) {
var w = a.dataSeriesIndexes[l],
h = this.data[w];
b.lineWidth = h.lineThickness;
var s = h.dataPoints,
q = "solid";
if (b.setLineDash) {
var n = R(h.nullDataLineDashType, h.lineThickness),
q = h.lineDashType,
f = R(q, h.lineThickness);
b.setLineDash(f);
}
var B = h.id;
this._eventManager.objectMap[B] = {
objectType: "dataSeries",
dataSeriesIndex: w,
};
B = N(B);
c.strokeStyle = B;
c.lineWidth = 0 < h.lineThickness ? Math.max(h.lineThickness, 4) : 0;
var B = h._colorSet,
k =
(B =
h.lineColor =
h.options.lineColor ? h.options.lineColor : B[0]);
b.strokeStyle = B;
var p = !0,
t = 0,
C,
x;
b.beginPath();
if (0 < s.length) {
for (var u = !1, t = 0; t < s.length; t++)
if (
((C = s[t].x.getTime ? s[t].x.getTime() : s[t].x),
!(
C < a.axisX.dataInfo.viewPortMin ||
(C > a.axisX.dataInfo.viewPortMax &&
(!h.connectNullData || !u))
))
)
if ("number" !== typeof s[t].y)
0 < t &&
!(h.connectNullData || u || p) &&
(b.stroke(), r && c.stroke()),
(u = !0);
else {
C = a.axisX.convertValueToPixel(C);
x = a.axisY.convertValueToPixel(s[t].y);
var y = h.dataPointIds[t];
this._eventManager.objectMap[y] = {
id: y,
objectType: "dataPoint",
dataSeriesIndex: w,
dataPointIndex: t,
x1: C,
y1: x,
};
p || u
? (!p && h.connectNullData
? (b.setLineDash &&
(h.options.nullDataLineDashType ||
(q === h.lineDashType &&
h.lineDashType !== h.nullDataLineDashType)) &&
(b.stroke(),
b.beginPath(),
b.moveTo(m.x, m.y),
(q = h.nullDataLineDashType),
b.setLineDash(n)),
b.lineTo(C, x),
r && c.lineTo(C, x))
: (b.beginPath(),
b.moveTo(C, x),
r && (c.beginPath(), c.moveTo(C, x))),
(u = p = !1))
: (b.lineTo(C, x),
r && c.lineTo(C, x),
0 == t % 500 &&
(b.stroke(),
b.beginPath(),
b.moveTo(C, x),
r && (c.stroke(), c.beginPath(), c.moveTo(C, x))));
m = { x: C, y: x };
t < s.length - 1 &&
(k !== (s[t].lineColor || B) ||
q !== (s[t].lineDashType || h.lineDashType)) &&
(b.stroke(),
b.beginPath(),
b.moveTo(C, x),
(k = s[t].lineColor || B),
(b.strokeStyle = k),
b.setLineDash &&
(s[t].lineDashType
? ((q = s[t].lineDashType),
b.setLineDash(R(q, h.lineThickness)))
: ((q = h.lineDashType), b.setLineDash(f))));
if (0 < s[t].markerSize || 0 < h.markerSize) {
var A = h.getMarkerProperties(t, C, x, b);
g.push(A);
y = N(y);
r &&
g.push({
x: C,
y: x,
ctx: c,
type: A.type,
size: A.size,
color: y,
borderColor: y,
borderThickness: A.borderThickness,
});
}
(s[t].indexLabel ||
h.indexLabel ||
s[t].indexLabelFormatter ||
h.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "line",
dataPoint: s[t],
dataSeries: h,
point: { x: C, y: x },
direction: 0 > s[t].y === a.axisY.reversed ? 1 : -1,
color: B,
});
}
b.stroke();
r && c.stroke();
}
}
ia.drawMarkers(g);
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
c.beginPath());
b.restore();
b.beginPath();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderStepLine = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = this._eventManager.ghostCtx;
b.save();
var e = this.plotArea;
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
for (var g = [], m, l = 0; l < a.dataSeriesIndexes.length; l++) {
var w = a.dataSeriesIndexes[l],
h = this.data[w];
b.lineWidth = h.lineThickness;
var s = h.dataPoints,
q = "solid";
if (b.setLineDash) {
var n = R(h.nullDataLineDashType, h.lineThickness),
q = h.lineDashType,
f = R(q, h.lineThickness);
b.setLineDash(f);
}
var B = h.id;
this._eventManager.objectMap[B] = {
objectType: "dataSeries",
dataSeriesIndex: w,
};
B = N(B);
c.strokeStyle = B;
c.lineWidth = 0 < h.lineThickness ? Math.max(h.lineThickness, 4) : 0;
var B = h._colorSet,
k =
(B =
h.lineColor =
h.options.lineColor ? h.options.lineColor : B[0]);
b.strokeStyle = B;
var p = !0,
t = 0,
C,
x;
b.beginPath();
if (0 < s.length) {
for (var u = !1, t = 0; t < s.length; t++)
if (
((C = s[t].getTime ? s[t].x.getTime() : s[t].x),
!(
C < a.axisX.dataInfo.viewPortMin ||
(C > a.axisX.dataInfo.viewPortMax &&
(!h.connectNullData || !u))
))
)
if ("number" !== typeof s[t].y)
0 < t &&
!(h.connectNullData || u || p) &&
(b.stroke(), r && c.stroke()),
(u = !0);
else {
var y = x;
C = a.axisX.convertValueToPixel(C);
x = a.axisY.convertValueToPixel(s[t].y);
var A = h.dataPointIds[t];
this._eventManager.objectMap[A] = {
id: A,
objectType: "dataPoint",
dataSeriesIndex: w,
dataPointIndex: t,
x1: C,
y1: x,
};
p || u
? (!p && h.connectNullData
? (b.setLineDash &&
(h.options.nullDataLineDashType ||
(q === h.lineDashType &&
h.lineDashType !== h.nullDataLineDashType)) &&
(b.stroke(),
b.beginPath(),
b.moveTo(m.x, m.y),
(q = h.nullDataLineDashType),
b.setLineDash(n)),
b.lineTo(C, y),
b.lineTo(C, x),
r && (c.lineTo(C, y), c.lineTo(C, x)))
: (b.beginPath(),
b.moveTo(C, x),
r && (c.beginPath(), c.moveTo(C, x))),
(u = p = !1))
: (b.lineTo(C, y),
r && c.lineTo(C, y),
b.lineTo(C, x),
r && c.lineTo(C, x),
0 == t % 500 &&
(b.stroke(),
b.beginPath(),
b.moveTo(C, x),
r && (c.stroke(), c.beginPath(), c.moveTo(C, x))));
m = { x: C, y: x };
t < s.length - 1 &&
(k !== (s[t].lineColor || B) ||
q !== (s[t].lineDashType || h.lineDashType)) &&
(b.stroke(),
b.beginPath(),
b.moveTo(C, x),
(k = s[t].lineColor || B),
(b.strokeStyle = k),
b.setLineDash &&
(s[t].lineDashType
? ((q = s[t].lineDashType),
b.setLineDash(R(q, h.lineThickness)))
: ((q = h.lineDashType), b.setLineDash(f))));
if (0 < s[t].markerSize || 0 < h.markerSize)
(y = h.getMarkerProperties(t, C, x, b)),
g.push(y),
(A = N(A)),
r &&
g.push({
x: C,
y: x,
ctx: c,
type: y.type,
size: y.size,
color: A,
borderColor: A,
borderThickness: y.borderThickness,
});
(s[t].indexLabel ||
h.indexLabel ||
s[t].indexLabelFormatter ||
h.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "stepLine",
dataPoint: s[t],
dataSeries: h,
point: { x: C, y: x },
direction: 0 > s[t].y === a.axisY.reversed ? 1 : -1,
color: B,
});
}
b.stroke();
r && c.stroke();
}
}
ia.drawMarkers(g);
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
c.beginPath());
b.restore();
b.beginPath();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderSpline = function (a) {
function d(a) {
a = v(a, 2);
if (0 < a.length) {
c.beginPath();
r && e.beginPath();
c.moveTo(a[0].x, a[0].y);
a[0].newStrokeStyle && (c.strokeStyle = a[0].newStrokeStyle);
a[0].newLineDashArray && c.setLineDash(a[0].newLineDashArray);
r && e.moveTo(a[0].x, a[0].y);
for (var b = 0; b < a.length - 3; b += 3)
if (
(c.bezierCurveTo(
a[b + 1].x,
a[b + 1].y,
a[b + 2].x,
a[b + 2].y,
a[b + 3].x,
a[b + 3].y
),
r &&
e.bezierCurveTo(
a[b + 1].x,
a[b + 1].y,
a[b + 2].x,
a[b + 2].y,
a[b + 3].x,
a[b + 3].y
),
(0 < b && 0 === b % 3e3) ||
a[b + 3].newStrokeStyle ||
a[b + 3].newLineDashArray)
)
c.stroke(),
c.beginPath(),
c.moveTo(a[b + 3].x, a[b + 3].y),
a[b + 3].newStrokeStyle &&
(c.strokeStyle = a[b + 3].newStrokeStyle),
a[b + 3].newLineDashArray &&
c.setLineDash(a[b + 3].newLineDashArray),
r &&
(e.stroke(), e.beginPath(), e.moveTo(a[b + 3].x, a[b + 3].y));
c.stroke();
r && e.stroke();
}
}
var b = a.targetCanvasCtx || this.plotArea.ctx,
c = r ? this._preRenderCtx : b;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = this._eventManager.ghostCtx;
c.save();
var g = this.plotArea;
c.beginPath();
c.rect(g.x1, g.y1, g.width, g.height);
c.clip();
for (var m = [], l = 0; l < a.dataSeriesIndexes.length; l++) {
var w = a.dataSeriesIndexes[l],
h = this.data[w];
c.lineWidth = h.lineThickness;
var s = h.dataPoints,
q = "solid";
if (c.setLineDash) {
var n = R(h.nullDataLineDashType, h.lineThickness),
q = h.lineDashType,
f = R(q, h.lineThickness);
c.setLineDash(f);
}
var B = h.id;
this._eventManager.objectMap[B] = {
objectType: "dataSeries",
dataSeriesIndex: w,
};
B = N(B);
e.strokeStyle = B;
e.lineWidth = 0 < h.lineThickness ? Math.max(h.lineThickness, 4) : 0;
var B = h._colorSet,
k =
(B =
h.lineColor =
h.options.lineColor ? h.options.lineColor : B[0]);
c.strokeStyle = B;
var p = 0,
t,
u,
x = [];
c.beginPath();
if (0 < s.length)
for (u = !1, p = 0; p < s.length; p++)
if (
((t = s[p].getTime ? s[p].x.getTime() : s[p].x),
!(
t < a.axisX.dataInfo.viewPortMin ||
(t > a.axisX.dataInfo.viewPortMax &&
(!h.connectNullData || !u))
))
)
if ("number" !== typeof s[p].y)
0 < p &&
!u &&
(h.connectNullData
? c.setLineDash &&
0 < x.length &&
(h.options.nullDataLineDashType ||
!s[p - 1].lineDashType) &&
((x[x.length - 1].newLineDashArray = n),
(q = h.nullDataLineDashType))
: (d(x), (x = []))),
(u = !0);
else {
t = a.axisX.convertValueToPixel(t);
u = a.axisY.convertValueToPixel(s[p].y);
var ma = h.dataPointIds[p];
this._eventManager.objectMap[ma] = {
id: ma,
objectType: "dataPoint",
dataSeriesIndex: w,
dataPointIndex: p,
x1: t,
y1: u,
};
x[x.length] = { x: t, y: u };
p < s.length - 1 &&
(k !== (s[p].lineColor || B) ||
q !== (s[p].lineDashType || h.lineDashType)) &&
((k = s[p].lineColor || B),
(x[x.length - 1].newStrokeStyle = k),
c.setLineDash &&
(s[p].lineDashType
? ((q = s[p].lineDashType),
(x[x.length - 1].newLineDashArray = R(
q,
h.lineThickness
)))
: ((q = h.lineDashType),
(x[x.length - 1].newLineDashArray = f))));
if (0 < s[p].markerSize || 0 < h.markerSize) {
var y = h.getMarkerProperties(p, t, u, c);
m.push(y);
ma = N(ma);
r &&
m.push({
x: t,
y: u,
ctx: e,
type: y.type,
size: y.size,
color: ma,
borderColor: ma,
borderThickness: y.borderThickness,
});
}
(s[p].indexLabel ||
h.indexLabel ||
s[p].indexLabelFormatter ||
h.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "spline",
dataPoint: s[p],
dataSeries: h,
point: { x: t, y: u },
direction: 0 > s[p].y === a.axisY.reversed ? 1 : -1,
color: B,
});
u = !1;
}
d(x);
}
ia.drawMarkers(m);
r &&
(b.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(c.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
c.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
c.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
c.clearRect(g.x1, g.y1, g.width, g.height),
e.beginPath());
c.restore();
c.beginPath();
return {
source: b,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderColumn = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = null,
e = this.plotArea,
g = 0,
m,
l,
w,
h = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
g = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1,
s = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: Math.min(
0.15 * this.width,
0.9 * (this.plotArea.width / a.plotType.totalDataSeries)
) << 0,
q = a.axisX.dataInfo.minDiff;
isFinite(q) || (q = 0.3 * Math.abs(a.axisX.range));
q = this.dataPointWidth = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
((e.width *
(a.axisX.logarithmic
? Math.log(q) / Math.log(a.axisX.range)
: Math.abs(q) / Math.abs(a.axisX.range))) /
a.plotType.totalDataSeries)) <<
0;
this.dataPointMaxWidth &&
g > s &&
(g = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
s
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
s < g &&
(s = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
g
));
q < g && (q = g);
q > s && (q = s);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.clip());
for (s = 0; s < a.dataSeriesIndexes.length; s++) {
var n = a.dataSeriesIndexes[s],
f = this.data[n],
B = f.dataPoints;
if (0 < B.length)
for (
var p = 5 < q && f.bevelEnabled ? !0 : !1, g = 0;
g < B.length;
g++
)
if (
(B[g].getTime ? (w = B[g].x.getTime()) : (w = B[g].x),
!(
w < a.axisX.dataInfo.viewPortMin ||
w > a.axisX.dataInfo.viewPortMax
) && "number" === typeof B[g].y)
) {
m = a.axisX.convertValueToPixel(w);
l = a.axisY.convertValueToPixel(B[g].y);
m = a.axisX.reversed
? (m +
(a.plotType.totalDataSeries * q) / 2 -
(a.previousDataSeriesCount + s) * q) <<
0
: (m -
(a.plotType.totalDataSeries * q) / 2 +
(a.previousDataSeriesCount + s) * q) <<
0;
var k = a.axisX.reversed ? (m - q) << 0 : (m + q) << 0,
t;
0 <= B[g].y ? (t = h) : ((t = l), (l = h));
l > t && ((c = l), (l = t), (t = c));
c = B[g].color
? B[g].color
: f._colorSet[g % f._colorSet.length];
ea(
b,
m,
l,
k,
t,
c,
0,
null,
p && 0 <= B[g].y,
0 > B[g].y && p,
!1,
!1,
f.fillOpacity
);
c = f.dataPointIds[g];
this._eventManager.objectMap[c] = {
id: c,
objectType: "dataPoint",
dataSeriesIndex: n,
dataPointIndex: g,
x1: m,
y1: l,
x2: k,
y2: t,
};
c = N(c);
r &&
ea(
this._eventManager.ghostCtx,
m,
l,
k,
t,
c,
0,
null,
!1,
!1,
!1,
!1
);
(B[g].indexLabel ||
f.indexLabel ||
B[g].indexLabelFormatter ||
f.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "column",
dataPoint: B[g],
dataSeries: f,
point: {
x: m + (k - m) / 2,
y: 0 > B[g].y === a.axisY.reversed ? l : t,
},
direction: 0 > B[g].y === a.axisY.reversed ? 1 : -1,
bounds: {
x1: m,
y1: Math.min(l, t),
x2: k,
y2: Math.max(l, t),
},
color: c,
});
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.yScaleAnimation,
easingFunction: M.easing.easeOutQuart,
animationBase:
h < a.axisY.bounds.y1
? a.axisY.bounds.y1
: h > a.axisY.bounds.y2
? a.axisY.bounds.y2
: h,
};
}
};
p.prototype.renderStackedColumn = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = null,
e = this.plotArea,
g = [],
m = [],
l = [],
w = [],
h = 0,
s,
q,
n = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
h = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1;
s = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: (0.15 * this.width) << 0;
var f = a.axisX.dataInfo.minDiff;
isFinite(f) || (f = 0.3 * Math.abs(a.axisX.range));
f = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
((e.width *
(a.axisX.logarithmic
? Math.log(f) / Math.log(a.axisX.range)
: Math.abs(f) / Math.abs(a.axisX.range))) /
a.plotType.plotUnits.length)) <<
0;
this.dataPointMaxWidth &&
h > s &&
(h = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
s
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
s < h &&
(s = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
h
));
f < h && (f = h);
f > s && (f = s);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.clip());
for (var B = 0; B < a.dataSeriesIndexes.length; B++) {
var k = a.dataSeriesIndexes[B],
p = this.data[k],
t = p.dataPoints;
if (0 < t.length) {
var u = 5 < f && p.bevelEnabled ? !0 : !1;
b.strokeStyle = "#4572A7 ";
for (h = 0; h < t.length; h++)
if (
((c = t[h].x.getTime ? t[h].x.getTime() : t[h].x),
!(
c < a.axisX.dataInfo.viewPortMin ||
c > a.axisX.dataInfo.viewPortMax
) && "number" === typeof t[h].y)
) {
s = a.axisX.convertValueToPixel(c);
var x =
(s - (a.plotType.plotUnits.length * f) / 2 + a.index * f) <<
0,
v = (x + f) << 0,
y;
if (
a.axisY.logarithmic ||
(a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length &&
0 < t[h].y)
)
(l[c] = t[h].y + (l[c] ? l[c] : 0)),
0 < l[c] &&
((q = a.axisY.convertValueToPixel(l[c])),
(y = "undefined" !== typeof g[c] ? g[c] : n),
(g[c] = q));
else if (
a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length &&
0 >= t[h].y
)
(w[c] = t[h].y + (w[c] ? w[c] : 0)),
(y = a.axisY.convertValueToPixel(w[c])),
(q = "undefined" !== typeof m[c] ? m[c] : n),
(m[c] = y);
else if (
((q = a.axisY.convertValueToPixel(t[h].y)), 0 <= t[h].y)
) {
var A = "undefined" !== typeof g[c] ? g[c] : 0;
q -= A;
y = n - A;
g[c] = A + (y - q);
} else
(A = m[c] ? m[c] : 0),
(y = q + A),
(q = n + A),
(m[c] = A + (y - q));
c = t[h].color
? t[h].color
: p._colorSet[h % p._colorSet.length];
ea(
b,
x,
q,
v,
y,
c,
0,
null,
u && 0 <= t[h].y,
0 > t[h].y && u,
!1,
!1,
p.fillOpacity
);
c = p.dataPointIds[h];
this._eventManager.objectMap[c] = {
id: c,
objectType: "dataPoint",
dataSeriesIndex: k,
dataPointIndex: h,
x1: x,
y1: q,
x2: v,
y2: y,
};
c = N(c);
r &&
ea(
this._eventManager.ghostCtx,
x,
q,
v,
y,
c,
0,
null,
!1,
!1,
!1,
!1
);
(t[h].indexLabel ||
p.indexLabel ||
t[h].indexLabelFormatter ||
p.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "stackedColumn",
dataPoint: t[h],
dataSeries: p,
point: { x: s, y: 0 <= t[h].y ? q : y },
direction: 0 > t[h].y === a.axisY.reversed ? 1 : -1,
bounds: {
x1: x,
y1: Math.min(q, y),
x2: v,
y2: Math.max(q, y),
},
color: c,
});
}
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.yScaleAnimation,
easingFunction: M.easing.easeOutQuart,
animationBase:
n < a.axisY.bounds.y1
? a.axisY.bounds.y1
: n > a.axisY.bounds.y2
? a.axisY.bounds.y2
: n,
};
}
};
p.prototype.renderStackedColumn100 = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = null,
e = this.plotArea,
g = [],
m = [],
l = [],
w = [],
h = 0,
s,
q,
n = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
h = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1;
s = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: (0.15 * this.width) << 0;
var f = a.axisX.dataInfo.minDiff;
isFinite(f) || (f = 0.3 * Math.abs(a.axisX.range));
f = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
((e.width *
(a.axisX.logarithmic
? Math.log(f) / Math.log(a.axisX.range)
: Math.abs(f) / Math.abs(a.axisX.range))) /
a.plotType.plotUnits.length)) <<
0;
this.dataPointMaxWidth &&
h > s &&
(h = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
s
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
s < h &&
(s = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
h
));
f < h && (f = h);
f > s && (f = s);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.clip());
for (var B = 0; B < a.dataSeriesIndexes.length; B++) {
var p = a.dataSeriesIndexes[B],
k = this.data[p],
t = k.dataPoints;
if (0 < t.length)
for (
var u = 5 < f && k.bevelEnabled ? !0 : !1, h = 0;
h < t.length;
h++
)
if (
((c = t[h].x.getTime ? t[h].x.getTime() : t[h].x),
!(
c < a.axisX.dataInfo.viewPortMin ||
c > a.axisX.dataInfo.viewPortMax
) && "number" === typeof t[h].y)
) {
s = a.axisX.convertValueToPixel(c);
q =
0 !== a.dataPointYSums[c]
? 100 * (t[h].y / a.dataPointYSums[c])
: 0;
var x =
(s - (a.plotType.plotUnits.length * f) / 2 + a.index * f) <<
0,
v = (x + f) << 0,
y;
if (
a.axisY.logarithmic ||
(a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length &&
0 < t[h].y)
) {
l[c] = q + ("undefined" !== typeof l[c] ? l[c] : 0);
if (0 >= l[c]) continue;
q = a.axisY.convertValueToPixel(l[c]);
y = g[c] ? g[c] : n;
g[c] = q;
} else if (
a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length &&
0 >= t[h].y
)
(w[c] = q + ("undefined" !== typeof w[c] ? w[c] : 0)),
(y = a.axisY.convertValueToPixel(w[c])),
(q = m[c] ? m[c] : n),
(m[c] = y);
else if (((q = a.axisY.convertValueToPixel(q)), 0 <= t[h].y)) {
var A = "undefined" !== typeof g[c] ? g[c] : 0;
q -= A;
y = n - A;
a.dataSeriesIndexes.length - 1 === B &&
1 >= Math.abs(e.y1 - q) &&
(q = e.y1);
g[c] = A + (y - q);
} else
(A = "undefined" !== typeof m[c] ? m[c] : 0),
(y = q + A),
(q = n + A),
a.dataSeriesIndexes.length - 1 === B &&
1 >= Math.abs(e.y2 - y) &&
(y = e.y2),
(m[c] = A + (y - q));
c = t[h].color
? t[h].color
: k._colorSet[h % k._colorSet.length];
ea(
b,
x,
q,
v,
y,
c,
0,
null,
u && 0 <= t[h].y,
0 > t[h].y && u,
!1,
!1,
k.fillOpacity
);
c = k.dataPointIds[h];
this._eventManager.objectMap[c] = {
id: c,
objectType: "dataPoint",
dataSeriesIndex: p,
dataPointIndex: h,
x1: x,
y1: q,
x2: v,
y2: y,
};
c = N(c);
r &&
ea(
this._eventManager.ghostCtx,
x,
q,
v,
y,
c,
0,
null,
!1,
!1,
!1,
!1
);
(t[h].indexLabel ||
k.indexLabel ||
t[h].indexLabelFormatter ||
k.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "stackedColumn100",
dataPoint: t[h],
dataSeries: k,
point: { x: s, y: 0 <= t[h].y ? q : y },
direction: 0 > t[h].y === a.axisY.reversed ? 1 : -1,
bounds: {
x1: x,
y1: Math.min(q, y),
x2: v,
y2: Math.max(q, y),
},
color: c,
});
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.yScaleAnimation,
easingFunction: M.easing.easeOutQuart,
animationBase:
n < a.axisY.bounds.y1
? a.axisY.bounds.y1
: n > a.axisY.bounds.y2
? a.axisY.bounds.y2
: n,
};
}
};
p.prototype.renderBar = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = null,
e = this.plotArea,
g = 0,
m,
l,
w,
h = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
g = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1,
s = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: Math.min(
0.15 * this.height,
0.9 * (this.plotArea.height / a.plotType.totalDataSeries)
) << 0,
q = a.axisX.dataInfo.minDiff;
isFinite(q) || (q = 0.3 * Math.abs(a.axisX.range));
q = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
((e.height *
(a.axisX.logarithmic
? Math.log(q) / Math.log(a.axisX.range)
: Math.abs(q) / Math.abs(a.axisX.range))) /
a.plotType.totalDataSeries)) <<
0;
this.dataPointMaxWidth &&
g > s &&
(g = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
s
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
s < g &&
(s = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
g
));
q < g && (q = g);
q > s && (q = s);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.clip());
for (s = 0; s < a.dataSeriesIndexes.length; s++) {
var n = a.dataSeriesIndexes[s],
f = this.data[n],
B = f.dataPoints;
if (0 < B.length) {
var k = 5 < q && f.bevelEnabled ? !0 : !1;
b.strokeStyle = "#4572A7 ";
for (g = 0; g < B.length; g++)
if (
(B[g].getTime ? (w = B[g].x.getTime()) : (w = B[g].x),
!(
w < a.axisX.dataInfo.viewPortMin ||
w > a.axisX.dataInfo.viewPortMax
) && "number" === typeof B[g].y)
) {
l = a.axisX.convertValueToPixel(w);
m = a.axisY.convertValueToPixel(B[g].y);
l = a.axisX.reversed
? (l +
(a.plotType.totalDataSeries * q) / 2 -
(a.previousDataSeriesCount + s) * q) <<
0
: (l -
(a.plotType.totalDataSeries * q) / 2 +
(a.previousDataSeriesCount + s) * q) <<
0;
var p = a.axisX.reversed ? (l - q) << 0 : (l + q) << 0,
t;
0 <= B[g].y ? (t = h) : ((t = m), (m = h));
c = B[g].color
? B[g].color
: f._colorSet[g % f._colorSet.length];
ea(b, t, l, m, p, c, 0, null, k, !1, !1, !1, f.fillOpacity);
c = f.dataPointIds[g];
this._eventManager.objectMap[c] = {
id: c,
objectType: "dataPoint",
dataSeriesIndex: n,
dataPointIndex: g,
x1: t,
y1: l,
x2: m,
y2: p,
};
c = N(c);
r &&
ea(
this._eventManager.ghostCtx,
t,
l,
m,
p,
c,
0,
null,
!1,
!1,
!1,
!1
);
(B[g].indexLabel ||
f.indexLabel ||
B[g].indexLabelFormatter ||
f.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "bar",
dataPoint: B[g],
dataSeries: f,
point: { x: 0 <= B[g].y ? m : t, y: l + (p - l) / 2 },
direction: 0 > B[g].y === a.axisY.reversed ? 1 : -1,
bounds: {
x1: Math.min(t, m),
y1: l,
x2: Math.max(t, m),
y2: p,
},
color: c,
});
}
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.xScaleAnimation,
easingFunction: M.easing.easeOutQuart,
animationBase:
h < a.axisY.bounds.x1
? a.axisY.bounds.x1
: h > a.axisY.bounds.x2
? a.axisY.bounds.x2
: h,
};
}
};
p.prototype.renderStackedBar = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = null,
e = this.plotArea,
g = [],
m = [],
l = [],
w = [],
h = 0,
s,
q,
n = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
h = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1;
q = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: (0.15 * this.height) << 0;
var f = a.axisX.dataInfo.minDiff;
isFinite(f) || (f = 0.3 * Math.abs(a.axisX.range));
f = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
((e.height *
(a.axisX.logarithmic
? Math.log(f) / Math.log(a.axisX.range)
: Math.abs(f) / Math.abs(a.axisX.range))) /
a.plotType.plotUnits.length)) <<
0;
this.dataPointMaxWidth &&
h > q &&
(h = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
q
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
q < h &&
(q = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
h
));
f < h && (f = h);
f > q && (f = q);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.clip());
for (var B = 0; B < a.dataSeriesIndexes.length; B++) {
var p = a.dataSeriesIndexes[B],
k = this.data[p],
t = k.dataPoints;
if (0 < t.length) {
var u = 5 < f && k.bevelEnabled ? !0 : !1;
b.strokeStyle = "#4572A7 ";
for (h = 0; h < t.length; h++)
if (
((c = t[h].x.getTime ? t[h].x.getTime() : t[h].x),
!(
c < a.axisX.dataInfo.viewPortMin ||
c > a.axisX.dataInfo.viewPortMax
) && "number" === typeof t[h].y)
) {
q = a.axisX.convertValueToPixel(c);
var x =
(q - (a.plotType.plotUnits.length * f) / 2 + a.index * f) <<
0,
v = (x + f) << 0,
y;
if (
a.axisY.logarithmic ||
(a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length &&
0 < t[h].y)
)
(l[c] = t[h].y + (l[c] ? l[c] : 0)),
0 < l[c] &&
((y = g[c] ? g[c] : n),
(g[c] = s = a.axisY.convertValueToPixel(l[c])));
else if (
a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length &&
0 >= t[h].y
)
(w[c] = t[h].y + (w[c] ? w[c] : 0)),
(s = m[c] ? m[c] : n),
(m[c] = y = a.axisY.convertValueToPixel(w[c]));
else if (
((s = a.axisY.convertValueToPixel(t[h].y)), 0 <= t[h].y)
) {
var A = g[c] ? g[c] : 0;
y = n + A;
s += A;
g[c] = A + (s - y);
} else
(A = m[c] ? m[c] : 0),
(y = s - A),
(s = n - A),
(m[c] = A + (s - y));
c = t[h].color
? t[h].color
: k._colorSet[h % k._colorSet.length];
ea(b, y, x, s, v, c, 0, null, u, !1, !1, !1, k.fillOpacity);
c = k.dataPointIds[h];
this._eventManager.objectMap[c] = {
id: c,
objectType: "dataPoint",
dataSeriesIndex: p,
dataPointIndex: h,
x1: y,
y1: x,
x2: s,
y2: v,
};
c = N(c);
r &&
ea(
this._eventManager.ghostCtx,
y,
x,
s,
v,
c,
0,
null,
!1,
!1,
!1,
!1
);
(t[h].indexLabel ||
k.indexLabel ||
t[h].indexLabelFormatter ||
k.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "stackedBar",
dataPoint: t[h],
dataSeries: k,
point: { x: 0 <= t[h].y ? s : y, y: q },
direction: 0 > t[h].y === a.axisY.reversed ? 1 : -1,
bounds: {
x1: Math.min(y, s),
y1: x,
x2: Math.max(y, s),
y2: v,
},
color: c,
});
}
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.xScaleAnimation,
easingFunction: M.easing.easeOutQuart,
animationBase:
n < a.axisY.bounds.x1
? a.axisY.bounds.x1
: n > a.axisY.bounds.x2
? a.axisY.bounds.x2
: n,
};
}
};
p.prototype.renderStackedBar100 = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = null,
e = this.plotArea,
g = [],
m = [],
l = [],
w = [],
h = 0,
s,
q,
n = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
h = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1;
q = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: (0.15 * this.height) << 0;
var f = a.axisX.dataInfo.minDiff;
isFinite(f) || (f = 0.3 * Math.abs(a.axisX.range));
f = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
((e.height *
(a.axisX.logarithmic
? Math.log(f) / Math.log(a.axisX.range)
: Math.abs(f) / Math.abs(a.axisX.range))) /
a.plotType.plotUnits.length)) <<
0;
this.dataPointMaxWidth &&
h > q &&
(h = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
q
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
q < h &&
(q = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
h
));
f < h && (f = h);
f > q && (f = q);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.clip());
for (var B = 0; B < a.dataSeriesIndexes.length; B++) {
var k = a.dataSeriesIndexes[B],
p = this.data[k],
t = p.dataPoints;
if (0 < t.length) {
var u = 5 < f && p.bevelEnabled ? !0 : !1;
b.strokeStyle = "#4572A7 ";
for (h = 0; h < t.length; h++)
if (
((c = t[h].x.getTime ? t[h].x.getTime() : t[h].x),
!(
c < a.axisX.dataInfo.viewPortMin ||
c > a.axisX.dataInfo.viewPortMax
) && "number" === typeof t[h].y)
) {
q = a.axisX.convertValueToPixel(c);
var x;
x =
0 !== a.dataPointYSums[c]
? 100 * (t[h].y / a.dataPointYSums[c])
: 0;
var v =
(q - (a.plotType.plotUnits.length * f) / 2 + a.index * f) <<
0,
y = (v + f) << 0;
if (
a.axisY.logarithmic ||
(a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length &&
0 < t[h].y)
) {
l[c] = x + (l[c] ? l[c] : 0);
if (0 >= l[c]) continue;
x = g[c] ? g[c] : n;
g[c] = s = a.axisY.convertValueToPixel(l[c]);
} else if (
a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length &&
0 >= t[h].y
)
(w[c] = x + (w[c] ? w[c] : 0)),
(s = m[c] ? m[c] : n),
(m[c] = x = a.axisY.convertValueToPixel(w[c]));
else if (((s = a.axisY.convertValueToPixel(x)), 0 <= t[h].y)) {
var A = g[c] ? g[c] : 0;
x = n + A;
s += A;
a.dataSeriesIndexes.length - 1 === B &&
1 >= Math.abs(e.x2 - s) &&
(s = e.x2);
g[c] = A + (s - x);
} else
(A = m[c] ? m[c] : 0),
(x = s - A),
(s = n - A),
a.dataSeriesIndexes.length - 1 === B &&
1 >= Math.abs(e.x1 - x) &&
(x = e.x1),
(m[c] = A + (s - x));
c = t[h].color
? t[h].color
: p._colorSet[h % p._colorSet.length];
ea(b, x, v, s, y, c, 0, null, u, !1, !1, !1, p.fillOpacity);
c = p.dataPointIds[h];
this._eventManager.objectMap[c] = {
id: c,
objectType: "dataPoint",
dataSeriesIndex: k,
dataPointIndex: h,
x1: x,
y1: v,
x2: s,
y2: y,
};
c = N(c);
r &&
ea(
this._eventManager.ghostCtx,
x,
v,
s,
y,
c,
0,
null,
!1,
!1,
!1,
!1
);
(t[h].indexLabel ||
p.indexLabel ||
t[h].indexLabelFormatter ||
p.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "stackedBar100",
dataPoint: t[h],
dataSeries: p,
point: { x: 0 <= t[h].y ? s : x, y: q },
direction: 0 > t[h].y === a.axisY.reversed ? 1 : -1,
bounds: {
x1: Math.min(x, s),
y1: v,
x2: Math.max(x, s),
y2: y,
},
color: c,
});
}
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.xScaleAnimation,
easingFunction: M.easing.easeOutQuart,
animationBase:
n < a.axisY.bounds.x1
? a.axisY.bounds.x1
: n > a.axisY.bounds.x2
? a.axisY.bounds.x2
: n,
};
}
};
p.prototype.renderArea = function (a) {
var d, b;
function c() {
A &&
(0 < B.lineThickness && g.stroke(),
a.axisY.logarithmic ||
(0 >= a.axisY.viewportMinimum && 0 <= a.axisY.viewportMaximum)
? (y = v)
: 0 > a.axisY.viewportMaximum
? (y = w.y1)
: 0 < a.axisY.viewportMinimum && (y = l.y2),
g.lineTo(t, y),
g.lineTo(A.x, y),
g.closePath(),
(g.globalAlpha = B.fillOpacity),
g.fill(),
(g.globalAlpha = 1),
r && (m.lineTo(t, y), m.lineTo(A.x, y), m.closePath(), m.fill()),
g.beginPath(),
g.moveTo(t, u),
m.beginPath(),
m.moveTo(t, u),
(A = { x: t, y: u }));
}
var e = a.targetCanvasCtx || this.plotArea.ctx,
g = r ? this._preRenderCtx : e;
if (!(0 >= a.dataSeriesIndexes.length)) {
var m = this._eventManager.ghostCtx,
l = a.axisX.lineCoordinates,
w = a.axisY.lineCoordinates,
h = [],
s = this.plotArea,
q;
g.save();
r && m.save();
g.beginPath();
g.rect(s.x1, s.y1, s.width, s.height);
g.clip();
r && (m.beginPath(), m.rect(s.x1, s.y1, s.width, s.height), m.clip());
for (var n = 0; n < a.dataSeriesIndexes.length; n++) {
var f = a.dataSeriesIndexes[n],
B = this.data[f],
p = B.dataPoints,
h = B.id;
this._eventManager.objectMap[h] = {
objectType: "dataSeries",
dataSeriesIndex: f,
};
h = N(h);
m.fillStyle = h;
h = [];
d = !0;
var k = 0,
t,
u,
x,
v = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
y,
A = null;
if (0 < p.length) {
var z = B._colorSet[k % B._colorSet.length],
aa = (B.lineColor = B.options.lineColor || z),
T = aa;
g.fillStyle = z;
g.strokeStyle = aa;
g.lineWidth = B.lineThickness;
b = "solid";
if (g.setLineDash) {
var Y = R(B.nullDataLineDashType, B.lineThickness);
b = B.lineDashType;
var ca = R(b, B.lineThickness);
g.setLineDash(ca);
}
for (var da = !0; k < p.length; k++)
if (
((x = p[k].x.getTime ? p[k].x.getTime() : p[k].x),
!(
x < a.axisX.dataInfo.viewPortMin ||
(x > a.axisX.dataInfo.viewPortMax &&
(!B.connectNullData || !da))
))
)
if ("number" !== typeof p[k].y)
B.connectNullData || da || d || c(), (da = !0);
else {
t = a.axisX.convertValueToPixel(x);
u = a.axisY.convertValueToPixel(p[k].y);
d || da
? (!d && B.connectNullData
? (g.setLineDash &&
(B.options.nullDataLineDashType ||
(b === B.lineDashType &&
B.lineDashType !== B.nullDataLineDashType)) &&
((d = t),
(b = u),
(t = q.x),
(u = q.y),
c(),
g.moveTo(q.x, q.y),
(t = d),
(u = b),
(A = q),
(b = B.nullDataLineDashType),
g.setLineDash(Y)),
g.lineTo(t, u),
r && m.lineTo(t, u))
: (g.beginPath(),
g.moveTo(t, u),
r && (m.beginPath(), m.moveTo(t, u)),
(A = { x: t, y: u })),
(da = d = !1))
: (g.lineTo(t, u),
r && m.lineTo(t, u),
0 == k % 250 && c());
q = { x: t, y: u };
k < p.length - 1 &&
(T !== (p[k].lineColor || aa) ||
b !== (p[k].lineDashType || B.lineDashType)) &&
(c(),
(T = p[k].lineColor || aa),
(g.strokeStyle = T),
g.setLineDash &&
(p[k].lineDashType
? ((b = p[k].lineDashType),
g.setLineDash(R(b, B.lineThickness)))
: ((b = B.lineDashType), g.setLineDash(ca))));
var Z = B.dataPointIds[k];
this._eventManager.objectMap[Z] = {
id: Z,
objectType: "dataPoint",
dataSeriesIndex: f,
dataPointIndex: k,
x1: t,
y1: u,
};
0 !== p[k].markerSize &&
(0 < p[k].markerSize || 0 < B.markerSize) &&
((x = B.getMarkerProperties(k, t, u, g)),
h.push(x),
(Z = N(Z)),
r &&
h.push({
x: t,
y: u,
ctx: m,
type: x.type,
size: x.size,
color: Z,
borderColor: Z,
borderThickness: x.borderThickness,
}));
(p[k].indexLabel ||
B.indexLabel ||
p[k].indexLabelFormatter ||
B.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "area",
dataPoint: p[k],
dataSeries: B,
point: { x: t, y: u },
direction: 0 > p[k].y === a.axisY.reversed ? 1 : -1,
color: z,
});
}
c();
ia.drawMarkers(h);
}
}
r &&
(e.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(g.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
g.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
g.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
g.clearRect(s.x1, s.y1, s.width, s.height),
this._eventManager.ghostCtx.restore());
g.restore();
return {
source: e,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderSplineArea = function (a) {
function d() {
var b = v(x, 2);
if (0 < b.length) {
if (0 < q.lineThickness) {
c.beginPath();
c.moveTo(b[0].x, b[0].y);
b[0].newStrokeStyle && (c.strokeStyle = b[0].newStrokeStyle);
b[0].newLineDashArray && c.setLineDash(b[0].newLineDashArray);
for (var d = 0; d < b.length - 3; d += 3)
if (
(c.bezierCurveTo(
b[d + 1].x,
b[d + 1].y,
b[d + 2].x,
b[d + 2].y,
b[d + 3].x,
b[d + 3].y
),
r &&
e.bezierCurveTo(
b[d + 1].x,
b[d + 1].y,
b[d + 2].x,
b[d + 2].y,
b[d + 3].x,
b[d + 3].y
),
b[d + 3].newStrokeStyle || b[d + 3].newLineDashArray)
)
c.stroke(),
c.beginPath(),
c.moveTo(b[d + 3].x, b[d + 3].y),
b[d + 3].newStrokeStyle &&
(c.strokeStyle = b[d + 3].newStrokeStyle),
b[d + 3].newLineDashArray &&
c.setLineDash(b[d + 3].newLineDashArray);
c.stroke();
}
c.beginPath();
c.moveTo(b[0].x, b[0].y);
r && (e.beginPath(), e.moveTo(b[0].x, b[0].y));
for (d = 0; d < b.length - 3; d += 3)
c.bezierCurveTo(
b[d + 1].x,
b[d + 1].y,
b[d + 2].x,
b[d + 2].y,
b[d + 3].x,
b[d + 3].y
),
r &&
e.bezierCurveTo(
b[d + 1].x,
b[d + 1].y,
b[d + 2].x,
b[d + 2].y,
b[d + 3].x,
b[d + 3].y
);
a.axisY.logarithmic ||
(0 >= a.axisY.viewportMinimum && 0 <= a.axisY.viewportMaximum)
? (t = p)
: 0 > a.axisY.viewportMaximum
? (t = m.y1)
: 0 < a.axisY.viewportMinimum && (t = g.y2);
u = { x: b[0].x, y: b[0].y };
c.lineTo(b[b.length - 1].x, t);
c.lineTo(u.x, t);
c.closePath();
c.globalAlpha = q.fillOpacity;
c.fill();
c.globalAlpha = 1;
r &&
(e.lineTo(b[b.length - 1].x, t),
e.lineTo(u.x, t),
e.closePath(),
e.fill());
}
}
var b = a.targetCanvasCtx || this.plotArea.ctx,
c = r ? this._preRenderCtx : b;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = this._eventManager.ghostCtx,
g = a.axisX.lineCoordinates,
m = a.axisY.lineCoordinates,
l = [],
w = this.plotArea;
c.save();
r && e.save();
c.beginPath();
c.rect(w.x1, w.y1, w.width, w.height);
c.clip();
r && (e.beginPath(), e.rect(w.x1, w.y1, w.width, w.height), e.clip());
for (var h = 0; h < a.dataSeriesIndexes.length; h++) {
var s = a.dataSeriesIndexes[h],
q = this.data[s],
n = q.dataPoints,
l = q.id;
this._eventManager.objectMap[l] = {
objectType: "dataSeries",
dataSeriesIndex: s,
};
l = N(l);
e.fillStyle = l;
var l = [],
f = 0,
B,
k,
p = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
t,
u = null,
x = [];
if (0 < n.length) {
var ma = q._colorSet[f % q._colorSet.length],
y = (q.lineColor = q.options.lineColor || ma),
A = y;
c.fillStyle = ma;
c.strokeStyle = y;
c.lineWidth = q.lineThickness;
var z = "solid";
if (c.setLineDash) {
var aa = R(q.nullDataLineDashType, q.lineThickness),
z = q.lineDashType,
T = R(z, q.lineThickness);
c.setLineDash(T);
}
for (k = !1; f < n.length; f++)
if (
((B = n[f].x.getTime ? n[f].x.getTime() : n[f].x),
!(
B < a.axisX.dataInfo.viewPortMin ||
(B > a.axisX.dataInfo.viewPortMax &&
(!q.connectNullData || !k))
))
)
if ("number" !== typeof n[f].y)
0 < f &&
!k &&
(q.connectNullData
? c.setLineDash &&
0 < x.length &&
(q.options.nullDataLineDashType ||
!n[f - 1].lineDashType) &&
((x[x.length - 1].newLineDashArray = aa),
(z = q.nullDataLineDashType))
: (d(), (x = []))),
(k = !0);
else {
B = a.axisX.convertValueToPixel(B);
k = a.axisY.convertValueToPixel(n[f].y);
var Y = q.dataPointIds[f];
this._eventManager.objectMap[Y] = {
id: Y,
objectType: "dataPoint",
dataSeriesIndex: s,
dataPointIndex: f,
x1: B,
y1: k,
};
x[x.length] = { x: B, y: k };
f < n.length - 1 &&
(A !== (n[f].lineColor || y) ||
z !== (n[f].lineDashType || q.lineDashType)) &&
((A = n[f].lineColor || y),
(x[x.length - 1].newStrokeStyle = A),
c.setLineDash &&
(n[f].lineDashType
? ((z = n[f].lineDashType),
(x[x.length - 1].newLineDashArray = R(
z,
q.lineThickness
)))
: ((z = q.lineDashType),
(x[x.length - 1].newLineDashArray = T))));
if (
0 !== n[f].markerSize &&
(0 < n[f].markerSize || 0 < q.markerSize)
) {
var ca = q.getMarkerProperties(f, B, k, c);
l.push(ca);
Y = N(Y);
r &&
l.push({
x: B,
y: k,
ctx: e,
type: ca.type,
size: ca.size,
color: Y,
borderColor: Y,
borderThickness: ca.borderThickness,
});
}
(n[f].indexLabel ||
q.indexLabel ||
n[f].indexLabelFormatter ||
q.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "splineArea",
dataPoint: n[f],
dataSeries: q,
point: { x: B, y: k },
direction: 0 > n[f].y === a.axisY.reversed ? 1 : -1,
color: ma,
});
k = !1;
}
d();
ia.drawMarkers(l);
}
}
r &&
(b.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(c.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
c.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
c.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
c.clearRect(w.x1, w.y1, w.width, w.height),
this._eventManager.ghostCtx.restore());
c.restore();
return {
source: b,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderStepArea = function (a) {
var d, b;
function c() {
A &&
(0 < B.lineThickness && g.stroke(),
a.axisY.logarithmic ||
(0 >= a.axisY.viewportMinimum && 0 <= a.axisY.viewportMaximum)
? (y = v)
: 0 > a.axisY.viewportMaximum
? (y = w.y1)
: 0 < a.axisY.viewportMinimum && (y = l.y2),
g.lineTo(t, y),
g.lineTo(A.x, y),
g.closePath(),
(g.globalAlpha = B.fillOpacity),
g.fill(),
(g.globalAlpha = 1),
r && (m.lineTo(t, y), m.lineTo(A.x, y), m.closePath(), m.fill()),
g.beginPath(),
g.moveTo(t, u),
m.beginPath(),
m.moveTo(t, u),
(A = { x: t, y: u }));
}
var e = a.targetCanvasCtx || this.plotArea.ctx,
g = r ? this._preRenderCtx : e;
if (!(0 >= a.dataSeriesIndexes.length)) {
var m = this._eventManager.ghostCtx,
l = a.axisX.lineCoordinates,
w = a.axisY.lineCoordinates,
h = [],
s = this.plotArea,
q;
g.save();
r && m.save();
g.beginPath();
g.rect(s.x1, s.y1, s.width, s.height);
g.clip();
r && (m.beginPath(), m.rect(s.x1, s.y1, s.width, s.height), m.clip());
for (var n = 0; n < a.dataSeriesIndexes.length; n++) {
var f = a.dataSeriesIndexes[n],
B = this.data[f],
k = B.dataPoints,
h = B.id;
this._eventManager.objectMap[h] = {
objectType: "dataSeries",
dataSeriesIndex: f,
};
h = N(h);
m.fillStyle = h;
h = [];
d = !0;
var p = 0,
t,
u,
x,
v = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
y,
A = null;
b = !1;
if (0 < k.length) {
var z = B._colorSet[p % B._colorSet.length],
aa = (B.lineColor = B.options.lineColor || z),
T = aa;
g.fillStyle = z;
g.strokeStyle = aa;
g.lineWidth = B.lineThickness;
var Y = "solid";
if (g.setLineDash) {
var ca = R(B.nullDataLineDashType, B.lineThickness),
Y = B.lineDashType,
da = R(Y, B.lineThickness);
g.setLineDash(da);
}
for (; p < k.length; p++)
if (
((x = k[p].x.getTime ? k[p].x.getTime() : k[p].x),
!(
x < a.axisX.dataInfo.viewPortMin ||
(x > a.axisX.dataInfo.viewPortMax &&
(!B.connectNullData || !b))
))
) {
var Z = u;
"number" !== typeof k[p].y
? (B.connectNullData || b || d || c(), (b = !0))
: ((t = a.axisX.convertValueToPixel(x)),
(u = a.axisY.convertValueToPixel(k[p].y)),
d || b
? (!d && B.connectNullData
? (g.setLineDash &&
(B.options.nullDataLineDashType ||
(Y === B.lineDashType &&
B.lineDashType !== B.nullDataLineDashType)) &&
((d = t),
(b = u),
(t = q.x),
(u = q.y),
c(),
g.moveTo(q.x, q.y),
(t = d),
(u = b),
(A = q),
(Y = B.nullDataLineDashType),
g.setLineDash(ca)),
g.lineTo(t, Z),
g.lineTo(t, u),
r && (m.lineTo(t, Z), m.lineTo(t, u)))
: (g.beginPath(),
g.moveTo(t, u),
r && (m.beginPath(), m.moveTo(t, u)),
(A = { x: t, y: u })),
(b = d = !1))
: (g.lineTo(t, Z),
r && m.lineTo(t, Z),
g.lineTo(t, u),
r && m.lineTo(t, u),
0 == p % 250 && c()),
(q = { x: t, y: u }),
p < k.length - 1 &&
(T !== (k[p].lineColor || aa) ||
Y !== (k[p].lineDashType || B.lineDashType)) &&
(c(),
(T = k[p].lineColor || aa),
(g.strokeStyle = T),
g.setLineDash &&
(k[p].lineDashType
? ((Y = k[p].lineDashType),
g.setLineDash(R(Y, B.lineThickness)))
: ((Y = B.lineDashType), g.setLineDash(da)))),
(x = B.dataPointIds[p]),
(this._eventManager.objectMap[x] = {
id: x,
objectType: "dataPoint",
dataSeriesIndex: f,
dataPointIndex: p,
x1: t,
y1: u,
}),
0 !== k[p].markerSize &&
(0 < k[p].markerSize || 0 < B.markerSize) &&
((Z = B.getMarkerProperties(p, t, u, g)),
h.push(Z),
(x = N(x)),
r &&
h.push({
x: t,
y: u,
ctx: m,
type: Z.type,
size: Z.size,
color: x,
borderColor: x,
borderThickness: Z.borderThickness,
})),
(k[p].indexLabel ||
B.indexLabel ||
k[p].indexLabelFormatter ||
B.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "stepArea",
dataPoint: k[p],
dataSeries: B,
point: { x: t, y: u },
direction: 0 > k[p].y === a.axisY.reversed ? 1 : -1,
color: z,
}));
}
c();
ia.drawMarkers(h);
}
}
r &&
(e.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(g.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
g.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
g.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
g.clearRect(s.x1, s.y1, s.width, s.height),
this._eventManager.ghostCtx.restore());
g.restore();
return {
source: e,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderStackedArea = function (a) {
function d() {
if (!(1 > h.length)) {
for (0 < A.lineThickness && c.stroke(); 0 < h.length; ) {
var a = h.pop();
c.lineTo(a.x, a.y);
r && u.lineTo(a.x, a.y);
}
c.closePath();
c.globalAlpha = A.fillOpacity;
c.fill();
c.globalAlpha = 1;
c.beginPath();
r && (u.closePath(), u.fill(), u.beginPath());
h = [];
}
}
var b = a.targetCanvasCtx || this.plotArea.ctx,
c = r ? this._preRenderCtx : b;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = null,
g = null,
m = [],
l = this.plotArea,
w = [],
h = [],
s = [],
q = [],
n = 0,
f,
k,
p = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
u = this._eventManager.ghostCtx,
t,
C,
x;
r && u.beginPath();
c.save();
r && u.save();
c.beginPath();
c.rect(l.x1, l.y1, l.width, l.height);
c.clip();
r && (u.beginPath(), u.rect(l.x1, l.y1, l.width, l.height), u.clip());
for (var e = [], v = 0; v < a.dataSeriesIndexes.length; v++) {
var y = a.dataSeriesIndexes[v],
A = this.data[y],
z = A.dataPoints;
A.dataPointIndexes = [];
for (n = 0; n < z.length; n++)
(y = z[n].x.getTime ? z[n].x.getTime() : z[n].x),
(A.dataPointIndexes[y] = n),
e[y] || (s.push(y), (e[y] = !0));
s.sort(Sa);
}
for (v = 0; v < a.dataSeriesIndexes.length; v++) {
y = a.dataSeriesIndexes[v];
A = this.data[y];
z = A.dataPoints;
C = !0;
h = [];
n = A.id;
this._eventManager.objectMap[n] = {
objectType: "dataSeries",
dataSeriesIndex: y,
};
n = N(n);
u.fillStyle = n;
if (0 < s.length) {
var e = A._colorSet[0],
aa = (A.lineColor = A.options.lineColor || e),
T = aa;
c.fillStyle = e;
c.strokeStyle = aa;
c.lineWidth = A.lineThickness;
x = "solid";
if (c.setLineDash) {
var Y = R(A.nullDataLineDashType, A.lineThickness);
x = A.lineDashType;
var ca = R(x, A.lineThickness);
c.setLineDash(ca);
}
for (var da = !0, n = 0; n < s.length; n++) {
var g = s[n],
Z = null,
Z =
0 <= A.dataPointIndexes[g]
? z[A.dataPointIndexes[g]]
: { x: g, y: null };
if (
!(
g < a.axisX.dataInfo.viewPortMin ||
(g > a.axisX.dataInfo.viewPortMax &&
(!A.connectNullData || !da))
)
)
if ("number" !== typeof Z.y)
A.connectNullData || da || C || d(), (da = !0);
else {
f = a.axisX.convertValueToPixel(g);
var oa = w[g] ? w[g] : 0;
if (
a.axisY.logarithmic ||
(a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length)
) {
q[g] = Z.y + (q[g] ? q[g] : 0);
if (0 >= q[g] && a.axisY.logarithmic) continue;
k = a.axisY.convertValueToPixel(q[g]);
} else (k = a.axisY.convertValueToPixel(Z.y)), (k -= oa);
h.push({ x: f, y: p - oa });
w[g] = p - k;
C || da
? (!C && A.connectNullData
? (c.setLineDash &&
(A.options.nullDataLineDashType ||
(x === A.lineDashType &&
A.lineDashType !== A.nullDataLineDashType)) &&
((C = h.pop()),
(x = h[h.length - 1]),
d(),
c.moveTo(t.x, t.y),
h.push(x),
h.push(C),
(x = A.nullDataLineDashType),
c.setLineDash(Y)),
c.lineTo(f, k),
r && u.lineTo(f, k))
: (c.beginPath(),
c.moveTo(f, k),
r && (u.beginPath(), u.moveTo(f, k))),
(da = C = !1))
: (c.lineTo(f, k),
r && u.lineTo(f, k),
0 == n % 250 &&
(d(),
c.moveTo(f, k),
r && u.moveTo(f, k),
h.push({ x: f, y: p - oa })));
t = { x: f, y: k };
n < z.length - 1 &&
(T !== (z[n].lineColor || aa) ||
x !== (z[n].lineDashType || A.lineDashType)) &&
(d(),
c.beginPath(),
c.moveTo(f, k),
h.push({ x: f, y: p - oa }),
(T = z[n].lineColor || aa),
(c.strokeStyle = T),
c.setLineDash &&
(z[n].lineDashType
? ((x = z[n].lineDashType),
c.setLineDash(R(x, A.lineThickness)))
: ((x = A.lineDashType), c.setLineDash(ca))));
if (0 <= A.dataPointIndexes[g]) {
var la = A.dataPointIds[A.dataPointIndexes[g]];
this._eventManager.objectMap[la] = {
id: la,
objectType: "dataPoint",
dataSeriesIndex: y,
dataPointIndex: A.dataPointIndexes[g],
x1: f,
y1: k,
};
}
0 <= A.dataPointIndexes[g] &&
0 !== Z.markerSize &&
(0 < Z.markerSize || 0 < A.markerSize) &&
((oa = A.getMarkerProperties(
A.dataPointIndexes[g],
f,
k,
c
)),
m.push(oa),
(g = N(la)),
r &&
m.push({
x: f,
y: k,
ctx: u,
type: oa.type,
size: oa.size,
color: g,
borderColor: g,
borderThickness: oa.borderThickness,
}));
(Z.indexLabel ||
A.indexLabel ||
Z.indexLabelFormatter ||
A.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "stackedArea",
dataPoint: Z,
dataSeries: A,
point: { x: f, y: k },
direction: 0 > z[n].y === a.axisY.reversed ? 1 : -1,
color: e,
});
}
}
d();
c.moveTo(f, k);
r && u.moveTo(f, k);
}
delete A.dataPointIndexes;
}
ia.drawMarkers(m);
r &&
(b.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(c.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
c.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
c.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
c.clearRect(l.x1, l.y1, l.width, l.height),
u.restore());
c.restore();
return {
source: b,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderStackedArea100 = function (a) {
function d() {
for (0 < A.lineThickness && c.stroke(); 0 < h.length; ) {
var a = h.pop();
c.lineTo(a.x, a.y);
r && x.lineTo(a.x, a.y);
}
c.closePath();
c.globalAlpha = A.fillOpacity;
c.fill();
c.globalAlpha = 1;
c.beginPath();
r && (x.closePath(), x.fill(), x.beginPath());
h = [];
}
var b = a.targetCanvasCtx || this.plotArea.ctx,
c = r ? this._preRenderCtx : b;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = null,
g = null,
m = this.plotArea,
l = [],
w = [],
h = [],
s = [],
q = [],
n = 0,
f,
k,
p,
u,
t,
C = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
x = this._eventManager.ghostCtx;
c.save();
r && x.save();
c.beginPath();
c.rect(m.x1, m.y1, m.width, m.height);
c.clip();
r && (x.beginPath(), x.rect(m.x1, m.y1, m.width, m.height), x.clip());
for (var e = [], v = 0; v < a.dataSeriesIndexes.length; v++) {
var y = a.dataSeriesIndexes[v],
A = this.data[y],
z = A.dataPoints;
A.dataPointIndexes = [];
for (n = 0; n < z.length; n++)
(y = z[n].x.getTime ? z[n].x.getTime() : z[n].x),
(A.dataPointIndexes[y] = n),
e[y] || (s.push(y), (e[y] = !0));
s.sort(Sa);
}
for (v = 0; v < a.dataSeriesIndexes.length; v++) {
y = a.dataSeriesIndexes[v];
A = this.data[y];
z = A.dataPoints;
u = !0;
e = A.id;
this._eventManager.objectMap[e] = {
objectType: "dataSeries",
dataSeriesIndex: y,
};
e = N(e);
x.fillStyle = e;
h = [];
if (0 < s.length) {
var e = A._colorSet[n % A._colorSet.length],
aa = (A.lineColor = A.options.lineColor || e),
T = aa;
c.fillStyle = e;
c.strokeStyle = aa;
c.lineWidth = A.lineThickness;
t = "solid";
if (c.setLineDash) {
var Y = R(A.nullDataLineDashType, A.lineThickness);
t = A.lineDashType;
var ca = R(t, A.lineThickness);
c.setLineDash(ca);
}
for (var da = !0, n = 0; n < s.length; n++) {
var g = s[n],
Z = null,
Z =
0 <= A.dataPointIndexes[g]
? z[A.dataPointIndexes[g]]
: { x: g, y: null };
if (
!(
g < a.axisX.dataInfo.viewPortMin ||
(g > a.axisX.dataInfo.viewPortMax &&
(!A.connectNullData || !da))
)
)
if ("number" !== typeof Z.y)
A.connectNullData || da || u || d(), (da = !0);
else {
var oa;
oa =
0 !== a.dataPointYSums[g]
? 100 * (Z.y / a.dataPointYSums[g])
: 0;
f = a.axisX.convertValueToPixel(g);
var la = w[g] ? w[g] : 0;
if (
a.axisY.logarithmic ||
(a.axisY.scaleBreaks &&
0 < a.axisY.scaleBreaks._appliedBreaks.length)
) {
q[g] = oa + (q[g] ? q[g] : 0);
if (0 >= q[g] && a.axisY.logarithmic) continue;
k = a.axisY.convertValueToPixel(q[g]);
} else (k = a.axisY.convertValueToPixel(oa)), (k -= la);
h.push({ x: f, y: C - la });
w[g] = C - k;
u || da
? (!u && A.connectNullData
? (c.setLineDash &&
(A.options.nullDataLineDashType ||
(t === A.lineDashType &&
A.lineDashType !== A.nullDataLineDashType)) &&
((u = h.pop()),
(t = h[h.length - 1]),
d(),
c.moveTo(p.x, p.y),
h.push(t),
h.push(u),
(t = A.nullDataLineDashType),
c.setLineDash(Y)),
c.lineTo(f, k),
r && x.lineTo(f, k))
: (c.beginPath(),
c.moveTo(f, k),
r && (x.beginPath(), x.moveTo(f, k))),
(da = u = !1))
: (c.lineTo(f, k),
r && x.lineTo(f, k),
0 == n % 250 &&
(d(),
c.moveTo(f, k),
r && x.moveTo(f, k),
h.push({ x: f, y: C - la })));
p = { x: f, y: k };
n < z.length - 1 &&
(T !== (z[n].lineColor || aa) ||
t !== (z[n].lineDashType || A.lineDashType)) &&
(d(),
c.beginPath(),
c.moveTo(f, k),
h.push({ x: f, y: C - la }),
(T = z[n].lineColor || aa),
(c.strokeStyle = T),
c.setLineDash &&
(z[n].lineDashType
? ((t = z[n].lineDashType),
c.setLineDash(R(t, A.lineThickness)))
: ((t = A.lineDashType), c.setLineDash(ca))));
if (0 <= A.dataPointIndexes[g]) {
var G = A.dataPointIds[A.dataPointIndexes[g]];
this._eventManager.objectMap[G] = {
id: G,
objectType: "dataPoint",
dataSeriesIndex: y,
dataPointIndex: A.dataPointIndexes[g],
x1: f,
y1: k,
};
}
0 <= A.dataPointIndexes[g] &&
0 !== Z.markerSize &&
(0 < Z.markerSize || 0 < A.markerSize) &&
((la = A.getMarkerProperties(n, f, k, c)),
l.push(la),
(g = N(G)),
r &&
l.push({
x: f,
y: k,
ctx: x,
type: la.type,
size: la.size,
color: g,
borderColor: g,
borderThickness: la.borderThickness,
}));
(Z.indexLabel ||
A.indexLabel ||
Z.indexLabelFormatter ||
A.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "stackedArea100",
dataPoint: Z,
dataSeries: A,
point: { x: f, y: k },
direction: 0 > z[n].y === a.axisY.reversed ? 1 : -1,
color: e,
});
}
}
d();
c.moveTo(f, k);
r && x.moveTo(f, k);
}
delete A.dataPointIndexes;
}
ia.drawMarkers(l);
r &&
(b.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(c.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
c.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
c.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
c.clearRect(m.x1, m.y1, m.width, m.height),
x.restore());
c.restore();
return {
source: b,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderBubble = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = this.plotArea,
e = 0,
g,
m;
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(c.x1, c.y1, c.width, c.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(c.x1, c.y1, c.width, c.height),
this._eventManager.ghostCtx.clip());
for (
var l = -Infinity, w = Infinity, h = 0;
h < a.dataSeriesIndexes.length;
h++
)
for (
var s = a.dataSeriesIndexes[h],
q = this.data[s],
n = q.dataPoints,
f = 0,
e = 0;
e < n.length;
e++
)
(g = n[e].getTime ? (g = n[e].x.getTime()) : (g = n[e].x)),
g < a.axisX.dataInfo.viewPortMin ||
g > a.axisX.dataInfo.viewPortMax ||
"undefined" === typeof n[e].z ||
((f = n[e].z), f > l && (l = f), f < w && (w = f));
for (
var k = 25 * Math.PI,
p = Math.max(
Math.pow((0.25 * Math.min(c.height, c.width)) / 2, 2) * Math.PI,
k
),
h = 0;
h < a.dataSeriesIndexes.length;
h++
)
if (
((s = a.dataSeriesIndexes[h]),
(q = this.data[s]),
(n = q.dataPoints),
0 < n.length)
)
for (b.strokeStyle = "#4572A7 ", e = 0; e < n.length; e++)
if (
((g = n[e].getTime ? (g = n[e].x.getTime()) : (g = n[e].x)),
!(
g < a.axisX.dataInfo.viewPortMin ||
g > a.axisX.dataInfo.viewPortMax
) && "number" === typeof n[e].y)
) {
g = a.axisX.convertValueToPixel(g);
m = a.axisY.convertValueToPixel(n[e].y);
var f = n[e].z,
u =
2 *
Math.max(
Math.sqrt(
(l === w ? p / 2 : k + ((p - k) / (l - w)) * (f - w)) /
Math.PI
) << 0,
1
),
f = q.getMarkerProperties(e, b);
f.size = u;
b.globalAlpha = q.fillOpacity;
ia.drawMarker(
g,
m,
b,
f.type,
f.size,
f.color,
f.borderColor,
f.borderThickness
);
b.globalAlpha = 1;
var t = q.dataPointIds[e];
this._eventManager.objectMap[t] = {
id: t,
objectType: "dataPoint",
dataSeriesIndex: s,
dataPointIndex: e,
x1: g,
y1: m,
size: u,
};
u = N(t);
r &&
ia.drawMarker(
g,
m,
this._eventManager.ghostCtx,
f.type,
f.size,
u,
u,
f.borderThickness
);
(n[e].indexLabel ||
q.indexLabel ||
n[e].indexLabelFormatter ||
q.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "bubble",
dataPoint: n[e],
dataSeries: q,
point: { x: g, y: m },
direction: 1,
bounds: {
x1: g - f.size / 2,
y1: m - f.size / 2,
x2: g + f.size / 2,
y2: m + f.size / 2,
},
color: null,
});
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(c.x1, c.y1, c.width, c.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
};
p.prototype.renderScatter = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = this.plotArea,
e = 0,
g,
m;
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(c.x1, c.y1, c.width, c.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(c.x1, c.y1, c.width, c.height),
this._eventManager.ghostCtx.clip());
for (var l = 0; l < a.dataSeriesIndexes.length; l++) {
var w = a.dataSeriesIndexes[l],
h = this.data[w],
s = h.dataPoints;
if (0 < s.length) {
b.strokeStyle = "#4572A7 ";
Math.pow((0.3 * Math.min(c.height, c.width)) / 2, 2);
for (var q = 0, n = 0, e = 0; e < s.length; e++)
if (
((g = s[e].getTime ? (g = s[e].x.getTime()) : (g = s[e].x)),
!(
g < a.axisX.dataInfo.viewPortMin ||
g > a.axisX.dataInfo.viewPortMax
) && "number" === typeof s[e].y)
) {
g = a.axisX.convertValueToPixel(g);
m = a.axisY.convertValueToPixel(s[e].y);
var f = h.getMarkerProperties(e, g, m, b);
b.globalAlpha = h.fillOpacity;
ia.drawMarker(
f.x,
f.y,
f.ctx,
f.type,
f.size,
f.color,
f.borderColor,
f.borderThickness
);
b.globalAlpha = 1;
(Math.sqrt((q - g) * (q - g) + (n - m) * (n - m)) <
Math.min(f.size, 5) &&
s.length >
Math.min(this.plotArea.width, this.plotArea.height)) ||
((q = h.dataPointIds[e]),
(this._eventManager.objectMap[q] = {
id: q,
objectType: "dataPoint",
dataSeriesIndex: w,
dataPointIndex: e,
x1: g,
y1: m,
}),
(q = N(q)),
r &&
ia.drawMarker(
f.x,
f.y,
this._eventManager.ghostCtx,
f.type,
f.size,
q,
q,
f.borderThickness
),
(s[e].indexLabel ||
h.indexLabel ||
s[e].indexLabelFormatter ||
h.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "scatter",
dataPoint: s[e],
dataSeries: h,
point: { x: g, y: m },
direction: 1,
bounds: {
x1: g - f.size / 2,
y1: m - f.size / 2,
x2: g + f.size / 2,
y2: m + f.size / 2,
},
color: null,
}),
(q = g),
(n = m));
}
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(c.x1, c.y1, c.width, c.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
};
p.prototype.renderCandlestick = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d,
c = this._eventManager.ghostCtx;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = null,
g = null,
m = this.plotArea,
l = 0,
w,
h,
s,
q,
n,
f,
e = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1,
g = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 0.015 * this.width,
k = a.axisX.dataInfo.minDiff;
isFinite(k) || (k = 0.3 * Math.abs(a.axisX.range));
k = this.options.dataPointWidth
? this.dataPointWidth
: (0.7 *
m.width *
(a.axisX.logarithmic
? Math.log(k) / Math.log(a.axisX.range)
: Math.abs(k) / Math.abs(a.axisX.range))) <<
0;
this.dataPointMaxWidth &&
e > g &&
(e = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
g
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
g < e &&
(g = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
e
));
k < e && (k = e);
k > g && (k = g);
b.save();
r && c.save();
b.beginPath();
b.rect(m.x1, m.y1, m.width, m.height);
b.clip();
r && (c.beginPath(), c.rect(m.x1, m.y1, m.width, m.height), c.clip());
for (var p = 0; p < a.dataSeriesIndexes.length; p++) {
var v = a.dataSeriesIndexes[p],
t = this.data[v],
C = t.dataPoints;
if (0 < C.length)
for (
var x = 5 < k && t.bevelEnabled ? !0 : !1, l = 0;
l < C.length;
l++
)
if (
(C[l].getTime ? (f = C[l].x.getTime()) : (f = C[l].x),
!(
f < a.axisX.dataInfo.viewPortMin ||
f > a.axisX.dataInfo.viewPortMax
) &&
!u(C[l].y) &&
C[l].y.length &&
"number" === typeof C[l].y[0] &&
"number" === typeof C[l].y[1] &&
"number" === typeof C[l].y[2] &&
"number" === typeof C[l].y[3])
) {
w = a.axisX.convertValueToPixel(f);
h = a.axisY.convertValueToPixel(C[l].y[0]);
s = a.axisY.convertValueToPixel(C[l].y[1]);
q = a.axisY.convertValueToPixel(C[l].y[2]);
n = a.axisY.convertValueToPixel(C[l].y[3]);
var z = (w - k / 2) << 0,
y = (z + k) << 0,
g = t.options.fallingColor ? t.fallingColor : t._colorSet[0],
e = C[l].color ? C[l].color : t._colorSet[0],
A = Math.round(Math.max(1, 0.15 * k)),
D = 0 === A % 2 ? 0 : 0.5,
aa = t.dataPointIds[l];
this._eventManager.objectMap[aa] = {
id: aa,
objectType: "dataPoint",
dataSeriesIndex: v,
dataPointIndex: l,
x1: z,
y1: h,
x2: y,
y2: s,
x3: w,
y3: q,
x4: w,
y4: n,
borderThickness: A,
color: e,
};
b.strokeStyle = e;
b.beginPath();
b.lineWidth = A;
c.lineWidth = Math.max(A, 4);
"candlestick" === t.type
? (b.moveTo(w - D, s),
b.lineTo(w - D, Math.min(h, n)),
b.stroke(),
b.moveTo(w - D, Math.max(h, n)),
b.lineTo(w - D, q),
b.stroke(),
ea(
b,
z,
Math.min(h, n),
y,
Math.max(h, n),
C[l].y[0] <= C[l].y[3] ? t.risingColor : g,
A,
e,
x,
x,
!1,
!1,
t.fillOpacity
),
r &&
((e = N(aa)),
(c.strokeStyle = e),
c.moveTo(w - D, s),
c.lineTo(w - D, Math.min(h, n)),
c.stroke(),
c.moveTo(w - D, Math.max(h, n)),
c.lineTo(w - D, q),
c.stroke(),
ea(
c,
z,
Math.min(h, n),
y,
Math.max(h, n),
e,
0,
null,
!1,
!1,
!1,
!1
)))
: "ohlc" === t.type &&
(b.moveTo(w - D, s),
b.lineTo(w - D, q),
b.stroke(),
b.beginPath(),
b.moveTo(w, h),
b.lineTo(z, h),
b.stroke(),
b.beginPath(),
b.moveTo(w, n),
b.lineTo(y, n),
b.stroke(),
r &&
((e = N(aa)),
(c.strokeStyle = e),
c.moveTo(w - D, s),
c.lineTo(w - D, q),
c.stroke(),
c.beginPath(),
c.moveTo(w, h),
c.lineTo(z, h),
c.stroke(),
c.beginPath(),
c.moveTo(w, n),
c.lineTo(y, n),
c.stroke()));
(C[l].indexLabel ||
t.indexLabel ||
C[l].indexLabelFormatter ||
t.indexLabelFormatter) &&
this._indexLabels.push({
chartType: t.type,
dataPoint: C[l],
dataSeries: t,
point: { x: z + (y - z) / 2, y: a.axisY.reversed ? q : s },
direction: 1,
bounds: {
x1: z,
y1: Math.min(s, q),
x2: y,
y2: Math.max(s, q),
},
color: e,
});
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(m.x1, m.y1, m.width, m.height),
c.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
};
p.prototype.renderBoxAndWhisker = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d,
c = this._eventManager.ghostCtx;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = null,
g = this.plotArea,
m = 0,
l,
w,
h,
s,
q,
n,
f,
e = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1,
m = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 0.015 * this.width,
k = a.axisX.dataInfo.minDiff;
isFinite(k) || (k = 0.3 * Math.abs(a.axisX.range));
k = this.options.dataPointWidth
? this.dataPointWidth
: (0.7 *
g.width *
(a.axisX.logarithmic
? Math.log(k) / Math.log(a.axisX.range)
: Math.abs(k) / Math.abs(a.axisX.range))) <<
0;
this.dataPointMaxWidth &&
e > m &&
(e = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
m
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
m < e &&
(m = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
e
));
k < e && (k = e);
k > m && (k = m);
b.save();
r && c.save();
b.beginPath();
b.rect(g.x1, g.y1, g.width, g.height);
b.clip();
r && (c.beginPath(), c.rect(g.x1, g.y1, g.width, g.height), c.clip());
for (
var p = !1, p = !!a.axisY.reversed, v = 0;
v < a.dataSeriesIndexes.length;
v++
) {
var t = a.dataSeriesIndexes[v],
C = this.data[t],
x = C.dataPoints;
if (0 < x.length)
for (
var z = 5 < k && C.bevelEnabled ? !0 : !1, m = 0;
m < x.length;
m++
)
if (
(x[m].getTime ? (f = x[m].x.getTime()) : (f = x[m].x),
!(
f < a.axisX.dataInfo.viewPortMin ||
f > a.axisX.dataInfo.viewPortMax
) &&
!u(x[m].y) &&
x[m].y.length &&
"number" === typeof x[m].y[0] &&
"number" === typeof x[m].y[1] &&
"number" === typeof x[m].y[2] &&
"number" === typeof x[m].y[3] &&
"number" === typeof x[m].y[4] &&
5 === x[m].y.length)
) {
l = a.axisX.convertValueToPixel(f);
w = a.axisY.convertValueToPixel(x[m].y[0]);
h = a.axisY.convertValueToPixel(x[m].y[1]);
s = a.axisY.convertValueToPixel(x[m].y[2]);
q = a.axisY.convertValueToPixel(x[m].y[3]);
n = a.axisY.convertValueToPixel(x[m].y[4]);
var y = (l - k / 2) << 0,
A = (l + k / 2) << 0,
e = x[m].color ? x[m].color : C._colorSet[0],
D = Math.round(Math.max(1, 0.15 * k)),
aa = 0 === D % 2 ? 0 : 0.5,
T = x[m].whiskerColor
? x[m].whiskerColor
: x[m].color
? C.whiskerColor
? C.whiskerColor
: x[m].color
: C.whiskerColor
? C.whiskerColor
: e,
Y =
"number" === typeof x[m].whiskerThickness
? x[m].whiskerThickness
: "number" === typeof C.options.whiskerThickness
? C.whiskerThickness
: D,
ca = x[m].whiskerDashType
? x[m].whiskerDashType
: C.whiskerDashType,
da = u(x[m].whiskerLength)
? u(C.options.whiskerLength)
? k
: C.whiskerLength
: x[m].whiskerLength,
da =
"number" === typeof da
? 0 >= da
? 0
: da >= k
? k
: da
: "string" === typeof da
? (parseInt(da) * k) / 100 > k
? k
: (parseInt(da) * k) / 100
: k,
Z = 1 === Math.round(Y) % 2 ? 0.5 : 0,
oa = x[m].stemColor
? x[m].stemColor
: x[m].color
? C.stemColor
? C.stemColor
: x[m].color
: C.stemColor
? C.stemColor
: e,
la =
"number" === typeof x[m].stemThickness
? x[m].stemThickness
: "number" === typeof C.options.stemThickness
? C.stemThickness
: D,
G = 1 === Math.round(la) % 2 ? 0.5 : 0,
F = x[m].stemDashType ? x[m].stemDashType : C.stemDashType,
E = x[m].lineColor
? x[m].lineColor
: x[m].color
? C.lineColor
? C.lineColor
: x[m].color
: C.lineColor
? C.lineColor
: e,
H =
"number" === typeof x[m].lineThickness
? x[m].lineThickness
: "number" === typeof C.options.lineThickness
? C.lineThickness
: D,
I = x[m].lineDashType ? x[m].lineDashType : C.lineDashType,
K = 1 === Math.round(H) % 2 ? 0.5 : 0,
L = C.upperBoxColor,
O = C.lowerBoxColor,
Q = u(C.options.fillOpacity) ? 1 : C.fillOpacity,
P = C.dataPointIds[m];
this._eventManager.objectMap[P] = {
id: P,
objectType: "dataPoint",
dataSeriesIndex: t,
dataPointIndex: m,
x1: y,
y1: w,
x2: A,
y2: h,
x3: l,
y3: s,
x4: l,
y4: q,
y5: n,
borderThickness: D,
color: e,
stemThickness: la,
stemColor: oa,
whiskerThickness: Y,
whiskerLength: da,
whiskerColor: T,
lineThickness: H,
lineColor: E,
};
b.save();
0 < la &&
(b.beginPath(),
(b.strokeStyle = oa),
(b.lineWidth = la),
b.setLineDash && b.setLineDash(R(F, la)),
b.moveTo(l - G, h),
b.lineTo(l - G, w),
b.stroke(),
b.moveTo(l - G, q),
b.lineTo(l - G, s),
b.stroke());
b.restore();
c.lineWidth = Math.max(D, 4);
b.beginPath();
ea(
b,
y,
Math.min(n, h),
A,
Math.max(h, n),
O,
0,
e,
p ? z : !1,
p ? !1 : z,
!1,
!1,
Q
);
b.beginPath();
ea(
b,
y,
Math.min(s, n),
A,
Math.max(n, s),
L,
0,
e,
p ? !1 : z,
p ? z : !1,
!1,
!1,
Q
);
b.beginPath();
b.lineWidth = D;
b.strokeStyle = e;
b.rect(
y - aa,
Math.min(h, s) - aa,
A - y + 2 * aa,
Math.max(h, s) - Math.min(h, s) + 2 * aa
);
b.stroke();
b.save();
0 < H &&
(b.beginPath(),
(b.globalAlpha = 1),
b.setLineDash && b.setLineDash(R(I, H)),
(b.strokeStyle = E),
(b.lineWidth = H),
b.moveTo(y, n - K),
b.lineTo(A, n - K),
b.stroke());
b.restore();
b.save();
0 < Y &&
(b.beginPath(),
b.setLineDash && b.setLineDash(R(ca, Y)),
(b.strokeStyle = T),
(b.lineWidth = Y),
b.moveTo((l - da / 2) << 0, q - Z),
b.lineTo((l + da / 2) << 0, q - Z),
b.stroke(),
b.moveTo((l - da / 2) << 0, w + Z),
b.lineTo((l + da / 2) << 0, w + Z),
b.stroke());
b.restore();
r &&
((e = N(P)),
(c.strokeStyle = e),
(c.lineWidth = la),
0 < la &&
(c.moveTo(l - aa - G, h),
c.lineTo(l - aa - G, Math.max(w, q)),
c.stroke(),
c.moveTo(l - aa - G, Math.min(w, q)),
c.lineTo(l - aa - G, s),
c.stroke()),
ea(
c,
y,
Math.max(h, s),
A,
Math.min(h, s),
e,
0,
null,
!1,
!1,
!1,
!1
),
0 < Y &&
(c.beginPath(),
(c.lineWidth = Y),
c.moveTo(l + da / 2, q - Z),
c.lineTo(l - da / 2, q - Z),
c.stroke(),
c.moveTo(l + da / 2, w + Z),
c.lineTo(l - da / 2, w + Z),
c.stroke()));
(x[m].indexLabel ||
C.indexLabel ||
x[m].indexLabelFormatter ||
C.indexLabelFormatter) &&
this._indexLabels.push({
chartType: C.type,
dataPoint: x[m],
dataSeries: C,
point: { x: y + (A - y) / 2, y: a.axisY.reversed ? w : q },
direction: 1,
bounds: {
x1: y,
y1: Math.min(w, q),
x2: A,
y2: Math.max(w, q),
},
color: e,
});
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(g.x1, g.y1, g.width, g.height),
c.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
};
p.prototype.renderRangeColumn = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = null,
e = this.plotArea,
g = 0,
m,
l,
w,
g = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1;
m = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 0.03 * this.width;
var h = a.axisX.dataInfo.minDiff;
isFinite(h) || (h = 0.3 * Math.abs(a.axisX.range));
h = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
((e.width *
(a.axisX.logarithmic
? Math.log(h) / Math.log(a.axisX.range)
: Math.abs(h) / Math.abs(a.axisX.range))) /
a.plotType.totalDataSeries)) <<
0;
this.dataPointMaxWidth &&
g > m &&
(g = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
m
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
m < g &&
(m = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
g
));
h < g && (h = g);
h > m && (h = m);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.clip());
for (var s = 0; s < a.dataSeriesIndexes.length; s++) {
var q = a.dataSeriesIndexes[s],
n = this.data[q],
f = n.dataPoints;
if (0 < f.length)
for (
var k = 5 < h && n.bevelEnabled ? !0 : !1, g = 0;
g < f.length;
g++
)
if (
(f[g].getTime ? (w = f[g].x.getTime()) : (w = f[g].x),
!(
w < a.axisX.dataInfo.viewPortMin ||
w > a.axisX.dataInfo.viewPortMax
) &&
!u(f[g].y) &&
f[g].y.length &&
"number" === typeof f[g].y[0] &&
"number" === typeof f[g].y[1])
) {
c = a.axisX.convertValueToPixel(w);
m = a.axisY.convertValueToPixel(f[g].y[0]);
l = a.axisY.convertValueToPixel(f[g].y[1]);
var p = a.axisX.reversed
? (c +
(a.plotType.totalDataSeries * h) / 2 -
(a.previousDataSeriesCount + s) * h) <<
0
: (c -
(a.plotType.totalDataSeries * h) / 2 +
(a.previousDataSeriesCount + s) * h) <<
0,
v = a.axisX.reversed ? (p - h) << 0 : (p + h) << 0,
c = f[g].color
? f[g].color
: n._colorSet[g % n._colorSet.length];
if (m > l) {
var t = m;
m = l;
l = t;
}
t = n.dataPointIds[g];
this._eventManager.objectMap[t] = {
id: t,
objectType: "dataPoint",
dataSeriesIndex: q,
dataPointIndex: g,
x1: p,
y1: m,
x2: v,
y2: l,
};
ea(b, p, m, v, l, c, 0, c, k, k, !1, !1, n.fillOpacity);
c = N(t);
r &&
ea(
this._eventManager.ghostCtx,
p,
m,
v,
l,
c,
0,
null,
!1,
!1,
!1,
!1
);
if (
f[g].indexLabel ||
n.indexLabel ||
f[g].indexLabelFormatter ||
n.indexLabelFormatter
)
this._indexLabels.push({
chartType: "rangeColumn",
dataPoint: f[g],
dataSeries: n,
indexKeyword: 0,
point: {
x: p + (v - p) / 2,
y: f[g].y[1] >= f[g].y[0] ? l : m,
},
direction: f[g].y[1] >= f[g].y[0] ? -1 : 1,
bounds: {
x1: p,
y1: Math.min(m, l),
x2: v,
y2: Math.max(m, l),
},
color: c,
}),
this._indexLabels.push({
chartType: "rangeColumn",
dataPoint: f[g],
dataSeries: n,
indexKeyword: 1,
point: {
x: p + (v - p) / 2,
y: f[g].y[1] >= f[g].y[0] ? m : l,
},
direction: f[g].y[1] >= f[g].y[0] ? 1 : -1,
bounds: {
x1: p,
y1: Math.min(m, l),
x2: v,
y2: Math.max(m, l),
},
color: c,
});
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
};
p.prototype.renderError = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d,
c = a.axisY._position
? "left" === a.axisY._position || "right" === a.axisY._position
? !1
: !0
: !1;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = null,
g = !1,
m = this.plotArea,
l = 0,
w,
h,
s,
q,
n,
f,
k,
p = a.axisX.dataInfo.minDiff;
isFinite(p) || (p = 0.3 * Math.abs(a.axisX.range));
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(m.x1, m.y1, m.width, m.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(m.x1, m.y1, m.width, m.height),
this._eventManager.ghostCtx.clip());
for (var v = 0, t = 0; t < this.data.length; t++)
!this.data[t].type.match(/(bar|column)/gi) ||
!this.data[t].visible ||
(this.data[t].type.match(/(stacked)/gi) && v) ||
v++;
for (var C = 0; C < a.dataSeriesIndexes.length; C++) {
var x = a.dataSeriesIndexes[C],
z = this.data[x],
y = z.dataPoints,
A = u(z._linkedSeries)
? !1
: z._linkedSeries.type.match(/(bar|column)/gi) &&
z._linkedSeries.visible
? !0
: !1,
D = 0;
if (A)
for (e = z._linkedSeries.id, t = 0; t < e; t++)
!this.data[t].type.match(/(bar|column)/gi) ||
!this.data[t].visible ||
(this.data[t].type.match(/(stacked)/gi) && D) ||
(this.data[t].type.match(/(range)/gi) && (g = !0), D++);
e = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1;
l = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: c
? Math.min(
0.15 * this.height,
0.9 * (this.plotArea.height / (A ? v : 1))
) << 0
: 0.3 * this.width;
g &&
(l = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: c
? Math.min(
0.15 * this.height,
0.9 * (this.plotArea.height / (A ? v : 1))
) << 0
: 0.03 * this.width);
t = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
(((c ? m.height : m.width) *
(a.axisX.logarithmic
? Math.log(p) / Math.log(a.axisX.range)
: Math.abs(p) / Math.abs(a.axisX.range))) /
(A ? v : 1))) <<
0;
this.dataPointMaxWidth &&
e > l &&
(e = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
l
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
l < e &&
(l = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
e
));
t < e && (t = e);
t > l && (t = l);
if (0 < y.length)
for (var aa = z._colorSet, l = 0; l < y.length; l++) {
var e = (z.lineColor = z.options.color ? z.options.color : aa[0]),
T = {
color: y[l].whiskerColor
? y[l].whiskerColor
: y[l].color
? z.whiskerColor
? z.whiskerColor
: y[l].color
: z.whiskerColor
? z.whiskerColor
: e,
thickness: u(y[l].whiskerThickness)
? z.whiskerThickness
: y[l].whiskerThickness,
dashType: y[l].whiskerDashType
? y[l].whiskerDashType
: z.whiskerDashType,
length: u(y[l].whiskerLength)
? u(z.options.whiskerLength)
? t
: z.options.whiskerLength
: y[l].whiskerLength,
trimLength: u(y[l].whiskerLength)
? u(z.options.whiskerLength)
? 50
: 0
: 0,
};
T.length =
"number" === typeof T.length
? 0 >= T.length
? 0
: T.length >= t
? t
: T.length
: "string" === typeof T.length
? (parseInt(T.length) * t) / 100 > t
? t
: (parseInt(T.length) * t) / 100 > t
: t;
T.thickness =
"number" === typeof T.thickness
? 0 > T.thickness
? 0
: Math.round(T.thickness)
: 2;
var Y = {
color: y[l].stemColor
? y[l].stemColor
: y[l].color
? z.stemColor
? z.stemColor
: y[l].color
: z.stemColor
? z.stemColor
: e,
thickness: y[l].stemThickness
? y[l].stemThickness
: z.stemThickness,
dashType: y[l].stemDashType
? y[l].stemDashType
: z.stemDashType,
};
Y.thickness =
"number" === typeof Y.thickness
? 0 > Y.thickness
? 0
: Math.round(Y.thickness)
: 2;
y[l].getTime ? (k = y[l].x.getTime()) : (k = y[l].x);
if (
!(
k < a.axisX.dataInfo.viewPortMin ||
k > a.axisX.dataInfo.viewPortMax
) &&
!u(y[l].y) &&
y[l].y.length &&
"number" === typeof y[l].y[0] &&
"number" === typeof y[l].y[1]
) {
var ca = a.axisX.convertValueToPixel(k);
c ? (h = ca) : (w = ca);
ca = a.axisY.convertValueToPixel(y[l].y[0]);
c ? (s = ca) : (n = ca);
ca = a.axisY.convertValueToPixel(y[l].y[1]);
c ? (q = ca) : (f = ca);
c
? ((n = a.axisX.reversed
? (h + ((A ? v : 1) * t) / 2 - (A ? D - 1 : 0) * t) << 0
: (h - ((A ? v : 1) * t) / 2 + (A ? D - 1 : 0) * t) << 0),
(f = a.axisX.reversed ? (n - t) << 0 : (n + t) << 0))
: ((s = a.axisX.reversed
? (w + ((A ? v : 1) * t) / 2 - (A ? D - 1 : 0) * t) << 0
: (w - ((A ? v : 1) * t) / 2 + (A ? D - 1 : 0) * t) << 0),
(q = a.axisX.reversed ? (s - t) << 0 : (s + t) << 0));
!c && n > f && ((ca = n), (n = f), (f = ca));
c && s > q && ((ca = s), (s = q), (q = ca));
ca = z.dataPointIds[l];
this._eventManager.objectMap[ca] = {
id: ca,
objectType: "dataPoint",
dataSeriesIndex: x,
dataPointIndex: l,
x1: Math.min(s, q),
y1: Math.min(n, f),
x2: Math.max(q, s),
y2: Math.max(f, n),
isXYSwapped: c,
stemProperties: Y,
whiskerProperties: T,
};
E(
b,
Math.min(s, q),
Math.min(n, f),
Math.max(q, s),
Math.max(f, n),
e,
T,
Y,
c
);
r && E(this._eventManager.ghostCtx, s, n, q, f, e, T, Y, c);
if (
y[l].indexLabel ||
z.indexLabel ||
y[l].indexLabelFormatter ||
z.indexLabelFormatter
)
this._indexLabels.push({
chartType: "error",
dataPoint: y[l],
dataSeries: z,
indexKeyword: 0,
point: {
x: c ? (y[l].y[1] >= y[l].y[0] ? s : q) : s + (q - s) / 2,
y: c ? n + (f - n) / 2 : y[l].y[1] >= y[l].y[0] ? f : n,
},
direction: y[l].y[1] >= y[l].y[0] ? -1 : 1,
bounds: {
x1: c ? Math.min(s, q) : s,
y1: c ? n : Math.min(n, f),
x2: c ? Math.max(s, q) : q,
y2: c ? f : Math.max(n, f),
},
color: e,
axisSwapped: c,
}),
this._indexLabels.push({
chartType: "error",
dataPoint: y[l],
dataSeries: z,
indexKeyword: 1,
point: {
x: c
? y[l].y[1] >= y[l].y[0]
? q
: s
: s + (q - s) / 2,
y: c ? n + (f - n) / 2 : y[l].y[1] >= y[l].y[0] ? n : f,
},
direction: y[l].y[1] >= y[l].y[0] ? 1 : -1,
bounds: {
x1: c ? Math.min(s, q) : s,
y1: c ? n : Math.min(n, f),
x2: c ? Math.max(s, q) : q,
y2: c ? f : Math.max(n, f),
},
color: e,
axisSwapped: c,
});
}
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(m.x1, m.y1, m.width, m.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
};
p.prototype.renderRangeBar = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = null,
e = this.plotArea,
g = 0,
m,
l,
w,
h,
g = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1;
m = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: Math.min(
0.15 * this.height,
0.9 * (this.plotArea.height / a.plotType.totalDataSeries)
) << 0;
var s = a.axisX.dataInfo.minDiff;
isFinite(s) || (s = 0.3 * Math.abs(a.axisX.range));
s = this.options.dataPointWidth
? this.dataPointWidth
: (0.9 *
((e.height *
(a.axisX.logarithmic
? Math.log(s) / Math.log(a.axisX.range)
: Math.abs(s) / Math.abs(a.axisX.range))) /
a.plotType.totalDataSeries)) <<
0;
this.dataPointMaxWidth &&
g > m &&
(g = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
m
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
m < g &&
(m = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
g
));
s < g && (s = g);
s > m && (s = m);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(e.x1, e.y1, e.width, e.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.clip());
for (var q = 0; q < a.dataSeriesIndexes.length; q++) {
var n = a.dataSeriesIndexes[q],
f = this.data[n],
k = f.dataPoints;
if (0 < k.length) {
var p = 5 < s && f.bevelEnabled ? !0 : !1;
b.strokeStyle = "#4572A7 ";
for (g = 0; g < k.length; g++)
if (
(k[g].getTime ? (h = k[g].x.getTime()) : (h = k[g].x),
!(
h < a.axisX.dataInfo.viewPortMin ||
h > a.axisX.dataInfo.viewPortMax
) &&
!u(k[g].y) &&
k[g].y.length &&
"number" === typeof k[g].y[0] &&
"number" === typeof k[g].y[1])
) {
m = a.axisY.convertValueToPixel(k[g].y[0]);
l = a.axisY.convertValueToPixel(k[g].y[1]);
w = a.axisX.convertValueToPixel(h);
w = a.axisX.reversed
? (w +
(a.plotType.totalDataSeries * s) / 2 -
(a.previousDataSeriesCount + q) * s) <<
0
: (w -
(a.plotType.totalDataSeries * s) / 2 +
(a.previousDataSeriesCount + q) * s) <<
0;
var v = a.axisX.reversed ? (w - s) << 0 : (w + s) << 0;
m > l && ((c = m), (m = l), (l = c));
c = k[g].color
? k[g].color
: f._colorSet[g % f._colorSet.length];
ea(b, m, w, l, v, c, 0, null, p, !1, !1, !1, f.fillOpacity);
c = f.dataPointIds[g];
this._eventManager.objectMap[c] = {
id: c,
objectType: "dataPoint",
dataSeriesIndex: n,
dataPointIndex: g,
x1: m,
y1: w,
x2: l,
y2: v,
};
c = N(c);
r &&
ea(
this._eventManager.ghostCtx,
m,
w,
l,
v,
c,
0,
null,
!1,
!1,
!1,
!1
);
if (
k[g].indexLabel ||
f.indexLabel ||
k[g].indexLabelFormatter ||
f.indexLabelFormatter
)
this._indexLabels.push({
chartType: "rangeBar",
dataPoint: k[g],
dataSeries: f,
indexKeyword: 0,
point: {
x: k[g].y[1] >= k[g].y[0] ? m : l,
y: w + (v - w) / 2,
},
direction: k[g].y[1] >= k[g].y[0] ? -1 : 1,
bounds: {
x1: Math.min(m, l),
y1: w,
x2: Math.max(m, l),
y2: v,
},
color: c,
}),
this._indexLabels.push({
chartType: "rangeBar",
dataPoint: k[g],
dataSeries: f,
indexKeyword: 1,
point: {
x: k[g].y[1] >= k[g].y[0] ? l : m,
y: w + (v - w) / 2,
},
direction: k[g].y[1] >= k[g].y[0] ? 1 : -1,
bounds: {
x1: Math.min(m, l),
y1: w,
x2: Math.max(m, l),
y2: v,
},
color: c,
});
}
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(e.x1, e.y1, e.width, e.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
};
p.prototype.renderRangeArea = function (a) {
function d() {
if (C) {
var a = null;
0 < s.lineThickness && c.stroke();
for (var b = w.length - 1; 0 <= b; b--)
(a = w[b]), c.lineTo(a.x, a.y), e.lineTo(a.x, a.y);
c.closePath();
c.globalAlpha = s.fillOpacity;
c.fill();
c.globalAlpha = 1;
e.fill();
if (0 < s.lineThickness) {
c.beginPath();
c.moveTo(a.x, a.y);
for (b = 0; b < w.length; b++) (a = w[b]), c.lineTo(a.x, a.y);
c.stroke();
}
c.beginPath();
c.moveTo(k, p);
e.beginPath();
e.moveTo(k, p);
C = { x: k, y: p };
w = [];
w.push({ x: k, y: u });
}
}
var b = a.targetCanvasCtx || this.plotArea.ctx,
c = r ? this._preRenderCtx : b;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = this._eventManager.ghostCtx,
g = [],
m = this.plotArea;
c.save();
r && e.save();
c.beginPath();
c.rect(m.x1, m.y1, m.width, m.height);
c.clip();
r && (e.beginPath(), e.rect(m.x1, m.y1, m.width, m.height), e.clip());
for (var l = 0; l < a.dataSeriesIndexes.length; l++) {
var w = [],
h = a.dataSeriesIndexes[l],
s = this.data[h],
q = s.dataPoints,
g = s.id;
this._eventManager.objectMap[g] = {
objectType: "dataSeries",
dataSeriesIndex: h,
};
g = N(g);
e.fillStyle = g;
var g = [],
n = !0,
f = 0,
k,
p,
u,
t,
C = null;
if (0 < q.length) {
var x = s._colorSet[f % s._colorSet.length],
v = (s.lineColor = s.options.lineColor || x),
y = v;
c.fillStyle = x;
c.strokeStyle = v;
c.lineWidth = s.lineThickness;
var A = "solid";
if (c.setLineDash) {
var z = R(s.nullDataLineDashType, s.lineThickness),
A = s.lineDashType,
D = R(A, s.lineThickness);
c.setLineDash(D);
}
for (var T = !0; f < q.length; f++)
if (
((t = q[f].x.getTime ? q[f].x.getTime() : q[f].x),
!(
t < a.axisX.dataInfo.viewPortMin ||
(t > a.axisX.dataInfo.viewPortMax &&
(!s.connectNullData || !T))
))
)
if (
null !== q[f].y &&
q[f].y.length &&
"number" === typeof q[f].y[0] &&
"number" === typeof q[f].y[1]
) {
k = a.axisX.convertValueToPixel(t);
p = a.axisY.convertValueToPixel(q[f].y[0]);
u = a.axisY.convertValueToPixel(q[f].y[1]);
n || T
? (s.connectNullData && !n
? (c.setLineDash &&
(s.options.nullDataLineDashType ||
(A === s.lineDashType &&
s.lineDashType !== s.nullDataLineDashType)) &&
((w[w.length - 1].newLineDashArray = D),
(A = s.nullDataLineDashType),
c.setLineDash(z)),
c.lineTo(k, p),
r && e.lineTo(k, p),
w.push({ x: k, y: u }))
: (c.beginPath(),
c.moveTo(k, p),
(C = { x: k, y: p }),
(w = []),
w.push({ x: k, y: u }),
r && (e.beginPath(), e.moveTo(k, p))),
(T = n = !1))
: (c.lineTo(k, p),
w.push({ x: k, y: u }),
r && e.lineTo(k, p),
0 == f % 250 && d());
t = s.dataPointIds[f];
this._eventManager.objectMap[t] = {
id: t,
objectType: "dataPoint",
dataSeriesIndex: h,
dataPointIndex: f,
x1: k,
y1: p,
y2: u,
};
f < q.length - 1 &&
(y !== (q[f].lineColor || v) ||
A !== (q[f].lineDashType || s.lineDashType)) &&
(d(),
(y = q[f].lineColor || v),
(w[w.length - 1].newStrokeStyle = y),
(c.strokeStyle = y),
c.setLineDash &&
(q[f].lineDashType
? ((A = q[f].lineDashType),
(w[w.length - 1].newLineDashArray = R(
A,
s.lineThickness
)),
c.setLineDash(w[w.length - 1].newLineDashArray))
: ((A = s.lineDashType),
(w[w.length - 1].newLineDashArray = D),
c.setLineDash(D))));
if (
0 !== q[f].markerSize &&
(0 < q[f].markerSize || 0 < s.markerSize)
) {
var Y = s.getMarkerProperties(f, k, u, c);
g.push(Y);
var ca = N(t);
r &&
g.push({
x: k,
y: u,
ctx: e,
type: Y.type,
size: Y.size,
color: ca,
borderColor: ca,
borderThickness: Y.borderThickness,
});
Y = s.getMarkerProperties(f, k, p, c);
g.push(Y);
ca = N(t);
r &&
g.push({
x: k,
y: p,
ctx: e,
type: Y.type,
size: Y.size,
color: ca,
borderColor: ca,
borderThickness: Y.borderThickness,
});
}
if (
q[f].indexLabel ||
s.indexLabel ||
q[f].indexLabelFormatter ||
s.indexLabelFormatter
)
this._indexLabels.push({
chartType: "rangeArea",
dataPoint: q[f],
dataSeries: s,
indexKeyword: 0,
point: { x: k, y: p },
direction:
q[f].y[0] > q[f].y[1] === a.axisY.reversed ? -1 : 1,
color: x,
}),
this._indexLabels.push({
chartType: "rangeArea",
dataPoint: q[f],
dataSeries: s,
indexKeyword: 1,
point: { x: k, y: u },
direction:
q[f].y[0] > q[f].y[1] === a.axisY.reversed ? 1 : -1,
color: x,
});
} else T || n || d(), (T = !0);
d();
ia.drawMarkers(g);
}
}
r &&
(b.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(c.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
c.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
c.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
c.clearRect(m.x1, m.y1, m.width, m.height),
this._eventManager.ghostCtx.restore());
c.restore();
return {
source: b,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderRangeSplineArea = function (a) {
function d(a, b) {
var d = v(u, 2);
if (0 < d.length) {
if (0 < h.lineThickness) {
c.strokeStyle = b;
c.setLineDash && c.setLineDash(a);
c.beginPath();
c.moveTo(d[0].x, d[0].y);
for (var f = 0; f < d.length - 3; f += 3) {
if (d[f].newStrokeStyle || d[f].newLineDashArray)
c.stroke(),
c.beginPath(),
c.moveTo(d[f].x, d[f].y),
d[f].newStrokeStyle && (c.strokeStyle = d[f].newStrokeStyle),
d[f].newLineDashArray && c.setLineDash(d[f].newLineDashArray);
c.bezierCurveTo(
d[f + 1].x,
d[f + 1].y,
d[f + 2].x,
d[f + 2].y,
d[f + 3].x,
d[f + 3].y
);
}
c.stroke();
}
c.beginPath();
c.moveTo(d[0].x, d[0].y);
r && (e.beginPath(), e.moveTo(d[0].x, d[0].y));
for (f = 0; f < d.length - 3; f += 3)
c.bezierCurveTo(
d[f + 1].x,
d[f + 1].y,
d[f + 2].x,
d[f + 2].y,
d[f + 3].x,
d[f + 3].y
),
r &&
e.bezierCurveTo(
d[f + 1].x,
d[f + 1].y,
d[f + 2].x,
d[f + 2].y,
d[f + 3].x,
d[f + 3].y
);
d = v(z, 2);
c.lineTo(z[z.length - 1].x, z[z.length - 1].y);
for (f = d.length - 1; 2 < f; f -= 3)
c.bezierCurveTo(
d[f - 1].x,
d[f - 1].y,
d[f - 2].x,
d[f - 2].y,
d[f - 3].x,
d[f - 3].y
),
r &&
e.bezierCurveTo(
d[f - 1].x,
d[f - 1].y,
d[f - 2].x,
d[f - 2].y,
d[f - 3].x,
d[f - 3].y
);
c.closePath();
c.globalAlpha = h.fillOpacity;
c.fill();
r && (e.closePath(), e.fill());
c.globalAlpha = 1;
if (0 < h.lineThickness) {
c.strokeStyle = b;
c.setLineDash && c.setLineDash(a);
c.beginPath();
c.moveTo(d[0].x, d[0].y);
for (var g = (f = 0); f < d.length - 3; f += 3, g++) {
if (u[g].newStrokeStyle || u[g].newLineDashArray)
c.stroke(),
c.beginPath(),
c.moveTo(d[f].x, d[f].y),
u[g].newStrokeStyle && (c.strokeStyle = u[g].newStrokeStyle),
u[g].newLineDashArray && c.setLineDash(u[g].newLineDashArray);
c.bezierCurveTo(
d[f + 1].x,
d[f + 1].y,
d[f + 2].x,
d[f + 2].y,
d[f + 3].x,
d[f + 3].y
);
}
c.stroke();
}
c.beginPath();
}
}
var b = a.targetCanvasCtx || this.plotArea.ctx,
c = r ? this._preRenderCtx : b;
if (!(0 >= a.dataSeriesIndexes.length)) {
var e = this._eventManager.ghostCtx,
g = [],
m = this.plotArea;
c.save();
r && e.save();
c.beginPath();
c.rect(m.x1, m.y1, m.width, m.height);
c.clip();
r && (e.beginPath(), e.rect(m.x1, m.y1, m.width, m.height), e.clip());
for (var l = 0; l < a.dataSeriesIndexes.length; l++) {
var w = a.dataSeriesIndexes[l],
h = this.data[w],
k = h.dataPoints,
g = h.id;
this._eventManager.objectMap[g] = {
objectType: "dataSeries",
dataSeriesIndex: w,
};
g = N(g);
e.fillStyle = g;
var g = [],
q = 0,
n,
f,
p,
u = [],
z = [];
if (0 < k.length) {
var t = h._colorSet[q % h._colorSet.length],
C = (h.lineColor = h.options.lineColor || t),
x = C;
c.fillStyle = t;
c.lineWidth = h.lineThickness;
var F = "solid",
y;
if (c.setLineDash) {
var A = R(h.nullDataLineDashType, h.lineThickness),
F = h.lineDashType;
y = R(F, h.lineThickness);
}
for (f = !1; q < k.length; q++)
if (
((n = k[q].x.getTime ? k[q].x.getTime() : k[q].x),
!(
n < a.axisX.dataInfo.viewPortMin ||
(n > a.axisX.dataInfo.viewPortMax &&
(!h.connectNullData || !f))
))
)
if (
null !== k[q].y &&
k[q].y.length &&
"number" === typeof k[q].y[0] &&
"number" === typeof k[q].y[1]
) {
n = a.axisX.convertValueToPixel(n);
f = a.axisY.convertValueToPixel(k[q].y[0]);
p = a.axisY.convertValueToPixel(k[q].y[1]);
var E = h.dataPointIds[q];
this._eventManager.objectMap[E] = {
id: E,
objectType: "dataPoint",
dataSeriesIndex: w,
dataPointIndex: q,
x1: n,
y1: f,
y2: p,
};
u[u.length] = { x: n, y: f };
z[z.length] = { x: n, y: p };
q < k.length - 1 &&
(x !== (k[q].lineColor || C) ||
F !== (k[q].lineDashType || h.lineDashType)) &&
((x = k[q].lineColor || C),
(u[u.length - 1].newStrokeStyle = x),
c.setLineDash &&
(k[q].lineDashType
? ((F = k[q].lineDashType),
(u[u.length - 1].newLineDashArray = R(
F,
h.lineThickness
)))
: ((F = h.lineDashType),
(u[u.length - 1].newLineDashArray = y))));
if (
0 !== k[q].markerSize &&
(0 < k[q].markerSize || 0 < h.markerSize)
) {
var aa = h.getMarkerProperties(q, n, f, c);
g.push(aa);
var T = N(E);
r &&
g.push({
x: n,
y: f,
ctx: e,
type: aa.type,
size: aa.size,
color: T,
borderColor: T,
borderThickness: aa.borderThickness,
});
aa = h.getMarkerProperties(q, n, p, c);
g.push(aa);
T = N(E);
r &&
g.push({
x: n,
y: p,
ctx: e,
type: aa.type,
size: aa.size,
color: T,
borderColor: T,
borderThickness: aa.borderThickness,
});
}
if (
k[q].indexLabel ||
h.indexLabel ||
k[q].indexLabelFormatter ||
h.indexLabelFormatter
)
this._indexLabels.push({
chartType: "rangeSplineArea",
dataPoint: k[q],
dataSeries: h,
indexKeyword: 0,
point: { x: n, y: f },
direction: k[q].y[0] <= k[q].y[1] ? -1 : 1,
color: t,
}),
this._indexLabels.push({
chartType: "rangeSplineArea",
dataPoint: k[q],
dataSeries: h,
indexKeyword: 1,
point: { x: n, y: p },
direction: k[q].y[0] <= k[q].y[1] ? 1 : -1,
color: t,
});
f = !1;
} else
0 < q &&
!f &&
(h.connectNullData
? c.setLineDash &&
0 < u.length &&
(h.options.nullDataLineDashType ||
!k[q - 1].lineDashType) &&
((u[u.length - 1].newLineDashArray = A),
(F = h.nullDataLineDashType))
: (d(y, C), (u = []), (z = []))),
(f = !0);
d(y, C);
ia.drawMarkers(g);
}
}
r &&
(b.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(c.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
c.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
c.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
c.clearRect(m.x1, m.y1, m.width, m.height),
this._eventManager.ghostCtx.restore());
c.restore();
return {
source: b,
dest: this.plotArea.ctx,
animationCallback: M.xClipAnimation,
easingFunction: M.easing.linear,
animationBase: 0,
};
}
};
p.prototype.renderWaterfall = function (a) {
var d = a.targetCanvasCtx || this.plotArea.ctx,
b = r ? this._preRenderCtx : d;
if (!(0 >= a.dataSeriesIndexes.length)) {
var c = this._eventManager.ghostCtx,
e = null,
g = this.plotArea,
m = 0,
l,
k,
h,
s,
q = a.axisY.convertValueToPixel(
a.axisY.logarithmic ? a.axisY.viewportMinimum : 0
),
m = this.options.dataPointMinWidth
? this.dataPointMinWidth
: this.options.dataPointWidth
? this.dataPointWidth
: 1;
k = this.options.dataPointMaxWidth
? this.dataPointMaxWidth
: this.options.dataPointWidth
? this.dataPointWidth
: Math.min(
0.15 * this.width,
0.9 * (this.plotArea.width / a.plotType.totalDataSeries)
) << 0;
var n = a.axisX.dataInfo.minDiff;
isFinite(n) || (n = 0.3 * Math.abs(a.axisX.range));
n = this.options.dataPointWidth
? this.dataPointWidth
: (0.6 *
((g.width *
(a.axisX.logarithmic
? Math.log(n) / Math.log(a.axisX.range)
: Math.abs(n) / Math.abs(a.axisX.range))) /
a.plotType.totalDataSeries)) <<
0;
this.dataPointMaxWidth &&
m > k &&
(m = Math.min(
this.options.dataPointWidth ? this.dataPointWidth : Infinity,
k
));
!this.dataPointMaxWidth &&
this.dataPointMinWidth &&
k < m &&
(k = Math.max(
this.options.dataPointWidth ? this.dataPointWidth : -Infinity,
m
));
n < m && (n = m);
n > k && (n = k);
b.save();
r && this._eventManager.ghostCtx.save();
b.beginPath();
b.rect(g.x1, g.y1, g.width, g.height);
b.clip();
r &&
(this._eventManager.ghostCtx.beginPath(),
this._eventManager.ghostCtx.rect(g.x1, g.y1, g.width, g.height),
this._eventManager.ghostCtx.clip());
for (var f = 0; f < a.dataSeriesIndexes.length; f++) {
var p = a.dataSeriesIndexes[f],
u = this.data[p],
v = u.dataPoints,
e = u._colorSet[0];
u.risingColor = u.options.risingColor ? u.options.risingColor : e;
u.fallingColor = u.options.fallingColor
? u.options.fallingColor
: "#e40a0a";
var t =
"number" === typeof u.options.lineThickness
? Math.round(u.lineThickness)
: 1,
C = 1 === Math.round(t) % 2 ? -0.5 : 0;
if (0 < v.length)
for (
var x = 5 < n && u.bevelEnabled ? !0 : !1,
z = !1,
y = null,
A = null,
m = 0;
m < v.length;
m++
)
if (
(v[m].getTime ? (s = v[m].x.getTime()) : (s = v[m].x),
"number" !== typeof v[m].y)
) {
if (0 < m && !z && u.connectNullData)
var D =
u.options.nullDataLineDashType || !v[m - 1].lineDashType
? u.nullDataLineDashType
: v[m - 1].lineDashType;
z = !0;
} else {
l = a.axisX.convertValueToPixel(s);
k =
0 === u.dataPointEOs[m].cumulativeSum
? q
: a.axisY.convertValueToPixel(
u.dataPointEOs[m].cumulativeSum
);
h =
0 === u.dataPointEOs[m].cumulativeSumYStartValue
? q
: a.axisY.convertValueToPixel(
u.dataPointEOs[m].cumulativeSumYStartValue
);
l = a.axisX.reversed
? (l +
(a.plotType.totalDataSeries * n) / 2 -
(a.previousDataSeriesCount + f) * n) <<
0
: (l -
(a.plotType.totalDataSeries * n) / 2 +
(a.previousDataSeriesCount + f) * n) <<
0;
var F = a.axisX.reversed ? (l - n) << 0 : (l + n) << 0;
k > h && ((e = k), (k = h), (h = e));
a.axisY.reversed && ((e = k), (k = h), (h = e));
e = u.dataPointIds[m];
this._eventManager.objectMap[e] = {
id: e,
objectType: "dataPoint",
dataSeriesIndex: p,
dataPointIndex: m,
x1: l,
y1: k,
x2: F,
y2: h,
};
var T = v[m].color
? v[m].color
: 0 < v[m].y
? u.risingColor
: u.fallingColor;
ea(b, l, k, F, h, T, 0, T, x, x, !1, !1, u.fillOpacity);
e = N(e);
r &&
ea(
this._eventManager.ghostCtx,
l,
k,
F,
h,
e,
0,
null,
!1,
!1,
!1,
!1
);
var Y,
T = l;
Y =
("undefined" !== typeof v[m].isIntermediateSum &&
!0 === v[m].isIntermediateSum) ||
("undefined" !== typeof v[m].isCumulativeSum &&
!0 === v[m].isCumulativeSum)
? 0 < v[m].y
? k
: h
: 0 < v[m].y
? h
: k;
0 < m &&
y &&
(!z || u.connectNullData) &&
(z && b.setLineDash && b.setLineDash(R(D, t)),
b.beginPath(),
b.moveTo(y, A - C),
b.lineTo(T, Y - C),
0 < t && b.stroke(),
r &&
(c.beginPath(),
c.moveTo(y, A - C),
c.lineTo(T, Y - C),
0 < t && c.stroke()));
z = !1;
y = F;
A = 0 < v[m].y ? k : h;
T = v[m].lineDashType
? v[m].lineDashType
: u.options.lineDashType
? u.options.lineDashType
: "shortDash";
b.strokeStyle = v[m].lineColor
? v[m].lineColor
: u.options.lineColor
? u.options.lineColor
: "#9e9e9e";
b.lineWidth = t;
b.setLineDash && ((T = R(T, t)), b.setLineDash(T));
(v[m].indexLabel ||
u.indexLabel ||
v[m].indexLabelFormatter ||
u.indexLabelFormatter) &&
this._indexLabels.push({
chartType: "waterfall",
dataPoint: v[m],
dataSeries: u,
point: { x: l + (F - l) / 2, y: 0 <= v[m].y ? k : h },
direction: 0 > v[m].y === a.axisY.reversed ? 1 : -1,
bounds: {
x1: l,
y1: Math.min(k, h),
x2: F,
y2: Math.max(k, h),
},
color: e,
});
}
}
r &&
(d.drawImage(this._preRenderCanvas, 0, 0, this.width, this.height),
(b.globalCompositeOperation = "source-atop"),
a.axisX.maskCanvas &&
b.drawImage(a.axisX.maskCanvas, 0, 0, this.width, this.height),
a.axisY.maskCanvas &&
b.drawImage(a.axisY.maskCanvas, 0, 0, this.width, this.height),
this._breaksCanvasCtx &&
this._breaksCanvasCtx.drawImage(
this._preRenderCanvas,
0,
0,
this.width,
this.height
),
b.clearRect(g.x1, g.y1, g.width, g.height),
this._eventManager.ghostCtx.restore());
b.restore();
return {
source: d,
dest: this.plotArea.ctx,
animationCallback: M.fadeInAnimation,
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
};
var ja = function (a, d, b, c, e, g, m, l, k) {
if (!(0 > b)) {
"undefined" === typeof l && (l = 1);
if (!r) {
var h = Number((m % (2 * Math.PI)).toFixed(8));
Number((g % (2 * Math.PI)).toFixed(8)) === h && (m -= 1e-4);
}
a.save();
a.globalAlpha = l;
"pie" === e
? (a.beginPath(),
a.moveTo(d.x, d.y),
a.arc(d.x, d.y, b, g, m, !1),
(a.fillStyle = c),
(a.strokeStyle = "white"),
(a.lineWidth = 2),
a.closePath(),
a.fill())
: "doughnut" === e &&
(a.beginPath(),
a.arc(d.x, d.y, b, g, m, !1),
0 <= k && a.arc(d.x, d.y, k * b, m, g, !0),
a.closePath(),
(a.fillStyle = c),
(a.strokeStyle = "white"),
(a.lineWidth = 2),
a.fill());
a.globalAlpha = 1;
a.restore();
}
};
p.prototype.renderPie = function (a) {
function d() {
if (h && s) {
for (var a = 0, b = 0, c = 0, e = 0, d = 0; d < s.length; d++) {
var g = s[d],
l = h.dataPointIds[d];
f[d].id = l;
f[d].objectType = "dataPoint";
f[d].dataPointIndex = d;
f[d].dataSeriesIndex = 0;
var m = f[d],
q = { percent: null, total: null },
p = null,
q = k.getPercentAndTotal(h, g);
if (h.indexLabelFormatter || g.indexLabelFormatter)
p = {
chart: k.options,
dataSeries: h,
dataPoint: g,
total: q.total,
percent: q.percent,
};
q = g.indexLabelFormatter
? g.indexLabelFormatter(p)
: g.indexLabel
? k.replaceKeywordsWithValue(g.indexLabel, g, h, d)
: h.indexLabelFormatter
? h.indexLabelFormatter(p)
: h.indexLabel
? k.replaceKeywordsWithValue(h.indexLabel, g, h, d)
: g.label
? g.label
: "";
k._eventManager.objectMap[l] = m;
m.center = { x: x.x, y: x.y };
m.y = g.y;
m.radius = A;
m.percentInnerRadius = F;
m.indexLabelText = q;
m.indexLabelPlacement = h.indexLabelPlacement;
m.indexLabelLineColor = g.indexLabelLineColor
? g.indexLabelLineColor
: h.options.indexLabelLineColor
? h.options.indexLabelLineColor
: g.color
? g.color
: h._colorSet[d % h._colorSet.length];
m.indexLabelLineThickness = u(g.indexLabelLineThickness)
? h.indexLabelLineThickness
: g.indexLabelLineThickness;
m.indexLabelLineDashType = g.indexLabelLineDashType
? g.indexLabelLineDashType
: h.indexLabelLineDashType;
m.indexLabelFontColor = g.indexLabelFontColor
? g.indexLabelFontColor
: h.indexLabelFontColor;
m.indexLabelFontStyle = g.indexLabelFontStyle
? g.indexLabelFontStyle
: h.indexLabelFontStyle;
m.indexLabelFontWeight = g.indexLabelFontWeight
? g.indexLabelFontWeight
: h.indexLabelFontWeight;
m.indexLabelFontSize = u(g.indexLabelFontSize)
? h.indexLabelFontSize
: g.indexLabelFontSize;
m.indexLabelFontFamily = g.indexLabelFontFamily
? g.indexLabelFontFamily
: h.indexLabelFontFamily;
m.indexLabelBackgroundColor = g.indexLabelBackgroundColor
? g.indexLabelBackgroundColor
: h.options.indexLabelBackgroundColor
? h.options.indexLabelBackgroundColor
: h.indexLabelBackgroundColor;
m.indexLabelMaxWidth = g.indexLabelMaxWidth
? g.indexLabelMaxWidth
: h.indexLabelMaxWidth
? h.indexLabelMaxWidth
: 0.33 * n.width;
m.indexLabelWrap =
"undefined" !== typeof g.indexLabelWrap
? g.indexLabelWrap
: h.indexLabelWrap;
m.startAngle =
0 === d
? h.startAngle
? (h.startAngle / 180) * Math.PI
: 0
: f[d - 1].endAngle;
m.startAngle = (m.startAngle + 2 * Math.PI) % (2 * Math.PI);
m.endAngle = m.startAngle + ((2 * Math.PI) / z) * Math.abs(g.y);
g = (m.endAngle + m.startAngle) / 2;
g = (g + 2 * Math.PI) % (2 * Math.PI);
m.midAngle = g;
if (m.midAngle > Math.PI / 2 - t && m.midAngle < Math.PI / 2 + t) {
if (0 === a || f[c].midAngle > m.midAngle) c = d;
a++;
} else if (
m.midAngle > (3 * Math.PI) / 2 - t &&
m.midAngle < (3 * Math.PI) / 2 + t
) {
if (0 === b || f[e].midAngle > m.midAngle) e = d;
b++;
}
m.hemisphere =
g > Math.PI / 2 && g <= (3 * Math.PI) / 2 ? "left" : "right";
m.indexLabelTextBlock = new ka(k.plotArea.ctx, {
fontSize: m.indexLabelFontSize,
fontFamily: m.indexLabelFontFamily,
fontColor: m.indexLabelFontColor,
fontStyle: m.indexLabelFontStyle,
fontWeight: m.indexLabelFontWeight,
horizontalAlign: "left",
backgroundColor: m.indexLabelBackgroundColor,
maxWidth: m.indexLabelMaxWidth,
maxHeight: m.indexLabelWrap
? 5 * m.indexLabelFontSize
: 1.5 * m.indexLabelFontSize,
text: m.indexLabelText,
padding: 0,
textBaseline: "top",
});
m.indexLabelTextBlock.measureText();
}
l = g = 0;
q = !1;
for (d = 0; d < s.length; d++)
(m = f[(c + d) % s.length]),
1 < a &&
m.midAngle > Math.PI / 2 - t &&
m.midAngle < Math.PI / 2 + t &&
(g <= a / 2 && !q
? ((m.hemisphere = "right"), g++)
: ((m.hemisphere = "left"), (q = !0)));
q = !1;
for (d = 0; d < s.length; d++)
(m = f[(e + d) % s.length]),
1 < b &&
m.midAngle > (3 * Math.PI) / 2 - t &&
m.midAngle < (3 * Math.PI) / 2 + t &&
(l <= b / 2 && !q
? ((m.hemisphere = "left"), l++)
: ((m.hemisphere = "right"), (q = !0)));
}
}
function b(a) {
var b = k.plotArea.ctx;
b.clearRect(n.x1, n.y1, n.width, n.height);
b.fillStyle = k.backgroundColor;
b.fillRect(n.x1, n.y1, n.width, n.height);
for (b = 0; b < s.length; b++) {
var c = f[b].startAngle,
e = f[b].endAngle;
if (e > c) {
var d = 0.07 * A * Math.cos(f[b].midAngle),
g = 0.07 * A * Math.sin(f[b].midAngle),
m = !1;
if (s[b].exploded) {
if (
1e-9 < Math.abs(f[b].center.x - (x.x + d)) ||
1e-9 < Math.abs(f[b].center.y - (x.y + g))
)
(f[b].center.x = x.x + d * a),
(f[b].center.y = x.y + g * a),
(m = !0);
} else if (
0 < Math.abs(f[b].center.x - x.x) ||
0 < Math.abs(f[b].center.y - x.y)
)
(f[b].center.x = x.x + d * (1 - a)),
(f[b].center.y = x.y + g * (1 - a)),
(m = !0);
m &&
((d = {}),
(d.dataSeries = h),
(d.dataPoint = h.dataPoints[b]),
(d.index = b),
k.toolTip.highlightObjects([d]));
ja(
k.plotArea.ctx,
f[b].center,
f[b].radius,
s[b].color ? s[b].color : h._colorSet[b % h._colorSet.length],
h.type,
c,
e,
h.fillOpacity,
f[b].percentInnerRadius
);
}
}
a = k.plotArea.ctx;
a.save();
a.fillStyle = "black";
a.strokeStyle = "grey";
a.textBaseline = "middle";
a.lineJoin = "round";
for (b = b = 0; b < s.length; b++)
(c = f[b]),
c.indexLabelText &&
((c.indexLabelTextBlock.y -= c.indexLabelTextBlock.height / 2),
(e = 0),
(e =
"left" === c.hemisphere
? "inside" !== h.indexLabelPlacement
? -(c.indexLabelTextBlock.width + q)
: -c.indexLabelTextBlock.width / 2
: "inside" !== h.indexLabelPlacement
? q
: -c.indexLabelTextBlock.width / 2),
(c.indexLabelTextBlock.x += e),
c.indexLabelTextBlock.render(!0),
(c.indexLabelTextBlock.x -= e),
(c.indexLabelTextBlock.y += c.indexLabelTextBlock.height / 2),
"inside" !== c.indexLabelPlacement &&
0 < c.indexLabelLineThickness &&
((e = c.center.x + A * Math.cos(c.midAngle)),
(d = c.center.y + A * Math.sin(c.midAngle)),
(a.strokeStyle = c.indexLabelLineColor),
(a.lineWidth = c.indexLabelLineThickness),
a.setLineDash &&
a.setLineDash(
R(c.indexLabelLineDashType, c.indexLabelLineThickness)
),
a.beginPath(),
a.moveTo(e, d),
a.lineTo(c.indexLabelTextBlock.x, c.indexLabelTextBlock.y),
a.lineTo(
c.indexLabelTextBlock.x + ("left" === c.hemisphere ? -q : q),
c.indexLabelTextBlock.y
),
a.stroke()),
(a.lineJoin = "miter"));
a.save();
}
function c(a, b) {
var c = 0,
c = a.indexLabelTextBlock.y - a.indexLabelTextBlock.height / 2,
e = a.indexLabelTextBlock.y + a.indexLabelTextBlock.height / 2,
d = b.indexLabelTextBlock.y - b.indexLabelTextBlock.height / 2,
f = b.indexLabelTextBlock.y + b.indexLabelTextBlock.height / 2;
return (c =
b.indexLabelTextBlock.y > a.indexLabelTextBlock.y ? d - e : c - f);
}
function e(a) {
for (var b = null, e = 1; e < s.length; e++)
if (
((b = (a + e + f.length) % f.length),
f[b].hemisphere !== f[a].hemisphere)
) {
b = null;
break;
} else if (
f[b].indexLabelText &&
b !== a &&
(0 > c(f[b], f[a]) ||
("right" === f[a].hemisphere
? f[b].indexLabelTextBlock.y >= f[a].indexLabelTextBlock.y
: f[b].indexLabelTextBlock.y <= f[a].indexLabelTextBlock.y))
)
break;
else b = null;
return b;
}
function g(a, b, d) {
d = (d || 0) + 1;
if (1e3 < d) return 0;
b = b || 0;
var m = 0,
h = x.y - 1 * r,
l = x.y + 1 * r;
if (0 <= a && a < s.length) {
var n = f[a];
if (
(0 > b && n.indexLabelTextBlock.y < h) ||
(0 < b && n.indexLabelTextBlock.y > l)
)
return 0;
var k = 0,
q = 0,
q = (k = k = 0);
0 > b
? n.indexLabelTextBlock.y - n.indexLabelTextBlock.height / 2 > h &&
n.indexLabelTextBlock.y - n.indexLabelTextBlock.height / 2 + b <
h &&
(b = -(
h -
(n.indexLabelTextBlock.y - n.indexLabelTextBlock.height / 2 + b)
))
: n.indexLabelTextBlock.y + n.indexLabelTextBlock.height / 2 < h &&
n.indexLabelTextBlock.y + n.indexLabelTextBlock.height / 2 + b >
l &&
(b =
n.indexLabelTextBlock.y +
n.indexLabelTextBlock.height / 2 +
b -
l);
b = n.indexLabelTextBlock.y + b;
h = 0;
h =
"right" === n.hemisphere
? x.x + Math.sqrt(Math.pow(r, 2) - Math.pow(b - x.y, 2))
: x.x - Math.sqrt(Math.pow(r, 2) - Math.pow(b - x.y, 2));
q = x.x + A * Math.cos(n.midAngle);
k = x.y + A * Math.sin(n.midAngle);
k = Math.sqrt(Math.pow(h - q, 2) + Math.pow(b - k, 2));
q = Math.acos(A / r);
k = Math.acos((r * r + A * A - k * k) / (2 * A * r));
b = k < q ? b - n.indexLabelTextBlock.y : 0;
h = null;
for (l = 1; l < s.length; l++)
if (
((h = (a - l + f.length) % f.length),
f[h].hemisphere !== f[a].hemisphere)
) {
h = null;
break;
} else if (
f[h].indexLabelText &&
f[h].hemisphere === f[a].hemisphere &&
h !== a &&
(0 > c(f[h], f[a]) ||
("right" === f[a].hemisphere
? f[h].indexLabelTextBlock.y <= f[a].indexLabelTextBlock.y
: f[h].indexLabelTextBlock.y >= f[a].indexLabelTextBlock.y))
)
break;
else h = null;
q = h;
k = e(a);
l = h = 0;
0 > b
? ((l = "right" === n.hemisphere ? q : k),
(m = b),
null !== l &&
((q = -b),
(b =
n.indexLabelTextBlock.y -
n.indexLabelTextBlock.height / 2 -
(f[l].indexLabelTextBlock.y +
f[l].indexLabelTextBlock.height / 2)),
b - q < p &&
((h = -q),
(l = g(l, h, d + 1)),
+l.toFixed(C) > +h.toFixed(C) &&
(m = b > p ? -(b - p) : -(q - (l - h))))))
: 0 < b &&
((l = "right" === n.hemisphere ? k : q),
(m = b),
null !== l &&
((q = b),
(b =
f[l].indexLabelTextBlock.y -
f[l].indexLabelTextBlock.height / 2 -
(n.indexLabelTextBlock.y + n.indexLabelTextBlock.height / 2)),
b - q < p &&
((h = q),
(l = g(l, h, d + 1)),
+l.toFixed(C) < +h.toFixed(C) &&
(m = b > p ? b - p : q - (h - l)))));
m &&
((d = n.indexLabelTextBlock.y + m),
(b = 0),
(b =
"right" === n.hemisphere
? x.x + Math.sqrt(Math.pow(r, 2) - Math.pow(d - x.y, 2))
: x.x - Math.sqrt(Math.pow(r, 2) - Math.pow(d - x.y, 2))),
n.midAngle > Math.PI / 2 - t && n.midAngle < Math.PI / 2 + t
? ((h = (a - 1 + f.length) % f.length),
(h = f[h]),
(a = f[(a + 1 + f.length) % f.length]),
"left" === n.hemisphere &&
"right" === h.hemisphere &&
b > h.indexLabelTextBlock.x
? (b = h.indexLabelTextBlock.x - 15)
: "right" === n.hemisphere &&
"left" === a.hemisphere &&
b < a.indexLabelTextBlock.x &&
(b = a.indexLabelTextBlock.x + 15))
: n.midAngle > (3 * Math.PI) / 2 - t &&
n.midAngle < (3 * Math.PI) / 2 + t &&
((h = (a - 1 + f.length) % f.length),
(h = f[h]),
(a = f[(a + 1 + f.length) % f.length]),
"right" === n.hemisphere &&
"left" === h.hemisphere &&
b < h.indexLabelTextBlock.x
? (b = h.indexLabelTextBlock.x + 15)
: "left" === n.hemisphere &&
"right" === a.hemisphere &&
b > a.indexLabelTextBlock.x &&
(b = a.indexLabelTextBlock.x - 15)),
(n.indexLabelTextBlock.y = d),
(n.indexLabelTextBlock.x = b),
(n.indexLabelAngle = Math.atan2(
n.indexLabelTextBlock.y - x.y,
n.indexLabelTextBlock.x - x.x
)));
}
return m;
}
function m() {
var a = k.plotArea.ctx;
a.fillStyle = "grey";
a.strokeStyle = "grey";
a.font = "16px Arial";
a.textBaseline = "middle";
for (
var b = (a = 0), d = 0, m = !0, b = 0;
10 > b && (1 > b || 0 < d);
b++
) {
if (
h.radius ||
(!h.radius &&
"undefined" !== typeof h.innerRadius &&
null !== h.innerRadius &&
A - d <= D)
)
m = !1;
m && (A -= d);
d = 0;
if ("inside" !== h.indexLabelPlacement) {
r = A * v;
for (a = 0; a < s.length; a++) {
var l = f[a];
l.indexLabelTextBlock.x = x.x + r * Math.cos(l.midAngle);
l.indexLabelTextBlock.y = x.y + r * Math.sin(l.midAngle);
l.indexLabelAngle = l.midAngle;
l.radius = A;
l.percentInnerRadius = F;
}
for (var t, u, a = 0; a < s.length; a++) {
var l = f[a],
y = e(a);
if (null !== y) {
t = f[a];
u = f[y];
var z = 0,
z = c(t, u) - p;
if (0 > z) {
for (var E = (u = 0), H = 0; H < s.length; H++)
H !== a &&
f[H].hemisphere === l.hemisphere &&
(f[H].indexLabelTextBlock.y < l.indexLabelTextBlock.y
? u++
: E++);
u = (z / (u + E || 1)) * E;
var E = -1 * (z - u),
I = (H = 0);
"right" === l.hemisphere
? ((H = g(a, u)),
(E = -1 * (z - H)),
(I = g(y, E)),
+I.toFixed(C) < +E.toFixed(C) &&
+H.toFixed(C) <= +u.toFixed(C) &&
g(a, -(E - I)))
: ((H = g(y, u)),
(E = -1 * (z - H)),
(I = g(a, E)),
+I.toFixed(C) < +E.toFixed(C) &&
+H.toFixed(C) <= +u.toFixed(C) &&
g(y, -(E - I)));
}
}
}
} else
for (a = 0; a < s.length; a++)
(l = f[a]),
(r = "pie" === h.type ? 0.7 * A : 0.8 * A),
(y = x.x + r * Math.cos(l.midAngle)),
(u = x.y + r * Math.sin(l.midAngle)),
(l.indexLabelTextBlock.x = y),
(l.indexLabelTextBlock.y = u);
for (a = 0; a < s.length; a++)
if (
((l = f[a]),
(y = l.indexLabelTextBlock.measureText()),
0 !== y.height && 0 !== y.width)
)
(y = y = 0),
"right" === l.hemisphere
? ((y =
n.x2 -
(l.indexLabelTextBlock.x +
l.indexLabelTextBlock.width +
q)),
(y *= -1))
: (y =
n.x1 -
(l.indexLabelTextBlock.x -
l.indexLabelTextBlock.width -
q)),
0 < y &&
(!m &&
l.indexLabelText &&
((u =
"right" === l.hemisphere
? n.x2 - l.indexLabelTextBlock.x
: l.indexLabelTextBlock.x - n.x1),
0.3 * l.indexLabelTextBlock.maxWidth > u
? (l.indexLabelText = "")
: (l.indexLabelTextBlock.maxWidth = 0.85 * u),
0.3 * l.indexLabelTextBlock.maxWidth < u &&
(l.indexLabelTextBlock.x -=
"right" === l.hemisphere ? 2 : -2)),
Math.abs(
l.indexLabelTextBlock.y -
l.indexLabelTextBlock.height / 2 -
x.y
) < A ||
Math.abs(
l.indexLabelTextBlock.y +
l.indexLabelTextBlock.height / 2 -
x.y
) < A) &&
((y /= Math.abs(Math.cos(l.indexLabelAngle))),
9 < y && (y *= 0.3),
y > d && (d = y)),
(y = y = 0),
0 < l.indexLabelAngle && l.indexLabelAngle < Math.PI
? ((y =
n.y2 -
(l.indexLabelTextBlock.y +
l.indexLabelTextBlock.height / 2 +
5)),
(y *= -1))
: (y =
n.y1 -
(l.indexLabelTextBlock.y -
l.indexLabelTextBlock.height / 2 -
5)),
0 < y &&
(!m &&
l.indexLabelText &&
((u =
0 < l.indexLabelAngle && l.indexLabelAngle < Math.PI
? -1
: 1),
0 === g(a, y * u) && g(a, 2 * u)),
Math.abs(l.indexLabelTextBlock.x - x.x) < A &&
((y /= Math.abs(Math.sin(l.indexLabelAngle))),
9 < y && (y *= 0.3),
y > d && (d = y)));
var K = function (a, b, c) {
for (
var e = [], d = 0;
e.push(f[b]), b !== c;
b = (b + 1 + s.length) % s.length
);
e.sort(function (a, b) {
return a.y - b.y;
});
for (b = 0; b < e.length; b++)
if (((c = e[b]), d < 0.7 * a))
(d += c.indexLabelTextBlock.height),
(c.indexLabelTextBlock.text = ""),
(c.indexLabelText = ""),
c.indexLabelTextBlock.measureText();
else break;
};
(function () {
for (var a = -1, b = -1, d = 0, g = !1, l = 0; l < s.length; l++)
if (((g = !1), (t = f[l]), t.indexLabelText)) {
var m = e(l);
if (null !== m) {
var h = f[m];
z = 0;
z = c(t, h);
var n;
if ((n = 0 > z)) {
n = t.indexLabelTextBlock.x;
var k =
t.indexLabelTextBlock.y -
t.indexLabelTextBlock.height / 2,
w =
t.indexLabelTextBlock.y +
t.indexLabelTextBlock.height / 2,
p =
h.indexLabelTextBlock.y -
h.indexLabelTextBlock.height / 2,
u = h.indexLabelTextBlock.x + h.indexLabelTextBlock.width,
r =
h.indexLabelTextBlock.y +
h.indexLabelTextBlock.height / 2;
n =
t.indexLabelTextBlock.x + t.indexLabelTextBlock.width <
h.indexLabelTextBlock.x - q ||
n > u + q ||
k > r + q ||
w < p - q
? !1
: !0;
}
n
? (0 > a && (a = l),
m !== a && ((b = m), (d += -z)),
0 === l % Math.max(s.length / 10, 3) && (g = !0))
: (g = !0);
g &&
0 < d &&
0 <= a &&
0 <= b &&
(K(d, a, b), (b = a = -1), (d = 0));
}
}
0 < d && K(d, a, b);
})();
}
}
function l() {
k.plotArea.layoutManager.reset();
k.title &&
(k.title.dockInsidePlotArea ||
("center" === k.title.horizontalAlign &&
"center" === k.title.verticalAlign)) &&
k.title.render();
if (k.subtitles)
for (var a = 0; a < k.subtitles.length; a++) {
var b = k.subtitles[a];
(b.dockInsidePlotArea ||
("center" === b.horizontalAlign &&
"center" === b.verticalAlign)) &&
b.render();
}
k.legend &&
(k.legend.dockInsidePlotArea ||
("center" === k.legend.horizontalAlign &&
"center" === k.legend.verticalAlign)) &&
(k.legend.setLayout(), k.legend.render());
}
var k = this;
if (!(0 >= a.dataSeriesIndexes.length)) {
var h = this.data[a.dataSeriesIndexes[0]],
s = h.dataPoints,
q = 10,
n = this.plotArea,
f = h.dataPointEOs,
p = 2,
r,
v = 1.3,
t = (20 / 180) * Math.PI,
C = 6,
x = { x: (n.x2 + n.x1) / 2, y: (n.y2 + n.y1) / 2 },
z = 0;
a = !1;
for (var y = 0; y < s.length; y++)
(z += Math.abs(s[y].y)),
!a &&
"undefined" !== typeof s[y].indexLabel &&
null !== s[y].indexLabel &&
0 < s[y].indexLabel.toString().length &&
(a = !0),
!a &&
"undefined" !== typeof s[y].label &&
null !== s[y].label &&
0 < s[y].label.toString().length &&
(a = !0);
if (0 !== z) {
a =
a ||
("undefined" !== typeof h.indexLabel &&
null !== h.indexLabel &&
0 < h.indexLabel.toString().length);
var A =
"inside" !== h.indexLabelPlacement && a
? (0.75 * Math.min(n.width, n.height)) / 2
: (0.92 * Math.min(n.width, n.height)) / 2;
h.radius && (A = I(h.radius, A));
var D =
"undefined" !== typeof h.innerRadius && null !== h.innerRadius
? I(h.innerRadius, A)
: 0.7 * A;
h.radius = A;
"doughnut" === h.type && (h.innerRadius = D);
var F = Math.min(D / A, (A - 1) / A);
this.pieDoughnutClickHandler = function (a) {
k.isAnimating ||
(!u(a.dataSeries.explodeOnClick) &&
!a.dataSeries.explodeOnClick) ||
((a = a.dataPoint),
(a.exploded = a.exploded ? !1 : !0),
1 < this.dataPoints.length &&
k._animator.animate(0, 500, function (a) {
b(a);
l();
}));
};
d();
m();
m();
m();
m();
this.disableToolTip = !0;
this._animator.animate(
0,
this.animatedRender ? this.animationDuration : 0,
function (a) {
var b = k.plotArea.ctx;
b.clearRect(n.x1, n.y1, n.width, n.height);
b.fillStyle = k.backgroundColor;
b.fillRect(n.x1, n.y1, n.width, n.height);
a = f[0].startAngle + 2 * Math.PI * a;
for (b = 0; b < s.length; b++) {
var c = 0 === b ? f[b].startAngle : e,
e = c + (f[b].endAngle - f[b].startAngle),
d = !1;
e > a && ((e = a), (d = !0));
var g = s[b].color
? s[b].color
: h._colorSet[b % h._colorSet.length];
e > c &&
ja(
k.plotArea.ctx,
f[b].center,
f[b].radius,
g,
h.type,
c,
e,
h.fillOpacity,
f[b].percentInnerRadius
);
if (d) break;
}
l();
},
function () {
k.disableToolTip = !1;
k._animator.animate(0, k.animatedRender ? 500 : 0, function (a) {
b(a);
l();
});
}
);
}
}
};
var ra = function (a, d, b, c) {
"undefined" === typeof b && (b = 1);
0 >= Math.round(d.y4 - d.y1) ||
(a.save(),
(a.globalAlpha = b),
a.beginPath(),
a.moveTo(Math.round(d.x1), Math.round(d.y1)),
a.lineTo(Math.round(d.x2), Math.round(d.y2)),
a.lineTo(Math.round(d.x3), Math.round(d.y3)),
a.lineTo(Math.round(d.x4), Math.round(d.y4)),
"undefined" !== d.x5 &&
(a.lineTo(Math.round(d.x5), Math.round(d.y5)),
a.lineTo(Math.round(d.x6), Math.round(d.y6))),
a.closePath(),
(a.fillStyle = c ? c : d.color),
a.fill(),
(a.globalAplha = 1),
a.restore());
};
p.prototype.renderFunnel = function (a) {
function d() {
for (var a = 0, b = [], c = 0; c < C.length; c++) {
if ("undefined" === typeof C[c].y) return -1;
C[c].y = "number" === typeof C[c].y ? C[c].y : 0;
a += Math.abs(C[c].y);
}
if (0 === a) return -1;
for (c = b[0] = 0; c < C.length; c++)
b.push((Math.abs(C[c].y) * F) / a);
return b;
}
function b() {
var a = $,
b = V,
c = K,
e = ea,
d,
f;
d = O;
f = Z - N;
e = Math.abs(((f - d) * (b - a + (e - c))) / 2);
c = ea - K;
d = f - d;
f = c * (f - Z);
f = Math.abs(f);
f = e + f;
for (var e = [], g = 0, l = 0; l < C.length; l++) {
if ("undefined" === typeof C[l].y) return -1;
C[l].y = "number" === typeof C[l].y ? C[l].y : 0;
g += Math.abs(C[l].y);
}
if (0 === g) return -1;
for (
var m = (e[0] = 0), h = 0, n, k, b = b - a, m = !1, l = 0;
l < C.length;
l++
)
(a = (Math.abs(C[l].y) * f) / g),
m
? (n = 0 == Number(c.toFixed(3)) ? 0 : a / c)
: ((k = ba * ba * b * b - 4 * Math.abs(ba) * a),
0 > k
? ((k = c),
(m = ((b + k) * (d - h)) / 2),
(a -= m),
(n = d - h),
(h += d - h),
(n += 0 == k ? 0 : a / k),
(h += a / k),
(m = !0))
: ((n = (Math.abs(ba) * b - Math.sqrt(k)) / 2),
(k = b - (2 * n) / Math.abs(ba)),
(h += n),
h > d &&
((h -= n),
(k = c),
(m = ((b + k) * (d - h)) / 2),
(a -= m),
(n = d - h),
(h += d - h),
(n += a / k),
(h += a / k),
(m = !0)),
(b = k))),
e.push(n);
return e;
}
function c() {
if (t && C) {
for (
var a,
b,
c,
e,
d,
g,
l,
h,
m,
n,
k,
q,
s,
w,
p = [],
B = [],
x = { percent: null, total: null },
v = null,
y = 0;
y < C.length;
y++
)
(w = P[y]),
(w =
"undefined" !== typeof w.x5
? (w.y2 + w.y4) / 2
: (w.y2 + w.y3) / 2),
(w = f(w).x2 + 1),
(p[y] = L - w - S);
w = 0.5 * S;
for (var y = 0, A = C.length - 1; y < C.length || 0 <= A; y++, A--) {
b = t.reversed ? C[A] : C[y];
a = b.color
? b.color
: t.reversed
? t._colorSet[(C.length - 1 - y) % t._colorSet.length]
: t._colorSet[y % t._colorSet.length];
c = b.indexLabelPlacement || t.indexLabelPlacement || "outside";
e =
b.indexLabelBackgroundColor ||
t.indexLabelBackgroundColor ||
(r ? "transparent" : null);
d = b.indexLabelFontColor || t.indexLabelFontColor || "#979797";
g = u(b.indexLabelFontSize)
? t.indexLabelFontSize
: b.indexLabelFontSize;
l = b.indexLabelFontStyle || t.indexLabelFontStyle || "normal";
h = b.indexLabelFontFamily || t.indexLabelFontFamily || "arial";
m = b.indexLabelFontWeight || t.indexLabelFontWeight || "normal";
a = b.indexLabelLineColor || t.options.indexLabelLineColor || a;
n =
"number" === typeof b.indexLabelLineThickness
? b.indexLabelLineThickness
: "number" === typeof t.indexLabelLineThickness
? t.indexLabelLineThickness
: 2;
k = b.indexLabelLineDashType || t.indexLabelLineDashType || "solid";
q =
"undefined" !== typeof b.indexLabelWrap
? b.indexLabelWrap
: "undefined" !== typeof t.indexLabelWrap
? t.indexLabelWrap
: !0;
s = t.dataPointIds[y];
z._eventManager.objectMap[s] = {
id: s,
objectType: "dataPoint",
dataPointIndex: y,
dataSeriesIndex: 0,
funnelSection: P[t.reversed ? C.length - 1 - y : y],
};
"inside" === t.indexLabelPlacement &&
((p[y] =
y !== fa
? t.reversed
? P[y].x2 - P[y].x1
: P[y].x3 - P[y].x4
: P[y].x3 - P[y].x6),
20 > p[y] &&
((p[y] =
y !== fa
? t.reversed
? P[y].x3 - P[y].x4
: P[y].x2 - P[y].x1
: P[y].x2 - P[y].x1),
(p[y] /= 2)));
s = b.indexLabelMaxWidth
? b.indexLabelMaxWidth
: t.options.indexLabelMaxWidth
? t.indexLabelMaxWidth
: p[y];
if (s > p[y] || 0 > s) s = p[y];
B[y] = "inside" === t.indexLabelPlacement ? P[y].height : !1;
x = z.getPercentAndTotal(t, b);
if (t.indexLabelFormatter || b.indexLabelFormatter)
v = {
chart: z.options,
dataSeries: t,
dataPoint: b,
total: x.total,
percent: x.percent,
};
b = b.indexLabelFormatter
? b.indexLabelFormatter(v)
: b.indexLabel
? z.replaceKeywordsWithValue(b.indexLabel, b, t, y)
: t.indexLabelFormatter
? t.indexLabelFormatter(v)
: t.indexLabel
? z.replaceKeywordsWithValue(t.indexLabel, b, t, y)
: b.label
? b.label
: "";
0 >= n && (n = 0);
1e3 > s && 1e3 - s < w && (s += 1e3 - s);
Q.roundRect || Ea(Q);
c = new ka(Q, {
fontSize: g,
fontFamily: h,
fontColor: d,
fontStyle: l,
fontWeight: m,
horizontalAlign: c,
backgroundColor: e,
maxWidth: s,
maxHeight: !1 === B[y] ? (q ? 4.28571429 * g : 1.5 * g) : B[y],
text: b,
padding: ga,
});
c.measureText();
J.push({
textBlock: c,
id: t.reversed ? A : y,
isDirty: !1,
lineColor: a,
lineThickness: n,
lineDashType: k,
height: c.height < c.maxHeight ? c.height : c.maxHeight,
width: c.width < c.maxWidth ? c.width : c.maxWidth,
});
}
}
}
function e() {
var a,
b,
c,
e,
d,
f = [];
d = !1;
c = 0;
for (
var g,
l = L - V - S / 2,
l = t.options.indexLabelMaxWidth
? t.indexLabelMaxWidth > l
? l
: t.indexLabelMaxWidth
: l,
h = J.length - 1;
0 <= h;
h--
) {
g = C[J[h].id];
c = J[h];
e = c.textBlock;
b = (a = n(h) < P.length ? J[n(h)] : null) ? a.textBlock : null;
c = c.height;
a && e.y + c + ga > b.y && (d = !0);
c = g.indexLabelMaxWidth || l;
if (c > l || 0 > c) c = l;
f.push(c);
}
if (d)
for (h = J.length - 1; 0 <= h; h--)
(a = P[h]),
(J[h].textBlock.maxWidth = f[f.length - (h + 1)]),
J[h].textBlock.measureText(),
(J[h].textBlock.x = L - l),
(c =
J[h].textBlock.height < J[h].textBlock.maxHeight
? J[h].textBlock.height
: J[h].textBlock.maxHeight),
(d =
J[h].textBlock.width < J[h].textBlock.maxWidth
? J[h].textBlock.width
: J[h].textBlock.maxWidth),
(J[h].height = c),
(J[h].width = d),
(c =
"undefined" !== typeof a.x5
? (a.y2 + a.y4) / 2
: (a.y2 + a.y3) / 2),
(J[h].textBlock.y = c - J[h].height / 2),
t.reversed
? (J[h].textBlock.y + J[h].height > pa + D &&
(J[h].textBlock.y = pa + D - J[h].height),
J[h].textBlock.y < wa - D && (J[h].textBlock.y = wa - D))
: (J[h].textBlock.y < pa - D && (J[h].textBlock.y = pa - D),
J[h].textBlock.y + J[h].height > wa + D &&
(J[h].textBlock.y = wa + D - J[h].height));
}
function g() {
var a, b, c, e;
if ("inside" !== t.indexLabelPlacement)
for (var d = 0; d < P.length; d++)
0 == J[d].textBlock.text.length
? (J[d].isDirty = !0)
: ((a = P[d]),
(c =
"undefined" !== typeof a.x5
? (a.y2 + a.y4) / 2
: (a.y2 + a.y3) / 2),
(b = t.reversed
? "undefined" !== typeof a.x5
? c > Da
? f(c).x2 + 1
: (a.x2 + a.x3) / 2 + 1
: (a.x2 + a.x3) / 2 + 1
: "undefined" !== typeof a.x5
? c < Da
? f(c).x2 + 1
: (a.x4 + a.x3) / 2 + 1
: (a.x2 + a.x3) / 2 + 1),
(J[d].textBlock.x = b + S),
(J[d].textBlock.y = c - J[d].height / 2),
t.reversed
? (J[d].textBlock.y + J[d].height > pa + D &&
(J[d].textBlock.y = pa + D - J[d].height),
J[d].textBlock.y < wa - D && (J[d].textBlock.y = wa - D))
: (J[d].textBlock.y < pa - D && (J[d].textBlock.y = pa - D),
J[d].textBlock.y + J[d].height > wa + D &&
(J[d].textBlock.y = wa + D - J[d].height)));
else
for (d = 0; d < P.length; d++)
0 == J[d].textBlock.text.length
? (J[d].isDirty = !0)
: ((a = P[d]),
(b = a.height),
(c = J[d].height),
(e = J[d].width),
b >= c
? ((b =
d != fa
? (a.x4 + a.x3) / 2 - e / 2
: (a.x5 + a.x4) / 2 - e / 2),
(c =
d != fa
? (a.y1 + a.y3) / 2 - c / 2
: (a.y1 + a.y4) / 2 - c / 2),
(J[d].textBlock.x = b),
(J[d].textBlock.y = c))
: (J[d].isDirty = !0));
}
function m() {
function a(b, c) {
var d;
if (0 > b || b >= J.length) return 0;
var e,
f = J[b].textBlock;
if (0 > c) {
c *= -1;
e = q(b);
d = l(e, b);
if (d >= c) return (f.y -= c), c;
if (0 == b) return 0 < d && (f.y -= d), d;
d += a(e, -(c - d));
0 < d && (f.y -= d);
return d;
}
e = n(b);
d = l(b, e);
if (d >= c) return (f.y += c), c;
if (b == P.length - 1) return 0 < d && (f.y += d), d;
d += a(e, c - d);
0 < d && (f.y += d);
return d;
}
function b() {
var a,
d,
e,
f,
g = 0,
h;
f = (Z - O + 2 * D) / k;
h = k;
for (var l, m = 1; m < h; m++) {
e = m * f;
for (var s = J.length - 1; 0 <= s; s--)
!J[s].isDirty &&
J[s].textBlock.y < e &&
J[s].textBlock.y + J[s].height > e &&
((l = n(s)),
!(l >= J.length - 1) &&
J[s].textBlock.y + J[s].height + ga > J[l].textBlock.y &&
(J[s].textBlock.y =
J[s].textBlock.y + J[s].height - e > e - J[s].textBlock.y
? e + 1
: e - J[s].height - 1));
}
for (l = P.length - 1; 0 < l; l--)
if (!J[l].isDirty) {
e = q(l);
if (0 > e && ((e = 0), J[e].isDirty)) break;
if (J[l].textBlock.y < J[e].textBlock.y + J[e].height) {
d = d || l;
f = l;
for (
h = 0;
J[f].textBlock.y < J[e].textBlock.y + J[e].height + ga;
) {
a = a || J[f].textBlock.y + J[f].height;
h += J[f].height;
h += ga;
f = e;
if (0 >= f) {
f = 0;
h += J[f].height;
break;
}
e = q(f);
if (0 > e) {
f = 0;
h += J[f].height;
break;
}
}
if (f != l) {
g = J[f].textBlock.y;
a -= g;
a = h - a;
g = c(a, d, f);
break;
}
}
}
return g;
}
function c(a, b, d) {
var e = [],
f = 0,
g = 0;
for (a = Math.abs(a); d <= b; d++) e.push(P[d]);
e.sort(function (a, b) {
return a.height - b.height;
});
for (d = 0; d < e.length; d++)
if (((b = e[d]), f < a))
g++,
(f += J[b.id].height + ga),
(J[b.id].textBlock.text = ""),
(J[b.id].indexLabelText = ""),
(J[b.id].isDirty = !0),
J[b.id].textBlock.measureText();
else break;
return g;
}
for (var d, e, f, g, h, m, k = 1, s = 0; s < 2 * k; s++) {
for (
var w = J.length - 1;
0 <= w &&
!(0 <= q(w) && q(w),
(f = J[w]),
(g = f.textBlock),
(m = (h = n(w) < P.length ? J[n(w)] : null) ? h.textBlock : null),
(d = +f.height.toFixed(6)),
(e = +g.y.toFixed(6)),
!f.isDirty &&
h &&
e + d + ga > +m.y.toFixed(6) &&
((d = g.y + d + ga - m.y),
(e = a(w, -d)),
e < d && (0 < e && (d -= e), (e = a(n(w), d)), e != d)));
w--
);
b();
}
}
function l(a, b) {
return (
(b < P.length ? J[b].textBlock.y : t.reversed ? pa + D : wa + D) -
(0 > a
? t.reversed
? wa - D
: pa - D
: J[a].textBlock.y + J[a].height + ga)
);
}
function k(a, b, c) {
var d,
e,
f,
l = [],
m = D,
n = [];
-1 !== b &&
(0 <= W.indexOf(b)
? ((e = W.indexOf(b)), W.splice(e, 1))
: (W.push(b),
(W = W.sort(function (a, b) {
return a - b;
}))));
if (0 === W.length) l = ia;
else {
e =
(D *
(1 != W.length || (0 != W[0] && W[0] != P.length - 1) ? 2 : 1)) /
h();
for (var q = 0; q < P.length; q++) {
if (1 == W.length && 0 == W[0]) {
if (0 === q) {
l.push(ia[q]);
d = m;
continue;
}
} else 0 === q && (d = -1 * m);
l.push(ia[q] + d);
if (0 <= W.indexOf(q) || (q < P.length && 0 <= W.indexOf(q + 1)))
d += e;
}
}
f = (function () {
for (var a = [], b = 0; b < P.length; b++) a.push(l[b] - P[b].y1);
return a;
})();
var w = {
startTime: new Date().getTime(),
duration: c || 500,
easingFunction: function (a, b, c, d) {
return M.easing.easeOutQuart(a, b, c, d);
},
changeSection: function (a) {
for (var b, c, d = 0; d < P.length; d++)
(b = f[d]),
(c = P[d]),
(b *= a),
"undefined" === typeof n[d] && (n[d] = 0),
0 > n && (n *= -1),
(c.y1 += b - n[d]),
(c.y2 += b - n[d]),
(c.y3 += b - n[d]),
(c.y4 += b - n[d]),
c.y5 && ((c.y5 += b - n[d]), (c.y6 += b - n[d])),
(n[d] = b);
},
};
a._animator.animate(
0,
c,
function (c) {
var d = a.plotArea.ctx || a.ctx;
ja = !0;
d.clearRect(x.x1, x.y1, x.x2 - x.x1, x.y2 - x.y1);
d.fillStyle = a.backgroundColor;
d.fillRect(x.x1, x.y1, x.width, x.height);
w.changeSection(c, b);
var e = {};
e.dataSeries = t;
e.dataPoint = t.reversed
? t.dataPoints[C.length - 1 - b]
: t.dataPoints[b];
e.index = t.reversed ? C.length - 1 - b : b;
a.toolTip.highlightObjects([e]);
for (e = 0; e < P.length; e++) ra(d, P[e], t.fillOpacity);
v(d);
H && ("inside" !== t.indexLabelPlacement ? s(d) : g(), p(d));
1 <= c && (ja = !1);
},
null,
M.easing.easeOutQuart
);
}
function h() {
for (var a = 0, b = 0; b < P.length - 1; b++)
(0 <= W.indexOf(b) || 0 <= W.indexOf(b + 1)) && a++;
return a;
}
function s(a) {
for (var b, c, d, e, g = 0; g < P.length; g++)
(e = 1 === J[g].lineThickness % 2 ? 0.5 : 0),
(c = (((P[g].y2 + P[g].y4) / 2) << 0) + e),
(b = f(c).x2 - 1),
(d = J[g].textBlock.x),
(e = ((J[g].textBlock.y + J[g].height / 2) << 0) + e),
J[g].isDirty ||
0 == J[g].lineThickness ||
((a.strokeStyle = J[g].lineColor),
(a.lineWidth = J[g].lineThickness),
a.setLineDash &&
a.setLineDash(R(J[g].lineDashType, J[g].lineThickness)),
a.beginPath(),
a.moveTo(b, c),
a.lineTo(d, e),
a.stroke());
}
function q(a) {
for (a -= 1; -1 <= a && -1 != a && J[a].isDirty; a--);
return a;
}
function n(a) {
for (a += 1; a <= P.length && a != P.length && J[a].isDirty; a++);
return a;
}
function f(a) {
for (var b, c = 0; c < C.length; c++)
if (P[c].y1 < a && P[c].y4 > a) {
b = P[c];
break;
}
return b
? ((a = b.y6
? a > b.y6
? b.x3 + ((b.x4 - b.x3) / (b.y4 - b.y3)) * (a - b.y3)
: b.x2 + ((b.x3 - b.x2) / (b.y3 - b.y2)) * (a - b.y2)
: b.x2 + ((b.x3 - b.x2) / (b.y3 - b.y2)) * (a - b.y2)),
{ x1: a, x2: a })
: -1;
}
function p(a) {
for (var b = 0; b < P.length; b++)
J[b].isDirty ||
(a && (J[b].textBlock.ctx = a), J[b].textBlock.render(!0));
}
function v(a) {
z.plotArea.layoutManager.reset();
a.roundRect || Ea(a);
z.title &&
(z.title.dockInsidePlotArea ||
("center" === z.title.horizontalAlign &&
"center" === z.title.verticalAlign)) &&
((z.title.ctx = a), z.title.render());
if (z.subtitles)
for (var b = 0; b < z.subtitles.length; b++) {
var c = z.subtitles[b];
if (
c.dockInsidePlotArea ||
("center" === c.horizontalAlign && "center" === c.verticalAlign)
)
(z.subtitles.ctx = a), c.render();
}
z.legend &&
(z.legend.dockInsidePlotArea ||
("center" === z.legend.horizontalAlign &&
"center" === z.legend.verticalAlign)) &&
((z.legend.ctx = a), z.legend.setLayout(), z.legend.render());
U.fNg && U.fNg(z);
}
var z = this;
if (!(0 >= a.dataSeriesIndexes.length)) {
for (
var t = this.data[a.dataSeriesIndexes[0]],
C = t.dataPoints,
x = this.plotArea,
D = 0.025 * x.width,
y = 0.01 * x.width,
A = 0,
F = x.height - 2 * D,
E = Math.min(x.width - 2 * y, 2.8 * x.height),
H = !1,
I = 0;
I < C.length;
I++
)
if (
(!H &&
"undefined" !== typeof C[I].indexLabel &&
null !== C[I].indexLabel &&
0 < C[I].indexLabel.toString().length &&
(H = !0),
!H &&
"undefined" !== typeof C[I].label &&
null !== C[I].label &&
0 < C[I].label.toString().length &&
(H = !0),
(!H && "function" === typeof t.indexLabelFormatter) ||
"function" === typeof C[I].indexLabelFormatter)
)
H = !0;
H =
H ||
("undefined" !== typeof t.indexLabel &&
null !== t.indexLabel &&
0 < t.indexLabel.toString().length);
("inside" !== t.indexLabelPlacement && H) ||
(y = (x.width - 0.75 * E) / 2);
var I = x.x1 + y,
L = x.x2 - y,
O = x.y1 + D,
Z = x.y2 - D,
Q = a.targetCanvasCtx || this.plotArea.ctx || this.ctx;
if (0 != t.length && t.dataPoints && t.visible && 0 !== C.length) {
var N, G;
a = (75 * E) / 100;
var S = (30 * (L - a)) / 100;
"funnel" === t.type
? ((N = u(t.options.neckHeight) ? 0.35 * F : t.neckHeight),
(G = u(t.options.neckWidth) ? 0.25 * a : t.neckWidth),
"string" === typeof N && N.match(/%$/)
? ((N = parseInt(N)), (N = (N * F) / 100))
: (N = parseInt(N)),
"string" === typeof G && G.match(/%$/)
? ((G = parseInt(G)), (G = (G * a) / 100))
: (G = parseInt(G)),
N > F ? (N = F) : 0 >= N && (N = 0),
G > a ? (G = a - 0.5) : 0 >= G && (G = 0))
: "pyramid" === t.type &&
((G = N = 0), (t.reversed = t.reversed ? !1 : !0));
var y = I + a / 2,
$ = I,
V = I + a,
pa = t.reversed ? Z : O,
K = y - G / 2,
ea = y + G / 2,
Da = t.reversed ? O + N : Z - N,
wa = t.reversed ? O : Z;
a = [];
var y = [],
P = [],
E = [],
X = O,
fa,
ba = (Da - pa) / (K - $),
ha = -ba,
I =
"area" === (t.valueRepresents ? t.valueRepresents : "height")
? b()
: d();
if (-1 !== I) {
if (t.reversed)
for (E.push(X), G = I.length - 1; 0 < G; G--)
(X += I[G]), E.push(X);
else for (G = 0; G < I.length; G++) (X += I[G]), E.push(X);
if (t.reversed)
for (G = 0; G < I.length; G++)
E[G] < Da
? (a.push(K), y.push(ea), (fa = G))
: (a.push((E[G] - pa + ba * $) / ba),
y.push((E[G] - pa + ha * V) / ha));
else
for (G = 0; G < I.length; G++)
E[G] < Da
? (a.push((E[G] - pa + ba * $) / ba),
y.push((E[G] - pa + ha * V) / ha),
(fa = G))
: (a.push(K), y.push(ea));
for (G = 0; G < I.length - 1; G++)
(X = t.reversed
? C[C.length - 1 - G].color
? C[C.length - 1 - G].color
: t._colorSet[(C.length - 1 - G) % t._colorSet.length]
: C[G].color
? C[G].color
: t._colorSet[G % t._colorSet.length]),
G === fa
? P.push({
x1: a[G],
y1: E[G],
x2: y[G],
y2: E[G],
x3: ea,
y3: Da,
x4: y[G + 1],
y4: E[G + 1],
x5: a[G + 1],
y5: E[G + 1],
x6: K,
y6: Da,
id: G,
height: E[G + 1] - E[G],
color: X,
})
: P.push({
x1: a[G],
y1: E[G],
x2: y[G],
y2: E[G],
x3: y[G + 1],
y3: E[G + 1],
x4: a[G + 1],
y4: E[G + 1],
id: G,
height: E[G + 1] - E[G],
color: X,
});
var ga = 2,
J = [],
ja = !1,
W = [],
ia = [],
I = !1;
a = a = 0;
Fa(W);
for (G = 0; G < C.length; G++)
C[G].exploded &&
((I = !0), t.reversed ? W.push(C.length - 1 - G) : W.push(G));
Q.clearRect(x.x1, x.y1, x.width, x.height);
Q.fillStyle = z.backgroundColor;
Q.fillRect(x.x1, x.y1, x.width, x.height);
if (
H &&
t.visible &&
(c(), g(), e(), "inside" !== t.indexLabelPlacement)
) {
m();
for (G = 0; G < C.length; G++)
J[G].isDirty ||
((a = J[G].textBlock.x + J[G].width),
(a = (L - a) / 2),
0 == G && (A = a),
A > a && (A = a));
for (G = 0; G < P.length; G++)
(P[G].x1 += A),
(P[G].x2 += A),
(P[G].x3 += A),
(P[G].x4 += A),
P[G].x5 && ((P[G].x5 += A), (P[G].x6 += A)),
(J[G].textBlock.x += A);
}
for (G = 0; G < P.length; G++)
(A = P[G]), ra(Q, A, t.fillOpacity), ia.push(A.y1);
v(Q);
H &&
t.visible &&
("inside" === t.indexLabelPlacement || z.animationEnabled || s(Q),
z.animationEnabled || p());
if (!H)
for (G = 0; G < C.length; G++)
(A = t.dataPointIds[G]),
(a = {
id: A,
objectType: "dataPoint",
dataPointIndex: G,
dataSeriesIndex: 0,
funnelSection: P[t.reversed ? C.length - 1 - G : G],
}),
(z._eventManager.objectMap[A] = a);
!z.animationEnabled && I
? k(z, -1, 0)
: z.animationEnabled && !z.animatedRender && k(z, -1, 0);
this.funnelPyramidClickHandler = function (a) {
var b = -1;
if (
!ja &&
!z.isAnimating &&
(u(a.dataSeries.explodeOnClick) ||
a.dataSeries.explodeOnClick) &&
((b = t.reversed
? C.length - 1 - a.dataPointIndex
: a.dataPointIndex),
0 <= b)
) {
a = b;
if ("funnel" === t.type || "pyramid" === t.type)
t.reversed
? (C[C.length - 1 - a].exploded = C[C.length - 1 - a]
.exploded
? !1
: !0)
: (C[a].exploded = C[a].exploded ? !1 : !0);
k(z, b, 500);
}
};
return {
source: Q,
dest: this.plotArea.ctx,
animationCallback: function (a, b) {
M.fadeInAnimation(a, b);
1 <= a && (k(z, -1, 500), v(z.plotArea.ctx || z.ctx));
},
easingFunction: M.easing.easeInQuad,
animationBase: 0,
};
}
}
}
};
p.prototype.requestAnimFrame = (function () {
return (
window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.oRequestAnimationFrame ||
window.msRequestAnimationFrame ||
function (a) {
window.setTimeout(a, 1e3 / 60);
}
);
})();
p.prototype.cancelRequestAnimFrame =
window.cancelAnimationFrame ||
window.webkitCancelRequestAnimationFrame ||
window.mozCancelRequestAnimationFrame ||
window.oCancelRequestAnimationFrame ||
window.msCancelRequestAnimationFrame ||
clearTimeout;
p.prototype.set = function (a, d, b) {
b = "undefined" === typeof b ? !0 : b;
"options" === a
? ((this.options = d), b && this.render())
: p.base.set.call(this, a, d, b);
};
p.prototype.exportChart = function (a) {
a = "undefined" === typeof a ? {} : a;
var d = a.format ? a.format : "png",
b = a.fileName ? a.fileName : this.exportFileName;
if (a.toDataURL) return this.canvas.toDataURL("image/" + d);
Ta(this.canvas, d, b);
};
p.prototype.print = function () {
var a = this.exportChart({ toDataURL: !0 }),
d = document.createElement("iframe");
d.setAttribute("class", "canvasjs-chart-print-frame");
d.setAttribute(
"style",
"position:absolute; width:100%; border: 0px; margin: 0px 0px 0px 0px; padding 0px 0px 0px 0px;"
);
d.style.height = this.height + "px";
this._canvasJSContainer.appendChild(d);
var b = this,
c = d.contentWindow || d.contentDocument.document || d.contentDocument;
c.document.open();
c.document.write(
'<!DOCTYPE HTML>\n<html><body style="margin: 0px 0px 0px 0px; padding: 0px 0px 0px 0px;"><img src="' +
a +
'"/><body/></html>'
);
c.document.close();
setTimeout(function () {
c.focus();
c.print();
setTimeout(function () {
b._canvasJSContainer.removeChild(d);
}, 1e3);
}, 500);
};
p.prototype.getPercentAndTotal = function (a, d) {
var b = null,
c = null,
e = null;
if (0 <= a.type.indexOf("stacked"))
(c = 0),
(b = d.x.getTime ? d.x.getTime() : d.x),
b in a.plotUnit.yTotals &&
((c = a.plotUnit.yTotals[b]),
(e = isNaN(d.y) ? 0 : 100 * (d.y / c)));
else if (
"pie" === a.type ||
"doughnut" === a.type ||
"funnel" === a.type ||
"pyramid" === a.type
) {
for (b = c = 0; b < a.dataPoints.length; b++)
isNaN(a.dataPoints[b].y) || (c += a.dataPoints[b].y);
e = isNaN(d.y) ? 0 : 100 * (d.y / c);
}
return { percent: e, total: c };
};
p.prototype.replaceKeywordsWithValue = function (a, d, b, c, e) {
var g = this;
e = "undefined" === typeof e ? 0 : e;
if (
(0 <= b.type.indexOf("stacked") ||
"pie" === b.type ||
"doughnut" === b.type ||
"funnel" === b.type ||
"pyramid" === b.type) &&
(0 <= a.indexOf("#percent") || 0 <= a.indexOf("#total"))
) {
var m = "#percent",
l = "#total",
k = this.getPercentAndTotal(b, d),
l = isNaN(k.total) ? l : k.total,
m = isNaN(k.percent) ? m : k.percent;
do {
k = "";
if (b.percentFormatString) k = b.percentFormatString;
else {
var k = "#,##0.",
h = Math.max(Math.ceil(Math.log(1 / Math.abs(m)) / Math.LN10), 2);
if (isNaN(h) || !isFinite(h)) h = 2;
for (var s = 0; s < h; s++) k += "#";
b.percentFormatString = k;
}
a = a.replace("#percent", ba(m, k, g._cultureInfo));
a = a.replace(
"#total",
ba(
l,
b.yValueFormatString ? b.yValueFormatString : "#,##0.########",
g._cultureInfo
)
);
} while (0 <= a.indexOf("#percent") || 0 <= a.indexOf("#total"));
}
return a.replace(/\{.*?\}|"[^"]*"|'[^']*'/g, function (a) {
if (
('"' === a[0] && '"' === a[a.length - 1]) ||
("'" === a[0] && "'" === a[a.length - 1])
)
return a.slice(1, a.length - 1);
a = Ia(a.slice(1, a.length - 1));
a = a.replace("#index", e);
var h = null;
try {
var f = a.match(/(.*?)\s*\[\s*(.*?)\s*\]/);
f && 0 < f.length && ((h = Ia(f[2])), (a = Ia(f[1])));
} catch (l) {}
f = null;
if ("color" === a)
return "waterfall" === b.type
? d.color
? d.color
: 0 < d.y
? b.risingColor
: b.fallingColor
: "error" === b.type
? b.color
? b.color
: b._colorSet[h % b._colorSet.length]
: d.color
? d.color
: b.color
? b.color
: b._colorSet[c % b._colorSet.length];
if (d.hasOwnProperty(a)) f = d;
else if (b.hasOwnProperty(a)) f = b;
else return "";
f = f[a];
null !== h && (f = f[h]);
if ("x" === a)
if (
"dateTime" === b.axisX.valueType ||
"dateTime" === b.xValueType ||
(d.x && d.x.getTime)
) {
if (
g.plotInfo.plotTypes[0].plotUnits[0].axisX &&
!g.plotInfo.plotTypes[0].plotUnits[0].axisX.logarithmic
)
return Ca(
f,
d.xValueFormatString
? d.xValueFormatString
: b.xValueFormatString
? b.xValueFormatString
: (b.xValueFormatString =
g.axisX && g.axisX.autoValueFormatString
? g.axisX.autoValueFormatString
: "DD MMM YY"),
g._cultureInfo
);
} else
return ba(
f,
d.xValueFormatString
? d.xValueFormatString
: b.xValueFormatString
? b.xValueFormatString
: (b.xValueFormatString = "#,##0.########"),
g._cultureInfo
);
else
return "y" === a
? ba(
f,
d.yValueFormatString
? d.yValueFormatString
: b.yValueFormatString
? b.yValueFormatString
: (b.yValueFormatString = "#,##0.########"),
g._cultureInfo
)
: "z" === a
? ba(
f,
d.zValueFormatString
? d.zValueFormatString
: b.zValueFormatString
? b.zValueFormatString
: (b.zValueFormatString = "#,##0.########"),
g._cultureInfo
)
: f;
});
};
qa(H, V);
H.prototype.setLayout = function () {
var a = this.dockInsidePlotArea ? this.chart.plotArea : this.chart,
d = a.layoutManager.getFreeSpace(),
b = null,
c = 0,
e = 0,
g = 0,
m = 0,
l = (this.markerMargin =
this.chart.options.legend &&
!u(this.chart.options.legend.markerMargin)
? this.chart.options.legend.markerMargin
: 0.3 * this.fontSize);
this.height = 0;
var k = [],
h = [];
"top" === this.verticalAlign || "bottom" === this.verticalAlign
? ((this.orientation = "horizontal"),
(b = this.verticalAlign),
(g = this.maxWidth =
null !== this.maxWidth ? this.maxWidth : d.width),
(m = this.maxHeight =
null !== this.maxHeight ? this.maxHeight : 0.5 * d.height))
: "center" === this.verticalAlign &&
((this.orientation = "vertical"),
(b = this.horizontalAlign),
(g = this.maxWidth =
null !== this.maxWidth ? this.maxWidth : 0.5 * d.width),
(m = this.maxHeight =
null !== this.maxHeight ? this.maxHeight : d.height));
this.errorMarkerColor = [];
for (var s = 0; s < this.dataSeries.length; s++) {
var q = this.dataSeries[s];
if (q.dataPoints && q.dataPoints.length)
if (
"pie" !== q.type &&
"doughnut" !== q.type &&
"funnel" !== q.type &&
"pyramid" !== q.type
) {
var n = (q.legendMarkerType = q.legendMarkerType
? q.legendMarkerType
: ("line" !== q.type &&
"stepLine" !== q.type &&
"spline" !== q.type &&
"scatter" !== q.type &&
"bubble" !== q.type) ||
!q.markerType
? "error" === q.type && q._linkedSeries
? q._linkedSeries.legendMarkerType
? q._linkedSeries.legendMarkerType
: F.getDefaultLegendMarker(q._linkedSeries.type)
: F.getDefaultLegendMarker(q.type)
: q.markerType),
f = q.legendText
? q.legendText
: this.itemTextFormatter
? this.itemTextFormatter({
chart: this.chart,
legend: this.options,
dataSeries: q,
dataPoint: null,
})
: q.name,
p = (q.legendMarkerColor = q.legendMarkerColor
? q.legendMarkerColor
: q.markerColor
? q.markerColor
: "error" === q.type
? u(q.whiskerColor)
? q._colorSet[0]
: q.whiskerColor
: q._colorSet[0]),
r =
q.markerSize ||
("line" !== q.type &&
"stepLine" !== q.type &&
"spline" !== q.type)
? 0.75 * this.lineHeight
: 0,
v = q.legendMarkerBorderColor
? q.legendMarkerBorderColor
: q.markerBorderColor,
t = q.legendMarkerBorderThickness
? q.legendMarkerBorderThickness
: q.markerBorderThickness
? Math.max(1, Math.round(0.2 * r))
: 0;
"error" === q.type && this.errorMarkerColor.push(p);
f = this.chart.replaceKeywordsWithValue(f, q.dataPoints[0], q, s);
n = {
markerType: n,
markerColor: p,
text: f,
textBlock: null,
chartType: q.type,
markerSize: r,
lineColor: q._colorSet[0],
dataSeriesIndex: q.index,
dataPointIndex: null,
markerBorderColor: v,
markerBorderThickness: t,
};
k.push(n);
} else
for (var z = 0; z < q.dataPoints.length; z++) {
var x = q.dataPoints[z],
n = x.legendMarkerType
? x.legendMarkerType
: q.legendMarkerType
? q.legendMarkerType
: F.getDefaultLegendMarker(q.type),
f = x.legendText
? x.legendText
: q.legendText
? q.legendText
: this.itemTextFormatter
? this.itemTextFormatter({
chart: this.chart,
legend: this.options,
dataSeries: q,
dataPoint: x,
})
: x.name
? x.name
: "DataPoint: " + (z + 1),
p = x.legendMarkerColor
? x.legendMarkerColor
: q.legendMarkerColor
? q.legendMarkerColor
: x.color
? x.color
: q.color
? q.color
: q._colorSet[z % q._colorSet.length],
r = 0.75 * this.lineHeight,
v = x.legendMarkerBorderColor
? x.legendMarkerBorderColor
: q.legendMarkerBorderColor
? q.legendMarkerBorderColor
: x.markerBorderColor
? x.markerBorderColor
: q.markerBorderColor,
t = x.legendMarkerBorderThickness
? x.legendMarkerBorderThickness
: q.legendMarkerBorderThickness
? q.legendMarkerBorderThickness
: x.markerBorderThickness || q.markerBorderThickness
? Math.max(1, Math.round(0.2 * r))
: 0,
f = this.chart.replaceKeywordsWithValue(f, x, q, z),
n = {
markerType: n,
markerColor: p,
text: f,
textBlock: null,
chartType: q.type,
markerSize: r,
dataSeriesIndex: s,
dataPointIndex: z,
markerBorderColor: v,
markerBorderThickness: t,
};
(x.showInLegend || (q.showInLegend && !1 !== x.showInLegend)) &&
k.push(n);
}
}
!0 === this.reversed && k.reverse();
if (0 < k.length) {
q = null;
p = f = x = z = 0;
x =
null !== this.itemWidth
? null !== this.itemMaxWidth
? Math.min(this.itemWidth, this.itemMaxWidth, g)
: (this.itemMaxWidth = Math.min(this.itemWidth, g))
: null !== this.itemMaxWidth
? Math.min(this.itemMaxWidth, g)
: (this.itemMaxWidth = g);
r = 0 === r ? 0.75 * this.lineHeight : r;
x -= r + l;
for (s = 0; s < k.length; s++) {
n = k[s];
v = x;
if (
"line" === n.chartType ||
"spline" === n.chartType ||
"stepLine" === n.chartType
)
v -= 2 * 0.1 * this.lineHeight;
if (
!(
0 >= m ||
"undefined" === typeof m ||
0 >= v ||
"undefined" === typeof v
)
) {
if ("horizontal" === this.orientation) {
n.textBlock = new ka(this.ctx, {
x: 0,
y: 0,
maxWidth: v,
maxHeight: this.itemWrap ? m : 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: "middle",
});
n.textBlock.measureText();
null !== this.itemWidth &&
(n.textBlock.width =
this.itemWidth -
(r +
l +
("line" === n.chartType ||
"spline" === n.chartType ||
"stepLine" === n.chartType
? 2 * 0.1 * this.lineHeight
: 0)));
if (
!q ||
q.width +
Math.round(
n.textBlock.width +
r +
l +
(0 === q.width ? 0 : this.horizontalSpacing) +
("line" === n.chartType ||
"spline" === n.chartType ||
"stepLine" === n.chartType
? 2 * 0.1 * this.lineHeight
: 0)
) >
g
)
(q = { items: [], width: 0 }),
h.push(q),
(this.height += f),
(f = 0);
f = Math.max(f, n.textBlock.height);
} else
(n.textBlock = new ka(this.ctx, {
x: 0,
y: 0,
maxWidth: x,
maxHeight: !0 === this.itemWrap ? m : 1.5 * this.fontSize,
angle: 0,
text: n.text,
horizontalAlign: "left",
fontSize: this.fontSize,
fontFamily: this.fontFamily,
fontWeight: this.fontWeight,
fontColor: this.fontColor,
fontStyle: this.fontStyle,
textBaseline: "middle",
})),
n.textBlock.measureText(),
null !== this.itemWidth &&
(n.textBlock.width =
this.itemWidth -
(r +
l +
("line" === n.chartType ||
"spline" === n.chartType ||
"stepLine" === n.chartType
? 2 * 0.1 * this.lineHeight
: 0))),
this.height < m - this.lineHeight
? ((q = { items: [], width: 0 }), h.push(q))
: ((q = h[z]), (z = (z + 1) % h.length)),
(this.height += n.textBlock.height);
n.textBlock.x = q.width;
n.textBlock.y = 0;
q.width += Math.round(
n.textBlock.width +
r +
l +
(0 === q.width ? 0 : this.horizontalSpacing) +
("line" === n.chartType ||
"spline" === n.chartType ||
"stepLine" === n.chartType
? 2 * 0.1 * this.lineHeight
: 0)
);
q.items.push(n);
this.width = Math.max(q.width, this.width);
p =
n.textBlock.width +
(r +
l +
("line" === n.chartType ||
"spline" === n.chartType ||
"stepLine" === n.chartType
? 2 * 0.1 * this.lineHeight
: 0));
}
}
this.itemWidth = p;
this.height =
!1 === this.itemWrap ? h.length * this.lineHeight : this.height + f;
this.height = Math.min(m, this.height);
this.width = Math.min(g, this.width);
}
"top" === this.verticalAlign
? ((e =
"left" === this.horizontalAlign
? d.x1
: "right" === this.horizontalAlign
? d.x2 - this.width
: d.x1 + d.width / 2 - this.width / 2),
(c = d.y1))
: "center" === this.verticalAlign
? ((e =
"left" === this.horizontalAlign
? d.x1
: "right" === this.horizontalAlign
? d.x2 - this.width
: d.x1 + d.width / 2 - this.width / 2),
(c = d.y1 + d.height / 2 - this.height / 2))
: "bottom" === this.verticalAlign &&
((e =
"left" === this.horizontalAlign
? d.x1
: "right" === this.horizontalAlign
? d.x2 - this.width
: d.x1 + d.width / 2 - this.width / 2),
(c = d.y2 - this.height));
this.items = k;
for (s = 0; s < this.items.length; s++)
(n = k[s]),
(n.id = ++this.chart._eventManager.lastObjectId),
(this.chart._eventManager.objectMap[n.id] = {
id: n.id,
objectType: "legendItem",
legendItemIndex: s,
dataSeriesIndex: n.dataSeriesIndex,
dataPointIndex: n.dataPointIndex,
});
this.markerSize = r;
this.rows = h;
0 < k.length &&
a.layoutManager.registerSpace(b, {
width: this.width + 2 + 2,
height: this.height + 5 + 5,
});
this.bounds = { x1: e, y1: c, x2: e + this.width, y2: c + this.height };
};
H.prototype.render = function () {
var a = this.bounds.x1,
d = this.bounds.y1,
b = this.markerMargin,
c = this.maxWidth,
e = this.maxHeight,
g = this.markerSize,
m = this.rows;
((0 < this.borderThickness && this.borderColor) ||
this.backgroundColor) &&
this.ctx.roundRect(
a,
d,
this.width,
this.height,
this.cornerRadius,
this.borderThickness,
this.backgroundColor,
this.borderColor
);
for (var l = 0, k = 0; k < m.length; k++) {
for (var h = m[k], s = 0, q = 0; q < h.items.length; q++) {
var n = h.items[q],
f =
n.textBlock.x + a + (0 === q ? 0.2 * g : this.horizontalSpacing),
p = d + l,
u = f;
this.chart.data[n.dataSeriesIndex].visible ||
(this.ctx.globalAlpha = 0.5);
this.ctx.save();
this.ctx.beginPath();
this.ctx.rect(a, d, c, Math.max(e - (e % this.lineHeight), 0));
this.ctx.clip();
if (
"line" === n.chartType ||
"stepLine" === n.chartType ||
"spline" === n.chartType
)
(this.ctx.strokeStyle = n.lineColor),
(this.ctx.lineWidth = Math.ceil(this.lineHeight / 8)),
this.ctx.beginPath(),
this.ctx.moveTo(
f - 0.1 * this.lineHeight,
p + this.lineHeight / 2
),
this.ctx.lineTo(
f + 0.85 * this.lineHeight,
p + this.lineHeight / 2
),
this.ctx.stroke(),
(u -= 0.1 * this.lineHeight);
if ("error" === n.chartType) {
this.ctx.strokeStyle = this.errorMarkerColor[0];
this.ctx.lineWidth = g / 8;
this.ctx.beginPath();
var r = f - 0.08 * this.lineHeight + 0.1 * this.lineHeight,
t = p + 0.15 * this.lineHeight,
v = 0.7 * this.lineHeight,
x = v + 0.02 * this.lineHeight;
this.ctx.moveTo(r, t);
this.ctx.lineTo(r + v, t);
this.ctx.stroke();
this.ctx.beginPath();
this.ctx.moveTo(r + v / 2, t);
this.ctx.lineTo(r + v / 2, t + x);
this.ctx.stroke();
this.ctx.beginPath();
this.ctx.moveTo(r, t + x);
this.ctx.lineTo(r + v, t + x);
this.ctx.stroke();
this.errorMarkerColor.shift();
}
ia.drawMarker(
f + g / 2,
p + this.lineHeight / 2,
this.ctx,
n.markerType,
"error" === n.chartType ||
"line" === n.chartType ||
"spline" === n.chartType
? n.markerSize / 2
: n.markerSize,
n.markerColor,
n.markerBorderColor,
n.markerBorderThickness
);
n.textBlock.x = f + b + g;
if (
"line" === n.chartType ||
"stepLine" === n.chartType ||
"spline" === n.chartType
)
n.textBlock.x += 0.1 * this.lineHeight;
n.textBlock.y = Math.round(p + this.lineHeight / 2);
n.textBlock.render(!0);
this.ctx.restore();
s = 0 < q ? Math.max(s, n.textBlock.height) : n.textBlock.height;
this.chart.data[n.dataSeriesIndex].visible ||
(this.ctx.globalAlpha = 1);
f = N(n.id);
this.ghostCtx.fillStyle = f;
this.ghostCtx.beginPath();
this.ghostCtx.fillRect(
u,
n.textBlock.y - this.lineHeight / 2,
n.textBlock.x + n.textBlock.width - u,
n.textBlock.height
);
n.x1 = this.chart._eventManager.objectMap[n.id].x1 = u;
n.y1 = this.chart._eventManager.objectMap[n.id].y1 =
n.textBlock.y - this.lineHeight / 2;
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 - this.lineHeight / 2;
}
l += s;
}
};
qa(F, V);
F.prototype.getDefaultAxisPlacement = function () {
var a = this.type;
if (
"column" === a ||
"line" === a ||
"stepLine" === a ||
"spline" === a ||
"area" === a ||
"stepArea" === a ||
"splineArea" === a ||
"stackedColumn" === a ||
"stackedLine" === a ||
"bubble" === a ||
"scatter" === a ||
"stackedArea" === a ||
"stackedColumn100" === a ||
"stackedLine100" === a ||
"stackedArea100" === a ||
"candlestick" === a ||
"ohlc" === a ||
"rangeColumn" === a ||
"rangeArea" === a ||
"rangeSplineArea" === a ||
"boxAndWhisker" === a ||
"waterfall" === a
)
return "normal";
if (
"bar" === a ||
"stackedBar" === a ||
"stackedBar100" === a ||
"rangeBar" === a
)
return "xySwapped";
if ("pie" === a || "doughnut" === a || "funnel" === a || "pyramid" === a)
return "none";
"error" !== a && window.console.log("Unknown Chart Type: " + a);
return null;
};
F.getDefaultLegendMarker = function (a) {
if (
"column" === a ||
"stackedColumn" === a ||
"stackedLine" === a ||
"bar" === a ||
"stackedBar" === a ||
"stackedBar100" === a ||
"bubble" === a ||
"scatter" === a ||
"stackedColumn100" === a ||
"stackedLine100" === a ||
"stepArea" === a ||
"candlestick" === a ||
"ohlc" === a ||
"rangeColumn" === a ||
"rangeBar" === a ||
"rangeArea" === a ||
"rangeSplineArea" === a ||
"boxAndWhisker" === a ||
"waterfall" === a
)
return "square";
if (
"line" === a ||
"stepLine" === a ||
"spline" === a ||
"pie" === a ||
"doughnut" === a
)
return "circle";
if (
"area" === a ||
"splineArea" === a ||
"stackedArea" === a ||
"stackedArea100" === a ||
"funnel" === a ||
"pyramid" === a
)
return "triangle";
if ("error" === a) return "none";
window.console.log("Unknown Chart Type: " + a);
return null;
};
F.prototype.getDataPointAtX = function (a, d) {
if (!this.dataPoints || 0 === this.dataPoints.length) return null;
var b = { dataPoint: null, distance: Infinity, index: NaN },
c = null,
e = 0,
g = 0,
m = 1,
l = Infinity,
k = 0,
h = 0,
s = 0;
"none" !== this.chart.plotInfo.axisPlacement &&
(this.axisX.logarithmic
? ((s = Math.log(
this.dataPoints[this.dataPoints.length - 1].x /
this.dataPoints[0].x
)),
(s =
1 < s
? Math.min(
Math.max(
(((this.dataPoints.length - 1) / s) *
Math.log(a / this.dataPoints[0].x)) >>
0,
0
),
this.dataPoints.length
)
: 0))
: ((s =
this.dataPoints[this.dataPoints.length - 1].x -
this.dataPoints[0].x),
(s =
0 < s
? Math.min(
Math.max(
(((this.dataPoints.length - 1) / s) *
(a - this.dataPoints[0].x)) >>
0,
0
),
this.dataPoints.length
)
: 0)));
for (;;) {
g = 0 < m ? s + e : s - e;
if (0 <= g && g < this.dataPoints.length) {
var c = this.dataPoints[g],
q = this.axisX.logarithmic
? c.x > a
? c.x / a
: a / c.x
: Math.abs(c.x - a);
q < b.distance &&
((b.dataPoint = c), (b.distance = q), (b.index = g));
c = q;
c <= l ? (l = c) : 0 < m ? k++ : h++;
if (1e3 < k && 1e3 < h) break;
} else if (0 > s - e && s + e >= this.dataPoints.length) break;
-1 === m ? (e++, (m = 1)) : (m = -1);
}
return d || b.dataPoint.x !== a
? d && null !== b.dataPoint
? b
: null
: b;
};
F.prototype.getDataPointAtXY = function (a, d, b) {
if (
!this.dataPoints ||
0 === this.dataPoints.length ||
a < this.chart.plotArea.x1 ||
a > this.chart.plotArea.x2 ||
d < this.chart.plotArea.y1 ||
d > this.chart.plotArea.y2
)
return null;
b = b || !1;
var c = [],
e = 0,
g = 0,
m = 1,
l = !1,
k = Infinity,
h = 0,
s = 0,
q = 0;
if ("none" !== this.chart.plotInfo.axisPlacement)
if (
((q = (
this.chart.axisX[0] ? this.chart.axisX[0] : this.chart.axisX2[0]
).getXValueAt({ x: a, y: d })),
this.axisX.logarithmic)
)
var n = Math.log(
this.dataPoints[this.dataPoints.length - 1].x /
this.dataPoints[0].x
),
q =
1 < n
? Math.min(
Math.max(
(((this.dataPoints.length - 1) / n) *
Math.log(q / this.dataPoints[0].x)) >>
0,
0
),
this.dataPoints.length
)
: 0;
else
(n =
this.dataPoints[this.dataPoints.length - 1].x -
this.dataPoints[0].x),
(q =
0 < n
? Math.min(
Math.max(
(((this.dataPoints.length - 1) / n) *
(q - this.dataPoints[0].x)) >>
0,
0
),
this.dataPoints.length
)
: 0);
for (;;) {
g = 0 < m ? q + e : q - e;
if (0 <= g && g < this.dataPoints.length) {
var n = this.chart._eventManager.objectMap[this.dataPointIds[g]],
f = this.dataPoints[g],
p = null;
if (n) {
switch (this.type) {
case "column":
case "stackedColumn":
case "stackedColumn100":
case "bar":
case "stackedBar":
case "stackedBar100":
case "rangeColumn":
case "rangeBar":
case "waterfall":
case "error":
a >= n.x1 &&
a <= n.x2 &&
d >= n.y1 &&
d <= n.y2 &&
(c.push({
dataPoint: f,
dataPointIndex: g,
dataSeries: this,
distance: Math.min(
Math.abs(n.x1 - a),
Math.abs(n.x2 - a),
Math.abs(n.y1 - d),
Math.abs(n.y2 - d)
),
}),
(l = !0));
break;
case "line":
case "stepLine":
case "spline":
case "area":
case "stepArea":
case "stackedArea":
case "stackedArea100":
case "splineArea":
case "scatter":
var u = na("markerSize", f, this) || 4,
r = b ? 20 : u,
p = Math.sqrt(Math.pow(n.x1 - a, 2) + Math.pow(n.y1 - d, 2));
p <= r &&
c.push({
dataPoint: f,
dataPointIndex: g,
dataSeries: this,
distance: p,
});
n = Math.abs(n.x1 - a);
n <= k ? (k = n) : 0 < m ? h++ : s++;
p <= u / 2 && (l = !0);
break;
case "rangeArea":
case "rangeSplineArea":
u = na("markerSize", f, this) || 4;
r = b ? 20 : u;
p = Math.min(
Math.sqrt(Math.pow(n.x1 - a, 2) + Math.pow(n.y1 - d, 2)),
Math.sqrt(Math.pow(n.x1 - a, 2) + Math.pow(n.y2 - d, 2))
);
p <= r &&
c.push({
dataPoint: f,
dataPointIndex: g,
dataSeries: this,
distance: p,
});
n = Math.abs(n.x1 - a);
n <= k ? (k = n) : 0 < m ? h++ : s++;
p <= u / 2 && (l = !0);
break;
case "bubble":
u = n.size;
p = Math.sqrt(Math.pow(n.x1 - a, 2) + Math.pow(n.y1 - d, 2));
p <= u / 2 &&
(c.push({
dataPoint: f,
dataPointIndex: g,
dataSeries: this,
distance: p,
}),
(l = !0));
break;
case "pie":
case "doughnut":
u = n.center;
r =
"doughnut" === this.type
? n.percentInnerRadius * n.radius
: 0;
p = Math.sqrt(Math.pow(u.x - a, 2) + Math.pow(u.y - d, 2));
p < n.radius &&
p > r &&
((p = Math.atan2(d - u.y, a - u.x)),
0 > p && (p += 2 * Math.PI),
(p = Number(
((((180 * (p / Math.PI)) % 360) + 360) % 360).toFixed(12)
)),
(u = Number(
(
(((180 * (n.startAngle / Math.PI)) % 360) + 360) %
360
).toFixed(12)
)),
(r = Number(
(
(((180 * (n.endAngle / Math.PI)) % 360) + 360) %
360
).toFixed(12)
)),
0 === r && 1 < n.endAngle && (r = 360),
u >= r && 0 !== f.y && ((r += 360), p < u && (p += 360)),
p > u &&
p < r &&
(c.push({
dataPoint: f,
dataPointIndex: g,
dataSeries: this,
distance: 0,
}),
(l = !0)));
break;
case "funnel":
case "pyramid":
p = n.funnelSection;
d > p.y1 &&
d < p.y4 &&
(p.y6
? d > p.y6
? ((g =
p.x6 + ((p.x5 - p.x6) / (p.y5 - p.y6)) * (d - p.y6)),
(p =
p.x3 + ((p.x4 - p.x3) / (p.y4 - p.y3)) * (d - p.y3)))
: ((g =
p.x1 + ((p.x6 - p.x1) / (p.y6 - p.y1)) * (d - p.y1)),
(p =
p.x2 + ((p.x3 - p.x2) / (p.y3 - p.y2)) * (d - p.y2)))
: ((g =
p.x1 + ((p.x4 - p.x1) / (p.y4 - p.y1)) * (d - p.y1)),
(p =
p.x2 + ((p.x3 - p.x2) / (p.y3 - p.y2)) * (d - p.y2))),
a > g &&
a < p &&
(c.push({
dataPoint: f,
dataPointIndex: n.dataPointIndex,
dataSeries: this,
distance: 0,
}),
(l = !0)));
break;
case "boxAndWhisker":
if (
(a >= n.x1 - n.borderThickness / 2 &&
a <= n.x2 + n.borderThickness / 2 &&
d >= n.y4 - n.borderThickness / 2 &&
d <= n.y1 + n.borderThickness / 2) ||
(Math.abs(n.x2 - a + n.x1 - a) < n.borderThickness &&
d >= n.y1 &&
d <= n.y4)
)
c.push({
dataPoint: f,
dataPointIndex: g,
dataSeries: this,
distance: Math.min(
Math.abs(n.x1 - a),
Math.abs(n.x2 - a),
Math.abs(n.y2 - d),
Math.abs(n.y3 - d)
),
}),
(l = !0);
break;
case "candlestick":
if (
(a >= n.x1 - n.borderThickness / 2 &&
a <= n.x2 + n.borderThickness / 2 &&
d >= n.y2 - n.borderThickness / 2 &&
d <= n.y3 + n.borderThickness / 2) ||
(Math.abs(n.x2 - a + n.x1 - a) < n.borderThickness &&
d >= n.y1 &&
d <= n.y4)
)
c.push({
dataPoint: f,
dataPointIndex: g,
dataSeries: this,
distance: Math.min(
Math.abs(n.x1 - a),
Math.abs(n.x2 - a),
Math.abs(n.y2 - d),
Math.abs(n.y3 - d)
),
}),
(l = !0);
break;
case "ohlc":
if (
(Math.abs(n.x2 - a + n.x1 - a) < n.borderThickness &&
d >= n.y2 &&
d <= n.y3) ||
(a >= n.x1 &&
a <= (n.x2 + n.x1) / 2 &&
d >= n.y1 - n.borderThickness / 2 &&
d <= n.y1 + n.borderThickness / 2) ||
(a >= (n.x1 + n.x2) / 2 &&
a <= n.x2 &&
d >= n.y4 - n.borderThickness / 2 &&
d <= n.y4 + n.borderThickness / 2)
)
c.push({
dataPoint: f,
dataPointIndex: g,
dataSeries: this,
distance: Math.min(
Math.abs(n.x1 - a),
Math.abs(n.x2 - a),
Math.abs(n.y2 - d),
Math.abs(n.y3 - d)
),
}),
(l = !0);
}
if (l || (1e3 < h && 1e3 < s)) break;
}
} else if (0 > q - e && q + e >= this.dataPoints.length) break;
-1 === m ? (e++, (m = 1)) : (m = -1);
}
a = null;
for (d = 0; d < c.length; d++)
a ? c[d].distance <= a.distance && (a = c[d]) : (a = c[d]);
return a;
};
F.prototype.getMarkerProperties = function (a, d, b, c) {
var e = this.dataPoints;
return {
x: d,
y: b,
ctx: c,
type: e[a].markerType ? e[a].markerType : this.markerType,
size: e[a].markerSize ? e[a].markerSize : this.markerSize,
color: e[a].markerColor
? e[a].markerColor
: this.markerColor
? this.markerColor
: e[a].color
? e[a].color
: this.color
? this.color
: this._colorSet[a % this._colorSet.length],
borderColor: e[a].markerBorderColor
? e[a].markerBorderColor
: this.markerBorderColor
? this.markerBorderColor
: null,
borderThickness: e[a].markerBorderThickness
? e[a].markerBorderThickness
: this.markerBorderThickness
? this.markerBorderThickness
: null,
};
};
qa(z, V);
z.prototype.createExtraLabelsForLog = function (a) {
a = (a || 0) + 1;
if (!(5 < a)) {
var d = this.logLabelValues[0] || this.intervalStartPosition;
if (
Math.log(this.range) / Math.log(d / this.viewportMinimum) <
this.noTicks - 1
) {
for (
var b = z.getNiceNumber(
(d - this.viewportMinimum) /
Math.min(
Math.max(2, this.noTicks - this.logLabelValues.length),
3
),
!0
),
c = Math.ceil(this.viewportMinimum / b) * b;
c < d;
c += b
)
c < this.viewportMinimum || this.logLabelValues.push(c);
this.logLabelValues.sort(Sa);
this.createExtraLabelsForLog(a);
}
}
};
z.prototype.createLabels = function () {
var a,
d,
b = 0,
c = 0,
e,
g = 0,
m = 0,
c = 0,
c = this.interval,
l = 0,
k,
h = 0.6 * this.chart.height,
p;
a = !1;
var q = this.scaleBreaks ? this.scaleBreaks._appliedBreaks : [],
n = q.length
? u(this.scaleBreaks.firstBreakIndex)
? 0
: this.scaleBreaks.firstBreakIndex
: 0;
if (
"axisX" !== this.type ||
"dateTime" !== this.valueType ||
this.logarithmic
) {
e = this.viewportMaximum;
if (this.labels) {
a = Math.ceil(c);
for (
var c = Math.ceil(this.intervalStartPosition), f = !1, b = c;
b < this.viewportMaximum;
b += a
)
if (this.labels[b]) f = !0;
else {
f = !1;
break;
}
f && ((this.interval = a), (this.intervalStartPosition = c));
}
if (this.logarithmic && !this.equidistantInterval)
for (
this.logLabelValues ||
((this.logLabelValues = []), this.createExtraLabelsForLog()),
c = 0,
f = n;
c < this.logLabelValues.length;
c++
)
if (((b = this.logLabelValues[c]), b < this.viewportMinimum)) c++;
else {
for (; f < q.length && b > q[f].endValue; f++);
a = f < q.length && b >= q[f].startValue && b <= q[f].endValue;
p = b;
a ||
((a = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.options,
value: p,
label: this.labels[p] ? this.labels[p] : null,
})
: "axisX" === this.type && this.labels[p]
? this.labels[p]
: ba(p, this.valueFormatString, this.chart._cultureInfo)),
(a = new ka(this.ctx, {
x: 0,
y: 0,
maxWidth: g,
maxHeight: m,
angle: this.labelAngle,
text: this.prefix + a + this.suffix,
backgroundColor: this.labelBackgroundColor,
borderColor: this.labelBorderColor,
borderThickness: this.labelBorderThickness,
cornerRadius: this.labelCornerRadius,
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: p,
textBlock: a,
effectiveHeight: null,
}));
}
f = n;
for (
b = this.intervalStartPosition;
b <= e;
b = parseFloat(
1e-12 > this.interval
? this.logarithmic && this.equidistantInterval
? b * Math.pow(this.logarithmBase, this.interval)
: b + this.interval
: (this.logarithmic && this.equidistantInterval
? b * Math.pow(this.logarithmBase, this.interval)
: b + this.interval
).toFixed(12)
)
) {
for (; f < q.length && b > q[f].endValue; f++);
a = f < q.length && b >= q[f].startValue && b <= q[f].endValue;
p = b;
a ||
((a = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.options,
value: p,
label: this.labels[p] ? this.labels[p] : null,
})
: "axisX" === this.type && this.labels[p]
? this.labels[p]
: ba(p, this.valueFormatString, this.chart._cultureInfo)),
(a = new ka(this.ctx, {
x: 0,
y: 0,
maxWidth: g,
maxHeight: m,
angle: this.labelAngle,
text: this.prefix + a + this.suffix,
horizontalAlign: "left",
backgroundColor: this.labelBackgroundColor,
borderColor: this.labelBorderColor,
borderThickness: this.labelBorderThickness,
cornerRadius: this.labelCornerRadius,
fontSize: this.labelFontSize,
fontFamily: this.labelFontFamily,
fontWeight: this.labelFontWeight,
fontColor: this.labelFontColor,
fontStyle: this.labelFontStyle,
textBaseline: "middle",
})),
this._labels.push({
position: p,
textBlock: a,
effectiveHeight: null,
}));
}
} else
for (
this.intervalStartPosition = this.getLabelStartPoint(
new Date(this.viewportMinimum),
this.intervalType,
this.interval
),
e = Ya(
new Date(this.viewportMaximum),
this.interval,
this.intervalType
),
f = n,
b = this.intervalStartPosition;
b < e;
Ya(b, c, this.intervalType)
) {
for (a = b.getTime(); f < q.length && a > q[f].endValue; f++);
p = a;
a = f < q.length && a >= q[f].startValue && a <= q[f].endValue;
a ||
((a = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.options,
value: new Date(p),
label: this.labels[p] ? this.labels[p] : null,
})
: "axisX" === this.type && this.labels[p]
? this.labels[p]
: Ca(p, this.valueFormatString, this.chart._cultureInfo)),
(a = new ka(this.ctx, {
x: 0,
y: 0,
maxWidth: g,
backgroundColor: this.labelBackgroundColor,
borderColor: this.labelBorderColor,
borderThickness: this.labelBorderThickness,
cornerRadius: this.labelCornerRadius,
maxHeight: m,
angle: this.labelAngle,
text: this.prefix + a + 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: p,
textBlock: a,
effectiveHeight: null,
breaksLabelType: void 0,
}));
}
if ("bottom" === this._position || "top" === this._position)
(l =
this.logarithmic &&
!this.equidistantInterval &&
2 <= this._labels.length
? (this.lineCoordinates.width *
Math.log(
Math.min(
this._labels[this._labels.length - 1].position /
this._labels[this._labels.length - 2].position,
this._labels[1].position / this._labels[0].position
)
)) /
Math.log(this.range)
: (this.lineCoordinates.width /
(this.logarithmic && this.equidistantInterval
? Math.log(this.range) / Math.log(this.logarithmBase)
: Math.abs(this.range))) *
S[this.intervalType + "Duration"] *
this.interval),
(g =
"undefined" === typeof this.options.labelMaxWidth
? (0.5 * this.chart.width) >> 0
: this.options.labelMaxWidth),
this.chart.panEnabled ||
(m =
"undefined" === typeof this.options.labelWrap || this.labelWrap
? (0.8 * this.chart.height) >> 0
: 1.5 * this.labelFontSize);
else if ("left" === this._position || "right" === this._position)
(l =
this.logarithmic &&
!this.equidistantInterval &&
2 <= this._labels.length
? (this.lineCoordinates.height *
Math.log(
Math.min(
this._labels[this._labels.length - 1].position /
this._labels[this._labels.length - 2].position,
this._labels[1].position / this._labels[0].position
)
)) /
Math.log(this.range)
: (this.lineCoordinates.height /
(this.logarithmic && this.equidistantInterval
? Math.log(this.range) / Math.log(this.logarithmBase)
: Math.abs(this.range))) *
S[this.intervalType + "Duration"] *
this.interval),
this.chart.panEnabled ||
(g =
"undefined" === typeof this.options.labelMaxWidth
? (0.3 * this.chart.width) >> 0
: this.options.labelMaxWidth),
(m =
"undefined" === typeof this.options.labelWrap || this.labelWrap
? (0.3 * this.chart.height) >> 0
: 1.5 * this.labelFontSize);
for (c = 0; c < this._labels.length; c++) {
a = this._labels[c].textBlock;
a.maxWidth = g;
a.maxHeight = m;
var B = a.measureText();
k = B.height;
}
e = [];
n = q = 0;
if (this.labelAutoFit || this.options.labelAutoFit)
if (
(u(this.labelAngle) ||
((this.labelAngle = ((this.labelAngle % 360) + 360) % 360),
90 < this.labelAngle && 270 > this.labelAngle
? (this.labelAngle -= 180)
: 270 <= this.labelAngle &&
360 >= this.labelAngle &&
(this.labelAngle -= 360)),
"bottom" === this._position || "top" === this._position)
)
if (
((g = (0.9 * l) >> 0),
(n = 0),
!this.chart.panEnabled && 1 <= this._labels.length)
) {
this.sessionVariables.labelFontSize = this.labelFontSize;
this.sessionVariables.labelMaxWidth = g;
this.sessionVariables.labelMaxHeight = m;
this.sessionVariables.labelAngle = this.labelAngle;
this.sessionVariables.labelWrap = this.labelWrap;
for (b = 0; b < this._labels.length; b++)
if (!this._labels[b].breaksLabelType) {
a = this._labels[b].textBlock;
for (var v, f = a.text.split(" "), c = 0; c < f.length; c++)
(p = f[c]),
(this.ctx.font =
a.fontStyle +
" " +
a.fontWeight +
" " +
a.fontSize +
"px " +
a.fontFamily),
(p = this.ctx.measureText(p)),
p.width > n && ((v = b), (n = p.width));
}
b = 0;
for (
b = this.intervalStartPosition < this.viewportMinimum ? 1 : 0;
b < this._labels.length;
b++
)
if (!this._labels[b].breaksLabelType) {
a = this._labels[b].textBlock;
B = a.measureText();
for (f = b + 1; f < this._labels.length; f++)
if (!this._labels[f].breaksLabelType) {
d = this._labels[f].textBlock;
d = d.measureText();
break;
}
e.push(a.height);
this.sessionVariables.labelMaxHeight = Math.max.apply(Math, e);
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle));
Math.sin((Math.PI / 180) * Math.abs(this.labelAngle));
c =
g * Math.sin((Math.PI / 180) * Math.abs(this.labelAngle)) +
(m - a.fontSize / 2) *
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle));
if (
u(this.options.labelAngle) &&
isNaN(this.options.labelAngle) &&
0 !== this.options.labelAngle
)
if (
((this.sessionVariables.labelMaxHeight =
0 === this.labelAngle
? m
: Math.min(
(c -
g *
Math.cos(
(Math.PI / 180) * Math.abs(this.labelAngle)
)) /
Math.sin(
(Math.PI / 180) * Math.abs(this.labelAngle)
),
c
)),
(p =
(h -
(k + a.fontSize / 2) *
Math.cos((Math.PI / 180) * Math.abs(-25))) /
Math.sin((Math.PI / 180) * Math.abs(-25))),
!u(this.options.labelWrap))
)
this.labelWrap
? u(this.options.labelMaxWidth)
? ((this.sessionVariables.labelMaxWidth = Math.min(
Math.max(g, n),
p
)),
(this.sessionVariables.labelWrap = this.labelWrap),
(B.width + d.width) >> 0 > 2 * g &&
(this.sessionVariables.labelAngle = -25))
: ((this.sessionVariables.labelWrap = this.labelWrap),
(this.sessionVariables.labelMaxWidth =
this.options.labelMaxWidth),
(this.sessionVariables.labelAngle =
this.sessionVariables.labelMaxWidth > g
? -25
: this.sessionVariables.labelAngle))
: u(this.options.labelMaxWidth)
? ((this.sessionVariables.labelWrap = this.labelWrap),
(this.sessionVariables.labelMaxHeight = m),
(this.sessionVariables.labelMaxWidth = g),
(B.width + d.width) >> 0 > 2 * g &&
((this.sessionVariables.labelAngle = -25),
(this.sessionVariables.labelMaxWidth = p)))
: ((this.sessionVariables.labelAngle =
this.sessionVariables.labelMaxWidth > g
? -25
: this.sessionVariables.labelAngle),
(this.sessionVariables.labelMaxWidth =
this.options.labelMaxWidth),
(this.sessionVariables.labelMaxHeight = m),
(this.sessionVariables.labelWrap = this.labelWrap));
else {
if (u(this.options.labelWrap))
if (!u(this.options.labelMaxWidth))
this.options.labelMaxWidth < g
? ((this.sessionVariables.labelMaxWidth =
this.options.labelMaxWidth),
(this.sessionVariables.labelMaxHeight = c))
: ((this.sessionVariables.labelAngle = -25),
(this.sessionVariables.labelMaxWidth =
this.options.labelMaxWidth),
(this.sessionVariables.labelMaxHeight = m));
else if (!u(d))
if (
((c = (B.width + d.width) >> 0),
(f = this.labelFontSize),
n < g)
)
c - 2 * g > q &&
((q = c - 2 * g),
c >= 2 * g && c < 2.2 * g
? ((this.sessionVariables.labelMaxWidth = g),
u(this.options.labelFontSize) &&
12 < f &&
((f = Math.floor((12 / 13) * f)),
a.measureText()),
(this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? f
: this.options.labelFontSize),
(this.sessionVariables.labelAngle =
this.labelAngle))
: c >= 2.2 * g && c < 2.8 * g
? ((this.sessionVariables.labelAngle = -25),
(this.sessionVariables.labelMaxWidth = p),
(this.sessionVariables.labelFontSize = f))
: c >= 2.8 * g && c < 3.2 * g
? ((this.sessionVariables.labelMaxWidth =
Math.max(g, n)),
(this.sessionVariables.labelWrap = !0),
u(this.options.labelFontSize) &&
12 < this.labelFontSize &&
((this.labelFontSize = Math.floor(
(12 / 13) * this.labelFontSize
)),
a.measureText()),
(this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? f
: this.options.labelFontSize),
(this.sessionVariables.labelAngle =
this.labelAngle))
: c >= 3.2 * g && c < 3.6 * g
? ((this.sessionVariables.labelAngle = -25),
(this.sessionVariables.labelWrap = !0),
(this.sessionVariables.labelMaxWidth = p),
(this.sessionVariables.labelFontSize =
this.labelFontSize))
: c > 3.6 * g && c < 5 * g
? (u(this.options.labelFontSize) &&
12 < f &&
((f = Math.floor((12 / 13) * f)),
a.measureText()),
(this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? f
: this.options.labelFontSize),
(this.sessionVariables.labelWrap = !0),
(this.sessionVariables.labelAngle = -25),
(this.sessionVariables.labelMaxWidth = p))
: c > 5 * g &&
((this.sessionVariables.labelWrap = !0),
(this.sessionVariables.labelMaxWidth = g),
(this.sessionVariables.labelFontSize = f),
(this.sessionVariables.labelMaxHeight = m),
(this.sessionVariables.labelAngle =
this.labelAngle)));
else if (
v === b &&
((0 === v &&
n +
this._labels[v + 1].textBlock.measureText()
.width -
2 * g >
q) ||
(v === this._labels.length - 1 &&
n +
this._labels[v - 1].textBlock.measureText()
.width -
2 * g >
q) ||
(0 < v &&
v < this._labels.length - 1 &&
n +
this._labels[v + 1].textBlock.measureText()
.width -
2 * g >
q &&
n +
this._labels[v - 1].textBlock.measureText()
.width -
2 * g >
q))
)
(q =
0 === v
? n +
this._labels[v + 1].textBlock.measureText()
.width -
2 * g
: n +
this._labels[v - 1].textBlock.measureText()
.width -
2 * g),
(this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? f
: this.options.labelFontSize),
(this.sessionVariables.labelWrap = !0),
(this.sessionVariables.labelAngle = -25),
(this.sessionVariables.labelMaxWidth = p);
else if (0 === q)
for (
this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? f
: this.options.labelFontSize,
this.sessionVariables.labelWrap = !0,
c = 0;
c < this._labels.length;
c++
)
(a = this._labels[c].textBlock),
(a.maxWidth =
this.sessionVariables.labelMaxWidth =
Math.min(Math.max(g, n), p)),
(B = a.measureText()),
c < this._labels.length - 1 &&
((f = c + 1),
(d = this._labels[f].textBlock),
(d.maxWidth =
this.sessionVariables.labelMaxWidth =
Math.min(Math.max(g, n), p)),
(d = d.measureText()),
(B.width + d.width) >> 0 > 2 * g &&
(this.sessionVariables.labelAngle = -25));
}
else
((this.sessionVariables.labelAngle = this.labelAngle),
(this.sessionVariables.labelMaxHeight =
0 === this.labelAngle
? m
: Math.min(
(c -
g *
Math.cos(
(Math.PI / 180) * Math.abs(this.labelAngle)
)) /
Math.sin(
(Math.PI / 180) * Math.abs(this.labelAngle)
),
c
)),
(p =
0 != this.labelAngle
? (h -
(k + a.fontSize / 2) *
Math.cos(
(Math.PI / 180) * Math.abs(this.labelAngle)
)) /
Math.sin((Math.PI / 180) * Math.abs(this.labelAngle))
: g),
(this.sessionVariables.labelMaxHeight = m =
this.labelWrap
? (h -
p *
Math.sin(
(Math.PI / 180) * Math.abs(this.labelAngle)
)) /
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle))
: 1.5 * this.labelFontSize),
u(this.options.labelWrap))
? u(this.options.labelWrap) &&
(this.labelWrap && !u(this.options.labelMaxWidth)
? ((this.sessionVariables.labelWrap = this.labelWrap),
(this.sessionVariables.labelMaxWidth = this.options
.labelMaxWidth
? this.options.labelMaxWidth
: p),
(this.sessionVariables.labelMaxHeight = m))
: ((this.sessionVariables.labelAngle = this.labelAngle),
(this.sessionVariables.labelMaxWidth = p),
(this.sessionVariables.labelMaxHeight =
c < 0.9 * l ? 0.9 * l : c),
(this.sessionVariables.labelWrap = this.labelWrap)))
: (this.options.labelWrap
? ((this.sessionVariables.labelWrap = this.labelWrap),
(this.sessionVariables.labelMaxWidth = this.options
.labelMaxWidth
? this.options.labelMaxWidth
: p))
: (u(this.options.labelMaxWidth),
(this.sessionVariables.labelMaxWidth = this.options
.labelMaxWidth
? this.options.labelMaxWidth
: p),
(this.sessionVariables.labelWrap = this.labelWrap)),
(this.sessionVariables.labelMaxHeight = m));
}
for (c = 0; c < this._labels.length; c++)
(a = this._labels[c].textBlock),
(a.maxWidth = this.labelMaxWidth =
this.sessionVariables.labelMaxWidth),
(a.fontSize = this.sessionVariables.labelFontSize),
(a.angle = this.labelAngle = this.sessionVariables.labelAngle),
(a.wrap = this.labelWrap = this.sessionVariables.labelWrap),
(a.maxHeight = this.sessionVariables.labelMaxHeight),
a.measureText();
} else
for (b = 0; b < this._labels.length; b++)
(a = this._labels[b].textBlock),
(a.maxWidth = this.labelMaxWidth =
u(this.options.labelMaxWidth)
? this.sessionVariables.labelMaxWidth
: this.options.labelMaxWidth),
(a.fontSize = this.labelFontSize =
u(this.options.labelFontSize)
? this.sessionVariables.labelFontSize
: this.options.labelFontSize),
(a.angle = this.labelAngle =
u(this.options.labelAngle)
? this.sessionVariables.labelAngle
: this.labelAngle),
(a.wrap = this.labelWrap =
u(this.options.labelWrap)
? this.sessionVariables.labelWrap
: this.options.labelWrap),
(a.maxHeight = this.sessionVariables.labelMaxHeight),
a.measureText();
else if ("left" === this._position || "right" === this._position)
if (
((g = u(this.options.labelMaxWidth)
? (0.3 * this.chart.width) >> 0
: this.options.labelMaxWidth),
(m =
"undefined" === typeof this.options.labelWrap || this.labelWrap
? (0.3 * this.chart.height) >> 0
: 1.5 * this.labelFontSize),
!this.chart.panEnabled && 1 <= this._labels.length)
) {
this.sessionVariables.labelFontSize = this.labelFontSize;
this.sessionVariables.labelMaxWidth = g;
this.sessionVariables.labelMaxHeight = m;
this.sessionVariables.labelAngle = u(
this.sessionVariables.labelAngle
)
? 0
: this.sessionVariables.labelAngle;
this.sessionVariables.labelWrap = this.labelWrap;
for (b = 0; b < this._labels.length; b++)
if (!this._labels[b].breaksLabelType) {
a = this._labels[b].textBlock;
B = a.measureText();
for (f = b + 1; f < this._labels.length; f++)
if (!this._labels[f].breaksLabelType) {
d = this._labels[f].textBlock;
d = d.measureText();
break;
}
e.push(a.height);
this.sessionVariables.labelMaxHeight = Math.max.apply(Math, e);
c =
g * Math.sin((Math.PI / 180) * Math.abs(this.labelAngle)) +
(m - a.fontSize / 2) *
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle));
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle));
Math.sin((Math.PI / 180) * Math.abs(this.labelAngle));
u(this.options.labelAngle) &&
isNaN(this.options.labelAngle) &&
0 !== this.options.labelAngle
? u(this.options.labelWrap)
? u(this.options.labelWrap) &&
(u(this.options.labelMaxWidth)
? u(d) ||
((l = (B.height + d.height) >> 0),
l - 2 * m > n &&
((n = l - 2 * m),
l >= 2 * m && l < 2.4 * m
? (u(this.options.labelFontSize) &&
12 < this.labelFontSize &&
((this.labelFontSize = Math.floor(
(12 / 13) * this.labelFontSize
)),
a.measureText()),
(this.sessionVariables.labelMaxHeight = m),
(this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? this.labelFontSize
: this.options.labelFontSize))
: l >= 2.4 * m && l < 2.8 * m
? ((this.sessionVariables.labelMaxHeight = c),
(this.sessionVariables.labelFontSize =
this.labelFontSize),
(this.sessionVariables.labelWrap = !0))
: l >= 2.8 * m && l < 3.2 * m
? ((this.sessionVariables.labelMaxHeight = m),
(this.sessionVariables.labelWrap = !0),
u(this.options.labelFontSize) &&
12 < this.labelFontSize &&
((this.labelFontSize = Math.floor(
(12 / 13) * this.labelFontSize
)),
a.measureText()),
(this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? this.labelFontSize
: this.options.labelFontSize),
(this.sessionVariables.labelAngle = u(
this.sessionVariables.labelAngle
)
? 0
: this.sessionVariables.labelAngle))
: l >= 3.2 * m && l < 3.6 * m
? ((this.sessionVariables.labelMaxHeight = c),
(this.sessionVariables.labelWrap = !0),
(this.sessionVariables.labelFontSize =
this.labelFontSize))
: l > 3.6 * m && l < 10 * m
? (u(this.options.labelFontSize) &&
12 < this.labelFontSize &&
((this.labelFontSize = Math.floor(
(12 / 13) * this.labelFontSize
)),
a.measureText()),
(this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? this.labelFontSize
: this.options.labelFontSize),
(this.sessionVariables.labelMaxWidth = g),
(this.sessionVariables.labelMaxHeight = m),
(this.sessionVariables.labelAngle = u(
this.sessionVariables.labelAngle
)
? 0
: this.sessionVariables.labelAngle))
: l > 10 * m &&
l < 50 * m &&
(u(this.options.labelFontSize) &&
12 < this.labelFontSize &&
((this.labelFontSize = Math.floor(
(12 / 13) * this.labelFontSize
)),
a.measureText()),
(this.sessionVariables.labelFontSize = u(
this.options.labelFontSize
)
? this.labelFontSize
: this.options.labelFontSize),
(this.sessionVariables.labelMaxHeight = m),
(this.sessionVariables.labelMaxWidth = g),
(this.sessionVariables.labelAngle = u(
this.sessionVariables.labelAngle
)
? 0
: this.sessionVariables.labelAngle))))
: ((this.sessionVariables.labelMaxHeight = m),
(this.sessionVariables.labelMaxWidth = this.options
.labelMaxWidth
? this.options.labelMaxWidth
: this.sessionVariables.labelMaxWidth)))
: ((this.sessionVariables.labelMaxWidth = this.labelWrap
? this.options.labelMaxWidth
? this.options.labelMaxWidth
: this.sessionVariables.labelMaxWidth
: this.labelMaxWidth
? this.options.labelMaxWidth
? this.options.labelMaxWidth
: this.sessionVariables.labelMaxWidth
: g),
(this.sessionVariables.labelMaxHeight = m))
: ((this.sessionVariables.labelAngle = this.labelAngle),
(this.sessionVariables.labelMaxWidth =
0 === this.labelAngle
? g
: Math.min(
(c -
m *
Math.sin(
(Math.PI / 180) * Math.abs(this.labelAngle)
)) /
Math.cos(
(Math.PI / 180) * Math.abs(this.labelAngle)
),
m
)),
u(this.options.labelWrap))
? u(this.options.labelWrap) &&
(this.labelWrap && !u(this.options.labelMaxWidth)
? ((this.sessionVariables.labelMaxWidth = this.options
.labelMaxWidth
? this.options.labelMaxWidth >
this.options.labelMaxWidth
: this.sessionVariables.labelMaxWidth),
(this.sessionVariables.labelWrap = this.labelWrap),
(this.sessionVariables.labelMaxHeight = c))
: ((this.sessionVariables.labelMaxWidth = this.options
.labelMaxWidth
? this.options.labelMaxWidth
: g),
(this.sessionVariables.labelMaxHeight =
0 === this.labelAngle ? m : c),
u(this.options.labelMaxWidth) &&
(this.sessionVariables.labelAngle = this.labelAngle)))
: this.options.labelWrap
? ((this.sessionVariables.labelMaxHeight =
0 === this.labelAngle ? m : c),
(this.sessionVariables.labelWrap = this.labelWrap),
(this.sessionVariables.labelMaxWidth = g))
: ((this.sessionVariables.labelMaxHeight = m),
u(this.options.labelMaxWidth),
(this.sessionVariables.labelMaxWidth = this.options
.labelMaxWidth
? this.options.labelMaxWidth
: this.sessionVariables.labelMaxWidth),
(this.sessionVariables.labelWrap = this.labelWrap));
}
for (c = 0; c < this._labels.length; c++)
(a = this._labels[c].textBlock),
(a.maxWidth = this.labelMaxWidth =
this.sessionVariables.labelMaxWidth),
(a.fontSize = this.labelFontSize =
this.sessionVariables.labelFontSize),
(a.angle = this.labelAngle = this.sessionVariables.labelAngle),
(a.wrap = this.labelWrap = this.sessionVariables.labelWrap),
(a.maxHeight = this.sessionVariables.labelMaxHeight),
a.measureText();
} else
for (b = 0; b < this._labels.length; b++)
(a = this._labels[b].textBlock),
(a.maxWidth = this.labelMaxWidth =
u(this.options.labelMaxWidth)
? this.sessionVariables.labelMaxWidth
: this.options.labelMaxWidth),
(a.fontSize = this.labelFontSize =
u(this.options.labelFontSize)
? this.sessionVariables.labelFontSize
: this.options.labelFontSize),
(a.angle = this.labelAngle =
u(this.options.labelAngle)
? this.sessionVariables.labelAngle
: this.labelAngle),
(a.wrap = this.labelWrap =
u(this.options.labelWrap)
? this.sessionVariables.labelWrap
: this.options.labelWrap),
(a.maxHeight = this.sessionVariables.labelMaxHeight),
a.measureText();
for (b = 0; b < this.stripLines.length; b++) {
var g = this.stripLines[b],
z;
if ("outside" === g.labelPlacement) {
m = this.sessionVariables.labelMaxWidth;
if ("bottom" === this._position || "top" === this._position)
z = u(g.options.labelWrap)
? this.sessionVariables.labelMaxHeight
: g.labelWrap
? (0.8 * this.chart.height) >> 0
: 1.5 * this.labelFontSize;
if ("left" === this._position || "right" === this._position)
z = u(g.options.labelWrap)
? this.sessionVariables.labelMaxHeight
: g.labelWrap
? (0.8 * this.chart.width) >> 0
: 1.5 * this.labelFontSize;
u(g.labelBackgroundColor) && (g.labelBackgroundColor = "#EEEEEE");
} else
(m =
"bottom" === this._position || "top" === this._position
? (0.9 * this.chart.width) >> 0
: (0.9 * this.chart.height) >> 0),
(z =
u(g.options.labelWrap) || g.labelWrap
? "bottom" === this._position || "top" === this._position
? (0.8 * this.chart.width) >> 0
: (0.8 * this.chart.height) >> 0
: 1.5 * this.labelFontSize),
u(g.labelBackgroundColor) &&
(u(g.startValue) && 0 !== g.startValue
? (g.labelBackgroundColor = r ? "transparent" : null)
: (g.labelBackgroundColor = "#EEEEEE"));
a = new ka(this.ctx, {
x: 0,
y: 0,
backgroundColor: g.labelBackgroundColor,
borderColor: g.labelBorderColor,
borderThickness: g.labelBorderThickness,
cornerRadius: g.labelCornerRadius,
maxWidth: g.options.labelMaxWidth ? g.options.labelMaxWidth : m,
maxHeight: z,
angle: this.labelAngle,
text: g.labelFormatter
? g.labelFormatter({ chart: this.chart, axis: this, stripLine: g })
: g.label,
horizontalAlign: "left",
fontSize:
"outside" === g.labelPlacement
? g.options.labelFontSize
? g.labelFontSize
: this.labelFontSize
: g.labelFontSize,
fontFamily:
"outside" === g.labelPlacement
? g.options.labelFontFamily
? g.labelFontFamily
: this.labelFontFamily
: g.labelFontFamily,
fontWeight:
"outside" === g.labelPlacement
? g.options.labelFontWeight
? g.labelFontWeight
: this.labelFontWeight
: g.labelFontWeight,
fontColor: g.labelFontColor || g.color,
fontStyle:
"outside" === g.labelPlacement
? g.options.labelFontStyle
? g.labelFontStyle
: this.fontWeight
: g.labelFontStyle,
textBaseline: "middle",
});
this._stripLineLabels.push({
position: g.value,
textBlock: a,
effectiveHeight: null,
stripLine: g,
});
}
};
z.prototype.createLabelsAndCalculateWidth = function () {
var a = 0,
d = 0;
this._labels = [];
this._stripLineLabels = [];
var b = this.chart.isNavigator ? 0 : 5;
if ("left" === this._position || "right" === this._position) {
this.createLabels();
for (d = 0; d < this._labels.length; d++) {
var c = this._labels[d].textBlock,
e = c.measureText(),
g = 0,
g =
0 === this.labelAngle
? e.width
: e.width *
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle)) +
(e.height - c.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(this.labelAngle));
a < g && (a = g);
this._labels[d].effectiveWidth = g;
}
for (d = 0; d < this._stripLineLabels.length; d++)
"outside" === this._stripLineLabels[d].stripLine.labelPlacement &&
this._stripLineLabels[d].stripLine.value >= this.viewportMinimum &&
this._stripLineLabels[d].stripLine.value <= this.viewportMaximum &&
((c = this._stripLineLabels[d].textBlock),
(e = c.measureText()),
(g =
0 === this.labelAngle
? e.width
: e.width *
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle)) +
(e.height - c.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(this.labelAngle))),
a < g && (a = g),
(this._stripLineLabels[d].effectiveWidth = g));
}
d = this.title ? this._titleTextBlock.measureText().height + 2 : 0;
return (c =
"inside" === this.labelPlacement
? (c = d + b)
: d + a + this.tickLength + b);
};
z.prototype.createLabelsAndCalculateHeight = function () {
var a = 0;
this._labels = [];
this._stripLineLabels = [];
var d,
b = 0,
c = this.chart.isNavigator ? 0 : 5;
this.createLabels();
if ("bottom" === this._position || "top" === this._position) {
for (b = 0; b < this._labels.length; b++) {
d = this._labels[b].textBlock;
var e = d.measureText(),
g = 0,
g =
0 === this.labelAngle
? e.height
: e.width *
Math.sin((Math.PI / 180) * Math.abs(this.labelAngle)) +
(e.height - d.fontSize / 2) *
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle));
a < g && (a = g);
this._labels[b].effectiveHeight = g;
}
for (b = 0; b < this._stripLineLabels.length; b++)
"outside" === this._stripLineLabels[b].stripLine.labelPlacement &&
this._stripLineLabels[b].stripLine.value >= this.viewportMinimum &&
this._stripLineLabels[b].stripLine.value <= this.viewportMaximum &&
((d = this._stripLineLabels[b].textBlock),
(e = d.measureText()),
(g =
0 === this.labelAngle
? e.height
: e.width *
Math.sin((Math.PI / 180) * Math.abs(this.labelAngle)) +
(e.height - d.fontSize / 2) *
Math.cos((Math.PI / 180) * Math.abs(this.labelAngle))),
a < g && (a = g),
(this._stripLineLabels[b].effectiveHeight = g));
}
d = this.title ? this._titleTextBlock.measureText().height + 2 : 0;
return (b =
"inside" === this.labelPlacement
? (b = d + c)
: d + a + this.tickLength + c);
};
z.setLayout = function (a, d, b, c, e, g) {
var m,
l,
k,
h,
p = a[0] ? a[0].chart : d[0].chart,
q = p.isNavigator ? 0 : 10,
n = p._axes;
if (a && 0 < a.length)
for (var f = 0; f < a.length; f++)
a[f] && a[f].calculateAxisParameters();
if (d && 0 < d.length)
for (f = 0; f < d.length; f++) d[f].calculateAxisParameters();
if (b && 0 < b.length)
for (f = 0; f < b.length; f++) b[f].calculateAxisParameters();
if (c && 0 < c.length)
for (f = 0; f < c.length; f++) c[f].calculateAxisParameters();
for (f = 0; f < n.length; f++)
if (n[f] && n[f].scaleBreaks && n[f].scaleBreaks._appliedBreaks.length)
for (
var r = n[f].scaleBreaks._appliedBreaks, v = 0;
v < r.length && !(r[v].startValue > n[f].viewportMaximum);
v++
)
r[v].endValue < n[f].viewportMinimum ||
(u(n[f].scaleBreaks.firstBreakIndex) &&
(n[f].scaleBreaks.firstBreakIndex = v),
r[v].startValue >= n[f].viewPortMinimum &&
(n[f].scaleBreaks.lastBreakIndex = v));
for (
var z = (v = 0),
t = 0,
C = 0,
x = 0,
D = 0,
y = 0,
A,
E,
F = (l = 0),
H,
I,
L,
r = (H = I = L = !1),
f = 0;
f < n.length;
f++
)
n[f] &&
n[f].title &&
(n[f]._titleTextBlock = new ka(n[f].ctx, {
text: n[f].title,
horizontalAlign: "center",
fontSize: n[f].titleFontSize,
fontFamily: n[f].titleFontFamily,
fontWeight: n[f].titleFontWeight,
fontColor: n[f].titleFontColor,
fontStyle: n[f].titleFontStyle,
borderColor: n[f].titleBorderColor,
borderThickness: n[f].titleBorderThickness,
backgroundColor: n[f].titleBackgroundColor,
cornerRadius: n[f].titleCornerRadius,
textBaseline: "top",
}));
for (f = 0; f < n.length; f++)
if (n[f].title)
switch (n[f]._position) {
case "left":
n[f]._titleTextBlock.maxWidth = n[f].titleMaxWidth || g.height;
n[f]._titleTextBlock.maxHeight = n[f].titleWrap
? 0.8 * g.width
: 1.5 * n[f].titleFontSize;
n[f]._titleTextBlock.angle = -90;
break;
case "right":
n[f]._titleTextBlock.maxWidth = n[f].titleMaxWidth || g.height;
n[f]._titleTextBlock.maxHeight = n[f].titleWrap
? 0.8 * g.width
: 1.5 * n[f].titleFontSize;
n[f]._titleTextBlock.angle = 90;
break;
default:
(n[f]._titleTextBlock.maxWidth = n[f].titleMaxWidth || g.width),
(n[f]._titleTextBlock.maxHeight = n[f].titleWrap
? 0.8 * g.height
: 1.5 * n[f].titleFontSize),
(n[f]._titleTextBlock.angle = 0);
}
if ("normal" === e) {
for (
var C = [], x = [], D = [], y = [], M = [], N = [], O = [], Q = [];
4 > v;
) {
var G = 0,
R = 0,
S = 0,
U = 0,
W = (e = 0),
K = 0,
$ = 0,
V = 0,
X = 0,
P = 0,
ba = 0;
if (b && 0 < b.length)
for (D = [], f = P = 0; f < b.length; f++)
D.push(
Math.ceil(b[f] ? b[f].createLabelsAndCalculateWidth() : 0)
),
(P += D[f]),
(K += b[f] && !p.isNavigator ? b[f].margin : 0);
else
D.push(Math.ceil(b[0] ? b[0].createLabelsAndCalculateWidth() : 0));
O.push(D);
if (c && 0 < c.length)
for (y = [], f = ba = 0; f < c.length; f++)
y.push(
Math.ceil(c[f] ? c[f].createLabelsAndCalculateWidth() : 0)
),
(ba += y[f]),
($ += c[f] ? c[f].margin : 0);
else
y.push(Math.ceil(c[0] ? c[0].createLabelsAndCalculateWidth() : 0));
Q.push(y);
m = Math.round(g.x1 + P + K);
k = Math.round(
g.x2 - ba - $ > p.width - q ? p.width - q : g.x2 - ba - $
);
if (a && 0 < a.length)
for (C = [], f = V = 0; f < a.length; f++)
a[f] && (a[f].lineCoordinates = {}),
(a[f].lineCoordinates.width = Math.abs(k - m)),
a[f].title &&
(a[f]._titleTextBlock.maxWidth =
0 < a[f].titleMaxWidth &&
a[f].titleMaxWidth < a[f].lineCoordinates.width
? a[f].titleMaxWidth
: a[f].lineCoordinates.width),
C.push(
Math.ceil(a[f] ? a[f].createLabelsAndCalculateHeight() : 0)
),
(V += C[f]),
(e += a[f] && !p.isNavigator ? a[f].margin : 0);
else
C.push(Math.ceil(a[0] ? a[0].createLabelsAndCalculateHeight() : 0));
M.push(C);
if (d && 0 < d.length)
for (x = [], f = X = 0; f < d.length; f++)
d[f] && (d[f].lineCoordinates = {}),
(d[f].lineCoordinates.width = Math.abs(k - m)),
d[f].title &&
(d[f]._titleTextBlock.maxWidth =
0 < d[f].titleMaxWidth &&
d[f].titleMaxWidth < d[f].lineCoordinates.width
? d[f].titleMaxWidth
: d[f].lineCoordinates.width),
x.push(
Math.ceil(d[f] ? d[f].createLabelsAndCalculateHeight() : 0)
),
(X += x[f]),
(W += d[f] && !p.isNavigator ? d[f].margin : 0);
else
x.push(Math.ceil(d[0] ? d[0].createLabelsAndCalculateHeight() : 0));
N.push(x);
if (a && 0 < a.length)
for (f = 0; f < a.length; f++)
a[f] &&
((a[f].lineCoordinates.x1 = m),
(k = Math.round(
g.x2 - ba - $ > p.width - q ? p.width - q : g.x2 - ba - $
)),
a[f]._labels &&
1 < a[f]._labels.length &&
((l = h = 0),
(h = a[f]._labels[1]),
(l =
"dateTime" === a[f].valueType
? a[f]._labels[a[f]._labels.length - 2]
: a[f]._labels[a[f]._labels.length - 1]),
(z =
h.textBlock.width *
Math.cos((Math.PI / 180) * Math.abs(h.textBlock.angle)) +
(h.textBlock.height - l.textBlock.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(h.textBlock.angle))),
(t =
l.textBlock.width *
Math.cos((Math.PI / 180) * Math.abs(l.textBlock.angle)) +
(l.textBlock.height - l.textBlock.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(l.textBlock.angle)))),
!a[f] ||
!a[f].labelAutoFit ||
u(A) ||
u(E) ||
p.isNavigator ||
((l = 0),
0 < a[f].labelAngle
? E + t > k &&
(l += 0 < a[f].labelAngle ? E + t - k - ba : 0)
: 0 > a[f].labelAngle
? A - z < m &&
A - z < a[f].viewportMinimum &&
(F =
m -
(K +
a[f].tickLength +
D +
A -
z +
a[f].labelFontSize / 2))
: 0 === a[f].labelAngle &&
(E + t > k && (l = E + t / 2 - k - ba),
A - z < m &&
A - z < a[f].viewportMinimum &&
(F = m - K - a[f].tickLength - D - A + z / 2)),
a[f].viewportMaximum === a[f].maximum &&
a[f].viewportMinimum === a[f].minimum &&
0 < a[f].labelAngle &&
0 < l
? (k -= l)
: a[f].viewportMaximum === a[f].maximum &&
a[f].viewportMinimum === a[f].minimum &&
0 > a[f].labelAngle &&
0 < F
? (m += F)
: a[f].viewportMaximum === a[f].maximum &&
a[f].viewportMinimum === a[f].minimum &&
0 === a[f].labelAngle &&
(0 < F && (m += F), 0 < l && (k -= l))),
p.panEnabled
? (V = p.sessionVariables.axisX.height)
: (p.sessionVariables.axisX.height = V),
(l = Math.round(g.y2 - V - e + G)),
(h = Math.round(g.y2)),
(a[f].lineCoordinates.x2 = k),
(a[f].lineCoordinates.width = k - m),
(a[f].lineCoordinates.y1 = l),
(a[f].lineCoordinates.y2 = l),
(a[f].bounds = {
x1: m,
y1: l,
x2: k,
y2: h - (V + e - C[f] - G),
width: k - m,
height: h - l,
})),
(G += C[f] + a[f].margin);
if (d && 0 < d.length)
for (f = 0; f < d.length; f++)
(d[f].lineCoordinates.x1 = Math.round(g.x1 + P + K)),
(d[f].lineCoordinates.x2 = Math.round(
g.x2 - ba - $ > p.width - q ? p.width - q : g.x2 - ba - $
)),
(d[f].lineCoordinates.width = Math.abs(k - m)),
d[f]._labels &&
1 < d[f]._labels.length &&
((h = d[f]._labels[1]),
(l =
"dateTime" === d[f].valueType
? d[f]._labels[d[f]._labels.length - 2]
: d[f]._labels[d[f]._labels.length - 1]),
(z =
h.textBlock.width *
Math.cos((Math.PI / 180) * Math.abs(h.textBlock.angle)) +
(h.textBlock.height - l.textBlock.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(h.textBlock.angle))),
(t =
l.textBlock.width *
Math.cos((Math.PI / 180) * Math.abs(l.textBlock.angle)) +
(l.textBlock.height - l.textBlock.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(l.textBlock.angle)))),
p.panEnabled
? (X = p.sessionVariables.axisX2.height)
: (p.sessionVariables.axisX2.height = X),
(l = Math.round(g.y1)),
(h = Math.round(g.y2 + d[f].margin)),
(d[f].lineCoordinates.y1 = l + X + W - R),
(d[f].lineCoordinates.y2 = l),
(d[f].bounds = {
x1: m,
y1: l + (X + W - x[f] - R),
x2: k,
y2: h,
width: k - m,
height: h - l,
}),
(R += x[f] + d[f].margin);
if (b && 0 < b.length)
for (f = 0; f < b.length; f++)
(K = p.isNavigator ? 0 : 10),
b[f] &&
((m = Math.round(
a[0] ? a[0].lineCoordinates.x1 : d[0].lineCoordinates.x1
)),
(K =
b[f]._labels && 0 < b[f]._labels.length
? b[f]._labels[b[f]._labels.length - 1].textBlock.height /
2
: q),
(l = Math.round(
g.y1 + X + W < Math.max(K, q)
? Math.max(K, q)
: g.y1 + X + W
)),
(k = Math.round(
a[0] ? a[0].lineCoordinates.x1 : d[0].lineCoordinates.x1
)),
(K =
0 < a.length
? 0
: b[f]._labels && 0 < b[f]._labels.length
? b[f]._labels[0].textBlock.height / 2
: q),
(h = Math.round(g.y2 - V - e - K)),
(b[f].lineCoordinates = {
x1: k - S,
y1: l,
x2: k - S,
y2: h,
height: Math.abs(h - l),
}),
(b[f].bounds = {
x1: m - (D[f] + S),
y1: l,
x2: k,
y2: h,
width: k - m,
height: h - l,
}),
b[f].title &&
(b[f]._titleTextBlock.maxWidth =
0 < b[f].titleMaxWidth &&
b[f].titleMaxWidth < b[f].lineCoordinates.height
? b[f].titleMaxWidth
: b[f].lineCoordinates.height),
(S += D[f] + b[f].margin));
if (c && 0 < c.length)
for (f = 0; f < c.length; f++)
c[f] &&
((m = Math.round(
a[0] ? a[0].lineCoordinates.x2 : d[0].lineCoordinates.x2
)),
(k = Math.round(m)),
(K =
c[f]._labels && 0 < c[f]._labels.length
? c[f]._labels[c[f]._labels.length - 1].textBlock.height / 2
: 0),
(l = Math.round(
g.y1 + X + W < Math.max(K, q) ? Math.max(K, q) : g.y1 + X + W
)),
(K =
0 < a.length
? 0
: c[f]._labels && 0 < c[f]._labels.length
? c[f]._labels[0].textBlock.height / 2
: 0),
(h = Math.round(g.y2 - (V + e + K))),
(c[f].lineCoordinates = {
x1: m + U,
y1: l,
x2: m + U,
y2: h,
height: Math.abs(h - l),
}),
(c[f].bounds = {
x1: m,
y1: l,
x2: k + (y[f] + U),
y2: h,
width: k - m,
height: h - l,
}),
c[f].title &&
(c[f]._titleTextBlock.maxWidth =
0 < c[f].titleMaxWidth &&
c[f].titleMaxWidth < c[f].lineCoordinates.height
? c[f].titleMaxWidth
: c[f].lineCoordinates.height),
(U += y[f] + c[f].margin));
if (a && 0 < a.length)
for (f = 0; f < a.length; f++)
a[f] &&
(a[f].calculateValueToPixelConversionParameters(),
a[f].calculateBreaksSizeInValues(),
a[f]._labels &&
1 < a[f]._labels.length &&
((A =
(a[f].logarithmic
? Math.log(
a[f]._labels[1].position / a[f].viewportMinimum
) / a[f].conversionParameters.lnLogarithmBase
: a[f]._labels[1].position - a[f].viewportMinimum) *
Math.abs(a[f].conversionParameters.pixelPerUnit) +
a[f].lineCoordinates.x1),
(m =
a[f]._labels[
a[f]._labels.length -
("dateTime" === a[f].valueType ? 2 : 1)
].position),
(m = a[f].getApparentDifference(a[f].viewportMinimum, m)),
(E = a[f].logarithmic
? (1 < m
? (Math.log(m) /
a[f].conversionParameters.lnLogarithmBase) *
Math.abs(a[f].conversionParameters.pixelPerUnit)
: 0) + a[f].lineCoordinates.x1
: (0 < m
? m * Math.abs(a[f].conversionParameters.pixelPerUnit)
: 0) + a[f].lineCoordinates.x1)));
if (d && 0 < d.length)
for (f = 0; f < d.length; f++)
d[f].calculateValueToPixelConversionParameters(),
d[f].calculateBreaksSizeInValues(),
d[f]._labels &&
1 < d[f]._labels.length &&
((A =
(d[f].logarithmic
? Math.log(
d[f]._labels[1].position / d[f].viewportMinimum
) / d[f].conversionParameters.lnLogarithmBase
: d[f]._labels[1].position - d[f].viewportMinimum) *
Math.abs(d[f].conversionParameters.pixelPerUnit) +
d[f].lineCoordinates.x1),
(m =
d[f]._labels[
d[f]._labels.length -
("dateTime" === d[f].valueType ? 2 : 1)
].position),
(m = d[f].getApparentDifference(d[f].viewportMinimum, m)),
(E = d[f].logarithmic
? (1 < m
? (Math.log(m) /
d[f].conversionParameters.lnLogarithmBase) *
Math.abs(d[f].conversionParameters.pixelPerUnit)
: 0) + d[f].lineCoordinates.x1
: (0 < m
? m * Math.abs(d[f].conversionParameters.pixelPerUnit)
: 0) + d[f].lineCoordinates.x1));
for (f = 0; f < n.length; f++)
"axisY" === n[f].type &&
(n[f].calculateValueToPixelConversionParameters(),
n[f].calculateBreaksSizeInValues());
if (0 < v) {
if (a && 0 < a.length)
for (f = 0; f < a.length; f++)
r = M[v - 1][f] === M[v][f] ? !0 : !1;
else r = !0;
if (d && 0 < d.length)
for (f = 0; f < d.length; f++)
H = N[v - 1][f] === N[v][f] ? !0 : !1;
else H = !0;
if (b && 0 < b.length)
for (f = 0; f < b.length; f++)
I = O[v - 1][f] === O[v][f] ? !0 : !1;
else I = !0;
if (c && 0 < c.length)
for (f = 0; f < c.length; f++)
L = Q[v - 1][f] === Q[v][f] ? !0 : !1;
else L = !0;
}
if (r && H && I && L) break;
v++;
}
if (a && 0 < a.length)
for (f = 0; f < a.length; f++)
a[f].calculateStripLinesThicknessInValues(),
a[f].calculateBreaksInPixels();
if (d && 0 < d.length)
for (f = 0; f < d.length; f++)
d[f].calculateStripLinesThicknessInValues(),
d[f].calculateBreaksInPixels();
if (b && 0 < b.length)
for (f = 0; f < b.length; f++)
b[f].calculateStripLinesThicknessInValues(),
b[f].calculateBreaksInPixels();
if (c && 0 < c.length)
for (f = 0; f < c.length; f++)
c[f].calculateStripLinesThicknessInValues(),
c[f].calculateBreaksInPixels();
} else {
q = [];
A = [];
F = [];
z = [];
E = [];
t = [];
M = [];
for (N = []; 4 > v; ) {
V = U = R = S = $ = K = W = e = Q = O = G = X = 0;
if (a && 0 < a.length)
for (F = [], f = U = 0; f < a.length; f++)
F.push(
Math.ceil(a[f] ? a[f].createLabelsAndCalculateWidth() : 0)
),
(U += F[f]),
(e += a[f] && !p.isNavigator ? a[f].margin : 0);
else
F.push(Math.ceil(a[0] ? a[0].createLabelsAndCalculateWidth() : 0));
M.push(F);
if (d && 0 < d.length)
for (z = [], f = V = 0; f < d.length; f++)
z.push(
Math.ceil(d[f] ? d[f].createLabelsAndCalculateWidth() : 0)
),
(V += z[f]),
(W += d[f] ? d[f].margin : 0);
else
z.push(Math.ceil(d[0] ? d[0].createLabelsAndCalculateWidth() : 0));
N.push(z);
if (b && 0 < b.length)
for (f = 0; f < b.length; f++)
(b[f].lineCoordinates = {}),
(m = Math.round(g.x1 + U + e)),
(k = Math.round(
g.x2 - V - W > p.width - 10 ? p.width - 10 : g.x2 - V - W
)),
b[f].labelAutoFit &&
!u(C) &&
(0 < !a.length &&
(m =
0 > b[f].labelAngle
? Math.max(m, C)
: 0 === b[f].labelAngle
? Math.max(m, C / 2)
: m),
0 < !d.length &&
(k =
0 < b[f].labelAngle
? k - x / 2
: 0 === b[f].labelAngle
? k - x / 2
: k)),
(b[f].lineCoordinates.x1 = m),
(b[f].lineCoordinates.x2 = k),
(b[f].lineCoordinates.width = Math.abs(k - m)),
b[f].title &&
(b[f]._titleTextBlock.maxWidth =
0 < b[f].titleMaxWidth &&
b[f].titleMaxWidth < b[f].lineCoordinates.width
? b[f].titleMaxWidth
: b[f].lineCoordinates.width);
if (c && 0 < c.length)
for (f = 0; f < c.length; f++)
(c[f].lineCoordinates = {}),
(m = Math.round(g.x1 + U + e)),
(k = Math.round(
g.x2 - V - W > c[f].chart.width - 10
? c[f].chart.width - 10
: g.x2 - V - W
)),
c[f] &&
c[f].labelAutoFit &&
!u(D) &&
(0 < !a.length &&
(m =
0 < c[f].labelAngle
? Math.max(m, D)
: 0 === c[f].labelAngle
? Math.max(m, D / 2)
: m),
0 < !d.length && (k -= y / 2)),
(c[f].lineCoordinates.x1 = m),
(c[f].lineCoordinates.x2 = k),
(c[f].lineCoordinates.width = Math.abs(k - m)),
c[f].title &&
(c[f]._titleTextBlock.maxWidth =
0 < c[f].titleMaxWidth &&
c[f].titleMaxWidth < c[f].lineCoordinates.width
? c[f].titleMaxWidth
: c[f].lineCoordinates.width);
if (b && 0 < b.length)
for (q = [], f = S = 0; f < b.length; f++)
q.push(
Math.ceil(b[f] ? b[f].createLabelsAndCalculateHeight() : 0)
),
(S += q[f] + b[f].margin),
(K += b[f].margin);
else
q.push(Math.ceil(b[0] ? b[0].createLabelsAndCalculateHeight() : 0));
E.push(q);
if (c && 0 < c.length)
for (A = [], f = R = 0; f < c.length; f++)
A.push(
Math.ceil(c[f] ? c[f].createLabelsAndCalculateHeight() : 0)
),
(R += A[f]),
($ += c[f].margin);
else
A.push(Math.ceil(c[0] ? c[0].createLabelsAndCalculateHeight() : 0));
t.push(A);
if (b && 0 < b.length)
for (f = 0; f < b.length; f++)
0 < b[f]._labels.length &&
((h = b[f]._labels[0]),
(l = b[f]._labels[b[f]._labels.length - 1]),
(C =
h.textBlock.width *
Math.cos((Math.PI / 180) * Math.abs(h.textBlock.angle)) +
(h.textBlock.height - l.textBlock.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(h.textBlock.angle))),
(x =
l.textBlock.width *
Math.cos((Math.PI / 180) * Math.abs(l.textBlock.angle)) +
(l.textBlock.height - l.textBlock.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(l.textBlock.angle))));
if (c && 0 < c.length)
for (f = 0; f < c.length; f++)
c[f] &&
0 < c[f]._labels.length &&
((h = c[f]._labels[0]),
(l = c[f]._labels[c[f]._labels.length - 1]),
(D =
h.textBlock.width *
Math.cos((Math.PI / 180) * Math.abs(h.textBlock.angle)) +
(h.textBlock.height - l.textBlock.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(h.textBlock.angle))),
(y =
l.textBlock.width *
Math.cos((Math.PI / 180) * Math.abs(l.textBlock.angle)) +
(l.textBlock.height - l.textBlock.fontSize / 2) *
Math.sin((Math.PI / 180) * Math.abs(l.textBlock.angle))));
if (p.panEnabled)
for (f = 0; f < b.length; f++)
q[f] = p.sessionVariables.axisY.height;
else
for (f = 0; f < b.length; f++)
p.sessionVariables.axisY.height = q[f];
if (b && 0 < b.length)
for (f = b.length - 1; 0 <= f; f--)
(l = Math.round(g.y2)),
(h = Math.round(
g.y2 > b[f].chart.height - 10 ? b[f].chart.height - 10 : g.y2
)),
(b[f].lineCoordinates.y1 = l - (q[f] + b[f].margin + X)),
(b[f].lineCoordinates.y2 = l - (q[f] + b[f].margin + X)),
(b[f].bounds = {
x1: m,
y1: l - (q[f] + X + b[f].margin),
x2: k,
y2: h - (X + b[f].margin),
width: k - m,
height: q[f],
}),
b[f].title &&
(b[f]._titleTextBlock.maxWidth =
0 < b[f].titleMaxWidth &&
b[f].titleMaxWidth < b[f].lineCoordinates.width
? b[f].titleMaxWidth
: b[f].lineCoordinates.width),
(X += q[f] + b[f].margin);
if (c && 0 < c.length)
for (f = c.length - 1; 0 <= f; f--)
c[f] &&
((l = Math.round(g.y1)),
(h = Math.round(g.y1 + (A[f] + c[f].margin + G))),
(c[f].lineCoordinates.y1 = h),
(c[f].lineCoordinates.y2 = h),
(c[f].bounds = {
x1: m,
y1: l + (c[f].margin + G),
x2: k,
y2: h,
width: k - m,
height: R,
}),
c[f].title &&
(c[f]._titleTextBlock.maxWidth =
0 < c[f].titleMaxWidth &&
c[f].titleMaxWidth < c[f].lineCoordinates.width
? c[f].titleMaxWidth
: c[f].lineCoordinates.width),
(G += A[f] + c[f].margin));
if (a && 0 < a.length)
for (f = 0; f < a.length; f++) {
K =
a[f]._labels && 0 < a[f]._labels.length
? a[f]._labels[0].textBlock.fontSize / 2
: 0;
m = Math.round(g.x1 + e);
l =
c && 0 < c.length
? Math.round(
c[0]
? c[0].lineCoordinates.y2
: g.y1 < Math.max(K, 10)
? Math.max(K, 10)
: g.y1
)
: g.y1 < Math.max(K, 10)
? Math.max(K, 10)
: g.y1;
k = Math.round(g.x1 + U + e);
h =
b && 0 < b.length
? Math.round(
b[0]
? b[0].lineCoordinates.y1
: g.y2 - S > p.height - Math.max(K, 10)
? p.height - Math.max(K, 10)
: g.y2 - S
)
: g.y2 > p.height - Math.max(K, 10)
? p.height - Math.max(K, 10)
: g.y2;
if (b && 0 < b.length)
for (K = 0; K < b.length; K++)
b[K] &&
b[K].labelAutoFit &&
((k =
0 > b[K].labelAngle
? Math.max(k, C)
: 0 === b[K].labelAngle
? Math.max(k, C / 2)
: k),
(m =
0 > b[K].labelAngle || 0 === b[K].labelAngle
? k - U
: m));
if (c && 0 < c.length)
for (K = 0; K < c.length; K++)
c[K] &&
c[K].labelAutoFit &&
((k = c[K].lineCoordinates.x1), (m = k - U));
a[f].lineCoordinates = {
x1: k - O,
y1: l,
x2: k - O,
y2: h,
height: Math.abs(h - l),
};
a[f].bounds = {
x1: k - (F[f] + O),
y1: l,
x2: k,
y2: h,
width: k - m,
height: h - l,
};
a[f].title &&
(a[f]._titleTextBlock.maxWidth =
0 < a[f].titleMaxWidth &&
a[f].titleMaxWidth < a[f].lineCoordinates.height
? a[f].titleMaxWidth
: a[f].lineCoordinates.height);
a[f].calculateValueToPixelConversionParameters();
a[f].calculateBreaksSizeInValues();
O += F[f] + a[f].margin;
}
if (d && 0 < d.length)
for (f = 0; f < d.length; f++) {
K =
d[f]._labels && 0 < d[f]._labels.length
? d[f]._labels[0].textBlock.fontSize / 2
: 0;
m = Math.round(g.x1 - e);
l =
c && 0 < c.length
? Math.round(
c[0]
? c[0].lineCoordinates.y2
: g.y1 < Math.max(K, 10)
? Math.max(K, 10)
: g.y1
)
: g.y1 < Math.max(K, 10)
? Math.max(K, 10)
: g.y1;
k = Math.round(g.x2 - V - W);
h =
b && 0 < b.length
? Math.round(
b[0]
? b[0].lineCoordinates.y1
: g.y2 - S > p.height - Math.max(K, 10)
? p.height - Math.max(K, 10)
: g.y2 - S
)
: g.y2 > p.height - Math.max(K, 10)
? p.height - Math.max(K, 10)
: g.y2;
if (b && 0 < b.length)
for (K = 0; K < b.length; K++)
b[K] &&
b[K].labelAutoFit &&
((k =
0 > b[K].labelAngle
? Math.max(k, C)
: 0 === b[K].labelAngle
? Math.max(k, C / 2)
: k),
(m =
0 > b[K].labelAngle || 0 === b[K].labelAngle
? k - V
: m));
if (c && 0 < c.length)
for (K = 0; K < c.length; K++)
c[K] &&
c[K].labelAutoFit &&
((k = c[K].lineCoordinates.x2), (m = k - V));
d[f].lineCoordinates = {
x1: k + Q,
y1: l,
x2: k + Q,
y2: h,
height: Math.abs(h - l),
};
d[f].bounds = {
x1: m,
y1: l,
x2: k + z[f] + Q,
y2: h,
width: k - m,
height: h - l,
};
d[f].title &&
(d[f]._titleTextBlock.maxWidth =
0 < d[f].titleMaxWidth &&
d[f].titleMaxWidth < d[f].lineCoordinates.height
? d[f].titleMaxWidth
: d[f].lineCoordinates.height);
d[f].calculateValueToPixelConversionParameters();
d[f].calculateBreaksSizeInValues();
Q += z[f] + d[f].margin;
}
for (f = 0; f < n.length; f++)
"axisY" === n[f].type &&
(n[f].calculateValueToPixelConversionParameters(),
n[f].calculateBreaksSizeInValues());
if (0 < v) {
if (a && 0 < a.length)
for (f = 0; f < a.length; f++)
r = M[v - 1][f] === M[v][f] ? !0 : !1;
else r = !0;
if (d && 0 < d.length)
for (f = 0; f < d.length; f++)
H = N[v - 1][f] === N[v][f] ? !0 : !1;
else H = !0;
if (b && 0 < b.length)
for (f = 0; f < b.length; f++)
I = E[v - 1][f] === E[v][f] ? !0 : !1;
else I = !0;
if (c && 0 < c.length)
for (f = 0; f < c.length; f++)
L = t[v - 1][f] === t[v][f] ? !0 : !1;
else L = !0;
}
if (r && H && I && L) break;
v++;
}
if (b && 0 < b.length)
for (f = 0; f < b.length; f++)
b[f].calculateStripLinesThicknessInValues(),
b[f].calculateBreaksInPixels();
if (c && 0 < c.length)
for (f = 0; f < c.length; f++)
c[f].calculateStripLinesThicknessInValues(),
c[f].calculateBreaksInPixels();
if (a && 0 < a.length)
for (f = 0; f < a.length; f++)
a[f].calculateStripLinesThicknessInValues(),
a[f].calculateBreaksInPixels();
if (d && 0 < d.length)
for (f = 0; f < d.length; f++)
d[f].calculateStripLinesThicknessInValues(),
d[f].calculateBreaksInPixels();
}
};
z.render = function (a, d, b, c, e) {
var g = a[0] ? a[0].chart : d[0].chart;
e = g.ctx;
var m = g._axes;
g.alignVerticalAxes && g.alignVerticalAxes();
e.save();
e.beginPath();
a[0] &&
e.rect(5, a[0].bounds.y1, a[0].chart.width - 10, a[0].bounds.height);
d[0] &&
e.rect(
5,
d[d.length - 1].bounds.y1,
d[0].chart.width - 10,
d[0].bounds.height
);
e.clip();
if (a && 0 < a.length)
for (var l = 0; l < a.length; l++) a[l].renderLabelsTicksAndTitle();
if (d && 0 < d.length)
for (l = 0; l < d.length; l++) d[l].renderLabelsTicksAndTitle();
e.restore();
if (b && 0 < b.length)
for (l = 0; l < b.length; l++) b[l].renderLabelsTicksAndTitle();
if (c && 0 < c.length)
for (l = 0; l < c.length; l++) c[l].renderLabelsTicksAndTitle();
g.preparePlotArea();
g = g.plotArea;
e.save();
e.beginPath();
e.rect(g.x1, g.y1, Math.abs(g.x2 - g.x1), Math.abs(g.y2 - g.y1));
e.clip();
if (a && 0 < a.length)
for (l = 0; l < m.length; l++)
m[l].renderStripLinesOfThicknessType("value");
if (d && 0 < d.length)
for (l = 0; l < d.length; l++)
d[l].renderStripLinesOfThicknessType("value");
if (b && 0 < b.length)
for (l = 0; l < b.length; l++)
b[l].renderStripLinesOfThicknessType("value");
if (c && 0 < c.length)
for (l = 0; l < c.length; l++)
c[l].renderStripLinesOfThicknessType("value");
if (a && 0 < a.length)
for (l = 0; l < a.length; l++) a[l].renderInterlacedColors();
if (d && 0 < d.length)
for (l = 0; l < d.length; l++) d[l].renderInterlacedColors();
if (b && 0 < b.length)
for (l = 0; l < b.length; l++) b[l].renderInterlacedColors();
if (c && 0 < c.length)
for (l = 0; l < c.length; l++) c[l].renderInterlacedColors();
e.restore();
if (a && 0 < a.length)
for (l = 0; l < a.length; l++)
a[l].renderGrid(),
r && (a[l].createMask(), a[l].renderBreaksBackground());
if (d && 0 < d.length)
for (l = 0; l < d.length; l++)
d[l].renderGrid(),
r && (d[l].createMask(), d[l].renderBreaksBackground());
if (b && 0 < b.length)
for (l = 0; l < b.length; l++)
b[l].renderGrid(),
r && (b[l].createMask(), b[l].renderBreaksBackground());
if (c && 0 < c.length)
for (l = 0; l < c.length; l++)
c[l].renderGrid(),
r && (c[l].createMask(), c[l].renderBreaksBackground());
if (a && 0 < a.length)
for (l = 0; l < a.length; l++) a[l].renderAxisLine();
if (d && 0 < d.length)
for (l = 0; l < d.length; l++) d[l].renderAxisLine();
if (b && 0 < b.length)
for (l = 0; l < b.length; l++) b[l].renderAxisLine();
if (c && 0 < c.length)
for (l = 0; l < c.length; l++) c[l].renderAxisLine();
if (a && 0 < a.length)
for (l = 0; l < a.length; l++)
a[l].renderStripLinesOfThicknessType("pixel");
if (d && 0 < d.length)
for (l = 0; l < d.length; l++)
d[l].renderStripLinesOfThicknessType("pixel");
if (b && 0 < b.length)
for (l = 0; l < b.length; l++)
b[l].renderStripLinesOfThicknessType("pixel");
if (c && 0 < c.length)
for (l = 0; l < c.length; l++)
c[l].renderStripLinesOfThicknessType("pixel");
};
z.prototype.calculateStripLinesThicknessInValues = function () {
for (var a = 0; a < this.stripLines.length; a++)
if (
null !== this.stripLines[a].startValue &&
null !== this.stripLines[a].endValue
) {
var d = Math.min(
this.stripLines[a].startValue,
this.stripLines[a].endValue
),
b = Math.max(
this.stripLines[a].startValue,
this.stripLines[a].endValue
),
d = this.getApparentDifference(d, b);
this.stripLines[a].value = this.logarithmic
? this.stripLines[a].value *
Math.sqrt(
Math.log(
this.stripLines[a].endValue / this.stripLines[a].startValue
) / Math.log(d)
)
: this.stripLines[a].value +
(Math.abs(
this.stripLines[a].endValue - this.stripLines[a].startValue
) -
d) /
2;
this.stripLines[a].thickness = d;
this.stripLines[a]._thicknessType = "value";
}
};
z.prototype.calculateBreaksSizeInValues = function () {
for (
var a =
"left" === this._position || "right" === this._position
? this.lineCoordinates.height || this.chart.height
: this.lineCoordinates.width || this.chart.width,
d = this.scaleBreaks ? this.scaleBreaks._appliedBreaks : [],
b =
this.conversionParameters.pixelPerUnit ||
a /
(this.logarithmic
? this.conversionParameters.maximum /
this.conversionParameters.minimum
: this.conversionParameters.maximum -
this.conversionParameters.minimum),
c = this.scaleBreaks && !u(this.scaleBreaks.options.spacing),
e,
g = 0;
g < d.length;
g++
)
(e = c || !u(d[g].options.spacing)),
(d[g].spacing =
I(d[g].spacing, a, 8, e ? 0.1 * a : 8, e ? 0 : 3) << 0),
(d[g].size = 0 > d[g].spacing ? 0 : Math.abs(d[g].spacing / b)),
this.logarithmic &&
(d[g].size = Math.pow(this.logarithmBase, d[g].size));
};
z.prototype.calculateBreaksInPixels = function () {
if (!(this.scaleBreaks && 0 >= this.scaleBreaks._appliedBreaks.length)) {
var a = this.scaleBreaks ? this.scaleBreaks._appliedBreaks : [];
a.length &&
(this.scaleBreaks.firstBreakIndex = this.scaleBreaks.lastBreakIndex =
null);
for (
var d = 0;
d < a.length &&
!(a[d].startValue > this.conversionParameters.maximum);
d++
)
a[d].endValue < this.conversionParameters.minimum ||
(u(this.scaleBreaks.firstBreakIndex) &&
(this.scaleBreaks.firstBreakIndex = d),
a[d].startValue >= this.conversionParameters.minimum &&
((a[d].startPixel = this.convertValueToPixel(a[d].startValue)),
(this.scaleBreaks.lastBreakIndex = d)),
a[d].endValue <= this.conversionParameters.maximum &&
(a[d].endPixel = this.convertValueToPixel(a[d].endValue)));
}
};
z.prototype.renderLabelsTicksAndTitle = function () {
var a = this,
d = !1,
b = 0,
c = 0,
e = 1,
g = 0;
0 !== this.labelAngle && 360 !== this.labelAngle && (e = 1.2);
if ("undefined" === typeof this.options.interval) {
if ("bottom" === this._position || "top" === this._position)
if (
this.logarithmic &&
!this.equidistantInterval &&
this.labelAutoFit
) {
for (
var b = [],
e = 0 !== this.labelAngle && 360 !== this.labelAngle ? 1 : 1.2,
m,
l = this.viewportMaximum,
k = this.lineCoordinates.width / Math.log(this.range),
h = this._labels.length - 1;
0 <= h;
h--
) {
q = this._labels[h];
if (q.position < this.viewportMinimum) break;
q.position > this.viewportMaximum ||
!(
h === this._labels.length - 1 ||
m < (Math.log(l / q.position) * k) / e
) ||
(b.push(q),
(l = q.position),
(m =
q.textBlock.width *
Math.abs(Math.cos((Math.PI / 180) * this.labelAngle)) +
q.textBlock.height *
Math.abs(Math.sin((Math.PI / 180) * this.labelAngle))));
}
this._labels = b;
} else {
for (h = 0; h < this._labels.length; h++)
(q = this._labels[h]),
q.position < this.viewportMinimum ||
((m =
q.textBlock.width *
Math.abs(Math.cos((Math.PI / 180) * this.labelAngle)) +
q.textBlock.height *
Math.abs(Math.sin((Math.PI / 180) * this.labelAngle))),
(b += m));
b > this.lineCoordinates.width * e && this.labelAutoFit && (d = !0);
}
if ("left" === this._position || "right" === this._position)
if (
this.logarithmic &&
!this.equidistantInterval &&
this.labelAutoFit
) {
for (
var b = [],
p,
l = this.viewportMaximum,
k = this.lineCoordinates.height / Math.log(this.range),
h = this._labels.length - 1;
0 <= h;
h--
) {
q = this._labels[h];
if (q.position < this.viewportMinimum) break;
q.position > this.viewportMaximum ||
!(
h === this._labels.length - 1 ||
p < Math.log(l / q.position) * k
) ||
(b.push(q),
(l = q.position),
(p =
q.textBlock.height *
Math.abs(Math.cos((Math.PI / 180) * this.labelAngle)) +
q.textBlock.width *
Math.abs(Math.sin((Math.PI / 180) * this.labelAngle))));
}
this._labels = b;
} else {
for (h = 0; h < this._labels.length; h++)
(q = this._labels[h]),
q.position < this.viewportMinimum ||
((p =
q.textBlock.height *
Math.abs(Math.cos((Math.PI / 180) * this.labelAngle)) +
q.textBlock.width *
Math.abs(Math.sin((Math.PI / 180) * this.labelAngle))),
(c += p));
c > this.lineCoordinates.height * e &&
this.labelAutoFit &&
(d = !0);
}
}
this.logarithmic &&
!this.equidistantInterval &&
this.labelAutoFit &&
this._labels.sort(function (a, b) {
return a.position - b.position;
});
var h = 0,
q,
n;
if ("bottom" === this._position) {
for (h = 0; h < this._labels.length; h++)
(q = this._labels[h]),
q.position < this.viewportMinimum ||
q.position > this.viewportMaximum ||
(d && 0 !== g++ % 2 && this.labelAutoFit) ||
((n = this.getPixelCoordinatesOnAxis(q.position)),
this.tickThickness &&
"inside" != this.labelPlacement &&
((this.ctx.lineWidth = this.tickThickness),
(this.ctx.strokeStyle = this.tickColor),
(c =
1 === this.ctx.lineWidth % 2 ? (n.x << 0) + 0.5 : n.x << 0),
this.ctx.beginPath(),
this.ctx.moveTo(c, n.y << 0),
this.ctx.lineTo(c, (n.y + this.tickLength) << 0),
this.ctx.stroke()),
0 === q.textBlock.angle
? ((n.x -= q.textBlock.width / 2),
(n.y =
"inside" === this.labelPlacement
? n.y - (this.tickLength + q.textBlock.fontSize / 2)
: n.y + this.tickLength + q.textBlock.fontSize / 2))
: ((n.x =
"inside" === this.labelPlacement
? 0 > this.labelAngle
? n.x
: n.x -
q.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle)
: n.x -
(0 > this.labelAngle
? q.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle)
: 0)),
(n.y =
"inside" === this.labelPlacement
? 0 > this.labelAngle
? n.y - this.tickLength - 5
: n.y -
this.tickLength -
Math.abs(
q.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle) +
5
)
: n.y +
this.tickLength +
Math.abs(
0 > this.labelAngle
? q.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle) -
5
: 5
))),
(q.textBlock.x = n.x),
(q.textBlock.y = n.y));
"inside" === this.labelPlacement &&
this.chart.addEventListener(
"dataAnimationIterationEnd",
function () {
for (h = 0; h < a._labels.length; h++)
if (
((q = a._labels[h]),
!(
q.position < a.viewportMinimum ||
q.position > a.viewportMaximum ||
(d && 0 !== g++ % 2 && a.labelAutoFit)
) &&
((n = a.getPixelCoordinatesOnAxis(q.position)),
a.tickThickness))
) {
a.ctx.lineWidth = a.tickThickness;
a.ctx.strokeStyle = a.tickColor;
var b =
1 === a.ctx.lineWidth % 2 ? (n.x << 0) + 0.5 : n.x << 0;
a.ctx.save();
a.ctx.beginPath();
a.ctx.moveTo(b, n.y << 0);
a.ctx.lineTo(b, (n.y - a.tickLength) << 0);
a.ctx.stroke();
a.ctx.restore();
}
},
this
);
this.title &&
(this._titleTextBlock.measureText(),
(this._titleTextBlock.x =
this.lineCoordinates.x1 +
this.lineCoordinates.width / 2 -
this._titleTextBlock.width / 2),
(this._titleTextBlock.y =
this.bounds.y2 - this._titleTextBlock.height - 3),
(this.titleMaxWidth = this._titleTextBlock.maxWidth),
this._titleTextBlock.render(!0));
} else if ("top" === this._position) {
for (h = 0; h < this._labels.length; h++)
(q = this._labels[h]),
q.position < this.viewportMinimum ||
q.position > this.viewportMaximum ||
(d && 0 !== g++ % 2 && this.labelAutoFit) ||
((n = this.getPixelCoordinatesOnAxis(q.position)),
this.tickThickness &&
"inside" != this.labelPlacement &&
((this.ctx.lineWidth = this.tickThickness),
(this.ctx.strokeStyle = this.tickColor),
(c =
1 === this.ctx.lineWidth % 2 ? (n.x << 0) + 0.5 : n.x << 0),
this.ctx.beginPath(),
this.ctx.moveTo(c, n.y << 0),
this.ctx.lineTo(c, (n.y - this.tickLength) << 0),
this.ctx.stroke()),
0 === q.textBlock.angle
? ((n.x -= q.textBlock.width / 2),
(n.y =
"inside" === this.labelPlacement
? n.y + this.labelFontSize / 2 + this.tickLength + 5
: n.y -
(this.tickLength +
q.textBlock.height -
q.textBlock.fontSize / 2)))
: ((n.x =
"inside" === this.labelPlacement
? 0 < this.labelAngle
? n.x
: n.x -
q.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle)
: n.x +
(q.textBlock.height -
this.tickLength -
this.labelFontSize) *
Math.sin((Math.PI / 180) * this.labelAngle) -
(0 < this.labelAngle
? q.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle)
: 0)),
(n.y =
"inside" === this.labelPlacement
? 0 < this.labelAngle
? n.y + this.tickLength + 5
: n.y -
q.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle) +
this.tickLength +
5
: n.y -
(this.tickLength +
((q.textBlock.height - q.textBlock.fontSize / 2) *
Math.cos((Math.PI / 180) * this.labelAngle) +
(0 < this.labelAngle
? q.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle)
: 0))))),
(q.textBlock.x = n.x),
(q.textBlock.y = n.y));
"inside" === this.labelPlacement &&
this.chart.addEventListener(
"dataAnimationIterationEnd",
function () {
for (h = 0; h < a._labels.length; h++)
if (
((q = a._labels[h]),
!(
q.position < a.viewportMinimum ||
q.position > a.viewportMaximum ||
(d && 0 !== g++ % 2 && a.labelAutoFit)
) &&
((n = a.getPixelCoordinatesOnAxis(q.position)),
a.tickThickness))
) {
a.ctx.lineWidth = a.tickThickness;
a.ctx.strokeStyle = a.tickColor;
var b =
1 === this.ctx.lineWidth % 2 ? (n.x << 0) + 0.5 : n.x << 0;
a.ctx.save();
a.ctx.beginPath();
a.ctx.moveTo(b, n.y << 0);
a.ctx.lineTo(b, (n.y + a.tickLength) << 0);
a.ctx.stroke();
a.ctx.restore();
}
},
this
);
this.title &&
(this._titleTextBlock.measureText(),
(this._titleTextBlock.x =
this.lineCoordinates.x1 +
this.lineCoordinates.width / 2 -
this._titleTextBlock.width / 2),
(this._titleTextBlock.y = this.bounds.y1 + 1),
(this.titleMaxWidth = this._titleTextBlock.maxWidth),
this._titleTextBlock.render(!0));
} else if ("left" === this._position) {
for (h = 0; h < this._labels.length; h++)
(q = this._labels[h]),
q.position < this.viewportMinimum ||
q.position > this.viewportMaximum ||
(d && 0 !== g++ % 2 && this.labelAutoFit) ||
((n = this.getPixelCoordinatesOnAxis(q.position)),
this.tickThickness &&
"inside" != this.labelPlacement &&
((this.ctx.lineWidth = this.tickThickness),
(this.ctx.strokeStyle = this.tickColor),
(c =
1 === this.ctx.lineWidth % 2 ? (n.y << 0) + 0.5 : n.y << 0),
this.ctx.beginPath(),
this.ctx.moveTo(n.x << 0, c),
this.ctx.lineTo((n.x - this.tickLength) << 0, c),
this.ctx.stroke()),
0 === this.labelAngle
? ((q.textBlock.y = n.y),
(q.textBlock.x =
"inside" === this.labelPlacement
? n.x + this.tickLength + 5
: n.x -
q.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle) -
this.tickLength -
5))
: ((q.textBlock.y =
"inside" === this.labelPlacement
? n.y
: n.y -
q.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle)),
(q.textBlock.x =
"inside" === this.labelPlacement
? n.x + this.tickLength + 5
: 0 < this.labelAngle
? n.x -
q.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle) -
this.tickLength -
5
: n.x -
q.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle) +
(q.textBlock.height - q.textBlock.fontSize / 2 - 5) *
Math.sin((Math.PI / 180) * this.labelAngle) -
this.tickLength)));
"inside" === this.labelPlacement &&
this.chart.addEventListener(
"dataAnimationIterationEnd",
function () {
for (h = 0; h < a._labels.length; h++)
if (
((q = a._labels[h]),
!(
q.position < a.viewportMinimum ||
q.position > a.viewportMaximum ||
(d && 0 !== g++ % 2 && a.labelAutoFit)
) &&
((n = a.getPixelCoordinatesOnAxis(q.position)),
a.tickThickness))
) {
a.ctx.lineWidth = a.tickThickness;
a.ctx.strokeStyle = a.tickColor;
var b =
1 === a.ctx.lineWidth % 2 ? (n.y << 0) + 0.5 : n.y << 0;
a.ctx.save();
a.ctx.beginPath();
a.ctx.moveTo(n.x << 0, b);
a.ctx.lineTo((n.x + a.tickLength) << 0, b);
a.ctx.stroke();
a.ctx.restore();
}
},
this
);
this.title &&
(this._titleTextBlock.measureText(),
(this._titleTextBlock.x = this.bounds.x1 + 1),
(this._titleTextBlock.y =
this.lineCoordinates.height / 2 +
this._titleTextBlock.width / 2 +
this.lineCoordinates.y1),
(this.titleMaxWidth = this._titleTextBlock.maxWidth),
this._titleTextBlock.render(!0));
} else if ("right" === this._position) {
for (h = 0; h < this._labels.length; h++)
(q = this._labels[h]),
q.position < this.viewportMinimum ||
q.position > this.viewportMaximum ||
(d && 0 !== g++ % 2 && this.labelAutoFit) ||
((n = this.getPixelCoordinatesOnAxis(q.position)),
this.tickThickness &&
"inside" != this.labelPlacement &&
((this.ctx.lineWidth = this.tickThickness),
(this.ctx.strokeStyle = this.tickColor),
(c =
1 === this.ctx.lineWidth % 2 ? (n.y << 0) + 0.5 : n.y << 0),
this.ctx.beginPath(),
this.ctx.moveTo(n.x << 0, c),
this.ctx.lineTo((n.x + this.tickLength) << 0, c),
this.ctx.stroke()),
0 === this.labelAngle
? ((q.textBlock.y = n.y),
(q.textBlock.x =
"inside" === this.labelPlacement
? n.x - q.textBlock.width - this.tickLength - 5
: n.x + this.tickLength + 5))
: ((q.textBlock.y =
"inside" === this.labelPlacement
? n.y -
q.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle)
: 0 > this.labelAngle
? n.y
: n.y -
(q.textBlock.height - q.textBlock.fontSize / 2 - 5) *
Math.cos((Math.PI / 180) * this.labelAngle)),
(q.textBlock.x =
"inside" === this.labelPlacement
? n.x -
q.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle) -
this.tickLength -
5
: 0 < this.labelAngle
? n.x +
(q.textBlock.height - q.textBlock.fontSize / 2 - 5) *
Math.sin((Math.PI / 180) * this.labelAngle) +
this.tickLength
: n.x + this.tickLength + 5)));
"inside" === this.labelPlacement &&
this.chart.addEventListener(
"dataAnimationIterationEnd",
function () {
for (h = 0; h < a._labels.length; h++)
if (
((q = a._labels[h]),
!(
q.position < a.viewportMinimum ||
q.position > a.viewportMaximum ||
(d && 0 !== g++ % 2 && a.labelAutoFit)
) &&
((n = a.getPixelCoordinatesOnAxis(q.position)),
a.tickThickness))
) {
a.ctx.lineWidth = a.tickThickness;
a.ctx.strokeStyle = a.tickColor;
var b =
1 === a.ctx.lineWidth % 2 ? (n.y << 0) + 0.5 : n.y << 0;
a.ctx.save();
a.ctx.beginPath();
a.ctx.moveTo(n.x << 0, b);
a.ctx.lineTo((n.x - a.tickLength) << 0, b);
a.ctx.stroke();
a.ctx.restore();
}
},
this
);
this.title &&
(this._titleTextBlock.measureText(),
(this._titleTextBlock.x = this.bounds.x2 - 1),
(this._titleTextBlock.y =
this.lineCoordinates.height / 2 -
this._titleTextBlock.width / 2 +
this.lineCoordinates.y1),
(this.titleMaxWidth = this._titleTextBlock.maxWidth),
this._titleTextBlock.render(!0));
}
g = 0;
if ("inside" === this.labelPlacement)
this.chart.addEventListener(
"dataAnimationIterationEnd",
function () {
for (h = 0; h < a._labels.length; h++)
(q = a._labels[h]),
q.position < a.viewportMinimum ||
q.position > a.viewportMaximum ||
(d && 0 !== g++ % 2 && a.labelAutoFit) ||
(a.ctx.save(),
a.ctx.beginPath(),
q.textBlock.render(!0),
a.ctx.restore());
},
this
);
else
for (h = 0; h < this._labels.length; h++)
(q = this._labels[h]),
q.position < this.viewportMinimum ||
q.position > this.viewportMaximum ||
(d && 0 !== g++ % 2 && this.labelAutoFit) ||
q.textBlock.render(!0);
};
z.prototype.renderInterlacedColors = function () {
var a = this.chart.plotArea.ctx,
d,
b,
c = this.chart.plotArea,
e = 0;
d = !0;
if (
("bottom" === this._position || "top" === this._position) &&
this.interlacedColor
)
for (
a.fillStyle = this.interlacedColor, e = 0;
e < this._labels.length;
e++
)
d
? ((d = this.getPixelCoordinatesOnAxis(this._labels[e].position)),
(b =
e + 1 > this._labels.length - 1
? this.getPixelCoordinatesOnAxis(this.viewportMaximum)
: this.getPixelCoordinatesOnAxis(
this._labels[e + 1].position
)),
a.fillRect(
Math.min(b.x, d.x),
c.y1,
Math.abs(b.x - d.x),
Math.abs(c.y1 - c.y2)
),
(d = !1))
: (d = !0);
else if (
("left" === this._position || "right" === this._position) &&
this.interlacedColor
)
for (
a.fillStyle = this.interlacedColor, e = 0;
e < this._labels.length;
e++
)
d
? ((b = this.getPixelCoordinatesOnAxis(this._labels[e].position)),
(d =
e + 1 > this._labels.length - 1
? this.getPixelCoordinatesOnAxis(this.viewportMaximum)
: this.getPixelCoordinatesOnAxis(
this._labels[e + 1].position
)),
a.fillRect(
c.x1,
Math.min(b.y, d.y),
Math.abs(c.x1 - c.x2),
Math.abs(d.y - b.y)
),
(d = !1))
: (d = !0);
a.beginPath();
};
z.prototype.renderStripLinesOfThicknessType = function (a) {
if (this.stripLines && 0 < this.stripLines.length && a) {
for (
var d = this,
b,
c = 0,
e = 0,
g = !1,
m = !1,
l = [],
k = [],
m = !1,
c = 0;
c < this.stripLines.length;
c++
) {
var h = this.stripLines[c];
h._thicknessType === a &&
(("pixel" === a &&
(h.value < this.viewportMinimum ||
h.value > this.viewportMaximum ||
u(h.value) ||
isNaN(this.range))) ||
l.push(h));
}
for (c = 0; c < this._stripLineLabels.length; c++)
if (
((h = this.stripLines[c]),
(b = this._stripLineLabels[c]),
!(
b.position < this.viewportMinimum ||
b.position > this.viewportMaximum ||
isNaN(this.range)
))
) {
a = this.getPixelCoordinatesOnAxis(b.position);
if ("outside" === b.stripLine.labelPlacement)
if (
(h &&
((this.ctx.strokeStyle = h.color),
"pixel" === h._thicknessType &&
(this.ctx.lineWidth = h.thickness)),
"bottom" === this._position)
) {
var p =
1 === this.ctx.lineWidth % 2 ? (a.x << 0) + 0.5 : a.x << 0;
this.ctx.beginPath();
this.ctx.moveTo(p, a.y << 0);
this.ctx.lineTo(p, (a.y + this.tickLength) << 0);
this.ctx.stroke();
0 === this.labelAngle
? ((a.x -= b.textBlock.width / 2),
(a.y += this.tickLength + b.textBlock.fontSize / 2))
: ((a.x -=
0 > this.labelAngle
? b.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle)
: 0),
(a.y +=
this.tickLength +
Math.abs(
0 > this.labelAngle
? b.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle) -
5
: 5
)));
} else
"top" === this._position
? ((p =
1 === this.ctx.lineWidth % 2
? (a.x << 0) + 0.5
: a.x << 0),
this.ctx.beginPath(),
this.ctx.moveTo(p, a.y << 0),
this.ctx.lineTo(p, (a.y - this.tickLength) << 0),
this.ctx.stroke(),
0 === this.labelAngle
? ((a.x -= b.textBlock.width / 2),
(a.y -= this.tickLength + b.textBlock.height))
: ((a.x +=
(b.textBlock.height -
this.tickLength -
this.labelFontSize / 2) *
Math.sin((Math.PI / 180) * this.labelAngle) -
(0 < this.labelAngle
? b.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle)
: 0)),
(a.y -=
this.tickLength +
(b.textBlock.height *
Math.cos((Math.PI / 180) * this.labelAngle) +
(0 < this.labelAngle
? b.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle)
: 0)))))
: "left" === this._position
? ((p =
1 === this.ctx.lineWidth % 2
? (a.y << 0) + 0.5
: a.y << 0),
this.ctx.beginPath(),
this.ctx.moveTo(a.x << 0, p),
this.ctx.lineTo((a.x - this.tickLength) << 0, p),
this.ctx.stroke(),
0 === this.labelAngle
? (a.x =
a.x -
b.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle) -
this.tickLength -
5)
: ((a.y -=
b.textBlock.width *
Math.sin((Math.PI / 180) * this.labelAngle)),
(a.x =
0 < this.labelAngle
? a.x -
b.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle) -
this.tickLength -
5
: a.x -
b.textBlock.width *
Math.cos((Math.PI / 180) * this.labelAngle) +
(b.textBlock.height -
b.textBlock.fontSize / 2 -
5) *
Math.sin((Math.PI / 180) * this.labelAngle) -
this.tickLength)))
: "right" === this._position &&
((p =
1 === this.ctx.lineWidth % 2
? (a.y << 0) + 0.5
: a.y << 0),
this.ctx.beginPath(),
this.ctx.moveTo(a.x << 0, p),
this.ctx.lineTo((a.x + this.tickLength) << 0, p),
this.ctx.stroke(),
0 === this.labelAngle
? (a.x = a.x + this.tickLength + 5)
: ((a.y =
0 > this.labelAngle
? a.y
: a.y -
(b.textBlock.height -
b.textBlock.fontSize / 2 -
5) *
Math.cos((Math.PI / 180) * this.labelAngle)),
(a.x =
0 < this.labelAngle
? a.x +
(b.textBlock.height -
b.textBlock.fontSize / 2 -
5) *
Math.sin((Math.PI / 180) * this.labelAngle) +
this.tickLength
: a.x + this.tickLength + 5)));
else
(b.textBlock.angle = -90),
"bottom" === this._position
? ((b.textBlock.maxWidth = this.options.stripLines[c]
.labelMaxWidth
? this.options.stripLines[c].labelMaxWidth
: this.chart.plotArea.height - 3),
b.textBlock.measureText(),
a.x - b.textBlock.height > this.chart.plotArea.x1
? u(h.startValue)
? (a.x -= b.textBlock.height - b.textBlock.fontSize / 2)
: (a.x -=
b.textBlock.height / 2 -
b.textBlock.fontSize / 2 +
3)
: ((b.textBlock.angle = 90),
u(h.startValue)
? (a.x +=
b.textBlock.height - b.textBlock.fontSize / 2)
: (a.x +=
b.textBlock.height / 2 -
b.textBlock.fontSize / 2 +
3)),
(a.y =
-90 === b.textBlock.angle
? "near" === b.stripLine.labelAlign
? this.chart.plotArea.y2 - 3
: "center" === b.stripLine.labelAlign
? (this.chart.plotArea.y2 +
this.chart.plotArea.y1 +
b.textBlock.width) /
2
: this.chart.plotArea.y1 + b.textBlock.width + 3
: "near" === b.stripLine.labelAlign
? this.chart.plotArea.y2 - b.textBlock.width - 3
: "center" === b.stripLine.labelAlign
? (this.chart.plotArea.y2 +
this.chart.plotArea.y1 -
b.textBlock.width) /
2
: this.chart.plotArea.y1 + 3))
: "top" === this._position
? ((b.textBlock.maxWidth = this.options.stripLines[c]
.labelMaxWidth
? this.options.stripLines[c].labelMaxWidth
: this.chart.plotArea.height - 3),
b.textBlock.measureText(),
a.x - b.textBlock.height > this.chart.plotArea.x1
? u(h.startValue)
? (a.x -= b.textBlock.height - b.textBlock.fontSize / 2)
: (a.x -=
b.textBlock.height / 2 -
b.textBlock.fontSize / 2 +
3)
: ((b.textBlock.angle = 90),
u(h.startValue)
? (a.x +=
b.textBlock.height - b.textBlock.fontSize / 2)
: (a.x +=
b.textBlock.height / 2 -
b.textBlock.fontSize / 2 +
3)),
(a.y =
-90 === b.textBlock.angle
? "near" === b.stripLine.labelAlign
? this.chart.plotArea.y1 + b.textBlock.width + 3
: "center" === b.stripLine.labelAlign
? (this.chart.plotArea.y2 +
this.chart.plotArea.y1 +
b.textBlock.width) /
2
: this.chart.plotArea.y2 - 3
: "near" === b.stripLine.labelAlign
? this.chart.plotArea.y1 + 3
: "center" === b.stripLine.labelAlign
? (this.chart.plotArea.y2 +
this.chart.plotArea.y1 -
b.textBlock.width) /
2
: this.chart.plotArea.y2 - b.textBlock.width - 3))
: "left" === this._position
? ((b.textBlock.maxWidth = this.options.stripLines[c]
.labelMaxWidth
? this.options.stripLines[c].labelMaxWidth
: this.chart.plotArea.width - 3),
(b.textBlock.angle = 0),
b.textBlock.measureText(),
a.y - b.textBlock.height > this.chart.plotArea.y1
? u(h.startValue)
? (a.y -= b.textBlock.height - b.textBlock.fontSize / 2)
: (a.y -=
b.textBlock.height / 2 - b.textBlock.fontSize + 3)
: a.y - b.textBlock.height < this.chart.plotArea.y2
? (a.y += b.textBlock.fontSize / 2 + 3)
: u(h.startValue)
? (a.y -= b.textBlock.height - b.textBlock.fontSize / 2)
: (a.y -=
b.textBlock.height / 2 - b.textBlock.fontSize + 3),
(a.x =
"near" === b.stripLine.labelAlign
? this.chart.plotArea.x1 + 3
: "center" === b.stripLine.labelAlign
? (this.chart.plotArea.x2 + this.chart.plotArea.x1) /
2 -
b.textBlock.width / 2
: this.chart.plotArea.x2 - b.textBlock.width - 3))
: "right" === this._position &&
((b.textBlock.maxWidth = this.options.stripLines[c]
.labelMaxWidth
? this.options.stripLines[c].labelMaxWidth
: this.chart.plotArea.width - 3),
(b.textBlock.angle = 0),
b.textBlock.measureText(),
a.y - +b.textBlock.height > this.chart.plotArea.y1
? u(h.startValue)
? (a.y -= b.textBlock.height - b.textBlock.fontSize / 2)
: (a.y -=
b.textBlock.height / 2 -
b.textBlock.fontSize / 2 -
3)
: a.y - b.textBlock.height < this.chart.plotArea.y2
? (a.y += b.textBlock.fontSize / 2 + 3)
: u(h.startValue)
? (a.y -= b.textBlock.height - b.textBlock.fontSize / 2)
: (a.y -=
b.textBlock.height / 2 -
b.textBlock.fontSize / 2 +
3),
(a.x =
"near" === b.stripLine.labelAlign
? this.chart.plotArea.x2 - b.textBlock.width - 3
: "center" === b.stripLine.labelAlign
? (this.chart.plotArea.x2 + this.chart.plotArea.x1) /
2 -
b.textBlock.width / 2
: this.chart.plotArea.x1 + 3));
b.textBlock.x = a.x;
b.textBlock.y = a.y;
k.push(b);
}
if (!m) {
m = !1;
this.ctx.save();
this.ctx.beginPath();
this.ctx.rect(
this.chart.plotArea.x1,
this.chart.plotArea.y1,
this.chart.plotArea.width,
this.chart.plotArea.height
);
this.ctx.clip();
for (c = 0; c < l.length; c++)
(h = l[c]),
h.showOnTop
? g ||
((g = !0),
this.chart.addEventListener(
"dataAnimationIterationEnd",
function () {
this.ctx.save();
this.ctx.beginPath();
this.ctx.rect(
this.chart.plotArea.x1,
this.chart.plotArea.y1,
this.chart.plotArea.width,
this.chart.plotArea.height
);
this.ctx.clip();
for (e = 0; e < l.length; e++)
(h = l[e]), h.showOnTop && h.render();
this.ctx.restore();
},
h
))
: h.render();
for (c = 0; c < k.length; c++)
(b = k[c]),
b.stripLine.showOnTop
? m ||
((m = !0),
this.chart.addEventListener(
"dataAnimationIterationEnd",
function () {
for (e = 0; e < k.length; e++)
(b = k[e]),
"inside" === b.stripLine.labelPlacement &&
b.stripLine.showOnTop &&
(d.ctx.save(),
d.ctx.beginPath(),
d.ctx.rect(
d.chart.plotArea.x1,
d.chart.plotArea.y1,
d.chart.plotArea.width,
d.chart.plotArea.height
),
d.ctx.clip(),
b.textBlock.render(!0),
d.ctx.restore());
},
b.textBlock
))
: "inside" === b.stripLine.labelPlacement &&
b.textBlock.render(!0);
this.ctx.restore();
m = !0;
}
if (m)
for (m = !1, c = 0; c < k.length; c++)
(b = k[c]),
b.stripLine.showOnTop
? m ||
((m = !0),
this.chart.addEventListener(
"dataAnimationIterationEnd",
function () {
for (e = 0; e < k.length; e++)
(b = k[e]),
"outside" === b.stripLine.labelPlacement &&
b.stripLine.showOnTop &&
b.textBlock.render(!0);
},
b.textBlock
))
: "outside" === b.stripLine.labelPlacement &&
b.textBlock.render(!0);
}
};
z.prototype.renderBreaksBackground = function () {
this.chart._breaksCanvas &&
this.scaleBreaks &&
0 < this.scaleBreaks._appliedBreaks.length &&
this.maskCanvas &&
(this.chart._breaksCanvasCtx.save(),
this.chart._breaksCanvasCtx.beginPath(),
this.chart._breaksCanvasCtx.rect(
this.chart.plotArea.x1,
this.chart.plotArea.y1,
this.chart.plotArea.width,
this.chart.plotArea.height
),
this.chart._breaksCanvasCtx.clip(),
this.chart._breaksCanvasCtx.drawImage(
this.maskCanvas,
0,
0,
this.chart.width,
this.chart.height
),
this.chart._breaksCanvasCtx.restore());
};
z.prototype.createMask = function () {
if (this.scaleBreaks && 0 < this.scaleBreaks._appliedBreaks.length) {
var a = this.scaleBreaks._appliedBreaks;
r
? ((this.maskCanvas = ta(this.chart.width, this.chart.height)),
(this.maskCtx = this.maskCanvas.getContext("2d")))
: ((this.maskCanvas = this.chart.plotArea.canvas),
(this.maskCtx = this.chart.plotArea.ctx));
this.maskCtx.save();
this.maskCtx.beginPath();
this.maskCtx.rect(
this.chart.plotArea.x1,
this.chart.plotArea.y1,
this.chart.plotArea.width,
this.chart.plotArea.height
);
this.maskCtx.clip();
for (var d = 0; d < a.length; d++)
a[d].endValue < this.viewportMinimum ||
a[d].startValue > this.viewportMaximum ||
isNaN(this.range) ||
a[d].render(this.maskCtx);
this.maskCtx.restore();
}
};
z.prototype.renderCrosshair = function (a, d) {
this.crosshair.render(a, d);
};
z.prototype.renderGrid = function () {
if (this.gridThickness && 0 < this.gridThickness) {
var a = this.chart.ctx;
a.save();
var d,
b = this.chart.plotArea;
a.lineWidth = this.gridThickness;
a.strokeStyle = this.gridColor;
a.setLineDash &&
a.setLineDash(R(this.gridDashType, this.gridThickness));
if ("bottom" === this._position || "top" === this._position)
for (c = 0; c < this._labels.length; c++)
this._labels[c].position < this.viewportMinimum ||
this._labels[c].position > this.viewportMaximum ||
this._labels[c].breaksLabelType ||
(a.beginPath(),
(d = this.getPixelCoordinatesOnAxis(this._labels[c].position)),
(d = 1 === a.lineWidth % 2 ? (d.x << 0) + 0.5 : d.x << 0),
a.moveTo(d, b.y1 << 0),
a.lineTo(d, b.y2 << 0),
a.stroke());
else if ("left" === this._position || "right" === this._position)
for (var c = 0; c < this._labels.length; c++)
this._labels[c].position < this.viewportMinimum ||
this._labels[c].position > this.viewportMaximum ||
this._labels[c].breaksLabelType ||
(a.beginPath(),
(d = this.getPixelCoordinatesOnAxis(this._labels[c].position)),
(d = 1 === a.lineWidth % 2 ? (d.y << 0) + 0.5 : d.y << 0),
a.moveTo(b.x1 << 0, d),
a.lineTo(b.x2 << 0, d),
a.stroke());
a.restore();
}
};
z.prototype.renderAxisLine = function () {
var a = this.chart.ctx,
d = r ? this.chart._preRenderCtx : a,
b = Math.ceil(this.tickThickness / (this.reversed ? -2 : 2)),
c = Math.ceil(this.tickThickness / (this.reversed ? 2 : -2)),
e,
g;
d.save();
if ("bottom" === this._position || "top" === this._position) {
if (this.lineThickness) {
this.reversed
? ((e = this.lineCoordinates.x2), (g = this.lineCoordinates.x1))
: ((e = this.lineCoordinates.x1), (g = this.lineCoordinates.x2));
d.lineWidth = this.lineThickness;
d.strokeStyle = this.lineColor ? this.lineColor : "black";
d.setLineDash &&
d.setLineDash(R(this.lineDashType, this.lineThickness));
var m =
1 === this.lineThickness % 2
? (this.lineCoordinates.y1 << 0) + 0.5
: this.lineCoordinates.y1 << 0;
d.beginPath();
if (this.scaleBreaks && !u(this.scaleBreaks.firstBreakIndex))
if (u(this.scaleBreaks.lastBreakIndex))
e =
this.scaleBreaks._appliedBreaks[
this.scaleBreaks.firstBreakIndex
].endPixel + c;
else
for (
var l = this.scaleBreaks.firstBreakIndex;
l <= this.scaleBreaks.lastBreakIndex;
l++
)
d.moveTo(e, m),
d.lineTo(
this.scaleBreaks._appliedBreaks[l].startPixel + b,
m
),
(e = this.scaleBreaks._appliedBreaks[l].endPixel + c);
e && (d.moveTo(e, m), d.lineTo(g, m));
d.stroke();
}
} else if (
("left" === this._position || "right" === this._position) &&
this.lineThickness
) {
this.reversed
? ((e = this.lineCoordinates.y1), (g = this.lineCoordinates.y2))
: ((e = this.lineCoordinates.y2), (g = this.lineCoordinates.y1));
d.lineWidth = this.lineThickness;
d.strokeStyle = this.lineColor;
d.setLineDash &&
d.setLineDash(R(this.lineDashType, this.lineThickness));
m =
1 === this.lineThickness % 2
? (this.lineCoordinates.x1 << 0) + 0.5
: this.lineCoordinates.x1 << 0;
d.beginPath();
if (this.scaleBreaks && !u(this.scaleBreaks.firstBreakIndex))
if (u(this.scaleBreaks.lastBreakIndex))
e =
this.scaleBreaks._appliedBreaks[this.scaleBreaks.firstBreakIndex]
.endPixel + b;
else
for (
l = this.scaleBreaks.firstBreakIndex;
l <= this.scaleBreaks.lastBreakIndex;
l++
)
d.moveTo(m, e),
d.lineTo(m, this.scaleBreaks._appliedBreaks[l].startPixel + c),
(e = this.scaleBreaks._appliedBreaks[l].endPixel + b);
e && (d.moveTo(m, e), d.lineTo(m, g));
d.stroke();
}
r &&
(a.drawImage(
this.chart._preRenderCanvas,
0,
0,
this.chart.width,
this.chart.height
),
this.chart._breaksCanvasCtx &&
this.chart._breaksCanvasCtx.drawImage(
this.chart._preRenderCanvas,
0,
0,
this.chart.width,
this.chart.height
),
d.clearRect(0, 0, this.chart.width, this.chart.height));
d.restore();
};
z.prototype.getPixelCoordinatesOnAxis = function (a) {
var d = {};
if ("bottom" === this._position || "top" === this._position)
(d.x = this.convertValueToPixel(a)), (d.y = this.lineCoordinates.y1);
if ("left" === this._position || "right" === this._position)
(d.y = this.convertValueToPixel(a)), (d.x = this.lineCoordinates.x2);
return d;
};
z.prototype.convertPixelToValue = function (a) {
if ("undefined" === typeof a) return null;
var d = 0,
b = 0,
c,
d = !0,
e = this.scaleBreaks ? this.scaleBreaks._appliedBreaks : [],
b =
"number" === typeof a
? a
: "left" === this._position || "right" === this._position
? a.y
: a.x;
if (this.logarithmic) {
a = c = Math.pow(
this.logarithmBase,
(b - this.conversionParameters.reference) /
this.conversionParameters.pixelPerUnit
);
if (
(b <= this.conversionParameters.reference ===
("left" === this._position || "right" === this._position)) !==
this.reversed
)
for (b = 0; b < e.length; b++) {
if (!(e[b].endValue < this.conversionParameters.minimum))
if (d)
if (e[b].startValue < this.conversionParameters.minimum) {
if (
1 < e[b].size &&
this.conversionParameters.minimum *
Math.pow(
e[b].endValue / e[b].startValue,
Math.log(c) / Math.log(e[b].size)
) <
e[b].endValue
) {
a = Math.pow(
e[b].endValue / e[b].startValue,
Math.log(c) / Math.log(e[b].size)
);
break;
} else
(a *=
e[b].endValue /
this.conversionParameters.minimum /
Math.pow(
e[b].size,
Math.log(
e[b].endValue / this.conversionParameters.minimum
) / Math.log(e[b].endValue / e[b].startValue)
)),
(c /= Math.pow(
e[b].size,
Math.log(
e[b].endValue / this.conversionParameters.minimum
) / Math.log(e[b].endValue / e[b].startValue)
));
d = !1;
} else if (
c >
e[b].startValue / this.conversionParameters.minimum
) {
c /= e[b].startValue / this.conversionParameters.minimum;
if (c < e[b].size) {
a *=
Math.pow(
e[b].endValue / e[b].startValue,
1 === e[b].size ? 1 : Math.log(c) / Math.log(e[b].size)
) / c;
break;
} else a *= e[b].endValue / e[b].startValue / e[b].size;
c /= e[b].size;
d = !1;
} else break;
else if (c > e[b].startValue / e[b - 1].endValue) {
c /= e[b].startValue / e[b - 1].endValue;
if (c < e[b].size) {
a *=
Math.pow(
e[b].endValue / e[b].startValue,
1 === e[b].size ? 1 : Math.log(c) / Math.log(e[b].size)
) / c;
break;
} else a *= e[b].endValue / e[b].startValue / e[b].size;
c /= e[b].size;
} else break;
}
else
for (b = e.length - 1; 0 <= b; b--)
if (!(e[b].startValue > this.conversionParameters.minimum))
if (d)
if (e[b].endValue > this.conversionParameters.minimum) {
if (
1 < e[b].size &&
this.conversionParameters.minimum *
Math.pow(
e[b].endValue / e[b].startValue,
Math.log(c) / Math.log(e[b].size)
) >
e[b].startValue
) {
a = Math.pow(
e[b].endValue / e[b].startValue,
Math.log(c) / Math.log(e[b].size)
);
break;
} else
(a *=
(e[b].startValue / this.conversionParameters.minimum) *
Math.pow(
e[b].size,
Math.log(
e[b].startValue / this.conversionParameters.minimum
) / Math.log(e[b].endValue / e[b].startValue)
) *
c),
(c *= Math.pow(
e[b].size,
Math.log(
this.conversionParameters.minimum / e[b].startValue
) / Math.log(e[b].endValue / e[b].startValue)
));
d = !1;
} else if (
c <
e[b].endValue / this.conversionParameters.minimum
) {
c /= e[b].endValue / this.conversionParameters.minimum;
if (c > 1 / e[b].size) {
a *=
Math.pow(
e[b].endValue / e[b].startValue,
1 >= e[b].size ? 1 : Math.log(c) / Math.log(e[b].size)
) * c;
break;
} else a /= e[b].endValue / e[b].startValue / e[b].size;
c *= e[b].size;
d = !1;
} else break;
else if (c < e[b].endValue / e[b + 1].startValue) {
c /= e[b].endValue / e[b + 1].startValue;
if (c > 1 / e[b].size) {
a *=
Math.pow(
e[b].endValue / e[b].startValue,
1 >= e[b].size ? 1 : Math.log(c) / Math.log(e[b].size)
) * c;
break;
} else a /= e[b].endValue / e[b].startValue / e[b].size;
c *= e[b].size;
} else break;
d = a * this.viewportMinimum;
} else {
a = c =
(b - this.conversionParameters.reference) /
this.conversionParameters.pixelPerUnit;
if (
(b <= this.conversionParameters.reference ===
("left" === this._position || "right" === this._position)) !==
this.reversed
)
for (b = 0; b < e.length; b++) {
if (!(e[b].endValue < this.conversionParameters.minimum))
if (d)
if (e[b].startValue < this.conversionParameters.minimum) {
if (
e[b].size &&
this.conversionParameters.minimum +
(c * (e[b].endValue - e[b].startValue)) / e[b].size <
e[b].endValue
) {
a =
0 >= e[b].size
? 0
: (c * (e[b].endValue - e[b].startValue)) / e[b].size;
break;
} else
(a +=
e[b].endValue -
this.conversionParameters.minimum -
(e[b].size *
(e[b].endValue - this.conversionParameters.minimum)) /
(e[b].endValue - e[b].startValue)),
(c -=
(e[b].size *
(e[b].endValue - this.conversionParameters.minimum)) /
(e[b].endValue - e[b].startValue));
d = !1;
} else if (
c >
e[b].startValue - this.conversionParameters.minimum
) {
c -= e[b].startValue - this.conversionParameters.minimum;
if (c < e[b].size) {
a +=
(e[b].endValue - e[b].startValue) *
(0 === e[b].size ? 1 : c / e[b].size) -
c;
break;
} else a += e[b].endValue - e[b].startValue - e[b].size;
c -= e[b].size;
d = !1;
} else break;
else if (c > e[b].startValue - e[b - 1].endValue) {
c -= e[b].startValue - e[b - 1].endValue;
if (c < e[b].size) {
a +=
(e[b].endValue - e[b].startValue) *
(0 === e[b].size ? 1 : c / e[b].size) -
c;
break;
} else a += e[b].endValue - e[b].startValue - e[b].size;
c -= e[b].size;
} else break;
}
else
for (b = e.length - 1; 0 <= b; b--)
if (!(e[b].startValue > this.conversionParameters.minimum))
if (d)
if (e[b].endValue > this.conversionParameters.minimum)
if (
e[b].size &&
this.conversionParameters.minimum +
(c * (e[b].endValue - e[b].startValue)) / e[b].size >
e[b].startValue
) {
a =
0 >= e[b].size
? 0
: (c * (e[b].endValue - e[b].startValue)) / e[b].size;
break;
} else
(a +=
e[b].startValue -
this.conversionParameters.minimum +
(e[b].size *
(this.conversionParameters.minimum - e[b].startValue)) /
(e[b].endValue - e[b].startValue)),
(c +=
(e[b].size *
(this.conversionParameters.minimum -
e[b].startValue)) /
(e[b].endValue - e[b].startValue)),
(d = !1);
else if (
c <
e[b].endValue - this.conversionParameters.minimum
) {
c -= e[b].endValue - this.conversionParameters.minimum;
if (c > -1 * e[b].size) {
a +=
(e[b].endValue - e[b].startValue) *
(0 === e[b].size ? 1 : c / e[b].size) +
c;
break;
} else a -= e[b].endValue - e[b].startValue - e[b].size;
c += e[b].size;
d = !1;
} else break;
else if (c < e[b].endValue - e[b + 1].startValue) {
c -= e[b].endValue - e[b + 1].startValue;
if (c > -1 * e[b].size) {
a +=
(e[b].endValue - e[b].startValue) *
(0 === e[b].size ? 1 : c / e[b].size) +
c;
break;
} else a -= e[b].endValue - e[b].startValue - e[b].size;
c += e[b].size;
} else break;
d = this.conversionParameters.minimum + a;
}
return d;
};
z.prototype.convertValueToPixel = function (a) {
a = this.getApparentDifference(this.conversionParameters.minimum, a, a);
return this.logarithmic
? (this.conversionParameters.reference +
(this.conversionParameters.pixelPerUnit *
Math.log(a / this.conversionParameters.minimum)) /
this.conversionParameters.lnLogarithmBase +
0.5) <<
0
: "axisX" === this.type
? (this.conversionParameters.reference +
this.conversionParameters.pixelPerUnit *
(a - this.conversionParameters.minimum) +
0.5) <<
0
: this.conversionParameters.reference +
this.conversionParameters.pixelPerUnit *
(a - this.conversionParameters.minimum) +
0.5;
};
z.prototype.getApparentDifference = function (a, d, b, c) {
var e = this.scaleBreaks ? this.scaleBreaks._appliedBreaks : [];
if (this.logarithmic) {
b = u(b) ? d / a : b;
for (var g = 0; g < e.length && !(d < e[g].startValue); g++)
a > e[g].endValue ||
(a <= e[g].startValue && d >= e[g].endValue
? (b = (b / e[g].endValue) * e[g].startValue * e[g].size)
: a >= e[g].startValue && d >= e[g].endValue
? (b =
(b / e[g].endValue) *
a *
Math.pow(
e[g].size,
Math.log(e[g].endValue / a) /
Math.log(e[g].endValue / e[g].startValue)
))
: a <= e[g].startValue && d <= e[g].endValue
? (b =
(b / d) *
e[g].startValue *
Math.pow(
e[g].size,
Math.log(d / e[g].startValue) /
Math.log(e[g].endValue / e[g].startValue)
))
: !c &&
a > e[g].startValue &&
d < e[g].endValue &&
(b =
a *
Math.pow(
e[g].size,
Math.log(d / a) / Math.log(e[g].endValue / e[g].startValue)
)));
} else
for (
b = u(b) ? Math.abs(d - a) : b, g = 0;
g < e.length && !(d < e[g].startValue);
g++
)
a > e[g].endValue ||
(a <= e[g].startValue && d >= e[g].endValue
? (b = b - e[g].endValue + e[g].startValue + e[g].size)
: a > e[g].startValue && d >= e[g].endValue
? (b =
b -
e[g].endValue +
a +
(e[g].size * (e[g].endValue - a)) /
(e[g].endValue - e[g].startValue))
: a <= e[g].startValue && d < e[g].endValue
? (b =
b -
d +
e[g].startValue +
(e[g].size * (d - e[g].startValue)) /
(e[g].endValue - e[g].startValue))
: !c &&
a > e[g].startValue &&
d < e[g].endValue &&
(b =
a +
(e[g].size * (d - a)) / (e[g].endValue - e[g].startValue)));
return b;
};
z.prototype.setViewPortRange = function (a, d) {
this.sessionVariables.newViewportMinimum = this.viewportMinimum =
Math.min(a, d);
this.sessionVariables.newViewportMaximum = this.viewportMaximum =
Math.max(a, d);
};
z.prototype.getXValueAt = function (a) {
if (!a) return null;
var d = null;
"left" === this._position
? (d = this.convertPixelToValue(a.y))
: "bottom" === this._position && (d = this.convertPixelToValue(a.x));
return d;
};
z.prototype.calculateValueToPixelConversionParameters = function (a) {
a = this.scaleBreaks ? this.scaleBreaks._appliedBreaks : [];
var d = { pixelPerUnit: null, minimum: null, reference: null },
b = this.lineCoordinates.width,
c = this.lineCoordinates.height,
b = "bottom" === this._position || "top" === this._position ? b : c,
c = Math.abs(this.range);
if (this.logarithmic)
for (
var e = 0;
e < a.length && !(this.viewportMaximum < a[e].startValue);
e++
)
this.viewportMinimum > a[e].endValue ||
(this.viewportMinimum >= a[e].startValue &&
this.viewportMaximum <= a[e].endValue
? (b = 0)
: this.viewportMinimum <= a[e].startValue &&
this.viewportMaximum >= a[e].endValue
? ((c = (c / a[e].endValue) * a[e].startValue),
(b =
0 < a[e].spacing.toString().indexOf("%")
? b * (1 - parseFloat(a[e].spacing) / 100)
: b - Math.min(a[e].spacing, 0.1 * b)))
: this.viewportMinimum > a[e].startValue &&
this.viewportMaximum >= a[e].endValue
? ((c = (c / a[e].endValue) * this.viewportMinimum),
(b =
0 < a[e].spacing.toString().indexOf("%")
? b *
(1 -
((parseFloat(a[e].spacing) / 100) *
Math.log(a[e].endValue / this.viewportMinimum)) /
Math.log(a[e].endValue / a[e].startValue))
: b -
(Math.min(a[e].spacing, 0.1 * b) *
Math.log(a[e].endValue / this.viewportMinimum)) /
Math.log(a[e].endValue / a[e].startValue)))
: this.viewportMinimum <= a[e].startValue &&
this.viewportMaximum < a[e].endValue &&
((c = (c / this.viewportMaximum) * a[e].startValue),
(b =
0 < a[e].spacing.toString().indexOf("%")
? b *
(1 -
((parseFloat(a[e].spacing) / 100) *
Math.log(this.viewportMaximum / a[e].startValue)) /
Math.log(a[e].endValue / a[e].startValue))
: b -
(Math.min(a[e].spacing, 0.1 * b) *
Math.log(this.viewportMaximum / a[e].startValue)) /
Math.log(a[e].endValue / a[e].startValue))));
else
for (
e = 0;
e < a.length && !(this.viewportMaximum < a[e].startValue);
e++
)
this.viewportMinimum > a[e].endValue ||
(this.viewportMinimum >= a[e].startValue &&
this.viewportMaximum <= a[e].endValue
? (b = 0)
: this.viewportMinimum <= a[e].startValue &&
this.viewportMaximum >= a[e].endValue
? ((c = c - a[e].endValue + a[e].startValue),
(b =
0 < a[e].spacing.toString().indexOf("%")
? b * (1 - parseFloat(a[e].spacing) / 100)
: b - Math.min(a[e].spacing, 0.1 * b)))
: this.viewportMinimum > a[e].startValue &&
this.viewportMaximum >= a[e].endValue
? ((c = c - a[e].endValue + this.viewportMinimum),
(b =
0 < a[e].spacing.toString().indexOf("%")
? b *
(1 -
((parseFloat(a[e].spacing) / 100) *
(a[e].endValue - this.viewportMinimum)) /
(a[e].endValue - a[e].startValue))
: b -
(Math.min(a[e].spacing, 0.1 * b) *
(a[e].endValue - this.viewportMinimum)) /
(a[e].endValue - a[e].startValue)))
: this.viewportMinimum <= a[e].startValue &&
this.viewportMaximum < a[e].endValue &&
((c = c - this.viewportMaximum + a[e].startValue),
(b =
0 < a[e].spacing.toString().indexOf("%")
? b *
(1 -
((parseFloat(a[e].spacing) / 100) *
(this.viewportMaximum - a[e].startValue)) /
(a[e].endValue - a[e].startValue))
: b -
(Math.min(a[e].spacing, 0.1 * b) *
(this.viewportMaximum - a[e].startValue)) /
(a[e].endValue - a[e].startValue))));
d.minimum = this.viewportMinimum;
d.maximum = this.viewportMaximum;
d.range = c;
if ("bottom" === this._position || "top" === this._position)
this.logarithmic
? ((d.lnLogarithmBase = Math.log(this.logarithmBase)),
(d.pixelPerUnit =
((this.reversed ? -1 : 1) * b * d.lnLogarithmBase) /
Math.log(Math.abs(c))))
: (d.pixelPerUnit = ((this.reversed ? -1 : 1) * b) / Math.abs(c)),
(d.reference = this.reversed
? this.lineCoordinates.x2
: this.lineCoordinates.x1);
if ("left" === this._position || "right" === this._position)
this.logarithmic
? ((d.lnLogarithmBase = Math.log(this.logarithmBase)),
(d.pixelPerUnit =
((this.reversed ? 1 : -1) * b * d.lnLogarithmBase) /
Math.log(Math.abs(c))))
: (d.pixelPerUnit = ((this.reversed ? 1 : -1) * b) / Math.abs(c)),
(d.reference = this.reversed
? this.lineCoordinates.y1
: this.lineCoordinates.y2);
this.conversionParameters = d;
};
z.prototype.calculateAxisParameters = function () {
if (this.logarithmic) this.calculateLogarithmicAxisParameters();
else {
var a = this.chart.layoutManager.getFreeSpace(),
d = !1,
b = !1;
"bottom" === this._position || "top" === this._position
? ((this.maxWidth = a.width), (this.maxHeight = a.height))
: ((this.maxWidth = a.height), (this.maxHeight = a.width));
var a =
"axisX" === this.type
? "xySwapped" === this.chart.plotInfo.axisPlacement
? 62
: 70
: "xySwapped" === this.chart.plotInfo.axisPlacement
? 50
: 40,
c = 4;
"axisX" === this.type && (c = 600 > this.maxWidth ? 8 : 6);
var a = Math.max(c, Math.floor(this.maxWidth / a)),
e,
g,
m,
c = 0;
!u(this.options.viewportMinimum) &&
!u(this.options.viewportMaximum) &&
this.options.viewportMinimum >= this.options.viewportMaximum &&
(this.viewportMinimum = this.viewportMaximum = null);
if (
u(this.options.viewportMinimum) &&
!u(this.sessionVariables.newViewportMinimum) &&
!isNaN(this.sessionVariables.newViewportMinimum)
)
this.viewportMinimum = this.sessionVariables.newViewportMinimum;
else if (null === this.viewportMinimum || isNaN(this.viewportMinimum))
this.viewportMinimum = this.minimum;
if (
u(this.options.viewportMaximum) &&
!u(this.sessionVariables.newViewportMaximum) &&
!isNaN(this.sessionVariables.newViewportMaximum)
)
this.viewportMaximum = this.sessionVariables.newViewportMaximum;
else if (null === this.viewportMaximum || isNaN(this.viewportMaximum))
this.viewportMaximum = this.maximum;
if (this.scaleBreaks)
for (c = 0; c < this.scaleBreaks._appliedBreaks.length; c++)
if (
((!u(this.sessionVariables.newViewportMinimum) &&
this.sessionVariables.newViewportMinimum >=
this.scaleBreaks._appliedBreaks[c].startValue) ||
(!u(this.options.minimum) &&
this.options.minimum >=
this.scaleBreaks._appliedBreaks[c].startValue) ||
(!u(this.options.viewportMinimum) &&
this.viewportMinimum >=
this.scaleBreaks._appliedBreaks[c].startValue)) &&
((!u(this.sessionVariables.newViewportMaximum) &&
this.sessionVariables.newViewportMaximum <=
this.scaleBreaks._appliedBreaks[c].endValue) ||
(!u(this.options.maximum) &&
this.options.maximum <=
this.scaleBreaks._appliedBreaks[c].endValue) ||
(!u(this.options.viewportMaximum) &&
this.viewportMaximum <=
this.scaleBreaks._appliedBreaks[c].endValue))
) {
this.scaleBreaks._appliedBreaks.splice(c, 1);
break;
}
if ("axisX" === this.type) {
if (this.dataSeries && 0 < this.dataSeries.length)
for (e = 0; e < this.dataSeries.length; e++)
"dateTime" === this.dataSeries[e].xValueType && (b = !0);
e =
null !== this.viewportMinimum
? this.viewportMinimum
: this.dataInfo.viewPortMin;
g =
null !== this.viewportMaximum
? this.viewportMaximum
: this.dataInfo.viewPortMax;
0 === g - e &&
((c =
"undefined" === typeof this.options.interval
? 0.4
: this.options.interval),
(g += c),
(e -= c));
Infinity !== this.dataInfo.minDiff
? (m = this.dataInfo.minDiff)
: 1 < g - e
? (m = 0.5 * Math.abs(g - e))
: ((m = 1), b && (d = !0));
} else
"axisY" === this.type &&
((e =
null !== this.viewportMinimum
? this.viewportMinimum
: this.dataInfo.viewPortMin),
(g =
null !== this.viewportMaximum
? this.viewportMaximum
: this.dataInfo.viewPortMax),
isFinite(e) || isFinite(g)
? isFinite(e)
? isFinite(g) || (g = e)
: (e = g)
: ((g =
"undefined" === typeof this.options.interval
? -Infinity
: this.options.interval),
(e =
"undefined" !== typeof this.options.interval ||
isFinite(this.dataInfo.minDiff)
? 0
: Infinity)),
0 === e && 0 === g
? ((g += 9), (e = 0))
: 0 === g - e
? ((c = Math.min(Math.abs(0.01 * Math.abs(g)), 5)),
(g += c),
(e -= c))
: e > g
? ((c = Math.min(
0.01 * Math.abs(this.getApparentDifference(g, e, null, !0)),
5
)),
0 <= g ? (e = g - c) : (g = isFinite(e) ? e + c : 0))
: ((c = Math.min(
0.01 * Math.abs(this.getApparentDifference(e, g, null, !0)),
0.05
)),
0 !== g && (g += c),
0 !== e && (e -= c)),
(m =
Infinity !== this.dataInfo.minDiff
? this.dataInfo.minDiff
: 1 < g - e
? 0.5 * Math.abs(g - e)
: 1),
this.includeZero &&
(null === this.viewportMinimum || isNaN(this.viewportMinimum)) &&
0 < e &&
(e = 0),
this.includeZero &&
(null === this.viewportMaximum || isNaN(this.viewportMaximum)) &&
0 > g &&
(g = 0));
c = this.getApparentDifference(
isNaN(this.viewportMinimum) || null === this.viewportMinimum
? e
: this.viewportMinimum,
isNaN(this.viewportMaximum) || null === this.viewportMaximum
? g
: this.viewportMaximum,
null,
!0
);
if ("axisX" === this.type && b) {
this.intervalType ||
(c / 1 <= a
? ((this.interval = 1), (this.intervalType = "millisecond"))
: c / 2 <= a
? ((this.interval = 2), (this.intervalType = "millisecond"))
: c / 5 <= a
? ((this.interval = 5), (this.intervalType = "millisecond"))
: c / 10 <= a
? ((this.interval = 10), (this.intervalType = "millisecond"))
: c / 20 <= a
? ((this.interval = 20), (this.intervalType = "millisecond"))
: c / 50 <= a
? ((this.interval = 50), (this.intervalType = "millisecond"))
: c / 100 <= a
? ((this.interval = 100), (this.intervalType = "millisecond"))
: c / 200 <= a
? ((this.interval = 200), (this.intervalType = "millisecond"))
: c / 250 <= a
? ((this.interval = 250), (this.intervalType = "millisecond"))
: c / 300 <= a
? ((this.interval = 300), (this.intervalType = "millisecond"))
: c / 400 <= a
? ((this.interval = 400), (this.intervalType = "millisecond"))
: c / 500 <= a
? ((this.interval = 500), (this.intervalType = "millisecond"))
: c / (1 * S.secondDuration) <= a
? ((this.interval = 1), (this.intervalType = "second"))
: c / (2 * S.secondDuration) <= a
? ((this.interval = 2), (this.intervalType = "second"))
: c / (5 * S.secondDuration) <= a
? ((this.interval = 5), (this.intervalType = "second"))
: c / (10 * S.secondDuration) <= a
? ((this.interval = 10), (this.intervalType = "second"))
: c / (15 * S.secondDuration) <= a
? ((this.interval = 15), (this.intervalType = "second"))
: c / (20 * S.secondDuration) <= a
? ((this.interval = 20), (this.intervalType = "second"))
: c / (30 * S.secondDuration) <= a
? ((this.interval = 30), (this.intervalType = "second"))
: c / (1 * S.minuteDuration) <= a
? ((this.interval = 1), (this.intervalType = "minute"))
: c / (2 * S.minuteDuration) <= a
? ((this.interval = 2), (this.intervalType = "minute"))
: c / (5 * S.minuteDuration) <= a
? ((this.interval = 5), (this.intervalType = "minute"))
: c / (10 * S.minuteDuration) <= a
? ((this.interval = 10), (this.intervalType = "minute"))
: c / (15 * S.minuteDuration) <= a
? ((this.interval = 15), (this.intervalType = "minute"))
: c / (20 * S.minuteDuration) <= a
? ((this.interval = 20), (this.intervalType = "minute"))
: c / (30 * S.minuteDuration) <= a
? ((this.interval = 30), (this.intervalType = "minute"))
: c / (1 * S.hourDuration) <= a
? ((this.interval = 1), (this.intervalType = "hour"))
: c / (2 * S.hourDuration) <= a
? ((this.interval = 2), (this.intervalType = "hour"))
: c / (3 * S.hourDuration) <= a
? ((this.interval = 3), (this.intervalType = "hour"))
: c / (6 * S.hourDuration) <= a
? ((this.interval = 6), (this.intervalType = "hour"))
: c / (1 * S.dayDuration) <= a
? ((this.interval = 1), (this.intervalType = "day"))
: c / (2 * S.dayDuration) <= a
? ((this.interval = 2), (this.intervalType = "day"))
: c / (4 * S.dayDuration) <= a
? ((this.interval = 4), (this.intervalType = "day"))
: c / (1 * S.weekDuration) <= a
? ((this.interval = 1), (this.intervalType = "week"))
: c / (2 * S.weekDuration) <= a
? ((this.interval = 2), (this.intervalType = "week"))
: c / (3 * S.weekDuration) <= a
? ((this.interval = 3), (this.intervalType = "week"))
: c / (1 * S.monthDuration) <= a
? ((this.interval = 1), (this.intervalType = "month"))
: c / (2 * S.monthDuration) <= a
? ((this.interval = 2), (this.intervalType = "month"))
: c / (3 * S.monthDuration) <= a
? ((this.interval = 3), (this.intervalType = "month"))
: c / (6 * S.monthDuration) <= a
? ((this.interval = 6), (this.intervalType = "month"))
: ((this.interval =
c / (1 * S.yearDuration) <= a
? 1
: c / (2 * S.yearDuration) <= a
? 2
: c / (4 * S.yearDuration) <= a
? 4
: Math.floor(
z.getNiceNumber(c / (a - 1), !0) / S.yearDuration
)),
(this.intervalType = "year")));
if (null === this.viewportMinimum || isNaN(this.viewportMinimum))
this.viewportMinimum = e - m / 2;
if (null === this.viewportMaximum || isNaN(this.viewportMaximum))
this.viewportMaximum = g + m / 2;
d
? (this.autoValueFormatString = "MMM DD YYYY HH:mm")
: "year" === this.intervalType
? (this.autoValueFormatString = "YYYY")
: "month" === this.intervalType
? (this.autoValueFormatString = "MMM YYYY")
: "week" === this.intervalType
? (this.autoValueFormatString = "MMM DD YYYY")
: "day" === this.intervalType
? (this.autoValueFormatString = "MMM DD YYYY")
: "hour" === this.intervalType
? (this.autoValueFormatString = "hh:mm TT")
: "minute" === this.intervalType
? (this.autoValueFormatString = "hh:mm TT")
: "second" === this.intervalType
? (this.autoValueFormatString = "hh:mm:ss TT")
: "millisecond" === this.intervalType &&
(this.autoValueFormatString = "fff'ms'");
this.valueFormatString ||
(this.valueFormatString = this.autoValueFormatString);
} else {
this.intervalType = "number";
c = z.getNiceNumber(c, !1);
this.interval =
this.options && 0 < this.options.interval
? this.options.interval
: z.getNiceNumber(c / (a - 1), !0);
if (null === this.viewportMinimum || isNaN(this.viewportMinimum))
this.viewportMinimum =
"axisX" === this.type
? e - m / 2
: Math.floor(e / this.interval) * this.interval;
if (null === this.viewportMaximum || isNaN(this.viewportMaximum))
this.viewportMaximum =
"axisX" === this.type
? g + m / 2
: Math.ceil(g / this.interval) * this.interval;
0 === this.viewportMaximum &&
0 === this.viewportMinimum &&
(0 === this.options.viewportMinimum
? (this.viewportMaximum += 10)
: 0 === this.options.viewportMaximum &&
(this.viewportMinimum -= 10),
this.options &&
"undefined" === typeof this.options.interval &&
(this.interval = z.getNiceNumber(
(this.viewportMaximum - this.viewportMinimum) / (a - 1),
!0
)));
}
if (null === this.minimum || null === this.maximum)
if (
("axisX" === this.type
? ((e = null !== this.minimum ? this.minimum : this.dataInfo.min),
(g = null !== this.maximum ? this.maximum : this.dataInfo.max),
0 === g - e &&
((c =
"undefined" === typeof this.options.interval
? 0.4
: this.options.interval),
(g += c),
(e -= c)),
(m =
Infinity !== this.dataInfo.minDiff
? this.dataInfo.minDiff
: 1 < g - e
? 0.5 * Math.abs(g - e)
: 1))
: "axisY" === this.type &&
((e = null !== this.minimum ? this.minimum : this.dataInfo.min),
(g = null !== this.maximum ? this.maximum : this.dataInfo.max),
isFinite(e) || isFinite(g)
? 0 === e && 0 === g
? ((g += 9), (e = 0))
: 0 === g - e
? ((c = Math.min(Math.abs(0.01 * Math.abs(g)), 5)),
(g += c),
(e -= c))
: e > g
? ((c = Math.min(
0.01 *
Math.abs(this.getApparentDifference(g, e, null, !0)),
5
)),
0 <= g ? (e = g - c) : (g = isFinite(e) ? e + c : 0))
: ((c = Math.min(
0.01 *
Math.abs(this.getApparentDifference(e, g, null, !0)),
0.05
)),
0 !== g && (g += c),
0 !== e && (e -= c))
: ((g =
"undefined" === typeof this.options.interval
? -Infinity
: this.options.interval),
(e =
"undefined" !== typeof this.options.interval ||
isFinite(this.dataInfo.minDiff)
? 0
: Infinity)),
(m =
Infinity !== this.dataInfo.minDiff
? this.dataInfo.minDiff
: 1 < g - e
? 0.5 * Math.abs(g - e)
: 1),
this.includeZero &&
(null === this.minimum || isNaN(this.minimum)) &&
0 < e &&
(e = 0),
this.includeZero &&
(null === this.maximum || isNaN(this.maximum)) &&
0 > g &&
(g = 0)),
Math.abs(this.getApparentDifference(e, g, null, !0)),
"axisX" === this.type && b)
) {
this.valueType = "dateTime";
if (null === this.minimum || isNaN(this.minimum))
this.minimum = e - m / 2;
if (null === this.maximum || isNaN(this.maximum))
this.maximum = g + m / 2;
} else
(this.intervalType = this.valueType = "number"),
null === this.minimum &&
((this.minimum =
"axisX" === this.type
? e - m / 2
: Math.floor(e / this.interval) * this.interval),
(this.minimum = Math.min(
this.minimum,
null === this.sessionVariables.viewportMinimum ||
isNaN(this.sessionVariables.viewportMinimum)
? Infinity
: this.sessionVariables.viewportMinimum
))),
null === this.maximum &&
((this.maximum =
"axisX" === this.type
? g + m / 2
: Math.ceil(g / this.interval) * this.interval),
(this.maximum = Math.max(
this.maximum,
null === this.sessionVariables.viewportMaximum ||
isNaN(this.sessionVariables.viewportMaximum)
? -Infinity
: this.sessionVariables.viewportMaximum
))),
0 === this.maximum &&
0 === this.minimum &&
(0 === this.options.minimum
? (this.maximum += 10)
: 0 === this.options.maximum && (this.minimum -= 10));
u(this.sessionVariables.newViewportMinimum) &&
(this.viewportMinimum = Math.max(this.viewportMinimum, this.minimum));
u(this.sessionVariables.newViewportMaximum) &&
(this.viewportMaximum = Math.min(this.viewportMaximum, this.maximum));
this.range = this.viewportMaximum - this.viewportMinimum;
this.intervalStartPosition =
"axisX" === this.type && b
? this.getLabelStartPoint(
new Date(this.viewportMinimum),
this.intervalType,
this.interval
)
: Math.floor(
(this.viewportMinimum + 0.2 * this.interval) / this.interval
) * this.interval;
this.valueFormatString ||
(this.valueFormatString = z.generateValueFormatString(this.range, 2));
}
};
z.prototype.calculateLogarithmicAxisParameters = function () {
var a = this.chart.layoutManager.getFreeSpace(),
d = Math.log(this.logarithmBase),
b;
"bottom" === this._position || "top" === this._position
? ((this.maxWidth = a.width), (this.maxHeight = a.height))
: ((this.maxWidth = a.height), (this.maxHeight = a.width));
var a =
"axisX" === this.type
? 500 > this.maxWidth
? 7
: Math.max(7, Math.floor(this.maxWidth / 100))
: Math.max(Math.floor(this.maxWidth / 50), 3),
c,
e,
g,
m;
m = 1;
if (null === this.viewportMinimum || isNaN(this.viewportMinimum))
this.viewportMinimum = this.minimum;
if (null === this.viewportMaximum || isNaN(this.viewportMaximum))
this.viewportMaximum = this.maximum;
if (this.scaleBreaks)
for (m = 0; m < this.scaleBreaks._appliedBreaks.length; m++)
if (
((!u(this.sessionVariables.newViewportMinimum) &&
this.sessionVariables.newViewportMinimum >=
this.scaleBreaks._appliedBreaks[m].startValue) ||
(!u(this.options.minimum) &&
this.options.minimum >=
this.scaleBreaks._appliedBreaks[m].startValue) ||
(!u(this.options.viewportMinimum) &&
this.viewportMinimum >=
this.scaleBreaks._appliedBreaks[m].startValue)) &&
((!u(this.sessionVariables.newViewportMaximum) &&
this.sessionVariables.newViewportMaximum <=
this.scaleBreaks._appliedBreaks[m].endValue) ||
(!u(this.options.maximum) &&
this.options.maximum <=
this.scaleBreaks._appliedBreaks[m].endValue) ||
(!u(this.options.viewportMaximum) &&
this.viewportMaximum <=
this.scaleBreaks._appliedBreaks[m].endValue))
) {
this.scaleBreaks._appliedBreaks.splice(m, 1);
break;
}
"axisX" === this.type
? ((c =
null !== this.viewportMinimum
? this.viewportMinimum
: this.dataInfo.viewPortMin),
(e =
null !== this.viewportMaximum
? this.viewportMaximum
: this.dataInfo.viewPortMax),
1 === e / c &&
((m = Math.pow(
this.logarithmBase,
"undefined" === typeof this.options.interval
? 0.4
: this.options.interval
)),
(e *= m),
(c /= m)),
(g =
Infinity !== this.dataInfo.minDiff
? this.dataInfo.minDiff
: e / c > this.logarithmBase
? (e / c) * Math.pow(this.logarithmBase, 0.5)
: this.logarithmBase))
: "axisY" === this.type &&
((c =
null !== this.viewportMinimum
? this.viewportMinimum
: this.dataInfo.viewPortMin),
(e =
null !== this.viewportMaximum
? this.viewportMaximum
: this.dataInfo.viewPortMax),
0 >= c && !isFinite(e)
? ((e =
"undefined" === typeof this.options.interval
? 0
: this.options.interval),
(c = 1))
: 0 >= c
? (c = e)
: isFinite(e) || (e = c),
1 === c && 1 === e
? ((e *= this.logarithmBase - 1 / this.logarithmBase), (c = 1))
: 1 === e / c
? ((m = Math.min(
e * Math.pow(this.logarithmBase, 0.01),
Math.pow(this.logarithmBase, 5)
)),
(e *= m),
(c /= m))
: c > e
? ((m = Math.min(
(c / e) * Math.pow(this.logarithmBase, 0.01),
Math.pow(this.logarithmBase, 5)
)),
1 <= e ? (c = e / m) : (e = c * m))
: ((m = Math.min(
(e / c) * Math.pow(this.logarithmBase, 0.01),
Math.pow(this.logarithmBase, 0.04)
)),
1 !== e && (e *= m),
1 !== c && (c /= m)),
(g =
Infinity !== this.dataInfo.minDiff
? this.dataInfo.minDiff
: e / c > this.logarithmBase
? (e / c) * Math.pow(this.logarithmBase, 0.5)
: this.logarithmBase),
this.includeZero &&
(null === this.viewportMinimum || isNaN(this.viewportMinimum)) &&
1 < c &&
(c = 1),
this.includeZero &&
(null === this.viewportMaximum || isNaN(this.viewportMaximum)) &&
1 > e &&
(e = 1));
m =
(isNaN(this.viewportMaximum) || null === this.viewportMaximum
? e
: this.viewportMaximum) /
(isNaN(this.viewportMinimum) || null === this.viewportMinimum
? c
: this.viewportMinimum);
var l =
(isNaN(this.viewportMaximum) || null === this.viewportMaximum
? e
: this.viewportMaximum) -
(isNaN(this.viewportMinimum) || null === this.viewportMinimum
? c
: this.viewportMinimum);
this.intervalType = "number";
m = Math.pow(
this.logarithmBase,
z.getNiceNumber(Math.abs(Math.log(m) / d), !1)
);
this.options && 0 < this.options.interval
? (this.interval = this.options.interval)
: ((this.interval = z.getNiceExponent(Math.log(m) / d / (a - 1), !0)),
(b = z.getNiceNumber(l / (a - 1), !0)));
if (null === this.viewportMinimum || isNaN(this.viewportMinimum))
this.viewportMinimum =
"axisX" === this.type
? c / Math.sqrt(g)
: Math.pow(
this.logarithmBase,
this.interval * Math.floor(Math.log(c) / d / this.interval)
);
if (null === this.viewportMaximum || isNaN(this.viewportMaximum))
this.viewportMaximum =
"axisX" === this.type
? e * Math.sqrt(g)
: Math.pow(
this.logarithmBase,
this.interval * Math.ceil(Math.log(e) / d / this.interval)
);
1 === this.viewportMaximum &&
1 === this.viewportMinimum &&
(1 === this.options.viewportMinimum
? (this.viewportMaximum *=
this.logarithmBase - 1 / this.logarithmBase)
: 1 === this.options.viewportMaximum &&
(this.viewportMinimum /=
this.logarithmBase - 1 / this.logarithmBase),
this.options &&
"undefined" === typeof this.options.interval &&
((this.interval = z.getNiceExponent(
Math.ceil(Math.log(m) / d) / (a - 1)
)),
(b = z.getNiceNumber(
(this.viewportMaximum - this.viewportMinimum) / (a - 1),
!0
))));
if (null === this.minimum || null === this.maximum)
"axisX" === this.type
? ((c = null !== this.minimum ? this.minimum : this.dataInfo.min),
(e = null !== this.maximum ? this.maximum : this.dataInfo.max),
1 === e / c &&
((m = Math.pow(
this.logarithmBase,
"undefined" === typeof this.options.interval
? 0.4
: this.options.interval
)),
(e *= m),
(c /= m)),
(g =
Infinity !== this.dataInfo.minDiff
? this.dataInfo.minDiff
: e / c > this.logarithmBase
? (e / c) * Math.pow(this.logarithmBase, 0.5)
: this.logarithmBase))
: "axisY" === this.type &&
((c = null !== this.minimum ? this.minimum : this.dataInfo.min),
(e = null !== this.maximum ? this.maximum : this.dataInfo.max),
isFinite(c) || isFinite(e)
? 1 === c && 1 === e
? ((e *= this.logarithmBase), (c /= this.logarithmBase))
: 1 === e / c
? ((m = Math.pow(this.logarithmBase, this.interval)),
(e *= m),
(c /= m))
: c > e
? ((m = Math.min(0.01 * (c / e), 5)),
1 <= e ? (c = e / m) : (e = c * m))
: ((m = Math.min(
(e / c) * Math.pow(this.logarithmBase, 0.01),
Math.pow(this.logarithmBase, 0.04)
)),
1 !== e && (e *= m),
1 !== c && (c /= m))
: ((e =
"undefined" === typeof this.options.interval
? 0
: this.options.interval),
(c = 1)),
(g =
Infinity !== this.dataInfo.minDiff
? this.dataInfo.minDiff
: e / c > this.logarithmBase
? (e / c) * Math.pow(this.logarithmBase, 0.5)
: this.logarithmBase),
this.includeZero &&
(null === this.minimum || isNaN(this.minimum)) &&
1 < c &&
(c = 1),
this.includeZero &&
(null === this.maximum || isNaN(this.maximum)) &&
1 > e &&
(e = 1)),
(this.intervalType = "number"),
null === this.minimum &&
((this.minimum =
"axisX" === this.type
? c / Math.sqrt(g)
: Math.pow(
this.logarithmBase,
this.interval * Math.floor(Math.log(c) / d / this.interval)
)),
(this.minimum = Math.min(
this.minimum,
null === this.sessionVariables.viewportMinimum ||
isNaN(this.sessionVariables.viewportMinimum)
? "undefined" ===
typeof this.sessionVariables.newViewportMinimum
? Infinity
: this.sessionVariables.newViewportMinimum
: this.sessionVariables.viewportMinimum
))),
null === this.maximum &&
((this.maximum =
"axisX" === this.type
? e * Math.sqrt(g)
: Math.pow(
this.logarithmBase,
this.interval * Math.ceil(Math.log(e) / d / this.interval)
)),
(this.maximum = Math.max(
this.maximum,
null === this.sessionVariables.viewportMaximum ||
isNaN(this.sessionVariables.viewportMaximum)
? "undefined" ===
typeof this.sessionVariables.newViewportMaximum
? 0
: this.sessionVariables.newViewportMaximum
: this.sessionVariables.viewportMaximum
))),
1 === this.maximum &&
1 === this.minimum &&
(1 === this.options.minimum
? (this.maximum *= this.logarithmBase - 1 / this.logarithmBase)
: 1 === this.options.maximum &&
(this.minimum /= this.logarithmBase - 1 / this.logarithmBase));
this.viewportMinimum = Math.max(this.viewportMinimum, this.minimum);
this.viewportMaximum = Math.min(this.viewportMaximum, this.maximum);
this.viewportMinimum > this.viewportMaximum &&
((!this.options.viewportMinimum && !this.options.minimum) ||
this.options.viewportMaximum ||
this.options.maximum
? this.options.viewportMinimum ||
this.options.minimum ||
(!this.options.viewportMaximum && !this.options.maximum) ||
(this.viewportMinimum = this.minimum =
(this.options.viewportMaximum || this.options.maximum) /
Math.pow(this.logarithmBase, 2 * Math.ceil(this.interval)))
: (this.viewportMaximum = this.maximum =
this.options.viewportMinimum || this.options.minimum));
c = Math.pow(
this.logarithmBase,
Math.floor(Math.log(this.viewportMinimum) / (d * this.interval) + 0.2) *
this.interval
);
this.range = this.viewportMaximum / this.viewportMinimum;
this.noTicks = a;
if (
!this.options.interval &&
this.range <
Math.pow(
this.logarithmBase,
8 > this.viewportMaximum || 3 > a ? 2 : 3
)
) {
for (
d = Math.floor(this.viewportMinimum / b + 0.5) * b;
d < this.viewportMinimum;
)
d += b;
this.equidistantInterval = !1;
this.intervalStartPosition = d;
this.interval = b;
} else
this.options.interval ||
((b = Math.ceil(this.interval)),
this.range > this.interval &&
((this.interval = b),
(c = Math.pow(
this.logarithmBase,
Math.floor(
Math.log(this.viewportMinimum) / (d * this.interval) + 0.2
) * this.interval
)))),
(this.equidistantInterval = !0),
(this.intervalStartPosition = c);
if (
!this.valueFormatString &&
((this.valueFormatString = "#,##0.##"), 1 > this.viewportMinimum)
) {
d =
Math.floor(Math.abs(Math.log(this.viewportMinimum) / Math.LN10)) + 2;
if (isNaN(d) || !isFinite(d)) d = 2;
if (2 < d) for (m = 0; m < d - 2; m++) this.valueFormatString += "#";
}
};
z.generateValueFormatString = function (a, d) {
var b = "#,##0.",
c = d;
1 > a &&
((c += Math.floor(Math.abs(Math.log(a) / Math.LN10))),
isNaN(c) || !isFinite(c)) &&
(c = d);
for (var e = 0; e < c; e++) b += "#";
return b;
};
z.getNiceExponent = function (a, d) {
var b = Math.floor(Math.log(a) / Math.LN10),
c = a / Math.pow(10, b),
c = 0 > b ? (1 >= c ? 1 : 5 >= c ? 5 : 10) : Math.max(Math.floor(c), 1);
return -20 > b
? Number(c * Math.pow(10, b))
: Number((c * Math.pow(10, b)).toFixed(20));
};
z.getNiceNumber = function (a, d) {
var b = Math.floor(Math.log(a) / Math.LN10),
c = a / Math.pow(10, b),
c = d
? 1.5 > c
? 1
: 3 > c
? 2
: 7 > c
? 5
: 10
: 1 >= c
? 1
: 2 >= c
? 2
: 5 >= c
? 5
: 10;
return -20 > b
? Number(c * Math.pow(10, b))
: Number((c * Math.pow(10, b)).toFixed(20));
};
z.prototype.getLabelStartPoint = function () {
var a = S[this.intervalType + "Duration"] * this.interval,
a = new Date(Math.floor(this.viewportMinimum / a) * a);
if ("millisecond" !== this.intervalType)
if ("second" === this.intervalType)
0 < a.getMilliseconds() &&
(a.setSeconds(a.getSeconds() + 1), a.setMilliseconds(0));
else if ("minute" === this.intervalType) {
if (0 < a.getSeconds() || 0 < a.getMilliseconds())
a.setMinutes(a.getMinutes() + 1),
a.setSeconds(0),
a.setMilliseconds(0);
} else if ("hour" === this.intervalType) {
if (
0 < a.getMinutes() ||
0 < a.getSeconds() ||
0 < a.getMilliseconds()
)
a.setHours(a.getHours() + 1),
a.setMinutes(0),
a.setSeconds(0),
a.setMilliseconds(0);
} else if ("day" === this.intervalType) {
if (
0 < a.getHours() ||
0 < a.getMinutes() ||
0 < a.getSeconds() ||
0 < a.getMilliseconds()
)
a.setDate(a.getDate() + 1),
a.setHours(0),
a.setMinutes(0),
a.setSeconds(0),
a.setMilliseconds(0);
} else if ("week" === this.intervalType) {
if (
0 < a.getDay() ||
0 < a.getHours() ||
0 < a.getMinutes() ||
0 < a.getSeconds() ||
0 < a.getMilliseconds()
)
a.setDate(a.getDate() + (7 - a.getDay())),
a.setHours(0),
a.setMinutes(0),
a.setSeconds(0),
a.setMilliseconds(0);
} else if ("month" === this.intervalType) {
if (
1 < a.getDate() ||
0 < a.getHours() ||
0 < a.getMinutes() ||
0 < a.getSeconds() ||
0 < a.getMilliseconds()
)
a.setMonth(a.getMonth() + 1),
a.setDate(1),
a.setHours(0),
a.setMinutes(0),
a.setSeconds(0),
a.setMilliseconds(0);
} else
"year" === this.intervalType &&
(0 < a.getMonth() ||
1 < a.getDate() ||
0 < a.getHours() ||
0 < a.getMinutes() ||
0 < a.getSeconds() ||
0 < a.getMilliseconds()) &&
(a.setFullYear(a.getFullYear() + 1),
a.setMonth(0),
a.setDate(1),
a.setHours(0),
a.setMinutes(0),
a.setSeconds(0),
a.setMilliseconds(0));
return a;
};
qa(Q, V);
qa(L, V);
L.prototype.createUserOptions = function (a) {
if ("undefined" !== typeof a || this.options._isPlaceholder) {
var d = 0;
this.parent.options._isPlaceholder && this.parent.createUserOptions();
this.options._isPlaceholder ||
(Fa(this.parent[this.optionsName]),
(d = this.parent.options[this.optionsName].indexOf(this.options)));
this.options = "undefined" === typeof a ? {} : a;
this.parent.options[this.optionsName][d] = this.options;
}
};
L.prototype.render = function (a) {
if (
0 !== this.spacing ||
(0 !== this.options.lineThickness &&
("undefined" !== typeof this.options.lineThickness ||
0 !== this.parent.lineThickness))
) {
var d = this.ctx,
b = this.ctx.globalAlpha;
this.ctx = a || this.ctx;
this.ctx.save();
this.ctx.beginPath();
this.ctx.rect(
this.chart.plotArea.x1,
this.chart.plotArea.y1,
this.chart.plotArea.width,
this.chart.plotArea.height
);
this.ctx.clip();
var c = this.scaleBreaks.parent.getPixelCoordinatesOnAxis(
this.startValue
),
e = this.scaleBreaks.parent.getPixelCoordinatesOnAxis(this.endValue);
this.ctx.strokeStyle = this.lineColor;
this.ctx.fillStyle = this.color;
this.ctx.beginPath();
this.ctx.globalAlpha = 1;
N(this.id);
var g, m, l, k, h, p;
a = Math.max(this.spacing, 3);
var q = Math.max(0, this.lineThickness);
this.ctx.lineWidth = q;
this.ctx.setLineDash && this.ctx.setLineDash(R(this.lineDashType, q));
if (
"bottom" === this.scaleBreaks.parent._position ||
"top" === this.scaleBreaks.parent._position
)
if (
((c = 1 === q % 2 ? (c.x << 0) + 0.5 : c.x << 0),
(m = 1 === q % 2 ? (e.x << 0) + 0.5 : e.x << 0),
"top" === this.scaleBreaks.parent._position
? ((e = this.chart.plotArea.y1),
(l = (this.chart.plotArea.y2 + q / 2 + 0.5) << 0))
: ((e = this.chart.plotArea.y2),
(l = (this.chart.plotArea.y1 - q / 2 + 0.5) << 0),
(a *= -1)),
(this.bounds = { x1: c - q / 2, y1: e, x2: m + q / 2, y2: l }),
this.ctx.moveTo(c, e),
"straight" === this.type ||
("top" === this.scaleBreaks.parent._position && 0 >= a) ||
("bottom" === this.scaleBreaks.parent._position && 0 <= a))
)
this.ctx.lineTo(c, l), this.ctx.lineTo(m, l), this.ctx.lineTo(m, e);
else if ("wavy" === this.type) {
k = c;
h = e;
g = 0.5;
p = (l - h) / a / 3;
for (var n = 0; n < p; n++)
this.ctx.bezierCurveTo(
k + g * a,
h + a,
k + g * a,
h + 2 * a,
k,
h + 3 * a
),
(h += 3 * a),
(g *= -1);
this.ctx.bezierCurveTo(
k + g * a,
h + a,
k + g * a,
h + 2 * a,
k,
h + 3 * a
);
k = m;
g *= -1;
this.ctx.lineTo(k, h);
for (n = 0; n < p; n++)
this.ctx.bezierCurveTo(
k + g * a,
h - a,
k + g * a,
h - 2 * a,
k,
h - 3 * a
),
(h -= 3 * a),
(g *= -1);
} else {
if ("zigzag" === this.type) {
g = -1;
h = e + a;
k = c + a;
p = (l - h) / a / 2;
for (n = 0; n < p; n++)
this.ctx.lineTo(k, h),
(k += 2 * g * a),
(h += 2 * a),
(g *= -1);
this.ctx.lineTo(k, h);
k += m - c;
for (n = 0; n < p + 1; n++)
this.ctx.lineTo(k, h),
(k += 2 * g * a),
(h -= 2 * a),
(g *= -1);
this.ctx.lineTo(k + g * a, h + a);
}
}
else if (
"left" === this.scaleBreaks.parent._position ||
"right" === this.scaleBreaks.parent._position
)
if (
((e = 1 === q % 2 ? (e.y << 0) + 0.5 : e.y << 0),
(l = 1 === q % 2 ? (c.y << 0) + 0.5 : c.y << 0),
"left" === this.scaleBreaks.parent._position
? ((c = this.chart.plotArea.x1),
(m = (this.chart.plotArea.x2 + q / 2 + 0.5) << 0))
: ((c = this.chart.plotArea.x2),
(m = (this.chart.plotArea.x1 - q / 2 + 0.5) << 0),
(a *= -1)),
(this.bounds = { x1: c, y1: e - q / 2, x2: m, y2: l + q / 2 }),
this.ctx.moveTo(c, e),
"straight" === this.type ||
("left" === this.scaleBreaks.parent._position && 0 >= a) ||
("right" === this.scaleBreaks.parent._position && 0 <= a))
)
this.ctx.lineTo(m, e), this.ctx.lineTo(m, l), this.ctx.lineTo(c, l);
else if ("wavy" === this.type) {
k = c;
h = e;
g = 0.5;
p = (m - k) / a / 3;
for (n = 0; n < p; n++)
this.ctx.bezierCurveTo(
k + a,
h + g * a,
k + 2 * a,
h + g * a,
k + 3 * a,
h
),
(k += 3 * a),
(g *= -1);
this.ctx.bezierCurveTo(
k + a,
h + g * a,
k + 2 * a,
h + g * a,
k + 3 * a,
h
);
h = l;
g *= -1;
this.ctx.lineTo(k, h);
for (n = 0; n < p; n++)
this.ctx.bezierCurveTo(
k - a,
h + g * a,
k - 2 * a,
h + g * a,
k - 3 * a,
h
),
(k -= 3 * a),
(g *= -1);
} else if ("zigzag" === this.type) {
g = 1;
h = e - a;
k = c + a;
p = (m - k) / a / 2;
for (n = 0; n < p; n++)
this.ctx.lineTo(k, h), (h += 2 * g * a), (k += 2 * a), (g *= -1);
this.ctx.lineTo(k, h);
h += l - e;
for (n = 0; n < p + 1; n++)
this.ctx.lineTo(k, h), (h += 2 * g * a), (k -= 2 * a), (g *= -1);
this.ctx.lineTo(k + a, h + g * a);
}
0 < q && this.ctx.stroke();
this.ctx.closePath();
this.ctx.globalAlpha = this.fillOpacity;
this.ctx.globalCompositeOperation = "destination-over";
this.ctx.fill();
this.ctx.restore();
this.ctx.globalAlpha = b;
this.ctx = d;
}
};
qa(X, V);
X.prototype.createUserOptions = function (a) {
if ("undefined" !== typeof a || this.options._isPlaceholder) {
var d = 0;
this.parent.options._isPlaceholder && this.parent.createUserOptions();
this.options._isPlaceholder ||
(Fa(this.parent.stripLines),
(d = this.parent.options.stripLines.indexOf(this.options)));
this.options = "undefined" === typeof a ? {} : a;
this.parent.options.stripLines[d] = this.options;
}
};
X.prototype.render = function () {
this.ctx.save();
var a = this.parent.getPixelCoordinatesOnAxis(this.value),
d = Math.abs(
"pixel" === this._thicknessType
? this.thickness
: this.parent.conversionParameters.pixelPerUnit * this.thickness
);
if (0 < d) {
var b = null === this.opacity ? 1 : this.opacity;
this.ctx.strokeStyle = this.color;
this.ctx.beginPath();
var c = this.ctx.globalAlpha;
this.ctx.globalAlpha = b;
N(this.id);
var e, g, m, l;
this.ctx.lineWidth = d;
this.ctx.setLineDash && this.ctx.setLineDash(R(this.lineDashType, d));
if (
"bottom" === this.parent._position ||
"top" === this.parent._position
)
(e = g = 1 === this.ctx.lineWidth % 2 ? (a.x << 0) + 0.5 : a.x << 0),
(m = this.chart.plotArea.y1),
(l = this.chart.plotArea.y2),
(this.bounds = { x1: e - d / 2, y1: m, x2: g + d / 2, y2: l });
else if (
"left" === this.parent._position ||
"right" === this.parent._position
)
(m = l = 1 === this.ctx.lineWidth % 2 ? (a.y << 0) + 0.5 : a.y << 0),
(e = this.chart.plotArea.x1),
(g = this.chart.plotArea.x2),
(this.bounds = { x1: e, y1: m - d / 2, x2: g, y2: l + d / 2 });
this.ctx.moveTo(e, m);
this.ctx.lineTo(g, l);
this.ctx.stroke();
this.ctx.globalAlpha = c;
}
this.ctx.restore();
};
qa(fa, V);
fa.prototype.render = function (a, d) {
var b,
c,
e,
g,
m = null,
l = (m = null),
k = "";
if (!this.valueFormatString)
if ("dateTime" === this.parent.valueType)
this.valueFormatString = this.parent.valueFormatString;
else {
var h = 0,
h =
"xySwapped" === this.chart.plotInfo.axisPlacement
? 50 < this.parent.range
? 0
: 500 < this.chart.width && 25 > this.parent.range
? 2
: Math.floor(
Math.abs(Math.log(this.parent.range) / Math.LN10)
) +
(5 > this.parent.range ? 2 : 10 > this.parent.range ? 1 : 0)
: 50 < this.parent.range
? 0
: Math.floor(
Math.abs(Math.log(this.parent.range) / Math.LN10)
) +
(5 > this.parent.range ? 2 : 10 > this.parent.range ? 1 : 0);
this.valueFormatString = z.generateValueFormatString(
this.parent.range,
h
);
}
var l = null === this.opacity ? 1 : this.opacity,
h = Math.abs(
"pixel" === this._thicknessType
? this.thickness
: this.parent.conversionParameters.pixelPerUnit * this.thickness
),
p = this.chart.overlaidCanvasCtx,
q = p.globalAlpha;
p.globalAlpha = l;
p.beginPath();
p.strokeStyle = this.color;
p.lineWidth = h;
p.save();
this.labelFontSize = u(this.options.labelFontSize)
? this.parent.labelFontSize
: this.labelFontSize;
if ("left" === this.parent._position || "right" === this.parent._position)
(this.labelMaxWidth = u(this.options.labelMaxWidth)
? this.parent.bounds.x2 - this.parent.bounds.x1
: this.labelMaxWidth),
(this.labelMaxHeight =
u(this.options.labelWrap) || this.labelWrap
? 3 * this.chart.height
: 2 * this.labelFontSize);
else if (
"top" === this.parent._position ||
"bottom" === this.parent._position
)
(this.labelMaxWidth = u(this.options.labelMaxWidth)
? 3 * this.chart.width
: this.labelMaxWidth),
(this.labelMaxHeight =
u(this.options.labelWrap) || this.labelWrap
? this.parent.bounds.height
: 2 * this.labelFontSize);
0 < h && p.setLineDash && p.setLineDash(R(this.lineDashType, h));
l = new ka(p, {
x: 0,
y: 0,
padding: { top: 2, right: 3, bottom: 2, left: 4 },
backgroundColor: this.labelBackgroundColor,
borderColor: this.labelBorderColor,
borderThickness: this.labelBorderThickness,
cornerRadius: this.labelCornerRadius,
maxWidth: this.labelMaxWidth,
maxHeight: this.labelMaxHeight,
angle: this.labelAngle,
text: k,
horizontalAlign: "left",
fontSize: this.labelFontSize,
fontFamily: this.labelFontFamily,
fontWeight: this.labelFontWeight,
fontColor: this.labelFontColor,
fontStyle: this.labelFontStyle,
textBaseline: "middle",
});
if (this.snapToDataPoint) {
var n = 0,
m = [];
if ("xySwapped" === this.chart.plotInfo.axisPlacement) {
var f = null;
if (
"bottom" === this.parent._position ||
"top" === this.parent._position
)
n = this.parent.dataSeries[0].axisX.convertPixelToValue({ y: d });
else if (
"left" === this.parent._position ||
"right" === this.parent._position
)
n = this.parent.convertPixelToValue({ y: d });
for (var r = 0; r < this.parent.dataSeries.length; r++)
(f = this.parent.dataSeries[r].getDataPointAtX(n, !0)) &&
0 <= f.index &&
((f.dataSeries = this.parent.dataSeries[r]),
null !== f.dataPoint.y && m.push(f));
f = null;
if (0 === m.length) return;
m.sort(function (a, b) {
return a.distance - b.distance;
});
f = Math.abs(a - this.parent.convertValueToPixel(m[0].dataPoint.y));
r = 0;
if (
"rangeBar" === m[0].dataSeries.type ||
"error" === m[0].dataSeries.type
)
for (
var f = Math.abs(
a - this.parent.convertValueToPixel(m[r].dataPoint.y[0])
),
v = 0,
n = 0;
n < m.length;
n++
)
if (m[n].dataPoint.y && m[n].dataPoint.y.length)
for (k = 0; k < m[n].dataPoint.y.length; k++)
(v = Math.abs(
a - this.parent.convertValueToPixel(m[n].dataPoint.y[k])
)),
v < f && ((f = v), (r = n));
else
(v = Math.abs(
a - this.parent.convertValueToPixel(m[n].dataPoint.y)
)),
v < f && ((f = v), (r = n));
else if ("stackedBar" === m[0].dataSeries.type)
for (
var f = Math.abs(
a - this.parent.convertValueToPixel(m[0].dataPoint.y)
),
D = (v = 0),
n = (r = 0);
n < m.length;
n++
)
if (m[n].dataPoint.y && m[n].dataPoint.y.length)
for (k = 0; k < m[n].dataPoint.y.length; k++)
(v = Math.abs(
a - this.parent.convertValueToPixel(m[n].dataPoint.y[k])
)),
v < f && ((f = v), (r = n));
else
(D += m[n].dataPoint.y),
(v = Math.abs(a - this.parent.convertValueToPixel(D))),
v < f && ((f = v), (r = n));
else if ("stackedBar100" === m[0].dataSeries.type)
for (
var f = Math.abs(
a - this.parent.convertValueToPixel(m[0].dataPoint.y)
),
t = (D = v = 0),
n = 0;
n < m.length;
n++
)
if (m[n].dataPoint.y && m[n].dataPoint.y.length)
for (k = 0; k < m[n].dataPoint.y.length; k++)
(v = Math.abs(
a - this.parent.convertValueToPixel(m[n].dataPoint.y[k])
)),
v < f && ((f = v), (r = n));
else
(D += m[n].dataPoint.y),
(t = m[n].dataPoint.x.getTime
? m[n].dataPoint.x.getTime()
: m[n].dataPoint.x),
(t = 100 * (D / m[n].dataSeries.plotUnit.dataPointYSums[t])),
(v = Math.abs(a - this.parent.convertValueToPixel(t))),
v < f && ((f = v), (r = n));
else
for (
f = Math.abs(
a - this.parent.convertValueToPixel(m[0].dataPoint.y)
),
n = r = v = 0;
n < m.length;
n++
)
if (m[n].dataPoint.y && m[n].dataPoint.y.length)
for (k = 0; k < m[n].dataPoint.y.length; k++)
(v = Math.abs(
a - this.parent.convertValueToPixel(m[n].dataPoint.y[k])
)),
v < f && ((f = v), (r = n));
else
(v = Math.abs(
a - this.parent.convertValueToPixel(m[n].dataPoint.y)
)),
v < f && ((f = v), (r = n));
k = m[r];
if (
"bottom" === this.parent._position ||
"top" === this.parent._position
) {
b = 0;
if (
"rangeBar" === this.parent.dataSeries[r].type ||
"error" === this.parent.dataSeries[r].type
) {
f = Math.abs(
a - this.parent.convertValueToPixel(k.dataPoint.y[0])
);
for (n = v = 0; n < k.dataPoint.y.length; n++)
(v = Math.abs(
a - this.parent.convertValueToPixel(k.dataPoint.y[n])
)),
v < f && ((f = v), (b = n));
m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(k.dataPoint.y[b]) << 0) +
0.5
: this.parent.convertValueToPixel(k.dataPoint.y[b]) << 0;
l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.y[b],
})
: u(this.options.label)
? ba(
k.dataPoint.y[b],
this.valueFormatString,
this.chart._cultureInfo
)
: this.label;
} else if ("stackedBar" === this.parent.dataSeries[r].type) {
f = Math.abs(
a - this.parent.convertValueToPixel(m[0].dataPoint.y)
);
D = v = 0;
for (n = r; 0 <= n; n--)
(D += m[n].dataPoint.y),
(v = Math.abs(a - this.parent.convertValueToPixel(D))),
v < f && ((f = v), (b = n));
m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(D) << 0) + 0.5
: this.parent.convertValueToPixel(D) << 0;
l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.y,
})
: u(this.options.label)
? ba(
k.dataPoint.y,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label;
} else if ("stackedBar100" === this.parent.dataSeries[r].type) {
f = Math.abs(
a - this.parent.convertValueToPixel(m[0].dataPoint.y)
);
t = D = v = 0;
for (n = r; 0 <= n; n--)
(D += m[n].dataPoint.y),
(t = m[n].dataPoint.x.getTime
? m[n].dataPoint.x.getTime()
: m[n].dataPoint.x),
(t = 100 * (D / m[n].dataSeries.plotUnit.dataPointYSums[t])),
(v = Math.abs(a - this.parent.convertValueToPixel(t))),
v < f && ((f = v), (b = n));
m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(t) << 0) + 0.5
: this.parent.convertValueToPixel(t) << 0;
l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: t,
})
: u(this.options.label)
? ba(t, this.valueFormatString, this.chart._cultureInfo)
: this.label;
} else
(m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(k.dataPoint.y) << 0) + 0.5
: this.parent.convertValueToPixel(k.dataPoint.y) << 0),
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.y,
})
: u(this.options.label)
? ba(
k.dataPoint.y,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label);
b = c = m;
e = this.chart.plotArea.y1;
g = this.chart.plotArea.y2;
this.bounds = { x1: b - h / 2, y1: e, x2: c + h / 2, y2: g };
l.x = b - l.measureText().width / 2;
l.x + l.width > this.chart.bounds.x2
? (l.x = this.chart.bounds.x2 - l.width)
: l.x < this.chart.bounds.x1 && (l.x = this.chart.bounds.x1);
l.y = this.parent.lineCoordinates.y2 + l.fontSize / 2 + 2;
} else if (
"left" === this.parent._position ||
"right" === this.parent._position
) {
e =
g =
m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(k.dataPoint.x) << 0) + 0.5
: this.parent.convertValueToPixel(k.dataPoint.x) << 0;
b = this.chart.plotArea.x1;
c = this.chart.plotArea.x2;
this.bounds = { x1: b, y1: e - h / 2, x2: c, y2: g + h / 2 };
t = !1;
if (this.parent.labels)
for (
m = Math.ceil(this.parent.interval), n = 0;
n < this.parent.viewportMaximum;
n += m
)
if (this.parent.labels[n]) t = !0;
else {
t = !1;
break;
}
if (t) {
if ("axisX" === this.parent.type)
for (
n = this.parent.convertPixelToValue({ y: d }),
f = null,
r = 0;
r < this.parent.dataSeries.length;
r++
)
(f = this.parent.dataSeries[r].getDataPointAtX(n, !0)) &&
0 <= f.index &&
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.x,
})
: u(this.options.label)
? f.dataPoint.label
: this.label);
} else
"dateTime" === this.parent.valueType
? (l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.x,
})
: u(this.options.label)
? Ca(
k.dataPoint.x,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label)
: "number" === this.parent.valueType &&
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.x,
})
: u(this.options.label)
? ba(
k.dataPoint.x,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label);
l.y = g + l.fontSize / 2 - l.measureText().height / 2 + 2;
l.y - l.fontSize / 2 < this.chart.bounds.y1
? (l.y = this.chart.bounds.y1 + l.fontSize / 2 + 2)
: l.y + l.measureText().height - l.fontSize / 2 >
this.chart.bounds.y2 &&
(l.y =
this.chart.bounds.y2 -
l.measureText().height +
l.fontSize / 2);
"left" === this.parent._position
? (l.x = this.parent.lineCoordinates.x2 - l.measureText().width)
: "right" === this.parent._position &&
(l.x = this.parent.lineCoordinates.x2);
}
} else if (
"bottom" === this.parent._position ||
"top" === this.parent._position
) {
n = this.parent.convertPixelToValue({ x: a });
for (r = 0; r < this.parent.dataSeries.length; r++)
(f = this.parent.dataSeries[r].getDataPointAtX(n, !0)) &&
0 <= f.index &&
((f.dataSeries = this.parent.dataSeries[r]),
null !== f.dataPoint.y && m.push(f));
if (0 === m.length) return;
m.sort(function (a, b) {
return a.distance - b.distance;
});
k = m[0];
b =
c =
m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(k.dataPoint.x) << 0) + 0.5
: this.parent.convertValueToPixel(k.dataPoint.x) << 0;
e = this.chart.plotArea.y1;
g = this.chart.plotArea.y2;
this.bounds = { x1: b - h / 2, y1: e, x2: c + h / 2, y2: g };
t = !1;
if (this.parent.labels)
for (
m = Math.ceil(this.parent.interval), n = 0;
n < this.parent.viewportMaximum;
n += m
)
if (this.parent.labels[n]) t = !0;
else {
t = !1;
break;
}
if (t) {
if ("axisX" === this.parent.type)
for (
n = this.parent.convertPixelToValue({ x: a }), f = null, r = 0;
r < this.parent.dataSeries.length;
r++
)
(f = this.parent.dataSeries[r].getDataPointAtX(n, !0)) &&
0 <= f.index &&
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.x,
})
: u(this.options.label)
? f.dataPoint.label
: this.label);
} else
"dateTime" === this.parent.valueType
? (l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.x,
})
: u(this.options.label)
? Ca(
k.dataPoint.x,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label)
: "number" === this.parent.valueType &&
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.x,
})
: u(this.options.label)
? ba(
k.dataPoint.x,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label);
l.x = b - l.measureText().width / 2;
l.x + l.width > this.chart.bounds.x2 &&
(l.x = this.chart.bounds.x2 - l.width);
l.x < this.chart.bounds.x1 && (l.x = this.chart.bounds.x1);
"bottom" === this.parent._position
? (l.y = this.parent.lineCoordinates.y2 + l.fontSize / 2 + 2)
: "top" === this.parent._position &&
(l.y =
this.parent.lineCoordinates.y1 - l.height + l.fontSize / 2 + 2);
} else if (
"left" === this.parent._position ||
"right" === this.parent._position
) {
!u(this.parent.dataSeries) &&
0 < this.parent.dataSeries.length &&
(n = this.parent.dataSeries[0].axisX.convertPixelToValue({ x: a }));
for (r = 0; r < this.parent.dataSeries.length; r++)
(f = this.parent.dataSeries[r].getDataPointAtX(n, !0)) &&
0 <= f.index &&
((f.dataSeries = this.parent.dataSeries[r]),
null !== f.dataPoint.y && m.push(f));
if (0 === m.length) return;
m.sort(function (a, b) {
return a.distance - b.distance;
});
r = 0;
if (
"rangeColumn" === m[0].dataSeries.type ||
"rangeArea" === m[0].dataSeries.type ||
"error" === m[0].dataSeries.type ||
"rangeSplineArea" === m[0].dataSeries.type ||
"candlestick" === m[0].dataSeries.type ||
"ohlc" === m[0].dataSeries.type ||
"boxAndWhisker" === m[0].dataSeries.type
)
for (
f = Math.abs(
d - this.parent.convertValueToPixel(m[0].dataPoint.y[0])
),
n = v = 0;
n < m.length;
n++
)
if (m[n].dataPoint.y && m[n].dataPoint.y.length)
for (k = 0; k < m[n].dataPoint.y.length; k++)
(v = Math.abs(
d - this.parent.convertValueToPixel(m[n].dataPoint.y[k])
)),
v < f && ((f = v), (r = n));
else
(v = Math.abs(
d - this.parent.convertValueToPixel(m[n].dataPoint.y)
)),
v < f && ((f = v), (r = n));
else if (
"stackedColumn" === m[0].dataSeries.type ||
"stackedArea" === m[0].dataSeries.type
)
for (
f = Math.abs(
d - this.parent.convertValueToPixel(m[0].dataPoint.y)
),
n = D = v = 0;
n < m.length;
n++
)
if (m[n].dataPoint.y && m[n].dataPoint.y.length)
for (k = 0; k < m[n].dataPoint.y.length; k++)
(v = Math.abs(
d - this.parent.convertValueToPixel(m[n].dataPoint.y[k])
)),
v < f && ((f = v), (r = n));
else
(D += m[n].dataPoint.y),
(v = Math.abs(d - this.parent.convertValueToPixel(D))),
v < f && ((f = v), (r = n));
else if (
"stackedColumn100" === m[0].dataSeries.type ||
"stackedArea100" === m[0].dataSeries.type
)
for (
f = Math.abs(
d - this.parent.convertValueToPixel(m[0].dataPoint.y)
),
n = t = D = v = 0;
n < m.length;
n++
)
if (m[n].dataPoint.y && m[n].dataPoint.y.length)
for (k = 0; k < m[n].dataPoint.y.length; k++)
(v = Math.abs(
d - this.parent.convertValueToPixel(m[n].dataPoint.y[k])
)),
v < f && ((f = v), (r = n));
else
(D += m[n].dataPoint.y),
(t = m[n].dataPoint.x.getTime
? m[n].dataPoint.x.getTime()
: m[n].dataPoint.x),
(t = 100 * (D / m[n].dataSeries.plotUnit.dataPointYSums[t])),
(v = Math.abs(d - this.parent.convertValueToPixel(t))),
v < f && ((f = v), (r = n));
else
for (
f = Math.abs(
d - this.parent.convertValueToPixel(m[0].dataPoint.y)
),
n = v = 0;
n < m.length;
n++
)
if (m[n].dataPoint.y && m[n].dataPoint.y.length)
for (k = 0; k < m[n].dataPoint.y.length; k++)
(v = Math.abs(
d - this.parent.convertValueToPixel(m[n].dataPoint.y[k])
)),
v < f && ((f = v), (r = n));
else
(v = Math.abs(
d - this.parent.convertValueToPixel(m[n].dataPoint.y)
)),
v < f && ((f = v), (r = n));
k = m[r];
b = 0;
if (
"rangeColumn" === this.parent.dataSeries[r].type ||
"rangeArea" === this.parent.dataSeries[r].type ||
"error" === this.parent.dataSeries[r].type ||
"rangeSplineArea" === this.parent.dataSeries[r].type ||
"candlestick" === this.parent.dataSeries[r].type ||
"ohlc" === this.parent.dataSeries[r].type ||
"boxAndWhisker" === this.parent.dataSeries[r].type
) {
f = Math.abs(d - this.parent.convertValueToPixel(k.dataPoint.y[0]));
for (n = v = 0; n < k.dataPoint.y.length; n++)
(v = Math.abs(
d - this.parent.convertValueToPixel(k.dataPoint.y[n])
)),
v < f && ((f = v), (b = n));
m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(k.dataPoint.y[b]) << 0) + 0.5
: this.parent.convertValueToPixel(k.dataPoint.y[b]) << 0;
l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.y[b],
})
: u(this.options.label)
? ba(
k.dataPoint.y[b],
this.valueFormatString,
this.chart._cultureInfo
)
: this.label;
} else if (
"stackedColumn" === this.parent.dataSeries[r].type ||
"stackedArea" === this.parent.dataSeries[r].type
) {
f = Math.abs(d - this.parent.convertValueToPixel(m[0].dataPoint.y));
D = v = 0;
for (n = r; 0 <= n; n--)
(D += m[n].dataPoint.y),
(v = Math.abs(d - this.parent.convertValueToPixel(D))),
v < f && ((f = v), (b = n));
m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(D) << 0) + 0.5
: this.parent.convertValueToPixel(D) << 0;
l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.y,
})
: u(this.options.label)
? ba(
k.dataPoint.y,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label;
} else if (
"stackedColumn100" === this.parent.dataSeries[r].type ||
"stackedArea100" === this.parent.dataSeries[r].type
) {
f = Math.abs(d - this.parent.convertValueToPixel(m[0].dataPoint.y));
D = v = 0;
for (n = r; 0 <= n; n--)
(D += m[n].dataPoint.y),
(t = m[n].dataPoint.x.getTime
? m[n].dataPoint.x.getTime()
: m[n].dataPoint.x),
(t = 100 * (D / m[n].dataSeries.plotUnit.dataPointYSums[t])),
(v = Math.abs(d - this.parent.convertValueToPixel(t))),
v < f && ((f = v), (b = n));
m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(t) << 0) + 0.5
: this.parent.convertValueToPixel(t) << 0;
l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: t,
})
: u(this.options.label)
? ba(t, this.valueFormatString, this.chart._cultureInfo)
: this.label;
} else
"waterfall" === this.parent.dataSeries[r].type
? ((m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(
k.dataSeries.dataPointEOs[k.index].cumulativeSum
) <<
0) +
0.5
: this.parent.convertValueToPixel(
k.dataSeries.dataPointEOs[k.index].cumulativeSum
) << 0),
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataSeries.dataPointEOs[k.index].cumulativeSum,
})
: u(this.options.label)
? ba(
k.dataSeries.dataPointEOs[k.index].cumulativeSum,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label))
: ((m =
1 === p.lineWidth % 2
? (this.parent.convertValueToPixel(k.dataPoint.y) << 0) +
0.5
: this.parent.convertValueToPixel(k.dataPoint.y) << 0),
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: k.dataPoint.y,
})
: u(this.options.label)
? ba(
k.dataPoint.y,
this.valueFormatString,
this.chart._cultureInfo
)
: this.label));
e = g = m;
b = this.chart.plotArea.x1;
c = this.chart.plotArea.x2;
this.bounds = { x1: b, y1: e - h / 2, x2: c, y2: g + h / 2 };
l.y = g + l.fontSize / 2 - l.measureText().height / 2 + 2;
l.y - l.fontSize / 2 < this.chart.bounds.y1
? (l.y = this.chart.bounds.y1 + l.fontSize / 2 + 2)
: l.y + l.measureText().height - l.fontSize / 2 >
this.chart.bounds.y2 &&
(l.y =
this.chart.bounds.y2 - l.measureText().height + l.fontSize / 2);
"left" === this.parent._position
? (l.x = this.parent.lineCoordinates.x2 - l.measureText().width)
: "right" === this.parent._position &&
(l.x = this.parent.lineCoordinates.x2);
}
m = null;
("bottom" === this.parent._position ||
"top" === this.parent._position) &&
b >= this.parent.convertValueToPixel(this.parent.viewportMinimum) &&
c <= this.parent.convertValueToPixel(this.parent.viewportMaximum) &&
(0 < h && (p.moveTo(b, e), p.lineTo(c, g), p.stroke()),
p.restore(),
!u(l.text) &&
("number" === typeof l.text.valueOf() || 0 < l.text.length) &&
l.render(!0));
("left" === this.parent._position ||
"right" === this.parent._position) &&
g >= this.parent.convertValueToPixel(this.parent.viewportMaximum) &&
e <= this.parent.convertValueToPixel(this.parent.viewportMinimum) &&
(0 < h && (p.moveTo(b, e), p.lineTo(c, g), p.stroke()),
p.restore(),
!u(l.text) &&
("number" === typeof l.text.valueOf() || 0 < l.text.length) &&
l.render(!0));
} else {
if (
"bottom" === this.parent._position ||
"top" === this.parent._position
)
(b = c = m = 1 === p.lineWidth % 2 ? (a << 0) + 0.5 : a << 0),
(e = this.chart.plotArea.y1),
(g = this.chart.plotArea.y2),
(this.bounds = { x1: b - h / 2, y1: e, x2: c + h / 2, y2: g });
else if (
"left" === this.parent._position ||
"right" === this.parent._position
)
(e = g = m = 1 === p.lineWidth % 2 ? (d << 0) + 0.5 : d << 0),
(b = this.chart.plotArea.x1),
(c = this.chart.plotArea.x2),
(this.bounds = { x1: b, y1: e - h / 2, x2: c, y2: g + h / 2 });
if ("xySwapped" === this.chart.plotInfo.axisPlacement)
if (
"left" === this.parent._position ||
"right" === this.parent._position
) {
t = !1;
if (this.parent.labels)
for (
m = Math.ceil(this.parent.interval), n = 0;
n < this.parent.viewportMaximum;
n += m
)
if (this.parent.labels[n]) t = !0;
else {
t = !1;
break;
}
if (t) {
if ("axisX" === this.parent.type)
for (
n = this.parent.convertPixelToValue({ y: d }),
f = null,
r = 0;
r < this.parent.dataSeries.length;
r++
)
(f = this.parent.dataSeries[r].getDataPointAtX(n, !0)) &&
0 <= f.index &&
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: this.parent.convertPixelToValue(a),
})
: u(this.options.label)
? f.dataPoint.label
: this.label);
} else
"dateTime" === this.parent.valueType
? (l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: this.parent.convertPixelToValue(d),
})
: u(this.options.label)
? Ca(
this.parent.convertPixelToValue(d),
this.valueFormatString,
this.chart._cultureInfo
)
: this.label)
: "number" === this.parent.valueType &&
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: this.parent.convertPixelToValue(d),
})
: u(this.options.label)
? ba(
this.parent.convertPixelToValue(d),
this.valueFormatString,
this.chart._cultureInfo
)
: this.label);
l.y = d + l.fontSize / 2 - l.measureText().height / 2 + 2;
l.y - l.fontSize / 2 < this.chart.bounds.y1
? (l.y = this.chart.bounds.y1 + l.fontSize / 2 + 2)
: l.y + l.measureText().height - l.fontSize / 2 >
this.chart.bounds.y2 &&
(l.y =
this.chart.bounds.y2 -
l.measureText().height +
l.fontSize / 2);
"left" === this.parent._position
? (l.x = this.parent.lineCoordinates.x1 - l.measureText().width)
: "right" === this.parent._position &&
(l.x = this.parent.lineCoordinates.x2);
} else {
if (
"bottom" === this.parent._position ||
"top" === this.parent._position
)
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: this.parent.convertPixelToValue(a),
})
: u(this.options.label)
? ba(
this.parent.convertPixelToValue(a),
this.valueFormatString,
this.chart._cultureInfo
)
: this.label),
(l.x = b - l.measureText().width / 2),
l.x + l.width > this.chart.bounds.x2 &&
(l.x = this.chart.bounds.x2 - l.width),
l.x < this.chart.bounds.x1 && (l.x = this.chart.bounds.x1),
"bottom" === this.parent._position &&
(l.y = this.parent.lineCoordinates.y2 + l.fontSize / 2 + 2),
"top" === this.parent._position &&
(l.y =
this.parent.lineCoordinates.y1 -
l.height +
l.fontSize / 2 +
2);
}
else if (
"bottom" === this.parent._position ||
"top" === this.parent._position
) {
t = !1;
k = "";
if (this.parent.labels)
for (
m = Math.ceil(this.parent.interval), n = 0;
n < this.parent.viewportMaximum;
n += m
)
if (this.parent.labels[n]) t = !0;
else {
t = !1;
break;
}
if (t) {
if ("axisX" === this.parent.type)
for (
n = this.parent.convertPixelToValue({ x: a }), f = null, r = 0;
r < this.parent.dataSeries.length;
r++
)
(f = this.parent.dataSeries[r].getDataPointAtX(n, !0)) &&
0 <= f.index &&
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: this.parent.convertPixelToValue(a),
})
: u(this.options.label)
? f.dataPoint.label
: this.label);
} else
"dateTime" === this.parent.valueType
? (l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: this.parent.convertPixelToValue(a),
})
: u(this.options.label)
? Ca(
this.parent.convertPixelToValue(a),
this.valueFormatString,
this.chart._cultureInfo
)
: this.label)
: "number" === this.parent.valueType &&
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value:
0 < this.parent.dataSeries.length
? this.parent.convertPixelToValue(a)
: "",
})
: u(this.options.label)
? ba(
this.parent.convertPixelToValue(a),
this.valueFormatString,
this.chart._cultureInfo
)
: this.label);
l.x = b - l.measureText().width / 2;
l.x + l.width > this.chart.bounds.x2 &&
(l.x = this.chart.bounds.x2 - l.width);
l.x < this.chart.bounds.x1 && (l.x = this.chart.bounds.x1);
"bottom" === this.parent._position
? (l.y = this.parent.lineCoordinates.y2 + l.fontSize / 2 + 2)
: "top" === this.parent._position &&
(l.y =
this.parent.lineCoordinates.y1 - l.height + l.fontSize / 2 + 2);
} else if (
"left" === this.parent._position ||
"right" === this.parent._position
)
(l.text = this.labelFormatter
? this.labelFormatter({
chart: this.chart,
axis: this.parent.options,
crosshair: this.options,
value: this.parent.convertPixelToValue(d),
})
: u(this.options.label)
? ba(
this.parent.convertPixelToValue(d),
this.valueFormatString,
this.chart._cultureInfo
)
: this.label),
(l.y = d + l.fontSize / 2 - l.measureText().height / 2 + 2),
l.y - l.fontSize / 2 < this.chart.bounds.y1
? (l.y = this.chart.bounds.y1 + l.fontSize / 2 + 2)
: l.y + l.measureText().height - l.fontSize / 2 >
this.chart.bounds.y2 &&
(l.y =
this.chart.bounds.y2 -
l.measureText().height +
l.fontSize / 2),
"left" === this.parent._position
? (l.x = this.parent.lineCoordinates.x2 - l.measureText().width)
: "right" === this.parent._position &&
(l.x = this.parent.lineCoordinates.x2);
0 < h && (p.moveTo(b, e), p.lineTo(c, g), p.stroke());
p.restore();
!u(l.text) &&
("number" === typeof l.text.valueOf() || 0 < l.text.length) &&
l.render(!0);
}
p.globalAlpha = q;
};
qa($, V);
$.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.pointerEvents = "none";
this.container.style.display = "none";
var a;
a = '<div style=" width: auto;height: auto;min-width: 50px;';
a += "line-height: auto;";
a += "margin: 0px 0px 0px 0px;";
a += "padding: 5px;";
a += "font-family: Calibri, Arial, Georgia, serif;";
a += "font-weight: normal;";
a += "font-style: " + (r ? "italic;" : "normal;");
a += "font-size: 14px;";
a += "color: #000000;";
a += "text-shadow: 1px 1px 1px rgba(0, 0, 0, 0.1);";
a += "text-align: left;";
a += "border: 2px solid gray;";
a += r
? "background: rgba(255,255,255,.9);"
: "background: rgb(255,255,255);";
a += "text-indent: 0px;";
a += "white-space: nowrap;";
a += "border-radius: 5px;";
a += "-moz-user-select:none;";
a += "-khtml-user-select: none;";
a += "-webkit-user-select: none;";
a += "-ms-user-select: none;";
a += "user-select: none;";
r ||
((a += "filter: alpha(opacity = 90);"),
(a +=
"filter: progid:DXImageTransform.Microsoft.Shadow(Strength=3, Direction=135, Color='#666666');"));
a += '} "> Sample Tooltip</div>';
this.container.innerHTML = a;
this.contentDiv = this.container.firstChild;
this.container.style.borderRadius = this.contentDiv.style.borderRadius;
this.chart._canvasJSContainer.appendChild(this.container);
}
};
$.prototype.mouseMoveHandler = function (a, d) {
(this._lastUpdated && 4 > new Date().getTime() - this._lastUpdated) ||
((this._lastUpdated = new Date().getTime()),
this.chart.resetOverlayedCanvas(),
this._updateToolTip(a, d));
};
$.prototype._updateToolTip = function (a, d, b) {
b = "undefined" === typeof b ? !0 : b;
this.container || this._initialize();
this.enabled || this.hide();
if (!this.chart.disableToolTip) {
if ("undefined" === typeof a || "undefined" === typeof d) {
if (isNaN(this._prevX) || isNaN(this._prevY)) return;
a = this._prevX;
d = this._prevY;
} else (this._prevX = a), (this._prevY = d);
var c = null,
e = null,
g = [],
k = 0;
if (
this.shared &&
this.enabled &&
"none" !== this.chart.plotInfo.axisPlacement
) {
if ("xySwapped" === this.chart.plotInfo.axisPlacement) {
var l = [];
if (this.chart.axisX)
for (var p = 0; p < this.chart.axisX.length; p++) {
for (
var k = this.chart.axisX[p].convertPixelToValue({ y: d }),
h = null,
c = 0;
c < this.chart.axisX[p].dataSeries.length;
c++
)
(h = this.chart.axisX[p].dataSeries[c].getDataPointAtX(
k,
b
)) &&
0 <= h.index &&
((h.dataSeries = this.chart.axisX[p].dataSeries[c]),
null !== h.dataPoint.y && l.push(h));
h = null;
}
if (this.chart.axisX2)
for (p = 0; p < this.chart.axisX2.length; p++) {
k = this.chart.axisX2[p].convertPixelToValue({ y: d });
h = null;
for (c = 0; c < this.chart.axisX2[p].dataSeries.length; c++)
(h = this.chart.axisX2[p].dataSeries[c].getDataPointAtX(
k,
b
)) &&
0 <= h.index &&
((h.dataSeries = this.chart.axisX2[p].dataSeries[c]),
null !== h.dataPoint.y && l.push(h));
h = null;
}
} else {
l = [];
if (this.chart.axisX)
for (p = 0; p < this.chart.axisX.length; p++)
for (
k = this.chart.axisX[p].convertPixelToValue({ x: a }),
h = null,
c = 0;
c < this.chart.axisX[p].dataSeries.length;
c++
)
(h = this.chart.axisX[p].dataSeries[c].getDataPointAtX(
k,
b
)) &&
0 <= h.index &&
((h.dataSeries = this.chart.axisX[p].dataSeries[c]),
null !== h.dataPoint.y && l.push(h));
if (this.chart.axisX2)
for (p = 0; p < this.chart.axisX2.length; p++)
for (
k = this.chart.axisX2[p].convertPixelToValue({ x: a }),
h = null,
c = 0;
c < this.chart.axisX2[p].dataSeries.length;
c++
)
(h = this.chart.axisX2[p].dataSeries[c].getDataPointAtX(
k,
b
)) &&
0 <= h.index &&
((h.dataSeries = this.chart.axisX2[p].dataSeries[c]),
null !== h.dataPoint.y && l.push(h));
}
if (0 === l.length) return;
l.sort(function (a, b) {
return a.distance - b.distance;
});
b = l[0];
for (c = 0; c < l.length; c++)
l[c].dataPoint.x.valueOf() === b.dataPoint.x.valueOf() &&
g.push(l[c]);
l = null;
} else {
if ((h = this.chart.getDataPointAtXY(a, d, b)))
(this.currentDataPointIndex = h.dataPointIndex),
(this.currentSeriesIndex = h.dataSeries.index);
else if (r)
if (
((h = ab(a, d, this.chart._eventManager.ghostCtx)),
0 < h &&
"undefined" !== typeof this.chart._eventManager.objectMap[h])
) {
h = this.chart._eventManager.objectMap[h];
if ("legendItem" === h.objectType) return;
this.currentSeriesIndex = h.dataSeriesIndex;
this.currentDataPointIndex =
0 <= h.dataPointIndex ? h.dataPointIndex : -1;
} else this.currentDataPointIndex = -1;
else this.currentDataPointIndex = -1;
if (0 <= this.currentSeriesIndex) {
e = this.chart.data[this.currentSeriesIndex];
h = {};
if (0 <= this.currentDataPointIndex)
(c = e.dataPoints[this.currentDataPointIndex]),
(h.dataSeries = e),
(h.dataPoint = c),
(h.index = this.currentDataPointIndex),
(h.distance = Math.abs(c.x - k)),
"waterfall" === e.type &&
((h.cumulativeSumYStartValue =
e.dataPointEOs[
this.currentDataPointIndex
].cumulativeSumYStartValue),
(h.cumulativeSum =
e.dataPointEOs[this.currentDataPointIndex].cumulativeSum));
else {
if (
!this.enabled ||
("line" !== e.type &&
"stepLine" !== e.type &&
"spline" !== e.type &&
"area" !== e.type &&
"stepArea" !== e.type &&
"splineArea" !== e.type &&
"stackedArea" !== e.type &&
"stackedArea100" !== e.type &&
"rangeArea" !== e.type &&
"rangeSplineArea" !== e.type &&
"candlestick" !== e.type &&
"ohlc" !== e.type &&
"boxAndWhisker" !== e.type)
)
return;
k = e.axisX.convertPixelToValue({ x: a });
h = e.getDataPointAtX(k, b);
h.dataSeries = e;
this.currentDataPointIndex = h.index;
c = h.dataPoint;
}
if (!u(h.dataPoint.y))
if (h.dataSeries.axisY)
if (0 < h.dataPoint.y.length) {
for (c = b = 0; c < h.dataPoint.y.length; c++)
h.dataPoint.y[c] < h.dataSeries.axisY.viewportMinimum
? b--
: h.dataPoint.y[c] > h.dataSeries.axisY.viewportMaximum &&
b++;
b < h.dataPoint.y.length &&
b > -h.dataPoint.y.length &&
g.push(h);
} else
"column" === e.type || "bar" === e.type
? 0 > h.dataPoint.y
? 0 > h.dataSeries.axisY.viewportMinimum &&
h.dataSeries.axisY.viewportMaximum >= h.dataPoint.y &&
g.push(h)
: h.dataSeries.axisY.viewportMinimum <= h.dataPoint.y &&
0 <= h.dataSeries.axisY.viewportMaximum &&
g.push(h)
: "bubble" === e.type
? ((b =
this.chart._eventManager.objectMap[
e.dataPointIds[h.index]
].size / 2),
h.dataPoint.y >= h.dataSeries.axisY.viewportMinimum - b &&
h.dataPoint.y <=
h.dataSeries.axisY.viewportMaximum + b &&
g.push(h))
: "waterfall" === e.type
? ((b = 0),
h.cumulativeSumYStartValue <
h.dataSeries.axisY.viewportMinimum
? b--
: h.cumulativeSumYStartValue >
h.dataSeries.axisY.viewportMaximum && b++,
h.cumulativeSum < h.dataSeries.axisY.viewportMinimum
? b--
: h.cumulativeSum >
h.dataSeries.axisY.viewportMaximum && b++,
2 > b && -2 < b && g.push(h))
: (0 <= h.dataSeries.type.indexOf("100") ||
"stackedColumn" === e.type ||
"stackedBar" === e.type ||
(h.dataPoint.y >= h.dataSeries.axisY.viewportMinimum &&
h.dataPoint.y <=
h.dataSeries.axisY.viewportMaximum)) &&
g.push(h);
else g.push(h);
}
}
if (0 < g.length && (this.highlightObjects(g), this.enabled))
if (
((b = ""),
(b = this.getToolTipInnerHTML({ entries: g })),
null !== b)
) {
this.contentDiv.innerHTML = b;
b = !1;
"none" === this.container.style.display &&
((b = !0), (this.container.style.display = "block"));
try {
(this.contentDiv.style.background = this.backgroundColor
? this.backgroundColor
: r
? "rgba(255,255,255,.9)"
: "rgb(255,255,255)"),
(this.borderColor =
"waterfall" === g[0].dataSeries.type
? (this.contentDiv.style.borderRightColor =
this.contentDiv.style.borderLeftColor =
this.contentDiv.style.borderColor =
this.options.borderColor
? this.options.borderColor
: g[0].dataPoint.color
? g[0].dataPoint.color
: 0 < g[0].dataPoint.y
? g[0].dataSeries.risingColor
: g[0].dataSeries.fallingColor)
: "error" === g[0].dataSeries.type
? (this.contentDiv.style.borderRightColor =
this.contentDiv.style.borderLeftColor =
this.contentDiv.style.borderColor =
this.options.borderColor
? this.options.borderColor
: g[0].dataSeries.color
? g[0].dataSeries.color
: g[0].dataSeries._colorSet[
e.index % g[0].dataSeries._colorSet.length
])
: (this.contentDiv.style.borderRightColor =
this.contentDiv.style.borderLeftColor =
this.contentDiv.style.borderColor =
this.options.borderColor
? this.options.borderColor
: g[0].dataPoint.color
? g[0].dataPoint.color
: g[0].dataSeries.color
? g[0].dataSeries.color
: g[0].dataSeries._colorSet[
g[0].index % g[0].dataSeries._colorSet.length
])),
(this.contentDiv.style.borderWidth =
this.borderThickness || 0 === this.borderThickness
? this.borderThickness + "px"
: "2px"),
(this.contentDiv.style.borderRadius =
this.cornerRadius || 0 === this.cornerRadius
? this.cornerRadius + "px"
: "5px"),
(this.container.style.borderRadius =
this.contentDiv.style.borderRadius),
(this.contentDiv.style.fontSize =
this.fontSize || 0 === this.fontSize
? 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
: r
? "italic"
: "normal");
} catch (s) {}
"pie" === g[0].dataSeries.type ||
"doughnut" === g[0].dataSeries.type ||
"funnel" === g[0].dataSeries.type ||
"pyramid" === g[0].dataSeries.type ||
"bar" === g[0].dataSeries.type ||
"rangeBar" === g[0].dataSeries.type ||
"stackedBar" === g[0].dataSeries.type ||
"stackedBar100" === g[0].dataSeries.type
? (a = a - 10 - this.container.clientWidth)
: ((a =
(g[0].dataSeries.axisX.convertValueToPixel(g[0].dataPoint.x) -
this.container.clientWidth) <<
0),
(a -= 10));
0 > a && (a += this.container.clientWidth + 20);
a + this.container.clientWidth >
Math.max(this.chart.container.clientWidth, this.chart.width) &&
(a = Math.max(
0,
Math.max(this.chart.container.clientWidth, this.chart.width) -
this.container.clientWidth
));
d =
1 !== g.length ||
this.shared ||
("line" !== g[0].dataSeries.type &&
"stepLine" !== g[0].dataSeries.type &&
"spline" !== g[0].dataSeries.type &&
"area" !== g[0].dataSeries.type &&
"stepArea" !== g[0].dataSeries.type &&
"splineArea" !== g[0].dataSeries.type)
? "bar" === g[0].dataSeries.type ||
"rangeBar" === g[0].dataSeries.type ||
"stackedBar" === g[0].dataSeries.type ||
"stackedBar100" === g[0].dataSeries.type
? g[0].dataSeries.axisX.convertValueToPixel(g[0].dataPoint.x)
: d
: g[0].dataSeries.axisY.convertValueToPixel(g[0].dataPoint.y);
d = -d + 10;
0 < d + this.container.clientHeight + 5 &&
(d -= d + this.container.clientHeight + 5 - 0);
this.fixMozTransitionDelay(a, d);
!this.animationEnabled || b
? this.disableAnimation()
: (this.enableAnimation(),
(this.container.style.MozTransition =
this.mozContainerTransition));
this.container.style.left = a + "px";
this.container.style.bottom = d + "px";
} else this.hide(!1);
}
};
$.prototype.highlightObjects = function (a) {
var d = this.chart.overlaidCanvasCtx;
this.chart.resetOverlayedCanvas();
d.clearRect(0, 0, this.chart.width, this.chart.height);
d.save();
var b = this.chart.plotArea,
c = 0;
d.beginPath();
d.rect(b.x1, b.y1, b.x2 - b.x1, b.y2 - b.y1);
d.clip();
for (b = 0; b < a.length; b++) {
var e = a[b];
if (
(e =
this.chart._eventManager.objectMap[
e.dataSeries.dataPointIds[e.index]
]) &&
e.objectType &&
"dataPoint" === e.objectType
) {
var c = this.chart.data[e.dataSeriesIndex],
g = c.dataPoints[e.dataPointIndex],
k = e.dataPointIndex;
!1 === g.highlightEnabled ||
(!0 !== c.highlightEnabled && !0 !== g.highlightEnabled) ||
("line" === c.type ||
"stepLine" === c.type ||
"spline" === c.type ||
"scatter" === c.type ||
"area" === c.type ||
"stepArea" === c.type ||
"splineArea" === c.type ||
"stackedArea" === c.type ||
"stackedArea100" === c.type ||
"rangeArea" === c.type ||
"rangeSplineArea" === c.type
? ((g = c.getMarkerProperties(
k,
e.x1,
e.y1,
this.chart.overlaidCanvasCtx
)),
(g.size = Math.max((1.5 * g.size) << 0, 10)),
(g.borderColor = g.borderColor || "#FFFFFF"),
(g.borderThickness =
g.borderThickness || Math.ceil(0.1 * g.size)),
ia.drawMarkers([g]),
"undefined" !== typeof e.y2 &&
((g = c.getMarkerProperties(
k,
e.x1,
e.y2,
this.chart.overlaidCanvasCtx
)),
(g.size = Math.max((1.5 * g.size) << 0, 10)),
(g.borderColor = g.borderColor || "#FFFFFF"),
(g.borderThickness =
g.borderThickness || Math.ceil(0.1 * g.size)),
ia.drawMarkers([g])))
: "bubble" === c.type
? ((g = c.getMarkerProperties(
k,
e.x1,
e.y1,
this.chart.overlaidCanvasCtx
)),
(g.size = e.size),
(g.color = "white"),
(g.borderColor = "white"),
(d.globalAlpha = 0.3),
ia.drawMarkers([g]),
(d.globalAlpha = 1))
: "column" === c.type ||
"stackedColumn" === c.type ||
"stackedColumn100" === c.type ||
"bar" === c.type ||
"rangeBar" === c.type ||
"stackedBar" === c.type ||
"stackedBar100" === c.type ||
"rangeColumn" === c.type ||
"waterfall" === c.type
? ea(
d,
e.x1,
e.y1,
e.x2,
e.y2,
"white",
0,
null,
!1,
!1,
!1,
!1,
0.3
)
: "pie" === c.type || "doughnut" === c.type
? ja(
d,
e.center,
e.radius,
"white",
c.type,
e.startAngle,
e.endAngle,
0.3,
e.percentInnerRadius
)
: "funnel" === c.type || "pyramid" === c.type
? ra(d, e.funnelSection, 0.3, "white")
: "candlestick" === c.type
? ((d.globalAlpha = 1),
(d.strokeStyle = e.color),
(d.lineWidth = 2 * e.borderThickness),
(c = 0 === d.lineWidth % 2 ? 0 : 0.5),
d.beginPath(),
d.moveTo(e.x3 - c, Math.min(e.y2, e.y3)),
d.lineTo(e.x3 - c, Math.min(e.y1, e.y4)),
d.stroke(),
d.beginPath(),
d.moveTo(e.x3 - c, Math.max(e.y1, e.y4)),
d.lineTo(e.x3 - c, Math.max(e.y2, e.y3)),
d.stroke(),
ea(
d,
e.x1,
Math.min(e.y1, e.y4),
e.x2,
Math.max(e.y1, e.y4),
"transparent",
2 * e.borderThickness,
e.color,
!1,
!1,
!1,
!1
),
(d.globalAlpha = 1))
: "ohlc" === c.type
? ((d.globalAlpha = 1),
(d.strokeStyle = e.color),
(d.lineWidth = 2 * e.borderThickness),
(c = 0 === d.lineWidth % 2 ? 0 : 0.5),
d.beginPath(),
d.moveTo(e.x3 - c, e.y2),
d.lineTo(e.x3 - c, e.y3),
d.stroke(),
d.beginPath(),
d.moveTo(e.x3, e.y1),
d.lineTo(e.x1, e.y1),
d.stroke(),
d.beginPath(),
d.moveTo(e.x3, e.y4),
d.lineTo(e.x2, e.y4),
d.stroke(),
(d.globalAlpha = 1))
: "boxAndWhisker" === c.type
? (d.save(),
(d.globalAlpha = 1),
(d.strokeStyle = e.stemColor),
(d.lineWidth = 2 * e.stemThickness),
0 < e.stemThickness &&
(d.beginPath(),
d.moveTo(e.x3, e.y2 + e.borderThickness / 2),
d.lineTo(e.x3, e.y1 + e.whiskerThickness / 2),
d.stroke(),
d.beginPath(),
d.moveTo(e.x3, e.y4 - e.whiskerThickness / 2),
d.lineTo(e.x3, e.y3 - e.borderThickness / 2),
d.stroke()),
d.beginPath(),
ea(
d,
e.x1 - e.borderThickness / 2,
Math.max(
e.y2 + e.borderThickness / 2,
e.y3 + e.borderThickness / 2
),
e.x2 + e.borderThickness / 2,
Math.min(
e.y2 - e.borderThickness / 2,
e.y3 - e.borderThickness / 2
),
"transparent",
e.borderThickness,
e.color,
!1,
!1,
!1,
!1
),
(d.globalAlpha = 1),
(d.strokeStyle = e.whiskerColor),
(d.lineWidth = 2 * e.whiskerThickness),
0 < e.whiskerThickness &&
(d.beginPath(),
d.moveTo(Math.floor(e.x3 - e.whiskerLength / 2), e.y4),
d.lineTo(Math.ceil(e.x3 + e.whiskerLength / 2), e.y4),
d.stroke(),
d.beginPath(),
d.moveTo(Math.floor(e.x3 - e.whiskerLength / 2), e.y1),
d.lineTo(Math.ceil(e.x3 + e.whiskerLength / 2), e.y1),
d.stroke()),
(d.globalAlpha = 1),
(d.strokeStyle = e.lineColor),
(d.lineWidth = 2 * e.lineThickness),
0 < e.lineThickness &&
(d.beginPath(),
d.moveTo(e.x1, e.y5),
d.lineTo(e.x2, e.y5),
d.stroke()),
d.restore(),
(d.globalAlpha = 1))
: "error" === c.type &&
E(
d,
e.x1,
e.y1,
e.x2,
e.y2,
"white",
e.whiskerProperties,
e.stemProperties,
e.isXYSwapped,
0.3
));
}
}
d.restore();
d.globalAlpha = 1;
d.beginPath();
};
$.prototype.getToolTipInnerHTML = function (a) {
a = a.entries;
for (
var d = null, b = null, c = null, e = 0, g = "", k = !0, l = 0;
l < a.length;
l++
)
if (a[l].dataSeries.toolTipContent || a[l].dataPoint.toolTipContent) {
k = !1;
break;
}
if (
k &&
((this.content && "function" === typeof this.content) ||
this.contentFormatter)
)
(a = { chart: this.chart, toolTip: this.options, entries: a }),
(d = this.contentFormatter
? this.contentFormatter(a)
: this.content(a));
else if (this.shared && "none" !== this.chart.plotInfo.axisPlacement) {
for (var p = null, h = "", l = 0; l < a.length; l++)
(b = a[l].dataSeries),
(c = a[l].dataPoint),
(e = a[l].index),
(g = ""),
0 === l &&
k &&
!this.content &&
(this.chart.axisX && 0 < this.chart.axisX.length
? (h +=
"undefined" !== typeof this.chart.axisX[0].labels[c.x]
? this.chart.axisX[0].labels[c.x]
: "{x}")
: this.chart.axisX2 &&
0 < this.chart.axisX2.length &&
(h +=
"undefined" !== typeof this.chart.axisX2[0].labels[c.x]
? this.chart.axisX2[0].labels[c.x]
: "{x}"),
(h += "</br>"),
(h = this.chart.replaceKeywordsWithValue(h, c, b, e))),
null === c.toolTipContent ||
("undefined" === typeof c.toolTipContent &&
null === b.options.toolTipContent) ||
("line" === b.type ||
"stepLine" === b.type ||
"spline" === b.type ||
"area" === b.type ||
"stepArea" === b.type ||
"splineArea" === b.type ||
"column" === b.type ||
"bar" === b.type ||
"scatter" === b.type ||
"stackedColumn" === b.type ||
"stackedColumn100" === b.type ||
"stackedBar" === b.type ||
"stackedBar100" === b.type ||
"stackedArea" === b.type ||
"stackedArea100" === b.type ||
"waterfall" === b.type
? (this.chart.axisX &&
1 < this.chart.axisX.length &&
(g +=
p != b.axisXIndex
? b.axisX.title
? b.axisX.title + "<br/>"
: "X:{axisXIndex}<br/>"
: ""),
(g += c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>{name}:</span>&nbsp;&nbsp;{y}"),
(p = b.axisXIndex))
: "bubble" === b.type
? (this.chart.axisX &&
1 < this.chart.axisX.length &&
(g +=
p != b.axisXIndex
? b.axisX.title
? b.axisX.title + "<br/>"
: "X:{axisXIndex}<br/>"
: ""),
(g += c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>{name}:</span>&nbsp;&nbsp;{y}, &nbsp;&nbsp;{z}"))
: "rangeColumn" === b.type ||
"rangeBar" === b.type ||
"rangeArea" === b.type ||
"rangeSplineArea" === b.type ||
"error" === b.type
? (this.chart.axisX &&
1 < this.chart.axisX.length &&
(g +=
p != b.axisXIndex
? b.axisX.title
? b.axisX.title + "<br/>"
: "X:{axisXIndex}<br/>"
: ""),
(g += c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>{name}:</span>&nbsp;&nbsp;{y[0]},&nbsp;{y[1]}"))
: "candlestick" === b.type || "ohlc" === b.type
? (this.chart.axisX &&
1 < this.chart.axisX.length &&
(g +=
p != b.axisXIndex
? b.axisX.title
? b.axisX.title + "<br/>"
: "X:{axisXIndex}<br/>"
: ""),
(g += c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>{name}:</span><br/>Open: &nbsp;&nbsp;{y[0]}<br/>High: &nbsp;&nbsp;&nbsp;{y[1]}<br/>Low:&nbsp;&nbsp;&nbsp;{y[2]}<br/>Close: &nbsp;&nbsp;{y[3]}"))
: "boxAndWhisker" === b.type &&
(this.chart.axisX &&
1 < this.chart.axisX.length &&
(g +=
p != b.axisXIndex
? b.axisX.title
? b.axisX.title + "<br/>"
: "X:{axisXIndex}<br/>"
: ""),
(g += c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>{name}:</span><br/>Minimum: &nbsp;&nbsp;{y[0]}<br/>Q1: &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{y[1]}<br/>Q2: &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{y[4]}<br/>Q3: &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{y[2]}<br/>Maximum: &nbsp;{y[3]}")),
null === d && (d = ""),
!0 === this.reversed
? ((d = this.chart.replaceKeywordsWithValue(g, c, b, e) + d),
l < a.length - 1 && (d = "</br>" + d))
: ((d += this.chart.replaceKeywordsWithValue(g, c, b, e)),
l < a.length - 1 && (d += "</br>")));
null !== d && (d = h + d);
} else {
b = a[0].dataSeries;
c = a[0].dataPoint;
e = a[0].index;
if (
null === c.toolTipContent ||
("undefined" === typeof c.toolTipContent &&
null === b.options.toolTipContent)
)
return null;
"line" === b.type ||
"stepLine" === b.type ||
"spline" === b.type ||
"area" === b.type ||
"stepArea" === b.type ||
"splineArea" === b.type ||
"column" === b.type ||
"bar" === b.type ||
"scatter" === b.type ||
"stackedColumn" === b.type ||
"stackedColumn100" === b.type ||
"stackedBar" === b.type ||
"stackedBar100" === b.type ||
"stackedArea" === b.type ||
"stackedArea100" === b.type ||
"waterfall" === b.type
? (g = c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>" +
(c.label ? "{label}" : "{x}") +
":</span>&nbsp;&nbsp;{y}")
: "bubble" === b.type
? (g = c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>" +
(c.label ? "{label}" : "{x}") +
":</span>&nbsp;&nbsp;{y}, &nbsp;&nbsp;{z}")
: "pie" === b.type ||
"doughnut" === b.type ||
"funnel" === b.type ||
"pyramid" === b.type
? (g = c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>" +
(c.name
? "{name}:</span>&nbsp;&nbsp;"
: c.label
? "{label}:</span>&nbsp;&nbsp;"
: "</span>") +
"{y}")
: "rangeColumn" === b.type ||
"rangeBar" === b.type ||
"rangeArea" === b.type ||
"rangeSplineArea" === b.type ||
"error" === b.type
? (g = c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>" +
(c.label ? "{label}" : "{x}") +
" :</span>&nbsp;&nbsp;{y[0]}, &nbsp;{y[1]}")
: "candlestick" === b.type || "ohlc" === b.type
? (g = c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>" +
(c.label ? "{label}" : "{x}") +
"</span><br/>Open: &nbsp;&nbsp;{y[0]}<br/>High: &nbsp;&nbsp;&nbsp;{y[1]}<br/>Low: &nbsp;&nbsp;&nbsp;&nbsp;{y[2]}<br/>Close: &nbsp;&nbsp;{y[3]}")
: "boxAndWhisker" === b.type &&
(g = c.toolTipContent
? c.toolTipContent
: b.toolTipContent
? b.toolTipContent
: this.content && "function" !== typeof this.content
? this.content
: "<span style='\"" +
(this.options.fontColor ? "" : "'color:{color};'") +
"\"'>" +
(c.label ? "{label}" : "{x}") +
"</span><br/>Minimum: &nbsp;&nbsp;{y[0]}<br/>Q1: &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{y[1]}<br/>Q2: &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{y[4]}<br/>Q3: &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{y[2]}<br/>Maximum: &nbsp;{y[3]}");
null === d && (d = "");
d += this.chart.replaceKeywordsWithValue(g, c, b, e);
}
return d;
};
$.prototype.enableAnimation = function () {
if (!this.container.style.WebkitTransition) {
var a = this.getContainerTransition(this.containerTransitionDuration);
this.container.style.WebkitTransition = a;
this.container.style.MsTransition = a;
this.container.style.transition = a;
this.container.style.MozTransition = this.mozContainerTransition;
}
};
$.prototype.disableAnimation = function () {
this.container.style.WebkitTransition &&
((this.container.style.WebkitTransition = ""),
(this.container.style.MozTransition = ""),
(this.container.style.MsTransition = ""),
(this.container.style.transition = ""));
};
$.prototype.hide = function (a) {
this.container &&
((this.container.style.display = "none"),
(this.currentSeriesIndex = -1),
(this._prevY = this._prevX = NaN),
("undefined" === typeof a || a) && this.chart.resetOverlayedCanvas());
};
$.prototype.show = function (a, d, b) {
this._updateToolTip(a, d, "undefined" === typeof b ? !1 : b);
};
$.prototype.fixMozTransitionDelay = function (a, d) {
if (20 < this.chart._eventManager.lastObjectId)
this.mozContainerTransition = this.getContainerTransition(0);
else {
var b = parseFloat(this.container.style.left),
b = isNaN(b) ? 0 : b,
c = parseFloat(this.container.style.bottom),
c = isNaN(c) ? 0 : c;
10 < Math.sqrt(Math.pow(b - a, 2) + Math.pow(c - d, 2))
? (this.mozContainerTransition = this.getContainerTransition(0.1))
: (this.mozContainerTransition = this.getContainerTransition(0));
}
};
$.prototype.getContainerTransition = function (a) {
return "left " + a + "s ease-out 0s, bottom " + a + "s ease-out 0s";
};
ha.prototype.reset = function () {
this.lastObjectId = 0;
this.objectMap = [];
this.rectangularRegionEventSubscriptions = [];
this.previousDataPointEventObject = null;
this.eventObjects = [];
r &&
(this.ghostCtx.clearRect(0, 0, this.chart.width, this.chart.height),
this.ghostCtx.beginPath());
};
ha.prototype.getNewObjectTrackingId = function () {
return ++this.lastObjectId;
};
ha.prototype.mouseEventHandler = function (a) {
if ("mousemove" === a.type || "click" === a.type) {
var d = [],
b = Ra(a),
c = null;
if (
(c = this.chart.getObjectAtXY(b.x, b.y, !1)) &&
"undefined" !== typeof this.objectMap[c]
)
if (((c = this.objectMap[c]), "dataPoint" === c.objectType)) {
var e = this.chart.data[c.dataSeriesIndex],
g = e.dataPoints[c.dataPointIndex],
k = c.dataPointIndex;
c.eventParameter = {
x: b.x,
y: b.y,
dataPoint: g,
dataSeries: e.options,
dataPointIndex: k,
dataSeriesIndex: e.index,
chart: this.chart,
};
c.eventContext = {
context: g,
userContext: g,
mouseover: "mouseover",
mousemove: "mousemove",
mouseout: "mouseout",
click: "click",
};
d.push(c);
c = this.objectMap[e.id];
c.eventParameter = {
x: b.x,
y: b.y,
dataPoint: g,
dataSeries: e.options,
dataPointIndex: k,
dataSeriesIndex: e.index,
chart: this.chart,
};
c.eventContext = {
context: e,
userContext: e.options,
mouseover: "mouseover",
mousemove: "mousemove",
mouseout: "mouseout",
click: "click",
};
d.push(this.objectMap[e.id]);
} else
"legendItem" === c.objectType &&
((e = this.chart.data[c.dataSeriesIndex]),
(g =
null !== c.dataPointIndex
? e.dataPoints[c.dataPointIndex]
: null),
(c.eventParameter = {
x: b.x,
y: b.y,
dataSeries: e.options,
dataPoint: g,
dataPointIndex: c.dataPointIndex,
dataSeriesIndex: c.dataSeriesIndex,
chart: this.chart,
}),
(c.eventContext = {
context: this.chart.legend,
userContext: this.chart.legend.options,
mouseover: "itemmouseover",
mousemove: "itemmousemove",
mouseout: "itemmouseout",
click: "itemclick",
}),
d.push(c));
e = [];
for (b = 0; b < this.mouseoveredObjectMaps.length; b++) {
g = !0;
for (c = 0; c < d.length; c++)
if (d[c].id === this.mouseoveredObjectMaps[b].id) {
g = !1;
break;
}
g
? this.fireEvent(this.mouseoveredObjectMaps[b], "mouseout", a)
: e.push(this.mouseoveredObjectMaps[b]);
}
this.mouseoveredObjectMaps = e;
for (b = 0; b < d.length; b++) {
e = !1;
for (c = 0; c < this.mouseoveredObjectMaps.length; c++)
if (d[b].id === this.mouseoveredObjectMaps[c].id) {
e = !0;
break;
}
e ||
(this.fireEvent(d[b], "mouseover", a),
this.mouseoveredObjectMaps.push(d[b]));
"click" === a.type
? this.fireEvent(d[b], "click", a)
: "mousemove" === a.type && this.fireEvent(d[b], "mousemove", a);
}
}
};
ha.prototype.fireEvent = function (a, d, b) {
if (a && d) {
var c = a.eventParameter,
e = a.eventContext,
g = a.eventContext.userContext;
g && e && g[e[d]] && g[e[d]].call(g, c);
"mouseout" !== d
? g.cursor &&
g.cursor !== b.target.style.cursor &&
(b.target.style.cursor = g.cursor)
: ((b.target.style.cursor = this.chart._defaultCursor),
delete a.eventParameter,
delete a.eventContext);
"click" === d &&
"dataPoint" === a.objectType &&
this.chart.pieDoughnutClickHandler &&
this.chart.pieDoughnutClickHandler.call(
this.chart.data[a.dataSeriesIndex],
c
);
"click" === d &&
"dataPoint" === a.objectType &&
this.chart.funnelPyramidClickHandler &&
this.chart.funnelPyramidClickHandler.call(
this.chart.data[a.dataSeriesIndex],
c
);
}
};
ga.prototype.animate = function (a, d, b, c, e) {
var g = this;
this.chart.isAnimating = !0;
e = e || M.easing.linear;
b &&
this.animations.push({
startTime: new Date().getTime() + (a ? a : 0),
duration: d,
animationCallback: b,
onComplete: c,
});
for (a = []; 0 < this.animations.length; )
if (
((d = this.animations.shift()),
(b = new Date().getTime()),
(c = 0),
d.startTime <= b &&
((c = e(Math.min(b - d.startTime, d.duration), 0, 1, d.duration)),
(c = Math.min(c, 1)),
isNaN(c) || !isFinite(c)) &&
(c = 1),
1 > c && a.push(d),
d.animationCallback(c),
1 <= c && d.onComplete)
)
d.onComplete();
this.animations = a;
0 < this.animations.length
? (this.animationRequestId = this.chart.requestAnimFrame.call(
window,
function () {
g.animate.call(g);
}
))
: (this.chart.isAnimating = !1);
};
ga.prototype.cancelAllAnimations = function () {
this.animations = [];
this.animationRequestId &&
this.chart.cancelRequestAnimFrame.call(window, this.animationRequestId);
this.animationRequestId = null;
this.chart.isAnimating = !1;
};
var M = {
yScaleAnimation: function (a, d) {
if (0 !== a) {
var b = d.dest,
c = d.source.canvas,
e = d.animationBase;
b.drawImage(
c,
0,
0,
c.width,
c.height,
0,
e - e * a,
b.canvas.width / W,
(a * b.canvas.height) / W
);
}
},
xScaleAnimation: function (a, d) {
if (0 !== a) {
var b = d.dest,
c = d.source.canvas,
e = d.animationBase;
b.drawImage(
c,
0,
0,
c.width,
c.height,
e - e * a,
0,
(a * b.canvas.width) / W,
b.canvas.height / W
);
}
},
xClipAnimation: function (a, d) {
if (0 !== a) {
var b = d.dest,
c = d.source.canvas;
b.save();
0 < a &&
b.drawImage(
c,
0,
0,
c.width * a,
c.height,
0,
0,
(c.width * a) / W,
c.height / W
);
b.restore();
}
},
fadeInAnimation: function (a, d) {
if (0 !== a) {
var b = d.dest,
c = d.source.canvas;
b.save();
b.globalAlpha = a;
b.drawImage(
c,
0,
0,
c.width,
c.height,
0,
0,
b.canvas.width / W,
b.canvas.height / W
);
b.restore();
}
},
easing: {
linear: function (a, d, b, c) {
return (b * a) / c + d;
},
easeOutQuad: function (a, d, b, c) {
return -b * (a /= c) * (a - 2) + d;
},
easeOutQuart: function (a, d, b, c) {
return -b * ((a = a / c - 1) * a * a * a - 1) + d;
},
easeInQuad: function (a, d, b, c) {
return b * (a /= c) * a + d;
},
easeInQuart: function (a, d, b, c) {
return b * (a /= c) * a * a * a + d;
},
},
},
ia = {
drawMarker: function (a, d, b, c, e, g, k, l) {
if (b) {
var p = 1;
b.fillStyle = g ? g : "#000000";
b.strokeStyle = k ? k : "#000000";
b.lineWidth = l ? l : 0;
b.setLineDash && b.setLineDash(R("solid", l));
"circle" === c
? (b.moveTo(a, d),
b.beginPath(),
b.arc(a, d, e / 2, 0, 2 * Math.PI, !1),
g && b.fill(),
l &&
(k
? b.stroke()
: ((p = b.globalAlpha),
(b.globalAlpha = 0.15),
(b.strokeStyle = "black"),
b.stroke(),
(b.globalAlpha = p))))
: "square" === c
? (b.beginPath(),
b.rect(a - e / 2, d - e / 2, e, e),
g && b.fill(),
l &&
(k
? b.stroke()
: ((p = b.globalAlpha),
(b.globalAlpha = 0.15),
(b.strokeStyle = "black"),
b.stroke(),
(b.globalAlpha = p))))
: "triangle" === c
? (b.beginPath(),
b.moveTo(a - e / 2, d + e / 2),
b.lineTo(a + e / 2, d + e / 2),
b.lineTo(a, d - e / 2),
b.closePath(),
g && b.fill(),
l &&
(k
? b.stroke()
: ((p = b.globalAlpha),
(b.globalAlpha = 0.15),
(b.strokeStyle = "black"),
b.stroke(),
(b.globalAlpha = p))),
b.beginPath())
: "cross" === c &&
((b.strokeStyle = g),
(b.lineWidth = e / 4),
b.beginPath(),
b.moveTo(a - e / 2, d - e / 2),
b.lineTo(a + e / 2, d + e / 2),
b.stroke(),
b.moveTo(a + e / 2, d - e / 2),
b.lineTo(a - e / 2, d + e / 2),
b.stroke());
}
},
drawMarkers: function (a) {
for (var d = 0; d < a.length; d++) {
var b = a[d];
ia.drawMarker(
b.x,
b.y,
b.ctx,
b.type,
b.size,
b.color,
b.borderColor,
b.borderThickness
);
}
},
};
return p;
})();
Na.Chart.version = "v2.3.1 GA";
})();
/*
excanvas is used to support IE678 which do not implement HTML5 Canvas Element. You can safely remove the following excanvas code if you don't need to support older browsers.
Copyright 2006 Google Inc. https://code.google.com/p/explorercanvas/
Licensed under the Apache License, Version 2.0
*/
document.createElement("canvas").getContext ||
(function () {
function V() {
return this.context_ || (this.context_ = new C(this));
}
function W(a, b, c) {
var g = M.call(arguments, 2);
return function () {
return a.apply(b, g.concat(M.call(arguments)));
};
}
function N(a) {
return String(a).replace(/&/g, "&amp;").replace(/"/g, "&quot;");
}
function O(a) {
a.namespaces.g_vml_ ||
a.namespaces.add(
"g_vml_",
"urn:schemas-microsoft-com:vml",
"#default#VML"
);
a.namespaces.g_o_ ||
a.namespaces.add(
"g_o_",
"urn:schemas-microsoft-com:office:office",
"#default#VML"
);
a.styleSheets.ex_canvas_ ||
((a = a.createStyleSheet()),
(a.owningElement.id = "ex_canvas_"),
(a.cssText =
"canvas{display:inline-block;overflow:hidden;text-align:left;width:300px;height:150px}"));
}
function X(a) {
var b = a.srcElement;
switch (a.propertyName) {
case "width":
b.getContext().clearRect();
b.style.width = b.attributes.width.nodeValue + "px";
b.firstChild.style.width = b.clientWidth + "px";
break;
case "height":
b.getContext().clearRect(),
(b.style.height = b.attributes.height.nodeValue + "px"),
(b.firstChild.style.height = b.clientHeight + "px");
}
}
function Y(a) {
a = a.srcElement;
a.firstChild &&
((a.firstChild.style.width = a.clientWidth + "px"),
(a.firstChild.style.height = a.clientHeight + "px"));
}
function D() {
return [
[1, 0, 0],
[0, 1, 0],
[0, 0, 1],
];
}
function t(a, b) {
for (var c = D(), g = 0; 3 > g; g++)
for (var e = 0; 3 > e; e++) {
for (var f = 0, d = 0; 3 > d; d++) f += a[g][d] * b[d][e];
c[g][e] = f;
}
return c;
}
function P(a, b) {
b.fillStyle = a.fillStyle;
b.lineCap = a.lineCap;
b.lineJoin = a.lineJoin;
b.lineWidth = a.lineWidth;
b.miterLimit = a.miterLimit;
b.shadowBlur = a.shadowBlur;
b.shadowColor = a.shadowColor;
b.shadowOffsetX = a.shadowOffsetX;
b.shadowOffsetY = a.shadowOffsetY;
b.strokeStyle = a.strokeStyle;
b.globalAlpha = a.globalAlpha;
b.font = a.font;
b.textAlign = a.textAlign;
b.textBaseline = a.textBaseline;
b.arcScaleX_ = a.arcScaleX_;
b.arcScaleY_ = a.arcScaleY_;
b.lineScale_ = a.lineScale_;
}
function Q(a) {
var b = a.indexOf("(", 3),
c = a.indexOf(")", b + 1),
b = a.substring(b + 1, c).split(",");
if (4 != b.length || "a" != a.charAt(3)) b[3] = 1;
return b;
}
function E(a, b, c) {
return Math.min(c, Math.max(b, a));
}
function F(a, b, c) {
0 > c && c++;
1 < c && c--;
return 1 > 6 * c
? a + 6 * (b - a) * c
: 1 > 2 * c
? b
: 2 > 3 * c
? a + 6 * (b - a) * (2 / 3 - c)
: a;
}
function G(a) {
if (a in H) return H[a];
var b,
c = 1;
a = String(a);
if ("#" == a.charAt(0)) b = a;
else if (/^rgb/.test(a)) {
c = Q(a);
b = "#";
for (var g, e = 0; 3 > e; e++)
(g =
-1 != c[e].indexOf("%")
? Math.floor(255 * (parseFloat(c[e]) / 100))
: +c[e]),
(b += v[E(g, 0, 255)]);
c = +c[3];
} else if (/^hsl/.test(a)) {
e = c = Q(a);
b = (parseFloat(e[0]) / 360) % 360;
0 > b && b++;
g = E(parseFloat(e[1]) / 100, 0, 1);
e = E(parseFloat(e[2]) / 100, 0, 1);
if (0 == g) g = e = b = e;
else {
var f = 0.5 > e ? e * (1 + g) : e + g - e * g,
d = 2 * e - f;
g = F(d, f, b + 1 / 3);
e = F(d, f, b);
b = F(d, f, b - 1 / 3);
}
b =
"#" +
v[Math.floor(255 * g)] +
v[Math.floor(255 * e)] +
v[Math.floor(255 * b)];
c = c[3];
} else b = Z[a] || a;
return (H[a] = { color: b, alpha: c });
}
function C(a) {
this.m_ = D();
this.mStack_ = [];
this.aStack_ = [];
this.currentPath_ = [];
this.fillStyle = this.strokeStyle = "#000";
this.lineWidth = 1;
this.lineJoin = "miter";
this.lineCap = "butt";
this.miterLimit = 1 * q;
this.globalAlpha = 1;
this.font = "10px sans-serif";
this.textAlign = "left";
this.textBaseline = "alphabetic";
this.canvas = a;
var b =
"width:" +
a.clientWidth +
"px;height:" +
a.clientHeight +
"px;overflow:hidden;position:absolute",
c = a.ownerDocument.createElement("div");
c.style.cssText = b;
a.appendChild(c);
b = c.cloneNode(!1);
b.style.backgroundColor = "red";
b.style.filter = "alpha(opacity=0)";
a.appendChild(b);
this.element_ = c;
this.lineScale_ = this.arcScaleY_ = this.arcScaleX_ = 1;
}
function R(a, b, c, g) {
a.currentPath_.push({
type: "bezierCurveTo",
cp1x: b.x,
cp1y: b.y,
cp2x: c.x,
cp2y: c.y,
x: g.x,
y: g.y,
});
a.currentX_ = g.x;
a.currentY_ = g.y;
}
function S(a, b) {
var c = G(a.strokeStyle),
g = c.color,
c = c.alpha * a.globalAlpha,
e = a.lineScale_ * a.lineWidth;
1 > e && (c *= e);
b.push(
"<g_vml_:stroke",
' opacity="',
c,
'"',
' joinstyle="',
a.lineJoin,
'"',
' miterlimit="',
a.miterLimit,
'"',
' endcap="',
$[a.lineCap] || "square",
'"',
' weight="',
e,
'px"',
' color="',
g,
'" />'
);
}
function T(a, b, c, g) {
var e = a.fillStyle,
f = a.arcScaleX_,
d = a.arcScaleY_,
k = g.x - c.x,
n = g.y - c.y;
if (e instanceof w) {
var h = 0,
l = (g = 0),
u = 0,
m = 1;
if ("gradient" == e.type_) {
h = e.x1_ / f;
c = e.y1_ / d;
var p = s(a, e.x0_ / f, e.y0_ / d),
h = s(a, h, c),
h = (180 * Math.atan2(h.x - p.x, h.y - p.y)) / Math.PI;
0 > h && (h += 360);
1e-6 > h && (h = 0);
} else
(p = s(a, e.x0_, e.y0_)),
(g = (p.x - c.x) / k),
(l = (p.y - c.y) / n),
(k /= f * q),
(n /= d * q),
(m = x.max(k, n)),
(u = (2 * e.r0_) / m),
(m = (2 * e.r1_) / m - u);
f = e.colors_;
f.sort(function (a, b) {
return a.offset - b.offset;
});
d = f.length;
p = f[0].color;
c = f[d - 1].color;
k = f[0].alpha * a.globalAlpha;
a = f[d - 1].alpha * a.globalAlpha;
for (var n = [], r = 0; r < d; r++) {
var t = f[r];
n.push(t.offset * m + u + " " + t.color);
}
b.push(
'<g_vml_:fill type="',
e.type_,
'"',
' method="none" focus="100%"',
' color="',
p,
'"',
' color2="',
c,
'"',
' colors="',
n.join(","),
'"',
' opacity="',
a,
'"',
' g_o_:opacity2="',
k,
'"',
' angle="',
h,
'"',
' focusposition="',
g,
",",
l,
'" />'
);
} else
e instanceof I
? k &&
n &&
b.push(
"<g_vml_:fill",
' position="',
(-c.x / k) * f * f,
",",
(-c.y / n) * d * d,
'"',
' type="tile"',
' src="',
e.src_,
'" />'
)
: ((e = G(a.fillStyle)),
b.push(
'<g_vml_:fill color="',
e.color,
'" opacity="',
e.alpha * a.globalAlpha,
'" />'
));
}
function s(a, b, c) {
a = a.m_;
return {
x: q * (b * a[0][0] + c * a[1][0] + a[2][0]) - r,
y: q * (b * a[0][1] + c * a[1][1] + a[2][1]) - r,
};
}
function z(a, b, c) {
isFinite(b[0][0]) &&
isFinite(b[0][1]) &&
isFinite(b[1][0]) &&
isFinite(b[1][1]) &&
isFinite(b[2][0]) &&
isFinite(b[2][1]) &&
((a.m_ = b),
c && (a.lineScale_ = aa(ba(b[0][0] * b[1][1] - b[0][1] * b[1][0]))));
}
function w(a) {
this.type_ = a;
this.r1_ = this.y1_ = this.x1_ = this.r0_ = this.y0_ = this.x0_ = 0;
this.colors_ = [];
}
function I(a, b) {
if (!a || 1 != a.nodeType || "IMG" != a.tagName)
throw new A("TYPE_MISMATCH_ERR");
if ("complete" != a.readyState) throw new A("INVALID_STATE_ERR");
switch (b) {
case "repeat":
case null:
case "":
this.repetition_ = "repeat";
break;
case "repeat-x":
case "repeat-y":
case "no-repeat":
this.repetition_ = b;
break;
default:
throw new A("SYNTAX_ERR");
}
this.src_ = a.src;
this.width_ = a.width;
this.height_ = a.height;
}
function A(a) {
this.code = this[a];
this.message = a + ": DOM Exception " + this.code;
}
var x = Math,
k = x.round,
J = x.sin,
K = x.cos,
ba = x.abs,
aa = x.sqrt,
q = 10,
r = q / 2;
navigator.userAgent.match(/MSIE ([\d.]+)?/);
var M = Array.prototype.slice;
O(document);
var U = {
init: function (a) {
a = a || document;
a.createElement("canvas");
a.attachEvent("onreadystatechange", W(this.init_, this, a));
},
init_: function (a) {
a = a.getElementsByTagName("canvas");
for (var b = 0; b < a.length; b++) this.initElement(a[b]);
},
initElement: function (a) {
if (!a.getContext) {
a.getContext = V;
O(a.ownerDocument);
a.innerHTML = "";
a.attachEvent("onpropertychange", X);
a.attachEvent("onresize", Y);
var b = a.attributes;
b.width && b.width.specified
? (a.style.width = b.width.nodeValue + "px")
: (a.width = a.clientWidth);
b.height && b.height.specified
? (a.style.height = b.height.nodeValue + "px")
: (a.height = a.clientHeight);
}
return a;
},
};
U.init();
for (var v = [], d = 0; 16 > d; d++)
for (var B = 0; 16 > B; B++)
v[16 * d + B] = d.toString(16) + B.toString(16);
var Z = {
aliceblue: "#F0F8FF",
antiquewhite: "#FAEBD7",
aquamarine: "#7FFFD4",
azure: "#F0FFFF",
beige: "#F5F5DC",
bisque: "#FFE4C4",
black: "#000000",
blanchedalmond: "#FFEBCD",
blueviolet: "#8A2BE2",
brown: "#A52A2A",
burlywood: "#DEB887",
cadetblue: "#5F9EA0",
chartreuse: "#7FFF00",
chocolate: "#D2691E",
coral: "#FF7F50",
cornflowerblue: "#6495ED",
cornsilk: "#FFF8DC",
crimson: "#DC143C",
cyan: "#00FFFF",
darkblue: "#00008B",
darkcyan: "#008B8B",
darkgoldenrod: "#B8860B",
darkgray: "#A9A9A9",
darkgreen: "#006400",
darkgrey: "#A9A9A9",
darkkhaki: "#BDB76B",
darkmagenta: "#8B008B",
darkolivegreen: "#556B2F",
darkorange: "#FF8C00",
darkorchid: "#9932CC",
darkred: "#8B0000",
darksalmon: "#E9967A",
darkseagreen: "#8FBC8F",
darkslateblue: "#483D8B",
darkslategray: "#2F4F4F",
darkslategrey: "#2F4F4F",
darkturquoise: "#00CED1",
darkviolet: "#9400D3",
deeppink: "#FF1493",
deepskyblue: "#00BFFF",
dimgray: "#696969",
dimgrey: "#696969",
dodgerblue: "#1E90FF",
firebrick: "#B22222",
floralwhite: "#FFFAF0",
forestgreen: "#228B22",
gainsboro: "#DCDCDC",
ghostwhite: "#F8F8FF",
gold: "#FFD700",
goldenrod: "#DAA520",
grey: "#808080",
greenyellow: "#ADFF2F",
honeydew: "#F0FFF0",
hotpink: "#FF69B4",
indianred: "#CD5C5C",
indigo: "#4B0082",
ivory: "#FFFFF0",
khaki: "#F0E68C",
lavender: "#E6E6FA",
lavenderblush: "#FFF0F5",
lawngreen: "#7CFC00",
lemonchiffon: "#FFFACD",
lightblue: "#ADD8E6",
lightcoral: "#F08080",
lightcyan: "#E0FFFF",
lightgoldenrodyellow: "#FAFAD2",
lightgreen: "#90EE90",
lightgrey: "#D3D3D3",
lightpink: "#FFB6C1",
lightsalmon: "#FFA07A",
lightseagreen: "#20B2AA",
lightskyblue: "#87CEFA",
lightslategray: "#778899",
lightslategrey: "#778899",
lightsteelblue: "#B0C4DE",
lightyellow: "#FFFFE0",
limegreen: "#32CD32",
linen: "#FAF0E6",
magenta: "#FF00FF",
mediumaquamarine: "#66CDAA",
mediumblue: "#0000CD",
mediumorchid: "#BA55D3",
mediumpurple: "#9370DB",
mediumseagreen: "#3CB371",
mediumslateblue: "#7B68EE",
mediumspringgreen: "#00FA9A",
mediumturquoise: "#48D1CC",
mediumvioletred: "#C71585",
midnightblue: "#191970",
mintcream: "#F5FFFA",
mistyrose: "#FFE4E1",
moccasin: "#FFE4B5",
navajowhite: "#FFDEAD",
oldlace: "#FDF5E6",
olivedrab: "#6B8E23",
orange: "#FFA500",
orangered: "#FF4500",
orchid: "#DA70D6",
palegoldenrod: "#EEE8AA",
palegreen: "#98FB98",
paleturquoise: "#AFEEEE",
palevioletred: "#DB7093",
papayawhip: "#FFEFD5",
peachpuff: "#FFDAB9",
peru: "#CD853F",
pink: "#FFC0CB",
plum: "#DDA0DD",
powderblue: "#B0E0E6",
rosybrown: "#BC8F8F",
royalblue: "#4169E1",
saddlebrown: "#8B4513",
salmon: "#FA8072",
sandybrown: "#F4A460",
seagreen: "#2E8B57",
seashell: "#FFF5EE",
sienna: "#A0522D",
skyblue: "#87CEEB",
slateblue: "#6A5ACD",
slategray: "#708090",
slategrey: "#708090",
snow: "#FFFAFA",
springgreen: "#00FF7F",
steelblue: "#4682B4",
tan: "#D2B48C",
thistle: "#D8BFD8",
tomato: "#FF6347",
turquoise: "#40E0D0",
violet: "#EE82EE",
wheat: "#F5DEB3",
whitesmoke: "#F5F5F5",
yellowgreen: "#9ACD32",
},
H = {},
L = {},
$ = { butt: "flat", round: "round" },
d = C.prototype;
d.clearRect = function () {
this.textMeasureEl_ &&
(this.textMeasureEl_.removeNode(!0), (this.textMeasureEl_ = null));
this.element_.innerHTML = "";
};
d.beginPath = function () {
this.currentPath_ = [];
};
d.moveTo = function (a, b) {
var c = s(this, a, b);
this.currentPath_.push({ type: "moveTo", x: c.x, y: c.y });
this.currentX_ = c.x;
this.currentY_ = c.y;
};
d.lineTo = function (a, b) {
var c = s(this, a, b);
this.currentPath_.push({ type: "lineTo", x: c.x, y: c.y });
this.currentX_ = c.x;
this.currentY_ = c.y;
};
d.bezierCurveTo = function (a, b, c, g, e, f) {
e = s(this, e, f);
a = s(this, a, b);
c = s(this, c, g);
R(this, a, c, e);
};
d.quadraticCurveTo = function (a, b, c, g) {
a = s(this, a, b);
c = s(this, c, g);
g = {
x: this.currentX_ + (2 / 3) * (a.x - this.currentX_),
y: this.currentY_ + (2 / 3) * (a.y - this.currentY_),
};
R(
this,
g,
{
x: g.x + (c.x - this.currentX_) / 3,
y: g.y + (c.y - this.currentY_) / 3,
},
c
);
};
d.arc = function (a, b, c, g, e, f) {
c *= q;
var d = f ? "at" : "wa",
k = a + K(g) * c - r,
n = b + J(g) * c - r;
g = a + K(e) * c - r;
e = b + J(e) * c - r;
k != g || f || (k += 0.125);
a = s(this, a, b);
k = s(this, k, n);
g = s(this, g, e);
this.currentPath_.push({
type: d,
x: a.x,
y: a.y,
radius: c,
xStart: k.x,
yStart: k.y,
xEnd: g.x,
yEnd: g.y,
});
};
d.rect = function (a, b, c, g) {
this.moveTo(a, b);
this.lineTo(a + c, b);
this.lineTo(a + c, b + g);
this.lineTo(a, b + g);
this.closePath();
};
d.strokeRect = function (a, b, c, g) {
var e = this.currentPath_;
this.beginPath();
this.moveTo(a, b);
this.lineTo(a + c, b);
this.lineTo(a + c, b + g);
this.lineTo(a, b + g);
this.closePath();
this.stroke();
this.currentPath_ = e;
};
d.fillRect = function (a, b, c, g) {
var e = this.currentPath_;
this.beginPath();
this.moveTo(a, b);
this.lineTo(a + c, b);
this.lineTo(a + c, b + g);
this.lineTo(a, b + g);
this.closePath();
this.fill();
this.currentPath_ = e;
};
d.createLinearGradient = function (a, b, c, g) {
var e = new w("gradient");
e.x0_ = a;
e.y0_ = b;
e.x1_ = c;
e.y1_ = g;
return e;
};
d.createRadialGradient = function (a, b, c, g, e, f) {
var d = new w("gradientradial");
d.x0_ = a;
d.y0_ = b;
d.r0_ = c;
d.x1_ = g;
d.y1_ = e;
d.r1_ = f;
return d;
};
d.drawImage = function (a, b) {
var c, g, e, d, r, y, n, h;
e = a.runtimeStyle.width;
d = a.runtimeStyle.height;
a.runtimeStyle.width = "auto";
a.runtimeStyle.height = "auto";
var l = a.width,
u = a.height;
a.runtimeStyle.width = e;
a.runtimeStyle.height = d;
if (3 == arguments.length)
(c = arguments[1]),
(g = arguments[2]),
(r = y = 0),
(n = e = l),
(h = d = u);
else if (5 == arguments.length)
(c = arguments[1]),
(g = arguments[2]),
(e = arguments[3]),
(d = arguments[4]),
(r = y = 0),
(n = l),
(h = u);
else if (9 == arguments.length)
(r = arguments[1]),
(y = arguments[2]),
(n = arguments[3]),
(h = arguments[4]),
(c = arguments[5]),
(g = arguments[6]),
(e = arguments[7]),
(d = arguments[8]);
else throw Error("Invalid number of arguments");
var m = s(this, c, g),
p = [];
p.push(
" <g_vml_:group",
' coordsize="',
10 * q,
",",
10 * q,
'"',
' coordorigin="0,0"',
' style="width:',
10,
"px;height:",
10,
"px;position:absolute;"
);
if (
1 != this.m_[0][0] ||
this.m_[0][1] ||
1 != this.m_[1][1] ||
this.m_[1][0]
) {
var t = [];
t.push(
"M11=",
this.m_[0][0],
",",
"M12=",
this.m_[1][0],
",",
"M21=",
this.m_[0][1],
",",
"M22=",
this.m_[1][1],
",",
"Dx=",
k(m.x / q),
",",
"Dy=",
k(m.y / q),
""
);
var v = s(this, c + e, g),
w = s(this, c, g + d);
c = s(this, c + e, g + d);
m.x = x.max(m.x, v.x, w.x, c.x);
m.y = x.max(m.y, v.y, w.y, c.y);
p.push(
"padding:0 ",
k(m.x / q),
"px ",
k(m.y / q),
"px 0;filter:progid:DXImageTransform.Microsoft.Matrix(",
t.join(""),
", sizingmethod='clip');"
);
} else p.push("top:", k(m.y / q), "px;left:", k(m.x / q), "px;");
p.push(
' ">',
'<g_vml_:image src="',
a.src,
'"',
' style="width:',
q * e,
"px;",
" height:",
q * d,
'px"',
' cropleft="',
r / l,
'"',
' croptop="',
y / u,
'"',
' cropright="',
(l - r - n) / l,
'"',
' cropbottom="',
(u - y - h) / u,
'"',
" />",
"</g_vml_:group>"
);
this.element_.insertAdjacentHTML("BeforeEnd", p.join(""));
};
d.stroke = function (a) {
var b = [];
b.push(
"<g_vml_:shape",
' filled="',
!!a,
'"',
' style="position:absolute;width:',
10,
"px;height:",
10,
'px;"',
' coordorigin="0,0"',
' coordsize="',
10 * q,
",",
10 * q,
'"',
' stroked="',
!a,
'"',
' path="'
);
for (
var c = { x: null, y: null }, d = { x: null, y: null }, e = 0;
e < this.currentPath_.length;
e++
) {
var f = this.currentPath_[e];
switch (f.type) {
case "moveTo":
b.push(" m ", k(f.x), ",", k(f.y));
break;
case "lineTo":
b.push(" l ", k(f.x), ",", k(f.y));
break;
case "close":
b.push(" x ");
f = null;
break;
case "bezierCurveTo":
b.push(
" c ",
k(f.cp1x),
",",
k(f.cp1y),
",",
k(f.cp2x),
",",
k(f.cp2y),
",",
k(f.x),
",",
k(f.y)
);
break;
case "at":
case "wa":
b.push(
" ",
f.type,
" ",
k(f.x - this.arcScaleX_ * f.radius),
",",
k(f.y - this.arcScaleY_ * f.radius),
" ",
k(f.x + this.arcScaleX_ * f.radius),
",",
k(f.y + this.arcScaleY_ * f.radius),
" ",
k(f.xStart),
",",
k(f.yStart),
" ",
k(f.xEnd),
",",
k(f.yEnd)
);
}
if (f) {
if (null == c.x || f.x < c.x) c.x = f.x;
if (null == d.x || f.x > d.x) d.x = f.x;
if (null == c.y || f.y < c.y) c.y = f.y;
if (null == d.y || f.y > d.y) d.y = f.y;
}
}
b.push(' ">');
a ? T(this, b, c, d) : S(this, b);
b.push("</g_vml_:shape>");
this.element_.insertAdjacentHTML("beforeEnd", b.join(""));
};
d.fill = function () {
this.stroke(!0);
};
d.closePath = function () {
this.currentPath_.push({ type: "close" });
};
d.save = function () {
var a = {};
P(this, a);
this.aStack_.push(a);
this.mStack_.push(this.m_);
this.m_ = t(D(), this.m_);
};
d.restore = function () {
this.aStack_.length &&
(P(this.aStack_.pop(), this), (this.m_ = this.mStack_.pop()));
};
d.translate = function (a, b) {
z(
this,
t(
[
[1, 0, 0],
[0, 1, 0],
[a, b, 1],
],
this.m_
),
!1
);
};
d.rotate = function (a) {
var b = K(a);
a = J(a);
z(
this,
t(
[
[b, a, 0],
[-a, b, 0],
[0, 0, 1],
],
this.m_
),
!1
);
};
d.scale = function (a, b) {
this.arcScaleX_ *= a;
this.arcScaleY_ *= b;
z(
this,
t(
[
[a, 0, 0],
[0, b, 0],
[0, 0, 1],
],
this.m_
),
!0
);
};
d.transform = function (a, b, c, d, e, f) {
z(
this,
t(
[
[a, b, 0],
[c, d, 0],
[e, f, 1],
],
this.m_
),
!0
);
};
d.setTransform = function (a, b, c, d, e, f) {
z(
this,
[
[a, b, 0],
[c, d, 0],
[e, f, 1],
],
!0
);
};
d.drawText_ = function (a, b, c, d, e) {
var f = this.m_;
d = 0;
var r = 1e3,
t = 0,
n = [],
h;
h = this.font;
if (L[h]) h = L[h];
else {
var l = document.createElement("div").style;
try {
l.font = h;
} catch (u) {}
h = L[h] = {
style: l.fontStyle || "normal",
variant: l.fontVariant || "normal",
weight: l.fontWeight || "normal",
size: l.fontSize || 10,
family: l.fontFamily || "sans-serif",
};
}
var l = h,
m = this.element_;
h = {};
for (var p in l) h[p] = l[p];
p = parseFloat(m.currentStyle.fontSize);
m = parseFloat(l.size);
"number" == typeof l.size
? (h.size = l.size)
: -1 != l.size.indexOf("px")
? (h.size = m)
: -1 != l.size.indexOf("em")
? (h.size = p * m)
: -1 != l.size.indexOf("%")
? (h.size = (p / 100) * m)
: -1 != l.size.indexOf("pt")
? (h.size = m / 0.75)
: (h.size = p);
h.size *= 0.981;
p =
h.style +
" " +
h.variant +
" " +
h.weight +
" " +
h.size +
"px " +
h.family;
m = this.element_.currentStyle;
l = this.textAlign.toLowerCase();
switch (l) {
case "left":
case "center":
case "right":
break;
case "end":
l = "ltr" == m.direction ? "right" : "left";
break;
case "start":
l = "rtl" == m.direction ? "right" : "left";
break;
default:
l = "left";
}
switch (this.textBaseline) {
case "hanging":
case "top":
t = h.size / 1.75;
break;
case "middle":
break;
default:
case null:
case "alphabetic":
case "ideographic":
case "bottom":
t = -h.size / 2.25;
}
switch (l) {
case "right":
d = 1e3;
r = 0.05;
break;
case "center":
d = r = 500;
}
b = s(this, b + 0, c + t);
n.push(
'<g_vml_:line from="',
-d,
' 0" to="',
r,
' 0.05" ',
' coordsize="100 100" coordorigin="0 0"',
' filled="',
!e,
'" stroked="',
!!e,
'" style="position:absolute;width:1px;height:1px;">'
);
e ? S(this, n) : T(this, n, { x: -d, y: 0 }, { x: r, y: h.size });
e =
f[0][0].toFixed(3) +
"," +
f[1][0].toFixed(3) +
"," +
f[0][1].toFixed(3) +
"," +
f[1][1].toFixed(3) +
",0,0";
b = k(b.x / q) + "," + k(b.y / q);
n.push(
'<g_vml_:skew on="t" matrix="',
e,
'" ',
' offset="',
b,
'" origin="',
d,
' 0" />',
'<g_vml_:path textpathok="true" />',
'<g_vml_:textpath on="true" string="',
N(a),
'" style="v-text-align:',
l,
";font:",
N(p),
'" /></g_vml_:line>'
);
this.element_.insertAdjacentHTML("beforeEnd", n.join(""));
};
d.fillText = function (a, b, c, d) {
this.drawText_(a, b, c, d, !1);
};
d.strokeText = function (a, b, c, d) {
this.drawText_(a, b, c, d, !0);
};
d.measureText = function (a) {
this.textMeasureEl_ ||
(this.element_.insertAdjacentHTML(
"beforeEnd",
'<span style="position:absolute;top:-20000px;left:0;padding:0;margin:0;border:none;white-space:pre;"></span>'
),
(this.textMeasureEl_ = this.element_.lastChild));
var b = this.element_.ownerDocument;
this.textMeasureEl_.innerHTML = "";
this.textMeasureEl_.style.font = this.font;
this.textMeasureEl_.appendChild(b.createTextNode(a));
return { width: this.textMeasureEl_.offsetWidth };
};
d.clip = function () {};
d.arcTo = function () {};
d.createPattern = function (a, b) {
return new I(a, b);
};
w.prototype.addColorStop = function (a, b) {
b = G(b);
this.colors_.push({ offset: a, color: b.color, alpha: b.alpha });
};
d = A.prototype = Error();
d.INDEX_SIZE_ERR = 1;
d.DOMSTRING_SIZE_ERR = 2;
d.HIERARCHY_REQUEST_ERR = 3;
d.WRONG_DOCUMENT_ERR = 4;
d.INVALID_CHARACTER_ERR = 5;
d.NO_DATA_ALLOWED_ERR = 6;
d.NO_MODIFICATION_ALLOWED_ERR = 7;
d.NOT_FOUND_ERR = 8;
d.NOT_SUPPORTED_ERR = 9;
d.INUSE_ATTRIBUTE_ERR = 10;
d.INVALID_STATE_ERR = 11;
d.SYNTAX_ERR = 12;
d.INVALID_MODIFICATION_ERR = 13;
d.NAMESPACE_ERR = 14;
d.INVALID_ACCESS_ERR = 15;
d.VALIDATION_ERR = 16;
d.TYPE_MISMATCH_ERR = 17;
G_vmlCanvasManager = U;
CanvasRenderingContext2D = C;
CanvasGradient = w;
CanvasPattern = I;
DOMException = A;
})();
/*eslint-enable*/
/*jshint ignore:end*/