{"version":3,"file":"BarChart-D-_BMW51.js","sources":["../../../node_modules/.pnpm/@kurkle+color@0.3.2/node_modules/@kurkle/color/dist/color.esm.js","../../../node_modules/.pnpm/chart.js@4.4.4/node_modules/chart.js/dist/chunks/helpers.segment.js","../../../node_modules/.pnpm/chart.js@4.4.4/node_modules/chart.js/dist/chart.js","../../../node_modules/.pnpm/vue-chartjs@5.3.1_chart.js@4.4.4_vue@3.5.13_typescript@5.6.2_/node_modules/vue-chartjs/dist/index.js","../../../app/javascript/shared/components/charts/BarChart.vue"],"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.4.4\n * https://www.chartjs.org\n * (c) 2024 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(items);\n    if (set.size === items.length) {\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, 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 = isNaN(logDelta) ? 1 : 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        clip: true,\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\n/**\n * Converts the given font object into a CSS font string.\n * @param font - A font object.\n * @return The CSS font string. See https://developer.mozilla.org/en-US/docs/Web/CSS/font\n * @private\n */ function 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/**\n * @private\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/**\n * @private\n */ // eslint-disable-next-line complexity\nfunction _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        // Undefined strings and arrays should not be measured\n        if (thing !== undefined && thing !== null && !isArray(thing)) {\n            longest = _measureText(ctx, data, gc, longest, thing);\n        } else if (isArray(thing)) {\n            // if it is an array lets measure each element\n            // to do maybe simplify this function a bit so we can do this more recursively?\n            for(j = 0, jlen = thing.length; j < jlen; j++){\n                nestedThing = thing[j];\n                // Undefined strings and arrays should not be measured\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/**\n * Returns the aligned pixel value to avoid anti-aliasing blur\n * @param chart - The chart instance.\n * @param pixel - A pixel value.\n * @param width - The width of the element.\n * @returns The aligned pixel value.\n * @private\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/**\n * Clears the entire canvas.\n */ function clearCanvas(canvas, ctx) {\n    if (!ctx && !canvas) {\n        return;\n    }\n    ctx = ctx || canvas.getContext('2d');\n    ctx.save();\n    // canvas.width and canvas.height do not consider the canvas transform,\n    // while clearRect does\n    ctx.resetTransform();\n    ctx.clearRect(0, 0, canvas.width, canvas.height);\n    ctx.restore();\n}\nfunction drawPoint(ctx, options, x, y) {\n    // eslint-disable-next-line @typescript-eslint/no-use-before-define\n    drawPointLegend(ctx, options, x, y, null);\n}\n// eslint-disable-next-line complexity\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 includes circle\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            // NOTE: the rounded rect implementation changed to use `arc` instead of\n            // `quadraticCurveTo` since it generates better results when rect is\n            // almost a circle. 0.516 (instead of 0.5) produces results with visually\n            // closer proportion to the previous impl and it is inscribed in the\n            // circle with `radius`. For more details, see the following PRs:\n            // https://github.com/chartjs/Chart.js/issues/5597\n            // https://github.com/chartjs/Chart.js/issues/5858\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        /* falls through */ 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        /* falls through */ 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/**\n * Returns true if the point is inside the rectangle\n * @param point - The point to test\n * @param area - The rectangle\n * @param margin - allowed margin\n * @private\n */ function _isPointInArea(point, area, margin) {\n    margin = margin || 0.5; // margin - default is to match rounded decimals\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/**\n * @private\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/**\n * @private\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}\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        /**\n     * Now that IE11 support has been dropped, we can use more\n     * of the TextMetrics object. The actual bounding boxes\n     * are unflagged in Chrome, Firefox, Edge, and Safari so they\n     * can be safely used.\n     * See https://developer.mozilla.org/en-US/docs/Web/API/TextMetrics#Browser_compatibility\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/**\n * Render text onto the canvas\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 += Number(font.lineHeight);\n    }\n    ctx.restore();\n}\n/**\n * Add a path of a rectangle with rounded corners to the current sub-path\n * @param ctx - Context\n * @param rect - Bounding rect\n */ function addRoundedRectPath(ctx, rect) {\n    const { x , y , w , h , radius  } = rect;\n    // top left arc\n    ctx.arc(x + radius.topLeft, y + radius.topLeft, radius.topLeft, 1.5 * PI, PI, true);\n    // line from top left to bottom left\n    ctx.lineTo(x, y + h - radius.bottomLeft);\n    // bottom left arc\n    ctx.arc(x + radius.bottomLeft, y + h - radius.bottomLeft, radius.bottomLeft, PI, HALF_PI, true);\n    // line from bottom left to bottom right\n    ctx.lineTo(x + w - radius.bottomRight, y + h);\n    // bottom right arc\n    ctx.arc(x + w - radius.bottomRight, y + h - radius.bottomRight, radius.bottomRight, HALF_PI, 0, true);\n    // line from bottom right to top right\n    ctx.lineTo(x + w, y + radius.topRight);\n    // top right arc\n    ctx.arc(x + w - radius.topRight, y + radius.topRight, radius.topRight, 0, -HALF_PI, true);\n    // line from top right to top left\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\n/**\n * Creates a Proxy for resolving raw values for options.\n * @param scopes - The option scopes to look for values, in resolution order\n * @param prefixes - The prefixes for values, in resolution order.\n * @param rootScopes - The root option scopes\n * @param fallback - Parent scopes fallback\n * @param getTarget - callback for getting the target for changed values\n * @returns Proxy\n * @private\n */ function _createResolver(scopes, prefixes = [\n    ''\n], rootScopes, fallback, getTarget = ()=>scopes[0]) {\n    const finalRootScopes = rootScopes || scopes;\n    if (typeof fallback === 'undefined') {\n        fallback = _resolve('_fallback', scopes);\n    }\n    const cache = {\n        [Symbol.toStringTag]: 'Object',\n        _cacheable: true,\n        _scopes: scopes,\n        _rootScopes: finalRootScopes,\n        _fallback: fallback,\n        _getTarget: getTarget,\n        override: (scope)=>_createResolver([\n                scope,\n                ...scopes\n            ], prefixes, finalRootScopes, fallback)\n    };\n    return new Proxy(cache, {\n        /**\n     * A trap for the delete operator.\n     */ deleteProperty (target, prop) {\n            delete target[prop]; // remove from cache\n            delete target._keys; // remove cached keys\n            delete scopes[0][prop]; // remove from top level scope\n            return true;\n        },\n        /**\n     * A trap for getting property values.\n     */ get (target, prop) {\n            return _cached(target, prop, ()=>_resolveWithPrefixes(prop, prefixes, scopes, target));\n        },\n        /**\n     * A trap for Object.getOwnPropertyDescriptor.\n     * Also used by Object.hasOwnProperty.\n     */ getOwnPropertyDescriptor (target, prop) {\n            return Reflect.getOwnPropertyDescriptor(target._scopes[0], prop);\n        },\n        /**\n     * A trap for Object.getPrototypeOf.\n     */ getPrototypeOf () {\n            return Reflect.getPrototypeOf(scopes[0]);\n        },\n        /**\n     * A trap for the in operator.\n     */ has (target, prop) {\n            return getKeysFromAllScopes(target).includes(prop);\n        },\n        /**\n     * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n     */ ownKeys (target) {\n            return getKeysFromAllScopes(target);\n        },\n        /**\n     * A trap for setting property values.\n     */ set (target, prop, value) {\n            const storage = target._storage || (target._storage = getTarget());\n            target[prop] = storage[prop] = value; // set to top level scope + cache\n            delete target._keys; // remove cached keys\n            return true;\n        }\n    });\n}\n/**\n * Returns an Proxy for resolving option values with context.\n * @param proxy - The Proxy returned by `_createResolver`\n * @param context - Context object for scriptable/indexable options\n * @param subProxy - The proxy provided for scriptable options\n * @param descriptorDefaults - Defaults for descriptors\n * @private\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        /**\n     * A trap for the delete operator.\n     */ deleteProperty (target, prop) {\n            delete target[prop]; // remove from cache\n            delete proxy[prop]; // remove from proxy\n            return true;\n        },\n        /**\n     * A trap for getting property values.\n     */ get (target, prop, receiver) {\n            return _cached(target, prop, ()=>_resolveWithContext(target, prop, receiver));\n        },\n        /**\n     * A trap for Object.getOwnPropertyDescriptor.\n     * Also used by Object.hasOwnProperty.\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        /**\n     * A trap for Object.getPrototypeOf.\n     */ getPrototypeOf () {\n            return Reflect.getPrototypeOf(proxy);\n        },\n        /**\n     * A trap for the in operator.\n     */ has (target, prop) {\n            return Reflect.has(proxy, prop);\n        },\n        /**\n     * A trap for Object.getOwnPropertyNames and Object.getOwnPropertySymbols.\n     */ ownKeys () {\n            return Reflect.ownKeys(proxy);\n        },\n        /**\n     * A trap for setting property values.\n     */ set (target, prop, value) {\n            proxy[prop] = value; // set to proxy\n            delete target[prop]; // remove from cache\n            return true;\n        }\n    });\n}\n/**\n * @private\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) || prop === 'constructor') {\n        return target[prop];\n    }\n    const value = resolve();\n    // cache the resolved value\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]; // resolve from proxy\n    // resolve with context\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        // if the resolved value is an object, create a sub resolver for it\n        value = _attachContext(value, _context, _subProxy && _subProxy[prop], descriptors);\n    }\n    return value;\n}\nfunction _resolveScriptable(prop, getValue, 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    let value = getValue(_context, _subProxy || receiver);\n    _stack.delete(prop);\n    if (needsSubResolver(prop, value)) {\n        // When scriptable option returns an object, create a resolver on that.\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 (typeof _context.index !== 'undefined' && isIndexable(prop)) {\n        return value[_context.index % value.length];\n    } else if (isObject(value[0])) {\n        // Array of objects, return array or resolvers\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 (typeof fallback !== 'undefined' && fallback !== key && fallback !== parentFallback) {\n                // When we reach the descriptor that defines a new _fallback, return that.\n                // The fallback will resume to that new scope.\n                return fallback;\n            }\n        } else if (scope === false && typeof parentFallback !== 'undefined' && key !== parentFallback) {\n            // Fallback to `false` results to `false`, when falling back to different key.\n            // For example `interaction` from `hover` or `plugins.tooltip` and `animation` from `animations`\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 (typeof fallback !== 'undefined' && 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        // For array of objects, the object is used to store updated values\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 (typeof value !== 'undefined') {\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 (typeof value !== 'undefined') {\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 = canvas && _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        if (_isDomSupported()) {\n            window.addEventListener('test', null, options);\n            window.removeEventListener('test', null, options);\n        }\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    if (!prevStyle) {\n        return false;\n    }\n    const cache = [];\n    const replacer = function(key, value) {\n        if (!isPatternOrGradient(value)) {\n            return value;\n        }\n        if (!cache.includes(value)) {\n            cache.push(value);\n        }\n        return cache.indexOf(value);\n    };\n    return JSON.stringify(style, replacer) !== JSON.stringify(prevStyle, replacer);\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.4.4\n * https://www.chartjs.org\n * (c) 2024 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';\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, meta) {\n    const { iScale , vScale  } = meta;\n    const iAxisKey = iScale.axis === 'x' ? 'x' : 'y';\n    const vAxisKey = vScale.axis === 'x' ? 'x' : 'y';\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            [iAxisKey]: key,\n            [vAxisKey]: 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            const meta = this._cachedMeta;\n            this._data = convertObjectDataToArray(data, meta);\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 currentParsed = this._cachedMeta.controller.getParsed(dataIndex);\n        const iScaleValue = currentParsed && currentParsed[iScale.axis];\n        const skipNull = (meta)=>{\n            const parsed = meta._parsed.find((item)=>item[iScale.axis] === iScaleValue);\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 && !rects[i].hidden) {\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' && !name.startsWith('borderDash') && !name.startsWith('hoverBorderDash')\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            if (!this.datasetElementType) {\n                this.addElements();\n            }\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        } else if (this.datasetElementType) {\n            delete meta.dataset;\n            this.datasetElementType = false;\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,\nPieController: PieController,\nPolarAreaController: PolarAreaController,\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    options;\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] && 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 height = chartArea.h * weight;\n            const width = stack.size || box.width;\n            if (defined(stack.start)) {\n                x = stack.start;\n            }\n            if (box.fullSize) {\n                setBoxDims(box, x, userPadding.top, width, params.outerHeight - userPadding.bottom - userPadding.top);\n            } else {\n                setBoxDims(box, x, chartArea.top + stack.placed, width, height);\n            }\n            stack.start = x;\n            stack.placed += height;\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    if (node) {\n        node.addEventListener(type, listener, eventListenerOptions);\n    }\n}\nfunction removeListener(chart, type, listener) {\n    if (chart && chart.canvas) {\n        chart.canvas.removeEventListener(type, listener, eventListenerOptions);\n    }\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 = canvas && _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    x;\n    y;\n    active = false;\n    options;\n    $animations;\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 positionAxisID = Object.keys(position)[0];\n            const value = position[positionAxisID];\n            titleX = scales[positionAxisID].getPixelForValue(value) - 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 positionAxisID = Object.keys(position)[0];\n                const value = position[positionAxisID];\n                borderValue = alignBorderValue(this.chart.scales[positionAxisID].getPixelForValue(value));\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 ret = this._getYAxisLabelAlignment(tl);\n            textAlign = ret.textAlign;\n            x = ret.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 positionAxisID = Object.keys(position)[0];\n                const value = position[positionAxisID];\n                x = this.chart.scales[positionAxisID].getPixelForValue(value);\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                    case 'inner':\n                        if (i === ilen - 1) {\n                            left -= width;\n                        } else if (i > 0) {\n                            left -= width / 2;\n                        }\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 i = 0; i < local.length; i++){\n        const plugin = local[i];\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 idMatchesAxis(id) {\n    if (id === 'x' || id === 'y' || id === 'r') {\n        return id;\n    }\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 (idMatchesAxis(id)) {\n        return id;\n    }\n    for (const opts of scaleOptions){\n        const axis = opts.axis || axisFromPosition(opts.position) || id.length > 1 && idMatchesAxis(id[0].toLowerCase());\n        if (axis) {\n            return axis;\n        }\n    }\n    throw new Error(`Cannot determine type of '${id}' axis. Please provide 'axis' or 'position' option.`);\n}\nfunction getAxisFromDataset(id, axis, dataset) {\n    if (dataset[axis + 'AxisID'] === id) {\n        return {\n            axis\n        };\n    }\n}\nfunction retrieveAxisFromDatasets(id, config) {\n    if (config.data && config.data.datasets) {\n        const boundDs = config.data.datasets.filter((d)=>d.xAxisID === id || d.yAxisID === id);\n        if (boundDs.length) {\n            return getAxisFromDataset(id, 'x', boundDs[0]) || getAxisFromDataset(id, 'y', boundDs[0]);\n        }\n    }\n    return {};\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, retrieveAxisFromDatasets(id, config), defaults.scales[scaleConf.type]);\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).some((key)=>isFunction(value[key]));\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.4.4\";\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 getSizeForArea(scale, chartArea, field) {\n    return scale.options.clip ? scale[field] : chartArea[field];\n}\nfunction getDatasetArea(meta, chartArea) {\n    const { xScale , yScale  } = meta;\n    if (xScale && yScale) {\n        return {\n            left: getSizeForArea(xScale, chartArea, 'left'),\n            right: getSizeForArea(xScale, chartArea, 'right'),\n            top: getSizeForArea(yScale, chartArea, 'top'),\n            bottom: getSizeForArea(yScale, chartArea, 'bottom')\n        };\n    }\n    return chartArea;\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 i = 0, ilen = this.data.datasets.length; i < ilen; ++i){\n            this._updateDataset(i, isFunction(mode) ? mode({\n                datasetIndex: i\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._resizeBeforeDraw = null;\n            this._resize(width, height);\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 pCenter = rThetaToXY(innerEndAdjustedRadius, innerEndAdjustedAngle, x, y);\n            ctx.arc(pCenter.x, pCenter.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 pCenter = rThetaToXY(innerStartAdjustedRadius, innerStartAdjustedAngle, x, y);\n            ctx.arc(pCenter.x, pCenter.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 pCenter = rThetaToXY(outerStartAdjustedRadius, outerStartAdjustedAngle, x, y);\n            ctx.arc(pCenter.x, pCenter.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 , borderDash , borderDashOffset  } = options;\n    const inner = options.borderAlign === 'inner';\n    if (!borderWidth) {\n        return;\n    }\n    ctx.setLineDash(borderDash || []);\n    ctx.lineDashOffset = borderDashOffset;\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        borderDash: [],\n        borderDashOffset: 0,\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    static descriptors = {\n        _scriptable: true,\n        _indexable: (name)=>name !== 'borderDash'\n    };\n    circumference;\n    endAngle;\n    fullCircles;\n    innerRadius;\n    outerRadius;\n    pixelMargin;\n    startAngle;\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 + this.options.borderWidth) / 2;\n        const _circumference = valueOrDefault(circumference, endAngle - startAngle);\n        const nonZeroBetween = _angleBetween(angle, startAngle, endAngle) && startAngle !== endAngle;\n        const betweenAngles = _circumference >= TAU || nonZeroBetween;\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}\n function 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    parsed;\n    skip;\n    stop;\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,\nBarElement: BarElement,\nLineElement: LineElement,\nPointElement: PointElement\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 hitbox of hitboxes){\n                if (hitbox.col !== col) {\n                    col = hitbox.col;\n                    top = _alignStartEnd(align, this.top + titleHeight + padding, this.bottom - this.columnSizes[col].height);\n                }\n                hitbox.top = top;\n                hitbox.left += this.left + padding;\n                hitbox.left = rtlHelper.leftForLtr(rtlHelper.x(hitbox.left), hitbox.width);\n                top += hitbox.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) + padding;\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;\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 xSet = new Set();\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                xSet.add(pos.x);\n                y += pos.y;\n                ++count;\n            }\n        }\n        if (count === 0 || xSet.size === 0) {\n            return false;\n        }\n        const xAverage = [\n            ...xSet\n        ].reduce((a, b)=>a + b) / xSet.size;\n        return {\n            x: xAverage,\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 labelColor = this.labelColors[i];\n        const labelPointStyle = this.labelPointStyles[i];\n        const { boxHeight , boxWidth  } = 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 = labelColor.borderColor;\n            ctx.fillStyle = labelColor.backgroundColor;\n            drawPoint(ctx, drawOptions, centerX, centerY);\n        } else {\n            ctx.lineWidth = isObject(labelColor.borderWidth) ? Math.max(...Object.values(labelColor.borderWidth)) : labelColor.borderWidth || 1;\n            ctx.strokeStyle = labelColor.borderColor;\n            ctx.setLineDash(labelColor.borderDash || []);\n            ctx.lineDashOffset = labelColor.borderDashOffset || 0;\n            const outerX = rtlHelper.leftForLtr(rtlColorX, boxWidth);\n            const innerX = rtlHelper.leftForLtr(rtlHelper.xPlus(rtlColorX, 1), boxWidth - 2);\n            const borderRadius = toTRBLCorners(labelColor.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 = labelColor.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 = labelColor.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.filter((i)=>this.chart.data.datasets[i.datasetIndex] && this.chart.getDatasetMeta(i.datasetIndex).controller.getParsed(i.index) !== undefined);\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        const tickValue = Math.round((niceMin + j * spacing) * factor) / factor;\n        if (maxDefined && tickValue > max) {\n            break;\n        }\n        ticks.push({\n            value: tickValue\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 createPointLabelItem(scale, index, itemOpts) {\n    const outerDistance = scale.drawingArea;\n    const { extra , additionalAngle , padding , size  } = itemOpts;\n    const pointLabelPosition = scale.getPointPosition(index, outerDistance + extra + padding, additionalAngle);\n    const angle = Math.round(toDegrees(_normalizeAngle(pointLabelPosition.angle + HALF_PI)));\n    const y = yForAngle(pointLabelPosition.y, size.h, angle);\n    const textAlign = getTextAlignForAngle(angle);\n    const left = leftForTextAlign(pointLabelPosition.x, size.w, textAlign);\n    return {\n        visible: true,\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}\nfunction isNotOverlapped(item, area) {\n    if (!area) {\n        return true;\n    }\n    const { left , top , right , bottom  } = item;\n    const apexesInArea = _isPointInArea({\n        x: left,\n        y: top\n    }, area) || _isPointInArea({\n        x: left,\n        y: bottom\n    }, area) || _isPointInArea({\n        x: right,\n        y: top\n    }, area) || _isPointInArea({\n        x: right,\n        y: bottom\n    }, area);\n    return !apexesInArea;\n}\nfunction buildPointLabelItems(scale, labelSizes, padding) {\n    const items = [];\n    const valueCount = scale._pointLabels.length;\n    const opts = scale.options;\n    const { centerPointLabels , display  } = opts.pointLabels;\n    const itemOpts = {\n        extra: getTickBackdropHeight(opts) / 2,\n        additionalAngle: centerPointLabels ? PI / valueCount : 0\n    };\n    let area;\n    for(let i = 0; i < valueCount; i++){\n        itemOpts.padding = padding[i];\n        itemOpts.size = labelSizes[i];\n        const item = createPointLabelItem(scale, i, itemOpts);\n        items.push(item);\n        if (display === 'auto') {\n            item.visible = isNotOverlapped(item, area);\n            if (item.visible) {\n                area = item;\n            }\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 drawPointLabelBox(ctx, opts, item) {\n    const { left , top , right , bottom  } = item;\n    const { backdropColor  } = opts;\n    if (!isNullOrUndef(backdropColor)) {\n        const borderRadius = toTRBLCorners(opts.borderRadius);\n        const padding = toPadding(opts.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}\nfunction drawPointLabels(scale, labelCount) {\n    const { ctx , options: { pointLabels  }  } = scale;\n    for(let i = labelCount - 1; i >= 0; i--){\n        const item = scale._pointLabelItems[i];\n        if (!item.visible) {\n            continue;\n        }\n        const optsAtIndex = pointLabels.setContext(scale.getPointLabelContext(i));\n        drawPointLabelBox(ctx, optsAtIndex, item);\n        const plFont = toFont(optsAtIndex.font);\n        const { x , y , textAlign  } = item;\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 || index === 0 && this.min < 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.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 && this.min >= 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                strokeColor: optsAtIndex.textStrokeColor,\n                strokeWidth: optsAtIndex.textStrokeWidth\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(sorter).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 _generate() {\n        const min = this.min;\n        const max = this.max;\n        let timestamps = super.getDataTimestamps();\n        if (!timestamps.includes(min) || !timestamps.length) {\n            timestamps.splice(0, 0, min);\n        }\n        if (!timestamps.includes(max) || timestamps.length === 1) {\n            timestamps.push(max);\n        }\n        return timestamps.sort((a, b)=>a - b);\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, Ticks, TimeScale, TimeSeriesScale, plugin_title as Title, plugin_tooltip as Tooltip, adapters as _adapters, _detectPlatform, animator, controllers, defaults, elements, layouts, plugins, registerables, registry, scales };\n//# sourceMappingURL=chart.js.map\n","import { Chart as Chart$1, BarController, DoughnutController, LineController, PieController, PolarAreaController, RadarController, BubbleController, ScatterController } from 'chart.js';\nimport { version, isProxy, toRaw, defineComponent, ref, shallowRef, onMounted, onUnmounted, watch, nextTick, h } from 'vue';\n\nconst CommonProps = {\n    data: {\n        type: Object,\n        required: true\n    },\n    options: {\n        type: Object,\n        default: ()=>({})\n    },\n    plugins: {\n        type: Array,\n        default: ()=>[]\n    },\n    datasetIdKey: {\n        type: String,\n        default: \"label\"\n    },\n    updateMode: {\n        type: String,\n        default: undefined\n    }\n};\nconst A11yProps = {\n    ariaLabel: {\n        type: String\n    },\n    ariaDescribedby: {\n        type: String\n    }\n};\nconst Props = {\n    type: {\n        type: String,\n        required: true\n    },\n    destroyDelay: {\n        type: Number,\n        default: 0 // No delay by default\n    },\n    ...CommonProps,\n    ...A11yProps\n};\n\nconst compatProps = version[0] === \"2\" ? (internals, props)=>Object.assign(internals, {\n        attrs: props\n    }) : (internals, props)=>Object.assign(internals, props);\nfunction toRawIfProxy(obj) {\n    return isProxy(obj) ? toRaw(obj) : obj;\n}\nfunction cloneProxy(obj) {\n    let src = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : obj;\n    return isProxy(src) ? new Proxy(obj, {}) : obj;\n}\nfunction setOptions(chart, nextOptions) {\n    const options = chart.options;\n    if (options && nextOptions) {\n        Object.assign(options, nextOptions);\n    }\n}\nfunction setLabels(currentData, nextLabels) {\n    currentData.labels = nextLabels;\n}\nfunction setDatasets(currentData, nextDatasets, datasetIdKey) {\n    const addedDatasets = [];\n    currentData.datasets = nextDatasets.map((nextDataset)=>{\n        // given the new set, find it's current match\n        const currentDataset = currentData.datasets.find((dataset)=>dataset[datasetIdKey] === nextDataset[datasetIdKey]);\n        // There is no original to update, so simply add new one\n        if (!currentDataset || !nextDataset.data || addedDatasets.includes(currentDataset)) {\n            return {\n                ...nextDataset\n            };\n        }\n        addedDatasets.push(currentDataset);\n        Object.assign(currentDataset, nextDataset);\n        return currentDataset;\n    });\n}\nfunction cloneData(data, datasetIdKey) {\n    const nextData = {\n        labels: [],\n        datasets: []\n    };\n    setLabels(nextData, data.labels);\n    setDatasets(nextData, data.datasets, datasetIdKey);\n    return nextData;\n}\n/**\n * Get dataset from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */ function getDatasetAtEvent(chart, event) {\n    return chart.getElementsAtEventForMode(event, \"dataset\", {\n        intersect: true\n    }, false);\n}\n/**\n * Get single dataset element from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */ function getElementAtEvent(chart, event) {\n    return chart.getElementsAtEventForMode(event, \"nearest\", {\n        intersect: true\n    }, false);\n}\n/**\n * Get all dataset elements from mouse click event\n * @param chart - Chart.js instance\n * @param event - Mouse click event\n * @returns Dataset\n */ function getElementsAtEvent(chart, event) {\n    return chart.getElementsAtEventForMode(event, \"index\", {\n        intersect: true\n    }, false);\n}\n\nconst Chart = defineComponent({\n    props: Props,\n    setup (props, param) {\n        let { expose , slots  } = param;\n        const canvasRef = ref(null);\n        const chartRef = shallowRef(null);\n        expose({\n            chart: chartRef\n        });\n        const renderChart = ()=>{\n            if (!canvasRef.value) return;\n            const { type , data , options , plugins , datasetIdKey  } = props;\n            const clonedData = cloneData(data, datasetIdKey);\n            const proxiedData = cloneProxy(clonedData, data);\n            chartRef.value = new Chart$1(canvasRef.value, {\n                type,\n                data: proxiedData,\n                options: {\n                    ...options\n                },\n                plugins\n            });\n        };\n        const destroyChart = ()=>{\n            const chart = toRaw(chartRef.value);\n            if (chart) {\n                if (props.destroyDelay > 0) {\n                    setTimeout(()=>{\n                        chart.destroy();\n                        chartRef.value = null;\n                    }, props.destroyDelay);\n                } else {\n                    chart.destroy();\n                    chartRef.value = null;\n                }\n            }\n        };\n        const update = (chart)=>{\n            chart.update(props.updateMode);\n        };\n        onMounted(renderChart);\n        onUnmounted(destroyChart);\n        watch([\n            ()=>props.options,\n            ()=>props.data\n        ], (param, param1)=>{\n            let [nextOptionsProxy, nextDataProxy] = param, [prevOptionsProxy, prevDataProxy] = param1;\n            const chart = toRaw(chartRef.value);\n            if (!chart) {\n                return;\n            }\n            let shouldUpdate = false;\n            if (nextOptionsProxy) {\n                const nextOptions = toRawIfProxy(nextOptionsProxy);\n                const prevOptions = toRawIfProxy(prevOptionsProxy);\n                if (nextOptions && nextOptions !== prevOptions) {\n                    setOptions(chart, nextOptions);\n                    shouldUpdate = true;\n                }\n            }\n            if (nextDataProxy) {\n                const nextLabels = toRawIfProxy(nextDataProxy.labels);\n                const prevLabels = toRawIfProxy(prevDataProxy.labels);\n                const nextDatasets = toRawIfProxy(nextDataProxy.datasets);\n                const prevDatasets = toRawIfProxy(prevDataProxy.datasets);\n                if (nextLabels !== prevLabels) {\n                    setLabels(chart.config.data, nextLabels);\n                    shouldUpdate = true;\n                }\n                if (nextDatasets && nextDatasets !== prevDatasets) {\n                    setDatasets(chart.config.data, nextDatasets, props.datasetIdKey);\n                    shouldUpdate = true;\n                }\n            }\n            if (shouldUpdate) {\n                nextTick(()=>{\n                    update(chart);\n                });\n            }\n        }, {\n            deep: true\n        });\n        return ()=>{\n            return h(\"canvas\", {\n                role: \"img\",\n                ariaLabel: props.ariaLabel,\n                ariaDescribedby: props.ariaDescribedby,\n                ref: canvasRef\n            }, [\n                h(\"p\", {}, [\n                    slots.default ? slots.default() : \"\"\n                ])\n            ]);\n        };\n    }\n});\n\nfunction createTypedChart(type, registerables) {\n    Chart$1.register(registerables);\n    return defineComponent({\n        props: CommonProps,\n        setup (props, param) {\n            let { expose  } = param;\n            const ref = shallowRef(null);\n            const reforwardRef = (chartRef)=>{\n                ref.value = chartRef?.chart;\n            };\n            expose({\n                chart: ref\n            });\n            return ()=>{\n                return h(Chart, compatProps({\n                    ref: reforwardRef\n                }, {\n                    type,\n                    ...props\n                }));\n            };\n        }\n    });\n}\nconst Bar = /* #__PURE__ */ createTypedChart(\"bar\", BarController);\nconst Doughnut = /* #__PURE__ */ createTypedChart(\"doughnut\", DoughnutController);\nconst Line = /* #__PURE__ */ createTypedChart(\"line\", LineController);\nconst Pie = /* #__PURE__ */ createTypedChart(\"pie\", PieController);\nconst PolarArea = /* #__PURE__ */ createTypedChart(\"polarArea\", PolarAreaController);\nconst Radar = /* #__PURE__ */ createTypedChart(\"radar\", RadarController);\nconst Bubble = /* #__PURE__ */ createTypedChart(\"bubble\", BubbleController);\nconst Scatter = /* #__PURE__ */ createTypedChart(\"scatter\", ScatterController);\n\nexport { Bar, Bubble, Chart, Doughnut, Line, Pie, PolarArea, Radar, Scatter, createTypedChart, getDatasetAtEvent, getElementAtEvent, getElementsAtEvent };\n//# sourceMappingURL=index.js.map\n","<script setup>\nimport { computed } from 'vue';\nimport { Bar } from 'vue-chartjs';\nimport {\n  Chart as ChartJS,\n  Title,\n  Tooltip,\n  BarElement,\n  CategoryScale,\n  LinearScale,\n} from 'chart.js';\n\nconst props = defineProps({\n  collection: {\n    type: Object,\n    default: () => ({}),\n  },\n  chartOptions: {\n    type: Object,\n    default: () => ({}),\n  },\n});\n\nChartJS.register(Title, Tooltip, BarElement, CategoryScale, LinearScale);\n\nconst fontFamily =\n  'Inter,-apple-system,system-ui,BlinkMacSystemFont,\"Segoe UI\",Roboto,\"Helvetica Neue\",Arial,sans-serif';\n\nconst defaultChartOptions = {\n  responsive: true,\n  maintainAspectRatio: false,\n  legend: {\n    display: false,\n    labels: {\n      fontFamily,\n    },\n  },\n  animation: {\n    duration: 0,\n  },\n  datasets: {\n    bar: {\n      barPercentage: 1.0,\n    },\n  },\n  scales: {\n    x: {\n      ticks: {\n        fontFamily: fontFamily,\n      },\n      grid: {\n        drawOnChartArea: false,\n      },\n    },\n    y: {\n      type: 'linear',\n      position: 'left',\n      ticks: {\n        fontFamily: fontFamily,\n        beginAtZero: true,\n        stepSize: 1,\n      },\n      grid: {\n        drawOnChartArea: false,\n      },\n    },\n  },\n};\n\nconst options = computed(() => {\n  return { ...defaultChartOptions, ...props.chartOptions };\n});\n</script>\n\n<template>\n  <Bar :data=\"collection\" :options=\"options\" />\n</template>\n"],"names":["round","v","lim","l","h","p2b","n2b","b2n","n2p","map$1","hex","h1","b","h2","eq","isShort","hexParse","str","len","ret","alpha","a","f","hexString","HUE_RE","hsl2rgbn","s","n","k","hsv2rgbn","hwb2rgbn","w","rgb","i","hueValue","r","g","d","max","rgb2hsl","min","calln","c","hsl2rgb","hwb2rgb","hsv2rgb","hue","hueParse","m","p1","p2","rotate","deg","hslString","map","names$1","unpack","unpacked","keys","tkeys","j","ok","nk","names","nameParse","RGB_RE","rgbParse","rgbString","to","from","interpolate","rgb1","rgb2","t","modHSL","ratio","tmp","clone","proto","fromObject","input","functionParse","Color","type","obj","color","weight","c1","c2","w2","p","w1","val","noop","uid","id","isNullOrUndef","value","isArray","isObject","isNumberFinite","finiteOrDefault","defaultValue","valueOrDefault","toDimension","dimension","callback","fn","args","thisArg","each","loopable","reverse","_elementsEqual","a0","a1","ilen","v0","v1","source","target","klen","isValidKey","key","_merger","options","tval","sval","merge","sources","merger","current","mergeIf","_mergerIf","keyResolvers","o","_splitKey","parts","part","_getKeyResolver","resolveObjectKey","_capitalize","defined","isFunction","setsEqual","item","_isClickEvent","e","PI","TAU","INFINITY","RAD_PER_DEG","HALF_PI","QUARTER_PI","TWO_THIRDS_PI","log10","sign","almostEquals","x","y","epsilon","niceNum","range","roundedRange","niceRange","fraction","_factorize","result","sqrt","isNumber","almostWhole","rounded","_setMinAndMaxByKey","array","property","toRadians","degrees","toDegrees","radians","_decimalPlaces","getAngleFromPoint","centrePoint","anglePoint","distanceFromXCenter","distanceFromYCenter","radialDistanceFromCenter","angle","distanceBetweenPoints","pt1","pt2","_normalizeAngle","_angleBetween","start","end","sameAngleIsFullCircle","angleToStart","angleToEnd","startToAngle","endToAngle","_limitValue","_int16Range","_isBetween","_lookup","table","cmp","index","hi","lo","mid","_lookupByKey","last","ti","_rlookupByKey","_filterBetween","values","arrayEvents","listenArrayEvents","listener","method","base","res","object","unlistenArrayEvents","stub","listeners","_arrayUnique","items","set","requestAnimFrame","throttled","argsToUse","ticking","debounce","delay","timeout","_toLeftRightCenter","align","_alignStartEnd","atEdge","elasticIn","elasticOut","effects","isPatternOrGradient","getHoverColor","numbers","colors","applyAnimationsDefaults","defaults","name","applyLayoutsDefaults","intlCache","getNumberFormat","locale","cacheKey","formatter","formatNumber","num","formatters","tickValue","ticks","notation","delta","maxTick","calculateDelta","logDelta","numDecimal","remain","Ticks","applyScaleDefaults","_ctx","overrides","descriptors","getScope$1","node","root","scope","Defaults","_descriptors","_appliers","context","ctx","targetScope","targetName","scopeObject","targetScopeObject","privateName","local","appliers","apply","toFontString","font","_measureText","data","gc","longest","string","textWidth","_alignPixel","chart","pixel","width","devicePixelRatio","halfWidth","clearCanvas","canvas","drawPoint","drawPointLegend","xOffset","yOffset","size","cornerRadius","xOffsetW","yOffsetW","style","rotation","radius","rad","_isPointInArea","point","area","margin","clipArea","unclipArea","setRenderOpts","opts","decorateText","line","metrics","left","right","top","bottom","yDecoration","drawBackdrop","oldColor","renderText","text","lines","stroke","addRoundedRectPath","rect","LINE_HEIGHT","FONT_STYLE","toLineHeight","matches","numberOrZero","_readValueToProps","props","objProps","read","prop","toTRBL","toTRBLCorners","toPadding","toFont","fallback","resolve","inputs","info","_addGrace","minmax","grace","beginAtZero","change","keepZero","add","createContext","parentContext","_createResolver","scopes","prefixes","rootScopes","getTarget","finalRootScopes","_resolve","cache","_cached","_resolveWithPrefixes","getKeysFromAllScopes","storage","_attachContext","proxy","subProxy","descriptorDefaults","receiver","_resolveWithContext","_scriptable","_indexable","_allKeys","readKey","prefix","needsSubResolver","_proxy","_context","_subProxy","_resolveScriptable","_resolveArray","getValue","_stack","createSubResolver","isIndexable","arr","resolver","resolveFallback","getScope","parent","addScopes","parentScopes","parentFallback","allScopes","addScopesFromKey","subGetTarget","resolveKeysFromAllScopes","_isDomSupported","_getParentNode","domNode","parseMaxStyle","styleValue","parentProperty","valueInPixels","getComputedStyle","element","getStyle","el","positions","getPositionedStyle","styles","suffix","pos","useOffsetPos","getCanvasPosition","touches","offsetX","offsetY","box","getRelativePosition","event","currentDevicePixelRatio","borderBox","paddings","borders","height","getContainerSize","maxWidth","maxHeight","container","containerStyle","containerBorder","containerPadding","round1","getMaximumSize","bbWidth","bbHeight","aspectRatio","margins","containerSize","retinaScale","forceRatio","forceStyle","pixelRatio","deviceHeight","deviceWidth","supportsEventListenerOptions","passiveSupported","readUsedSize","getRightToLeftAdapter","rectX","itemWidth","getLeftToRightAdapter","_itemWidth","getRtlAdapter","rtl","overrideTextDirection","direction","original","restoreTextDirection","Animator","anims","date","callbacks","numSteps","remaining","draw","charts","cb","acc","cur","animator","transparent","interpolators","factor","c0","Animation","cfg","currentValue","elapsed","duration","loop","promises","rej","resolved","Animations","config","animationOptions","animatedProps","option","newOptions","resolveTargetOptions","animations","awaitAll","running","animation","properties","anim","scaleClip","scale","allowedOverflow","defaultClip","xScale","yScale","toClip","getSortedDatasetIndices","filterVisible","metasets","applyStack","stack","dsIndex","singleMode","datasetIndex","otherValue","convertObjectDataToArray","meta","iScale","vScale","iAxisKey","vAxisKey","adata","isStacked","stacked","getStackKey","indexScale","valueScale","getUserBounds","minDefined","maxDefined","getOrCreateStack","stacks","stackKey","indexValue","subStack","getLastIndexInStack","positive","updateStacks","controller","parsed","iAxis","vAxis","itemStacks","visualValues","getFirstScaleId","axis","scales","createDatasetContext","createDataContext","clearStacks","isDirectUpdateMode","mode","cloneIfNotShared","cached","shared","createStack","canStack","DatasetController","dataset","chooseId","xid","yid","rid","indexAxis","iid","vid","scaleID","_data","resetNewElements","stackChanged","oldStacked","scopeKeys","count","_stacked","sorted","prev","isNotInOrderComparedToPrev","labels","singleScale","xAxisKey","yAxisKey","parsedValue","_parsed","otherScale","otherMin","otherMax","_skip","elements","active","drawActiveElementsOnTop","elementType","sharing","transition","sharedOptions","firstOpts","previouslySharedOptions","includeOptions","arg1","arg2","numMeta","numData","move","removed","newCount","__publicField","getAllScaleValues","visibleMetas","computeMinSampleSize","curr","updateMinAndPrev","computeFitCategoryTraits","ruler","stackCount","thickness","computeFlexCategoryTraits","pixels","next","percent","parseFloatBar","entry","startValue","endValue","barStart","barEnd","parseValue","parseArrayOrPrimitive","isFloatBar","custom","barSign","actualBase","borderProps","setBorderSkipped","edge","parseEdge","swap","startEnd","orig","v2","setInflateAmount","inflateAmount","BarController","bars","reset","horizontal","vpixels","ipixels","dataIndex","currentParsed","iScaleValue","skipNull","barThickness","baseValue","minBarLength","floating","length","head","startPixel","endPixel","halfGrid","maxBarThickness","center","stackIndex","rects","abstract","DateAdapterBase","members","adapters","binarySearch","metaset","intersect","_sorted","lookupMethod","evaluateInteractionItems","position","handler","getDistanceMetricForAxis","useX","useY","deltaX","deltaY","getIntersectItems","useFinalPosition","includeInvisible","getNearestRadialItems","evaluationFunc","startAngle","endAngle","getNearestCartesianItems","distanceMetric","minDistance","inRange","distance","getNearestItems","getAxisItems","rangeMethod","intersectsItem","Interaction","STATIC_POSITIONS","filterByPosition","filterDynamicPositionByAxis","sortByWeight","wrapBoxes","boxes","layoutBoxes","stackWeight","buildStacks","layouts","wrap","setLayoutDims","params","vBoxMaxWidth","hBoxMaxHeight","layout","fullSize","buildLayoutBoxes","centerHorizontal","centerVertical","getCombinedMax","maxPadding","chartArea","updateMaxPadding","boxPadding","updateDims","newWidth","newHeight","widthChanged","heightChanged","handleMaxPadding","updatePos","getMargins","marginForPositions","fitBoxes","refitBoxes","refit","changed","same","other","setBoxDims","placeBoxes","userPadding","layoutItem","minPadding","padding","availableWidth","availableHeight","verticalBoxes","horizontalBoxes","visibleVerticalBoxCount","total","BasePlatform","BasicPlatform","EXPANDO_KEY","EVENT_TYPES","isNullOrEmpty","initCanvas","renderHeight","renderWidth","displayWidth","displayHeight","eventListenerOptions","addListener","removeListener","fromNativeEvent","nodeListContains","nodeList","createAttachObserver","observer","entries","trigger","createDetachObserver","drpListeningCharts","oldDevicePixelRatio","onWindowResize","dpr","resize","listenDevicePixelRatioChanges","unlistenDevicePixelRatioChanges","createResizeObserver","releaseObserver","createProxyAndListen","DomPlatform","initial","proxies","_detectPlatform","Element","final","autoSkip","tickOpts","determinedMaxTicks","determineMaxTicks","ticksLimit","majorIndices","getMajorIndices","numMajorIndices","first","newTicks","skipMajors","spacing","calculateSpacing","avgMajorSpacing","skip","offset","tickLength","maxScale","maxChart","evenMajorSpacing","getEvenSpacing","factors","majorStart","majorEnd","diff","reverseAlign","offsetFromEdge","getTicksLimit","ticksLength","maxTicksLimit","sample","numItems","increment","getPixelForGridLine","offsetGridLines","validIndex","lineValue","garbageCollect","caches","gcLen","getTickMarkLength","getTitleHeight","createScaleContext","createTickContext","tick","titleAlign","titleArgs","titleX","titleY","positionAxisID","Scale","raw","_userMin","_userMax","_suggestedMin","_suggestedMax","metas","sampleSize","samplingEnabled","reversePixels","numTicks","minRotation","maxRotation","labelRotation","tickWidth","maxLabelDiagonal","labelSizes","maxLabelWidth","maxLabelHeight","minSize","titleOpts","gridOpts","display","isHorizontal","titleHeight","widest","highest","tickPadding","angleRadians","cos","sin","labelHeight","labelWidth","isRotated","labelsBelowTicks","offsetLeft","offsetRight","paddingLeft","paddingRight","paddingTop","paddingBottom","widths","heights","widestLabelSize","highestLabelSize","jlen","label","tickFont","fontString","lineHeight","nestedLabel","valueAt","idx","decimal","optionTicks","rot","grid","border","tl","borderOpts","axisWidth","axisHalfWidth","alignBorderValue","borderValue","alignedLineValue","tx1","ty1","tx2","ty2","x1","y1","x2","y2","limit","step","optsAtIndex","optsAtIndexBorder","lineWidth","lineColor","borderDash","borderDashOffset","tickColor","tickBorderDash","tickBorderDashOffset","crossAlign","mirror","tickAndPadding","hTickAndPadding","textAlign","lineCount","textOffset","textBaseline","halfCount","strokeColor","strokeWidth","tickTextAlign","backdrop","labelPadding","backgroundColor","drawLine","lastLineWidth","renderTextOptions","title","tz","gz","bz","axisID","fontSize","TypedRegistry","override","parentScope","isIChartComponent","registerDefaults","itemDefaults","routeDefaults","routes","propertyParts","sourceName","sourceScope","Registry","typedRegistry","arg","reg","itemReg","registry","component","camelMethod","PluginService","hook","filter","descriptor","plugin","all","plugins","allPlugins","createDescriptors","previousDescriptors","localIds","getOpts","pluginOpts","getIndexAxis","datasetDefaults","getAxisFromDefaultScaleID","getDefaultScaleIDFromAxis","idMatchesAxis","axisFromPosition","determineAxis","scaleOptions","getAxisFromDataset","retrieveAxisFromDatasets","boundDs","mergeScaleConfig","chartDefaults","configScales","chartIndexAxis","scaleConf","defaultId","defaultScaleOptions","defaultID","initOptions","initData","initConfig","keyCache","keysCached","cachedKeys","generate","addIfFound","Config","datasetType","mainScope","resetCache","_scopeCache","keyLists","subPrefixes","getResolver","needContext","subResolver","resolverCache","hasFunction","isScriptable","scriptable","indexable","version","KNOWN_POSITIONS","positionIsHorizontal","compare2Level","l1","l2","onAnimationsComplete","onAnimationProgress","getCanvas","instances","getChart","moveNumericKeys","intKey","determineLastEvent","lastEvent","inChartArea","isClick","getSizeForArea","field","getDatasetArea","Chart$1","_a","invalidatePlugins","userConfig","initialCanvas","existingChart","maintainAspectRatio","_aspectRatio","newSize","newRatio","scalesOptions","axisOptions","scaleOpts","updated","isRadial","scaleType","scaleClass","hasUpdated","datasets","newControllers","ControllerClass","datasetElementType","dataElementType","animsDisabled","_active","_lastEvent","existingEvents","newEvents","_hiddenIndices","changes","_dataChanges","datasetCount","makeSet","changeSet","noArea","layers","clip","useClip","visible","platform","_add","_remove","detached","attached","enabled","activeElements","lastActive","pluginId","replay","hoverOptions","deactivated","activated","eventFilter","Chart","getBarBounds","bar","half","skipOrLimit","parseBorderWidth","maxW","maxH","parseBorderRadius","enableBorderRadius","maxR","enableBorder","boundingRects","bounds","skipX","skipY","hasRadius","addNormalRectPath","inflateRect","amount","refRect","BarElement","borderColor","inner","outer","addRectPath","mouseX","mouseY","Title","textSize","fontOpts","createTitle","plugin_title","_args","titleBlock","positioners","xSet","eventPosition","nearestElement","tp","pushOrConcat","toPush","splitNewlines","createTooltipItem","getTooltipSize","tooltip","body","footer","boxWidth","boxHeight","bodyFont","titleFont","footerFont","titleLineCount","footerLineCount","bodyLineItemCount","combinedBodyLength","bodyItem","bodyLineHeight","widthPadding","maxLineWidth","determineYAlign","doesNotFitWithAlign","xAlign","caret","determineXAlign","yAlign","chartWidth","determineAlignment","alignX","alignY","paddingAndSize","getBackgroundPoint","alignment","caretSize","caretPadding","topLeft","topRight","bottomLeft","bottomRight","getAlignedX","getBeforeAfterBodyLines","createTooltipContext","tooltipItems","overrideCallbacks","defaultCallbacks","labelCount","tooltipItem","invokeCallbackWithFallback","Tooltip","beforeTitle","afterTitle","bodyItems","scoped","beforeFooter","afterFooter","labelColors","labelPointStyles","labelTextColors","positionAndSize","backgroundPoint","tooltipPoint","caretPosition","ptX","ptY","x3","y3","pt","titleSpacing","rtlHelper","labelColor","labelPointStyle","colorX","rtlColorX","yOffSet","colorY","drawOptions","centerX","centerY","outerX","innerX","borderRadius","bodySpacing","bodyAlign","displayColors","xLinePadding","fillLineOfText","bodyAlignForCalculation","textColor","tooltipSize","animX","animY","opacity","hasTooltipContent","positionChanged","caretX","caretY","plugin_tooltip","addIfString","addedLabels","findOrAddLabel","_getLabelForValue","CategoryScale","added","generateTicks$1","generationOptions","dataRange","precision","maxTicks","maxDigits","includeBounds","unit","maxSpaces","rmin","rmax","countDefined","minSpacing","niceMin","niceMax","numSpaces","decimalPlaces","relativeLabelSize","LinearScaleBase","setMin","setMax","minSign","maxSign","stepSize","numericGeneratorOptions","LinearScale","INTERVALS","UNITS","sorter","parse","adapter","parser","isoWeekday","determineUnitForAutoTicks","minUnit","capacity","interval","determineUnitForFormatting","determineMajorUnit","addTick","time","timestamps","timestamp","setMajorTicks","majorUnit","major","ticksFromTimestamps","TimeScale","_applyBounds","timeOpts","minor","weekday","hasWeekday","format","formats","fmt","minorFormat","majorFormat","offsets","ticksOpts","tickLabelWidth","cosRotation","sinRotation","tickFontSize","exampleTime","displayFormats","exampleLabel","prevSource","nextSource","prevTarget","nextTarget","span","TimeSeriesScale","CommonProps","A11yProps","Props","compatProps","internals","toRawIfProxy","isProxy","toRaw","cloneProxy","src","setOptions","nextOptions","setLabels","currentData","nextLabels","setDatasets","nextDatasets","datasetIdKey","addedDatasets","nextDataset","currentDataset","cloneData","nextData","defineComponent","param","expose","slots","canvasRef","ref","chartRef","shallowRef","renderChart","clonedData","proxiedData","destroyChart","update","onMounted","onUnmounted","watch","param1","nextOptionsProxy","nextDataProxy","prevOptionsProxy","prevDataProxy","shouldUpdate","prevOptions","prevLabels","prevDatasets","nextTick","createTypedChart","registerables","reforwardRef","Bar","fontFamily","__props","ChartJS","defaultChartOptions","computed"],"mappings":"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","x_google_ignoreList":[0,1,2,3]}