Source code

Revision control

Copy as Markdown

Other Tools

{"version":3,"file":"chartjs-7fd89fd7.js","sources":["../../node_modules/@kurkle/color/dist/color.esm.js","../../node_modules/chart.js/dist/chunks/helpers.segment.js","../../node_modules/chart.js/dist/chart.js","../../node_modules/chart.js/auto/auto.js","../../chartjs.js"],"sourcesContent":["/*!\n * @kurkle/color v0.3.2\n * https://github.com/kurkle/color#readme\n * (c) 2023 Jukka Kurkela\n * Released under the MIT License\n */\nfunction round(v) {\n return v + 0.5 | 0;\n}\nconst lim = (v, l, h) => Math.max(Math.min(v, h), l);\nfunction p2b(v) {\n return lim(round(v * 2.55), 0, 255);\n}\nfunction b2p(v) {\n return lim(round(v / 2.55), 0, 100);\n}\nfunction n2b(v) {\n return lim(round(v * 255), 0, 255);\n}\nfunction b2n(v) {\n return lim(round(v / 2.55) / 100, 0, 1);\n}\nfunction n2p(v) {\n return lim(round(v * 100), 0, 100);\n}\n\nconst map$1 = {0: 0, 1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9, A: 10, B: 11, C: 12, D: 13, E: 14, F: 15, a: 10, b: 11, c: 12, d: 13, e: 14, f: 15};\nconst hex = [...'0123456789ABCDEF'];\nconst h1 = b => hex[b & 0xF];\nconst h2 = b => hex[(b & 0xF0) >> 4] + hex[b & 0xF];\nconst eq = b => ((b & 0xF0) >> 4) === (b & 0xF);\nconst isShort = v => eq(v.r) && eq(v.g) && eq(v.b) && eq(v.a);\nfunction hexParse(str) {\n var len = str.length;\n var ret;\n if (str[0] === '#') {\n if (len === 4 || len === 5) {\n ret = {\n r: 255 & map$1[str[1]] * 17,\n g: 255 & map$1[str[2]] * 17,\n b: 255 & map$1[str[3]] * 17,\n a: len === 5 ? map$1[str[4]] * 17 : 255\n };\n } else if (len === 7 || len === 9) {\n ret = {\n r: map$1[str[1]] << 4 | map$1[str[2]],\n g: map$1[str[3]] << 4 | map$1[str[4]],\n b: map$1[str[5]] << 4 | map$1[str[6]],\n a: len === 9 ? (map$1[str[7]] << 4 | map$1[str[8]]) : 255\n };\n }\n }\n return ret;\n}\nconst alpha = (a, f) => a < 255 ? f(a) : '';\nfunction hexString(v) {\n var f = isShort(v) ? h1 : h2;\n return v\n ? '#' + f(v.r) + f(v.g) + f(v.b) + alpha(v.a, f)\n : undefined;\n}\n\nconst HUE_RE = /^(hsla?|hwb|hsv)\\(\\s*([-+.e\\d]+)(?:deg)?[\\s,]+([-+.e\\d]+)%[\\s,]+([-+.e\\d]+)%(?:[\\s,]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction hsl2rgbn(h, s, l) {\n const a = s * Math.min(l, 1 - l);\n const f = (n, k = (n + h / 30) % 12) => l - a * Math.max(Math.min(k - 3, 9 - k, 1), -1);\n return [f(0), f(8), f(4)];\n}\nfunction hsv2rgbn(h, s, v) {\n const f = (n, k = (n + h / 60) % 6) => v - v * s * Math.max(Math.min(k, 4 - k, 1), 0);\n return [f(5), f(3), f(1)];\n}\nfunction hwb2rgbn(h, w, b) {\n const rgb = hsl2rgbn(h, 1, 0.5);\n let i;\n if (w + b > 1) {\n i = 1 / (w + b);\n w *= i;\n b *= i;\n }\n for (i = 0; i < 3; i++) {\n rgb[i] *= 1 - w - b;\n rgb[i] += w;\n }\n return rgb;\n}\nfunction hueValue(r, g, b, d, max) {\n if (r === max) {\n return ((g - b) / d) + (g < b ? 6 : 0);\n }\n if (g === max) {\n return (b - r) / d + 2;\n }\n return (r - g) / d + 4;\n}\nfunction rgb2hsl(v) {\n const range = 255;\n const r = v.r / range;\n const g = v.g / range;\n const b = v.b / range;\n const max = Math.max(r, g, b);\n const min = Math.min(r, g, b);\n const l = (max + min) / 2;\n let h, s, d;\n if (max !== min) {\n d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n h = hueValue(r, g, b, d, max);\n h = h * 60 + 0.5;\n }\n return [h | 0, s || 0, l];\n}\nfunction calln(f, a, b, c) {\n return (\n Array.isArray(a)\n ? f(a[0], a[1], a[2])\n : f(a, b, c)\n ).map(n2b);\n}\nfunction hsl2rgb(h, s, l) {\n return calln(hsl2rgbn, h, s, l);\n}\nfunction hwb2rgb(h, w, b) {\n return calln(hwb2rgbn, h, w, b);\n}\nfunction hsv2rgb(h, s, v) {\n return calln(hsv2rgbn, h, s, v);\n}\nfunction hue(h) {\n return (h % 360 + 360) % 360;\n}\nfunction hueParse(str) {\n const m = HUE_RE.exec(str);\n let a = 255;\n let v;\n if (!m) {\n return;\n }\n if (m[5] !== v) {\n a = m[6] ? p2b(+m[5]) : n2b(+m[5]);\n }\n const h = hue(+m[2]);\n const p1 = +m[3] / 100;\n const p2 = +m[4] / 100;\n if (m[1] === 'hwb') {\n v = hwb2rgb(h, p1, p2);\n } else if (m[1] === 'hsv') {\n v = hsv2rgb(h, p1, p2);\n } else {\n v = hsl2rgb(h, p1, p2);\n }\n return {\n r: v[0],\n g: v[1],\n b: v[2],\n a: a\n };\n}\nfunction rotate(v, deg) {\n var h = rgb2hsl(v);\n h[0] = hue(h[0] + deg);\n h = hsl2rgb(h);\n v.r = h[0];\n v.g = h[1];\n v.b = h[2];\n}\nfunction hslString(v) {\n if (!v) {\n return;\n }\n const a = rgb2hsl(v);\n const h = a[0];\n const s = n2p(a[1]);\n const l = n2p(a[2]);\n return v.a < 255\n ? `hsla(${h}, ${s}%, ${l}%, ${b2n(v.a)})`\n : `hsl(${h}, ${s}%, ${l}%)`;\n}\n\nconst map = {\n x: 'dark',\n Z: 'light',\n Y: 're',\n X: 'blu',\n W: 'gr',\n V: 'medium',\n U: 'slate',\n A: 'ee',\n T: 'ol',\n S: 'or',\n B: 'ra',\n C: 'lateg',\n D: 'ights',\n R: 'in',\n Q: 'turquois',\n E: 'hi',\n P: 'ro',\n O: 'al',\n N: 'le',\n M: 'de',\n L: 'yello',\n F: 'en',\n K: 'ch',\n G: 'arks',\n H: 'ea',\n I: 'ightg',\n J: 'wh'\n};\nconst names$1 = {\n OiceXe: 'f0f8ff',\n antiquewEte: 'faebd7',\n aqua: 'ffff',\n aquamarRe: '7fffd4',\n azuY: 'f0ffff',\n beige: 'f5f5dc',\n bisque: 'ffe4c4',\n black: '0',\n blanKedOmond: 'ffebcd',\n Xe: 'ff',\n XeviTet: '8a2be2',\n bPwn: 'a52a2a',\n burlywood: 'deb887',\n caMtXe: '5f9ea0',\n KartYuse: '7fff00',\n KocTate: 'd2691e',\n cSO: 'ff7f50',\n cSnflowerXe: '6495ed',\n cSnsilk: 'fff8dc',\n crimson: 'dc143c',\n cyan: 'ffff',\n xXe: '8b',\n xcyan: '8b8b',\n xgTMnPd: 'b8860b',\n xWay: 'a9a9a9',\n xgYF: '6400',\n xgYy: 'a9a9a9',\n xkhaki: 'bdb76b',\n xmagFta: '8b008b',\n xTivegYF: '556b2f',\n xSange: 'ff8c00',\n xScEd: '9932cc',\n xYd: '8b0000',\n xsOmon: 'e9967a',\n xsHgYF: '8fbc8f',\n xUXe: '483d8b',\n xUWay: '2f4f4f',\n xUgYy: '2f4f4f',\n xQe: 'ced1',\n xviTet: '9400d3',\n dAppRk: 'ff1493',\n dApskyXe: 'bfff',\n dimWay: '696969',\n dimgYy: '696969',\n dodgerXe: '1e90ff',\n fiYbrick: 'b22222',\n flSOwEte: 'fffaf0',\n foYstWAn: '228b22',\n fuKsia: 'ff00ff',\n gaRsbSo: 'dcdcdc',\n ghostwEte: 'f8f8ff',\n gTd: 'ffd700',\n gTMnPd: 'daa520',\n Way: '808080',\n gYF: '8000',\n gYFLw: 'adff2f',\n gYy: '808080',\n honeyMw: 'f0fff0',\n hotpRk: 'ff69b4',\n RdianYd: 'cd5c5c',\n Rdigo: '4b0082',\n ivSy: 'fffff0',\n khaki: 'f0e68c',\n lavFMr: 'e6e6fa',\n lavFMrXsh: 'fff0f5',\n lawngYF: '7cfc00',\n NmoncEffon: 'fffacd',\n ZXe: 'add8e6',\n ZcSO: 'f08080',\n Zcyan: 'e0ffff',\n ZgTMnPdLw: 'fafad2',\n ZWay: 'd3d3d3',\n ZgYF: '90ee90',\n ZgYy: 'd3d3d3',\n ZpRk: 'ffb6c1',\n ZsOmon: 'ffa07a',\n ZsHgYF: '20b2aa',\n ZskyXe: '87cefa',\n ZUWay: '778899',\n ZUgYy: '778899',\n ZstAlXe: 'b0c4de',\n ZLw: 'ffffe0',\n lime: 'ff00',\n limegYF: '32cd32',\n lRF: 'faf0e6',\n magFta: 'ff00ff',\n maPon: '800000',\n VaquamarRe: '66cdaa',\n VXe: 'cd',\n VScEd: 'ba55d3',\n VpurpN: '9370db',\n VsHgYF: '3cb371',\n VUXe: '7b68ee',\n VsprRggYF: 'fa9a',\n VQe: '48d1cc',\n VviTetYd: 'c71585',\n midnightXe: '191970',\n mRtcYam: 'f5fffa',\n mistyPse: 'ffe4e1',\n moccasR: 'ffe4b5',\n navajowEte: 'ffdead',\n navy: '80',\n Tdlace: 'fdf5e6',\n Tive: '808000',\n TivedBb: '6b8e23',\n Sange: 'ffa500',\n SangeYd: 'ff4500',\n ScEd: 'da70d6',\n pOegTMnPd: 'eee8aa',\n pOegYF: '98fb98',\n pOeQe: 'afeeee',\n pOeviTetYd: 'db7093',\n papayawEp: 'ffefd5',\n pHKpuff: 'ffdab9',\n peru: 'cd853f',\n pRk: 'ffc0cb',\n plum: 'dda0dd',\n powMrXe: 'b0e0e6',\n purpN: '800080',\n YbeccapurpN: '663399',\n Yd: 'ff0000',\n Psybrown: 'bc8f8f',\n PyOXe: '4169e1',\n saddNbPwn: '8b4513',\n sOmon: 'fa8072',\n sandybPwn: 'f4a460',\n sHgYF: '2e8b57',\n sHshell: 'fff5ee',\n siFna: 'a0522d',\n silver: 'c0c0c0',\n skyXe: '87ceeb',\n UXe: '6a5acd',\n UWay: '708090',\n UgYy: '708090',\n snow: 'fffafa',\n sprRggYF: 'ff7f',\n stAlXe: '4682b4',\n tan: 'd2b48c',\n teO: '8080',\n tEstN: 'd8bfd8',\n tomato: 'ff6347',\n Qe: '40e0d0',\n viTet: 'ee82ee',\n JHt: 'f5deb3',\n wEte: 'ffffff',\n wEtesmoke: 'f5f5f5',\n Lw: 'ffff00',\n LwgYF: '9acd32'\n};\nfunction unpack() {\n const unpacked = {};\n const keys = Object.keys(names$1);\n const tkeys = Object.keys(map);\n let i, j, k, ok, nk;\n for (i = 0; i < keys.length; i++) {\n ok = nk = keys[i];\n for (j = 0; j < tkeys.length; j++) {\n k = tkeys[j];\n nk = nk.replace(k, map[k]);\n }\n k = parseInt(names$1[ok], 16);\n unpacked[nk] = [k >> 16 & 0xFF, k >> 8 & 0xFF, k & 0xFF];\n }\n return unpacked;\n}\n\nlet names;\nfunction nameParse(str) {\n if (!names) {\n names = unpack();\n names.transparent = [0, 0, 0, 0];\n }\n const a = names[str.toLowerCase()];\n return a && {\n r: a[0],\n g: a[1],\n b: a[2],\n a: a.length === 4 ? a[3] : 255\n };\n}\n\nconst RGB_RE = /^rgba?\\(\\s*([-+.\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?[\\s,]+([-+.e\\d]+)(%)?(?:[\\s,/]+([-+.e\\d]+)(%)?)?\\s*\\)$/;\nfunction rgbParse(str) {\n const m = RGB_RE.exec(str);\n let a = 255;\n let r, g, b;\n if (!m) {\n return;\n }\n if (m[7] !== r) {\n const v = +m[7];\n a = m[8] ? p2b(v) : lim(v * 255, 0, 255);\n }\n r = +m[1];\n g = +m[3];\n b = +m[5];\n r = 255 & (m[2] ? p2b(r) : lim(r, 0, 255));\n g = 255 & (m[4] ? p2b(g) : lim(g, 0, 255));\n b = 255 & (m[6] ? p2b(b) : lim(b, 0, 255));\n return {\n r: r,\n g: g,\n b: b,\n a: a\n };\n}\nfunction rgbString(v) {\n return v && (\n v.a < 255\n ? `rgba(${v.r}, ${v.g}, ${v.b}, ${b2n(v.a)})`\n : `rgb(${v.r}, ${v.g}, ${v.b})`\n );\n}\n\nconst to = v => v <= 0.0031308 ? v * 12.92 : Math.pow(v, 1.0 / 2.4) * 1.055 - 0.055;\nconst from = v => v <= 0.04045 ? v / 12.92 : Math.pow((v + 0.055) / 1.055, 2.4);\nfunction interpolate(rgb1, rgb2, t) {\n const r = from(b2n(rgb1.r));\n const g = from(b2n(rgb1.g));\n const b = from(b2n(rgb1.b));\n return {\n r: n2b(to(r + t * (from(b2n(rgb2.r)) - r))),\n g: n2b(to(g + t * (from(b2n(rgb2.g)) - g))),\n b: n2b(to(b + t * (from(b2n(rgb2.b)) - b))),\n a: rgb1.a + t * (rgb2.a - rgb1.a)\n };\n}\n\nfunction modHSL(v, i, ratio) {\n if (v) {\n let tmp = rgb2hsl(v);\n tmp[i] = Math.max(0, Math.min(tmp[i] + tmp[i] * ratio, i === 0 ? 360 : 1));\n tmp = hsl2rgb(tmp);\n v.r = tmp[0];\n v.g = tmp[1];\n v.b = tmp[2];\n }\n}\nfunction clone(v, proto) {\n return v ? Object.assign(proto || {}, v) : v;\n}\nfunction fromObject(input) {\n var v = {r: 0, g: 0, b: 0, a: 255};\n if (Array.isArray(input)) {\n if (input.length >= 3) {\n v = {r: input[0], g: input[1], b: input[2], a: 255};\n if (input.length > 3) {\n v.a = n2b(input[3]);\n }\n }\n } else {\n v = clone(input, {r: 0, g: 0, b: 0, a: 1});\n v.a = n2b(v.a);\n }\n return v;\n}\nfunction functionParse(str) {\n if (str.charAt(0) === 'r') {\n return rgbParse(str);\n }\n return hueParse(str);\n}\nclass Color {\n constructor(input) {\n if (input instanceof Color) {\n return input;\n }\n const type = typeof input;\n let v;\n if (type === 'object') {\n v = fromObject(input);\n } else if (type === 'string') {\n v = hexParse(input) || nameParse(input) || functionParse(input);\n }\n this._rgb = v;\n this._valid = !!v;\n }\n get valid() {\n return this._valid;\n }\n get rgb() {\n var v = clone(this._rgb);\n if (v) {\n v.a = b2n(v.a);\n }\n return v;\n }\n set rgb(obj) {\n this._rgb = fromObject(obj);\n }\n rgbString() {\n return this._valid ? rgbString(this._rgb) : undefined;\n }\n hexString() {\n return this._valid ? hexString(this._rgb) : undefined;\n }\n hslString() {\n return this._valid ? hslString(this._rgb) : undefined;\n }\n mix(color, weight) {\n if (color) {\n const c1 = this.rgb;\n const c2 = color.rgb;\n let w2;\n const p = weight === w2 ? 0.5 : weight;\n const w = 2 * p - 1;\n const a = c1.a - c2.a;\n const w1 = ((w * a === -1 ? w : (w + a) / (1 + w * a)) + 1) / 2.0;\n w2 = 1 - w1;\n c1.r = 0xFF & w1 * c1.r + w2 * c2.r + 0.5;\n c1.g = 0xFF & w1 * c1.g + w2 * c2.g + 0.5;\n c1.b = 0xFF & w1 * c1.b + w2 * c2.b + 0.5;\n c1.a = p * c1.a + (1 - p) * c2.a;\n this.rgb = c1;\n }\n return this;\n }\n interpolate(color, t) {\n if (color) {\n this._rgb = interpolate(this._rgb, color._rgb, t);\n }\n return this;\n }\n clone() {\n return new Color(this.rgb);\n }\n alpha(a) {\n this._rgb.a = n2b(a);\n return this;\n }\n clearer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 - ratio;\n return this;\n }\n greyscale() {\n const rgb = this._rgb;\n const val = round(rgb.r * 0.3 + rgb.g * 0.59 + rgb.b * 0.11);\n rgb.r = rgb.g = rgb.b = val;\n return this;\n }\n opaquer(ratio) {\n const rgb = this._rgb;\n rgb.a *= 1 + ratio;\n return this;\n }\n negate() {\n const v = this._rgb;\n v.r = 255 - v.r;\n v.g = 255 - v.g;\n v.b = 255 - v.b;\n return this;\n }\n lighten(ratio) {\n modHSL(this._rgb, 2, ratio);\n return this;\n }\n darken(ratio) {\n modHSL(this._rgb, 2, -ratio);\n return this;\n }\n saturate(ratio) {\n modHSL(this._rgb, 1, ratio);\n return this;\n }\n desaturate(ratio) {\n modHSL(this._rgb, 1, -ratio);\n return this;\n }\n rotate(deg) {\n rotate(this._rgb, deg);\n return this;\n }\n}\n\nfunction index_esm(input) {\n return new Color(input);\n}\n\nexport { Color, b2n, b2p, index_esm as default, hexParse, hexString, hsl2rgb, hslString, hsv2rgb, hueParse, hwb2rgb, lim, n2b, n2p, nameParse, p2b, rgb2hsl, rgbParse, rgbString, rotate, round };\n","/*!\n * Chart.js v4.2.1\n * https://www.chartjs.org\n * (c) 2023 Chart.js Contributors\n * Released under the MIT License\n */\nimport { Color } from '@kurkle/color';\n\n/**\n * @namespace Chart.helpers\n */ /**\n * An empty function that can be used, for example, for optional callback.\n */ function noop() {\n/* noop */ }\n/**\n * Returns a unique id, sequentially generated from a global variable.\n */ const uid = (()=>{\n let id = 0;\n return ()=>id++;\n})();\n/**\n * Returns true if `value` is neither null nor undefined, else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */ function isNullOrUndef(value) {\n return value === null || typeof value === 'undefined';\n}\n/**\n * Returns true if `value` is an array (including typed arrays), else returns false.\n * @param value - The value to test.\n * @function\n */ function isArray(value) {\n if (Array.isArray && Array.isArray(value)) {\n return true;\n }\n const type = Object.prototype.toString.call(value);\n if (type.slice(0, 7) === '[object' && type.slice(-6) === 'Array]') {\n return true;\n }\n return false;\n}\n/**\n * Returns true if `value` is an object (excluding null), else returns false.\n * @param value - The value to test.\n * @since 2.7.0\n */ function isObject(value) {\n return value !== null && Object.prototype.toString.call(value) === '[object Object]';\n}\n/**\n * Returns true if `value` is a finite number, else returns false\n * @param value - The value to test.\n */ function isNumberFinite(value) {\n return (typeof value === 'number' || value instanceof Number) && isFinite(+value);\n}\n/**\n * Returns `value` if finite, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is not finite.\n */ function finiteOrDefault(value, defaultValue) {\n return isNumberFinite(value) ? value : defaultValue;\n}\n/**\n * Returns `value` if defined, else returns `defaultValue`.\n * @param value - The value to return if defined.\n * @param defaultValue - The value to return if `value` is undefined.\n */ function valueOrDefault(value, defaultValue) {\n return typeof value === 'undefined' ? defaultValue : value;\n}\nconst toPercentage = (value, dimension)=>typeof value === 'string' && value.endsWith('%') ? parseFloat(value) / 100 : +value / dimension;\nconst toDimension = (value, dimension)=>typeof value === 'string' && value.endsWith('%') ? parseFloat(value) / 100 * dimension : +value;\n/**\n * Calls `fn` with the given `args` in the scope defined by `thisArg` and returns the\n * value returned by `fn`. If `fn` is not a function, this method returns undefined.\n * @param fn - The function to call.\n * @param args - The arguments with which `fn` should be called.\n * @param [thisArg] - The value of `this` provided for the call to `fn`.\n */ function callback(fn, args, thisArg) {\n if (fn && typeof fn.call === 'function') {\n return fn.apply(thisArg, args);\n }\n}\nfunction each(loopable, fn, thisArg, reverse) {\n let i, len, keys;\n if (isArray(loopable)) {\n len = loopable.length;\n if (reverse) {\n for(i = len - 1; i >= 0; i--){\n fn.call(thisArg, loopable[i], i);\n }\n } else {\n for(i = 0; i < len; i++){\n fn.call(thisArg, loopable[i], i);\n }\n }\n } else if (isObject(loopable)) {\n keys = Object.keys(loopable);\n len = keys.length;\n for(i = 0; i < len; i++){\n fn.call(thisArg, loopable[keys[i]], keys[i]);\n }\n }\n}\n/**\n * Returns true if the `a0` and `a1` arrays have the same content, else returns false.\n * @param a0 - The array to compare\n * @param a1 - The array to compare\n * @private\n */ function _elementsEqual(a0, a1) {\n let i, ilen, v0, v1;\n if (!a0 || !a1 || a0.length !== a1.length) {\n return false;\n }\n for(i = 0, ilen = a0.length; i < ilen; ++i){\n v0 = a0[i];\n v1 = a1[i];\n if (v0.datasetIndex !== v1.datasetIndex || v0.index !== v1.index) {\n return false;\n }\n }\n return true;\n}\n/**\n * Returns a deep copy of `source` without keeping references on objects and arrays.\n * @param source - The value to clone.\n */ function clone(source) {\n if (isArray(source)) {\n return source.map(clone);\n }\n if (isObject(source)) {\n const target = Object.create(null);\n const keys = Object.keys(source);\n const klen = keys.length;\n let k = 0;\n for(; k < klen; ++k){\n target[keys[k]] = clone(source[keys[k]]);\n }\n return target;\n }\n return source;\n}\nfunction isValidKey(key) {\n return [\n '__proto__',\n 'prototype',\n 'constructor'\n ].indexOf(key) === -1;\n}\n/**\n * The default merger when Chart.helpers.merge is called without merger option.\n * Note(SB): also used by mergeConfig and mergeScaleConfig as fallback.\n * @private\n */ function _merger(key, target, source, options) {\n if (!isValidKey(key)) {\n return;\n }\n const tval = target[key];\n const sval = source[key];\n if (isObject(tval) && isObject(sval)) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n merge(tval, sval, options);\n } else {\n target[key] = clone(sval);\n }\n}\nfunction merge(target, source, options) {\n const sources = isArray(source) ? source : [\n source\n ];\n const ilen = sources.length;\n if (!isObject(target)) {\n return target;\n }\n options = options || {};\n const merger = options.merger || _merger;\n let current;\n for(let i = 0; i < ilen; ++i){\n current = sources[i];\n if (!isObject(current)) {\n continue;\n }\n const keys = Object.keys(current);\n for(let k = 0, klen = keys.length; k < klen; ++k){\n merger(keys[k], target, current, options);\n }\n }\n return target;\n}\nfunction mergeIf(target, source) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n return merge(target, source, {\n merger: _mergerIf\n });\n}\n/**\n * Merges source[key] in target[key] only if target[key] is undefined.\n * @private\n */ function _mergerIf(key, target, source) {\n if (!isValidKey(key)) {\n return;\n }\n const tval = target[key];\n const sval = source[key];\n if (isObject(tval) && isObject(sval)) {\n mergeIf(tval, sval);\n } else if (!Object.prototype.hasOwnProperty.call(target, key)) {\n target[key] = clone(sval);\n }\n}\n/**\n * @private\n */ function _deprecated(scope, value, previous, current) {\n if (value !== undefined) {\n console.warn(scope + ': \"' + previous + '\" is deprecated. Please use \"' + current + '\" instead');\n }\n}\n// resolveObjectKey resolver cache\nconst keyResolvers = {\n // Chart.helpers.core resolveObjectKey should resolve empty key to root object\n '': (v)=>v,\n // default resolvers\n x: (o)=>o.x,\n y: (o)=>o.y\n};\n/**\n * @private\n */ function _splitKey(key) {\n const parts = key.split('.');\n const keys = [];\n let tmp = '';\n for (const part of parts){\n tmp += part;\n if (tmp.endsWith('\\\\')) {\n tmp = tmp.slice(0, -1) + '.';\n } else {\n keys.push(tmp);\n tmp = '';\n }\n }\n return keys;\n}\nfunction _getKeyResolver(key) {\n const keys = _splitKey(key);\n return (obj)=>{\n for (const k of keys){\n if (k === '') {\n break;\n }\n obj = obj && obj[k];\n }\n return obj;\n };\n}\nfunction resolveObjectKey(obj, key) {\n const resolver = keyResolvers[key] || (keyResolvers[key] = _getKeyResolver(key));\n return resolver(obj);\n}\n/**\n * @private\n */ function _capitalize(str) {\n return str.charAt(0).toUpperCase() + str.slice(1);\n}\nconst defined = (value)=>typeof value !== 'undefined';\nconst isFunction = (value)=>typeof value === 'function';\n// Adapted from https://stackoverflow.com/questions/31128855/comparing-ecma6-sets-for-equality#31129384\nconst setsEqual = (a, b)=>{\n if (a.size !== b.size) {\n return false;\n }\n for (const item of a){\n if (!b.has(item)) {\n return false;\n }\n }\n return true;\n};\n/**\n * @param e - The event\n * @private\n */ function _isClickEvent(e) {\n return e.type === 'mouseup' || e.type === 'click' || e.type === 'contextmenu';\n}\n\n/**\n * @alias Chart.helpers.math\n * @namespace\n */ const PI = Math.PI;\nconst TAU = 2 * PI;\nconst PITAU = TAU + PI;\nconst INFINITY = Number.POSITIVE_INFINITY;\nconst RAD_PER_DEG = PI / 180;\nconst HALF_PI = PI / 2;\nconst QUARTER_PI = PI / 4;\nconst TWO_THIRDS_PI = PI * 2 / 3;\nconst log10 = Math.log10;\nconst sign = Math.sign;\nfunction almostEquals(x, y, epsilon) {\n return Math.abs(x - y) < epsilon;\n}\n/**\n * Implementation of the nice number algorithm used in determining where axis labels will go\n */ function niceNum(range) {\n const roundedRange = Math.round(range);\n range = almostEquals(range, roundedRange, range / 1000) ? roundedRange : range;\n const niceRange = Math.pow(10, Math.floor(log10(range)));\n const fraction = range / niceRange;\n const niceFraction = fraction <= 1 ? 1 : fraction <= 2 ? 2 : fraction <= 5 ? 5 : 10;\n return niceFraction * niceRange;\n}\n/**\n * Returns an array of factors sorted from 1 to sqrt(value)\n * @private\n */ function _factorize(value) {\n const result = [];\n const sqrt = Math.sqrt(value);\n let i;\n for(i = 1; i < sqrt; i++){\n if (value % i === 0) {\n result.push(i);\n result.push(value / i);\n }\n }\n if (sqrt === (sqrt | 0)) {\n result.push(sqrt);\n }\n result.sort((a, b)=>a - b).pop();\n return result;\n}\nfunction isNumber(n) {\n return !isNaN(parseFloat(n)) && isFinite(n);\n}\nfunction almostWhole(x, epsilon) {\n const rounded = Math.round(x);\n return rounded - epsilon <= x && rounded + epsilon >= x;\n}\n/**\n * @private\n */ function _setMinAndMaxByKey(array, target, property) {\n let i, ilen, value;\n for(i = 0, ilen = array.length; i < ilen; i++){\n value = array[i][property];\n if (!isNaN(value)) {\n target.min = Math.min(target.min, value);\n target.max = Math.max(target.max, value);\n }\n }\n}\nfunction toRadians(degrees) {\n return degrees * (PI / 180);\n}\nfunction toDegrees(radians) {\n return radians * (180 / PI);\n}\n/**\n * Returns the number of decimal places\n * i.e. the number of digits after the decimal point, of the value of this Number.\n * @param x - A number.\n * @returns The number of decimal places.\n * @private\n */ function _decimalPlaces(x) {\n if (!isNumberFinite(x)) {\n return;\n }\n let e = 1;\n let p = 0;\n while(Math.round(x * e) / e !== x){\n e *= 10;\n p++;\n }\n return p;\n}\n// Gets the angle from vertical upright to the point about a centre.\nfunction getAngleFromPoint(centrePoint, anglePoint) {\n const distanceFromXCenter = anglePoint.x - centrePoint.x;\n const distanceFromYCenter = anglePoint.y - centrePoint.y;\n const radialDistanceFromCenter = Math.sqrt(distanceFromXCenter * distanceFromXCenter + distanceFromYCenter * distanceFromYCenter);\n let angle = Math.atan2(distanceFromYCenter, distanceFromXCenter);\n if (angle < -0.5 * PI) {\n angle += TAU; // make sure the returned angle is in the range of (-PI/2, 3PI/2]\n }\n return {\n angle,\n distance: radialDistanceFromCenter\n };\n}\nfunction distanceBetweenPoints(pt1, pt2) {\n return Math.sqrt(Math.pow(pt2.x - pt1.x, 2) + Math.pow(pt2.y - pt1.y, 2));\n}\n/**\n * Shortest distance between angles, in either direction.\n * @private\n */ function _angleDiff(a, b) {\n return (a - b + PITAU) % TAU - PI;\n}\n/**\n * Normalize angle to be between 0 and 2*PI\n * @private\n */ function _normalizeAngle(a) {\n return (a % TAU + TAU) % TAU;\n}\n/**\n * @private\n */ function _angleBetween(angle, start, end, sameAngleIsFullCircle) {\n const a = _normalizeAngle(angle);\n const s = _normalizeAngle(start);\n const e = _normalizeAngle(end);\n const angleToStart = _normalizeAngle(s - a);\n const angleToEnd = _normalizeAngle(e - a);\n const startToAngle = _normalizeAngle(a - s);\n const endToAngle = _normalizeAngle(a - e);\n return a === s || a === e || sameAngleIsFullCircle && s === e || angleToStart > angleToEnd && startToAngle < endToAngle;\n}\n/**\n * Limit `value` between `min` and `max`\n * @param value\n * @param min\n * @param max\n * @private\n */ function _limitValue(value, min, max) {\n return Math.max(min, Math.min(max, value));\n}\n/**\n * @param {number} value\n * @private\n */ function _int16Range(value) {\n return _limitValue(value, -32768, 32767);\n}\n/**\n * @param value\n * @param start\n * @param end\n * @param [epsilon]\n * @private\n */ function _isBetween(value, start, end, epsilon = 1e-6) {\n return value >= Math.min(start, end) - epsilon && value <= Math.max(start, end) + epsilon;\n}\n\nfunction _lookup(table, value, cmp) {\n cmp = cmp || ((index)=>table[index] < value);\n let hi = table.length - 1;\n let lo = 0;\n let mid;\n while(hi - lo > 1){\n mid = lo + hi >> 1;\n if (cmp(mid)) {\n lo = mid;\n } else {\n hi = mid;\n }\n }\n return {\n lo,\n hi\n };\n}\n/**\n * Binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @param last - lookup last index\n * @private\n */ const _lookupByKey = (table, key, value, last)=>_lookup(table, value, last ? (index)=>{\n const ti = table[index][key];\n return ti < value || ti === value && table[index + 1][key] === value;\n } : (index)=>table[index][key] < value);\n/**\n * Reverse binary search\n * @param table - the table search. must be sorted!\n * @param key - property name for the value in each entry\n * @param value - value to find\n * @private\n */ const _rlookupByKey = (table, key, value)=>_lookup(table, value, (index)=>table[index][key] >= value);\n/**\n * Return subset of `values` between `min` and `max` inclusive.\n * Values are assumed to be in sorted order.\n * @param values - sorted array of values\n * @param min - min value\n * @param max - max value\n */ function _filterBetween(values, min, max) {\n let start = 0;\n let end = values.length;\n while(start < end && values[start] < min){\n start++;\n }\n while(end > start && values[end - 1] > max){\n end--;\n }\n return start > 0 || end < values.length ? values.slice(start, end) : values;\n}\nconst arrayEvents = [\n 'push',\n 'pop',\n 'shift',\n 'splice',\n 'unshift'\n];\nfunction listenArrayEvents(array, listener) {\n if (array._chartjs) {\n array._chartjs.listeners.push(listener);\n return;\n }\n Object.defineProperty(array, '_chartjs', {\n configurable: true,\n enumerable: false,\n value: {\n listeners: [\n listener\n ]\n }\n });\n arrayEvents.forEach((key)=>{\n const method = '_onData' + _capitalize(key);\n const base = array[key];\n Object.defineProperty(array, key, {\n configurable: true,\n enumerable: false,\n value (...args) {\n const res = base.apply(this, args);\n array._chartjs.listeners.forEach((object)=>{\n if (typeof object[method] === 'function') {\n object[method](...args);\n }\n });\n return res;\n }\n });\n });\n}\nfunction unlistenArrayEvents(array, listener) {\n const stub = array._chartjs;\n if (!stub) {\n return;\n }\n const listeners = stub.listeners;\n const index = listeners.indexOf(listener);\n if (index !== -1) {\n listeners.splice(index, 1);\n }\n if (listeners.length > 0) {\n return;\n }\n arrayEvents.forEach((key)=>{\n delete array[key];\n });\n delete array._chartjs;\n}\n/**\n * @param items\n */ function _arrayUnique(items) {\n const set = new Set();\n let i, ilen;\n for(i = 0, ilen = items.length; i < ilen; ++i){\n set.add(items[i]);\n }\n if (set.size === ilen) {\n return items;\n }\n return Array.from(set);\n}\n\nfunction fontString(pixelSize, fontStyle, fontFamily) {\n return fontStyle + ' ' + pixelSize + 'px ' + fontFamily;\n}\n/**\n* Request animation polyfill\n*/ const requestAnimFrame = function() {\n if (typeof window === 'undefined') {\n return function(callback) {\n return callback();\n };\n }\n return window.requestAnimationFrame;\n}();\n/**\n * Throttles calling `fn` once per animation frame\n * Latest arguments are used on the actual call\n */ function throttled(fn, thisArg) {\n let argsToUse = [];\n let ticking = false;\n return function(...args) {\n // Save the args for use later\n argsToUse = args;\n if (!ticking) {\n ticking = true;\n requestAnimFrame.call(window, ()=>{\n ticking = false;\n fn.apply(thisArg, argsToUse);\n });\n }\n };\n}\n/**\n * Debounces calling `fn` for `delay` ms\n */ function debounce(fn, delay) {\n let timeout;\n return function(...args) {\n if (delay) {\n clearTimeout(timeout);\n timeout = setTimeout(fn, delay, args);\n } else {\n fn.apply(this, args);\n }\n return delay;\n };\n}\n/**\n * Converts 'start' to 'left', 'end' to 'right' and others to 'center'\n * @private\n */ const _toLeftRightCenter = (align)=>align === 'start' ? 'left' : align === 'end' ? 'right' : 'center';\n/**\n * Returns `start`, `end` or `(start + end) / 2` depending on `align`. Defaults to `center`\n * @private\n */ const _alignStartEnd = (align, start, end)=>align === 'start' ? start : align === 'end' ? end : (start + end) / 2;\n/**\n * Returns `left`, `right` or `(left + right) / 2` depending on `align`. Defaults to `left`\n * @private\n */ const _textX = (align, left, right, rtl)=>{\n const check = rtl ? 'left' : 'right';\n return align === check ? right : align === 'center' ? (left + right) / 2 : left;\n};\n/**\n * Return start and count of visible points.\n * @private\n */ function _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled) {\n const pointCount = points.length;\n let start = 0;\n let count = pointCount;\n if (meta._sorted) {\n const { iScale , _parsed } = meta;\n const axis = iScale.axis;\n const { min , max , minDefined , maxDefined } = iScale.getUserBounds();\n if (minDefined) {\n start = _limitValue(Math.min(// @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, iScale.axis, min).lo, // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? pointCount : _lookupByKey(points, axis, iScale.getPixelForValue(min)).lo), 0, pointCount - 1);\n }\n if (maxDefined) {\n count = _limitValue(Math.max(// @ts-expect-error Need to type _parsed\n _lookupByKey(_parsed, iScale.axis, max, true).hi + 1, // @ts-expect-error Need to fix types on _lookupByKey\n animationsDisabled ? 0 : _lookupByKey(points, axis, iScale.getPixelForValue(max), true).hi + 1), start, pointCount) - start;\n } else {\n count = pointCount - start;\n }\n }\n return {\n start,\n count\n };\n}\n/**\n * Checks if the scale ranges have changed.\n * @param {object} meta - dataset meta.\n * @returns {boolean}\n * @private\n */ function _scaleRangesChanged(meta) {\n const { xScale , yScale , _scaleRanges } = meta;\n const newRanges = {\n xmin: xScale.min,\n xmax: xScale.max,\n ymin: yScale.min,\n ymax: yScale.max\n };\n if (!_scaleRanges) {\n meta._scaleRanges = newRanges;\n return true;\n }\n const changed = _scaleRanges.xmin !== xScale.min || _scaleRanges.xmax !== xScale.max || _scaleRanges.ymin !== yScale.min || _scaleRanges.ymax !== yScale.max;\n Object.assign(_scaleRanges, newRanges);\n return changed;\n}\n\nconst atEdge = (t)=>t === 0 || t === 1;\nconst elasticIn = (t, s, p)=>-(Math.pow(2, 10 * (t -= 1)) * Math.sin((t - s) * TAU / p));\nconst elasticOut = (t, s, p)=>Math.pow(2, -10 * t) * Math.sin((t - s) * TAU / p) + 1;\n/**\n * Easing functions adapted from Robert Penner's easing equations.\n * @namespace Chart.helpers.easing.effects\n * @see http://www.robertpenner.com/easing/\n */ const effects = {\n linear: (t)=>t,\n easeInQuad: (t)=>t * t,\n easeOutQuad: (t)=>-t * (t - 2),\n easeInOutQuad: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t : -0.5 * (--t * (t - 2) - 1),\n easeInCubic: (t)=>t * t * t,\n easeOutCubic: (t)=>(t -= 1) * t * t + 1,\n easeInOutCubic: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t : 0.5 * ((t -= 2) * t * t + 2),\n easeInQuart: (t)=>t * t * t * t,\n easeOutQuart: (t)=>-((t -= 1) * t * t * t - 1),\n easeInOutQuart: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t * t : -0.5 * ((t -= 2) * t * t * t - 2),\n easeInQuint: (t)=>t * t * t * t * t,\n easeOutQuint: (t)=>(t -= 1) * t * t * t * t + 1,\n easeInOutQuint: (t)=>(t /= 0.5) < 1 ? 0.5 * t * t * t * t * t : 0.5 * ((t -= 2) * t * t * t * t + 2),\n easeInSine: (t)=>-Math.cos(t * HALF_PI) + 1,\n easeOutSine: (t)=>Math.sin(t * HALF_PI),\n easeInOutSine: (t)=>-0.5 * (Math.cos(PI * t) - 1),\n easeInExpo: (t)=>t === 0 ? 0 : Math.pow(2, 10 * (t - 1)),\n easeOutExpo: (t)=>t === 1 ? 1 : -Math.pow(2, -10 * t) + 1,\n easeInOutExpo: (t)=>atEdge(t) ? t : t < 0.5 ? 0.5 * Math.pow(2, 10 * (t * 2 - 1)) : 0.5 * (-Math.pow(2, -10 * (t * 2 - 1)) + 2),\n easeInCirc: (t)=>t >= 1 ? t : -(Math.sqrt(1 - t * t) - 1),\n easeOutCirc: (t)=>Math.sqrt(1 - (t -= 1) * t),\n easeInOutCirc: (t)=>(t /= 0.5) < 1 ? -0.5 * (Math.sqrt(1 - t * t) - 1) : 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1),\n easeInElastic: (t)=>atEdge(t) ? t : elasticIn(t, 0.075, 0.3),\n easeOutElastic: (t)=>atEdge(t) ? t : elasticOut(t, 0.075, 0.3),\n easeInOutElastic (t) {\n const s = 0.1125;\n const p = 0.45;\n return atEdge(t) ? t : t < 0.5 ? 0.5 * elasticIn(t * 2, s, p) : 0.5 + 0.5 * elasticOut(t * 2 - 1, s, p);\n },\n easeInBack (t) {\n const s = 1.70158;\n return t * t * ((s + 1) * t - s);\n },\n easeOutBack (t) {\n const s = 1.70158;\n return (t -= 1) * t * ((s + 1) * t + s) + 1;\n },\n easeInOutBack (t) {\n let s = 1.70158;\n if ((t /= 0.5) < 1) {\n return 0.5 * (t * t * (((s *= 1.525) + 1) * t - s));\n }\n return 0.5 * ((t -= 2) * t * (((s *= 1.525) + 1) * t + s) + 2);\n },\n easeInBounce: (t)=>1 - effects.easeOutBounce(1 - t),\n easeOutBounce (t) {\n const m = 7.5625;\n const d = 2.75;\n if (t < 1 / d) {\n return m * t * t;\n }\n if (t < 2 / d) {\n return m * (t -= 1.5 / d) * t + 0.75;\n }\n if (t < 2.5 / d) {\n return m * (t -= 2.25 / d) * t + 0.9375;\n }\n return m * (t -= 2.625 / d) * t + 0.984375;\n },\n easeInOutBounce: (t)=>t < 0.5 ? effects.easeInBounce(t * 2) * 0.5 : effects.easeOutBounce(t * 2 - 1) * 0.5 + 0.5\n};\n\nfunction isPatternOrGradient(value) {\n if (value && typeof value === 'object') {\n const type = value.toString();\n return type === '[object CanvasPattern]' || type === '[object CanvasGradient]';\n }\n return false;\n}\nfunction color(value) {\n return isPatternOrGradient(value) ? value : new Color(value);\n}\nfunction getHoverColor(value) {\n return isPatternOrGradient(value) ? value : new Color(value).saturate(0.5).darken(0.1).hexString();\n}\n\nconst numbers = [\n 'x',\n 'y',\n 'borderWidth',\n 'radius',\n 'tension'\n];\nconst colors = [\n 'color',\n 'borderColor',\n 'backgroundColor'\n];\nfunction applyAnimationsDefaults(defaults) {\n defaults.set('animation', {\n delay: undefined,\n duration: 1000,\n easing: 'easeOutQuart',\n fn: undefined,\n from: undefined,\n loop: undefined,\n to: undefined,\n type: undefined\n });\n defaults.describe('animation', {\n _fallback: false,\n _indexable: false,\n _scriptable: (name)=>name !== 'onProgress' && name !== 'onComplete' && name !== 'fn'\n });\n defaults.set('animations', {\n colors: {\n type: 'color',\n properties: colors\n },\n numbers: {\n type: 'number',\n properties: numbers\n }\n });\n defaults.describe('animations', {\n _fallback: 'animation'\n });\n defaults.set('transitions', {\n active: {\n animation: {\n duration: 400\n }\n },\n resize: {\n animation: {\n duration: 0\n }\n },\n show: {\n animations: {\n colors: {\n from: 'transparent'\n },\n visible: {\n type: 'boolean',\n duration: 0\n }\n }\n },\n hide: {\n animations: {\n colors: {\n to: 'transparent'\n },\n visible: {\n type: 'boolean',\n easing: 'linear',\n fn: (v)=>v | 0\n }\n }\n }\n });\n}\n\nfunction applyLayoutsDefaults(defaults) {\n defaults.set('layout', {\n autoPadding: true,\n padding: {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0\n }\n });\n}\n\nconst intlCache = new Map();\nfunction getNumberFormat(locale, options) {\n options = options || {};\n const cacheKey = locale + JSON.stringify(options);\n let formatter = intlCache.get(cacheKey);\n if (!formatter) {\n formatter = new Intl.NumberFormat(locale, options);\n intlCache.set(cacheKey, formatter);\n }\n return formatter;\n}\nfunction formatNumber(num, locale, options) {\n return getNumberFormat(locale, options).format(num);\n}\n\nconst formatters = {\n values (value) {\n return isArray(value) ? value : '' + value;\n },\n numeric (tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0';\n }\n const locale = this.chart.options.locale;\n let notation;\n let delta = tickValue;\n if (ticks.length > 1) {\n const maxTick = Math.max(Math.abs(ticks[0].value), Math.abs(ticks[ticks.length - 1].value));\n if (maxTick < 1e-4 || maxTick > 1e+15) {\n notation = 'scientific';\n }\n delta = calculateDelta(tickValue, ticks);\n }\n const logDelta = log10(Math.abs(delta));\n const numDecimal = Math.max(Math.min(-1 * Math.floor(logDelta), 20), 0);\n const options = {\n notation,\n minimumFractionDigits: numDecimal,\n maximumFractionDigits: numDecimal\n };\n Object.assign(options, this.options.ticks.format);\n return formatNumber(tickValue, locale, options);\n },\n logarithmic (tickValue, index, ticks) {\n if (tickValue === 0) {\n return '0';\n }\n const remain = ticks[index].significand || tickValue / Math.pow(10, Math.floor(log10(tickValue)));\n if ([\n 1,\n 2,\n 3,\n 5,\n 10,\n 15\n ].includes(remain) || index > 0.8 * ticks.length) {\n return formatters.numeric.call(this, tickValue, index, ticks);\n }\n return '';\n }\n};\nfunction calculateDelta(tickValue, ticks) {\n let delta = ticks.length > 3 ? ticks[2].value - ticks[1].value : ticks[1].value - ticks[0].value;\n if (Math.abs(delta) >= 1 && tickValue !== Math.floor(tickValue)) {\n delta = tickValue - Math.floor(tickValue);\n }\n return delta;\n}\n var Ticks = {\n formatters\n};\n\nfunction applyScaleDefaults(defaults) {\n defaults.set('scale', {\n display: true,\n offset: false,\n reverse: false,\n beginAtZero: false,\n bounds: 'ticks',\n grace: 0,\n grid: {\n display: true,\n lineWidth: 1,\n drawOnChartArea: true,\n drawTicks: true,\n tickLength: 8,\n tickWidth: (_ctx, options)=>options.lineWidth,\n tickColor: (_ctx, options)=>options.color,\n offset: false\n },\n border: {\n display: true,\n dash: [],\n dashOffset: 0.0,\n width: 1\n },\n title: {\n display: false,\n text: '',\n padding: {\n top: 4,\n bottom: 4\n }\n },\n ticks: {\n minRotation: 0,\n maxRotation: 50,\n mirror: false,\n textStrokeWidth: 0,\n textStrokeColor: '',\n padding: 3,\n display: true,\n autoSkip: true,\n autoSkipPadding: 3,\n labelOffset: 0,\n callback: Ticks.formatters.values,\n minor: {},\n major: {},\n align: 'center',\n crossAlign: 'near',\n showLabelBackdrop: false,\n backdropColor: 'rgba(255, 255, 255, 0.75)',\n backdropPadding: 2\n }\n });\n defaults.route('scale.ticks', 'color', '', 'color');\n defaults.route('scale.grid', 'color', '', 'borderColor');\n defaults.route('scale.border', 'color', '', 'borderColor');\n defaults.route('scale.title', 'color', '', 'color');\n defaults.describe('scale', {\n _fallback: false,\n _scriptable: (name)=>!name.startsWith('before') && !name.startsWith('after') && name !== 'callback' && name !== 'parser',\n _indexable: (name)=>name !== 'borderDash' && name !== 'tickBorderDash' && name !== 'dash'\n });\n defaults.describe('scales', {\n _fallback: 'scale'\n });\n defaults.describe('scale.ticks', {\n _scriptable: (name)=>name !== 'backdropPadding' && name !== 'callback',\n _indexable: (name)=>name !== 'backdropPadding'\n });\n}\n\nconst overrides = Object.create(null);\nconst descriptors = Object.create(null);\n function getScope$1(node, key) {\n if (!key) {\n return node;\n }\n const keys = key.split('.');\n for(let i = 0, n = keys.length; i < n; ++i){\n const k = keys[i];\n node = node[k] || (node[k] = Object.create(null));\n }\n return node;\n}\nfunction set(root, scope, values) {\n if (typeof scope === 'string') {\n return merge(getScope$1(root, scope), values);\n }\n return merge(getScope$1(root, ''), scope);\n}\n class Defaults {\n constructor(_descriptors, _appliers){\n this.animation = undefined;\n this.backgroundColor = 'rgba(0,0,0,0.1)';\n this.borderColor = 'rgba(0,0,0,0.1)';\n this.color = '#666';\n this.datasets = {};\n this.devicePixelRatio = (context)=>context.chart.platform.getDevicePixelRatio();\n this.elements = {};\n this.events = [\n 'mousemove',\n 'mouseout',\n 'click',\n 'touchstart',\n 'touchmove'\n ];\n this.font = {\n family: \"'Helvetica Neue', 'Helvetica', 'Arial', sans-serif\",\n size: 12,\n style: 'normal',\n lineHeight: 1.2,\n weight: null\n };\n this.hover = {};\n this.hoverBackgroundColor = (ctx, options)=>getHoverColor(options.backgroundColor);\n this.hoverBorderColor = (ctx, options)=>getHoverColor(options.borderColor);\n this.hoverColor = (ctx, options)=>getHoverColor(options.color);\n this.indexAxis = 'x';\n this.interaction = {\n mode: 'nearest',\n intersect: true,\n includeInvisible: false\n };\n this.maintainAspectRatio = true;\n this.onHover = null;\n this.onClick = null;\n this.parsing = true;\n this.plugins = {};\n this.responsive = true;\n this.scale = undefined;\n this.scales = {};\n this.showLine = true;\n this.drawActiveElementsOnTop = true;\n this.describe(_descriptors);\n this.apply(_appliers);\n }\n set(scope, values) {\n return set(this, scope, values);\n }\n get(scope) {\n return getScope$1(this, scope);\n }\n describe(scope, values) {\n return set(descriptors, scope, values);\n }\n override(scope, values) {\n return set(overrides, scope, values);\n }\n route(scope, name, targetScope, targetName) {\n const scopeObject = getScope$1(this, scope);\n const targetScopeObject = getScope$1(this, targetScope);\n const privateName = '_' + name;\n Object.defineProperties(scopeObject, {\n [privateName]: {\n value: scopeObject[name],\n writable: true\n },\n [name]: {\n enumerable: true,\n get () {\n const local = this[privateName];\n const target = targetScopeObject[targetName];\n if (isObject(local)) {\n return Object.assign({}, target, local);\n }\n return valueOrDefault(local, target);\n },\n set (value) {\n this[privateName] = value;\n }\n }\n });\n }\n apply(appliers) {\n appliers.forEach((apply)=>apply(this));\n }\n}\nvar defaults = /* #__PURE__ */ new Defaults({\n _scriptable: (name)=>!name.startsWith('on'),\n _indexable: (name)=>name !== 'events',\n hover: {\n _fallback: 'interaction'\n },\n interaction: {\n _scriptable: false,\n _indexable: false\n }\n}, [\n applyAnimationsDefaults,\n applyLayoutsDefaults,\n applyScaleDefaults\n]);\n\nfunction toFontString(font) {\n if (!font || isNullOrUndef(font.size) || isNullOrUndef(font.family)) {\n return null;\n }\n return (font.style ? font.style + ' ' : '') + (font.weight ? font.weight + ' ' : '') + font.size + 'px ' + font.family;\n}\n function _measureText(ctx, data, gc, longest, string) {\n let textWidth = data[string];\n if (!textWidth) {\n textWidth = data[string] = ctx.measureText(string).width;\n gc.push(string);\n }\n if (textWidth > longest) {\n longest = textWidth;\n }\n return longest;\n}\n function _longestText(ctx, font, arrayOfThings, cache) {\n cache = cache || {};\n let data = cache.data = cache.data || {};\n let gc = cache.garbageCollect = cache.garbageCollect || [];\n if (cache.font !== font) {\n data = cache.data = {};\n gc = cache.garbageCollect = [];\n cache.font = font;\n }\n ctx.save();\n ctx.font = font;\n let longest = 0;\n const ilen = arrayOfThings.length;\n let i, j, jlen, thing, nestedThing;\n for(i = 0; i < ilen; i++){\n thing = arrayOfThings[i];\n if (thing !== undefined && thing !== null && isArray(thing) !== true) {\n longest = _measureText(ctx, data, gc, longest, thing);\n } else if (isArray(thing)) {\n for(j = 0, jlen = thing.length; j < jlen; j++){\n nestedThing = thing[j];\n if (nestedThing !== undefined && nestedThing !== null && !isArray(nestedThing)) {\n longest = _measureText(ctx, data, gc, longest, nestedThing);\n }\n }\n }\n }\n ctx.restore();\n const gcLen = gc.length / 2;\n if (gcLen > arrayOfThings.length) {\n for(i = 0; i < gcLen; i++){\n delete data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n return longest;\n}\n function _alignPixel(chart, pixel, width) {\n const devicePixelRatio = chart.currentDevicePixelRatio;\n const halfWidth = width !== 0 ? Math.max(width / 2, 0.5) : 0;\n return Math.round((pixel - halfWidth) * devicePixelRatio) / devicePixelRatio + halfWidth;\n}\n function clearCanvas(canvas, ctx) {\n ctx = ctx || canvas.getContext('2d');\n ctx.save();\n ctx.resetTransform();\n ctx.clearRect(0, 0, canvas.width, canvas.height);\n ctx.restore();\n}\nfunction drawPoint(ctx, options, x, y) {\n drawPointLegend(ctx, options, x, y, null);\n}\nfunction drawPointLegend(ctx, options, x, y, w) {\n let type, xOffset, yOffset, size, cornerRadius, width, xOffsetW, yOffsetW;\n const style = options.pointStyle;\n const rotation = options.rotation;\n const radius = options.radius;\n let rad = (rotation || 0) * RAD_PER_DEG;\n if (style && typeof style === 'object') {\n type = style.toString();\n if (type === '[object HTMLImageElement]' || type === '[object HTMLCanvasElement]') {\n ctx.save();\n ctx.translate(x, y);\n ctx.rotate(rad);\n ctx.drawImage(style, -style.width / 2, -style.height / 2, style.width, style.height);\n ctx.restore();\n return;\n }\n }\n if (isNaN(radius) || radius <= 0) {\n return;\n }\n ctx.beginPath();\n switch(style){\n default:\n if (w) {\n ctx.ellipse(x, y, w / 2, radius, 0, 0, TAU);\n } else {\n ctx.arc(x, y, radius, 0, TAU);\n }\n ctx.closePath();\n break;\n case 'triangle':\n width = w ? w / 2 : radius;\n ctx.moveTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n rad += TWO_THIRDS_PI;\n ctx.lineTo(x + Math.sin(rad) * width, y - Math.cos(rad) * radius);\n ctx.closePath();\n break;\n case 'rectRounded':\n cornerRadius = radius * 0.516;\n size = radius - cornerRadius;\n xOffset = Math.cos(rad + QUARTER_PI) * size;\n xOffsetW = Math.cos(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n yOffset = Math.sin(rad + QUARTER_PI) * size;\n yOffsetW = Math.sin(rad + QUARTER_PI) * (w ? w / 2 - cornerRadius : size);\n ctx.arc(x - xOffsetW, y - yOffset, cornerRadius, rad - PI, rad - HALF_PI);\n ctx.arc(x + yOffsetW, y - xOffset, cornerRadius, rad - HALF_PI, rad);\n ctx.arc(x + xOffsetW, y + yOffset, cornerRadius, rad, rad + HALF_PI);\n ctx.arc(x - yOffsetW, y + xOffset, cornerRadius, rad + HALF_PI, rad + PI);\n ctx.closePath();\n break;\n case 'rect':\n if (!rotation) {\n size = Math.SQRT1_2 * radius;\n width = w ? w / 2 : size;\n ctx.rect(x - width, y - size, 2 * width, 2 * size);\n break;\n }\n rad += QUARTER_PI;\n case 'rectRot':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n ctx.closePath();\n break;\n case 'crossRot':\n rad += QUARTER_PI;\n case 'cross':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'star':\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n rad += QUARTER_PI;\n xOffsetW = Math.cos(rad) * (w ? w / 2 : radius);\n xOffset = Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n yOffsetW = Math.sin(rad) * (w ? w / 2 : radius);\n ctx.moveTo(x - xOffsetW, y - yOffset);\n ctx.lineTo(x + xOffsetW, y + yOffset);\n ctx.moveTo(x + yOffsetW, y - xOffset);\n ctx.lineTo(x - yOffsetW, y + xOffset);\n break;\n case 'line':\n xOffset = w ? w / 2 : Math.cos(rad) * radius;\n yOffset = Math.sin(rad) * radius;\n ctx.moveTo(x - xOffset, y - yOffset);\n ctx.lineTo(x + xOffset, y + yOffset);\n break;\n case 'dash':\n ctx.moveTo(x, y);\n ctx.lineTo(x + Math.cos(rad) * (w ? w / 2 : radius), y + Math.sin(rad) * radius);\n break;\n case false:\n ctx.closePath();\n break;\n }\n ctx.fill();\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n}\n function _isPointInArea(point, area, margin) {\n margin = margin || 0.5;\n return !area || point && point.x > area.left - margin && point.x < area.right + margin && point.y > area.top - margin && point.y < area.bottom + margin;\n}\nfunction clipArea(ctx, area) {\n ctx.save();\n ctx.beginPath();\n ctx.rect(area.left, area.top, area.right - area.left, area.bottom - area.top);\n ctx.clip();\n}\nfunction unclipArea(ctx) {\n ctx.restore();\n}\n function _steppedLineTo(ctx, previous, target, flip, mode) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n if (mode === 'middle') {\n const midpoint = (previous.x + target.x) / 2.0;\n ctx.lineTo(midpoint, previous.y);\n ctx.lineTo(midpoint, target.y);\n } else if (mode === 'after' !== !!flip) {\n ctx.lineTo(previous.x, target.y);\n } else {\n ctx.lineTo(target.x, previous.y);\n }\n ctx.lineTo(target.x, target.y);\n}\n function _bezierCurveTo(ctx, previous, target, flip) {\n if (!previous) {\n return ctx.lineTo(target.x, target.y);\n }\n ctx.bezierCurveTo(flip ? previous.cp1x : previous.cp2x, flip ? previous.cp1y : previous.cp2y, flip ? target.cp2x : target.cp1x, flip ? target.cp2y : target.cp1y, target.x, target.y);\n}\n function renderText(ctx, text, x, y, font, opts = {}) {\n const lines = isArray(text) ? text : [\n text\n ];\n const stroke = opts.strokeWidth > 0 && opts.strokeColor !== '';\n let i, line;\n ctx.save();\n ctx.font = font.string;\n setRenderOpts(ctx, opts);\n for(i = 0; i < lines.length; ++i){\n line = lines[i];\n if (opts.backdrop) {\n drawBackdrop(ctx, opts.backdrop);\n }\n if (stroke) {\n if (opts.strokeColor) {\n ctx.strokeStyle = opts.strokeColor;\n }\n if (!isNullOrUndef(opts.strokeWidth)) {\n ctx.lineWidth = opts.strokeWidth;\n }\n ctx.strokeText(line, x, y, opts.maxWidth);\n }\n ctx.fillText(line, x, y, opts.maxWidth);\n decorateText(ctx, x, y, line, opts);\n y += font.lineHeight;\n }\n ctx.restore();\n}\nfunction setRenderOpts(ctx, opts) {\n if (opts.translation) {\n ctx.translate(opts.translation[0], opts.translation[1]);\n }\n if (!isNullOrUndef(opts.rotation)) {\n ctx.rotate(opts.rotation);\n }\n if (opts.color) {\n ctx.fillStyle = opts.color;\n }\n if (opts.textAlign) {\n ctx.textAlign = opts.textAlign;\n }\n if (opts.textBaseline) {\n ctx.textBaseline = opts.textBaseline;\n }\n}\nfunction decorateText(ctx, x, y, line, opts) {\n if (opts.strikethrough || opts.underline) {\n const metrics = ctx.measureText(line);\n const left = x - metrics.actualBoundingBoxLeft;\n const right = x + metrics.actualBoundingBoxRight;\n const top = y - metrics.actualBoundingBoxAscent;\n const bottom = y + metrics.actualBoundingBoxDescent;\n const yDecoration = opts.strikethrough ? (top + bottom) / 2 : bottom;\n ctx.strokeStyle = ctx.fillStyle;\n ctx.beginPath();\n ctx.lineWidth = opts.decorationWidth || 2;\n ctx.moveTo(left, yDecoration);\n ctx.lineTo(right, yDecoration);\n ctx.stroke();\n }\n}\nfunction drawBackdrop(ctx, opts) {\n const oldColor = ctx.fillStyle;\n ctx.fillStyle = opts.color;\n ctx.fillRect(opts.left, opts.top, opts.width, opts.height);\n ctx.fillStyle = oldColor;\n}\n function addRoundedRectPath(ctx, rect) {\n const { x , y , w , h , radius } = rect;\n ctx.arc(x + radius.topLeft, y + radius.topLeft, radius.topLeft, -HALF_PI, PI, true);\n ctx.lineTo(x, y + h - radius.bottomLeft);\n ctx.arc(x + radius.bottomLeft, y + h - radius.bottomLeft, radius.bottomLeft, PI, HALF_PI, true);\n ctx.lineTo(x + w - radius.bottomRight, y + h);\n ctx.arc(x + w - radius.bottomRight, y + h - radius.bottomRight, radius.bottomRight, HALF_PI, 0, true);\n ctx.lineTo(x + w, y + radius.topRight);\n ctx.arc(x + w - radius.topRight, y + radius.topRight, radius.topRight, 0, -HALF_PI, true);\n ctx.lineTo(x + radius.topLeft, y);\n}\n\nconst LINE_HEIGHT = /^(normal|(\\d+(?:\\.\\d+)?)(px|em|%)?)$/;\nconst FONT_STYLE = /^(normal|italic|initial|inherit|unset|(oblique( -?[0-9]?[0-9]deg)?))$/;\n/**\n * @alias Chart.helpers.options\n * @namespace\n */ /**\n * Converts the given line height `value` in pixels for a specific font `size`.\n * @param value - The lineHeight to parse (eg. 1.6, '14px', '75%', '1.6em').\n * @param size - The font size (in pixels) used to resolve relative `value`.\n * @returns The effective line height in pixels (size * 1.2 if value is invalid).\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/line-height\n * @since 2.7.0\n */ function toLineHeight(value, size) {\n const matches = ('' + value).match(LINE_HEIGHT);\n if (!matches || matches[1] === 'normal') {\n return size * 1.2;\n }\n value = +matches[2];\n switch(matches[3]){\n case 'px':\n return value;\n case '%':\n value /= 100;\n break;\n }\n return size * value;\n}\nconst numberOrZero = (v)=>+v || 0;\nfunction _readValueToProps(value, props) {\n const ret = {};\n const objProps = isObject(props);\n const keys = objProps ? Object.keys(props) : props;\n const read = isObject(value) ? objProps ? (prop)=>valueOrDefault(value[prop], value[props[prop]]) : (prop)=>value[prop] : ()=>value;\n for (const prop of keys){\n ret[prop] = numberOrZero(read(prop));\n }\n return ret;\n}\n/**\n * Converts the given value into a TRBL object.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left)\n * @since 3.0.0\n */ function toTRBL(value) {\n return _readValueToProps(value, {\n top: 'y',\n right: 'x',\n bottom: 'y',\n left: 'x'\n });\n}\n/**\n * Converts the given value into a TRBL corners object (similar with css border-radius).\n * @param value - If a number, set the value to all TRBL corner components,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * @returns The TRBL corner values (topLeft, topRight, bottomLeft, bottomRight)\n * @since 3.0.0\n */ function toTRBLCorners(value) {\n return _readValueToProps(value, [\n 'topLeft',\n 'topRight',\n 'bottomLeft',\n 'bottomRight'\n ]);\n}\n/**\n * Converts the given value into a padding object with pre-computed width/height.\n * @param value - If a number, set the value to all TRBL component,\n * else, if an object, use defined properties and sets undefined ones to 0.\n * x / y are shorthands for same value for left/right and top/bottom.\n * @returns The padding values (top, right, bottom, left, width, height)\n * @since 2.7.0\n */ function toPadding(value) {\n const obj = toTRBL(value);\n obj.width = obj.left + obj.right;\n obj.height = obj.top + obj.bottom;\n return obj;\n}\n/**\n * Parses font options and returns the font object.\n * @param options - A object that contains font options to be parsed.\n * @param fallback - A object that contains fallback font options.\n * @return The font object.\n * @private\n */ function toFont(options, fallback) {\n options = options || {};\n fallback = fallback || defaults.font;\n let size = valueOrDefault(options.size, fallback.size);\n if (typeof size === 'string') {\n size = parseInt(size, 10);\n }\n let style = valueOrDefault(options.style, fallback.style);\n if (style && !('' + style).match(FONT_STYLE)) {\n console.warn('Invalid font style specified: \"' + style + '\"');\n style = undefined;\n }\n const font = {\n family: valueOrDefault(options.family, fallback.family),\n lineHeight: toLineHeight(valueOrDefault(options.lineHeight, fallback.lineHeight), size),\n size,\n style,\n weight: valueOrDefault(options.weight, fallback.weight),\n string: ''\n };\n font.string = toFontString(font);\n return font;\n}\n/**\n * Evaluates the given `inputs` sequentially and returns the first defined value.\n * @param inputs - An array of values, falling back to the last value.\n * @param context - If defined and the current value is a function, the value\n * is called with `context` as first argument and the result becomes the new input.\n * @param index - If defined and the current value is an array, the value\n * at `index` become the new input.\n * @param info - object to return information about resolution in\n * @param info.cacheable - Will be set to `false` if option is not cacheable.\n * @since 2.7.0\n */ function resolve(inputs, context, index, info) {\n let cacheable = true;\n let i, ilen, value;\n for(i = 0, ilen = inputs.length; i < ilen; ++i){\n value = inputs[i];\n if (value === undefined) {\n continue;\n }\n if (context !== undefined && typeof value === 'function') {\n value = value(context);\n cacheable = false;\n }\n if (index !== undefined && isArray(value)) {\n value = value[index % value.length];\n cacheable = false;\n }\n if (value !== undefined) {\n if (info && !cacheable) {\n info.cacheable = false;\n }\n return value;\n }\n }\n}\n/**\n * @param minmax\n * @param grace\n * @param beginAtZero\n * @private\n */ function _addGrace(minmax, grace, beginAtZero) {\n const { min , max } = minmax;\n const change = toDimension(grace, (max - min) / 2);\n const keepZero = (value, add)=>beginAtZero && value === 0 ? 0 : value + add;\n return {\n min: keepZero(min, -Math.abs(change)),\n max: keepZero(max, change)\n };\n}\nfunction createContext(parentContext, context) {\n return Object.assign(Object.create(parentContext), context);\n}\n\nfunction _createResolver(scopes, prefixes = [\n ''\n], rootScopes = scopes, fallback, getTarget = ()=>scopes[0]) {\n if (!defined(fallback)) {\n fallback = _resolve('_fallback', scopes);\n }\n const cache = {\n [Symbol.toStringTag]: 'Object',\n _cacheable: true,\n _scopes: scopes,\n _rootScopes: rootScopes,\n _fallback: fallback,\n _getTarget: getTarget,\n override: (scope)=>_createResolver([\n scope,\n ...scopes\n ], prefixes, rootScopes, fallback)\n };\n return new Proxy(cache, {\n deleteProperty (target, prop) {\n delete target[prop];\n delete target._keys;\n delete scopes[0][prop];\n return true;\n },\n get (target, prop) {\n return _cached(target, prop, ()=>_resolveWithPrefixes(prop, prefixes, scopes, target));\n },\n getOwnPropertyDescriptor (target, prop) {\n return Reflect.getOwnPropertyDescriptor(target._scopes[0], prop);\n },\n getPrototypeOf () {\n return Reflect.getPrototypeOf(scopes[0]);\n },\n has (target, prop) {\n return getKeysFromAllScopes(target).includes(prop);\n },\n ownKeys (target) {\n return getKeysFromAllScopes(target);\n },\n set (target, prop, value) {\n const storage = target._storage || (target._storage = getTarget());\n target[prop] = storage[prop] = value;\n delete target._keys;\n return true;\n }\n });\n}\n function _attachContext(proxy, context, subProxy, descriptorDefaults) {\n const cache = {\n _cacheable: false,\n _proxy: proxy,\n _context: context,\n _subProxy: subProxy,\n _stack: new Set(),\n _descriptors: _descriptors(proxy, descriptorDefaults),\n setContext: (ctx)=>_attachContext(proxy, ctx, subProxy, descriptorDefaults),\n override: (scope)=>_attachContext(proxy.override(scope), context, subProxy, descriptorDefaults)\n };\n return new Proxy(cache, {\n deleteProperty (target, prop) {\n delete target[prop];\n delete proxy[prop];\n return true;\n },\n get (target, prop, receiver) {\n return _cached(target, prop, ()=>_resolveWithContext(target, prop, receiver));\n },\n getOwnPropertyDescriptor (target, prop) {\n return target._descriptors.allKeys ? Reflect.has(proxy, prop) ? {\n enumerable: true,\n configurable: true\n } : undefined : Reflect.getOwnPropertyDescriptor(proxy, prop);\n },\n getPrototypeOf () {\n return Reflect.getPrototypeOf(proxy);\n },\n has (target, prop) {\n return Reflect.has(proxy, prop);\n },\n ownKeys () {\n return Reflect.ownKeys(proxy);\n },\n set (target, prop, value) {\n proxy[prop] = value;\n delete target[prop];\n return true;\n }\n });\n}\n function _descriptors(proxy, defaults = {\n scriptable: true,\n indexable: true\n}) {\n const { _scriptable =defaults.scriptable , _indexable =defaults.indexable , _allKeys =defaults.allKeys } = proxy;\n return {\n allKeys: _allKeys,\n scriptable: _scriptable,\n indexable: _indexable,\n isScriptable: isFunction(_scriptable) ? _scriptable : ()=>_scriptable,\n isIndexable: isFunction(_indexable) ? _indexable : ()=>_indexable\n };\n}\nconst readKey = (prefix, name)=>prefix ? prefix + _capitalize(name) : name;\nconst needsSubResolver = (prop, value)=>isObject(value) && prop !== 'adapters' && (Object.getPrototypeOf(value) === null || value.constructor === Object);\nfunction _cached(target, prop, resolve) {\n if (Object.prototype.hasOwnProperty.call(target, prop)) {\n return target[prop];\n }\n const value = resolve();\n target[prop] = value;\n return value;\n}\nfunction _resolveWithContext(target, prop, receiver) {\n const { _proxy , _context , _subProxy , _descriptors: descriptors } = target;\n let value = _proxy[prop];\n if (isFunction(value) && descriptors.isScriptable(prop)) {\n value = _resolveScriptable(prop, value, target, receiver);\n }\n if (isArray(value) && value.length) {\n value = _resolveArray(prop, value, target, descriptors.isIndexable);\n }\n if (needsSubResolver(prop, value)) {\n value = _attachContext(value, _context, _subProxy && _subProxy[prop], descriptors);\n }\n return value;\n}\nfunction _resolveScriptable(prop, value, target, receiver) {\n const { _proxy , _context , _subProxy , _stack } = target;\n if (_stack.has(prop)) {\n throw new Error('Recursion detected: ' + Array.from(_stack).join('->') + '->' + prop);\n }\n _stack.add(prop);\n value = value(_context, _subProxy || receiver);\n _stack.delete(prop);\n if (needsSubResolver(prop, value)) {\n value = createSubResolver(_proxy._scopes, _proxy, prop, value);\n }\n return value;\n}\nfunction _resolveArray(prop, value, target, isIndexable) {\n const { _proxy , _context , _subProxy , _descriptors: descriptors } = target;\n if (defined(_context.index) && isIndexable(prop)) {\n value = value[_context.index % value.length];\n } else if (isObject(value[0])) {\n const arr = value;\n const scopes = _proxy._scopes.filter((s)=>s !== arr);\n value = [];\n for (const item of arr){\n const resolver = createSubResolver(scopes, _proxy, prop, item);\n value.push(_attachContext(resolver, _context, _subProxy && _subProxy[prop], descriptors));\n }\n }\n return value;\n}\nfunction resolveFallback(fallback, prop, value) {\n return isFunction(fallback) ? fallback(prop, value) : fallback;\n}\nconst getScope = (key, parent)=>key === true ? parent : typeof key === 'string' ? resolveObjectKey(parent, key) : undefined;\nfunction addScopes(set, parentScopes, key, parentFallback, value) {\n for (const parent of parentScopes){\n const scope = getScope(key, parent);\n if (scope) {\n set.add(scope);\n const fallback = resolveFallback(scope._fallback, key, value);\n if (defined(fallback) && fallback !== key && fallback !== parentFallback) {\n return fallback;\n }\n } else if (scope === false && defined(parentFallback) && key !== parentFallback) {\n return null;\n }\n }\n return false;\n}\nfunction createSubResolver(parentScopes, resolver, prop, value) {\n const rootScopes = resolver._rootScopes;\n const fallback = resolveFallback(resolver._fallback, prop, value);\n const allScopes = [\n ...parentScopes,\n ...rootScopes\n ];\n const set = new Set();\n set.add(value);\n let key = addScopesFromKey(set, allScopes, prop, fallback || prop, value);\n if (key === null) {\n return false;\n }\n if (defined(fallback) && fallback !== prop) {\n key = addScopesFromKey(set, allScopes, fallback, key, value);\n if (key === null) {\n return false;\n }\n }\n return _createResolver(Array.from(set), [\n ''\n ], rootScopes, fallback, ()=>subGetTarget(resolver, prop, value));\n}\nfunction addScopesFromKey(set, allScopes, key, fallback, item) {\n while(key){\n key = addScopes(set, allScopes, key, fallback, item);\n }\n return key;\n}\nfunction subGetTarget(resolver, prop, value) {\n const parent = resolver._getTarget();\n if (!(prop in parent)) {\n parent[prop] = {};\n }\n const target = parent[prop];\n if (isArray(target) && isObject(value)) {\n return value;\n }\n return target || {};\n}\nfunction _resolveWithPrefixes(prop, prefixes, scopes, proxy) {\n let value;\n for (const prefix of prefixes){\n value = _resolve(readKey(prefix, prop), scopes);\n if (defined(value)) {\n return needsSubResolver(prop, value) ? createSubResolver(scopes, proxy, prop, value) : value;\n }\n }\n}\nfunction _resolve(key, scopes) {\n for (const scope of scopes){\n if (!scope) {\n continue;\n }\n const value = scope[key];\n if (defined(value)) {\n return value;\n }\n }\n}\nfunction getKeysFromAllScopes(target) {\n let keys = target._keys;\n if (!keys) {\n keys = target._keys = resolveKeysFromAllScopes(target._scopes);\n }\n return keys;\n}\nfunction resolveKeysFromAllScopes(scopes) {\n const set = new Set();\n for (const scope of scopes){\n for (const key of Object.keys(scope).filter((k)=>!k.startsWith('_'))){\n set.add(key);\n }\n }\n return Array.from(set);\n}\nfunction _parseObjectDataRadialScale(meta, data, start, count) {\n const { iScale } = meta;\n const { key ='r' } = this._parsing;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n r: iScale.parse(resolveObjectKey(item, key), index)\n };\n }\n return parsed;\n}\n\nconst EPSILON = Number.EPSILON || 1e-14;\nconst getPoint = (points, i)=>i < points.length && !points[i].skip && points[i];\nconst getValueAxis = (indexAxis)=>indexAxis === 'x' ? 'y' : 'x';\nfunction splineCurve(firstPoint, middlePoint, afterPoint, t) {\n // Props to Rob Spencer at scaled innovation for his post on splining between points\n // http://scaledinnovation.com/analytics/splines/aboutSplines.html\n // This function must also respect \"skipped\" points\n const previous = firstPoint.skip ? middlePoint : firstPoint;\n const current = middlePoint;\n const next = afterPoint.skip ? middlePoint : afterPoint;\n const d01 = distanceBetweenPoints(current, previous);\n const d12 = distanceBetweenPoints(next, current);\n let s01 = d01 / (d01 + d12);\n let s12 = d12 / (d01 + d12);\n // If all points are the same, s01 & s02 will be inf\n s01 = isNaN(s01) ? 0 : s01;\n s12 = isNaN(s12) ? 0 : s12;\n const fa = t * s01; // scaling factor for triangle Ta\n const fb = t * s12;\n return {\n previous: {\n x: current.x - fa * (next.x - previous.x),\n y: current.y - fa * (next.y - previous.y)\n },\n next: {\n x: current.x + fb * (next.x - previous.x),\n y: current.y + fb * (next.y - previous.y)\n }\n };\n}\n/**\n * Adjust tangents to ensure monotonic properties\n */ function monotoneAdjust(points, deltaK, mK) {\n const pointsLen = points.length;\n let alphaK, betaK, tauK, squaredMagnitude, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(let i = 0; i < pointsLen - 1; ++i){\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent || !pointAfter) {\n continue;\n }\n if (almostEquals(deltaK[i], 0, EPSILON)) {\n mK[i] = mK[i + 1] = 0;\n continue;\n }\n alphaK = mK[i] / deltaK[i];\n betaK = mK[i + 1] / deltaK[i];\n squaredMagnitude = Math.pow(alphaK, 2) + Math.pow(betaK, 2);\n if (squaredMagnitude <= 9) {\n continue;\n }\n tauK = 3 / Math.sqrt(squaredMagnitude);\n mK[i] = alphaK * tauK * deltaK[i];\n mK[i + 1] = betaK * tauK * deltaK[i];\n }\n}\nfunction monotoneCompute(points, mK, indexAxis = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n let delta, pointBefore, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(let i = 0; i < pointsLen; ++i){\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n const iPixel = pointCurrent[indexAxis];\n const vPixel = pointCurrent[valueAxis];\n if (pointBefore) {\n delta = (iPixel - pointBefore[indexAxis]) / 3;\n pointCurrent[`cp1${indexAxis}`] = iPixel - delta;\n pointCurrent[`cp1${valueAxis}`] = vPixel - delta * mK[i];\n }\n if (pointAfter) {\n delta = (pointAfter[indexAxis] - iPixel) / 3;\n pointCurrent[`cp2${indexAxis}`] = iPixel + delta;\n pointCurrent[`cp2${valueAxis}`] = vPixel + delta * mK[i];\n }\n }\n}\n/**\n * This function calculates Bézier control points in a similar way than |splineCurve|,\n * but preserves monotonicity of the provided data and ensures no local extremums are added\n * between the dataset discrete points due to the interpolation.\n * See : https://en.wikipedia.org/wiki/Monotone_cubic_interpolation\n */ function splineCurveMonotone(points, indexAxis = 'x') {\n const valueAxis = getValueAxis(indexAxis);\n const pointsLen = points.length;\n const deltaK = Array(pointsLen).fill(0);\n const mK = Array(pointsLen);\n // Calculate slopes (deltaK) and initialize tangents (mK)\n let i, pointBefore, pointCurrent;\n let pointAfter = getPoint(points, 0);\n for(i = 0; i < pointsLen; ++i){\n pointBefore = pointCurrent;\n pointCurrent = pointAfter;\n pointAfter = getPoint(points, i + 1);\n if (!pointCurrent) {\n continue;\n }\n if (pointAfter) {\n const slopeDelta = pointAfter[indexAxis] - pointCurrent[indexAxis];\n // In the case of two points that appear at the same x pixel, slopeDeltaX is 0\n deltaK[i] = slopeDelta !== 0 ? (pointAfter[valueAxis] - pointCurrent[valueAxis]) / slopeDelta : 0;\n }\n mK[i] = !pointBefore ? deltaK[i] : !pointAfter ? deltaK[i - 1] : sign(deltaK[i - 1]) !== sign(deltaK[i]) ? 0 : (deltaK[i - 1] + deltaK[i]) / 2;\n }\n monotoneAdjust(points, deltaK, mK);\n monotoneCompute(points, mK, indexAxis);\n}\nfunction capControlPoint(pt, min, max) {\n return Math.max(Math.min(pt, max), min);\n}\nfunction capBezierPoints(points, area) {\n let i, ilen, point, inArea, inAreaPrev;\n let inAreaNext = _isPointInArea(points[0], area);\n for(i = 0, ilen = points.length; i < ilen; ++i){\n inAreaPrev = inArea;\n inArea = inAreaNext;\n inAreaNext = i < ilen - 1 && _isPointInArea(points[i + 1], area);\n if (!inArea) {\n continue;\n }\n point = points[i];\n if (inAreaPrev) {\n point.cp1x = capControlPoint(point.cp1x, area.left, area.right);\n point.cp1y = capControlPoint(point.cp1y, area.top, area.bottom);\n }\n if (inAreaNext) {\n point.cp2x = capControlPoint(point.cp2x, area.left, area.right);\n point.cp2y = capControlPoint(point.cp2y, area.top, area.bottom);\n }\n }\n}\n/**\n * @private\n */ function _updateBezierControlPoints(points, options, area, loop, indexAxis) {\n let i, ilen, point, controlPoints;\n // Only consider points that are drawn in case the spanGaps option is used\n if (options.spanGaps) {\n points = points.filter((pt)=>!pt.skip);\n }\n if (options.cubicInterpolationMode === 'monotone') {\n splineCurveMonotone(points, indexAxis);\n } else {\n let prev = loop ? points[points.length - 1] : points[0];\n for(i = 0, ilen = points.length; i < ilen; ++i){\n point = points[i];\n controlPoints = splineCurve(prev, point, points[Math.min(i + 1, ilen - (loop ? 0 : 1)) % ilen], options.tension);\n point.cp1x = controlPoints.previous.x;\n point.cp1y = controlPoints.previous.y;\n point.cp2x = controlPoints.next.x;\n point.cp2y = controlPoints.next.y;\n prev = point;\n }\n }\n if (options.capBezierPoints) {\n capBezierPoints(points, area);\n }\n}\n\n/**\n * Note: typedefs are auto-exported, so use a made-up `dom` namespace where\n * necessary to avoid duplicates with `export * from './helpers`; see\n * https://github.com/microsoft/TypeScript/issues/46011\n * @typedef { import('../core/core.controller.js').default } dom.Chart\n * @typedef { import('../../types').ChartEvent } ChartEvent\n */ /**\n * @private\n */ function _isDomSupported() {\n return typeof window !== 'undefined' && typeof document !== 'undefined';\n}\n/**\n * @private\n */ function _getParentNode(domNode) {\n let parent = domNode.parentNode;\n if (parent && parent.toString() === '[object ShadowRoot]') {\n parent = parent.host;\n }\n return parent;\n}\n/**\n * convert max-width/max-height values that may be percentages into a number\n * @private\n */ function parseMaxStyle(styleValue, node, parentProperty) {\n let valueInPixels;\n if (typeof styleValue === 'string') {\n valueInPixels = parseInt(styleValue, 10);\n if (styleValue.indexOf('%') !== -1) {\n // percentage * size in dimension\n valueInPixels = valueInPixels / 100 * node.parentNode[parentProperty];\n }\n } else {\n valueInPixels = styleValue;\n }\n return valueInPixels;\n}\nconst getComputedStyle = (element)=>element.ownerDocument.defaultView.getComputedStyle(element, null);\nfunction getStyle(el, property) {\n return getComputedStyle(el).getPropertyValue(property);\n}\nconst positions = [\n 'top',\n 'right',\n 'bottom',\n 'left'\n];\nfunction getPositionedStyle(styles, style, suffix) {\n const result = {};\n suffix = suffix ? '-' + suffix : '';\n for(let i = 0; i < 4; i++){\n const pos = positions[i];\n result[pos] = parseFloat(styles[style + '-' + pos + suffix]) || 0;\n }\n result.width = result.left + result.right;\n result.height = result.top + result.bottom;\n return result;\n}\nconst useOffsetPos = (x, y, target)=>(x > 0 || y > 0) && (!target || !target.shadowRoot);\n/**\n * @param e\n * @param canvas\n * @returns Canvas position\n */ function getCanvasPosition(e, canvas) {\n const touches = e.touches;\n const source = touches && touches.length ? touches[0] : e;\n const { offsetX , offsetY } = source;\n let box = false;\n let x, y;\n if (useOffsetPos(offsetX, offsetY, e.target)) {\n x = offsetX;\n y = offsetY;\n } else {\n const rect = canvas.getBoundingClientRect();\n x = source.clientX - rect.left;\n y = source.clientY - rect.top;\n box = true;\n }\n return {\n x,\n y,\n box\n };\n}\n/**\n * Gets an event's x, y coordinates, relative to the chart area\n * @param event\n * @param chart\n * @returns x and y coordinates of the event\n */ function getRelativePosition(event, chart) {\n if ('native' in event) {\n return event;\n }\n const { canvas , currentDevicePixelRatio } = chart;\n const style = getComputedStyle(canvas);\n const borderBox = style.boxSizing === 'border-box';\n const paddings = getPositionedStyle(style, 'padding');\n const borders = getPositionedStyle(style, 'border', 'width');\n const { x , y , box } = getCanvasPosition(event, canvas);\n const xOffset = paddings.left + (box && borders.left);\n const yOffset = paddings.top + (box && borders.top);\n let { width , height } = chart;\n if (borderBox) {\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n return {\n x: Math.round((x - xOffset) / width * canvas.width / currentDevicePixelRatio),\n y: Math.round((y - yOffset) / height * canvas.height / currentDevicePixelRatio)\n };\n}\nfunction getContainerSize(canvas, width, height) {\n let maxWidth, maxHeight;\n if (width === undefined || height === undefined) {\n const container = _getParentNode(canvas);\n if (!container) {\n width = canvas.clientWidth;\n height = canvas.clientHeight;\n } else {\n const rect = container.getBoundingClientRect(); // this is the border box of the container\n const containerStyle = getComputedStyle(container);\n const containerBorder = getPositionedStyle(containerStyle, 'border', 'width');\n const containerPadding = getPositionedStyle(containerStyle, 'padding');\n width = rect.width - containerPadding.width - containerBorder.width;\n height = rect.height - containerPadding.height - containerBorder.height;\n maxWidth = parseMaxStyle(containerStyle.maxWidth, container, 'clientWidth');\n maxHeight = parseMaxStyle(containerStyle.maxHeight, container, 'clientHeight');\n }\n }\n return {\n width,\n height,\n maxWidth: maxWidth || INFINITY,\n maxHeight: maxHeight || INFINITY\n };\n}\nconst round1 = (v)=>Math.round(v * 10) / 10;\n// eslint-disable-next-line complexity\nfunction getMaximumSize(canvas, bbWidth, bbHeight, aspectRatio) {\n const style = getComputedStyle(canvas);\n const margins = getPositionedStyle(style, 'margin');\n const maxWidth = parseMaxStyle(style.maxWidth, canvas, 'clientWidth') || INFINITY;\n const maxHeight = parseMaxStyle(style.maxHeight, canvas, 'clientHeight') || INFINITY;\n const containerSize = getContainerSize(canvas, bbWidth, bbHeight);\n let { width , height } = containerSize;\n if (style.boxSizing === 'content-box') {\n const borders = getPositionedStyle(style, 'border', 'width');\n const paddings = getPositionedStyle(style, 'padding');\n width -= paddings.width + borders.width;\n height -= paddings.height + borders.height;\n }\n width = Math.max(0, width - margins.width);\n height = Math.max(0, aspectRatio ? width / aspectRatio : height - margins.height);\n width = round1(Math.min(width, maxWidth, containerSize.maxWidth));\n height = round1(Math.min(height, maxHeight, containerSize.maxHeight));\n if (width && !height) {\n // https://github.com/chartjs/Chart.js/issues/4659\n // If the canvas has width, but no height, default to aspectRatio of 2 (canvas default)\n height = round1(width / 2);\n }\n const maintainHeight = bbWidth !== undefined || bbHeight !== undefined;\n if (maintainHeight && aspectRatio && containerSize.height && height > containerSize.height) {\n height = containerSize.height;\n width = round1(Math.floor(height * aspectRatio));\n }\n return {\n width,\n height\n };\n}\n/**\n * @param chart\n * @param forceRatio\n * @param forceStyle\n * @returns True if the canvas context size or transformation has changed.\n */ function retinaScale(chart, forceRatio, forceStyle) {\n const pixelRatio = forceRatio || 1;\n const deviceHeight = Math.floor(chart.height * pixelRatio);\n const deviceWidth = Math.floor(chart.width * pixelRatio);\n chart.height = Math.floor(chart.height);\n chart.width = Math.floor(chart.width);\n const canvas = chart.canvas;\n // If no style has been set on the canvas, the render size is used as display size,\n // making the chart visually bigger, so let's enforce it to the \"correct\" values.\n // See https://github.com/chartjs/Chart.js/issues/3575\n if (canvas.style && (forceStyle || !canvas.style.height && !canvas.style.width)) {\n canvas.style.height = `${chart.height}px`;\n canvas.style.width = `${chart.width}px`;\n }\n if (chart.currentDevicePixelRatio !== pixelRatio || canvas.height !== deviceHeight || canvas.width !== deviceWidth) {\n chart.currentDevicePixelRatio = pixelRatio;\n canvas.height = deviceHeight;\n canvas.width = deviceWidth;\n chart.ctx.setTransform(pixelRatio, 0, 0, pixelRatio, 0, 0);\n return true;\n }\n return false;\n}\n/**\n * Detects support for options object argument in addEventListener.\n * https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener#Safely_detecting_option_support\n * @private\n */ const supportsEventListenerOptions = function() {\n let passiveSupported = false;\n try {\n const options = {\n get passive () {\n passiveSupported = true;\n return false;\n }\n };\n window.addEventListener('test', null, options);\n window.removeEventListener('test', null, options);\n } catch (e) {\n // continue regardless of error\n }\n return passiveSupported;\n}();\n/**\n * The \"used\" size is the final value of a dimension property after all calculations have\n * been performed. This method uses the computed style of `element` but returns undefined\n * if the computed style is not expressed in pixels. That can happen in some cases where\n * `element` has a size relative to its parent and this last one is not yet displayed,\n * for example because of `display: none` on a parent node.\n * @see https://developer.mozilla.org/en-US/docs/Web/CSS/used_value\n * @returns Size in pixels or undefined if unknown.\n */ function readUsedSize(element, property) {\n const value = getStyle(element, property);\n const matches = value && value.match(/^(\\d+)(\\.\\d+)?px$/);\n return matches ? +matches[1] : undefined;\n}\n\n/**\n * @private\n */ function _pointInLine(p1, p2, t, mode) {\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: p1.y + t * (p2.y - p1.y)\n };\n}\n/**\n * @private\n */ function _steppedInterpolation(p1, p2, t, mode) {\n return {\n x: p1.x + t * (p2.x - p1.x),\n y: mode === 'middle' ? t < 0.5 ? p1.y : p2.y : mode === 'after' ? t < 1 ? p1.y : p2.y : t > 0 ? p2.y : p1.y\n };\n}\n/**\n * @private\n */ function _bezierInterpolation(p1, p2, t, mode) {\n const cp1 = {\n x: p1.cp2x,\n y: p1.cp2y\n };\n const cp2 = {\n x: p2.cp1x,\n y: p2.cp1y\n };\n const a = _pointInLine(p1, cp1, t);\n const b = _pointInLine(cp1, cp2, t);\n const c = _pointInLine(cp2, p2, t);\n const d = _pointInLine(a, b, t);\n const e = _pointInLine(b, c, t);\n return _pointInLine(d, e, t);\n}\n\nconst getRightToLeftAdapter = function(rectX, width) {\n return {\n x (x) {\n return rectX + rectX + width - x;\n },\n setWidth (w) {\n width = w;\n },\n textAlign (align) {\n if (align === 'center') {\n return align;\n }\n return align === 'right' ? 'left' : 'right';\n },\n xPlus (x, value) {\n return x - value;\n },\n leftForLtr (x, itemWidth) {\n return x - itemWidth;\n }\n };\n};\nconst getLeftToRightAdapter = function() {\n return {\n x (x) {\n return x;\n },\n setWidth (w) {},\n textAlign (align) {\n return align;\n },\n xPlus (x, value) {\n return x + value;\n },\n leftForLtr (x, _itemWidth) {\n return x;\n }\n };\n};\nfunction getRtlAdapter(rtl, rectX, width) {\n return rtl ? getRightToLeftAdapter(rectX, width) : getLeftToRightAdapter();\n}\nfunction overrideTextDirection(ctx, direction) {\n let style, original;\n if (direction === 'ltr' || direction === 'rtl') {\n style = ctx.canvas.style;\n original = [\n style.getPropertyValue('direction'),\n style.getPropertyPriority('direction')\n ];\n style.setProperty('direction', direction, 'important');\n ctx.prevTextDirection = original;\n }\n}\nfunction restoreTextDirection(ctx, original) {\n if (original !== undefined) {\n delete ctx.prevTextDirection;\n ctx.canvas.style.setProperty('direction', original[0], original[1]);\n }\n}\n\nfunction propertyFn(property) {\n if (property === 'angle') {\n return {\n between: _angleBetween,\n compare: _angleDiff,\n normalize: _normalizeAngle\n };\n }\n return {\n between: _isBetween,\n compare: (a, b)=>a - b,\n normalize: (x)=>x\n };\n}\nfunction normalizeSegment({ start , end , count , loop , style }) {\n return {\n start: start % count,\n end: end % count,\n loop: loop && (end - start + 1) % count === 0,\n style\n };\n}\nfunction getSegment(segment, points, bounds) {\n const { property , start: startBound , end: endBound } = bounds;\n const { between , normalize } = propertyFn(property);\n const count = points.length;\n let { start , end , loop } = segment;\n let i, ilen;\n if (loop) {\n start += count;\n end += count;\n for(i = 0, ilen = count; i < ilen; ++i){\n if (!between(normalize(points[start % count][property]), startBound, endBound)) {\n break;\n }\n start--;\n end--;\n }\n start %= count;\n end %= count;\n }\n if (end < start) {\n end += count;\n }\n return {\n start,\n end,\n loop,\n style: segment.style\n };\n}\n function _boundSegment(segment, points, bounds) {\n if (!bounds) {\n return [\n segment\n ];\n }\n const { property , start: startBound , end: endBound } = bounds;\n const count = points.length;\n const { compare , between , normalize } = propertyFn(property);\n const { start , end , loop , style } = getSegment(segment, points, bounds);\n const result = [];\n let inside = false;\n let subStart = null;\n let value, point, prevValue;\n const startIsBefore = ()=>between(startBound, prevValue, value) && compare(startBound, prevValue) !== 0;\n const endIsBefore = ()=>compare(endBound, value) === 0 || between(endBound, prevValue, value);\n const shouldStart = ()=>inside || startIsBefore();\n const shouldStop = ()=>!inside || endIsBefore();\n for(let i = start, prev = start; i <= end; ++i){\n point = points[i % count];\n if (point.skip) {\n continue;\n }\n value = normalize(point[property]);\n if (value === prevValue) {\n continue;\n }\n inside = between(value, startBound, endBound);\n if (subStart === null && shouldStart()) {\n subStart = compare(value, startBound) === 0 ? i : prev;\n }\n if (subStart !== null && shouldStop()) {\n result.push(normalizeSegment({\n start: subStart,\n end: i,\n loop,\n count,\n style\n }));\n subStart = null;\n }\n prev = i;\n prevValue = value;\n }\n if (subStart !== null) {\n result.push(normalizeSegment({\n start: subStart,\n end,\n loop,\n count,\n style\n }));\n }\n return result;\n}\n function _boundSegments(line, bounds) {\n const result = [];\n const segments = line.segments;\n for(let i = 0; i < segments.length; i++){\n const sub = _boundSegment(segments[i], line.points, bounds);\n if (sub.length) {\n result.push(...sub);\n }\n }\n return result;\n}\n function findStartAndEnd(points, count, loop, spanGaps) {\n let start = 0;\n let end = count - 1;\n if (loop && !spanGaps) {\n while(start < count && !points[start].skip){\n start++;\n }\n }\n while(start < count && points[start].skip){\n start++;\n }\n start %= count;\n if (loop) {\n end += start;\n }\n while(end > start && points[end % count].skip){\n end--;\n }\n end %= count;\n return {\n start,\n end\n };\n}\n function solidSegments(points, start, max, loop) {\n const count = points.length;\n const result = [];\n let last = start;\n let prev = points[start];\n let end;\n for(end = start + 1; end <= max; ++end){\n const cur = points[end % count];\n if (cur.skip || cur.stop) {\n if (!prev.skip) {\n loop = false;\n result.push({\n start: start % count,\n end: (end - 1) % count,\n loop\n });\n start = last = cur.stop ? end : null;\n }\n } else {\n last = end;\n if (prev.skip) {\n start = end;\n }\n }\n prev = cur;\n }\n if (last !== null) {\n result.push({\n start: start % count,\n end: last % count,\n loop\n });\n }\n return result;\n}\n function _computeSegments(line, segmentOptions) {\n const points = line.points;\n const spanGaps = line.options.spanGaps;\n const count = points.length;\n if (!count) {\n return [];\n }\n const loop = !!line._loop;\n const { start , end } = findStartAndEnd(points, count, loop, spanGaps);\n if (spanGaps === true) {\n return splitByStyles(line, [\n {\n start,\n end,\n loop\n }\n ], points, segmentOptions);\n }\n const max = end < start ? end + count : end;\n const completeLoop = !!line._fullLoop && start === 0 && end === count - 1;\n return splitByStyles(line, solidSegments(points, start, max, completeLoop), points, segmentOptions);\n}\n function splitByStyles(line, segments, points, segmentOptions) {\n if (!segmentOptions || !segmentOptions.setContext || !points) {\n return segments;\n }\n return doSplitByStyles(line, segments, points, segmentOptions);\n}\n function doSplitByStyles(line, segments, points, segmentOptions) {\n const chartContext = line._chart.getContext();\n const baseStyle = readStyle(line.options);\n const { _datasetIndex: datasetIndex , options: { spanGaps } } = line;\n const count = points.length;\n const result = [];\n let prevStyle = baseStyle;\n let start = segments[0].start;\n let i = start;\n function addStyle(s, e, l, st) {\n const dir = spanGaps ? -1 : 1;\n if (s === e) {\n return;\n }\n s += count;\n while(points[s % count].skip){\n s -= dir;\n }\n while(points[e % count].skip){\n e += dir;\n }\n if (s % count !== e % count) {\n result.push({\n start: s % count,\n end: e % count,\n loop: l,\n style: st\n });\n prevStyle = st;\n start = e % count;\n }\n }\n for (const segment of segments){\n start = spanGaps ? start : segment.start;\n let prev = points[start % count];\n let style;\n for(i = start + 1; i <= segment.end; i++){\n const pt = points[i % count];\n style = readStyle(segmentOptions.setContext(createContext(chartContext, {\n type: 'segment',\n p0: prev,\n p1: pt,\n p0DataIndex: (i - 1) % count,\n p1DataIndex: i % count,\n datasetIndex\n })));\n if (styleChanged(style, prevStyle)) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n prev = pt;\n prevStyle = style;\n }\n if (start < i - 1) {\n addStyle(start, i - 1, segment.loop, prevStyle);\n }\n }\n return result;\n}\nfunction readStyle(options) {\n return {\n backgroundColor: options.backgroundColor,\n borderCapStyle: options.borderCapStyle,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderJoinStyle: options.borderJoinStyle,\n borderWidth: options.borderWidth,\n borderColor: options.borderColor\n };\n}\nfunction styleChanged(style, prevStyle) {\n return prevStyle && JSON.stringify(style) !== JSON.stringify(prevStyle);\n}\n\nexport { unclipArea as $, _rlookupByKey as A, _lookupByKey as B, _isPointInArea as C, getAngleFromPoint as D, toPadding as E, each as F, getMaximumSize as G, HALF_PI as H, _getParentNode as I, readUsedSize as J, supportsEventListenerOptions as K, throttled as L, _isDomSupported as M, _factorize as N, finiteOrDefault as O, PI as P, callback as Q, _addGrace as R, _limitValue as S, TAU as T, toDegrees as U, _measureText as V, _int16Range as W, _alignPixel as X, clipArea as Y, renderText as Z, _arrayUnique as _, resolve as a, fontString as a$, toFont as a0, _toLeftRightCenter as a1, _alignStartEnd as a2, overrides as a3, merge as a4, _capitalize as a5, descriptors as a6, isFunction as a7, _attachContext as a8, _createResolver as a9, overrideTextDirection as aA, _textX as aB, restoreTextDirection as aC, drawPointLegend as aD, distanceBetweenPoints as aE, noop as aF, _setMinAndMaxByKey as aG, niceNum as aH, almostWhole as aI, almostEquals as aJ, _decimalPlaces as aK, Ticks as aL, log10 as aM, _longestText as aN, _filterBetween as aO, _lookup as aP, isPatternOrGradient as aQ, getHoverColor as aR, clone as aS, _merger as aT, _mergerIf as aU, _deprecated as aV, _splitKey as aW, toFontString as aX, splineCurve as aY, splineCurveMonotone as aZ, getStyle as a_, _descriptors as aa, mergeIf as ab, uid as ac, debounce as ad, retinaScale as ae, clearCanvas as af, setsEqual as ag, _elementsEqual as ah, _isClickEvent as ai, _isBetween as aj, _readValueToProps as ak, _updateBezierControlPoints as al, _computeSegments as am, _boundSegments as an, _steppedInterpolation as ao, _bezierInterpolation as ap, _pointInLine as aq, _steppedLineTo as ar, _bezierCurveTo as as, drawPoint as at, addRoundedRectPath as au, toTRBL as av, toTRBLCorners as aw, _boundSegment as ax, _normalizeAngle as ay, getRtlAdapter as az, isArray as b, toLineHeight as b0, PITAU as b1, INFINITY as b2, RAD_PER_DEG as b3, QUARTER_PI as b4, TWO_THIRDS_PI as b5, _angleDiff as b6, color as c, defaults as d, effects as e, resolveObjectKey as f, isNumberFinite as g, defined as h, isObject as i, createContext as j, isNullOrUndef as k, listenArrayEvents as l, toPercentage as m, toDimension as n, formatNumber as o, _angleBetween as p, _getStartAndCountOfVisiblePoints as q, requestAnimFrame as r, sign as s, toRadians as t, unlistenArrayEvents as u, valueOrDefault as v, _scaleRangesChanged as w, isNumber as x, _parseObjectDataRadialScale as y, getRelativePosition as z };\n//# sourceMappingURL=helpers.segment.js.map\n","/*!\n * Chart.js v4.2.1\n * https://www.chartjs.org\n * (c) 2023 Chart.js Contributors\n * Released under the MIT License\n */\nimport { r as requestAnimFrame, a as resolve, e as effects, c as color, i as isObject, d as defaults, b as isArray, v as valueOrDefault, u as unlistenArrayEvents, l as listenArrayEvents, f as resolveObjectKey, g as isNumberFinite, h as defined, s as sign, j as createContext, k as isNullOrUndef, _ as _arrayUnique, t as toRadians, m as toPercentage, n as toDimension, T as TAU, o as formatNumber, p as _angleBetween, H as HALF_PI, P as PI, q as _getStartAndCountOfVisiblePoints, w as _scaleRangesChanged, x as isNumber, y as _parseObjectDataRadialScale, z as getRelativePosition, A as _rlookupByKey, B as _lookupByKey, C as _isPointInArea, D as getAngleFromPoint, E as toPadding, F as each, G as getMaximumSize, I as _getParentNode, J as readUsedSize, K as supportsEventListenerOptions, L as throttled, M as _isDomSupported, N as _factorize, O as finiteOrDefault, Q as callback, R as _addGrace, S as _limitValue, U as toDegrees, V as _measureText, W as _int16Range, X as _alignPixel, Y as clipArea, Z as renderText, $ as unclipArea, a0 as toFont, a1 as _toLeftRightCenter, a2 as _alignStartEnd, a3 as overrides, a4 as merge, a5 as _capitalize, a6 as descriptors, a7 as isFunction, a8 as _attachContext, a9 as _createResolver, aa as _descriptors, ab as mergeIf, ac as uid, ad as debounce, ae as retinaScale, af as clearCanvas, ag as setsEqual, ah as _elementsEqual, ai as _isClickEvent, aj as _isBetween, ak as _readValueToProps, al as _updateBezierControlPoints, am as _computeSegments, an as _boundSegments, ao as _steppedInterpolation, ap as _bezierInterpolation, aq as _pointInLine, ar as _steppedLineTo, as as _bezierCurveTo, at as drawPoint, au as addRoundedRectPath, av as toTRBL, aw as toTRBLCorners, ax as _boundSegment, ay as _normalizeAngle, az as getRtlAdapter, aA as overrideTextDirection, aB as _textX, aC as restoreTextDirection, aD as drawPointLegend, aE as distanceBetweenPoints, aF as noop, aG as _setMinAndMaxByKey, aH as niceNum, aI as almostWhole, aJ as almostEquals, aK as _decimalPlaces, aL as Ticks, aM as log10, aN as _longestText, aO as _filterBetween, aP as _lookup } from './chunks/helpers.segment.js';\nexport { aL as Ticks, d as defaults } from './chunks/helpers.segment.js';\nimport '@kurkle/color';\n\nclass Animator {\n constructor(){\n this._request = null;\n this._charts = new Map();\n this._running = false;\n this._lastDate = undefined;\n }\n _notify(chart, anims, date, type) {\n const callbacks = anims.listeners[type];\n const numSteps = anims.duration;\n callbacks.forEach((fn)=>fn({\n chart,\n initial: anims.initial,\n numSteps,\n currentStep: Math.min(date - anims.start, numSteps)\n }));\n }\n _refresh() {\n if (this._request) {\n return;\n }\n this._running = true;\n this._request = requestAnimFrame.call(window, ()=>{\n this._update();\n this._request = null;\n if (this._running) {\n this._refresh();\n }\n });\n }\n _update(date = Date.now()) {\n let remaining = 0;\n this._charts.forEach((anims, chart)=>{\n if (!anims.running || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n let draw = false;\n let item;\n for(; i >= 0; --i){\n item = items[i];\n if (item._active) {\n if (item._total > anims.duration) {\n anims.duration = item._total;\n }\n item.tick(date);\n draw = true;\n } else {\n items[i] = items[items.length - 1];\n items.pop();\n }\n }\n if (draw) {\n chart.draw();\n this._notify(chart, anims, date, 'progress');\n }\n if (!items.length) {\n anims.running = false;\n this._notify(chart, anims, date, 'complete');\n anims.initial = false;\n }\n remaining += items.length;\n });\n this._lastDate = date;\n if (remaining === 0) {\n this._running = false;\n }\n }\n _getAnims(chart) {\n const charts = this._charts;\n let anims = charts.get(chart);\n if (!anims) {\n anims = {\n running: false,\n initial: true,\n items: [],\n listeners: {\n complete: [],\n progress: []\n }\n };\n charts.set(chart, anims);\n }\n return anims;\n }\n listen(chart, event, cb) {\n this._getAnims(chart).listeners[event].push(cb);\n }\n add(chart, items) {\n if (!items || !items.length) {\n return;\n }\n this._getAnims(chart).items.push(...items);\n }\n has(chart) {\n return this._getAnims(chart).items.length > 0;\n }\n start(chart) {\n const anims = this._charts.get(chart);\n if (!anims) {\n return;\n }\n anims.running = true;\n anims.start = Date.now();\n anims.duration = anims.items.reduce((acc, cur)=>Math.max(acc, cur._duration), 0);\n this._refresh();\n }\n running(chart) {\n if (!this._running) {\n return false;\n }\n const anims = this._charts.get(chart);\n if (!anims || !anims.running || !anims.items.length) {\n return false;\n }\n return true;\n }\n stop(chart) {\n const anims = this._charts.get(chart);\n if (!anims || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n for(; i >= 0; --i){\n items[i].cancel();\n }\n anims.items = [];\n this._notify(chart, anims, Date.now(), 'complete');\n }\n remove(chart) {\n return this._charts.delete(chart);\n }\n}\nvar animator = /* #__PURE__ */ new Animator();\n\nconst transparent = 'transparent';\nconst interpolators = {\n boolean (from, to, factor) {\n return factor > 0.5 ? to : from;\n },\n color (from, to, factor) {\n const c0 = color(from || transparent);\n const c1 = c0.valid && color(to || transparent);\n return c1 && c1.valid ? c1.mix(c0, factor).hexString() : to;\n },\n number (from, to, factor) {\n return from + (to - from) * factor;\n }\n};\nclass Animation {\n constructor(cfg, target, prop, to){\n const currentValue = target[prop];\n to = resolve([\n cfg.to,\n to,\n currentValue,\n cfg.from\n ]);\n const from = resolve([\n cfg.from,\n currentValue,\n to\n ]);\n this._active = true;\n this._fn = cfg.fn || interpolators[cfg.type || typeof from];\n this._easing = effects[cfg.easing] || effects.linear;\n this._start = Math.floor(Date.now() + (cfg.delay || 0));\n this._duration = this._total = Math.floor(cfg.duration);\n this._loop = !!cfg.loop;\n this._target = target;\n this._prop = prop;\n this._from = from;\n this._to = to;\n this._promises = undefined;\n }\n active() {\n return this._active;\n }\n update(cfg, to, date) {\n if (this._active) {\n this._notify(false);\n const currentValue = this._target[this._prop];\n const elapsed = date - this._start;\n const remain = this._duration - elapsed;\n this._start = date;\n this._duration = Math.floor(Math.max(remain, cfg.duration));\n this._total += elapsed;\n this._loop = !!cfg.loop;\n this._to = resolve([\n cfg.to,\n to,\n currentValue,\n cfg.from\n ]);\n this._from = resolve([\n cfg.from,\n currentValue,\n to\n ]);\n }\n }\n cancel() {\n if (this._active) {\n this.tick(Date.now());\n this._active = false;\n this._notify(false);\n }\n }\n tick(date) {\n const elapsed = date - this._start;\n const duration = this._duration;\n const prop = this._prop;\n const from = this._from;\n const loop = this._loop;\n const to = this._to;\n let factor;\n this._active = from !== to && (loop || elapsed < duration);\n if (!this._active) {\n this._target[prop] = to;\n this._notify(true);\n return;\n }\n if (elapsed < 0) {\n this._target[prop] = from;\n return;\n }\n factor = elapsed / duration % 2;\n factor = loop && factor > 1 ? 2 - factor : factor;\n factor = this._easing(Math.min(1, Math.max(0, factor)));\n this._target[prop] = this._fn(from, to, factor);\n }\n wait() {\n const promises = this._promises || (this._promises = []);\n return new Promise((res, rej)=>{\n promises.push({\n res,\n rej\n });\n });\n }\n _notify(resolved) {\n const method = resolved ? 'res' : 'rej';\n const promises = this._promises || [];\n for(let i = 0; i < promises.length; i++){\n promises[i][method]();\n }\n }\n}\n\nclass Animations {\n constructor(chart, config){\n this._chart = chart;\n this._properties = new Map();\n this.configure(config);\n }\n configure(config) {\n if (!isObject(config)) {\n return;\n }\n const animationOptions = Object.keys(defaults.animation);\n const animatedProps = this._properties;\n Object.getOwnPropertyNames(config).forEach((key)=>{\n const cfg = config[key];\n if (!isObject(cfg)) {\n return;\n }\n const resolved = {};\n for (const option of animationOptions){\n resolved[option] = cfg[option];\n }\n (isArray(cfg.properties) && cfg.properties || [\n key\n ]).forEach((prop)=>{\n if (prop === key || !animatedProps.has(prop)) {\n animatedProps.set(prop, resolved);\n }\n });\n });\n }\n _animateOptions(target, values) {\n const newOptions = values.options;\n const options = resolveTargetOptions(target, newOptions);\n if (!options) {\n return [];\n }\n const animations = this._createAnimations(options, newOptions);\n if (newOptions.$shared) {\n awaitAll(target.options.$animations, newOptions).then(()=>{\n target.options = newOptions;\n }, ()=>{\n });\n }\n return animations;\n }\n _createAnimations(target, values) {\n const animatedProps = this._properties;\n const animations = [];\n const running = target.$animations || (target.$animations = {});\n const props = Object.keys(values);\n const date = Date.now();\n let i;\n for(i = props.length - 1; i >= 0; --i){\n const prop = props[i];\n if (prop.charAt(0) === '$') {\n continue;\n }\n if (prop === 'options') {\n animations.push(...this._animateOptions(target, values));\n continue;\n }\n const value = values[prop];\n let animation = running[prop];\n const cfg = animatedProps.get(prop);\n if (animation) {\n if (cfg && animation.active()) {\n animation.update(cfg, value, date);\n continue;\n } else {\n animation.cancel();\n }\n }\n if (!cfg || !cfg.duration) {\n target[prop] = value;\n continue;\n }\n running[prop] = animation = new Animation(cfg, target, prop, value);\n animations.push(animation);\n }\n return animations;\n }\n update(target, values) {\n if (this._properties.size === 0) {\n Object.assign(target, values);\n return;\n }\n const animations = this._createAnimations(target, values);\n if (animations.length) {\n animator.add(this._chart, animations);\n return true;\n }\n }\n}\nfunction awaitAll(animations, properties) {\n const running = [];\n const keys = Object.keys(properties);\n for(let i = 0; i < keys.length; i++){\n const anim = animations[keys[i]];\n if (anim && anim.active()) {\n running.push(anim.wait());\n }\n }\n return Promise.all(running);\n}\nfunction resolveTargetOptions(target, newOptions) {\n if (!newOptions) {\n return;\n }\n let options = target.options;\n if (!options) {\n target.options = newOptions;\n return;\n }\n if (options.$shared) {\n target.options = options = Object.assign({}, options, {\n $shared: false,\n $animations: {}\n });\n }\n return options;\n}\n\nfunction scaleClip(scale, allowedOverflow) {\n const opts = scale && scale.options || {};\n const reverse = opts.reverse;\n const min = opts.min === undefined ? allowedOverflow : 0;\n const max = opts.max === undefined ? allowedOverflow : 0;\n return {\n start: reverse ? max : min,\n end: reverse ? min : max\n };\n}\nfunction defaultClip(xScale, yScale, allowedOverflow) {\n if (allowedOverflow === false) {\n return false;\n }\n const x = scaleClip(xScale, allowedOverflow);\n const y = scaleClip(yScale, allowedOverflow);\n return {\n top: y.end,\n right: x.end,\n bottom: y.start,\n left: x.start\n };\n}\nfunction toClip(value) {\n let t, r, b, l;\n if (isObject(value)) {\n t = value.top;\n r = value.right;\n b = value.bottom;\n l = value.left;\n } else {\n t = r = b = l = value;\n }\n return {\n top: t,\n right: r,\n bottom: b,\n left: l,\n disabled: value === false\n };\n}\nfunction getSortedDatasetIndices(chart, filterVisible) {\n const keys = [];\n const metasets = chart._getSortedDatasetMetas(filterVisible);\n let i, ilen;\n for(i = 0, ilen = metasets.length; i < ilen; ++i){\n keys.push(metasets[i].index);\n }\n return keys;\n}\nfunction applyStack(stack, value, dsIndex, options = {}) {\n const keys = stack.keys;\n const singleMode = options.mode === 'single';\n let i, ilen, datasetIndex, otherValue;\n if (value === null) {\n return;\n }\n for(i = 0, ilen = keys.length; i < ilen; ++i){\n datasetIndex = +keys[i];\n if (datasetIndex === dsIndex) {\n if (options.all) {\n continue;\n }\n break;\n }\n otherValue = stack.values[datasetIndex];\n if (isNumberFinite(otherValue) && (singleMode || value === 0 || sign(value) === sign(otherValue))) {\n value += otherValue;\n }\n }\n return value;\n}\nfunction convertObjectDataToArray(data) {\n const keys = Object.keys(data);\n const adata = new Array(keys.length);\n let i, ilen, key;\n for(i = 0, ilen = keys.length; i < ilen; ++i){\n key = keys[i];\n adata[i] = {\n x: key,\n y: data[key]\n };\n }\n return adata;\n}\nfunction isStacked(scale, meta) {\n const stacked = scale && scale.options.stacked;\n return stacked || stacked === undefined && meta.stack !== undefined;\n}\nfunction getStackKey(indexScale, valueScale, meta) {\n return `${indexScale.id}.${valueScale.id}.${meta.stack || meta.type}`;\n}\nfunction getUserBounds(scale) {\n const { min , max , minDefined , maxDefined } = scale.getUserBounds();\n return {\n min: minDefined ? min : Number.NEGATIVE_INFINITY,\n max: maxDefined ? max : Number.POSITIVE_INFINITY\n };\n}\nfunction getOrCreateStack(stacks, stackKey, indexValue) {\n const subStack = stacks[stackKey] || (stacks[stackKey] = {});\n return subStack[indexValue] || (subStack[indexValue] = {});\n}\nfunction getLastIndexInStack(stack, vScale, positive, type) {\n for (const meta of vScale.getMatchingVisibleMetas(type).reverse()){\n const value = stack[meta.index];\n if (positive && value > 0 || !positive && value < 0) {\n return meta.index;\n }\n }\n return null;\n}\nfunction updateStacks(controller, parsed) {\n const { chart , _cachedMeta: meta } = controller;\n const stacks = chart._stacks || (chart._stacks = {});\n const { iScale , vScale , index: datasetIndex } = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const key = getStackKey(iScale, vScale, meta);\n const ilen = parsed.length;\n let stack;\n for(let i = 0; i < ilen; ++i){\n const item = parsed[i];\n const { [iAxis]: index , [vAxis]: value } = item;\n const itemStacks = item._stacks || (item._stacks = {});\n stack = itemStacks[vAxis] = getOrCreateStack(stacks, key, index);\n stack[datasetIndex] = value;\n stack._top = getLastIndexInStack(stack, vScale, true, meta.type);\n stack._bottom = getLastIndexInStack(stack, vScale, false, meta.type);\n const visualValues = stack._visualValues || (stack._visualValues = {});\n visualValues[datasetIndex] = value;\n }\n}\nfunction getFirstScaleId(chart, axis) {\n const scales = chart.scales;\n return Object.keys(scales).filter((key)=>scales[key].axis === axis).shift();\n}\nfunction createDatasetContext(parent, index) {\n return createContext(parent, {\n active: false,\n dataset: undefined,\n datasetIndex: index,\n index,\n mode: 'default',\n type: 'dataset'\n });\n}\nfunction createDataContext(parent, index, element) {\n return createContext(parent, {\n active: false,\n dataIndex: index,\n parsed: undefined,\n raw: undefined,\n element,\n index,\n mode: 'default',\n type: 'data'\n });\n}\nfunction clearStacks(meta, items) {\n const datasetIndex = meta.controller.index;\n const axis = meta.vScale && meta.vScale.axis;\n if (!axis) {\n return;\n }\n items = items || meta._parsed;\n for (const parsed of items){\n const stacks = parsed._stacks;\n if (!stacks || stacks[axis] === undefined || stacks[axis][datasetIndex] === undefined) {\n return;\n }\n delete stacks[axis][datasetIndex];\n if (stacks[axis]._visualValues !== undefined && stacks[axis]._visualValues[datasetIndex] !== undefined) {\n delete stacks[axis]._visualValues[datasetIndex];\n }\n }\n}\nconst isDirectUpdateMode = (mode)=>mode === 'reset' || mode === 'none';\nconst cloneIfNotShared = (cached, shared)=>shared ? cached : Object.assign({}, cached);\nconst createStack = (canStack, meta, chart)=>canStack && !meta.hidden && meta._stacked && {\n keys: getSortedDatasetIndices(chart, true),\n values: null\n };\nclass DatasetController {\n static defaults = {};\n static datasetElementType = null;\n static dataElementType = null;\n constructor(chart, datasetIndex){\n this.chart = chart;\n this._ctx = chart.ctx;\n this.index = datasetIndex;\n this._cachedDataOpts = {};\n this._cachedMeta = this.getMeta();\n this._type = this._cachedMeta.type;\n this.options = undefined;\n this._parsing = false;\n this._data = undefined;\n this._objectData = undefined;\n this._sharedOptions = undefined;\n this._drawStart = undefined;\n this._drawCount = undefined;\n this.enableOptionSharing = false;\n this.supportsDecimation = false;\n this.$context = undefined;\n this._syncList = [];\n this.datasetElementType = new.target.datasetElementType;\n this.dataElementType = new.target.dataElementType;\n this.initialize();\n }\n initialize() {\n const meta = this._cachedMeta;\n this.configure();\n this.linkScales();\n meta._stacked = isStacked(meta.vScale, meta);\n this.addElements();\n if (this.options.fill && !this.chart.isPluginEnabled('filler')) {\n console.warn(\"Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options\");\n }\n }\n updateIndex(datasetIndex) {\n if (this.index !== datasetIndex) {\n clearStacks(this._cachedMeta);\n }\n this.index = datasetIndex;\n }\n linkScales() {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n const chooseId = (axis, x, y, r)=>axis === 'x' ? x : axis === 'r' ? r : y;\n const xid = meta.xAxisID = valueOrDefault(dataset.xAxisID, getFirstScaleId(chart, 'x'));\n const yid = meta.yAxisID = valueOrDefault(dataset.yAxisID, getFirstScaleId(chart, 'y'));\n const rid = meta.rAxisID = valueOrDefault(dataset.rAxisID, getFirstScaleId(chart, 'r'));\n const indexAxis = meta.indexAxis;\n const iid = meta.iAxisID = chooseId(indexAxis, xid, yid, rid);\n const vid = meta.vAxisID = chooseId(indexAxis, yid, xid, rid);\n meta.xScale = this.getScaleForId(xid);\n meta.yScale = this.getScaleForId(yid);\n meta.rScale = this.getScaleForId(rid);\n meta.iScale = this.getScaleForId(iid);\n meta.vScale = this.getScaleForId(vid);\n }\n getDataset() {\n return this.chart.data.datasets[this.index];\n }\n getMeta() {\n return this.chart.getDatasetMeta(this.index);\n }\n getScaleForId(scaleID) {\n return this.chart.scales[scaleID];\n }\n _getOtherScale(scale) {\n const meta = this._cachedMeta;\n return scale === meta.iScale ? meta.vScale : meta.iScale;\n }\n reset() {\n this._update('reset');\n }\n _destroy() {\n const meta = this._cachedMeta;\n if (this._data) {\n unlistenArrayEvents(this._data, this);\n }\n if (meta._stacked) {\n clearStacks(meta);\n }\n }\n _dataCheck() {\n const dataset = this.getDataset();\n const data = dataset.data || (dataset.data = []);\n const _data = this._data;\n if (isObject(data)) {\n this._data = convertObjectDataToArray(data);\n } else if (_data !== data) {\n if (_data) {\n unlistenArrayEvents(_data, this);\n const meta = this._cachedMeta;\n clearStacks(meta);\n meta._parsed = [];\n }\n if (data && Object.isExtensible(data)) {\n listenArrayEvents(data, this);\n }\n this._syncList = [];\n this._data = data;\n }\n }\n addElements() {\n const meta = this._cachedMeta;\n this._dataCheck();\n if (this.datasetElementType) {\n meta.dataset = new this.datasetElementType();\n }\n }\n buildOrUpdateElements(resetNewElements) {\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n let stackChanged = false;\n this._dataCheck();\n const oldStacked = meta._stacked;\n meta._stacked = isStacked(meta.vScale, meta);\n if (meta.stack !== dataset.stack) {\n stackChanged = true;\n clearStacks(meta);\n meta.stack = dataset.stack;\n }\n this._resyncElements(resetNewElements);\n if (stackChanged || oldStacked !== meta._stacked) {\n updateStacks(this, meta._parsed);\n }\n }\n configure() {\n const config = this.chart.config;\n const scopeKeys = config.datasetScopeKeys(this._type);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys, true);\n this.options = config.createResolver(scopes, this.getContext());\n this._parsing = this.options.parsing;\n this._cachedDataOpts = {};\n }\n parse(start, count) {\n const { _cachedMeta: meta , _data: data } = this;\n const { iScale , _stacked } = meta;\n const iAxis = iScale.axis;\n let sorted = start === 0 && count === data.length ? true : meta._sorted;\n let prev = start > 0 && meta._parsed[start - 1];\n let i, cur, parsed;\n if (this._parsing === false) {\n meta._parsed = data;\n meta._sorted = true;\n parsed = data;\n } else {\n if (isArray(data[start])) {\n parsed = this.parseArrayData(meta, data, start, count);\n } else if (isObject(data[start])) {\n parsed = this.parseObjectData(meta, data, start, count);\n } else {\n parsed = this.parsePrimitiveData(meta, data, start, count);\n }\n const isNotInOrderComparedToPrev = ()=>cur[iAxis] === null || prev && cur[iAxis] < prev[iAxis];\n for(i = 0; i < count; ++i){\n meta._parsed[i + start] = cur = parsed[i];\n if (sorted) {\n if (isNotInOrderComparedToPrev()) {\n sorted = false;\n }\n prev = cur;\n }\n }\n meta._sorted = sorted;\n }\n if (_stacked) {\n updateStacks(this, parsed);\n }\n }\n parsePrimitiveData(meta, data, start, count) {\n const { iScale , vScale } = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = new Array(count);\n let i, ilen, index;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n parsed[i] = {\n [iAxis]: singleScale || iScale.parse(labels[index], index),\n [vAxis]: vScale.parse(data[index], index)\n };\n }\n return parsed;\n }\n parseArrayData(meta, data, start, count) {\n const { xScale , yScale } = meta;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(item[0], index),\n y: yScale.parse(item[1], index)\n };\n }\n return parsed;\n }\n parseObjectData(meta, data, start, count) {\n const { xScale , yScale } = meta;\n const { xAxisKey ='x' , yAxisKey ='y' } = this._parsing;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(resolveObjectKey(item, xAxisKey), index),\n y: yScale.parse(resolveObjectKey(item, yAxisKey), index)\n };\n }\n return parsed;\n }\n getParsed(index) {\n return this._cachedMeta._parsed[index];\n }\n getDataElement(index) {\n return this._cachedMeta.data[index];\n }\n applyStack(scale, parsed, mode) {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const value = parsed[scale.axis];\n const stack = {\n keys: getSortedDatasetIndices(chart, true),\n values: parsed._stacks[scale.axis]._visualValues\n };\n return applyStack(stack, value, meta.index, {\n mode\n });\n }\n updateRangeFromParsed(range, scale, parsed, stack) {\n const parsedValue = parsed[scale.axis];\n let value = parsedValue === null ? NaN : parsedValue;\n const values = stack && parsed._stacks[scale.axis];\n if (stack && values) {\n stack.values = values;\n value = applyStack(stack, parsedValue, this._cachedMeta.index);\n }\n range.min = Math.min(range.min, value);\n range.max = Math.max(range.max, value);\n }\n getMinMax(scale, canStack) {\n const meta = this._cachedMeta;\n const _parsed = meta._parsed;\n const sorted = meta._sorted && scale === meta.iScale;\n const ilen = _parsed.length;\n const otherScale = this._getOtherScale(scale);\n const stack = createStack(canStack, meta, this.chart);\n const range = {\n min: Number.POSITIVE_INFINITY,\n max: Number.NEGATIVE_INFINITY\n };\n const { min: otherMin , max: otherMax } = getUserBounds(otherScale);\n let i, parsed;\n function _skip() {\n parsed = _parsed[i];\n const otherValue = parsed[otherScale.axis];\n return !isNumberFinite(parsed[scale.axis]) || otherMin > otherValue || otherMax < otherValue;\n }\n for(i = 0; i < ilen; ++i){\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n if (sorted) {\n break;\n }\n }\n if (sorted) {\n for(i = ilen - 1; i >= 0; --i){\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n break;\n }\n }\n return range;\n }\n getAllParsedValues(scale) {\n const parsed = this._cachedMeta._parsed;\n const values = [];\n let i, ilen, value;\n for(i = 0, ilen = parsed.length; i < ilen; ++i){\n value = parsed[i][scale.axis];\n if (isNumberFinite(value)) {\n values.push(value);\n }\n }\n return values;\n }\n getMaxOverflow() {\n return false;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const parsed = this.getParsed(index);\n return {\n label: iScale ? '' + iScale.getLabelForValue(parsed[iScale.axis]) : '',\n value: vScale ? '' + vScale.getLabelForValue(parsed[vScale.axis]) : ''\n };\n }\n _update(mode) {\n const meta = this._cachedMeta;\n this.update(mode || 'default');\n meta._clip = toClip(valueOrDefault(this.options.clip, defaultClip(meta.xScale, meta.yScale, this.getMaxOverflow())));\n }\n update(mode) {}\n draw() {\n const ctx = this._ctx;\n const chart = this.chart;\n const meta = this._cachedMeta;\n const elements = meta.data || [];\n const area = chart.chartArea;\n const active = [];\n const start = this._drawStart || 0;\n const count = this._drawCount || elements.length - start;\n const drawActiveElementsOnTop = this.options.drawActiveElementsOnTop;\n let i;\n if (meta.dataset) {\n meta.dataset.draw(ctx, area, start, count);\n }\n for(i = start; i < start + count; ++i){\n const element = elements[i];\n if (element.hidden) {\n continue;\n }\n if (element.active && drawActiveElementsOnTop) {\n active.push(element);\n } else {\n element.draw(ctx, area);\n }\n }\n for(i = 0; i < active.length; ++i){\n active[i].draw(ctx, area);\n }\n }\n getStyle(index, active) {\n const mode = active ? 'active' : 'default';\n return index === undefined && this._cachedMeta.dataset ? this.resolveDatasetElementOptions(mode) : this.resolveDataElementOptions(index || 0, mode);\n }\n getContext(index, active, mode) {\n const dataset = this.getDataset();\n let context;\n if (index >= 0 && index < this._cachedMeta.data.length) {\n const element = this._cachedMeta.data[index];\n context = element.$context || (element.$context = createDataContext(this.getContext(), index, element));\n context.parsed = this.getParsed(index);\n context.raw = dataset.data[index];\n context.index = context.dataIndex = index;\n } else {\n context = this.$context || (this.$context = createDatasetContext(this.chart.getContext(), this.index));\n context.dataset = dataset;\n context.index = context.datasetIndex = this.index;\n }\n context.active = !!active;\n context.mode = mode;\n return context;\n }\n resolveDatasetElementOptions(mode) {\n return this._resolveElementOptions(this.datasetElementType.id, mode);\n }\n resolveDataElementOptions(index, mode) {\n return this._resolveElementOptions(this.dataElementType.id, mode, index);\n }\n _resolveElementOptions(elementType, mode = 'default', index) {\n const active = mode === 'active';\n const cache = this._cachedDataOpts;\n const cacheKey = elementType + '-' + mode;\n const cached = cache[cacheKey];\n const sharing = this.enableOptionSharing && defined(index);\n if (cached) {\n return cloneIfNotShared(cached, sharing);\n }\n const config = this.chart.config;\n const scopeKeys = config.datasetElementScopeKeys(this._type, elementType);\n const prefixes = active ? [\n `${elementType}Hover`,\n 'hover',\n elementType,\n ''\n ] : [\n elementType,\n ''\n ];\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n const names = Object.keys(defaults.elements[elementType]);\n const context = ()=>this.getContext(index, active, mode);\n const values = config.resolveNamedOptions(scopes, names, context, prefixes);\n if (values.$shared) {\n values.$shared = sharing;\n cache[cacheKey] = Object.freeze(cloneIfNotShared(values, sharing));\n }\n return values;\n }\n _resolveAnimations(index, transition, active) {\n const chart = this.chart;\n const cache = this._cachedDataOpts;\n const cacheKey = `animation-${transition}`;\n const cached = cache[cacheKey];\n if (cached) {\n return cached;\n }\n let options;\n if (chart.options.animation !== false) {\n const config = this.chart.config;\n const scopeKeys = config.datasetAnimationScopeKeys(this._type, transition);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n options = config.createResolver(scopes, this.getContext(index, active, transition));\n }\n const animations = new Animations(chart, options && options.animations);\n if (options && options._cacheable) {\n cache[cacheKey] = Object.freeze(animations);\n }\n return animations;\n }\n getSharedOptions(options) {\n if (!options.$shared) {\n return;\n }\n return this._sharedOptions || (this._sharedOptions = Object.assign({}, options));\n }\n includeOptions(mode, sharedOptions) {\n return !sharedOptions || isDirectUpdateMode(mode) || this.chart._animationsDisabled;\n }\n _getSharedOptions(start, mode) {\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const previouslySharedOptions = this._sharedOptions;\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions) || sharedOptions !== previouslySharedOptions;\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n return {\n sharedOptions,\n includeOptions\n };\n }\n updateElement(element, index, properties, mode) {\n if (isDirectUpdateMode(mode)) {\n Object.assign(element, properties);\n } else {\n this._resolveAnimations(index, mode).update(element, properties);\n }\n }\n updateSharedOptions(sharedOptions, mode, newOptions) {\n if (sharedOptions && !isDirectUpdateMode(mode)) {\n this._resolveAnimations(undefined, mode).update(sharedOptions, newOptions);\n }\n }\n _setStyle(element, index, mode, active) {\n element.active = active;\n const options = this.getStyle(index, active);\n this._resolveAnimations(index, mode, active).update(element, {\n options: !active && this.getSharedOptions(options) || options\n });\n }\n removeHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', false);\n }\n setHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', true);\n }\n _removeDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n if (element) {\n this._setStyle(element, undefined, 'active', false);\n }\n }\n _setDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n if (element) {\n this._setStyle(element, undefined, 'active', true);\n }\n }\n _resyncElements(resetNewElements) {\n const data = this._data;\n const elements = this._cachedMeta.data;\n for (const [method, arg1, arg2] of this._syncList){\n this[method](arg1, arg2);\n }\n this._syncList = [];\n const numMeta = elements.length;\n const numData = data.length;\n const count = Math.min(numData, numMeta);\n if (count) {\n this.parse(0, count);\n }\n if (numData > numMeta) {\n this._insertElements(numMeta, numData - numMeta, resetNewElements);\n } else if (numData < numMeta) {\n this._removeElements(numData, numMeta - numData);\n }\n }\n _insertElements(start, count, resetNewElements = true) {\n const meta = this._cachedMeta;\n const data = meta.data;\n const end = start + count;\n let i;\n const move = (arr)=>{\n arr.length += count;\n for(i = arr.length - 1; i >= end; i--){\n arr[i] = arr[i - count];\n }\n };\n move(data);\n for(i = start; i < end; ++i){\n data[i] = new this.dataElementType();\n }\n if (this._parsing) {\n move(meta._parsed);\n }\n this.parse(start, count);\n if (resetNewElements) {\n this.updateElements(data, start, count, 'reset');\n }\n }\n updateElements(element, start, count, mode) {}\n _removeElements(start, count) {\n const meta = this._cachedMeta;\n if (this._parsing) {\n const removed = meta._parsed.splice(start, count);\n if (meta._stacked) {\n clearStacks(meta, removed);\n }\n }\n meta.data.splice(start, count);\n }\n _sync(args) {\n if (this._parsing) {\n this._syncList.push(args);\n } else {\n const [method, arg1, arg2] = args;\n this[method](arg1, arg2);\n }\n this.chart._dataChanges.push([\n this.index,\n ...args\n ]);\n }\n _onDataPush() {\n const count = arguments.length;\n this._sync([\n '_insertElements',\n this.getDataset().data.length - count,\n count\n ]);\n }\n _onDataPop() {\n this._sync([\n '_removeElements',\n this._cachedMeta.data.length - 1,\n 1\n ]);\n }\n _onDataShift() {\n this._sync([\n '_removeElements',\n 0,\n 1\n ]);\n }\n _onDataSplice(start, count) {\n if (count) {\n this._sync([\n '_removeElements',\n start,\n count\n ]);\n }\n const newCount = arguments.length - 2;\n if (newCount) {\n this._sync([\n '_insertElements',\n start,\n newCount\n ]);\n }\n }\n _onDataUnshift() {\n this._sync([\n '_insertElements',\n 0,\n arguments.length\n ]);\n }\n}\n\nfunction getAllScaleValues(scale, type) {\n if (!scale._cache.$bar) {\n const visibleMetas = scale.getMatchingVisibleMetas(type);\n let values = [];\n for(let i = 0, ilen = visibleMetas.length; i < ilen; i++){\n values = values.concat(visibleMetas[i].controller.getAllParsedValues(scale));\n }\n scale._cache.$bar = _arrayUnique(values.sort((a, b)=>a - b));\n }\n return scale._cache.$bar;\n}\n function computeMinSampleSize(meta) {\n const scale = meta.iScale;\n const values = getAllScaleValues(scale, meta.type);\n let min = scale._length;\n let i, ilen, curr, prev;\n const updateMinAndPrev = ()=>{\n if (curr === 32767 || curr === -32768) {\n return;\n }\n if (defined(prev)) {\n min = Math.min(min, Math.abs(curr - prev) || min);\n }\n prev = curr;\n };\n for(i = 0, ilen = values.length; i < ilen; ++i){\n curr = scale.getPixelForValue(values[i]);\n updateMinAndPrev();\n }\n prev = undefined;\n for(i = 0, ilen = scale.ticks.length; i < ilen; ++i){\n curr = scale.getPixelForTick(i);\n updateMinAndPrev();\n }\n return min;\n}\n function computeFitCategoryTraits(index, ruler, options, stackCount) {\n const thickness = options.barThickness;\n let size, ratio;\n if (isNullOrUndef(thickness)) {\n size = ruler.min * options.categoryPercentage;\n ratio = options.barPercentage;\n } else {\n size = thickness * stackCount;\n ratio = 1;\n }\n return {\n chunk: size / stackCount,\n ratio,\n start: ruler.pixels[index] - size / 2\n };\n}\n function computeFlexCategoryTraits(index, ruler, options, stackCount) {\n const pixels = ruler.pixels;\n const curr = pixels[index];\n let prev = index > 0 ? pixels[index - 1] : null;\n let next = index < pixels.length - 1 ? pixels[index + 1] : null;\n const percent = options.categoryPercentage;\n if (prev === null) {\n prev = curr - (next === null ? ruler.end - ruler.start : next - curr);\n }\n if (next === null) {\n next = curr + curr - prev;\n }\n const start = curr - (curr - Math.min(prev, next)) / 2 * percent;\n const size = Math.abs(next - prev) / 2 * percent;\n return {\n chunk: size / stackCount,\n ratio: options.barPercentage,\n start\n };\n}\nfunction parseFloatBar(entry, item, vScale, i) {\n const startValue = vScale.parse(entry[0], i);\n const endValue = vScale.parse(entry[1], i);\n const min = Math.min(startValue, endValue);\n const max = Math.max(startValue, endValue);\n let barStart = min;\n let barEnd = max;\n if (Math.abs(min) > Math.abs(max)) {\n barStart = max;\n barEnd = min;\n }\n item[vScale.axis] = barEnd;\n item._custom = {\n barStart,\n barEnd,\n start: startValue,\n end: endValue,\n min,\n max\n };\n}\nfunction parseValue(entry, item, vScale, i) {\n if (isArray(entry)) {\n parseFloatBar(entry, item, vScale, i);\n } else {\n item[vScale.axis] = vScale.parse(entry, i);\n }\n return item;\n}\nfunction parseArrayOrPrimitive(meta, data, start, count) {\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = [];\n let i, ilen, item, entry;\n for(i = start, ilen = start + count; i < ilen; ++i){\n entry = data[i];\n item = {};\n item[iScale.axis] = singleScale || iScale.parse(labels[i], i);\n parsed.push(parseValue(entry, item, vScale, i));\n }\n return parsed;\n}\nfunction isFloatBar(custom) {\n return custom && custom.barStart !== undefined && custom.barEnd !== undefined;\n}\nfunction barSign(size, vScale, actualBase) {\n if (size !== 0) {\n return sign(size);\n }\n return (vScale.isHorizontal() ? 1 : -1) * (vScale.min >= actualBase ? 1 : -1);\n}\nfunction borderProps(properties) {\n let reverse, start, end, top, bottom;\n if (properties.horizontal) {\n reverse = properties.base > properties.x;\n start = 'left';\n end = 'right';\n } else {\n reverse = properties.base < properties.y;\n start = 'bottom';\n end = 'top';\n }\n if (reverse) {\n top = 'end';\n bottom = 'start';\n } else {\n top = 'start';\n bottom = 'end';\n }\n return {\n start,\n end,\n reverse,\n top,\n bottom\n };\n}\nfunction setBorderSkipped(properties, options, stack, index) {\n let edge = options.borderSkipped;\n const res = {};\n if (!edge) {\n properties.borderSkipped = res;\n return;\n }\n if (edge === true) {\n properties.borderSkipped = {\n top: true,\n right: true,\n bottom: true,\n left: true\n };\n return;\n }\n const { start , end , reverse , top , bottom } = borderProps(properties);\n if (edge === 'middle' && stack) {\n properties.enableBorderRadius = true;\n if ((stack._top || 0) === index) {\n edge = top;\n } else if ((stack._bottom || 0) === index) {\n edge = bottom;\n } else {\n res[parseEdge(bottom, start, end, reverse)] = true;\n edge = top;\n }\n }\n res[parseEdge(edge, start, end, reverse)] = true;\n properties.borderSkipped = res;\n}\nfunction parseEdge(edge, a, b, reverse) {\n if (reverse) {\n edge = swap(edge, a, b);\n edge = startEnd(edge, b, a);\n } else {\n edge = startEnd(edge, a, b);\n }\n return edge;\n}\nfunction swap(orig, v1, v2) {\n return orig === v1 ? v2 : orig === v2 ? v1 : orig;\n}\nfunction startEnd(v, start, end) {\n return v === 'start' ? start : v === 'end' ? end : v;\n}\nfunction setInflateAmount(properties, { inflateAmount }, ratio) {\n properties.inflateAmount = inflateAmount === 'auto' ? ratio === 1 ? 0.33 : 0 : inflateAmount;\n}\nclass BarController extends DatasetController {\n static id = 'bar';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'bar',\n categoryPercentage: 0.8,\n barPercentage: 0.9,\n grouped: true,\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'base',\n 'width',\n 'height'\n ]\n }\n }\n };\n static overrides = {\n scales: {\n _index_: {\n type: 'category',\n offset: true,\n grid: {\n offset: true\n }\n },\n _value_: {\n type: 'linear',\n beginAtZero: true\n }\n }\n };\n parsePrimitiveData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n parseArrayData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n parseObjectData(meta, data, start, count) {\n const { iScale , vScale } = meta;\n const { xAxisKey ='x' , yAxisKey ='y' } = this._parsing;\n const iAxisKey = iScale.axis === 'x' ? xAxisKey : yAxisKey;\n const vAxisKey = vScale.axis === 'x' ? xAxisKey : yAxisKey;\n const parsed = [];\n let i, ilen, item, obj;\n for(i = start, ilen = start + count; i < ilen; ++i){\n obj = data[i];\n item = {};\n item[iScale.axis] = iScale.parse(resolveObjectKey(obj, iAxisKey), i);\n parsed.push(parseValue(resolveObjectKey(obj, vAxisKey), item, vScale, i));\n }\n return parsed;\n }\n updateRangeFromParsed(range, scale, parsed, stack) {\n super.updateRangeFromParsed(range, scale, parsed, stack);\n const custom = parsed._custom;\n if (custom && scale === this._cachedMeta.vScale) {\n range.min = Math.min(range.min, custom.min);\n range.max = Math.max(range.max, custom.max);\n }\n }\n getMaxOverflow() {\n return 0;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const { iScale , vScale } = meta;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const value = isFloatBar(custom) ? '[' + custom.start + ', ' + custom.end + ']' : '' + vScale.getLabelForValue(parsed[vScale.axis]);\n return {\n label: '' + iScale.getLabelForValue(parsed[iScale.axis]),\n value\n };\n }\n initialize() {\n this.enableOptionSharing = true;\n super.initialize();\n const meta = this._cachedMeta;\n meta.stack = this.getDataset().stack;\n }\n update(mode) {\n const meta = this._cachedMeta;\n this.updateElements(meta.data, 0, meta.data.length, mode);\n }\n updateElements(bars, start, count, mode) {\n const reset = mode === 'reset';\n const { index , _cachedMeta: { vScale } } = this;\n const base = vScale.getBasePixel();\n const horizontal = vScale.isHorizontal();\n const ruler = this._getRuler();\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n for(let i = start; i < start + count; i++){\n const parsed = this.getParsed(i);\n const vpixels = reset || isNullOrUndef(parsed[vScale.axis]) ? {\n base,\n head: base\n } : this._calculateBarValuePixels(i);\n const ipixels = this._calculateBarIndexPixels(i, ruler);\n const stack = (parsed._stacks || {})[vScale.axis];\n const properties = {\n horizontal,\n base: vpixels.base,\n enableBorderRadius: !stack || isFloatBar(parsed._custom) || index === stack._top || index === stack._bottom,\n x: horizontal ? vpixels.head : ipixels.center,\n y: horizontal ? ipixels.center : vpixels.head,\n height: horizontal ? ipixels.size : Math.abs(vpixels.size),\n width: horizontal ? Math.abs(vpixels.size) : ipixels.size\n };\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, bars[i].active ? 'active' : mode);\n }\n const options = properties.options || bars[i].options;\n setBorderSkipped(properties, options, stack, index);\n setInflateAmount(properties, options, ruler.ratio);\n this.updateElement(bars[i], i, properties, mode);\n }\n }\n _getStacks(last, dataIndex) {\n const { iScale } = this._cachedMeta;\n const metasets = iScale.getMatchingVisibleMetas(this._type).filter((meta)=>meta.controller.options.grouped);\n const stacked = iScale.options.stacked;\n const stacks = [];\n const skipNull = (meta)=>{\n const parsed = meta.controller.getParsed(dataIndex);\n const val = parsed && parsed[meta.vScale.axis];\n if (isNullOrUndef(val) || isNaN(val)) {\n return true;\n }\n };\n for (const meta of metasets){\n if (dataIndex !== undefined && skipNull(meta)) {\n continue;\n }\n if (stacked === false || stacks.indexOf(meta.stack) === -1 || stacked === undefined && meta.stack === undefined) {\n stacks.push(meta.stack);\n }\n if (meta.index === last) {\n break;\n }\n }\n if (!stacks.length) {\n stacks.push(undefined);\n }\n return stacks;\n }\n _getStackCount(index) {\n return this._getStacks(undefined, index).length;\n }\n _getStackIndex(datasetIndex, name, dataIndex) {\n const stacks = this._getStacks(datasetIndex, dataIndex);\n const index = name !== undefined ? stacks.indexOf(name) : -1;\n return index === -1 ? stacks.length - 1 : index;\n }\n _getRuler() {\n const opts = this.options;\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const pixels = [];\n let i, ilen;\n for(i = 0, ilen = meta.data.length; i < ilen; ++i){\n pixels.push(iScale.getPixelForValue(this.getParsed(i)[iScale.axis], i));\n }\n const barThickness = opts.barThickness;\n const min = barThickness || computeMinSampleSize(meta);\n return {\n min,\n pixels,\n start: iScale._startPixel,\n end: iScale._endPixel,\n stackCount: this._getStackCount(),\n scale: iScale,\n grouped: opts.grouped,\n ratio: barThickness ? 1 : opts.categoryPercentage * opts.barPercentage\n };\n }\n _calculateBarValuePixels(index) {\n const { _cachedMeta: { vScale , _stacked , index: datasetIndex } , options: { base: baseValue , minBarLength } } = this;\n const actualBase = baseValue || 0;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const floating = isFloatBar(custom);\n let value = parsed[vScale.axis];\n let start = 0;\n let length = _stacked ? this.applyStack(vScale, parsed, _stacked) : value;\n let head, size;\n if (length !== value) {\n start = length - value;\n length = value;\n }\n if (floating) {\n value = custom.barStart;\n length = custom.barEnd - custom.barStart;\n if (value !== 0 && sign(value) !== sign(custom.barEnd)) {\n start = 0;\n }\n start += value;\n }\n const startValue = !isNullOrUndef(baseValue) && !floating ? baseValue : start;\n let base = vScale.getPixelForValue(startValue);\n if (this.chart.getDataVisibility(index)) {\n head = vScale.getPixelForValue(start + length);\n } else {\n head = base;\n }\n size = head - base;\n if (Math.abs(size) < minBarLength) {\n size = barSign(size, vScale, actualBase) * minBarLength;\n if (value === actualBase) {\n base -= size / 2;\n }\n const startPixel = vScale.getPixelForDecimal(0);\n const endPixel = vScale.getPixelForDecimal(1);\n const min = Math.min(startPixel, endPixel);\n const max = Math.max(startPixel, endPixel);\n base = Math.max(Math.min(base, max), min);\n head = base + size;\n if (_stacked && !floating) {\n parsed._stacks[vScale.axis]._visualValues[datasetIndex] = vScale.getValueForPixel(head) - vScale.getValueForPixel(base);\n }\n }\n if (base === vScale.getPixelForValue(actualBase)) {\n const halfGrid = sign(size) * vScale.getLineWidthForValue(actualBase) / 2;\n base += halfGrid;\n size -= halfGrid;\n }\n return {\n size,\n base,\n head,\n center: head + size / 2\n };\n }\n _calculateBarIndexPixels(index, ruler) {\n const scale = ruler.scale;\n const options = this.options;\n const skipNull = options.skipNull;\n const maxBarThickness = valueOrDefault(options.maxBarThickness, Infinity);\n let center, size;\n if (ruler.grouped) {\n const stackCount = skipNull ? this._getStackCount(index) : ruler.stackCount;\n const range = options.barThickness === 'flex' ? computeFlexCategoryTraits(index, ruler, options, stackCount) : computeFitCategoryTraits(index, ruler, options, stackCount);\n const stackIndex = this._getStackIndex(this.index, this._cachedMeta.stack, skipNull ? index : undefined);\n center = range.start + range.chunk * stackIndex + range.chunk / 2;\n size = Math.min(maxBarThickness, range.chunk * range.ratio);\n } else {\n center = scale.getPixelForValue(this.getParsed(index)[scale.axis], index);\n size = Math.min(maxBarThickness, ruler.min * ruler.ratio);\n }\n return {\n base: center - size / 2,\n head: center + size / 2,\n center,\n size\n };\n }\n draw() {\n const meta = this._cachedMeta;\n const vScale = meta.vScale;\n const rects = meta.data;\n const ilen = rects.length;\n let i = 0;\n for(; i < ilen; ++i){\n if (this.getParsed(i)[vScale.axis] !== null) {\n rects[i].draw(this._ctx);\n }\n }\n }\n}\n\nclass BubbleController extends DatasetController {\n static id = 'bubble';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'borderWidth',\n 'radius'\n ]\n }\n }\n };\n static overrides = {\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n initialize() {\n this.enableOptionSharing = true;\n super.initialize();\n }\n parsePrimitiveData(meta, data, start, count) {\n const parsed = super.parsePrimitiveData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n parsed[i]._custom = this.resolveDataElementOptions(i + start).radius;\n }\n return parsed;\n }\n parseArrayData(meta, data, start, count) {\n const parsed = super.parseArrayData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item[2], this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n parseObjectData(meta, data, start, count) {\n const parsed = super.parseObjectData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item && item.r && +item.r, this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n getMaxOverflow() {\n const data = this._cachedMeta.data;\n let max = 0;\n for(let i = data.length - 1; i >= 0; --i){\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const { xScale , yScale } = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n const r = parsed._custom;\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + (r ? ', ' + r : '') + ')'\n };\n }\n update(mode) {\n const points = this._cachedMeta.data;\n this.updateElements(points, 0, points.length, mode);\n }\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const { iScale , vScale } = this._cachedMeta;\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n for(let i = start; i < start + count; i++){\n const point = points[i];\n const parsed = !reset && this.getParsed(i);\n const properties = {};\n const iPixel = properties[iAxis] = reset ? iScale.getPixelForDecimal(0.5) : iScale.getPixelForValue(parsed[iAxis]);\n const vPixel = properties[vAxis] = reset ? vScale.getBasePixel() : vScale.getPixelForValue(parsed[vAxis]);\n properties.skip = isNaN(iPixel) || isNaN(vPixel);\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n if (reset) {\n properties.options.radius = 0;\n }\n }\n this.updateElement(point, i, properties, mode);\n }\n }\n resolveDataElementOptions(index, mode) {\n const parsed = this.getParsed(index);\n let values = super.resolveDataElementOptions(index, mode);\n if (values.$shared) {\n values = Object.assign({}, values, {\n $shared: false\n });\n }\n const radius = values.radius;\n if (mode !== 'active') {\n values.radius = 0;\n }\n values.radius += valueOrDefault(parsed && parsed._custom, radius);\n return values;\n }\n}\n\nfunction getRatioAndOffset(rotation, circumference, cutout) {\n let ratioX = 1;\n let ratioY = 1;\n let offsetX = 0;\n let offsetY = 0;\n if (circumference < TAU) {\n const startAngle = rotation;\n const endAngle = startAngle + circumference;\n const startX = Math.cos(startAngle);\n const startY = Math.sin(startAngle);\n const endX = Math.cos(endAngle);\n const endY = Math.sin(endAngle);\n const calcMax = (angle, a, b)=>_angleBetween(angle, startAngle, endAngle, true) ? 1 : Math.max(a, a * cutout, b, b * cutout);\n const calcMin = (angle, a, b)=>_angleBetween(angle, startAngle, endAngle, true) ? -1 : Math.min(a, a * cutout, b, b * cutout);\n const maxX = calcMax(0, startX, endX);\n const maxY = calcMax(HALF_PI, startY, endY);\n const minX = calcMin(PI, startX, endX);\n const minY = calcMin(PI + HALF_PI, startY, endY);\n ratioX = (maxX - minX) / 2;\n ratioY = (maxY - minY) / 2;\n offsetX = -(maxX + minX) / 2;\n offsetY = -(maxY + minY) / 2;\n }\n return {\n ratioX,\n ratioY,\n offsetX,\n offsetY\n };\n}\nclass DoughnutController extends DatasetController {\n static id = 'doughnut';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'arc',\n animation: {\n animateRotate: true,\n animateScale: false\n },\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'circumference',\n 'endAngle',\n 'innerRadius',\n 'outerRadius',\n 'startAngle',\n 'x',\n 'y',\n 'offset',\n 'borderWidth',\n 'spacing'\n ]\n }\n },\n cutout: '50%',\n rotation: 0,\n circumference: 360,\n radius: '100%',\n spacing: 0,\n indexAxis: 'r'\n };\n static descriptors = {\n _scriptable: (name)=>name !== 'spacing',\n _indexable: (name)=>name !== 'spacing'\n };\n static overrides = {\n aspectRatio: 1,\n plugins: {\n legend: {\n labels: {\n generateLabels (chart) {\n const data = chart.data;\n if (data.labels.length && data.datasets.length) {\n const { labels: { pointStyle , color } } = chart.legend.options;\n return data.labels.map((label, i)=>{\n const meta = chart.getDatasetMeta(0);\n const style = meta.controller.getStyle(i);\n return {\n text: label,\n fillStyle: style.backgroundColor,\n strokeStyle: style.borderColor,\n fontColor: color,\n lineWidth: style.borderWidth,\n pointStyle: pointStyle,\n hidden: !chart.getDataVisibility(i),\n index: i\n };\n });\n }\n return [];\n }\n },\n onClick (e, legendItem, legend) {\n legend.chart.toggleDataVisibility(legendItem.index);\n legend.chart.update();\n }\n }\n }\n };\n constructor(chart, datasetIndex){\n super(chart, datasetIndex);\n this.enableOptionSharing = true;\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n this.offsetX = undefined;\n this.offsetY = undefined;\n }\n linkScales() {}\n parse(start, count) {\n const data = this.getDataset().data;\n const meta = this._cachedMeta;\n if (this._parsing === false) {\n meta._parsed = data;\n } else {\n let getter = (i)=>+data[i];\n if (isObject(data[start])) {\n const { key ='value' } = this._parsing;\n getter = (i)=>+resolveObjectKey(data[i], key);\n }\n let i, ilen;\n for(i = start, ilen = start + count; i < ilen; ++i){\n meta._parsed[i] = getter(i);\n }\n }\n }\n _getRotation() {\n return toRadians(this.options.rotation - 90);\n }\n _getCircumference() {\n return toRadians(this.options.circumference);\n }\n _getRotationExtents() {\n let min = TAU;\n let max = -TAU;\n for(let i = 0; i < this.chart.data.datasets.length; ++i){\n if (this.chart.isDatasetVisible(i) && this.chart.getDatasetMeta(i).type === this._type) {\n const controller = this.chart.getDatasetMeta(i).controller;\n const rotation = controller._getRotation();\n const circumference = controller._getCircumference();\n min = Math.min(min, rotation);\n max = Math.max(max, rotation + circumference);\n }\n }\n return {\n rotation: min,\n circumference: max - min\n };\n }\n update(mode) {\n const chart = this.chart;\n const { chartArea } = chart;\n const meta = this._cachedMeta;\n const arcs = meta.data;\n const spacing = this.getMaxBorderWidth() + this.getMaxOffset(arcs) + this.options.spacing;\n const maxSize = Math.max((Math.min(chartArea.width, chartArea.height) - spacing) / 2, 0);\n const cutout = Math.min(toPercentage(this.options.cutout, maxSize), 1);\n const chartWeight = this._getRingWeight(this.index);\n const { circumference , rotation } = this._getRotationExtents();\n const { ratioX , ratioY , offsetX , offsetY } = getRatioAndOffset(rotation, circumference, cutout);\n const maxWidth = (chartArea.width - spacing) / ratioX;\n const maxHeight = (chartArea.height - spacing) / ratioY;\n const maxRadius = Math.max(Math.min(maxWidth, maxHeight) / 2, 0);\n const outerRadius = toDimension(this.options.radius, maxRadius);\n const innerRadius = Math.max(outerRadius * cutout, 0);\n const radiusLength = (outerRadius - innerRadius) / this._getVisibleDatasetWeightTotal();\n this.offsetX = offsetX * outerRadius;\n this.offsetY = offsetY * outerRadius;\n meta.total = this.calculateTotal();\n this.outerRadius = outerRadius - radiusLength * this._getRingWeightOffset(this.index);\n this.innerRadius = Math.max(this.outerRadius - radiusLength * chartWeight, 0);\n this.updateElements(arcs, 0, arcs.length, mode);\n }\n _circumference(i, reset) {\n const opts = this.options;\n const meta = this._cachedMeta;\n const circumference = this._getCircumference();\n if (reset && opts.animation.animateRotate || !this.chart.getDataVisibility(i) || meta._parsed[i] === null || meta.data[i].hidden) {\n return 0;\n }\n return this.calculateCircumference(meta._parsed[i] * circumference / TAU);\n }\n updateElements(arcs, start, count, mode) {\n const reset = mode === 'reset';\n const chart = this.chart;\n const chartArea = chart.chartArea;\n const opts = chart.options;\n const animationOpts = opts.animation;\n const centerX = (chartArea.left + chartArea.right) / 2;\n const centerY = (chartArea.top + chartArea.bottom) / 2;\n const animateScale = reset && animationOpts.animateScale;\n const innerRadius = animateScale ? 0 : this.innerRadius;\n const outerRadius = animateScale ? 0 : this.outerRadius;\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n let startAngle = this._getRotation();\n let i;\n for(i = 0; i < start; ++i){\n startAngle += this._circumference(i, reset);\n }\n for(i = start; i < start + count; ++i){\n const circumference = this._circumference(i, reset);\n const arc = arcs[i];\n const properties = {\n x: centerX + this.offsetX,\n y: centerY + this.offsetY,\n startAngle,\n endAngle: startAngle + circumference,\n circumference,\n outerRadius,\n innerRadius\n };\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, arc.active ? 'active' : mode);\n }\n startAngle += circumference;\n this.updateElement(arc, i, properties, mode);\n }\n }\n calculateTotal() {\n const meta = this._cachedMeta;\n const metaData = meta.data;\n let total = 0;\n let i;\n for(i = 0; i < metaData.length; i++){\n const value = meta._parsed[i];\n if (value !== null && !isNaN(value) && this.chart.getDataVisibility(i) && !metaData[i].hidden) {\n total += Math.abs(value);\n }\n }\n return total;\n }\n calculateCircumference(value) {\n const total = this._cachedMeta.total;\n if (total > 0 && !isNaN(value)) {\n return TAU * (Math.abs(value) / total);\n }\n return 0;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const chart = this.chart;\n const labels = chart.data.labels || [];\n const value = formatNumber(meta._parsed[index], chart.options.locale);\n return {\n label: labels[index] || '',\n value\n };\n }\n getMaxBorderWidth(arcs) {\n let max = 0;\n const chart = this.chart;\n let i, ilen, meta, controller, options;\n if (!arcs) {\n for(i = 0, ilen = chart.data.datasets.length; i < ilen; ++i){\n if (chart.isDatasetVisible(i)) {\n meta = chart.getDatasetMeta(i);\n arcs = meta.data;\n controller = meta.controller;\n break;\n }\n }\n }\n if (!arcs) {\n return 0;\n }\n for(i = 0, ilen = arcs.length; i < ilen; ++i){\n options = controller.resolveDataElementOptions(i);\n if (options.borderAlign !== 'inner') {\n max = Math.max(max, options.borderWidth || 0, options.hoverBorderWidth || 0);\n }\n }\n return max;\n }\n getMaxOffset(arcs) {\n let max = 0;\n for(let i = 0, ilen = arcs.length; i < ilen; ++i){\n const options = this.resolveDataElementOptions(i);\n max = Math.max(max, options.offset || 0, options.hoverOffset || 0);\n }\n return max;\n }\n _getRingWeightOffset(datasetIndex) {\n let ringWeightOffset = 0;\n for(let i = 0; i < datasetIndex; ++i){\n if (this.chart.isDatasetVisible(i)) {\n ringWeightOffset += this._getRingWeight(i);\n }\n }\n return ringWeightOffset;\n }\n _getRingWeight(datasetIndex) {\n return Math.max(valueOrDefault(this.chart.data.datasets[datasetIndex].weight, 1), 0);\n }\n _getVisibleDatasetWeightTotal() {\n return this._getRingWeightOffset(this.chart.data.datasets.length) || 1;\n }\n}\n\nclass LineController extends DatasetController {\n static id = 'line';\n static defaults = {\n datasetElementType: 'line',\n dataElementType: 'point',\n showLine: true,\n spanGaps: false\n };\n static overrides = {\n scales: {\n _index_: {\n type: 'category'\n },\n _value_: {\n type: 'linear'\n }\n }\n };\n initialize() {\n this.enableOptionSharing = true;\n this.supportsDecimation = true;\n super.initialize();\n }\n update(mode) {\n const meta = this._cachedMeta;\n const { dataset: line , data: points = [] , _dataset } = meta;\n const animationsDisabled = this.chart._animationsDisabled;\n let { start , count } = _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled);\n this._drawStart = start;\n this._drawCount = count;\n if (_scaleRangesChanged(meta)) {\n start = 0;\n count = points.length;\n }\n line._chart = this.chart;\n line._datasetIndex = this.index;\n line._decimated = !!_dataset._decimated;\n line.points = points;\n const options = this.resolveDatasetElementOptions(mode);\n if (!this.options.showLine) {\n options.borderWidth = 0;\n }\n options.segment = this.options.segment;\n this.updateElement(line, undefined, {\n animated: !animationsDisabled,\n options\n }, mode);\n this.updateElements(points, start, count, mode);\n }\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const { iScale , vScale , _stacked , _dataset } = this._cachedMeta;\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const { spanGaps , segment } = this.options;\n const maxGapLength = isNumber(spanGaps) ? spanGaps : Number.POSITIVE_INFINITY;\n const directUpdate = this.chart._animationsDisabled || reset || mode === 'none';\n const end = start + count;\n const pointsCount = points.length;\n let prevParsed = start > 0 && this.getParsed(start - 1);\n for(let i = 0; i < pointsCount; ++i){\n const point = points[i];\n const properties = directUpdate ? point : {};\n if (i < start || i >= end) {\n properties.skip = true;\n continue;\n }\n const parsed = this.getParsed(i);\n const nullData = isNullOrUndef(parsed[vAxis]);\n const iPixel = properties[iAxis] = iScale.getPixelForValue(parsed[iAxis], i);\n const vPixel = properties[vAxis] = reset || nullData ? vScale.getBasePixel() : vScale.getPixelForValue(_stacked ? this.applyStack(vScale, parsed, _stacked) : parsed[vAxis], i);\n properties.skip = isNaN(iPixel) || isNaN(vPixel) || nullData;\n properties.stop = i > 0 && Math.abs(parsed[iAxis] - prevParsed[iAxis]) > maxGapLength;\n if (segment) {\n properties.parsed = parsed;\n properties.raw = _dataset.data[i];\n }\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n }\n if (!directUpdate) {\n this.updateElement(point, i, properties, mode);\n }\n prevParsed = parsed;\n }\n }\n getMaxOverflow() {\n const meta = this._cachedMeta;\n const dataset = meta.dataset;\n const border = dataset.options && dataset.options.borderWidth || 0;\n const data = meta.data || [];\n if (!data.length) {\n return border;\n }\n const firstPoint = data[0].size(this.resolveDataElementOptions(0));\n const lastPoint = data[data.length - 1].size(this.resolveDataElementOptions(data.length - 1));\n return Math.max(border, firstPoint, lastPoint) / 2;\n }\n draw() {\n const meta = this._cachedMeta;\n meta.dataset.updateControlPoints(this.chart.chartArea, meta.iScale.axis);\n super.draw();\n }\n}\n\nclass PolarAreaController extends DatasetController {\n static id = 'polarArea';\n static defaults = {\n dataElementType: 'arc',\n animation: {\n animateRotate: true,\n animateScale: true\n },\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius'\n ]\n }\n },\n indexAxis: 'r',\n startAngle: 0\n };\n static overrides = {\n aspectRatio: 1,\n plugins: {\n legend: {\n labels: {\n generateLabels (chart) {\n const data = chart.data;\n if (data.labels.length && data.datasets.length) {\n const { labels: { pointStyle , color } } = chart.legend.options;\n return data.labels.map((label, i)=>{\n const meta = chart.getDatasetMeta(0);\n const style = meta.controller.getStyle(i);\n return {\n text: label,\n fillStyle: style.backgroundColor,\n strokeStyle: style.borderColor,\n fontColor: color,\n lineWidth: style.borderWidth,\n pointStyle: pointStyle,\n hidden: !chart.getDataVisibility(i),\n index: i\n };\n });\n }\n return [];\n }\n },\n onClick (e, legendItem, legend) {\n legend.chart.toggleDataVisibility(legendItem.index);\n legend.chart.update();\n }\n }\n },\n scales: {\n r: {\n type: 'radialLinear',\n angleLines: {\n display: false\n },\n beginAtZero: true,\n grid: {\n circular: true\n },\n pointLabels: {\n display: false\n },\n startAngle: 0\n }\n }\n };\n constructor(chart, datasetIndex){\n super(chart, datasetIndex);\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const chart = this.chart;\n const labels = chart.data.labels || [];\n const value = formatNumber(meta._parsed[index].r, chart.options.locale);\n return {\n label: labels[index] || '',\n value\n };\n }\n parseObjectData(meta, data, start, count) {\n return _parseObjectDataRadialScale.bind(this)(meta, data, start, count);\n }\n update(mode) {\n const arcs = this._cachedMeta.data;\n this._updateRadius();\n this.updateElements(arcs, 0, arcs.length, mode);\n }\n getMinMax() {\n const meta = this._cachedMeta;\n const range = {\n min: Number.POSITIVE_INFINITY,\n max: Number.NEGATIVE_INFINITY\n };\n meta.data.forEach((element, index)=>{\n const parsed = this.getParsed(index).r;\n if (!isNaN(parsed) && this.chart.getDataVisibility(index)) {\n if (parsed < range.min) {\n range.min = parsed;\n }\n if (parsed > range.max) {\n range.max = parsed;\n }\n }\n });\n return range;\n }\n _updateRadius() {\n const chart = this.chart;\n const chartArea = chart.chartArea;\n const opts = chart.options;\n const minSize = Math.min(chartArea.right - chartArea.left, chartArea.bottom - chartArea.top);\n const outerRadius = Math.max(minSize / 2, 0);\n const innerRadius = Math.max(opts.cutoutPercentage ? outerRadius / 100 * opts.cutoutPercentage : 1, 0);\n const radiusLength = (outerRadius - innerRadius) / chart.getVisibleDatasetCount();\n this.outerRadius = outerRadius - radiusLength * this.index;\n this.innerRadius = this.outerRadius - radiusLength;\n }\n updateElements(arcs, start, count, mode) {\n const reset = mode === 'reset';\n const chart = this.chart;\n const opts = chart.options;\n const animationOpts = opts.animation;\n const scale = this._cachedMeta.rScale;\n const centerX = scale.xCenter;\n const centerY = scale.yCenter;\n const datasetStartAngle = scale.getIndexAngle(0) - 0.5 * PI;\n let angle = datasetStartAngle;\n let i;\n const defaultAngle = 360 / this.countVisibleElements();\n for(i = 0; i < start; ++i){\n angle += this._computeAngle(i, mode, defaultAngle);\n }\n for(i = start; i < start + count; i++){\n const arc = arcs[i];\n let startAngle = angle;\n let endAngle = angle + this._computeAngle(i, mode, defaultAngle);\n let outerRadius = chart.getDataVisibility(i) ? scale.getDistanceFromCenterForValue(this.getParsed(i).r) : 0;\n angle = endAngle;\n if (reset) {\n if (animationOpts.animateScale) {\n outerRadius = 0;\n }\n if (animationOpts.animateRotate) {\n startAngle = endAngle = datasetStartAngle;\n }\n }\n const properties = {\n x: centerX,\n y: centerY,\n innerRadius: 0,\n outerRadius,\n startAngle,\n endAngle,\n options: this.resolveDataElementOptions(i, arc.active ? 'active' : mode)\n };\n this.updateElement(arc, i, properties, mode);\n }\n }\n countVisibleElements() {\n const meta = this._cachedMeta;\n let count = 0;\n meta.data.forEach((element, index)=>{\n if (!isNaN(this.getParsed(index).r) && this.chart.getDataVisibility(index)) {\n count++;\n }\n });\n return count;\n }\n _computeAngle(index, mode, defaultAngle) {\n return this.chart.getDataVisibility(index) ? toRadians(this.resolveDataElementOptions(index, mode).angle || defaultAngle) : 0;\n }\n}\n\nclass PieController extends DoughnutController {\n static id = 'pie';\n static defaults = {\n cutout: 0,\n rotation: 0,\n circumference: 360,\n radius: '100%'\n };\n}\n\nclass RadarController extends DatasetController {\n static id = 'radar';\n static defaults = {\n datasetElementType: 'line',\n dataElementType: 'point',\n indexAxis: 'r',\n showLine: true,\n elements: {\n line: {\n fill: 'start'\n }\n }\n };\n static overrides = {\n aspectRatio: 1,\n scales: {\n r: {\n type: 'radialLinear'\n }\n }\n };\n getLabelAndValue(index) {\n const vScale = this._cachedMeta.vScale;\n const parsed = this.getParsed(index);\n return {\n label: vScale.getLabels()[index],\n value: '' + vScale.getLabelForValue(parsed[vScale.axis])\n };\n }\n parseObjectData(meta, data, start, count) {\n return _parseObjectDataRadialScale.bind(this)(meta, data, start, count);\n }\n update(mode) {\n const meta = this._cachedMeta;\n const line = meta.dataset;\n const points = meta.data || [];\n const labels = meta.iScale.getLabels();\n line.points = points;\n if (mode !== 'resize') {\n const options = this.resolveDatasetElementOptions(mode);\n if (!this.options.showLine) {\n options.borderWidth = 0;\n }\n const properties = {\n _loop: true,\n _fullLoop: labels.length === points.length,\n options\n };\n this.updateElement(line, undefined, properties, mode);\n }\n this.updateElements(points, 0, points.length, mode);\n }\n updateElements(points, start, count, mode) {\n const scale = this._cachedMeta.rScale;\n const reset = mode === 'reset';\n for(let i = start; i < start + count; i++){\n const point = points[i];\n const options = this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n const pointPosition = scale.getPointPositionForValue(i, this.getParsed(i).r);\n const x = reset ? scale.xCenter : pointPosition.x;\n const y = reset ? scale.yCenter : pointPosition.y;\n const properties = {\n x,\n y,\n angle: pointPosition.angle,\n skip: isNaN(x) || isNaN(y),\n options\n };\n this.updateElement(point, i, properties, mode);\n }\n }\n}\n\nclass ScatterController extends DatasetController {\n static id = 'scatter';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n showLine: false,\n fill: false\n };\n static overrides = {\n interaction: {\n mode: 'point'\n },\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const { xScale , yScale } = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + ')'\n };\n }\n update(mode) {\n const meta = this._cachedMeta;\n const { data: points = [] } = meta;\n const animationsDisabled = this.chart._animationsDisabled;\n let { start , count } = _getStartAndCountOfVisiblePoints(meta, points, animationsDisabled);\n this._drawStart = start;\n this._drawCount = count;\n if (_scaleRangesChanged(meta)) {\n start = 0;\n count = points.length;\n }\n if (this.options.showLine) {\n const { dataset: line , _dataset } = meta;\n line._chart = this.chart;\n line._datasetIndex = this.index;\n line._decimated = !!_dataset._decimated;\n line.points = points;\n const options = this.resolveDatasetElementOptions(mode);\n options.segment = this.options.segment;\n this.updateElement(line, undefined, {\n animated: !animationsDisabled,\n options\n }, mode);\n }\n this.updateElements(points, start, count, mode);\n }\n addElements() {\n const { showLine } = this.options;\n if (!this.datasetElementType && showLine) {\n this.datasetElementType = this.chart.registry.getElement('line');\n }\n super.addElements();\n }\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const { iScale , vScale , _stacked , _dataset } = this._cachedMeta;\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const { spanGaps , segment } = this.options;\n const maxGapLength = isNumber(spanGaps) ? spanGaps : Number.POSITIVE_INFINITY;\n const directUpdate = this.chart._animationsDisabled || reset || mode === 'none';\n let prevParsed = start > 0 && this.getParsed(start - 1);\n for(let i = start; i < start + count; ++i){\n const point = points[i];\n const parsed = this.getParsed(i);\n const properties = directUpdate ? point : {};\n const nullData = isNullOrUndef(parsed[vAxis]);\n const iPixel = properties[iAxis] = iScale.getPixelForValue(parsed[iAxis], i);\n const vPixel = properties[vAxis] = reset || nullData ? vScale.getBasePixel() : vScale.getPixelForValue(_stacked ? this.applyStack(vScale, parsed, _stacked) : parsed[vAxis], i);\n properties.skip = isNaN(iPixel) || isNaN(vPixel) || nullData;\n properties.stop = i > 0 && Math.abs(parsed[iAxis] - prevParsed[iAxis]) > maxGapLength;\n if (segment) {\n properties.parsed = parsed;\n properties.raw = _dataset.data[i];\n }\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n }\n if (!directUpdate) {\n this.updateElement(point, i, properties, mode);\n }\n prevParsed = parsed;\n }\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n }\n getMaxOverflow() {\n const meta = this._cachedMeta;\n const data = meta.data || [];\n if (!this.options.showLine) {\n let max = 0;\n for(let i = data.length - 1; i >= 0; --i){\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n const dataset = meta.dataset;\n const border = dataset.options && dataset.options.borderWidth || 0;\n if (!data.length) {\n return border;\n }\n const firstPoint = data[0].size(this.resolveDataElementOptions(0));\n const lastPoint = data[data.length - 1].size(this.resolveDataElementOptions(data.length - 1));\n return Math.max(border, firstPoint, lastPoint) / 2;\n }\n}\n\nvar controllers = /*#__PURE__*/Object.freeze({\n__proto__: null,\nBarController: BarController,\nBubbleController: BubbleController,\nDoughnutController: DoughnutController,\nLineController: LineController,\nPolarAreaController: PolarAreaController,\nPieController: PieController,\nRadarController: RadarController,\nScatterController: ScatterController\n});\n\n/**\n * @namespace Chart._adapters\n * @since 2.8.0\n * @private\n */ function abstract() {\n throw new Error('This method is not implemented: Check that a complete date adapter is provided.');\n}\n/**\n * Date adapter (current used by the time scale)\n * @namespace Chart._adapters._date\n * @memberof Chart._adapters\n * @private\n */ class DateAdapterBase {\n /**\n * Override default date adapter methods.\n * Accepts type parameter to define options type.\n * @example\n * Chart._adapters._date.override<{myAdapterOption: string}>({\n * init() {\n * console.log(this.options.myAdapterOption);\n * }\n * })\n */ static override(members) {\n Object.assign(DateAdapterBase.prototype, members);\n }\n constructor(options){\n this.options = options || {};\n }\n // eslint-disable-next-line @typescript-eslint/no-empty-function\n init() {}\n formats() {\n return abstract();\n }\n parse() {\n return abstract();\n }\n format() {\n return abstract();\n }\n add() {\n return abstract();\n }\n diff() {\n return abstract();\n }\n startOf() {\n return abstract();\n }\n endOf() {\n return abstract();\n }\n}\nvar adapters = {\n _date: DateAdapterBase\n};\n\nfunction binarySearch(metaset, axis, value, intersect) {\n const { controller , data , _sorted } = metaset;\n const iScale = controller._cachedMeta.iScale;\n if (iScale && axis === iScale.axis && axis !== 'r' && _sorted && data.length) {\n const lookupMethod = iScale._reversePixels ? _rlookupByKey : _lookupByKey;\n if (!intersect) {\n return lookupMethod(data, axis, value);\n } else if (controller._sharedOptions) {\n const el = data[0];\n const range = typeof el.getRange === 'function' && el.getRange(axis);\n if (range) {\n const start = lookupMethod(data, axis, value - range);\n const end = lookupMethod(data, axis, value + range);\n return {\n lo: start.lo,\n hi: end.hi\n };\n }\n }\n }\n return {\n lo: 0,\n hi: data.length - 1\n };\n}\n function evaluateInteractionItems(chart, axis, position, handler, intersect) {\n const metasets = chart.getSortedVisibleDatasetMetas();\n const value = position[axis];\n for(let i = 0, ilen = metasets.length; i < ilen; ++i){\n const { index , data } = metasets[i];\n const { lo , hi } = binarySearch(metasets[i], axis, value, intersect);\n for(let j = lo; j <= hi; ++j){\n const element = data[j];\n if (!element.skip) {\n handler(element, index, j);\n }\n }\n }\n}\n function getDistanceMetricForAxis(axis) {\n const useX = axis.indexOf('x') !== -1;\n const useY = axis.indexOf('y') !== -1;\n return function(pt1, pt2) {\n const deltaX = useX ? Math.abs(pt1.x - pt2.x) : 0;\n const deltaY = useY ? Math.abs(pt1.y - pt2.y) : 0;\n return Math.sqrt(Math.pow(deltaX, 2) + Math.pow(deltaY, 2));\n };\n}\n function getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) {\n const items = [];\n if (!includeInvisible && !chart.isPointInArea(position)) {\n return items;\n }\n const evaluationFunc = function(element, datasetIndex, index) {\n if (!includeInvisible && !_isPointInArea(element, chart.chartArea, 0)) {\n return;\n }\n if (element.inRange(position.x, position.y, useFinalPosition)) {\n items.push({\n element,\n datasetIndex,\n index\n });\n }\n };\n evaluateInteractionItems(chart, axis, position, evaluationFunc, true);\n return items;\n}\n function getNearestRadialItems(chart, position, axis, useFinalPosition) {\n let items = [];\n function evaluationFunc(element, datasetIndex, index) {\n const { startAngle , endAngle } = element.getProps([\n 'startAngle',\n 'endAngle'\n ], useFinalPosition);\n const { angle } = getAngleFromPoint(element, {\n x: position.x,\n y: position.y\n });\n if (_angleBetween(angle, startAngle, endAngle)) {\n items.push({\n element,\n datasetIndex,\n index\n });\n }\n }\n evaluateInteractionItems(chart, axis, position, evaluationFunc);\n return items;\n}\n function getNearestCartesianItems(chart, position, axis, intersect, useFinalPosition, includeInvisible) {\n let items = [];\n const distanceMetric = getDistanceMetricForAxis(axis);\n let minDistance = Number.POSITIVE_INFINITY;\n function evaluationFunc(element, datasetIndex, index) {\n const inRange = element.inRange(position.x, position.y, useFinalPosition);\n if (intersect && !inRange) {\n return;\n }\n const center = element.getCenterPoint(useFinalPosition);\n const pointInArea = !!includeInvisible || chart.isPointInArea(center);\n if (!pointInArea && !inRange) {\n return;\n }\n const distance = distanceMetric(position, center);\n if (distance < minDistance) {\n items = [\n {\n element,\n datasetIndex,\n index\n }\n ];\n minDistance = distance;\n } else if (distance === minDistance) {\n items.push({\n element,\n datasetIndex,\n index\n });\n }\n }\n evaluateInteractionItems(chart, axis, position, evaluationFunc);\n return items;\n}\n function getNearestItems(chart, position, axis, intersect, useFinalPosition, includeInvisible) {\n if (!includeInvisible && !chart.isPointInArea(position)) {\n return [];\n }\n return axis === 'r' && !intersect ? getNearestRadialItems(chart, position, axis, useFinalPosition) : getNearestCartesianItems(chart, position, axis, intersect, useFinalPosition, includeInvisible);\n}\n function getAxisItems(chart, position, axis, intersect, useFinalPosition) {\n const items = [];\n const rangeMethod = axis === 'x' ? 'inXRange' : 'inYRange';\n let intersectsItem = false;\n evaluateInteractionItems(chart, axis, position, (element, datasetIndex, index)=>{\n if (element[rangeMethod](position[axis], useFinalPosition)) {\n items.push({\n element,\n datasetIndex,\n index\n });\n intersectsItem = intersectsItem || element.inRange(position.x, position.y, useFinalPosition);\n }\n });\n if (intersect && !intersectsItem) {\n return [];\n }\n return items;\n}\n var Interaction = {\n evaluateInteractionItems,\n modes: {\n index (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'x';\n const includeInvisible = options.includeInvisible || false;\n const items = options.intersect ? getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) : getNearestItems(chart, position, axis, false, useFinalPosition, includeInvisible);\n const elements = [];\n if (!items.length) {\n return [];\n }\n chart.getSortedVisibleDatasetMetas().forEach((meta)=>{\n const index = items[0].index;\n const element = meta.data[index];\n if (element && !element.skip) {\n elements.push({\n element,\n datasetIndex: meta.index,\n index\n });\n }\n });\n return elements;\n },\n dataset (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n let items = options.intersect ? getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible) : getNearestItems(chart, position, axis, false, useFinalPosition, includeInvisible);\n if (items.length > 0) {\n const datasetIndex = items[0].datasetIndex;\n const data = chart.getDatasetMeta(datasetIndex).data;\n items = [];\n for(let i = 0; i < data.length; ++i){\n items.push({\n element: data[i],\n datasetIndex,\n index: i\n });\n }\n }\n return items;\n },\n point (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n return getIntersectItems(chart, position, axis, useFinalPosition, includeInvisible);\n },\n nearest (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n const axis = options.axis || 'xy';\n const includeInvisible = options.includeInvisible || false;\n return getNearestItems(chart, position, axis, options.intersect, useFinalPosition, includeInvisible);\n },\n x (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n return getAxisItems(chart, position, 'x', options.intersect, useFinalPosition);\n },\n y (chart, e, options, useFinalPosition) {\n const position = getRelativePosition(e, chart);\n return getAxisItems(chart, position, 'y', options.intersect, useFinalPosition);\n }\n }\n};\n\nconst STATIC_POSITIONS = [\n 'left',\n 'top',\n 'right',\n 'bottom'\n];\nfunction filterByPosition(array, position) {\n return array.filter((v)=>v.pos === position);\n}\nfunction filterDynamicPositionByAxis(array, axis) {\n return array.filter((v)=>STATIC_POSITIONS.indexOf(v.pos) === -1 && v.box.axis === axis);\n}\nfunction sortByWeight(array, reverse) {\n return array.sort((a, b)=>{\n const v0 = reverse ? b : a;\n const v1 = reverse ? a : b;\n return v0.weight === v1.weight ? v0.index - v1.index : v0.weight - v1.weight;\n });\n}\nfunction wrapBoxes(boxes) {\n const layoutBoxes = [];\n let i, ilen, box, pos, stack, stackWeight;\n for(i = 0, ilen = (boxes || []).length; i < ilen; ++i){\n box = boxes[i];\n ({ position: pos , options: { stack , stackWeight =1 } } = box);\n layoutBoxes.push({\n index: i,\n box,\n pos,\n horizontal: box.isHorizontal(),\n weight: box.weight,\n stack: stack && pos + stack,\n stackWeight\n });\n }\n return layoutBoxes;\n}\nfunction buildStacks(layouts) {\n const stacks = {};\n for (const wrap of layouts){\n const { stack , pos , stackWeight } = wrap;\n if (!stack || !STATIC_POSITIONS.includes(pos)) {\n continue;\n }\n const _stack = stacks[stack] || (stacks[stack] = {\n count: 0,\n placed: 0,\n weight: 0,\n size: 0\n });\n _stack.count++;\n _stack.weight += stackWeight;\n }\n return stacks;\n}\n function setLayoutDims(layouts, params) {\n const stacks = buildStacks(layouts);\n const { vBoxMaxWidth , hBoxMaxHeight } = params;\n let i, ilen, layout;\n for(i = 0, ilen = layouts.length; i < ilen; ++i){\n layout = layouts[i];\n const { fullSize } = layout.box;\n const stack = stacks[layout.stack];\n const factor = stack && layout.stackWeight / stack.weight;\n if (layout.horizontal) {\n layout.width = factor ? factor * vBoxMaxWidth : fullSize && params.availableWidth;\n layout.height = hBoxMaxHeight;\n } else {\n layout.width = vBoxMaxWidth;\n layout.height = factor ? factor * hBoxMaxHeight : fullSize && params.availableHeight;\n }\n }\n return stacks;\n}\nfunction buildLayoutBoxes(boxes) {\n const layoutBoxes = wrapBoxes(boxes);\n const fullSize = sortByWeight(layoutBoxes.filter((wrap)=>wrap.box.fullSize), true);\n const left = sortByWeight(filterByPosition(layoutBoxes, 'left'), true);\n const right = sortByWeight(filterByPosition(layoutBoxes, 'right'));\n const top = sortByWeight(filterByPosition(layoutBoxes, 'top'), true);\n const bottom = sortByWeight(filterByPosition(layoutBoxes, 'bottom'));\n const centerHorizontal = filterDynamicPositionByAxis(layoutBoxes, 'x');\n const centerVertical = filterDynamicPositionByAxis(layoutBoxes, 'y');\n return {\n fullSize,\n leftAndTop: left.concat(top),\n rightAndBottom: right.concat(centerVertical).concat(bottom).concat(centerHorizontal),\n chartArea: filterByPosition(layoutBoxes, 'chartArea'),\n vertical: left.concat(right).concat(centerVertical),\n horizontal: top.concat(bottom).concat(centerHorizontal)\n };\n}\nfunction getCombinedMax(maxPadding, chartArea, a, b) {\n return Math.max(maxPadding[a], chartArea[a]) + Math.max(maxPadding[b], chartArea[b]);\n}\nfunction updateMaxPadding(maxPadding, boxPadding) {\n maxPadding.top = Math.max(maxPadding.top, boxPadding.top);\n maxPadding.left = Math.max(maxPadding.left, boxPadding.left);\n maxPadding.bottom = Math.max(maxPadding.bottom, boxPadding.bottom);\n maxPadding.right = Math.max(maxPadding.right, boxPadding.right);\n}\nfunction updateDims(chartArea, params, layout, stacks) {\n const { pos , box } = layout;\n const maxPadding = chartArea.maxPadding;\n if (!isObject(pos)) {\n if (layout.size) {\n chartArea[pos] -= layout.size;\n }\n const stack = stacks[layout.stack] || {\n size: 0,\n count: 1\n };\n stack.size = Math.max(stack.size, layout.horizontal ? box.height : box.width);\n layout.size = stack.size / stack.count;\n chartArea[pos] += layout.size;\n }\n if (box.getPadding) {\n updateMaxPadding(maxPadding, box.getPadding());\n }\n const newWidth = Math.max(0, params.outerWidth - getCombinedMax(maxPadding, chartArea, 'left', 'right'));\n const newHeight = Math.max(0, params.outerHeight - getCombinedMax(maxPadding, chartArea, 'top', 'bottom'));\n const widthChanged = newWidth !== chartArea.w;\n const heightChanged = newHeight !== chartArea.h;\n chartArea.w = newWidth;\n chartArea.h = newHeight;\n return layout.horizontal ? {\n same: widthChanged,\n other: heightChanged\n } : {\n same: heightChanged,\n other: widthChanged\n };\n}\nfunction handleMaxPadding(chartArea) {\n const maxPadding = chartArea.maxPadding;\n function updatePos(pos) {\n const change = Math.max(maxPadding[pos] - chartArea[pos], 0);\n chartArea[pos] += change;\n return change;\n }\n chartArea.y += updatePos('top');\n chartArea.x += updatePos('left');\n updatePos('right');\n updatePos('bottom');\n}\nfunction getMargins(horizontal, chartArea) {\n const maxPadding = chartArea.maxPadding;\n function marginForPositions(positions) {\n const margin = {\n left: 0,\n top: 0,\n right: 0,\n bottom: 0\n };\n positions.forEach((pos)=>{\n margin[pos] = Math.max(chartArea[pos], maxPadding[pos]);\n });\n return margin;\n }\n return horizontal ? marginForPositions([\n 'left',\n 'right'\n ]) : marginForPositions([\n 'top',\n 'bottom'\n ]);\n}\nfunction fitBoxes(boxes, chartArea, params, stacks) {\n const refitBoxes = [];\n let i, ilen, layout, box, refit, changed;\n for(i = 0, ilen = boxes.length, refit = 0; i < ilen; ++i){\n layout = boxes[i];\n box = layout.box;\n box.update(layout.width || chartArea.w, layout.height || chartArea.h, getMargins(layout.horizontal, chartArea));\n const { same , other } = updateDims(chartArea, params, layout, stacks);\n refit |= same && refitBoxes.length;\n changed = changed || other;\n if (!box.fullSize) {\n refitBoxes.push(layout);\n }\n }\n return refit && fitBoxes(refitBoxes, chartArea, params, stacks) || changed;\n}\nfunction setBoxDims(box, left, top, width, height) {\n box.top = top;\n box.left = left;\n box.right = left + width;\n box.bottom = top + height;\n box.width = width;\n box.height = height;\n}\nfunction placeBoxes(boxes, chartArea, params, stacks) {\n const userPadding = params.padding;\n let { x , y } = chartArea;\n for (const layout of boxes){\n const box = layout.box;\n const stack = stacks[layout.stack] || {\n count: 1,\n placed: 0,\n weight: 1\n };\n const weight = layout.stackWeight / stack.weight || 1;\n if (layout.horizontal) {\n const width = chartArea.w * weight;\n const height = stack.size || box.height;\n if (defined(stack.start)) {\n y = stack.start;\n }\n if (box.fullSize) {\n setBoxDims(box, userPadding.left, y, params.outerWidth - userPadding.right - userPadding.left, height);\n } else {\n setBoxDims(box, chartArea.left + stack.placed, y, width, height);\n }\n stack.start = y;\n stack.placed += width;\n y = box.bottom;\n } else {\n const height1 = chartArea.h * weight;\n const width1 = stack.size || box.width;\n if (defined(stack.start)) {\n x = stack.start;\n }\n if (box.fullSize) {\n setBoxDims(box, x, userPadding.top, width1, params.outerHeight - userPadding.bottom - userPadding.top);\n } else {\n setBoxDims(box, x, chartArea.top + stack.placed, width1, height1);\n }\n stack.start = x;\n stack.placed += height1;\n x = box.right;\n }\n }\n chartArea.x = x;\n chartArea.y = y;\n}\nvar layouts = {\n addBox (chart, item) {\n if (!chart.boxes) {\n chart.boxes = [];\n }\n item.fullSize = item.fullSize || false;\n item.position = item.position || 'top';\n item.weight = item.weight || 0;\n item._layers = item._layers || function() {\n return [\n {\n z: 0,\n draw (chartArea) {\n item.draw(chartArea);\n }\n }\n ];\n };\n chart.boxes.push(item);\n },\n removeBox (chart, layoutItem) {\n const index = chart.boxes ? chart.boxes.indexOf(layoutItem) : -1;\n if (index !== -1) {\n chart.boxes.splice(index, 1);\n }\n },\n configure (chart, item, options) {\n item.fullSize = options.fullSize;\n item.position = options.position;\n item.weight = options.weight;\n },\n update (chart, width, height, minPadding) {\n if (!chart) {\n return;\n }\n const padding = toPadding(chart.options.layout.padding);\n const availableWidth = Math.max(width - padding.width, 0);\n const availableHeight = Math.max(height - padding.height, 0);\n const boxes = buildLayoutBoxes(chart.boxes);\n const verticalBoxes = boxes.vertical;\n const horizontalBoxes = boxes.horizontal;\n each(chart.boxes, (box)=>{\n if (typeof box.beforeLayout === 'function') {\n box.beforeLayout();\n }\n });\n const visibleVerticalBoxCount = verticalBoxes.reduce((total, wrap)=>wrap.box.options && wrap.box.options.display === false ? total : total + 1, 0) || 1;\n const params = Object.freeze({\n outerWidth: width,\n outerHeight: height,\n padding,\n availableWidth,\n availableHeight,\n vBoxMaxWidth: availableWidth / 2 / visibleVerticalBoxCount,\n hBoxMaxHeight: availableHeight / 2\n });\n const maxPadding = Object.assign({}, padding);\n updateMaxPadding(maxPadding, toPadding(minPadding));\n const chartArea = Object.assign({\n maxPadding,\n w: availableWidth,\n h: availableHeight,\n x: padding.left,\n y: padding.top\n }, padding);\n const stacks = setLayoutDims(verticalBoxes.concat(horizontalBoxes), params);\n fitBoxes(boxes.fullSize, chartArea, params, stacks);\n fitBoxes(verticalBoxes, chartArea, params, stacks);\n if (fitBoxes(horizontalBoxes, chartArea, params, stacks)) {\n fitBoxes(verticalBoxes, chartArea, params, stacks);\n }\n handleMaxPadding(chartArea);\n placeBoxes(boxes.leftAndTop, chartArea, params, stacks);\n chartArea.x += chartArea.w;\n chartArea.y += chartArea.h;\n placeBoxes(boxes.rightAndBottom, chartArea, params, stacks);\n chart.chartArea = {\n left: chartArea.left,\n top: chartArea.top,\n right: chartArea.left + chartArea.w,\n bottom: chartArea.top + chartArea.h,\n height: chartArea.h,\n width: chartArea.w\n };\n each(boxes.chartArea, (layout)=>{\n const box = layout.box;\n Object.assign(box, chart.chartArea);\n box.update(chartArea.w, chartArea.h, {\n left: 0,\n top: 0,\n right: 0,\n bottom: 0\n });\n });\n }\n};\n\nclass BasePlatform {\n acquireContext(canvas, aspectRatio) {}\n releaseContext(context) {\n return false;\n }\n addEventListener(chart, type, listener) {}\n removeEventListener(chart, type, listener) {}\n getDevicePixelRatio() {\n return 1;\n }\n getMaximumSize(element, width, height, aspectRatio) {\n width = Math.max(0, width || element.width);\n height = height || element.height;\n return {\n width,\n height: Math.max(0, aspectRatio ? Math.floor(width / aspectRatio) : height)\n };\n }\n isAttached(canvas) {\n return true;\n }\n updateConfig(config) {\n }\n}\n\nclass BasicPlatform extends BasePlatform {\n acquireContext(item) {\n return item && item.getContext && item.getContext('2d') || null;\n }\n updateConfig(config) {\n config.options.animation = false;\n }\n}\n\nconst EXPANDO_KEY = '$chartjs';\n const EVENT_TYPES = {\n touchstart: 'mousedown',\n touchmove: 'mousemove',\n touchend: 'mouseup',\n pointerenter: 'mouseenter',\n pointerdown: 'mousedown',\n pointermove: 'mousemove',\n pointerup: 'mouseup',\n pointerleave: 'mouseout',\n pointerout: 'mouseout'\n};\nconst isNullOrEmpty = (value)=>value === null || value === '';\n function initCanvas(canvas, aspectRatio) {\n const style = canvas.style;\n const renderHeight = canvas.getAttribute('height');\n const renderWidth = canvas.getAttribute('width');\n canvas[EXPANDO_KEY] = {\n initial: {\n height: renderHeight,\n width: renderWidth,\n style: {\n display: style.display,\n height: style.height,\n width: style.width\n }\n }\n };\n style.display = style.display || 'block';\n style.boxSizing = style.boxSizing || 'border-box';\n if (isNullOrEmpty(renderWidth)) {\n const displayWidth = readUsedSize(canvas, 'width');\n if (displayWidth !== undefined) {\n canvas.width = displayWidth;\n }\n }\n if (isNullOrEmpty(renderHeight)) {\n if (canvas.style.height === '') {\n canvas.height = canvas.width / (aspectRatio || 2);\n } else {\n const displayHeight = readUsedSize(canvas, 'height');\n if (displayHeight !== undefined) {\n canvas.height = displayHeight;\n }\n }\n }\n return canvas;\n}\nconst eventListenerOptions = supportsEventListenerOptions ? {\n passive: true\n} : false;\nfunction addListener(node, type, listener) {\n node.addEventListener(type, listener, eventListenerOptions);\n}\nfunction removeListener(chart, type, listener) {\n chart.canvas.removeEventListener(type, listener, eventListenerOptions);\n}\nfunction fromNativeEvent(event, chart) {\n const type = EVENT_TYPES[event.type] || event.type;\n const { x , y } = getRelativePosition(event, chart);\n return {\n type,\n chart,\n native: event,\n x: x !== undefined ? x : null,\n y: y !== undefined ? y : null\n };\n}\nfunction nodeListContains(nodeList, canvas) {\n for (const node of nodeList){\n if (node === canvas || node.contains(canvas)) {\n return true;\n }\n }\n}\nfunction createAttachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver((entries)=>{\n let trigger = false;\n for (const entry of entries){\n trigger = trigger || nodeListContains(entry.addedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.removedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {\n childList: true,\n subtree: true\n });\n return observer;\n}\nfunction createDetachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver((entries)=>{\n let trigger = false;\n for (const entry of entries){\n trigger = trigger || nodeListContains(entry.removedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.addedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {\n childList: true,\n subtree: true\n });\n return observer;\n}\nconst drpListeningCharts = new Map();\nlet oldDevicePixelRatio = 0;\nfunction onWindowResize() {\n const dpr = window.devicePixelRatio;\n if (dpr === oldDevicePixelRatio) {\n return;\n }\n oldDevicePixelRatio = dpr;\n drpListeningCharts.forEach((resize, chart)=>{\n if (chart.currentDevicePixelRatio !== dpr) {\n resize();\n }\n });\n}\nfunction listenDevicePixelRatioChanges(chart, resize) {\n if (!drpListeningCharts.size) {\n window.addEventListener('resize', onWindowResize);\n }\n drpListeningCharts.set(chart, resize);\n}\nfunction unlistenDevicePixelRatioChanges(chart) {\n drpListeningCharts.delete(chart);\n if (!drpListeningCharts.size) {\n window.removeEventListener('resize', onWindowResize);\n }\n}\nfunction createResizeObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n return;\n }\n const resize = throttled((width, height)=>{\n const w = container.clientWidth;\n listener(width, height);\n if (w < container.clientWidth) {\n listener();\n }\n }, window);\n const observer = new ResizeObserver((entries)=>{\n const entry = entries[0];\n const width = entry.contentRect.width;\n const height = entry.contentRect.height;\n if (width === 0 && height === 0) {\n return;\n }\n resize(width, height);\n });\n observer.observe(container);\n listenDevicePixelRatioChanges(chart, resize);\n return observer;\n}\nfunction releaseObserver(chart, type, observer) {\n if (observer) {\n observer.disconnect();\n }\n if (type === 'resize') {\n unlistenDevicePixelRatioChanges(chart);\n }\n}\nfunction createProxyAndListen(chart, type, listener) {\n const canvas = chart.canvas;\n const proxy = throttled((event)=>{\n if (chart.ctx !== null) {\n listener(fromNativeEvent(event, chart));\n }\n }, chart);\n addListener(canvas, type, proxy);\n return proxy;\n}\n class DomPlatform extends BasePlatform {\n acquireContext(canvas, aspectRatio) {\n const context = canvas && canvas.getContext && canvas.getContext('2d');\n if (context && context.canvas === canvas) {\n initCanvas(canvas, aspectRatio);\n return context;\n }\n return null;\n }\n releaseContext(context) {\n const canvas = context.canvas;\n if (!canvas[EXPANDO_KEY]) {\n return false;\n }\n const initial = canvas[EXPANDO_KEY].initial;\n [\n 'height',\n 'width'\n ].forEach((prop)=>{\n const value = initial[prop];\n if (isNullOrUndef(value)) {\n canvas.removeAttribute(prop);\n } else {\n canvas.setAttribute(prop, value);\n }\n });\n const style = initial.style || {};\n Object.keys(style).forEach((key)=>{\n canvas.style[key] = style[key];\n });\n canvas.width = canvas.width;\n delete canvas[EXPANDO_KEY];\n return true;\n }\n addEventListener(chart, type, listener) {\n this.removeEventListener(chart, type);\n const proxies = chart.$proxies || (chart.$proxies = {});\n const handlers = {\n attach: createAttachObserver,\n detach: createDetachObserver,\n resize: createResizeObserver\n };\n const handler = handlers[type] || createProxyAndListen;\n proxies[type] = handler(chart, type, listener);\n }\n removeEventListener(chart, type) {\n const proxies = chart.$proxies || (chart.$proxies = {});\n const proxy = proxies[type];\n if (!proxy) {\n return;\n }\n const handlers = {\n attach: releaseObserver,\n detach: releaseObserver,\n resize: releaseObserver\n };\n const handler = handlers[type] || removeListener;\n handler(chart, type, proxy);\n proxies[type] = undefined;\n }\n getDevicePixelRatio() {\n return window.devicePixelRatio;\n }\n getMaximumSize(canvas, width, height, aspectRatio) {\n return getMaximumSize(canvas, width, height, aspectRatio);\n }\n isAttached(canvas) {\n const container = _getParentNode(canvas);\n return !!(container && container.isConnected);\n }\n}\n\nfunction _detectPlatform(canvas) {\n if (!_isDomSupported() || typeof OffscreenCanvas !== 'undefined' && canvas instanceof OffscreenCanvas) {\n return BasicPlatform;\n }\n return DomPlatform;\n}\n\nclass Element {\n static defaults = {};\n static defaultRoutes = undefined;\n active = false;\n tooltipPosition(useFinalPosition) {\n const { x , y } = this.getProps([\n 'x',\n 'y'\n ], useFinalPosition);\n return {\n x,\n y\n };\n }\n hasValue() {\n return isNumber(this.x) && isNumber(this.y);\n }\n getProps(props, final) {\n const anims = this.$animations;\n if (!final || !anims) {\n // let's not create an object, if not needed\n return this;\n }\n const ret = {};\n props.forEach((prop)=>{\n ret[prop] = anims[prop] && anims[prop].active() ? anims[prop]._to : this[prop];\n });\n return ret;\n }\n}\n\nfunction autoSkip(scale, ticks) {\n const tickOpts = scale.options.ticks;\n const determinedMaxTicks = determineMaxTicks(scale);\n const ticksLimit = Math.min(tickOpts.maxTicksLimit || determinedMaxTicks, determinedMaxTicks);\n const majorIndices = tickOpts.major.enabled ? getMajorIndices(ticks) : [];\n const numMajorIndices = majorIndices.length;\n const first = majorIndices[0];\n const last = majorIndices[numMajorIndices - 1];\n const newTicks = [];\n if (numMajorIndices > ticksLimit) {\n skipMajors(ticks, newTicks, majorIndices, numMajorIndices / ticksLimit);\n return newTicks;\n }\n const spacing = calculateSpacing(majorIndices, ticks, ticksLimit);\n if (numMajorIndices > 0) {\n let i, ilen;\n const avgMajorSpacing = numMajorIndices > 1 ? Math.round((last - first) / (numMajorIndices - 1)) : null;\n skip(ticks, newTicks, spacing, isNullOrUndef(avgMajorSpacing) ? 0 : first - avgMajorSpacing, first);\n for(i = 0, ilen = numMajorIndices - 1; i < ilen; i++){\n skip(ticks, newTicks, spacing, majorIndices[i], majorIndices[i + 1]);\n }\n skip(ticks, newTicks, spacing, last, isNullOrUndef(avgMajorSpacing) ? ticks.length : last + avgMajorSpacing);\n return newTicks;\n }\n skip(ticks, newTicks, spacing);\n return newTicks;\n}\nfunction determineMaxTicks(scale) {\n const offset = scale.options.offset;\n const tickLength = scale._tickSize();\n const maxScale = scale._length / tickLength + (offset ? 0 : 1);\n const maxChart = scale._maxLength / tickLength;\n return Math.floor(Math.min(maxScale, maxChart));\n}\n function calculateSpacing(majorIndices, ticks, ticksLimit) {\n const evenMajorSpacing = getEvenSpacing(majorIndices);\n const spacing = ticks.length / ticksLimit;\n if (!evenMajorSpacing) {\n return Math.max(spacing, 1);\n }\n const factors = _factorize(evenMajorSpacing);\n for(let i = 0, ilen = factors.length - 1; i < ilen; i++){\n const factor = factors[i];\n if (factor > spacing) {\n return factor;\n }\n }\n return Math.max(spacing, 1);\n}\n function getMajorIndices(ticks) {\n const result = [];\n let i, ilen;\n for(i = 0, ilen = ticks.length; i < ilen; i++){\n if (ticks[i].major) {\n result.push(i);\n }\n }\n return result;\n}\n function skipMajors(ticks, newTicks, majorIndices, spacing) {\n let count = 0;\n let next = majorIndices[0];\n let i;\n spacing = Math.ceil(spacing);\n for(i = 0; i < ticks.length; i++){\n if (i === next) {\n newTicks.push(ticks[i]);\n count++;\n next = majorIndices[count * spacing];\n }\n }\n}\n function skip(ticks, newTicks, spacing, majorStart, majorEnd) {\n const start = valueOrDefault(majorStart, 0);\n const end = Math.min(valueOrDefault(majorEnd, ticks.length), ticks.length);\n let count = 0;\n let length, i, next;\n spacing = Math.ceil(spacing);\n if (majorEnd) {\n length = majorEnd - majorStart;\n spacing = length / Math.floor(length / spacing);\n }\n next = start;\n while(next < 0){\n count++;\n next = Math.round(start + count * spacing);\n }\n for(i = Math.max(start, 0); i < end; i++){\n if (i === next) {\n newTicks.push(ticks[i]);\n count++;\n next = Math.round(start + count * spacing);\n }\n }\n}\n function getEvenSpacing(arr) {\n const len = arr.length;\n let i, diff;\n if (len < 2) {\n return false;\n }\n for(diff = arr[0], i = 1; i < len; ++i){\n if (arr[i] - arr[i - 1] !== diff) {\n return false;\n }\n }\n return diff;\n}\n\nconst reverseAlign = (align)=>align === 'left' ? 'right' : align === 'right' ? 'left' : align;\nconst offsetFromEdge = (scale, edge, offset)=>edge === 'top' || edge === 'left' ? scale[edge] + offset : scale[edge] - offset;\nconst getTicksLimit = (ticksLength, maxTicksLimit)=>Math.min(maxTicksLimit || ticksLength, ticksLength);\n function sample(arr, numItems) {\n const result = [];\n const increment = arr.length / numItems;\n const len = arr.length;\n let i = 0;\n for(; i < len; i += increment){\n result.push(arr[Math.floor(i)]);\n }\n return result;\n}\n function getPixelForGridLine(scale, index, offsetGridLines) {\n const length = scale.ticks.length;\n const validIndex = Math.min(index, length - 1);\n const start = scale._startPixel;\n const end = scale._endPixel;\n const epsilon = 1e-6;\n let lineValue = scale.getPixelForTick(validIndex);\n let offset;\n if (offsetGridLines) {\n if (length === 1) {\n offset = Math.max(lineValue - start, end - lineValue);\n } else if (index === 0) {\n offset = (scale.getPixelForTick(1) - lineValue) / 2;\n } else {\n offset = (lineValue - scale.getPixelForTick(validIndex - 1)) / 2;\n }\n lineValue += validIndex < index ? offset : -offset;\n if (lineValue < start - epsilon || lineValue > end + epsilon) {\n return;\n }\n }\n return lineValue;\n}\n function garbageCollect(caches, length) {\n each(caches, (cache)=>{\n const gc = cache.gc;\n const gcLen = gc.length / 2;\n let i;\n if (gcLen > length) {\n for(i = 0; i < gcLen; ++i){\n delete cache.data[gc[i]];\n }\n gc.splice(0, gcLen);\n }\n });\n}\n function getTickMarkLength(options) {\n return options.drawTicks ? options.tickLength : 0;\n}\n function getTitleHeight(options, fallback) {\n if (!options.display) {\n return 0;\n }\n const font = toFont(options.font, fallback);\n const padding = toPadding(options.padding);\n const lines = isArray(options.text) ? options.text.length : 1;\n return lines * font.lineHeight + padding.height;\n}\nfunction createScaleContext(parent, scale) {\n return createContext(parent, {\n scale,\n type: 'scale'\n });\n}\nfunction createTickContext(parent, index, tick) {\n return createContext(parent, {\n tick,\n index,\n type: 'tick'\n });\n}\nfunction titleAlign(align, position, reverse) {\n let ret = _toLeftRightCenter(align);\n if (reverse && position !== 'right' || !reverse && position === 'right') {\n ret = reverseAlign(ret);\n }\n return ret;\n}\nfunction titleArgs(scale, offset, position, align) {\n const { top , left , bottom , right , chart } = scale;\n const { chartArea , scales } = chart;\n let rotation = 0;\n let maxWidth, titleX, titleY;\n const height = bottom - top;\n const width = right - left;\n if (scale.isHorizontal()) {\n titleX = _alignStartEnd(align, left, right);\n if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n titleY = scales[positionAxisID].getPixelForValue(value) + height - offset;\n } else if (position === 'center') {\n titleY = (chartArea.bottom + chartArea.top) / 2 + height - offset;\n } else {\n titleY = offsetFromEdge(scale, position, offset);\n }\n maxWidth = right - left;\n } else {\n if (isObject(position)) {\n const positionAxisID1 = Object.keys(position)[0];\n const value1 = position[positionAxisID1];\n titleX = scales[positionAxisID1].getPixelForValue(value1) - width + offset;\n } else if (position === 'center') {\n titleX = (chartArea.left + chartArea.right) / 2 - width + offset;\n } else {\n titleX = offsetFromEdge(scale, position, offset);\n }\n titleY = _alignStartEnd(align, bottom, top);\n rotation = position === 'left' ? -HALF_PI : HALF_PI;\n }\n return {\n titleX,\n titleY,\n maxWidth,\n rotation\n };\n}\nclass Scale extends Element {\n constructor(cfg){\n super();\n this.id = cfg.id;\n this.type = cfg.type;\n this.options = undefined;\n this.ctx = cfg.ctx;\n this.chart = cfg.chart;\n this.top = undefined;\n this.bottom = undefined;\n this.left = undefined;\n this.right = undefined;\n this.width = undefined;\n this.height = undefined;\n this._margins = {\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n };\n this.maxWidth = undefined;\n this.maxHeight = undefined;\n this.paddingTop = undefined;\n this.paddingBottom = undefined;\n this.paddingLeft = undefined;\n this.paddingRight = undefined;\n this.axis = undefined;\n this.labelRotation = undefined;\n this.min = undefined;\n this.max = undefined;\n this._range = undefined;\n this.ticks = [];\n this._gridLineItems = null;\n this._labelItems = null;\n this._labelSizes = null;\n this._length = 0;\n this._maxLength = 0;\n this._longestTextCache = {};\n this._startPixel = undefined;\n this._endPixel = undefined;\n this._reversePixels = false;\n this._userMax = undefined;\n this._userMin = undefined;\n this._suggestedMax = undefined;\n this._suggestedMin = undefined;\n this._ticksLength = 0;\n this._borderValue = 0;\n this._cache = {};\n this._dataLimitsCached = false;\n this.$context = undefined;\n }\n init(options) {\n this.options = options.setContext(this.getContext());\n this.axis = options.axis;\n this._userMin = this.parse(options.min);\n this._userMax = this.parse(options.max);\n this._suggestedMin = this.parse(options.suggestedMin);\n this._suggestedMax = this.parse(options.suggestedMax);\n }\n parse(raw, index) {\n return raw;\n }\n getUserBounds() {\n let { _userMin , _userMax , _suggestedMin , _suggestedMax } = this;\n _userMin = finiteOrDefault(_userMin, Number.POSITIVE_INFINITY);\n _userMax = finiteOrDefault(_userMax, Number.NEGATIVE_INFINITY);\n _suggestedMin = finiteOrDefault(_suggestedMin, Number.POSITIVE_INFINITY);\n _suggestedMax = finiteOrDefault(_suggestedMax, Number.NEGATIVE_INFINITY);\n return {\n min: finiteOrDefault(_userMin, _suggestedMin),\n max: finiteOrDefault(_userMax, _suggestedMax),\n minDefined: isNumberFinite(_userMin),\n maxDefined: isNumberFinite(_userMax)\n };\n }\n getMinMax(canStack) {\n let { min , max , minDefined , maxDefined } = this.getUserBounds();\n let range;\n if (minDefined && maxDefined) {\n return {\n min,\n max\n };\n }\n const metas = this.getMatchingVisibleMetas();\n for(let i = 0, ilen = metas.length; i < ilen; ++i){\n range = metas[i].controller.getMinMax(this, canStack);\n if (!minDefined) {\n min = Math.min(min, range.min);\n }\n if (!maxDefined) {\n max = Math.max(max, range.max);\n }\n }\n min = maxDefined && min > max ? max : min;\n max = minDefined && min > max ? min : max;\n return {\n min: finiteOrDefault(min, finiteOrDefault(max, min)),\n max: finiteOrDefault(max, finiteOrDefault(min, max))\n };\n }\n getPadding() {\n return {\n left: this.paddingLeft || 0,\n top: this.paddingTop || 0,\n right: this.paddingRight || 0,\n bottom: this.paddingBottom || 0\n };\n }\n getTicks() {\n return this.ticks;\n }\n getLabels() {\n const data = this.chart.data;\n return this.options.labels || (this.isHorizontal() ? data.xLabels : data.yLabels) || data.labels || [];\n }\n getLabelItems(chartArea = this.chart.chartArea) {\n const items = this._labelItems || (this._labelItems = this._computeLabelItems(chartArea));\n return items;\n }\n beforeLayout() {\n this._cache = {};\n this._dataLimitsCached = false;\n }\n beforeUpdate() {\n callback(this.options.beforeUpdate, [\n this\n ]);\n }\n update(maxWidth, maxHeight, margins) {\n const { beginAtZero , grace , ticks: tickOpts } = this.options;\n const sampleSize = tickOpts.sampleSize;\n this.beforeUpdate();\n this.maxWidth = maxWidth;\n this.maxHeight = maxHeight;\n this._margins = margins = Object.assign({\n left: 0,\n right: 0,\n top: 0,\n bottom: 0\n }, margins);\n this.ticks = null;\n this._labelSizes = null;\n this._gridLineItems = null;\n this._labelItems = null;\n this.beforeSetDimensions();\n this.setDimensions();\n this.afterSetDimensions();\n this._maxLength = this.isHorizontal() ? this.width + margins.left + margins.right : this.height + margins.top + margins.bottom;\n if (!this._dataLimitsCached) {\n this.beforeDataLimits();\n this.determineDataLimits();\n this.afterDataLimits();\n this._range = _addGrace(this, grace, beginAtZero);\n this._dataLimitsCached = true;\n }\n this.beforeBuildTicks();\n this.ticks = this.buildTicks() || [];\n this.afterBuildTicks();\n const samplingEnabled = sampleSize < this.ticks.length;\n this._convertTicksToLabels(samplingEnabled ? sample(this.ticks, sampleSize) : this.ticks);\n this.configure();\n this.beforeCalculateLabelRotation();\n this.calculateLabelRotation();\n this.afterCalculateLabelRotation();\n if (tickOpts.display && (tickOpts.autoSkip || tickOpts.source === 'auto')) {\n this.ticks = autoSkip(this, this.ticks);\n this._labelSizes = null;\n this.afterAutoSkip();\n }\n if (samplingEnabled) {\n this._convertTicksToLabels(this.ticks);\n }\n this.beforeFit();\n this.fit();\n this.afterFit();\n this.afterUpdate();\n }\n configure() {\n let reversePixels = this.options.reverse;\n let startPixel, endPixel;\n if (this.isHorizontal()) {\n startPixel = this.left;\n endPixel = this.right;\n } else {\n startPixel = this.top;\n endPixel = this.bottom;\n reversePixels = !reversePixels;\n }\n this._startPixel = startPixel;\n this._endPixel = endPixel;\n this._reversePixels = reversePixels;\n this._length = endPixel - startPixel;\n this._alignToPixels = this.options.alignToPixels;\n }\n afterUpdate() {\n callback(this.options.afterUpdate, [\n this\n ]);\n }\n beforeSetDimensions() {\n callback(this.options.beforeSetDimensions, [\n this\n ]);\n }\n setDimensions() {\n if (this.isHorizontal()) {\n this.width = this.maxWidth;\n this.left = 0;\n this.right = this.width;\n } else {\n this.height = this.maxHeight;\n this.top = 0;\n this.bottom = this.height;\n }\n this.paddingLeft = 0;\n this.paddingTop = 0;\n this.paddingRight = 0;\n this.paddingBottom = 0;\n }\n afterSetDimensions() {\n callback(this.options.afterSetDimensions, [\n this\n ]);\n }\n _callHooks(name) {\n this.chart.notifyPlugins(name, this.getContext());\n callback(this.options[name], [\n this\n ]);\n }\n beforeDataLimits() {\n this._callHooks('beforeDataLimits');\n }\n determineDataLimits() {}\n afterDataLimits() {\n this._callHooks('afterDataLimits');\n }\n beforeBuildTicks() {\n this._callHooks('beforeBuildTicks');\n }\n buildTicks() {\n return [];\n }\n afterBuildTicks() {\n this._callHooks('afterBuildTicks');\n }\n beforeTickToLabelConversion() {\n callback(this.options.beforeTickToLabelConversion, [\n this\n ]);\n }\n generateTickLabels(ticks) {\n const tickOpts = this.options.ticks;\n let i, ilen, tick;\n for(i = 0, ilen = ticks.length; i < ilen; i++){\n tick = ticks[i];\n tick.label = callback(tickOpts.callback, [\n tick.value,\n i,\n ticks\n ], this);\n }\n }\n afterTickToLabelConversion() {\n callback(this.options.afterTickToLabelConversion, [\n this\n ]);\n }\n beforeCalculateLabelRotation() {\n callback(this.options.beforeCalculateLabelRotation, [\n this\n ]);\n }\n calculateLabelRotation() {\n const options = this.options;\n const tickOpts = options.ticks;\n const numTicks = getTicksLimit(this.ticks.length, options.ticks.maxTicksLimit);\n const minRotation = tickOpts.minRotation || 0;\n const maxRotation = tickOpts.maxRotation;\n let labelRotation = minRotation;\n let tickWidth, maxHeight, maxLabelDiagonal;\n if (!this._isVisible() || !tickOpts.display || minRotation >= maxRotation || numTicks <= 1 || !this.isHorizontal()) {\n this.labelRotation = minRotation;\n return;\n }\n const labelSizes = this._getLabelSizes();\n const maxLabelWidth = labelSizes.widest.width;\n const maxLabelHeight = labelSizes.highest.height;\n const maxWidth = _limitValue(this.chart.width - maxLabelWidth, 0, this.maxWidth);\n tickWidth = options.offset ? this.maxWidth / numTicks : maxWidth / (numTicks - 1);\n if (maxLabelWidth + 6 > tickWidth) {\n tickWidth = maxWidth / (numTicks - (options.offset ? 0.5 : 1));\n maxHeight = this.maxHeight - getTickMarkLength(options.grid) - tickOpts.padding - getTitleHeight(options.title, this.chart.options.font);\n maxLabelDiagonal = Math.sqrt(maxLabelWidth * maxLabelWidth + maxLabelHeight * maxLabelHeight);\n labelRotation = toDegrees(Math.min(Math.asin(_limitValue((labelSizes.highest.height + 6) / tickWidth, -1, 1)), Math.asin(_limitValue(maxHeight / maxLabelDiagonal, -1, 1)) - Math.asin(_limitValue(maxLabelHeight / maxLabelDiagonal, -1, 1))));\n labelRotation = Math.max(minRotation, Math.min(maxRotation, labelRotation));\n }\n this.labelRotation = labelRotation;\n }\n afterCalculateLabelRotation() {\n callback(this.options.afterCalculateLabelRotation, [\n this\n ]);\n }\n afterAutoSkip() {}\n beforeFit() {\n callback(this.options.beforeFit, [\n this\n ]);\n }\n fit() {\n const minSize = {\n width: 0,\n height: 0\n };\n const { chart , options: { ticks: tickOpts , title: titleOpts , grid: gridOpts } } = this;\n const display = this._isVisible();\n const isHorizontal = this.isHorizontal();\n if (display) {\n const titleHeight = getTitleHeight(titleOpts, chart.options.font);\n if (isHorizontal) {\n minSize.width = this.maxWidth;\n minSize.height = getTickMarkLength(gridOpts) + titleHeight;\n } else {\n minSize.height = this.maxHeight;\n minSize.width = getTickMarkLength(gridOpts) + titleHeight;\n }\n if (tickOpts.display && this.ticks.length) {\n const { first , last , widest , highest } = this._getLabelSizes();\n const tickPadding = tickOpts.padding * 2;\n const angleRadians = toRadians(this.labelRotation);\n const cos = Math.cos(angleRadians);\n const sin = Math.sin(angleRadians);\n if (isHorizontal) {\n const labelHeight = tickOpts.mirror ? 0 : sin * widest.width + cos * highest.height;\n minSize.height = Math.min(this.maxHeight, minSize.height + labelHeight + tickPadding);\n } else {\n const labelWidth = tickOpts.mirror ? 0 : cos * widest.width + sin * highest.height;\n minSize.width = Math.min(this.maxWidth, minSize.width + labelWidth + tickPadding);\n }\n this._calculatePadding(first, last, sin, cos);\n }\n }\n this._handleMargins();\n if (isHorizontal) {\n this.width = this._length = chart.width - this._margins.left - this._margins.right;\n this.height = minSize.height;\n } else {\n this.width = minSize.width;\n this.height = this._length = chart.height - this._margins.top - this._margins.bottom;\n }\n }\n _calculatePadding(first, last, sin, cos) {\n const { ticks: { align , padding } , position } = this.options;\n const isRotated = this.labelRotation !== 0;\n const labelsBelowTicks = position !== 'top' && this.axis === 'x';\n if (this.isHorizontal()) {\n const offsetLeft = this.getPixelForTick(0) - this.left;\n const offsetRight = this.right - this.getPixelForTick(this.ticks.length - 1);\n let paddingLeft = 0;\n let paddingRight = 0;\n if (isRotated) {\n if (labelsBelowTicks) {\n paddingLeft = cos * first.width;\n paddingRight = sin * last.height;\n } else {\n paddingLeft = sin * first.height;\n paddingRight = cos * last.width;\n }\n } else if (align === 'start') {\n paddingRight = last.width;\n } else if (align === 'end') {\n paddingLeft = first.width;\n } else if (align !== 'inner') {\n paddingLeft = first.width / 2;\n paddingRight = last.width / 2;\n }\n this.paddingLeft = Math.max((paddingLeft - offsetLeft + padding) * this.width / (this.width - offsetLeft), 0);\n this.paddingRight = Math.max((paddingRight - offsetRight + padding) * this.width / (this.width - offsetRight), 0);\n } else {\n let paddingTop = last.height / 2;\n let paddingBottom = first.height / 2;\n if (align === 'start') {\n paddingTop = 0;\n paddingBottom = first.height;\n } else if (align === 'end') {\n paddingTop = last.height;\n paddingBottom = 0;\n }\n this.paddingTop = paddingTop + padding;\n this.paddingBottom = paddingBottom + padding;\n }\n }\n _handleMargins() {\n if (this._margins) {\n this._margins.left = Math.max(this.paddingLeft, this._margins.left);\n this._margins.top = Math.max(this.paddingTop, this._margins.top);\n this._margins.right = Math.max(this.paddingRight, this._margins.right);\n this._margins.bottom = Math.max(this.paddingBottom, this._margins.bottom);\n }\n }\n afterFit() {\n callback(this.options.afterFit, [\n this\n ]);\n }\n isHorizontal() {\n const { axis , position } = this.options;\n return position === 'top' || position === 'bottom' || axis === 'x';\n }\n isFullSize() {\n return this.options.fullSize;\n }\n _convertTicksToLabels(ticks) {\n this.beforeTickToLabelConversion();\n this.generateTickLabels(ticks);\n let i, ilen;\n for(i = 0, ilen = ticks.length; i < ilen; i++){\n if (isNullOrUndef(ticks[i].label)) {\n ticks.splice(i, 1);\n ilen--;\n i--;\n }\n }\n this.afterTickToLabelConversion();\n }\n _getLabelSizes() {\n let labelSizes = this._labelSizes;\n if (!labelSizes) {\n const sampleSize = this.options.ticks.sampleSize;\n let ticks = this.ticks;\n if (sampleSize < ticks.length) {\n ticks = sample(ticks, sampleSize);\n }\n this._labelSizes = labelSizes = this._computeLabelSizes(ticks, ticks.length, this.options.ticks.maxTicksLimit);\n }\n return labelSizes;\n }\n _computeLabelSizes(ticks, length, maxTicksLimit) {\n const { ctx , _longestTextCache: caches } = this;\n const widths = [];\n const heights = [];\n const increment = Math.floor(length / getTicksLimit(length, maxTicksLimit));\n let widestLabelSize = 0;\n let highestLabelSize = 0;\n let i, j, jlen, label, tickFont, fontString, cache, lineHeight, width, height, nestedLabel;\n for(i = 0; i < length; i += increment){\n label = ticks[i].label;\n tickFont = this._resolveTickFontOptions(i);\n ctx.font = fontString = tickFont.string;\n cache = caches[fontString] = caches[fontString] || {\n data: {},\n gc: []\n };\n lineHeight = tickFont.lineHeight;\n width = height = 0;\n if (!isNullOrUndef(label) && !isArray(label)) {\n width = _measureText(ctx, cache.data, cache.gc, width, label);\n height = lineHeight;\n } else if (isArray(label)) {\n for(j = 0, jlen = label.length; j < jlen; ++j){\n nestedLabel = label[j];\n if (!isNullOrUndef(nestedLabel) && !isArray(nestedLabel)) {\n width = _measureText(ctx, cache.data, cache.gc, width, nestedLabel);\n height += lineHeight;\n }\n }\n }\n widths.push(width);\n heights.push(height);\n widestLabelSize = Math.max(width, widestLabelSize);\n highestLabelSize = Math.max(height, highestLabelSize);\n }\n garbageCollect(caches, length);\n const widest = widths.indexOf(widestLabelSize);\n const highest = heights.indexOf(highestLabelSize);\n const valueAt = (idx)=>({\n width: widths[idx] || 0,\n height: heights[idx] || 0\n });\n return {\n first: valueAt(0),\n last: valueAt(length - 1),\n widest: valueAt(widest),\n highest: valueAt(highest),\n widths,\n heights\n };\n }\n getLabelForValue(value) {\n return value;\n }\n getPixelForValue(value, index) {\n return NaN;\n }\n getValueForPixel(pixel) {}\n getPixelForTick(index) {\n const ticks = this.ticks;\n if (index < 0 || index > ticks.length - 1) {\n return null;\n }\n return this.getPixelForValue(ticks[index].value);\n }\n getPixelForDecimal(decimal) {\n if (this._reversePixels) {\n decimal = 1 - decimal;\n }\n const pixel = this._startPixel + decimal * this._length;\n return _int16Range(this._alignToPixels ? _alignPixel(this.chart, pixel, 0) : pixel);\n }\n getDecimalForPixel(pixel) {\n const decimal = (pixel - this._startPixel) / this._length;\n return this._reversePixels ? 1 - decimal : decimal;\n }\n getBasePixel() {\n return this.getPixelForValue(this.getBaseValue());\n }\n getBaseValue() {\n const { min , max } = this;\n return min < 0 && max < 0 ? max : min > 0 && max > 0 ? min : 0;\n }\n getContext(index) {\n const ticks = this.ticks || [];\n if (index >= 0 && index < ticks.length) {\n const tick = ticks[index];\n return tick.$context || (tick.$context = createTickContext(this.getContext(), index, tick));\n }\n return this.$context || (this.$context = createScaleContext(this.chart.getContext(), this));\n }\n _tickSize() {\n const optionTicks = this.options.ticks;\n const rot = toRadians(this.labelRotation);\n const cos = Math.abs(Math.cos(rot));\n const sin = Math.abs(Math.sin(rot));\n const labelSizes = this._getLabelSizes();\n const padding = optionTicks.autoSkipPadding || 0;\n const w = labelSizes ? labelSizes.widest.width + padding : 0;\n const h = labelSizes ? labelSizes.highest.height + padding : 0;\n return this.isHorizontal() ? h * cos > w * sin ? w / cos : h / sin : h * sin < w * cos ? h / cos : w / sin;\n }\n _isVisible() {\n const display = this.options.display;\n if (display !== 'auto') {\n return !!display;\n }\n return this.getMatchingVisibleMetas().length > 0;\n }\n _computeGridLineItems(chartArea) {\n const axis = this.axis;\n const chart = this.chart;\n const options = this.options;\n const { grid , position , border } = options;\n const offset = grid.offset;\n const isHorizontal = this.isHorizontal();\n const ticks = this.ticks;\n const ticksLength = ticks.length + (offset ? 1 : 0);\n const tl = getTickMarkLength(grid);\n const items = [];\n const borderOpts = border.setContext(this.getContext());\n const axisWidth = borderOpts.display ? borderOpts.width : 0;\n const axisHalfWidth = axisWidth / 2;\n const alignBorderValue = function(pixel) {\n return _alignPixel(chart, pixel, axisWidth);\n };\n let borderValue, i, lineValue, alignedLineValue;\n let tx1, ty1, tx2, ty2, x1, y1, x2, y2;\n if (position === 'top') {\n borderValue = alignBorderValue(this.bottom);\n ty1 = this.bottom - tl;\n ty2 = borderValue - axisHalfWidth;\n y1 = alignBorderValue(chartArea.top) + axisHalfWidth;\n y2 = chartArea.bottom;\n } else if (position === 'bottom') {\n borderValue = alignBorderValue(this.top);\n y1 = chartArea.top;\n y2 = alignBorderValue(chartArea.bottom) - axisHalfWidth;\n ty1 = borderValue + axisHalfWidth;\n ty2 = this.top + tl;\n } else if (position === 'left') {\n borderValue = alignBorderValue(this.right);\n tx1 = this.right - tl;\n tx2 = borderValue - axisHalfWidth;\n x1 = alignBorderValue(chartArea.left) + axisHalfWidth;\n x2 = chartArea.right;\n } else if (position === 'right') {\n borderValue = alignBorderValue(this.left);\n x1 = chartArea.left;\n x2 = alignBorderValue(chartArea.right) - axisHalfWidth;\n tx1 = borderValue + axisHalfWidth;\n tx2 = this.left + tl;\n } else if (axis === 'x') {\n if (position === 'center') {\n borderValue = alignBorderValue((chartArea.top + chartArea.bottom) / 2 + 0.5);\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n borderValue = alignBorderValue(this.chart.scales[positionAxisID].getPixelForValue(value));\n }\n y1 = chartArea.top;\n y2 = chartArea.bottom;\n ty1 = borderValue + axisHalfWidth;\n ty2 = ty1 + tl;\n } else if (axis === 'y') {\n if (position === 'center') {\n borderValue = alignBorderValue((chartArea.left + chartArea.right) / 2);\n } else if (isObject(position)) {\n const positionAxisID1 = Object.keys(position)[0];\n const value1 = position[positionAxisID1];\n borderValue = alignBorderValue(this.chart.scales[positionAxisID1].getPixelForValue(value1));\n }\n tx1 = borderValue - axisHalfWidth;\n tx2 = tx1 - tl;\n x1 = chartArea.left;\n x2 = chartArea.right;\n }\n const limit = valueOrDefault(options.ticks.maxTicksLimit, ticksLength);\n const step = Math.max(1, Math.ceil(ticksLength / limit));\n for(i = 0; i < ticksLength; i += step){\n const context = this.getContext(i);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n const lineWidth = optsAtIndex.lineWidth;\n const lineColor = optsAtIndex.color;\n const borderDash = optsAtIndexBorder.dash || [];\n const borderDashOffset = optsAtIndexBorder.dashOffset;\n const tickWidth = optsAtIndex.tickWidth;\n const tickColor = optsAtIndex.tickColor;\n const tickBorderDash = optsAtIndex.tickBorderDash || [];\n const tickBorderDashOffset = optsAtIndex.tickBorderDashOffset;\n lineValue = getPixelForGridLine(this, i, offset);\n if (lineValue === undefined) {\n continue;\n }\n alignedLineValue = _alignPixel(chart, lineValue, lineWidth);\n if (isHorizontal) {\n tx1 = tx2 = x1 = x2 = alignedLineValue;\n } else {\n ty1 = ty2 = y1 = y2 = alignedLineValue;\n }\n items.push({\n tx1,\n ty1,\n tx2,\n ty2,\n x1,\n y1,\n x2,\n y2,\n width: lineWidth,\n color: lineColor,\n borderDash,\n borderDashOffset,\n tickWidth,\n tickColor,\n tickBorderDash,\n tickBorderDashOffset\n });\n }\n this._ticksLength = ticksLength;\n this._borderValue = borderValue;\n return items;\n }\n _computeLabelItems(chartArea) {\n const axis = this.axis;\n const options = this.options;\n const { position , ticks: optionTicks } = options;\n const isHorizontal = this.isHorizontal();\n const ticks = this.ticks;\n const { align , crossAlign , padding , mirror } = optionTicks;\n const tl = getTickMarkLength(options.grid);\n const tickAndPadding = tl + padding;\n const hTickAndPadding = mirror ? -padding : tickAndPadding;\n const rotation = -toRadians(this.labelRotation);\n const items = [];\n let i, ilen, tick, label, x, y, textAlign, pixel, font, lineHeight, lineCount, textOffset;\n let textBaseline = 'middle';\n if (position === 'top') {\n y = this.bottom - hTickAndPadding;\n textAlign = this._getXAxisLabelAlignment();\n } else if (position === 'bottom') {\n y = this.top + hTickAndPadding;\n textAlign = this._getXAxisLabelAlignment();\n } else if (position === 'left') {\n const ret = this._getYAxisLabelAlignment(tl);\n textAlign = ret.textAlign;\n x = ret.x;\n } else if (position === 'right') {\n const ret1 = this._getYAxisLabelAlignment(tl);\n textAlign = ret1.textAlign;\n x = ret1.x;\n } else if (axis === 'x') {\n if (position === 'center') {\n y = (chartArea.top + chartArea.bottom) / 2 + tickAndPadding;\n } else if (isObject(position)) {\n const positionAxisID = Object.keys(position)[0];\n const value = position[positionAxisID];\n y = this.chart.scales[positionAxisID].getPixelForValue(value) + tickAndPadding;\n }\n textAlign = this._getXAxisLabelAlignment();\n } else if (axis === 'y') {\n if (position === 'center') {\n x = (chartArea.left + chartArea.right) / 2 - tickAndPadding;\n } else if (isObject(position)) {\n const positionAxisID1 = Object.keys(position)[0];\n const value1 = position[positionAxisID1];\n x = this.chart.scales[positionAxisID1].getPixelForValue(value1);\n }\n textAlign = this._getYAxisLabelAlignment(tl).textAlign;\n }\n if (axis === 'y') {\n if (align === 'start') {\n textBaseline = 'top';\n } else if (align === 'end') {\n textBaseline = 'bottom';\n }\n }\n const labelSizes = this._getLabelSizes();\n for(i = 0, ilen = ticks.length; i < ilen; ++i){\n tick = ticks[i];\n label = tick.label;\n const optsAtIndex = optionTicks.setContext(this.getContext(i));\n pixel = this.getPixelForTick(i) + optionTicks.labelOffset;\n font = this._resolveTickFontOptions(i);\n lineHeight = font.lineHeight;\n lineCount = isArray(label) ? label.length : 1;\n const halfCount = lineCount / 2;\n const color = optsAtIndex.color;\n const strokeColor = optsAtIndex.textStrokeColor;\n const strokeWidth = optsAtIndex.textStrokeWidth;\n let tickTextAlign = textAlign;\n if (isHorizontal) {\n x = pixel;\n if (textAlign === 'inner') {\n if (i === ilen - 1) {\n tickTextAlign = !this.options.reverse ? 'right' : 'left';\n } else if (i === 0) {\n tickTextAlign = !this.options.reverse ? 'left' : 'right';\n } else {\n tickTextAlign = 'center';\n }\n }\n if (position === 'top') {\n if (crossAlign === 'near' || rotation !== 0) {\n textOffset = -lineCount * lineHeight + lineHeight / 2;\n } else if (crossAlign === 'center') {\n textOffset = -labelSizes.highest.height / 2 - halfCount * lineHeight + lineHeight;\n } else {\n textOffset = -labelSizes.highest.height + lineHeight / 2;\n }\n } else {\n if (crossAlign === 'near' || rotation !== 0) {\n textOffset = lineHeight / 2;\n } else if (crossAlign === 'center') {\n textOffset = labelSizes.highest.height / 2 - halfCount * lineHeight;\n } else {\n textOffset = labelSizes.highest.height - lineCount * lineHeight;\n }\n }\n if (mirror) {\n textOffset *= -1;\n }\n if (rotation !== 0 && !optsAtIndex.showLabelBackdrop) {\n x += lineHeight / 2 * Math.sin(rotation);\n }\n } else {\n y = pixel;\n textOffset = (1 - lineCount) * lineHeight / 2;\n }\n let backdrop;\n if (optsAtIndex.showLabelBackdrop) {\n const labelPadding = toPadding(optsAtIndex.backdropPadding);\n const height = labelSizes.heights[i];\n const width = labelSizes.widths[i];\n let top = textOffset - labelPadding.top;\n let left = 0 - labelPadding.left;\n switch(textBaseline){\n case 'middle':\n top -= height / 2;\n break;\n case 'bottom':\n top -= height;\n break;\n }\n switch(textAlign){\n case 'center':\n left -= width / 2;\n break;\n case 'right':\n left -= width;\n break;\n }\n backdrop = {\n left,\n top,\n width: width + labelPadding.width,\n height: height + labelPadding.height,\n color: optsAtIndex.backdropColor\n };\n }\n items.push({\n label,\n font,\n textOffset,\n options: {\n rotation,\n color,\n strokeColor,\n strokeWidth,\n textAlign: tickTextAlign,\n textBaseline,\n translation: [\n x,\n y\n ],\n backdrop\n }\n });\n }\n return items;\n }\n _getXAxisLabelAlignment() {\n const { position , ticks } = this.options;\n const rotation = -toRadians(this.labelRotation);\n if (rotation) {\n return position === 'top' ? 'left' : 'right';\n }\n let align = 'center';\n if (ticks.align === 'start') {\n align = 'left';\n } else if (ticks.align === 'end') {\n align = 'right';\n } else if (ticks.align === 'inner') {\n align = 'inner';\n }\n return align;\n }\n _getYAxisLabelAlignment(tl) {\n const { position , ticks: { crossAlign , mirror , padding } } = this.options;\n const labelSizes = this._getLabelSizes();\n const tickAndPadding = tl + padding;\n const widest = labelSizes.widest.width;\n let textAlign;\n let x;\n if (position === 'left') {\n if (mirror) {\n x = this.right + padding;\n if (crossAlign === 'near') {\n textAlign = 'left';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x += widest / 2;\n } else {\n textAlign = 'right';\n x += widest;\n }\n } else {\n x = this.right - tickAndPadding;\n if (crossAlign === 'near') {\n textAlign = 'right';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x -= widest / 2;\n } else {\n textAlign = 'left';\n x = this.left;\n }\n }\n } else if (position === 'right') {\n if (mirror) {\n x = this.left + padding;\n if (crossAlign === 'near') {\n textAlign = 'right';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x -= widest / 2;\n } else {\n textAlign = 'left';\n x -= widest;\n }\n } else {\n x = this.left + tickAndPadding;\n if (crossAlign === 'near') {\n textAlign = 'left';\n } else if (crossAlign === 'center') {\n textAlign = 'center';\n x += widest / 2;\n } else {\n textAlign = 'right';\n x = this.right;\n }\n }\n } else {\n textAlign = 'right';\n }\n return {\n textAlign,\n x\n };\n }\n _computeLabelArea() {\n if (this.options.ticks.mirror) {\n return;\n }\n const chart = this.chart;\n const position = this.options.position;\n if (position === 'left' || position === 'right') {\n return {\n top: 0,\n left: this.left,\n bottom: chart.height,\n right: this.right\n };\n }\n if (position === 'top' || position === 'bottom') {\n return {\n top: this.top,\n left: 0,\n bottom: this.bottom,\n right: chart.width\n };\n }\n }\n drawBackground() {\n const { ctx , options: { backgroundColor } , left , top , width , height } = this;\n if (backgroundColor) {\n ctx.save();\n ctx.fillStyle = backgroundColor;\n ctx.fillRect(left, top, width, height);\n ctx.restore();\n }\n }\n getLineWidthForValue(value) {\n const grid = this.options.grid;\n if (!this._isVisible() || !grid.display) {\n return 0;\n }\n const ticks = this.ticks;\n const index = ticks.findIndex((t)=>t.value === value);\n if (index >= 0) {\n const opts = grid.setContext(this.getContext(index));\n return opts.lineWidth;\n }\n return 0;\n }\n drawGrid(chartArea) {\n const grid = this.options.grid;\n const ctx = this.ctx;\n const items = this._gridLineItems || (this._gridLineItems = this._computeGridLineItems(chartArea));\n let i, ilen;\n const drawLine = (p1, p2, style)=>{\n if (!style.width || !style.color) {\n return;\n }\n ctx.save();\n ctx.lineWidth = style.width;\n ctx.strokeStyle = style.color;\n ctx.setLineDash(style.borderDash || []);\n ctx.lineDashOffset = style.borderDashOffset;\n ctx.beginPath();\n ctx.moveTo(p1.x, p1.y);\n ctx.lineTo(p2.x, p2.y);\n ctx.stroke();\n ctx.restore();\n };\n if (grid.display) {\n for(i = 0, ilen = items.length; i < ilen; ++i){\n const item = items[i];\n if (grid.drawOnChartArea) {\n drawLine({\n x: item.x1,\n y: item.y1\n }, {\n x: item.x2,\n y: item.y2\n }, item);\n }\n if (grid.drawTicks) {\n drawLine({\n x: item.tx1,\n y: item.ty1\n }, {\n x: item.tx2,\n y: item.ty2\n }, {\n color: item.tickColor,\n width: item.tickWidth,\n borderDash: item.tickBorderDash,\n borderDashOffset: item.tickBorderDashOffset\n });\n }\n }\n }\n }\n drawBorder() {\n const { chart , ctx , options: { border , grid } } = this;\n const borderOpts = border.setContext(this.getContext());\n const axisWidth = border.display ? borderOpts.width : 0;\n if (!axisWidth) {\n return;\n }\n const lastLineWidth = grid.setContext(this.getContext(0)).lineWidth;\n const borderValue = this._borderValue;\n let x1, x2, y1, y2;\n if (this.isHorizontal()) {\n x1 = _alignPixel(chart, this.left, axisWidth) - axisWidth / 2;\n x2 = _alignPixel(chart, this.right, lastLineWidth) + lastLineWidth / 2;\n y1 = y2 = borderValue;\n } else {\n y1 = _alignPixel(chart, this.top, axisWidth) - axisWidth / 2;\n y2 = _alignPixel(chart, this.bottom, lastLineWidth) + lastLineWidth / 2;\n x1 = x2 = borderValue;\n }\n ctx.save();\n ctx.lineWidth = borderOpts.width;\n ctx.strokeStyle = borderOpts.color;\n ctx.beginPath();\n ctx.moveTo(x1, y1);\n ctx.lineTo(x2, y2);\n ctx.stroke();\n ctx.restore();\n }\n drawLabels(chartArea) {\n const optionTicks = this.options.ticks;\n if (!optionTicks.display) {\n return;\n }\n const ctx = this.ctx;\n const area = this._computeLabelArea();\n if (area) {\n clipArea(ctx, area);\n }\n const items = this.getLabelItems(chartArea);\n for (const item of items){\n const renderTextOptions = item.options;\n const tickFont = item.font;\n const label = item.label;\n const y = item.textOffset;\n renderText(ctx, label, 0, y, tickFont, renderTextOptions);\n }\n if (area) {\n unclipArea(ctx);\n }\n }\n drawTitle() {\n const { ctx , options: { position , title , reverse } } = this;\n if (!title.display) {\n return;\n }\n const font = toFont(title.font);\n const padding = toPadding(title.padding);\n const align = title.align;\n let offset = font.lineHeight / 2;\n if (position === 'bottom' || position === 'center' || isObject(position)) {\n offset += padding.bottom;\n if (isArray(title.text)) {\n offset += font.lineHeight * (title.text.length - 1);\n }\n } else {\n offset += padding.top;\n }\n const { titleX , titleY , maxWidth , rotation } = titleArgs(this, offset, position, align);\n renderText(ctx, title.text, 0, 0, font, {\n color: title.color,\n maxWidth,\n rotation,\n textAlign: titleAlign(align, position, reverse),\n textBaseline: 'middle',\n translation: [\n titleX,\n titleY\n ]\n });\n }\n draw(chartArea) {\n if (!this._isVisible()) {\n return;\n }\n this.drawBackground();\n this.drawGrid(chartArea);\n this.drawBorder();\n this.drawTitle();\n this.drawLabels(chartArea);\n }\n _layers() {\n const opts = this.options;\n const tz = opts.ticks && opts.ticks.z || 0;\n const gz = valueOrDefault(opts.grid && opts.grid.z, -1);\n const bz = valueOrDefault(opts.border && opts.border.z, 0);\n if (!this._isVisible() || this.draw !== Scale.prototype.draw) {\n return [\n {\n z: tz,\n draw: (chartArea)=>{\n this.draw(chartArea);\n }\n }\n ];\n }\n return [\n {\n z: gz,\n draw: (chartArea)=>{\n this.drawBackground();\n this.drawGrid(chartArea);\n this.drawTitle();\n }\n },\n {\n z: bz,\n draw: ()=>{\n this.drawBorder();\n }\n },\n {\n z: tz,\n draw: (chartArea)=>{\n this.drawLabels(chartArea);\n }\n }\n ];\n }\n getMatchingVisibleMetas(type) {\n const metas = this.chart.getSortedVisibleDatasetMetas();\n const axisID = this.axis + 'AxisID';\n const result = [];\n let i, ilen;\n for(i = 0, ilen = metas.length; i < ilen; ++i){\n const meta = metas[i];\n if (meta[axisID] === this.id && (!type || meta.type === type)) {\n result.push(meta);\n }\n }\n return result;\n }\n _resolveTickFontOptions(index) {\n const opts = this.options.ticks.setContext(this.getContext(index));\n return toFont(opts.font);\n }\n _maxDigits() {\n const fontSize = this._resolveTickFontOptions(0).lineHeight;\n return (this.isHorizontal() ? this.width : this.height) / fontSize;\n }\n}\n\nclass TypedRegistry {\n constructor(type, scope, override){\n this.type = type;\n this.scope = scope;\n this.override = override;\n this.items = Object.create(null);\n }\n isForType(type) {\n return Object.prototype.isPrototypeOf.call(this.type.prototype, type.prototype);\n }\n register(item) {\n const proto = Object.getPrototypeOf(item);\n let parentScope;\n if (isIChartComponent(proto)) {\n parentScope = this.register(proto);\n }\n const items = this.items;\n const id = item.id;\n const scope = this.scope + '.' + id;\n if (!id) {\n throw new Error('class does not have id: ' + item);\n }\n if (id in items) {\n return scope;\n }\n items[id] = item;\n registerDefaults(item, scope, parentScope);\n if (this.override) {\n defaults.override(item.id, item.overrides);\n }\n return scope;\n }\n get(id) {\n return this.items[id];\n }\n unregister(item) {\n const items = this.items;\n const id = item.id;\n const scope = this.scope;\n if (id in items) {\n delete items[id];\n }\n if (scope && id in defaults[scope]) {\n delete defaults[scope][id];\n if (this.override) {\n delete overrides[id];\n }\n }\n }\n}\nfunction registerDefaults(item, scope, parentScope) {\n const itemDefaults = merge(Object.create(null), [\n parentScope ? defaults.get(parentScope) : {},\n defaults.get(scope),\n item.defaults\n ]);\n defaults.set(scope, itemDefaults);\n if (item.defaultRoutes) {\n routeDefaults(scope, item.defaultRoutes);\n }\n if (item.descriptors) {\n defaults.describe(scope, item.descriptors);\n }\n}\nfunction routeDefaults(scope, routes) {\n Object.keys(routes).forEach((property)=>{\n const propertyParts = property.split('.');\n const sourceName = propertyParts.pop();\n const sourceScope = [\n scope\n ].concat(propertyParts).join('.');\n const parts = routes[property].split('.');\n const targetName = parts.pop();\n const targetScope = parts.join('.');\n defaults.route(sourceScope, sourceName, targetScope, targetName);\n });\n}\nfunction isIChartComponent(proto) {\n return 'id' in proto && 'defaults' in proto;\n}\n\nclass Registry {\n constructor(){\n this.controllers = new TypedRegistry(DatasetController, 'datasets', true);\n this.elements = new TypedRegistry(Element, 'elements');\n this.plugins = new TypedRegistry(Object, 'plugins');\n this.scales = new TypedRegistry(Scale, 'scales');\n this._typedRegistries = [\n this.controllers,\n this.scales,\n this.elements\n ];\n }\n add(...args) {\n this._each('register', args);\n }\n remove(...args) {\n this._each('unregister', args);\n }\n addControllers(...args) {\n this._each('register', args, this.controllers);\n }\n addElements(...args) {\n this._each('register', args, this.elements);\n }\n addPlugins(...args) {\n this._each('register', args, this.plugins);\n }\n addScales(...args) {\n this._each('register', args, this.scales);\n }\n getController(id) {\n return this._get(id, this.controllers, 'controller');\n }\n getElement(id) {\n return this._get(id, this.elements, 'element');\n }\n getPlugin(id) {\n return this._get(id, this.plugins, 'plugin');\n }\n getScale(id) {\n return this._get(id, this.scales, 'scale');\n }\n removeControllers(...args) {\n this._each('unregister', args, this.controllers);\n }\n removeElements(...args) {\n this._each('unregister', args, this.elements);\n }\n removePlugins(...args) {\n this._each('unregister', args, this.plugins);\n }\n removeScales(...args) {\n this._each('unregister', args, this.scales);\n }\n _each(method, args, typedRegistry) {\n [\n ...args\n ].forEach((arg)=>{\n const reg = typedRegistry || this._getRegistryForType(arg);\n if (typedRegistry || reg.isForType(arg) || reg === this.plugins && arg.id) {\n this._exec(method, reg, arg);\n } else {\n each(arg, (item)=>{\n const itemReg = typedRegistry || this._getRegistryForType(item);\n this._exec(method, itemReg, item);\n });\n }\n });\n }\n _exec(method, registry, component) {\n const camelMethod = _capitalize(method);\n callback(component['before' + camelMethod], [], component);\n registry[method](component);\n callback(component['after' + camelMethod], [], component);\n }\n _getRegistryForType(type) {\n for(let i = 0; i < this._typedRegistries.length; i++){\n const reg = this._typedRegistries[i];\n if (reg.isForType(type)) {\n return reg;\n }\n }\n return this.plugins;\n }\n _get(id, typedRegistry, type) {\n const item = typedRegistry.get(id);\n if (item === undefined) {\n throw new Error('\"' + id + '\" is not a registered ' + type + '.');\n }\n return item;\n }\n}\nvar registry = /* #__PURE__ */ new Registry();\n\nclass PluginService {\n constructor(){\n this._init = [];\n }\n notify(chart, hook, args, filter) {\n if (hook === 'beforeInit') {\n this._init = this._createDescriptors(chart, true);\n this._notify(this._init, chart, 'install');\n }\n const descriptors = filter ? this._descriptors(chart).filter(filter) : this._descriptors(chart);\n const result = this._notify(descriptors, chart, hook, args);\n if (hook === 'afterDestroy') {\n this._notify(descriptors, chart, 'stop');\n this._notify(this._init, chart, 'uninstall');\n }\n return result;\n }\n _notify(descriptors, chart, hook, args) {\n args = args || {};\n for (const descriptor of descriptors){\n const plugin = descriptor.plugin;\n const method = plugin[hook];\n const params = [\n chart,\n args,\n descriptor.options\n ];\n if (callback(method, params, plugin) === false && args.cancelable) {\n return false;\n }\n }\n return true;\n }\n invalidate() {\n if (!isNullOrUndef(this._cache)) {\n this._oldCache = this._cache;\n this._cache = undefined;\n }\n }\n _descriptors(chart) {\n if (this._cache) {\n return this._cache;\n }\n const descriptors = this._cache = this._createDescriptors(chart);\n this._notifyStateChanges(chart);\n return descriptors;\n }\n _createDescriptors(chart, all) {\n const config = chart && chart.config;\n const options = valueOrDefault(config.options && config.options.plugins, {});\n const plugins = allPlugins(config);\n return options === false && !all ? [] : createDescriptors(chart, plugins, options, all);\n }\n _notifyStateChanges(chart) {\n const previousDescriptors = this._oldCache || [];\n const descriptors = this._cache;\n const diff = (a, b)=>a.filter((x)=>!b.some((y)=>x.plugin.id === y.plugin.id));\n this._notify(diff(previousDescriptors, descriptors), chart, 'stop');\n this._notify(diff(descriptors, previousDescriptors), chart, 'start');\n }\n}\n function allPlugins(config) {\n const localIds = {};\n const plugins = [];\n const keys = Object.keys(registry.plugins.items);\n for(let i = 0; i < keys.length; i++){\n plugins.push(registry.getPlugin(keys[i]));\n }\n const local = config.plugins || [];\n for(let i1 = 0; i1 < local.length; i1++){\n const plugin = local[i1];\n if (plugins.indexOf(plugin) === -1) {\n plugins.push(plugin);\n localIds[plugin.id] = true;\n }\n }\n return {\n plugins,\n localIds\n };\n}\nfunction getOpts(options, all) {\n if (!all && options === false) {\n return null;\n }\n if (options === true) {\n return {};\n }\n return options;\n}\nfunction createDescriptors(chart, { plugins , localIds }, options, all) {\n const result = [];\n const context = chart.getContext();\n for (const plugin of plugins){\n const id = plugin.id;\n const opts = getOpts(options[id], all);\n if (opts === null) {\n continue;\n }\n result.push({\n plugin,\n options: pluginOpts(chart.config, {\n plugin,\n local: localIds[id]\n }, opts, context)\n });\n }\n return result;\n}\nfunction pluginOpts(config, { plugin , local }, opts, context) {\n const keys = config.pluginScopeKeys(plugin);\n const scopes = config.getOptionScopes(opts, keys);\n if (local && plugin.defaults) {\n scopes.push(plugin.defaults);\n }\n return config.createResolver(scopes, context, [\n ''\n ], {\n scriptable: false,\n indexable: false,\n allKeys: true\n });\n}\n\nfunction getIndexAxis(type, options) {\n const datasetDefaults = defaults.datasets[type] || {};\n const datasetOptions = (options.datasets || {})[type] || {};\n return datasetOptions.indexAxis || options.indexAxis || datasetDefaults.indexAxis || 'x';\n}\nfunction getAxisFromDefaultScaleID(id, indexAxis) {\n let axis = id;\n if (id === '_index_') {\n axis = indexAxis;\n } else if (id === '_value_') {\n axis = indexAxis === 'x' ? 'y' : 'x';\n }\n return axis;\n}\nfunction getDefaultScaleIDFromAxis(axis, indexAxis) {\n return axis === indexAxis ? '_index_' : '_value_';\n}\nfunction axisFromPosition(position) {\n if (position === 'top' || position === 'bottom') {\n return 'x';\n }\n if (position === 'left' || position === 'right') {\n return 'y';\n }\n}\nfunction determineAxis(id, scaleOptions) {\n if (id === 'x' || id === 'y' || id === 'r') {\n return id;\n }\n id = scaleOptions.axis || axisFromPosition(scaleOptions.position) || id.length > 1 && determineAxis(id[0].toLowerCase(), scaleOptions);\n if (id) {\n return id;\n }\n throw new Error(`Cannot determine type of '${name}' axis. Please provide 'axis' or 'position' option.`);\n}\nfunction mergeScaleConfig(config, options) {\n const chartDefaults = overrides[config.type] || {\n scales: {}\n };\n const configScales = options.scales || {};\n const chartIndexAxis = getIndexAxis(config.type, options);\n const scales = Object.create(null);\n Object.keys(configScales).forEach((id)=>{\n const scaleConf = configScales[id];\n if (!isObject(scaleConf)) {\n return console.error(`Invalid scale configuration for scale: ${id}`);\n }\n if (scaleConf._proxy) {\n return console.warn(`Ignoring resolver passed as options for scale: ${id}`);\n }\n const axis = determineAxis(id, scaleConf);\n const defaultId = getDefaultScaleIDFromAxis(axis, chartIndexAxis);\n const defaultScaleOptions = chartDefaults.scales || {};\n scales[id] = mergeIf(Object.create(null), [\n {\n axis\n },\n scaleConf,\n defaultScaleOptions[axis],\n defaultScaleOptions[defaultId]\n ]);\n });\n config.data.datasets.forEach((dataset)=>{\n const type = dataset.type || config.type;\n const indexAxis = dataset.indexAxis || getIndexAxis(type, options);\n const datasetDefaults = overrides[type] || {};\n const defaultScaleOptions = datasetDefaults.scales || {};\n Object.keys(defaultScaleOptions).forEach((defaultID)=>{\n const axis = getAxisFromDefaultScaleID(defaultID, indexAxis);\n const id = dataset[axis + 'AxisID'] || axis;\n scales[id] = scales[id] || Object.create(null);\n mergeIf(scales[id], [\n {\n axis\n },\n configScales[id],\n defaultScaleOptions[defaultID]\n ]);\n });\n });\n Object.keys(scales).forEach((key)=>{\n const scale = scales[key];\n mergeIf(scale, [\n defaults.scales[scale.type],\n defaults.scale\n ]);\n });\n return scales;\n}\nfunction initOptions(config) {\n const options = config.options || (config.options = {});\n options.plugins = valueOrDefault(options.plugins, {});\n options.scales = mergeScaleConfig(config, options);\n}\nfunction initData(data) {\n data = data || {};\n data.datasets = data.datasets || [];\n data.labels = data.labels || [];\n return data;\n}\nfunction initConfig(config) {\n config = config || {};\n config.data = initData(config.data);\n initOptions(config);\n return config;\n}\nconst keyCache = new Map();\nconst keysCached = new Set();\nfunction cachedKeys(cacheKey, generate) {\n let keys = keyCache.get(cacheKey);\n if (!keys) {\n keys = generate();\n keyCache.set(cacheKey, keys);\n keysCached.add(keys);\n }\n return keys;\n}\nconst addIfFound = (set, obj, key)=>{\n const opts = resolveObjectKey(obj, key);\n if (opts !== undefined) {\n set.add(opts);\n }\n};\nclass Config {\n constructor(config){\n this._config = initConfig(config);\n this._scopeCache = new Map();\n this._resolverCache = new Map();\n }\n get platform() {\n return this._config.platform;\n }\n get type() {\n return this._config.type;\n }\n set type(type) {\n this._config.type = type;\n }\n get data() {\n return this._config.data;\n }\n set data(data) {\n this._config.data = initData(data);\n }\n get options() {\n return this._config.options;\n }\n set options(options) {\n this._config.options = options;\n }\n get plugins() {\n return this._config.plugins;\n }\n update() {\n const config = this._config;\n this.clearCache();\n initOptions(config);\n }\n clearCache() {\n this._scopeCache.clear();\n this._resolverCache.clear();\n }\n datasetScopeKeys(datasetType) {\n return cachedKeys(datasetType, ()=>[\n [\n `datasets.${datasetType}`,\n ''\n ]\n ]);\n }\n datasetAnimationScopeKeys(datasetType, transition) {\n return cachedKeys(`${datasetType}.transition.${transition}`, ()=>[\n [\n `datasets.${datasetType}.transitions.${transition}`,\n `transitions.${transition}`\n ],\n [\n `datasets.${datasetType}`,\n ''\n ]\n ]);\n }\n datasetElementScopeKeys(datasetType, elementType) {\n return cachedKeys(`${datasetType}-${elementType}`, ()=>[\n [\n `datasets.${datasetType}.elements.${elementType}`,\n `datasets.${datasetType}`,\n `elements.${elementType}`,\n ''\n ]\n ]);\n }\n pluginScopeKeys(plugin) {\n const id = plugin.id;\n const type = this.type;\n return cachedKeys(`${type}-plugin-${id}`, ()=>[\n [\n `plugins.${id}`,\n ...plugin.additionalOptionScopes || []\n ]\n ]);\n }\n _cachedScopes(mainScope, resetCache) {\n const _scopeCache = this._scopeCache;\n let cache = _scopeCache.get(mainScope);\n if (!cache || resetCache) {\n cache = new Map();\n _scopeCache.set(mainScope, cache);\n }\n return cache;\n }\n getOptionScopes(mainScope, keyLists, resetCache) {\n const { options , type } = this;\n const cache = this._cachedScopes(mainScope, resetCache);\n const cached = cache.get(keyLists);\n if (cached) {\n return cached;\n }\n const scopes = new Set();\n keyLists.forEach((keys)=>{\n if (mainScope) {\n scopes.add(mainScope);\n keys.forEach((key)=>addIfFound(scopes, mainScope, key));\n }\n keys.forEach((key)=>addIfFound(scopes, options, key));\n keys.forEach((key)=>addIfFound(scopes, overrides[type] || {}, key));\n keys.forEach((key)=>addIfFound(scopes, defaults, key));\n keys.forEach((key)=>addIfFound(scopes, descriptors, key));\n });\n const array = Array.from(scopes);\n if (array.length === 0) {\n array.push(Object.create(null));\n }\n if (keysCached.has(keyLists)) {\n cache.set(keyLists, array);\n }\n return array;\n }\n chartOptionScopes() {\n const { options , type } = this;\n return [\n options,\n overrides[type] || {},\n defaults.datasets[type] || {},\n {\n type\n },\n defaults,\n descriptors\n ];\n }\n resolveNamedOptions(scopes, names, context, prefixes = [\n ''\n ]) {\n const result = {\n $shared: true\n };\n const { resolver , subPrefixes } = getResolver(this._resolverCache, scopes, prefixes);\n let options = resolver;\n if (needContext(resolver, names)) {\n result.$shared = false;\n context = isFunction(context) ? context() : context;\n const subResolver = this.createResolver(scopes, context, subPrefixes);\n options = _attachContext(resolver, context, subResolver);\n }\n for (const prop of names){\n result[prop] = options[prop];\n }\n return result;\n }\n createResolver(scopes, context, prefixes = [\n ''\n ], descriptorDefaults) {\n const { resolver } = getResolver(this._resolverCache, scopes, prefixes);\n return isObject(context) ? _attachContext(resolver, context, undefined, descriptorDefaults) : resolver;\n }\n}\nfunction getResolver(resolverCache, scopes, prefixes) {\n let cache = resolverCache.get(scopes);\n if (!cache) {\n cache = new Map();\n resolverCache.set(scopes, cache);\n }\n const cacheKey = prefixes.join();\n let cached = cache.get(cacheKey);\n if (!cached) {\n const resolver = _createResolver(scopes, prefixes);\n cached = {\n resolver,\n subPrefixes: prefixes.filter((p)=>!p.toLowerCase().includes('hover'))\n };\n cache.set(cacheKey, cached);\n }\n return cached;\n}\nconst hasFunction = (value)=>isObject(value) && Object.getOwnPropertyNames(value).reduce((acc, key)=>acc || isFunction(value[key]), false);\nfunction needContext(proxy, names) {\n const { isScriptable , isIndexable } = _descriptors(proxy);\n for (const prop of names){\n const scriptable = isScriptable(prop);\n const indexable = isIndexable(prop);\n const value = (indexable || scriptable) && proxy[prop];\n if (scriptable && (isFunction(value) || hasFunction(value)) || indexable && isArray(value)) {\n return true;\n }\n }\n return false;\n}\n\nvar version = \"4.2.1\";\n\nconst KNOWN_POSITIONS = [\n 'top',\n 'bottom',\n 'left',\n 'right',\n 'chartArea'\n];\nfunction positionIsHorizontal(position, axis) {\n return position === 'top' || position === 'bottom' || KNOWN_POSITIONS.indexOf(position) === -1 && axis === 'x';\n}\nfunction compare2Level(l1, l2) {\n return function(a, b) {\n return a[l1] === b[l1] ? a[l2] - b[l2] : a[l1] - b[l1];\n };\n}\nfunction onAnimationsComplete(context) {\n const chart = context.chart;\n const animationOptions = chart.options.animation;\n chart.notifyPlugins('afterRender');\n callback(animationOptions && animationOptions.onComplete, [\n context\n ], chart);\n}\nfunction onAnimationProgress(context) {\n const chart = context.chart;\n const animationOptions = chart.options.animation;\n callback(animationOptions && animationOptions.onProgress, [\n context\n ], chart);\n}\n function getCanvas(item) {\n if (_isDomSupported() && typeof item === 'string') {\n item = document.getElementById(item);\n } else if (item && item.length) {\n item = item[0];\n }\n if (item && item.canvas) {\n item = item.canvas;\n }\n return item;\n}\nconst instances = {};\nconst getChart = (key)=>{\n const canvas = getCanvas(key);\n return Object.values(instances).filter((c)=>c.canvas === canvas).pop();\n};\nfunction moveNumericKeys(obj, start, move) {\n const keys = Object.keys(obj);\n for (const key of keys){\n const intKey = +key;\n if (intKey >= start) {\n const value = obj[key];\n delete obj[key];\n if (move > 0 || intKey > start) {\n obj[intKey + move] = value;\n }\n }\n }\n}\n function determineLastEvent(e, lastEvent, inChartArea, isClick) {\n if (!inChartArea || e.type === 'mouseout') {\n return null;\n }\n if (isClick) {\n return lastEvent;\n }\n return e;\n}\nfunction getDatasetArea(meta) {\n const { xScale , yScale } = meta;\n if (xScale && yScale) {\n return {\n left: xScale.left,\n right: xScale.right,\n top: yScale.top,\n bottom: yScale.bottom\n };\n }\n}\nclass Chart {\n static defaults = defaults;\n static instances = instances;\n static overrides = overrides;\n static registry = registry;\n static version = version;\n static getChart = getChart;\n static register(...items) {\n registry.add(...items);\n invalidatePlugins();\n }\n static unregister(...items) {\n registry.remove(...items);\n invalidatePlugins();\n }\n constructor(item, userConfig){\n const config = this.config = new Config(userConfig);\n const initialCanvas = getCanvas(item);\n const existingChart = getChart(initialCanvas);\n if (existingChart) {\n throw new Error('Canvas is already in use. Chart with ID \\'' + existingChart.id + '\\'' + ' must be destroyed before the canvas with ID \\'' + existingChart.canvas.id + '\\' can be reused.');\n }\n const options = config.createResolver(config.chartOptionScopes(), this.getContext());\n this.platform = new (config.platform || _detectPlatform(initialCanvas))();\n this.platform.updateConfig(config);\n const context = this.platform.acquireContext(initialCanvas, options.aspectRatio);\n const canvas = context && context.canvas;\n const height = canvas && canvas.height;\n const width = canvas && canvas.width;\n this.id = uid();\n this.ctx = context;\n this.canvas = canvas;\n this.width = width;\n this.height = height;\n this._options = options;\n this._aspectRatio = this.aspectRatio;\n this._layers = [];\n this._metasets = [];\n this._stacks = undefined;\n this.boxes = [];\n this.currentDevicePixelRatio = undefined;\n this.chartArea = undefined;\n this._active = [];\n this._lastEvent = undefined;\n this._listeners = {};\n this._responsiveListeners = undefined;\n this._sortedMetasets = [];\n this.scales = {};\n this._plugins = new PluginService();\n this.$proxies = {};\n this._hiddenIndices = {};\n this.attached = false;\n this._animationsDisabled = undefined;\n this.$context = undefined;\n this._doResize = debounce((mode)=>this.update(mode), options.resizeDelay || 0);\n this._dataChanges = [];\n instances[this.id] = this;\n if (!context || !canvas) {\n console.error(\"Failed to create chart: can't acquire context from the given item\");\n return;\n }\n animator.listen(this, 'complete', onAnimationsComplete);\n animator.listen(this, 'progress', onAnimationProgress);\n this._initialize();\n if (this.attached) {\n this.update();\n }\n }\n get aspectRatio() {\n const { options: { aspectRatio , maintainAspectRatio } , width , height , _aspectRatio } = this;\n if (!isNullOrUndef(aspectRatio)) {\n return aspectRatio;\n }\n if (maintainAspectRatio && _aspectRatio) {\n return _aspectRatio;\n }\n return height ? width / height : null;\n }\n get data() {\n return this.config.data;\n }\n set data(data) {\n this.config.data = data;\n }\n get options() {\n return this._options;\n }\n set options(options) {\n this.config.options = options;\n }\n get registry() {\n return registry;\n }\n _initialize() {\n this.notifyPlugins('beforeInit');\n if (this.options.responsive) {\n this.resize();\n } else {\n retinaScale(this, this.options.devicePixelRatio);\n }\n this.bindEvents();\n this.notifyPlugins('afterInit');\n return this;\n }\n clear() {\n clearCanvas(this.canvas, this.ctx);\n return this;\n }\n stop() {\n animator.stop(this);\n return this;\n }\n resize(width, height) {\n if (!animator.running(this)) {\n this._resize(width, height);\n } else {\n this._resizeBeforeDraw = {\n width,\n height\n };\n }\n }\n _resize(width, height) {\n const options = this.options;\n const canvas = this.canvas;\n const aspectRatio = options.maintainAspectRatio && this.aspectRatio;\n const newSize = this.platform.getMaximumSize(canvas, width, height, aspectRatio);\n const newRatio = options.devicePixelRatio || this.platform.getDevicePixelRatio();\n const mode = this.width ? 'resize' : 'attach';\n this.width = newSize.width;\n this.height = newSize.height;\n this._aspectRatio = this.aspectRatio;\n if (!retinaScale(this, newRatio, true)) {\n return;\n }\n this.notifyPlugins('resize', {\n size: newSize\n });\n callback(options.onResize, [\n this,\n newSize\n ], this);\n if (this.attached) {\n if (this._doResize(mode)) {\n this.render();\n }\n }\n }\n ensureScalesHaveIDs() {\n const options = this.options;\n const scalesOptions = options.scales || {};\n each(scalesOptions, (axisOptions, axisID)=>{\n axisOptions.id = axisID;\n });\n }\n buildOrUpdateScales() {\n const options = this.options;\n const scaleOpts = options.scales;\n const scales = this.scales;\n const updated = Object.keys(scales).reduce((obj, id)=>{\n obj[id] = false;\n return obj;\n }, {});\n let items = [];\n if (scaleOpts) {\n items = items.concat(Object.keys(scaleOpts).map((id)=>{\n const scaleOptions = scaleOpts[id];\n const axis = determineAxis(id, scaleOptions);\n const isRadial = axis === 'r';\n const isHorizontal = axis === 'x';\n return {\n options: scaleOptions,\n dposition: isRadial ? 'chartArea' : isHorizontal ? 'bottom' : 'left',\n dtype: isRadial ? 'radialLinear' : isHorizontal ? 'category' : 'linear'\n };\n }));\n }\n each(items, (item)=>{\n const scaleOptions = item.options;\n const id = scaleOptions.id;\n const axis = determineAxis(id, scaleOptions);\n const scaleType = valueOrDefault(scaleOptions.type, item.dtype);\n if (scaleOptions.position === undefined || positionIsHorizontal(scaleOptions.position, axis) !== positionIsHorizontal(item.dposition)) {\n scaleOptions.position = item.dposition;\n }\n updated[id] = true;\n let scale = null;\n if (id in scales && scales[id].type === scaleType) {\n scale = scales[id];\n } else {\n const scaleClass = registry.getScale(scaleType);\n scale = new scaleClass({\n id,\n type: scaleType,\n ctx: this.ctx,\n chart: this\n });\n scales[scale.id] = scale;\n }\n scale.init(scaleOptions, options);\n });\n each(updated, (hasUpdated, id)=>{\n if (!hasUpdated) {\n delete scales[id];\n }\n });\n each(scales, (scale)=>{\n layouts.configure(this, scale, scale.options);\n layouts.addBox(this, scale);\n });\n }\n _updateMetasets() {\n const metasets = this._metasets;\n const numData = this.data.datasets.length;\n const numMeta = metasets.length;\n metasets.sort((a, b)=>a.index - b.index);\n if (numMeta > numData) {\n for(let i = numData; i < numMeta; ++i){\n this._destroyDatasetMeta(i);\n }\n metasets.splice(numData, numMeta - numData);\n }\n this._sortedMetasets = metasets.slice(0).sort(compare2Level('order', 'index'));\n }\n _removeUnreferencedMetasets() {\n const { _metasets: metasets , data: { datasets } } = this;\n if (metasets.length > datasets.length) {\n delete this._stacks;\n }\n metasets.forEach((meta, index)=>{\n if (datasets.filter((x)=>x === meta._dataset).length === 0) {\n this._destroyDatasetMeta(index);\n }\n });\n }\n buildOrUpdateControllers() {\n const newControllers = [];\n const datasets = this.data.datasets;\n let i, ilen;\n this._removeUnreferencedMetasets();\n for(i = 0, ilen = datasets.length; i < ilen; i++){\n const dataset = datasets[i];\n let meta = this.getDatasetMeta(i);\n const type = dataset.type || this.config.type;\n if (meta.type && meta.type !== type) {\n this._destroyDatasetMeta(i);\n meta = this.getDatasetMeta(i);\n }\n meta.type = type;\n meta.indexAxis = dataset.indexAxis || getIndexAxis(type, this.options);\n meta.order = dataset.order || 0;\n meta.index = i;\n meta.label = '' + dataset.label;\n meta.visible = this.isDatasetVisible(i);\n if (meta.controller) {\n meta.controller.updateIndex(i);\n meta.controller.linkScales();\n } else {\n const ControllerClass = registry.getController(type);\n const { datasetElementType , dataElementType } = defaults.datasets[type];\n Object.assign(ControllerClass, {\n dataElementType: registry.getElement(dataElementType),\n datasetElementType: datasetElementType && registry.getElement(datasetElementType)\n });\n meta.controller = new ControllerClass(this, i);\n newControllers.push(meta.controller);\n }\n }\n this._updateMetasets();\n return newControllers;\n }\n _resetElements() {\n each(this.data.datasets, (dataset, datasetIndex)=>{\n this.getDatasetMeta(datasetIndex).controller.reset();\n }, this);\n }\n reset() {\n this._resetElements();\n this.notifyPlugins('reset');\n }\n update(mode) {\n const config = this.config;\n config.update();\n const options = this._options = config.createResolver(config.chartOptionScopes(), this.getContext());\n const animsDisabled = this._animationsDisabled = !options.animation;\n this._updateScales();\n this._checkEventBindings();\n this._updateHiddenIndices();\n this._plugins.invalidate();\n if (this.notifyPlugins('beforeUpdate', {\n mode,\n cancelable: true\n }) === false) {\n return;\n }\n const newControllers = this.buildOrUpdateControllers();\n this.notifyPlugins('beforeElementsUpdate');\n let minPadding = 0;\n for(let i = 0, ilen = this.data.datasets.length; i < ilen; i++){\n const { controller } = this.getDatasetMeta(i);\n const reset = !animsDisabled && newControllers.indexOf(controller) === -1;\n controller.buildOrUpdateElements(reset);\n minPadding = Math.max(+controller.getMaxOverflow(), minPadding);\n }\n minPadding = this._minPadding = options.layout.autoPadding ? minPadding : 0;\n this._updateLayout(minPadding);\n if (!animsDisabled) {\n each(newControllers, (controller)=>{\n controller.reset();\n });\n }\n this._updateDatasets(mode);\n this.notifyPlugins('afterUpdate', {\n mode\n });\n this._layers.sort(compare2Level('z', '_idx'));\n const { _active , _lastEvent } = this;\n if (_lastEvent) {\n this._eventHandler(_lastEvent, true);\n } else if (_active.length) {\n this._updateHoverStyles(_active, _active, true);\n }\n this.render();\n }\n _updateScales() {\n each(this.scales, (scale)=>{\n layouts.removeBox(this, scale);\n });\n this.ensureScalesHaveIDs();\n this.buildOrUpdateScales();\n }\n _checkEventBindings() {\n const options = this.options;\n const existingEvents = new Set(Object.keys(this._listeners));\n const newEvents = new Set(options.events);\n if (!setsEqual(existingEvents, newEvents) || !!this._responsiveListeners !== options.responsive) {\n this.unbindEvents();\n this.bindEvents();\n }\n }\n _updateHiddenIndices() {\n const { _hiddenIndices } = this;\n const changes = this._getUniformDataChanges() || [];\n for (const { method , start , count } of changes){\n const move = method === '_removeElements' ? -count : count;\n moveNumericKeys(_hiddenIndices, start, move);\n }\n }\n _getUniformDataChanges() {\n const _dataChanges = this._dataChanges;\n if (!_dataChanges || !_dataChanges.length) {\n return;\n }\n this._dataChanges = [];\n const datasetCount = this.data.datasets.length;\n const makeSet = (idx)=>new Set(_dataChanges.filter((c)=>c[0] === idx).map((c, i)=>i + ',' + c.splice(1).join(',')));\n const changeSet = makeSet(0);\n for(let i = 1; i < datasetCount; i++){\n if (!setsEqual(changeSet, makeSet(i))) {\n return;\n }\n }\n return Array.from(changeSet).map((c)=>c.split(',')).map((a)=>({\n method: a[1],\n start: +a[2],\n count: +a[3]\n }));\n }\n _updateLayout(minPadding) {\n if (this.notifyPlugins('beforeLayout', {\n cancelable: true\n }) === false) {\n return;\n }\n layouts.update(this, this.width, this.height, minPadding);\n const area = this.chartArea;\n const noArea = area.width <= 0 || area.height <= 0;\n this._layers = [];\n each(this.boxes, (box)=>{\n if (noArea && box.position === 'chartArea') {\n return;\n }\n if (box.configure) {\n box.configure();\n }\n this._layers.push(...box._layers());\n }, this);\n this._layers.forEach((item, index)=>{\n item._idx = index;\n });\n this.notifyPlugins('afterLayout');\n }\n _updateDatasets(mode) {\n if (this.notifyPlugins('beforeDatasetsUpdate', {\n mode,\n cancelable: true\n }) === false) {\n return;\n }\n for(let i = 0, ilen = this.data.datasets.length; i < ilen; ++i){\n this.getDatasetMeta(i).controller.configure();\n }\n for(let i1 = 0, ilen1 = this.data.datasets.length; i1 < ilen1; ++i1){\n this._updateDataset(i1, isFunction(mode) ? mode({\n datasetIndex: i1\n }) : mode);\n }\n this.notifyPlugins('afterDatasetsUpdate', {\n mode\n });\n }\n _updateDataset(index, mode) {\n const meta = this.getDatasetMeta(index);\n const args = {\n meta,\n index,\n mode,\n cancelable: true\n };\n if (this.notifyPlugins('beforeDatasetUpdate', args) === false) {\n return;\n }\n meta.controller._update(mode);\n args.cancelable = false;\n this.notifyPlugins('afterDatasetUpdate', args);\n }\n render() {\n if (this.notifyPlugins('beforeRender', {\n cancelable: true\n }) === false) {\n return;\n }\n if (animator.has(this)) {\n if (this.attached && !animator.running(this)) {\n animator.start(this);\n }\n } else {\n this.draw();\n onAnimationsComplete({\n chart: this\n });\n }\n }\n draw() {\n let i;\n if (this._resizeBeforeDraw) {\n const { width , height } = this._resizeBeforeDraw;\n this._resize(width, height);\n this._resizeBeforeDraw = null;\n }\n this.clear();\n if (this.width <= 0 || this.height <= 0) {\n return;\n }\n if (this.notifyPlugins('beforeDraw', {\n cancelable: true\n }) === false) {\n return;\n }\n const layers = this._layers;\n for(i = 0; i < layers.length && layers[i].z <= 0; ++i){\n layers[i].draw(this.chartArea);\n }\n this._drawDatasets();\n for(; i < layers.length; ++i){\n layers[i].draw(this.chartArea);\n }\n this.notifyPlugins('afterDraw');\n }\n _getSortedDatasetMetas(filterVisible) {\n const metasets = this._sortedMetasets;\n const result = [];\n let i, ilen;\n for(i = 0, ilen = metasets.length; i < ilen; ++i){\n const meta = metasets[i];\n if (!filterVisible || meta.visible) {\n result.push(meta);\n }\n }\n return result;\n }\n getSortedVisibleDatasetMetas() {\n return this._getSortedDatasetMetas(true);\n }\n _drawDatasets() {\n if (this.notifyPlugins('beforeDatasetsDraw', {\n cancelable: true\n }) === false) {\n return;\n }\n const metasets = this.getSortedVisibleDatasetMetas();\n for(let i = metasets.length - 1; i >= 0; --i){\n this._drawDataset(metasets[i]);\n }\n this.notifyPlugins('afterDatasetsDraw');\n }\n _drawDataset(meta) {\n const ctx = this.ctx;\n const clip = meta._clip;\n const useClip = !clip.disabled;\n const area = getDatasetArea(meta) || this.chartArea;\n const args = {\n meta,\n index: meta.index,\n cancelable: true\n };\n if (this.notifyPlugins('beforeDatasetDraw', args) === false) {\n return;\n }\n if (useClip) {\n clipArea(ctx, {\n left: clip.left === false ? 0 : area.left - clip.left,\n right: clip.right === false ? this.width : area.right + clip.right,\n top: clip.top === false ? 0 : area.top - clip.top,\n bottom: clip.bottom === false ? this.height : area.bottom + clip.bottom\n });\n }\n meta.controller.draw();\n if (useClip) {\n unclipArea(ctx);\n }\n args.cancelable = false;\n this.notifyPlugins('afterDatasetDraw', args);\n }\n isPointInArea(point) {\n return _isPointInArea(point, this.chartArea, this._minPadding);\n }\n getElementsAtEventForMode(e, mode, options, useFinalPosition) {\n const method = Interaction.modes[mode];\n if (typeof method === 'function') {\n return method(this, e, options, useFinalPosition);\n }\n return [];\n }\n getDatasetMeta(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n const metasets = this._metasets;\n let meta = metasets.filter((x)=>x && x._dataset === dataset).pop();\n if (!meta) {\n meta = {\n type: null,\n data: [],\n dataset: null,\n controller: null,\n hidden: null,\n xAxisID: null,\n yAxisID: null,\n order: dataset && dataset.order || 0,\n index: datasetIndex,\n _dataset: dataset,\n _parsed: [],\n _sorted: false\n };\n metasets.push(meta);\n }\n return meta;\n }\n getContext() {\n return this.$context || (this.$context = createContext(null, {\n chart: this,\n type: 'chart'\n }));\n }\n getVisibleDatasetCount() {\n return this.getSortedVisibleDatasetMetas().length;\n }\n isDatasetVisible(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n if (!dataset) {\n return false;\n }\n const meta = this.getDatasetMeta(datasetIndex);\n return typeof meta.hidden === 'boolean' ? !meta.hidden : !dataset.hidden;\n }\n setDatasetVisibility(datasetIndex, visible) {\n const meta = this.getDatasetMeta(datasetIndex);\n meta.hidden = !visible;\n }\n toggleDataVisibility(index) {\n this._hiddenIndices[index] = !this._hiddenIndices[index];\n }\n getDataVisibility(index) {\n return !this._hiddenIndices[index];\n }\n _updateVisibility(datasetIndex, dataIndex, visible) {\n const mode = visible ? 'show' : 'hide';\n const meta = this.getDatasetMeta(datasetIndex);\n const anims = meta.controller._resolveAnimations(undefined, mode);\n if (defined(dataIndex)) {\n meta.data[dataIndex].hidden = !visible;\n this.update();\n } else {\n this.setDatasetVisibility(datasetIndex, visible);\n anims.update(meta, {\n visible\n });\n this.update((ctx)=>ctx.datasetIndex === datasetIndex ? mode : undefined);\n }\n }\n hide(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, false);\n }\n show(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, true);\n }\n _destroyDatasetMeta(datasetIndex) {\n const meta = this._metasets[datasetIndex];\n if (meta && meta.controller) {\n meta.controller._destroy();\n }\n delete this._metasets[datasetIndex];\n }\n _stop() {\n let i, ilen;\n this.stop();\n animator.remove(this);\n for(i = 0, ilen = this.data.datasets.length; i < ilen; ++i){\n this._destroyDatasetMeta(i);\n }\n }\n destroy() {\n this.notifyPlugins('beforeDestroy');\n const { canvas , ctx } = this;\n this._stop();\n this.config.clearCache();\n if (canvas) {\n this.unbindEvents();\n clearCanvas(canvas, ctx);\n this.platform.releaseContext(ctx);\n this.canvas = null;\n this.ctx = null;\n }\n delete instances[this.id];\n this.notifyPlugins('afterDestroy');\n }\n toBase64Image(...args) {\n return this.canvas.toDataURL(...args);\n }\n bindEvents() {\n this.bindUserEvents();\n if (this.options.responsive) {\n this.bindResponsiveEvents();\n } else {\n this.attached = true;\n }\n }\n bindUserEvents() {\n const listeners = this._listeners;\n const platform = this.platform;\n const _add = (type, listener)=>{\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n const listener = (e, x, y)=>{\n e.offsetX = x;\n e.offsetY = y;\n this._eventHandler(e);\n };\n each(this.options.events, (type)=>_add(type, listener));\n }\n bindResponsiveEvents() {\n if (!this._responsiveListeners) {\n this._responsiveListeners = {};\n }\n const listeners = this._responsiveListeners;\n const platform = this.platform;\n const _add = (type, listener)=>{\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n const _remove = (type, listener)=>{\n if (listeners[type]) {\n platform.removeEventListener(this, type, listener);\n delete listeners[type];\n }\n };\n const listener = (width, height)=>{\n if (this.canvas) {\n this.resize(width, height);\n }\n };\n let detached;\n const attached = ()=>{\n _remove('attach', attached);\n this.attached = true;\n this.resize();\n _add('resize', listener);\n _add('detach', detached);\n };\n detached = ()=>{\n this.attached = false;\n _remove('resize', listener);\n this._stop();\n this._resize(0, 0);\n _add('attach', attached);\n };\n if (platform.isAttached(this.canvas)) {\n attached();\n } else {\n detached();\n }\n }\n unbindEvents() {\n each(this._listeners, (listener, type)=>{\n this.platform.removeEventListener(this, type, listener);\n });\n this._listeners = {};\n each(this._responsiveListeners, (listener, type)=>{\n this.platform.removeEventListener(this, type, listener);\n });\n this._responsiveListeners = undefined;\n }\n updateHoverStyle(items, mode, enabled) {\n const prefix = enabled ? 'set' : 'remove';\n let meta, item, i, ilen;\n if (mode === 'dataset') {\n meta = this.getDatasetMeta(items[0].datasetIndex);\n meta.controller['_' + prefix + 'DatasetHoverStyle']();\n }\n for(i = 0, ilen = items.length; i < ilen; ++i){\n item = items[i];\n const controller = item && this.getDatasetMeta(item.datasetIndex).controller;\n if (controller) {\n controller[prefix + 'HoverStyle'](item.element, item.datasetIndex, item.index);\n }\n }\n }\n getActiveElements() {\n return this._active || [];\n }\n setActiveElements(activeElements) {\n const lastActive = this._active || [];\n const active = activeElements.map(({ datasetIndex , index })=>{\n const meta = this.getDatasetMeta(datasetIndex);\n if (!meta) {\n throw new Error('No dataset found at index ' + datasetIndex);\n }\n return {\n datasetIndex,\n element: meta.data[index],\n index\n };\n });\n const changed = !_elementsEqual(active, lastActive);\n if (changed) {\n this._active = active;\n this._lastEvent = null;\n this._updateHoverStyles(active, lastActive);\n }\n }\n notifyPlugins(hook, args, filter) {\n return this._plugins.notify(this, hook, args, filter);\n }\n isPluginEnabled(pluginId) {\n return this._plugins._cache.filter((p)=>p.plugin.id === pluginId).length === 1;\n }\n _updateHoverStyles(active, lastActive, replay) {\n const hoverOptions = this.options.hover;\n const diff = (a, b)=>a.filter((x)=>!b.some((y)=>x.datasetIndex === y.datasetIndex && x.index === y.index));\n const deactivated = diff(lastActive, active);\n const activated = replay ? active : diff(active, lastActive);\n if (deactivated.length) {\n this.updateHoverStyle(deactivated, hoverOptions.mode, false);\n }\n if (activated.length && hoverOptions.mode) {\n this.updateHoverStyle(activated, hoverOptions.mode, true);\n }\n }\n _eventHandler(e, replay) {\n const args = {\n event: e,\n replay,\n cancelable: true,\n inChartArea: this.isPointInArea(e)\n };\n const eventFilter = (plugin)=>(plugin.options.events || this.options.events).includes(e.native.type);\n if (this.notifyPlugins('beforeEvent', args, eventFilter) === false) {\n return;\n }\n const changed = this._handleEvent(e, replay, args.inChartArea);\n args.cancelable = false;\n this.notifyPlugins('afterEvent', args, eventFilter);\n if (changed || args.changed) {\n this.render();\n }\n return this;\n }\n _handleEvent(e, replay, inChartArea) {\n const { _active: lastActive = [] , options } = this;\n const useFinalPosition = replay;\n const active = this._getActiveElements(e, lastActive, inChartArea, useFinalPosition);\n const isClick = _isClickEvent(e);\n const lastEvent = determineLastEvent(e, this._lastEvent, inChartArea, isClick);\n if (inChartArea) {\n this._lastEvent = null;\n callback(options.onHover, [\n e,\n active,\n this\n ], this);\n if (isClick) {\n callback(options.onClick, [\n e,\n active,\n this\n ], this);\n }\n }\n const changed = !_elementsEqual(active, lastActive);\n if (changed || replay) {\n this._active = active;\n this._updateHoverStyles(active, lastActive, replay);\n }\n this._lastEvent = lastEvent;\n return changed;\n }\n _getActiveElements(e, lastActive, inChartArea, useFinalPosition) {\n if (e.type === 'mouseout') {\n return [];\n }\n if (!inChartArea) {\n return lastActive;\n }\n const hoverOptions = this.options.hover;\n return this.getElementsAtEventForMode(e, hoverOptions.mode, hoverOptions, useFinalPosition);\n }\n}\nfunction invalidatePlugins() {\n return each(Chart.instances, (chart)=>chart._plugins.invalidate());\n}\n\nfunction clipArc(ctx, element, endAngle) {\n const { startAngle , pixelMargin , x , y , outerRadius , innerRadius } = element;\n let angleMargin = pixelMargin / outerRadius;\n // Draw an inner border by clipping the arc and drawing a double-width border\n // Enlarge the clipping arc by 0.33 pixels to eliminate glitches between borders\n ctx.beginPath();\n ctx.arc(x, y, outerRadius, startAngle - angleMargin, endAngle + angleMargin);\n if (innerRadius > pixelMargin) {\n angleMargin = pixelMargin / innerRadius;\n ctx.arc(x, y, innerRadius, endAngle + angleMargin, startAngle - angleMargin, true);\n } else {\n ctx.arc(x, y, pixelMargin, endAngle + HALF_PI, startAngle - HALF_PI);\n }\n ctx.closePath();\n ctx.clip();\n}\nfunction toRadiusCorners(value) {\n return _readValueToProps(value, [\n 'outerStart',\n 'outerEnd',\n 'innerStart',\n 'innerEnd'\n ]);\n}\n/**\n * Parse border radius from the provided options\n */ function parseBorderRadius$1(arc, innerRadius, outerRadius, angleDelta) {\n const o = toRadiusCorners(arc.options.borderRadius);\n const halfThickness = (outerRadius - innerRadius) / 2;\n const innerLimit = Math.min(halfThickness, angleDelta * innerRadius / 2);\n // Outer limits are complicated. We want to compute the available angular distance at\n // a radius of outerRadius - borderRadius because for small angular distances, this term limits.\n // We compute at r = outerRadius - borderRadius because this circle defines the center of the border corners.\n //\n // If the borderRadius is large, that value can become negative.\n // This causes the outer borders to lose their radius entirely, which is rather unexpected. To solve that, if borderRadius > outerRadius\n // we know that the thickness term will dominate and compute the limits at that point\n const computeOuterLimit = (val)=>{\n const outerArcLimit = (outerRadius - Math.min(halfThickness, val)) * angleDelta / 2;\n return _limitValue(val, 0, Math.min(halfThickness, outerArcLimit));\n };\n return {\n outerStart: computeOuterLimit(o.outerStart),\n outerEnd: computeOuterLimit(o.outerEnd),\n innerStart: _limitValue(o.innerStart, 0, innerLimit),\n innerEnd: _limitValue(o.innerEnd, 0, innerLimit)\n };\n}\n/**\n * Convert (r, 𝜃) to (x, y)\n */ function rThetaToXY(r, theta, x, y) {\n return {\n x: x + r * Math.cos(theta),\n y: y + r * Math.sin(theta)\n };\n}\n/**\n * Path the arc, respecting border radius by separating into left and right halves.\n *\n * Start End\n *\n * 1--->a--->2 Outer\n * / \\\n * 8 3\n * | |\n * | |\n * 7 4\n * \\ /\n * 6<---b<---5 Inner\n */ function pathArc(ctx, element, offset, spacing, end, circular) {\n const { x , y , startAngle: start , pixelMargin , innerRadius: innerR } = element;\n const outerRadius = Math.max(element.outerRadius + spacing + offset - pixelMargin, 0);\n const innerRadius = innerR > 0 ? innerR + spacing + offset + pixelMargin : 0;\n let spacingOffset = 0;\n const alpha = end - start;\n if (spacing) {\n // When spacing is present, it is the same for all items\n // So we adjust the start and end angle of the arc such that\n // the distance is the same as it would be without the spacing\n const noSpacingInnerRadius = innerR > 0 ? innerR - spacing : 0;\n const noSpacingOuterRadius = outerRadius > 0 ? outerRadius - spacing : 0;\n const avNogSpacingRadius = (noSpacingInnerRadius + noSpacingOuterRadius) / 2;\n const adjustedAngle = avNogSpacingRadius !== 0 ? alpha * avNogSpacingRadius / (avNogSpacingRadius + spacing) : alpha;\n spacingOffset = (alpha - adjustedAngle) / 2;\n }\n const beta = Math.max(0.001, alpha * outerRadius - offset / PI) / outerRadius;\n const angleOffset = (alpha - beta) / 2;\n const startAngle = start + angleOffset + spacingOffset;\n const endAngle = end - angleOffset - spacingOffset;\n const { outerStart , outerEnd , innerStart , innerEnd } = parseBorderRadius$1(element, innerRadius, outerRadius, endAngle - startAngle);\n const outerStartAdjustedRadius = outerRadius - outerStart;\n const outerEndAdjustedRadius = outerRadius - outerEnd;\n const outerStartAdjustedAngle = startAngle + outerStart / outerStartAdjustedRadius;\n const outerEndAdjustedAngle = endAngle - outerEnd / outerEndAdjustedRadius;\n const innerStartAdjustedRadius = innerRadius + innerStart;\n const innerEndAdjustedRadius = innerRadius + innerEnd;\n const innerStartAdjustedAngle = startAngle + innerStart / innerStartAdjustedRadius;\n const innerEndAdjustedAngle = endAngle - innerEnd / innerEndAdjustedRadius;\n ctx.beginPath();\n if (circular) {\n // The first arc segments from point 1 to point a to point 2\n const outerMidAdjustedAngle = (outerStartAdjustedAngle + outerEndAdjustedAngle) / 2;\n ctx.arc(x, y, outerRadius, outerStartAdjustedAngle, outerMidAdjustedAngle);\n ctx.arc(x, y, outerRadius, outerMidAdjustedAngle, outerEndAdjustedAngle);\n // The corner segment from point 2 to point 3\n if (outerEnd > 0) {\n const pCenter = rThetaToXY(outerEndAdjustedRadius, outerEndAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, outerEnd, outerEndAdjustedAngle, endAngle + HALF_PI);\n }\n // The line from point 3 to point 4\n const p4 = rThetaToXY(innerEndAdjustedRadius, endAngle, x, y);\n ctx.lineTo(p4.x, p4.y);\n // The corner segment from point 4 to point 5\n if (innerEnd > 0) {\n const pCenter1 = rThetaToXY(innerEndAdjustedRadius, innerEndAdjustedAngle, x, y);\n ctx.arc(pCenter1.x, pCenter1.y, innerEnd, endAngle + HALF_PI, innerEndAdjustedAngle + Math.PI);\n }\n // The inner arc from point 5 to point b to point 6\n const innerMidAdjustedAngle = (endAngle - innerEnd / innerRadius + (startAngle + innerStart / innerRadius)) / 2;\n ctx.arc(x, y, innerRadius, endAngle - innerEnd / innerRadius, innerMidAdjustedAngle, true);\n ctx.arc(x, y, innerRadius, innerMidAdjustedAngle, startAngle + innerStart / innerRadius, true);\n // The corner segment from point 6 to point 7\n if (innerStart > 0) {\n const pCenter2 = rThetaToXY(innerStartAdjustedRadius, innerStartAdjustedAngle, x, y);\n ctx.arc(pCenter2.x, pCenter2.y, innerStart, innerStartAdjustedAngle + Math.PI, startAngle - HALF_PI);\n }\n // The line from point 7 to point 8\n const p8 = rThetaToXY(outerStartAdjustedRadius, startAngle, x, y);\n ctx.lineTo(p8.x, p8.y);\n // The corner segment from point 8 to point 1\n if (outerStart > 0) {\n const pCenter3 = rThetaToXY(outerStartAdjustedRadius, outerStartAdjustedAngle, x, y);\n ctx.arc(pCenter3.x, pCenter3.y, outerStart, startAngle - HALF_PI, outerStartAdjustedAngle);\n }\n } else {\n ctx.moveTo(x, y);\n const outerStartX = Math.cos(outerStartAdjustedAngle) * outerRadius + x;\n const outerStartY = Math.sin(outerStartAdjustedAngle) * outerRadius + y;\n ctx.lineTo(outerStartX, outerStartY);\n const outerEndX = Math.cos(outerEndAdjustedAngle) * outerRadius + x;\n const outerEndY = Math.sin(outerEndAdjustedAngle) * outerRadius + y;\n ctx.lineTo(outerEndX, outerEndY);\n }\n ctx.closePath();\n}\nfunction drawArc(ctx, element, offset, spacing, circular) {\n const { fullCircles , startAngle , circumference } = element;\n let endAngle = element.endAngle;\n if (fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n for(let i = 0; i < fullCircles; ++i){\n ctx.fill();\n }\n if (!isNaN(circumference)) {\n endAngle = startAngle + (circumference % TAU || TAU);\n }\n }\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n ctx.fill();\n return endAngle;\n}\nfunction drawBorder(ctx, element, offset, spacing, circular) {\n const { fullCircles , startAngle , circumference , options } = element;\n const { borderWidth , borderJoinStyle } = options;\n const inner = options.borderAlign === 'inner';\n if (!borderWidth) {\n return;\n }\n if (inner) {\n ctx.lineWidth = borderWidth * 2;\n ctx.lineJoin = borderJoinStyle || 'round';\n } else {\n ctx.lineWidth = borderWidth;\n ctx.lineJoin = borderJoinStyle || 'bevel';\n }\n let endAngle = element.endAngle;\n if (fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n for(let i = 0; i < fullCircles; ++i){\n ctx.stroke();\n }\n if (!isNaN(circumference)) {\n endAngle = startAngle + (circumference % TAU || TAU);\n }\n }\n if (inner) {\n clipArc(ctx, element, endAngle);\n }\n if (!fullCircles) {\n pathArc(ctx, element, offset, spacing, endAngle, circular);\n ctx.stroke();\n }\n}\nclass ArcElement extends Element {\n static id = 'arc';\n static defaults = {\n borderAlign: 'center',\n borderColor: '#fff',\n borderJoinStyle: undefined,\n borderRadius: 0,\n borderWidth: 2,\n offset: 0,\n spacing: 0,\n angle: undefined,\n circular: true\n };\n static defaultRoutes = {\n backgroundColor: 'backgroundColor'\n };\n constructor(cfg){\n super();\n this.options = undefined;\n this.circumference = undefined;\n this.startAngle = undefined;\n this.endAngle = undefined;\n this.innerRadius = undefined;\n this.outerRadius = undefined;\n this.pixelMargin = 0;\n this.fullCircles = 0;\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n inRange(chartX, chartY, useFinalPosition) {\n const point = this.getProps([\n 'x',\n 'y'\n ], useFinalPosition);\n const { angle , distance } = getAngleFromPoint(point, {\n x: chartX,\n y: chartY\n });\n const { startAngle , endAngle , innerRadius , outerRadius , circumference } = this.getProps([\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius',\n 'circumference'\n ], useFinalPosition);\n const rAdjust = this.options.spacing / 2;\n const _circumference = valueOrDefault(circumference, endAngle - startAngle);\n const betweenAngles = _circumference >= TAU || _angleBetween(angle, startAngle, endAngle);\n const withinRadius = _isBetween(distance, innerRadius + rAdjust, outerRadius + rAdjust);\n return betweenAngles && withinRadius;\n }\n getCenterPoint(useFinalPosition) {\n const { x , y , startAngle , endAngle , innerRadius , outerRadius } = this.getProps([\n 'x',\n 'y',\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius'\n ], useFinalPosition);\n const { offset , spacing } = this.options;\n const halfAngle = (startAngle + endAngle) / 2;\n const halfRadius = (innerRadius + outerRadius + spacing + offset) / 2;\n return {\n x: x + Math.cos(halfAngle) * halfRadius,\n y: y + Math.sin(halfAngle) * halfRadius\n };\n }\n tooltipPosition(useFinalPosition) {\n return this.getCenterPoint(useFinalPosition);\n }\n draw(ctx) {\n const { options , circumference } = this;\n const offset = (options.offset || 0) / 4;\n const spacing = (options.spacing || 0) / 2;\n const circular = options.circular;\n this.pixelMargin = options.borderAlign === 'inner' ? 0.33 : 0;\n this.fullCircles = circumference > TAU ? Math.floor(circumference / TAU) : 0;\n if (circumference === 0 || this.innerRadius < 0 || this.outerRadius < 0) {\n return;\n }\n ctx.save();\n const halfAngle = (this.startAngle + this.endAngle) / 2;\n ctx.translate(Math.cos(halfAngle) * offset, Math.sin(halfAngle) * offset);\n const fix = 1 - Math.sin(Math.min(PI, circumference || 0));\n const radiusOffset = offset * fix;\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n drawArc(ctx, this, radiusOffset, spacing, circular);\n drawBorder(ctx, this, radiusOffset, spacing, circular);\n ctx.restore();\n }\n}\n\nfunction setStyle(ctx, options, style = options) {\n ctx.lineCap = valueOrDefault(style.borderCapStyle, options.borderCapStyle);\n ctx.setLineDash(valueOrDefault(style.borderDash, options.borderDash));\n ctx.lineDashOffset = valueOrDefault(style.borderDashOffset, options.borderDashOffset);\n ctx.lineJoin = valueOrDefault(style.borderJoinStyle, options.borderJoinStyle);\n ctx.lineWidth = valueOrDefault(style.borderWidth, options.borderWidth);\n ctx.strokeStyle = valueOrDefault(style.borderColor, options.borderColor);\n}\nfunction lineTo(ctx, previous, target) {\n ctx.lineTo(target.x, target.y);\n}\nfunction getLineMethod(options) {\n if (options.stepped) {\n return _steppedLineTo;\n }\n if (options.tension || options.cubicInterpolationMode === 'monotone') {\n return _bezierCurveTo;\n }\n return lineTo;\n}\nfunction pathVars(points, segment, params = {}) {\n const count = points.length;\n const { start: paramsStart = 0 , end: paramsEnd = count - 1 } = params;\n const { start: segmentStart , end: segmentEnd } = segment;\n const start = Math.max(paramsStart, segmentStart);\n const end = Math.min(paramsEnd, segmentEnd);\n const outside = paramsStart < segmentStart && paramsEnd < segmentStart || paramsStart > segmentEnd && paramsEnd > segmentEnd;\n return {\n count,\n start,\n loop: segment.loop,\n ilen: end < start && !outside ? count + end - start : end - start\n };\n}\n function pathSegment(ctx, line, segment, params) {\n const { points , options } = line;\n const { count , start , loop , ilen } = pathVars(points, segment, params);\n const lineMethod = getLineMethod(options);\n let { move =true , reverse } = params || {};\n let i, point, prev;\n for(i = 0; i <= ilen; ++i){\n point = points[(start + (reverse ? ilen - i : i)) % count];\n if (point.skip) {\n continue;\n } else if (move) {\n ctx.moveTo(point.x, point.y);\n move = false;\n } else {\n lineMethod(ctx, prev, point, reverse, options.stepped);\n }\n prev = point;\n }\n if (loop) {\n point = points[(start + (reverse ? ilen : 0)) % count];\n lineMethod(ctx, prev, point, reverse, options.stepped);\n }\n return !!loop;\n}\n function fastPathSegment(ctx, line, segment, params) {\n const points = line.points;\n const { count , start , ilen } = pathVars(points, segment, params);\n const { move =true , reverse } = params || {};\n let avgX = 0;\n let countX = 0;\n let i, point, prevX, minY, maxY, lastY;\n const pointIndex = (index)=>(start + (reverse ? ilen - index : index)) % count;\n const drawX = ()=>{\n if (minY !== maxY) {\n ctx.lineTo(avgX, maxY);\n ctx.lineTo(avgX, minY);\n ctx.lineTo(avgX, lastY);\n }\n };\n if (move) {\n point = points[pointIndex(0)];\n ctx.moveTo(point.x, point.y);\n }\n for(i = 0; i <= ilen; ++i){\n point = points[pointIndex(i)];\n if (point.skip) {\n continue;\n }\n const x = point.x;\n const y = point.y;\n const truncX = x | 0;\n if (truncX === prevX) {\n if (y < minY) {\n minY = y;\n } else if (y > maxY) {\n maxY = y;\n }\n avgX = (countX * avgX + x) / ++countX;\n } else {\n drawX();\n ctx.lineTo(x, y);\n prevX = truncX;\n countX = 0;\n minY = maxY = y;\n }\n lastY = y;\n }\n drawX();\n}\n function _getSegmentMethod(line) {\n const opts = line.options;\n const borderDash = opts.borderDash && opts.borderDash.length;\n const useFastPath = !line._decimated && !line._loop && !opts.tension && opts.cubicInterpolationMode !== 'monotone' && !opts.stepped && !borderDash;\n return useFastPath ? fastPathSegment : pathSegment;\n}\n function _getInterpolationMethod(options) {\n if (options.stepped) {\n return _steppedInterpolation;\n }\n if (options.tension || options.cubicInterpolationMode === 'monotone') {\n return _bezierInterpolation;\n }\n return _pointInLine;\n}\nfunction strokePathWithCache(ctx, line, start, count) {\n let path = line._path;\n if (!path) {\n path = line._path = new Path2D();\n if (line.path(path, start, count)) {\n path.closePath();\n }\n }\n setStyle(ctx, line.options);\n ctx.stroke(path);\n}\nfunction strokePathDirect(ctx, line, start, count) {\n const { segments , options } = line;\n const segmentMethod = _getSegmentMethod(line);\n for (const segment of segments){\n setStyle(ctx, options, segment.style);\n ctx.beginPath();\n if (segmentMethod(ctx, line, segment, {\n start,\n end: start + count - 1\n })) {\n ctx.closePath();\n }\n ctx.stroke();\n }\n}\nconst usePath2D = typeof Path2D === 'function';\nfunction draw(ctx, line, start, count) {\n if (usePath2D && !line.options.segment) {\n strokePathWithCache(ctx, line, start, count);\n } else {\n strokePathDirect(ctx, line, start, count);\n }\n}\nclass LineElement extends Element {\n static id = 'line';\n static defaults = {\n borderCapStyle: 'butt',\n borderDash: [],\n borderDashOffset: 0,\n borderJoinStyle: 'miter',\n borderWidth: 3,\n capBezierPoints: true,\n cubicInterpolationMode: 'default',\n fill: false,\n spanGaps: false,\n stepped: false,\n tension: 0\n };\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n static descriptors = {\n _scriptable: true,\n _indexable: (name)=>name !== 'borderDash' && name !== 'fill'\n };\n constructor(cfg){\n super();\n this.animated = true;\n this.options = undefined;\n this._chart = undefined;\n this._loop = undefined;\n this._fullLoop = undefined;\n this._path = undefined;\n this._points = undefined;\n this._segments = undefined;\n this._decimated = false;\n this._pointsUpdated = false;\n this._datasetIndex = undefined;\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n updateControlPoints(chartArea, indexAxis) {\n const options = this.options;\n if ((options.tension || options.cubicInterpolationMode === 'monotone') && !options.stepped && !this._pointsUpdated) {\n const loop = options.spanGaps ? this._loop : this._fullLoop;\n _updateBezierControlPoints(this._points, options, chartArea, loop, indexAxis);\n this._pointsUpdated = true;\n }\n }\n set points(points) {\n this._points = points;\n delete this._segments;\n delete this._path;\n this._pointsUpdated = false;\n }\n get points() {\n return this._points;\n }\n get segments() {\n return this._segments || (this._segments = _computeSegments(this, this.options.segment));\n }\n first() {\n const segments = this.segments;\n const points = this.points;\n return segments.length && points[segments[0].start];\n }\n last() {\n const segments = this.segments;\n const points = this.points;\n const count = segments.length;\n return count && points[segments[count - 1].end];\n }\n interpolate(point, property) {\n const options = this.options;\n const value = point[property];\n const points = this.points;\n const segments = _boundSegments(this, {\n property,\n start: value,\n end: value\n });\n if (!segments.length) {\n return;\n }\n const result = [];\n const _interpolate = _getInterpolationMethod(options);\n let i, ilen;\n for(i = 0, ilen = segments.length; i < ilen; ++i){\n const { start , end } = segments[i];\n const p1 = points[start];\n const p2 = points[end];\n if (p1 === p2) {\n result.push(p1);\n continue;\n }\n const t = Math.abs((value - p1[property]) / (p2[property] - p1[property]));\n const interpolated = _interpolate(p1, p2, t, options.stepped);\n interpolated[property] = point[property];\n result.push(interpolated);\n }\n return result.length === 1 ? result[0] : result;\n }\n pathSegment(ctx, segment, params) {\n const segmentMethod = _getSegmentMethod(this);\n return segmentMethod(ctx, this, segment, params);\n }\n path(ctx, start, count) {\n const segments = this.segments;\n const segmentMethod = _getSegmentMethod(this);\n let loop = this._loop;\n start = start || 0;\n count = count || this.points.length - start;\n for (const segment of segments){\n loop &= segmentMethod(ctx, this, segment, {\n start,\n end: start + count - 1\n });\n }\n return !!loop;\n }\n draw(ctx, chartArea, start, count) {\n const options = this.options || {};\n const points = this.points || [];\n if (points.length && options.borderWidth) {\n ctx.save();\n draw(ctx, this, start, count);\n ctx.restore();\n }\n if (this.animated) {\n this._pointsUpdated = false;\n this._path = undefined;\n }\n }\n}\n\nfunction inRange$1(el, pos, axis, useFinalPosition) {\n const options = el.options;\n const { [axis]: value } = el.getProps([\n axis\n ], useFinalPosition);\n return Math.abs(pos - value) < options.radius + options.hitRadius;\n}\nclass PointElement extends Element {\n static id = 'point';\n /**\n * @type {any}\n */ static defaults = {\n borderWidth: 1,\n hitRadius: 1,\n hoverBorderWidth: 1,\n hoverRadius: 4,\n pointStyle: 'circle',\n radius: 3,\n rotation: 0\n };\n /**\n * @type {any}\n */ static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n constructor(cfg){\n super();\n this.options = undefined;\n this.parsed = undefined;\n this.skip = undefined;\n this.stop = undefined;\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n inRange(mouseX, mouseY, useFinalPosition) {\n const options = this.options;\n const { x , y } = this.getProps([\n 'x',\n 'y'\n ], useFinalPosition);\n return Math.pow(mouseX - x, 2) + Math.pow(mouseY - y, 2) < Math.pow(options.hitRadius + options.radius, 2);\n }\n inXRange(mouseX, useFinalPosition) {\n return inRange$1(this, mouseX, 'x', useFinalPosition);\n }\n inYRange(mouseY, useFinalPosition) {\n return inRange$1(this, mouseY, 'y', useFinalPosition);\n }\n getCenterPoint(useFinalPosition) {\n const { x , y } = this.getProps([\n 'x',\n 'y'\n ], useFinalPosition);\n return {\n x,\n y\n };\n }\n size(options) {\n options = options || this.options || {};\n let radius = options.radius || 0;\n radius = Math.max(radius, radius && options.hoverRadius || 0);\n const borderWidth = radius && options.borderWidth || 0;\n return (radius + borderWidth) * 2;\n }\n draw(ctx, area) {\n const options = this.options;\n if (this.skip || options.radius < 0.1 || !_isPointInArea(this, area, this.size(options) / 2)) {\n return;\n }\n ctx.strokeStyle = options.borderColor;\n ctx.lineWidth = options.borderWidth;\n ctx.fillStyle = options.backgroundColor;\n drawPoint(ctx, options, this.x, this.y);\n }\n getRange() {\n const options = this.options || {};\n // @ts-expect-error Fallbacks should never be hit in practice\n return options.radius + options.hitRadius;\n }\n}\n\nfunction getBarBounds(bar, useFinalPosition) {\n const { x , y , base , width , height } = bar.getProps([\n 'x',\n 'y',\n 'base',\n 'width',\n 'height'\n ], useFinalPosition);\n let left, right, top, bottom, half;\n if (bar.horizontal) {\n half = height / 2;\n left = Math.min(x, base);\n right = Math.max(x, base);\n top = y - half;\n bottom = y + half;\n } else {\n half = width / 2;\n left = x - half;\n right = x + half;\n top = Math.min(y, base);\n bottom = Math.max(y, base);\n }\n return {\n left,\n top,\n right,\n bottom\n };\n}\nfunction skipOrLimit(skip, value, min, max) {\n return skip ? 0 : _limitValue(value, min, max);\n}\nfunction parseBorderWidth(bar, maxW, maxH) {\n const value = bar.options.borderWidth;\n const skip = bar.borderSkipped;\n const o = toTRBL(value);\n return {\n t: skipOrLimit(skip.top, o.top, 0, maxH),\n r: skipOrLimit(skip.right, o.right, 0, maxW),\n b: skipOrLimit(skip.bottom, o.bottom, 0, maxH),\n l: skipOrLimit(skip.left, o.left, 0, maxW)\n };\n}\nfunction parseBorderRadius(bar, maxW, maxH) {\n const { enableBorderRadius } = bar.getProps([\n 'enableBorderRadius'\n ]);\n const value = bar.options.borderRadius;\n const o = toTRBLCorners(value);\n const maxR = Math.min(maxW, maxH);\n const skip = bar.borderSkipped;\n const enableBorder = enableBorderRadius || isObject(value);\n return {\n topLeft: skipOrLimit(!enableBorder || skip.top || skip.left, o.topLeft, 0, maxR),\n topRight: skipOrLimit(!enableBorder || skip.top || skip.right, o.topRight, 0, maxR),\n bottomLeft: skipOrLimit(!enableBorder || skip.bottom || skip.left, o.bottomLeft, 0, maxR),\n bottomRight: skipOrLimit(!enableBorder || skip.bottom || skip.right, o.bottomRight, 0, maxR)\n };\n}\nfunction boundingRects(bar) {\n const bounds = getBarBounds(bar);\n const width = bounds.right - bounds.left;\n const height = bounds.bottom - bounds.top;\n const border = parseBorderWidth(bar, width / 2, height / 2);\n const radius = parseBorderRadius(bar, width / 2, height / 2);\n return {\n outer: {\n x: bounds.left,\n y: bounds.top,\n w: width,\n h: height,\n radius\n },\n inner: {\n x: bounds.left + border.l,\n y: bounds.top + border.t,\n w: width - border.l - border.r,\n h: height - border.t - border.b,\n radius: {\n topLeft: Math.max(0, radius.topLeft - Math.max(border.t, border.l)),\n topRight: Math.max(0, radius.topRight - Math.max(border.t, border.r)),\n bottomLeft: Math.max(0, radius.bottomLeft - Math.max(border.b, border.l)),\n bottomRight: Math.max(0, radius.bottomRight - Math.max(border.b, border.r))\n }\n }\n };\n}\nfunction inRange(bar, x, y, useFinalPosition) {\n const skipX = x === null;\n const skipY = y === null;\n const skipBoth = skipX && skipY;\n const bounds = bar && !skipBoth && getBarBounds(bar, useFinalPosition);\n return bounds && (skipX || _isBetween(x, bounds.left, bounds.right)) && (skipY || _isBetween(y, bounds.top, bounds.bottom));\n}\nfunction hasRadius(radius) {\n return radius.topLeft || radius.topRight || radius.bottomLeft || radius.bottomRight;\n}\n function addNormalRectPath(ctx, rect) {\n ctx.rect(rect.x, rect.y, rect.w, rect.h);\n}\nfunction inflateRect(rect, amount, refRect = {}) {\n const x = rect.x !== refRect.x ? -amount : 0;\n const y = rect.y !== refRect.y ? -amount : 0;\n const w = (rect.x + rect.w !== refRect.x + refRect.w ? amount : 0) - x;\n const h = (rect.y + rect.h !== refRect.y + refRect.h ? amount : 0) - y;\n return {\n x: rect.x + x,\n y: rect.y + y,\n w: rect.w + w,\n h: rect.h + h,\n radius: rect.radius\n };\n}\nclass BarElement extends Element {\n static id = 'bar';\n static defaults = {\n borderSkipped: 'start',\n borderWidth: 0,\n borderRadius: 0,\n inflateAmount: 'auto',\n pointStyle: undefined\n };\n static defaultRoutes = {\n backgroundColor: 'backgroundColor',\n borderColor: 'borderColor'\n };\n constructor(cfg){\n super();\n this.options = undefined;\n this.horizontal = undefined;\n this.base = undefined;\n this.width = undefined;\n this.height = undefined;\n this.inflateAmount = undefined;\n if (cfg) {\n Object.assign(this, cfg);\n }\n }\n draw(ctx) {\n const { inflateAmount , options: { borderColor , backgroundColor } } = this;\n const { inner , outer } = boundingRects(this);\n const addRectPath = hasRadius(outer.radius) ? addRoundedRectPath : addNormalRectPath;\n ctx.save();\n if (outer.w !== inner.w || outer.h !== inner.h) {\n ctx.beginPath();\n addRectPath(ctx, inflateRect(outer, inflateAmount, inner));\n ctx.clip();\n addRectPath(ctx, inflateRect(inner, -inflateAmount, outer));\n ctx.fillStyle = borderColor;\n ctx.fill('evenodd');\n }\n ctx.beginPath();\n addRectPath(ctx, inflateRect(inner, inflateAmount));\n ctx.fillStyle = backgroundColor;\n ctx.fill();\n ctx.restore();\n }\n inRange(mouseX, mouseY, useFinalPosition) {\n return inRange(this, mouseX, mouseY, useFinalPosition);\n }\n inXRange(mouseX, useFinalPosition) {\n return inRange(this, mouseX, null, useFinalPosition);\n }\n inYRange(mouseY, useFinalPosition) {\n return inRange(this, null, mouseY, useFinalPosition);\n }\n getCenterPoint(useFinalPosition) {\n const { x , y , base , horizontal } = this.getProps([\n 'x',\n 'y',\n 'base',\n 'horizontal'\n ], useFinalPosition);\n return {\n x: horizontal ? (x + base) / 2 : x,\n y: horizontal ? y : (y + base) / 2\n };\n }\n getRange(axis) {\n return axis === 'x' ? this.width / 2 : this.height / 2;\n }\n}\n\nvar elements = /*#__PURE__*/Object.freeze({\n__proto__: null,\nArcElement: ArcElement,\nLineElement: LineElement,\nPointElement: PointElement,\nBarElement: BarElement\n});\n\nconst BORDER_COLORS = [\n 'rgb(54, 162, 235)',\n 'rgb(255, 99, 132)',\n 'rgb(255, 159, 64)',\n 'rgb(255, 205, 86)',\n 'rgb(75, 192, 192)',\n 'rgb(153, 102, 255)',\n 'rgb(201, 203, 207)' // grey\n];\n// Border colors with 50% transparency\nconst BACKGROUND_COLORS = /* #__PURE__ */ BORDER_COLORS.map((color)=>color.replace('rgb(', 'rgba(').replace(')', ', 0.5)'));\nfunction getBorderColor(i) {\n return BORDER_COLORS[i % BORDER_COLORS.length];\n}\nfunction getBackgroundColor(i) {\n return BACKGROUND_COLORS[i % BACKGROUND_COLORS.length];\n}\nfunction colorizeDefaultDataset(dataset, i) {\n dataset.borderColor = getBorderColor(i);\n dataset.backgroundColor = getBackgroundColor(i);\n return ++i;\n}\nfunction colorizeDoughnutDataset(dataset, i) {\n dataset.backgroundColor = dataset.data.map(()=>getBorderColor(i++));\n return i;\n}\nfunction colorizePolarAreaDataset(dataset, i) {\n dataset.backgroundColor = dataset.data.map(()=>getBackgroundColor(i++));\n return i;\n}\nfunction getColorizer(chart) {\n let i = 0;\n return (dataset, datasetIndex)=>{\n const controller = chart.getDatasetMeta(datasetIndex).controller;\n if (controller instanceof DoughnutController) {\n i = colorizeDoughnutDataset(dataset, i);\n } else if (controller instanceof PolarAreaController) {\n i = colorizePolarAreaDataset(dataset, i);\n } else if (controller) {\n i = colorizeDefaultDataset(dataset, i);\n }\n };\n}\nfunction containsColorsDefinitions(descriptors) {\n let k;\n for(k in descriptors){\n if (descriptors[k].borderColor || descriptors[k].backgroundColor) {\n return true;\n }\n }\n return false;\n}\nfunction containsColorsDefinition(descriptor) {\n return descriptor && (descriptor.borderColor || descriptor.backgroundColor);\n}\nvar plugin_colors = {\n id: 'colors',\n defaults: {\n enabled: true,\n forceOverride: false\n },\n beforeLayout (chart, _args, options) {\n if (!options.enabled) {\n return;\n }\n const { data: { datasets } , options: chartOptions } = chart.config;\n const { elements } = chartOptions;\n if (!options.forceOverride && (containsColorsDefinitions(datasets) || containsColorsDefinition(chartOptions) || elements && containsColorsDefinitions(elements))) {\n return;\n }\n const colorizer = getColorizer(chart);\n datasets.forEach(colorizer);\n }\n};\n\nfunction lttbDecimation(data, start, count, availableWidth, options) {\n const samples = options.samples || availableWidth;\n if (samples >= count) {\n return data.slice(start, start + count);\n }\n const decimated = [];\n const bucketWidth = (count - 2) / (samples - 2);\n let sampledIndex = 0;\n const endIndex = start + count - 1;\n let a = start;\n let i, maxAreaPoint, maxArea, area, nextA;\n decimated[sampledIndex++] = data[a];\n for(i = 0; i < samples - 2; i++){\n let avgX = 0;\n let avgY = 0;\n let j;\n const avgRangeStart = Math.floor((i + 1) * bucketWidth) + 1 + start;\n const avgRangeEnd = Math.min(Math.floor((i + 2) * bucketWidth) + 1, count) + start;\n const avgRangeLength = avgRangeEnd - avgRangeStart;\n for(j = avgRangeStart; j < avgRangeEnd; j++){\n avgX += data[j].x;\n avgY += data[j].y;\n }\n avgX /= avgRangeLength;\n avgY /= avgRangeLength;\n const rangeOffs = Math.floor(i * bucketWidth) + 1 + start;\n const rangeTo = Math.min(Math.floor((i + 1) * bucketWidth) + 1, count) + start;\n const { x: pointAx , y: pointAy } = data[a];\n maxArea = area = -1;\n for(j = rangeOffs; j < rangeTo; j++){\n area = 0.5 * Math.abs((pointAx - avgX) * (data[j].y - pointAy) - (pointAx - data[j].x) * (avgY - pointAy));\n if (area > maxArea) {\n maxArea = area;\n maxAreaPoint = data[j];\n nextA = j;\n }\n }\n decimated[sampledIndex++] = maxAreaPoint;\n a = nextA;\n }\n decimated[sampledIndex++] = data[endIndex];\n return decimated;\n}\nfunction minMaxDecimation(data, start, count, availableWidth) {\n let avgX = 0;\n let countX = 0;\n let i, point, x, y, prevX, minIndex, maxIndex, startIndex, minY, maxY;\n const decimated = [];\n const endIndex = start + count - 1;\n const xMin = data[start].x;\n const xMax = data[endIndex].x;\n const dx = xMax - xMin;\n for(i = start; i < start + count; ++i){\n point = data[i];\n x = (point.x - xMin) / dx * availableWidth;\n y = point.y;\n const truncX = x | 0;\n if (truncX === prevX) {\n if (y < minY) {\n minY = y;\n minIndex = i;\n } else if (y > maxY) {\n maxY = y;\n maxIndex = i;\n }\n avgX = (countX * avgX + point.x) / ++countX;\n } else {\n const lastIndex = i - 1;\n if (!isNullOrUndef(minIndex) && !isNullOrUndef(maxIndex)) {\n const intermediateIndex1 = Math.min(minIndex, maxIndex);\n const intermediateIndex2 = Math.max(minIndex, maxIndex);\n if (intermediateIndex1 !== startIndex && intermediateIndex1 !== lastIndex) {\n decimated.push({\n ...data[intermediateIndex1],\n x: avgX\n });\n }\n if (intermediateIndex2 !== startIndex && intermediateIndex2 !== lastIndex) {\n decimated.push({\n ...data[intermediateIndex2],\n x: avgX\n });\n }\n }\n if (i > 0 && lastIndex !== startIndex) {\n decimated.push(data[lastIndex]);\n }\n decimated.push(point);\n prevX = truncX;\n countX = 0;\n minY = maxY = y;\n minIndex = maxIndex = startIndex = i;\n }\n }\n return decimated;\n}\nfunction cleanDecimatedDataset(dataset) {\n if (dataset._decimated) {\n const data = dataset._data;\n delete dataset._decimated;\n delete dataset._data;\n Object.defineProperty(dataset, 'data', {\n configurable: true,\n enumerable: true,\n writable: true,\n value: data\n });\n }\n}\nfunction cleanDecimatedData(chart) {\n chart.data.datasets.forEach((dataset)=>{\n cleanDecimatedDataset(dataset);\n });\n}\nfunction getStartAndCountOfVisiblePointsSimplified(meta, points) {\n const pointCount = points.length;\n let start = 0;\n let count;\n const { iScale } = meta;\n const { min , max , minDefined , maxDefined } = iScale.getUserBounds();\n if (minDefined) {\n start = _limitValue(_lookupByKey(points, iScale.axis, min).lo, 0, pointCount - 1);\n }\n if (maxDefined) {\n count = _limitValue(_lookupByKey(points, iScale.axis, max).hi + 1, start, pointCount) - start;\n } else {\n count = pointCount - start;\n }\n return {\n start,\n count\n };\n}\nvar plugin_decimation = {\n id: 'decimation',\n defaults: {\n algorithm: 'min-max',\n enabled: false\n },\n beforeElementsUpdate: (chart, args, options)=>{\n if (!options.enabled) {\n cleanDecimatedData(chart);\n return;\n }\n const availableWidth = chart.width;\n chart.data.datasets.forEach((dataset, datasetIndex)=>{\n const { _data , indexAxis } = dataset;\n const meta = chart.getDatasetMeta(datasetIndex);\n const data = _data || dataset.data;\n if (resolve([\n indexAxis,\n chart.options.indexAxis\n ]) === 'y') {\n return;\n }\n if (!meta.controller.supportsDecimation) {\n return;\n }\n const xAxis = chart.scales[meta.xAxisID];\n if (xAxis.type !== 'linear' && xAxis.type !== 'time') {\n return;\n }\n if (chart.options.parsing) {\n return;\n }\n let { start , count } = getStartAndCountOfVisiblePointsSimplified(meta, data);\n const threshold = options.threshold || 4 * availableWidth;\n if (count <= threshold) {\n cleanDecimatedDataset(dataset);\n return;\n }\n if (isNullOrUndef(_data)) {\n dataset._data = data;\n delete dataset.data;\n Object.defineProperty(dataset, 'data', {\n configurable: true,\n enumerable: true,\n get: function() {\n return this._decimated;\n },\n set: function(d) {\n this._data = d;\n }\n });\n }\n let decimated;\n switch(options.algorithm){\n case 'lttb':\n decimated = lttbDecimation(data, start, count, availableWidth, options);\n break;\n case 'min-max':\n decimated = minMaxDecimation(data, start, count, availableWidth);\n break;\n default:\n throw new Error(`Unsupported decimation algorithm '${options.algorithm}'`);\n }\n dataset._decimated = decimated;\n });\n },\n destroy (chart) {\n cleanDecimatedData(chart);\n }\n};\n\nfunction _segments(line, target, property) {\n const segments = line.segments;\n const points = line.points;\n const tpoints = target.points;\n const parts = [];\n for (const segment of segments){\n let { start , end } = segment;\n end = _findSegmentEnd(start, end, points);\n const bounds = _getBounds(property, points[start], points[end], segment.loop);\n if (!target.segments) {\n parts.push({\n source: segment,\n target: bounds,\n start: points[start],\n end: points[end]\n });\n continue;\n }\n const targetSegments = _boundSegments(target, bounds);\n for (const tgt of targetSegments){\n const subBounds = _getBounds(property, tpoints[tgt.start], tpoints[tgt.end], tgt.loop);\n const fillSources = _boundSegment(segment, points, subBounds);\n for (const fillSource of fillSources){\n parts.push({\n source: fillSource,\n target: tgt,\n start: {\n [property]: _getEdge(bounds, subBounds, 'start', Math.max)\n },\n end: {\n [property]: _getEdge(bounds, subBounds, 'end', Math.min)\n }\n });\n }\n }\n }\n return parts;\n}\nfunction _getBounds(property, first, last, loop) {\n if (loop) {\n return;\n }\n let start = first[property];\n let end = last[property];\n if (property === 'angle') {\n start = _normalizeAngle(start);\n end = _normalizeAngle(end);\n }\n return {\n property,\n start,\n end\n };\n}\nfunction _pointsFromSegments(boundary, line) {\n const { x =null , y =null } = boundary || {};\n const linePoints = line.points;\n const points = [];\n line.segments.forEach(({ start , end })=>{\n end = _findSegmentEnd(start, end, linePoints);\n const first = linePoints[start];\n const last = linePoints[end];\n if (y !== null) {\n points.push({\n x: first.x,\n y\n });\n points.push({\n x: last.x,\n y\n });\n } else if (x !== null) {\n points.push({\n x,\n y: first.y\n });\n points.push({\n x,\n y: last.y\n });\n }\n });\n return points;\n}\nfunction _findSegmentEnd(start, end, points) {\n for(; end > start; end--){\n const point = points[end];\n if (!isNaN(point.x) && !isNaN(point.y)) {\n break;\n }\n }\n return end;\n}\nfunction _getEdge(a, b, prop, fn) {\n if (a && b) {\n return fn(a[prop], b[prop]);\n }\n return a ? a[prop] : b ? b[prop] : 0;\n}\n\nfunction _createBoundaryLine(boundary, line) {\n let points = [];\n let _loop = false;\n if (isArray(boundary)) {\n _loop = true;\n points = boundary;\n } else {\n points = _pointsFromSegments(boundary, line);\n }\n return points.length ? new LineElement({\n points,\n options: {\n tension: 0\n },\n _loop,\n _fullLoop: _loop\n }) : null;\n}\nfunction _shouldApplyFill(source) {\n return source && source.fill !== false;\n}\n\nfunction _resolveTarget(sources, index, propagate) {\n const source = sources[index];\n let fill = source.fill;\n const visited = [\n index\n ];\n let target;\n if (!propagate) {\n return fill;\n }\n while(fill !== false && visited.indexOf(fill) === -1){\n if (!isNumberFinite(fill)) {\n return fill;\n }\n target = sources[fill];\n if (!target) {\n return false;\n }\n if (target.visible) {\n return fill;\n }\n visited.push(fill);\n fill = target.fill;\n }\n return false;\n}\n function _decodeFill(line, index, count) {\n const fill = parseFillOption(line);\n if (isObject(fill)) {\n return isNaN(fill.value) ? false : fill;\n }\n let target = parseFloat(fill);\n if (isNumberFinite(target) && Math.floor(target) === target) {\n return decodeTargetIndex(fill[0], index, target, count);\n }\n return [\n 'origin',\n 'start',\n 'end',\n 'stack',\n 'shape'\n ].indexOf(fill) >= 0 && fill;\n}\nfunction decodeTargetIndex(firstCh, index, target, count) {\n if (firstCh === '-' || firstCh === '+') {\n target = index + target;\n }\n if (target === index || target < 0 || target >= count) {\n return false;\n }\n return target;\n}\n function _getTargetPixel(fill, scale) {\n let pixel = null;\n if (fill === 'start') {\n pixel = scale.bottom;\n } else if (fill === 'end') {\n pixel = scale.top;\n } else if (isObject(fill)) {\n pixel = scale.getPixelForValue(fill.value);\n } else if (scale.getBasePixel) {\n pixel = scale.getBasePixel();\n }\n return pixel;\n}\n function _getTargetValue(fill, scale, startValue) {\n let value;\n if (fill === 'start') {\n value = startValue;\n } else if (fill === 'end') {\n value = scale.options.reverse ? scale.min : scale.max;\n } else if (isObject(fill)) {\n value = fill.value;\n } else {\n value = scale.getBaseValue();\n }\n return value;\n}\n function parseFillOption(line) {\n const options = line.options;\n const fillOption = options.fill;\n let fill = valueOrDefault(fillOption && fillOption.target, fillOption);\n if (fill === undefined) {\n fill = !!options.backgroundColor;\n }\n if (fill === false || fill === null) {\n return false;\n }\n if (fill === true) {\n return 'origin';\n }\n return fill;\n}\n\nfunction _buildStackLine(source) {\n const { scale , index , line } = source;\n const points = [];\n const segments = line.segments;\n const sourcePoints = line.points;\n const linesBelow = getLinesBelow(scale, index);\n linesBelow.push(_createBoundaryLine({\n x: null,\n y: scale.bottom\n }, line));\n for(let i = 0; i < segments.length; i++){\n const segment = segments[i];\n for(let j = segment.start; j <= segment.end; j++){\n addPointsBelow(points, sourcePoints[j], linesBelow);\n }\n }\n return new LineElement({\n points,\n options: {}\n });\n}\n function getLinesBelow(scale, index) {\n const below = [];\n const metas = scale.getMatchingVisibleMetas('line');\n for(let i = 0; i < metas.length; i++){\n const meta = metas[i];\n if (meta.index === index) {\n break;\n }\n if (!meta.hidden) {\n below.unshift(meta.dataset);\n }\n }\n return below;\n}\n function addPointsBelow(points, sourcePoint, linesBelow) {\n const postponed = [];\n for(let j = 0; j < linesBelow.length; j++){\n const line = linesBelow[j];\n const { first , last , point } = findPoint(line, sourcePoint, 'x');\n if (!point || first && last) {\n continue;\n }\n if (first) {\n postponed.unshift(point);\n } else {\n points.push(point);\n if (!last) {\n break;\n }\n }\n }\n points.push(...postponed);\n}\n function findPoint(line, sourcePoint, property) {\n const point = line.interpolate(sourcePoint, property);\n if (!point) {\n return {};\n }\n const pointValue = point[property];\n const segments = line.segments;\n const linePoints = line.points;\n let first = false;\n let last = false;\n for(let i = 0; i < segments.length; i++){\n const segment = segments[i];\n const firstValue = linePoints[segment.start][property];\n const lastValue = linePoints[segment.end][property];\n if (_isBetween(pointValue, firstValue, lastValue)) {\n first = pointValue === firstValue;\n last = pointValue === lastValue;\n break;\n }\n }\n return {\n first,\n last,\n point\n };\n}\n\nclass simpleArc {\n constructor(opts){\n this.x = opts.x;\n this.y = opts.y;\n this.radius = opts.radius;\n }\n pathSegment(ctx, bounds, opts) {\n const { x , y , radius } = this;\n bounds = bounds || {\n start: 0,\n end: TAU\n };\n ctx.arc(x, y, radius, bounds.end, bounds.start, true);\n return !opts.bounds;\n }\n interpolate(point) {\n const { x , y , radius } = this;\n const angle = point.angle;\n return {\n x: x + Math.cos(angle) * radius,\n y: y + Math.sin(angle) * radius,\n angle\n };\n }\n}\n\nfunction _getTarget(source) {\n const { chart , fill , line } = source;\n if (isNumberFinite(fill)) {\n return getLineByIndex(chart, fill);\n }\n if (fill === 'stack') {\n return _buildStackLine(source);\n }\n if (fill === 'shape') {\n return true;\n }\n const boundary = computeBoundary(source);\n if (boundary instanceof simpleArc) {\n return boundary;\n }\n return _createBoundaryLine(boundary, line);\n}\n function getLineByIndex(chart, index) {\n const meta = chart.getDatasetMeta(index);\n const visible = meta && chart.isDatasetVisible(index);\n return visible ? meta.dataset : null;\n}\nfunction computeBoundary(source) {\n const scale = source.scale || {};\n if (scale.getPointPositionForValue) {\n return computeCircularBoundary(source);\n }\n return computeLinearBoundary(source);\n}\nfunction computeLinearBoundary(source) {\n const { scale ={} , fill } = source;\n const pixel = _getTargetPixel(fill, scale);\n if (isNumberFinite(pixel)) {\n const horizontal = scale.isHorizontal();\n return {\n x: horizontal ? pixel : null,\n y: horizontal ? null : pixel\n };\n }\n return null;\n}\nfunction computeCircularBoundary(source) {\n const { scale , fill } = source;\n const options = scale.options;\n const length = scale.getLabels().length;\n const start = options.reverse ? scale.max : scale.min;\n const value = _getTargetValue(fill, scale, start);\n const target = [];\n if (options.grid.circular) {\n const center = scale.getPointPositionForValue(0, start);\n return new simpleArc({\n x: center.x,\n y: center.y,\n radius: scale.getDistanceFromCenterForValue(value)\n });\n }\n for(let i = 0; i < length; ++i){\n target.push(scale.getPointPositionForValue(i, value));\n }\n return target;\n}\n\nfunction _drawfill(ctx, source, area) {\n const target = _getTarget(source);\n const { line , scale , axis } = source;\n const lineOpts = line.options;\n const fillOption = lineOpts.fill;\n const color = lineOpts.backgroundColor;\n const { above =color , below =color } = fillOption || {};\n if (target && line.points.length) {\n clipArea(ctx, area);\n doFill(ctx, {\n line,\n target,\n above,\n below,\n area,\n scale,\n axis\n });\n unclipArea(ctx);\n }\n}\nfunction doFill(ctx, cfg) {\n const { line , target , above , below , area , scale } = cfg;\n const property = line._loop ? 'angle' : cfg.axis;\n ctx.save();\n if (property === 'x' && below !== above) {\n clipVertical(ctx, target, area.top);\n fill(ctx, {\n line,\n target,\n color: above,\n scale,\n property\n });\n ctx.restore();\n ctx.save();\n clipVertical(ctx, target, area.bottom);\n }\n fill(ctx, {\n line,\n target,\n color: below,\n scale,\n property\n });\n ctx.restore();\n}\nfunction clipVertical(ctx, target, clipY) {\n const { segments , points } = target;\n let first = true;\n let lineLoop = false;\n ctx.beginPath();\n for (const segment of segments){\n const { start , end } = segment;\n const firstPoint = points[start];\n const lastPoint = points[_findSegmentEnd(start, end, points)];\n if (first) {\n ctx.moveTo(firstPoint.x, firstPoint.y);\n first = false;\n } else {\n ctx.lineTo(firstPoint.x, clipY);\n ctx.lineTo(firstPoint.x, firstPoint.y);\n }\n lineLoop = !!target.pathSegment(ctx, segment, {\n move: lineLoop\n });\n if (lineLoop) {\n ctx.closePath();\n } else {\n ctx.lineTo(lastPoint.x, clipY);\n }\n }\n ctx.lineTo(target.first().x, clipY);\n ctx.closePath();\n ctx.clip();\n}\nfunction fill(ctx, cfg) {\n const { line , target , property , color , scale } = cfg;\n const segments = _segments(line, target, property);\n for (const { source: src , target: tgt , start , end } of segments){\n const { style: { backgroundColor =color } = {} } = src;\n const notShape = target !== true;\n ctx.save();\n ctx.fillStyle = backgroundColor;\n clipBounds(ctx, scale, notShape && _getBounds(property, start, end));\n ctx.beginPath();\n const lineLoop = !!line.pathSegment(ctx, src);\n let loop;\n if (notShape) {\n if (lineLoop) {\n ctx.closePath();\n } else {\n interpolatedLineTo(ctx, target, end, property);\n }\n const targetLoop = !!target.pathSegment(ctx, tgt, {\n move: lineLoop,\n reverse: true\n });\n loop = lineLoop && targetLoop;\n if (!loop) {\n interpolatedLineTo(ctx, target, start, property);\n }\n }\n ctx.closePath();\n ctx.fill(loop ? 'evenodd' : 'nonzero');\n ctx.restore();\n }\n}\nfunction clipBounds(ctx, scale, bounds) {\n const { top , bottom } = scale.chart.chartArea;\n const { property , start , end } = bounds || {};\n if (property === 'x') {\n ctx.beginPath();\n ctx.rect(start, top, end - start, bottom - top);\n ctx.clip();\n }\n}\nfunction interpolatedLineTo(ctx, target, point, property) {\n const interpolatedPoint = target.interpolate(point, property);\n if (interpolatedPoint) {\n ctx.lineTo(interpolatedPoint.x, interpolatedPoint.y);\n }\n}\n\nvar index = {\n id: 'filler',\n afterDatasetsUpdate (chart, _args, options) {\n const count = (chart.data.datasets || []).length;\n const sources = [];\n let meta, i, line, source;\n for(i = 0; i < count; ++i){\n meta = chart.getDatasetMeta(i);\n line = meta.dataset;\n source = null;\n if (line && line.options && line instanceof LineElement) {\n source = {\n visible: chart.isDatasetVisible(i),\n index: i,\n fill: _decodeFill(line, i, count),\n chart,\n axis: meta.controller.options.indexAxis,\n scale: meta.vScale,\n line\n };\n }\n meta.$filler = source;\n sources.push(source);\n }\n for(i = 0; i < count; ++i){\n source = sources[i];\n if (!source || source.fill === false) {\n continue;\n }\n source.fill = _resolveTarget(sources, i, options.propagate);\n }\n },\n beforeDraw (chart, _args, options) {\n const draw = options.drawTime === 'beforeDraw';\n const metasets = chart.getSortedVisibleDatasetMetas();\n const area = chart.chartArea;\n for(let i = metasets.length - 1; i >= 0; --i){\n const source = metasets[i].$filler;\n if (!source) {\n continue;\n }\n source.line.updateControlPoints(area, source.axis);\n if (draw && source.fill) {\n _drawfill(chart.ctx, source, area);\n }\n }\n },\n beforeDatasetsDraw (chart, _args, options) {\n if (options.drawTime !== 'beforeDatasetsDraw') {\n return;\n }\n const metasets = chart.getSortedVisibleDatasetMetas();\n for(let i = metasets.length - 1; i >= 0; --i){\n const source = metasets[i].$filler;\n if (_shouldApplyFill(source)) {\n _drawfill(chart.ctx, source, chart.chartArea);\n }\n }\n },\n beforeDatasetDraw (chart, args, options) {\n const source = args.meta.$filler;\n if (!_shouldApplyFill(source) || options.drawTime !== 'beforeDatasetDraw') {\n return;\n }\n _drawfill(chart.ctx, source, chart.chartArea);\n },\n defaults: {\n propagate: true,\n drawTime: 'beforeDatasetDraw'\n }\n};\n\nconst getBoxSize = (labelOpts, fontSize)=>{\n let { boxHeight =fontSize , boxWidth =fontSize } = labelOpts;\n if (labelOpts.usePointStyle) {\n boxHeight = Math.min(boxHeight, fontSize);\n boxWidth = labelOpts.pointStyleWidth || Math.min(boxWidth, fontSize);\n }\n return {\n boxWidth,\n boxHeight,\n itemHeight: Math.max(fontSize, boxHeight)\n };\n};\nconst itemsEqual = (a, b)=>a !== null && b !== null && a.datasetIndex === b.datasetIndex && a.index === b.index;\nclass Legend extends Element {\n constructor(config){\n super();\n this._added = false;\n this.legendHitBoxes = [];\n this._hoveredItem = null;\n this.doughnutMode = false;\n this.chart = config.chart;\n this.options = config.options;\n this.ctx = config.ctx;\n this.legendItems = undefined;\n this.columnSizes = undefined;\n this.lineWidths = undefined;\n this.maxHeight = undefined;\n this.maxWidth = undefined;\n this.top = undefined;\n this.bottom = undefined;\n this.left = undefined;\n this.right = undefined;\n this.height = undefined;\n this.width = undefined;\n this._margins = undefined;\n this.position = undefined;\n this.weight = undefined;\n this.fullSize = undefined;\n }\n update(maxWidth, maxHeight, margins) {\n this.maxWidth = maxWidth;\n this.maxHeight = maxHeight;\n this._margins = margins;\n this.setDimensions();\n this.buildLabels();\n this.fit();\n }\n setDimensions() {\n if (this.isHorizontal()) {\n this.width = this.maxWidth;\n this.left = this._margins.left;\n this.right = this.width;\n } else {\n this.height = this.maxHeight;\n this.top = this._margins.top;\n this.bottom = this.height;\n }\n }\n buildLabels() {\n const labelOpts = this.options.labels || {};\n let legendItems = callback(labelOpts.generateLabels, [\n this.chart\n ], this) || [];\n if (labelOpts.filter) {\n legendItems = legendItems.filter((item)=>labelOpts.filter(item, this.chart.data));\n }\n if (labelOpts.sort) {\n legendItems = legendItems.sort((a, b)=>labelOpts.sort(a, b, this.chart.data));\n }\n if (this.options.reverse) {\n legendItems.reverse();\n }\n this.legendItems = legendItems;\n }\n fit() {\n const { options , ctx } = this;\n if (!options.display) {\n this.width = this.height = 0;\n return;\n }\n const labelOpts = options.labels;\n const labelFont = toFont(labelOpts.font);\n const fontSize = labelFont.size;\n const titleHeight = this._computeTitleHeight();\n const { boxWidth , itemHeight } = getBoxSize(labelOpts, fontSize);\n let width, height;\n ctx.font = labelFont.string;\n if (this.isHorizontal()) {\n width = this.maxWidth;\n height = this._fitRows(titleHeight, fontSize, boxWidth, itemHeight) + 10;\n } else {\n height = this.maxHeight;\n width = this._fitCols(titleHeight, labelFont, boxWidth, itemHeight) + 10;\n }\n this.width = Math.min(width, options.maxWidth || this.maxWidth);\n this.height = Math.min(height, options.maxHeight || this.maxHeight);\n }\n _fitRows(titleHeight, fontSize, boxWidth, itemHeight) {\n const { ctx , maxWidth , options: { labels: { padding } } } = this;\n const hitboxes = this.legendHitBoxes = [];\n const lineWidths = this.lineWidths = [\n 0\n ];\n const lineHeight = itemHeight + padding;\n let totalHeight = titleHeight;\n ctx.textAlign = 'left';\n ctx.textBaseline = 'middle';\n let row = -1;\n let top = -lineHeight;\n this.legendItems.forEach((legendItem, i)=>{\n const itemWidth = boxWidth + fontSize / 2 + ctx.measureText(legendItem.text).width;\n if (i === 0 || lineWidths[lineWidths.length - 1] + itemWidth + 2 * padding > maxWidth) {\n totalHeight += lineHeight;\n lineWidths[lineWidths.length - (i > 0 ? 0 : 1)] = 0;\n top += lineHeight;\n row++;\n }\n hitboxes[i] = {\n left: 0,\n top,\n row,\n width: itemWidth,\n height: itemHeight\n };\n lineWidths[lineWidths.length - 1] += itemWidth + padding;\n });\n return totalHeight;\n }\n _fitCols(titleHeight, labelFont, boxWidth, _itemHeight) {\n const { ctx , maxHeight , options: { labels: { padding } } } = this;\n const hitboxes = this.legendHitBoxes = [];\n const columnSizes = this.columnSizes = [];\n const heightLimit = maxHeight - titleHeight;\n let totalWidth = padding;\n let currentColWidth = 0;\n let currentColHeight = 0;\n let left = 0;\n let col = 0;\n this.legendItems.forEach((legendItem, i)=>{\n const { itemWidth , itemHeight } = calculateItemSize(boxWidth, labelFont, ctx, legendItem, _itemHeight);\n if (i > 0 && currentColHeight + itemHeight + 2 * padding > heightLimit) {\n totalWidth += currentColWidth + padding;\n columnSizes.push({\n width: currentColWidth,\n height: currentColHeight\n });\n left += currentColWidth + padding;\n col++;\n currentColWidth = currentColHeight = 0;\n }\n hitboxes[i] = {\n left,\n top: currentColHeight,\n col,\n width: itemWidth,\n height: itemHeight\n };\n currentColWidth = Math.max(currentColWidth, itemWidth);\n currentColHeight += itemHeight + padding;\n });\n totalWidth += currentColWidth;\n columnSizes.push({\n width: currentColWidth,\n height: currentColHeight\n });\n return totalWidth;\n }\n adjustHitBoxes() {\n if (!this.options.display) {\n return;\n }\n const titleHeight = this._computeTitleHeight();\n const { legendHitBoxes: hitboxes , options: { align , labels: { padding } , rtl } } = this;\n const rtlHelper = getRtlAdapter(rtl, this.left, this.width);\n if (this.isHorizontal()) {\n let row = 0;\n let left = _alignStartEnd(align, this.left + padding, this.right - this.lineWidths[row]);\n for (const hitbox of hitboxes){\n if (row !== hitbox.row) {\n row = hitbox.row;\n left = _alignStartEnd(align, this.left + padding, this.right - this.lineWidths[row]);\n }\n hitbox.top += this.top + titleHeight + padding;\n hitbox.left = rtlHelper.leftForLtr(rtlHelper.x(left), hitbox.width);\n left += hitbox.width + padding;\n }\n } else {\n let col = 0;\n let top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n for (const hitbox1 of hitboxes){\n if (hitbox1.col !== col) {\n col = hitbox1.col;\n top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n }\n hitbox1.top = top;\n hitbox1.left += this.left + padding;\n hitbox1.left = rtlHelper.leftForLtr(rtlHelper.x(hitbox1.left), hitbox1.width);\n top += hitbox1.height + padding;\n }\n }\n }\n isHorizontal() {\n return this.options.position === 'top' || this.options.position === 'bottom';\n }\n draw() {\n if (this.options.display) {\n const ctx = this.ctx;\n clipArea(ctx, this);\n this._draw();\n unclipArea(ctx);\n }\n }\n _draw() {\n const { options: opts , columnSizes , lineWidths , ctx } = this;\n const { align , labels: labelOpts } = opts;\n const defaultColor = defaults.color;\n const rtlHelper = getRtlAdapter(opts.rtl, this.left, this.width);\n const labelFont = toFont(labelOpts.font);\n const { padding } = labelOpts;\n const fontSize = labelFont.size;\n const halfFontSize = fontSize / 2;\n let cursor;\n this.drawTitle();\n ctx.textAlign = rtlHelper.textAlign('left');\n ctx.textBaseline = 'middle';\n ctx.lineWidth = 0.5;\n ctx.font = labelFont.string;\n const { boxWidth , boxHeight , itemHeight } = getBoxSize(labelOpts, fontSize);\n const drawLegendBox = function(x, y, legendItem) {\n if (isNaN(boxWidth) || boxWidth <= 0 || isNaN(boxHeight) || boxHeight < 0) {\n return;\n }\n ctx.save();\n const lineWidth = valueOrDefault(legendItem.lineWidth, 1);\n ctx.fillStyle = valueOrDefault(legendItem.fillStyle, defaultColor);\n ctx.lineCap = valueOrDefault(legendItem.lineCap, 'butt');\n ctx.lineDashOffset = valueOrDefault(legendItem.lineDashOffset, 0);\n ctx.lineJoin = valueOrDefault(legendItem.lineJoin, 'miter');\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = valueOrDefault(legendItem.strokeStyle, defaultColor);\n ctx.setLineDash(valueOrDefault(legendItem.lineDash, []));\n if (labelOpts.usePointStyle) {\n const drawOptions = {\n radius: boxHeight * Math.SQRT2 / 2,\n pointStyle: legendItem.pointStyle,\n rotation: legendItem.rotation,\n borderWidth: lineWidth\n };\n const centerX = rtlHelper.xPlus(x, boxWidth / 2);\n const centerY = y + halfFontSize;\n drawPointLegend(ctx, drawOptions, centerX, centerY, labelOpts.pointStyleWidth && boxWidth);\n } else {\n const yBoxTop = y + Math.max((fontSize - boxHeight) / 2, 0);\n const xBoxLeft = rtlHelper.leftForLtr(x, boxWidth);\n const borderRadius = toTRBLCorners(legendItem.borderRadius);\n ctx.beginPath();\n if (Object.values(borderRadius).some((v)=>v !== 0)) {\n addRoundedRectPath(ctx, {\n x: xBoxLeft,\n y: yBoxTop,\n w: boxWidth,\n h: boxHeight,\n radius: borderRadius\n });\n } else {\n ctx.rect(xBoxLeft, yBoxTop, boxWidth, boxHeight);\n }\n ctx.fill();\n if (lineWidth !== 0) {\n ctx.stroke();\n }\n }\n ctx.restore();\n };\n const fillText = function(x, y, legendItem) {\n renderText(ctx, legendItem.text, x, y + itemHeight / 2, labelFont, {\n strikethrough: legendItem.hidden,\n textAlign: rtlHelper.textAlign(legendItem.textAlign)\n });\n };\n const isHorizontal = this.isHorizontal();\n const titleHeight = this._computeTitleHeight();\n if (isHorizontal) {\n cursor = {\n x: _alignStartEnd(align, this.left + padding, this.right - lineWidths[0]),\n y: this.top + padding + titleHeight,\n line: 0\n };\n } else {\n cursor = {\n x: this.left + padding,\n y: _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - columnSizes[0].height),\n line: 0\n };\n }\n overrideTextDirection(this.ctx, opts.textDirection);\n const lineHeight = itemHeight + padding;\n this.legendItems.forEach((legendItem, i)=>{\n ctx.strokeStyle = legendItem.fontColor;\n ctx.fillStyle = legendItem.fontColor;\n const textWidth = ctx.measureText(legendItem.text).width;\n const textAlign = rtlHelper.textAlign(legendItem.textAlign || (legendItem.textAlign = labelOpts.textAlign));\n const width = boxWidth + halfFontSize + textWidth;\n let x = cursor.x;\n let y = cursor.y;\n rtlHelper.setWidth(this.width);\n if (isHorizontal) {\n if (i > 0 && x + width + padding > this.right) {\n y = cursor.y += lineHeight;\n cursor.line++;\n x = cursor.x = _alignStartEnd(align, this.left + padding, this.right - lineWidths[cursor.line]);\n }\n } else if (i > 0 && y + lineHeight > this.bottom) {\n x = cursor.x = x + columnSizes[cursor.line].width + padding;\n cursor.line++;\n y = cursor.y = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - columnSizes[cursor.line].height);\n }\n const realX = rtlHelper.x(x);\n drawLegendBox(realX, y, legendItem);\n x = _textX(textAlign, x + boxWidth + halfFontSize, isHorizontal ? x + width : this.right, opts.rtl);\n fillText(rtlHelper.x(x), y, legendItem);\n if (isHorizontal) {\n cursor.x += width + padding;\n } else if (typeof legendItem.text !== 'string') {\n const fontLineHeight = labelFont.lineHeight;\n cursor.y += calculateLegendItemHeight(legendItem, fontLineHeight);\n } else {\n cursor.y += lineHeight;\n }\n });\n restoreTextDirection(this.ctx, opts.textDirection);\n }\n drawTitle() {\n const opts = this.options;\n const titleOpts = opts.title;\n const titleFont = toFont(titleOpts.font);\n const titlePadding = toPadding(titleOpts.padding);\n if (!titleOpts.display) {\n return;\n }\n const rtlHelper = getRtlAdapter(opts.rtl, this.left, this.width);\n const ctx = this.ctx;\n const position = titleOpts.position;\n const halfFontSize = titleFont.size / 2;\n const topPaddingPlusHalfFontSize = titlePadding.top + halfFontSize;\n let y;\n let left = this.left;\n let maxWidth = this.width;\n if (this.isHorizontal()) {\n maxWidth = Math.max(...this.lineWidths);\n y = this.top + topPaddingPlusHalfFontSize;\n left = _alignStartEnd(opts.align, left, this.right - maxWidth);\n } else {\n const maxHeight = this.columnSizes.reduce((acc, size)=>Math.max(acc, size.height), 0);\n y = topPaddingPlusHalfFontSize + _alignStartEnd(opts.align, this.top, this.bottom - maxHeight - opts.labels.padding - this._computeTitleHeight());\n }\n const x = _alignStartEnd(position, left, left + maxWidth);\n ctx.textAlign = rtlHelper.textAlign(_toLeftRightCenter(position));\n ctx.textBaseline = 'middle';\n ctx.strokeStyle = titleOpts.color;\n ctx.fillStyle = titleOpts.color;\n ctx.font = titleFont.string;\n renderText(ctx, titleOpts.text, x, y, titleFont);\n }\n _computeTitleHeight() {\n const titleOpts = this.options.title;\n const titleFont = toFont(titleOpts.font);\n const titlePadding = toPadding(titleOpts.padding);\n return titleOpts.display ? titleFont.lineHeight + titlePadding.height : 0;\n }\n _getLegendItemAt(x, y) {\n let i, hitBox, lh;\n if (_isBetween(x, this.left, this.right) && _isBetween(y, this.top, this.bottom)) {\n lh = this.legendHitBoxes;\n for(i = 0; i < lh.length; ++i){\n hitBox = lh[i];\n if (_isBetween(x, hitBox.left, hitBox.left + hitBox.width) && _isBetween(y, hitBox.top, hitBox.top + hitBox.height)) {\n return this.legendItems[i];\n }\n }\n }\n return null;\n }\n handleEvent(e) {\n const opts = this.options;\n if (!isListened(e.type, opts)) {\n return;\n }\n const hoveredItem = this._getLegendItemAt(e.x, e.y);\n if (e.type === 'mousemove' || e.type === 'mouseout') {\n const previous = this._hoveredItem;\n const sameItem = itemsEqual(previous, hoveredItem);\n if (previous && !sameItem) {\n callback(opts.onLeave, [\n e,\n previous,\n this\n ], this);\n }\n this._hoveredItem = hoveredItem;\n if (hoveredItem && !sameItem) {\n callback(opts.onHover, [\n e,\n hoveredItem,\n this\n ], this);\n }\n } else if (hoveredItem) {\n callback(opts.onClick, [\n e,\n hoveredItem,\n this\n ], this);\n }\n }\n}\nfunction calculateItemSize(boxWidth, labelFont, ctx, legendItem, _itemHeight) {\n const itemWidth = calculateItemWidth(legendItem, boxWidth, labelFont, ctx);\n const itemHeight = calculateItemHeight(_itemHeight, legendItem, labelFont.lineHeight);\n return {\n itemWidth,\n itemHeight\n };\n}\nfunction calculateItemWidth(legendItem, boxWidth, labelFont, ctx) {\n let legendItemText = legendItem.text;\n if (legendItemText && typeof legendItemText !== 'string') {\n legendItemText = legendItemText.reduce((a, b)=>a.length > b.length ? a : b);\n }\n return boxWidth + labelFont.size / 2 + ctx.measureText(legendItemText).width;\n}\nfunction calculateItemHeight(_itemHeight, legendItem, fontLineHeight) {\n let itemHeight = _itemHeight;\n if (typeof legendItem.text !== 'string') {\n itemHeight = calculateLegendItemHeight(legendItem, fontLineHeight);\n }\n return itemHeight;\n}\nfunction calculateLegendItemHeight(legendItem, fontLineHeight) {\n const labelHeight = legendItem.text ? legendItem.text.length + 0.5 : 0;\n return fontLineHeight * labelHeight;\n}\nfunction isListened(type, opts) {\n if ((type === 'mousemove' || type === 'mouseout') && (opts.onHover || opts.onLeave)) {\n return true;\n }\n if (opts.onClick && (type === 'click' || type === 'mouseup')) {\n return true;\n }\n return false;\n}\nvar plugin_legend = {\n id: 'legend',\n _element: Legend,\n start (chart, _args, options) {\n const legend = chart.legend = new Legend({\n ctx: chart.ctx,\n options,\n chart\n });\n layouts.configure(chart, legend, options);\n layouts.addBox(chart, legend);\n },\n stop (chart) {\n layouts.removeBox(chart, chart.legend);\n delete chart.legend;\n },\n beforeUpdate (chart, _args, options) {\n const legend = chart.legend;\n layouts.configure(chart, legend, options);\n legend.options = options;\n },\n afterUpdate (chart) {\n const legend = chart.legend;\n legend.buildLabels();\n legend.adjustHitBoxes();\n },\n afterEvent (chart, args) {\n if (!args.replay) {\n chart.legend.handleEvent(args.event);\n }\n },\n defaults: {\n display: true,\n position: 'top',\n align: 'center',\n fullSize: true,\n reverse: false,\n weight: 1000,\n onClick (e, legendItem, legend) {\n const index = legendItem.datasetIndex;\n const ci = legend.chart;\n if (ci.isDatasetVisible(index)) {\n ci.hide(index);\n legendItem.hidden = true;\n } else {\n ci.show(index);\n legendItem.hidden = false;\n }\n },\n onHover: null,\n onLeave: null,\n labels: {\n color: (ctx)=>ctx.chart.options.color,\n boxWidth: 40,\n padding: 10,\n generateLabels (chart) {\n const datasets = chart.data.datasets;\n const { labels: { usePointStyle , pointStyle , textAlign , color , useBorderRadius , borderRadius } } = chart.legend.options;\n return chart._getSortedDatasetMetas().map((meta)=>{\n const style = meta.controller.getStyle(usePointStyle ? 0 : undefined);\n const borderWidth = toPadding(style.borderWidth);\n return {\n text: datasets[meta.index].label,\n fillStyle: style.backgroundColor,\n fontColor: color,\n hidden: !meta.visible,\n lineCap: style.borderCapStyle,\n lineDash: style.borderDash,\n lineDashOffset: style.borderDashOffset,\n lineJoin: style.borderJoinStyle,\n lineWidth: (borderWidth.width + borderWidth.height) / 4,\n strokeStyle: style.borderColor,\n pointStyle: pointStyle || style.pointStyle,\n rotation: style.rotation,\n textAlign: textAlign || style.textAlign,\n borderRadius: useBorderRadius && (borderRadius || style.borderRadius),\n datasetIndex: meta.index\n };\n }, this);\n }\n },\n title: {\n color: (ctx)=>ctx.chart.options.color,\n display: false,\n position: 'center',\n text: ''\n }\n },\n descriptors: {\n _scriptable: (name)=>!name.startsWith('on'),\n labels: {\n _scriptable: (name)=>![\n 'generateLabels',\n 'filter',\n 'sort'\n ].includes(name)\n }\n }\n};\n\nclass Title extends Element {\n constructor(config){\n super();\n this.chart = config.chart;\n this.options = config.options;\n this.ctx = config.ctx;\n this._padding = undefined;\n this.top = undefined;\n this.bottom = undefined;\n this.left = undefined;\n this.right = undefined;\n this.width = undefined;\n this.height = undefined;\n this.position = undefined;\n this.weight = undefined;\n this.fullSize = undefined;\n }\n update(maxWidth, maxHeight) {\n const opts = this.options;\n this.left = 0;\n this.top = 0;\n if (!opts.display) {\n this.width = this.height = this.right = this.bottom = 0;\n return;\n }\n this.width = this.right = maxWidth;\n this.height = this.bottom = maxHeight;\n const lineCount = isArray(opts.text) ? opts.text.length : 1;\n this._padding = toPadding(opts.padding);\n const textSize = lineCount * toFont(opts.font).lineHeight + this._padding.height;\n if (this.isHorizontal()) {\n this.height = textSize;\n } else {\n this.width = textSize;\n }\n }\n isHorizontal() {\n const pos = this.options.position;\n return pos === 'top' || pos === 'bottom';\n }\n _drawArgs(offset) {\n const { top , left , bottom , right , options } = this;\n const align = options.align;\n let rotation = 0;\n let maxWidth, titleX, titleY;\n if (this.isHorizontal()) {\n titleX = _alignStartEnd(align, left, right);\n titleY = top + offset;\n maxWidth = right - left;\n } else {\n if (options.position === 'left') {\n titleX = left + offset;\n titleY = _alignStartEnd(align, bottom, top);\n rotation = PI * -0.5;\n } else {\n titleX = right - offset;\n titleY = _alignStartEnd(align, top, bottom);\n rotation = PI * 0.5;\n }\n maxWidth = bottom - top;\n }\n return {\n titleX,\n titleY,\n maxWidth,\n rotation\n };\n }\n draw() {\n const ctx = this.ctx;\n const opts = this.options;\n if (!opts.display) {\n return;\n }\n const fontOpts = toFont(opts.font);\n const lineHeight = fontOpts.lineHeight;\n const offset = lineHeight / 2 + this._padding.top;\n const { titleX , titleY , maxWidth , rotation } = this._drawArgs(offset);\n renderText(ctx, opts.text, 0, 0, fontOpts, {\n color: opts.color,\n maxWidth,\n rotation,\n textAlign: _toLeftRightCenter(opts.align),\n textBaseline: 'middle',\n translation: [\n titleX,\n titleY\n ]\n });\n }\n}\nfunction createTitle(chart, titleOpts) {\n const title = new Title({\n ctx: chart.ctx,\n options: titleOpts,\n chart\n });\n layouts.configure(chart, title, titleOpts);\n layouts.addBox(chart, title);\n chart.titleBlock = title;\n}\nvar plugin_title = {\n id: 'title',\n _element: Title,\n start (chart, _args, options) {\n createTitle(chart, options);\n },\n stop (chart) {\n const titleBlock = chart.titleBlock;\n layouts.removeBox(chart, titleBlock);\n delete chart.titleBlock;\n },\n beforeUpdate (chart, _args, options) {\n const title = chart.titleBlock;\n layouts.configure(chart, title, options);\n title.options = options;\n },\n defaults: {\n align: 'center',\n display: false,\n font: {\n weight: 'bold'\n },\n fullSize: true,\n padding: 10,\n position: 'top',\n text: '',\n weight: 2000\n },\n defaultRoutes: {\n color: 'color'\n },\n descriptors: {\n _scriptable: true,\n _indexable: false\n }\n};\n\nconst map = new WeakMap();\nvar plugin_subtitle = {\n id: 'subtitle',\n start (chart, _args, options) {\n const title = new Title({\n ctx: chart.ctx,\n options,\n chart\n });\n layouts.configure(chart, title, options);\n layouts.addBox(chart, title);\n map.set(chart, title);\n },\n stop (chart) {\n layouts.removeBox(chart, map.get(chart));\n map.delete(chart);\n },\n beforeUpdate (chart, _args, options) {\n const title = map.get(chart);\n layouts.configure(chart, title, options);\n title.options = options;\n },\n defaults: {\n align: 'center',\n display: false,\n font: {\n weight: 'normal'\n },\n fullSize: true,\n padding: 0,\n position: 'top',\n text: '',\n weight: 1500\n },\n defaultRoutes: {\n color: 'color'\n },\n descriptors: {\n _scriptable: true,\n _indexable: false\n }\n};\n\nconst positioners = {\n average (items) {\n if (!items.length) {\n return false;\n }\n let i, len;\n let x = 0;\n let y = 0;\n let count = 0;\n for(i = 0, len = items.length; i < len; ++i){\n const el = items[i].element;\n if (el && el.hasValue()) {\n const pos = el.tooltipPosition();\n x += pos.x;\n y += pos.y;\n ++count;\n }\n }\n return {\n x: x / count,\n y: y / count\n };\n },\n nearest (items, eventPosition) {\n if (!items.length) {\n return false;\n }\n let x = eventPosition.x;\n let y = eventPosition.y;\n let minDistance = Number.POSITIVE_INFINITY;\n let i, len, nearestElement;\n for(i = 0, len = items.length; i < len; ++i){\n const el = items[i].element;\n if (el && el.hasValue()) {\n const center = el.getCenterPoint();\n const d = distanceBetweenPoints(eventPosition, center);\n if (d < minDistance) {\n minDistance = d;\n nearestElement = el;\n }\n }\n }\n if (nearestElement) {\n const tp = nearestElement.tooltipPosition();\n x = tp.x;\n y = tp.y;\n }\n return {\n x,\n y\n };\n }\n};\nfunction pushOrConcat(base, toPush) {\n if (toPush) {\n if (isArray(toPush)) {\n Array.prototype.push.apply(base, toPush);\n } else {\n base.push(toPush);\n }\n }\n return base;\n}\n function splitNewlines(str) {\n if ((typeof str === 'string' || str instanceof String) && str.indexOf('\\n') > -1) {\n return str.split('\\n');\n }\n return str;\n}\n function createTooltipItem(chart, item) {\n const { element , datasetIndex , index } = item;\n const controller = chart.getDatasetMeta(datasetIndex).controller;\n const { label , value } = controller.getLabelAndValue(index);\n return {\n chart,\n label,\n parsed: controller.getParsed(index),\n raw: chart.data.datasets[datasetIndex].data[index],\n formattedValue: value,\n dataset: controller.getDataset(),\n dataIndex: index,\n datasetIndex,\n element\n };\n}\n function getTooltipSize(tooltip, options) {\n const ctx = tooltip.chart.ctx;\n const { body , footer , title } = tooltip;\n const { boxWidth , boxHeight } = options;\n const bodyFont = toFont(options.bodyFont);\n const titleFont = toFont(options.titleFont);\n const footerFont = toFont(options.footerFont);\n const titleLineCount = title.length;\n const footerLineCount = footer.length;\n const bodyLineItemCount = body.length;\n const padding = toPadding(options.padding);\n let height = padding.height;\n let width = 0;\n let combinedBodyLength = body.reduce((count, bodyItem)=>count + bodyItem.before.length + bodyItem.lines.length + bodyItem.after.length, 0);\n combinedBodyLength += tooltip.beforeBody.length + tooltip.afterBody.length;\n if (titleLineCount) {\n height += titleLineCount * titleFont.lineHeight + (titleLineCount - 1) * options.titleSpacing + options.titleMarginBottom;\n }\n if (combinedBodyLength) {\n const bodyLineHeight = options.displayColors ? Math.max(boxHeight, bodyFont.lineHeight) : bodyFont.lineHeight;\n height += bodyLineItemCount * bodyLineHeight + (combinedBodyLength - bodyLineItemCount) * bodyFont.lineHeight + (combinedBodyLength - 1) * options.bodySpacing;\n }\n if (footerLineCount) {\n height += options.footerMarginTop + footerLineCount * footerFont.lineHeight + (footerLineCount - 1) * options.footerSpacing;\n }\n let widthPadding = 0;\n const maxLineWidth = function(line) {\n width = Math.max(width, ctx.measureText(line).width + widthPadding);\n };\n ctx.save();\n ctx.font = titleFont.string;\n each(tooltip.title, maxLineWidth);\n ctx.font = bodyFont.string;\n each(tooltip.beforeBody.concat(tooltip.afterBody), maxLineWidth);\n widthPadding = options.displayColors ? boxWidth + 2 + options.boxPadding : 0;\n each(body, (bodyItem)=>{\n each(bodyItem.before, maxLineWidth);\n each(bodyItem.lines, maxLineWidth);\n each(bodyItem.after, maxLineWidth);\n });\n widthPadding = 0;\n ctx.font = footerFont.string;\n each(tooltip.footer, maxLineWidth);\n ctx.restore();\n width += padding.width;\n return {\n width,\n height\n };\n}\nfunction determineYAlign(chart, size) {\n const { y , height } = size;\n if (y < height / 2) {\n return 'top';\n } else if (y > chart.height - height / 2) {\n return 'bottom';\n }\n return 'center';\n}\nfunction doesNotFitWithAlign(xAlign, chart, options, size) {\n const { x , width } = size;\n const caret = options.caretSize + options.caretPadding;\n if (xAlign === 'left' && x + width + caret > chart.width) {\n return true;\n }\n if (xAlign === 'right' && x - width - caret < 0) {\n return true;\n }\n}\nfunction determineXAlign(chart, options, size, yAlign) {\n const { x , width } = size;\n const { width: chartWidth , chartArea: { left , right } } = chart;\n let xAlign = 'center';\n if (yAlign === 'center') {\n xAlign = x <= (left + right) / 2 ? 'left' : 'right';\n } else if (x <= width / 2) {\n xAlign = 'left';\n } else if (x >= chartWidth - width / 2) {\n xAlign = 'right';\n }\n if (doesNotFitWithAlign(xAlign, chart, options, size)) {\n xAlign = 'center';\n }\n return xAlign;\n}\n function determineAlignment(chart, options, size) {\n const yAlign = size.yAlign || options.yAlign || determineYAlign(chart, size);\n return {\n xAlign: size.xAlign || options.xAlign || determineXAlign(chart, options, size, yAlign),\n yAlign\n };\n}\nfunction alignX(size, xAlign) {\n let { x , width } = size;\n if (xAlign === 'right') {\n x -= width;\n } else if (xAlign === 'center') {\n x -= width / 2;\n }\n return x;\n}\nfunction alignY(size, yAlign, paddingAndSize) {\n let { y , height } = size;\n if (yAlign === 'top') {\n y += paddingAndSize;\n } else if (yAlign === 'bottom') {\n y -= height + paddingAndSize;\n } else {\n y -= height / 2;\n }\n return y;\n}\n function getBackgroundPoint(options, size, alignment, chart) {\n const { caretSize , caretPadding , cornerRadius } = options;\n const { xAlign , yAlign } = alignment;\n const paddingAndSize = caretSize + caretPadding;\n const { topLeft , topRight , bottomLeft , bottomRight } = toTRBLCorners(cornerRadius);\n let x = alignX(size, xAlign);\n const y = alignY(size, yAlign, paddingAndSize);\n if (yAlign === 'center') {\n if (xAlign === 'left') {\n x += paddingAndSize;\n } else if (xAlign === 'right') {\n x -= paddingAndSize;\n }\n } else if (xAlign === 'left') {\n x -= Math.max(topLeft, bottomLeft) + caretSize;\n } else if (xAlign === 'right') {\n x += Math.max(topRight, bottomRight) + caretSize;\n }\n return {\n x: _limitValue(x, 0, chart.width - size.width),\n y: _limitValue(y, 0, chart.height - size.height)\n };\n}\nfunction getAlignedX(tooltip, align, options) {\n const padding = toPadding(options.padding);\n return align === 'center' ? tooltip.x + tooltip.width / 2 : align === 'right' ? tooltip.x + tooltip.width - padding.right : tooltip.x + padding.left;\n}\n function getBeforeAfterBodyLines(callback) {\n return pushOrConcat([], splitNewlines(callback));\n}\nfunction createTooltipContext(parent, tooltip, tooltipItems) {\n return createContext(parent, {\n tooltip,\n tooltipItems,\n type: 'tooltip'\n });\n}\nfunction overrideCallbacks(callbacks, context) {\n const override = context && context.dataset && context.dataset.tooltip && context.dataset.tooltip.callbacks;\n return override ? callbacks.override(override) : callbacks;\n}\nconst defaultCallbacks = {\n beforeTitle: noop,\n title (tooltipItems) {\n if (tooltipItems.length > 0) {\n const item = tooltipItems[0];\n const labels = item.chart.data.labels;\n const labelCount = labels ? labels.length : 0;\n if (this && this.options && this.options.mode === 'dataset') {\n return item.dataset.label || '';\n } else if (item.label) {\n return item.label;\n } else if (labelCount > 0 && item.dataIndex < labelCount) {\n return labels[item.dataIndex];\n }\n }\n return '';\n },\n afterTitle: noop,\n beforeBody: noop,\n beforeLabel: noop,\n label (tooltipItem) {\n if (this && this.options && this.options.mode === 'dataset') {\n return tooltipItem.label + ': ' + tooltipItem.formattedValue || tooltipItem.formattedValue;\n }\n let label = tooltipItem.dataset.label || '';\n if (label) {\n label += ': ';\n }\n const value = tooltipItem.formattedValue;\n if (!isNullOrUndef(value)) {\n label += value;\n }\n return label;\n },\n labelColor (tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n borderColor: options.borderColor,\n backgroundColor: options.backgroundColor,\n borderWidth: options.borderWidth,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderRadius: 0\n };\n },\n labelTextColor () {\n return this.options.bodyColor;\n },\n labelPointStyle (tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n pointStyle: options.pointStyle,\n rotation: options.rotation\n };\n },\n afterLabel: noop,\n afterBody: noop,\n beforeFooter: noop,\n footer: noop,\n afterFooter: noop\n};\n function invokeCallbackWithFallback(callbacks, name, ctx, arg) {\n const result = callbacks[name].call(ctx, arg);\n if (typeof result === 'undefined') {\n return defaultCallbacks[name].call(ctx, arg);\n }\n return result;\n}\nclass Tooltip extends Element {\n static positioners = positioners;\n constructor(config){\n super();\n this.opacity = 0;\n this._active = [];\n this._eventPosition = undefined;\n this._size = undefined;\n this._cachedAnimations = undefined;\n this._tooltipItems = [];\n this.$animations = undefined;\n this.$context = undefined;\n this.chart = config.chart;\n this.options = config.options;\n this.dataPoints = undefined;\n this.title = undefined;\n this.beforeBody = undefined;\n this.body = undefined;\n this.afterBody = undefined;\n this.footer = undefined;\n this.xAlign = undefined;\n this.yAlign = undefined;\n this.x = undefined;\n this.y = undefined;\n this.height = undefined;\n this.width = undefined;\n this.caretX = undefined;\n this.caretY = undefined;\n this.labelColors = undefined;\n this.labelPointStyles = undefined;\n this.labelTextColors = undefined;\n }\n initialize(options) {\n this.options = options;\n this._cachedAnimations = undefined;\n this.$context = undefined;\n }\n _resolveAnimations() {\n const cached = this._cachedAnimations;\n if (cached) {\n return cached;\n }\n const chart = this.chart;\n const options = this.options.setContext(this.getContext());\n const opts = options.enabled && chart.options.animation && options.animations;\n const animations = new Animations(this.chart, opts);\n if (opts._cacheable) {\n this._cachedAnimations = Object.freeze(animations);\n }\n return animations;\n }\n getContext() {\n return this.$context || (this.$context = createTooltipContext(this.chart.getContext(), this, this._tooltipItems));\n }\n getTitle(context, options) {\n const { callbacks } = options;\n const beforeTitle = invokeCallbackWithFallback(callbacks, 'beforeTitle', this, context);\n const title = invokeCallbackWithFallback(callbacks, 'title', this, context);\n const afterTitle = invokeCallbackWithFallback(callbacks, 'afterTitle', this, context);\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeTitle));\n lines = pushOrConcat(lines, splitNewlines(title));\n lines = pushOrConcat(lines, splitNewlines(afterTitle));\n return lines;\n }\n getBeforeBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(invokeCallbackWithFallback(options.callbacks, 'beforeBody', this, tooltipItems));\n }\n getBody(tooltipItems, options) {\n const { callbacks } = options;\n const bodyItems = [];\n each(tooltipItems, (context)=>{\n const bodyItem = {\n before: [],\n lines: [],\n after: []\n };\n const scoped = overrideCallbacks(callbacks, context);\n pushOrConcat(bodyItem.before, splitNewlines(invokeCallbackWithFallback(scoped, 'beforeLabel', this, context)));\n pushOrConcat(bodyItem.lines, invokeCallbackWithFallback(scoped, 'label', this, context));\n pushOrConcat(bodyItem.after, splitNewlines(invokeCallbackWithFallback(scoped, 'afterLabel', this, context)));\n bodyItems.push(bodyItem);\n });\n return bodyItems;\n }\n getAfterBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(invokeCallbackWithFallback(options.callbacks, 'afterBody', this, tooltipItems));\n }\n getFooter(tooltipItems, options) {\n const { callbacks } = options;\n const beforeFooter = invokeCallbackWithFallback(callbacks, 'beforeFooter', this, tooltipItems);\n const footer = invokeCallbackWithFallback(callbacks, 'footer', this, tooltipItems);\n const afterFooter = invokeCallbackWithFallback(callbacks, 'afterFooter', this, tooltipItems);\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeFooter));\n lines = pushOrConcat(lines, splitNewlines(footer));\n lines = pushOrConcat(lines, splitNewlines(afterFooter));\n return lines;\n }\n _createItems(options) {\n const active = this._active;\n const data = this.chart.data;\n const labelColors = [];\n const labelPointStyles = [];\n const labelTextColors = [];\n let tooltipItems = [];\n let i, len;\n for(i = 0, len = active.length; i < len; ++i){\n tooltipItems.push(createTooltipItem(this.chart, active[i]));\n }\n if (options.filter) {\n tooltipItems = tooltipItems.filter((element, index, array)=>options.filter(element, index, array, data));\n }\n if (options.itemSort) {\n tooltipItems = tooltipItems.sort((a, b)=>options.itemSort(a, b, data));\n }\n each(tooltipItems, (context)=>{\n const scoped = overrideCallbacks(options.callbacks, context);\n labelColors.push(invokeCallbackWithFallback(scoped, 'labelColor', this, context));\n labelPointStyles.push(invokeCallbackWithFallback(scoped, 'labelPointStyle', this, context));\n labelTextColors.push(invokeCallbackWithFallback(scoped, 'labelTextColor', this, context));\n });\n this.labelColors = labelColors;\n this.labelPointStyles = labelPointStyles;\n this.labelTextColors = labelTextColors;\n this.dataPoints = tooltipItems;\n return tooltipItems;\n }\n update(changed, replay) {\n const options = this.options.setContext(this.getContext());\n const active = this._active;\n let properties;\n let tooltipItems = [];\n if (!active.length) {\n if (this.opacity !== 0) {\n properties = {\n opacity: 0\n };\n }\n } else {\n const position = positioners[options.position].call(this, active, this._eventPosition);\n tooltipItems = this._createItems(options);\n this.title = this.getTitle(tooltipItems, options);\n this.beforeBody = this.getBeforeBody(tooltipItems, options);\n this.body = this.getBody(tooltipItems, options);\n this.afterBody = this.getAfterBody(tooltipItems, options);\n this.footer = this.getFooter(tooltipItems, options);\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, size);\n const alignment = determineAlignment(this.chart, options, positionAndSize);\n const backgroundPoint = getBackgroundPoint(options, positionAndSize, alignment, this.chart);\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n properties = {\n opacity: 1,\n x: backgroundPoint.x,\n y: backgroundPoint.y,\n width: size.width,\n height: size.height,\n caretX: position.x,\n caretY: position.y\n };\n }\n this._tooltipItems = tooltipItems;\n this.$context = undefined;\n if (properties) {\n this._resolveAnimations().update(this, properties);\n }\n if (changed && options.external) {\n options.external.call(this, {\n chart: this.chart,\n tooltip: this,\n replay\n });\n }\n }\n drawCaret(tooltipPoint, ctx, size, options) {\n const caretPosition = this.getCaretPosition(tooltipPoint, size, options);\n ctx.lineTo(caretPosition.x1, caretPosition.y1);\n ctx.lineTo(caretPosition.x2, caretPosition.y2);\n ctx.lineTo(caretPosition.x3, caretPosition.y3);\n }\n getCaretPosition(tooltipPoint, size, options) {\n const { xAlign , yAlign } = this;\n const { caretSize , cornerRadius } = options;\n const { topLeft , topRight , bottomLeft , bottomRight } = toTRBLCorners(cornerRadius);\n const { x: ptX , y: ptY } = tooltipPoint;\n const { width , height } = size;\n let x1, x2, x3, y1, y2, y3;\n if (yAlign === 'center') {\n y2 = ptY + height / 2;\n if (xAlign === 'left') {\n x1 = ptX;\n x2 = x1 - caretSize;\n y1 = y2 + caretSize;\n y3 = y2 - caretSize;\n } else {\n x1 = ptX + width;\n x2 = x1 + caretSize;\n y1 = y2 - caretSize;\n y3 = y2 + caretSize;\n }\n x3 = x1;\n } else {\n if (xAlign === 'left') {\n x2 = ptX + Math.max(topLeft, bottomLeft) + caretSize;\n } else if (xAlign === 'right') {\n x2 = ptX + width - Math.max(topRight, bottomRight) - caretSize;\n } else {\n x2 = this.caretX;\n }\n if (yAlign === 'top') {\n y1 = ptY;\n y2 = y1 - caretSize;\n x1 = x2 - caretSize;\n x3 = x2 + caretSize;\n } else {\n y1 = ptY + height;\n y2 = y1 + caretSize;\n x1 = x2 + caretSize;\n x3 = x2 - caretSize;\n }\n y3 = y1;\n }\n return {\n x1,\n x2,\n x3,\n y1,\n y2,\n y3\n };\n }\n drawTitle(pt, ctx, options) {\n const title = this.title;\n const length = title.length;\n let titleFont, titleSpacing, i;\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n pt.x = getAlignedX(this, options.titleAlign, options);\n ctx.textAlign = rtlHelper.textAlign(options.titleAlign);\n ctx.textBaseline = 'middle';\n titleFont = toFont(options.titleFont);\n titleSpacing = options.titleSpacing;\n ctx.fillStyle = options.titleColor;\n ctx.font = titleFont.string;\n for(i = 0; i < length; ++i){\n ctx.fillText(title[i], rtlHelper.x(pt.x), pt.y + titleFont.lineHeight / 2);\n pt.y += titleFont.lineHeight + titleSpacing;\n if (i + 1 === length) {\n pt.y += options.titleMarginBottom - titleSpacing;\n }\n }\n }\n }\n _drawColorBox(ctx, pt, i, rtlHelper, options) {\n const labelColors = this.labelColors[i];\n const labelPointStyle = this.labelPointStyles[i];\n const { boxHeight , boxWidth , boxPadding } = options;\n const bodyFont = toFont(options.bodyFont);\n const colorX = getAlignedX(this, 'left', options);\n const rtlColorX = rtlHelper.x(colorX);\n const yOffSet = boxHeight < bodyFont.lineHeight ? (bodyFont.lineHeight - boxHeight) / 2 : 0;\n const colorY = pt.y + yOffSet;\n if (options.usePointStyle) {\n const drawOptions = {\n radius: Math.min(boxWidth, boxHeight) / 2,\n pointStyle: labelPointStyle.pointStyle,\n rotation: labelPointStyle.rotation,\n borderWidth: 1\n };\n const centerX = rtlHelper.leftForLtr(rtlColorX, boxWidth) + boxWidth / 2;\n const centerY = colorY + boxHeight / 2;\n ctx.strokeStyle = options.multiKeyBackground;\n ctx.fillStyle = options.multiKeyBackground;\n drawPoint(ctx, drawOptions, centerX, centerY);\n ctx.strokeStyle = labelColors.borderColor;\n ctx.fillStyle = labelColors.backgroundColor;\n drawPoint(ctx, drawOptions, centerX, centerY);\n } else {\n ctx.lineWidth = isObject(labelColors.borderWidth) ? Math.max(...Object.values(labelColors.borderWidth)) : labelColors.borderWidth || 1;\n ctx.strokeStyle = labelColors.borderColor;\n ctx.setLineDash(labelColors.borderDash || []);\n ctx.lineDashOffset = labelColors.borderDashOffset || 0;\n const outerX = rtlHelper.leftForLtr(rtlColorX, boxWidth - boxPadding);\n const innerX = rtlHelper.leftForLtr(rtlHelper.xPlus(rtlColorX, 1), boxWidth - boxPadding - 2);\n const borderRadius = toTRBLCorners(labelColors.borderRadius);\n if (Object.values(borderRadius).some((v)=>v !== 0)) {\n ctx.beginPath();\n ctx.fillStyle = options.multiKeyBackground;\n addRoundedRectPath(ctx, {\n x: outerX,\n y: colorY,\n w: boxWidth,\n h: boxHeight,\n radius: borderRadius\n });\n ctx.fill();\n ctx.stroke();\n ctx.fillStyle = labelColors.backgroundColor;\n ctx.beginPath();\n addRoundedRectPath(ctx, {\n x: innerX,\n y: colorY + 1,\n w: boxWidth - 2,\n h: boxHeight - 2,\n radius: borderRadius\n });\n ctx.fill();\n } else {\n ctx.fillStyle = options.multiKeyBackground;\n ctx.fillRect(outerX, colorY, boxWidth, boxHeight);\n ctx.strokeRect(outerX, colorY, boxWidth, boxHeight);\n ctx.fillStyle = labelColors.backgroundColor;\n ctx.fillRect(innerX, colorY + 1, boxWidth - 2, boxHeight - 2);\n }\n }\n ctx.fillStyle = this.labelTextColors[i];\n }\n drawBody(pt, ctx, options) {\n const { body } = this;\n const { bodySpacing , bodyAlign , displayColors , boxHeight , boxWidth , boxPadding } = options;\n const bodyFont = toFont(options.bodyFont);\n let bodyLineHeight = bodyFont.lineHeight;\n let xLinePadding = 0;\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n const fillLineOfText = function(line) {\n ctx.fillText(line, rtlHelper.x(pt.x + xLinePadding), pt.y + bodyLineHeight / 2);\n pt.y += bodyLineHeight + bodySpacing;\n };\n const bodyAlignForCalculation = rtlHelper.textAlign(bodyAlign);\n let bodyItem, textColor, lines, i, j, ilen, jlen;\n ctx.textAlign = bodyAlign;\n ctx.textBaseline = 'middle';\n ctx.font = bodyFont.string;\n pt.x = getAlignedX(this, bodyAlignForCalculation, options);\n ctx.fillStyle = options.bodyColor;\n each(this.beforeBody, fillLineOfText);\n xLinePadding = displayColors && bodyAlignForCalculation !== 'right' ? bodyAlign === 'center' ? boxWidth / 2 + boxPadding : boxWidth + 2 + boxPadding : 0;\n for(i = 0, ilen = body.length; i < ilen; ++i){\n bodyItem = body[i];\n textColor = this.labelTextColors[i];\n ctx.fillStyle = textColor;\n each(bodyItem.before, fillLineOfText);\n lines = bodyItem.lines;\n if (displayColors && lines.length) {\n this._drawColorBox(ctx, pt, i, rtlHelper, options);\n bodyLineHeight = Math.max(bodyFont.lineHeight, boxHeight);\n }\n for(j = 0, jlen = lines.length; j < jlen; ++j){\n fillLineOfText(lines[j]);\n bodyLineHeight = bodyFont.lineHeight;\n }\n each(bodyItem.after, fillLineOfText);\n }\n xLinePadding = 0;\n bodyLineHeight = bodyFont.lineHeight;\n each(this.afterBody, fillLineOfText);\n pt.y -= bodySpacing;\n }\n drawFooter(pt, ctx, options) {\n const footer = this.footer;\n const length = footer.length;\n let footerFont, i;\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n pt.x = getAlignedX(this, options.footerAlign, options);\n pt.y += options.footerMarginTop;\n ctx.textAlign = rtlHelper.textAlign(options.footerAlign);\n ctx.textBaseline = 'middle';\n footerFont = toFont(options.footerFont);\n ctx.fillStyle = options.footerColor;\n ctx.font = footerFont.string;\n for(i = 0; i < length; ++i){\n ctx.fillText(footer[i], rtlHelper.x(pt.x), pt.y + footerFont.lineHeight / 2);\n pt.y += footerFont.lineHeight + options.footerSpacing;\n }\n }\n }\n drawBackground(pt, ctx, tooltipSize, options) {\n const { xAlign , yAlign } = this;\n const { x , y } = pt;\n const { width , height } = tooltipSize;\n const { topLeft , topRight , bottomLeft , bottomRight } = toTRBLCorners(options.cornerRadius);\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n ctx.lineWidth = options.borderWidth;\n ctx.beginPath();\n ctx.moveTo(x + topLeft, y);\n if (yAlign === 'top') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + width - topRight, y);\n ctx.quadraticCurveTo(x + width, y, x + width, y + topRight);\n if (yAlign === 'center' && xAlign === 'right') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + width, y + height - bottomRight);\n ctx.quadraticCurveTo(x + width, y + height, x + width - bottomRight, y + height);\n if (yAlign === 'bottom') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x + bottomLeft, y + height);\n ctx.quadraticCurveTo(x, y + height, x, y + height - bottomLeft);\n if (yAlign === 'center' && xAlign === 'left') {\n this.drawCaret(pt, ctx, tooltipSize, options);\n }\n ctx.lineTo(x, y + topLeft);\n ctx.quadraticCurveTo(x, y, x + topLeft, y);\n ctx.closePath();\n ctx.fill();\n if (options.borderWidth > 0) {\n ctx.stroke();\n }\n }\n _updateAnimationTarget(options) {\n const chart = this.chart;\n const anims = this.$animations;\n const animX = anims && anims.x;\n const animY = anims && anims.y;\n if (animX || animY) {\n const position = positioners[options.position].call(this, this._active, this._eventPosition);\n if (!position) {\n return;\n }\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, this._size);\n const alignment = determineAlignment(chart, options, positionAndSize);\n const point = getBackgroundPoint(options, positionAndSize, alignment, chart);\n if (animX._to !== point.x || animY._to !== point.y) {\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n this.width = size.width;\n this.height = size.height;\n this.caretX = position.x;\n this.caretY = position.y;\n this._resolveAnimations().update(this, point);\n }\n }\n }\n _willRender() {\n return !!this.opacity;\n }\n draw(ctx) {\n const options = this.options.setContext(this.getContext());\n let opacity = this.opacity;\n if (!opacity) {\n return;\n }\n this._updateAnimationTarget(options);\n const tooltipSize = {\n width: this.width,\n height: this.height\n };\n const pt = {\n x: this.x,\n y: this.y\n };\n opacity = Math.abs(opacity) < 1e-3 ? 0 : opacity;\n const padding = toPadding(options.padding);\n const hasTooltipContent = this.title.length || this.beforeBody.length || this.body.length || this.afterBody.length || this.footer.length;\n if (options.enabled && hasTooltipContent) {\n ctx.save();\n ctx.globalAlpha = opacity;\n this.drawBackground(pt, ctx, tooltipSize, options);\n overrideTextDirection(ctx, options.textDirection);\n pt.y += padding.top;\n this.drawTitle(pt, ctx, options);\n this.drawBody(pt, ctx, options);\n this.drawFooter(pt, ctx, options);\n restoreTextDirection(ctx, options.textDirection);\n ctx.restore();\n }\n }\n getActiveElements() {\n return this._active || [];\n }\n setActiveElements(activeElements, eventPosition) {\n const lastActive = this._active;\n const active = activeElements.map(({ datasetIndex , index })=>{\n const meta = this.chart.getDatasetMeta(datasetIndex);\n if (!meta) {\n throw new Error('Cannot find a dataset at index ' + datasetIndex);\n }\n return {\n datasetIndex,\n element: meta.data[index],\n index\n };\n });\n const changed = !_elementsEqual(lastActive, active);\n const positionChanged = this._positionChanged(active, eventPosition);\n if (changed || positionChanged) {\n this._active = active;\n this._eventPosition = eventPosition;\n this._ignoreReplayEvents = true;\n this.update(true);\n }\n }\n handleEvent(e, replay, inChartArea = true) {\n if (replay && this._ignoreReplayEvents) {\n return false;\n }\n this._ignoreReplayEvents = false;\n const options = this.options;\n const lastActive = this._active || [];\n const active = this._getActiveElements(e, lastActive, replay, inChartArea);\n const positionChanged = this._positionChanged(active, e);\n const changed = replay || !_elementsEqual(active, lastActive) || positionChanged;\n if (changed) {\n this._active = active;\n if (options.enabled || options.external) {\n this._eventPosition = {\n x: e.x,\n y: e.y\n };\n this.update(true, replay);\n }\n }\n return changed;\n }\n _getActiveElements(e, lastActive, replay, inChartArea) {\n const options = this.options;\n if (e.type === 'mouseout') {\n return [];\n }\n if (!inChartArea) {\n return lastActive;\n }\n const active = this.chart.getElementsAtEventForMode(e, options.mode, options, replay);\n if (options.reverse) {\n active.reverse();\n }\n return active;\n }\n _positionChanged(active, e) {\n const { caretX , caretY , options } = this;\n const position = positioners[options.position].call(this, active, e);\n return position !== false && (caretX !== position.x || caretY !== position.y);\n }\n}\nvar plugin_tooltip = {\n id: 'tooltip',\n _element: Tooltip,\n positioners,\n afterInit (chart, _args, options) {\n if (options) {\n chart.tooltip = new Tooltip({\n chart,\n options\n });\n }\n },\n beforeUpdate (chart, _args, options) {\n if (chart.tooltip) {\n chart.tooltip.initialize(options);\n }\n },\n reset (chart, _args, options) {\n if (chart.tooltip) {\n chart.tooltip.initialize(options);\n }\n },\n afterDraw (chart) {\n const tooltip = chart.tooltip;\n if (tooltip && tooltip._willRender()) {\n const args = {\n tooltip\n };\n if (chart.notifyPlugins('beforeTooltipDraw', {\n ...args,\n cancelable: true\n }) === false) {\n return;\n }\n tooltip.draw(chart.ctx);\n chart.notifyPlugins('afterTooltipDraw', args);\n }\n },\n afterEvent (chart, args) {\n if (chart.tooltip) {\n const useFinalPosition = args.replay;\n if (chart.tooltip.handleEvent(args.event, useFinalPosition, args.inChartArea)) {\n args.changed = true;\n }\n }\n },\n defaults: {\n enabled: true,\n external: null,\n position: 'average',\n backgroundColor: 'rgba(0,0,0,0.8)',\n titleColor: '#fff',\n titleFont: {\n weight: 'bold'\n },\n titleSpacing: 2,\n titleMarginBottom: 6,\n titleAlign: 'left',\n bodyColor: '#fff',\n bodySpacing: 2,\n bodyFont: {},\n bodyAlign: 'left',\n footerColor: '#fff',\n footerSpacing: 2,\n footerMarginTop: 6,\n footerFont: {\n weight: 'bold'\n },\n footerAlign: 'left',\n padding: 6,\n caretPadding: 2,\n caretSize: 5,\n cornerRadius: 6,\n boxHeight: (ctx, opts)=>opts.bodyFont.size,\n boxWidth: (ctx, opts)=>opts.bodyFont.size,\n multiKeyBackground: '#fff',\n displayColors: true,\n boxPadding: 0,\n borderColor: 'rgba(0,0,0,0)',\n borderWidth: 0,\n animation: {\n duration: 400,\n easing: 'easeOutQuart'\n },\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'width',\n 'height',\n 'caretX',\n 'caretY'\n ]\n },\n opacity: {\n easing: 'linear',\n duration: 200\n }\n },\n callbacks: defaultCallbacks\n },\n defaultRoutes: {\n bodyFont: 'font',\n footerFont: 'font',\n titleFont: 'font'\n },\n descriptors: {\n _scriptable: (name)=>name !== 'filter' && name !== 'itemSort' && name !== 'external',\n _indexable: false,\n callbacks: {\n _scriptable: false,\n _indexable: false\n },\n animation: {\n _fallback: false\n },\n animations: {\n _fallback: 'animation'\n }\n },\n additionalOptionScopes: [\n 'interaction'\n ]\n};\n\nvar plugins = /*#__PURE__*/Object.freeze({\n__proto__: null,\nColors: plugin_colors,\nDecimation: plugin_decimation,\nFiller: index,\nLegend: plugin_legend,\nSubTitle: plugin_subtitle,\nTitle: plugin_title,\nTooltip: plugin_tooltip\n});\n\nconst addIfString = (labels, raw, index, addedLabels)=>{\n if (typeof raw === 'string') {\n index = labels.push(raw) - 1;\n addedLabels.unshift({\n index,\n label: raw\n });\n } else if (isNaN(raw)) {\n index = null;\n }\n return index;\n};\nfunction findOrAddLabel(labels, raw, index, addedLabels) {\n const first = labels.indexOf(raw);\n if (first === -1) {\n return addIfString(labels, raw, index, addedLabels);\n }\n const last = labels.lastIndexOf(raw);\n return first !== last ? index : first;\n}\nconst validIndex = (index, max)=>index === null ? null : _limitValue(Math.round(index), 0, max);\nfunction _getLabelForValue(value) {\n const labels = this.getLabels();\n if (value >= 0 && value < labels.length) {\n return labels[value];\n }\n return value;\n}\nclass CategoryScale extends Scale {\n static id = 'category';\n static defaults = {\n ticks: {\n callback: _getLabelForValue\n }\n };\n constructor(cfg){\n super(cfg);\n this._startValue = undefined;\n this._valueRange = 0;\n this._addedLabels = [];\n }\n init(scaleOptions) {\n const added = this._addedLabels;\n if (added.length) {\n const labels = this.getLabels();\n for (const { index , label } of added){\n if (labels[index] === label) {\n labels.splice(index, 1);\n }\n }\n this._addedLabels = [];\n }\n super.init(scaleOptions);\n }\n parse(raw, index) {\n if (isNullOrUndef(raw)) {\n return null;\n }\n const labels = this.getLabels();\n index = isFinite(index) && labels[index] === raw ? index : findOrAddLabel(labels, raw, valueOrDefault(index, raw), this._addedLabels);\n return validIndex(index, labels.length - 1);\n }\n determineDataLimits() {\n const { minDefined , maxDefined } = this.getUserBounds();\n let { min , max } = this.getMinMax(true);\n if (this.options.bounds === 'ticks') {\n if (!minDefined) {\n min = 0;\n }\n if (!maxDefined) {\n max = this.getLabels().length - 1;\n }\n }\n this.min = min;\n this.max = max;\n }\n buildTicks() {\n const min = this.min;\n const max = this.max;\n const offset = this.options.offset;\n const ticks = [];\n let labels = this.getLabels();\n labels = min === 0 && max === labels.length - 1 ? labels : labels.slice(min, max + 1);\n this._valueRange = Math.max(labels.length - (offset ? 0 : 1), 1);\n this._startValue = this.min - (offset ? 0.5 : 0);\n for(let value = min; value <= max; value++){\n ticks.push({\n value\n });\n }\n return ticks;\n }\n getLabelForValue(value) {\n return _getLabelForValue.call(this, value);\n }\n configure() {\n super.configure();\n if (!this.isHorizontal()) {\n this._reversePixels = !this._reversePixels;\n }\n }\n getPixelForValue(value) {\n if (typeof value !== 'number') {\n value = this.parse(value);\n }\n return value === null ? NaN : this.getPixelForDecimal((value - this._startValue) / this._valueRange);\n }\n getPixelForTick(index) {\n const ticks = this.ticks;\n if (index < 0 || index > ticks.length - 1) {\n return null;\n }\n return this.getPixelForValue(ticks[index].value);\n }\n getValueForPixel(pixel) {\n return Math.round(this._startValue + this.getDecimalForPixel(pixel) * this._valueRange);\n }\n getBasePixel() {\n return this.bottom;\n }\n}\n\nfunction generateTicks$1(generationOptions, dataRange) {\n const ticks = [];\n const MIN_SPACING = 1e-14;\n const { bounds , step , min , max , precision , count , maxTicks , maxDigits , includeBounds } = generationOptions;\n const unit = step || 1;\n const maxSpaces = maxTicks - 1;\n const { min: rmin , max: rmax } = dataRange;\n const minDefined = !isNullOrUndef(min);\n const maxDefined = !isNullOrUndef(max);\n const countDefined = !isNullOrUndef(count);\n const minSpacing = (rmax - rmin) / (maxDigits + 1);\n let spacing = niceNum((rmax - rmin) / maxSpaces / unit) * unit;\n let factor, niceMin, niceMax, numSpaces;\n if (spacing < MIN_SPACING && !minDefined && !maxDefined) {\n return [\n {\n value: rmin\n },\n {\n value: rmax\n }\n ];\n }\n numSpaces = Math.ceil(rmax / spacing) - Math.floor(rmin / spacing);\n if (numSpaces > maxSpaces) {\n spacing = niceNum(numSpaces * spacing / maxSpaces / unit) * unit;\n }\n if (!isNullOrUndef(precision)) {\n factor = Math.pow(10, precision);\n spacing = Math.ceil(spacing * factor) / factor;\n }\n if (bounds === 'ticks') {\n niceMin = Math.floor(rmin / spacing) * spacing;\n niceMax = Math.ceil(rmax / spacing) * spacing;\n } else {\n niceMin = rmin;\n niceMax = rmax;\n }\n if (minDefined && maxDefined && step && almostWhole((max - min) / step, spacing / 1000)) {\n numSpaces = Math.round(Math.min((max - min) / spacing, maxTicks));\n spacing = (max - min) / numSpaces;\n niceMin = min;\n niceMax = max;\n } else if (countDefined) {\n niceMin = minDefined ? min : niceMin;\n niceMax = maxDefined ? max : niceMax;\n numSpaces = count - 1;\n spacing = (niceMax - niceMin) / numSpaces;\n } else {\n numSpaces = (niceMax - niceMin) / spacing;\n if (almostEquals(numSpaces, Math.round(numSpaces), spacing / 1000)) {\n numSpaces = Math.round(numSpaces);\n } else {\n numSpaces = Math.ceil(numSpaces);\n }\n }\n const decimalPlaces = Math.max(_decimalPlaces(spacing), _decimalPlaces(niceMin));\n factor = Math.pow(10, isNullOrUndef(precision) ? decimalPlaces : precision);\n niceMin = Math.round(niceMin * factor) / factor;\n niceMax = Math.round(niceMax * factor) / factor;\n let j = 0;\n if (minDefined) {\n if (includeBounds && niceMin !== min) {\n ticks.push({\n value: min\n });\n if (niceMin < min) {\n j++;\n }\n if (almostEquals(Math.round((niceMin + j * spacing) * factor) / factor, min, relativeLabelSize(min, minSpacing, generationOptions))) {\n j++;\n }\n } else if (niceMin < min) {\n j++;\n }\n }\n for(; j < numSpaces; ++j){\n ticks.push({\n value: Math.round((niceMin + j * spacing) * factor) / factor\n });\n }\n if (maxDefined && includeBounds && niceMax !== max) {\n if (ticks.length && almostEquals(ticks[ticks.length - 1].value, max, relativeLabelSize(max, minSpacing, generationOptions))) {\n ticks[ticks.length - 1].value = max;\n } else {\n ticks.push({\n value: max\n });\n }\n } else if (!maxDefined || niceMax === max) {\n ticks.push({\n value: niceMax\n });\n }\n return ticks;\n}\nfunction relativeLabelSize(value, minSpacing, { horizontal , minRotation }) {\n const rad = toRadians(minRotation);\n const ratio = (horizontal ? Math.sin(rad) : Math.cos(rad)) || 0.001;\n const length = 0.75 * minSpacing * ('' + value).length;\n return Math.min(minSpacing / ratio, length);\n}\nclass LinearScaleBase extends Scale {\n constructor(cfg){\n super(cfg);\n this.start = undefined;\n this.end = undefined;\n this._startValue = undefined;\n this._endValue = undefined;\n this._valueRange = 0;\n }\n parse(raw, index) {\n if (isNullOrUndef(raw)) {\n return null;\n }\n if ((typeof raw === 'number' || raw instanceof Number) && !isFinite(+raw)) {\n return null;\n }\n return +raw;\n }\n handleTickRangeOptions() {\n const { beginAtZero } = this.options;\n const { minDefined , maxDefined } = this.getUserBounds();\n let { min , max } = this;\n const setMin = (v)=>min = minDefined ? min : v;\n const setMax = (v)=>max = maxDefined ? max : v;\n if (beginAtZero) {\n const minSign = sign(min);\n const maxSign = sign(max);\n if (minSign < 0 && maxSign < 0) {\n setMax(0);\n } else if (minSign > 0 && maxSign > 0) {\n setMin(0);\n }\n }\n if (min === max) {\n let offset = max === 0 ? 1 : Math.abs(max * 0.05);\n setMax(max + offset);\n if (!beginAtZero) {\n setMin(min - offset);\n }\n }\n this.min = min;\n this.max = max;\n }\n getTickLimit() {\n const tickOpts = this.options.ticks;\n let { maxTicksLimit , stepSize } = tickOpts;\n let maxTicks;\n if (stepSize) {\n maxTicks = Math.ceil(this.max / stepSize) - Math.floor(this.min / stepSize) + 1;\n if (maxTicks > 1000) {\n console.warn(`scales.${this.id}.ticks.stepSize: ${stepSize} would result generating up to ${maxTicks} ticks. Limiting to 1000.`);\n maxTicks = 1000;\n }\n } else {\n maxTicks = this.computeTickLimit();\n maxTicksLimit = maxTicksLimit || 11;\n }\n if (maxTicksLimit) {\n maxTicks = Math.min(maxTicksLimit, maxTicks);\n }\n return maxTicks;\n }\n computeTickLimit() {\n return Number.POSITIVE_INFINITY;\n }\n buildTicks() {\n const opts = this.options;\n const tickOpts = opts.ticks;\n let maxTicks = this.getTickLimit();\n maxTicks = Math.max(2, maxTicks);\n const numericGeneratorOptions = {\n maxTicks,\n bounds: opts.bounds,\n min: opts.min,\n max: opts.max,\n precision: tickOpts.precision,\n step: tickOpts.stepSize,\n count: tickOpts.count,\n maxDigits: this._maxDigits(),\n horizontal: this.isHorizontal(),\n minRotation: tickOpts.minRotation || 0,\n includeBounds: tickOpts.includeBounds !== false\n };\n const dataRange = this._range || this;\n const ticks = generateTicks$1(numericGeneratorOptions, dataRange);\n if (opts.bounds === 'ticks') {\n _setMinAndMaxByKey(ticks, this, 'value');\n }\n if (opts.reverse) {\n ticks.reverse();\n this.start = this.max;\n this.end = this.min;\n } else {\n this.start = this.min;\n this.end = this.max;\n }\n return ticks;\n }\n configure() {\n const ticks = this.ticks;\n let start = this.min;\n let end = this.max;\n super.configure();\n if (this.options.offset && ticks.length) {\n const offset = (end - start) / Math.max(ticks.length - 1, 1) / 2;\n start -= offset;\n end += offset;\n }\n this._startValue = start;\n this._endValue = end;\n this._valueRange = end - start;\n }\n getLabelForValue(value) {\n return formatNumber(value, this.chart.options.locale, this.options.ticks.format);\n }\n}\n\nclass LinearScale extends LinearScaleBase {\n static id = 'linear';\n static defaults = {\n ticks: {\n callback: Ticks.formatters.numeric\n }\n };\n determineDataLimits() {\n const { min , max } = this.getMinMax(true);\n this.min = isNumberFinite(min) ? min : 0;\n this.max = isNumberFinite(max) ? max : 1;\n this.handleTickRangeOptions();\n }\n computeTickLimit() {\n const horizontal = this.isHorizontal();\n const length = horizontal ? this.width : this.height;\n const minRotation = toRadians(this.options.ticks.minRotation);\n const ratio = (horizontal ? Math.sin(minRotation) : Math.cos(minRotation)) || 0.001;\n const tickFont = this._resolveTickFontOptions(0);\n return Math.ceil(length / Math.min(40, tickFont.lineHeight / ratio));\n }\n getPixelForValue(value) {\n return value === null ? NaN : this.getPixelForDecimal((value - this._startValue) / this._valueRange);\n }\n getValueForPixel(pixel) {\n return this._startValue + this.getDecimalForPixel(pixel) * this._valueRange;\n }\n}\n\nconst log10Floor = (v)=>Math.floor(log10(v));\nconst changeExponent = (v, m)=>Math.pow(10, log10Floor(v) + m);\nfunction isMajor(tickVal) {\n const remain = tickVal / Math.pow(10, log10Floor(tickVal));\n return remain === 1;\n}\nfunction steps(min, max, rangeExp) {\n const rangeStep = Math.pow(10, rangeExp);\n const start = Math.floor(min / rangeStep);\n const end = Math.ceil(max / rangeStep);\n return end - start;\n}\nfunction startExp(min, max) {\n const range = max - min;\n let rangeExp = log10Floor(range);\n while(steps(min, max, rangeExp) > 10){\n rangeExp++;\n }\n while(steps(min, max, rangeExp) < 10){\n rangeExp--;\n }\n return Math.min(rangeExp, log10Floor(min));\n}\n function generateTicks(generationOptions, { min , max }) {\n min = finiteOrDefault(generationOptions.min, min);\n const ticks = [];\n const minExp = log10Floor(min);\n let exp = startExp(min, max);\n let precision = exp < 0 ? Math.pow(10, Math.abs(exp)) : 1;\n const stepSize = Math.pow(10, exp);\n const base = minExp > exp ? Math.pow(10, minExp) : 0;\n const start = Math.round((min - base) * precision) / precision;\n const offset = Math.floor((min - base) / stepSize / 10) * stepSize * 10;\n let significand = Math.floor((start - offset) / Math.pow(10, exp));\n let value = finiteOrDefault(generationOptions.min, Math.round((base + offset + significand * Math.pow(10, exp)) * precision) / precision);\n while(value < max){\n ticks.push({\n value,\n major: isMajor(value),\n significand\n });\n if (significand >= 10) {\n significand = significand < 15 ? 15 : 20;\n } else {\n significand++;\n }\n if (significand >= 20) {\n exp++;\n significand = 2;\n precision = exp >= 0 ? 1 : precision;\n }\n value = Math.round((base + offset + significand * Math.pow(10, exp)) * precision) / precision;\n }\n const lastTick = finiteOrDefault(generationOptions.max, value);\n ticks.push({\n value: lastTick,\n major: isMajor(lastTick),\n significand\n });\n return ticks;\n}\nclass LogarithmicScale extends Scale {\n static id = 'logarithmic';\n static defaults = {\n ticks: {\n callback: Ticks.formatters.logarithmic,\n major: {\n enabled: true\n }\n }\n };\n constructor(cfg){\n super(cfg);\n this.start = undefined;\n this.end = undefined;\n this._startValue = undefined;\n this._valueRange = 0;\n }\n parse(raw, index) {\n const value = LinearScaleBase.prototype.parse.apply(this, [\n raw,\n index\n ]);\n if (value === 0) {\n this._zero = true;\n return undefined;\n }\n return isNumberFinite(value) && value > 0 ? value : null;\n }\n determineDataLimits() {\n const { min , max } = this.getMinMax(true);\n this.min = isNumberFinite(min) ? Math.max(0, min) : null;\n this.max = isNumberFinite(max) ? Math.max(0, max) : null;\n if (this.options.beginAtZero) {\n this._zero = true;\n }\n if (this._zero && this.min !== this._suggestedMin && !isNumberFinite(this._userMin)) {\n this.min = min === changeExponent(this.min, 0) ? changeExponent(this.min, -1) : changeExponent(this.min, 0);\n }\n this.handleTickRangeOptions();\n }\n handleTickRangeOptions() {\n const { minDefined , maxDefined } = this.getUserBounds();\n let min = this.min;\n let max = this.max;\n const setMin = (v)=>min = minDefined ? min : v;\n const setMax = (v)=>max = maxDefined ? max : v;\n if (min === max) {\n if (min <= 0) {\n setMin(1);\n setMax(10);\n } else {\n setMin(changeExponent(min, -1));\n setMax(changeExponent(max, +1));\n }\n }\n if (min <= 0) {\n setMin(changeExponent(max, -1));\n }\n if (max <= 0) {\n setMax(changeExponent(min, +1));\n }\n this.min = min;\n this.max = max;\n }\n buildTicks() {\n const opts = this.options;\n const generationOptions = {\n min: this._userMin,\n max: this._userMax\n };\n const ticks = generateTicks(generationOptions, this);\n if (opts.bounds === 'ticks') {\n _setMinAndMaxByKey(ticks, this, 'value');\n }\n if (opts.reverse) {\n ticks.reverse();\n this.start = this.max;\n this.end = this.min;\n } else {\n this.start = this.min;\n this.end = this.max;\n }\n return ticks;\n }\n getLabelForValue(value) {\n return value === undefined ? '0' : formatNumber(value, this.chart.options.locale, this.options.ticks.format);\n }\n configure() {\n const start = this.min;\n super.configure();\n this._startValue = log10(start);\n this._valueRange = log10(this.max) - log10(start);\n }\n getPixelForValue(value) {\n if (value === undefined || value === 0) {\n value = this.min;\n }\n if (value === null || isNaN(value)) {\n return NaN;\n }\n return this.getPixelForDecimal(value === this.min ? 0 : (log10(value) - this._startValue) / this._valueRange);\n }\n getValueForPixel(pixel) {\n const decimal = this.getDecimalForPixel(pixel);\n return Math.pow(10, this._startValue + decimal * this._valueRange);\n }\n}\n\nfunction getTickBackdropHeight(opts) {\n const tickOpts = opts.ticks;\n if (tickOpts.display && opts.display) {\n const padding = toPadding(tickOpts.backdropPadding);\n return valueOrDefault(tickOpts.font && tickOpts.font.size, defaults.font.size) + padding.height;\n }\n return 0;\n}\nfunction measureLabelSize(ctx, font, label) {\n label = isArray(label) ? label : [\n label\n ];\n return {\n w: _longestText(ctx, font.string, label),\n h: label.length * font.lineHeight\n };\n}\nfunction determineLimits(angle, pos, size, min, max) {\n if (angle === min || angle === max) {\n return {\n start: pos - size / 2,\n end: pos + size / 2\n };\n } else if (angle < min || angle > max) {\n return {\n start: pos - size,\n end: pos\n };\n }\n return {\n start: pos,\n end: pos + size\n };\n}\n function fitWithPointLabels(scale) {\n const orig = {\n l: scale.left + scale._padding.left,\n r: scale.right - scale._padding.right,\n t: scale.top + scale._padding.top,\n b: scale.bottom - scale._padding.bottom\n };\n const limits = Object.assign({}, orig);\n const labelSizes = [];\n const padding = [];\n const valueCount = scale._pointLabels.length;\n const pointLabelOpts = scale.options.pointLabels;\n const additionalAngle = pointLabelOpts.centerPointLabels ? PI / valueCount : 0;\n for(let i = 0; i < valueCount; i++){\n const opts = pointLabelOpts.setContext(scale.getPointLabelContext(i));\n padding[i] = opts.padding;\n const pointPosition = scale.getPointPosition(i, scale.drawingArea + padding[i], additionalAngle);\n const plFont = toFont(opts.font);\n const textSize = measureLabelSize(scale.ctx, plFont, scale._pointLabels[i]);\n labelSizes[i] = textSize;\n const angleRadians = _normalizeAngle(scale.getIndexAngle(i) + additionalAngle);\n const angle = Math.round(toDegrees(angleRadians));\n const hLimits = determineLimits(angle, pointPosition.x, textSize.w, 0, 180);\n const vLimits = determineLimits(angle, pointPosition.y, textSize.h, 90, 270);\n updateLimits(limits, orig, angleRadians, hLimits, vLimits);\n }\n scale.setCenterPoint(orig.l - limits.l, limits.r - orig.r, orig.t - limits.t, limits.b - orig.b);\n scale._pointLabelItems = buildPointLabelItems(scale, labelSizes, padding);\n}\nfunction updateLimits(limits, orig, angle, hLimits, vLimits) {\n const sin = Math.abs(Math.sin(angle));\n const cos = Math.abs(Math.cos(angle));\n let x = 0;\n let y = 0;\n if (hLimits.start < orig.l) {\n x = (orig.l - hLimits.start) / sin;\n limits.l = Math.min(limits.l, orig.l - x);\n } else if (hLimits.end > orig.r) {\n x = (hLimits.end - orig.r) / sin;\n limits.r = Math.max(limits.r, orig.r + x);\n }\n if (vLimits.start < orig.t) {\n y = (orig.t - vLimits.start) / cos;\n limits.t = Math.min(limits.t, orig.t - y);\n } else if (vLimits.end > orig.b) {\n y = (vLimits.end - orig.b) / cos;\n limits.b = Math.max(limits.b, orig.b + y);\n }\n}\nfunction buildPointLabelItems(scale, labelSizes, padding) {\n const items = [];\n const valueCount = scale._pointLabels.length;\n const opts = scale.options;\n const extra = getTickBackdropHeight(opts) / 2;\n const outerDistance = scale.drawingArea;\n const additionalAngle = opts.pointLabels.centerPointLabels ? PI / valueCount : 0;\n for(let i = 0; i < valueCount; i++){\n const pointLabelPosition = scale.getPointPosition(i, outerDistance + extra + padding[i], additionalAngle);\n const angle = Math.round(toDegrees(_normalizeAngle(pointLabelPosition.angle + HALF_PI)));\n const size = labelSizes[i];\n const y = yForAngle(pointLabelPosition.y, size.h, angle);\n const textAlign = getTextAlignForAngle(angle);\n const left = leftForTextAlign(pointLabelPosition.x, size.w, textAlign);\n items.push({\n x: pointLabelPosition.x,\n y,\n textAlign,\n left,\n top: y,\n right: left + size.w,\n bottom: y + size.h\n });\n }\n return items;\n}\nfunction getTextAlignForAngle(angle) {\n if (angle === 0 || angle === 180) {\n return 'center';\n } else if (angle < 180) {\n return 'left';\n }\n return 'right';\n}\nfunction leftForTextAlign(x, w, align) {\n if (align === 'right') {\n x -= w;\n } else if (align === 'center') {\n x -= w / 2;\n }\n return x;\n}\nfunction yForAngle(y, h, angle) {\n if (angle === 90 || angle === 270) {\n y -= h / 2;\n } else if (angle > 270 || angle < 90) {\n y -= h;\n }\n return y;\n}\nfunction drawPointLabels(scale, labelCount) {\n const { ctx , options: { pointLabels } } = scale;\n for(let i = labelCount - 1; i >= 0; i--){\n const optsAtIndex = pointLabels.setContext(scale.getPointLabelContext(i));\n const plFont = toFont(optsAtIndex.font);\n const { x , y , textAlign , left , top , right , bottom } = scale._pointLabelItems[i];\n const { backdropColor } = optsAtIndex;\n if (!isNullOrUndef(backdropColor)) {\n const borderRadius = toTRBLCorners(optsAtIndex.borderRadius);\n const padding = toPadding(optsAtIndex.backdropPadding);\n ctx.fillStyle = backdropColor;\n const backdropLeft = left - padding.left;\n const backdropTop = top - padding.top;\n const backdropWidth = right - left + padding.width;\n const backdropHeight = bottom - top + padding.height;\n if (Object.values(borderRadius).some((v)=>v !== 0)) {\n ctx.beginPath();\n addRoundedRectPath(ctx, {\n x: backdropLeft,\n y: backdropTop,\n w: backdropWidth,\n h: backdropHeight,\n radius: borderRadius\n });\n ctx.fill();\n } else {\n ctx.fillRect(backdropLeft, backdropTop, backdropWidth, backdropHeight);\n }\n }\n renderText(ctx, scale._pointLabels[i], x, y + plFont.lineHeight / 2, plFont, {\n color: optsAtIndex.color,\n textAlign: textAlign,\n textBaseline: 'middle'\n });\n }\n}\nfunction pathRadiusLine(scale, radius, circular, labelCount) {\n const { ctx } = scale;\n if (circular) {\n ctx.arc(scale.xCenter, scale.yCenter, radius, 0, TAU);\n } else {\n let pointPosition = scale.getPointPosition(0, radius);\n ctx.moveTo(pointPosition.x, pointPosition.y);\n for(let i = 1; i < labelCount; i++){\n pointPosition = scale.getPointPosition(i, radius);\n ctx.lineTo(pointPosition.x, pointPosition.y);\n }\n }\n}\nfunction drawRadiusLine(scale, gridLineOpts, radius, labelCount, borderOpts) {\n const ctx = scale.ctx;\n const circular = gridLineOpts.circular;\n const { color , lineWidth } = gridLineOpts;\n if (!circular && !labelCount || !color || !lineWidth || radius < 0) {\n return;\n }\n ctx.save();\n ctx.strokeStyle = color;\n ctx.lineWidth = lineWidth;\n ctx.setLineDash(borderOpts.dash);\n ctx.lineDashOffset = borderOpts.dashOffset;\n ctx.beginPath();\n pathRadiusLine(scale, radius, circular, labelCount);\n ctx.closePath();\n ctx.stroke();\n ctx.restore();\n}\nfunction createPointLabelContext(parent, index, label) {\n return createContext(parent, {\n label,\n index,\n type: 'pointLabel'\n });\n}\nclass RadialLinearScale extends LinearScaleBase {\n static id = 'radialLinear';\n static defaults = {\n display: true,\n animate: true,\n position: 'chartArea',\n angleLines: {\n display: true,\n lineWidth: 1,\n borderDash: [],\n borderDashOffset: 0.0\n },\n grid: {\n circular: false\n },\n startAngle: 0,\n ticks: {\n showLabelBackdrop: true,\n callback: Ticks.formatters.numeric\n },\n pointLabels: {\n backdropColor: undefined,\n backdropPadding: 2,\n display: true,\n font: {\n size: 10\n },\n callback (label) {\n return label;\n },\n padding: 5,\n centerPointLabels: false\n }\n };\n static defaultRoutes = {\n 'angleLines.color': 'borderColor',\n 'pointLabels.color': 'color',\n 'ticks.color': 'color'\n };\n static descriptors = {\n angleLines: {\n _fallback: 'grid'\n }\n };\n constructor(cfg){\n super(cfg);\n this.xCenter = undefined;\n this.yCenter = undefined;\n this.drawingArea = undefined;\n this._pointLabels = [];\n this._pointLabelItems = [];\n }\n setDimensions() {\n const padding = this._padding = toPadding(getTickBackdropHeight(this.options) / 2);\n const w = this.width = this.maxWidth - padding.width;\n const h = this.height = this.maxHeight - padding.height;\n this.xCenter = Math.floor(this.left + w / 2 + padding.left);\n this.yCenter = Math.floor(this.top + h / 2 + padding.top);\n this.drawingArea = Math.floor(Math.min(w, h) / 2);\n }\n determineDataLimits() {\n const { min , max } = this.getMinMax(false);\n this.min = isNumberFinite(min) && !isNaN(min) ? min : 0;\n this.max = isNumberFinite(max) && !isNaN(max) ? max : 0;\n this.handleTickRangeOptions();\n }\n computeTickLimit() {\n return Math.ceil(this.drawingArea / getTickBackdropHeight(this.options));\n }\n generateTickLabels(ticks) {\n LinearScaleBase.prototype.generateTickLabels.call(this, ticks);\n this._pointLabels = this.getLabels().map((value, index)=>{\n const label = callback(this.options.pointLabels.callback, [\n value,\n index\n ], this);\n return label || label === 0 ? label : '';\n }).filter((v, i)=>this.chart.getDataVisibility(i));\n }\n fit() {\n const opts = this.options;\n if (opts.display && opts.pointLabels.display) {\n fitWithPointLabels(this);\n } else {\n this.setCenterPoint(0, 0, 0, 0);\n }\n }\n setCenterPoint(leftMovement, rightMovement, topMovement, bottomMovement) {\n this.xCenter += Math.floor((leftMovement - rightMovement) / 2);\n this.yCenter += Math.floor((topMovement - bottomMovement) / 2);\n this.drawingArea -= Math.min(this.drawingArea / 2, Math.max(leftMovement, rightMovement, topMovement, bottomMovement));\n }\n getIndexAngle(index) {\n const angleMultiplier = TAU / (this._pointLabels.length || 1);\n const startAngle = this.options.startAngle || 0;\n return _normalizeAngle(index * angleMultiplier + toRadians(startAngle));\n }\n getDistanceFromCenterForValue(value) {\n if (isNullOrUndef(value)) {\n return NaN;\n }\n const scalingFactor = this.drawingArea / (this.max - this.min);\n if (this.options.reverse) {\n return (this.max - value) * scalingFactor;\n }\n return (value - this.min) * scalingFactor;\n }\n getValueForDistanceFromCenter(distance) {\n if (isNullOrUndef(distance)) {\n return NaN;\n }\n const scaledDistance = distance / (this.drawingArea / (this.max - this.min));\n return this.options.reverse ? this.max - scaledDistance : this.min + scaledDistance;\n }\n getPointLabelContext(index) {\n const pointLabels = this._pointLabels || [];\n if (index >= 0 && index < pointLabels.length) {\n const pointLabel = pointLabels[index];\n return createPointLabelContext(this.getContext(), index, pointLabel);\n }\n }\n getPointPosition(index, distanceFromCenter, additionalAngle = 0) {\n const angle = this.getIndexAngle(index) - HALF_PI + additionalAngle;\n return {\n x: Math.cos(angle) * distanceFromCenter + this.xCenter,\n y: Math.sin(angle) * distanceFromCenter + this.yCenter,\n angle\n };\n }\n getPointPositionForValue(index, value) {\n return this.getPointPosition(index, this.getDistanceFromCenterForValue(value));\n }\n getBasePosition(index) {\n return this.getPointPositionForValue(index || 0, this.getBaseValue());\n }\n getPointLabelPosition(index) {\n const { left , top , right , bottom } = this._pointLabelItems[index];\n return {\n left,\n top,\n right,\n bottom\n };\n }\n drawBackground() {\n const { backgroundColor , grid: { circular } } = this.options;\n if (backgroundColor) {\n const ctx = this.ctx;\n ctx.save();\n ctx.beginPath();\n pathRadiusLine(this, this.getDistanceFromCenterForValue(this._endValue), circular, this._pointLabels.length);\n ctx.closePath();\n ctx.fillStyle = backgroundColor;\n ctx.fill();\n ctx.restore();\n }\n }\n drawGrid() {\n const ctx = this.ctx;\n const opts = this.options;\n const { angleLines , grid , border } = opts;\n const labelCount = this._pointLabels.length;\n let i, offset, position;\n if (opts.pointLabels.display) {\n drawPointLabels(this, labelCount);\n }\n if (grid.display) {\n this.ticks.forEach((tick, index)=>{\n if (index !== 0) {\n offset = this.getDistanceFromCenterForValue(tick.value);\n const context = this.getContext(index);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n drawRadiusLine(this, optsAtIndex, offset, labelCount, optsAtIndexBorder);\n }\n });\n }\n if (angleLines.display) {\n ctx.save();\n for(i = labelCount - 1; i >= 0; i--){\n const optsAtIndex = angleLines.setContext(this.getPointLabelContext(i));\n const { color , lineWidth } = optsAtIndex;\n if (!lineWidth || !color) {\n continue;\n }\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = color;\n ctx.setLineDash(optsAtIndex.borderDash);\n ctx.lineDashOffset = optsAtIndex.borderDashOffset;\n offset = this.getDistanceFromCenterForValue(opts.ticks.reverse ? this.min : this.max);\n position = this.getPointPosition(i, offset);\n ctx.beginPath();\n ctx.moveTo(this.xCenter, this.yCenter);\n ctx.lineTo(position.x, position.y);\n ctx.stroke();\n }\n ctx.restore();\n }\n }\n drawBorder() {}\n drawLabels() {\n const ctx = this.ctx;\n const opts = this.options;\n const tickOpts = opts.ticks;\n if (!tickOpts.display) {\n return;\n }\n const startAngle = this.getIndexAngle(0);\n let offset, width;\n ctx.save();\n ctx.translate(this.xCenter, this.yCenter);\n ctx.rotate(startAngle);\n ctx.textAlign = 'center';\n ctx.textBaseline = 'middle';\n this.ticks.forEach((tick, index)=>{\n if (index === 0 && !opts.reverse) {\n return;\n }\n const optsAtIndex = tickOpts.setContext(this.getContext(index));\n const tickFont = toFont(optsAtIndex.font);\n offset = this.getDistanceFromCenterForValue(this.ticks[index].value);\n if (optsAtIndex.showLabelBackdrop) {\n ctx.font = tickFont.string;\n width = ctx.measureText(tick.label).width;\n ctx.fillStyle = optsAtIndex.backdropColor;\n const padding = toPadding(optsAtIndex.backdropPadding);\n ctx.fillRect(-width / 2 - padding.left, -offset - tickFont.size / 2 - padding.top, width + padding.width, tickFont.size + padding.height);\n }\n renderText(ctx, tick.label, 0, -offset, tickFont, {\n color: optsAtIndex.color\n });\n });\n ctx.restore();\n }\n drawTitle() {}\n}\n\nconst INTERVALS = {\n millisecond: {\n common: true,\n size: 1,\n steps: 1000\n },\n second: {\n common: true,\n size: 1000,\n steps: 60\n },\n minute: {\n common: true,\n size: 60000,\n steps: 60\n },\n hour: {\n common: true,\n size: 3600000,\n steps: 24\n },\n day: {\n common: true,\n size: 86400000,\n steps: 30\n },\n week: {\n common: false,\n size: 604800000,\n steps: 4\n },\n month: {\n common: true,\n size: 2.628e9,\n steps: 12\n },\n quarter: {\n common: false,\n size: 7.884e9,\n steps: 4\n },\n year: {\n common: true,\n size: 3.154e10\n }\n};\n const UNITS = /* #__PURE__ */ Object.keys(INTERVALS);\n function sorter(a, b) {\n return a - b;\n}\n function parse(scale, input) {\n if (isNullOrUndef(input)) {\n return null;\n }\n const adapter = scale._adapter;\n const { parser , round , isoWeekday } = scale._parseOpts;\n let value = input;\n if (typeof parser === 'function') {\n value = parser(value);\n }\n if (!isNumberFinite(value)) {\n value = typeof parser === 'string' ? adapter.parse(value, parser) : adapter.parse(value);\n }\n if (value === null) {\n return null;\n }\n if (round) {\n value = round === 'week' && (isNumber(isoWeekday) || isoWeekday === true) ? adapter.startOf(value, 'isoWeek', isoWeekday) : adapter.startOf(value, round);\n }\n return +value;\n}\n function determineUnitForAutoTicks(minUnit, min, max, capacity) {\n const ilen = UNITS.length;\n for(let i = UNITS.indexOf(minUnit); i < ilen - 1; ++i){\n const interval = INTERVALS[UNITS[i]];\n const factor = interval.steps ? interval.steps : Number.MAX_SAFE_INTEGER;\n if (interval.common && Math.ceil((max - min) / (factor * interval.size)) <= capacity) {\n return UNITS[i];\n }\n }\n return UNITS[ilen - 1];\n}\n function determineUnitForFormatting(scale, numTicks, minUnit, min, max) {\n for(let i = UNITS.length - 1; i >= UNITS.indexOf(minUnit); i--){\n const unit = UNITS[i];\n if (INTERVALS[unit].common && scale._adapter.diff(max, min, unit) >= numTicks - 1) {\n return unit;\n }\n }\n return UNITS[minUnit ? UNITS.indexOf(minUnit) : 0];\n}\n function determineMajorUnit(unit) {\n for(let i = UNITS.indexOf(unit) + 1, ilen = UNITS.length; i < ilen; ++i){\n if (INTERVALS[UNITS[i]].common) {\n return UNITS[i];\n }\n }\n}\n function addTick(ticks, time, timestamps) {\n if (!timestamps) {\n ticks[time] = true;\n } else if (timestamps.length) {\n const { lo , hi } = _lookup(timestamps, time);\n const timestamp = timestamps[lo] >= time ? timestamps[lo] : timestamps[hi];\n ticks[timestamp] = true;\n }\n}\n function setMajorTicks(scale, ticks, map, majorUnit) {\n const adapter = scale._adapter;\n const first = +adapter.startOf(ticks[0].value, majorUnit);\n const last = ticks[ticks.length - 1].value;\n let major, index;\n for(major = first; major <= last; major = +adapter.add(major, 1, majorUnit)){\n index = map[major];\n if (index >= 0) {\n ticks[index].major = true;\n }\n }\n return ticks;\n}\n function ticksFromTimestamps(scale, values, majorUnit) {\n const ticks = [];\n const map = {};\n const ilen = values.length;\n let i, value;\n for(i = 0; i < ilen; ++i){\n value = values[i];\n map[value] = i;\n ticks.push({\n value,\n major: false\n });\n }\n return ilen === 0 || !majorUnit ? ticks : setMajorTicks(scale, ticks, map, majorUnit);\n}\nclass TimeScale extends Scale {\n static id = 'time';\n static defaults = {\n bounds: 'data',\n adapters: {},\n time: {\n parser: false,\n unit: false,\n round: false,\n isoWeekday: false,\n minUnit: 'millisecond',\n displayFormats: {}\n },\n ticks: {\n source: 'auto',\n callback: false,\n major: {\n enabled: false\n }\n }\n };\n constructor(props){\n super(props);\n this._cache = {\n data: [],\n labels: [],\n all: []\n };\n this._unit = 'day';\n this._majorUnit = undefined;\n this._offsets = {};\n this._normalized = false;\n this._parseOpts = undefined;\n }\n init(scaleOpts, opts = {}) {\n const time = scaleOpts.time || (scaleOpts.time = {});\n const adapter = this._adapter = new adapters._date(scaleOpts.adapters.date);\n adapter.init(opts);\n mergeIf(time.displayFormats, adapter.formats());\n this._parseOpts = {\n parser: time.parser,\n round: time.round,\n isoWeekday: time.isoWeekday\n };\n super.init(scaleOpts);\n this._normalized = opts.normalized;\n }\n parse(raw, index) {\n if (raw === undefined) {\n return null;\n }\n return parse(this, raw);\n }\n beforeLayout() {\n super.beforeLayout();\n this._cache = {\n data: [],\n labels: [],\n all: []\n };\n }\n determineDataLimits() {\n const options = this.options;\n const adapter = this._adapter;\n const unit = options.time.unit || 'day';\n let { min , max , minDefined , maxDefined } = this.getUserBounds();\n function _applyBounds(bounds) {\n if (!minDefined && !isNaN(bounds.min)) {\n min = Math.min(min, bounds.min);\n }\n if (!maxDefined && !isNaN(bounds.max)) {\n max = Math.max(max, bounds.max);\n }\n }\n if (!minDefined || !maxDefined) {\n _applyBounds(this._getLabelBounds());\n if (options.bounds !== 'ticks' || options.ticks.source !== 'labels') {\n _applyBounds(this.getMinMax(false));\n }\n }\n min = isNumberFinite(min) && !isNaN(min) ? min : +adapter.startOf(Date.now(), unit);\n max = isNumberFinite(max) && !isNaN(max) ? max : +adapter.endOf(Date.now(), unit) + 1;\n this.min = Math.min(min, max - 1);\n this.max = Math.max(min + 1, max);\n }\n _getLabelBounds() {\n const arr = this.getLabelTimestamps();\n let min = Number.POSITIVE_INFINITY;\n let max = Number.NEGATIVE_INFINITY;\n if (arr.length) {\n min = arr[0];\n max = arr[arr.length - 1];\n }\n return {\n min,\n max\n };\n }\n buildTicks() {\n const options = this.options;\n const timeOpts = options.time;\n const tickOpts = options.ticks;\n const timestamps = tickOpts.source === 'labels' ? this.getLabelTimestamps() : this._generate();\n if (options.bounds === 'ticks' && timestamps.length) {\n this.min = this._userMin || timestamps[0];\n this.max = this._userMax || timestamps[timestamps.length - 1];\n }\n const min = this.min;\n const max = this.max;\n const ticks = _filterBetween(timestamps, min, max);\n this._unit = timeOpts.unit || (tickOpts.autoSkip ? determineUnitForAutoTicks(timeOpts.minUnit, this.min, this.max, this._getLabelCapacity(min)) : determineUnitForFormatting(this, ticks.length, timeOpts.minUnit, this.min, this.max));\n this._majorUnit = !tickOpts.major.enabled || this._unit === 'year' ? undefined : determineMajorUnit(this._unit);\n this.initOffsets(timestamps);\n if (options.reverse) {\n ticks.reverse();\n }\n return ticksFromTimestamps(this, ticks, this._majorUnit);\n }\n afterAutoSkip() {\n if (this.options.offsetAfterAutoskip) {\n this.initOffsets(this.ticks.map((tick)=>+tick.value));\n }\n }\n initOffsets(timestamps = []) {\n let start = 0;\n let end = 0;\n let first, last;\n if (this.options.offset && timestamps.length) {\n first = this.getDecimalForValue(timestamps[0]);\n if (timestamps.length === 1) {\n start = 1 - first;\n } else {\n start = (this.getDecimalForValue(timestamps[1]) - first) / 2;\n }\n last = this.getDecimalForValue(timestamps[timestamps.length - 1]);\n if (timestamps.length === 1) {\n end = last;\n } else {\n end = (last - this.getDecimalForValue(timestamps[timestamps.length - 2])) / 2;\n }\n }\n const limit = timestamps.length < 3 ? 0.5 : 0.25;\n start = _limitValue(start, 0, limit);\n end = _limitValue(end, 0, limit);\n this._offsets = {\n start,\n end,\n factor: 1 / (start + 1 + end)\n };\n }\n _generate() {\n const adapter = this._adapter;\n const min = this.min;\n const max = this.max;\n const options = this.options;\n const timeOpts = options.time;\n const minor = timeOpts.unit || determineUnitForAutoTicks(timeOpts.minUnit, min, max, this._getLabelCapacity(min));\n const stepSize = valueOrDefault(options.ticks.stepSize, 1);\n const weekday = minor === 'week' ? timeOpts.isoWeekday : false;\n const hasWeekday = isNumber(weekday) || weekday === true;\n const ticks = {};\n let first = min;\n let time, count;\n if (hasWeekday) {\n first = +adapter.startOf(first, 'isoWeek', weekday);\n }\n first = +adapter.startOf(first, hasWeekday ? 'day' : minor);\n if (adapter.diff(max, min, minor) > 100000 * stepSize) {\n throw new Error(min + ' and ' + max + ' are too far apart with stepSize of ' + stepSize + ' ' + minor);\n }\n const timestamps = options.ticks.source === 'data' && this.getDataTimestamps();\n for(time = first, count = 0; time < max; time = +adapter.add(time, stepSize, minor), count++){\n addTick(ticks, time, timestamps);\n }\n if (time === max || options.bounds === 'ticks' || count === 1) {\n addTick(ticks, time, timestamps);\n }\n return Object.keys(ticks).sort((a, b)=>a - b).map((x)=>+x);\n }\n getLabelForValue(value) {\n const adapter = this._adapter;\n const timeOpts = this.options.time;\n if (timeOpts.tooltipFormat) {\n return adapter.format(value, timeOpts.tooltipFormat);\n }\n return adapter.format(value, timeOpts.displayFormats.datetime);\n }\n format(value, format) {\n const options = this.options;\n const formats = options.time.displayFormats;\n const unit = this._unit;\n const fmt = format || formats[unit];\n return this._adapter.format(value, fmt);\n }\n _tickFormatFunction(time, index, ticks, format) {\n const options = this.options;\n const formatter = options.ticks.callback;\n if (formatter) {\n return callback(formatter, [\n time,\n index,\n ticks\n ], this);\n }\n const formats = options.time.displayFormats;\n const unit = this._unit;\n const majorUnit = this._majorUnit;\n const minorFormat = unit && formats[unit];\n const majorFormat = majorUnit && formats[majorUnit];\n const tick = ticks[index];\n const major = majorUnit && majorFormat && tick && tick.major;\n return this._adapter.format(time, format || (major ? majorFormat : minorFormat));\n }\n generateTickLabels(ticks) {\n let i, ilen, tick;\n for(i = 0, ilen = ticks.length; i < ilen; ++i){\n tick = ticks[i];\n tick.label = this._tickFormatFunction(tick.value, i, ticks);\n }\n }\n getDecimalForValue(value) {\n return value === null ? NaN : (value - this.min) / (this.max - this.min);\n }\n getPixelForValue(value) {\n const offsets = this._offsets;\n const pos = this.getDecimalForValue(value);\n return this.getPixelForDecimal((offsets.start + pos) * offsets.factor);\n }\n getValueForPixel(pixel) {\n const offsets = this._offsets;\n const pos = this.getDecimalForPixel(pixel) / offsets.factor - offsets.end;\n return this.min + pos * (this.max - this.min);\n }\n _getLabelSize(label) {\n const ticksOpts = this.options.ticks;\n const tickLabelWidth = this.ctx.measureText(label).width;\n const angle = toRadians(this.isHorizontal() ? ticksOpts.maxRotation : ticksOpts.minRotation);\n const cosRotation = Math.cos(angle);\n const sinRotation = Math.sin(angle);\n const tickFontSize = this._resolveTickFontOptions(0).size;\n return {\n w: tickLabelWidth * cosRotation + tickFontSize * sinRotation,\n h: tickLabelWidth * sinRotation + tickFontSize * cosRotation\n };\n }\n _getLabelCapacity(exampleTime) {\n const timeOpts = this.options.time;\n const displayFormats = timeOpts.displayFormats;\n const format = displayFormats[timeOpts.unit] || displayFormats.millisecond;\n const exampleLabel = this._tickFormatFunction(exampleTime, 0, ticksFromTimestamps(this, [\n exampleTime\n ], this._majorUnit), format);\n const size = this._getLabelSize(exampleLabel);\n const capacity = Math.floor(this.isHorizontal() ? this.width / size.w : this.height / size.h) - 1;\n return capacity > 0 ? capacity : 1;\n }\n getDataTimestamps() {\n let timestamps = this._cache.data || [];\n let i, ilen;\n if (timestamps.length) {\n return timestamps;\n }\n const metas = this.getMatchingVisibleMetas();\n if (this._normalized && metas.length) {\n return this._cache.data = metas[0].controller.getAllParsedValues(this);\n }\n for(i = 0, ilen = metas.length; i < ilen; ++i){\n timestamps = timestamps.concat(metas[i].controller.getAllParsedValues(this));\n }\n return this._cache.data = this.normalize(timestamps);\n }\n getLabelTimestamps() {\n const timestamps = this._cache.labels || [];\n let i, ilen;\n if (timestamps.length) {\n return timestamps;\n }\n const labels = this.getLabels();\n for(i = 0, ilen = labels.length; i < ilen; ++i){\n timestamps.push(parse(this, labels[i]));\n }\n return this._cache.labels = this._normalized ? timestamps : this.normalize(timestamps);\n }\n normalize(values) {\n return _arrayUnique(values.sort(sorter));\n }\n}\n\nfunction interpolate(table, val, reverse) {\n let lo = 0;\n let hi = table.length - 1;\n let prevSource, nextSource, prevTarget, nextTarget;\n if (reverse) {\n if (val >= table[lo].pos && val <= table[hi].pos) {\n ({ lo , hi } = _lookupByKey(table, 'pos', val));\n }\n ({ pos: prevSource , time: prevTarget } = table[lo]);\n ({ pos: nextSource , time: nextTarget } = table[hi]);\n } else {\n if (val >= table[lo].time && val <= table[hi].time) {\n ({ lo , hi } = _lookupByKey(table, 'time', val));\n }\n ({ time: prevSource , pos: prevTarget } = table[lo]);\n ({ time: nextSource , pos: nextTarget } = table[hi]);\n }\n const span = nextSource - prevSource;\n return span ? prevTarget + (nextTarget - prevTarget) * (val - prevSource) / span : prevTarget;\n}\nclass TimeSeriesScale extends TimeScale {\n static id = 'timeseries';\n static defaults = TimeScale.defaults;\n constructor(props){\n super(props);\n this._table = [];\n this._minPos = undefined;\n this._tableRange = undefined;\n }\n initOffsets() {\n const timestamps = this._getTimestampsForTable();\n const table = this._table = this.buildLookupTable(timestamps);\n this._minPos = interpolate(table, this.min);\n this._tableRange = interpolate(table, this.max) - this._minPos;\n super.initOffsets(timestamps);\n }\n buildLookupTable(timestamps) {\n const { min , max } = this;\n const items = [];\n const table = [];\n let i, ilen, prev, curr, next;\n for(i = 0, ilen = timestamps.length; i < ilen; ++i){\n curr = timestamps[i];\n if (curr >= min && curr <= max) {\n items.push(curr);\n }\n }\n if (items.length < 2) {\n return [\n {\n time: min,\n pos: 0\n },\n {\n time: max,\n pos: 1\n }\n ];\n }\n for(i = 0, ilen = items.length; i < ilen; ++i){\n next = items[i + 1];\n prev = items[i - 1];\n curr = items[i];\n if (Math.round((next + prev) / 2) !== curr) {\n table.push({\n time: curr,\n pos: i / (ilen - 1)\n });\n }\n }\n return table;\n }\n _getTimestampsForTable() {\n let timestamps = this._cache.all || [];\n if (timestamps.length) {\n return timestamps;\n }\n const data = this.getDataTimestamps();\n const label = this.getLabelTimestamps();\n if (data.length && label.length) {\n timestamps = this.normalize(data.concat(label));\n } else {\n timestamps = data.length ? data : label;\n }\n timestamps = this._cache.all = timestamps;\n return timestamps;\n }\n getDecimalForValue(value) {\n return (interpolate(this._table, value) - this._minPos) / this._tableRange;\n }\n getValueForPixel(pixel) {\n const offsets = this._offsets;\n const decimal = this.getDecimalForPixel(pixel) / offsets.factor - offsets.end;\n return interpolate(this._table, decimal * this._tableRange + this._minPos, true);\n }\n}\n\nvar scales = /*#__PURE__*/Object.freeze({\n__proto__: null,\nCategoryScale: CategoryScale,\nLinearScale: LinearScale,\nLogarithmicScale: LogarithmicScale,\nRadialLinearScale: RadialLinearScale,\nTimeScale: TimeScale,\nTimeSeriesScale: TimeSeriesScale\n});\n\nconst registerables = [\n controllers,\n elements,\n plugins,\n scales\n];\n\nexport { Animation, Animations, ArcElement, BarController, BarElement, BasePlatform, BasicPlatform, BubbleController, CategoryScale, Chart, plugin_colors as Colors, DatasetController, plugin_decimation as Decimation, DomPlatform, DoughnutController, Element, index as Filler, Interaction, plugin_legend as Legend, LineController, LineElement, LinearScale, LogarithmicScale, PieController, PointElement, PolarAreaController, RadarController, RadialLinearScale, Scale, ScatterController, plugin_subtitle as SubTitle, TimeScale, TimeSeriesScale, plugin_title as Title, plugin_tooltip as Tooltip, adapters as _adapters, _detectPlatform, animator, controllers, elements, layouts, plugins, registerables, registry, scales };\n//# sourceMappingURL=chart.js.map\n","import {Chart, registerables} from '../dist/chart.js';\n\nChart.register(...registerables);\n\nexport * from '../dist/chart.js';\nexport default Chart;\n","import Chart from \"chart.js/auto\";\nimport { csvParse } from \"d3-dsv\";\n\n// These 2 imports use some vite machinery to directly import these files as\n// strings. Then they are constants and this reduces the load on the GC.\nimport airportsString from \"./datasets/airports.csv?raw\";\nimport flightsString from \"./datasets/flights-airports.csv?raw\";\n\n/*\n * From https://www.omnicalculator.com/other/latitude-longitude-distance:\n * d = 2R × sin⁻¹(√[sin²((θ₂ - θ₁)/2) + cosθ₁ × cosθ₂ × sin²((φ₂ - φ₁)/2)])\n *\n * where:\n * θ₁, φ₁ – First point latitude and longitude coordinates;\n * θ₂, φ₂ – Second point latitude and longitude coordinates;\n * R – Earth's radius (R = 6371 km); and\n * d – Distance between them along Earth's surface.\n */\nconst R = 6371;\nfunction computeDistance(coords1, coords2) {\n const long1 = toRadian(coords1.longitude);\n const lat1 = toRadian(coords1.latitude);\n const long2 = toRadian(coords2.longitude);\n const lat2 = toRadian(coords2.latitude);\n const longSquareSin = Math.sin((long2 - long1) / 2) ** 2;\n const latSquareSin = Math.sin((lat2 - lat1) / 2) ** 2;\n const d = 2 * R * Math.asin(Math.sqrt(latSquareSin + Math.cos(lat1) * Math.cos(lat2) * longSquareSin));\n return d;\n}\n\nconst RAD = Math.PI / 180;\nfunction toRadian(deg) {\n return deg * RAD;\n}\n\nlet preparedData = null;\nfunction prepare() {\n /**\n * AirportInformation: { state, iata, name, city, country, latitude, longitude }\n * airports: Array<AirportInformation>\n * flights: Array<{ origin, destination, count }>\n */\n const airports = csvParse(airportsString);\n const flights = csvParse(flightsString);\n const airportMap = new Map(airports.map((airport) => [airport.iata, airport]));\n\n for (const flight of flights) {\n const origAirport = airportMap.get(flight.origin);\n const destAirport = airportMap.get(flight.destination);\n flight.distance = computeDistance(origAirport, destAirport);\n }\n\n preparedData = { flights, airportMap };\n}\n\nconst ROOT = document.getElementById(\"chart\");\nconst opaqueCheckBox = document.getElementById(\"opaque-color\");\n\nlet currentChart = null;\nfunction drawScattered(data) {\n if (!preparedData)\n throw new Error(\"Please prepare the data first.\");\n\n reset();\n\n currentChart = new Chart(ROOT, {\n type: \"scatter\",\n data: {\n datasets: [\n {\n data: preparedData.flights,\n backgroundColor: opaqueCheckBox.checked ? \"rgb(0, 125, 255)\" : \"rgba(0, 125, 255, .20)\",\n },\n ],\n },\n options: {\n animation: false,\n parsing: {\n xAxisKey: \"distance\",\n yAxisKey: \"count\",\n },\n plugins: {\n legend: {\n display: false,\n },\n title: {\n display: true,\n text: \"Number of flights for a distance\",\n position: \"bottom\",\n },\n tooltip: {\n displayColors: false,\n callbacks: {\n label: (item) => {\n const orig = preparedData.airportMap.get(item.raw.origin);\n const dest = preparedData.airportMap.get(item.raw.destination);\n const result = `✈ ${orig.name} (${orig.iata}) → ${dest.name} (${dest.iata}): ${Math.round(item.raw.distance)} km`;\n return result;\n },\n },\n },\n },\n scales: {\n x: {\n title: {\n text: \"distance →\",\n align: \"end\",\n display: true,\n },\n ticks: {\n format: {\n style: \"unit\",\n unit: \"kilometer\",\n },\n },\n },\n y: {\n type: \"logarithmic\",\n title: {\n text: \"# of flights →\",\n align: \"end\",\n display: true,\n },\n },\n },\n },\n });\n}\n\nfunction openTooltip() {\n if (!currentChart)\n throw new Error(\"No chart is present, please draw a chart first\");\n\n const renderedDataset = currentChart.getDatasetMeta(0);\n const node = currentChart.canvas;\n const rect = node.getBoundingClientRect();\n\n // Index 2426 is carefully chosen to display a lot of lines (which depends\n // on the zoom level).\n const point = renderedDataset.data[2426];\n const event = new MouseEvent(\"mousemove\", {\n clientX: rect.left + point.x,\n clientY: rect.top + point.y,\n cancelable: true,\n bubbles: true,\n });\n\n node.dispatchEvent(event);\n}\n\nfunction reset() {\n if (currentChart) {\n currentChart.destroy();\n currentChart = null;\n }\n}\n\nasync function runAllTheThings() {\n [\n // Force prettier to use a multiline formatting\n \"prepare\",\n \"add-scatter-chart-button\",\n \"open-tooltip\",\n ].forEach((id) => document.getElementById(id).click());\n}\n\ndocument.getElementById(\"prepare\").addEventListener(\"click\", prepare);\ndocument.getElementById(\"add-scatter-chart-button\").addEventListener(\"click\", drawScattered);\ndocument.getElementById(\"open-tooltip\").addEventListener(\"click\", openTooltip);\ndocument.getElementById(\"reset\").addEventListener(\"click\", reset);\ndocument.getElementById(\"run-all\").addEventListener(\"click\", runAllTheThings);\n\nif (import.meta.env.DEV)\n runAllTheThings();\n"],"names":["map","interpolate","clone","color","index","set","callback","defaults","name","_descriptors","resolve","descriptors","draw","from","to","scales","elements","names","reset","i","inRange","layouts","positions","validIndex","registry","plugins","listener","alpha","skip","fill","round"],"mappings":"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","x_google_ignoreList":[0,1,2,3]}