%PDF- %PDF-
| Direktori : /home/tjamichg/intranet.tjamich.gob.mx/intranet/common/vendors/chart.js/ |
| Current File : /home/tjamichg/intranet.tjamich.gob.mx/intranet/common/vendors/chart.js/Chart.min.js |
var Chart = function (s) {
function v(a, c, b) {
a = A((a - c.graphMin) / (c.steps * c.stepValue), 1, 0);
return b * c.steps * a
}
function x(a, c, b, e) {
function h() {
g += f;
var k = a.animation ? A(d(g), null, 0) : 1;
e.clearRect(0, 0, q, u);
a.scaleOverlay ? (b(k), c()) : (c(), b(k));
if (1 >= g)D(h); else if ("function" == typeof a.onAnimationComplete)a.onAnimationComplete()
}
var f = a.animation ? 1 / A(a.animationSteps, Number.MAX_VALUE, 1) : 1, d = B[a.animationEasing], g = a.animation ? 0 : 1;
"function" !== typeof c && (c = function () {
});
D(h)
}
function C(a, c, b, e, h, f) {
var d;
a =
Math.floor(Math.log(e - h) / Math.LN10);
h = Math.floor(h / (1 * Math.pow(10, a))) * Math.pow(10, a);
e = Math.ceil(e / (1 * Math.pow(10, a))) * Math.pow(10, a) - h;
a = Math.pow(10, a);
for (d = Math.round(e / a); d < b || d > c;)a = d < b ? a / 2 : 2 * a, d = Math.round(e / a);
c = [];
z(f, c, d, h, a);
return{steps: d, stepValue: a, graphMin: h, labels: c}
}
function z(a, c, b, e, h) {
if (a)for (var f = 1; f < b + 1; f++)c.push(E(a, {value: (e + h * f).toFixed(0 != h % 1 ? h.toString().split(".")[1].length : 0)}))
}
function A(a, c, b) {
return!isNaN(parseFloat(c)) && isFinite(c) && a > c ? c : !isNaN(parseFloat(b)) &&
isFinite(b) && a < b ? b : a
}
function y(a, c) {
var b = {}, e;
for (e in a)b[e] = a[e];
for (e in c)b[e] = c[e];
return b
}
function E(a, c) {
var b = !/\W/.test(a) ? F[a] = F[a] || E(document.getElementById(a).innerHTML) : new Function("obj", "var p=[],print=function(){p.push.apply(p,arguments);};with(obj){p.push('" + a.replace(/[\r\t\n]/g, " ").split("<%").join("\t").replace(/((^|%>)[^\t]*)'/g, "$1\r").replace(/\t=(.*?)%>/g, "',$1,'").split("\t").join("');").split("%>").join("p.push('").split("\r").join("\\'") + "');}return p.join('');");
return c ?
b(c) : b
}
var r = this, B = {linear: function (a) {
return a
}, easeInQuad: function (a) {
return a * a
}, easeOutQuad: function (a) {
return-1 * a * (a - 2)
}, easeInOutQuad: function (a) {
return 1 > (a /= 0.5) ? 0.5 * a * a : -0.5 * (--a * (a - 2) - 1)
}, easeInCubic: function (a) {
return a * a * a
}, easeOutCubic: function (a) {
return 1 * ((a = a / 1 - 1) * a * a + 1)
}, easeInOutCubic: function (a) {
return 1 > (a /= 0.5) ? 0.5 * a * a * a : 0.5 * ((a -= 2) * a * a + 2)
}, easeInQuart: function (a) {
return a * a * a * a
}, easeOutQuart: function (a) {
return-1 * ((a = a / 1 - 1) * a * a * a - 1)
}, easeInOutQuart: function (a) {
return 1 > (a /= 0.5) ?
0.5 * a * a * a * a : -0.5 * ((a -= 2) * a * a * a - 2)
}, easeInQuint: function (a) {
return 1 * (a /= 1) * a * a * a * a
}, easeOutQuint: function (a) {
return 1 * ((a = a / 1 - 1) * a * a * a * a + 1)
}, easeInOutQuint: function (a) {
return 1 > (a /= 0.5) ? 0.5 * a * a * a * a * a : 0.5 * ((a -= 2) * a * a * a * a + 2)
}, easeInSine: function (a) {
return-1 * Math.cos(a / 1 * (Math.PI / 2)) + 1
}, easeOutSine: function (a) {
return 1 * Math.sin(a / 1 * (Math.PI / 2))
}, easeInOutSine: function (a) {
return-0.5 * (Math.cos(Math.PI * a / 1) - 1)
}, easeInExpo: function (a) {
return 0 == a ? 1 : 1 * Math.pow(2, 10 * (a / 1 - 1))
}, easeOutExpo: function (a) {
return 1 ==
a ? 1 : 1 * (-Math.pow(2, -10 * a / 1) + 1)
}, easeInOutExpo: function (a) {
return 0 == a ? 0 : 1 == a ? 1 : 1 > (a /= 0.5) ? 0.5 * Math.pow(2, 10 * (a - 1)) : 0.5 * (-Math.pow(2, -10 * --a) + 2)
}, easeInCirc: function (a) {
return 1 <= a ? a : -1 * (Math.sqrt(1 - (a /= 1) * a) - 1)
}, easeOutCirc: function (a) {
return 1 * Math.sqrt(1 - (a = a / 1 - 1) * a)
}, easeInOutCirc: function (a) {
return 1 > (a /= 0.5) ? -0.5 * (Math.sqrt(1 - a * a) - 1) : 0.5 * (Math.sqrt(1 - (a -= 2) * a) + 1)
}, easeInElastic: function (a) {
var c = 1.70158, b = 0, e = 1;
if (0 == a)return 0;
if (1 == (a /= 1))return 1;
b || (b = 0.3);
e < Math.abs(1) ? (e = 1, c = b / 4) : c = b / (2 *
Math.PI) * Math.asin(1 / e);
return-(e * Math.pow(2, 10 * (a -= 1)) * Math.sin((1 * a - c) * 2 * Math.PI / b))
}, easeOutElastic: function (a) {
var c = 1.70158, b = 0, e = 1;
if (0 == a)return 0;
if (1 == (a /= 1))return 1;
b || (b = 0.3);
e < Math.abs(1) ? (e = 1, c = b / 4) : c = b / (2 * Math.PI) * Math.asin(1 / e);
return e * Math.pow(2, -10 * a) * Math.sin((1 * a - c) * 2 * Math.PI / b) + 1
}, easeInOutElastic: function (a) {
var c = 1.70158, b = 0, e = 1;
if (0 == a)return 0;
if (2 == (a /= 0.5))return 1;
b || (b = 1 * 0.3 * 1.5);
e < Math.abs(1) ? (e = 1, c = b / 4) : c = b / (2 * Math.PI) * Math.asin(1 / e);
return 1 > a ? -0.5 * e * Math.pow(2, 10 *
(a -= 1)) * Math.sin((1 * a - c) * 2 * Math.PI / b) : 0.5 * e * Math.pow(2, -10 * (a -= 1)) * Math.sin((1 * a - c) * 2 * Math.PI / b) + 1
}, easeInBack: function (a) {
return 1 * (a /= 1) * a * (2.70158 * a - 1.70158)
}, easeOutBack: function (a) {
return 1 * ((a = a / 1 - 1) * a * (2.70158 * a + 1.70158) + 1)
}, easeInOutBack: function (a) {
var c = 1.70158;
return 1 > (a /= 0.5) ? 0.5 * a * a * (((c *= 1.525) + 1) * a - c) : 0.5 * ((a -= 2) * a * (((c *= 1.525) + 1) * a + c) + 2)
}, easeInBounce: function (a) {
return 1 - B.easeOutBounce(1 - a)
}, easeOutBounce: function (a) {
return(a /= 1) < 1 / 2.75 ? 1 * 7.5625 * a * a : a < 2 / 2.75 ? 1 * (7.5625 * (a -= 1.5 / 2.75) *
a + 0.75) : a < 2.5 / 2.75 ? 1 * (7.5625 * (a -= 2.25 / 2.75) * a + 0.9375) : 1 * (7.5625 * (a -= 2.625 / 2.75) * a + 0.984375)
}, easeInOutBounce: function (a) {
return 0.5 > a ? 0.5 * B.easeInBounce(2 * a) : 0.5 * B.easeOutBounce(2 * a - 1) + 0.5
}}, q = s.canvas.width, u = s.canvas.height;
window.devicePixelRatio && (s.canvas.style.width = q + "px", s.canvas.style.height = u + "px", s.canvas.height = u * window.devicePixelRatio, s.canvas.width = q * window.devicePixelRatio, s.scale(window.devicePixelRatio, window.devicePixelRatio));
this.PolarArea = function (a, c) {
r.PolarArea.defaults = {scaleOverlay: !0,
scaleOverride: !1, scaleSteps: null, scaleStepWidth: null, scaleStartValue: null, scaleShowLine: !0, scaleLineColor: "rgba(0,0,0,.1)", scaleLineWidth: 1, scaleShowLabels: !0, scaleLabel: "<%=value%>", scaleFontFamily: "'Arial'", scaleFontSize: 12, scaleFontStyle: "normal", scaleFontColor: "#666", scaleShowLabelBackdrop: !0, scaleBackdropColor: "rgba(255,255,255,0.75)", scaleBackdropPaddingY: 2, scaleBackdropPaddingX: 2, segmentShowStroke: !0, segmentStrokeColor: "#fff", segmentStrokeWidth: 2, animation: !0, animationSteps: 100, animationEasing: "easeOutBounce",
animateRotate: !0, animateScale: !1, onAnimationComplete: null};
var b = c ? y(r.PolarArea.defaults, c) : r.PolarArea.defaults;
return new G(a, b, s)
};
this.Radar = function (a, c) {
r.Radar.defaults = {scaleOverlay: !1, scaleOverride: !1, scaleSteps: null, scaleStepWidth: null, scaleStartValue: null, scaleShowLine: !0, scaleLineColor: "rgba(0,0,0,.1)", scaleLineWidth: 1, scaleShowLabels: !1, scaleLabel: "<%=value%>", scaleFontFamily: "'Arial'", scaleFontSize: 12, scaleFontStyle: "normal", scaleFontColor: "#666", scaleShowLabelBackdrop: !0, scaleBackdropColor: "rgba(255,255,255,0.75)",
scaleBackdropPaddingY: 2, scaleBackdropPaddingX: 2, angleShowLineOut: !0, angleLineColor: "rgba(0,0,0,.1)", angleLineWidth: 1, pointLabelFontFamily: "'Arial'", pointLabelFontStyle: "normal", pointLabelFontSize: 12, pointLabelFontColor: "#666", pointDot: !0, pointDotRadius: 3, pointDotStrokeWidth: 1, datasetStroke: !0, datasetStrokeWidth: 2, datasetFill: !0, animation: !0, animationSteps: 60, animationEasing: "easeOutQuart", onAnimationComplete: null};
var b = c ? y(r.Radar.defaults, c) : r.Radar.defaults;
return new H(a, b, s)
};
this.Pie = function (a, c) {
r.Pie.defaults = {segmentShowStroke: !0, segmentStrokeColor: "#fff", segmentStrokeWidth: 2, animation: !0, animationSteps: 100, animationEasing: "easeOutBounce", animateRotate: !0, animateScale: !1, onAnimationComplete: null};
var b = c ? y(r.Pie.defaults, c) : r.Pie.defaults;
return new I(a, b, s)
};
this.Doughnut = function (a, c) {
r.Doughnut.defaults = {segmentShowStroke: !0, segmentStrokeColor: "#fff", segmentStrokeWidth: 2, percentageInnerCutout: 50, animation: !0, animationSteps: 100, animationEasing: "easeOutBounce", animateRotate: !0, animateScale: !1,
onAnimationComplete: null};
var b = c ? y(r.Doughnut.defaults, c) : r.Doughnut.defaults;
return new J(a, b, s)
};
this.Line = function (a, c) {
r.Line.defaults = {scaleOverlay: !1, scaleOverride: !1, scaleSteps: null, scaleStepWidth: null, scaleStartValue: null, scaleLineColor: "rgba(0,0,0,.1)", scaleLineWidth: 1, scaleShowLabels: !0, scaleLabel: "<%=value%>", scaleFontFamily: "'Arial'", scaleFontSize: 12, scaleFontStyle: "normal", scaleFontColor: "#666", scaleShowGridLines: !0, scaleGridLineColor: "rgba(0,0,0,.05)", scaleGridLineWidth: 1, bezierCurve: !0,
pointDot: !0, pointDotRadius: 4, pointDotStrokeWidth: 2, datasetStroke: !0, datasetStrokeWidth: 2, datasetFill: !0, animation: !0, animationSteps: 60, animationEasing: "easeOutQuart", onAnimationComplete: null};
var b = c ? y(r.Line.defaults, c) : r.Line.defaults;
return new K(a, b, s)
};
this.Bar = function (a, c) {
r.Bar.defaults = {scaleOverlay: !1, scaleOverride: !1, scaleSteps: null, scaleStepWidth: null, scaleStartValue: null, scaleLineColor: "rgba(0,0,0,.1)", scaleLineWidth: 1, scaleShowLabels: !0, scaleLabel: "<%=value%>", scaleFontFamily: "'Arial'",
scaleFontSize: 12, scaleFontStyle: "normal", scaleFontColor: "#666", scaleShowGridLines: !0, scaleGridLineColor: "rgba(0,0,0,.05)", scaleGridLineWidth: 1, barShowStroke: !0, barStrokeWidth: 2, barValueSpacing: 5, barDatasetSpacing: 1, animation: !0, animationSteps: 60, animationEasing: "easeOutQuart", onAnimationComplete: null};
var b = c ? y(r.Bar.defaults, c) : r.Bar.defaults;
return new L(a, b, s)
};
var G = function (a, c, b) {
var e, h, f, d, g, k, j, l, m;
g = Math.min.apply(Math, [q, u]) / 2;
g -= Math.max.apply(Math, [0.5 * c.scaleFontSize, 0.5 * c.scaleLineWidth]);
d = 2 * c.scaleFontSize;
c.scaleShowLabelBackdrop && (d += 2 * c.scaleBackdropPaddingY, g -= 1.5 * c.scaleBackdropPaddingY);
l = g;
d = d ? d : 5;
e = Number.MIN_VALUE;
h = Number.MAX_VALUE;
for (f = 0; f < a.length; f++)a[f].value > e && (e = a[f].value), a[f].value < h && (h = a[f].value);
f = Math.floor(l / (0.66 * d));
d = Math.floor(0.5 * (l / d));
m = c.scaleShowLabels ? c.scaleLabel : null;
c.scaleOverride ? (j = {steps: c.scaleSteps, stepValue: c.scaleStepWidth, graphMin: c.scaleStartValue, labels: []}, z(m, j.labels, j.steps, c.scaleStartValue, c.scaleStepWidth)) : j = C(l, f, d, e, h,
m);
k = g / j.steps;
x(c, function () {
for (var a = 0; a < j.steps; a++)if (c.scaleShowLine && (b.beginPath(), b.arc(q / 2, u / 2, k * (a + 1), 0, 2 * Math.PI, !0), b.strokeStyle = c.scaleLineColor, b.lineWidth = c.scaleLineWidth, b.stroke()), c.scaleShowLabels) {
b.textAlign = "center";
b.font = c.scaleFontStyle + " " + c.scaleFontSize + "px " + c.scaleFontFamily;
var e = j.labels[a];
if (c.scaleShowLabelBackdrop) {
var d = b.measureText(e).width;
b.fillStyle = c.scaleBackdropColor;
b.beginPath();
b.rect(Math.round(q / 2 - d / 2 - c.scaleBackdropPaddingX), Math.round(u / 2 - k * (a +
1) - 0.5 * c.scaleFontSize - c.scaleBackdropPaddingY), Math.round(d + 2 * c.scaleBackdropPaddingX), Math.round(c.scaleFontSize + 2 * c.scaleBackdropPaddingY));
b.fill()
}
b.textBaseline = "middle";
b.fillStyle = c.scaleFontColor;
b.fillText(e, q / 2, u / 2 - k * (a + 1))
}
}, function (e) {
var d = -Math.PI / 2, g = 2 * Math.PI / a.length, f = 1, h = 1;
c.animation && (c.animateScale && (f = e), c.animateRotate && (h = e));
for (e = 0; e < a.length; e++)b.beginPath(), b.arc(q / 2, u / 2, f * v(a[e].value, j, k), d, d + h * g, !1), b.lineTo(q / 2, u / 2), b.closePath(), b.fillStyle = a[e].color, b.fill(),
c.segmentShowStroke && (b.strokeStyle = c.segmentStrokeColor, b.lineWidth = c.segmentStrokeWidth, b.stroke()), d += h * g
}, b)
}, H = function (a, c, b) {
var e, h, f, d, g, k, j, l, m;
a.labels || (a.labels = []);
g = Math.min.apply(Math, [q, u]) / 2;
d = 2 * c.scaleFontSize;
for (e = l = 0; e < a.labels.length; e++)b.font = c.pointLabelFontStyle + " " + c.pointLabelFontSize + "px " + c.pointLabelFontFamily, h = b.measureText(a.labels[e]).width, h > l && (l = h);
g -= Math.max.apply(Math, [l, 1.5 * (c.pointLabelFontSize / 2)]);
g -= c.pointLabelFontSize;
l = g = A(g, null, 0);
d = d ? d : 5;
e = Number.MIN_VALUE;
h = Number.MAX_VALUE;
for (f = 0; f < a.datasets.length; f++)for (m = 0; m < a.datasets[f].data.length; m++)a.datasets[f].data[m] > e && (e = a.datasets[f].data[m]), a.datasets[f].data[m] < h && (h = a.datasets[f].data[m]);
f = Math.floor(l / (0.66 * d));
d = Math.floor(0.5 * (l / d));
m = c.scaleShowLabels ? c.scaleLabel : null;
c.scaleOverride ? (j = {steps: c.scaleSteps, stepValue: c.scaleStepWidth, graphMin: c.scaleStartValue, labels: []}, z(m, j.labels, j.steps, c.scaleStartValue, c.scaleStepWidth)) : j = C(l, f, d, e, h, m);
k = g / j.steps;
x(c, function () {
var e = 2 * Math.PI /
a.datasets[0].data.length;
b.save();
b.translate(q / 2, u / 2);
if (c.angleShowLineOut) {
b.strokeStyle = c.angleLineColor;
b.lineWidth = c.angleLineWidth;
for (var d = 0; d < a.datasets[0].data.length; d++)b.rotate(e), b.beginPath(), b.moveTo(0, 0), b.lineTo(0, -g), b.stroke()
}
for (d = 0; d < j.steps; d++) {
b.beginPath();
if (c.scaleShowLine) {
b.strokeStyle = c.scaleLineColor;
b.lineWidth = c.scaleLineWidth;
b.moveTo(0, -k * (d + 1));
for (var f = 0; f < a.datasets[0].data.length; f++)b.rotate(e), b.lineTo(0, -k * (d + 1));
b.closePath();
b.stroke()
}
c.scaleShowLabels &&
(b.textAlign = "center", b.font = c.scaleFontStyle + " " + c.scaleFontSize + "px " + c.scaleFontFamily, b.textBaseline = "middle", c.scaleShowLabelBackdrop && (f = b.measureText(j.labels[d]).width, b.fillStyle = c.scaleBackdropColor, b.beginPath(), b.rect(Math.round(-f / 2 - c.scaleBackdropPaddingX), Math.round(-k * (d + 1) - 0.5 * c.scaleFontSize - c.scaleBackdropPaddingY), Math.round(f + 2 * c.scaleBackdropPaddingX), Math.round(c.scaleFontSize + 2 * c.scaleBackdropPaddingY)), b.fill()), b.fillStyle = c.scaleFontColor, b.fillText(j.labels[d], 0, -k * (d +
1)))
}
for (d = 0; d < a.labels.length; d++) {
b.font = c.pointLabelFontStyle + " " + c.pointLabelFontSize + "px " + c.pointLabelFontFamily;
b.fillStyle = c.pointLabelFontColor;
var f = Math.sin(e * d) * (g + c.pointLabelFontSize), h = Math.cos(e * d) * (g + c.pointLabelFontSize);
b.textAlign = e * d == Math.PI || 0 == e * d ? "center" : e * d > Math.PI ? "right" : "left";
b.textBaseline = "middle";
b.fillText(a.labels[d], f, -h)
}
b.restore()
}, function (d) {
var e = 2 * Math.PI / a.datasets[0].data.length;
b.save();
b.translate(q / 2, u / 2);
for (var g = 0; g < a.datasets.length; g++) {
b.beginPath();
b.moveTo(0, d * -1 * v(a.datasets[g].data[0], j, k));
for (var f = 1; f < a.datasets[g].data.length; f++)b.rotate(e), b.lineTo(0, d * -1 * v(a.datasets[g].data[f], j, k));
b.closePath();
b.fillStyle = a.datasets[g].fillColor;
b.strokeStyle = a.datasets[g].strokeColor;
b.lineWidth = c.datasetStrokeWidth;
b.fill();
b.stroke();
if (c.pointDot) {
b.fillStyle = a.datasets[g].pointColor;
b.strokeStyle = a.datasets[g].pointStrokeColor;
b.lineWidth = c.pointDotStrokeWidth;
for (f = 0; f < a.datasets[g].data.length; f++)b.rotate(e), b.beginPath(), b.arc(0, d * -1 *
v(a.datasets[g].data[f], j, k), c.pointDotRadius, 2 * Math.PI, !1), b.fill(), b.stroke()
}
b.rotate(e)
}
b.restore()
}, b)
}, I = function (a, c, b) {
for (var e = 0, h = Math.min.apply(Math, [u / 2, q / 2]) - 5, f = 0; f < a.length; f++)e += a[f].value;
x(c, null, function (d) {
var g = -Math.PI / 2, f = 1, j = 1;
c.animation && (c.animateScale && (f = d), c.animateRotate && (j = d));
for (d = 0; d < a.length; d++) {
var l = j * a[d].value / e * 2 * Math.PI;
b.beginPath();
b.arc(q / 2, u / 2, f * h, g, g + l);
b.lineTo(q / 2, u / 2);
b.closePath();
b.fillStyle = a[d].color;
b.fill();
c.segmentShowStroke && (b.lineWidth =
c.segmentStrokeWidth, b.strokeStyle = c.segmentStrokeColor, b.stroke());
g += l
}
}, b)
}, J = function (a, c, b) {
for (var e = 0, h = Math.min.apply(Math, [u / 2, q / 2]) - 5, f = h * (c.percentageInnerCutout / 100), d = 0; d < a.length; d++)e += a[d].value;
x(c, null, function (d) {
var k = -Math.PI / 2, j = 1, l = 1;
c.animation && (c.animateScale && (j = d), c.animateRotate && (l = d));
for (d = 0; d < a.length; d++) {
var m = l * a[d].value / e * 2 * Math.PI;
b.beginPath();
b.arc(q / 2, u / 2, j * h, k, k + m, !1);
b.arc(q / 2, u / 2, j * f, k + m, k, !0);
b.closePath();
b.fillStyle = a[d].color;
b.fill();
c.segmentShowStroke &&
(b.lineWidth = c.segmentStrokeWidth, b.strokeStyle = c.segmentStrokeColor, b.stroke());
k += m
}
}, b)
}, K = function (a, c, b) {
var e, h, f, d, g, k, j, l, m, t, r, n, p, s = 0;
g = u;
b.font = c.scaleFontStyle + " " + c.scaleFontSize + "px " + c.scaleFontFamily;
t = 1;
for (d = 0; d < a.labels.length; d++)e = b.measureText(a.labels[d]).width, t = e > t ? e : t;
q / a.labels.length < t ? (s = 45, q / a.labels.length < Math.cos(s) * t ? (s = 90, g -= t) : g -= Math.sin(s) * t) : g -= c.scaleFontSize;
d = c.scaleFontSize;
g = g - 5 - d;
e = Number.MIN_VALUE;
h = Number.MAX_VALUE;
for (f = 0; f < a.datasets.length; f++)for (l =
0; l < a.datasets[f].data.length; l++)a.datasets[f].data[l] > e && (e = a.datasets[f].data[l]), a.datasets[f].data[l] < h && (h = a.datasets[f].data[l]);
f = Math.floor(g / (0.66 * d));
d = Math.floor(0.5 * (g / d));
l = c.scaleShowLabels ? c.scaleLabel : "";
c.scaleOverride ? (j = {steps: c.scaleSteps, stepValue: c.scaleStepWidth, graphMin: c.scaleStartValue, labels: []}, z(l, j.labels, j.steps, c.scaleStartValue, c.scaleStepWidth)) : j = C(g, f, d, e, h, l);
k = Math.floor(g / j.steps);
d = 1;
if (c.scaleShowLabels) {
b.font = c.scaleFontStyle + " " + c.scaleFontSize + "px " + c.scaleFontFamily;
for (e = 0; e < j.labels.length; e++)h = b.measureText(j.labels[e]).width, d = h > d ? h : d;
d += 10
}
r = q - d - t;
m = Math.floor(r / (a.labels.length - 1));
n = q - t / 2 - r;
p = g + c.scaleFontSize / 2;
x(c, function () {
b.lineWidth = c.scaleLineWidth;
b.strokeStyle = c.scaleLineColor;
b.beginPath();
b.moveTo(q - t / 2 + 5, p);
b.lineTo(q - t / 2 - r - 5, p);
b.stroke();
0 < s ? (b.save(), b.textAlign = "right") : b.textAlign = "center";
b.fillStyle = c.scaleFontColor;
for (var d = 0; d < a.labels.length; d++)b.save(), 0 < s ? (b.translate(n + d * m, p + c.scaleFontSize), b.rotate(-(s * (Math.PI / 180))), b.fillText(a.labels[d],
0, 0), b.restore()) : b.fillText(a.labels[d], n + d * m, p + c.scaleFontSize + 3), b.beginPath(), b.moveTo(n + d * m, p + 3), c.scaleShowGridLines && 0 < d ? (b.lineWidth = c.scaleGridLineWidth, b.strokeStyle = c.scaleGridLineColor, b.lineTo(n + d * m, 5)) : b.lineTo(n + d * m, p + 3), b.stroke();
b.lineWidth = c.scaleLineWidth;
b.strokeStyle = c.scaleLineColor;
b.beginPath();
b.moveTo(n, p + 5);
b.lineTo(n, 5);
b.stroke();
b.textAlign = "right";
b.textBaseline = "middle";
for (d = 0; d < j.steps; d++)b.beginPath(), b.moveTo(n - 3, p - (d + 1) * k), c.scaleShowGridLines ? (b.lineWidth = c.scaleGridLineWidth,
b.strokeStyle = c.scaleGridLineColor, b.lineTo(n + r + 5, p - (d + 1) * k)) : b.lineTo(n - 0.5, p - (d + 1) * k), b.stroke(), c.scaleShowLabels && b.fillText(j.labels[d], n - 8, p - (d + 1) * k)
}, function (d) {
function e(b, c) {
return p - d * v(a.datasets[b].data[c], j, k)
}
for (var f = 0; f < a.datasets.length; f++) {
b.strokeStyle = a.datasets[f].strokeColor;
b.lineWidth = c.datasetStrokeWidth;
b.beginPath();
b.moveTo(n, p - d * v(a.datasets[f].data[0], j, k));
for (var g = 1; g < a.datasets[f].data.length; g++)c.bezierCurve ? b.bezierCurveTo(n + m * (g - 0.5), e(f, g - 1), n + m * (g - 0.5),
e(f, g), n + m * g, e(f, g)) : b.lineTo(n + m * g, e(f, g));
b.stroke();
c.datasetFill ? (b.lineTo(n + m * (a.datasets[f].data.length - 1), p), b.lineTo(n, p), b.closePath(), b.fillStyle = a.datasets[f].fillColor, b.fill()) : b.closePath();
if (c.pointDot) {
b.fillStyle = a.datasets[f].pointColor;
b.strokeStyle = a.datasets[f].pointStrokeColor;
b.lineWidth = c.pointDotStrokeWidth;
for (g = 0; g < a.datasets[f].data.length; g++)b.beginPath(), b.arc(n + m * g, p - d * v(a.datasets[f].data[g], j, k), c.pointDotRadius, 0, 2 * Math.PI, !0), b.fill(), b.stroke()
}
}
}, b)
}, L = function (a, c, b) {
var e, h, f, d, g, k, j, l, m, t, r, n, p, s, w = 0;
g = u;
b.font = c.scaleFontStyle + " " + c.scaleFontSize + "px " + c.scaleFontFamily;
t = 1;
for (d = 0; d < a.labels.length; d++)e = b.measureText(a.labels[d]).width, t = e > t ? e : t;
q / a.labels.length < t ? (w = 45, q / a.labels.length < Math.cos(w) * t ? (w = 90, g -= t) : g -= Math.sin(w) * t) : g -= c.scaleFontSize;
d = c.scaleFontSize;
g = g - 5 - d;
e = Number.MIN_VALUE;
h = Number.MAX_VALUE;
for (f = 0; f < a.datasets.length; f++)for (l = 0; l < a.datasets[f].data.length; l++)a.datasets[f].data[l] > e && (e = a.datasets[f].data[l]), a.datasets[f].data[l] <
h && (h = a.datasets[f].data[l]);
f = Math.floor(g / (0.66 * d));
d = Math.floor(0.5 * (g / d));
l = c.scaleShowLabels ? c.scaleLabel : "";
c.scaleOverride ? (j = {steps: c.scaleSteps, stepValue: c.scaleStepWidth, graphMin: c.scaleStartValue, labels: []}, z(l, j.labels, j.steps, c.scaleStartValue, c.scaleStepWidth)) : j = C(g, f, d, e, h, l);
k = Math.floor(g / j.steps);
d = 1;
if (c.scaleShowLabels) {
b.font = c.scaleFontStyle + " " + c.scaleFontSize + "px " + c.scaleFontFamily;
for (e = 0; e < j.labels.length; e++)h = b.measureText(j.labels[e]).width, d = h > d ? h : d;
d += 10
}
r = q - d - t;
m =
Math.floor(r / a.labels.length);
s = (m - 2 * c.scaleGridLineWidth - 2 * c.barValueSpacing - (c.barDatasetSpacing * a.datasets.length - 1) - (c.barStrokeWidth / 2 * a.datasets.length - 1)) / a.datasets.length;
n = q - t / 2 - r;
p = g + c.scaleFontSize / 2;
x(c, function () {
b.lineWidth = c.scaleLineWidth;
b.strokeStyle = c.scaleLineColor;
b.beginPath();
b.moveTo(q - t / 2 + 5, p);
b.lineTo(q - t / 2 - r - 5, p);
b.stroke();
0 < w ? (b.save(), b.textAlign = "right") : b.textAlign = "center";
b.fillStyle = c.scaleFontColor;
for (var d = 0; d < a.labels.length; d++)b.save(), 0 < w ? (b.translate(n +
d * m, p + c.scaleFontSize), b.rotate(-(w * (Math.PI / 180))), b.fillText(a.labels[d], 0, 0), b.restore()) : b.fillText(a.labels[d], n + d * m + m / 2, p + c.scaleFontSize + 3), b.beginPath(), b.moveTo(n + (d + 1) * m, p + 3), b.lineWidth = c.scaleGridLineWidth, b.strokeStyle = c.scaleGridLineColor, b.lineTo(n + (d + 1) * m, 5), b.stroke();
b.lineWidth = c.scaleLineWidth;
b.strokeStyle = c.scaleLineColor;
b.beginPath();
b.moveTo(n, p + 5);
b.lineTo(n, 5);
b.stroke();
b.textAlign = "right";
b.textBaseline = "middle";
for (d = 0; d < j.steps; d++)b.beginPath(), b.moveTo(n - 3, p - (d + 1) *
k), c.scaleShowGridLines ? (b.lineWidth = c.scaleGridLineWidth, b.strokeStyle = c.scaleGridLineColor, b.lineTo(n + r + 5, p - (d + 1) * k)) : b.lineTo(n - 0.5, p - (d + 1) * k), b.stroke(), c.scaleShowLabels && b.fillText(j.labels[d], n - 8, p - (d + 1) * k)
}, function (d) {
b.lineWidth = c.barStrokeWidth;
for (var e = 0; e < a.datasets.length; e++) {
b.fillStyle = a.datasets[e].fillColor;
b.strokeStyle = a.datasets[e].strokeColor;
for (var f = 0; f < a.datasets[e].data.length; f++) {
var g = n + c.barValueSpacing + m * f + s * e + c.barDatasetSpacing * e + c.barStrokeWidth * e;
b.beginPath();
b.moveTo(g, p);
b.lineTo(g, p - d * v(a.datasets[e].data[f], j, k) + c.barStrokeWidth / 2);
b.lineTo(g + s, p - d * v(a.datasets[e].data[f], j, k) + c.barStrokeWidth / 2);
b.lineTo(g + s, p);
c.barShowStroke && b.stroke();
b.closePath();
b.fill()
}
}
}, b)
}, D = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (a) {
window.setTimeout(a, 1E3 / 60)
}, F = {}
};