/*!
* Chart.js
* http://chartjs.org/
* Version: 2.7.2
*
* Copyright 2018 Chart.js Contributors
* Released under the MIT license
* https://github.com/chartjs/Chart.js/blob/master/LICENSE.md
*/
!function (t) {
if ("object" == typeof exports && "undefined" != typeof module) module.exports = t(); else if ("function" == typeof define && define.amd) define([], t); else {
("undefined" != typeof window ? window : "undefined" != typeof global ? global : "undefined" != typeof self ? self : this).Chart = t()
}
}(function () {
return function t(e, i, n) {
function a(o, s) {
if (!i[o]) {
if (!e[o]) {
var l = "function" == typeof require && require;
if (!s && l) return l(o, !0);
if (r) return r(o, !0);
var u = new Error("Cannot find module '" + o + "'");
throw u.code = "MODULE_NOT_FOUND", u
}
var d = i[o] = {exports: {}};
e[o][0].call(d.exports, function (t) {
var i = e[o][1][t];
return a(i || t)
}, d, d.exports, t, e, i, n)
}
return i[o].exports
}
for (var r = "function" == typeof require && require, o = 0; o < n.length; o++) a(n[o]);
return a
}({
1: [function (t, e, i) {
var n = t(5);
function a(t) {
if (t) {
var e = [0, 0, 0], i = 1, a = t.match(/^#([a-fA-F0-9]{3})$/i);
if (a) {
a = a[1];
for (var r = 0; r < e.length; r++) e[r] = parseInt(a[r] + a[r], 16)
} else if (a = t.match(/^#([a-fA-F0-9]{6})$/i)) {
a = a[1];
for (r = 0; r < e.length; r++) e[r] = parseInt(a.slice(2 * r, 2 * r + 2), 16)
} else if (a = t.match(/^rgba?\(\s*([+-]?\d+)\s*,\s*([+-]?\d+)\s*,\s*([+-]?\d+)\s*(?:,\s*([+-]?[\d\.]+)\s*)?\)$/i)) {
for (r = 0; r < e.length; r++) e[r] = parseInt(a[r + 1]);
i = parseFloat(a[4])
} else if (a = t.match(/^rgba?\(\s*([+-]?[\d\.]+)\%\s*,\s*([+-]?[\d\.]+)\%\s*,\s*([+-]?[\d\.]+)\%\s*(?:,\s*([+-]?[\d\.]+)\s*)?\)$/i)) {
for (r = 0; r < e.length; r++) e[r] = Math.round(2.55 * parseFloat(a[r + 1]));
i = parseFloat(a[4])
} else if (a = t.match(/(\w+)/)) {
if ("transparent" == a[1]) return [0, 0, 0, 0];
if (!(e = n[a[1]])) return
}
for (r = 0; r < e.length; r++) e[r] = d(e[r], 0, 255);
return i = i || 0 == i ? d(i, 0, 1) : 1, e[3] = i, e
}
}
function r(t) {
if (t) {
var e = t.match(/^hsla?\(\s*([+-]?\d+)(?:deg)?\s*,\s*([+-]?[\d\.]+)%\s*,\s*([+-]?[\d\.]+)%\s*(?:,\s*([+-]?[\d\.]+)\s*)?\)/);
if (e) {
var i = parseFloat(e[4]);
return [d(parseInt(e[1]), 0, 360), d(parseFloat(e[2]), 0, 100), d(parseFloat(e[3]), 0, 100), d(isNaN(i) ? 1 : i, 0, 1)]
}
}
}
function o(t) {
if (t) {
var e = t.match(/^hwb\(\s*([+-]?\d+)(?:deg)?\s*,\s*([+-]?[\d\.]+)%\s*,\s*([+-]?[\d\.]+)%\s*(?:,\s*([+-]?[\d\.]+)\s*)?\)/);
if (e) {
var i = parseFloat(e[4]);
return [d(parseInt(e[1]), 0, 360), d(parseFloat(e[2]), 0, 100), d(parseFloat(e[3]), 0, 100), d(isNaN(i) ? 1 : i, 0, 1)]
}
}
}
function s(t, e) {
return void 0 === e && (e = void 0 !== t[3] ? t[3] : 1), "rgba(" + t[0] + ", " + t[1] + ", " + t[2] + ", " + e + ")"
}
function l(t, e) {
return "rgba(" + Math.round(t[0] / 255 * 100) + "%, " + Math.round(t[1] / 255 * 100) + "%, " + Math.round(t[2] / 255 * 100) + "%, " + (e || t[3] || 1) + ")"
}
function u(t, e) {
return void 0 === e && (e = void 0 !== t[3] ? t[3] : 1), "hsla(" + t[0] + ", " + t[1] + "%, " + t[2] + "%, " + e + ")"
}
function d(t, e, i) {
return Math.min(Math.max(e, t), i)
}
function h(t) {
var e = t.toString(16).toUpperCase();
return e.length < 2 ? "0" + e : e
}
e.exports = {
getRgba: a, getHsla: r, getRgb: function (t) {
var e = a(t);
return e && e.slice(0, 3)
}, getHsl: function (t) {
var e = r(t);
return e && e.slice(0, 3)
}, getHwb: o, getAlpha: function (t) {
var e = a(t);
{
if (e) return e[3];
if (e = r(t)) return e[3];
if (e = o(t)) return e[3]
}
}, hexString: function (t) {
return "#" + h(t[0]) + h(t[1]) + h(t[2])
}, rgbString: function (t, e) {
if (e < 1 || t[3] && t[3] < 1) return s(t, e);
return "rgb(" + t[0] + ", " + t[1] + ", " + t[2] + ")"
}, rgbaString: s, percentString: function (t, e) {
if (e < 1 || t[3] && t[3] < 1) return l(t, e);
var i = Math.round(t[0] / 255 * 100), n = Math.round(t[1] / 255 * 100),
a = Math.round(t[2] / 255 * 100);
return "rgb(" + i + "%, " + n + "%, " + a + "%)"
}, percentaString: l, hslString: function (t, e) {
if (e < 1 || t[3] && t[3] < 1) return u(t, e);
return "hsl(" + t[0] + ", " + t[1] + "%, " + t[2] + "%)"
}, hslaString: u, hwbString: function (t, e) {
void 0 === e && (e = void 0 !== t[3] ? t[3] : 1);
return "hwb(" + t[0] + ", " + t[1] + "%, " + t[2] + "%" + (void 0 !== e && 1 !== e ? ", " + e : "") + ")"
}, keyword: function (t) {
return c[t.slice(0, 3)]
}
};
var c = {};
for (var f in n) c[n[f]] = f
}, {5: 5}], 2: [function (t, e, i) {
var n = t(4), a = t(1), r = function (t) {
return t instanceof r ? t : this instanceof r ? (this.valid = !1, this.values = {
rgb: [0, 0, 0],
hsl: [0, 0, 0],
hsv: [0, 0, 0],
hwb: [0, 0, 0],
cmyk: [0, 0, 0, 0],
alpha: 1
}, void("string" == typeof t ? (e = a.getRgba(t)) ? this.setValues("rgb", e) : (e = a.getHsla(t)) ? this.setValues("hsl", e) : (e = a.getHwb(t)) && this.setValues("hwb", e) : "object" == typeof t && (void 0 !== (e = t).r || void 0 !== e.red ? this.setValues("rgb", e) : void 0 !== e.l || void 0 !== e.lightness ? this.setValues("hsl", e) : void 0 !== e.v || void 0 !== e.value ? this.setValues("hsv", e) : void 0 !== e.w || void 0 !== e.whiteness ? this.setValues("hwb", e) : void 0 === e.c && void 0 === e.cyan || this.setValues("cmyk", e)))) : new r(t);
var e
};
r.prototype = {
isValid: function () {
return this.valid
}, rgb: function () {
return this.setSpace("rgb", arguments)
}, hsl: function () {
return this.setSpace("hsl", arguments)
}, hsv: function () {
return this.setSpace("hsv", arguments)
}, hwb: function () {
return this.setSpace("hwb", arguments)
}, cmyk: function () {
return this.setSpace("cmyk", arguments)
}, rgbArray: function () {
return this.values.rgb
}, hslArray: function () {
return this.values.hsl
}, hsvArray: function () {
return this.values.hsv
}, hwbArray: function () {
var t = this.values;
return 1 !== t.alpha ? t.hwb.concat([t.alpha]) : t.hwb
}, cmykArray: function () {
return this.values.cmyk
}, rgbaArray: function () {
var t = this.values;
return t.rgb.concat([t.alpha])
}, hslaArray: function () {
var t = this.values;
return t.hsl.concat([t.alpha])
}, alpha: function (t) {
return void 0 === t ? this.values.alpha : (this.setValues("alpha", t), this)
}, red: function (t) {
return this.setChannel("rgb", 0, t)
}, green: function (t) {
return this.setChannel("rgb", 1, t)
}, blue: function (t) {
return this.setChannel("rgb", 2, t)
}, hue: function (t) {
return t && (t = (t %= 360) < 0 ? 360 + t : t), this.setChannel("hsl", 0, t)
}, saturation: function (t) {
return this.setChannel("hsl", 1, t)
}, lightness: function (t) {
return this.setChannel("hsl", 2, t)
}, saturationv: function (t) {
return this.setChannel("hsv", 1, t)
}, whiteness: function (t) {
return this.setChannel("hwb", 1, t)
}, blackness: function (t) {
return this.setChannel("hwb", 2, t)
}, value: function (t) {
return this.setChannel("hsv", 2, t)
}, cyan: function (t) {
return this.setChannel("cmyk", 0, t)
}, magenta: function (t) {
return this.setChannel("cmyk", 1, t)
}, yellow: function (t) {
return this.setChannel("cmyk", 2, t)
}, black: function (t) {
return this.setChannel("cmyk", 3, t)
}, hexString: function () {
return a.hexString(this.values.rgb)
}, rgbString: function () {
return a.rgbString(this.values.rgb, this.values.alpha)
}, rgbaString: function () {
return a.rgbaString(this.values.rgb, this.values.alpha)
}, percentString: function () {
return a.percentString(this.values.rgb, this.values.alpha)
}, hslString: function () {
return a.hslString(this.values.hsl, this.values.alpha)
}, hslaString: function () {
return a.hslaString(this.values.hsl, this.values.alpha)
}, hwbString: function () {
return a.hwbString(this.values.hwb, this.values.alpha)
}, keyword: function () {
return a.keyword(this.values.rgb, this.values.alpha)
}, rgbNumber: function () {
var t = this.values.rgb;
return t[0] << 16 | t[1] << 8 | t[2]
}, luminosity: function () {
for (var t = this.values.rgb, e = [], i = 0; i < t.length; i++) {
var n = t[i] / 255;
e[i] = n <= .03928 ? n / 12.92 : Math.pow((n + .055) / 1.055, 2.4)
}
return .2126 * e[0] + .7152 * e[1] + .0722 * e[2]
}, contrast: function (t) {
var e = this.luminosity(), i = t.luminosity();
return e > i ? (e + .05) / (i + .05) : (i + .05) / (e + .05)
}, level: function (t) {
var e = this.contrast(t);
return e >= 7.1 ? "AAA" : e >= 4.5 ? "AA" : ""
}, dark: function () {
var t = this.values.rgb;
return (299 * t[0] + 587 * t[1] + 114 * t[2]) / 1e3 < 128
}, light: function () {
return !this.dark()
}, negate: function () {
for (var t = [], e = 0; e < 3; e++) t[e] = 255 - this.values.rgb[e];
return this.setValues("rgb", t), this
}, lighten: function (t) {
var e = this.values.hsl;
return e[2] += e[2] * t, this.setValues("hsl", e), this
}, darken: function (t) {
var e = this.values.hsl;
return e[2] -= e[2] * t, this.setValues("hsl", e), this
}, saturate: function (t) {
var e = this.values.hsl;
return e[1] += e[1] * t, this.setValues("hsl", e), this
}, desaturate: function (t) {
var e = this.values.hsl;
return e[1] -= e[1] * t, this.setValues("hsl", e), this
}, whiten: function (t) {
var e = this.values.hwb;
return e[1] += e[1] * t, this.setValues("hwb", e), this
}, blacken: function (t) {
var e = this.values.hwb;
return e[2] += e[2] * t, this.setValues("hwb", e), this
}, greyscale: function () {
var t = this.values.rgb, e = .3 * t[0] + .59 * t[1] + .11 * t[2];
return this.setValues("rgb", [e, e, e]), this
}, clearer: function (t) {
var e = this.values.alpha;
return this.setValues("alpha", e - e * t), this
}, opaquer: function (t) {
var e = this.values.alpha;
return this.setValues("alpha", e + e * t), this
}, rotate: function (t) {
var e = this.values.hsl, i = (e[0] + t) % 360;
return e[0] = i < 0 ? 360 + i : i, this.setValues("hsl", e), this
}, mix: function (t, e) {
var i = this, n = t, a = void 0 === e ? .5 : e, r = 2 * a - 1, o = i.alpha() - n.alpha(),
s = ((r * o == -1 ? r : (r + o) / (1 + r * o)) + 1) / 2, l = 1 - s;
return this.rgb(s * i.red() + l * n.red(), s * i.green() + l * n.green(), s * i.blue() + l * n.blue()).alpha(i.alpha() * a + n.alpha() * (1 - a))
}, toJSON: function () {
return this.rgb()
}, clone: function () {
var t, e, i = new r, n = this.values, a = i.values;
for (var o in n) n.hasOwnProperty(o) && (t = n[o], "[object Array]" === (e = {}.toString.call(t)) ? a[o] = t.slice(0) : "[object Number]" === e ? a[o] = t : console.error("unexpected color value:", t));
return i
}
}, r.prototype.spaces = {
rgb: ["red", "green", "blue"],
hsl: ["hue", "saturation", "lightness"],
hsv: ["hue", "saturation", "value"],
hwb: ["hue", "whiteness", "blackness"],
cmyk: ["cyan", "magenta", "yellow", "black"]
}, r.prototype.maxes = {
rgb: [255, 255, 255],
hsl: [360, 100, 100],
hsv: [360, 100, 100],
hwb: [360, 100, 100],
cmyk: [100, 100, 100, 100]
}, r.prototype.getValues = function (t) {
for (var e = this.values, i = {}, n = 0; n < t.length; n++) i[t.charAt(n)] = e[t][n];
return 1 !== e.alpha && (i.a = e.alpha), i
}, r.prototype.setValues = function (t, e) {
var i, a, r = this.values, o = this.spaces, s = this.maxes, l = 1;
if (this.valid = !0, "alpha" === t) l = e; else if (e.length) r[t] = e.slice(0, t.length), l = e[t.length]; else if (void 0 !== e[t.charAt(0)]) {
for (i = 0; i < t.length; i++) r[t][i] = e[t.charAt(i)];
l = e.a
} else if (void 0 !== e[o[t][0]]) {
var u = o[t];
for (i = 0; i < t.length; i++) r[t][i] = e[u[i]];
l = e.alpha
}
if (r.alpha = Math.max(0, Math.min(1, void 0 === l ? r.alpha : l)), "alpha" === t) return !1;
for (i = 0; i < t.length; i++) a = Math.max(0, Math.min(s[t][i], r[t][i])), r[t][i] = Math.round(a);
for (var d in o) d !== t && (r[d] = n[t][d](r[t]));
return !0
}, r.prototype.setSpace = function (t, e) {
var i = e[0];
return void 0 === i ? this.getValues(t) : ("number" == typeof i && (i = Array.prototype.slice.call(e)), this.setValues(t, i), this)
}, r.prototype.setChannel = function (t, e, i) {
var n = this.values[t];
return void 0 === i ? n[e] : i === n[e] ? this : (n[e] = i, this.setValues(t, n), this)
}, "undefined" != typeof window && (window.Color = r), e.exports = r
}, {1: 1, 4: 4}], 3: [function (t, e, i) {
function n(t) {
var e, i, n = t[0] / 255, a = t[1] / 255, r = t[2] / 255, o = Math.min(n, a, r), s = Math.max(n, a, r),
l = s - o;
return s == o ? e = 0 : n == s ? e = (a - r) / l : a == s ? e = 2 + (r - n) / l : r == s && (e = 4 + (n - a) / l), (e = Math.min(60 * e, 360)) < 0 && (e += 360), i = (o + s) / 2, [e, 100 * (s == o ? 0 : i <= .5 ? l / (s + o) : l / (2 - s - o)), 100 * i]
}
function a(t) {
var e, i, n = t[0], a = t[1], r = t[2], o = Math.min(n, a, r), s = Math.max(n, a, r), l = s - o;
return i = 0 == s ? 0 : l / s * 1e3 / 10, s == o ? e = 0 : n == s ? e = (a - r) / l : a == s ? e = 2 + (r - n) / l : r == s && (e = 4 + (n - a) / l), (e = Math.min(60 * e, 360)) < 0 && (e += 360), [e, i, s / 255 * 1e3 / 10]
}
function o(t) {
var e = t[0], i = t[1], a = t[2];
return [n(t)[0], 100 * (1 / 255 * Math.min(e, Math.min(i, a))), 100 * (a = 1 - 1 / 255 * Math.max(e, Math.max(i, a)))]
}
function s(t) {
var e, i = t[0] / 255, n = t[1] / 255, a = t[2] / 255;
return [100 * ((1 - i - (e = Math.min(1 - i, 1 - n, 1 - a))) / (1 - e) || 0), 100 * ((1 - n - e) / (1 - e) || 0), 100 * ((1 - a - e) / (1 - e) || 0), 100 * e]
}
function l(t) {
return S[JSON.stringify(t)]
}
function u(t) {
var e = t[0] / 255, i = t[1] / 255, n = t[2] / 255;
return [100 * (.4124 * (e = e > .04045 ? Math.pow((e + .055) / 1.055, 2.4) : e / 12.92) + .3576 * (i = i > .04045 ? Math.pow((i + .055) / 1.055, 2.4) : i / 12.92) + .1805 * (n = n > .04045 ? Math.pow((n + .055) / 1.055, 2.4) : n / 12.92)), 100 * (.2126 * e + .7152 * i + .0722 * n), 100 * (.0193 * e + .1192 * i + .9505 * n)]
}
function d(t) {
var e = u(t), i = e[0], n = e[1], a = e[2];
return n /= 100, a /= 108.883, i = (i /= 95.047) > .008856 ? Math.pow(i, 1 / 3) : 7.787 * i + 16 / 116, [116 * (n = n > .008856 ? Math.pow(n, 1 / 3) : 7.787 * n + 16 / 116) - 16, 500 * (i - n), 200 * (n - (a = a > .008856 ? Math.pow(a, 1 / 3) : 7.787 * a + 16 / 116))]
}
function h(t) {
var e, i, n, a, r, o = t[0] / 360, s = t[1] / 100, l = t[2] / 100;
if (0 == s) return [r = 255 * l, r, r];
e = 2 * l - (i = l < .5 ? l * (1 + s) : l + s - l * s), a = [0, 0, 0];
for (var u = 0; u < 3; u++) (n = o + 1 / 3 * -(u - 1)) < 0 && n++, n > 1 && n--, r = 6 * n < 1 ? e + 6 * (i - e) * n : 2 * n < 1 ? i : 3 * n < 2 ? e + (i - e) * (2 / 3 - n) * 6 : e, a[u] = 255 * r;
return a
}
function c(t) {
var e = t[0] / 60, i = t[1] / 100, n = t[2] / 100, a = Math.floor(e) % 6, r = e - Math.floor(e),
o = 255 * n * (1 - i), s = 255 * n * (1 - i * r), l = 255 * n * (1 - i * (1 - r));
n *= 255;
switch (a) {
case 0:
return [n, l, o];
case 1:
return [s, n, o];
case 2:
return [o, n, l];
case 3:
return [o, s, n];
case 4:
return [l, o, n];
case 5:
return [n, o, s]
}
}
function f(t) {
var e, i, n, a, o = t[0] / 360, s = t[1] / 100, l = t[2] / 100, u = s + l;
switch (u > 1 && (s /= u, l /= u), n = 6 * o - (e = Math.floor(6 * o)), 0 != (1 & e) && (n = 1 - n), a = s + n * ((i = 1 - l) - s), e) {
default:
case 6:
case 0:
r = i, g = a, b = s;
break;
case 1:
r = a, g = i, b = s;
break;
case 2:
r = s, g = i, b = a;
break;
case 3:
r = s, g = a, b = i;
break;
case 4:
r = a, g = s, b = i;
break;
case 5:
r = i, g = s, b = a
}
return [255 * r, 255 * g, 255 * b]
}
function m(t) {
var e = t[0] / 100, i = t[1] / 100, n = t[2] / 100, a = t[3] / 100;
return [255 * (1 - Math.min(1, e * (1 - a) + a)), 255 * (1 - Math.min(1, i * (1 - a) + a)), 255 * (1 - Math.min(1, n * (1 - a) + a))]
}
function p(t) {
var e, i, n, a = t[0] / 100, r = t[1] / 100, o = t[2] / 100;
return i = -.9689 * a + 1.8758 * r + .0415 * o, n = .0557 * a + -.204 * r + 1.057 * o, e = (e = 3.2406 * a + -1.5372 * r + -.4986 * o) > .0031308 ? 1.055 * Math.pow(e, 1 / 2.4) - .055 : e *= 12.92, i = i > .0031308 ? 1.055 * Math.pow(i, 1 / 2.4) - .055 : i *= 12.92, n = n > .0031308 ? 1.055 * Math.pow(n, 1 / 2.4) - .055 : n *= 12.92, [255 * (e = Math.min(Math.max(0, e), 1)), 255 * (i = Math.min(Math.max(0, i), 1)), 255 * (n = Math.min(Math.max(0, n), 1))]
}
function v(t) {
var e = t[0], i = t[1], n = t[2];
return i /= 100, n /= 108.883, e = (e /= 95.047) > .008856 ? Math.pow(e, 1 / 3) : 7.787 * e + 16 / 116, [116 * (i = i > .008856 ? Math.pow(i, 1 / 3) : 7.787 * i + 16 / 116) - 16, 500 * (e - i), 200 * (i - (n = n > .008856 ? Math.pow(n, 1 / 3) : 7.787 * n + 16 / 116))]
}
function y(t) {
var e, i, n, a, r = t[0], o = t[1], s = t[2];
return r <= 8 ? a = (i = 100 * r / 903.3) / 100 * 7.787 + 16 / 116 : (i = 100 * Math.pow((r + 16) / 116, 3), a = Math.pow(i / 100, 1 / 3)), [e = e / 95.047 <= .008856 ? e = 95.047 * (o / 500 + a - 16 / 116) / 7.787 : 95.047 * Math.pow(o / 500 + a, 3), i, n = n / 108.883 <= .008859 ? n = 108.883 * (a - s / 200 - 16 / 116) / 7.787 : 108.883 * Math.pow(a - s / 200, 3)]
}
function x(t) {
var e, i = t[0], n = t[1], a = t[2];
return (e = 360 * Math.atan2(a, n) / 2 / Math.PI) < 0 && (e += 360), [i, Math.sqrt(n * n + a * a), e]
}
function _(t) {
return p(y(t))
}
function k(t) {
var e, i = t[0], n = t[1];
return e = t[2] / 360 * 2 * Math.PI, [i, n * Math.cos(e), n * Math.sin(e)]
}
function w(t) {
return M[t]
}
e.exports = {
rgb2hsl: n,
rgb2hsv: a,
rgb2hwb: o,
rgb2cmyk: s,
rgb2keyword: l,
rgb2xyz: u,
rgb2lab: d,
rgb2lch: function (t) {
return x(d(t))
},
hsl2rgb: h,
hsl2hsv: function (t) {
var e = t[0], i = t[1] / 100, n = t[2] / 100;
if (0 === n) return [0, 0, 0];
return [e, 100 * (2 * (i *= (n *= 2) <= 1 ? n : 2 - n) / (n + i)), 100 * ((n + i) / 2)]
},
hsl2hwb: function (t) {
return o(h(t))
},
hsl2cmyk: function (t) {
return s(h(t))
},
hsl2keyword: function (t) {
return l(h(t))
},
hsv2rgb: c,
hsv2hsl: function (t) {
var e, i, n = t[0], a = t[1] / 100, r = t[2] / 100;
return e = a * r, [n, 100 * (e = (e /= (i = (2 - a) * r) <= 1 ? i : 2 - i) || 0), 100 * (i /= 2)]
},
hsv2hwb: function (t) {
return o(c(t))
},
hsv2cmyk: function (t) {
return s(c(t))
},
hsv2keyword: function (t) {
return l(c(t))
},
hwb2rgb: f,
hwb2hsl: function (t) {
return n(f(t))
},
hwb2hsv: function (t) {
return a(f(t))
},
hwb2cmyk: function (t) {
return s(f(t))
},
hwb2keyword: function (t) {
return l(f(t))
},
cmyk2rgb: m,
cmyk2hsl: function (t) {
return n(m(t))
},
cmyk2hsv: function (t) {
return a(m(t))
},
cmyk2hwb: function (t) {
return o(m(t))
},
cmyk2keyword: function (t) {
return l(m(t))
},
keyword2rgb: w,
keyword2hsl: function (t) {
return n(w(t))
},
keyword2hsv: function (t) {
return a(w(t))
},
keyword2hwb: function (t) {
return o(w(t))
},
keyword2cmyk: function (t) {
return s(w(t))
},
keyword2lab: function (t) {
return d(w(t))
},
keyword2xyz: function (t) {
return u(w(t))
},
xyz2rgb: p,
xyz2lab: v,
xyz2lch: function (t) {
return x(v(t))
},
lab2xyz: y,
lab2rgb: _,
lab2lch: x,
lch2lab: k,
lch2xyz: function (t) {
return y(k(t))
},
lch2rgb: function (t) {
return _(k(t))
}
};
var M = {
aliceblue: [240, 248, 255],
antiquewhite: [250, 235, 215],
aqua: [0, 255, 255],
aquamarine: [127, 255, 212],
azure: [240, 255, 255],
beige: [245, 245, 220],
bisque: [255, 228, 196],
black: [0, 0, 0],
blanchedalmond: [255, 235, 205],
blue: [0, 0, 255],
blueviolet: [138, 43, 226],
brown: [165, 42, 42],
burlywood: [222, 184, 135],
cadetblue: [95, 158, 160],
chartreuse: [127, 255, 0],
chocolate: [210, 105, 30],
coral: [255, 127, 80],
cornflowerblue: [100, 149, 237],
cornsilk: [255, 248, 220],
crimson: [220, 20, 60],
cyan: [0, 255, 255],
darkblue: [0, 0, 139],
darkcyan: [0, 139, 139],
darkgoldenrod: [184, 134, 11],
darkgray: [169, 169, 169],
darkgreen: [0, 100, 0],
darkgrey: [169, 169, 169],
darkkhaki: [189, 183, 107],
darkmagenta: [139, 0, 139],
darkolivegreen: [85, 107, 47],
darkorange: [255, 140, 0],
darkorchid: [153, 50, 204],
darkred: [139, 0, 0],
darksalmon: [233, 150, 122],
darkseagreen: [143, 188, 143],
darkslateblue: [72, 61, 139],
darkslategray: [47, 79, 79],
darkslategrey: [47, 79, 79],
darkturquoise: [0, 206, 209],
darkviolet: [148, 0, 211],
deeppink: [255, 20, 147],
deepskyblue: [0, 191, 255],
dimgray: [105, 105, 105],
dimgrey: [105, 105, 105],
dodgerblue: [30, 144, 255],
firebrick: [178, 34, 34],
floralwhite: [255, 250, 240],
forestgreen: [34, 139, 34],
fuchsia: [255, 0, 255],
gainsboro: [220, 220, 220],
ghostwhite: [248, 248, 255],
gold: [255, 215, 0],
goldenrod: [218, 165, 32],
gray: [128, 128, 128],
green: [0, 128, 0],
greenyellow: [173, 255, 47],
grey: [128, 128, 128],
honeydew: [240, 255, 240],
hotpink: [255, 105, 180],
indianred: [205, 92, 92],
indigo: [75, 0, 130],
ivory: [255, 255, 240],
khaki: [240, 230, 140],
lavender: [230, 230, 250],
lavenderblush: [255, 240, 245],
lawngreen: [124, 252, 0],
lemonchiffon: [255, 250, 205],
lightblue: [173, 216, 230],
lightcoral: [240, 128, 128],
lightcyan: [224, 255, 255],
lightgoldenrodyellow: [250, 250, 210],
lightgray: [211, 211, 211],
lightgreen: [144, 238, 144],
lightgrey: [211, 211, 211],
lightpink: [255, 182, 193],
lightsalmon: [255, 160, 122],
lightseagreen: [32, 178, 170],
lightskyblue: [135, 206, 250],
lightslategray: [119, 136, 153],
lightslategrey: [119, 136, 153],
lightsteelblue: [176, 196, 222],
lightyellow: [255, 255, 224],
lime: [0, 255, 0],
limegreen: [50, 205, 50],
linen: [250, 240, 230],
magenta: [255, 0, 255],
maroon: [128, 0, 0],
mediumaquamarine: [102, 205, 170],
mediumblue: [0, 0, 205],
mediumorchid: [186, 85, 211],
mediumpurple: [147, 112, 219],
mediumseagreen: [60, 179, 113],
mediumslateblue: [123, 104, 238],
mediumspringgreen: [0, 250, 154],
mediumturquoise: [72, 209, 204],
mediumvioletred: [199, 21, 133],
midnightblue: [25, 25, 112],
mintcream: [245, 255, 250],
mistyrose: [255, 228, 225],
moccasin: [255, 228, 181],
navajowhite: [255, 222, 173],
navy: [0, 0, 128],
oldlace: [253, 245, 230],
olive: [128, 128, 0],
olivedrab: [107, 142, 35],
orange: [255, 165, 0],
orangered: [255, 69, 0],
orchid: [218, 112, 214],
palegoldenrod: [238, 232, 170],
palegreen: [152, 251, 152],
paleturquoise: [175, 238, 238],
palevioletred: [219, 112, 147],
papayawhip: [255, 239, 213],
peachpuff: [255, 218, 185],
peru: [205, 133, 63],
pink: [255, 192, 203],
plum: [221, 160, 221],
powderblue: [176, 224, 230],
purple: [128, 0, 128],
rebeccapurple: [102, 51, 153],
red: [255, 0, 0],
rosybrown: [188, 143, 143],
royalblue: [65, 105, 225],
saddlebrown: [139, 69, 19],
salmon: [250, 128, 114],
sandybrown: [244, 164, 96],
seagreen: [46, 139, 87],
seashell: [255, 245, 238],
sienna: [160, 82, 45],
silver: [192, 192, 192],
skyblue: [135, 206, 235],
slateblue: [106, 90, 205],
slategray: [112, 128, 144],
slategrey: [112, 128, 144],
snow: [255, 250, 250],
springgreen: [0, 255, 127],
steelblue: [70, 130, 180],
tan: [210, 180, 140],
teal: [0, 128, 128],
thistle: [216, 191, 216],
tomato: [255, 99, 71],
turquoise: [64, 224, 208],
violet: [238, 130, 238],
wheat: [245, 222, 179],
white: [255, 255, 255],
whitesmoke: [245, 245, 245],
yellow: [255, 255, 0],
yellowgreen: [154, 205, 50]
}, S = {};
for (var D in M) S[JSON.stringify(M[D])] = D
}, {}], 4: [function (t, e, i) {
var n = t(3), a = function () {
return new u
};
for (var r in n) {
a[r + "Raw"] = function (t) {
return function (e) {
return "number" == typeof e && (e = Array.prototype.slice.call(arguments)), n[t](e)
}
}(r);
var o = /(\w+)2(\w+)/.exec(r), s = o[1], l = o[2];
(a[s] = a[s] || {})[l] = a[r] = function (t) {
return function (e) {
"number" == typeof e && (e = Array.prototype.slice.call(arguments));
var i = n[t](e);
if ("string" == typeof i || void 0 === i) return i;
for (var a = 0; a < i.length; a++) i[a] = Math.round(i[a]);
return i
}
}(r)
}
var u = function () {
this.convs = {}
};
u.prototype.routeSpace = function (t, e) {
var i = e[0];
return void 0 === i ? this.getValues(t) : ("number" == typeof i && (i = Array.prototype.slice.call(e)), this.setValues(t, i))
}, u.prototype.setValues = function (t, e) {
return this.space = t, this.convs = {}, this.convs[t] = e, this
}, u.prototype.getValues = function (t) {
var e = this.convs[t];
if (!e) {
var i = this.space, n = this.convs[i];
e = a[i][t](n), this.convs[t] = e
}
return e
}, ["rgb", "hsl", "hsv", "cmyk", "keyword"].forEach(function (t) {
u.prototype[t] = function (e) {
return this.routeSpace(t, arguments)
}
}), e.exports = a
}, {3: 3}], 5: [function (t, e, i) {
"use strict";
e.exports = {
aliceblue: [240, 248, 255],
antiquewhite: [250, 235, 215],
aqua: [0, 255, 255],
aquamarine: [127, 255, 212],
azure: [240, 255, 255],
beige: [245, 245, 220],
bisque: [255, 228, 196],
black: [0, 0, 0],
blanchedalmond: [255, 235, 205],
blue: [0, 0, 255],
blueviolet: [138, 43, 226],
brown: [165, 42, 42],
burlywood: [222, 184, 135],
cadetblue: [95, 158, 160],
chartreuse: [127, 255, 0],
chocolate: [210, 105, 30],
coral: [255, 127, 80],
cornflowerblue: [100, 149, 237],
cornsilk: [255, 248, 220],
crimson: [220, 20, 60],
cyan: [0, 255, 255],
darkblue: [0, 0, 139],
darkcyan: [0, 139, 139],
darkgoldenrod: [184, 134, 11],
darkgray: [169, 169, 169],
darkgreen: [0, 100, 0],
darkgrey: [169, 169, 169],
darkkhaki: [189, 183, 107],
darkmagenta: [139, 0, 139],
darkolivegreen: [85, 107, 47],
darkorange: [255, 140, 0],
darkorchid: [153, 50, 204],
darkred: [139, 0, 0],
darksalmon: [233, 150, 122],
darkseagreen: [143, 188, 143],
darkslateblue: [72, 61, 139],
darkslategray: [47, 79, 79],
darkslategrey: [47, 79, 79],
darkturquoise: [0, 206, 209],
darkviolet: [148, 0, 211],
deeppink: [255, 20, 147],
deepskyblue: [0, 191, 255],
dimgray: [105, 105, 105],
dimgrey: [105, 105, 105],
dodgerblue: [30, 144, 255],
firebrick: [178, 34, 34],
floralwhite: [255, 250, 240],
forestgreen: [34, 139, 34],
fuchsia: [255, 0, 255],
gainsboro: [220, 220, 220],
ghostwhite: [248, 248, 255],
gold: [255, 215, 0],
goldenrod: [218, 165, 32],
gray: [128, 128, 128],
green: [0, 128, 0],
greenyellow: [173, 255, 47],
grey: [128, 128, 128],
honeydew: [240, 255, 240],
hotpink: [255, 105, 180],
indianred: [205, 92, 92],
indigo: [75, 0, 130],
ivory: [255, 255, 240],
khaki: [240, 230, 140],
lavender: [230, 230, 250],
lavenderblush: [255, 240, 245],
lawngreen: [124, 252, 0],
lemonchiffon: [255, 250, 205],
lightblue: [173, 216, 230],
lightcoral: [240, 128, 128],
lightcyan: [224, 255, 255],
lightgoldenrodyellow: [250, 250, 210],
lightgray: [211, 211, 211],
lightgreen: [144, 238, 144],
lightgrey: [211, 211, 211],
lightpink: [255, 182, 193],
lightsalmon: [255, 160, 122],
lightseagreen: [32, 178, 170],
lightskyblue: [135, 206, 250],
lightslategray: [119, 136, 153],
lightslategrey: [119, 136, 153],
lightsteelblue: [176, 196, 222],
lightyellow: [255, 255, 224],
lime: [0, 255, 0],
limegreen: [50, 205, 50],
linen: [250, 240, 230],
magenta: [255, 0, 255],
maroon: [128, 0, 0],
mediumaquamarine: [102, 205, 170],
mediumblue: [0, 0, 205],
mediumorchid: [186, 85, 211],
mediumpurple: [147, 112, 219],
mediumseagreen: [60, 179, 113],
mediumslateblue: [123, 104, 238],
mediumspringgreen: [0, 250, 154],
mediumturquoise: [72, 209, 204],
mediumvioletred: [199, 21, 133],
midnightblue: [25, 25, 112],
mintcream: [245, 255, 250],
mistyrose: [255, 228, 225],
moccasin: [255, 228, 181],
navajowhite: [255, 222, 173],
navy: [0, 0, 128],
oldlace: [253, 245, 230],
olive: [128, 128, 0],
olivedrab: [107, 142, 35],
orange: [255, 165, 0],
orangered: [255, 69, 0],
orchid: [218, 112, 214],
palegoldenrod: [238, 232, 170],
palegreen: [152, 251, 152],
paleturquoise: [175, 238, 238],
palevioletred: [219, 112, 147],
papayawhip: [255, 239, 213],
peachpuff: [255, 218, 185],
peru: [205, 133, 63],
pink: [255, 192, 203],
plum: [221, 160, 221],
powderblue: [176, 224, 230],
purple: [128, 0, 128],
rebeccapurple: [102, 51, 153],
red: [255, 0, 0],
rosybrown: [188, 143, 143],
royalblue: [65, 105, 225],
saddlebrown: [139, 69, 19],
salmon: [250, 128, 114],
sandybrown: [244, 164, 96],
seagreen: [46, 139, 87],
seashell: [255, 245, 238],
sienna: [160, 82, 45],
silver: [192, 192, 192],
skyblue: [135, 206, 235],
slateblue: [106, 90, 205],
slategray: [112, 128, 144],
slategrey: [112, 128, 144],
snow: [255, 250, 250],
springgreen: [0, 255, 127],
steelblue: [70, 130, 180],
tan: [210, 180, 140],
teal: [0, 128, 128],
thistle: [216, 191, 216],
tomato: [255, 99, 71],
turquoise: [64, 224, 208],
violet: [238, 130, 238],
wheat: [245, 222, 179],
white: [255, 255, 255],
whitesmoke: [245, 245, 245],
yellow: [255, 255, 0],
yellowgreen: [154, 205, 50]
}
}, {}], 6: [function (t, e, i) {
var n, a;
n = this, a = function () {
"use strict";
var i, n;
function a() {
return i.apply(null, arguments)
}
function r(t) {
return t instanceof Array || "[object Array]" === Object.prototype.toString.call(t)
}
function o(t) {
return null != t && "[object Object]" === Object.prototype.toString.call(t)
}
function s(t) {
return void 0 === t
}
function l(t) {
return "number" == typeof t || "[object Number]" === Object.prototype.toString.call(t)
}
function u(t) {
return t instanceof Date || "[object Date]" === Object.prototype.toString.call(t)
}
function d(t, e) {
var i, n = [];
for (i = 0; i < t.length; ++i) n.push(e(t[i], i));
return n
}
function h(t, e) {
return Object.prototype.hasOwnProperty.call(t, e)
}
function c(t, e) {
for (var i in e) h(e, i) && (t[i] = e[i]);
return h(e, "toString") && (t.toString = e.toString), h(e, "valueOf") && (t.valueOf = e.valueOf), t
}
function f(t, e, i, n) {
return Pe(t, e, i, n, !0).utc()
}
function g(t) {
return null == t._pf && (t._pf = {
empty: !1,
unusedTokens: [],
unusedInput: [],
overflow: -2,
charsLeftOver: 0,
nullInput: !1,
invalidMonth: null,
invalidFormat: !1,
userInvalidated: !1,
iso: !1,
parsedDateParts: [],
meridiem: null,
rfc2822: !1,
weekdayMismatch: !1
}), t._pf
}
function m(t) {
if (null == t._isValid) {
var e = g(t), i = n.call(e.parsedDateParts, function (t) {
return null != t
}),
a = !isNaN(t._d.getTime()) && e.overflow < 0 && !e.empty && !e.invalidMonth && !e.invalidWeekday && !e.weekdayMismatch && !e.nullInput && !e.invalidFormat && !e.userInvalidated && (!e.meridiem || e.meridiem && i);
if (t._strict && (a = a && 0 === e.charsLeftOver && 0 === e.unusedTokens.length && void 0 === e.bigHour), null != Object.isFrozen && Object.isFrozen(t)) return a;
t._isValid = a
}
return t._isValid
}
function p(t) {
var e = f(NaN);
return null != t ? c(g(e), t) : g(e).userInvalidated = !0, e
}
n = Array.prototype.some ? Array.prototype.some : function (t) {
for (var e = Object(this), i = e.length >>> 0, n = 0; n < i; n++) if (n in e && t.call(this, e[n], n, e)) return !0;
return !1
};
var v = a.momentProperties = [];
function y(t, e) {
var i, n, a;
if (s(e._isAMomentObject) || (t._isAMomentObject = e._isAMomentObject), s(e._i) || (t._i = e._i), s(e._f) || (t._f = e._f), s(e._l) || (t._l = e._l), s(e._strict) || (t._strict = e._strict), s(e._tzm) || (t._tzm = e._tzm), s(e._isUTC) || (t._isUTC = e._isUTC), s(e._offset) || (t._offset = e._offset), s(e._pf) || (t._pf = g(e)), s(e._locale) || (t._locale = e._locale), v.length > 0) for (i = 0; i < v.length; i++) s(a = e[n = v[i]]) || (t[n] = a);
return t
}
var b = !1;
function x(t) {
y(this, t), this._d = new Date(null != t._d ? t._d.getTime() : NaN), this.isValid() || (this._d = new Date(NaN)), !1 === b && (b = !0, a.updateOffset(this), b = !1)
}
function _(t) {
return t instanceof x || null != t && null != t._isAMomentObject
}
function k(t) {
return t < 0 ? Math.ceil(t) || 0 : Math.floor(t)
}
function w(t) {
var e = +t, i = 0;
return 0 !== e && isFinite(e) && (i = k(e)), i
}
function M(t, e, i) {
var n, a = Math.min(t.length, e.length), r = Math.abs(t.length - e.length), o = 0;
for (n = 0; n < a; n++) (i && t[n] !== e[n] || !i && w(t[n]) !== w(e[n])) && o++;
return o + r
}
function S(t) {
!1 === a.suppressDeprecationWarnings && "undefined" != typeof console && console.warn && console.warn("Deprecation warning: " + t)
}
function D(t, e) {
var i = !0;
return c(function () {
if (null != a.deprecationHandler && a.deprecationHandler(null, t), i) {
for (var n, r = [], o = 0; o < arguments.length; o++) {
if (n = "", "object" == typeof arguments[o]) {
for (var s in n += "\n[" + o + "] ", arguments[0]) n += s + ": " + arguments[0][s] + ", ";
n = n.slice(0, -2)
} else n = arguments[o];
r.push(n)
}
S(t + "\nArguments: " + Array.prototype.slice.call(r).join("") + "\n" + (new Error).stack), i = !1
}
return e.apply(this, arguments)
}, e)
}
var C, P = {};
function T(t, e) {
null != a.deprecationHandler && a.deprecationHandler(t, e), P[t] || (S(e), P[t] = !0)
}
function O(t) {
return t instanceof Function || "[object Function]" === Object.prototype.toString.call(t)
}
function I(t, e) {
var i, n = c({}, t);
for (i in e) h(e, i) && (o(t[i]) && o(e[i]) ? (n[i] = {}, c(n[i], t[i]), c(n[i], e[i])) : null != e[i] ? n[i] = e[i] : delete n[i]);
for (i in t) h(t, i) && !h(e, i) && o(t[i]) && (n[i] = c({}, n[i]));
return n
}
function A(t) {
null != t && this.set(t)
}
a.suppressDeprecationWarnings = !1, a.deprecationHandler = null, C = Object.keys ? Object.keys : function (t) {
var e, i = [];
for (e in t) h(t, e) && i.push(e);
return i
};
var F = {};
function R(t, e) {
var i = t.toLowerCase();
F[i] = F[i + "s"] = F[e] = t
}
function L(t) {
return "string" == typeof t ? F[t] || F[t.toLowerCase()] : void 0
}
function W(t) {
var e, i, n = {};
for (i in t) h(t, i) && (e = L(i)) && (n[e] = t[i]);
return n
}
var Y = {};
function N(t, e) {
Y[t] = e
}
function z(t, e, i) {
var n = "" + Math.abs(t), a = e - n.length;
return (t >= 0 ? i ? "+" : "" : "-") + Math.pow(10, Math.max(0, a)).toString().substr(1) + n
}
var H = /(\[[^\[]*\])|(\\)?([Hh]mm(ss)?|Mo|MM?M?M?|Do|DDDo|DD?D?D?|ddd?d?|do?|w[o|w]?|W[o|W]?|Qo?|YYYYYY|YYYYY|YYYY|YY|gg(ggg?)?|GG(GGG?)?|e|E|a|A|hh?|HH?|kk?|mm?|ss?|S{1,9}|x|X|zz?|ZZ?|.)/g,
V = /(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g, B = {}, E = {};
function j(t, e, i, n) {
var a = n;
"string" == typeof n && (a = function () {
return this[n]()
}), t && (E[t] = a), e && (E[e[0]] = function () {
return z(a.apply(this, arguments), e[1], e[2])
}), i && (E[i] = function () {
return this.localeData().ordinal(a.apply(this, arguments), t)
})
}
function U(t, e) {
return t.isValid() ? (e = q(e, t.localeData()), B[e] = B[e] || function (t) {
var e, i, n, a = t.match(H);
for (e = 0, i = a.length; e < i; e++) E[a[e]] ? a[e] = E[a[e]] : a[e] = (n = a[e]).match(/\[[\s\S]/) ? n.replace(/^\[|\]$/g, "") : n.replace(/\\/g, "");
return function (e) {
var n, r = "";
for (n = 0; n < i; n++) r += O(a[n]) ? a[n].call(e, t) : a[n];
return r
}
}(e), B[e](t)) : t.localeData().invalidDate()
}
function q(t, e) {
var i = 5;
function n(t) {
return e.longDateFormat(t) || t
}
for (V.lastIndex = 0; i >= 0 && V.test(t);) t = t.replace(V, n), V.lastIndex = 0, i -= 1;
return t
}
var G = /\d/, Z = /\d\d/, X = /\d{3}/, J = /\d{4}/, K = /[+-]?\d{6}/, $ = /\d\d?/, Q = /\d\d\d\d?/,
tt = /\d\d\d\d\d\d?/, et = /\d{1,3}/, it = /\d{1,4}/, nt = /[+-]?\d{1,6}/, at = /\d+/,
rt = /[+-]?\d+/, ot = /Z|[+-]\d\d:?\d\d/gi, st = /Z|[+-]\d\d(?::?\d\d)?/gi,
lt = /[0-9]{0,256}['a-z\u00A0-\u05FF\u0700-\uD7FF\uF900-\uFDCF\uFDF0-\uFF07\uFF10-\uFFEF]{1,256}|[\u0600-\u06FF\/]{1,256}(\s*?[\u0600-\u06FF]{1,256}){1,2}/i,
ut = {};
function dt(t, e, i) {
ut[t] = O(e) ? e : function (t, n) {
return t && i ? i : e
}
}
function ht(t, e) {
return h(ut, t) ? ut[t](e._strict, e._locale) : new RegExp(ct(t.replace("\\", "").replace(/\\(\[)|\\(\])|\[([^\]\[]*)\]|\\(.)/g, function (t, e, i, n, a) {
return e || i || n || a
})))
}
function ct(t) {
return t.replace(/[-\/\\^$*+?.()|[\]{}]/g, "\\$&")
}
var ft = {};
function gt(t, e) {
var i, n = e;
for ("string" == typeof t && (t = [t]), l(e) && (n = function (t, i) {
i[e] = w(t)
}), i = 0; i < t.length; i++) ft[t[i]] = n
}
function mt(t, e) {
gt(t, function (t, i, n, a) {
n._w = n._w || {}, e(t, n._w, n, a)
})
}
var pt = 0, vt = 1, yt = 2, bt = 3, xt = 4, _t = 5, kt = 6, wt = 7, Mt = 8;
function St(t) {
return Dt(t) ? 366 : 365
}
function Dt(t) {
return t % 4 == 0 && t % 100 != 0 || t % 400 == 0
}
j("Y", 0, 0, function () {
var t = this.year();
return t <= 9999 ? "" + t : "+" + t
}), j(0, ["YY", 2], 0, function () {
return this.year() % 100
}), j(0, ["YYYY", 4], 0, "year"), j(0, ["YYYYY", 5], 0, "year"), j(0, ["YYYYYY", 6, !0], 0, "year"), R("year", "y"), N("year", 1), dt("Y", rt), dt("YY", $, Z), dt("YYYY", it, J), dt("YYYYY", nt, K), dt("YYYYYY", nt, K), gt(["YYYYY", "YYYYYY"], pt), gt("YYYY", function (t, e) {
e[pt] = 2 === t.length ? a.parseTwoDigitYear(t) : w(t)
}), gt("YY", function (t, e) {
e[pt] = a.parseTwoDigitYear(t)
}), gt("Y", function (t, e) {
e[pt] = parseInt(t, 10)
}), a.parseTwoDigitYear = function (t) {
return w(t) + (w(t) > 68 ? 1900 : 2e3)
};
var Ct, Pt = Tt("FullYear", !0);
function Tt(t, e) {
return function (i) {
return null != i ? (It(this, t, i), a.updateOffset(this, e), this) : Ot(this, t)
}
}
function Ot(t, e) {
return t.isValid() ? t._d["get" + (t._isUTC ? "UTC" : "") + e]() : NaN
}
function It(t, e, i) {
t.isValid() && !isNaN(i) && ("FullYear" === e && Dt(t.year()) && 1 === t.month() && 29 === t.date() ? t._d["set" + (t._isUTC ? "UTC" : "") + e](i, t.month(), At(i, t.month())) : t._d["set" + (t._isUTC ? "UTC" : "") + e](i))
}
function At(t, e) {
if (isNaN(t) || isNaN(e)) return NaN;
var i, n = (e % (i = 12) + i) % i;
return t += (e - n) / 12, 1 === n ? Dt(t) ? 29 : 28 : 31 - n % 7 % 2
}
Ct = Array.prototype.indexOf ? Array.prototype.indexOf : function (t) {
var e;
for (e = 0; e < this.length; ++e) if (this[e] === t) return e;
return -1
}, j("M", ["MM", 2], "Mo", function () {
return this.month() + 1
}), j("MMM", 0, 0, function (t) {
return this.localeData().monthsShort(this, t)
}), j("MMMM", 0, 0, function (t) {
return this.localeData().months(this, t)
}), R("month", "M"), N("month", 8), dt("M", $), dt("MM", $, Z), dt("MMM", function (t, e) {
return e.monthsShortRegex(t)
}), dt("MMMM", function (t, e) {
return e.monthsRegex(t)
}), gt(["M", "MM"], function (t, e) {
e[vt] = w(t) - 1
}), gt(["MMM", "MMMM"], function (t, e, i, n) {
var a = i._locale.monthsParse(t, n, i._strict);
null != a ? e[vt] = a : g(i).invalidMonth = t
});
var Ft = /D[oD]?(\[[^\[\]]*\]|\s)+MMMM?/,
Rt = "January_February_March_April_May_June_July_August_September_October_November_December".split("_");
var Lt = "Jan_Feb_Mar_Apr_May_Jun_Jul_Aug_Sep_Oct_Nov_Dec".split("_");
function Wt(t, e) {
var i;
if (!t.isValid()) return t;
if ("string" == typeof e) if (/^\d+$/.test(e)) e = w(e); else if (!l(e = t.localeData().monthsParse(e))) return t;
return i = Math.min(t.date(), At(t.year(), e)), t._d["set" + (t._isUTC ? "UTC" : "") + "Month"](e, i), t
}
function Yt(t) {
return null != t ? (Wt(this, t), a.updateOffset(this, !0), this) : Ot(this, "Month")
}
var Nt = lt;
var zt = lt;
function Ht() {
function t(t, e) {
return e.length - t.length
}
var e, i, n = [], a = [], r = [];
for (e = 0; e < 12; e++) i = f([2e3, e]), n.push(this.monthsShort(i, "")), a.push(this.months(i, "")), r.push(this.months(i, "")), r.push(this.monthsShort(i, ""));
for (n.sort(t), a.sort(t), r.sort(t), e = 0; e < 12; e++) n[e] = ct(n[e]), a[e] = ct(a[e]);
for (e = 0; e < 24; e++) r[e] = ct(r[e]);
this._monthsRegex = new RegExp("^(" + r.join("|") + ")", "i"), this._monthsShortRegex = this._monthsRegex, this._monthsStrictRegex = new RegExp("^(" + a.join("|") + ")", "i"), this._monthsShortStrictRegex = new RegExp("^(" + n.join("|") + ")", "i")
}
function Vt(t) {
var e = new Date(Date.UTC.apply(null, arguments));
return t < 100 && t >= 0 && isFinite(e.getUTCFullYear()) && e.setUTCFullYear(t), e
}
function Bt(t, e, i) {
var n = 7 + e - i;
return -((7 + Vt(t, 0, n).getUTCDay() - e) % 7) + n - 1
}
function Et(t, e, i, n, a) {
var r, o, s = 1 + 7 * (e - 1) + (7 + i - n) % 7 + Bt(t, n, a);
return s <= 0 ? o = St(r = t - 1) + s : s > St(t) ? (r = t + 1, o = s - St(t)) : (r = t, o = s), {
year: r,
dayOfYear: o
}
}
function jt(t, e, i) {
var n, a, r = Bt(t.year(), e, i), o = Math.floor((t.dayOfYear() - r - 1) / 7) + 1;
return o < 1 ? n = o + Ut(a = t.year() - 1, e, i) : o > Ut(t.year(), e, i) ? (n = o - Ut(t.year(), e, i), a = t.year() + 1) : (a = t.year(), n = o), {
week: n,
year: a
}
}
function Ut(t, e, i) {
var n = Bt(t, e, i), a = Bt(t + 1, e, i);
return (St(t) - n + a) / 7
}
j("w", ["ww", 2], "wo", "week"), j("W", ["WW", 2], "Wo", "isoWeek"), R("week", "w"), R("isoWeek", "W"), N("week", 5), N("isoWeek", 5), dt("w", $), dt("ww", $, Z), dt("W", $), dt("WW", $, Z), mt(["w", "ww", "W", "WW"], function (t, e, i, n) {
e[n.substr(0, 1)] = w(t)
});
j("d", 0, "do", "day"), j("dd", 0, 0, function (t) {
return this.localeData().weekdaysMin(this, t)
}), j("ddd", 0, 0, function (t) {
return this.localeData().weekdaysShort(this, t)
}), j("dddd", 0, 0, function (t) {
return this.localeData().weekdays(this, t)
}), j("e", 0, 0, "weekday"), j("E", 0, 0, "isoWeekday"), R("day", "d"), R("weekday", "e"), R("isoWeekday", "E"), N("day", 11), N("weekday", 11), N("isoWeekday", 11), dt("d", $), dt("e", $), dt("E", $), dt("dd", function (t, e) {
return e.weekdaysMinRegex(t)
}), dt("ddd", function (t, e) {
return e.weekdaysShortRegex(t)
}), dt("dddd", function (t, e) {
return e.weekdaysRegex(t)
}), mt(["dd", "ddd", "dddd"], function (t, e, i, n) {
var a = i._locale.weekdaysParse(t, n, i._strict);
null != a ? e.d = a : g(i).invalidWeekday = t
}), mt(["d", "e", "E"], function (t, e, i, n) {
e[n] = w(t)
});
var qt = "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_");
var Gt = "Sun_Mon_Tue_Wed_Thu_Fri_Sat".split("_");
var Zt = "Su_Mo_Tu_We_Th_Fr_Sa".split("_");
var Xt = lt;
var Jt = lt;
var Kt = lt;
function $t() {
function t(t, e) {
return e.length - t.length
}
var e, i, n, a, r, o = [], s = [], l = [], u = [];
for (e = 0; e < 7; e++) i = f([2e3, 1]).day(e), n = this.weekdaysMin(i, ""), a = this.weekdaysShort(i, ""), r = this.weekdays(i, ""), o.push(n), s.push(a), l.push(r), u.push(n), u.push(a), u.push(r);
for (o.sort(t), s.sort(t), l.sort(t), u.sort(t), e = 0; e < 7; e++) s[e] = ct(s[e]), l[e] = ct(l[e]), u[e] = ct(u[e]);
this._weekdaysRegex = new RegExp("^(" + u.join("|") + ")", "i"), this._weekdaysShortRegex = this._weekdaysRegex, this._weekdaysMinRegex = this._weekdaysRegex, this._weekdaysStrictRegex = new RegExp("^(" + l.join("|") + ")", "i"), this._weekdaysShortStrictRegex = new RegExp("^(" + s.join("|") + ")", "i"), this._weekdaysMinStrictRegex = new RegExp("^(" + o.join("|") + ")", "i")
}
function Qt() {
return this.hours() % 12 || 12
}
function te(t, e) {
j(t, 0, 0, function () {
return this.localeData().meridiem(this.hours(), this.minutes(), e)
})
}
function ee(t, e) {
return e._meridiemParse
}
j("H", ["HH", 2], 0, "hour"), j("h", ["hh", 2], 0, Qt), j("k", ["kk", 2], 0, function () {
return this.hours() || 24
}), j("hmm", 0, 0, function () {
return "" + Qt.apply(this) + z(this.minutes(), 2)
}), j("hmmss", 0, 0, function () {
return "" + Qt.apply(this) + z(this.minutes(), 2) + z(this.seconds(), 2)
}), j("Hmm", 0, 0, function () {
return "" + this.hours() + z(this.minutes(), 2)
}), j("Hmmss", 0, 0, function () {
return "" + this.hours() + z(this.minutes(), 2) + z(this.seconds(), 2)
}), te("a", !0), te("A", !1), R("hour", "h"), N("hour", 13), dt("a", ee), dt("A", ee), dt("H", $), dt("h", $), dt("k", $), dt("HH", $, Z), dt("hh", $, Z), dt("kk", $, Z), dt("hmm", Q), dt("hmmss", tt), dt("Hmm", Q), dt("Hmmss", tt), gt(["H", "HH"], bt), gt(["k", "kk"], function (t, e, i) {
var n = w(t);
e[bt] = 24 === n ? 0 : n
}), gt(["a", "A"], function (t, e, i) {
i._isPm = i._locale.isPM(t), i._meridiem = t
}), gt(["h", "hh"], function (t, e, i) {
e[bt] = w(t), g(i).bigHour = !0
}), gt("hmm", function (t, e, i) {
var n = t.length - 2;
e[bt] = w(t.substr(0, n)), e[xt] = w(t.substr(n)), g(i).bigHour = !0
}), gt("hmmss", function (t, e, i) {
var n = t.length - 4, a = t.length - 2;
e[bt] = w(t.substr(0, n)), e[xt] = w(t.substr(n, 2)), e[_t] = w(t.substr(a)), g(i).bigHour = !0
}), gt("Hmm", function (t, e, i) {
var n = t.length - 2;
e[bt] = w(t.substr(0, n)), e[xt] = w(t.substr(n))
}), gt("Hmmss", function (t, e, i) {
var n = t.length - 4, a = t.length - 2;
e[bt] = w(t.substr(0, n)), e[xt] = w(t.substr(n, 2)), e[_t] = w(t.substr(a))
});
var ie, ne = Tt("Hours", !0), ae = {
calendar: {
sameDay: "[Today at] LT",
nextDay: "[Tomorrow at] LT",
nextWeek: "dddd [at] LT",
lastDay: "[Yesterday at] LT",
lastWeek: "[Last] dddd [at] LT",
sameElse: "L"
},
longDateFormat: {
LTS: "h:mm:ss A",
LT: "h:mm A",
L: "MM/DD/YYYY",
LL: "MMMM D, YYYY",
LLL: "MMMM D, YYYY h:mm A",
LLLL: "dddd, MMMM D, YYYY h:mm A"
},
invalidDate: "Invalid date",
ordinal: "%d",
dayOfMonthOrdinalParse: /\d{1,2}/,
relativeTime: {
future: "in %s",
past: "%s ago",
s: "a few seconds",
ss: "%d seconds",
m: "a minute",
mm: "%d minutes",
h: "an hour",
hh: "%d hours",
d: "a day",
dd: "%d days",
M: "a month",
MM: "%d months",
y: "a year",
yy: "%d years"
},
months: Rt,
monthsShort: Lt,
week: {dow: 0, doy: 6},
weekdays: qt,
weekdaysMin: Zt,
weekdaysShort: Gt,
meridiemParse: /[ap]\.?m?\.?/i
}, re = {}, oe = {};
function se(t) {
return t ? t.toLowerCase().replace("_", "-") : t
}
function le(i) {
var n = null;
if (!re[i] && void 0 !== e && e && e.exports) try {
n = ie._abbr, t("./locale/" + i), ue(n)
} catch (t) {
}
return re[i]
}
function ue(t, e) {
var i;
return t && (i = s(e) ? he(t) : de(t, e)) && (ie = i), ie._abbr
}
function de(t, e) {
if (null !== e) {
var i = ae;
if (e.abbr = t, null != re[t]) T("defineLocaleOverride", "use moment.updateLocale(localeName, config) to change an existing locale. moment.defineLocale(localeName, config) should only be used for creating a new locale See http://momentjs.com/guides/#/warnings/define-locale/ for more info."), i = re[t]._config; else if (null != e.parentLocale) {
if (null == re[e.parentLocale]) return oe[e.parentLocale] || (oe[e.parentLocale] = []), oe[e.parentLocale].push({
name: t,
config: e
}), null;
i = re[e.parentLocale]._config
}
return re[t] = new A(I(i, e)), oe[t] && oe[t].forEach(function (t) {
de(t.name, t.config)
}), ue(t), re[t]
}
return delete re[t], null
}
function he(t) {
var e;
if (t && t._locale && t._locale._abbr && (t = t._locale._abbr), !t) return ie;
if (!r(t)) {
if (e = le(t)) return e;
t = [t]
}
return function (t) {
for (var e, i, n, a, r = 0; r < t.length;) {
for (e = (a = se(t[r]).split("-")).length, i = (i = se(t[r + 1])) ? i.split("-") : null; e > 0;) {
if (n = le(a.slice(0, e).join("-"))) return n;
if (i && i.length >= e && M(a, i, !0) >= e - 1) break;
e--
}
r++
}
return null
}(t)
}
function ce(t) {
var e, i = t._a;
return i && -2 === g(t).overflow && (e = i[vt] < 0 || i[vt] > 11 ? vt : i[yt] < 1 || i[yt] > At(i[pt], i[vt]) ? yt : i[bt] < 0 || i[bt] > 24 || 24 === i[bt] && (0 !== i[xt] || 0 !== i[_t] || 0 !== i[kt]) ? bt : i[xt] < 0 || i[xt] > 59 ? xt : i[_t] < 0 || i[_t] > 59 ? _t : i[kt] < 0 || i[kt] > 999 ? kt : -1, g(t)._overflowDayOfYear && (e < pt || e > yt) && (e = yt), g(t)._overflowWeeks && -1 === e && (e = wt), g(t)._overflowWeekday && -1 === e && (e = Mt), g(t).overflow = e), t
}
function fe(t, e, i) {
return null != t ? t : null != e ? e : i
}
function ge(t) {
var e, i, n, r, o, s = [];
if (!t._d) {
var l, u;
for (l = t, u = new Date(a.now()), n = l._useUTC ? [u.getUTCFullYear(), u.getUTCMonth(), u.getUTCDate()] : [u.getFullYear(), u.getMonth(), u.getDate()], t._w && null == t._a[yt] && null == t._a[vt] && function (t) {
var e, i, n, a, r, o, s, l;
if (null != (e = t._w).GG || null != e.W || null != e.E) r = 1, o = 4, i = fe(e.GG, t._a[pt], jt(Te(), 1, 4).year), n = fe(e.W, 1), ((a = fe(e.E, 1)) < 1 || a > 7) && (l = !0); else {
r = t._locale._week.dow, o = t._locale._week.doy;
var u = jt(Te(), r, o);
i = fe(e.gg, t._a[pt], u.year), n = fe(e.w, u.week), null != e.d ? ((a = e.d) < 0 || a > 6) && (l = !0) : null != e.e ? (a = e.e + r, (e.e < 0 || e.e > 6) && (l = !0)) : a = r
}
n < 1 || n > Ut(i, r, o) ? g(t)._overflowWeeks = !0 : null != l ? g(t)._overflowWeekday = !0 : (s = Et(i, n, a, r, o), t._a[pt] = s.year, t._dayOfYear = s.dayOfYear)
}(t), null != t._dayOfYear && (o = fe(t._a[pt], n[pt]), (t._dayOfYear > St(o) || 0 === t._dayOfYear) && (g(t)._overflowDayOfYear = !0), i = Vt(o, 0, t._dayOfYear), t._a[vt] = i.getUTCMonth(), t._a[yt] = i.getUTCDate()), e = 0; e < 3 && null == t._a[e]; ++e) t._a[e] = s[e] = n[e];
for (; e < 7; e++) t._a[e] = s[e] = null == t._a[e] ? 2 === e ? 1 : 0 : t._a[e];
24 === t._a[bt] && 0 === t._a[xt] && 0 === t._a[_t] && 0 === t._a[kt] && (t._nextDay = !0, t._a[bt] = 0), t._d = (t._useUTC ? Vt : function (t, e, i, n, a, r, o) {
var s = new Date(t, e, i, n, a, r, o);
return t < 100 && t >= 0 && isFinite(s.getFullYear()) && s.setFullYear(t), s
}).apply(null, s), r = t._useUTC ? t._d.getUTCDay() : t._d.getDay(), null != t._tzm && t._d.setUTCMinutes(t._d.getUTCMinutes() - t._tzm), t._nextDay && (t._a[bt] = 24), t._w && void 0 !== t._w.d && t._w.d !== r && (g(t).weekdayMismatch = !0)
}
}
var me = /^\s*((?:[+-]\d{6}|\d{4})-(?:\d\d-\d\d|W\d\d-\d|W\d\d|\d\d\d|\d\d))(?:(T| )(\d\d(?::\d\d(?::\d\d(?:[.,]\d+)?)?)?)([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?$/,
pe = /^\s*((?:[+-]\d{6}|\d{4})(?:\d\d\d\d|W\d\d\d|W\d\d|\d\d\d|\d\d))(?:(T| )(\d\d(?:\d\d(?:\d\d(?:[.,]\d+)?)?)?)([\+\-]\d\d(?::?\d\d)?|\s*Z)?)?$/,
ve = /Z|[+-]\d\d(?::?\d\d)?/,
ye = [["YYYYYY-MM-DD", /[+-]\d{6}-\d\d-\d\d/], ["YYYY-MM-DD", /\d{4}-\d\d-\d\d/], ["GGGG-[W]WW-E", /\d{4}-W\d\d-\d/], ["GGGG-[W]WW", /\d{4}-W\d\d/, !1], ["YYYY-DDD", /\d{4}-\d{3}/], ["YYYY-MM", /\d{4}-\d\d/, !1], ["YYYYYYMMDD", /[+-]\d{10}/], ["YYYYMMDD", /\d{8}/], ["GGGG[W]WWE", /\d{4}W\d{3}/], ["GGGG[W]WW", /\d{4}W\d{2}/, !1], ["YYYYDDD", /\d{7}/]],
be = [["HH:mm:ss.SSSS", /\d\d:\d\d:\d\d\.\d+/], ["HH:mm:ss,SSSS", /\d\d:\d\d:\d\d,\d+/], ["HH:mm:ss", /\d\d:\d\d:\d\d/], ["HH:mm", /\d\d:\d\d/], ["HHmmss.SSSS", /\d\d\d\d\d\d\.\d+/], ["HHmmss,SSSS", /\d\d\d\d\d\d,\d+/], ["HHmmss", /\d\d\d\d\d\d/], ["HHmm", /\d\d\d\d/], ["HH", /\d\d/]],
xe = /^\/?Date\((\-?\d+)/i;
function _e(t) {
var e, i, n, a, r, o, s = t._i, l = me.exec(s) || pe.exec(s);
if (l) {
for (g(t).iso = !0, e = 0, i = ye.length; e < i; e++) if (ye[e][1].exec(l[1])) {
a = ye[e][0], n = !1 !== ye[e][2];
break
}
if (null == a) return void(t._isValid = !1);
if (l[3]) {
for (e = 0, i = be.length; e < i; e++) if (be[e][1].exec(l[3])) {
r = (l[2] || " ") + be[e][0];
break
}
if (null == r) return void(t._isValid = !1)
}
if (!n && null != r) return void(t._isValid = !1);
if (l[4]) {
if (!ve.exec(l[4])) return void(t._isValid = !1);
o = "Z"
}
t._f = a + (r || "") + (o || ""), De(t)
} else t._isValid = !1
}
var ke = /^(?:(Mon|Tue|Wed|Thu|Fri|Sat|Sun),?\s)?(\d{1,2})\s(Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec)\s(\d{2,4})\s(\d\d):(\d\d)(?::(\d\d))?\s(?:(UT|GMT|[ECMP][SD]T)|([Zz])|([+-]\d{4}))$/;
function we(t, e, i, n, a, r) {
var o = [function (t) {
var e = parseInt(t, 10);
{
if (e <= 49) return 2e3 + e;
if (e <= 999) return 1900 + e
}
return e
}(t), Lt.indexOf(e), parseInt(i, 10), parseInt(n, 10), parseInt(a, 10)];
return r && o.push(parseInt(r, 10)), o
}
var Me = {
UT: 0,
GMT: 0,
EDT: -240,
EST: -300,
CDT: -300,
CST: -360,
MDT: -360,
MST: -420,
PDT: -420,
PST: -480
};
function Se(t) {
var e, i, n, a = ke.exec(t._i.replace(/\([^)]*\)|[\n\t]/g, " ").replace(/(\s\s+)/g, " ").trim());
if (a) {
var r = we(a[4], a[3], a[2], a[5], a[6], a[7]);
if (e = a[1], i = r, n = t, e && Gt.indexOf(e) !== new Date(i[0], i[1], i[2]).getDay() && (g(n).weekdayMismatch = !0, n._isValid = !1, 1)) return;
t._a = r, t._tzm = function (t, e, i) {
if (t) return Me[t];
if (e) return 0;
var n = parseInt(i, 10), a = n % 100;
return (n - a) / 100 * 60 + a
}(a[8], a[9], a[10]), t._d = Vt.apply(null, t._a), t._d.setUTCMinutes(t._d.getUTCMinutes() - t._tzm), g(t).rfc2822 = !0
} else t._isValid = !1
}
function De(t) {
if (t._f !== a.ISO_8601) if (t._f !== a.RFC_2822) {
t._a = [], g(t).empty = !0;
var e, i, n, r, o, s, l, u, d = "" + t._i, c = d.length, f = 0;
for (n = q(t._f, t._locale).match(H) || [], e = 0; e < n.length; e++) r = n[e], (i = (d.match(ht(r, t)) || [])[0]) && ((o = d.substr(0, d.indexOf(i))).length > 0 && g(t).unusedInput.push(o), d = d.slice(d.indexOf(i) + i.length), f += i.length), E[r] ? (i ? g(t).empty = !1 : g(t).unusedTokens.push(r), s = r, u = t, null != (l = i) && h(ft, s) && ft[s](l, u._a, u, s)) : t._strict && !i && g(t).unusedTokens.push(r);
g(t).charsLeftOver = c - f, d.length > 0 && g(t).unusedInput.push(d), t._a[bt] <= 12 && !0 === g(t).bigHour && t._a[bt] > 0 && (g(t).bigHour = void 0), g(t).parsedDateParts = t._a.slice(0), g(t).meridiem = t._meridiem, t._a[bt] = function (t, e, i) {
var n;
if (null == i) return e;
return null != t.meridiemHour ? t.meridiemHour(e, i) : null != t.isPM ? ((n = t.isPM(i)) && e < 12 && (e += 12), n || 12 !== e || (e = 0), e) : e
}(t._locale, t._a[bt], t._meridiem), ge(t), ce(t)
} else Se(t); else _e(t)
}
function Ce(t) {
var e, i, n, h, f = t._i, v = t._f;
return t._locale = t._locale || he(t._l), null === f || void 0 === v && "" === f ? p({nullInput: !0}) : ("string" == typeof f && (t._i = f = t._locale.preparse(f)), _(f) ? new x(ce(f)) : (u(f) ? t._d = f : r(v) ? function (t) {
var e, i, n, a, r;
if (0 === t._f.length) return g(t).invalidFormat = !0, void(t._d = new Date(NaN));
for (a = 0; a < t._f.length; a++) r = 0, e = y({}, t), null != t._useUTC && (e._useUTC = t._useUTC), e._f = t._f[a], De(e), m(e) && (r += g(e).charsLeftOver, r += 10 * g(e).unusedTokens.length, g(e).score = r, (null == n || r < n) && (n = r, i = e));
c(t, i || e)
}(t) : v ? De(t) : s(i = (e = t)._i) ? e._d = new Date(a.now()) : u(i) ? e._d = new Date(i.valueOf()) : "string" == typeof i ? (n = e, null === (h = xe.exec(n._i)) ? (_e(n), !1 === n._isValid && (delete n._isValid, Se(n), !1 === n._isValid && (delete n._isValid, a.createFromInputFallback(n)))) : n._d = new Date(+h[1])) : r(i) ? (e._a = d(i.slice(0), function (t) {
return parseInt(t, 10)
}), ge(e)) : o(i) ? function (t) {
if (!t._d) {
var e = W(t._i);
t._a = d([e.year, e.month, e.day || e.date, e.hour, e.minute, e.second, e.millisecond], function (t) {
return t && parseInt(t, 10)
}), ge(t)
}
}(e) : l(i) ? e._d = new Date(i) : a.createFromInputFallback(e), m(t) || (t._d = null), t))
}
function Pe(t, e, i, n, a) {
var s, l = {};
return !0 !== i && !1 !== i || (n = i, i = void 0), (o(t) && function (t) {
if (Object.getOwnPropertyNames) return 0 === Object.getOwnPropertyNames(t).length;
var e;
for (e in t) if (t.hasOwnProperty(e)) return !1;
return !0
}(t) || r(t) && 0 === t.length) && (t = void 0), l._isAMomentObject = !0, l._useUTC = l._isUTC = a, l._l = i, l._i = t, l._f = e, l._strict = n, (s = new x(ce(Ce(l))))._nextDay && (s.add(1, "d"), s._nextDay = void 0), s
}
function Te(t, e, i, n) {
return Pe(t, e, i, n, !1)
}
a.createFromInputFallback = D("value provided is not in a recognized RFC2822 or ISO format. moment construction falls back to js Date(), which is not reliable across all browsers and versions. Non RFC2822/ISO date formats are discouraged and will be removed in an upcoming major release. Please refer to http://momentjs.com/guides/#/warnings/js-date/ for more info.", function (t) {
t._d = new Date(t._i + (t._useUTC ? " UTC" : ""))
}), a.ISO_8601 = function () {
}, a.RFC_2822 = function () {
};
var Oe = D("moment().min is deprecated, use moment.max instead. http://momentjs.com/guides/#/warnings/min-max/", function () {
var t = Te.apply(null, arguments);
return this.isValid() && t.isValid() ? t < this ? this : t : p()
}),
Ie = D("moment().max is deprecated, use moment.min instead. http://momentjs.com/guides/#/warnings/min-max/", function () {
var t = Te.apply(null, arguments);
return this.isValid() && t.isValid() ? t > this ? this : t : p()
});
function Ae(t, e) {
var i, n;
if (1 === e.length && r(e[0]) && (e = e[0]), !e.length) return Te();
for (i = e[0], n = 1; n < e.length; ++n) e[n].isValid() && !e[n][t](i) || (i = e[n]);
return i
}
var Fe = ["year", "quarter", "month", "week", "day", "hour", "minute", "second", "millisecond"];
function Re(t) {
var e = W(t), i = e.year || 0, n = e.quarter || 0, a = e.month || 0, r = e.week || 0,
o = e.day || 0, s = e.hour || 0, l = e.minute || 0, u = e.second || 0, d = e.millisecond || 0;
this._isValid = function (t) {
for (var e in t) if (-1 === Ct.call(Fe, e) || null != t[e] && isNaN(t[e])) return !1;
for (var i = !1, n = 0; n < Fe.length; ++n) if (t[Fe[n]]) {
if (i) return !1;
parseFloat(t[Fe[n]]) !== w(t[Fe[n]]) && (i = !0)
}
return !0
}(e), this._milliseconds = +d + 1e3 * u + 6e4 * l + 1e3 * s * 60 * 60, this._days = +o + 7 * r, this._months = +a + 3 * n + 12 * i, this._data = {}, this._locale = he(), this._bubble()
}
function Le(t) {
return t instanceof Re
}
function We(t) {
return t < 0 ? -1 * Math.round(-1 * t) : Math.round(t)
}
function Ye(t, e) {
j(t, 0, 0, function () {
var t = this.utcOffset(), i = "+";
return t < 0 && (t = -t, i = "-"), i + z(~~(t / 60), 2) + e + z(~~t % 60, 2)
})
}
Ye("Z", ":"), Ye("ZZ", ""), dt("Z", st), dt("ZZ", st), gt(["Z", "ZZ"], function (t, e, i) {
i._useUTC = !0, i._tzm = ze(st, t)
});
var Ne = /([\+\-]|\d\d)/gi;
function ze(t, e) {
var i = (e || "").match(t);
if (null === i) return null;
var n = ((i[i.length - 1] || []) + "").match(Ne) || ["-", 0, 0], a = 60 * n[1] + w(n[2]);
return 0 === a ? 0 : "+" === n[0] ? a : -a
}
function He(t, e) {
var i, n;
return e._isUTC ? (i = e.clone(), n = (_(t) || u(t) ? t.valueOf() : Te(t).valueOf()) - i.valueOf(), i._d.setTime(i._d.valueOf() + n), a.updateOffset(i, !1), i) : Te(t).local()
}
function Ve(t) {
return 15 * -Math.round(t._d.getTimezoneOffset() / 15)
}
function Be() {
return !!this.isValid() && (this._isUTC && 0 === this._offset)
}
a.updateOffset = function () {
};
var Ee = /^(\-|\+)?(?:(\d*)[. ])?(\d+)\:(\d+)(?:\:(\d+)(\.\d*)?)?$/,
je = /^(-|\+)?P(?:([-+]?[0-9,.]*)Y)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)W)?(?:([-+]?[0-9,.]*)D)?(?:T(?:([-+]?[0-9,.]*)H)?(?:([-+]?[0-9,.]*)M)?(?:([-+]?[0-9,.]*)S)?)?$/;
function Ue(t, e) {
var i, n, a, r = t, o = null;
return Le(t) ? r = {
ms: t._milliseconds,
d: t._days,
M: t._months
} : l(t) ? (r = {}, e ? r[e] = t : r.milliseconds = t) : (o = Ee.exec(t)) ? (i = "-" === o[1] ? -1 : 1, r = {
y: 0,
d: w(o[yt]) * i,
h: w(o[bt]) * i,
m: w(o[xt]) * i,
s: w(o[_t]) * i,
ms: w(We(1e3 * o[kt])) * i
}) : (o = je.exec(t)) ? (i = "-" === o[1] ? -1 : (o[1], 1), r = {
y: qe(o[2], i),
M: qe(o[3], i),
w: qe(o[4], i),
d: qe(o[5], i),
h: qe(o[6], i),
m: qe(o[7], i),
s: qe(o[8], i)
}) : null == r ? r = {} : "object" == typeof r && ("from" in r || "to" in r) && (a = function (t, e) {
var i;
if (!t.isValid() || !e.isValid()) return {milliseconds: 0, months: 0};
e = He(e, t), t.isBefore(e) ? i = Ge(t, e) : ((i = Ge(e, t)).milliseconds = -i.milliseconds, i.months = -i.months);
return i
}(Te(r.from), Te(r.to)), (r = {}).ms = a.milliseconds, r.M = a.months), n = new Re(r), Le(t) && h(t, "_locale") && (n._locale = t._locale), n
}
function qe(t, e) {
var i = t && parseFloat(t.replace(",", "."));
return (isNaN(i) ? 0 : i) * e
}
function Ge(t, e) {
var i = {milliseconds: 0, months: 0};
return i.months = e.month() - t.month() + 12 * (e.year() - t.year()), t.clone().add(i.months, "M").isAfter(e) && --i.months, i.milliseconds = +e - +t.clone().add(i.months, "M"), i
}
function Ze(t, e) {
return function (i, n) {
var a;
return null === n || isNaN(+n) || (T(e, "moment()." + e + "(period, number) is deprecated. Please use moment()." + e + "(number, period). See http://momentjs.com/guides/#/warnings/add-inverted-param/ for more info."), a = i, i = n, n = a), Xe(this, Ue(i = "string" == typeof i ? +i : i, n), t), this
}
}
function Xe(t, e, i, n) {
var r = e._milliseconds, o = We(e._days), s = We(e._months);
t.isValid() && (n = null == n || n, s && Wt(t, Ot(t, "Month") + s * i), o && It(t, "Date", Ot(t, "Date") + o * i), r && t._d.setTime(t._d.valueOf() + r * i), n && a.updateOffset(t, o || s))
}
Ue.fn = Re.prototype, Ue.invalid = function () {
return Ue(NaN)
};
var Je = Ze(1, "add"), Ke = Ze(-1, "subtract");
function $e(t, e) {
var i = 12 * (e.year() - t.year()) + (e.month() - t.month()), n = t.clone().add(i, "months");
return -(i + (e - n < 0 ? (e - n) / (n - t.clone().add(i - 1, "months")) : (e - n) / (t.clone().add(i + 1, "months") - n))) || 0
}
function Qe(t) {
var e;
return void 0 === t ? this._locale._abbr : (null != (e = he(t)) && (this._locale = e), this)
}
a.defaultFormat = "YYYY-MM-DDTHH:mm:ssZ", a.defaultFormatUtc = "YYYY-MM-DDTHH:mm:ss[Z]";
var ti = D("moment().lang() is deprecated. Instead, use moment().localeData() to get the language configuration. Use moment().locale() to change languages.", function (t) {
return void 0 === t ? this.localeData() : this.locale(t)
});
function ei() {
return this._locale
}
function ii(t, e) {
j(0, [t, t.length], 0, e)
}
function ni(t, e, i, n, a) {
var r;
return null == t ? jt(this, n, a).year : (e > (r = Ut(t, n, a)) && (e = r), function (t, e, i, n, a) {
var r = Et(t, e, i, n, a), o = Vt(r.year, 0, r.dayOfYear);
return this.year(o.getUTCFullYear()), this.month(o.getUTCMonth()), this.date(o.getUTCDate()), this
}.call(this, t, e, i, n, a))
}
j(0, ["gg", 2], 0, function () {
return this.weekYear() % 100
}), j(0, ["GG", 2], 0, function () {
return this.isoWeekYear() % 100
}), ii("gggg", "weekYear"), ii("ggggg", "weekYear"), ii("GGGG", "isoWeekYear"), ii("GGGGG", "isoWeekYear"), R("weekYear", "gg"), R("isoWeekYear", "GG"), N("weekYear", 1), N("isoWeekYear", 1), dt("G", rt), dt("g", rt), dt("GG", $, Z), dt("gg", $, Z), dt("GGGG", it, J), dt("gggg", it, J), dt("GGGGG", nt, K), dt("ggggg", nt, K), mt(["gggg", "ggggg", "GGGG", "GGGGG"], function (t, e, i, n) {
e[n.substr(0, 2)] = w(t)
}), mt(["gg", "GG"], function (t, e, i, n) {
e[n] = a.parseTwoDigitYear(t)
}), j("Q", 0, "Qo", "quarter"), R("quarter", "Q"), N("quarter", 7), dt("Q", G), gt("Q", function (t, e) {
e[vt] = 3 * (w(t) - 1)
}), j("D", ["DD", 2], "Do", "date"), R("date", "D"), N("date", 9), dt("D", $), dt("DD", $, Z), dt("Do", function (t, e) {
return t ? e._dayOfMonthOrdinalParse || e._ordinalParse : e._dayOfMonthOrdinalParseLenient
}), gt(["D", "DD"], yt), gt("Do", function (t, e) {
e[yt] = w(t.match($)[0])
});
var ai = Tt("Date", !0);
j("DDD", ["DDDD", 3], "DDDo", "dayOfYear"), R("dayOfYear", "DDD"), N("dayOfYear", 4), dt("DDD", et), dt("DDDD", X), gt(["DDD", "DDDD"], function (t, e, i) {
i._dayOfYear = w(t)
}), j("m", ["mm", 2], 0, "minute"), R("minute", "m"), N("minute", 14), dt("m", $), dt("mm", $, Z), gt(["m", "mm"], xt);
var ri = Tt("Minutes", !1);
j("s", ["ss", 2], 0, "second"), R("second", "s"), N("second", 15), dt("s", $), dt("ss", $, Z), gt(["s", "ss"], _t);
var oi, si = Tt("Seconds", !1);
for (j("S", 0, 0, function () {
return ~~(this.millisecond() / 100)
}), j(0, ["SS", 2], 0, function () {
return ~~(this.millisecond() / 10)
}), j(0, ["SSS", 3], 0, "millisecond"), j(0, ["SSSS", 4], 0, function () {
return 10 * this.millisecond()
}), j(0, ["SSSSS", 5], 0, function () {
return 100 * this.millisecond()
}), j(0, ["SSSSSS", 6], 0, function () {
return 1e3 * this.millisecond()
}), j(0, ["SSSSSSS", 7], 0, function () {
return 1e4 * this.millisecond()
}), j(0, ["SSSSSSSS", 8], 0, function () {
return 1e5 * this.millisecond()
}), j(0, ["SSSSSSSSS", 9], 0, function () {
return 1e6 * this.millisecond()
}), R("millisecond", "ms"), N("millisecond", 16), dt("S", et, G), dt("SS", et, Z), dt("SSS", et, X), oi = "SSSS"; oi.length <= 9; oi += "S") dt(oi, at);
function li(t, e) {
e[kt] = w(1e3 * ("0." + t))
}
for (oi = "S"; oi.length <= 9; oi += "S") gt(oi, li);
var ui = Tt("Milliseconds", !1);
j("z", 0, 0, "zoneAbbr"), j("zz", 0, 0, "zoneName");
var di = x.prototype;
function hi(t) {
return t
}
di.add = Je, di.calendar = function (t, e) {
var i = t || Te(), n = He(i, this).startOf("day"), r = a.calendarFormat(this, n) || "sameElse",
o = e && (O(e[r]) ? e[r].call(this, i) : e[r]);
return this.format(o || this.localeData().calendar(r, this, Te(i)))
}, di.clone = function () {
return new x(this)
}, di.diff = function (t, e, i) {
var n, a, r;
if (!this.isValid()) return NaN;
if (!(n = He(t, this)).isValid()) return NaN;
switch (a = 6e4 * (n.utcOffset() - this.utcOffset()), e = L(e)) {
case"year":
r = $e(this, n) / 12;
break;
case"month":
r = $e(this, n);
break;
case"quarter":
r = $e(this, n) / 3;
break;
case"second":
r = (this - n) / 1e3;
break;
case"minute":
r = (this - n) / 6e4;
break;
case"hour":
r = (this - n) / 36e5;
break;
case"day":
r = (this - n - a) / 864e5;
break;
case"week":
r = (this - n - a) / 6048e5;
break;
default:
r = this - n
}
return i ? r : k(r)
}, di.endOf = function (t) {
return void 0 === (t = L(t)) || "millisecond" === t ? this : ("date" === t && (t = "day"), this.startOf(t).add(1, "isoWeek" === t ? "week" : t).subtract(1, "ms"))
}, di.format = function (t) {
t || (t = this.isUtc() ? a.defaultFormatUtc : a.defaultFormat);
var e = U(this, t);
return this.localeData().postformat(e)
}, di.from = function (t, e) {
return this.isValid() && (_(t) && t.isValid() || Te(t).isValid()) ? Ue({
to: this,
from: t
}).locale(this.locale()).humanize(!e) : this.localeData().invalidDate()
}, di.fromNow = function (t) {
return this.from(Te(), t)
}, di.to = function (t, e) {
return this.isValid() && (_(t) && t.isValid() || Te(t).isValid()) ? Ue({
from: this,
to: t
}).locale(this.locale()).humanize(!e) : this.localeData().invalidDate()
}, di.toNow = function (t) {
return this.to(Te(), t)
}, di.get = function (t) {
return O(this[t = L(t)]) ? this[t]() : this
}, di.invalidAt = function () {
return g(this).overflow
}, di.isAfter = function (t, e) {
var i = _(t) ? t : Te(t);
return !(!this.isValid() || !i.isValid()) && ("millisecond" === (e = L(s(e) ? "millisecond" : e)) ? this.valueOf() > i.valueOf() : i.valueOf() < this.clone().startOf(e).valueOf())
}, di.isBefore = function (t, e) {
var i = _(t) ? t : Te(t);
return !(!this.isValid() || !i.isValid()) && ("millisecond" === (e = L(s(e) ? "millisecond" : e)) ? this.valueOf() < i.valueOf() : this.clone().endOf(e).valueOf() < i.valueOf())
}, di.isBetween = function (t, e, i, n) {
return ("(" === (n = n || "()")[0] ? this.isAfter(t, i) : !this.isBefore(t, i)) && (")" === n[1] ? this.isBefore(e, i) : !this.isAfter(e, i))
}, di.isSame = function (t, e) {
var i, n = _(t) ? t : Te(t);
return !(!this.isValid() || !n.isValid()) && ("millisecond" === (e = L(e || "millisecond")) ? this.valueOf() === n.valueOf() : (i = n.valueOf(), this.clone().startOf(e).valueOf() <= i && i <= this.clone().endOf(e).valueOf()))
}, di.isSameOrAfter = function (t, e) {
return this.isSame(t, e) || this.isAfter(t, e)
}, di.isSameOrBefore = function (t, e) {
return this.isSame(t, e) || this.isBefore(t, e)
}, di.isValid = function () {
return m(this)
}, di.lang = ti, di.locale = Qe, di.localeData = ei, di.max = Ie, di.min = Oe, di.parsingFlags = function () {
return c({}, g(this))
}, di.set = function (t, e) {
if ("object" == typeof t) for (var i = function (t) {
var e = [];
for (var i in t) e.push({unit: i, priority: Y[i]});
return e.sort(function (t, e) {
return t.priority - e.priority
}), e
}(t = W(t)), n = 0; n < i.length; n++) this[i[n].unit](t[i[n].unit]); else if (O(this[t = L(t)])) return this[t](e);
return this
}, di.startOf = function (t) {
switch (t = L(t)) {
case"year":
this.month(0);
case"quarter":
case"month":
this.date(1);
case"week":
case"isoWeek":
case"day":
case"date":
this.hours(0);
case"hour":
this.minutes(0);
case"minute":
this.seconds(0);
case"second":
this.milliseconds(0)
}
return "week" === t && this.weekday(0), "isoWeek" === t && this.isoWeekday(1), "quarter" === t && this.month(3 * Math.floor(this.month() / 3)), this
}, di.subtract = Ke, di.toArray = function () {
var t = this;
return [t.year(), t.month(), t.date(), t.hour(), t.minute(), t.second(), t.millisecond()]
}, di.toObject = function () {
var t = this;
return {
years: t.year(),
months: t.month(),
date: t.date(),
hours: t.hours(),
minutes: t.minutes(),
seconds: t.seconds(),
milliseconds: t.milliseconds()
}
}, di.toDate = function () {
return new Date(this.valueOf())
}, di.toISOString = function (t) {
if (!this.isValid()) return null;
var e = !0 !== t, i = e ? this.clone().utc() : this;
return i.year() < 0 || i.year() > 9999 ? U(i, e ? "YYYYYY-MM-DD[T]HH:mm:ss.SSS[Z]" : "YYYYYY-MM-DD[T]HH:mm:ss.SSSZ") : O(Date.prototype.toISOString) ? e ? this.toDate().toISOString() : new Date(this._d.valueOf()).toISOString().replace("Z", U(i, "Z")) : U(i, e ? "YYYY-MM-DD[T]HH:mm:ss.SSS[Z]" : "YYYY-MM-DD[T]HH:mm:ss.SSSZ")
}, di.inspect = function () {
if (!this.isValid()) return "moment.invalid(/* " + this._i + " */)";
var t = "moment", e = "";
this.isLocal() || (t = 0 === this.utcOffset() ? "moment.utc" : "moment.parseZone", e = "Z");
var i = "[" + t + '("]', n = 0 <= this.year() && this.year() <= 9999 ? "YYYY" : "YYYYYY",
a = e + '[")]';
return this.format(i + n + "-MM-DD[T]HH:mm:ss.SSS" + a)
}, di.toJSON = function () {
return this.isValid() ? this.toISOString() : null
}, di.toString = function () {
return this.clone().locale("en").format("ddd MMM DD YYYY HH:mm:ss [GMT]ZZ")
}, di.unix = function () {
return Math.floor(this.valueOf() / 1e3)
}, di.valueOf = function () {
return this._d.valueOf() - 6e4 * (this._offset || 0)
}, di.creationData = function () {
return {
input: this._i,
format: this._f,
locale: this._locale,
isUTC: this._isUTC,
strict: this._strict
}
}, di.year = Pt, di.isLeapYear = function () {
return Dt(this.year())
}, di.weekYear = function (t) {
return ni.call(this, t, this.week(), this.weekday(), this.localeData()._week.dow, this.localeData()._week.doy)
}, di.isoWeekYear = function (t) {
return ni.call(this, t, this.isoWeek(), this.isoWeekday(), 1, 4)
}, di.quarter = di.quarters = function (t) {
return null == t ? Math.ceil((this.month() + 1) / 3) : this.month(3 * (t - 1) + this.month() % 3)
}, di.month = Yt, di.daysInMonth = function () {
return At(this.year(), this.month())
}, di.week = di.weeks = function (t) {
var e = this.localeData().week(this);
return null == t ? e : this.add(7 * (t - e), "d")
}, di.isoWeek = di.isoWeeks = function (t) {
var e = jt(this, 1, 4).week;
return null == t ? e : this.add(7 * (t - e), "d")
}, di.weeksInYear = function () {
var t = this.localeData()._week;
return Ut(this.year(), t.dow, t.doy)
}, di.isoWeeksInYear = function () {
return Ut(this.year(), 1, 4)
}, di.date = ai, di.day = di.days = function (t) {
if (!this.isValid()) return null != t ? this : NaN;
var e, i, n = this._isUTC ? this._d.getUTCDay() : this._d.getDay();
return null != t ? (e = t, i = this.localeData(), t = "string" != typeof e ? e : isNaN(e) ? "number" == typeof(e = i.weekdaysParse(e)) ? e : null : parseInt(e, 10), this.add(t - n, "d")) : n
}, di.weekday = function (t) {
if (!this.isValid()) return null != t ? this : NaN;
var e = (this.day() + 7 - this.localeData()._week.dow) % 7;
return null == t ? e : this.add(t - e, "d")
}, di.isoWeekday = function (t) {
if (!this.isValid()) return null != t ? this : NaN;
if (null != t) {
var e = (i = t, n = this.localeData(), "string" == typeof i ? n.weekdaysParse(i) % 7 || 7 : isNaN(i) ? null : i);
return this.day(this.day() % 7 ? e : e - 7)
}
return this.day() || 7;
var i, n
}, di.dayOfYear = function (t) {
var e = Math.round((this.clone().startOf("day") - this.clone().startOf("year")) / 864e5) + 1;
return null == t ? e : this.add(t - e, "d")
}, di.hour = di.hours = ne, di.minute = di.minutes = ri, di.second = di.seconds = si, di.millisecond = di.milliseconds = ui, di.utcOffset = function (t, e, i) {
var n, r = this._offset || 0;
if (!this.isValid()) return null != t ? this : NaN;
if (null != t) {
if ("string" == typeof t) {
if (null === (t = ze(st, t))) return this
} else Math.abs(t) < 16 && !i && (t *= 60);
return !this._isUTC && e && (n = Ve(this)), this._offset = t, this._isUTC = !0, null != n && this.add(n, "m"), r !== t && (!e || this._changeInProgress ? Xe(this, Ue(t - r, "m"), 1, !1) : this._changeInProgress || (this._changeInProgress = !0, a.updateOffset(this, !0), this._changeInProgress = null)), this
}
return this._isUTC ? r : Ve(this)
}, di.utc = function (t) {
return this.utcOffset(0, t)
}, di.local = function (t) {
return this._isUTC && (this.utcOffset(0, t), this._isUTC = !1, t && this.subtract(Ve(this), "m")), this
}, di.parseZone = function () {
if (null != this._tzm) this.utcOffset(this._tzm, !1, !0); else if ("string" == typeof this._i) {
var t = ze(ot, this._i);
null != t ? this.utcOffset(t) : this.utcOffset(0, !0)
}
return this
}, di.hasAlignedHourOffset = function (t) {
return !!this.isValid() && (t = t ? Te(t).utcOffset() : 0, (this.utcOffset() - t) % 60 == 0)
}, di.isDST = function () {
return this.utcOffset() > this.clone().month(0).utcOffset() || this.utcOffset() > this.clone().month(5).utcOffset()
}, di.isLocal = function () {
return !!this.isValid() && !this._isUTC
}, di.isUtcOffset = function () {
return !!this.isValid() && this._isUTC
}, di.isUtc = Be, di.isUTC = Be, di.zoneAbbr = function () {
return this._isUTC ? "UTC" : ""
}, di.zoneName = function () {
return this._isUTC ? "Coordinated Universal Time" : ""
}, di.dates = D("dates accessor is deprecated. Use date instead.", ai), di.months = D("months accessor is deprecated. Use month instead", Yt), di.years = D("years accessor is deprecated. Use year instead", Pt), di.zone = D("moment().zone is deprecated, use moment().utcOffset instead. http://momentjs.com/guides/#/warnings/zone/", function (t, e) {
return null != t ? ("string" != typeof t && (t = -t), this.utcOffset(t, e), this) : -this.utcOffset()
}), di.isDSTShifted = D("isDSTShifted is deprecated. See http://momentjs.com/guides/#/warnings/dst-shifted/ for more information", function () {
if (!s(this._isDSTShifted)) return this._isDSTShifted;
var t = {};
if (y(t, this), (t = Ce(t))._a) {
var e = t._isUTC ? f(t._a) : Te(t._a);
this._isDSTShifted = this.isValid() && M(t._a, e.toArray()) > 0
} else this._isDSTShifted = !1;
return this._isDSTShifted
});
var ci = A.prototype;
function fi(t, e, i, n) {
var a = he(), r = f().set(n, e);
return a[i](r, t)
}
function gi(t, e, i) {
if (l(t) && (e = t, t = void 0), t = t || "", null != e) return fi(t, e, i, "month");
var n, a = [];
for (n = 0; n < 12; n++) a[n] = fi(t, n, i, "month");
return a
}
function mi(t, e, i, n) {
"boolean" == typeof t ? (l(e) && (i = e, e = void 0), e = e || "") : (i = e = t, t = !1, l(e) && (i = e, e = void 0), e = e || "");
var a, r = he(), o = t ? r._week.dow : 0;
if (null != i) return fi(e, (i + o) % 7, n, "day");
var s = [];
for (a = 0; a < 7; a++) s[a] = fi(e, (a + o) % 7, n, "day");
return s
}
ci.calendar = function (t, e, i) {
var n = this._calendar[t] || this._calendar.sameElse;
return O(n) ? n.call(e, i) : n
}, ci.longDateFormat = function (t) {
var e = this._longDateFormat[t], i = this._longDateFormat[t.toUpperCase()];
return e || !i ? e : (this._longDateFormat[t] = i.replace(/MMMM|MM|DD|dddd/g, function (t) {
return t.slice(1)
}), this._longDateFormat[t])
}, ci.invalidDate = function () {
return this._invalidDate
}, ci.ordinal = function (t) {
return this._ordinal.replace("%d", t)
}, ci.preparse = hi, ci.postformat = hi, ci.relativeTime = function (t, e, i, n) {
var a = this._relativeTime[i];
return O(a) ? a(t, e, i, n) : a.replace(/%d/i, t)
}, ci.pastFuture = function (t, e) {
var i = this._relativeTime[t > 0 ? "future" : "past"];
return O(i) ? i(e) : i.replace(/%s/i, e)
}, ci.set = function (t) {
var e, i;
for (i in t) O(e = t[i]) ? this[i] = e : this["_" + i] = e;
this._config = t, this._dayOfMonthOrdinalParseLenient = new RegExp((this._dayOfMonthOrdinalParse.source || this._ordinalParse.source) + "|" + /\d{1,2}/.source)
}, ci.months = function (t, e) {
return t ? r(this._months) ? this._months[t.month()] : this._months[(this._months.isFormat || Ft).test(e) ? "format" : "standalone"][t.month()] : r(this._months) ? this._months : this._months.standalone
}, ci.monthsShort = function (t, e) {
return t ? r(this._monthsShort) ? this._monthsShort[t.month()] : this._monthsShort[Ft.test(e) ? "format" : "standalone"][t.month()] : r(this._monthsShort) ? this._monthsShort : this._monthsShort.standalone
}, ci.monthsParse = function (t, e, i) {
var n, a, r;
if (this._monthsParseExact) return function (t, e, i) {
var n, a, r, o = t.toLocaleLowerCase();
if (!this._monthsParse) for (this._monthsParse = [], this._longMonthsParse = [], this._shortMonthsParse = [], n = 0; n < 12; ++n) r = f([2e3, n]), this._shortMonthsParse[n] = this.monthsShort(r, "").toLocaleLowerCase(), this._longMonthsParse[n] = this.months(r, "").toLocaleLowerCase();
return i ? "MMM" === e ? -1 !== (a = Ct.call(this._shortMonthsParse, o)) ? a : null : -1 !== (a = Ct.call(this._longMonthsParse, o)) ? a : null : "MMM" === e ? -1 !== (a = Ct.call(this._shortMonthsParse, o)) ? a : -1 !== (a = Ct.call(this._longMonthsParse, o)) ? a : null : -1 !== (a = Ct.call(this._longMonthsParse, o)) ? a : -1 !== (a = Ct.call(this._shortMonthsParse, o)) ? a : null
}.call(this, t, e, i);
for (this._monthsParse || (this._monthsParse = [], this._longMonthsParse = [], this._shortMonthsParse = []), n = 0; n < 12; n++) {
if (a = f([2e3, n]), i && !this._longMonthsParse[n] && (this._longMonthsParse[n] = new RegExp("^" + this.months(a, "").replace(".", "") + "$", "i"), this._shortMonthsParse[n] = new RegExp("^" + this.monthsShort(a, "").replace(".", "") + "$", "i")), i || this._monthsParse[n] || (r = "^" + this.months(a, "") + "|^" + this.monthsShort(a, ""), this._monthsParse[n] = new RegExp(r.replace(".", ""), "i")), i && "MMMM" === e && this._longMonthsParse[n].test(t)) return n;
if (i && "MMM" === e && this._shortMonthsParse[n].test(t)) return n;
if (!i && this._monthsParse[n].test(t)) return n
}
}, ci.monthsRegex = function (t) {
return this._monthsParseExact ? (h(this, "_monthsRegex") || Ht.call(this), t ? this._monthsStrictRegex : this._monthsRegex) : (h(this, "_monthsRegex") || (this._monthsRegex = zt), this._monthsStrictRegex && t ? this._monthsStrictRegex : this._monthsRegex)
}, ci.monthsShortRegex = function (t) {
return this._monthsParseExact ? (h(this, "_monthsRegex") || Ht.call(this), t ? this._monthsShortStrictRegex : this._monthsShortRegex) : (h(this, "_monthsShortRegex") || (this._monthsShortRegex = Nt), this._monthsShortStrictRegex && t ? this._monthsShortStrictRegex : this._monthsShortRegex)
}, ci.week = function (t) {
return jt(t, this._week.dow, this._week.doy).week
}, ci.firstDayOfYear = function () {
return this._week.doy
}, ci.firstDayOfWeek = function () {
return this._week.dow
}, ci.weekdays = function (t, e) {
return t ? r(this._weekdays) ? this._weekdays[t.day()] : this._weekdays[this._weekdays.isFormat.test(e) ? "format" : "standalone"][t.day()] : r(this._weekdays) ? this._weekdays : this._weekdays.standalone
}, ci.weekdaysMin = function (t) {
return t ? this._weekdaysMin[t.day()] : this._weekdaysMin
}, ci.weekdaysShort = function (t) {
return t ? this._weekdaysShort[t.day()] : this._weekdaysShort
}, ci.weekdaysParse = function (t, e, i) {
var n, a, r;
if (this._weekdaysParseExact) return function (t, e, i) {
var n, a, r, o = t.toLocaleLowerCase();
if (!this._weekdaysParse) for (this._weekdaysParse = [], this._shortWeekdaysParse = [], this._minWeekdaysParse = [], n = 0; n < 7; ++n) r = f([2e3, 1]).day(n), this._minWeekdaysParse[n] = this.weekdaysMin(r, "").toLocaleLowerCase(), this._shortWeekdaysParse[n] = this.weekdaysShort(r, "").toLocaleLowerCase(), this._weekdaysParse[n] = this.weekdays(r, "").toLocaleLowerCase();
return i ? "dddd" === e ? -1 !== (a = Ct.call(this._weekdaysParse, o)) ? a : null : "ddd" === e ? -1 !== (a = Ct.call(this._shortWeekdaysParse, o)) ? a : null : -1 !== (a = Ct.call(this._minWeekdaysParse, o)) ? a : null : "dddd" === e ? -1 !== (a = Ct.call(this._weekdaysParse, o)) ? a : -1 !== (a = Ct.call(this._shortWeekdaysParse, o)) ? a : -1 !== (a = Ct.call(this._minWeekdaysParse, o)) ? a : null : "ddd" === e ? -1 !== (a = Ct.call(this._shortWeekdaysParse, o)) ? a : -1 !== (a = Ct.call(this._weekdaysParse, o)) ? a : -1 !== (a = Ct.call(this._minWeekdaysParse, o)) ? a : null : -1 !== (a = Ct.call(this._minWeekdaysParse, o)) ? a : -1 !== (a = Ct.call(this._weekdaysParse, o)) ? a : -1 !== (a = Ct.call(this._shortWeekdaysParse, o)) ? a : null
}.call(this, t, e, i);
for (this._weekdaysParse || (this._weekdaysParse = [], this._minWeekdaysParse = [], this._shortWeekdaysParse = [], this._fullWeekdaysParse = []), n = 0; n < 7; n++) {
if (a = f([2e3, 1]).day(n), i && !this._fullWeekdaysParse[n] && (this._fullWeekdaysParse[n] = new RegExp("^" + this.weekdays(a, "").replace(".", ".?") + "$", "i"), this._shortWeekdaysParse[n] = new RegExp("^" + this.weekdaysShort(a, "").replace(".", ".?") + "$", "i"), this._minWeekdaysParse[n] = new RegExp("^" + this.weekdaysMin(a, "").replace(".", ".?") + "$", "i")), this._weekdaysParse[n] || (r = "^" + this.weekdays(a, "") + "|^" + this.weekdaysShort(a, "") + "|^" + this.weekdaysMin(a, ""), this._weekdaysParse[n] = new RegExp(r.replace(".", ""), "i")), i && "dddd" === e && this._fullWeekdaysParse[n].test(t)) return n;
if (i && "ddd" === e && this._shortWeekdaysParse[n].test(t)) return n;
if (i && "dd" === e && this._minWeekdaysParse[n].test(t)) return n;
if (!i && this._weekdaysParse[n].test(t)) return n
}
}, ci.weekdaysRegex = function (t) {
return this._weekdaysParseExact ? (h(this, "_weekdaysRegex") || $t.call(this), t ? this._weekdaysStrictRegex : this._weekdaysRegex) : (h(this, "_weekdaysRegex") || (this._weekdaysRegex = Xt), this._weekdaysStrictRegex && t ? this._weekdaysStrictRegex : this._weekdaysRegex)
}, ci.weekdaysShortRegex = function (t) {
return this._weekdaysParseExact ? (h(this, "_weekdaysRegex") || $t.call(this), t ? this._weekdaysShortStrictRegex : this._weekdaysShortRegex) : (h(this, "_weekdaysShortRegex") || (this._weekdaysShortRegex = Jt), this._weekdaysShortStrictRegex && t ? this._weekdaysShortStrictRegex : this._weekdaysShortRegex)
}, ci.weekdaysMinRegex = function (t) {
return this._weekdaysParseExact ? (h(this, "_weekdaysRegex") || $t.call(this), t ? this._weekdaysMinStrictRegex : this._weekdaysMinRegex) : (h(this, "_weekdaysMinRegex") || (this._weekdaysMinRegex = Kt), this._weekdaysMinStrictRegex && t ? this._weekdaysMinStrictRegex : this._weekdaysMinRegex)
}, ci.isPM = function (t) {
return "p" === (t + "").toLowerCase().charAt(0)
}, ci.meridiem = function (t, e, i) {
return t > 11 ? i ? "pm" : "PM" : i ? "am" : "AM"
}, ue("en", {
dayOfMonthOrdinalParse: /\d{1,2}(th|st|nd|rd)/, ordinal: function (t) {
var e = t % 10;
return t + (1 === w(t % 100 / 10) ? "th" : 1 === e ? "st" : 2 === e ? "nd" : 3 === e ? "rd" : "th")
}
}), a.lang = D("moment.lang is deprecated. Use moment.locale instead.", ue), a.langData = D("moment.langData is deprecated. Use moment.localeData instead.", he);
var pi = Math.abs;
function vi(t, e, i, n) {
var a = Ue(e, i);
return t._milliseconds += n * a._milliseconds, t._days += n * a._days, t._months += n * a._months, t._bubble()
}
function yi(t) {
return t < 0 ? Math.floor(t) : Math.ceil(t)
}
function bi(t) {
return 4800 * t / 146097
}
function xi(t) {
return 146097 * t / 4800
}
function _i(t) {
return function () {
return this.as(t)
}
}
var ki = _i("ms"), wi = _i("s"), Mi = _i("m"), Si = _i("h"), Di = _i("d"), Ci = _i("w"), Pi = _i("M"),
Ti = _i("y");
function Oi(t) {
return function () {
return this.isValid() ? this._data[t] : NaN
}
}
var Ii = Oi("milliseconds"), Ai = Oi("seconds"), Fi = Oi("minutes"), Ri = Oi("hours"), Li = Oi("days"),
Wi = Oi("months"), Yi = Oi("years");
var Ni = Math.round, zi = {ss: 44, s: 45, m: 45, h: 22, d: 26, M: 11};
var Hi = Math.abs;
function Vi(t) {
return (t > 0) - (t < 0) || +t
}
function Bi() {
if (!this.isValid()) return this.localeData().invalidDate();
var t, e, i = Hi(this._milliseconds) / 1e3, n = Hi(this._days), a = Hi(this._months);
e = k((t = k(i / 60)) / 60), i %= 60, t %= 60;
var r = k(a / 12), o = a %= 12, s = n, l = e, u = t,
d = i ? i.toFixed(3).replace(/\.?0+$/, "") : "", h = this.asSeconds();
if (!h) return "P0D";
var c = h < 0 ? "-" : "", f = Vi(this._months) !== Vi(h) ? "-" : "",
g = Vi(this._days) !== Vi(h) ? "-" : "", m = Vi(this._milliseconds) !== Vi(h) ? "-" : "";
return c + "P" + (r ? f + r + "Y" : "") + (o ? f + o + "M" : "") + (s ? g + s + "D" : "") + (l || u || d ? "T" : "") + (l ? m + l + "H" : "") + (u ? m + u + "M" : "") + (d ? m + d + "S" : "")
}
var Ei = Re.prototype;
return Ei.isValid = function () {
return this._isValid
}, Ei.abs = function () {
var t = this._data;
return this._milliseconds = pi(this._milliseconds), this._days = pi(this._days), this._months = pi(this._months), t.milliseconds = pi(t.milliseconds), t.seconds = pi(t.seconds), t.minutes = pi(t.minutes), t.hours = pi(t.hours), t.months = pi(t.months), t.years = pi(t.years), this
}, Ei.add = function (t, e) {
return vi(this, t, e, 1)
}, Ei.subtract = function (t, e) {
return vi(this, t, e, -1)
}, Ei.as = function (t) {
if (!this.isValid()) return NaN;
var e, i, n = this._milliseconds;
if ("month" === (t = L(t)) || "year" === t) return e = this._days + n / 864e5, i = this._months + bi(e), "month" === t ? i : i / 12;
switch (e = this._days + Math.round(xi(this._months)), t) {
case"week":
return e / 7 + n / 6048e5;
case"day":
return e + n / 864e5;
case"hour":
return 24 * e + n / 36e5;
case"minute":
return 1440 * e + n / 6e4;
case"second":
return 86400 * e + n / 1e3;
case"millisecond":
return Math.floor(864e5 * e) + n;
default:
throw new Error("Unknown unit " + t)
}
}, Ei.asMilliseconds = ki, Ei.asSeconds = wi, Ei.asMinutes = Mi, Ei.asHours = Si, Ei.asDays = Di, Ei.asWeeks = Ci, Ei.asMonths = Pi, Ei.asYears = Ti, Ei.valueOf = function () {
return this.isValid() ? this._milliseconds + 864e5 * this._days + this._months % 12 * 2592e6 + 31536e6 * w(this._months / 12) : NaN
}, Ei._bubble = function () {
var t, e, i, n, a, r = this._milliseconds, o = this._days, s = this._months, l = this._data;
return r >= 0 && o >= 0 && s >= 0 || r <= 0 && o <= 0 && s <= 0 || (r += 864e5 * yi(xi(s) + o), o = 0, s = 0), l.milliseconds = r % 1e3, t = k(r / 1e3), l.seconds = t % 60, e = k(t / 60), l.minutes = e % 60, i = k(e / 60), l.hours = i % 24, s += a = k(bi(o += k(i / 24))), o -= yi(xi(a)), n = k(s / 12), s %= 12, l.days = o, l.months = s, l.years = n, this
}, Ei.clone = function () {
return Ue(this)
}, Ei.get = function (t) {
return t = L(t), this.isValid() ? this[t + "s"]() : NaN
}, Ei.milliseconds = Ii, Ei.seconds = Ai, Ei.minutes = Fi, Ei.hours = Ri, Ei.days = Li, Ei.weeks = function () {
return k(this.days() / 7)
}, Ei.months = Wi, Ei.years = Yi, Ei.humanize = function (t) {
if (!this.isValid()) return this.localeData().invalidDate();
var e, i, n, a, r, o, s, l, u, d, h, c = this.localeData(),
f = (i = !t, n = c, a = Ue(e = this).abs(), r = Ni(a.as("s")), o = Ni(a.as("m")), s = Ni(a.as("h")), l = Ni(a.as("d")), u = Ni(a.as("M")), d = Ni(a.as("y")), (h = r <= zi.ss && ["s", r] || r < zi.s && ["ss", r] || o <= 1 && ["m"] || o < zi.m && ["mm", o] || s <= 1 && ["h"] || s < zi.h && ["hh", s] || l <= 1 && ["d"] || l < zi.d && ["dd", l] || u <= 1 && ["M"] || u < zi.M && ["MM", u] || d <= 1 && ["y"] || ["yy", d])[2] = i, h[3] = +e > 0, h[4] = n, function (t, e, i, n, a) {
return a.relativeTime(e || 1, !!i, t, n)
}.apply(null, h));
return t && (f = c.pastFuture(+this, f)), c.postformat(f)
}, Ei.toISOString = Bi, Ei.toString = Bi, Ei.toJSON = Bi, Ei.locale = Qe, Ei.localeData = ei, Ei.toIsoString = D("toIsoString() is deprecated. Please use toISOString() instead (notice the capitals)", Bi), Ei.lang = ti, j("X", 0, 0, "unix"), j("x", 0, 0, "valueOf"), dt("x", rt), dt("X", /[+-]?\d+(\.\d{1,3})?/), gt("X", function (t, e, i) {
i._d = new Date(1e3 * parseFloat(t, 10))
}), gt("x", function (t, e, i) {
i._d = new Date(w(t))
}), a.version = "2.20.1", i = Te, a.fn = di, a.min = function () {
return Ae("isBefore", [].slice.call(arguments, 0))
}, a.max = function () {
return Ae("isAfter", [].slice.call(arguments, 0))
}, a.now = function () {
return Date.now ? Date.now() : +new Date
}, a.utc = f, a.unix = function (t) {
return Te(1e3 * t)
}, a.months = function (t, e) {
return gi(t, e, "months")
}, a.isDate = u, a.locale = ue, a.invalid = p, a.duration = Ue, a.isMoment = _, a.weekdays = function (t, e, i) {
return mi(t, e, i, "weekdays")
}, a.parseZone = function () {
return Te.apply(null, arguments).parseZone()
}, a.localeData = he, a.isDuration = Le, a.monthsShort = function (t, e) {
return gi(t, e, "monthsShort")
}, a.weekdaysMin = function (t, e, i) {
return mi(t, e, i, "weekdaysMin")
}, a.defineLocale = de, a.updateLocale = function (t, e) {
if (null != e) {
var i, n, a = ae;
null != (n = le(t)) && (a = n._config), (i = new A(e = I(a, e))).parentLocale = re[t], re[t] = i, ue(t)
} else null != re[t] && (null != re[t].parentLocale ? re[t] = re[t].parentLocale : null != re[t] && delete re[t]);
return re[t]
}, a.locales = function () {
return C(re)
}, a.weekdaysShort = function (t, e, i) {
return mi(t, e, i, "weekdaysShort")
}, a.normalizeUnits = L, a.relativeTimeRounding = function (t) {
return void 0 === t ? Ni : "function" == typeof t && (Ni = t, !0)
}, a.relativeTimeThreshold = function (t, e) {
return void 0 !== zi[t] && (void 0 === e ? zi[t] : (zi[t] = e, "s" === t && (zi.ss = e - 1), !0))
}, a.calendarFormat = function (t, e) {
var i = t.diff(e, "days", !0);
return i < -6 ? "sameElse" : i < -1 ? "lastWeek" : i < 0 ? "lastDay" : i < 1 ? "sameDay" : i < 2 ? "nextDay" : i < 7 ? "nextWeek" : "sameElse"
}, a.prototype = di, a.HTML5_FMT = {
DATETIME_LOCAL: "YYYY-MM-DDTHH:mm",
DATETIME_LOCAL_SECONDS: "YYYY-MM-DDTHH:mm:ss",
DATETIME_LOCAL_MS: "YYYY-MM-DDTHH:mm:ss.SSS",
DATE: "YYYY-MM-DD",
TIME: "HH:mm",
TIME_SECONDS: "HH:mm:ss",
TIME_MS: "HH:mm:ss.SSS",
WEEK: "YYYY-[W]WW",
MONTH: "YYYY-MM"
}, a
}, "object" == typeof i && void 0 !== e ? e.exports = a() : n.moment = a()
}, {}], 7: [function (t, e, i) {
var n = t(29)();
n.helpers = t(45), t(27)(n), n.defaults = t(25), n.Element = t(26), n.elements = t(40), n.Interaction = t(28), n.layouts = t(30), n.platform = t(48), n.plugins = t(31), n.Ticks = t(34), t(22)(n), t(23)(n), t(24)(n), t(33)(n), t(32)(n), t(35)(n), t(55)(n), t(53)(n), t(54)(n), t(56)(n), t(57)(n), t(58)(n), t(15)(n), t(16)(n), t(17)(n), t(18)(n), t(19)(n), t(20)(n), t(21)(n), t(8)(n), t(9)(n), t(10)(n), t(11)(n), t(12)(n), t(13)(n), t(14)(n);
var a = t(49);
for (var r in a) a.hasOwnProperty(r) && n.plugins.register(a[r]);
n.platform.initialize(), e.exports = n, "undefined" != typeof window && (window.Chart = n), n.Legend = a.legend._element, n.Title = a.title._element, n.pluginService = n.plugins, n.PluginBase = n.Element.extend({}), n.canvasHelpers = n.helpers.canvas, n.layoutService = n.layouts
}, {
10: 10,
11: 11,
12: 12,
13: 13,
14: 14,
15: 15,
16: 16,
17: 17,
18: 18,
19: 19,
20: 20,
21: 21,
22: 22,
23: 23,
24: 24,
25: 25,
26: 26,
27: 27,
28: 28,
29: 29,
30: 30,
31: 31,
32: 32,
33: 33,
34: 34,
35: 35,
40: 40,
45: 45,
48: 48,
49: 49,
53: 53,
54: 54,
55: 55,
56: 56,
57: 57,
58: 58,
8: 8,
9: 9
}], 8: [function (t, e, i) {
"use strict";
e.exports = function (t) {
t.Bar = function (e, i) {
return i.type = "bar", new t(e, i)
}
}
}, {}], 9: [function (t, e, i) {
"use strict";
e.exports = function (t) {
t.Bubble = function (e, i) {
return i.type = "bubble", new t(e, i)
}
}
}, {}], 10: [function (t, e, i) {
"use strict";
e.exports = function (t) {
t.Doughnut = function (e, i) {
return i.type = "doughnut", new t(e, i)
}
}
}, {}], 11: [function (t, e, i) {
"use strict";
e.exports = function (t) {
t.Line = function (e, i) {
return i.type = "line", new t(e, i)
}
}
}, {}], 12: [function (t, e, i) {
"use strict";
e.exports = function (t) {
t.PolarArea = function (e, i) {
return i.type = "polarArea", new t(e, i)
}
}
}, {}], 13: [function (t, e, i) {
"use strict";
e.exports = function (t) {
t.Radar = function (e, i) {
return i.type = "radar", new t(e, i)
}
}
}, {}], 14: [function (t, e, i) {
"use strict";
e.exports = function (t) {
t.Scatter = function (e, i) {
return i.type = "scatter", new t(e, i)
}
}
}, {}], 15: [function (t, e, i) {
"use strict";
var n = t(25), a = t(40), r = t(45);
n._set("bar", {
hover: {mode: "label"},
scales: {
xAxes: [{
type: "category",
categoryPercentage: .8,
barPercentage: .9,
offset: !0,
gridLines: {offsetGridLines: !0}
}], yAxes: [{type: "linear"}]
}
}), n._set("horizontalBar", {
hover: {mode: "index", axis: "y"},
scales: {
xAxes: [{type: "linear", position: "bottom"}],
yAxes: [{
position: "left",
type: "category",
categoryPercentage: .8,
barPercentage: .9,
offset: !0,
gridLines: {offsetGridLines: !0}
}]
},
elements: {rectangle: {borderSkipped: "left"}},
tooltips: {
callbacks: {
title: function (t, e) {
var i = "";
return t.length > 0 && (t[0].yLabel ? i = t[0].yLabel : e.labels.length > 0 && t[0].index < e.labels.length && (i = e.labels[t[0].index])), i
}, label: function (t, e) {
return (e.datasets[t.datasetIndex].label || "") + ": " + t.xLabel
}
}, mode: "index", axis: "y"
}
}), e.exports = function (t) {
t.controllers.bar = t.DatasetController.extend({
dataElementType: a.Rectangle, initialize: function () {
var e;
t.DatasetController.prototype.initialize.apply(this, arguments), (e = this.getMeta()).stack = this.getDataset().stack, e.bar = !0
}, update: function (t) {
var e, i, n = this.getMeta().data;
for (this._ruler = this.getRuler(), e = 0, i = n.length; e < i; ++e) this.updateElement(n[e], e, t)
}, updateElement: function (t, e, i) {
var n = this, a = n.chart, o = n.getMeta(), s = n.getDataset(), l = t.custom || {},
u = a.options.elements.rectangle;
t._xScale = n.getScaleForId(o.xAxisID), t._yScale = n.getScaleForId(o.yAxisID), t._datasetIndex = n.index, t._index = e, t._model = {
datasetLabel: s.label,
label: a.data.labels[e],
borderSkipped: l.borderSkipped ? l.borderSkipped : u.borderSkipped,
backgroundColor: l.backgroundColor ? l.backgroundColor : r.valueAtIndexOrDefault(s.backgroundColor, e, u.backgroundColor),
borderColor: l.borderColor ? l.borderColor : r.valueAtIndexOrDefault(s.borderColor, e, u.borderColor),
borderWidth: l.borderWidth ? l.borderWidth : r.valueAtIndexOrDefault(s.borderWidth, e, u.borderWidth)
}, n.updateElementGeometry(t, e, i), t.pivot()
}, updateElementGeometry: function (t, e, i) {
var n = this, a = t._model, r = n.getValueScale(), o = r.getBasePixel(), s = r.isHorizontal(),
l = n._ruler || n.getRuler(), u = n.calculateBarValuePixels(n.index, e),
d = n.calculateBarIndexPixels(n.index, e, l);
a.horizontal = s, a.base = i ? o : u.base, a.x = s ? i ? o : u.head : d.center, a.y = s ? d.center : i ? o : u.head, a.height = s ? d.size : void 0, a.width = s ? void 0 : d.size
}, getValueScaleId: function () {
return this.getMeta().yAxisID
}, getIndexScaleId: function () {
return this.getMeta().xAxisID
}, getValueScale: function () {
return this.getScaleForId(this.getValueScaleId())
}, getIndexScale: function () {
return this.getScaleForId(this.getIndexScaleId())
}, _getStacks: function (t) {
var e, i, n = this.chart, a = this.getIndexScale().options.stacked,
r = void 0 === t ? n.data.datasets.length : t + 1, o = [];
for (e = 0; e < r; ++e) (i = n.getDatasetMeta(e)).bar && n.isDatasetVisible(e) && (!1 === a || !0 === a && -1 === o.indexOf(i.stack) || void 0 === a && (void 0 === i.stack || -1 === o.indexOf(i.stack))) && o.push(i.stack);
return o
}, getStackCount: function () {
return this._getStacks().length
}, getStackIndex: function (t, e) {
var i = this._getStacks(t), n = void 0 !== e ? i.indexOf(e) : -1;
return -1 === n ? i.length - 1 : n
}, getRuler: function () {
var t, e, i = this.getIndexScale(), n = this.getStackCount(), a = this.index,
o = i.isHorizontal(), s = o ? i.left : i.top, l = s + (o ? i.width : i.height), u = [];
for (t = 0, e = this.getMeta().data.length; t < e; ++t) u.push(i.getPixelForValue(null, t, a));
return {
min: r.isNullOrUndef(i.options.barThickness) ? function (t, e) {
var i, n, a, r, o = t.isHorizontal() ? t.width : t.height, s = t.getTicks();
for (a = 1, r = e.length; a < r; ++a) o = Math.min(o, e[a] - e[a - 1]);
for (a = 0, r = s.length; a < r; ++a) n = t.getPixelForTick(a), o = a > 0 ? Math.min(o, n - i) : o, i = n;
return o
}(i, u) : -1, pixels: u, start: s, end: l, stackCount: n, scale: i
}
}, calculateBarValuePixels: function (t, e) {
var i, n, a, r, o, s, l = this.chart, u = this.getMeta(), d = this.getValueScale(),
h = l.data.datasets, c = d.getRightValue(h[t].data[e]), f = d.options.stacked, g = u.stack,
m = 0;
if (f || void 0 === f && void 0 !== g) for (i = 0; i < t; ++i) (n = l.getDatasetMeta(i)).bar && n.stack === g && n.controller.getValueScaleId() === d.id && l.isDatasetVisible(i) && (a = d.getRightValue(h[i].data[e]), (c < 0 && a < 0 || c >= 0 && a > 0) && (m += a));
return r = d.getPixelForValue(m), {
size: s = ((o = d.getPixelForValue(m + c)) - r) / 2,
base: r,
head: o,
center: o + s / 2
}
}, calculateBarIndexPixels: function (t, e, i) {
var n, a, o, s, l, u, d, h, c, f, g, m, p, v, y, b, x, _ = i.scale.options,
k = "flex" === _.barThickness ? (c = e, g = _, p = (f = i).pixels, v = p[c], y = c > 0 ? p[c - 1] : null, b = c < p.length - 1 ? p[c + 1] : null, x = g.categoryPercentage, null === y && (y = v - (null === b ? f.end - v : b - v)), null === b && (b = v + v - y), m = v - (v - y) / 2 * x, {
chunk: (b - y) / 2 * x / f.stackCount,
ratio: g.barPercentage,
start: m
}) : (n = e, a = i, u = (o = _).barThickness, d = a.stackCount, h = a.pixels[n], r.isNullOrUndef(u) ? (s = a.min * o.categoryPercentage, l = o.barPercentage) : (s = u * d, l = 1), {
chunk: s / d,
ratio: l,
start: h - s / 2
}), w = this.getStackIndex(t, this.getMeta().stack),
M = k.start + k.chunk * w + k.chunk / 2,
S = Math.min(r.valueOrDefault(_.maxBarThickness, 1 / 0), k.chunk * k.ratio);
return {base: M - S / 2, head: M + S / 2, center: M, size: S}
}, draw: function () {
var t = this.chart, e = this.getValueScale(), i = this.getMeta().data, n = this.getDataset(),
a = i.length, o = 0;
for (r.canvas.clipArea(t.ctx, t.chartArea); o < a; ++o) isNaN(e.getRightValue(n.data[o])) || i[o].draw();
r.canvas.unclipArea(t.ctx)
}, setHoverStyle: function (t) {
var e = this.chart.data.datasets[t._datasetIndex], i = t._index, n = t.custom || {},
a = t._model;
a.backgroundColor = n.hoverBackgroundColor ? n.hoverBackgroundColor : r.valueAtIndexOrDefault(e.hoverBackgroundColor, i, r.getHoverColor(a.backgroundColor)), a.borderColor = n.hoverBorderColor ? n.hoverBorderColor : r.valueAtIndexOrDefault(e.hoverBorderColor, i, r.getHoverColor(a.borderColor)), a.borderWidth = n.hoverBorderWidth ? n.hoverBorderWidth : r.valueAtIndexOrDefault(e.hoverBorderWidth, i, a.borderWidth)
}, removeHoverStyle: function (t) {
var e = this.chart.data.datasets[t._datasetIndex], i = t._index, n = t.custom || {},
a = t._model, o = this.chart.options.elements.rectangle;
a.backgroundColor = n.backgroundColor ? n.backgroundColor : r.valueAtIndexOrDefault(e.backgroundColor, i, o.backgroundColor), a.borderColor = n.borderColor ? n.borderColor : r.valueAtIndexOrDefault(e.borderColor, i, o.borderColor), a.borderWidth = n.borderWidth ? n.borderWidth : r.valueAtIndexOrDefault(e.borderWidth, i, o.borderWidth)
}
}), t.controllers.horizontalBar = t.controllers.bar.extend({
getValueScaleId: function () {
return this.getMeta().xAxisID
}, getIndexScaleId: function () {
return this.getMeta().yAxisID
}
})
}
}, {25: 25, 40: 40, 45: 45}], 16: [function (t, e, i) {
"use strict";
var n = t(25), a = t(40), r = t(45);
n._set("bubble", {
hover: {mode: "single"},
scales: {
xAxes: [{type: "linear", position: "bottom", id: "x-axis-0"}],
yAxes: [{type: "linear", position: "left", id: "y-axis-0"}]
},
tooltips: {
callbacks: {
title: function () {
return ""
}, label: function (t, e) {
var i = e.datasets[t.datasetIndex].label || "",
n = e.datasets[t.datasetIndex].data[t.index];
return i + ": (" + t.xLabel + ", " + t.yLabel + ", " + n.r + ")"
}
}
}
}), e.exports = function (t) {
t.controllers.bubble = t.DatasetController.extend({
dataElementType: a.Point, update: function (t) {
var e = this, i = e.getMeta().data;
r.each(i, function (i, n) {
e.updateElement(i, n, t)
})
}, updateElement: function (t, e, i) {
var n = this, a = n.getMeta(), r = t.custom || {}, o = n.getScaleForId(a.xAxisID),
s = n.getScaleForId(a.yAxisID), l = n._resolveElementOptions(t, e),
u = n.getDataset().data[e], d = n.index,
h = i ? o.getPixelForDecimal(.5) : o.getPixelForValue("object" == typeof u ? u : NaN, e, d),
c = i ? s.getBasePixel() : s.getPixelForValue(u, e, d);
t._xScale = o, t._yScale = s, t._options = l, t._datasetIndex = d, t._index = e, t._model = {
backgroundColor: l.backgroundColor,
borderColor: l.borderColor,
borderWidth: l.borderWidth,
hitRadius: l.hitRadius,
pointStyle: l.pointStyle,
radius: i ? 0 : l.radius,
skip: r.skip || isNaN(h) || isNaN(c),
x: h,
y: c
}, t.pivot()
}, setHoverStyle: function (t) {
var e = t._model, i = t._options;
e.backgroundColor = r.valueOrDefault(i.hoverBackgroundColor, r.getHoverColor(i.backgroundColor)), e.borderColor = r.valueOrDefault(i.hoverBorderColor, r.getHoverColor(i.borderColor)), e.borderWidth = r.valueOrDefault(i.hoverBorderWidth, i.borderWidth), e.radius = i.radius + i.hoverRadius
}, removeHoverStyle: function (t) {
var e = t._model, i = t._options;
e.backgroundColor = i.backgroundColor, e.borderColor = i.borderColor, e.borderWidth = i.borderWidth, e.radius = i.radius
}, _resolveElementOptions: function (t, e) {
var i, n, a, o = this.chart, s = o.data.datasets[this.index], l = t.custom || {},
u = o.options.elements.point, d = r.options.resolve, h = s.data[e], c = {},
f = {chart: o, dataIndex: e, dataset: s, datasetIndex: this.index},
g = ["backgroundColor", "borderColor", "borderWidth", "hoverBackgroundColor", "hoverBorderColor", "hoverBorderWidth", "hoverRadius", "hitRadius", "pointStyle"];
for (i = 0, n = g.length; i < n; ++i) c[a = g[i]] = d([l[a], s[a], u[a]], f, e);
return c.radius = d([l.radius, h ? h.r : void 0, s.radius, u.radius], f, e), c
}
})
}
}, {25: 25, 40: 40, 45: 45}], 17: [function (t, e, i) {
"use strict";
var n = t(25), a = t(40), r = t(45);
n._set("doughnut", {
animation: {animateRotate: !0, animateScale: !1},
hover: {mode: "single"},
legendCallback: function (t) {
var e = [];
e.push('
');
var i = t.data, n = i.datasets, a = i.labels;
if (n.length) for (var r = 0; r < n[0].data.length; ++r) e.push('- '), a[r] && e.push(a[r]), e.push("
");
return e.push("
"), e.join("")
},
legend: {
labels: {
generateLabels: function (t) {
var e = t.data;
return e.labels.length && e.datasets.length ? e.labels.map(function (i, n) {
var a = t.getDatasetMeta(0), o = e.datasets[0], s = a.data[n], l = s && s.custom || {},
u = r.valueAtIndexOrDefault, d = t.options.elements.arc;
return {
text: i,
fillStyle: l.backgroundColor ? l.backgroundColor : u(o.backgroundColor, n, d.backgroundColor),
strokeStyle: l.borderColor ? l.borderColor : u(o.borderColor, n, d.borderColor),
lineWidth: l.borderWidth ? l.borderWidth : u(o.borderWidth, n, d.borderWidth),
hidden: isNaN(o.data[n]) || a.data[n].hidden,
index: n
}
}) : []
}
}, onClick: function (t, e) {
var i, n, a, r = e.index, o = this.chart;
for (i = 0, n = (o.data.datasets || []).length; i < n; ++i) (a = o.getDatasetMeta(i)).data[r] && (a.data[r].hidden = !a.data[r].hidden);
o.update()
}
},
cutoutPercentage: 50,
rotation: -.5 * Math.PI,
circumference: 2 * Math.PI,
tooltips: {
callbacks: {
title: function () {
return ""
}, label: function (t, e) {
var i = e.labels[t.index], n = ": " + e.datasets[t.datasetIndex].data[t.index];
return r.isArray(i) ? (i = i.slice())[0] += n : i += n, i
}
}
}
}), n._set("pie", r.clone(n.doughnut)), n._set("pie", {cutoutPercentage: 0}), e.exports = function (t) {
t.controllers.doughnut = t.controllers.pie = t.DatasetController.extend({
dataElementType: a.Arc,
linkScales: r.noop,
getRingIndex: function (t) {
for (var e = 0, i = 0; i < t; ++i) this.chart.isDatasetVisible(i) && ++e;
return e
},
update: function (t) {
var e = this, i = e.chart, n = i.chartArea, a = i.options, o = a.elements.arc,
s = n.right - n.left - o.borderWidth, l = n.bottom - n.top - o.borderWidth,
u = Math.min(s, l), d = {x: 0, y: 0}, h = e.getMeta(), c = a.cutoutPercentage,
f = a.circumference;
if (f < 2 * Math.PI) {
var g = a.rotation % (2 * Math.PI),
m = (g += 2 * Math.PI * (g >= Math.PI ? -1 : g < -Math.PI ? 1 : 0)) + f,
p = Math.cos(g), v = Math.sin(g), y = Math.cos(m), b = Math.sin(m),
x = g <= 0 && m >= 0 || g <= 2 * Math.PI && 2 * Math.PI <= m,
_ = g <= .5 * Math.PI && .5 * Math.PI <= m || g <= 2.5 * Math.PI && 2.5 * Math.PI <= m,
k = g <= -Math.PI && -Math.PI <= m || g <= Math.PI && Math.PI <= m,
w = g <= .5 * -Math.PI && .5 * -Math.PI <= m || g <= 1.5 * Math.PI && 1.5 * Math.PI <= m,
M = c / 100, S = k ? -1 : Math.min(p * (p < 0 ? 1 : M), y * (y < 0 ? 1 : M)),
D = w ? -1 : Math.min(v * (v < 0 ? 1 : M), b * (b < 0 ? 1 : M)),
C = x ? 1 : Math.max(p * (p > 0 ? 1 : M), y * (y > 0 ? 1 : M)),
P = _ ? 1 : Math.max(v * (v > 0 ? 1 : M), b * (b > 0 ? 1 : M)), T = .5 * (C - S),
O = .5 * (P - D);
u = Math.min(s / T, l / O), d = {x: -.5 * (C + S), y: -.5 * (P + D)}
}
i.borderWidth = e.getMaxBorderWidth(h.data), i.outerRadius = Math.max((u - i.borderWidth) / 2, 0), i.innerRadius = Math.max(c ? i.outerRadius / 100 * c : 0, 0), i.radiusLength = (i.outerRadius - i.innerRadius) / i.getVisibleDatasetCount(), i.offsetX = d.x * i.outerRadius, i.offsetY = d.y * i.outerRadius, h.total = e.calculateTotal(), e.outerRadius = i.outerRadius - i.radiusLength * e.getRingIndex(e.index), e.innerRadius = Math.max(e.outerRadius - i.radiusLength, 0), r.each(h.data, function (i, n) {
e.updateElement(i, n, t)
})
},
updateElement: function (t, e, i) {
var n = this, a = n.chart, o = a.chartArea, s = a.options, l = s.animation,
u = (o.left + o.right) / 2, d = (o.top + o.bottom) / 2, h = s.rotation, c = s.rotation,
f = n.getDataset(),
g = i && l.animateRotate ? 0 : t.hidden ? 0 : n.calculateCircumference(f.data[e]) * (s.circumference / (2 * Math.PI)),
m = i && l.animateScale ? 0 : n.innerRadius, p = i && l.animateScale ? 0 : n.outerRadius,
v = r.valueAtIndexOrDefault;
r.extend(t, {
_datasetIndex: n.index,
_index: e,
_model: {
x: u + a.offsetX,
y: d + a.offsetY,
startAngle: h,
endAngle: c,
circumference: g,
outerRadius: p,
innerRadius: m,
label: v(f.label, e, a.data.labels[e])
}
});
var y = t._model;
this.removeHoverStyle(t), i && l.animateRotate || (y.startAngle = 0 === e ? s.rotation : n.getMeta().data[e - 1]._model.endAngle, y.endAngle = y.startAngle + y.circumference), t.pivot()
},
removeHoverStyle: function (e) {
t.DatasetController.prototype.removeHoverStyle.call(this, e, this.chart.options.elements.arc)
},
calculateTotal: function () {
var t, e = this.getDataset(), i = this.getMeta(), n = 0;
return r.each(i.data, function (i, a) {
t = e.data[a], isNaN(t) || i.hidden || (n += Math.abs(t))
}), n
},
calculateCircumference: function (t) {
var e = this.getMeta().total;
return e > 0 && !isNaN(t) ? 2 * Math.PI * (Math.abs(t) / e) : 0
},
getMaxBorderWidth: function (t) {
for (var e, i, n = 0, a = this.index, r = t.length, o = 0; o < r; o++) e = t[o]._model ? t[o]._model.borderWidth : 0, n = (i = t[o]._chart ? t[o]._chart.config.data.datasets[a].hoverBorderWidth : 0) > (n = e > n ? e : n) ? i : n;
return n
}
})
}
}, {25: 25, 40: 40, 45: 45}], 18: [function (t, e, i) {
"use strict";
var n = t(25), a = t(40), r = t(45);
n._set("line", {
showLines: !0,
spanGaps: !1,
hover: {mode: "label"},
scales: {xAxes: [{type: "category", id: "x-axis-0"}], yAxes: [{type: "linear", id: "y-axis-0"}]}
}), e.exports = function (t) {
function e(t, e) {
return r.valueOrDefault(t.showLine, e.showLines)
}
t.controllers.line = t.DatasetController.extend({
datasetElementType: a.Line,
dataElementType: a.Point,
update: function (t) {
var i, n, a, o = this, s = o.getMeta(), l = s.dataset, u = s.data || [], d = o.chart.options,
h = d.elements.line, c = o.getScaleForId(s.yAxisID), f = o.getDataset(), g = e(f, d);
for (g && (a = l.custom || {}, void 0 !== f.tension && void 0 === f.lineTension && (f.lineTension = f.tension), l._scale = c, l._datasetIndex = o.index, l._children = u, l._model = {
spanGaps: f.spanGaps ? f.spanGaps : d.spanGaps,
tension: a.tension ? a.tension : r.valueOrDefault(f.lineTension, h.tension),
backgroundColor: a.backgroundColor ? a.backgroundColor : f.backgroundColor || h.backgroundColor,
borderWidth: a.borderWidth ? a.borderWidth : f.borderWidth || h.borderWidth,
borderColor: a.borderColor ? a.borderColor : f.borderColor || h.borderColor,
borderCapStyle: a.borderCapStyle ? a.borderCapStyle : f.borderCapStyle || h.borderCapStyle,
borderDash: a.borderDash ? a.borderDash : f.borderDash || h.borderDash,
borderDashOffset: a.borderDashOffset ? a.borderDashOffset : f.borderDashOffset || h.borderDashOffset,
borderJoinStyle: a.borderJoinStyle ? a.borderJoinStyle : f.borderJoinStyle || h.borderJoinStyle,
fill: a.fill ? a.fill : void 0 !== f.fill ? f.fill : h.fill,
steppedLine: a.steppedLine ? a.steppedLine : r.valueOrDefault(f.steppedLine, h.stepped),
cubicInterpolationMode: a.cubicInterpolationMode ? a.cubicInterpolationMode : r.valueOrDefault(f.cubicInterpolationMode, h.cubicInterpolationMode)
}, l.pivot()), i = 0, n = u.length; i < n; ++i) o.updateElement(u[i], i, t);
for (g && 0 !== l._model.tension && o.updateBezierControlPoints(), i = 0, n = u.length; i < n; ++i) u[i].pivot()
},
getPointBackgroundColor: function (t, e) {
var i = this.chart.options.elements.point.backgroundColor, n = this.getDataset(),
a = t.custom || {};
return a.backgroundColor ? i = a.backgroundColor : n.pointBackgroundColor ? i = r.valueAtIndexOrDefault(n.pointBackgroundColor, e, i) : n.backgroundColor && (i = n.backgroundColor), i
},
getPointBorderColor: function (t, e) {
var i = this.chart.options.elements.point.borderColor, n = this.getDataset(),
a = t.custom || {};
return a.borderColor ? i = a.borderColor : n.pointBorderColor ? i = r.valueAtIndexOrDefault(n.pointBorderColor, e, i) : n.borderColor && (i = n.borderColor), i
},
getPointBorderWidth: function (t, e) {
var i = this.chart.options.elements.point.borderWidth, n = this.getDataset(),
a = t.custom || {};
return isNaN(a.borderWidth) ? !isNaN(n.pointBorderWidth) || r.isArray(n.pointBorderWidth) ? i = r.valueAtIndexOrDefault(n.pointBorderWidth, e, i) : isNaN(n.borderWidth) || (i = n.borderWidth) : i = a.borderWidth, i
},
updateElement: function (t, e, i) {
var n, a, o = this, s = o.getMeta(), l = t.custom || {}, u = o.getDataset(), d = o.index,
h = u.data[e], c = o.getScaleForId(s.yAxisID), f = o.getScaleForId(s.xAxisID),
g = o.chart.options.elements.point;
void 0 !== u.radius && void 0 === u.pointRadius && (u.pointRadius = u.radius), void 0 !== u.hitRadius && void 0 === u.pointHitRadius && (u.pointHitRadius = u.hitRadius), n = f.getPixelForValue("object" == typeof h ? h : NaN, e, d), a = i ? c.getBasePixel() : o.calculatePointY(h, e, d), t._xScale = f, t._yScale = c, t._datasetIndex = d, t._index = e, t._model = {
x: n,
y: a,
skip: l.skip || isNaN(n) || isNaN(a),
radius: l.radius || r.valueAtIndexOrDefault(u.pointRadius, e, g.radius),
pointStyle: l.pointStyle || r.valueAtIndexOrDefault(u.pointStyle, e, g.pointStyle),
backgroundColor: o.getPointBackgroundColor(t, e),
borderColor: o.getPointBorderColor(t, e),
borderWidth: o.getPointBorderWidth(t, e),
tension: s.dataset._model ? s.dataset._model.tension : 0,
steppedLine: !!s.dataset._model && s.dataset._model.steppedLine,
hitRadius: l.hitRadius || r.valueAtIndexOrDefault(u.pointHitRadius, e, g.hitRadius)
}
},
calculatePointY: function (t, e, i) {
var n, a, r, o = this.chart, s = this.getMeta(), l = this.getScaleForId(s.yAxisID), u = 0,
d = 0;
if (l.options.stacked) {
for (n = 0; n < i; n++) if (a = o.data.datasets[n], "line" === (r = o.getDatasetMeta(n)).type && r.yAxisID === l.id && o.isDatasetVisible(n)) {
var h = Number(l.getRightValue(a.data[e]));
h < 0 ? d += h || 0 : u += h || 0
}
var c = Number(l.getRightValue(t));
return c < 0 ? l.getPixelForValue(d + c) : l.getPixelForValue(u + c)
}
return l.getPixelForValue(t)
},
updateBezierControlPoints: function () {
var t, e, i, n, a = this.getMeta(), o = this.chart.chartArea, s = a.data || [];
function l(t, e, i) {
return Math.max(Math.min(t, i), e)
}
if (a.dataset._model.spanGaps && (s = s.filter(function (t) {
return !t._model.skip
})), "monotone" === a.dataset._model.cubicInterpolationMode) r.splineCurveMonotone(s); else for (t = 0, e = s.length; t < e; ++t) i = s[t]._model, n = r.splineCurve(r.previousItem(s, t)._model, i, r.nextItem(s, t)._model, a.dataset._model.tension), i.controlPointPreviousX = n.previous.x, i.controlPointPreviousY = n.previous.y, i.controlPointNextX = n.next.x, i.controlPointNextY = n.next.y;
if (this.chart.options.elements.line.capBezierPoints) for (t = 0, e = s.length; t < e; ++t) (i = s[t]._model).controlPointPreviousX = l(i.controlPointPreviousX, o.left, o.right), i.controlPointPreviousY = l(i.controlPointPreviousY, o.top, o.bottom), i.controlPointNextX = l(i.controlPointNextX, o.left, o.right), i.controlPointNextY = l(i.controlPointNextY, o.top, o.bottom)
},
draw: function () {
var t = this.chart, i = this.getMeta(), n = i.data || [], a = t.chartArea, o = n.length, s = 0;
for (r.canvas.clipArea(t.ctx, a), e(this.getDataset(), t.options) && i.dataset.draw(), r.canvas.unclipArea(t.ctx); s < o; ++s) n[s].draw(a)
},
setHoverStyle: function (t) {
var e = this.chart.data.datasets[t._datasetIndex], i = t._index, n = t.custom || {},
a = t._model;
a.radius = n.hoverRadius || r.valueAtIndexOrDefault(e.pointHoverRadius, i, this.chart.options.elements.point.hoverRadius), a.backgroundColor = n.hoverBackgroundColor || r.valueAtIndexOrDefault(e.pointHoverBackgroundColor, i, r.getHoverColor(a.backgroundColor)), a.borderColor = n.hoverBorderColor || r.valueAtIndexOrDefault(e.pointHoverBorderColor, i, r.getHoverColor(a.borderColor)), a.borderWidth = n.hoverBorderWidth || r.valueAtIndexOrDefault(e.pointHoverBorderWidth, i, a.borderWidth)
},
removeHoverStyle: function (t) {
var e = this, i = e.chart.data.datasets[t._datasetIndex], n = t._index, a = t.custom || {},
o = t._model;
void 0 !== i.radius && void 0 === i.pointRadius && (i.pointRadius = i.radius), o.radius = a.radius || r.valueAtIndexOrDefault(i.pointRadius, n, e.chart.options.elements.point.radius), o.backgroundColor = e.getPointBackgroundColor(t, n), o.borderColor = e.getPointBorderColor(t, n), o.borderWidth = e.getPointBorderWidth(t, n)
}
})
}
}, {25: 25, 40: 40, 45: 45}], 19: [function (t, e, i) {
"use strict";
var n = t(25), a = t(40), r = t(45);
n._set("polarArea", {
scale: {
type: "radialLinear",
angleLines: {display: !1},
gridLines: {circular: !0},
pointLabels: {display: !1},
ticks: {beginAtZero: !0}
},
animation: {animateRotate: !0, animateScale: !0},
startAngle: -.5 * Math.PI,
legendCallback: function (t) {
var e = [];
e.push('');
var i = t.data, n = i.datasets, a = i.labels;
if (n.length) for (var r = 0; r < n[0].data.length; ++r) e.push('- '), a[r] && e.push(a[r]), e.push("
");
return e.push("
"), e.join("")
},
legend: {
labels: {
generateLabels: function (t) {
var e = t.data;
return e.labels.length && e.datasets.length ? e.labels.map(function (i, n) {
var a = t.getDatasetMeta(0), o = e.datasets[0], s = a.data[n].custom || {},
l = r.valueAtIndexOrDefault, u = t.options.elements.arc;
return {
text: i,
fillStyle: s.backgroundColor ? s.backgroundColor : l(o.backgroundColor, n, u.backgroundColor),
strokeStyle: s.borderColor ? s.borderColor : l(o.borderColor, n, u.borderColor),
lineWidth: s.borderWidth ? s.borderWidth : l(o.borderWidth, n, u.borderWidth),
hidden: isNaN(o.data[n]) || a.data[n].hidden,
index: n
}
}) : []
}
}, onClick: function (t, e) {
var i, n, a, r = e.index, o = this.chart;
for (i = 0, n = (o.data.datasets || []).length; i < n; ++i) (a = o.getDatasetMeta(i)).data[r].hidden = !a.data[r].hidden;
o.update()
}
},
tooltips: {
callbacks: {
title: function () {
return ""
}, label: function (t, e) {
return e.labels[t.index] + ": " + t.yLabel
}
}
}
}), e.exports = function (t) {
t.controllers.polarArea = t.DatasetController.extend({
dataElementType: a.Arc,
linkScales: r.noop,
update: function (t) {
var e = this, i = e.chart, n = i.chartArea, a = e.getMeta(), o = i.options, s = o.elements.arc,
l = Math.min(n.right - n.left, n.bottom - n.top);
i.outerRadius = Math.max((l - s.borderWidth / 2) / 2, 0), i.innerRadius = Math.max(o.cutoutPercentage ? i.outerRadius / 100 * o.cutoutPercentage : 1, 0), i.radiusLength = (i.outerRadius - i.innerRadius) / i.getVisibleDatasetCount(), e.outerRadius = i.outerRadius - i.radiusLength * e.index, e.innerRadius = e.outerRadius - i.radiusLength, a.count = e.countVisibleElements(), r.each(a.data, function (i, n) {
e.updateElement(i, n, t)
})
},
updateElement: function (t, e, i) {
for (var n = this, a = n.chart, o = n.getDataset(), s = a.options, l = s.animation, u = a.scale, d = a.data.labels, h = n.calculateCircumference(o.data[e]), c = u.xCenter, f = u.yCenter, g = 0, m = n.getMeta(), p = 0; p < e; ++p) isNaN(o.data[p]) || m.data[p].hidden || ++g;
var v = s.startAngle, y = t.hidden ? 0 : u.getDistanceFromCenterForValue(o.data[e]),
b = v + h * g, x = b + (t.hidden ? 0 : h),
_ = l.animateScale ? 0 : u.getDistanceFromCenterForValue(o.data[e]);
r.extend(t, {
_datasetIndex: n.index,
_index: e,
_scale: u,
_model: {
x: c,
y: f,
innerRadius: 0,
outerRadius: i ? _ : y,
startAngle: i && l.animateRotate ? v : b,
endAngle: i && l.animateRotate ? v : x,
label: r.valueAtIndexOrDefault(d, e, d[e])
}
}), n.removeHoverStyle(t), t.pivot()
},
removeHoverStyle: function (e) {
t.DatasetController.prototype.removeHoverStyle.call(this, e, this.chart.options.elements.arc)
},
countVisibleElements: function () {
var t = this.getDataset(), e = this.getMeta(), i = 0;
return r.each(e.data, function (e, n) {
isNaN(t.data[n]) || e.hidden || i++
}), i
},
calculateCircumference: function (t) {
var e = this.getMeta().count;
return e > 0 && !isNaN(t) ? 2 * Math.PI / e : 0
}
})
}
}, {25: 25, 40: 40, 45: 45}], 20: [function (t, e, i) {
"use strict";
var n = t(25), a = t(40), r = t(45);
n._set("radar", {scale: {type: "radialLinear"}, elements: {line: {tension: 0}}}), e.exports = function (t) {
t.controllers.radar = t.DatasetController.extend({
datasetElementType: a.Line,
dataElementType: a.Point,
linkScales: r.noop,
update: function (t) {
var e = this, i = e.getMeta(), n = i.dataset, a = i.data, o = n.custom || {},
s = e.getDataset(), l = e.chart.options.elements.line, u = e.chart.scale;
void 0 !== s.tension && void 0 === s.lineTension && (s.lineTension = s.tension), r.extend(i.dataset, {
_datasetIndex: e.index,
_scale: u,
_children: a,
_loop: !0,
_model: {
tension: o.tension ? o.tension : r.valueOrDefault(s.lineTension, l.tension),
backgroundColor: o.backgroundColor ? o.backgroundColor : s.backgroundColor || l.backgroundColor,
borderWidth: o.borderWidth ? o.borderWidth : s.borderWidth || l.borderWidth,
borderColor: o.borderColor ? o.borderColor : s.borderColor || l.borderColor,
fill: o.fill ? o.fill : void 0 !== s.fill ? s.fill : l.fill,
borderCapStyle: o.borderCapStyle ? o.borderCapStyle : s.borderCapStyle || l.borderCapStyle,
borderDash: o.borderDash ? o.borderDash : s.borderDash || l.borderDash,
borderDashOffset: o.borderDashOffset ? o.borderDashOffset : s.borderDashOffset || l.borderDashOffset,
borderJoinStyle: o.borderJoinStyle ? o.borderJoinStyle : s.borderJoinStyle || l.borderJoinStyle
}
}), i.dataset.pivot(), r.each(a, function (i, n) {
e.updateElement(i, n, t)
}, e), e.updateBezierControlPoints()
},
updateElement: function (t, e, i) {
var n = this, a = t.custom || {}, o = n.getDataset(), s = n.chart.scale,
l = n.chart.options.elements.point, u = s.getPointPositionForValue(e, o.data[e]);
void 0 !== o.radius && void 0 === o.pointRadius && (o.pointRadius = o.radius), void 0 !== o.hitRadius && void 0 === o.pointHitRadius && (o.pointHitRadius = o.hitRadius), r.extend(t, {
_datasetIndex: n.index,
_index: e,
_scale: s,
_model: {
x: i ? s.xCenter : u.x,
y: i ? s.yCenter : u.y,
tension: a.tension ? a.tension : r.valueOrDefault(o.lineTension, n.chart.options.elements.line.tension),
radius: a.radius ? a.radius : r.valueAtIndexOrDefault(o.pointRadius, e, l.radius),
backgroundColor: a.backgroundColor ? a.backgroundColor : r.valueAtIndexOrDefault(o.pointBackgroundColor, e, l.backgroundColor),
borderColor: a.borderColor ? a.borderColor : r.valueAtIndexOrDefault(o.pointBorderColor, e, l.borderColor),
borderWidth: a.borderWidth ? a.borderWidth : r.valueAtIndexOrDefault(o.pointBorderWidth, e, l.borderWidth),
pointStyle: a.pointStyle ? a.pointStyle : r.valueAtIndexOrDefault(o.pointStyle, e, l.pointStyle),
hitRadius: a.hitRadius ? a.hitRadius : r.valueAtIndexOrDefault(o.pointHitRadius, e, l.hitRadius)
}
}), t._model.skip = a.skip ? a.skip : isNaN(t._model.x) || isNaN(t._model.y)
},
updateBezierControlPoints: function () {
var t = this.chart.chartArea, e = this.getMeta();
r.each(e.data, function (i, n) {
var a = i._model,
o = r.splineCurve(r.previousItem(e.data, n, !0)._model, a, r.nextItem(e.data, n, !0)._model, a.tension);
a.controlPointPreviousX = Math.max(Math.min(o.previous.x, t.right), t.left), a.controlPointPreviousY = Math.max(Math.min(o.previous.y, t.bottom), t.top), a.controlPointNextX = Math.max(Math.min(o.next.x, t.right), t.left), a.controlPointNextY = Math.max(Math.min(o.next.y, t.bottom), t.top), i.pivot()
})
},
setHoverStyle: function (t) {
var e = this.chart.data.datasets[t._datasetIndex], i = t.custom || {}, n = t._index,
a = t._model;
a.radius = i.hoverRadius ? i.hoverRadius : r.valueAtIndexOrDefault(e.pointHoverRadius, n, this.chart.options.elements.point.hoverRadius), a.backgroundColor = i.hoverBackgroundColor ? i.hoverBackgroundColor : r.valueAtIndexOrDefault(e.pointHoverBackgroundColor, n, r.getHoverColor(a.backgroundColor)), a.borderColor = i.hoverBorderColor ? i.hoverBorderColor : r.valueAtIndexOrDefault(e.pointHoverBorderColor, n, r.getHoverColor(a.borderColor)), a.borderWidth = i.hoverBorderWidth ? i.hoverBorderWidth : r.valueAtIndexOrDefault(e.pointHoverBorderWidth, n, a.borderWidth)
},
removeHoverStyle: function (t) {
var e = this.chart.data.datasets[t._datasetIndex], i = t.custom || {}, n = t._index,
a = t._model, o = this.chart.options.elements.point;
a.radius = i.radius ? i.radius : r.valueAtIndexOrDefault(e.pointRadius, n, o.radius), a.backgroundColor = i.backgroundColor ? i.backgroundColor : r.valueAtIndexOrDefault(e.pointBackgroundColor, n, o.backgroundColor), a.borderColor = i.borderColor ? i.borderColor : r.valueAtIndexOrDefault(e.pointBorderColor, n, o.borderColor), a.borderWidth = i.borderWidth ? i.borderWidth : r.valueAtIndexOrDefault(e.pointBorderWidth, n, o.borderWidth)
}
})
}
}, {25: 25, 40: 40, 45: 45}], 21: [function (t, e, i) {
"use strict";
t(25)._set("scatter", {
hover: {mode: "single"},
scales: {
xAxes: [{id: "x-axis-1", type: "linear", position: "bottom"}],
yAxes: [{id: "y-axis-1", type: "linear", position: "left"}]
},
showLines: !1,
tooltips: {
callbacks: {
title: function () {
return ""
}, label: function (t) {
return "(" + t.xLabel + ", " + t.yLabel + ")"
}
}
}
}), e.exports = function (t) {
t.controllers.scatter = t.controllers.line
}
}, {25: 25}], 22: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26), r = t(45);
n._set("global", {
animation: {
duration: 1e3,
easing: "easeOutQuart",
onProgress: r.noop,
onComplete: r.noop
}
}), e.exports = function (t) {
t.Animation = a.extend({
chart: null,
currentStep: 0,
numSteps: 60,
easing: "",
render: null,
onAnimationProgress: null,
onAnimationComplete: null
}), t.animationService = {
frameDuration: 17,
animations: [],
dropFrames: 0,
request: null,
addAnimation: function (t, e, i, n) {
var a, r, o = this.animations;
for (e.chart = t, n || (t.animating = !0), a = 0, r = o.length; a < r; ++a) if (o[a].chart === t) return void(o[a] = e);
o.push(e), 1 === o.length && this.requestAnimationFrame()
},
cancelAnimation: function (t) {
var e = r.findIndex(this.animations, function (e) {
return e.chart === t
});
-1 !== e && (this.animations.splice(e, 1), t.animating = !1)
},
requestAnimationFrame: function () {
var t = this;
null === t.request && (t.request = r.requestAnimFrame.call(window, function () {
t.request = null, t.startDigest()
}))
},
startDigest: function () {
var t = this, e = Date.now(), i = 0;
t.dropFrames > 1 && (i = Math.floor(t.dropFrames), t.dropFrames = t.dropFrames % 1), t.advance(1 + i);
var n = Date.now();
t.dropFrames += (n - e) / t.frameDuration, t.animations.length > 0 && t.requestAnimationFrame()
},
advance: function (t) {
for (var e, i, n = this.animations, a = 0; a < n.length;) i = (e = n[a]).chart, e.currentStep = (e.currentStep || 0) + t, e.currentStep = Math.min(e.currentStep, e.numSteps), r.callback(e.render, [i, e], i), r.callback(e.onAnimationProgress, [e], i), e.currentStep >= e.numSteps ? (r.callback(e.onAnimationComplete, [e], i), i.animating = !1, n.splice(a, 1)) : ++a
}
}, Object.defineProperty(t.Animation.prototype, "animationObject", {
get: function () {
return this
}
}), Object.defineProperty(t.Animation.prototype, "chartInstance", {
get: function () {
return this.chart
}, set: function (t) {
this.chart = t
}
})
}
}, {25: 25, 26: 26, 45: 45}], 23: [function (t, e, i) {
"use strict";
var n = t(25), a = t(45), r = t(28), o = t(30), s = t(48), l = t(31);
e.exports = function (t) {
function e(t) {
return "top" === t || "bottom" === t
}
t.types = {}, t.instances = {}, t.controllers = {}, a.extend(t.prototype, {
construct: function (e, i) {
var r, o, l = this;
(o = (r = (r = i) || {}).data = r.data || {}).datasets = o.datasets || [], o.labels = o.labels || [], r.options = a.configMerge(n.global, n[r.type], r.options || {}), i = r;
var u = s.acquireContext(e, i), d = u && u.canvas, h = d && d.height, c = d && d.width;
l.id = a.uid(), l.ctx = u, l.canvas = d, l.config = i, l.width = c, l.height = h, l.aspectRatio = h ? c / h : null, l.options = i.options, l._bufferedRender = !1, l.chart = l, l.controller = l, t.instances[l.id] = l, Object.defineProperty(l, "data", {
get: function () {
return l.config.data
}, set: function (t) {
l.config.data = t
}
}), u && d ? (l.initialize(), l.update()) : console.error("Failed to create chart: can't acquire context from the given item")
}, initialize: function () {
var t = this;
return l.notify(t, "beforeInit"), a.retinaScale(t, t.options.devicePixelRatio), t.bindEvents(), t.options.responsive && t.resize(!0), t.ensureScalesHaveIDs(), t.buildOrUpdateScales(), t.initToolTip(), l.notify(t, "afterInit"), t
}, clear: function () {
return a.canvas.clear(this), this
}, stop: function () {
return t.animationService.cancelAnimation(this), this
}, resize: function (t) {
var e = this, i = e.options, n = e.canvas, r = i.maintainAspectRatio && e.aspectRatio || null,
o = Math.max(0, Math.floor(a.getMaximumWidth(n))),
s = Math.max(0, Math.floor(r ? o / r : a.getMaximumHeight(n)));
if ((e.width !== o || e.height !== s) && (n.width = e.width = o, n.height = e.height = s, n.style.width = o + "px", n.style.height = s + "px", a.retinaScale(e, i.devicePixelRatio), !t)) {
var u = {width: o, height: s};
l.notify(e, "resize", [u]), e.options.onResize && e.options.onResize(e, u), e.stop(), e.update(e.options.responsiveAnimationDuration)
}
}, ensureScalesHaveIDs: function () {
var t = this.options, e = t.scales || {}, i = t.scale;
a.each(e.xAxes, function (t, e) {
t.id = t.id || "x-axis-" + e
}), a.each(e.yAxes, function (t, e) {
t.id = t.id || "y-axis-" + e
}), i && (i.id = i.id || "scale")
}, buildOrUpdateScales: function () {
var i = this, n = i.options, r = i.scales || {}, o = [],
s = Object.keys(r).reduce(function (t, e) {
return t[e] = !1, t
}, {});
n.scales && (o = o.concat((n.scales.xAxes || []).map(function (t) {
return {options: t, dtype: "category", dposition: "bottom"}
}), (n.scales.yAxes || []).map(function (t) {
return {options: t, dtype: "linear", dposition: "left"}
}))), n.scale && o.push({
options: n.scale,
dtype: "radialLinear",
isDefault: !0,
dposition: "chartArea"
}), a.each(o, function (n) {
var o = n.options, l = o.id, u = a.valueOrDefault(o.type, n.dtype);
e(o.position) !== e(n.dposition) && (o.position = n.dposition), s[l] = !0;
var d = null;
if (l in r && r[l].type === u) (d = r[l]).options = o, d.ctx = i.ctx, d.chart = i; else {
var h = t.scaleService.getScaleConstructor(u);
if (!h) return;
d = new h({id: l, type: u, options: o, ctx: i.ctx, chart: i}), r[d.id] = d
}
d.mergeTicksOptions(), n.isDefault && (i.scale = d)
}), a.each(s, function (t, e) {
t || delete r[e]
}), i.scales = r, t.scaleService.addScalesToLayout(this)
}, buildOrUpdateControllers: function () {
var e = this, i = [], n = [];
return a.each(e.data.datasets, function (a, r) {
var o = e.getDatasetMeta(r), s = a.type || e.config.type;
if (o.type && o.type !== s && (e.destroyDatasetMeta(r), o = e.getDatasetMeta(r)), o.type = s, i.push(o.type), o.controller) o.controller.updateIndex(r), o.controller.linkScales(); else {
var l = t.controllers[o.type];
if (void 0 === l) throw new Error('"' + o.type + '" is not a chart type.');
o.controller = new l(e, r), n.push(o.controller)
}
}, e), n
}, resetElements: function () {
var t = this;
a.each(t.data.datasets, function (e, i) {
t.getDatasetMeta(i).controller.reset()
}, t)
}, reset: function () {
this.resetElements(), this.tooltip.initialize()
}, update: function (e) {
var i, n, r = this;
if (e && "object" == typeof e || (e = {
duration: e,
lazy: arguments[1]
}), n = (i = r).options, a.each(i.scales, function (t) {
o.removeBox(i, t)
}), n = a.configMerge(t.defaults.global, t.defaults[i.config.type], n), i.options = i.config.options = n, i.ensureScalesHaveIDs(), i.buildOrUpdateScales(), i.tooltip._options = n.tooltips, i.tooltip.initialize(), l._invalidate(r), !1 !== l.notify(r, "beforeUpdate")) {
r.tooltip._data = r.data;
var s = r.buildOrUpdateControllers();
a.each(r.data.datasets, function (t, e) {
r.getDatasetMeta(e).controller.buildOrUpdateElements()
}, r), r.updateLayout(), r.options.animation && r.options.animation.duration && a.each(s, function (t) {
t.reset()
}), r.updateDatasets(), r.tooltip.initialize(), r.lastActive = [], l.notify(r, "afterUpdate"), r._bufferedRender ? r._bufferedRequest = {
duration: e.duration,
easing: e.easing,
lazy: e.lazy
} : r.render(e)
}
}, updateLayout: function () {
!1 !== l.notify(this, "beforeLayout") && (o.update(this, this.width, this.height), l.notify(this, "afterScaleUpdate"), l.notify(this, "afterLayout"))
}, updateDatasets: function () {
if (!1 !== l.notify(this, "beforeDatasetsUpdate")) {
for (var t = 0, e = this.data.datasets.length; t < e; ++t) this.updateDataset(t);
l.notify(this, "afterDatasetsUpdate")
}
}, updateDataset: function (t) {
var e = this.getDatasetMeta(t), i = {meta: e, index: t};
!1 !== l.notify(this, "beforeDatasetUpdate", [i]) && (e.controller.update(), l.notify(this, "afterDatasetUpdate", [i]))
}, render: function (e) {
var i = this;
e && "object" == typeof e || (e = {duration: e, lazy: arguments[1]});
var n = e.duration, r = e.lazy;
if (!1 !== l.notify(i, "beforeRender")) {
var o = i.options.animation, s = function (t) {
l.notify(i, "afterRender"), a.callback(o && o.onComplete, [t], i)
};
if (o && (void 0 !== n && 0 !== n || void 0 === n && 0 !== o.duration)) {
var u = new t.Animation({
numSteps: (n || o.duration) / 16.66,
easing: e.easing || o.easing,
render: function (t, e) {
var i = a.easing.effects[e.easing], n = e.currentStep, r = n / e.numSteps;
t.draw(i(r), r, n)
},
onAnimationProgress: o.onProgress,
onAnimationComplete: s
});
t.animationService.addAnimation(i, u, n, r)
} else i.draw(), s(new t.Animation({numSteps: 0, chart: i}));
return i
}
}, draw: function (t) {
var e = this;
e.clear(), a.isNullOrUndef(t) && (t = 1), e.transition(t), !1 !== l.notify(e, "beforeDraw", [t]) && (a.each(e.boxes, function (t) {
t.draw(e.chartArea)
}, e), e.scale && e.scale.draw(), e.drawDatasets(t), e._drawTooltip(t), l.notify(e, "afterDraw", [t]))
}, transition: function (t) {
for (var e = 0, i = (this.data.datasets || []).length; e < i; ++e) this.isDatasetVisible(e) && this.getDatasetMeta(e).controller.transition(t);
this.tooltip.transition(t)
}, drawDatasets: function (t) {
var e = this;
if (!1 !== l.notify(e, "beforeDatasetsDraw", [t])) {
for (var i = (e.data.datasets || []).length - 1; i >= 0; --i) e.isDatasetVisible(i) && e.drawDataset(i, t);
l.notify(e, "afterDatasetsDraw", [t])
}
}, drawDataset: function (t, e) {
var i = this.getDatasetMeta(t), n = {meta: i, index: t, easingValue: e};
!1 !== l.notify(this, "beforeDatasetDraw", [n]) && (i.controller.draw(e), l.notify(this, "afterDatasetDraw", [n]))
}, _drawTooltip: function (t) {
var e = this.tooltip, i = {tooltip: e, easingValue: t};
!1 !== l.notify(this, "beforeTooltipDraw", [i]) && (e.draw(), l.notify(this, "afterTooltipDraw", [i]))
}, getElementAtEvent: function (t) {
return r.modes.single(this, t)
}, getElementsAtEvent: function (t) {
return r.modes.label(this, t, {intersect: !0})
}, getElementsAtXAxis: function (t) {
return r.modes["x-axis"](this, t, {intersect: !0})
}, getElementsAtEventForMode: function (t, e, i) {
var n = r.modes[e];
return "function" == typeof n ? n(this, t, i) : []
}, getDatasetAtEvent: function (t) {
return r.modes.dataset(this, t, {intersect: !0})
}, getDatasetMeta: function (t) {
var e = this.data.datasets[t];
e._meta || (e._meta = {});
var i = e._meta[this.id];
return i || (i = e._meta[this.id] = {
type: null,
data: [],
dataset: null,
controller: null,
hidden: null,
xAxisID: null,
yAxisID: null
}), i
}, getVisibleDatasetCount: function () {
for (var t = 0, e = 0, i = this.data.datasets.length; e < i; ++e) this.isDatasetVisible(e) && t++;
return t
}, isDatasetVisible: function (t) {
var e = this.getDatasetMeta(t);
return "boolean" == typeof e.hidden ? !e.hidden : !this.data.datasets[t].hidden
}, generateLegend: function () {
return this.options.legendCallback(this)
}, destroyDatasetMeta: function (t) {
var e = this.id, i = this.data.datasets[t], n = i._meta && i._meta[e];
n && (n.controller.destroy(), delete i._meta[e])
}, destroy: function () {
var e, i, n = this, r = n.canvas;
for (n.stop(), e = 0, i = n.data.datasets.length; e < i; ++e) n.destroyDatasetMeta(e);
r && (n.unbindEvents(), a.canvas.clear(n), s.releaseContext(n.ctx), n.canvas = null, n.ctx = null), l.notify(n, "destroy"), delete t.instances[n.id]
}, toBase64Image: function () {
return this.canvas.toDataURL.apply(this.canvas, arguments)
}, initToolTip: function () {
var e = this;
e.tooltip = new t.Tooltip({
_chart: e,
_chartInstance: e,
_data: e.data,
_options: e.options.tooltips
}, e)
}, bindEvents: function () {
var t = this, e = t._listeners = {}, i = function () {
t.eventHandler.apply(t, arguments)
};
a.each(t.options.events, function (n) {
s.addEventListener(t, n, i), e[n] = i
}), t.options.responsive && (i = function () {
t.resize()
}, s.addEventListener(t, "resize", i), e.resize = i)
}, unbindEvents: function () {
var t = this, e = t._listeners;
e && (delete t._listeners, a.each(e, function (e, i) {
s.removeEventListener(t, i, e)
}))
}, updateHoverStyle: function (t, e, i) {
var n, a, r, o = i ? "setHoverStyle" : "removeHoverStyle";
for (a = 0, r = t.length; a < r; ++a) (n = t[a]) && this.getDatasetMeta(n._datasetIndex).controller[o](n)
}, eventHandler: function (t) {
var e = this, i = e.tooltip;
if (!1 !== l.notify(e, "beforeEvent", [t])) {
e._bufferedRender = !0, e._bufferedRequest = null;
var n = e.handleEvent(t);
i && (n = i._start ? i.handleEvent(t) : n | i.handleEvent(t)), l.notify(e, "afterEvent", [t]);
var a = e._bufferedRequest;
return a ? e.render(a) : n && !e.animating && (e.stop(), e.render(e.options.hover.animationDuration, !0)), e._bufferedRender = !1, e._bufferedRequest = null, e
}
}, handleEvent: function (t) {
var e, i = this, n = i.options || {}, r = n.hover;
return i.lastActive = i.lastActive || [], "mouseout" === t.type ? i.active = [] : i.active = i.getElementsAtEventForMode(t, r.mode, r), a.callback(n.onHover || n.hover.onHover, [t.native, i.active], i), "mouseup" !== t.type && "click" !== t.type || n.onClick && n.onClick.call(i, t.native, i.active), i.lastActive.length && i.updateHoverStyle(i.lastActive, r.mode, !1), i.active.length && r.mode && i.updateHoverStyle(i.active, r.mode, !0), e = !a.arrayEquals(i.active, i.lastActive), i.lastActive = i.active, e
}
}), t.Controller = t
}
}, {25: 25, 28: 28, 30: 30, 31: 31, 45: 45, 48: 48}], 24: [function (t, e, i) {
"use strict";
var n = t(45);
e.exports = function (t) {
var e = ["push", "pop", "shift", "splice", "unshift"];
function i(t, i) {
var n = t._chartjs;
if (n) {
var a = n.listeners, r = a.indexOf(i);
-1 !== r && a.splice(r, 1), a.length > 0 || (e.forEach(function (e) {
delete t[e]
}), delete t._chartjs)
}
}
t.DatasetController = function (t, e) {
this.initialize(t, e)
}, n.extend(t.DatasetController.prototype, {
datasetElementType: null,
dataElementType: null,
initialize: function (t, e) {
this.chart = t, this.index = e, this.linkScales(), this.addElements()
},
updateIndex: function (t) {
this.index = t
},
linkScales: function () {
var t = this, e = t.getMeta(), i = t.getDataset();
null !== e.xAxisID && e.xAxisID in t.chart.scales || (e.xAxisID = i.xAxisID || t.chart.options.scales.xAxes[0].id), null !== e.yAxisID && e.yAxisID in t.chart.scales || (e.yAxisID = i.yAxisID || t.chart.options.scales.yAxes[0].id)
},
getDataset: function () {
return this.chart.data.datasets[this.index]
},
getMeta: function () {
return this.chart.getDatasetMeta(this.index)
},
getScaleForId: function (t) {
return this.chart.scales[t]
},
reset: function () {
this.update(!0)
},
destroy: function () {
this._data && i(this._data, this)
},
createMetaDataset: function () {
var t = this.datasetElementType;
return t && new t({_chart: this.chart, _datasetIndex: this.index})
},
createMetaData: function (t) {
var e = this.dataElementType;
return e && new e({_chart: this.chart, _datasetIndex: this.index, _index: t})
},
addElements: function () {
var t, e, i = this.getMeta(), n = this.getDataset().data || [], a = i.data;
for (t = 0, e = n.length; t < e; ++t) a[t] = a[t] || this.createMetaData(t);
i.dataset = i.dataset || this.createMetaDataset()
},
addElementAndReset: function (t) {
var e = this.createMetaData(t);
this.getMeta().data.splice(t, 0, e), this.updateElement(e, t, !0)
},
buildOrUpdateElements: function () {
var t, a, r = this, o = r.getDataset(), s = o.data || (o.data = []);
r._data !== s && (r._data && i(r._data, r), a = r, (t = s)._chartjs ? t._chartjs.listeners.push(a) : (Object.defineProperty(t, "_chartjs", {
configurable: !0,
enumerable: !1,
value: {listeners: [a]}
}), e.forEach(function (e) {
var i = "onData" + e.charAt(0).toUpperCase() + e.slice(1), a = t[e];
Object.defineProperty(t, e, {
configurable: !0, enumerable: !1, value: function () {
var e = Array.prototype.slice.call(arguments), r = a.apply(this, e);
return n.each(t._chartjs.listeners, function (t) {
"function" == typeof t[i] && t[i].apply(t, e)
}), r
}
})
})), r._data = s), r.resyncElements()
},
update: n.noop,
transition: function (t) {
for (var e = this.getMeta(), i = e.data || [], n = i.length, a = 0; a < n; ++a) i[a].transition(t);
e.dataset && e.dataset.transition(t)
},
draw: function () {
var t = this.getMeta(), e = t.data || [], i = e.length, n = 0;
for (t.dataset && t.dataset.draw(); n < i; ++n) e[n].draw()
},
removeHoverStyle: function (t, e) {
var i = this.chart.data.datasets[t._datasetIndex], a = t._index, r = t.custom || {},
o = n.valueAtIndexOrDefault, s = t._model;
s.backgroundColor = r.backgroundColor ? r.backgroundColor : o(i.backgroundColor, a, e.backgroundColor), s.borderColor = r.borderColor ? r.borderColor : o(i.borderColor, a, e.borderColor), s.borderWidth = r.borderWidth ? r.borderWidth : o(i.borderWidth, a, e.borderWidth)
},
setHoverStyle: function (t) {
var e = this.chart.data.datasets[t._datasetIndex], i = t._index, a = t.custom || {},
r = n.valueAtIndexOrDefault, o = n.getHoverColor, s = t._model;
s.backgroundColor = a.hoverBackgroundColor ? a.hoverBackgroundColor : r(e.hoverBackgroundColor, i, o(s.backgroundColor)), s.borderColor = a.hoverBorderColor ? a.hoverBorderColor : r(e.hoverBorderColor, i, o(s.borderColor)), s.borderWidth = a.hoverBorderWidth ? a.hoverBorderWidth : r(e.hoverBorderWidth, i, s.borderWidth)
},
resyncElements: function () {
var t = this.getMeta(), e = this.getDataset().data, i = t.data.length, n = e.length;
n < i ? t.data.splice(n, i - n) : n > i && this.insertElements(i, n - i)
},
insertElements: function (t, e) {
for (var i = 0; i < e; ++i) this.addElementAndReset(t + i)
},
onDataPush: function () {
this.insertElements(this.getDataset().data.length - 1, arguments.length)
},
onDataPop: function () {
this.getMeta().data.pop()
},
onDataShift: function () {
this.getMeta().data.shift()
},
onDataSplice: function (t, e) {
this.getMeta().data.splice(t, e), this.insertElements(t, arguments.length - 2)
},
onDataUnshift: function () {
this.insertElements(0, arguments.length)
}
}), t.DatasetController.extend = n.inherits
}
}, {45: 45}], 25: [function (t, e, i) {
"use strict";
var n = t(45);
e.exports = {
_set: function (t, e) {
return n.merge(this[t] || (this[t] = {}), e)
}
}
}, {45: 45}], 26: [function (t, e, i) {
"use strict";
var n = t(2), a = t(45);
var r = function (t) {
a.extend(this, t), this.initialize.apply(this, arguments)
};
a.extend(r.prototype, {
initialize: function () {
this.hidden = !1
}, pivot: function () {
var t = this;
return t._view || (t._view = a.clone(t._model)), t._start = {}, t
}, transition: function (t) {
var e = this, i = e._model, a = e._start, r = e._view;
return i && 1 !== t ? (r || (r = e._view = {}), a || (a = e._start = {}), function (t, e, i, a) {
var r, o, s, l, u, d, h, c, f, g = Object.keys(i);
for (r = 0, o = g.length; r < o; ++r) if (d = i[s = g[r]], e.hasOwnProperty(s) || (e[s] = d), (l = e[s]) !== d && "_" !== s[0]) {
if (t.hasOwnProperty(s) || (t[s] = l), (h = typeof d) == typeof(u = t[s])) if ("string" === h) {
if ((c = n(u)).valid && (f = n(d)).valid) {
e[s] = f.mix(c, a).rgbString();
continue
}
} else if ("number" === h && isFinite(u) && isFinite(d)) {
e[s] = u + (d - u) * a;
continue
}
e[s] = d
}
}(a, r, i, t), e) : (e._view = i, e._start = null, e)
}, tooltipPosition: function () {
return {x: this._model.x, y: this._model.y}
}, hasValue: function () {
return a.isNumber(this._model.x) && a.isNumber(this._model.y)
}
}), r.extend = a.inherits, e.exports = r
}, {2: 2, 45: 45}], 27: [function (t, e, i) {
"use strict";
var n = t(2), a = t(25), r = t(45);
e.exports = function (t) {
function e(t, e, i) {
var n;
return "string" == typeof t ? (n = parseInt(t, 10), -1 !== t.indexOf("%") && (n = n / 100 * e.parentNode[i])) : n = t, n
}
function i(t) {
return null != t && "none" !== t
}
function o(t, n, a) {
var r = document.defaultView, o = t.parentNode, s = r.getComputedStyle(t)[n],
l = r.getComputedStyle(o)[n], u = i(s), d = i(l), h = Number.POSITIVE_INFINITY;
return u || d ? Math.min(u ? e(s, t, a) : h, d ? e(l, o, a) : h) : "none"
}
r.configMerge = function () {
return r.merge(r.clone(arguments[0]), [].slice.call(arguments, 1), {
merger: function (e, i, n, a) {
var o = i[e] || {}, s = n[e];
"scales" === e ? i[e] = r.scaleMerge(o, s) : "scale" === e ? i[e] = r.merge(o, [t.scaleService.getScaleDefaults(s.type), s]) : r._merger(e, i, n, a)
}
})
}, r.scaleMerge = function () {
return r.merge(r.clone(arguments[0]), [].slice.call(arguments, 1), {
merger: function (e, i, n, a) {
if ("xAxes" === e || "yAxes" === e) {
var o, s, l, u = n[e].length;
for (i[e] || (i[e] = []), o = 0; o < u; ++o) l = n[e][o], s = r.valueOrDefault(l.type, "xAxes" === e ? "category" : "linear"), o >= i[e].length && i[e].push({}), !i[e][o].type || l.type && l.type !== i[e][o].type ? r.merge(i[e][o], [t.scaleService.getScaleDefaults(s), l]) : r.merge(i[e][o], l)
} else r._merger(e, i, n, a)
}
})
}, r.where = function (t, e) {
if (r.isArray(t) && Array.prototype.filter) return t.filter(e);
var i = [];
return r.each(t, function (t) {
e(t) && i.push(t)
}), i
}, r.findIndex = Array.prototype.findIndex ? function (t, e, i) {
return t.findIndex(e, i)
} : function (t, e, i) {
i = void 0 === i ? t : i;
for (var n = 0, a = t.length; n < a; ++n) if (e.call(i, t[n], n, t)) return n;
return -1
}, r.findNextWhere = function (t, e, i) {
r.isNullOrUndef(i) && (i = -1);
for (var n = i + 1; n < t.length; n++) {
var a = t[n];
if (e(a)) return a
}
}, r.findPreviousWhere = function (t, e, i) {
r.isNullOrUndef(i) && (i = t.length);
for (var n = i - 1; n >= 0; n--) {
var a = t[n];
if (e(a)) return a
}
}, r.isNumber = function (t) {
return !isNaN(parseFloat(t)) && isFinite(t)
}, r.almostEquals = function (t, e, i) {
return Math.abs(t - e) < i
}, r.almostWhole = function (t, e) {
var i = Math.round(t);
return i - e < t && i + e > t
}, r.max = function (t) {
return t.reduce(function (t, e) {
return isNaN(e) ? t : Math.max(t, e)
}, Number.NEGATIVE_INFINITY)
}, r.min = function (t) {
return t.reduce(function (t, e) {
return isNaN(e) ? t : Math.min(t, e)
}, Number.POSITIVE_INFINITY)
}, r.sign = Math.sign ? function (t) {
return Math.sign(t)
} : function (t) {
return 0 === (t = +t) || isNaN(t) ? t : t > 0 ? 1 : -1
}, r.log10 = Math.log10 ? function (t) {
return Math.log10(t)
} : function (t) {
var e = Math.log(t) * Math.LOG10E, i = Math.round(e);
return t === Math.pow(10, i) ? i : e
}, r.toRadians = function (t) {
return t * (Math.PI / 180)
}, r.toDegrees = function (t) {
return t * (180 / Math.PI)
}, r.getAngleFromPoint = function (t, e) {
var i = e.x - t.x, n = e.y - t.y, a = Math.sqrt(i * i + n * n), r = Math.atan2(n, i);
return r < -.5 * Math.PI && (r += 2 * Math.PI), {angle: r, distance: a}
}, r.distanceBetweenPoints = function (t, e) {
return Math.sqrt(Math.pow(e.x - t.x, 2) + Math.pow(e.y - t.y, 2))
}, r.aliasPixel = function (t) {
return t % 2 == 0 ? 0 : .5
}, r.splineCurve = function (t, e, i, n) {
var a = t.skip ? e : t, r = e, o = i.skip ? e : i,
s = Math.sqrt(Math.pow(r.x - a.x, 2) + Math.pow(r.y - a.y, 2)),
l = Math.sqrt(Math.pow(o.x - r.x, 2) + Math.pow(o.y - r.y, 2)), u = s / (s + l),
d = l / (s + l), h = n * (u = isNaN(u) ? 0 : u), c = n * (d = isNaN(d) ? 0 : d);
return {
previous: {x: r.x - h * (o.x - a.x), y: r.y - h * (o.y - a.y)},
next: {x: r.x + c * (o.x - a.x), y: r.y + c * (o.y - a.y)}
}
}, r.EPSILON = Number.EPSILON || 1e-14, r.splineCurveMonotone = function (t) {
var e, i, n, a, o, s, l, u, d, h = (t || []).map(function (t) {
return {model: t._model, deltaK: 0, mK: 0}
}), c = h.length;
for (e = 0; e < c; ++e) if (!(n = h[e]).model.skip) {
if (i = e > 0 ? h[e - 1] : null, (a = e < c - 1 ? h[e + 1] : null) && !a.model.skip) {
var f = a.model.x - n.model.x;
n.deltaK = 0 !== f ? (a.model.y - n.model.y) / f : 0
}
!i || i.model.skip ? n.mK = n.deltaK : !a || a.model.skip ? n.mK = i.deltaK : this.sign(i.deltaK) !== this.sign(n.deltaK) ? n.mK = 0 : n.mK = (i.deltaK + n.deltaK) / 2
}
for (e = 0; e < c - 1; ++e) n = h[e], a = h[e + 1], n.model.skip || a.model.skip || (r.almostEquals(n.deltaK, 0, this.EPSILON) ? n.mK = a.mK = 0 : (o = n.mK / n.deltaK, s = a.mK / n.deltaK, (u = Math.pow(o, 2) + Math.pow(s, 2)) <= 9 || (l = 3 / Math.sqrt(u), n.mK = o * l * n.deltaK, a.mK = s * l * n.deltaK)));
for (e = 0; e < c; ++e) (n = h[e]).model.skip || (i = e > 0 ? h[e - 1] : null, a = e < c - 1 ? h[e + 1] : null, i && !i.model.skip && (d = (n.model.x - i.model.x) / 3, n.model.controlPointPreviousX = n.model.x - d, n.model.controlPointPreviousY = n.model.y - d * n.mK), a && !a.model.skip && (d = (a.model.x - n.model.x) / 3, n.model.controlPointNextX = n.model.x + d, n.model.controlPointNextY = n.model.y + d * n.mK))
}, r.nextItem = function (t, e, i) {
return i ? e >= t.length - 1 ? t[0] : t[e + 1] : e >= t.length - 1 ? t[t.length - 1] : t[e + 1]
}, r.previousItem = function (t, e, i) {
return i ? e <= 0 ? t[t.length - 1] : t[e - 1] : e <= 0 ? t[0] : t[e - 1]
}, r.niceNum = function (t, e) {
var i = Math.floor(r.log10(t)), n = t / Math.pow(10, i);
return (e ? n < 1.5 ? 1 : n < 3 ? 2 : n < 7 ? 5 : 10 : n <= 1 ? 1 : n <= 2 ? 2 : n <= 5 ? 5 : 10) * Math.pow(10, i)
}, r.requestAnimFrame = "undefined" == typeof window ? function (t) {
t()
} : window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.oRequestAnimationFrame || window.msRequestAnimationFrame || function (t) {
return window.setTimeout(t, 1e3 / 60)
}, r.getRelativePosition = function (t, e) {
var i, n, a = t.originalEvent || t, o = t.currentTarget || t.srcElement,
s = o.getBoundingClientRect(), l = a.touches;
l && l.length > 0 ? (i = l[0].clientX, n = l[0].clientY) : (i = a.clientX, n = a.clientY);
var u = parseFloat(r.getStyle(o, "padding-left")), d = parseFloat(r.getStyle(o, "padding-top")),
h = parseFloat(r.getStyle(o, "padding-right")), c = parseFloat(r.getStyle(o, "padding-bottom")),
f = s.right - s.left - u - h, g = s.bottom - s.top - d - c;
return {
x: i = Math.round((i - s.left - u) / f * o.width / e.currentDevicePixelRatio),
y: n = Math.round((n - s.top - d) / g * o.height / e.currentDevicePixelRatio)
}
}, r.getConstraintWidth = function (t) {
return o(t, "max-width", "clientWidth")
}, r.getConstraintHeight = function (t) {
return o(t, "max-height", "clientHeight")
}, r.getMaximumWidth = function (t) {
var e = t.parentNode;
if (!e) return t.clientWidth;
var i = parseInt(r.getStyle(e, "padding-left"), 10),
n = parseInt(r.getStyle(e, "padding-right"), 10), a = e.clientWidth - i - n,
o = r.getConstraintWidth(t);
return isNaN(o) ? a : Math.min(a, o)
}, r.getMaximumHeight = function (t) {
var e = t.parentNode;
if (!e) return t.clientHeight;
var i = parseInt(r.getStyle(e, "padding-top"), 10),
n = parseInt(r.getStyle(e, "padding-bottom"), 10), a = e.clientHeight - i - n,
o = r.getConstraintHeight(t);
return isNaN(o) ? a : Math.min(a, o)
}, r.getStyle = function (t, e) {
return t.currentStyle ? t.currentStyle[e] : document.defaultView.getComputedStyle(t, null).getPropertyValue(e)
}, r.retinaScale = function (t, e) {
var i = t.currentDevicePixelRatio = e || window.devicePixelRatio || 1;
if (1 !== i) {
var n = t.canvas, a = t.height, r = t.width;
n.height = a * i, n.width = r * i, t.ctx.scale(i, i), n.style.height || n.style.width || (n.style.height = a + "px", n.style.width = r + "px")
}
}, r.fontString = function (t, e, i) {
return e + " " + t + "px " + i
}, r.longestText = function (t, e, i, n) {
var a = (n = n || {}).data = n.data || {}, o = n.garbageCollect = n.garbageCollect || [];
n.font !== e && (a = n.data = {}, o = n.garbageCollect = [], n.font = e), t.font = e;
var s = 0;
r.each(i, function (e) {
null != e && !0 !== r.isArray(e) ? s = r.measureText(t, a, o, s, e) : r.isArray(e) && r.each(e, function (e) {
null == e || r.isArray(e) || (s = r.measureText(t, a, o, s, e))
})
});
var l = o.length / 2;
if (l > i.length) {
for (var u = 0; u < l; u++) delete a[o[u]];
o.splice(0, l)
}
return s
}, r.measureText = function (t, e, i, n, a) {
var r = e[a];
return r || (r = e[a] = t.measureText(a).width, i.push(a)), r > n && (n = r), n
}, r.numberOfLabelLines = function (t) {
var e = 1;
return r.each(t, function (t) {
r.isArray(t) && t.length > e && (e = t.length)
}), e
}, r.color = n ? function (t) {
return t instanceof CanvasGradient && (t = a.global.defaultColor), n(t)
} : function (t) {
return console.error("Color.js not found!"), t
}, r.getHoverColor = function (t) {
return t instanceof CanvasPattern ? t : r.color(t).saturate(.5).darken(.1).rgbString()
}
}
}, {2: 2, 25: 25, 45: 45}], 28: [function (t, e, i) {
"use strict";
var n = t(45);
function a(t, e) {
return t.native ? {x: t.x, y: t.y} : n.getRelativePosition(t, e)
}
function r(t, e) {
var i, n, a, r, o;
for (n = 0, r = t.data.datasets.length; n < r; ++n) if (t.isDatasetVisible(n)) for (a = 0, o = (i = t.getDatasetMeta(n)).data.length; a < o; ++a) {
var s = i.data[a];
s._view.skip || e(s)
}
}
function o(t, e) {
var i = [];
return r(t, function (t) {
t.inRange(e.x, e.y) && i.push(t)
}), i
}
function s(t, e, i, n) {
var a = Number.POSITIVE_INFINITY, o = [];
return r(t, function (t) {
if (!i || t.inRange(e.x, e.y)) {
var r = t.getCenterPoint(), s = n(e, r);
s < a ? (o = [t], a = s) : s === a && o.push(t)
}
}), o
}
function l(t) {
var e = -1 !== t.indexOf("x"), i = -1 !== t.indexOf("y");
return function (t, n) {
var a = e ? Math.abs(t.x - n.x) : 0, r = i ? Math.abs(t.y - n.y) : 0;
return Math.sqrt(Math.pow(a, 2) + Math.pow(r, 2))
}
}
function u(t, e, i) {
var n = a(e, t);
i.axis = i.axis || "x";
var r = l(i.axis), u = i.intersect ? o(t, n) : s(t, n, !1, r), d = [];
return u.length ? (t.data.datasets.forEach(function (e, i) {
if (t.isDatasetVisible(i)) {
var n = t.getDatasetMeta(i).data[u[0]._index];
n && !n._view.skip && d.push(n)
}
}), d) : []
}
e.exports = {
modes: {
single: function (t, e) {
var i = a(e, t), n = [];
return r(t, function (t) {
if (t.inRange(i.x, i.y)) return n.push(t), n
}), n.slice(0, 1)
}, label: u, index: u, dataset: function (t, e, i) {
var n = a(e, t);
i.axis = i.axis || "xy";
var r = l(i.axis), u = i.intersect ? o(t, n) : s(t, n, !1, r);
return u.length > 0 && (u = t.getDatasetMeta(u[0]._datasetIndex).data), u
}, "x-axis": function (t, e) {
return u(t, e, {intersect: !1})
}, point: function (t, e) {
return o(t, a(e, t))
}, nearest: function (t, e, i) {
var n = a(e, t);
i.axis = i.axis || "xy";
var r = l(i.axis), o = s(t, n, i.intersect, r);
return o.length > 1 && o.sort(function (t, e) {
var i = t.getArea() - e.getArea();
return 0 === i && (i = t._datasetIndex - e._datasetIndex), i
}), o.slice(0, 1)
}, x: function (t, e, i) {
var n = a(e, t), o = [], s = !1;
return r(t, function (t) {
t.inXRange(n.x) && o.push(t), t.inRange(n.x, n.y) && (s = !0)
}), i.intersect && !s && (o = []), o
}, y: function (t, e, i) {
var n = a(e, t), o = [], s = !1;
return r(t, function (t) {
t.inYRange(n.y) && o.push(t), t.inRange(n.x, n.y) && (s = !0)
}), i.intersect && !s && (o = []), o
}
}
}
}, {45: 45}], 29: [function (t, e, i) {
"use strict";
t(25)._set("global", {
responsive: !0,
responsiveAnimationDuration: 0,
maintainAspectRatio: !0,
events: ["mousemove", "mouseout", "click", "touchstart", "touchmove"],
hover: {onHover: null, mode: "nearest", intersect: !0, animationDuration: 400},
onClick: null,
defaultColor: "rgba(0,0,0,0.1)",
defaultFontColor: "#666",
defaultFontFamily: "'Helvetica Neue', 'Helvetica', 'Arial', sans-serif",
defaultFontSize: 12,
defaultFontStyle: "normal",
showLines: !0,
elements: {},
layout: {padding: {top: 0, right: 0, bottom: 0, left: 0}}
}), e.exports = function () {
var t = function (t, e) {
return this.construct(t, e), this
};
return t.Chart = t, t
}
}, {25: 25}], 30: [function (t, e, i) {
"use strict";
var n = t(45);
function a(t, e) {
return n.where(t, function (t) {
return t.position === e
})
}
function r(t, e) {
t.forEach(function (t, e) {
return t._tmpIndex_ = e, t
}), t.sort(function (t, i) {
var n = e ? i : t, a = e ? t : i;
return n.weight === a.weight ? n._tmpIndex_ - a._tmpIndex_ : n.weight - a.weight
}), t.forEach(function (t) {
delete t._tmpIndex_
})
}
e.exports = {
defaults: {}, addBox: function (t, e) {
t.boxes || (t.boxes = []), e.fullWidth = e.fullWidth || !1, e.position = e.position || "top", e.weight = e.weight || 0, t.boxes.push(e)
}, removeBox: function (t, e) {
var i = t.boxes ? t.boxes.indexOf(e) : -1;
-1 !== i && t.boxes.splice(i, 1)
}, configure: function (t, e, i) {
for (var n, a = ["fullWidth", "position", "weight"], r = a.length, o = 0; o < r; ++o) n = a[o], i.hasOwnProperty(n) && (e[n] = i[n])
}, update: function (t, e, i) {
if (t) {
var o = t.options.layout || {}, s = n.options.toPadding(o.padding), l = s.left, u = s.right,
d = s.top, h = s.bottom, c = a(t.boxes, "left"), f = a(t.boxes, "right"),
g = a(t.boxes, "top"), m = a(t.boxes, "bottom"), p = a(t.boxes, "chartArea");
r(c, !0), r(f, !1), r(g, !0), r(m, !1);
var v = e - l - u, y = i - d - h, b = y / 2, x = (e - v / 2) / (c.length + f.length),
_ = (i - b) / (g.length + m.length), k = v, w = y, M = [];
n.each(c.concat(f, g, m), function (t) {
var e, i = t.isHorizontal();
i ? (e = t.update(t.fullWidth ? v : k, _), w -= e.height) : (e = t.update(x, w), k -= e.width), M.push({
horizontal: i,
minSize: e,
box: t
})
});
var S = 0, D = 0, C = 0, P = 0;
n.each(g.concat(m), function (t) {
if (t.getPadding) {
var e = t.getPadding();
S = Math.max(S, e.left), D = Math.max(D, e.right)
}
}), n.each(c.concat(f), function (t) {
if (t.getPadding) {
var e = t.getPadding();
C = Math.max(C, e.top), P = Math.max(P, e.bottom)
}
});
var T = l, O = u, I = d, A = h;
n.each(c.concat(f), z), n.each(c, function (t) {
T += t.width
}), n.each(f, function (t) {
O += t.width
}), n.each(g.concat(m), z), n.each(g, function (t) {
I += t.height
}), n.each(m, function (t) {
A += t.height
}), n.each(c.concat(f), function (t) {
var e = n.findNextWhere(M, function (e) {
return e.box === t
}), i = {left: 0, right: 0, top: I, bottom: A};
e && t.update(e.minSize.width, w, i)
}), T = l, O = u, I = d, A = h, n.each(c, function (t) {
T += t.width
}), n.each(f, function (t) {
O += t.width
}), n.each(g, function (t) {
I += t.height
}), n.each(m, function (t) {
A += t.height
});
var F = Math.max(S - T, 0);
T += F, O += Math.max(D - O, 0);
var R = Math.max(C - I, 0);
I += R, A += Math.max(P - A, 0);
var L = i - I - A, W = e - T - O;
W === k && L === w || (n.each(c, function (t) {
t.height = L
}), n.each(f, function (t) {
t.height = L
}), n.each(g, function (t) {
t.fullWidth || (t.width = W)
}), n.each(m, function (t) {
t.fullWidth || (t.width = W)
}), w = L, k = W);
var Y = l + F, N = d + R;
n.each(c.concat(g), H), Y += k, N += w, n.each(f, H), n.each(m, H), t.chartArea = {
left: T,
top: I,
right: T + k,
bottom: I + w
}, n.each(p, function (e) {
e.left = t.chartArea.left, e.top = t.chartArea.top, e.right = t.chartArea.right, e.bottom = t.chartArea.bottom, e.update(k, w)
})
}
function z(t) {
var e = n.findNextWhere(M, function (e) {
return e.box === t
});
if (e) if (t.isHorizontal()) {
var i = {left: Math.max(T, S), right: Math.max(O, D), top: 0, bottom: 0};
t.update(t.fullWidth ? v : k, y / 2, i)
} else t.update(e.minSize.width, w)
}
function H(t) {
t.isHorizontal() ? (t.left = t.fullWidth ? l : T, t.right = t.fullWidth ? e - u : T + k, t.top = N, t.bottom = N + t.height, N = t.bottom) : (t.left = Y, t.right = Y + t.width, t.top = I, t.bottom = I + w, Y = t.right)
}
}
}
}, {45: 45}], 31: [function (t, e, i) {
"use strict";
var n = t(25), a = t(45);
n._set("global", {plugins: {}}), e.exports = {
_plugins: [], _cacheId: 0, register: function (t) {
var e = this._plugins;
[].concat(t).forEach(function (t) {
-1 === e.indexOf(t) && e.push(t)
}), this._cacheId++
}, unregister: function (t) {
var e = this._plugins;
[].concat(t).forEach(function (t) {
var i = e.indexOf(t);
-1 !== i && e.splice(i, 1)
}), this._cacheId++
}, clear: function () {
this._plugins = [], this._cacheId++
}, count: function () {
return this._plugins.length
}, getAll: function () {
return this._plugins
}, notify: function (t, e, i) {
var n, a, r, o, s, l = this.descriptors(t), u = l.length;
for (n = 0; n < u; ++n) if ("function" == typeof(s = (r = (a = l[n]).plugin)[e]) && ((o = [t].concat(i || [])).push(a.options), !1 === s.apply(r, o))) return !1;
return !0
}, descriptors: function (t) {
var e = t.$plugins || (t.$plugins = {});
if (e.id === this._cacheId) return e.descriptors;
var i = [], r = [], o = t && t.config || {}, s = o.options && o.options.plugins || {};
return this._plugins.concat(o.plugins || []).forEach(function (t) {
if (-1 === i.indexOf(t)) {
var e = t.id, o = s[e];
!1 !== o && (!0 === o && (o = a.clone(n.global.plugins[e])), i.push(t), r.push({
plugin: t,
options: o || {}
}))
}
}), e.descriptors = r, e.id = this._cacheId, r
}, _invalidate: function (t) {
delete t.$plugins
}
}
}, {25: 25, 45: 45}], 32: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26), r = t(45), o = t(34);
function s(t) {
var e, i, n = [];
for (e = 0, i = t.length; e < i; ++e) n.push(t[e].label);
return n
}
function l(t, e, i) {
var n = t.getPixelForTick(e);
return i && (n -= 0 === e ? (t.getPixelForTick(1) - n) / 2 : (n - t.getPixelForTick(e - 1)) / 2), n
}
n._set("scale", {
display: !0,
position: "left",
offset: !1,
gridLines: {
display: !0,
color: "rgba(0, 0, 0, 0.1)",
lineWidth: 1,
drawBorder: !0,
drawOnChartArea: !0,
drawTicks: !0,
tickMarkLength: 10,
zeroLineWidth: 1,
zeroLineColor: "rgba(0,0,0,0.25)",
zeroLineBorderDash: [],
zeroLineBorderDashOffset: 0,
offsetGridLines: !1,
borderDash: [],
borderDashOffset: 0
},
scaleLabel: {display: !1, labelString: "", lineHeight: 1.2, padding: {top: 4, bottom: 4}},
ticks: {
beginAtZero: !1,
minRotation: 0,
maxRotation: 50,
mirror: !1,
padding: 0,
reverse: !1,
display: !0,
autoSkip: !0,
autoSkipPadding: 0,
labelOffset: 0,
callback: o.formatters.values,
minor: {},
major: {}
}
}), e.exports = function (t) {
function e(t, e, i) {
return r.isArray(e) ? r.longestText(t, i, e) : t.measureText(e).width
}
function i(t) {
var e = r.valueOrDefault, i = n.global, a = e(t.fontSize, i.defaultFontSize),
o = e(t.fontStyle, i.defaultFontStyle), s = e(t.fontFamily, i.defaultFontFamily);
return {size: a, style: o, family: s, font: r.fontString(a, o, s)}
}
function o(t) {
return r.options.toLineHeight(r.valueOrDefault(t.lineHeight, 1.2), r.valueOrDefault(t.fontSize, n.global.defaultFontSize))
}
t.Scale = a.extend({
getPadding: function () {
return {
left: this.paddingLeft || 0,
top: this.paddingTop || 0,
right: this.paddingRight || 0,
bottom: this.paddingBottom || 0
}
},
getTicks: function () {
return this._ticks
},
mergeTicksOptions: function () {
var t = this.options.ticks;
for (var e in!1 === t.minor && (t.minor = {display: !1}), !1 === t.major && (t.major = {display: !1}), t) "major" !== e && "minor" !== e && (void 0 === t.minor[e] && (t.minor[e] = t[e]), void 0 === t.major[e] && (t.major[e] = t[e]))
},
beforeUpdate: function () {
r.callback(this.options.beforeUpdate, [this])
},
update: function (t, e, i) {
var n, a, o, s, l, u, d = this;
for (d.beforeUpdate(), d.maxWidth = t, d.maxHeight = e, d.margins = r.extend({
left: 0,
right: 0,
top: 0,
bottom: 0
}, i), d.longestTextCache = d.longestTextCache || {}, d.beforeSetDimensions(), d.setDimensions(), d.afterSetDimensions(), d.beforeDataLimits(), d.determineDataLimits(), d.afterDataLimits(), d.beforeBuildTicks(), l = d.buildTicks() || [], d.afterBuildTicks(), d.beforeTickToLabelConversion(), o = d.convertTicksToLabels(l) || d.ticks, d.afterTickToLabelConversion(), d.ticks = o, n = 0, a = o.length; n < a; ++n) s = o[n], (u = l[n]) ? u.label = s : l.push(u = {
label: s,
major: !1
});
return d._ticks = l, d.beforeCalculateTickRotation(), d.calculateTickRotation(), d.afterCalculateTickRotation(), d.beforeFit(), d.fit(), d.afterFit(), d.afterUpdate(), d.minSize
},
afterUpdate: function () {
r.callback(this.options.afterUpdate, [this])
},
beforeSetDimensions: function () {
r.callback(this.options.beforeSetDimensions, [this])
},
setDimensions: function () {
var t = this;
t.isHorizontal() ? (t.width = t.maxWidth, t.left = 0, t.right = t.width) : (t.height = t.maxHeight, t.top = 0, t.bottom = t.height), t.paddingLeft = 0, t.paddingTop = 0, t.paddingRight = 0, t.paddingBottom = 0
},
afterSetDimensions: function () {
r.callback(this.options.afterSetDimensions, [this])
},
beforeDataLimits: function () {
r.callback(this.options.beforeDataLimits, [this])
},
determineDataLimits: r.noop,
afterDataLimits: function () {
r.callback(this.options.afterDataLimits, [this])
},
beforeBuildTicks: function () {
r.callback(this.options.beforeBuildTicks, [this])
},
buildTicks: r.noop,
afterBuildTicks: function () {
r.callback(this.options.afterBuildTicks, [this])
},
beforeTickToLabelConversion: function () {
r.callback(this.options.beforeTickToLabelConversion, [this])
},
convertTicksToLabels: function () {
var t = this.options.ticks;
this.ticks = this.ticks.map(t.userCallback || t.callback, this)
},
afterTickToLabelConversion: function () {
r.callback(this.options.afterTickToLabelConversion, [this])
},
beforeCalculateTickRotation: function () {
r.callback(this.options.beforeCalculateTickRotation, [this])
},
calculateTickRotation: function () {
var t = this, e = t.ctx, n = t.options.ticks, a = s(t._ticks), o = i(n);
e.font = o.font;
var l = n.minRotation || 0;
if (a.length && t.options.display && t.isHorizontal()) for (var u, d = r.longestText(e, o.font, a, t.longestTextCache), h = d, c = t.getPixelForTick(1) - t.getPixelForTick(0) - 6; h > c && l < n.maxRotation;) {
var f = r.toRadians(l);
if (u = Math.cos(f), Math.sin(f) * d > t.maxHeight) {
l--;
break
}
l++, h = u * d
}
t.labelRotation = l
},
afterCalculateTickRotation: function () {
r.callback(this.options.afterCalculateTickRotation, [this])
},
beforeFit: function () {
r.callback(this.options.beforeFit, [this])
},
fit: function () {
var t = this, n = t.minSize = {width: 0, height: 0}, a = s(t._ticks), l = t.options,
u = l.ticks, d = l.scaleLabel, h = l.gridLines, c = l.display, f = t.isHorizontal(),
g = i(u), m = l.gridLines.tickMarkLength;
if (n.width = f ? t.isFullWidth() ? t.maxWidth - t.margins.left - t.margins.right : t.maxWidth : c && h.drawTicks ? m : 0, n.height = f ? c && h.drawTicks ? m : 0 : t.maxHeight, d.display && c) {
var p = o(d) + r.options.toPadding(d.padding).height;
f ? n.height += p : n.width += p
}
if (u.display && c) {
var v = r.longestText(t.ctx, g.font, a, t.longestTextCache), y = r.numberOfLabelLines(a),
b = .5 * g.size, x = t.options.ticks.padding;
if (f) {
t.longestLabelWidth = v;
var _ = r.toRadians(t.labelRotation), k = Math.cos(_),
w = Math.sin(_) * v + g.size * y + b * (y - 1) + b;
n.height = Math.min(t.maxHeight, n.height + w + x), t.ctx.font = g.font;
var M = e(t.ctx, a[0], g.font), S = e(t.ctx, a[a.length - 1], g.font);
0 !== t.labelRotation ? (t.paddingLeft = "bottom" === l.position ? k * M + 3 : k * b + 3, t.paddingRight = "bottom" === l.position ? k * b + 3 : k * S + 3) : (t.paddingLeft = M / 2 + 3, t.paddingRight = S / 2 + 3)
} else u.mirror ? v = 0 : v += x + b, n.width = Math.min(t.maxWidth, n.width + v), t.paddingTop = g.size / 2, t.paddingBottom = g.size / 2
}
t.handleMargins(), t.width = n.width, t.height = n.height
},
handleMargins: function () {
var t = this;
t.margins && (t.paddingLeft = Math.max(t.paddingLeft - t.margins.left, 0), t.paddingTop = Math.max(t.paddingTop - t.margins.top, 0), t.paddingRight = Math.max(t.paddingRight - t.margins.right, 0), t.paddingBottom = Math.max(t.paddingBottom - t.margins.bottom, 0))
},
afterFit: function () {
r.callback(this.options.afterFit, [this])
},
isHorizontal: function () {
return "top" === this.options.position || "bottom" === this.options.position
},
isFullWidth: function () {
return this.options.fullWidth
},
getRightValue: function (t) {
if (r.isNullOrUndef(t)) return NaN;
if ("number" == typeof t && !isFinite(t)) return NaN;
if (t) if (this.isHorizontal()) {
if (void 0 !== t.x) return this.getRightValue(t.x)
} else if (void 0 !== t.y) return this.getRightValue(t.y);
return t
},
getLabelForIndex: r.noop,
getPixelForValue: r.noop,
getValueForPixel: r.noop,
getPixelForTick: function (t) {
var e = this, i = e.options.offset;
if (e.isHorizontal()) {
var n = (e.width - (e.paddingLeft + e.paddingRight)) / Math.max(e._ticks.length - (i ? 0 : 1), 1),
a = n * t + e.paddingLeft;
i && (a += n / 2);
var r = e.left + Math.round(a);
return r += e.isFullWidth() ? e.margins.left : 0
}
var o = e.height - (e.paddingTop + e.paddingBottom);
return e.top + t * (o / (e._ticks.length - 1))
},
getPixelForDecimal: function (t) {
var e = this;
if (e.isHorizontal()) {
var i = (e.width - (e.paddingLeft + e.paddingRight)) * t + e.paddingLeft,
n = e.left + Math.round(i);
return n += e.isFullWidth() ? e.margins.left : 0
}
return e.top + t * e.height
},
getBasePixel: function () {
return this.getPixelForValue(this.getBaseValue())
},
getBaseValue: function () {
var t = this.min, e = this.max;
return this.beginAtZero ? 0 : t < 0 && e < 0 ? e : t > 0 && e > 0 ? t : 0
},
_autoSkip: function (t) {
var e, i, n, a, o = this, s = o.isHorizontal(), l = o.options.ticks.minor, u = t.length,
d = r.toRadians(o.labelRotation), h = Math.cos(d), c = o.longestLabelWidth * h, f = [];
for (l.maxTicksLimit && (a = l.maxTicksLimit), s && (e = !1, (c + l.autoSkipPadding) * u > o.width - (o.paddingLeft + o.paddingRight) && (e = 1 + Math.floor((c + l.autoSkipPadding) * u / (o.width - (o.paddingLeft + o.paddingRight)))), a && u > a && (e = Math.max(e, Math.floor(u / a)))), i = 0; i < u; i++) n = t[i], (e > 1 && i % e > 0 || i % e == 0 && i + e >= u) && i !== u - 1 && delete n.label, f.push(n);
return f
},
draw: function (t) {
var e = this, a = e.options;
if (a.display) {
var s = e.ctx, u = n.global, d = a.ticks.minor, h = a.ticks.major || d, c = a.gridLines,
f = a.scaleLabel, g = 0 !== e.labelRotation, m = e.isHorizontal(),
p = d.autoSkip ? e._autoSkip(e.getTicks()) : e.getTicks(),
v = r.valueOrDefault(d.fontColor, u.defaultFontColor), y = i(d),
b = r.valueOrDefault(h.fontColor, u.defaultFontColor), x = i(h),
_ = c.drawTicks ? c.tickMarkLength : 0,
k = r.valueOrDefault(f.fontColor, u.defaultFontColor), w = i(f),
M = r.options.toPadding(f.padding), S = r.toRadians(e.labelRotation), D = [],
C = e.options.gridLines.lineWidth,
P = "right" === a.position ? e.right : e.right - C - _,
T = "right" === a.position ? e.right + _ : e.right,
O = "bottom" === a.position ? e.top + C : e.bottom - _ - C,
I = "bottom" === a.position ? e.top + C + _ : e.bottom + C;
if (r.each(p, function (i, n) {
if (!r.isNullOrUndef(i.label)) {
var o, s, h, f, v, y, b, x, k, w, M, A, F, R, L = i.label;
n === e.zeroLineIndex && a.offset === c.offsetGridLines ? (o = c.zeroLineWidth, s = c.zeroLineColor, h = c.zeroLineBorderDash, f = c.zeroLineBorderDashOffset) : (o = r.valueAtIndexOrDefault(c.lineWidth, n), s = r.valueAtIndexOrDefault(c.color, n), h = r.valueOrDefault(c.borderDash, u.borderDash), f = r.valueOrDefault(c.borderDashOffset, u.borderDashOffset));
var W = "middle", Y = "middle", N = d.padding;
if (m) {
var z = _ + N;
"bottom" === a.position ? (Y = g ? "middle" : "top", W = g ? "right" : "center", R = e.top + z) : (Y = g ? "middle" : "bottom", W = g ? "left" : "center", R = e.bottom - z);
var H = l(e, n, c.offsetGridLines && p.length > 1);
H < e.left && (s = "rgba(0,0,0,0)"), H += r.aliasPixel(o), F = e.getPixelForTick(n) + d.labelOffset, v = b = k = M = H, y = O, x = I, w = t.top, A = t.bottom + C
} else {
var V, B = "left" === a.position;
d.mirror ? (W = B ? "left" : "right", V = N) : (W = B ? "right" : "left", V = _ + N), F = B ? e.right - V : e.left + V;
var E = l(e, n, c.offsetGridLines && p.length > 1);
E < e.top && (s = "rgba(0,0,0,0)"), E += r.aliasPixel(o), R = e.getPixelForTick(n) + d.labelOffset, v = P, b = T, k = t.left, M = t.right + C, y = x = w = A = E
}
D.push({
tx1: v,
ty1: y,
tx2: b,
ty2: x,
x1: k,
y1: w,
x2: M,
y2: A,
labelX: F,
labelY: R,
glWidth: o,
glColor: s,
glBorderDash: h,
glBorderDashOffset: f,
rotation: -1 * S,
label: L,
major: i.major,
textBaseline: Y,
textAlign: W
})
}
}), r.each(D, function (t) {
if (c.display && (s.save(), s.lineWidth = t.glWidth, s.strokeStyle = t.glColor, s.setLineDash && (s.setLineDash(t.glBorderDash), s.lineDashOffset = t.glBorderDashOffset), s.beginPath(), c.drawTicks && (s.moveTo(t.tx1, t.ty1), s.lineTo(t.tx2, t.ty2)), c.drawOnChartArea && (s.moveTo(t.x1, t.y1), s.lineTo(t.x2, t.y2)), s.stroke(), s.restore()), d.display) {
s.save(), s.translate(t.labelX, t.labelY), s.rotate(t.rotation), s.font = t.major ? x.font : y.font, s.fillStyle = t.major ? b : v, s.textBaseline = t.textBaseline, s.textAlign = t.textAlign;
var i = t.label;
if (r.isArray(i)) for (var n = i.length, a = 1.5 * y.size, o = e.isHorizontal() ? 0 : -a * (n - 1) / 2, l = 0; l < n; ++l) s.fillText("" + i[l], 0, o), o += a; else s.fillText(i, 0, 0);
s.restore()
}
}), f.display) {
var A, F, R = 0, L = o(f) / 2;
if (m) A = e.left + (e.right - e.left) / 2, F = "bottom" === a.position ? e.bottom - L - M.bottom : e.top + L + M.top; else {
var W = "left" === a.position;
A = W ? e.left + L + M.top : e.right - L - M.top, F = e.top + (e.bottom - e.top) / 2, R = W ? -.5 * Math.PI : .5 * Math.PI
}
s.save(), s.translate(A, F), s.rotate(R), s.textAlign = "center", s.textBaseline = "middle", s.fillStyle = k, s.font = w.font, s.fillText(f.labelString, 0, 0), s.restore()
}
if (c.drawBorder) {
s.lineWidth = r.valueAtIndexOrDefault(c.lineWidth, 0), s.strokeStyle = r.valueAtIndexOrDefault(c.color, 0);
var Y = e.left, N = e.right + C, z = e.top, H = e.bottom + C,
V = r.aliasPixel(s.lineWidth);
m ? (z = H = "top" === a.position ? e.bottom : e.top, z += V, H += V) : (Y = N = "left" === a.position ? e.right : e.left, Y += V, N += V), s.beginPath(), s.moveTo(Y, z), s.lineTo(N, H), s.stroke()
}
}
}
})
}
}, {25: 25, 26: 26, 34: 34, 45: 45}], 33: [function (t, e, i) {
"use strict";
var n = t(25), a = t(45), r = t(30);
e.exports = function (t) {
t.scaleService = {
constructors: {}, defaults: {}, registerScaleType: function (t, e, i) {
this.constructors[t] = e, this.defaults[t] = a.clone(i)
}, getScaleConstructor: function (t) {
return this.constructors.hasOwnProperty(t) ? this.constructors[t] : void 0
}, getScaleDefaults: function (t) {
return this.defaults.hasOwnProperty(t) ? a.merge({}, [n.scale, this.defaults[t]]) : {}
}, updateScaleDefaults: function (t, e) {
this.defaults.hasOwnProperty(t) && (this.defaults[t] = a.extend(this.defaults[t], e))
}, addScalesToLayout: function (t) {
a.each(t.scales, function (e) {
e.fullWidth = e.options.fullWidth, e.position = e.options.position, e.weight = e.options.weight, r.addBox(t, e)
})
}
}
}
}, {25: 25, 30: 30, 45: 45}], 34: [function (t, e, i) {
"use strict";
var n = t(45);
e.exports = {
formatters: {
values: function (t) {
return n.isArray(t) ? t : "" + t
}, linear: function (t, e, i) {
var a = i.length > 3 ? i[2] - i[1] : i[1] - i[0];
Math.abs(a) > 1 && t !== Math.floor(t) && (a = t - Math.floor(t));
var r = n.log10(Math.abs(a)), o = "";
if (0 !== t) {
var s = -1 * Math.floor(r);
s = Math.max(Math.min(s, 20), 0), o = t.toFixed(s)
} else o = "0";
return o
}, logarithmic: function (t, e, i) {
var a = t / Math.pow(10, Math.floor(n.log10(t)));
return 0 === t ? "0" : 1 === a || 2 === a || 5 === a || 0 === e || e === i.length - 1 ? t.toExponential() : ""
}
}
}
}, {45: 45}], 35: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26), r = t(45);
n._set("global", {
tooltips: {
enabled: !0,
custom: null,
mode: "nearest",
position: "average",
intersect: !0,
backgroundColor: "rgba(0,0,0,0.8)",
titleFontStyle: "bold",
titleSpacing: 2,
titleMarginBottom: 6,
titleFontColor: "#fff",
titleAlign: "left",
bodySpacing: 2,
bodyFontColor: "#fff",
bodyAlign: "left",
footerFontStyle: "bold",
footerSpacing: 2,
footerMarginTop: 6,
footerFontColor: "#fff",
footerAlign: "left",
yPadding: 6,
xPadding: 6,
caretPadding: 2,
caretSize: 5,
cornerRadius: 6,
multiKeyBackground: "#fff",
displayColors: !0,
borderColor: "rgba(0,0,0,0)",
borderWidth: 0,
callbacks: {
beforeTitle: r.noop,
title: function (t, e) {
var i = "", n = e.labels, a = n ? n.length : 0;
if (t.length > 0) {
var r = t[0];
r.xLabel ? i = r.xLabel : a > 0 && r.index < a && (i = n[r.index])
}
return i
},
afterTitle: r.noop,
beforeBody: r.noop,
beforeLabel: r.noop,
label: function (t, e) {
var i = e.datasets[t.datasetIndex].label || "";
return i && (i += ": "), i += t.yLabel
},
labelColor: function (t, e) {
var i = e.getDatasetMeta(t.datasetIndex).data[t.index]._view;
return {borderColor: i.borderColor, backgroundColor: i.backgroundColor}
},
labelTextColor: function () {
return this._options.bodyFontColor
},
afterLabel: r.noop,
afterBody: r.noop,
beforeFooter: r.noop,
footer: r.noop,
afterFooter: r.noop
}
}
}), e.exports = function (t) {
function e(t, e) {
var i = r.color(t);
return i.alpha(e * i.alpha()).rgbaString()
}
function i(t, e) {
return e && (r.isArray(e) ? Array.prototype.push.apply(t, e) : t.push(e)), t
}
function o(t) {
var e = n.global, i = r.valueOrDefault;
return {
xPadding: t.xPadding,
yPadding: t.yPadding,
xAlign: t.xAlign,
yAlign: t.yAlign,
bodyFontColor: t.bodyFontColor,
_bodyFontFamily: i(t.bodyFontFamily, e.defaultFontFamily),
_bodyFontStyle: i(t.bodyFontStyle, e.defaultFontStyle),
_bodyAlign: t.bodyAlign,
bodyFontSize: i(t.bodyFontSize, e.defaultFontSize),
bodySpacing: t.bodySpacing,
titleFontColor: t.titleFontColor,
_titleFontFamily: i(t.titleFontFamily, e.defaultFontFamily),
_titleFontStyle: i(t.titleFontStyle, e.defaultFontStyle),
titleFontSize: i(t.titleFontSize, e.defaultFontSize),
_titleAlign: t.titleAlign,
titleSpacing: t.titleSpacing,
titleMarginBottom: t.titleMarginBottom,
footerFontColor: t.footerFontColor,
_footerFontFamily: i(t.footerFontFamily, e.defaultFontFamily),
_footerFontStyle: i(t.footerFontStyle, e.defaultFontStyle),
footerFontSize: i(t.footerFontSize, e.defaultFontSize),
_footerAlign: t.footerAlign,
footerSpacing: t.footerSpacing,
footerMarginTop: t.footerMarginTop,
caretSize: t.caretSize,
cornerRadius: t.cornerRadius,
backgroundColor: t.backgroundColor,
opacity: 0,
legendColorBackground: t.multiKeyBackground,
displayColors: t.displayColors,
borderColor: t.borderColor,
borderWidth: t.borderWidth
}
}
t.Tooltip = a.extend({
initialize: function () {
this._model = o(this._options), this._lastActive = []
}, getTitle: function () {
var t = this._options.callbacks, e = t.beforeTitle.apply(this, arguments),
n = t.title.apply(this, arguments), a = t.afterTitle.apply(this, arguments), r = [];
return r = i(r = i(r = i(r, e), n), a)
}, getBeforeBody: function () {
var t = this._options.callbacks.beforeBody.apply(this, arguments);
return r.isArray(t) ? t : void 0 !== t ? [t] : []
}, getBody: function (t, e) {
var n = this, a = n._options.callbacks, o = [];
return r.each(t, function (t) {
var r = {before: [], lines: [], after: []};
i(r.before, a.beforeLabel.call(n, t, e)), i(r.lines, a.label.call(n, t, e)), i(r.after, a.afterLabel.call(n, t, e)), o.push(r)
}), o
}, getAfterBody: function () {
var t = this._options.callbacks.afterBody.apply(this, arguments);
return r.isArray(t) ? t : void 0 !== t ? [t] : []
}, getFooter: function () {
var t = this._options.callbacks, e = t.beforeFooter.apply(this, arguments),
n = t.footer.apply(this, arguments), a = t.afterFooter.apply(this, arguments), r = [];
return r = i(r = i(r = i(r, e), n), a)
}, update: function (e) {
var i, n, a, s, l, u, d, h, c, f, g, m, p, v, y, b, x, _, k, w, M = this, S = M._options,
D = M._model, C = M._model = o(S), P = M._active, T = M._data,
O = {xAlign: D.xAlign, yAlign: D.yAlign}, I = {x: D.x, y: D.y},
A = {width: D.width, height: D.height}, F = {x: D.caretX, y: D.caretY};
if (P.length) {
C.opacity = 1;
var R = [], L = [];
F = t.Tooltip.positioners[S.position].call(M, P, M._eventPosition);
var W = [];
for (i = 0, n = P.length; i < n; ++i) W.push((b = P[i], x = void 0, _ = void 0, void 0, void 0, x = b._xScale, _ = b._yScale || b._scale, k = b._index, w = b._datasetIndex, {
xLabel: x ? x.getLabelForIndex(k, w) : "",
yLabel: _ ? _.getLabelForIndex(k, w) : "",
index: k,
datasetIndex: w,
x: b._model.x,
y: b._model.y
}));
S.filter && (W = W.filter(function (t) {
return S.filter(t, T)
})), S.itemSort && (W = W.sort(function (t, e) {
return S.itemSort(t, e, T)
})), r.each(W, function (t) {
R.push(S.callbacks.labelColor.call(M, t, M._chart)), L.push(S.callbacks.labelTextColor.call(M, t, M._chart))
}), C.title = M.getTitle(W, T), C.beforeBody = M.getBeforeBody(W, T), C.body = M.getBody(W, T), C.afterBody = M.getAfterBody(W, T), C.footer = M.getFooter(W, T), C.x = Math.round(F.x), C.y = Math.round(F.y), C.caretPadding = S.caretPadding, C.labelColors = R, C.labelTextColors = L, C.dataPoints = W, O = function (t, e) {
var i, n, a, r, o, s = t._model, l = t._chart, u = t._chart.chartArea, d = "center",
h = "center";
s.y < e.height ? h = "top" : s.y > l.height - e.height && (h = "bottom");
var c = (u.left + u.right) / 2, f = (u.top + u.bottom) / 2;
"center" === h ? (i = function (t) {
return t <= c
}, n = function (t) {
return t > c
}) : (i = function (t) {
return t <= e.width / 2
}, n = function (t) {
return t >= l.width - e.width / 2
}), a = function (t) {
return t + e.width + s.caretSize + s.caretPadding > l.width
}, r = function (t) {
return t - e.width - s.caretSize - s.caretPadding < 0
}, o = function (t) {
return t <= f ? "top" : "bottom"
}, i(s.x) ? (d = "left", a(s.x) && (d = "center", h = o(s.y))) : n(s.x) && (d = "right", r(s.x) && (d = "center", h = o(s.y)));
var g = t._options;
return {xAlign: g.xAlign ? g.xAlign : d, yAlign: g.yAlign ? g.yAlign : h}
}(this, A = function (t, e) {
var i = t._chart.ctx, n = 2 * e.yPadding, a = 0, o = e.body,
s = o.reduce(function (t, e) {
return t + e.before.length + e.lines.length + e.after.length
}, 0);
s += e.beforeBody.length + e.afterBody.length;
var l = e.title.length, u = e.footer.length, d = e.titleFontSize, h = e.bodyFontSize,
c = e.footerFontSize;
n += l * d, n += l ? (l - 1) * e.titleSpacing : 0, n += l ? e.titleMarginBottom : 0, n += s * h, n += s ? (s - 1) * e.bodySpacing : 0, n += u ? e.footerMarginTop : 0, n += u * c, n += u ? (u - 1) * e.footerSpacing : 0;
var f = 0, g = function (t) {
a = Math.max(a, i.measureText(t).width + f)
};
return i.font = r.fontString(d, e._titleFontStyle, e._titleFontFamily), r.each(e.title, g), i.font = r.fontString(h, e._bodyFontStyle, e._bodyFontFamily), r.each(e.beforeBody.concat(e.afterBody), g), f = e.displayColors ? h + 2 : 0, r.each(o, function (t) {
r.each(t.before, g), r.each(t.lines, g), r.each(t.after, g)
}), f = 0, i.font = r.fontString(c, e._footerFontStyle, e._footerFontFamily), r.each(e.footer, g), {
width: a += 2 * e.xPadding,
height: n
}
}(this, C)), a = C, s = A, l = O, u = M._chart, d = a.x, h = a.y, c = a.caretSize, f = a.caretPadding, g = a.cornerRadius, m = l.xAlign, p = l.yAlign, v = c + f, y = g + f, "right" === m ? d -= s.width : "center" === m && ((d -= s.width / 2) + s.width > u.width && (d = u.width - s.width), d < 0 && (d = 0)), "top" === p ? h += v : h -= "bottom" === p ? s.height + v : s.height / 2, "center" === p ? "left" === m ? d += v : "right" === m && (d -= v) : "left" === m ? d -= y : "right" === m && (d += y), I = {
x: d,
y: h
}
} else C.opacity = 0;
return C.xAlign = O.xAlign, C.yAlign = O.yAlign, C.x = I.x, C.y = I.y, C.width = A.width, C.height = A.height, C.caretX = F.x, C.caretY = F.y, M._model = C, e && S.custom && S.custom.call(M, C), M
}, drawCaret: function (t, e) {
var i = this._chart.ctx, n = this._view, a = this.getCaretPosition(t, e, n);
i.lineTo(a.x1, a.y1), i.lineTo(a.x2, a.y2), i.lineTo(a.x3, a.y3)
}, getCaretPosition: function (t, e, i) {
var n, a, r, o, s, l, u = i.caretSize, d = i.cornerRadius, h = i.xAlign, c = i.yAlign, f = t.x,
g = t.y, m = e.width, p = e.height;
if ("center" === c) s = g + p / 2, "left" === h ? (a = (n = f) - u, r = n, o = s + u, l = s - u) : (a = (n = f + m) + u, r = n, o = s - u, l = s + u); else if ("left" === h ? (n = (a = f + d + u) - u, r = a + u) : "right" === h ? (n = (a = f + m - d - u) - u, r = a + u) : (n = (a = i.caretX) - u, r = a + u), "top" === c) s = (o = g) - u, l = o; else {
s = (o = g + p) + u, l = o;
var v = r;
r = n, n = v
}
return {x1: n, x2: a, x3: r, y1: o, y2: s, y3: l}
}, drawTitle: function (t, i, n, a) {
var o = i.title;
if (o.length) {
n.textAlign = i._titleAlign, n.textBaseline = "top";
var s, l, u = i.titleFontSize, d = i.titleSpacing;
for (n.fillStyle = e(i.titleFontColor, a), n.font = r.fontString(u, i._titleFontStyle, i._titleFontFamily), s = 0, l = o.length; s < l; ++s) n.fillText(o[s], t.x, t.y), t.y += u + d, s + 1 === o.length && (t.y += i.titleMarginBottom - d)
}
}, drawBody: function (t, i, n, a) {
var o = i.bodyFontSize, s = i.bodySpacing, l = i.body;
n.textAlign = i._bodyAlign, n.textBaseline = "top", n.font = r.fontString(o, i._bodyFontStyle, i._bodyFontFamily);
var u = 0, d = function (e) {
n.fillText(e, t.x + u, t.y), t.y += o + s
};
n.fillStyle = e(i.bodyFontColor, a), r.each(i.beforeBody, d);
var h = i.displayColors;
u = h ? o + 2 : 0, r.each(l, function (s, l) {
var u = e(i.labelTextColors[l], a);
n.fillStyle = u, r.each(s.before, d), r.each(s.lines, function (r) {
h && (n.fillStyle = e(i.legendColorBackground, a), n.fillRect(t.x, t.y, o, o), n.lineWidth = 1, n.strokeStyle = e(i.labelColors[l].borderColor, a), n.strokeRect(t.x, t.y, o, o), n.fillStyle = e(i.labelColors[l].backgroundColor, a), n.fillRect(t.x + 1, t.y + 1, o - 2, o - 2), n.fillStyle = u), d(r)
}), r.each(s.after, d)
}), u = 0, r.each(i.afterBody, d), t.y -= s
}, drawFooter: function (t, i, n, a) {
var o = i.footer;
o.length && (t.y += i.footerMarginTop, n.textAlign = i._footerAlign, n.textBaseline = "top", n.fillStyle = e(i.footerFontColor, a), n.font = r.fontString(i.footerFontSize, i._footerFontStyle, i._footerFontFamily), r.each(o, function (e) {
n.fillText(e, t.x, t.y), t.y += i.footerFontSize + i.footerSpacing
}))
}, drawBackground: function (t, i, n, a, r) {
n.fillStyle = e(i.backgroundColor, r), n.strokeStyle = e(i.borderColor, r), n.lineWidth = i.borderWidth;
var o = i.xAlign, s = i.yAlign, l = t.x, u = t.y, d = a.width, h = a.height, c = i.cornerRadius;
n.beginPath(), n.moveTo(l + c, u), "top" === s && this.drawCaret(t, a), n.lineTo(l + d - c, u), n.quadraticCurveTo(l + d, u, l + d, u + c), "center" === s && "right" === o && this.drawCaret(t, a), n.lineTo(l + d, u + h - c), n.quadraticCurveTo(l + d, u + h, l + d - c, u + h), "bottom" === s && this.drawCaret(t, a), n.lineTo(l + c, u + h), n.quadraticCurveTo(l, u + h, l, u + h - c), "center" === s && "left" === o && this.drawCaret(t, a), n.lineTo(l, u + c), n.quadraticCurveTo(l, u, l + c, u), n.closePath(), n.fill(), i.borderWidth > 0 && n.stroke()
}, draw: function () {
var t = this._chart.ctx, e = this._view;
if (0 !== e.opacity) {
var i = {width: e.width, height: e.height}, n = {x: e.x, y: e.y},
a = Math.abs(e.opacity < .001) ? 0 : e.opacity,
r = e.title.length || e.beforeBody.length || e.body.length || e.afterBody.length || e.footer.length;
this._options.enabled && r && (this.drawBackground(n, e, t, i, a), n.x += e.xPadding, n.y += e.yPadding, this.drawTitle(n, e, t, a), this.drawBody(n, e, t, a), this.drawFooter(n, e, t, a))
}
}, handleEvent: function (t) {
var e, i = this, n = i._options;
return i._lastActive = i._lastActive || [], "mouseout" === t.type ? i._active = [] : i._active = i._chart.getElementsAtEventForMode(t, n.mode, n), (e = !r.arrayEquals(i._active, i._lastActive)) && (i._lastActive = i._active, (n.enabled || n.custom) && (i._eventPosition = {
x: t.x,
y: t.y
}, i.update(!0), i.pivot())), e
}
}), t.Tooltip.positioners = {
average: function (t) {
if (!t.length) return !1;
var e, i, n = 0, a = 0, r = 0;
for (e = 0, i = t.length; e < i; ++e) {
var o = t[e];
if (o && o.hasValue()) {
var s = o.tooltipPosition();
n += s.x, a += s.y, ++r
}
}
return {x: Math.round(n / r), y: Math.round(a / r)}
}, nearest: function (t, e) {
var i, n, a, o = e.x, s = e.y, l = Number.POSITIVE_INFINITY;
for (i = 0, n = t.length; i < n; ++i) {
var u = t[i];
if (u && u.hasValue()) {
var d = u.getCenterPoint(), h = r.distanceBetweenPoints(e, d);
h < l && (l = h, a = u)
}
}
if (a) {
var c = a.tooltipPosition();
o = c.x, s = c.y
}
return {x: o, y: s}
}
}
}
}, {25: 25, 26: 26, 45: 45}], 36: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26), r = t(45);
n._set("global", {
elements: {
arc: {
backgroundColor: n.global.defaultColor,
borderColor: "#fff",
borderWidth: 2
}
}
}), e.exports = a.extend({
inLabelRange: function (t) {
var e = this._view;
return !!e && Math.pow(t - e.x, 2) < Math.pow(e.radius + e.hoverRadius, 2)
}, inRange: function (t, e) {
var i = this._view;
if (i) {
for (var n = r.getAngleFromPoint(i, {
x: t,
y: e
}), a = n.angle, o = n.distance, s = i.startAngle, l = i.endAngle; l < s;) l += 2 * Math.PI;
for (; a > l;) a -= 2 * Math.PI;
for (; a < s;) a += 2 * Math.PI;
var u = a >= s && a <= l, d = o >= i.innerRadius && o <= i.outerRadius;
return u && d
}
return !1
}, getCenterPoint: function () {
var t = this._view, e = (t.startAngle + t.endAngle) / 2, i = (t.innerRadius + t.outerRadius) / 2;
return {x: t.x + Math.cos(e) * i, y: t.y + Math.sin(e) * i}
}, getArea: function () {
var t = this._view;
return Math.PI * ((t.endAngle - t.startAngle) / (2 * Math.PI)) * (Math.pow(t.outerRadius, 2) - Math.pow(t.innerRadius, 2))
}, tooltipPosition: function () {
var t = this._view, e = t.startAngle + (t.endAngle - t.startAngle) / 2,
i = (t.outerRadius - t.innerRadius) / 2 + t.innerRadius;
return {x: t.x + Math.cos(e) * i, y: t.y + Math.sin(e) * i}
}, draw: function () {
var t = this._chart.ctx, e = this._view, i = e.startAngle, n = e.endAngle;
t.beginPath(), t.arc(e.x, e.y, e.outerRadius, i, n), t.arc(e.x, e.y, e.innerRadius, n, i, !0), t.closePath(), t.strokeStyle = e.borderColor, t.lineWidth = e.borderWidth, t.fillStyle = e.backgroundColor, t.fill(), t.lineJoin = "bevel", e.borderWidth && t.stroke()
}
})
}, {25: 25, 26: 26, 45: 45}], 37: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26), r = t(45), o = n.global;
n._set("global", {
elements: {
line: {
tension: .4,
backgroundColor: o.defaultColor,
borderWidth: 3,
borderColor: o.defaultColor,
borderCapStyle: "butt",
borderDash: [],
borderDashOffset: 0,
borderJoinStyle: "miter",
capBezierPoints: !0,
fill: !0
}
}
}), e.exports = a.extend({
draw: function () {
var t, e, i, n, a = this._view, s = this._chart.ctx, l = a.spanGaps, u = this._children.slice(),
d = o.elements.line, h = -1;
for (this._loop && u.length && u.push(u[0]), s.save(), s.lineCap = a.borderCapStyle || d.borderCapStyle, s.setLineDash && s.setLineDash(a.borderDash || d.borderDash), s.lineDashOffset = a.borderDashOffset || d.borderDashOffset, s.lineJoin = a.borderJoinStyle || d.borderJoinStyle, s.lineWidth = a.borderWidth || d.borderWidth, s.strokeStyle = a.borderColor || o.defaultColor, s.beginPath(), h = -1, t = 0; t < u.length; ++t) e = u[t], i = r.previousItem(u, t), n = e._view, 0 === t ? n.skip || (s.moveTo(n.x, n.y), h = t) : (i = -1 === h ? i : u[h], n.skip || (h !== t - 1 && !l || -1 === h ? s.moveTo(n.x, n.y) : r.canvas.lineTo(s, i._view, e._view), h = t));
s.stroke(), s.restore()
}
})
}, {25: 25, 26: 26, 45: 45}], 38: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26), r = t(45), o = n.global.defaultColor;
function s(t) {
var e = this._view;
return !!e && Math.abs(t - e.x) < e.radius + e.hitRadius
}
n._set("global", {
elements: {
point: {
radius: 3,
pointStyle: "circle",
backgroundColor: o,
borderColor: o,
borderWidth: 1,
hitRadius: 1,
hoverRadius: 4,
hoverBorderWidth: 1
}
}
}), e.exports = a.extend({
inRange: function (t, e) {
var i = this._view;
return !!i && Math.pow(t - i.x, 2) + Math.pow(e - i.y, 2) < Math.pow(i.hitRadius + i.radius, 2)
}, inLabelRange: s, inXRange: s, inYRange: function (t) {
var e = this._view;
return !!e && Math.abs(t - e.y) < e.radius + e.hitRadius
}, getCenterPoint: function () {
var t = this._view;
return {x: t.x, y: t.y}
}, getArea: function () {
return Math.PI * Math.pow(this._view.radius, 2)
}, tooltipPosition: function () {
var t = this._view;
return {x: t.x, y: t.y, padding: t.radius + t.borderWidth}
}, draw: function (t) {
var e = this._view, i = this._model, a = this._chart.ctx, s = e.pointStyle, l = e.radius, u = e.x,
d = e.y, h = r.color, c = 0;
e.skip || (a.strokeStyle = e.borderColor || o, a.lineWidth = r.valueOrDefault(e.borderWidth, n.global.elements.point.borderWidth), a.fillStyle = e.backgroundColor || o, void 0 !== t && (i.x < t.left || 1.01 * t.right < i.x || i.y < t.top || 1.01 * t.bottom < i.y) && (i.x < t.left ? c = (u - i.x) / (t.left - i.x) : 1.01 * t.right < i.x ? c = (i.x - u) / (i.x - t.right) : i.y < t.top ? c = (d - i.y) / (t.top - i.y) : 1.01 * t.bottom < i.y && (c = (i.y - d) / (i.y - t.bottom)), c = Math.round(100 * c) / 100, a.strokeStyle = h(a.strokeStyle).alpha(c).rgbString(), a.fillStyle = h(a.fillStyle).alpha(c).rgbString()), r.canvas.drawPoint(a, s, l, u, d))
}
})
}, {25: 25, 26: 26, 45: 45}], 39: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26);
function r(t) {
return void 0 !== t._view.width
}
function o(t) {
var e, i, n, a, o = t._view;
if (r(t)) {
var s = o.width / 2;
e = o.x - s, i = o.x + s, n = Math.min(o.y, o.base), a = Math.max(o.y, o.base)
} else {
var l = o.height / 2;
e = Math.min(o.x, o.base), i = Math.max(o.x, o.base), n = o.y - l, a = o.y + l
}
return {left: e, top: n, right: i, bottom: a}
}
n._set("global", {
elements: {
rectangle: {
backgroundColor: n.global.defaultColor,
borderColor: n.global.defaultColor,
borderSkipped: "bottom",
borderWidth: 0
}
}
}), e.exports = a.extend({
draw: function () {
var t, e, i, n, a, r, o, s = this._chart.ctx, l = this._view, u = l.borderWidth;
if (l.horizontal ? (t = l.base, e = l.x, i = l.y - l.height / 2, n = l.y + l.height / 2, a = e > t ? 1 : -1, r = 1, o = l.borderSkipped || "left") : (t = l.x - l.width / 2, e = l.x + l.width / 2, i = l.y, a = 1, r = (n = l.base) > i ? 1 : -1, o = l.borderSkipped || "bottom"), u) {
var d = Math.min(Math.abs(t - e), Math.abs(i - n)), h = (u = u > d ? d : u) / 2,
c = t + ("left" !== o ? h * a : 0), f = e + ("right" !== o ? -h * a : 0),
g = i + ("top" !== o ? h * r : 0), m = n + ("bottom" !== o ? -h * r : 0);
c !== f && (i = g, n = m), g !== m && (t = c, e = f)
}
s.beginPath(), s.fillStyle = l.backgroundColor, s.strokeStyle = l.borderColor, s.lineWidth = u;
var p = [[t, n], [t, i], [e, i], [e, n]], v = ["bottom", "left", "top", "right"].indexOf(o, 0);
function y(t) {
return p[(v + t) % 4]
}
-1 === v && (v = 0);
var b = y(0);
s.moveTo(b[0], b[1]);
for (var x = 1; x < 4; x++) b = y(x), s.lineTo(b[0], b[1]);
s.fill(), u && s.stroke()
}, height: function () {
var t = this._view;
return t.base - t.y
}, inRange: function (t, e) {
var i = !1;
if (this._view) {
var n = o(this);
i = t >= n.left && t <= n.right && e >= n.top && e <= n.bottom
}
return i
}, inLabelRange: function (t, e) {
if (!this._view) return !1;
var i = o(this);
return r(this) ? t >= i.left && t <= i.right : e >= i.top && e <= i.bottom
}, inXRange: function (t) {
var e = o(this);
return t >= e.left && t <= e.right
}, inYRange: function (t) {
var e = o(this);
return t >= e.top && t <= e.bottom
}, getCenterPoint: function () {
var t, e, i = this._view;
return r(this) ? (t = i.x, e = (i.y + i.base) / 2) : (t = (i.x + i.base) / 2, e = i.y), {x: t, y: e}
}, getArea: function () {
var t = this._view;
return t.width * Math.abs(t.y - t.base)
}, tooltipPosition: function () {
var t = this._view;
return {x: t.x, y: t.y}
}
})
}, {25: 25, 26: 26}], 40: [function (t, e, i) {
"use strict";
e.exports = {}, e.exports.Arc = t(36), e.exports.Line = t(37), e.exports.Point = t(38), e.exports.Rectangle = t(39)
}, {36: 36, 37: 37, 38: 38, 39: 39}], 41: [function (t, e, i) {
"use strict";
var n = t(42);
i = e.exports = {
clear: function (t) {
t.ctx.clearRect(0, 0, t.width, t.height)
}, roundedRect: function (t, e, i, n, a, r) {
if (r) {
var o = Math.min(r, n / 2), s = Math.min(r, a / 2);
t.moveTo(e + o, i), t.lineTo(e + n - o, i), t.quadraticCurveTo(e + n, i, e + n, i + s), t.lineTo(e + n, i + a - s), t.quadraticCurveTo(e + n, i + a, e + n - o, i + a), t.lineTo(e + o, i + a), t.quadraticCurveTo(e, i + a, e, i + a - s), t.lineTo(e, i + s), t.quadraticCurveTo(e, i, e + o, i)
} else t.rect(e, i, n, a)
}, drawPoint: function (t, e, i, n, a) {
var r, o, s, l, u, d;
if (!e || "object" != typeof e || "[object HTMLImageElement]" !== (r = e.toString()) && "[object HTMLCanvasElement]" !== r) {
if (!(isNaN(i) || i <= 0)) {
switch (e) {
default:
t.beginPath(), t.arc(n, a, i, 0, 2 * Math.PI), t.closePath(), t.fill();
break;
case"triangle":
t.beginPath(), u = (o = 3 * i / Math.sqrt(3)) * Math.sqrt(3) / 2, t.moveTo(n - o / 2, a + u / 3), t.lineTo(n + o / 2, a + u / 3), t.lineTo(n, a - 2 * u / 3), t.closePath(), t.fill();
break;
case"rect":
d = 1 / Math.SQRT2 * i, t.beginPath(), t.fillRect(n - d, a - d, 2 * d, 2 * d), t.strokeRect(n - d, a - d, 2 * d, 2 * d);
break;
case"rectRounded":
var h = i / Math.SQRT2, c = n - h, f = a - h, g = Math.SQRT2 * i;
t.beginPath(), this.roundedRect(t, c, f, g, g, i / 2), t.closePath(), t.fill();
break;
case"rectRot":
d = 1 / Math.SQRT2 * i, t.beginPath(), t.moveTo(n - d, a), t.lineTo(n, a + d), t.lineTo(n + d, a), t.lineTo(n, a - d), t.closePath(), t.fill();
break;
case"cross":
t.beginPath(), t.moveTo(n, a + i), t.lineTo(n, a - i), t.moveTo(n - i, a), t.lineTo(n + i, a), t.closePath();
break;
case"crossRot":
t.beginPath(), s = Math.cos(Math.PI / 4) * i, l = Math.sin(Math.PI / 4) * i, t.moveTo(n - s, a - l), t.lineTo(n + s, a + l), t.moveTo(n - s, a + l), t.lineTo(n + s, a - l), t.closePath();
break;
case"star":
t.beginPath(), t.moveTo(n, a + i), t.lineTo(n, a - i), t.moveTo(n - i, a), t.lineTo(n + i, a), s = Math.cos(Math.PI / 4) * i, l = Math.sin(Math.PI / 4) * i, t.moveTo(n - s, a - l), t.lineTo(n + s, a + l), t.moveTo(n - s, a + l), t.lineTo(n + s, a - l), t.closePath();
break;
case"line":
t.beginPath(), t.moveTo(n - i, a), t.lineTo(n + i, a), t.closePath();
break;
case"dash":
t.beginPath(), t.moveTo(n, a), t.lineTo(n + i, a), t.closePath()
}
t.stroke()
}
} else t.drawImage(e, n - e.width / 2, a - e.height / 2, e.width, e.height)
}, clipArea: function (t, e) {
t.save(), t.beginPath(), t.rect(e.left, e.top, e.right - e.left, e.bottom - e.top), t.clip()
}, unclipArea: function (t) {
t.restore()
}, lineTo: function (t, e, i, n) {
if (i.steppedLine) return "after" === i.steppedLine && !n || "after" !== i.steppedLine && n ? t.lineTo(e.x, i.y) : t.lineTo(i.x, e.y), void t.lineTo(i.x, i.y);
i.tension ? t.bezierCurveTo(n ? e.controlPointPreviousX : e.controlPointNextX, n ? e.controlPointPreviousY : e.controlPointNextY, n ? i.controlPointNextX : i.controlPointPreviousX, n ? i.controlPointNextY : i.controlPointPreviousY, i.x, i.y) : t.lineTo(i.x, i.y)
}
};
n.clear = i.clear, n.drawRoundedRectangle = function (t) {
t.beginPath(), i.roundedRect.apply(i, arguments), t.closePath()
}
}, {42: 42}], 42: [function (t, e, i) {
"use strict";
var n, a = {
noop: function () {
}, uid: (n = 0, function () {
return n++
}), isNullOrUndef: function (t) {
return null == t
}, isArray: Array.isArray ? Array.isArray : function (t) {
return "[object Array]" === Object.prototype.toString.call(t)
}, isObject: function (t) {
return null !== t && "[object Object]" === Object.prototype.toString.call(t)
}, valueOrDefault: function (t, e) {
return void 0 === t ? e : t
}, valueAtIndexOrDefault: function (t, e, i) {
return a.valueOrDefault(a.isArray(t) ? t[e] : t, i)
}, callback: function (t, e, i) {
if (t && "function" == typeof t.call) return t.apply(i, e)
}, each: function (t, e, i, n) {
var r, o, s;
if (a.isArray(t)) if (o = t.length, n) for (r = o - 1; r >= 0; r--) e.call(i, t[r], r); else for (r = 0; r < o; r++) e.call(i, t[r], r); else if (a.isObject(t)) for (o = (s = Object.keys(t)).length, r = 0; r < o; r++) e.call(i, t[s[r]], s[r])
}, arrayEquals: function (t, e) {
var i, n, r, o;
if (!t || !e || t.length !== e.length) return !1;
for (i = 0, n = t.length; i < n; ++i) if (r = t[i], o = e[i], r instanceof Array && o instanceof Array) {
if (!a.arrayEquals(r, o)) return !1
} else if (r !== o) return !1;
return !0
}, clone: function (t) {
if (a.isArray(t)) return t.map(a.clone);
if (a.isObject(t)) {
for (var e = {}, i = Object.keys(t), n = i.length, r = 0; r < n; ++r) e[i[r]] = a.clone(t[i[r]]);
return e
}
return t
}, _merger: function (t, e, i, n) {
var r = e[t], o = i[t];
a.isObject(r) && a.isObject(o) ? a.merge(r, o, n) : e[t] = a.clone(o)
}, _mergerIf: function (t, e, i) {
var n = e[t], r = i[t];
a.isObject(n) && a.isObject(r) ? a.mergeIf(n, r) : e.hasOwnProperty(t) || (e[t] = a.clone(r))
}, merge: function (t, e, i) {
var n, r, o, s, l, u = a.isArray(e) ? e : [e], d = u.length;
if (!a.isObject(t)) return t;
for (n = (i = i || {}).merger || a._merger, r = 0; r < d; ++r) if (e = u[r], a.isObject(e)) for (l = 0, s = (o = Object.keys(e)).length; l < s; ++l) n(o[l], t, e, i);
return t
}, mergeIf: function (t, e) {
return a.merge(t, e, {merger: a._mergerIf})
}, extend: function (t) {
for (var e = function (e, i) {
t[i] = e
}, i = 1, n = arguments.length; i < n; ++i) a.each(arguments[i], e);
return t
}, inherits: function (t) {
var e = this, i = t && t.hasOwnProperty("constructor") ? t.constructor : function () {
return e.apply(this, arguments)
}, n = function () {
this.constructor = i
};
return n.prototype = e.prototype, i.prototype = new n, i.extend = a.inherits, t && a.extend(i.prototype, t), i.__super__ = e.prototype, i
}
};
e.exports = a, a.callCallback = a.callback, a.indexOf = function (t, e, i) {
return Array.prototype.indexOf.call(t, e, i)
}, a.getValueOrDefault = a.valueOrDefault, a.getValueAtIndexOrDefault = a.valueAtIndexOrDefault
}, {}], 43: [function (t, e, i) {
"use strict";
var n = t(42), a = {
linear: function (t) {
return t
}, easeInQuad: function (t) {
return t * t
}, easeOutQuad: function (t) {
return -t * (t - 2)
}, easeInOutQuad: function (t) {
return (t /= .5) < 1 ? .5 * t * t : -.5 * (--t * (t - 2) - 1)
}, easeInCubic: function (t) {
return t * t * t
}, easeOutCubic: function (t) {
return (t -= 1) * t * t + 1
}, easeInOutCubic: function (t) {
return (t /= .5) < 1 ? .5 * t * t * t : .5 * ((t -= 2) * t * t + 2)
}, easeInQuart: function (t) {
return t * t * t * t
}, easeOutQuart: function (t) {
return -((t -= 1) * t * t * t - 1)
}, easeInOutQuart: function (t) {
return (t /= .5) < 1 ? .5 * t * t * t * t : -.5 * ((t -= 2) * t * t * t - 2)
}, easeInQuint: function (t) {
return t * t * t * t * t
}, easeOutQuint: function (t) {
return (t -= 1) * t * t * t * t + 1
}, easeInOutQuint: function (t) {
return (t /= .5) < 1 ? .5 * t * t * t * t * t : .5 * ((t -= 2) * t * t * t * t + 2)
}, easeInSine: function (t) {
return 1 - Math.cos(t * (Math.PI / 2))
}, easeOutSine: function (t) {
return Math.sin(t * (Math.PI / 2))
}, easeInOutSine: function (t) {
return -.5 * (Math.cos(Math.PI * t) - 1)
}, easeInExpo: function (t) {
return 0 === t ? 0 : Math.pow(2, 10 * (t - 1))
}, easeOutExpo: function (t) {
return 1 === t ? 1 : 1 - Math.pow(2, -10 * t)
}, easeInOutExpo: function (t) {
return 0 === t ? 0 : 1 === t ? 1 : (t /= .5) < 1 ? .5 * Math.pow(2, 10 * (t - 1)) : .5 * (2 - Math.pow(2, -10 * --t))
}, easeInCirc: function (t) {
return t >= 1 ? t : -(Math.sqrt(1 - t * t) - 1)
}, easeOutCirc: function (t) {
return Math.sqrt(1 - (t -= 1) * t)
}, easeInOutCirc: function (t) {
return (t /= .5) < 1 ? -.5 * (Math.sqrt(1 - t * t) - 1) : .5 * (Math.sqrt(1 - (t -= 2) * t) + 1)
}, easeInElastic: function (t) {
var e = 1.70158, i = 0, n = 1;
return 0 === t ? 0 : 1 === t ? 1 : (i || (i = .3), n < 1 ? (n = 1, e = i / 4) : e = i / (2 * Math.PI) * Math.asin(1 / n), -n * Math.pow(2, 10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / i))
}, easeOutElastic: function (t) {
var e = 1.70158, i = 0, n = 1;
return 0 === t ? 0 : 1 === t ? 1 : (i || (i = .3), n < 1 ? (n = 1, e = i / 4) : e = i / (2 * Math.PI) * Math.asin(1 / n), n * Math.pow(2, -10 * t) * Math.sin((t - e) * (2 * Math.PI) / i) + 1)
}, easeInOutElastic: function (t) {
var e = 1.70158, i = 0, n = 1;
return 0 === t ? 0 : 2 == (t /= .5) ? 1 : (i || (i = .45), n < 1 ? (n = 1, e = i / 4) : e = i / (2 * Math.PI) * Math.asin(1 / n), t < 1 ? n * Math.pow(2, 10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / i) * -.5 : n * Math.pow(2, -10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / i) * .5 + 1)
}, easeInBack: function (t) {
return t * t * (2.70158 * t - 1.70158)
}, easeOutBack: function (t) {
return (t -= 1) * t * (2.70158 * t + 1.70158) + 1
}, easeInOutBack: function (t) {
var e = 1.70158;
return (t /= .5) < 1 ? t * t * ((1 + (e *= 1.525)) * t - e) * .5 : .5 * ((t -= 2) * t * ((1 + (e *= 1.525)) * t + e) + 2)
}, easeInBounce: function (t) {
return 1 - a.easeOutBounce(1 - t)
}, easeOutBounce: function (t) {
return t < 1 / 2.75 ? 7.5625 * t * t : t < 2 / 2.75 ? 7.5625 * (t -= 1.5 / 2.75) * t + .75 : t < 2.5 / 2.75 ? 7.5625 * (t -= 2.25 / 2.75) * t + .9375 : 7.5625 * (t -= 2.625 / 2.75) * t + .984375
}, easeInOutBounce: function (t) {
return t < .5 ? .5 * a.easeInBounce(2 * t) : .5 * a.easeOutBounce(2 * t - 1) + .5
}
};
e.exports = {effects: a}, n.easingEffects = a
}, {42: 42}], 44: [function (t, e, i) {
"use strict";
var n = t(42);
e.exports = {
toLineHeight: function (t, e) {
var i = ("" + t).match(/^(normal|(\d+(?:\.\d+)?)(px|em|%)?)$/);
if (!i || "normal" === i[1]) return 1.2 * e;
switch (t = +i[2], i[3]) {
case"px":
return t;
case"%":
t /= 100
}
return e * t
}, toPadding: function (t) {
var e, i, a, r;
return n.isObject(t) ? (e = +t.top || 0, i = +t.right || 0, a = +t.bottom || 0, r = +t.left || 0) : e = i = a = r = +t || 0, {
top: e,
right: i,
bottom: a,
left: r,
height: e + a,
width: r + i
}
}, resolve: function (t, e, i) {
var a, r, o;
for (a = 0, r = t.length; a < r; ++a) if (void 0 !== (o = t[a]) && (void 0 !== e && "function" == typeof o && (o = o(e)), void 0 !== i && n.isArray(o) && (o = o[i]), void 0 !== o)) return o
}
}
}, {42: 42}], 45: [function (t, e, i) {
"use strict";
e.exports = t(42), e.exports.easing = t(43), e.exports.canvas = t(41), e.exports.options = t(44)
}, {41: 41, 42: 42, 43: 43, 44: 44}], 46: [function (t, e, i) {
e.exports = {
acquireContext: function (t) {
return t && t.canvas && (t = t.canvas), t && t.getContext("2d") || null
}
}
}, {}], 47: [function (t, e, i) {
"use strict";
var n = t(45), a = "$chartjs", r = "chartjs-", o = r + "render-monitor", s = r + "render-animation",
l = ["animationstart", "webkitAnimationStart"], u = {
touchstart: "mousedown",
touchmove: "mousemove",
touchend: "mouseup",
pointerenter: "mouseenter",
pointerdown: "mousedown",
pointermove: "mousemove",
pointerup: "mouseup",
pointerleave: "mouseout",
pointerout: "mouseout"
};
function d(t, e) {
var i = n.getStyle(t, e), a = i && i.match(/^(\d+)(\.\d+)?px$/);
return a ? Number(a[1]) : void 0
}
var h = !!function () {
var t = !1;
try {
var e = Object.defineProperty({}, "passive", {
get: function () {
t = !0
}
});
window.addEventListener("e", null, e)
} catch (t) {
}
return t
}() && {passive: !0};
function c(t, e, i) {
t.addEventListener(e, i, h)
}
function f(t, e, i) {
t.removeEventListener(e, i, h)
}
function g(t, e, i, n, a) {
return {type: t, chart: e, native: a || null, x: void 0 !== i ? i : null, y: void 0 !== n ? n : null}
}
function m(t, e, i) {
var u, d, h, f, m, p, v, y, b = t[a] || (t[a] = {}), x = b.resizer = function (t) {
var e = document.createElement("div"), i = r + "size-monitor",
n = "position:absolute;left:0;top:0;right:0;bottom:0;overflow:hidden;pointer-events:none;visibility:hidden;z-index:-1;";
e.style.cssText = n, e.className = i, e.innerHTML = '';
var a = e.childNodes[0], o = e.childNodes[1];
e._reset = function () {
a.scrollLeft = 1e6, a.scrollTop = 1e6, o.scrollLeft = 1e6, o.scrollTop = 1e6
};
var s = function () {
e._reset(), t()
};
return c(a, "scroll", s.bind(a, "expand")), c(o, "scroll", s.bind(o, "shrink")), e
}((u = function () {
if (b.resizer) return e(g("resize", i))
}, h = !1, f = [], function () {
f = Array.prototype.slice.call(arguments), d = d || this, h || (h = !0, n.requestAnimFrame.call(window, function () {
h = !1, u.apply(d, f)
}))
}));
p = function () {
if (b.resizer) {
var e = t.parentNode;
e && e !== x.parentNode && e.insertBefore(x, e.firstChild), x._reset()
}
}, v = (m = t)[a] || (m[a] = {}), y = v.renderProxy = function (t) {
t.animationName === s && p()
}, n.each(l, function (t) {
c(m, t, y)
}), v.reflow = !!m.offsetParent, m.classList.add(o)
}
function p(t) {
var e, i, r, s = t[a] || {}, u = s.resizer;
delete s.resizer, i = (e = t)[a] || {}, (r = i.renderProxy) && (n.each(l, function (t) {
f(e, t, r)
}), delete i.renderProxy), e.classList.remove(o), u && u.parentNode && u.parentNode.removeChild(u)
}
e.exports = {
_enabled: "undefined" != typeof window && "undefined" != typeof document,
initialize: function () {
var t, e, i, n = "from{opacity:0.99}to{opacity:1}";
e = "@-webkit-keyframes " + s + "{" + n + "}@keyframes " + s + "{" + n + "}." + o + "{-webkit-animation:" + s + " 0.001s;animation:" + s + " 0.001s;}", i = (t = this)._style || document.createElement("style"), t._style || (t._style = i, e = "/* Chart.js */\n" + e, i.setAttribute("type", "text/css"), document.getElementsByTagName("head")[0].appendChild(i)), i.appendChild(document.createTextNode(e))
},
acquireContext: function (t, e) {
"string" == typeof t ? t = document.getElementById(t) : t.length && (t = t[0]), t && t.canvas && (t = t.canvas);
var i = t && t.getContext && t.getContext("2d");
return i && i.canvas === t ? (function (t, e) {
var i = t.style, n = t.getAttribute("height"), r = t.getAttribute("width");
if (t[a] = {
initial: {
height: n,
width: r,
style: {display: i.display, height: i.height, width: i.width}
}
}, i.display = i.display || "block", null === r || "" === r) {
var o = d(t, "width");
void 0 !== o && (t.width = o)
}
if (null === n || "" === n) if ("" === t.style.height) t.height = t.width / (e.options.aspectRatio || 2); else {
var s = d(t, "height");
void 0 !== o && (t.height = s)
}
}(t, e), i) : null
},
releaseContext: function (t) {
var e = t.canvas;
if (e[a]) {
var i = e[a].initial;
["height", "width"].forEach(function (t) {
var a = i[t];
n.isNullOrUndef(a) ? e.removeAttribute(t) : e.setAttribute(t, a)
}), n.each(i.style || {}, function (t, i) {
e.style[i] = t
}), e.width = e.width, delete e[a]
}
},
addEventListener: function (t, e, i) {
var r = t.canvas;
if ("resize" !== e) {
var o = i[a] || (i[a] = {});
c(r, e, (o.proxies || (o.proxies = {}))[t.id + "_" + e] = function (e) {
var a, r, o, s;
i((r = t, o = u[(a = e).type] || a.type, s = n.getRelativePosition(a, r), g(o, r, s.x, s.y, a)))
})
} else m(r, i, t)
},
removeEventListener: function (t, e, i) {
var n = t.canvas;
if ("resize" !== e) {
var r = ((i[a] || {}).proxies || {})[t.id + "_" + e];
r && f(n, e, r)
} else p(n)
}
}, n.addEvent = c, n.removeEvent = f
}, {45: 45}], 48: [function (t, e, i) {
"use strict";
var n = t(45), a = t(46), r = t(47), o = r._enabled ? r : a;
e.exports = n.extend({
initialize: function () {
}, acquireContext: function () {
}, releaseContext: function () {
}, addEventListener: function () {
}, removeEventListener: function () {
}
}, o)
}, {45: 45, 46: 46, 47: 47}], 49: [function (t, e, i) {
"use strict";
e.exports = {}, e.exports.filler = t(50), e.exports.legend = t(51), e.exports.title = t(52)
}, {50: 50, 51: 51, 52: 52}], 50: [function (t, e, i) {
"use strict";
var n = t(25), a = t(40), r = t(45);
n._set("global", {plugins: {filler: {propagate: !0}}});
var o = {
dataset: function (t) {
var e = t.fill, i = t.chart, n = i.getDatasetMeta(e),
a = n && i.isDatasetVisible(e) && n.dataset._children || [], r = a.length || 0;
return r ? function (t, e) {
return e < r && a[e]._view || null
} : null
}, boundary: function (t) {
var e = t.boundary, i = e ? e.x : null, n = e ? e.y : null;
return function (t) {
return {x: null === i ? t.x : i, y: null === n ? t.y : n}
}
}
};
function s(t, e, i) {
var n, a = t._model || {}, r = a.fill;
if (void 0 === r && (r = !!a.backgroundColor), !1 === r || null === r) return !1;
if (!0 === r) return "origin";
if (n = parseFloat(r, 10), isFinite(n) && Math.floor(n) === n) return "-" !== r[0] && "+" !== r[0] || (n = e + n), !(n === e || n < 0 || n >= i) && n;
switch (r) {
case"bottom":
return "start";
case"top":
return "end";
case"zero":
return "origin";
case"origin":
case"start":
case"end":
return r;
default:
return !1
}
}
function l(t) {
var e, i = t.el._model || {}, n = t.el._scale || {}, a = t.fill, r = null;
if (isFinite(a)) return null;
if ("start" === a ? r = void 0 === i.scaleBottom ? n.bottom : i.scaleBottom : "end" === a ? r = void 0 === i.scaleTop ? n.top : i.scaleTop : void 0 !== i.scaleZero ? r = i.scaleZero : n.getBasePosition ? r = n.getBasePosition() : n.getBasePixel && (r = n.getBasePixel()), null != r) {
if (void 0 !== r.x && void 0 !== r.y) return r;
if ("number" == typeof r && isFinite(r)) return {
x: (e = n.isHorizontal()) ? r : null,
y: e ? null : r
}
}
return null
}
function u(t, e, i) {
var n, a = t[e].fill, r = [e];
if (!i) return a;
for (; !1 !== a && -1 === r.indexOf(a);) {
if (!isFinite(a)) return a;
if (!(n = t[a])) return !1;
if (n.visible) return a;
r.push(a), a = n.fill
}
return !1
}
function d(t) {
return t && !t.skip
}
function h(t, e, i, n, a) {
var o;
if (n && a) {
for (t.moveTo(e[0].x, e[0].y), o = 1; o < n; ++o) r.canvas.lineTo(t, e[o - 1], e[o]);
for (t.lineTo(i[a - 1].x, i[a - 1].y), o = a - 1; o > 0; --o) r.canvas.lineTo(t, i[o], i[o - 1], !0)
}
}
e.exports = {
id: "filler", afterDatasetsUpdate: function (t, e) {
var i, n, r, d, h, c, f, g = (t.data.datasets || []).length, m = e.propagate, p = [];
for (n = 0; n < g; ++n) d = null, (r = (i = t.getDatasetMeta(n)).dataset) && r._model && r instanceof a.Line && (d = {
visible: t.isDatasetVisible(n),
fill: s(r, n, g),
chart: t,
el: r
}), i.$filler = d, p.push(d);
for (n = 0; n < g; ++n) (d = p[n]) && (d.fill = u(p, n, m), d.boundary = l(d), d.mapper = (void 0, f = void 0, c = (h = d).fill, f = "dataset", !1 === c ? null : (isFinite(c) || (f = "boundary"), o[f](h))))
}, beforeDatasetDraw: function (t, e) {
var i = e.meta.$filler;
if (i) {
var a = t.ctx, o = i.el, s = o._view, l = o._children || [], u = i.mapper,
c = s.backgroundColor || n.global.defaultColor;
u && c && l.length && (r.canvas.clipArea(a, t.chartArea), function (t, e, i, n, a, r) {
var o, s, l, u, c, f, g, m = e.length, p = n.spanGaps, v = [], y = [], b = 0, x = 0;
for (t.beginPath(), o = 0, s = m + !!r; o < s; ++o) c = i(u = e[l = o % m]._view, l, n), f = d(u), g = d(c), f && g ? (b = v.push(u), x = y.push(c)) : b && x && (p ? (f && v.push(u), g && y.push(c)) : (h(t, v, y, b, x), b = x = 0, v = [], y = []));
h(t, v, y, b, x), t.closePath(), t.fillStyle = a, t.fill()
}(a, l, u, s, c, o._loop), r.canvas.unclipArea(a))
}
}
}
}, {25: 25, 40: 40, 45: 45}], 51: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26), r = t(45), o = t(30), s = r.noop;
function l(t, e) {
return t.usePointStyle ? e * Math.SQRT2 : t.boxWidth
}
n._set("global", {
legend: {
display: !0,
position: "top",
fullWidth: !0,
reverse: !1,
weight: 1e3,
onClick: function (t, e) {
var i = e.datasetIndex, n = this.chart, a = n.getDatasetMeta(i);
a.hidden = null === a.hidden ? !n.data.datasets[i].hidden : null, n.update()
},
onHover: null,
labels: {
boxWidth: 40, padding: 10, generateLabels: function (t) {
var e = t.data;
return r.isArray(e.datasets) ? e.datasets.map(function (e, i) {
return {
text: e.label,
fillStyle: r.isArray(e.backgroundColor) ? e.backgroundColor[0] : e.backgroundColor,
hidden: !t.isDatasetVisible(i),
lineCap: e.borderCapStyle,
lineDash: e.borderDash,
lineDashOffset: e.borderDashOffset,
lineJoin: e.borderJoinStyle,
lineWidth: e.borderWidth,
strokeStyle: e.borderColor,
pointStyle: e.pointStyle,
datasetIndex: i
}
}, this) : []
}
}
}, legendCallback: function (t) {
var e = [];
e.push('');
for (var i = 0; i < t.data.datasets.length; i++) e.push('- '), t.data.datasets[i].label && e.push(t.data.datasets[i].label), e.push("
");
return e.push("
"), e.join("")
}
});
var u = a.extend({
initialize: function (t) {
r.extend(this, t), this.legendHitBoxes = [], this.doughnutMode = !1
}, beforeUpdate: s, update: function (t, e, i) {
var n = this;
return n.beforeUpdate(), n.maxWidth = t, n.maxHeight = e, n.margins = i, n.beforeSetDimensions(), n.setDimensions(), n.afterSetDimensions(), n.beforeBuildLabels(), n.buildLabels(), n.afterBuildLabels(), n.beforeFit(), n.fit(), n.afterFit(), n.afterUpdate(), n.minSize
}, afterUpdate: s, beforeSetDimensions: s, setDimensions: function () {
var t = this;
t.isHorizontal() ? (t.width = t.maxWidth, t.left = 0, t.right = t.width) : (t.height = t.maxHeight, t.top = 0, t.bottom = t.height), t.paddingLeft = 0, t.paddingTop = 0, t.paddingRight = 0, t.paddingBottom = 0, t.minSize = {
width: 0,
height: 0
}
}, afterSetDimensions: s, beforeBuildLabels: s, buildLabels: function () {
var t = this, e = t.options.labels || {}, i = r.callback(e.generateLabels, [t.chart], t) || [];
e.filter && (i = i.filter(function (i) {
return e.filter(i, t.chart.data)
})), t.options.reverse && i.reverse(), t.legendItems = i
}, afterBuildLabels: s, beforeFit: s, fit: function () {
var t = this, e = t.options, i = e.labels, a = e.display, o = t.ctx, s = n.global,
u = r.valueOrDefault, d = u(i.fontSize, s.defaultFontSize),
h = u(i.fontStyle, s.defaultFontStyle), c = u(i.fontFamily, s.defaultFontFamily),
f = r.fontString(d, h, c), g = t.legendHitBoxes = [], m = t.minSize, p = t.isHorizontal();
if (p ? (m.width = t.maxWidth, m.height = a ? 10 : 0) : (m.width = a ? 10 : 0, m.height = t.maxHeight), a) if (o.font = f, p) {
var v = t.lineWidths = [0], y = t.legendItems.length ? d + i.padding : 0;
o.textAlign = "left", o.textBaseline = "top", r.each(t.legendItems, function (e, n) {
var a = l(i, d) + d / 2 + o.measureText(e.text).width;
v[v.length - 1] + a + i.padding >= t.width && (y += d + i.padding, v[v.length] = t.left), g[n] = {
left: 0,
top: 0,
width: a,
height: d
}, v[v.length - 1] += a + i.padding
}), m.height += y
} else {
var b = i.padding, x = t.columnWidths = [], _ = i.padding, k = 0, w = 0, M = d + b;
r.each(t.legendItems, function (t, e) {
var n = l(i, d) + d / 2 + o.measureText(t.text).width;
w + M > m.height && (_ += k + i.padding, x.push(k), k = 0, w = 0), k = Math.max(k, n), w += M, g[e] = {
left: 0,
top: 0,
width: n,
height: d
}
}), _ += k, x.push(k), m.width += _
}
t.width = m.width, t.height = m.height
}, afterFit: s, isHorizontal: function () {
return "top" === this.options.position || "bottom" === this.options.position
}, draw: function () {
var t = this, e = t.options, i = e.labels, a = n.global, o = a.elements.line, s = t.width,
u = t.lineWidths;
if (e.display) {
var d, h = t.ctx, c = r.valueOrDefault, f = c(i.fontColor, a.defaultFontColor),
g = c(i.fontSize, a.defaultFontSize), m = c(i.fontStyle, a.defaultFontStyle),
p = c(i.fontFamily, a.defaultFontFamily), v = r.fontString(g, m, p);
h.textAlign = "left", h.textBaseline = "middle", h.lineWidth = .5, h.strokeStyle = f, h.fillStyle = f, h.font = v;
var y = l(i, g), b = t.legendHitBoxes, x = t.isHorizontal();
d = x ? {x: t.left + (s - u[0]) / 2, y: t.top + i.padding, line: 0} : {
x: t.left + i.padding,
y: t.top + i.padding,
line: 0
};
var _ = g + i.padding;
r.each(t.legendItems, function (n, l) {
var f, m, p, v, k, w = h.measureText(n.text).width, M = y + g / 2 + w, S = d.x, D = d.y;
x ? S + M >= s && (D = d.y += _, d.line++, S = d.x = t.left + (s - u[d.line]) / 2) : D + _ > t.bottom && (S = d.x = S + t.columnWidths[d.line] + i.padding, D = d.y = t.top + i.padding, d.line++), function (t, i, n) {
if (!(isNaN(y) || y <= 0)) {
h.save(), h.fillStyle = c(n.fillStyle, a.defaultColor), h.lineCap = c(n.lineCap, o.borderCapStyle), h.lineDashOffset = c(n.lineDashOffset, o.borderDashOffset), h.lineJoin = c(n.lineJoin, o.borderJoinStyle), h.lineWidth = c(n.lineWidth, o.borderWidth), h.strokeStyle = c(n.strokeStyle, a.defaultColor);
var s = 0 === c(n.lineWidth, o.borderWidth);
if (h.setLineDash && h.setLineDash(c(n.lineDash, o.borderDash)), e.labels && e.labels.usePointStyle) {
var l = g * Math.SQRT2 / 2, u = l / Math.SQRT2, d = t + u, f = i + u;
r.canvas.drawPoint(h, n.pointStyle, l, d, f)
} else s || h.strokeRect(t, i, y, g), h.fillRect(t, i, y, g);
h.restore()
}
}(S, D, n), b[l].left = S, b[l].top = D, f = n, m = w, v = y + (p = g / 2) + S, k = D + p, h.fillText(f.text, v, k), f.hidden && (h.beginPath(), h.lineWidth = 2, h.moveTo(v, k), h.lineTo(v + m, k), h.stroke()), x ? d.x += M + i.padding : d.y += _
})
}
}, handleEvent: function (t) {
var e = this, i = e.options, n = "mouseup" === t.type ? "click" : t.type, a = !1;
if ("mousemove" === n) {
if (!i.onHover) return
} else {
if ("click" !== n) return;
if (!i.onClick) return
}
var r = t.x, o = t.y;
if (r >= e.left && r <= e.right && o >= e.top && o <= e.bottom) for (var s = e.legendHitBoxes, l = 0; l < s.length; ++l) {
var u = s[l];
if (r >= u.left && r <= u.left + u.width && o >= u.top && o <= u.top + u.height) {
if ("click" === n) {
i.onClick.call(e, t.native, e.legendItems[l]), a = !0;
break
}
if ("mousemove" === n) {
i.onHover.call(e, t.native, e.legendItems[l]), a = !0;
break
}
}
}
return a
}
});
function d(t, e) {
var i = new u({ctx: t.ctx, options: e, chart: t});
o.configure(t, i, e), o.addBox(t, i), t.legend = i
}
e.exports = {
id: "legend", _element: u, beforeInit: function (t) {
var e = t.options.legend;
e && d(t, e)
}, beforeUpdate: function (t) {
var e = t.options.legend, i = t.legend;
e ? (r.mergeIf(e, n.global.legend), i ? (o.configure(t, i, e), i.options = e) : d(t, e)) : i && (o.removeBox(t, i), delete t.legend)
}, afterEvent: function (t, e) {
var i = t.legend;
i && i.handleEvent(e)
}
}
}, {25: 25, 26: 26, 30: 30, 45: 45}], 52: [function (t, e, i) {
"use strict";
var n = t(25), a = t(26), r = t(45), o = t(30), s = r.noop;
n._set("global", {
title: {
display: !1,
fontStyle: "bold",
fullWidth: !0,
lineHeight: 1.2,
padding: 10,
position: "top",
text: "",
weight: 2e3
}
});
var l = a.extend({
initialize: function (t) {
r.extend(this, t), this.legendHitBoxes = []
},
beforeUpdate: s,
update: function (t, e, i) {
var n = this;
return n.beforeUpdate(), n.maxWidth = t, n.maxHeight = e, n.margins = i, n.beforeSetDimensions(), n.setDimensions(), n.afterSetDimensions(), n.beforeBuildLabels(), n.buildLabels(), n.afterBuildLabels(), n.beforeFit(), n.fit(), n.afterFit(), n.afterUpdate(), n.minSize
},
afterUpdate: s,
beforeSetDimensions: s,
setDimensions: function () {
var t = this;
t.isHorizontal() ? (t.width = t.maxWidth, t.left = 0, t.right = t.width) : (t.height = t.maxHeight, t.top = 0, t.bottom = t.height), t.paddingLeft = 0, t.paddingTop = 0, t.paddingRight = 0, t.paddingBottom = 0, t.minSize = {
width: 0,
height: 0
}
},
afterSetDimensions: s,
beforeBuildLabels: s,
buildLabels: s,
afterBuildLabels: s,
beforeFit: s,
fit: function () {
var t = r.valueOrDefault, e = this.options, i = e.display,
a = t(e.fontSize, n.global.defaultFontSize), o = this.minSize,
s = r.isArray(e.text) ? e.text.length : 1, l = r.options.toLineHeight(e.lineHeight, a),
u = i ? s * l + 2 * e.padding : 0;
this.isHorizontal() ? (o.width = this.maxWidth, o.height = u) : (o.width = u, o.height = this.maxHeight), this.width = o.width, this.height = o.height
},
afterFit: s,
isHorizontal: function () {
var t = this.options.position;
return "top" === t || "bottom" === t
},
draw: function () {
var t = this.ctx, e = r.valueOrDefault, i = this.options, a = n.global;
if (i.display) {
var o, s, l, u = e(i.fontSize, a.defaultFontSize), d = e(i.fontStyle, a.defaultFontStyle),
h = e(i.fontFamily, a.defaultFontFamily), c = r.fontString(u, d, h),
f = r.options.toLineHeight(i.lineHeight, u), g = f / 2 + i.padding, m = 0, p = this.top,
v = this.left, y = this.bottom, b = this.right;
t.fillStyle = e(i.fontColor, a.defaultFontColor), t.font = c, this.isHorizontal() ? (s = v + (b - v) / 2, l = p + g, o = b - v) : (s = "left" === i.position ? v + g : b - g, l = p + (y - p) / 2, o = y - p, m = Math.PI * ("left" === i.position ? -.5 : .5)), t.save(), t.translate(s, l), t.rotate(m), t.textAlign = "center", t.textBaseline = "middle";
var x = i.text;
if (r.isArray(x)) for (var _ = 0, k = 0; k < x.length; ++k) t.fillText(x[k], 0, _, o), _ += f; else t.fillText(x, 0, 0, o);
t.restore()
}
}
});
function u(t, e) {
var i = new l({ctx: t.ctx, options: e, chart: t});
o.configure(t, i, e), o.addBox(t, i), t.titleBlock = i
}
e.exports = {
id: "title", _element: l, beforeInit: function (t) {
var e = t.options.title;
e && u(t, e)
}, beforeUpdate: function (t) {
var e = t.options.title, i = t.titleBlock;
e ? (r.mergeIf(e, n.global.title), i ? (o.configure(t, i, e), i.options = e) : u(t, e)) : i && (o.removeBox(t, i), delete t.titleBlock)
}
}
}, {25: 25, 26: 26, 30: 30, 45: 45}], 53: [function (t, e, i) {
"use strict";
e.exports = function (t) {
var e = t.Scale.extend({
getLabels: function () {
var t = this.chart.data;
return this.options.labels || (this.isHorizontal() ? t.xLabels : t.yLabels) || t.labels
}, determineDataLimits: function () {
var t, e = this, i = e.getLabels();
e.minIndex = 0, e.maxIndex = i.length - 1, void 0 !== e.options.ticks.min && (t = i.indexOf(e.options.ticks.min), e.minIndex = -1 !== t ? t : e.minIndex), void 0 !== e.options.ticks.max && (t = i.indexOf(e.options.ticks.max), e.maxIndex = -1 !== t ? t : e.maxIndex), e.min = i[e.minIndex], e.max = i[e.maxIndex]
}, buildTicks: function () {
var t = this.getLabels();
this.ticks = 0 === this.minIndex && this.maxIndex === t.length - 1 ? t : t.slice(this.minIndex, this.maxIndex + 1)
}, getLabelForIndex: function (t, e) {
var i = this.chart.data, n = this.isHorizontal();
return i.yLabels && !n ? this.getRightValue(i.datasets[e].data[t]) : this.ticks[t - this.minIndex]
}, getPixelForValue: function (t, e) {
var i, n = this, a = n.options.offset,
r = Math.max(n.maxIndex + 1 - n.minIndex - (a ? 0 : 1), 1);
if (null != t && (i = n.isHorizontal() ? t.x : t.y), void 0 !== i || void 0 !== t && isNaN(e)) {
t = i || t;
var o = n.getLabels().indexOf(t);
e = -1 !== o ? o : e
}
if (n.isHorizontal()) {
var s = n.width / r, l = s * (e - n.minIndex);
return a && (l += s / 2), n.left + Math.round(l)
}
var u = n.height / r, d = u * (e - n.minIndex);
return a && (d += u / 2), n.top + Math.round(d)
}, getPixelForTick: function (t) {
return this.getPixelForValue(this.ticks[t], t + this.minIndex, null)
}, getValueForPixel: function (t) {
var e = this.options.offset, i = Math.max(this._ticks.length - (e ? 0 : 1), 1),
n = this.isHorizontal(), a = (n ? this.width : this.height) / i;
return t -= n ? this.left : this.top, e && (t -= a / 2), (t <= 0 ? 0 : Math.round(t / a)) + this.minIndex
}, getBasePixel: function () {
return this.bottom
}
});
t.scaleService.registerScaleType("category", e, {position: "bottom"})
}
}, {}], 54: [function (t, e, i) {
"use strict";
var n = t(25), a = t(45), r = t(34);
e.exports = function (t) {
var e = {position: "left", ticks: {callback: r.formatters.linear}}, i = t.LinearScaleBase.extend({
determineDataLimits: function () {
var t = this, e = t.options, i = t.chart, n = i.data.datasets, r = t.isHorizontal();
function o(e) {
return r ? e.xAxisID === t.id : e.yAxisID === t.id
}
t.min = null, t.max = null;
var s = e.stacked;
if (void 0 === s && a.each(n, function (t, e) {
if (!s) {
var n = i.getDatasetMeta(e);
i.isDatasetVisible(e) && o(n) && void 0 !== n.stack && (s = !0)
}
}), e.stacked || s) {
var l = {};
a.each(n, function (n, r) {
var s = i.getDatasetMeta(r),
u = [s.type, void 0 === e.stacked && void 0 === s.stack ? r : "", s.stack].join(".");
void 0 === l[u] && (l[u] = {positiveValues: [], negativeValues: []});
var d = l[u].positiveValues, h = l[u].negativeValues;
i.isDatasetVisible(r) && o(s) && a.each(n.data, function (i, n) {
var a = +t.getRightValue(i);
isNaN(a) || s.data[n].hidden || (d[n] = d[n] || 0, h[n] = h[n] || 0, e.relativePoints ? d[n] = 100 : a < 0 ? h[n] += a : d[n] += a)
})
}), a.each(l, function (e) {
var i = e.positiveValues.concat(e.negativeValues), n = a.min(i), r = a.max(i);
t.min = null === t.min ? n : Math.min(t.min, n), t.max = null === t.max ? r : Math.max(t.max, r)
})
} else a.each(n, function (e, n) {
var r = i.getDatasetMeta(n);
i.isDatasetVisible(n) && o(r) && a.each(e.data, function (e, i) {
var n = +t.getRightValue(e);
isNaN(n) || r.data[i].hidden || (null === t.min ? t.min = n : n < t.min && (t.min = n), null === t.max ? t.max = n : n > t.max && (t.max = n))
})
});
t.min = isFinite(t.min) && !isNaN(t.min) ? t.min : 0, t.max = isFinite(t.max) && !isNaN(t.max) ? t.max : 1, this.handleTickRangeOptions()
}, getTickLimit: function () {
var t, e = this.options.ticks;
if (this.isHorizontal()) t = Math.min(e.maxTicksLimit ? e.maxTicksLimit : 11, Math.ceil(this.width / 50)); else {
var i = a.valueOrDefault(e.fontSize, n.global.defaultFontSize);
t = Math.min(e.maxTicksLimit ? e.maxTicksLimit : 11, Math.ceil(this.height / (2 * i)))
}
return t
}, handleDirectionalChanges: function () {
this.isHorizontal() || this.ticks.reverse()
}, getLabelForIndex: function (t, e) {
return +this.getRightValue(this.chart.data.datasets[e].data[t])
}, getPixelForValue: function (t) {
var e = this.start, i = +this.getRightValue(t), n = this.end - e;
return this.isHorizontal() ? this.left + this.width / n * (i - e) : this.bottom - this.height / n * (i - e)
}, getValueForPixel: function (t) {
var e = this.isHorizontal(), i = e ? this.width : this.height,
n = (e ? t - this.left : this.bottom - t) / i;
return this.start + (this.end - this.start) * n
}, getPixelForTick: function (t) {
return this.getPixelForValue(this.ticksAsNumbers[t])
}
});
t.scaleService.registerScaleType("linear", i, e)
}
}, {25: 25, 34: 34, 45: 45}], 55: [function (t, e, i) {
"use strict";
var n = t(45);
e.exports = function (t) {
var e = n.noop;
t.LinearScaleBase = t.Scale.extend({
getRightValue: function (e) {
return "string" == typeof e ? +e : t.Scale.prototype.getRightValue.call(this, e)
}, handleTickRangeOptions: function () {
var t = this, e = t.options.ticks;
if (e.beginAtZero) {
var i = n.sign(t.min), a = n.sign(t.max);
i < 0 && a < 0 ? t.max = 0 : i > 0 && a > 0 && (t.min = 0)
}
var r = void 0 !== e.min || void 0 !== e.suggestedMin,
o = void 0 !== e.max || void 0 !== e.suggestedMax;
void 0 !== e.min ? t.min = e.min : void 0 !== e.suggestedMin && (null === t.min ? t.min = e.suggestedMin : t.min = Math.min(t.min, e.suggestedMin)), void 0 !== e.max ? t.max = e.max : void 0 !== e.suggestedMax && (null === t.max ? t.max = e.suggestedMax : t.max = Math.max(t.max, e.suggestedMax)), r !== o && t.min >= t.max && (r ? t.max = t.min + 1 : t.min = t.max - 1), t.min === t.max && (t.max++, e.beginAtZero || t.min--)
}, getTickLimit: e, handleDirectionalChanges: e, buildTicks: function () {
var t = this, e = t.options.ticks, i = t.getTickLimit(), a = {
maxTicks: i = Math.max(2, i),
min: e.min,
max: e.max,
stepSize: n.valueOrDefault(e.fixedStepSize, e.stepSize)
}, r = t.ticks = function (t, e) {
var i, a = [];
if (t.stepSize && t.stepSize > 0) i = t.stepSize; else {
var r = n.niceNum(e.max - e.min, !1);
i = n.niceNum(r / (t.maxTicks - 1), !0)
}
var o = Math.floor(e.min / i) * i, s = Math.ceil(e.max / i) * i;
t.min && t.max && t.stepSize && n.almostWhole((t.max - t.min) / t.stepSize, i / 1e3) && (o = t.min, s = t.max);
var l = (s - o) / i;
l = n.almostEquals(l, Math.round(l), i / 1e3) ? Math.round(l) : Math.ceil(l);
var u = 1;
i < 1 && (u = Math.pow(10, i.toString().length - 2), o = Math.round(o * u) / u, s = Math.round(s * u) / u), a.push(void 0 !== t.min ? t.min : o);
for (var d = 1; d < l; ++d) a.push(Math.round((o + d * i) * u) / u);
return a.push(void 0 !== t.max ? t.max : s), a
}(a, t);
t.handleDirectionalChanges(), t.max = n.max(r), t.min = n.min(r), e.reverse ? (r.reverse(), t.start = t.max, t.end = t.min) : (t.start = t.min, t.end = t.max)
}, convertTicksToLabels: function () {
this.ticksAsNumbers = this.ticks.slice(), this.zeroLineIndex = this.ticks.indexOf(0), t.Scale.prototype.convertTicksToLabels.call(this)
}
})
}
}, {45: 45}], 56: [function (t, e, i) {
"use strict";
var n = t(45), a = t(34);
e.exports = function (t) {
var e = {position: "left", ticks: {callback: a.formatters.logarithmic}}, i = t.Scale.extend({
determineDataLimits: function () {
var t = this, e = t.options, i = t.chart, a = i.data.datasets, r = t.isHorizontal();
function o(e) {
return r ? e.xAxisID === t.id : e.yAxisID === t.id
}
t.min = null, t.max = null, t.minNotZero = null;
var s = e.stacked;
if (void 0 === s && n.each(a, function (t, e) {
if (!s) {
var n = i.getDatasetMeta(e);
i.isDatasetVisible(e) && o(n) && void 0 !== n.stack && (s = !0)
}
}), e.stacked || s) {
var l = {};
n.each(a, function (a, r) {
var s = i.getDatasetMeta(r),
u = [s.type, void 0 === e.stacked && void 0 === s.stack ? r : "", s.stack].join(".");
i.isDatasetVisible(r) && o(s) && (void 0 === l[u] && (l[u] = []), n.each(a.data, function (e, i) {
var n = l[u], a = +t.getRightValue(e);
isNaN(a) || s.data[i].hidden || a < 0 || (n[i] = n[i] || 0, n[i] += a)
}))
}), n.each(l, function (e) {
if (e.length > 0) {
var i = n.min(e), a = n.max(e);
t.min = null === t.min ? i : Math.min(t.min, i), t.max = null === t.max ? a : Math.max(t.max, a)
}
})
} else n.each(a, function (e, a) {
var r = i.getDatasetMeta(a);
i.isDatasetVisible(a) && o(r) && n.each(e.data, function (e, i) {
var n = +t.getRightValue(e);
isNaN(n) || r.data[i].hidden || n < 0 || (null === t.min ? t.min = n : n < t.min && (t.min = n), null === t.max ? t.max = n : n > t.max && (t.max = n), 0 !== n && (null === t.minNotZero || n < t.minNotZero) && (t.minNotZero = n))
})
});
this.handleTickRangeOptions()
}, handleTickRangeOptions: function () {
var t = this, e = t.options.ticks, i = n.valueOrDefault;
t.min = i(e.min, t.min), t.max = i(e.max, t.max), t.min === t.max && (0 !== t.min && null !== t.min ? (t.min = Math.pow(10, Math.floor(n.log10(t.min)) - 1), t.max = Math.pow(10, Math.floor(n.log10(t.max)) + 1)) : (t.min = 1, t.max = 10)), null === t.min && (t.min = Math.pow(10, Math.floor(n.log10(t.max)) - 1)), null === t.max && (t.max = 0 !== t.min ? Math.pow(10, Math.floor(n.log10(t.min)) + 1) : 10), null === t.minNotZero && (t.min > 0 ? t.minNotZero = t.min : t.max < 1 ? t.minNotZero = Math.pow(10, Math.floor(n.log10(t.max))) : t.minNotZero = 1)
}, buildTicks: function () {
var t = this, e = t.options.ticks, i = !t.isHorizontal(), a = {min: e.min, max: e.max},
r = t.ticks = function (t, e) {
var i, a, r = [], o = n.valueOrDefault,
s = o(t.min, Math.pow(10, Math.floor(n.log10(e.min)))),
l = Math.floor(n.log10(e.max)), u = Math.ceil(e.max / Math.pow(10, l));
0 === s ? (i = Math.floor(n.log10(e.minNotZero)), a = Math.floor(e.minNotZero / Math.pow(10, i)), r.push(s), s = a * Math.pow(10, i)) : (i = Math.floor(n.log10(s)), a = Math.floor(s / Math.pow(10, i)));
for (var d = i < 0 ? Math.pow(10, Math.abs(i)) : 1; r.push(s), 10 == ++a && (a = 1, d = ++i >= 0 ? 1 : d), s = Math.round(a * Math.pow(10, i) * d) / d, i < l || i === l && a < u;) ;
var h = o(t.max, s);
return r.push(h), r
}(a, t);
t.max = n.max(r), t.min = n.min(r), e.reverse ? (i = !i, t.start = t.max, t.end = t.min) : (t.start = t.min, t.end = t.max), i && r.reverse()
}, convertTicksToLabels: function () {
this.tickValues = this.ticks.slice(), t.Scale.prototype.convertTicksToLabels.call(this)
}, getLabelForIndex: function (t, e) {
return +this.getRightValue(this.chart.data.datasets[e].data[t])
}, getPixelForTick: function (t) {
return this.getPixelForValue(this.tickValues[t])
}, _getFirstTickValue: function (t) {
var e = Math.floor(n.log10(t));
return Math.floor(t / Math.pow(10, e)) * Math.pow(10, e)
}, getPixelForValue: function (e) {
var i, a, r, o, s, l = this, u = l.options.ticks.reverse, d = n.log10,
h = l._getFirstTickValue(l.minNotZero), c = 0;
return e = +l.getRightValue(e), u ? (r = l.end, o = l.start, s = -1) : (r = l.start, o = l.end, s = 1), l.isHorizontal() ? (i = l.width, a = u ? l.right : l.left) : (i = l.height, s *= -1, a = u ? l.top : l.bottom), e !== r && (0 === r && (i -= c = n.getValueOrDefault(l.options.ticks.fontSize, t.defaults.global.defaultFontSize), r = h), 0 !== e && (c += i / (d(o) - d(r)) * (d(e) - d(r))), a += s * c), a
}, getValueForPixel: function (e) {
var i, a, r, o, s = this, l = s.options.ticks.reverse, u = n.log10,
d = s._getFirstTickValue(s.minNotZero);
if (l ? (a = s.end, r = s.start) : (a = s.start, r = s.end), s.isHorizontal() ? (i = s.width, o = l ? s.right - e : e - s.left) : (i = s.height, o = l ? e - s.top : s.bottom - e), o !== a) {
if (0 === a) {
var h = n.getValueOrDefault(s.options.ticks.fontSize, t.defaults.global.defaultFontSize);
o -= h, i -= h, a = d
}
o *= u(r) - u(a), o /= i, o = Math.pow(10, u(a) + o)
}
return o
}
});
t.scaleService.registerScaleType("logarithmic", i, e)
}
}, {34: 34, 45: 45}], 57: [function (t, e, i) {
"use strict";
var n = t(25), a = t(45), r = t(34);
e.exports = function (t) {
var e = n.global, i = {
display: !0,
animate: !0,
position: "chartArea",
angleLines: {display: !0, color: "rgba(0, 0, 0, 0.1)", lineWidth: 1},
gridLines: {circular: !1},
ticks: {
showLabelBackdrop: !0,
backdropColor: "rgba(255,255,255,0.75)",
backdropPaddingY: 2,
backdropPaddingX: 2,
callback: r.formatters.linear
},
pointLabels: {
display: !0, fontSize: 10, callback: function (t) {
return t
}
}
};
function o(t) {
var e = t.options;
return e.angleLines.display || e.pointLabels.display ? t.chart.data.labels.length : 0
}
function s(t) {
var i = t.options.pointLabels, n = a.valueOrDefault(i.fontSize, e.defaultFontSize),
r = a.valueOrDefault(i.fontStyle, e.defaultFontStyle),
o = a.valueOrDefault(i.fontFamily, e.defaultFontFamily);
return {size: n, style: r, family: o, font: a.fontString(n, r, o)}
}
function l(t, e, i, n, a) {
return t === n || t === a ? {start: e - i / 2, end: e + i / 2} : t < n || t > a ? {
start: e - i - 5,
end: e
} : {start: e, end: e + i + 5}
}
function u(t, e, i, n) {
if (a.isArray(e)) for (var r = i.y, o = 1.5 * n, s = 0; s < e.length; ++s) t.fillText(e[s], i.x, r), r += o; else t.fillText(e, i.x, i.y)
}
function d(t) {
return a.isNumber(t) ? t : 0
}
var h = t.LinearScaleBase.extend({
setDimensions: function () {
var t = this, i = t.options, n = i.ticks;
t.width = t.maxWidth, t.height = t.maxHeight, t.xCenter = Math.round(t.width / 2), t.yCenter = Math.round(t.height / 2);
var r = a.min([t.height, t.width]), o = a.valueOrDefault(n.fontSize, e.defaultFontSize);
t.drawingArea = i.display ? r / 2 - (o / 2 + n.backdropPaddingY) : r / 2
}, determineDataLimits: function () {
var t = this, e = t.chart, i = Number.POSITIVE_INFINITY, n = Number.NEGATIVE_INFINITY;
a.each(e.data.datasets, function (r, o) {
if (e.isDatasetVisible(o)) {
var s = e.getDatasetMeta(o);
a.each(r.data, function (e, a) {
var r = +t.getRightValue(e);
isNaN(r) || s.data[a].hidden || (i = Math.min(r, i), n = Math.max(r, n))
})
}
}), t.min = i === Number.POSITIVE_INFINITY ? 0 : i, t.max = n === Number.NEGATIVE_INFINITY ? 0 : n, t.handleTickRangeOptions()
}, getTickLimit: function () {
var t = this.options.ticks, i = a.valueOrDefault(t.fontSize, e.defaultFontSize);
return Math.min(t.maxTicksLimit ? t.maxTicksLimit : 11, Math.ceil(this.drawingArea / (1.5 * i)))
}, convertTicksToLabels: function () {
t.LinearScaleBase.prototype.convertTicksToLabels.call(this), this.pointLabels = this.chart.data.labels.map(this.options.pointLabels.callback, this)
}, getLabelForIndex: function (t, e) {
return +this.getRightValue(this.chart.data.datasets[e].data[t])
}, fit: function () {
var t, e;
this.options.pointLabels.display ? function (t) {
var e, i, n, r = s(t), u = Math.min(t.height / 2, t.width / 2),
d = {r: t.width, l: 0, t: t.height, b: 0}, h = {};
t.ctx.font = r.font, t._pointLabelSizes = [];
var c, f, g, m = o(t);
for (e = 0; e < m; e++) {
n = t.getPointPosition(e, u), c = t.ctx, f = r.size, g = t.pointLabels[e] || "", i = a.isArray(g) ? {
w: a.longestText(c, c.font, g),
h: g.length * f + 1.5 * (g.length - 1) * f
} : {w: c.measureText(g).width, h: f}, t._pointLabelSizes[e] = i;
var p = t.getIndexAngle(e), v = a.toDegrees(p) % 360, y = l(v, n.x, i.w, 0, 180),
b = l(v, n.y, i.h, 90, 270);
y.start < d.l && (d.l = y.start, h.l = p), y.end > d.r && (d.r = y.end, h.r = p), b.start < d.t && (d.t = b.start, h.t = p), b.end > d.b && (d.b = b.end, h.b = p)
}
t.setReductions(u, d, h)
}(this) : (t = this, e = Math.min(t.height / 2, t.width / 2), t.drawingArea = Math.round(e), t.setCenterPoint(0, 0, 0, 0))
}, setReductions: function (t, e, i) {
var n = e.l / Math.sin(i.l), a = Math.max(e.r - this.width, 0) / Math.sin(i.r),
r = -e.t / Math.cos(i.t), o = -Math.max(e.b - this.height, 0) / Math.cos(i.b);
n = d(n), a = d(a), r = d(r), o = d(o), this.drawingArea = Math.min(Math.round(t - (n + a) / 2), Math.round(t - (r + o) / 2)), this.setCenterPoint(n, a, r, o)
}, setCenterPoint: function (t, e, i, n) {
var a = this, r = a.width - e - a.drawingArea, o = t + a.drawingArea, s = i + a.drawingArea,
l = a.height - n - a.drawingArea;
a.xCenter = Math.round((o + r) / 2 + a.left), a.yCenter = Math.round((s + l) / 2 + a.top)
}, getIndexAngle: function (t) {
return t * (2 * Math.PI / o(this)) + (this.chart.options && this.chart.options.startAngle ? this.chart.options.startAngle : 0) * Math.PI * 2 / 360
}, getDistanceFromCenterForValue: function (t) {
if (null === t) return 0;
var e = this.drawingArea / (this.max - this.min);
return this.options.ticks.reverse ? (this.max - t) * e : (t - this.min) * e
}, getPointPosition: function (t, e) {
var i = this.getIndexAngle(t) - Math.PI / 2;
return {
x: Math.round(Math.cos(i) * e) + this.xCenter,
y: Math.round(Math.sin(i) * e) + this.yCenter
}
}, getPointPositionForValue: function (t, e) {
return this.getPointPosition(t, this.getDistanceFromCenterForValue(e))
}, getBasePosition: function () {
var t = this.min, e = this.max;
return this.getPointPositionForValue(0, this.beginAtZero ? 0 : t < 0 && e < 0 ? e : t > 0 && e > 0 ? t : 0)
}, draw: function () {
var t = this, i = t.options, n = i.gridLines, r = i.ticks, l = a.valueOrDefault;
if (i.display) {
var d = t.ctx, h = this.getIndexAngle(0), c = l(r.fontSize, e.defaultFontSize),
f = l(r.fontStyle, e.defaultFontStyle), g = l(r.fontFamily, e.defaultFontFamily),
m = a.fontString(c, f, g);
a.each(t.ticks, function (i, s) {
if (s > 0 || r.reverse) {
var u = t.getDistanceFromCenterForValue(t.ticksAsNumbers[s]);
if (n.display && 0 !== s && function (t, e, i, n) {
var r = t.ctx;
if (r.strokeStyle = a.valueAtIndexOrDefault(e.color, n - 1), r.lineWidth = a.valueAtIndexOrDefault(e.lineWidth, n - 1), t.options.gridLines.circular) r.beginPath(), r.arc(t.xCenter, t.yCenter, i, 0, 2 * Math.PI), r.closePath(), r.stroke(); else {
var s = o(t);
if (0 === s) return;
r.beginPath();
var l = t.getPointPosition(0, i);
r.moveTo(l.x, l.y);
for (var u = 1; u < s; u++) l = t.getPointPosition(u, i), r.lineTo(l.x, l.y);
r.closePath(), r.stroke()
}
}(t, n, u, s), r.display) {
var f = l(r.fontColor, e.defaultFontColor);
if (d.font = m, d.save(), d.translate(t.xCenter, t.yCenter), d.rotate(h), r.showLabelBackdrop) {
var g = d.measureText(i).width;
d.fillStyle = r.backdropColor, d.fillRect(-g / 2 - r.backdropPaddingX, -u - c / 2 - r.backdropPaddingY, g + 2 * r.backdropPaddingX, c + 2 * r.backdropPaddingY)
}
d.textAlign = "center", d.textBaseline = "middle", d.fillStyle = f, d.fillText(i, 0, -u), d.restore()
}
}
}), (i.angleLines.display || i.pointLabels.display) && function (t) {
var i = t.ctx, n = t.options, r = n.angleLines, l = n.pointLabels;
i.lineWidth = r.lineWidth, i.strokeStyle = r.color;
var d, h, c, f, g = t.getDistanceFromCenterForValue(n.ticks.reverse ? t.min : t.max),
m = s(t);
i.textBaseline = "top";
for (var p = o(t) - 1; p >= 0; p--) {
if (r.display) {
var v = t.getPointPosition(p, g);
i.beginPath(), i.moveTo(t.xCenter, t.yCenter), i.lineTo(v.x, v.y), i.stroke(), i.closePath()
}
if (l.display) {
var y = t.getPointPosition(p, g + 5),
b = a.valueAtIndexOrDefault(l.fontColor, p, e.defaultFontColor);
i.font = m.font, i.fillStyle = b;
var x = t.getIndexAngle(p), _ = a.toDegrees(x);
i.textAlign = 0 === (f = _) || 180 === f ? "center" : f < 180 ? "left" : "right", d = _, h = t._pointLabelSizes[p], c = y, 90 === d || 270 === d ? c.y -= h.h / 2 : (d > 270 || d < 90) && (c.y -= h.h), u(i, t.pointLabels[p] || "", y, m.size)
}
}
}(t)
}
}
});
t.scaleService.registerScaleType("radialLinear", h, i)
}
}, {25: 25, 34: 34, 45: 45}], 58: [function (t, e, i) {
"use strict";
var n = t(6);
n = "function" == typeof n ? n : window.moment;
var a = t(25), r = t(45), o = Number.MIN_SAFE_INTEGER || -9007199254740991,
s = Number.MAX_SAFE_INTEGER || 9007199254740991, l = {
millisecond: {common: !0, size: 1, steps: [1, 2, 5, 10, 20, 50, 100, 250, 500]},
second: {common: !0, size: 1e3, steps: [1, 2, 5, 10, 30]},
minute: {common: !0, size: 6e4, steps: [1, 2, 5, 10, 30]},
hour: {common: !0, size: 36e5, steps: [1, 2, 3, 6, 12]},
day: {common: !0, size: 864e5, steps: [1, 2, 5]},
week: {common: !1, size: 6048e5, steps: [1, 2, 3, 4]},
month: {common: !0, size: 2628e6, steps: [1, 2, 3]},
quarter: {common: !1, size: 7884e6, steps: [1, 2, 3, 4]},
year: {common: !0, size: 3154e7}
}, u = Object.keys(l);
function d(t, e) {
return t - e
}
function h(t) {
var e, i, n, a = {}, r = [];
for (e = 0, i = t.length; e < i; ++e) a[n = t[e]] || (a[n] = !0, r.push(n));
return r
}
function c(t, e, i, n) {
var a = function (t, e, i) {
for (var n, a, r, o = 0, s = t.length - 1; o >= 0 && o <= s;) {
if (a = t[(n = o + s >> 1) - 1] || null, r = t[n], !a) return {lo: null, hi: r};
if (r[e] < i) o = n + 1; else {
if (!(a[e] > i)) return {lo: a, hi: r};
s = n - 1
}
}
return {lo: r, hi: null}
}(t, e, i), r = a.lo ? a.hi ? a.lo : t[t.length - 2] : t[0],
o = a.lo ? a.hi ? a.hi : t[t.length - 1] : t[1], s = o[e] - r[e], l = s ? (i - r[e]) / s : 0,
u = (o[n] - r[n]) * l;
return r[n] + u
}
function f(t, e) {
var i = e.parser, a = e.parser || e.format;
return "function" == typeof i ? i(t) : "string" == typeof t && "string" == typeof a ? n(t, a) : (t instanceof n || (t = n(t)), t.isValid() ? t : "function" == typeof a ? a(t) : t)
}
function g(t, e) {
if (r.isNullOrUndef(t)) return null;
var i = e.options.time, n = f(e.getRightValue(t), i);
return n.isValid() ? (i.round && n.startOf(i.round), n.valueOf()) : null
}
function m(t) {
for (var e = u.indexOf(t) + 1, i = u.length; e < i; ++e) if (l[u[e]].common) return u[e]
}
function p(t, e, i, a) {
var o, d = a.time, h = d.unit || function (t, e, i, n) {
var a, r, o, d = u.length;
for (a = u.indexOf(t); a < d - 1; ++a) if (o = (r = l[u[a]]).steps ? r.steps[r.steps.length - 1] : s, r.common && Math.ceil((i - e) / (o * r.size)) <= n) return u[a];
return u[d - 1]
}(d.minUnit, t, e, i), c = m(h), f = r.valueOrDefault(d.stepSize, d.unitStepSize),
g = "week" === h && d.isoWeekday, p = a.ticks.major.enabled, v = l[h], y = n(t), b = n(e), x = [];
for (f || (f = function (t, e, i, n) {
var a, r, o, s = e - t, u = l[i], d = u.size, h = u.steps;
if (!h) return Math.ceil(s / (n * d));
for (a = 0, r = h.length; a < r && (o = h[a], !(Math.ceil(s / (d * o)) <= n)); ++a) ;
return o
}(t, e, h, i)), g && (y = y.isoWeekday(g), b = b.isoWeekday(g)), y = y.startOf(g ? "day" : h), (b = b.startOf(g ? "day" : h)) < e && b.add(1, h), o = n(y), p && c && !g && !d.round && (o.startOf(c), o.add(~~((y - o) / (v.size * f)) * f, h)); o < b; o.add(f, h)) x.push(+o);
return x.push(+o), x
}
e.exports = function (t) {
var e = t.Scale.extend({
initialize: function () {
if (!n) throw new Error("Chart.js - Moment.js could not be found! You must include it before Chart.js to use the time scale. Download at https://momentjs.com");
this.mergeTicksOptions(), t.Scale.prototype.initialize.call(this)
}, update: function () {
var e = this.options;
return e.time && e.time.format && console.warn("options.time.format is deprecated and replaced by options.time.parser."), t.Scale.prototype.update.apply(this, arguments)
}, getRightValue: function (e) {
return e && void 0 !== e.t && (e = e.t), t.Scale.prototype.getRightValue.call(this, e)
}, determineDataLimits: function () {
var t, e, i, a, l, u, c = this, f = c.chart, m = c.options.time, p = m.unit || "day", v = s,
y = o, b = [], x = [], _ = [];
for (t = 0, i = f.data.labels.length; t < i; ++t) _.push(g(f.data.labels[t], c));
for (t = 0, i = (f.data.datasets || []).length; t < i; ++t) if (f.isDatasetVisible(t)) if (l = f.data.datasets[t].data, r.isObject(l[0])) for (x[t] = [], e = 0, a = l.length; e < a; ++e) u = g(l[e], c), b.push(u), x[t][e] = u; else b.push.apply(b, _), x[t] = _.slice(0); else x[t] = [];
_.length && (_ = h(_).sort(d), v = Math.min(v, _[0]), y = Math.max(y, _[_.length - 1])), b.length && (b = h(b).sort(d), v = Math.min(v, b[0]), y = Math.max(y, b[b.length - 1])), v = g(m.min, c) || v, y = g(m.max, c) || y, v = v === s ? +n().startOf(p) : v, y = y === o ? +n().endOf(p) + 1 : y, c.min = Math.min(v, y), c.max = Math.max(v + 1, y), c._horizontal = c.isHorizontal(), c._table = [], c._timestamps = {
data: b,
datasets: x,
labels: _
}
}, buildTicks: function () {
var t, e, i, a, r, o, s, d, h, v, y, b, x = this, _ = x.min, k = x.max, w = x.options,
M = w.time, S = [], D = [];
switch (w.ticks.source) {
case"data":
S = x._timestamps.data;
break;
case"labels":
S = x._timestamps.labels;
break;
case"auto":
default:
S = p(_, k, x.getLabelCapacity(_), w)
}
for ("ticks" === w.bounds && S.length && (_ = S[0], k = S[S.length - 1]), _ = g(M.min, x) || _, k = g(M.max, x) || k, t = 0, e = S.length; t < e; ++t) (i = S[t]) >= _ && i <= k && D.push(i);
return x.min = _, x.max = k, x._unit = M.unit || function (t, e, i, a) {
var r, o, s = n.duration(n(a).diff(n(i)));
for (r = u.length - 1; r >= u.indexOf(e); r--) if (o = u[r], l[o].common && s.as(o) >= t.length) return o;
return u[e ? u.indexOf(e) : 0]
}(D, M.minUnit, x.min, x.max), x._majorUnit = m(x._unit), x._table = function (t, e, i, n) {
if ("linear" === n || !t.length) return [{time: e, pos: 0}, {time: i, pos: 1}];
var a, r, o, s, l, u = [], d = [e];
for (a = 0, r = t.length; a < r; ++a) (s = t[a]) > e && s < i && d.push(s);
for (d.push(i), a = 0, r = d.length; a < r; ++a) l = d[a + 1], o = d[a - 1], s = d[a], void 0 !== o && void 0 !== l && Math.round((l + o) / 2) === s || u.push({
time: s,
pos: a / (r - 1)
});
return u
}(x._timestamps.data, _, k, w.distribution), x._offsets = (a = x._table, r = D, o = _, s = k, y = 0, b = 0, (d = w).offset && r.length && (d.time.min || (h = r.length > 1 ? r[1] : s, v = r[0], y = (c(a, "time", h, "pos") - c(a, "time", v, "pos")) / 2), d.time.max || (h = r[r.length - 1], v = r.length > 1 ? r[r.length - 2] : o, b = (c(a, "time", h, "pos") - c(a, "time", v, "pos")) / 2)), {
left: y,
right: b
}), x._labelFormat = function (t, e) {
var i, n, a, r = t.length;
for (i = 0; i < r; i++) {
if (0 !== (n = f(t[i], e)).millisecond()) return "MMM D, YYYY h:mm:ss.SSS a";
0 === n.second() && 0 === n.minute() && 0 === n.hour() || (a = !0)
}
return a ? "MMM D, YYYY h:mm:ss a" : "MMM D, YYYY"
}(x._timestamps.data, M), function (t, e) {
var i, a, r, o, s = [];
for (i = 0, a = t.length; i < a; ++i) r = t[i], o = !!e && r === +n(r).startOf(e), s.push({
value: r,
major: o
});
return s
}(D, x._majorUnit)
}, getLabelForIndex: function (t, e) {
var i = this.chart.data, n = this.options.time,
a = i.labels && t < i.labels.length ? i.labels[t] : "", o = i.datasets[e].data[t];
return r.isObject(o) && (a = this.getRightValue(o)), n.tooltipFormat ? f(a, n).format(n.tooltipFormat) : "string" == typeof a ? a : f(a, n).format(this._labelFormat)
}, tickFormatFunction: function (t, e, i, n) {
var a = this.options, o = t.valueOf(), s = a.time.displayFormats, l = s[this._unit],
u = this._majorUnit, d = s[u], h = t.clone().startOf(u).valueOf(), c = a.ticks.major,
f = c.enabled && u && d && o === h, g = t.format(n || (f ? d : l)),
m = f ? c : a.ticks.minor, p = r.valueOrDefault(m.callback, m.userCallback);
return p ? p(g, e, i) : g
}, convertTicksToLabels: function (t) {
var e, i, a = [];
for (e = 0, i = t.length; e < i; ++e) a.push(this.tickFormatFunction(n(t[e].value), e, t));
return a
}, getPixelForOffset: function (t) {
var e = this, i = e._horizontal ? e.width : e.height, n = e._horizontal ? e.left : e.top,
a = c(e._table, "time", t, "pos");
return n + i * (e._offsets.left + a) / (e._offsets.left + 1 + e._offsets.right)
}, getPixelForValue: function (t, e, i) {
var n = null;
if (void 0 !== e && void 0 !== i && (n = this._timestamps.datasets[i][e]), null === n && (n = g(t, this)), null !== n) return this.getPixelForOffset(n)
}, getPixelForTick: function (t) {
var e = this.getTicks();
return t >= 0 && t < e.length ? this.getPixelForOffset(e[t].value) : null
}, getValueForPixel: function (t) {
var e = this, i = e._horizontal ? e.width : e.height, a = e._horizontal ? e.left : e.top,
r = (i ? (t - a) / i : 0) * (e._offsets.left + 1 + e._offsets.left) - e._offsets.right,
o = c(e._table, "pos", r, "time");
return n(o)
}, getLabelWidth: function (t) {
var e = this.options.ticks, i = this.ctx.measureText(t).width, n = r.toRadians(e.maxRotation),
o = Math.cos(n), s = Math.sin(n);
return i * o + r.valueOrDefault(e.fontSize, a.global.defaultFontSize) * s
}, getLabelCapacity: function (t) {
var e = this.options.time.displayFormats.millisecond,
i = this.tickFormatFunction(n(t), 0, [], e), a = this.getLabelWidth(i),
r = this.isHorizontal() ? this.width : this.height, o = Math.floor(r / a);
return o > 0 ? o : 1
}
});
t.scaleService.registerScaleType("time", e, {
position: "bottom",
distribution: "linear",
bounds: "data",
time: {
parser: !1,
format: !1,
unit: !1,
round: !1,
displayFormat: !1,
isoWeekday: !1,
minUnit: "millisecond",
displayFormats: {
millisecond: "h:mm:ss.SSS a",
second: "h:mm:ss a",
minute: "h:mm a",
hour: "hA",
day: "MMM D",
week: "ll",
month: "MMM YYYY",
quarter: "[Q]Q - YYYY",
year: "YYYY"
}
},
ticks: {autoSkip: !1, source: "auto", major: {enabled: !1}}
})
}
}, {25: 25, 45: 45, 6: 6}]
}, {}, [7])(7)
});