{"version":3,"file":"js/7302-aa156195da2ed6bb1ef9-v10.js","mappings":"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","sources":["webpack:///../../shared/node_modules/chart.js/dist/chart.js"],"sourcesContent":["/*!\n * Chart.js v4.4.0\n * https://www.chartjs.org\n * (c) 2023 Chart.js Contributors\n * Released under the MIT License\n */\nimport { r as requestAnimFrame, a as resolve, e as effects, c as color, i as isObject, d as defaults, b as isArray, v as valueOrDefault, u as unlistenArrayEvents, l as listenArrayEvents, f as resolveObjectKey, g as isNumberFinite, h as defined, s as sign, j as createContext, k as isNullOrUndef, _ as _arrayUnique, t as toRadians, m as toPercentage, n as toDimension, T as TAU, o as formatNumber, p as _angleBetween, H as HALF_PI, P as PI, q as _getStartAndCountOfVisiblePoints, w as _scaleRangesChanged, x as isNumber, y as _parseObjectDataRadialScale, z as getRelativePosition, A as _rlookupByKey, B as _lookupByKey, C as _isPointInArea, D as getAngleFromPoint, E as toPadding, F as each, G as getMaximumSize, I as _getParentNode, J as readUsedSize, K as supportsEventListenerOptions, L as throttled, M as _isDomSupported, N as _factorize, O as finiteOrDefault, Q as callback, R as _addGrace, S as _limitValue, U as toDegrees, V as _measureText, W as _int16Range, X as _alignPixel, Y as clipArea, Z as renderText, $ as unclipArea, a0 as toFont, a1 as _toLeftRightCenter, a2 as _alignStartEnd, a3 as overrides, a4 as merge, a5 as _capitalize, a6 as descriptors, a7 as isFunction, a8 as _attachContext, a9 as _createResolver, aa as _descriptors, ab as mergeIf, ac as uid, ad as debounce, ae as retinaScale, af as clearCanvas, ag as setsEqual, ah as _elementsEqual, ai as _isClickEvent, aj as _isBetween, ak as _readValueToProps, al as _updateBezierControlPoints, am as _computeSegments, an as _boundSegments, ao as _steppedInterpolation, ap as _bezierInterpolation, aq as _pointInLine, ar as _steppedLineTo, as as _bezierCurveTo, at as drawPoint, au as addRoundedRectPath, av as toTRBL, aw as toTRBLCorners, ax as _boundSegment, ay as _normalizeAngle, az as getRtlAdapter, aA as overrideTextDirection, aB as _textX, aC as restoreTextDirection, aD as drawPointLegend, aE as distanceBetweenPoints, aF as noop, aG as _setMinAndMaxByKey, aH as niceNum, aI as almostWhole, aJ as almostEquals, aK as _decimalPlaces, aL as Ticks, aM as log10, aN as _longestText, aO as _filterBetween, aP as _lookup } from './chunks/helpers.segment.js';\nimport '@kurkle/color';\n\nclass Animator {\n constructor(){\n this._request = null;\n this._charts = new Map();\n this._running = false;\n this._lastDate = undefined;\n }\n _notify(chart, anims, date, type) {\n const callbacks = anims.listeners[type];\n const numSteps = anims.duration;\n callbacks.forEach((fn)=>fn({\n chart,\n initial: anims.initial,\n numSteps,\n currentStep: Math.min(date - anims.start, numSteps)\n }));\n }\n _refresh() {\n if (this._request) {\n return;\n }\n this._running = true;\n this._request = requestAnimFrame.call(window, ()=>{\n this._update();\n this._request = null;\n if (this._running) {\n this._refresh();\n }\n });\n }\n _update(date = Date.now()) {\n let remaining = 0;\n this._charts.forEach((anims, chart)=>{\n if (!anims.running || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n let draw = false;\n let item;\n for(; i >= 0; --i){\n item = items[i];\n if (item._active) {\n if (item._total > anims.duration) {\n anims.duration = item._total;\n }\n item.tick(date);\n draw = true;\n } else {\n items[i] = items[items.length - 1];\n items.pop();\n }\n }\n if (draw) {\n chart.draw();\n this._notify(chart, anims, date, 'progress');\n }\n if (!items.length) {\n anims.running = false;\n this._notify(chart, anims, date, 'complete');\n anims.initial = false;\n }\n remaining += items.length;\n });\n this._lastDate = date;\n if (remaining === 0) {\n this._running = false;\n }\n }\n _getAnims(chart) {\n const charts = this._charts;\n let anims = charts.get(chart);\n if (!anims) {\n anims = {\n running: false,\n initial: true,\n items: [],\n listeners: {\n complete: [],\n progress: []\n }\n };\n charts.set(chart, anims);\n }\n return anims;\n }\n listen(chart, event, cb) {\n this._getAnims(chart).listeners[event].push(cb);\n }\n add(chart, items) {\n if (!items || !items.length) {\n return;\n }\n this._getAnims(chart).items.push(...items);\n }\n has(chart) {\n return this._getAnims(chart).items.length > 0;\n }\n start(chart) {\n const anims = this._charts.get(chart);\n if (!anims) {\n return;\n }\n anims.running = true;\n anims.start = Date.now();\n anims.duration = anims.items.reduce((acc, cur)=>Math.max(acc, cur._duration), 0);\n this._refresh();\n }\n running(chart) {\n if (!this._running) {\n return false;\n }\n const anims = this._charts.get(chart);\n if (!anims || !anims.running || !anims.items.length) {\n return false;\n }\n return true;\n }\n stop(chart) {\n const anims = this._charts.get(chart);\n if (!anims || !anims.items.length) {\n return;\n }\n const items = anims.items;\n let i = items.length - 1;\n for(; i >= 0; --i){\n items[i].cancel();\n }\n anims.items = [];\n this._notify(chart, anims, Date.now(), 'complete');\n }\n remove(chart) {\n return this._charts.delete(chart);\n }\n}\nvar animator = /* #__PURE__ */ new Animator();\n\nconst transparent = 'transparent';\nconst interpolators = {\n boolean (from, to, factor) {\n return factor > 0.5 ? to : from;\n },\n color (from, to, factor) {\n const c0 = color(from || transparent);\n const c1 = c0.valid && color(to || transparent);\n return c1 && c1.valid ? c1.mix(c0, factor).hexString() : to;\n },\n number (from, to, factor) {\n return from + (to - from) * factor;\n }\n};\nclass Animation {\n constructor(cfg, target, prop, to){\n const currentValue = target[prop];\n to = resolve([\n cfg.to,\n to,\n currentValue,\n cfg.from\n ]);\n const from = resolve([\n cfg.from,\n currentValue,\n to\n ]);\n this._active = true;\n this._fn = cfg.fn || interpolators[cfg.type || typeof from];\n this._easing = effects[cfg.easing] || effects.linear;\n this._start = Math.floor(Date.now() + (cfg.delay || 0));\n this._duration = this._total = Math.floor(cfg.duration);\n this._loop = !!cfg.loop;\n this._target = target;\n this._prop = prop;\n this._from = from;\n this._to = to;\n this._promises = undefined;\n }\n active() {\n return this._active;\n }\n update(cfg, to, date) {\n if (this._active) {\n this._notify(false);\n const currentValue = this._target[this._prop];\n const elapsed = date - this._start;\n const remain = this._duration - elapsed;\n this._start = date;\n this._duration = Math.floor(Math.max(remain, cfg.duration));\n this._total += elapsed;\n this._loop = !!cfg.loop;\n this._to = resolve([\n cfg.to,\n to,\n currentValue,\n cfg.from\n ]);\n this._from = resolve([\n cfg.from,\n currentValue,\n to\n ]);\n }\n }\n cancel() {\n if (this._active) {\n this.tick(Date.now());\n this._active = false;\n this._notify(false);\n }\n }\n tick(date) {\n const elapsed = date - this._start;\n const duration = this._duration;\n const prop = this._prop;\n const from = this._from;\n const loop = this._loop;\n const to = this._to;\n let factor;\n this._active = from !== to && (loop || elapsed < duration);\n if (!this._active) {\n this._target[prop] = to;\n this._notify(true);\n return;\n }\n if (elapsed < 0) {\n this._target[prop] = from;\n return;\n }\n factor = elapsed / duration % 2;\n factor = loop && factor > 1 ? 2 - factor : factor;\n factor = this._easing(Math.min(1, Math.max(0, factor)));\n this._target[prop] = this._fn(from, to, factor);\n }\n wait() {\n const promises = this._promises || (this._promises = []);\n return new Promise((res, rej)=>{\n promises.push({\n res,\n rej\n });\n });\n }\n _notify(resolved) {\n const method = resolved ? 'res' : 'rej';\n const promises = this._promises || [];\n for(let i = 0; i < promises.length; i++){\n promises[i][method]();\n }\n }\n}\n\nclass Animations {\n constructor(chart, config){\n this._chart = chart;\n this._properties = new Map();\n this.configure(config);\n }\n configure(config) {\n if (!isObject(config)) {\n return;\n }\n const animationOptions = Object.keys(defaults.animation);\n const animatedProps = this._properties;\n Object.getOwnPropertyNames(config).forEach((key)=>{\n const cfg = config[key];\n if (!isObject(cfg)) {\n return;\n }\n const resolved = {};\n for (const option of animationOptions){\n resolved[option] = cfg[option];\n }\n (isArray(cfg.properties) && cfg.properties || [\n key\n ]).forEach((prop)=>{\n if (prop === key || !animatedProps.has(prop)) {\n animatedProps.set(prop, resolved);\n }\n });\n });\n }\n _animateOptions(target, values) {\n const newOptions = values.options;\n const options = resolveTargetOptions(target, newOptions);\n if (!options) {\n return [];\n }\n const animations = this._createAnimations(options, newOptions);\n if (newOptions.$shared) {\n awaitAll(target.options.$animations, newOptions).then(()=>{\n target.options = newOptions;\n }, ()=>{\n });\n }\n return animations;\n }\n _createAnimations(target, values) {\n const animatedProps = this._properties;\n const animations = [];\n const running = target.$animations || (target.$animations = {});\n const props = Object.keys(values);\n const date = Date.now();\n let i;\n for(i = props.length - 1; i >= 0; --i){\n const prop = props[i];\n if (prop.charAt(0) === '$') {\n continue;\n }\n if (prop === 'options') {\n animations.push(...this._animateOptions(target, values));\n continue;\n }\n const value = values[prop];\n let animation = running[prop];\n const cfg = animatedProps.get(prop);\n if (animation) {\n if (cfg && animation.active()) {\n animation.update(cfg, value, date);\n continue;\n } else {\n animation.cancel();\n }\n }\n if (!cfg || !cfg.duration) {\n target[prop] = value;\n continue;\n }\n running[prop] = animation = new Animation(cfg, target, prop, value);\n animations.push(animation);\n }\n return animations;\n }\n update(target, values) {\n if (this._properties.size === 0) {\n Object.assign(target, values);\n return;\n }\n const animations = this._createAnimations(target, values);\n if (animations.length) {\n animator.add(this._chart, animations);\n return true;\n }\n }\n}\nfunction awaitAll(animations, properties) {\n const running = [];\n const keys = Object.keys(properties);\n for(let i = 0; i < keys.length; i++){\n const anim = animations[keys[i]];\n if (anim && anim.active()) {\n running.push(anim.wait());\n }\n }\n return Promise.all(running);\n}\nfunction resolveTargetOptions(target, newOptions) {\n if (!newOptions) {\n return;\n }\n let options = target.options;\n if (!options) {\n target.options = newOptions;\n return;\n }\n if (options.$shared) {\n target.options = options = Object.assign({}, options, {\n $shared: false,\n $animations: {}\n });\n }\n return options;\n}\n\nfunction scaleClip(scale, allowedOverflow) {\n const opts = scale && scale.options || {};\n const reverse = opts.reverse;\n const min = opts.min === undefined ? allowedOverflow : 0;\n const max = opts.max === undefined ? allowedOverflow : 0;\n return {\n start: reverse ? max : min,\n end: reverse ? min : max\n };\n}\nfunction defaultClip(xScale, yScale, allowedOverflow) {\n if (allowedOverflow === false) {\n return false;\n }\n const x = scaleClip(xScale, allowedOverflow);\n const y = scaleClip(yScale, allowedOverflow);\n return {\n top: y.end,\n right: x.end,\n bottom: y.start,\n left: x.start\n };\n}\nfunction toClip(value) {\n let t, r, b, l;\n if (isObject(value)) {\n t = value.top;\n r = value.right;\n b = value.bottom;\n l = value.left;\n } else {\n t = r = b = l = value;\n }\n return {\n top: t,\n right: r,\n bottom: b,\n left: l,\n disabled: value === false\n };\n}\nfunction getSortedDatasetIndices(chart, filterVisible) {\n const keys = [];\n const metasets = chart._getSortedDatasetMetas(filterVisible);\n let i, ilen;\n for(i = 0, ilen = metasets.length; i < ilen; ++i){\n keys.push(metasets[i].index);\n }\n return keys;\n}\nfunction applyStack(stack, value, dsIndex, options = {}) {\n const keys = stack.keys;\n const singleMode = options.mode === 'single';\n let i, ilen, datasetIndex, otherValue;\n if (value === null) {\n return;\n }\n for(i = 0, ilen = keys.length; i < ilen; ++i){\n datasetIndex = +keys[i];\n if (datasetIndex === dsIndex) {\n if (options.all) {\n continue;\n }\n break;\n }\n otherValue = stack.values[datasetIndex];\n if (isNumberFinite(otherValue) && (singleMode || value === 0 || sign(value) === sign(otherValue))) {\n value += otherValue;\n }\n }\n return value;\n}\nfunction convertObjectDataToArray(data) {\n const keys = Object.keys(data);\n const adata = new Array(keys.length);\n let i, ilen, key;\n for(i = 0, ilen = keys.length; i < ilen; ++i){\n key = keys[i];\n adata[i] = {\n x: key,\n y: data[key]\n };\n }\n return adata;\n}\nfunction isStacked(scale, meta) {\n const stacked = scale && scale.options.stacked;\n return stacked || stacked === undefined && meta.stack !== undefined;\n}\nfunction getStackKey(indexScale, valueScale, meta) {\n return `${indexScale.id}.${valueScale.id}.${meta.stack || meta.type}`;\n}\nfunction getUserBounds(scale) {\n const { min , max , minDefined , maxDefined } = scale.getUserBounds();\n return {\n min: minDefined ? min : Number.NEGATIVE_INFINITY,\n max: maxDefined ? max : Number.POSITIVE_INFINITY\n };\n}\nfunction getOrCreateStack(stacks, stackKey, indexValue) {\n const subStack = stacks[stackKey] || (stacks[stackKey] = {});\n return subStack[indexValue] || (subStack[indexValue] = {});\n}\nfunction getLastIndexInStack(stack, vScale, positive, type) {\n for (const meta of vScale.getMatchingVisibleMetas(type).reverse()){\n const value = stack[meta.index];\n if (positive && value > 0 || !positive && value < 0) {\n return meta.index;\n }\n }\n return null;\n}\nfunction updateStacks(controller, parsed) {\n const { chart , _cachedMeta: meta } = controller;\n const stacks = chart._stacks || (chart._stacks = {});\n const { iScale , vScale , index: datasetIndex } = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const key = getStackKey(iScale, vScale, meta);\n const ilen = parsed.length;\n let stack;\n for(let i = 0; i < ilen; ++i){\n const item = parsed[i];\n const { [iAxis]: index , [vAxis]: value } = item;\n const itemStacks = item._stacks || (item._stacks = {});\n stack = itemStacks[vAxis] = getOrCreateStack(stacks, key, index);\n stack[datasetIndex] = value;\n stack._top = getLastIndexInStack(stack, vScale, true, meta.type);\n stack._bottom = getLastIndexInStack(stack, vScale, false, meta.type);\n const visualValues = stack._visualValues || (stack._visualValues = {});\n visualValues[datasetIndex] = value;\n }\n}\nfunction getFirstScaleId(chart, axis) {\n const scales = chart.scales;\n return Object.keys(scales).filter((key)=>scales[key].axis === axis).shift();\n}\nfunction createDatasetContext(parent, index) {\n return createContext(parent, {\n active: false,\n dataset: undefined,\n datasetIndex: index,\n index,\n mode: 'default',\n type: 'dataset'\n });\n}\nfunction createDataContext(parent, index, element) {\n return createContext(parent, {\n active: false,\n dataIndex: index,\n parsed: undefined,\n raw: undefined,\n element,\n index,\n mode: 'default',\n type: 'data'\n });\n}\nfunction clearStacks(meta, items) {\n const datasetIndex = meta.controller.index;\n const axis = meta.vScale && meta.vScale.axis;\n if (!axis) {\n return;\n }\n items = items || meta._parsed;\n for (const parsed of items){\n const stacks = parsed._stacks;\n if (!stacks || stacks[axis] === undefined || stacks[axis][datasetIndex] === undefined) {\n return;\n }\n delete stacks[axis][datasetIndex];\n if (stacks[axis]._visualValues !== undefined && stacks[axis]._visualValues[datasetIndex] !== undefined) {\n delete stacks[axis]._visualValues[datasetIndex];\n }\n }\n}\nconst isDirectUpdateMode = (mode)=>mode === 'reset' || mode === 'none';\nconst cloneIfNotShared = (cached, shared)=>shared ? cached : Object.assign({}, cached);\nconst createStack = (canStack, meta, chart)=>canStack && !meta.hidden && meta._stacked && {\n keys: getSortedDatasetIndices(chart, true),\n values: null\n };\nclass DatasetController {\n static defaults = {};\n static datasetElementType = null;\n static dataElementType = null;\n constructor(chart, datasetIndex){\n this.chart = chart;\n this._ctx = chart.ctx;\n this.index = datasetIndex;\n this._cachedDataOpts = {};\n this._cachedMeta = this.getMeta();\n this._type = this._cachedMeta.type;\n this.options = undefined;\n this._parsing = false;\n this._data = undefined;\n this._objectData = undefined;\n this._sharedOptions = undefined;\n this._drawStart = undefined;\n this._drawCount = undefined;\n this.enableOptionSharing = false;\n this.supportsDecimation = false;\n this.$context = undefined;\n this._syncList = [];\n this.datasetElementType = new.target.datasetElementType;\n this.dataElementType = new.target.dataElementType;\n this.initialize();\n }\n initialize() {\n const meta = this._cachedMeta;\n this.configure();\n this.linkScales();\n meta._stacked = isStacked(meta.vScale, meta);\n this.addElements();\n if (this.options.fill && !this.chart.isPluginEnabled('filler')) {\n console.warn(\"Tried to use the 'fill' option without the 'Filler' plugin enabled. Please import and register the 'Filler' plugin and make sure it is not disabled in the options\");\n }\n }\n updateIndex(datasetIndex) {\n if (this.index !== datasetIndex) {\n clearStacks(this._cachedMeta);\n }\n this.index = datasetIndex;\n }\n linkScales() {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n const chooseId = (axis, x, y, r)=>axis === 'x' ? x : axis === 'r' ? r : y;\n const xid = meta.xAxisID = valueOrDefault(dataset.xAxisID, getFirstScaleId(chart, 'x'));\n const yid = meta.yAxisID = valueOrDefault(dataset.yAxisID, getFirstScaleId(chart, 'y'));\n const rid = meta.rAxisID = valueOrDefault(dataset.rAxisID, getFirstScaleId(chart, 'r'));\n const indexAxis = meta.indexAxis;\n const iid = meta.iAxisID = chooseId(indexAxis, xid, yid, rid);\n const vid = meta.vAxisID = chooseId(indexAxis, yid, xid, rid);\n meta.xScale = this.getScaleForId(xid);\n meta.yScale = this.getScaleForId(yid);\n meta.rScale = this.getScaleForId(rid);\n meta.iScale = this.getScaleForId(iid);\n meta.vScale = this.getScaleForId(vid);\n }\n getDataset() {\n return this.chart.data.datasets[this.index];\n }\n getMeta() {\n return this.chart.getDatasetMeta(this.index);\n }\n getScaleForId(scaleID) {\n return this.chart.scales[scaleID];\n }\n _getOtherScale(scale) {\n const meta = this._cachedMeta;\n return scale === meta.iScale ? meta.vScale : meta.iScale;\n }\n reset() {\n this._update('reset');\n }\n _destroy() {\n const meta = this._cachedMeta;\n if (this._data) {\n unlistenArrayEvents(this._data, this);\n }\n if (meta._stacked) {\n clearStacks(meta);\n }\n }\n _dataCheck() {\n const dataset = this.getDataset();\n const data = dataset.data || (dataset.data = []);\n const _data = this._data;\n if (isObject(data)) {\n this._data = convertObjectDataToArray(data);\n } else if (_data !== data) {\n if (_data) {\n unlistenArrayEvents(_data, this);\n const meta = this._cachedMeta;\n clearStacks(meta);\n meta._parsed = [];\n }\n if (data && Object.isExtensible(data)) {\n listenArrayEvents(data, this);\n }\n this._syncList = [];\n this._data = data;\n }\n }\n addElements() {\n const meta = this._cachedMeta;\n this._dataCheck();\n if (this.datasetElementType) {\n meta.dataset = new this.datasetElementType();\n }\n }\n buildOrUpdateElements(resetNewElements) {\n const meta = this._cachedMeta;\n const dataset = this.getDataset();\n let stackChanged = false;\n this._dataCheck();\n const oldStacked = meta._stacked;\n meta._stacked = isStacked(meta.vScale, meta);\n if (meta.stack !== dataset.stack) {\n stackChanged = true;\n clearStacks(meta);\n meta.stack = dataset.stack;\n }\n this._resyncElements(resetNewElements);\n if (stackChanged || oldStacked !== meta._stacked) {\n updateStacks(this, meta._parsed);\n }\n }\n configure() {\n const config = this.chart.config;\n const scopeKeys = config.datasetScopeKeys(this._type);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys, true);\n this.options = config.createResolver(scopes, this.getContext());\n this._parsing = this.options.parsing;\n this._cachedDataOpts = {};\n }\n parse(start, count) {\n const { _cachedMeta: meta , _data: data } = this;\n const { iScale , _stacked } = meta;\n const iAxis = iScale.axis;\n let sorted = start === 0 && count === data.length ? true : meta._sorted;\n let prev = start > 0 && meta._parsed[start - 1];\n let i, cur, parsed;\n if (this._parsing === false) {\n meta._parsed = data;\n meta._sorted = true;\n parsed = data;\n } else {\n if (isArray(data[start])) {\n parsed = this.parseArrayData(meta, data, start, count);\n } else if (isObject(data[start])) {\n parsed = this.parseObjectData(meta, data, start, count);\n } else {\n parsed = this.parsePrimitiveData(meta, data, start, count);\n }\n const isNotInOrderComparedToPrev = ()=>cur[iAxis] === null || prev && cur[iAxis] < prev[iAxis];\n for(i = 0; i < count; ++i){\n meta._parsed[i + start] = cur = parsed[i];\n if (sorted) {\n if (isNotInOrderComparedToPrev()) {\n sorted = false;\n }\n prev = cur;\n }\n }\n meta._sorted = sorted;\n }\n if (_stacked) {\n updateStacks(this, parsed);\n }\n }\n parsePrimitiveData(meta, data, start, count) {\n const { iScale , vScale } = meta;\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = new Array(count);\n let i, ilen, index;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n parsed[i] = {\n [iAxis]: singleScale || iScale.parse(labels[index], index),\n [vAxis]: vScale.parse(data[index], index)\n };\n }\n return parsed;\n }\n parseArrayData(meta, data, start, count) {\n const { xScale , yScale } = meta;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(item[0], index),\n y: yScale.parse(item[1], index)\n };\n }\n return parsed;\n }\n parseObjectData(meta, data, start, count) {\n const { xScale , yScale } = meta;\n const { xAxisKey ='x' , yAxisKey ='y' } = this._parsing;\n const parsed = new Array(count);\n let i, ilen, index, item;\n for(i = 0, ilen = count; i < ilen; ++i){\n index = i + start;\n item = data[index];\n parsed[i] = {\n x: xScale.parse(resolveObjectKey(item, xAxisKey), index),\n y: yScale.parse(resolveObjectKey(item, yAxisKey), index)\n };\n }\n return parsed;\n }\n getParsed(index) {\n return this._cachedMeta._parsed[index];\n }\n getDataElement(index) {\n return this._cachedMeta.data[index];\n }\n applyStack(scale, parsed, mode) {\n const chart = this.chart;\n const meta = this._cachedMeta;\n const value = parsed[scale.axis];\n const stack = {\n keys: getSortedDatasetIndices(chart, true),\n values: parsed._stacks[scale.axis]._visualValues\n };\n return applyStack(stack, value, meta.index, {\n mode\n });\n }\n updateRangeFromParsed(range, scale, parsed, stack) {\n const parsedValue = parsed[scale.axis];\n let value = parsedValue === null ? NaN : parsedValue;\n const values = stack && parsed._stacks[scale.axis];\n if (stack && values) {\n stack.values = values;\n value = applyStack(stack, parsedValue, this._cachedMeta.index);\n }\n range.min = Math.min(range.min, value);\n range.max = Math.max(range.max, value);\n }\n getMinMax(scale, canStack) {\n const meta = this._cachedMeta;\n const _parsed = meta._parsed;\n const sorted = meta._sorted && scale === meta.iScale;\n const ilen = _parsed.length;\n const otherScale = this._getOtherScale(scale);\n const stack = createStack(canStack, meta, this.chart);\n const range = {\n min: Number.POSITIVE_INFINITY,\n max: Number.NEGATIVE_INFINITY\n };\n const { min: otherMin , max: otherMax } = getUserBounds(otherScale);\n let i, parsed;\n function _skip() {\n parsed = _parsed[i];\n const otherValue = parsed[otherScale.axis];\n return !isNumberFinite(parsed[scale.axis]) || otherMin > otherValue || otherMax < otherValue;\n }\n for(i = 0; i < ilen; ++i){\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n if (sorted) {\n break;\n }\n }\n if (sorted) {\n for(i = ilen - 1; i >= 0; --i){\n if (_skip()) {\n continue;\n }\n this.updateRangeFromParsed(range, scale, parsed, stack);\n break;\n }\n }\n return range;\n }\n getAllParsedValues(scale) {\n const parsed = this._cachedMeta._parsed;\n const values = [];\n let i, ilen, value;\n for(i = 0, ilen = parsed.length; i < ilen; ++i){\n value = parsed[i][scale.axis];\n if (isNumberFinite(value)) {\n values.push(value);\n }\n }\n return values;\n }\n getMaxOverflow() {\n return false;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const parsed = this.getParsed(index);\n return {\n label: iScale ? '' + iScale.getLabelForValue(parsed[iScale.axis]) : '',\n value: vScale ? '' + vScale.getLabelForValue(parsed[vScale.axis]) : ''\n };\n }\n _update(mode) {\n const meta = this._cachedMeta;\n this.update(mode || 'default');\n meta._clip = toClip(valueOrDefault(this.options.clip, defaultClip(meta.xScale, meta.yScale, this.getMaxOverflow())));\n }\n update(mode) {}\n draw() {\n const ctx = this._ctx;\n const chart = this.chart;\n const meta = this._cachedMeta;\n const elements = meta.data || [];\n const area = chart.chartArea;\n const active = [];\n const start = this._drawStart || 0;\n const count = this._drawCount || elements.length - start;\n const drawActiveElementsOnTop = this.options.drawActiveElementsOnTop;\n let i;\n if (meta.dataset) {\n meta.dataset.draw(ctx, area, start, count);\n }\n for(i = start; i < start + count; ++i){\n const element = elements[i];\n if (element.hidden) {\n continue;\n }\n if (element.active && drawActiveElementsOnTop) {\n active.push(element);\n } else {\n element.draw(ctx, area);\n }\n }\n for(i = 0; i < active.length; ++i){\n active[i].draw(ctx, area);\n }\n }\n getStyle(index, active) {\n const mode = active ? 'active' : 'default';\n return index === undefined && this._cachedMeta.dataset ? this.resolveDatasetElementOptions(mode) : this.resolveDataElementOptions(index || 0, mode);\n }\n getContext(index, active, mode) {\n const dataset = this.getDataset();\n let context;\n if (index >= 0 && index < this._cachedMeta.data.length) {\n const element = this._cachedMeta.data[index];\n context = element.$context || (element.$context = createDataContext(this.getContext(), index, element));\n context.parsed = this.getParsed(index);\n context.raw = dataset.data[index];\n context.index = context.dataIndex = index;\n } else {\n context = this.$context || (this.$context = createDatasetContext(this.chart.getContext(), this.index));\n context.dataset = dataset;\n context.index = context.datasetIndex = this.index;\n }\n context.active = !!active;\n context.mode = mode;\n return context;\n }\n resolveDatasetElementOptions(mode) {\n return this._resolveElementOptions(this.datasetElementType.id, mode);\n }\n resolveDataElementOptions(index, mode) {\n return this._resolveElementOptions(this.dataElementType.id, mode, index);\n }\n _resolveElementOptions(elementType, mode = 'default', index) {\n const active = mode === 'active';\n const cache = this._cachedDataOpts;\n const cacheKey = elementType + '-' + mode;\n const cached = cache[cacheKey];\n const sharing = this.enableOptionSharing && defined(index);\n if (cached) {\n return cloneIfNotShared(cached, sharing);\n }\n const config = this.chart.config;\n const scopeKeys = config.datasetElementScopeKeys(this._type, elementType);\n const prefixes = active ? [\n `${elementType}Hover`,\n 'hover',\n elementType,\n ''\n ] : [\n elementType,\n ''\n ];\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n const names = Object.keys(defaults.elements[elementType]);\n const context = ()=>this.getContext(index, active, mode);\n const values = config.resolveNamedOptions(scopes, names, context, prefixes);\n if (values.$shared) {\n values.$shared = sharing;\n cache[cacheKey] = Object.freeze(cloneIfNotShared(values, sharing));\n }\n return values;\n }\n _resolveAnimations(index, transition, active) {\n const chart = this.chart;\n const cache = this._cachedDataOpts;\n const cacheKey = `animation-${transition}`;\n const cached = cache[cacheKey];\n if (cached) {\n return cached;\n }\n let options;\n if (chart.options.animation !== false) {\n const config = this.chart.config;\n const scopeKeys = config.datasetAnimationScopeKeys(this._type, transition);\n const scopes = config.getOptionScopes(this.getDataset(), scopeKeys);\n options = config.createResolver(scopes, this.getContext(index, active, transition));\n }\n const animations = new Animations(chart, options && options.animations);\n if (options && options._cacheable) {\n cache[cacheKey] = Object.freeze(animations);\n }\n return animations;\n }\n getSharedOptions(options) {\n if (!options.$shared) {\n return;\n }\n return this._sharedOptions || (this._sharedOptions = Object.assign({}, options));\n }\n includeOptions(mode, sharedOptions) {\n return !sharedOptions || isDirectUpdateMode(mode) || this.chart._animationsDisabled;\n }\n _getSharedOptions(start, mode) {\n const firstOpts = this.resolveDataElementOptions(start, mode);\n const previouslySharedOptions = this._sharedOptions;\n const sharedOptions = this.getSharedOptions(firstOpts);\n const includeOptions = this.includeOptions(mode, sharedOptions) || sharedOptions !== previouslySharedOptions;\n this.updateSharedOptions(sharedOptions, mode, firstOpts);\n return {\n sharedOptions,\n includeOptions\n };\n }\n updateElement(element, index, properties, mode) {\n if (isDirectUpdateMode(mode)) {\n Object.assign(element, properties);\n } else {\n this._resolveAnimations(index, mode).update(element, properties);\n }\n }\n updateSharedOptions(sharedOptions, mode, newOptions) {\n if (sharedOptions && !isDirectUpdateMode(mode)) {\n this._resolveAnimations(undefined, mode).update(sharedOptions, newOptions);\n }\n }\n _setStyle(element, index, mode, active) {\n element.active = active;\n const options = this.getStyle(index, active);\n this._resolveAnimations(index, mode, active).update(element, {\n options: !active && this.getSharedOptions(options) || options\n });\n }\n removeHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', false);\n }\n setHoverStyle(element, datasetIndex, index) {\n this._setStyle(element, index, 'active', true);\n }\n _removeDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n if (element) {\n this._setStyle(element, undefined, 'active', false);\n }\n }\n _setDatasetHoverStyle() {\n const element = this._cachedMeta.dataset;\n if (element) {\n this._setStyle(element, undefined, 'active', true);\n }\n }\n _resyncElements(resetNewElements) {\n const data = this._data;\n const elements = this._cachedMeta.data;\n for (const [method, arg1, arg2] of this._syncList){\n this[method](arg1, arg2);\n }\n this._syncList = [];\n const numMeta = elements.length;\n const numData = data.length;\n const count = Math.min(numData, numMeta);\n if (count) {\n this.parse(0, count);\n }\n if (numData > numMeta) {\n this._insertElements(numMeta, numData - numMeta, resetNewElements);\n } else if (numData < numMeta) {\n this._removeElements(numData, numMeta - numData);\n }\n }\n _insertElements(start, count, resetNewElements = true) {\n const meta = this._cachedMeta;\n const data = meta.data;\n const end = start + count;\n let i;\n const move = (arr)=>{\n arr.length += count;\n for(i = arr.length - 1; i >= end; i--){\n arr[i] = arr[i - count];\n }\n };\n move(data);\n for(i = start; i < end; ++i){\n data[i] = new this.dataElementType();\n }\n if (this._parsing) {\n move(meta._parsed);\n }\n this.parse(start, count);\n if (resetNewElements) {\n this.updateElements(data, start, count, 'reset');\n }\n }\n updateElements(element, start, count, mode) {}\n _removeElements(start, count) {\n const meta = this._cachedMeta;\n if (this._parsing) {\n const removed = meta._parsed.splice(start, count);\n if (meta._stacked) {\n clearStacks(meta, removed);\n }\n }\n meta.data.splice(start, count);\n }\n _sync(args) {\n if (this._parsing) {\n this._syncList.push(args);\n } else {\n const [method, arg1, arg2] = args;\n this[method](arg1, arg2);\n }\n this.chart._dataChanges.push([\n this.index,\n ...args\n ]);\n }\n _onDataPush() {\n const count = arguments.length;\n this._sync([\n '_insertElements',\n this.getDataset().data.length - count,\n count\n ]);\n }\n _onDataPop() {\n this._sync([\n '_removeElements',\n this._cachedMeta.data.length - 1,\n 1\n ]);\n }\n _onDataShift() {\n this._sync([\n '_removeElements',\n 0,\n 1\n ]);\n }\n _onDataSplice(start, count) {\n if (count) {\n this._sync([\n '_removeElements',\n start,\n count\n ]);\n }\n const newCount = arguments.length - 2;\n if (newCount) {\n this._sync([\n '_insertElements',\n start,\n newCount\n ]);\n }\n }\n _onDataUnshift() {\n this._sync([\n '_insertElements',\n 0,\n arguments.length\n ]);\n }\n}\n\nfunction getAllScaleValues(scale, type) {\n if (!scale._cache.$bar) {\n const visibleMetas = scale.getMatchingVisibleMetas(type);\n let values = [];\n for(let i = 0, ilen = visibleMetas.length; i < ilen; i++){\n values = values.concat(visibleMetas[i].controller.getAllParsedValues(scale));\n }\n scale._cache.$bar = _arrayUnique(values.sort((a, b)=>a - b));\n }\n return scale._cache.$bar;\n}\n function computeMinSampleSize(meta) {\n const scale = meta.iScale;\n const values = getAllScaleValues(scale, meta.type);\n let min = scale._length;\n let i, ilen, curr, prev;\n const updateMinAndPrev = ()=>{\n if (curr === 32767 || curr === -32768) {\n return;\n }\n if (defined(prev)) {\n min = Math.min(min, Math.abs(curr - prev) || min);\n }\n prev = curr;\n };\n for(i = 0, ilen = values.length; i < ilen; ++i){\n curr = scale.getPixelForValue(values[i]);\n updateMinAndPrev();\n }\n prev = undefined;\n for(i = 0, ilen = scale.ticks.length; i < ilen; ++i){\n curr = scale.getPixelForTick(i);\n updateMinAndPrev();\n }\n return min;\n}\n function computeFitCategoryTraits(index, ruler, options, stackCount) {\n const thickness = options.barThickness;\n let size, ratio;\n if (isNullOrUndef(thickness)) {\n size = ruler.min * options.categoryPercentage;\n ratio = options.barPercentage;\n } else {\n size = thickness * stackCount;\n ratio = 1;\n }\n return {\n chunk: size / stackCount,\n ratio,\n start: ruler.pixels[index] - size / 2\n };\n}\n function computeFlexCategoryTraits(index, ruler, options, stackCount) {\n const pixels = ruler.pixels;\n const curr = pixels[index];\n let prev = index > 0 ? pixels[index - 1] : null;\n let next = index < pixels.length - 1 ? pixels[index + 1] : null;\n const percent = options.categoryPercentage;\n if (prev === null) {\n prev = curr - (next === null ? ruler.end - ruler.start : next - curr);\n }\n if (next === null) {\n next = curr + curr - prev;\n }\n const start = curr - (curr - Math.min(prev, next)) / 2 * percent;\n const size = Math.abs(next - prev) / 2 * percent;\n return {\n chunk: size / stackCount,\n ratio: options.barPercentage,\n start\n };\n}\nfunction parseFloatBar(entry, item, vScale, i) {\n const startValue = vScale.parse(entry[0], i);\n const endValue = vScale.parse(entry[1], i);\n const min = Math.min(startValue, endValue);\n const max = Math.max(startValue, endValue);\n let barStart = min;\n let barEnd = max;\n if (Math.abs(min) > Math.abs(max)) {\n barStart = max;\n barEnd = min;\n }\n item[vScale.axis] = barEnd;\n item._custom = {\n barStart,\n barEnd,\n start: startValue,\n end: endValue,\n min,\n max\n };\n}\nfunction parseValue(entry, item, vScale, i) {\n if (isArray(entry)) {\n parseFloatBar(entry, item, vScale, i);\n } else {\n item[vScale.axis] = vScale.parse(entry, i);\n }\n return item;\n}\nfunction parseArrayOrPrimitive(meta, data, start, count) {\n const iScale = meta.iScale;\n const vScale = meta.vScale;\n const labels = iScale.getLabels();\n const singleScale = iScale === vScale;\n const parsed = [];\n let i, ilen, item, entry;\n for(i = start, ilen = start + count; i < ilen; ++i){\n entry = data[i];\n item = {};\n item[iScale.axis] = singleScale || iScale.parse(labels[i], i);\n parsed.push(parseValue(entry, item, vScale, i));\n }\n return parsed;\n}\nfunction isFloatBar(custom) {\n return custom && custom.barStart !== undefined && custom.barEnd !== undefined;\n}\nfunction barSign(size, vScale, actualBase) {\n if (size !== 0) {\n return sign(size);\n }\n return (vScale.isHorizontal() ? 1 : -1) * (vScale.min >= actualBase ? 1 : -1);\n}\nfunction borderProps(properties) {\n let reverse, start, end, top, bottom;\n if (properties.horizontal) {\n reverse = properties.base > properties.x;\n start = 'left';\n end = 'right';\n } else {\n reverse = properties.base < properties.y;\n start = 'bottom';\n end = 'top';\n }\n if (reverse) {\n top = 'end';\n bottom = 'start';\n } else {\n top = 'start';\n bottom = 'end';\n }\n return {\n start,\n end,\n reverse,\n top,\n bottom\n };\n}\nfunction setBorderSkipped(properties, options, stack, index) {\n let edge = options.borderSkipped;\n const res = {};\n if (!edge) {\n properties.borderSkipped = res;\n return;\n }\n if (edge === true) {\n properties.borderSkipped = {\n top: true,\n right: true,\n bottom: true,\n left: true\n };\n return;\n }\n const { start , end , reverse , top , bottom } = borderProps(properties);\n if (edge === 'middle' && stack) {\n properties.enableBorderRadius = true;\n if ((stack._top || 0) === index) {\n edge = top;\n } else if ((stack._bottom || 0) === index) {\n edge = bottom;\n } else {\n res[parseEdge(bottom, start, end, reverse)] = true;\n edge = top;\n }\n }\n res[parseEdge(edge, start, end, reverse)] = true;\n properties.borderSkipped = res;\n}\nfunction parseEdge(edge, a, b, reverse) {\n if (reverse) {\n edge = swap(edge, a, b);\n edge = startEnd(edge, b, a);\n } else {\n edge = startEnd(edge, a, b);\n }\n return edge;\n}\nfunction swap(orig, v1, v2) {\n return orig === v1 ? v2 : orig === v2 ? v1 : orig;\n}\nfunction startEnd(v, start, end) {\n return v === 'start' ? start : v === 'end' ? end : v;\n}\nfunction setInflateAmount(properties, { inflateAmount }, ratio) {\n properties.inflateAmount = inflateAmount === 'auto' ? ratio === 1 ? 0.33 : 0 : inflateAmount;\n}\nclass BarController extends DatasetController {\n static id = 'bar';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'bar',\n categoryPercentage: 0.8,\n barPercentage: 0.9,\n grouped: true,\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'base',\n 'width',\n 'height'\n ]\n }\n }\n };\n static overrides = {\n scales: {\n _index_: {\n type: 'category',\n offset: true,\n grid: {\n offset: true\n }\n },\n _value_: {\n type: 'linear',\n beginAtZero: true\n }\n }\n };\n parsePrimitiveData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n parseArrayData(meta, data, start, count) {\n return parseArrayOrPrimitive(meta, data, start, count);\n }\n parseObjectData(meta, data, start, count) {\n const { iScale , vScale } = meta;\n const { xAxisKey ='x' , yAxisKey ='y' } = this._parsing;\n const iAxisKey = iScale.axis === 'x' ? xAxisKey : yAxisKey;\n const vAxisKey = vScale.axis === 'x' ? xAxisKey : yAxisKey;\n const parsed = [];\n let i, ilen, item, obj;\n for(i = start, ilen = start + count; i < ilen; ++i){\n obj = data[i];\n item = {};\n item[iScale.axis] = iScale.parse(resolveObjectKey(obj, iAxisKey), i);\n parsed.push(parseValue(resolveObjectKey(obj, vAxisKey), item, vScale, i));\n }\n return parsed;\n }\n updateRangeFromParsed(range, scale, parsed, stack) {\n super.updateRangeFromParsed(range, scale, parsed, stack);\n const custom = parsed._custom;\n if (custom && scale === this._cachedMeta.vScale) {\n range.min = Math.min(range.min, custom.min);\n range.max = Math.max(range.max, custom.max);\n }\n }\n getMaxOverflow() {\n return 0;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const { iScale , vScale } = meta;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const value = isFloatBar(custom) ? '[' + custom.start + ', ' + custom.end + ']' : '' + vScale.getLabelForValue(parsed[vScale.axis]);\n return {\n label: '' + iScale.getLabelForValue(parsed[iScale.axis]),\n value\n };\n }\n initialize() {\n this.enableOptionSharing = true;\n super.initialize();\n const meta = this._cachedMeta;\n meta.stack = this.getDataset().stack;\n }\n update(mode) {\n const meta = this._cachedMeta;\n this.updateElements(meta.data, 0, meta.data.length, mode);\n }\n updateElements(bars, start, count, mode) {\n const reset = mode === 'reset';\n const { index , _cachedMeta: { vScale } } = this;\n const base = vScale.getBasePixel();\n const horizontal = vScale.isHorizontal();\n const ruler = this._getRuler();\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n for(let i = start; i < start + count; i++){\n const parsed = this.getParsed(i);\n const vpixels = reset || isNullOrUndef(parsed[vScale.axis]) ? {\n base,\n head: base\n } : this._calculateBarValuePixels(i);\n const ipixels = this._calculateBarIndexPixels(i, ruler);\n const stack = (parsed._stacks || {})[vScale.axis];\n const properties = {\n horizontal,\n base: vpixels.base,\n enableBorderRadius: !stack || isFloatBar(parsed._custom) || index === stack._top || index === stack._bottom,\n x: horizontal ? vpixels.head : ipixels.center,\n y: horizontal ? ipixels.center : vpixels.head,\n height: horizontal ? ipixels.size : Math.abs(vpixels.size),\n width: horizontal ? Math.abs(vpixels.size) : ipixels.size\n };\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, bars[i].active ? 'active' : mode);\n }\n const options = properties.options || bars[i].options;\n setBorderSkipped(properties, options, stack, index);\n setInflateAmount(properties, options, ruler.ratio);\n this.updateElement(bars[i], i, properties, mode);\n }\n }\n _getStacks(last, dataIndex) {\n const { iScale } = this._cachedMeta;\n const metasets = iScale.getMatchingVisibleMetas(this._type).filter((meta)=>meta.controller.options.grouped);\n const stacked = iScale.options.stacked;\n const stacks = [];\n const skipNull = (meta)=>{\n const parsed = meta.controller.getParsed(dataIndex);\n const val = parsed && parsed[meta.vScale.axis];\n if (isNullOrUndef(val) || isNaN(val)) {\n return true;\n }\n };\n for (const meta of metasets){\n if (dataIndex !== undefined && skipNull(meta)) {\n continue;\n }\n if (stacked === false || stacks.indexOf(meta.stack) === -1 || stacked === undefined && meta.stack === undefined) {\n stacks.push(meta.stack);\n }\n if (meta.index === last) {\n break;\n }\n }\n if (!stacks.length) {\n stacks.push(undefined);\n }\n return stacks;\n }\n _getStackCount(index) {\n return this._getStacks(undefined, index).length;\n }\n _getStackIndex(datasetIndex, name, dataIndex) {\n const stacks = this._getStacks(datasetIndex, dataIndex);\n const index = name !== undefined ? stacks.indexOf(name) : -1;\n return index === -1 ? stacks.length - 1 : index;\n }\n _getRuler() {\n const opts = this.options;\n const meta = this._cachedMeta;\n const iScale = meta.iScale;\n const pixels = [];\n let i, ilen;\n for(i = 0, ilen = meta.data.length; i < ilen; ++i){\n pixels.push(iScale.getPixelForValue(this.getParsed(i)[iScale.axis], i));\n }\n const barThickness = opts.barThickness;\n const min = barThickness || computeMinSampleSize(meta);\n return {\n min,\n pixels,\n start: iScale._startPixel,\n end: iScale._endPixel,\n stackCount: this._getStackCount(),\n scale: iScale,\n grouped: opts.grouped,\n ratio: barThickness ? 1 : opts.categoryPercentage * opts.barPercentage\n };\n }\n _calculateBarValuePixels(index) {\n const { _cachedMeta: { vScale , _stacked , index: datasetIndex } , options: { base: baseValue , minBarLength } } = this;\n const actualBase = baseValue || 0;\n const parsed = this.getParsed(index);\n const custom = parsed._custom;\n const floating = isFloatBar(custom);\n let value = parsed[vScale.axis];\n let start = 0;\n let length = _stacked ? this.applyStack(vScale, parsed, _stacked) : value;\n let head, size;\n if (length !== value) {\n start = length - value;\n length = value;\n }\n if (floating) {\n value = custom.barStart;\n length = custom.barEnd - custom.barStart;\n if (value !== 0 && sign(value) !== sign(custom.barEnd)) {\n start = 0;\n }\n start += value;\n }\n const startValue = !isNullOrUndef(baseValue) && !floating ? baseValue : start;\n let base = vScale.getPixelForValue(startValue);\n if (this.chart.getDataVisibility(index)) {\n head = vScale.getPixelForValue(start + length);\n } else {\n head = base;\n }\n size = head - base;\n if (Math.abs(size) < minBarLength) {\n size = barSign(size, vScale, actualBase) * minBarLength;\n if (value === actualBase) {\n base -= size / 2;\n }\n const startPixel = vScale.getPixelForDecimal(0);\n const endPixel = vScale.getPixelForDecimal(1);\n const min = Math.min(startPixel, endPixel);\n const max = Math.max(startPixel, endPixel);\n base = Math.max(Math.min(base, max), min);\n head = base + size;\n if (_stacked && !floating) {\n parsed._stacks[vScale.axis]._visualValues[datasetIndex] = vScale.getValueForPixel(head) - vScale.getValueForPixel(base);\n }\n }\n if (base === vScale.getPixelForValue(actualBase)) {\n const halfGrid = sign(size) * vScale.getLineWidthForValue(actualBase) / 2;\n base += halfGrid;\n size -= halfGrid;\n }\n return {\n size,\n base,\n head,\n center: head + size / 2\n };\n }\n _calculateBarIndexPixels(index, ruler) {\n const scale = ruler.scale;\n const options = this.options;\n const skipNull = options.skipNull;\n const maxBarThickness = valueOrDefault(options.maxBarThickness, Infinity);\n let center, size;\n if (ruler.grouped) {\n const stackCount = skipNull ? this._getStackCount(index) : ruler.stackCount;\n const range = options.barThickness === 'flex' ? computeFlexCategoryTraits(index, ruler, options, stackCount) : computeFitCategoryTraits(index, ruler, options, stackCount);\n const stackIndex = this._getStackIndex(this.index, this._cachedMeta.stack, skipNull ? index : undefined);\n center = range.start + range.chunk * stackIndex + range.chunk / 2;\n size = Math.min(maxBarThickness, range.chunk * range.ratio);\n } else {\n center = scale.getPixelForValue(this.getParsed(index)[scale.axis], index);\n size = Math.min(maxBarThickness, ruler.min * ruler.ratio);\n }\n return {\n base: center - size / 2,\n head: center + size / 2,\n center,\n size\n };\n }\n draw() {\n const meta = this._cachedMeta;\n const vScale = meta.vScale;\n const rects = meta.data;\n const ilen = rects.length;\n let i = 0;\n for(; i < ilen; ++i){\n if (this.getParsed(i)[vScale.axis] !== null) {\n rects[i].draw(this._ctx);\n }\n }\n }\n}\n\nclass BubbleController extends DatasetController {\n static id = 'bubble';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'point',\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'x',\n 'y',\n 'borderWidth',\n 'radius'\n ]\n }\n }\n };\n static overrides = {\n scales: {\n x: {\n type: 'linear'\n },\n y: {\n type: 'linear'\n }\n }\n };\n initialize() {\n this.enableOptionSharing = true;\n super.initialize();\n }\n parsePrimitiveData(meta, data, start, count) {\n const parsed = super.parsePrimitiveData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n parsed[i]._custom = this.resolveDataElementOptions(i + start).radius;\n }\n return parsed;\n }\n parseArrayData(meta, data, start, count) {\n const parsed = super.parseArrayData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item[2], this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n parseObjectData(meta, data, start, count) {\n const parsed = super.parseObjectData(meta, data, start, count);\n for(let i = 0; i < parsed.length; i++){\n const item = data[start + i];\n parsed[i]._custom = valueOrDefault(item && item.r && +item.r, this.resolveDataElementOptions(i + start).radius);\n }\n return parsed;\n }\n getMaxOverflow() {\n const data = this._cachedMeta.data;\n let max = 0;\n for(let i = data.length - 1; i >= 0; --i){\n max = Math.max(max, data[i].size(this.resolveDataElementOptions(i)) / 2);\n }\n return max > 0 && max;\n }\n getLabelAndValue(index) {\n const meta = this._cachedMeta;\n const labels = this.chart.data.labels || [];\n const { xScale , yScale } = meta;\n const parsed = this.getParsed(index);\n const x = xScale.getLabelForValue(parsed.x);\n const y = yScale.getLabelForValue(parsed.y);\n const r = parsed._custom;\n return {\n label: labels[index] || '',\n value: '(' + x + ', ' + y + (r ? ', ' + r : '') + ')'\n };\n }\n update(mode) {\n const points = this._cachedMeta.data;\n this.updateElements(points, 0, points.length, mode);\n }\n updateElements(points, start, count, mode) {\n const reset = mode === 'reset';\n const { iScale , vScale } = this._cachedMeta;\n const { sharedOptions , includeOptions } = this._getSharedOptions(start, mode);\n const iAxis = iScale.axis;\n const vAxis = vScale.axis;\n for(let i = start; i < start + count; i++){\n const point = points[i];\n const parsed = !reset && this.getParsed(i);\n const properties = {};\n const iPixel = properties[iAxis] = reset ? iScale.getPixelForDecimal(0.5) : iScale.getPixelForValue(parsed[iAxis]);\n const vPixel = properties[vAxis] = reset ? vScale.getBasePixel() : vScale.getPixelForValue(parsed[vAxis]);\n properties.skip = isNaN(iPixel) || isNaN(vPixel);\n if (includeOptions) {\n properties.options = sharedOptions || this.resolveDataElementOptions(i, point.active ? 'active' : mode);\n if (reset) {\n properties.options.radius = 0;\n }\n }\n this.updateElement(point, i, properties, mode);\n }\n }\n resolveDataElementOptions(index, mode) {\n const parsed = this.getParsed(index);\n let values = super.resolveDataElementOptions(index, mode);\n if (values.$shared) {\n values = Object.assign({}, values, {\n $shared: false\n });\n }\n const radius = values.radius;\n if (mode !== 'active') {\n values.radius = 0;\n }\n values.radius += valueOrDefault(parsed && parsed._custom, radius);\n return values;\n }\n}\n\nfunction getRatioAndOffset(rotation, circumference, cutout) {\n let ratioX = 1;\n let ratioY = 1;\n let offsetX = 0;\n let offsetY = 0;\n if (circumference < TAU) {\n const startAngle = rotation;\n const endAngle = startAngle + circumference;\n const startX = Math.cos(startAngle);\n const startY = Math.sin(startAngle);\n const endX = Math.cos(endAngle);\n const endY = Math.sin(endAngle);\n const calcMax = (angle, a, b)=>_angleBetween(angle, startAngle, endAngle, true) ? 1 : Math.max(a, a * cutout, b, b * cutout);\n const calcMin = (angle, a, b)=>_angleBetween(angle, startAngle, endAngle, true) ? -1 : Math.min(a, a * cutout, b, b * cutout);\n const maxX = calcMax(0, startX, endX);\n const maxY = calcMax(HALF_PI, startY, endY);\n const minX = calcMin(PI, startX, endX);\n const minY = calcMin(PI + HALF_PI, startY, endY);\n ratioX = (maxX - minX) / 2;\n ratioY = (maxY - minY) / 2;\n offsetX = -(maxX + minX) / 2;\n offsetY = -(maxY + minY) / 2;\n }\n return {\n ratioX,\n ratioY,\n offsetX,\n offsetY\n };\n}\nclass DoughnutController extends DatasetController {\n static id = 'doughnut';\n static defaults = {\n datasetElementType: false,\n dataElementType: 'arc',\n animation: {\n animateRotate: true,\n animateScale: false\n },\n animations: {\n numbers: {\n type: 'number',\n properties: [\n 'circumference',\n 'endAngle',\n 'innerRadius',\n 'outerRadius',\n 'startAngle',\n 'x',\n 'y',\n 'offset',\n 'borderWidth',\n 'spacing'\n ]\n }\n },\n cutout: '50%',\n rotation: 0,\n circumference: 360,\n radius: '100%',\n spacing: 0,\n indexAxis: 'r'\n };\n static descriptors = {\n _scriptable: (name)=>name !== 'spacing',\n _indexable: (name)=>name !== 'spacing' && !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](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 node.addEventListener(type, listener, eventListenerOptions);\n}\nfunction removeListener(chart, type, listener) {\n chart.canvas.removeEventListener(type, listener, eventListenerOptions);\n}\nfunction fromNativeEvent(event, chart) {\n const type = EVENT_TYPES[event.type] || event.type;\n const { x , y } = getRelativePosition(event, chart);\n return {\n type,\n chart,\n native: event,\n x: x !== undefined ? x : null,\n y: y !== undefined ? y : null\n };\n}\nfunction nodeListContains(nodeList, canvas) {\n for (const node of nodeList){\n if (node === canvas || node.contains(canvas)) {\n return true;\n }\n }\n}\nfunction createAttachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver((entries)=>{\n let trigger = false;\n for (const entry of entries){\n trigger = trigger || nodeListContains(entry.addedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.removedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {\n childList: true,\n subtree: true\n });\n return observer;\n}\nfunction createDetachObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const observer = new MutationObserver((entries)=>{\n let trigger = false;\n for (const entry of entries){\n trigger = trigger || nodeListContains(entry.removedNodes, canvas);\n trigger = trigger && !nodeListContains(entry.addedNodes, canvas);\n }\n if (trigger) {\n listener();\n }\n });\n observer.observe(document, {\n childList: true,\n subtree: true\n });\n return observer;\n}\nconst drpListeningCharts = new Map();\nlet oldDevicePixelRatio = 0;\nfunction onWindowResize() {\n const dpr = window.devicePixelRatio;\n if (dpr === oldDevicePixelRatio) {\n return;\n }\n oldDevicePixelRatio = dpr;\n drpListeningCharts.forEach((resize, chart)=>{\n if (chart.currentDevicePixelRatio !== dpr) {\n resize();\n }\n });\n}\nfunction listenDevicePixelRatioChanges(chart, resize) {\n if (!drpListeningCharts.size) {\n window.addEventListener('resize', onWindowResize);\n }\n drpListeningCharts.set(chart, resize);\n}\nfunction unlistenDevicePixelRatioChanges(chart) {\n drpListeningCharts.delete(chart);\n if (!drpListeningCharts.size) {\n window.removeEventListener('resize', onWindowResize);\n }\n}\nfunction createResizeObserver(chart, type, listener) {\n const canvas = chart.canvas;\n const container = canvas && _getParentNode(canvas);\n if (!container) {\n return;\n }\n const resize = throttled((width, height)=>{\n const w = container.clientWidth;\n listener(width, height);\n if (w < container.clientWidth) {\n listener();\n }\n }, window);\n const observer = new ResizeObserver((entries)=>{\n const entry = entries[0];\n const width = entry.contentRect.width;\n const height = entry.contentRect.height;\n if (width === 0 && height === 0) {\n return;\n }\n resize(width, height);\n });\n observer.observe(container);\n listenDevicePixelRatioChanges(chart, resize);\n return observer;\n}\nfunction releaseObserver(chart, type, observer) {\n if (observer) {\n observer.disconnect();\n }\n if (type === 'resize') {\n unlistenDevicePixelRatioChanges(chart);\n }\n}\nfunction createProxyAndListen(chart, type, listener) {\n const canvas = chart.canvas;\n const proxy = throttled((event)=>{\n if (chart.ctx !== null) {\n listener(fromNativeEvent(event, chart));\n }\n }, chart);\n addListener(canvas, type, proxy);\n return proxy;\n}\n class DomPlatform extends BasePlatform {\n acquireContext(canvas, aspectRatio) {\n const context = canvas && canvas.getContext && canvas.getContext('2d');\n if (context && context.canvas === canvas) {\n initCanvas(canvas, aspectRatio);\n return context;\n }\n return null;\n }\n releaseContext(context) {\n const canvas = context.canvas;\n if (!canvas[EXPANDO_KEY]) {\n return false;\n }\n const initial = canvas[EXPANDO_KEY].initial;\n [\n 'height',\n 'width'\n ].forEach((prop)=>{\n const value = initial[prop];\n if (isNullOrUndef(value)) {\n canvas.removeAttribute(prop);\n } else {\n canvas.setAttribute(prop, value);\n }\n });\n const style = initial.style || {};\n Object.keys(style).forEach((key)=>{\n canvas.style[key] = style[key];\n });\n canvas.width = canvas.width;\n delete canvas[EXPANDO_KEY];\n return true;\n }\n addEventListener(chart, type, listener) {\n this.removeEventListener(chart, type);\n const proxies = chart.$proxies || (chart.$proxies = {});\n const handlers = {\n attach: createAttachObserver,\n detach: createDetachObserver,\n resize: createResizeObserver\n };\n const handler = handlers[type] || createProxyAndListen;\n proxies[type] = handler(chart, type, listener);\n }\n removeEventListener(chart, type) {\n const proxies = chart.$proxies || (chart.$proxies = {});\n const proxy = proxies[type];\n if (!proxy) {\n return;\n }\n const handlers = {\n attach: releaseObserver,\n detach: releaseObserver,\n resize: releaseObserver\n };\n const handler = handlers[type] || removeListener;\n handler(chart, type, proxy);\n proxies[type] = undefined;\n }\n getDevicePixelRatio() {\n return window.devicePixelRatio;\n }\n getMaximumSize(canvas, width, height, aspectRatio) {\n return getMaximumSize(canvas, width, height, aspectRatio);\n }\n isAttached(canvas) {\n const container = _getParentNode(canvas);\n return !!(container && container.isConnected);\n }\n}\n\nfunction _detectPlatform(canvas) {\n if (!_isDomSupported() || typeof OffscreenCanvas !== 'undefined' && canvas instanceof OffscreenCanvas) {\n return BasicPlatform;\n }\n return DomPlatform;\n}\n\nclass Element {\n static defaults = {};\n static defaultRoutes = undefined;\n 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 }\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).reduce((acc, key)=>acc || isFunction(value[key]), false);\nfunction needContext(proxy, names) {\n const { isScriptable , isIndexable } = _descriptors(proxy);\n for (const prop of names){\n const scriptable = isScriptable(prop);\n const indexable = isIndexable(prop);\n const value = (indexable || scriptable) && proxy[prop];\n if (scriptable && (isFunction(value) || hasFunction(value)) || indexable && isArray(value)) {\n return true;\n }\n }\n return false;\n}\n\nvar version = \"4.4.0\";\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._resize(width, height);\n this._resizeBeforeDraw = null;\n }\n this.clear();\n if (this.width <= 0 || this.height <= 0) {\n return;\n }\n if (this.notifyPlugins('beforeDraw', {\n cancelable: true\n }) === false) {\n return;\n }\n const layers = this._layers;\n for(i = 0; i < layers.length && layers[i].z <= 0; ++i){\n layers[i].draw(this.chartArea);\n }\n this._drawDatasets();\n for(; i < layers.length; ++i){\n layers[i].draw(this.chartArea);\n }\n this.notifyPlugins('afterDraw');\n }\n _getSortedDatasetMetas(filterVisible) {\n const metasets = this._sortedMetasets;\n const result = [];\n let i, ilen;\n for(i = 0, ilen = metasets.length; i < ilen; ++i){\n const meta = metasets[i];\n if (!filterVisible || meta.visible) {\n result.push(meta);\n }\n }\n return result;\n }\n getSortedVisibleDatasetMetas() {\n return this._getSortedDatasetMetas(true);\n }\n _drawDatasets() {\n if (this.notifyPlugins('beforeDatasetsDraw', {\n cancelable: true\n }) === false) {\n return;\n }\n const metasets = this.getSortedVisibleDatasetMetas();\n for(let i = metasets.length - 1; i >= 0; --i){\n this._drawDataset(metasets[i]);\n }\n this.notifyPlugins('afterDatasetsDraw');\n }\n _drawDataset(meta) {\n const ctx = this.ctx;\n const clip = meta._clip;\n const useClip = !clip.disabled;\n const area = getDatasetArea(meta, this.chartArea);\n const args = {\n meta,\n index: meta.index,\n cancelable: true\n };\n if (this.notifyPlugins('beforeDatasetDraw', args) === false) {\n return;\n }\n if (useClip) {\n clipArea(ctx, {\n left: clip.left === false ? 0 : area.left - clip.left,\n right: clip.right === false ? this.width : area.right + clip.right,\n top: clip.top === false ? 0 : area.top - clip.top,\n bottom: clip.bottom === false ? this.height : area.bottom + clip.bottom\n });\n }\n meta.controller.draw();\n if (useClip) {\n unclipArea(ctx);\n }\n args.cancelable = false;\n this.notifyPlugins('afterDatasetDraw', args);\n }\n isPointInArea(point) {\n return _isPointInArea(point, this.chartArea, this._minPadding);\n }\n getElementsAtEventForMode(e, mode, options, useFinalPosition) {\n const method = Interaction.modes[mode];\n if (typeof method === 'function') {\n return method(this, e, options, useFinalPosition);\n }\n return [];\n }\n getDatasetMeta(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n const metasets = this._metasets;\n let meta = metasets.filter((x)=>x && x._dataset === dataset).pop();\n if (!meta) {\n meta = {\n type: null,\n data: [],\n dataset: null,\n controller: null,\n hidden: null,\n xAxisID: null,\n yAxisID: null,\n order: dataset && dataset.order || 0,\n index: datasetIndex,\n _dataset: dataset,\n _parsed: [],\n _sorted: false\n };\n metasets.push(meta);\n }\n return meta;\n }\n getContext() {\n return this.$context || (this.$context = createContext(null, {\n chart: this,\n type: 'chart'\n }));\n }\n getVisibleDatasetCount() {\n return this.getSortedVisibleDatasetMetas().length;\n }\n isDatasetVisible(datasetIndex) {\n const dataset = this.data.datasets[datasetIndex];\n if (!dataset) {\n return false;\n }\n const meta = this.getDatasetMeta(datasetIndex);\n return typeof meta.hidden === 'boolean' ? !meta.hidden : !dataset.hidden;\n }\n setDatasetVisibility(datasetIndex, visible) {\n const meta = this.getDatasetMeta(datasetIndex);\n meta.hidden = !visible;\n }\n toggleDataVisibility(index) {\n this._hiddenIndices[index] = !this._hiddenIndices[index];\n }\n getDataVisibility(index) {\n return !this._hiddenIndices[index];\n }\n _updateVisibility(datasetIndex, dataIndex, visible) {\n const mode = visible ? 'show' : 'hide';\n const meta = this.getDatasetMeta(datasetIndex);\n const anims = meta.controller._resolveAnimations(undefined, mode);\n if (defined(dataIndex)) {\n meta.data[dataIndex].hidden = !visible;\n this.update();\n } else {\n this.setDatasetVisibility(datasetIndex, visible);\n anims.update(meta, {\n visible\n });\n this.update((ctx)=>ctx.datasetIndex === datasetIndex ? mode : undefined);\n }\n }\n hide(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, false);\n }\n show(datasetIndex, dataIndex) {\n this._updateVisibility(datasetIndex, dataIndex, true);\n }\n _destroyDatasetMeta(datasetIndex) {\n const meta = this._metasets[datasetIndex];\n if (meta && meta.controller) {\n meta.controller._destroy();\n }\n delete this._metasets[datasetIndex];\n }\n _stop() {\n let i, ilen;\n this.stop();\n animator.remove(this);\n for(i = 0, ilen = this.data.datasets.length; i < ilen; ++i){\n this._destroyDatasetMeta(i);\n }\n }\n destroy() {\n this.notifyPlugins('beforeDestroy');\n const { canvas , ctx } = this;\n this._stop();\n this.config.clearCache();\n if (canvas) {\n this.unbindEvents();\n clearCanvas(canvas, ctx);\n this.platform.releaseContext(ctx);\n this.canvas = null;\n this.ctx = null;\n }\n delete instances[this.id];\n this.notifyPlugins('afterDestroy');\n }\n toBase64Image(...args) {\n return this.canvas.toDataURL(...args);\n }\n bindEvents() {\n this.bindUserEvents();\n if (this.options.responsive) {\n this.bindResponsiveEvents();\n } else {\n this.attached = true;\n }\n }\n bindUserEvents() {\n const listeners = this._listeners;\n const platform = this.platform;\n const _add = (type, listener)=>{\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n const listener = (e, x, y)=>{\n e.offsetX = x;\n e.offsetY = y;\n this._eventHandler(e);\n };\n each(this.options.events, (type)=>_add(type, listener));\n }\n bindResponsiveEvents() {\n if (!this._responsiveListeners) {\n this._responsiveListeners = {};\n }\n const listeners = this._responsiveListeners;\n const platform = this.platform;\n const _add = (type, listener)=>{\n platform.addEventListener(this, type, listener);\n listeners[type] = listener;\n };\n const _remove = (type, listener)=>{\n if (listeners[type]) {\n platform.removeEventListener(this, type, listener);\n delete listeners[type];\n }\n };\n const listener = (width, height)=>{\n if (this.canvas) {\n this.resize(width, height);\n }\n };\n let detached;\n const attached = ()=>{\n _remove('attach', attached);\n this.attached = true;\n this.resize();\n _add('resize', listener);\n _add('detach', detached);\n };\n detached = ()=>{\n this.attached = false;\n _remove('resize', listener);\n this._stop();\n this._resize(0, 0);\n _add('attach', attached);\n };\n if (platform.isAttached(this.canvas)) {\n attached();\n } else {\n detached();\n }\n }\n unbindEvents() {\n each(this._listeners, (listener, type)=>{\n this.platform.removeEventListener(this, type, listener);\n });\n this._listeners = {};\n each(this._responsiveListeners, (listener, type)=>{\n this.platform.removeEventListener(this, type, listener);\n });\n this._responsiveListeners = undefined;\n }\n updateHoverStyle(items, mode, enabled) {\n const prefix = enabled ? 'set' : 'remove';\n let meta, item, i, ilen;\n if (mode === 'dataset') {\n meta = this.getDatasetMeta(items[0].datasetIndex);\n meta.controller['_' + prefix + 'DatasetHoverStyle']();\n }\n for(i = 0, ilen = items.length; i < ilen; ++i){\n item = items[i];\n const controller = item && this.getDatasetMeta(item.datasetIndex).controller;\n if (controller) {\n controller[prefix + 'HoverStyle'](item.element, item.datasetIndex, item.index);\n }\n }\n }\n getActiveElements() {\n return this._active || [];\n }\n setActiveElements(activeElements) {\n const lastActive = this._active || [];\n const active = activeElements.map(({ datasetIndex , index })=>{\n const meta = this.getDatasetMeta(datasetIndex);\n if (!meta) {\n throw new Error('No dataset found at index ' + datasetIndex);\n }\n return {\n datasetIndex,\n element: meta.data[index],\n index\n };\n });\n const changed = !_elementsEqual(active, lastActive);\n if (changed) {\n this._active = active;\n this._lastEvent = null;\n this._updateHoverStyles(active, lastActive);\n }\n }\n notifyPlugins(hook, args, filter) {\n return this._plugins.notify(this, hook, args, filter);\n }\n isPluginEnabled(pluginId) {\n return this._plugins._cache.filter((p)=>p.plugin.id === pluginId).length === 1;\n }\n _updateHoverStyles(active, lastActive, replay) {\n const hoverOptions = this.options.hover;\n const diff = (a, b)=>a.filter((x)=>!b.some((y)=>x.datasetIndex === y.datasetIndex && x.index === y.index));\n const deactivated = diff(lastActive, active);\n const activated = replay ? active : diff(active, lastActive);\n if (deactivated.length) {\n this.updateHoverStyle(deactivated, hoverOptions.mode, false);\n }\n if (activated.length && hoverOptions.mode) {\n this.updateHoverStyle(activated, hoverOptions.mode, true);\n }\n }\n _eventHandler(e, replay) {\n const args = {\n event: e,\n replay,\n cancelable: true,\n inChartArea: this.isPointInArea(e)\n };\n const eventFilter = (plugin)=>(plugin.options.events || this.options.events).includes(e.native.type);\n if (this.notifyPlugins('beforeEvent', args, eventFilter) === false) {\n return;\n }\n const changed = this._handleEvent(e, replay, args.inChartArea);\n args.cancelable = false;\n this.notifyPlugins('afterEvent', args, eventFilter);\n if (changed || args.changed) {\n this.render();\n }\n return this;\n }\n _handleEvent(e, replay, inChartArea) {\n const { _active: lastActive = [] , options } = this;\n const useFinalPosition = replay;\n const active = this._getActiveElements(e, lastActive, inChartArea, useFinalPosition);\n const isClick = _isClickEvent(e);\n const lastEvent = determineLastEvent(e, this._lastEvent, inChartArea, isClick);\n if (inChartArea) {\n this._lastEvent = null;\n callback(options.onHover, [\n e,\n active,\n this\n ], this);\n if (isClick) {\n callback(options.onClick, [\n e,\n active,\n this\n ], this);\n }\n }\n const changed = !_elementsEqual(active, lastActive);\n if (changed || replay) {\n this._active = active;\n this._updateHoverStyles(active, lastActive, replay);\n }\n this._lastEvent = lastEvent;\n return changed;\n }\n _getActiveElements(e, lastActive, inChartArea, useFinalPosition) {\n if (e.type === 'mouseout') {\n return [];\n }\n if (!inChartArea) {\n return lastActive;\n }\n const hoverOptions = this.options.hover;\n return this.getElementsAtEventForMode(e, hoverOptions.mode, hoverOptions, useFinalPosition);\n }\n}\nfunction invalidatePlugins() {\n return each(Chart.instances, (chart)=>chart._plugins.invalidate());\n}\n\nfunction clipArc(ctx, element, endAngle) {\n const { startAngle , pixelMargin , x , y , outerRadius , innerRadius } = element;\n let angleMargin = pixelMargin / outerRadius;\n // Draw an inner border by clipping the arc and drawing a double-width border\n // Enlarge the clipping arc by 0.33 pixels to eliminate glitches between borders\n ctx.beginPath();\n ctx.arc(x, y, outerRadius, startAngle - angleMargin, endAngle + angleMargin);\n if (innerRadius > pixelMargin) {\n angleMargin = pixelMargin / innerRadius;\n ctx.arc(x, y, innerRadius, endAngle + angleMargin, startAngle - angleMargin, true);\n } else {\n ctx.arc(x, y, pixelMargin, endAngle + HALF_PI, startAngle - HALF_PI);\n }\n ctx.closePath();\n ctx.clip();\n}\nfunction toRadiusCorners(value) {\n return _readValueToProps(value, [\n 'outerStart',\n 'outerEnd',\n 'innerStart',\n 'innerEnd'\n ]);\n}\n/**\n * Parse border radius from the provided options\n */ function parseBorderRadius$1(arc, innerRadius, outerRadius, angleDelta) {\n const o = toRadiusCorners(arc.options.borderRadius);\n const halfThickness = (outerRadius - innerRadius) / 2;\n const innerLimit = Math.min(halfThickness, angleDelta * innerRadius / 2);\n // Outer limits are complicated. We want to compute the available angular distance at\n // a radius of outerRadius - borderRadius because for small angular distances, this term limits.\n // We compute at r = outerRadius - borderRadius because this circle defines the center of the border corners.\n //\n // If the borderRadius is large, that value can become negative.\n // This causes the outer borders to lose their radius entirely, which is rather unexpected. To solve that, if borderRadius > outerRadius\n // we know that the thickness term will dominate and compute the limits at that point\n const computeOuterLimit = (val)=>{\n const outerArcLimit = (outerRadius - Math.min(halfThickness, val)) * angleDelta / 2;\n return _limitValue(val, 0, Math.min(halfThickness, outerArcLimit));\n };\n return {\n outerStart: computeOuterLimit(o.outerStart),\n outerEnd: computeOuterLimit(o.outerEnd),\n innerStart: _limitValue(o.innerStart, 0, innerLimit),\n innerEnd: _limitValue(o.innerEnd, 0, innerLimit)\n };\n}\n/**\n * Convert (r, 𝜃) to (x, y)\n */ function rThetaToXY(r, theta, x, y) {\n return {\n x: x + r * Math.cos(theta),\n y: y + r * Math.sin(theta)\n };\n}\n/**\n * Path the arc, respecting border radius by separating into left and right halves.\n *\n * Start End\n *\n * 1--->a--->2 Outer\n * / \\\n * 8 3\n * | |\n * | |\n * 7 4\n * \\ /\n * 6<---b<---5 Inner\n */ function pathArc(ctx, element, offset, spacing, end, circular) {\n const { x , y , startAngle: start , pixelMargin , innerRadius: innerR } = element;\n const outerRadius = Math.max(element.outerRadius + spacing + offset - pixelMargin, 0);\n const innerRadius = innerR > 0 ? innerR + spacing + offset + pixelMargin : 0;\n let spacingOffset = 0;\n const alpha = end - start;\n if (spacing) {\n // When spacing is present, it is the same for all items\n // So we adjust the start and end angle of the arc such that\n // the distance is the same as it would be without the spacing\n const noSpacingInnerRadius = innerR > 0 ? innerR - spacing : 0;\n const noSpacingOuterRadius = outerRadius > 0 ? outerRadius - spacing : 0;\n const avNogSpacingRadius = (noSpacingInnerRadius + noSpacingOuterRadius) / 2;\n const adjustedAngle = avNogSpacingRadius !== 0 ? alpha * avNogSpacingRadius / (avNogSpacingRadius + spacing) : alpha;\n spacingOffset = (alpha - adjustedAngle) / 2;\n }\n const beta = Math.max(0.001, alpha * outerRadius - offset / PI) / outerRadius;\n const angleOffset = (alpha - beta) / 2;\n const startAngle = start + angleOffset + spacingOffset;\n const endAngle = end - angleOffset - spacingOffset;\n const { outerStart , outerEnd , innerStart , innerEnd } = parseBorderRadius$1(element, innerRadius, outerRadius, endAngle - startAngle);\n const outerStartAdjustedRadius = outerRadius - outerStart;\n const outerEndAdjustedRadius = outerRadius - outerEnd;\n const outerStartAdjustedAngle = startAngle + outerStart / outerStartAdjustedRadius;\n const outerEndAdjustedAngle = endAngle - outerEnd / outerEndAdjustedRadius;\n const innerStartAdjustedRadius = innerRadius + innerStart;\n const innerEndAdjustedRadius = innerRadius + innerEnd;\n const innerStartAdjustedAngle = startAngle + innerStart / innerStartAdjustedRadius;\n const innerEndAdjustedAngle = endAngle - innerEnd / innerEndAdjustedRadius;\n ctx.beginPath();\n if (circular) {\n // The first arc segments from point 1 to point a to point 2\n const outerMidAdjustedAngle = (outerStartAdjustedAngle + outerEndAdjustedAngle) / 2;\n ctx.arc(x, y, outerRadius, outerStartAdjustedAngle, outerMidAdjustedAngle);\n ctx.arc(x, y, outerRadius, outerMidAdjustedAngle, outerEndAdjustedAngle);\n // The corner segment from point 2 to point 3\n if (outerEnd > 0) {\n const pCenter = rThetaToXY(outerEndAdjustedRadius, outerEndAdjustedAngle, x, y);\n ctx.arc(pCenter.x, pCenter.y, outerEnd, outerEndAdjustedAngle, endAngle + HALF_PI);\n }\n // The line from point 3 to point 4\n const p4 = rThetaToXY(innerEndAdjustedRadius, endAngle, x, y);\n ctx.lineTo(p4.x, p4.y);\n // The corner segment from point 4 to point 5\n if (innerEnd > 0) {\n const 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 betweenAngles = _circumference >= TAU || _angleBetween(angle, startAngle, endAngle);\n const withinRadius = _isBetween(distance, innerRadius + rAdjust, outerRadius + rAdjust);\n return betweenAngles && withinRadius;\n }\n getCenterPoint(useFinalPosition) {\n const { x , y , startAngle , endAngle , innerRadius , outerRadius } = this.getProps([\n 'x',\n 'y',\n 'startAngle',\n 'endAngle',\n 'innerRadius',\n 'outerRadius'\n ], useFinalPosition);\n const { offset , spacing } = this.options;\n const halfAngle = (startAngle + endAngle) / 2;\n const halfRadius = (innerRadius + outerRadius + spacing + offset) / 2;\n return {\n x: x + Math.cos(halfAngle) * halfRadius,\n y: y + Math.sin(halfAngle) * halfRadius\n };\n }\n tooltipPosition(useFinalPosition) {\n return this.getCenterPoint(useFinalPosition);\n }\n draw(ctx) {\n const { options , circumference } = this;\n const offset = (options.offset || 0) / 4;\n const spacing = (options.spacing || 0) / 2;\n const circular = options.circular;\n this.pixelMargin = options.borderAlign === 'inner' ? 0.33 : 0;\n this.fullCircles = circumference > TAU ? Math.floor(circumference / TAU) : 0;\n if (circumference === 0 || this.innerRadius < 0 || this.outerRadius < 0) {\n return;\n }\n ctx.save();\n const halfAngle = (this.startAngle + this.endAngle) / 2;\n ctx.translate(Math.cos(halfAngle) * offset, Math.sin(halfAngle) * offset);\n const fix = 1 - Math.sin(Math.min(PI, circumference || 0));\n const radiusOffset = offset * fix;\n ctx.fillStyle = options.backgroundColor;\n ctx.strokeStyle = options.borderColor;\n drawArc(ctx, this, radiusOffset, spacing, circular);\n drawBorder(ctx, this, radiusOffset, spacing, circular);\n ctx.restore();\n }\n}\n\nfunction setStyle(ctx, options, style = options) {\n ctx.lineCap = valueOrDefault(style.borderCapStyle, options.borderCapStyle);\n ctx.setLineDash(valueOrDefault(style.borderDash, options.borderDash));\n ctx.lineDashOffset = valueOrDefault(style.borderDashOffset, options.borderDashOffset);\n ctx.lineJoin = valueOrDefault(style.borderJoinStyle, options.borderJoinStyle);\n ctx.lineWidth = valueOrDefault(style.borderWidth, options.borderWidth);\n ctx.strokeStyle = valueOrDefault(style.borderColor, options.borderColor);\n}\nfunction lineTo(ctx, previous, target) {\n ctx.lineTo(target.x, target.y);\n}\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 x = 0;\n let y = 0;\n let count = 0;\n for(i = 0, len = items.length; i < len; ++i){\n const el = items[i].element;\n if (el && el.hasValue()) {\n const pos = el.tooltipPosition();\n x += pos.x;\n y += pos.y;\n ++count;\n }\n }\n return {\n x: x / count,\n y: y / count\n };\n },\n nearest (items, eventPosition) {\n if (!items.length) {\n return false;\n }\n let x = eventPosition.x;\n let y = eventPosition.y;\n let minDistance = Number.POSITIVE_INFINITY;\n let i, len, nearestElement;\n for(i = 0, len = items.length; i < len; ++i){\n const el = items[i].element;\n if (el && el.hasValue()) {\n const center = el.getCenterPoint();\n const d = distanceBetweenPoints(eventPosition, center);\n if (d < minDistance) {\n minDistance = d;\n nearestElement = el;\n }\n }\n }\n if (nearestElement) {\n const tp = nearestElement.tooltipPosition();\n x = tp.x;\n y = tp.y;\n }\n return {\n x,\n y\n };\n }\n};\nfunction pushOrConcat(base, toPush) {\n if (toPush) {\n if (isArray(toPush)) {\n Array.prototype.push.apply(base, toPush);\n } else {\n base.push(toPush);\n }\n }\n return base;\n}\n function splitNewlines(str) {\n if ((typeof str === 'string' || str instanceof String) && str.indexOf('\\n') > -1) {\n return str.split('\\n');\n }\n return str;\n}\n function createTooltipItem(chart, item) {\n const { element , datasetIndex , index } = item;\n const controller = chart.getDatasetMeta(datasetIndex).controller;\n const { label , value } = controller.getLabelAndValue(index);\n return {\n chart,\n label,\n parsed: controller.getParsed(index),\n raw: chart.data.datasets[datasetIndex].data[index],\n formattedValue: value,\n dataset: controller.getDataset(),\n dataIndex: index,\n datasetIndex,\n element\n };\n}\n function getTooltipSize(tooltip, options) {\n const ctx = tooltip.chart.ctx;\n const { body , footer , title } = tooltip;\n const { boxWidth , boxHeight } = options;\n const bodyFont = toFont(options.bodyFont);\n const titleFont = toFont(options.titleFont);\n const footerFont = toFont(options.footerFont);\n const titleLineCount = title.length;\n const footerLineCount = footer.length;\n const bodyLineItemCount = body.length;\n const padding = toPadding(options.padding);\n let height = padding.height;\n let width = 0;\n let combinedBodyLength = body.reduce((count, bodyItem)=>count + bodyItem.before.length + bodyItem.lines.length + bodyItem.after.length, 0);\n combinedBodyLength += tooltip.beforeBody.length + tooltip.afterBody.length;\n if (titleLineCount) {\n height += titleLineCount * titleFont.lineHeight + (titleLineCount - 1) * options.titleSpacing + options.titleMarginBottom;\n }\n if (combinedBodyLength) {\n const bodyLineHeight = options.displayColors ? Math.max(boxHeight, bodyFont.lineHeight) : bodyFont.lineHeight;\n height += bodyLineItemCount * bodyLineHeight + (combinedBodyLength - bodyLineItemCount) * bodyFont.lineHeight + (combinedBodyLength - 1) * options.bodySpacing;\n }\n if (footerLineCount) {\n height += options.footerMarginTop + footerLineCount * footerFont.lineHeight + (footerLineCount - 1) * options.footerSpacing;\n }\n let widthPadding = 0;\n const maxLineWidth = function(line) {\n width = Math.max(width, ctx.measureText(line).width + widthPadding);\n };\n ctx.save();\n ctx.font = titleFont.string;\n each(tooltip.title, maxLineWidth);\n ctx.font = bodyFont.string;\n each(tooltip.beforeBody.concat(tooltip.afterBody), maxLineWidth);\n widthPadding = options.displayColors ? boxWidth + 2 + options.boxPadding : 0;\n each(body, (bodyItem)=>{\n each(bodyItem.before, maxLineWidth);\n each(bodyItem.lines, maxLineWidth);\n each(bodyItem.after, maxLineWidth);\n });\n widthPadding = 0;\n ctx.font = footerFont.string;\n each(tooltip.footer, maxLineWidth);\n ctx.restore();\n width += padding.width;\n return {\n width,\n height\n };\n}\nfunction determineYAlign(chart, size) {\n const { y , height } = size;\n if (y < height / 2) {\n return 'top';\n } else if (y > chart.height - height / 2) {\n return 'bottom';\n }\n return 'center';\n}\nfunction doesNotFitWithAlign(xAlign, chart, options, size) {\n const { x , width } = size;\n const caret = options.caretSize + options.caretPadding;\n if (xAlign === 'left' && x + width + caret > chart.width) {\n return true;\n }\n if (xAlign === 'right' && x - width - caret < 0) {\n return true;\n }\n}\nfunction determineXAlign(chart, options, size, yAlign) {\n const { x , width } = size;\n const { width: chartWidth , chartArea: { left , right } } = chart;\n let xAlign = 'center';\n if (yAlign === 'center') {\n xAlign = x <= (left + right) / 2 ? 'left' : 'right';\n } else if (x <= width / 2) {\n xAlign = 'left';\n } else if (x >= chartWidth - width / 2) {\n xAlign = 'right';\n }\n if (doesNotFitWithAlign(xAlign, chart, options, size)) {\n xAlign = 'center';\n }\n return xAlign;\n}\n function determineAlignment(chart, options, size) {\n const yAlign = size.yAlign || options.yAlign || determineYAlign(chart, size);\n return {\n xAlign: size.xAlign || options.xAlign || determineXAlign(chart, options, size, yAlign),\n yAlign\n };\n}\nfunction alignX(size, xAlign) {\n let { x , width } = size;\n if (xAlign === 'right') {\n x -= width;\n } else if (xAlign === 'center') {\n x -= width / 2;\n }\n return x;\n}\nfunction alignY(size, yAlign, paddingAndSize) {\n let { y , height } = size;\n if (yAlign === 'top') {\n y += paddingAndSize;\n } else if (yAlign === 'bottom') {\n y -= height + paddingAndSize;\n } else {\n y -= height / 2;\n }\n return y;\n}\n function getBackgroundPoint(options, size, alignment, chart) {\n const { caretSize , caretPadding , cornerRadius } = options;\n const { xAlign , yAlign } = alignment;\n const paddingAndSize = caretSize + caretPadding;\n const { topLeft , topRight , bottomLeft , bottomRight } = toTRBLCorners(cornerRadius);\n let x = alignX(size, xAlign);\n const y = alignY(size, yAlign, paddingAndSize);\n if (yAlign === 'center') {\n if (xAlign === 'left') {\n x += paddingAndSize;\n } else if (xAlign === 'right') {\n x -= paddingAndSize;\n }\n } else if (xAlign === 'left') {\n x -= Math.max(topLeft, bottomLeft) + caretSize;\n } else if (xAlign === 'right') {\n x += Math.max(topRight, bottomRight) + caretSize;\n }\n return {\n x: _limitValue(x, 0, chart.width - size.width),\n y: _limitValue(y, 0, chart.height - size.height)\n };\n}\nfunction getAlignedX(tooltip, align, options) {\n const padding = toPadding(options.padding);\n return align === 'center' ? tooltip.x + tooltip.width / 2 : align === 'right' ? tooltip.x + tooltip.width - padding.right : tooltip.x + padding.left;\n}\n function getBeforeAfterBodyLines(callback) {\n return pushOrConcat([], splitNewlines(callback));\n}\nfunction createTooltipContext(parent, tooltip, tooltipItems) {\n return createContext(parent, {\n tooltip,\n tooltipItems,\n type: 'tooltip'\n });\n}\nfunction overrideCallbacks(callbacks, context) {\n const override = context && context.dataset && context.dataset.tooltip && context.dataset.tooltip.callbacks;\n return override ? callbacks.override(override) : callbacks;\n}\nconst defaultCallbacks = {\n beforeTitle: noop,\n title (tooltipItems) {\n if (tooltipItems.length > 0) {\n const item = tooltipItems[0];\n const labels = item.chart.data.labels;\n const labelCount = labels ? labels.length : 0;\n if (this && this.options && this.options.mode === 'dataset') {\n return item.dataset.label || '';\n } else if (item.label) {\n return item.label;\n } else if (labelCount > 0 && item.dataIndex < labelCount) {\n return labels[item.dataIndex];\n }\n }\n return '';\n },\n afterTitle: noop,\n beforeBody: noop,\n beforeLabel: noop,\n label (tooltipItem) {\n if (this && this.options && this.options.mode === 'dataset') {\n return tooltipItem.label + ': ' + tooltipItem.formattedValue || tooltipItem.formattedValue;\n }\n let label = tooltipItem.dataset.label || '';\n if (label) {\n label += ': ';\n }\n const value = tooltipItem.formattedValue;\n if (!isNullOrUndef(value)) {\n label += value;\n }\n return label;\n },\n labelColor (tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n borderColor: options.borderColor,\n backgroundColor: options.backgroundColor,\n borderWidth: options.borderWidth,\n borderDash: options.borderDash,\n borderDashOffset: options.borderDashOffset,\n borderRadius: 0\n };\n },\n labelTextColor () {\n return this.options.bodyColor;\n },\n labelPointStyle (tooltipItem) {\n const meta = tooltipItem.chart.getDatasetMeta(tooltipItem.datasetIndex);\n const options = meta.controller.getStyle(tooltipItem.dataIndex);\n return {\n pointStyle: options.pointStyle,\n rotation: options.rotation\n };\n },\n afterLabel: noop,\n afterBody: noop,\n beforeFooter: noop,\n footer: noop,\n afterFooter: noop\n};\n function invokeCallbackWithFallback(callbacks, name, ctx, arg) {\n const result = callbacks[name].call(ctx, arg);\n if (typeof result === 'undefined') {\n return defaultCallbacks[name].call(ctx, arg);\n }\n return result;\n}\nclass Tooltip extends Element {\n static positioners = positioners;\n constructor(config){\n super();\n this.opacity = 0;\n this._active = [];\n this._eventPosition = undefined;\n this._size = undefined;\n this._cachedAnimations = undefined;\n this._tooltipItems = [];\n this.$animations = undefined;\n this.$context = undefined;\n this.chart = config.chart;\n this.options = config.options;\n this.dataPoints = undefined;\n this.title = undefined;\n this.beforeBody = undefined;\n this.body = undefined;\n this.afterBody = undefined;\n this.footer = undefined;\n this.xAlign = undefined;\n this.yAlign = undefined;\n this.x = undefined;\n this.y = undefined;\n this.height = undefined;\n this.width = undefined;\n this.caretX = undefined;\n this.caretY = undefined;\n this.labelColors = undefined;\n this.labelPointStyles = undefined;\n this.labelTextColors = undefined;\n }\n initialize(options) {\n this.options = options;\n this._cachedAnimations = undefined;\n this.$context = undefined;\n }\n _resolveAnimations() {\n const cached = this._cachedAnimations;\n if (cached) {\n return cached;\n }\n const chart = this.chart;\n const options = this.options.setContext(this.getContext());\n const opts = options.enabled && chart.options.animation && options.animations;\n const animations = new Animations(this.chart, opts);\n if (opts._cacheable) {\n this._cachedAnimations = Object.freeze(animations);\n }\n return animations;\n }\n getContext() {\n return this.$context || (this.$context = createTooltipContext(this.chart.getContext(), this, this._tooltipItems));\n }\n getTitle(context, options) {\n const { callbacks } = options;\n const beforeTitle = invokeCallbackWithFallback(callbacks, 'beforeTitle', this, context);\n const title = invokeCallbackWithFallback(callbacks, 'title', this, context);\n const afterTitle = invokeCallbackWithFallback(callbacks, 'afterTitle', this, context);\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeTitle));\n lines = pushOrConcat(lines, splitNewlines(title));\n lines = pushOrConcat(lines, splitNewlines(afterTitle));\n return lines;\n }\n getBeforeBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(invokeCallbackWithFallback(options.callbacks, 'beforeBody', this, tooltipItems));\n }\n getBody(tooltipItems, options) {\n const { callbacks } = options;\n const bodyItems = [];\n each(tooltipItems, (context)=>{\n const bodyItem = {\n before: [],\n lines: [],\n after: []\n };\n const scoped = overrideCallbacks(callbacks, context);\n pushOrConcat(bodyItem.before, splitNewlines(invokeCallbackWithFallback(scoped, 'beforeLabel', this, context)));\n pushOrConcat(bodyItem.lines, invokeCallbackWithFallback(scoped, 'label', this, context));\n pushOrConcat(bodyItem.after, splitNewlines(invokeCallbackWithFallback(scoped, 'afterLabel', this, context)));\n bodyItems.push(bodyItem);\n });\n return bodyItems;\n }\n getAfterBody(tooltipItems, options) {\n return getBeforeAfterBodyLines(invokeCallbackWithFallback(options.callbacks, 'afterBody', this, tooltipItems));\n }\n getFooter(tooltipItems, options) {\n const { callbacks } = options;\n const beforeFooter = invokeCallbackWithFallback(callbacks, 'beforeFooter', this, tooltipItems);\n const footer = invokeCallbackWithFallback(callbacks, 'footer', this, tooltipItems);\n const afterFooter = invokeCallbackWithFallback(callbacks, 'afterFooter', this, tooltipItems);\n let lines = [];\n lines = pushOrConcat(lines, splitNewlines(beforeFooter));\n lines = pushOrConcat(lines, splitNewlines(footer));\n lines = pushOrConcat(lines, splitNewlines(afterFooter));\n return lines;\n }\n _createItems(options) {\n const active = this._active;\n const data = this.chart.data;\n const labelColors = [];\n const labelPointStyles = [];\n const labelTextColors = [];\n let tooltipItems = [];\n let i, len;\n for(i = 0, len = active.length; i < len; ++i){\n tooltipItems.push(createTooltipItem(this.chart, active[i]));\n }\n if (options.filter) {\n tooltipItems = tooltipItems.filter((element, index, array)=>options.filter(element, index, array, data));\n }\n if (options.itemSort) {\n tooltipItems = tooltipItems.sort((a, b)=>options.itemSort(a, b, data));\n }\n each(tooltipItems, (context)=>{\n const scoped = overrideCallbacks(options.callbacks, context);\n labelColors.push(invokeCallbackWithFallback(scoped, 'labelColor', this, context));\n labelPointStyles.push(invokeCallbackWithFallback(scoped, 'labelPointStyle', this, context));\n labelTextColors.push(invokeCallbackWithFallback(scoped, 'labelTextColor', this, context));\n });\n this.labelColors = labelColors;\n this.labelPointStyles = labelPointStyles;\n this.labelTextColors = labelTextColors;\n this.dataPoints = tooltipItems;\n return tooltipItems;\n }\n update(changed, replay) {\n const options = this.options.setContext(this.getContext());\n const active = this._active;\n let properties;\n let tooltipItems = [];\n if (!active.length) {\n if (this.opacity !== 0) {\n properties = {\n opacity: 0\n };\n }\n } else {\n const position = positioners[options.position].call(this, active, this._eventPosition);\n tooltipItems = this._createItems(options);\n this.title = this.getTitle(tooltipItems, options);\n this.beforeBody = this.getBeforeBody(tooltipItems, options);\n this.body = this.getBody(tooltipItems, options);\n this.afterBody = this.getAfterBody(tooltipItems, options);\n this.footer = this.getFooter(tooltipItems, options);\n const size = this._size = getTooltipSize(this, options);\n const positionAndSize = Object.assign({}, position, size);\n const alignment = determineAlignment(this.chart, options, positionAndSize);\n const backgroundPoint = getBackgroundPoint(options, positionAndSize, alignment, this.chart);\n this.xAlign = alignment.xAlign;\n this.yAlign = alignment.yAlign;\n properties = {\n opacity: 1,\n x: backgroundPoint.x,\n y: backgroundPoint.y,\n width: size.width,\n height: size.height,\n caretX: position.x,\n caretY: position.y\n };\n }\n this._tooltipItems = tooltipItems;\n this.$context = undefined;\n if (properties) {\n this._resolveAnimations().update(this, properties);\n }\n if (changed && options.external) {\n options.external.call(this, {\n chart: this.chart,\n tooltip: this,\n replay\n });\n }\n }\n drawCaret(tooltipPoint, ctx, size, options) {\n const caretPosition = this.getCaretPosition(tooltipPoint, size, options);\n ctx.lineTo(caretPosition.x1, caretPosition.y1);\n ctx.lineTo(caretPosition.x2, caretPosition.y2);\n ctx.lineTo(caretPosition.x3, caretPosition.y3);\n }\n getCaretPosition(tooltipPoint, size, options) {\n const { xAlign , yAlign } = this;\n const { caretSize , cornerRadius } = options;\n const { topLeft , topRight , bottomLeft , bottomRight } = toTRBLCorners(cornerRadius);\n const { x: ptX , y: ptY } = tooltipPoint;\n const { width , height } = size;\n let x1, x2, x3, y1, y2, y3;\n if (yAlign === 'center') {\n y2 = ptY + height / 2;\n if (xAlign === 'left') {\n x1 = ptX;\n x2 = x1 - caretSize;\n y1 = y2 + caretSize;\n y3 = y2 - caretSize;\n } else {\n x1 = ptX + width;\n x2 = x1 + caretSize;\n y1 = y2 - caretSize;\n y3 = y2 + caretSize;\n }\n x3 = x1;\n } else {\n if (xAlign === 'left') {\n x2 = ptX + Math.max(topLeft, bottomLeft) + caretSize;\n } else if (xAlign === 'right') {\n x2 = ptX + width - Math.max(topRight, bottomRight) - caretSize;\n } else {\n x2 = this.caretX;\n }\n if (yAlign === 'top') {\n y1 = ptY;\n y2 = y1 - caretSize;\n x1 = x2 - caretSize;\n x3 = x2 + caretSize;\n } else {\n y1 = ptY + height;\n y2 = y1 + caretSize;\n x1 = x2 + caretSize;\n x3 = x2 - caretSize;\n }\n y3 = y1;\n }\n return {\n x1,\n x2,\n x3,\n y1,\n y2,\n y3\n };\n }\n drawTitle(pt, ctx, options) {\n const title = this.title;\n const length = title.length;\n let titleFont, titleSpacing, i;\n if (length) {\n const rtlHelper = getRtlAdapter(options.rtl, this.x, this.width);\n pt.x = getAlignedX(this, options.titleAlign, options);\n ctx.textAlign = rtlHelper.textAlign(options.titleAlign);\n ctx.textBaseline = 'middle';\n titleFont = toFont(options.titleFont);\n titleSpacing = options.titleSpacing;\n ctx.fillStyle = options.titleColor;\n ctx.font = titleFont.string;\n for(i = 0; i < length; ++i){\n ctx.fillText(title[i], rtlHelper.x(pt.x), pt.y + titleFont.lineHeight / 2);\n pt.y += titleFont.lineHeight + titleSpacing;\n if (i + 1 === length) {\n pt.y += options.titleMarginBottom - titleSpacing;\n }\n }\n }\n }\n _drawColorBox(ctx, pt, i, rtlHelper, options) {\n const 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;\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) {\n offset = this.getDistanceFromCenterForValue(tick.value);\n const context = this.getContext(index);\n const optsAtIndex = grid.setContext(context);\n const optsAtIndexBorder = border.setContext(context);\n drawRadiusLine(this, optsAtIndex, offset, labelCount, optsAtIndexBorder);\n }\n });\n }\n if (angleLines.display) {\n ctx.save();\n for(i = labelCount - 1; i >= 0; i--){\n const optsAtIndex = angleLines.setContext(this.getPointLabelContext(i));\n const { color , lineWidth } = optsAtIndex;\n if (!lineWidth || !color) {\n continue;\n }\n ctx.lineWidth = lineWidth;\n ctx.strokeStyle = color;\n ctx.setLineDash(optsAtIndex.borderDash);\n ctx.lineDashOffset = optsAtIndex.borderDashOffset;\n offset = this.getDistanceFromCenterForValue(opts.ticks.reverse ? this.min : this.max);\n position = this.getPointPosition(i, offset);\n ctx.beginPath();\n ctx.moveTo(this.xCenter, this.yCenter);\n ctx.lineTo(position.x, position.y);\n ctx.stroke();\n }\n ctx.restore();\n }\n }\n drawBorder() {}\n drawLabels() {\n const ctx = this.ctx;\n const opts = this.options;\n const tickOpts = opts.ticks;\n if (!tickOpts.display) {\n return;\n }\n const startAngle = this.getIndexAngle(0);\n let offset, width;\n ctx.save();\n ctx.translate(this.xCenter, this.yCenter);\n ctx.rotate(startAngle);\n ctx.textAlign = 'center';\n ctx.textBaseline = 'middle';\n this.ticks.forEach((tick, index)=>{\n if (index === 0 && !opts.reverse) {\n return;\n }\n const optsAtIndex = tickOpts.setContext(this.getContext(index));\n const tickFont = toFont(optsAtIndex.font);\n offset = this.getDistanceFromCenterForValue(this.ticks[index].value);\n if (optsAtIndex.showLabelBackdrop) {\n ctx.font = tickFont.string;\n width = ctx.measureText(tick.label).width;\n ctx.fillStyle = optsAtIndex.backdropColor;\n const padding = toPadding(optsAtIndex.backdropPadding);\n ctx.fillRect(-width / 2 - padding.left, -offset - tickFont.size / 2 - padding.top, width + padding.width, tickFont.size + padding.height);\n }\n renderText(ctx, tick.label, 0, -offset, tickFont, {\n color: optsAtIndex.color,\n 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"],"names":["Animator","constructor","this","_request","_charts","Map","_running","_lastDate","undefined","_notify","chart","anims","date","type","callbacks","listeners","numSteps","duration","forEach","fn","initial","currentStep","Math","min","start","_refresh","r","call","window","_update","Date","now","remaining","running","items","length","item","i","draw","_active","_total","tick","pop","_getAnims","charts","get","complete","progress","set","listen","event","cb","push","add","has","reduce","acc","cur","max","_duration","stop","cancel","remove","delete","animator","transparent","interpolators","boolean","from","to","factor","color","c0","c","c1","valid","mix","hexString","number","Animation","cfg","target","prop","currentValue","_fn","_easing","e","easing","linear","_start","floor","delay","_loop","loop","_target","_prop","_from","_to","_promises","active","update","elapsed","remain","wait","promises","Promise","res","rej","resolved","method","Animations","config","_chart","_properties","configure","animationOptions","Object","keys","d","animation","animatedProps","getOwnPropertyNames","key","option","properties","_animateOptions","values","newOptions","options","$shared","assign","$animations","resolveTargetOptions","animations","_createAnimations","anim","all","awaitAll","then","props","charAt","value","size","scaleClip","scale","allowedOverflow","opts","reverse","end","getSortedDatasetIndices","filterVisible","metasets","_getSortedDatasetMetas","ilen","index","applyStack","stack","dsIndex","singleMode","mode","datasetIndex","otherValue","s","isStacked","meta","stacked","getOrCreateStack","stacks","stackKey","indexValue","subStack","getLastIndexInStack","vScale","positive","getMatchingVisibleMetas","updateStacks","controller","parsed","_cachedMeta","_stacks","iScale","iAxis","axis","vAxis","indexScale","valueScale","id","getStackKey","_top","_bottom","_visualValues","getFirstScaleId","scales","filter","shift","clearStacks","_parsed","isDirectUpdateMode","cloneIfNotShared","cached","shared","DatasetController","static","_ctx","ctx","_cachedDataOpts","getMeta","_type","_parsing","_data","_objectData","_sharedOptions","_drawStart","_drawCount","enableOptionSharing","supportsDecimation","$context","_syncList","datasetElementType","dataElementType","initialize","linkScales","_stacked","addElements","fill","isPluginEnabled","console","warn","updateIndex","dataset","getDataset","chooseId","x","y","xid","xAxisID","v","yid","yAxisID","rid","rAxisID","indexAxis","iid","iAxisID","vid","vAxisID","xScale","getScaleForId","yScale","rScale","data","datasets","getDatasetMeta","scaleID","_getOtherScale","reset","_destroy","u","_dataCheck","adata","Array","convertObjectDataToArray","isExtensible","l","buildOrUpdateElements","resetNewElements","stackChanged","oldStacked","_resyncElements","scopeKeys","datasetScopeKeys","scopes","getOptionScopes","createResolver","getContext","parsing","parse","count","sorted","_sorted","prev","parseArrayData","parseObjectData","parsePrimitiveData","isNotInOrderComparedToPrev","labels","getLabels","singleScale","xAxisKey","yAxisKey","getParsed","getDataElement","updateRangeFromParsed","range","parsedValue","NaN","getMinMax","canStack","otherScale","hidden","createStack","Number","POSITIVE_INFINITY","NEGATIVE_INFINITY","otherMin","otherMax","minDefined","maxDefined","getUserBounds","_skip","getAllParsedValues","getMaxOverflow","getLabelAndValue","label","getLabelForValue","_clip","t","b","top","right","bottom","left","disabled","toClip","clip","defaultClip","elements","area","chartArea","drawActiveElementsOnTop","element","getStyle","resolveDatasetElementOptions","resolveDataElementOptions","context","parent","dataIndex","raw","createDataContext","createDatasetContext","_resolveElementOptions","elementType","cache","cacheKey","sharing","datasetElementScopeKeys","prefixes","names","resolveNamedOptions","freeze","_resolveAnimations","transition","datasetAnimationScopeKeys","_cacheable","getSharedOptions","includeOptions","sharedOptions","_animationsDisabled","_getSharedOptions","firstOpts","previouslySharedOptions","updateSharedOptions","updateElement","_setStyle","removeHoverStyle","setHoverStyle","_removeDatasetHoverStyle","_setDatasetHoverStyle","arg1","arg2","numMeta","numData","_insertElements","_removeElements","move","arr","updateElements","removed","splice","_sync","args","_dataChanges","_onDataPush","arguments","_onDataPop","_onDataShift","_onDataSplice","newCount","_onDataUnshift","computeMinSampleSize","_cache","$bar","visibleMetas","concat","_","sort","a","getAllScaleValues","curr","_length","updateMinAndPrev","abs","getPixelForValue","ticks","getPixelForTick","parseValue","entry","startValue","endValue","barStart","barEnd","_custom","parseFloatBar","parseArrayOrPrimitive","isFloatBar","custom","setBorderSkipped","edge","borderSkipped","horizontal","base","borderProps","enableBorderRadius","parseEdge","orig","v1","v2","startEnd","setInflateAmount","inflateAmount","ratio","BarController","categoryPercentage","barPercentage","grouped","numbers","_index_","offset","grid","_value_","beginAtZero","iAxisKey","vAxisKey","obj","super","bars","getBasePixel","isHorizontal","ruler","_getRuler","vpixels","head","_calculateBarValuePixels","ipixels","_calculateBarIndexPixels","center","height","width","_getStacks","last","skipNull","val","isNaN","indexOf","_getStackCount","_getStackIndex","name","pixels","barThickness","_startPixel","_endPixel","stackCount","baseValue","minBarLength","actualBase","floating","getDataVisibility","barSign","startPixel","getPixelForDecimal","endPixel","getValueForPixel","halfGrid","getLineWidthForValue","maxBarThickness","Infinity","next","percent","chunk","computeFlexCategoryTraits","thickness","computeFitCategoryTraits","stackIndex","rects","binarySearch","metaset","intersect","lookupMethod","_reversePixels","el","getRange","lo","hi","evaluateInteractionItems","position","handler","getSortedVisibleDatasetMetas","j","skip","getIntersectItems","useFinalPosition","includeInvisible","isPointInArea","inRange","getNearestItems","distanceMetric","useX","useY","pt1","pt2","deltaX","deltaY","sqrt","pow","getDistanceMetricForAxis","minDistance","getCenterPoint","distance","getNearestCartesianItems","startAngle","endAngle","getProps","angle","getNearestRadialItems","getAxisItems","rangeMethod","intersectsItem","Interaction","modes","point","nearest","STATIC_POSITIONS","filterByPosition","array","pos","filterDynamicPositionByAxis","box","sortByWeight","v0","weight","getCombinedMax","maxPadding","updateMaxPadding","boxPadding","updateDims","params","layout","getPadding","newWidth","outerWidth","newHeight","outerHeight","widthChanged","w","heightChanged","h","same","other","getMargins","positions","margin","marginForPositions","fitBoxes","boxes","refitBoxes","refit","changed","fullSize","setBoxDims","placeBoxes","userPadding","padding","placed","stackWeight","layouts","addBox","_layers","z","removeBox","layoutItem","minPadding","availableWidth","availableHeight","layoutBoxes","wrapBoxes","wrap","centerHorizontal","centerVertical","leftAndTop","rightAndBottom","vertical","buildLayoutBoxes","verticalBoxes","horizontalBoxes","beforeLayout","visibleVerticalBoxCount","total","display","vBoxMaxWidth","hBoxMaxHeight","includes","_stack","buildStacks","setLayoutDims","updatePos","change","handleMaxPadding","BasePlatform","acquireContext","canvas","aspectRatio","releaseContext","addEventListener","listener","removeEventListener","getDevicePixelRatio","getMaximumSize","isAttached","updateConfig","BasicPlatform","EXPANDO_KEY","EVENT_TYPES","touchstart","touchmove","touchend","pointerenter","pointerdown","pointermove","pointerup","pointerleave","pointerout","isNullOrEmpty","eventListenerOptions","passive","removeListener","nodeListContains","nodeList","node","contains","createAttachObserver","observer","MutationObserver","entries","trigger","addedNodes","removedNodes","observe","document","childList","subtree","createDetachObserver","drpListeningCharts","oldDevicePixelRatio","onWindowResize","dpr","devicePixelRatio","resize","currentDevicePixelRatio","createResizeObserver","container","clientWidth","ResizeObserver","contentRect","listenDevicePixelRatioChanges","releaseObserver","disconnect","unlistenDevicePixelRatioChanges","createProxyAndListen","proxy","native","fromNativeEvent","addListener","DomPlatform","style","renderHeight","getAttribute","renderWidth","boxSizing","displayWidth","displayHeight","initCanvas","removeAttribute","setAttribute","proxies","$proxies","attach","detach","isConnected","Element","tooltipPosition","hasValue","final","ret","newTicks","spacing","majorStart","majorEnd","ceil","round","offsetFromEdge","getTicksLimit","ticksLength","maxTicksLimit","sample","numItems","result","increment","len","getPixelForGridLine","offsetGridLines","validIndex","epsilon","lineValue","getTickMarkLength","drawTicks","tickLength","getTitleHeight","fallback","font","text","lineHeight","titleAlign","align","reverseAlign","Scale","_margins","maxWidth","maxHeight","paddingTop","paddingBottom","paddingLeft","paddingRight","labelRotation","_range","_gridLineItems","_labelItems","_labelSizes","_maxLength","_longestTextCache","_userMax","_userMin","_suggestedMax","_suggestedMin","_ticksLength","_borderValue","_dataLimitsCached","init","setContext","suggestedMin","suggestedMax","metas","getTicks","xLabels","yLabels","getLabelItems","_computeLabelItems","beforeUpdate","margins","grace","tickOpts","sampleSize","beforeSetDimensions","setDimensions","afterSetDimensions","beforeDataLimits","determineDataLimits","afterDataLimits","beforeBuildTicks","buildTicks","afterBuildTicks","samplingEnabled","_convertTicksToLabels","beforeCalculateLabelRotation","calculateLabelRotation","afterCalculateLabelRotation","autoSkip","source","determinedMaxTicks","_tickSize","maxScale","maxChart","determineMaxTicks","ticksLimit","majorIndices","major","enabled","getMajorIndices","numMajorIndices","first","skipMajors","evenMajorSpacing","diff","getEvenSpacing","factors","calculateSpacing","avgMajorSpacing","afterAutoSkip","beforeFit","fit","afterFit","afterUpdate","reversePixels","_alignToPixels","alignToPixels","_callHooks","notifyPlugins","beforeTickToLabelConversion","generateTickLabels","callback","afterTickToLabelConversion","numTicks","minRotation","maxRotation","tickWidth","maxLabelDiagonal","_isVisible","labelSizes","_getLabelSizes","maxLabelWidth","widest","maxLabelHeight","highest","title","asin","minSize","titleOpts","gridOpts","titleHeight","tickPadding","angleRadians","cos","sin","labelHeight","mirror","labelWidth","_calculatePadding","_handleMargins","isRotated","labelsBelowTicks","offsetLeft","offsetRight","isFullSize","_computeLabelSizes","caches","widths","heights","jlen","tickFont","fontString","nestedLabel","widestLabelSize","highestLabelSize","_resolveTickFontOptions","string","gc","gcLen","garbageCollect","valueAt","idx","pixel","decimal","getDecimalForPixel","getBaseValue","createTickContext","optionTicks","rot","autoSkipPadding","_computeGridLineItems","border","tl","borderOpts","axisWidth","axisHalfWidth","alignBorderValue","borderValue","alignedLineValue","tx1","ty1","tx2","ty2","x1","y1","x2","y2","positionAxisID","limit","step","optsAtIndex","optsAtIndexBorder","lineWidth","lineColor","borderDash","dash","borderDashOffset","dashOffset","tickColor","tickBorderDash","tickBorderDashOffset","crossAlign","tickAndPadding","hTickAndPadding","rotation","textAlign","lineCount","textOffset","textBaseline","_getXAxisLabelAlignment","_getYAxisLabelAlignment","labelOffset","halfCount","strokeColor","textStrokeColor","strokeWidth","textStrokeWidth","backdrop","tickTextAlign","showLabelBackdrop","labelPadding","backdropPadding","backdropColor","translation","_computeLabelArea","drawBackground","backgroundColor","save","fillStyle","fillRect","restore","findIndex","drawGrid","drawLine","p1","p2","strokeStyle","setLineDash","lineDashOffset","beginPath","moveTo","lineTo","stroke","drawOnChartArea","drawBorder","lastLineWidth","drawLabels","renderTextOptions","drawTitle","titleX","titleY","H","titleArgs","tz","gz","bz","prototype","axisID","_maxDigits","fontSize","TypedRegistry","scope","override","create","isForType","isPrototypeOf","register","proto","getPrototypeOf","parentScope","isIChartComponent","Error","itemDefaults","defaults","defaultRoutes","routes","property","propertyParts","split","sourceName","sourceScope","join","parts","targetName","targetScope","route","routeDefaults","descriptors","describe","registerDefaults","overrides","unregister","Registry","controllers","plugins","_typedRegistries","_each","addControllers","addPlugins","addScales","getController","_get","getElement","getPlugin","getScale","removeControllers","removeElements","removePlugins","removeScales","typedRegistry","arg","reg","_getRegistryForType","_exec","itemReg","registry","component","camelMethod","PluginService","_init","notify","hook","_createDescriptors","_descriptors","descriptor","plugin","cancelable","invalidate","_oldCache","_notifyStateChanges","localIds","local","allPlugins","getOpts","pluginOpts","createDescriptors","previousDescriptors","some","pluginScopeKeys","scriptable","indexable","allKeys","getIndexAxis","datasetDefaults","idMatchesAxis","determineAxis","scaleOptions","toLowerCase","getAxisFromDataset","initOptions","chartDefaults","configScales","chartIndexAxis","scaleConf","error","_proxy","boundDs","retrieveAxisFromDatasets","defaultId","getDefaultScaleIDFromAxis","defaultScaleOptions","defaultID","getAxisFromDefaultScaleID","mergeScaleConfig","initData","keyCache","keysCached","Set","cachedKeys","generate","addIfFound","Config","_config","initConfig","_scopeCache","_resolverCache","platform","clearCache","clear","datasetType","additionalOptionScopes","_cachedScopes","mainScope","resetCache","keyLists","chartOptionScopes","resolver","subPrefixes","getResolver","isScriptable","isIndexable","hasFunction","needContext","subResolver","descriptorDefaults","resolverCache","p","KNOWN_POSITIONS","positionIsHorizontal","compare2Level","l1","l2","onAnimationsComplete","onComplete","onAnimationProgress","onProgress","getCanvas","getElementById","instances","getChart","moveNumericKeys","intKey","getSizeForArea","field","Chart","invalidatePlugins","userConfig","initialCanvas","existingChart","OffscreenCanvas","_detectPlatform","_options","_aspectRatio","_metasets","_lastEvent","_listeners","_responsiveListeners","_sortedMetasets","_plugins","_hiddenIndices","attached","_doResize","resizeDelay","_initialize","maintainAspectRatio","responsive","bindEvents","_resizeBeforeDraw","_resize","newSize","newRatio","onResize","render","ensureScalesHaveIDs","scalesOptions","axisOptions","buildOrUpdateScales","scaleOpts","updated","map","isRadial","dposition","dtype","scaleType","hasUpdated","_updateMetasets","_destroyDatasetMeta","slice","_removeUnreferencedMetasets","_dataset","buildOrUpdateControllers","newControllers","order","visible","isDatasetVisible","ControllerClass","_resetElements","animsDisabled","_updateScales","_checkEventBindings","_updateHiddenIndices","_minPadding","autoPadding","_updateLayout","_updateDatasets","_eventHandler","_updateHoverStyles","existingEvents","newEvents","events","unbindEvents","changes","_getUniformDataChanges","datasetCount","makeSet","changeSet","noArea","_idx","_updateDataset","layers","_drawDatasets","_drawDataset","useClip","getDatasetArea","getElementsAtEventForMode","getVisibleDatasetCount","setDatasetVisibility","toggleDataVisibility","_updateVisibility","hide","show","_stop","destroy","toBase64Image","toDataURL","bindUserEvents","bindResponsiveEvents","_add","offsetX","offsetY","_remove","detached","updateHoverStyle","prefix","getActiveElements","setActiveElements","activeElements","lastActive","pluginId","replay","hoverOptions","hover","deactivated","activated","inChartArea","eventFilter","_handleEvent","_getActiveElements","isClick","lastEvent","determineLastEvent","onHover","onClick","getBarBounds","bar","half","skipOrLimit","skipX","skipY","bounds","addNormalRectPath","rect","inflateRect","amount","refRect","radius","BarElement","borderWidth","borderRadius","pointStyle","borderColor","inner","outer","maxW","maxH","o","parseBorderWidth","maxR","enableBorder","topLeft","topRight","bottomLeft","bottomRight","parseBorderRadius","boundingRects","addRectPath","mouseX","mouseY","inXRange","inYRange","WeakMap","positioners","average","eventPosition","nearestElement","tp","pushOrConcat","toPush","apply","splitNewlines","str","String","createTooltipItem","formattedValue","getTooltipSize","tooltip","body","footer","boxWidth","boxHeight","bodyFont","titleFont","footerFont","titleLineCount","footerLineCount","bodyLineItemCount","combinedBodyLength","bodyItem","before","lines","after","beforeBody","afterBody","titleSpacing","titleMarginBottom","displayColors","bodySpacing","footerMarginTop","footerSpacing","widthPadding","maxLineWidth","line","measureText","determineXAlign","yAlign","chartWidth","xAlign","caret","caretSize","caretPadding","doesNotFitWithAlign","determineAlignment","determineYAlign","getBackgroundPoint","alignment","cornerRadius","paddingAndSize","alignX","alignY","getAlignedX","getBeforeAfterBodyLines","overrideCallbacks","defaultCallbacks","beforeTitle","tooltipItems","labelCount","afterTitle","beforeLabel","tooltipItem","labelColor","labelTextColor","bodyColor","labelPointStyle","afterLabel","beforeFooter","afterFooter","invokeCallbackWithFallback","Tooltip","opacity","_eventPosition","_size","_cachedAnimations","_tooltipItems","dataPoints","caretX","caretY","labelColors","labelPointStyles","labelTextColors","getTitle","getBeforeBody","getBody","bodyItems","scoped","getAfterBody","getFooter","_createItems","itemSort","positionAndSize","backgroundPoint","external","drawCaret","tooltipPoint","caretPosition","getCaretPosition","x3","y3","ptX","ptY","pt","rtlHelper","rtl","titleColor","fillText","_drawColorBox","colorX","rtlColorX","yOffSet","colorY","usePointStyle","drawOptions","centerX","leftForLtr","centerY","multiKeyBackground","outerX","innerX","xPlus","strokeRect","drawBody","bodyAlign","bodyLineHeight","xLinePadding","fillLineOfText","bodyAlignForCalculation","textColor","drawFooter","footerAlign","footerColor","tooltipSize","quadraticCurveTo","closePath","_updateAnimationTarget","animX","animY","_willRender","hasTooltipContent","globalAlpha","textDirection","positionChanged","_positionChanged","_ignoreReplayEvents","handleEvent","plugin_tooltip","_element","afterInit","_args","afterDraw","afterEvent","_scriptable","_indexable","_fallback","_getLabelForValue","CategoryScale","_startValue","_valueRange","_addedLabels","added","isFinite","addedLabels","unshift","addIfString","lastIndexOf","findOrAddLabel","relativeLabelSize","minSpacing","rad","LinearScaleBase","_endValue","handleTickRangeOptions","setMin","setMax","minSign","maxSign","getTickLimit","maxTicks","stepSize","computeTickLimit","generationOptions","dataRange","precision","maxDigits","includeBounds","unit","maxSpaces","rmin","rmax","countDefined","niceMin","niceMax","numSpaces","decimalPlaces","tickValue","generateTicks$1","locale","format","LinearScale","formatters","numeric","logarithmic"],"sourceRoot":""}