<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[2196],{3148:function(t,e,i){i.d(e,{qi:function(){return Jt},kL:function(){return Yt},jI:function(){return w},u:function(){return ge}});var s=i(9676);class n{constructor(){this._request=null,this._charts=new Map,this._running=!1,this._lastDate=void 0}_notify(t,e,i,s){const n=e.listeners[s],o=e.duration;n.forEach((s=&gt;s({chart:t,initial:e.initial,numSteps:o,currentStep:Math.min(i-e.start,o)})))}_refresh(){this._request||(this._running=!0,this._request=s.r.call(window,(()=&gt;{this._update(),this._request=null,this._running&amp;&amp;this._refresh()})))}_update(t=Date.now()){let e=0;this._charts.forEach(((i,s)=&gt;{if(!i.running||!i.items.length)return;const n=i.items;let o,a=n.length-1,r=!1;for(;a&gt;=0;--a)o=n[a],o._active?(o._total&gt;i.duration&amp;&amp;(i.duration=o._total),o.tick(t),r=!0):(n[a]=n[n.length-1],n.pop());r&amp;&amp;(s.draw(),this._notify(s,i,t,"progress")),n.length||(i.running=!1,this._notify(s,i,t,"complete"),i.initial=!1),e+=n.length})),this._lastDate=t,0===e&amp;&amp;(this._running=!1)}_getAnims(t){const e=this._charts;let i=e.get(t);return i||(i={running:!1,initial:!0,items:[],listeners:{complete:[],progress:[]}},e.set(t,i)),i}listen(t,e,i){this._getAnims(t).listeners[e].push(i)}add(t,e){e&amp;&amp;e.length&amp;&amp;this._getAnims(t).items.push(...e)}has(t){return this._getAnims(t).items.length&gt;0}start(t){const e=this._charts.get(t);e&amp;&amp;(e.running=!0,e.start=Date.now(),e.duration=e.items.reduce(((t,e)=&gt;Math.max(t,e._duration)),0),this._refresh())}running(t){if(!this._running)return!1;const e=this._charts.get(t);return!!(e&amp;&amp;e.running&amp;&amp;e.items.length)}stop(t){const e=this._charts.get(t);if(!e||!e.items.length)return;const i=e.items;let s=i.length-1;for(;s&gt;=0;--s)i[s].cancel();e.items=[],this._notify(t,e,Date.now(),"complete")}remove(t){return this._charts.delete(t)}}var o=new n;const a="transparent",r={boolean:(t,e,i)=&gt;i&gt;.5?e:t,color(t,e,i){const n=(0,s.c)(t||a),o=n.valid&amp;&amp;(0,s.c)(e||a);return o&amp;&amp;o.valid?o.mix(n,i).hexString():e},number:(t,e,i)=&gt;t+(e-t)*i};class h{constructor(t,e,i,n){const o=e[i];n=(0,s.a)([t.to,n,o,t.from]);const a=(0,s.a)([t.from,o,n]);this._active=!0,this._fn=t.fn||r[t.type||typeof a],this._easing=s.e[t.easing]||s.e.linear,this._start=Math.floor(Date.now()+(t.delay||0)),this._duration=this._total=Math.floor(t.duration),this._loop=!!t.loop,this._target=e,this._prop=i,this._from=a,this._to=n,this._promises=void 0}active(){return this._active}update(t,e,i){if(this._active){this._notify(!1);const n=this._target[this._prop],o=i-this._start,a=this._duration-o;this._start=i,this._duration=Math.floor(Math.max(a,t.duration)),this._total+=o,this._loop=!!t.loop,this._to=(0,s.a)([t.to,e,n,t.from]),this._from=(0,s.a)([t.from,n,e])}}cancel(){this._active&amp;&amp;(this.tick(Date.now()),this._active=!1,this._notify(!1))}tick(t){const e=t-this._start,i=this._duration,s=this._prop,n=this._from,o=this._loop,a=this._to;let r;if(this._active=n!==a&amp;&amp;(o||e&lt;i),!this._active)return this._target[s]=a,void this._notify(!0);e&lt;0?this._target[s]=n:(r=e/i%2,r=o&amp;&amp;r&gt;1?2-r:r,r=this._easing(Math.min(1,Math.max(0,r))),this._target[s]=this._fn(n,a,r))}wait(){const t=this._promises||(this._promises=[]);return new Promise(((e,i)=&gt;{t.push({res:e,rej:i})}))}_notify(t){const e=t?"res":"rej",i=this._promises||[];for(let s=0;s&lt;i.length;s++)i[s][e]()}}class l{constructor(t,e){this._chart=t,this._properties=new Map,this.configure(e)}configure(t){if(!(0,s.i)(t))return;const e=Object.keys(s.d.animation),i=this._properties;Object.getOwnPropertyNames(t).forEach((n=&gt;{const o=t[n];if(!(0,s.i)(o))return;const a={};for(const t of e)a[t]=o[t];((0,s.b)(o.properties)&amp;&amp;o.properties||[n]).forEach((t=&gt;{t!==n&amp;&amp;i.has(t)||i.set(t,a)}))}))}_animateOptions(t,e){const i=e.options,s=function(t,e){if(!e)return;let i=t.options;if(!i)return void(t.options=e);i.$shared&amp;&amp;(t.options=i=Object.assign({},i,{$shared:!1,$animations:{}}));return i}(t,i);if(!s)return[];const n=this._createAnimations(s,i);return i.$shared&amp;&amp;function(t,e){const i=[],s=Object.keys(e);for(let n=0;n&lt;s.length;n++){const e=t[s[n]];e&amp;&amp;e.active()&amp;&amp;i.push(e.wait())}return Promise.all(i)}(t.options.$animations,i).then((()=&gt;{t.options=i}),(()=&gt;{})),n}_createAnimations(t,e){const i=this._properties,s=[],n=t.$animations||(t.$animations={}),o=Object.keys(e),a=Date.now();let r;for(r=o.length-1;r&gt;=0;--r){const l=o[r];if("$"===l.charAt(0))continue;if("options"===l){s.push(...this._animateOptions(t,e));continue}const c=e[l];let d=n[l];const u=i.get(l);if(d){if(u&amp;&amp;d.active()){d.update(u,c,a);continue}d.cancel()}u&amp;&amp;u.duration?(n[l]=d=new h(u,t,l,c),s.push(d)):t[l]=c}return s}update(t,e){if(0===this._properties.size)return void Object.assign(t,e);const i=this._createAnimations(t,e);return i.length?(o.add(this._chart,i),!0):void 0}}function c(t,e){const i=t&amp;&amp;t.options||{},s=i.reverse,n=void 0===i.min?e:0,o=void 0===i.max?e:0;return{start:s?o:n,end:s?n:o}}function d(t,e){const i=[],s=t._getSortedDatasetMetas(e);let n,o;for(n=0,o=s.length;n&lt;o;++n)i.push(s[n].index);return i}function u(t,e,i,n={}){const o=t.keys,a="single"===n.mode;let r,h,l,c;if(null!==e){for(r=0,h=o.length;r&lt;h;++r){if(l=+o[r],l===i){if(n.all)continue;break}c=t.values[l],(0,s.g)(c)&amp;&amp;(a||0===e||(0,s.s)(e)===(0,s.s)(c))&amp;&amp;(e+=c)}return e}}function g(t,e){const i=t&amp;&amp;t.options.stacked;return i||void 0===i&amp;&amp;void 0!==e.stack}function f(t,e,i){const s=t[e]||(t[e]={});return s[i]||(s[i]={})}function p(t,e,i,s){for(const n of e.getMatchingVisibleMetas(s).reverse()){const e=t[n.index];if(i&amp;&amp;e&gt;0||!i&amp;&amp;e&lt;0)return n.index}return null}function x(t,e){const{chart:i,_cachedMeta:s}=t,n=i._stacks||(i._stacks={}),{iScale:o,vScale:a,index:r}=s,h=o.axis,l=a.axis,c=function(t,e,i){return`${t.id}.${e.id}.${i.stack||i.type}`}(o,a,s),d=e.length;let u;for(let g=0;g&lt;d;++g){const t=e[g],{[h]:i,[l]:o}=t;u=(t._stacks||(t._stacks={}))[l]=f(n,c,i),u[r]=o,u._top=p(u,a,!0,s.type),u._bottom=p(u,a,!1,s.type);(u._visualValues||(u._visualValues={}))[r]=o}}function _(t,e){const i=t.scales;return Object.keys(i).filter((t=&gt;i[t].axis===e)).shift()}function m(t,e){const i=t.controller.index,s=t.vScale&amp;&amp;t.vScale.axis;if(s){e=e||t._parsed;for(const t of e){const e=t._stacks;if(!e||void 0===e[s]||void 0===e[s][i])return;delete e[s][i],void 0!==e[s]._visualValues&amp;&amp;void 0!==e[s]._visualValues[i]&amp;&amp;delete e[s]._visualValues[i]}}}const b=t=&gt;"reset"===t||"none"===t,y=(t,e)=&gt;e?t:Object.assign({},t);class v{static defaults={};static datasetElementType=null;static dataElementType=null;constructor(t,e){this.chart=t,this._ctx=t.ctx,this.index=e,this._cachedDataOpts={},this._cachedMeta=this.getMeta(),this._type=this._cachedMeta.type,this.options=void 0,this._parsing=!1,this._data=void 0,this._objectData=void 0,this._sharedOptions=void 0,this._drawStart=void 0,this._drawCount=void 0,this.enableOptionSharing=!1,this.supportsDecimation=!1,this.$context=void 0,this._syncList=[],this.datasetElementType=new.target.datasetElementType,this.dataElementType=new.target.dataElementType,this.initialize()}initialize(){const t=this._cachedMeta;this.configure(),this.linkScales(),t._stacked=g(t.vScale,t),this.addElements(),this.options.fill&amp;&amp;!this.chart.isPluginEnabled("filler")&amp;&amp;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")}updateIndex(t){this.index!==t&amp;&amp;m(this._cachedMeta),this.index=t}linkScales(){const t=this.chart,e=this._cachedMeta,i=this.getDataset(),n=(t,e,i,s)=&gt;"x"===t?e:"r"===t?s:i,o=e.xAxisID=(0,s.v)(i.xAxisID,_(t,"x")),a=e.yAxisID=(0,s.v)(i.yAxisID,_(t,"y")),r=e.rAxisID=(0,s.v)(i.rAxisID,_(t,"r")),h=e.indexAxis,l=e.iAxisID=n(h,o,a,r),c=e.vAxisID=n(h,a,o,r);e.xScale=this.getScaleForId(o),e.yScale=this.getScaleForId(a),e.rScale=this.getScaleForId(r),e.iScale=this.getScaleForId(l),e.vScale=this.getScaleForId(c)}getDataset(){return this.chart.data.datasets[this.index]}getMeta(){return this.chart.getDatasetMeta(this.index)}getScaleForId(t){return this.chart.scales[t]}_getOtherScale(t){const e=this._cachedMeta;return t===e.iScale?e.vScale:e.iScale}reset(){this._update("reset")}_destroy(){const t=this._cachedMeta;this._data&amp;&amp;(0,s.u)(this._data,this),t._stacked&amp;&amp;m(t)}_dataCheck(){const t=this.getDataset(),e=t.data||(t.data=[]),i=this._data;if((0,s.i)(e)){const t=this._cachedMeta;this._data=function(t,e){const{iScale:i,vScale:s}=e,n="x"===i.axis?"x":"y",o="x"===s.axis?"x":"y",a=Object.keys(t),r=new Array(a.length);let h,l,c;for(h=0,l=a.length;h&lt;l;++h)c=a[h],r[h]={[n]:c,[o]:t[c]};return r}(e,t)}else if(i!==e){if(i){(0,s.u)(i,this);const t=this._cachedMeta;m(t),t._parsed=[]}e&amp;&amp;Object.isExtensible(e)&amp;&amp;(0,s.l)(e,this),this._syncList=[],this._data=e}}addElements(){const t=this._cachedMeta;this._dataCheck(),this.datasetElementType&amp;&amp;(t.dataset=new this.datasetElementType)}buildOrUpdateElements(t){const e=this._cachedMeta,i=this.getDataset();let s=!1;this._dataCheck();const n=e._stacked;e._stacked=g(e.vScale,e),e.stack!==i.stack&amp;&amp;(s=!0,m(e),e.stack=i.stack),this._resyncElements(t),(s||n!==e._stacked)&amp;&amp;x(this,e._parsed)}configure(){const t=this.chart.config,e=t.datasetScopeKeys(this._type),i=t.getOptionScopes(this.getDataset(),e,!0);this.options=t.createResolver(i,this.getContext()),this._parsing=this.options.parsing,this._cachedDataOpts={}}parse(t,e){const{_cachedMeta:i,_data:n}=this,{iScale:o,_stacked:a}=i,r=o.axis;let h,l,c,d=0===t&amp;&amp;e===n.length||i._sorted,u=t&gt;0&amp;&amp;i._parsed[t-1];if(!1===this._parsing)i._parsed=n,i._sorted=!0,c=n;else{c=(0,s.b)(n[t])?this.parseArrayData(i,n,t,e):(0,s.i)(n[t])?this.parseObjectData(i,n,t,e):this.parsePrimitiveData(i,n,t,e);const o=()=&gt;null===l[r]||u&amp;&amp;l[r]&lt;u[r];for(h=0;h&lt;e;++h)i._parsed[h+t]=l=c[h],d&amp;&amp;(o()&amp;&amp;(d=!1),u=l);i._sorted=d}a&amp;&amp;x(this,c)}parsePrimitiveData(t,e,i,s){const{iScale:n,vScale:o}=t,a=n.axis,r=o.axis,h=n.getLabels(),l=n===o,c=new Array(s);let d,u,g;for(d=0,u=s;d&lt;u;++d)g=d+i,c[d]={[a]:l||n.parse(h[g],g),[r]:o.parse(e[g],g)};return c}parseArrayData(t,e,i,s){const{xScale:n,yScale:o}=t,a=new Array(s);let r,h,l,c;for(r=0,h=s;r&lt;h;++r)l=r+i,c=e[l],a[r]={x:n.parse(c[0],l),y:o.parse(c[1],l)};return a}parseObjectData(t,e,i,n){const{xScale:o,yScale:a}=t,{xAxisKey:r="x",yAxisKey:h="y"}=this._parsing,l=new Array(n);let c,d,u,g;for(c=0,d=n;c&lt;d;++c)u=c+i,g=e[u],l[c]={x:o.parse((0,s.f)(g,r),u),y:a.parse((0,s.f)(g,h),u)};return l}getParsed(t){return this._cachedMeta._parsed[t]}getDataElement(t){return this._cachedMeta.data[t]}applyStack(t,e,i){const s=this.chart,n=this._cachedMeta,o=e[t.axis];return u({keys:d(s,!0),values:e._stacks[t.axis]._visualValues},o,n.index,{mode:i})}updateRangeFromParsed(t,e,i,s){const n=i[e.axis];let o=null===n?NaN:n;const a=s&amp;&amp;i._stacks[e.axis];s&amp;&amp;a&amp;&amp;(s.values=a,o=u(s,n,this._cachedMeta.index)),t.min=Math.min(t.min,o),t.max=Math.max(t.max,o)}getMinMax(t,e){const i=this._cachedMeta,n=i._parsed,o=i._sorted&amp;&amp;t===i.iScale,a=n.length,r=this._getOtherScale(t),h=((t,e,i)=&gt;t&amp;&amp;!e.hidden&amp;&amp;e._stacked&amp;&amp;{keys:d(i,!0),values:null})(e,i,this.chart),l={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY},{min:c,max:u}=function(t){const{min:e,max:i,minDefined:s,maxDefined:n}=t.getUserBounds();return{min:s?e:Number.NEGATIVE_INFINITY,max:n?i:Number.POSITIVE_INFINITY}}(r);let g,f;function p(){f=n[g];const e=f[r.axis];return!(0,s.g)(f[t.axis])||c&gt;e||u&lt;e}for(g=0;g&lt;a&amp;&amp;(p()||(this.updateRangeFromParsed(l,t,f,h),!o));++g);if(o)for(g=a-1;g&gt;=0;--g)if(!p()){this.updateRangeFromParsed(l,t,f,h);break}return l}getAllParsedValues(t){const e=this._cachedMeta._parsed,i=[];let n,o,a;for(n=0,o=e.length;n&lt;o;++n)a=e[n][t.axis],(0,s.g)(a)&amp;&amp;i.push(a);return i}getMaxOverflow(){return!1}getLabelAndValue(t){const e=this._cachedMeta,i=e.iScale,s=e.vScale,n=this.getParsed(t);return{label:i?""+i.getLabelForValue(n[i.axis]):"",value:s?""+s.getLabelForValue(n[s.axis]):""}}_update(t){const e=this._cachedMeta;this.update(t||"default"),e._clip=function(t){let e,i,n,o;return(0,s.i)(t)?(e=t.top,i=t.right,n=t.bottom,o=t.left):e=i=n=o=t,{top:e,right:i,bottom:n,left:o,disabled:!1===t}}((0,s.v)(this.options.clip,function(t,e,i){if(!1===i)return!1;const s=c(t,i),n=c(e,i);return{top:n.end,right:s.end,bottom:n.start,left:s.start}}(e.xScale,e.yScale,this.getMaxOverflow())))}update(t){}draw(){const t=this._ctx,e=this.chart,i=this._cachedMeta,s=i.data||[],n=e.chartArea,o=[],a=this._drawStart||0,r=this._drawCount||s.length-a,h=this.options.drawActiveElementsOnTop;let l;for(i.dataset&amp;&amp;i.dataset.draw(t,n,a,r),l=a;l&lt;a+r;++l){const e=s[l];e.hidden||(e.active&amp;&amp;h?o.push(e):e.draw(t,n))}for(l=0;l&lt;o.length;++l)o[l].draw(t,n)}getStyle(t,e){const i=e?"active":"default";return void 0===t&amp;&amp;this._cachedMeta.dataset?this.resolveDatasetElementOptions(i):this.resolveDataElementOptions(t||0,i)}getContext(t,e,i){const n=this.getDataset();let o;if(t&gt;=0&amp;&amp;t&lt;this._cachedMeta.data.length){const e=this._cachedMeta.data[t];o=e.$context||(e.$context=function(t,e,i){return(0,s.j)(t,{active:!1,dataIndex:e,parsed:void 0,raw:void 0,element:i,index:e,mode:"default",type:"data"})}(this.getContext(),t,e)),o.parsed=this.getParsed(t),o.raw=n.data[t],o.index=o.dataIndex=t}else o=this.$context||(this.$context=function(t,e){return(0,s.j)(t,{active:!1,dataset:void 0,datasetIndex:e,index:e,mode:"default",type:"dataset"})}(this.chart.getContext(),this.index)),o.dataset=n,o.index=o.datasetIndex=this.index;return o.active=!!e,o.mode=i,o}resolveDatasetElementOptions(t){return this._resolveElementOptions(this.datasetElementType.id,t)}resolveDataElementOptions(t,e){return this._resolveElementOptions(this.dataElementType.id,e,t)}_resolveElementOptions(t,e="default",i){const n="active"===e,o=this._cachedDataOpts,a=t+"-"+e,r=o[a],h=this.enableOptionSharing&amp;&amp;(0,s.h)(i);if(r)return y(r,h);const l=this.chart.config,c=l.datasetElementScopeKeys(this._type,t),d=n?[`${t}Hover`,"hover",t,""]:[t,""],u=l.getOptionScopes(this.getDataset(),c),g=Object.keys(s.d.elements[t]),f=l.resolveNamedOptions(u,g,(()=&gt;this.getContext(i,n,e)),d);return f.$shared&amp;&amp;(f.$shared=h,o[a]=Object.freeze(y(f,h))),f}_resolveAnimations(t,e,i){const s=this.chart,n=this._cachedDataOpts,o=`animation-${e}`,a=n[o];if(a)return a;let r;if(!1!==s.options.animation){const s=this.chart.config,n=s.datasetAnimationScopeKeys(this._type,e),o=s.getOptionScopes(this.getDataset(),n);r=s.createResolver(o,this.getContext(t,i,e))}const h=new l(s,r&amp;&amp;r.animations);return r&amp;&amp;r._cacheable&amp;&amp;(n[o]=Object.freeze(h)),h}getSharedOptions(t){if(t.$shared)return this._sharedOptions||(this._sharedOptions=Object.assign({},t))}includeOptions(t,e){return!e||b(t)||this.chart._animationsDisabled}_getSharedOptions(t,e){const i=this.resolveDataElementOptions(t,e),s=this._sharedOptions,n=this.getSharedOptions(i),o=this.includeOptions(e,n)||n!==s;return this.updateSharedOptions(n,e,i),{sharedOptions:n,includeOptions:o}}updateElement(t,e,i,s){b(s)?Object.assign(t,i):this._resolveAnimations(e,s).update(t,i)}updateSharedOptions(t,e,i){t&amp;&amp;!b(e)&amp;&amp;this._resolveAnimations(void 0,e).update(t,i)}_setStyle(t,e,i,s){t.active=s;const n=this.getStyle(e,s);this._resolveAnimations(e,i,s).update(t,{options:!s&amp;&amp;this.getSharedOptions(n)||n})}removeHoverStyle(t,e,i){this._setStyle(t,i,"active",!1)}setHoverStyle(t,e,i){this._setStyle(t,i,"active",!0)}_removeDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&amp;&amp;this._setStyle(t,void 0,"active",!1)}_setDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&amp;&amp;this._setStyle(t,void 0,"active",!0)}_resyncElements(t){const e=this._data,i=this._cachedMeta.data;for(const[a,r,h]of this._syncList)this[a](r,h);this._syncList=[];const s=i.length,n=e.length,o=Math.min(n,s);o&amp;&amp;this.parse(0,o),n&gt;s?this._insertElements(s,n-s,t):n&lt;s&amp;&amp;this._removeElements(n,s-n)}_insertElements(t,e,i=!0){const s=this._cachedMeta,n=s.data,o=t+e;let a;const r=t=&gt;{for(t.length+=e,a=t.length-1;a&gt;=o;a--)t[a]=t[a-e]};for(r(n),a=t;a&lt;o;++a)n[a]=new this.dataElementType;this._parsing&amp;&amp;r(s._parsed),this.parse(t,e),i&amp;&amp;this.updateElements(n,t,e,"reset")}updateElements(t,e,i,s){}_removeElements(t,e){const i=this._cachedMeta;if(this._parsing){const s=i._parsed.splice(t,e);i._stacked&amp;&amp;m(i,s)}i.data.splice(t,e)}_sync(t){if(this._parsing)this._syncList.push(t);else{const[e,i,s]=t;this[e](i,s)}this.chart._dataChanges.push([this.index,...t])}_onDataPush(){const t=arguments.length;this._sync(["_insertElements",this.getDataset().data.length-t,t])}_onDataPop(){this._sync(["_removeElements",this._cachedMeta.data.length-1,1])}_onDataShift(){this._sync(["_removeElements",0,1])}_onDataSplice(t,e){e&amp;&amp;this._sync(["_removeElements",t,e]);const i=arguments.length-2;i&amp;&amp;this._sync(["_insertElements",t,i])}_onDataUnshift(){this._sync(["_insertElements",0,arguments.length])}}class w extends v{static id="doughnut";static defaults={datasetElementType:!1,dataElementType:"arc",animation:{animateRotate:!0,animateScale:!1},animations:{numbers:{type:"number",properties:["circumference","endAngle","innerRadius","outerRadius","startAngle","x","y","offset","borderWidth","spacing"]}},cutout:"50%",rotation:0,circumference:360,radius:"100%",spacing:0,indexAxis:"r"};static descriptors={_scriptable:t=&gt;"spacing"!==t,_indexable:t=&gt;"spacing"!==t&amp;&amp;!t.startsWith("borderDash")&amp;&amp;!t.startsWith("hoverBorderDash")};static overrides={aspectRatio:1,plugins:{legend:{labels:{generateLabels(t){const e=t.data;if(e.labels.length&amp;&amp;e.datasets.length){const{labels:{pointStyle:i,color:s}}=t.legend.options;return e.labels.map(((e,n)=&gt;{const o=t.getDatasetMeta(0).controller.getStyle(n);return{text:e,fillStyle:o.backgroundColor,strokeStyle:o.borderColor,fontColor:s,lineWidth:o.borderWidth,pointStyle:i,hidden:!t.getDataVisibility(n),index:n}}))}return[]}},onClick(t,e,i){i.chart.toggleDataVisibility(e.index),i.chart.update()}}}};constructor(t,e){super(t,e),this.enableOptionSharing=!0,this.innerRadius=void 0,this.outerRadius=void 0,this.offsetX=void 0,this.offsetY=void 0}linkScales(){}parse(t,e){const i=this.getDataset().data,n=this._cachedMeta;if(!1===this._parsing)n._parsed=i;else{let o,a,r=t=&gt;+i[t];if((0,s.i)(i[t])){const{key:t="value"}=this._parsing;r=e=&gt;+(0,s.f)(i[e],t)}for(o=t,a=t+e;o&lt;a;++o)n._parsed[o]=r(o)}}_getRotation(){return(0,s.t)(this.options.rotation-90)}_getCircumference(){return(0,s.t)(this.options.circumference)}_getRotationExtents(){let t=s.T,e=-s.T;for(let i=0;i&lt;this.chart.data.datasets.length;++i)if(this.chart.isDatasetVisible(i)&amp;&amp;this.chart.getDatasetMeta(i).type===this._type){const s=this.chart.getDatasetMeta(i).controller,n=s._getRotation(),o=s._getCircumference();t=Math.min(t,n),e=Math.max(e,n+o)}return{rotation:t,circumference:e-t}}update(t){const e=this.chart,{chartArea:i}=e,n=this._cachedMeta,o=n.data,a=this.getMaxBorderWidth()+this.getMaxOffset(o)+this.options.spacing,r=Math.max((Math.min(i.width,i.height)-a)/2,0),h=Math.min((0,s.m)(this.options.cutout,r),1),l=this._getRingWeight(this.index),{circumference:c,rotation:d}=this._getRotationExtents(),{ratioX:u,ratioY:g,offsetX:f,offsetY:p}=function(t,e,i){let n=1,o=1,a=0,r=0;if(e&lt;s.T){const h=t,l=h+e,c=Math.cos(h),d=Math.sin(h),u=Math.cos(l),g=Math.sin(l),f=(t,e,n)=&gt;(0,s.p)(t,h,l,!0)?1:Math.max(e,e*i,n,n*i),p=(t,e,n)=&gt;(0,s.p)(t,h,l,!0)?-1:Math.min(e,e*i,n,n*i),x=f(0,c,u),_=f(s.H,d,g),m=p(s.P,c,u),b=p(s.P+s.H,d,g);n=(x-m)/2,o=(_-b)/2,a=-(x+m)/2,r=-(_+b)/2}return{ratioX:n,ratioY:o,offsetX:a,offsetY:r}}(d,c,h),x=(i.width-a)/u,_=(i.height-a)/g,m=Math.max(Math.min(x,_)/2,0),b=(0,s.n)(this.options.radius,m),y=(b-Math.max(b*h,0))/this._getVisibleDatasetWeightTotal();this.offsetX=f*b,this.offsetY=p*b,n.total=this.calculateTotal(),this.outerRadius=b-y*this._getRingWeightOffset(this.index),this.innerRadius=Math.max(this.outerRadius-y*l,0),this.updateElements(o,0,o.length,t)}_circumference(t,e){const i=this.options,n=this._cachedMeta,o=this._getCircumference();return e&amp;&amp;i.animation.animateRotate||!this.chart.getDataVisibility(t)||null===n._parsed[t]||n.data[t].hidden?0:this.calculateCircumference(n._parsed[t]*o/s.T)}updateElements(t,e,i,s){const n="reset"===s,o=this.chart,a=o.chartArea,r=o.options.animation,h=(a.left+a.right)/2,l=(a.top+a.bottom)/2,c=n&amp;&amp;r.animateScale,d=c?0:this.innerRadius,u=c?0:this.outerRadius,{sharedOptions:g,includeOptions:f}=this._getSharedOptions(e,s);let p,x=this._getRotation();for(p=0;p&lt;e;++p)x+=this._circumference(p,n);for(p=e;p&lt;e+i;++p){const e=this._circumference(p,n),i=t[p],o={x:h+this.offsetX,y:l+this.offsetY,startAngle:x,endAngle:x+e,circumference:e,outerRadius:u,innerRadius:d};f&amp;&amp;(o.options=g||this.resolveDataElementOptions(p,i.active?"active":s)),x+=e,this.updateElement(i,p,o,s)}}calculateTotal(){const t=this._cachedMeta,e=t.data;let i,s=0;for(i=0;i&lt;e.length;i++){const n=t._parsed[i];null===n||isNaN(n)||!this.chart.getDataVisibility(i)||e[i].hidden||(s+=Math.abs(n))}return s}calculateCircumference(t){const e=this._cachedMeta.total;return e&gt;0&amp;&amp;!isNaN(t)?s.T*(Math.abs(t)/e):0}getLabelAndValue(t){const e=this._cachedMeta,i=this.chart,n=i.data.labels||[],o=(0,s.o)(e._parsed[t],i.options.locale);return{label:n[t]||"",value:o}}getMaxBorderWidth(t){let e=0;const i=this.chart;let s,n,o,a,r;if(!t)for(s=0,n=i.data.datasets.length;s&lt;n;++s)if(i.isDatasetVisible(s)){o=i.getDatasetMeta(s),t=o.data,a=o.controller;break}if(!t)return 0;for(s=0,n=t.length;s&lt;n;++s)r=a.resolveDataElementOptions(s),"inner"!==r.borderAlign&amp;&amp;(e=Math.max(e,r.borderWidth||0,r.hoverBorderWidth||0));return e}getMaxOffset(t){let e=0;for(let i=0,s=t.length;i&lt;s;++i){const t=this.resolveDataElementOptions(i);e=Math.max(e,t.offset||0,t.hoverOffset||0)}return e}_getRingWeightOffset(t){let e=0;for(let i=0;i&lt;t;++i)this.chart.isDatasetVisible(i)&amp;&amp;(e+=this._getRingWeight(i));return e}_getRingWeight(t){return Math.max((0,s.v)(this.chart.data.datasets[t].weight,1),0)}_getVisibleDatasetWeightTotal(){return this._getRingWeightOffset(this.chart.data.datasets.length)||1}}function M(t,e,i,n){const{controller:o,data:a,_sorted:r}=t,h=o._cachedMeta.iScale;if(h&amp;&amp;e===h.axis&amp;&amp;"r"!==e&amp;&amp;r&amp;&amp;a.length){const t=h._reversePixels?s.A:s.B;if(!n)return t(a,e,i);if(o._sharedOptions){const s=a[0],n="function"===typeof s.getRange&amp;&amp;s.getRange(e);if(n){const s=t(a,e,i-n),o=t(a,e,i+n);return{lo:s.lo,hi:o.hi}}}}return{lo:0,hi:a.length-1}}function k(t,e,i,s,n){const o=t.getSortedVisibleDatasetMetas(),a=i[e];for(let r=0,h=o.length;r&lt;h;++r){const{index:t,data:i}=o[r],{lo:h,hi:l}=M(o[r],e,a,n);for(let e=h;e&lt;=l;++e){const n=i[e];n.skip||s(n,t,e)}}}function S(t,e,i,n,o){const a=[];if(!o&amp;&amp;!t.isPointInArea(e))return a;return k(t,i,e,(function(i,r,h){(o||(0,s.C)(i,t.chartArea,0))&amp;&amp;i.inRange(e.x,e.y,n)&amp;&amp;a.push({element:i,datasetIndex:r,index:h})}),!0),a}function D(t,e,i,s,n,o){let a=[];const r=function(t){const e=-1!==t.indexOf("x"),i=-1!==t.indexOf("y");return function(t,s){const n=e?Math.abs(t.x-s.x):0,o=i?Math.abs(t.y-s.y):0;return Math.sqrt(Math.pow(n,2)+Math.pow(o,2))}}(i);let h=Number.POSITIVE_INFINITY;return k(t,i,e,(function(i,l,c){const d=i.inRange(e.x,e.y,n);if(s&amp;&amp;!d)return;const u=i.getCenterPoint(n);if(!(!!o||t.isPointInArea(u))&amp;&amp;!d)return;const g=r(e,u);g&lt;h?(a=[{element:i,datasetIndex:l,index:c}],h=g):g===h&amp;&amp;a.push({element:i,datasetIndex:l,index:c})})),a}function A(t,e,i,n,o,a){return a||t.isPointInArea(e)?"r"!==i||n?D(t,e,i,n,o,a):function(t,e,i,n){let o=[];return k(t,i,e,(function(t,i,a){const{startAngle:r,endAngle:h}=t.getProps(["startAngle","endAngle"],n),{angle:l}=(0,s.D)(t,{x:e.x,y:e.y});(0,s.p)(l,r,h)&amp;&amp;o.push({element:t,datasetIndex:i,index:a})})),o}(t,e,i,o):[]}function C(t,e,i,s,n){const o=[],a="x"===i?"inXRange":"inYRange";let r=!1;return k(t,i,e,((t,s,h)=&gt;{t[a](e[i],n)&amp;&amp;(o.push({element:t,datasetIndex:s,index:h}),r=r||t.inRange(e.x,e.y,n))})),s&amp;&amp;!r?[]:o}var E={evaluateInteractionItems:k,modes:{index(t,e,i,n){const o=(0,s.z)(e,t),a=i.axis||"x",r=i.includeInvisible||!1,h=i.intersect?S(t,o,a,n,r):A(t,o,a,!1,n,r),l=[];return h.length?(t.getSortedVisibleDatasetMetas().forEach((t=&gt;{const e=h[0].index,i=t.data[e];i&amp;&amp;!i.skip&amp;&amp;l.push({element:i,datasetIndex:t.index,index:e})})),l):[]},dataset(t,e,i,n){const o=(0,s.z)(e,t),a=i.axis||"xy",r=i.includeInvisible||!1;let h=i.intersect?S(t,o,a,n,r):A(t,o,a,!1,n,r);if(h.length&gt;0){const e=h[0].datasetIndex,i=t.getDatasetMeta(e).data;h=[];for(let t=0;t&lt;i.length;++t)h.push({element:i[t],datasetIndex:e,index:t})}return h},point:(t,e,i,n)=&gt;S(t,(0,s.z)(e,t),i.axis||"xy",n,i.includeInvisible||!1),nearest(t,e,i,n){const o=(0,s.z)(e,t),a=i.axis||"xy",r=i.includeInvisible||!1;return A(t,o,a,i.intersect,n,r)},x:(t,e,i,n)=&gt;C(t,(0,s.z)(e,t),"x",i.intersect,n),y:(t,e,i,n)=&gt;C(t,(0,s.z)(e,t),"y",i.intersect,n)}};const O=["left","top","right","bottom"];function P(t,e){return t.filter((t=&gt;t.pos===e))}function T(t,e){return t.filter((t=&gt;-1===O.indexOf(t.pos)&amp;&amp;t.box.axis===e))}function I(t,e){return t.sort(((t,i)=&gt;{const s=e?i:t,n=e?t:i;return s.weight===n.weight?s.index-n.index:s.weight-n.weight}))}function L(t,e){const i=function(t){const e={};for(const i of t){const{stack:t,pos:s,stackWeight:n}=i;if(!t||!O.includes(s))continue;const o=e[t]||(e[t]={count:0,placed:0,weight:0,size:0});o.count++,o.weight+=n}return e}(t),{vBoxMaxWidth:s,hBoxMaxHeight:n}=e;let o,a,r;for(o=0,a=t.length;o&lt;a;++o){r=t[o];const{fullSize:a}=r.box,h=i[r.stack],l=h&amp;&amp;r.stackWeight/h.weight;r.horizontal?(r.width=l?l*s:a&amp;&amp;e.availableWidth,r.height=n):(r.width=s,r.height=l?l*n:a&amp;&amp;e.availableHeight)}return i}function R(t,e,i,s){return Math.max(t[i],e[i])+Math.max(t[s],e[s])}function z(t,e){t.top=Math.max(t.top,e.top),t.left=Math.max(t.left,e.left),t.bottom=Math.max(t.bottom,e.bottom),t.right=Math.max(t.right,e.right)}function F(t,e,i,n){const{pos:o,box:a}=i,r=t.maxPadding;if(!(0,s.i)(o)){i.size&amp;&amp;(t[o]-=i.size);const e=n[i.stack]||{size:0,count:1};e.size=Math.max(e.size,i.horizontal?a.height:a.width),i.size=e.size/e.count,t[o]+=i.size}a.getPadding&amp;&amp;z(r,a.getPadding());const h=Math.max(0,e.outerWidth-R(r,t,"left","right")),l=Math.max(0,e.outerHeight-R(r,t,"top","bottom")),c=h!==t.w,d=l!==t.h;return t.w=h,t.h=l,i.horizontal?{same:c,other:d}:{same:d,other:c}}function B(t,e){const i=e.maxPadding;function s(t){const s={left:0,top:0,right:0,bottom:0};return t.forEach((t=&gt;{s[t]=Math.max(e[t],i[t])})),s}return s(t?["left","right"]:["top","bottom"])}function H(t,e,i,s){const n=[];let o,a,r,h,l,c;for(o=0,a=t.length,l=0;o&lt;a;++o){r=t[o],h=r.box,h.update(r.width||e.w,r.height||e.h,B(r.horizontal,e));const{same:a,other:d}=F(e,i,r,s);l|=a&amp;&amp;n.length,c=c||d,h.fullSize||n.push(r)}return l&amp;&amp;H(n,e,i,s)||c}function V(t,e,i,s,n){t.top=i,t.left=e,t.right=e+s,t.bottom=i+n,t.width=s,t.height=n}function j(t,e,i,n){const o=i.padding;let{x:a,y:r}=e;for(const h of t){const t=h.box,l=n[h.stack]||{count:1,placed:0,weight:1},c=h.stackWeight/l.weight||1;if(h.horizontal){const n=e.w*c,a=l.size||t.height;(0,s.h)(l.start)&amp;&amp;(r=l.start),t.fullSize?V(t,o.left,r,i.outerWidth-o.right-o.left,a):V(t,e.left+l.placed,r,n,a),l.start=r,l.placed+=n,r=t.bottom}else{const n=e.h*c,r=l.size||t.width;(0,s.h)(l.start)&amp;&amp;(a=l.start),t.fullSize?V(t,a,o.top,r,i.outerHeight-o.bottom-o.top):V(t,a,e.top+l.placed,r,n),l.start=a,l.placed+=n,a=t.right}}e.x=a,e.y=r}var W={addBox(t,e){t.boxes||(t.boxes=[]),e.fullSize=e.fullSize||!1,e.position=e.position||"top",e.weight=e.weight||0,e._layers=e._layers||function(){return[{z:0,draw(t){e.draw(t)}}]},t.boxes.push(e)},removeBox(t,e){const i=t.boxes?t.boxes.indexOf(e):-1;-1!==i&amp;&amp;t.boxes.splice(i,1)},configure(t,e,i){e.fullSize=i.fullSize,e.position=i.position,e.weight=i.weight},update(t,e,i,n){if(!t)return;const o=(0,s.E)(t.options.layout.padding),a=Math.max(e-o.width,0),r=Math.max(i-o.height,0),h=function(t){const e=function(t){const e=[];let i,s,n,o,a,r;for(i=0,s=(t||[]).length;i&lt;s;++i)n=t[i],({position:o,options:{stack:a,stackWeight:r=1}}=n),e.push({index:i,box:n,pos:o,horizontal:n.isHorizontal(),weight:n.weight,stack:a&amp;&amp;o+a,stackWeight:r});return e}(t),i=I(e.filter((t=&gt;t.box.fullSize)),!0),s=I(P(e,"left"),!0),n=I(P(e,"right")),o=I(P(e,"top"),!0),a=I(P(e,"bottom")),r=T(e,"x"),h=T(e,"y");return{fullSize:i,leftAndTop:s.concat(o),rightAndBottom:n.concat(h).concat(a).concat(r),chartArea:P(e,"chartArea"),vertical:s.concat(n).concat(h),horizontal:o.concat(a).concat(r)}}(t.boxes),l=h.vertical,c=h.horizontal;(0,s.F)(t.boxes,(t=&gt;{"function"===typeof t.beforeLayout&amp;&amp;t.beforeLayout()}));const d=l.reduce(((t,e)=&gt;e.box.options&amp;&amp;!1===e.box.options.display?t:t+1),0)||1,u=Object.freeze({outerWidth:e,outerHeight:i,padding:o,availableWidth:a,availableHeight:r,vBoxMaxWidth:a/2/d,hBoxMaxHeight:r/2}),g=Object.assign({},o);z(g,(0,s.E)(n));const f=Object.assign({maxPadding:g,w:a,h:r,x:o.left,y:o.top},o),p=L(l.concat(c),u);H(h.fullSize,f,u,p),H(l,f,u,p),H(c,f,u,p)&amp;&amp;H(l,f,u,p),function(t){const e=t.maxPadding;function i(i){const s=Math.max(e[i]-t[i],0);return t[i]+=s,s}t.y+=i("top"),t.x+=i("left"),i("right"),i("bottom")}(f),j(h.leftAndTop,f,u,p),f.x+=f.w,f.y+=f.h,j(h.rightAndBottom,f,u,p),t.chartArea={left:f.left,top:f.top,right:f.left+f.w,bottom:f.top+f.h,height:f.h,width:f.w},(0,s.F)(h.chartArea,(e=&gt;{const i=e.box;Object.assign(i,t.chartArea),i.update(f.w,f.h,{left:0,top:0,right:0,bottom:0})}))}};class ${acquireContext(t,e){}releaseContext(t){return!1}addEventListener(t,e,i){}removeEventListener(t,e,i){}getDevicePixelRatio(){return 1}getMaximumSize(t,e,i,s){return e=Math.max(0,e||t.width),i=i||t.height,{width:e,height:Math.max(0,s?Math.floor(e/s):i)}}isAttached(t){return!0}updateConfig(t){}}class N extends ${acquireContext(t){return t&amp;&amp;t.getContext&amp;&amp;t.getContext("2d")||null}updateConfig(t){t.options.animation=!1}}const U={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup",pointerenter:"mouseenter",pointerdown:"mousedown",pointermove:"mousemove",pointerup:"mouseup",pointerleave:"mouseout",pointerout:"mouseout"},Y=t=&gt;null===t||""===t;const X=!!s.K&amp;&amp;{passive:!0};function Q(t,e,i){t&amp;&amp;t.canvas&amp;&amp;t.canvas.removeEventListener(e,i,X)}function K(t,e){for(const i of t)if(i===e||i.contains(e))return!0}function q(t,e,i){const s=t.canvas,n=new MutationObserver((t=&gt;{let e=!1;for(const i of t)e=e||K(i.addedNodes,s),e=e&amp;&amp;!K(i.removedNodes,s);e&amp;&amp;i()}));return n.observe(document,{childList:!0,subtree:!0}),n}function G(t,e,i){const s=t.canvas,n=new MutationObserver((t=&gt;{let e=!1;for(const i of t)e=e||K(i.removedNodes,s),e=e&amp;&amp;!K(i.addedNodes,s);e&amp;&amp;i()}));return n.observe(document,{childList:!0,subtree:!0}),n}const J=new Map;let Z=0;function tt(){const t=window.devicePixelRatio;t!==Z&amp;&amp;(Z=t,J.forEach(((e,i)=&gt;{i.currentDevicePixelRatio!==t&amp;&amp;e()})))}function et(t,e,i){const n=t.canvas,o=n&amp;&amp;(0,s.I)(n);if(!o)return;const a=(0,s.L)(((t,e)=&gt;{const s=o.clientWidth;i(t,e),s&lt;o.clientWidth&amp;&amp;i()}),window),r=new ResizeObserver((t=&gt;{const e=t[0],i=e.contentRect.width,s=e.contentRect.height;0===i&amp;&amp;0===s||a(i,s)}));return r.observe(o),function(t,e){J.size||window.addEventListener("resize",tt),J.set(t,e)}(t,a),r}function it(t,e,i){i&amp;&amp;i.disconnect(),"resize"===e&amp;&amp;function(t){J.delete(t),J.size||window.removeEventListener("resize",tt)}(t)}function st(t,e,i){const n=t.canvas,o=(0,s.L)((e=&gt;{null!==t.ctx&amp;&amp;i(function(t,e){const i=U[t.type]||t.type,{x:n,y:o}=(0,s.z)(t,e);return{type:i,chart:e,native:t,x:void 0!==n?n:null,y:void 0!==o?o:null}}(e,t))}),t);return function(t,e,i){t&amp;&amp;t.addEventListener(e,i,X)}(n,e,o),o}class nt extends ${acquireContext(t,e){const i=t&amp;&amp;t.getContext&amp;&amp;t.getContext("2d");return i&amp;&amp;i.canvas===t?(function(t,e){const i=t.style,n=t.getAttribute("height"),o=t.getAttribute("width");if(t.$chartjs={initial:{height:n,width:o,style:{display:i.display,height:i.height,width:i.width}}},i.display=i.display||"block",i.boxSizing=i.boxSizing||"border-box",Y(o)){const e=(0,s.J)(t,"width");void 0!==e&amp;&amp;(t.width=e)}if(Y(n))if(""===t.style.height)t.height=t.width/(e||2);else{const e=(0,s.J)(t,"height");void 0!==e&amp;&amp;(t.height=e)}}(t,e),i):null}releaseContext(t){const e=t.canvas;if(!e.$chartjs)return!1;const i=e.$chartjs.initial;["height","width"].forEach((t=&gt;{const n=i[t];(0,s.k)(n)?e.removeAttribute(t):e.setAttribute(t,n)}));const n=i.style||{};return Object.keys(n).forEach((t=&gt;{e.style[t]=n[t]})),e.width=e.width,delete e.$chartjs,!0}addEventListener(t,e,i){this.removeEventListener(t,e);const s=t.$proxies||(t.$proxies={}),n={attach:q,detach:G,resize:et}[e]||st;s[e]=n(t,e,i)}removeEventListener(t,e){const i=t.$proxies||(t.$proxies={}),s=i[e];if(!s)return;({attach:it,detach:it,resize:it}[e]||Q)(t,e,s),i[e]=void 0}getDevicePixelRatio(){return window.devicePixelRatio}getMaximumSize(t,e,i,n){return(0,s.G)(t,e,i,n)}isAttached(t){const e=t&amp;&amp;(0,s.I)(t);return!(!e||!e.isConnected)}}class ot{static defaults={};static defaultRoutes=void 0;x;y;active=!1;options;$animations;tooltipPosition(t){const{x:e,y:i}=this.getProps(["x","y"],t);return{x:e,y:i}}hasValue(){return(0,s.x)(this.x)&amp;&amp;(0,s.x)(this.y)}getProps(t,e){const i=this.$animations;if(!e||!i)return this;const s={};return t.forEach((t=&gt;{s[t]=i[t]&amp;&amp;i[t].active()?i[t]._to:this[t]})),s}}function at(t,e){const i=t.options.ticks,n=function(t){const e=t.options.offset,i=t._tickSize(),s=t._length/i+(e?0:1),n=t._maxLength/i;return Math.floor(Math.min(s,n))}(t),o=Math.min(i.maxTicksLimit||n,n),a=i.major.enabled?function(t){const e=[];let i,s;for(i=0,s=t.length;i&lt;s;i++)t[i].major&amp;&amp;e.push(i);return e}(e):[],r=a.length,h=a[0],l=a[r-1],c=[];if(r&gt;o)return function(t,e,i,s){let n,o=0,a=i[0];for(s=Math.ceil(s),n=0;n&lt;t.length;n++)n===a&amp;&amp;(e.push(t[n]),o++,a=i[o*s])}(e,c,a,r/o),c;const d=function(t,e,i){const n=function(t){const e=t.length;let i,s;if(e&lt;2)return!1;for(s=t[0],i=1;i&lt;e;++i)if(t[i]-t[i-1]!==s)return!1;return s}(t),o=e.length/i;if(!n)return Math.max(o,1);const a=(0,s.N)(n);for(let s=0,r=a.length-1;s&lt;r;s++){const t=a[s];if(t&gt;o)return t}return Math.max(o,1)}(a,e,o);if(r&gt;0){let t,i;const n=r&gt;1?Math.round((l-h)/(r-1)):null;for(rt(e,c,d,(0,s.k)(n)?0:h-n,h),t=0,i=r-1;t&lt;i;t++)rt(e,c,d,a[t],a[t+1]);return rt(e,c,d,l,(0,s.k)(n)?e.length:l+n),c}return rt(e,c,d),c}function rt(t,e,i,n,o){const a=(0,s.v)(n,0),r=Math.min((0,s.v)(o,t.length),t.length);let h,l,c,d=0;for(i=Math.ceil(i),o&amp;&amp;(h=o-n,i=h/Math.floor(h/i)),c=a;c&lt;0;)d++,c=Math.round(a+d*i);for(l=Math.max(a,0);l&lt;r;l++)l===c&amp;&amp;(e.push(t[l]),d++,c=Math.round(a+d*i))}const ht=(t,e,i)=&gt;"top"===e||"left"===e?t[e]+i:t[e]-i,lt=(t,e)=&gt;Math.min(e||t,t);function ct(t,e){const i=[],s=t.length/e,n=t.length;let o=0;for(;o&lt;n;o+=s)i.push(t[Math.floor(o)]);return i}function dt(t,e,i){const s=t.ticks.length,n=Math.min(e,s-1),o=t._startPixel,a=t._endPixel,r=1e-6;let h,l=t.getPixelForTick(n);if(!(i&amp;&amp;(h=1===s?Math.max(l-o,a-l):0===e?(t.getPixelForTick(1)-l)/2:(l-t.getPixelForTick(n-1))/2,l+=n&lt;e?h:-h,l&lt;o-r||l&gt;a+r)))return l}function ut(t){return t.drawTicks?t.tickLength:0}function gt(t,e){if(!t.display)return 0;const i=(0,s.a0)(t.font,e),n=(0,s.E)(t.padding);return((0,s.b)(t.text)?t.text.length:1)*i.lineHeight+n.height}function ft(t,e,i){let n=(0,s.a1)(t);return(i&amp;&amp;"right"!==e||!i&amp;&amp;"right"===e)&amp;&amp;(n=(t=&gt;"left"===t?"right":"right"===t?"left":t)(n)),n}class pt extends ot{constructor(t){super(),this.id=t.id,this.type=t.type,this.options=void 0,this.ctx=t.ctx,this.chart=t.chart,this.top=void 0,this.bottom=void 0,this.left=void 0,this.right=void 0,this.width=void 0,this.height=void 0,this._margins={left:0,right:0,top:0,bottom:0},this.maxWidth=void 0,this.maxHeight=void 0,this.paddingTop=void 0,this.paddingBottom=void 0,this.paddingLeft=void 0,this.paddingRight=void 0,this.axis=void 0,this.labelRotation=void 0,this.min=void 0,this.max=void 0,this._range=void 0,this.ticks=[],this._gridLineItems=null,this._labelItems=null,this._labelSizes=null,this._length=0,this._maxLength=0,this._longestTextCache={},this._startPixel=void 0,this._endPixel=void 0,this._reversePixels=!1,this._userMax=void 0,this._userMin=void 0,this._suggestedMax=void 0,this._suggestedMin=void 0,this._ticksLength=0,this._borderValue=0,this._cache={},this._dataLimitsCached=!1,this.$context=void 0}init(t){this.options=t.setContext(this.getContext()),this.axis=t.axis,this._userMin=this.parse(t.min),this._userMax=this.parse(t.max),this._suggestedMin=this.parse(t.suggestedMin),this._suggestedMax=this.parse(t.suggestedMax)}parse(t,e){return t}getUserBounds(){let{_userMin:t,_userMax:e,_suggestedMin:i,_suggestedMax:n}=this;return t=(0,s.O)(t,Number.POSITIVE_INFINITY),e=(0,s.O)(e,Number.NEGATIVE_INFINITY),i=(0,s.O)(i,Number.POSITIVE_INFINITY),n=(0,s.O)(n,Number.NEGATIVE_INFINITY),{min:(0,s.O)(t,i),max:(0,s.O)(e,n),minDefined:(0,s.g)(t),maxDefined:(0,s.g)(e)}}getMinMax(t){let e,{min:i,max:n,minDefined:o,maxDefined:a}=this.getUserBounds();if(o&amp;&amp;a)return{min:i,max:n};const r=this.getMatchingVisibleMetas();for(let s=0,h=r.length;s&lt;h;++s)e=r[s].controller.getMinMax(this,t),o||(i=Math.min(i,e.min)),a||(n=Math.max(n,e.max));return i=a&amp;&amp;i&gt;n?n:i,n=o&amp;&amp;i&gt;n?i:n,{min:(0,s.O)(i,(0,s.O)(n,i)),max:(0,s.O)(n,(0,s.O)(i,n))}}getPadding(){return{left:this.paddingLeft||0,top:this.paddingTop||0,right:this.paddingRight||0,bottom:this.paddingBottom||0}}getTicks(){return this.ticks}getLabels(){const t=this.chart.data;return this.options.labels||(this.isHorizontal()?t.xLabels:t.yLabels)||t.labels||[]}getLabelItems(t=this.chart.chartArea){return this._labelItems||(this._labelItems=this._computeLabelItems(t))}beforeLayout(){this._cache={},this._dataLimitsCached=!1}beforeUpdate(){(0,s.Q)(this.options.beforeUpdate,[this])}update(t,e,i){const{beginAtZero:n,grace:o,ticks:a}=this.options,r=a.sampleSize;this.beforeUpdate(),this.maxWidth=t,this.maxHeight=e,this._margins=i=Object.assign({left:0,right:0,top:0,bottom:0},i),this.ticks=null,this._labelSizes=null,this._gridLineItems=null,this._labelItems=null,this.beforeSetDimensions(),this.setDimensions(),this.afterSetDimensions(),this._maxLength=this.isHorizontal()?this.width+i.left+i.right:this.height+i.top+i.bottom,this._dataLimitsCached||(this.beforeDataLimits(),this.determineDataLimits(),this.afterDataLimits(),this._range=(0,s.R)(this,o,n),this._dataLimitsCached=!0),this.beforeBuildTicks(),this.ticks=this.buildTicks()||[],this.afterBuildTicks();const h=r&lt;this.ticks.length;this._convertTicksToLabels(h?ct(this.ticks,r):this.ticks),this.configure(),this.beforeCalculateLabelRotation(),this.calculateLabelRotation(),this.afterCalculateLabelRotation(),a.display&amp;&amp;(a.autoSkip||"auto"===a.source)&amp;&amp;(this.ticks=at(this,this.ticks),this._labelSizes=null,this.afterAutoSkip()),h&amp;&amp;this._convertTicksToLabels(this.ticks),this.beforeFit(),this.fit(),this.afterFit(),this.afterUpdate()}configure(){let t,e,i=this.options.reverse;this.isHorizontal()?(t=this.left,e=this.right):(t=this.top,e=this.bottom,i=!i),this._startPixel=t,this._endPixel=e,this._reversePixels=i,this._length=e-t,this._alignToPixels=this.options.alignToPixels}afterUpdate(){(0,s.Q)(this.options.afterUpdate,[this])}beforeSetDimensions(){(0,s.Q)(this.options.beforeSetDimensions,[this])}setDimensions(){this.isHorizontal()?(this.width=this.maxWidth,this.left=0,this.right=this.width):(this.height=this.maxHeight,this.top=0,this.bottom=this.height),this.paddingLeft=0,this.paddingTop=0,this.paddingRight=0,this.paddingBottom=0}afterSetDimensions(){(0,s.Q)(this.options.afterSetDimensions,[this])}_callHooks(t){this.chart.notifyPlugins(t,this.getContext()),(0,s.Q)(this.options[t],[this])}beforeDataLimits(){this._callHooks("beforeDataLimits")}determineDataLimits(){}afterDataLimits(){this._callHooks("afterDataLimits")}beforeBuildTicks(){this._callHooks("beforeBuildTicks")}buildTicks(){return[]}afterBuildTicks(){this._callHooks("afterBuildTicks")}beforeTickToLabelConversion(){(0,s.Q)(this.options.beforeTickToLabelConversion,[this])}generateTickLabels(t){const e=this.options.ticks;let i,n,o;for(i=0,n=t.length;i&lt;n;i++)o=t[i],o.label=(0,s.Q)(e.callback,[o.value,i,t],this)}afterTickToLabelConversion(){(0,s.Q)(this.options.afterTickToLabelConversion,[this])}beforeCalculateLabelRotation(){(0,s.Q)(this.options.beforeCalculateLabelRotation,[this])}calculateLabelRotation(){const t=this.options,e=t.ticks,i=lt(this.ticks.length,t.ticks.maxTicksLimit),n=e.minRotation||0,o=e.maxRotation;let a,r,h,l=n;if(!this._isVisible()||!e.display||n&gt;=o||i&lt;=1||!this.isHorizontal())return void(this.labelRotation=n);const c=this._getLabelSizes(),d=c.widest.width,u=c.highest.height,g=(0,s.S)(this.chart.width-d,0,this.maxWidth);a=t.offset?this.maxWidth/i:g/(i-1),d+6&gt;a&amp;&amp;(a=g/(i-(t.offset?.5:1)),r=this.maxHeight-ut(t.grid)-e.padding-gt(t.title,this.chart.options.font),h=Math.sqrt(d*d+u*u),l=(0,s.U)(Math.min(Math.asin((0,s.S)((c.highest.height+6)/a,-1,1)),Math.asin((0,s.S)(r/h,-1,1))-Math.asin((0,s.S)(u/h,-1,1)))),l=Math.max(n,Math.min(o,l))),this.labelRotation=l}afterCalculateLabelRotation(){(0,s.Q)(this.options.afterCalculateLabelRotation,[this])}afterAutoSkip(){}beforeFit(){(0,s.Q)(this.options.beforeFit,[this])}fit(){const t={width:0,height:0},{chart:e,options:{ticks:i,title:n,grid:o}}=this,a=this._isVisible(),r=this.isHorizontal();if(a){const a=gt(n,e.options.font);if(r?(t.width=this.maxWidth,t.height=ut(o)+a):(t.height=this.maxHeight,t.width=ut(o)+a),i.display&amp;&amp;this.ticks.length){const{first:e,last:n,widest:o,highest:a}=this._getLabelSizes(),h=2*i.padding,l=(0,s.t)(this.labelRotation),c=Math.cos(l),d=Math.sin(l);if(r){const e=i.mirror?0:d*o.width+c*a.height;t.height=Math.min(this.maxHeight,t.height+e+h)}else{const e=i.mirror?0:c*o.width+d*a.height;t.width=Math.min(this.maxWidth,t.width+e+h)}this._calculatePadding(e,n,d,c)}}this._handleMargins(),r?(this.width=this._length=e.width-this._margins.left-this._margins.right,this.height=t.height):(this.width=t.width,this.height=this._length=e.height-this._margins.top-this._margins.bottom)}_calculatePadding(t,e,i,s){const{ticks:{align:n,padding:o},position:a}=this.options,r=0!==this.labelRotation,h="top"!==a&amp;&amp;"x"===this.axis;if(this.isHorizontal()){const a=this.getPixelForTick(0)-this.left,l=this.right-this.getPixelForTick(this.ticks.length-1);let c=0,d=0;r?h?(c=s*t.width,d=i*e.height):(c=i*t.height,d=s*e.width):"start"===n?d=e.width:"end"===n?c=t.width:"inner"!==n&amp;&amp;(c=t.width/2,d=e.width/2),this.paddingLeft=Math.max((c-a+o)*this.width/(this.width-a),0),this.paddingRight=Math.max((d-l+o)*this.width/(this.width-l),0)}else{let i=e.height/2,s=t.height/2;"start"===n?(i=0,s=t.height):"end"===n&amp;&amp;(i=e.height,s=0),this.paddingTop=i+o,this.paddingBottom=s+o}}_handleMargins(){this._margins&amp;&amp;(this._margins.left=Math.max(this.paddingLeft,this._margins.left),this._margins.top=Math.max(this.paddingTop,this._margins.top),this._margins.right=Math.max(this.paddingRight,this._margins.right),this._margins.bottom=Math.max(this.paddingBottom,this._margins.bottom))}afterFit(){(0,s.Q)(this.options.afterFit,[this])}isHorizontal(){const{axis:t,position:e}=this.options;return"top"===e||"bottom"===e||"x"===t}isFullSize(){return this.options.fullSize}_convertTicksToLabels(t){let e,i;for(this.beforeTickToLabelConversion(),this.generateTickLabels(t),e=0,i=t.length;e&lt;i;e++)(0,s.k)(t[e].label)&amp;&amp;(t.splice(e,1),i--,e--);this.afterTickToLabelConversion()}_getLabelSizes(){let t=this._labelSizes;if(!t){const e=this.options.ticks.sampleSize;let i=this.ticks;e&lt;i.length&amp;&amp;(i=ct(i,e)),this._labelSizes=t=this._computeLabelSizes(i,i.length,this.options.ticks.maxTicksLimit)}return t}_computeLabelSizes(t,e,i){const{ctx:n,_longestTextCache:o}=this,a=[],r=[],h=Math.floor(e/lt(e,i));let l,c,d,u,g,f,p,x,_,m,b,y=0,v=0;for(l=0;l&lt;e;l+=h){if(u=t[l].label,g=this._resolveTickFontOptions(l),n.font=f=g.string,p=o[f]=o[f]||{data:{},gc:[]},x=g.lineHeight,_=m=0,(0,s.k)(u)||(0,s.b)(u)){if((0,s.b)(u))for(c=0,d=u.length;c&lt;d;++c)b=u[c],(0,s.k)(b)||(0,s.b)(b)||(_=(0,s.V)(n,p.data,p.gc,_,b),m+=x)}else _=(0,s.V)(n,p.data,p.gc,_,u),m=x;a.push(_),r.push(m),y=Math.max(_,y),v=Math.max(m,v)}!function(t,e){(0,s.F)(t,(t=&gt;{const i=t.gc,s=i.length/2;let n;if(s&gt;e){for(n=0;n&lt;s;++n)delete t.data[i[n]];i.splice(0,s)}}))}(o,e);const w=a.indexOf(y),M=r.indexOf(v),k=t=&gt;({width:a[t]||0,height:r[t]||0});return{first:k(0),last:k(e-1),widest:k(w),highest:k(M),widths:a,heights:r}}getLabelForValue(t){return t}getPixelForValue(t,e){return NaN}getValueForPixel(t){}getPixelForTick(t){const e=this.ticks;return t&lt;0||t&gt;e.length-1?null:this.getPixelForValue(e[t].value)}getPixelForDecimal(t){this._reversePixels&amp;&amp;(t=1-t);const e=this._startPixel+t*this._length;return(0,s.W)(this._alignToPixels?(0,s.X)(this.chart,e,0):e)}getDecimalForPixel(t){const e=(t-this._startPixel)/this._length;return this._reversePixels?1-e:e}getBasePixel(){return this.getPixelForValue(this.getBaseValue())}getBaseValue(){const{min:t,max:e}=this;return t&lt;0&amp;&amp;e&lt;0?e:t&gt;0&amp;&amp;e&gt;0?t:0}getContext(t){const e=this.ticks||[];if(t&gt;=0&amp;&amp;t&lt;e.length){const i=e[t];return i.$context||(i.$context=function(t,e,i){return(0,s.j)(t,{tick:i,index:e,type:"tick"})}(this.getContext(),t,i))}return this.$context||(this.$context=(i=this.chart.getContext(),n=this,(0,s.j)(i,{scale:n,type:"scale"})));var i,n}_tickSize(){const t=this.options.ticks,e=(0,s.t)(this.labelRotation),i=Math.abs(Math.cos(e)),n=Math.abs(Math.sin(e)),o=this._getLabelSizes(),a=t.autoSkipPadding||0,r=o?o.widest.width+a:0,h=o?o.highest.height+a:0;return this.isHorizontal()?h*i&gt;r*n?r/i:h/n:h*n&lt;r*i?h/i:r/n}_isVisible(){const t=this.options.display;return"auto"!==t?!!t:this.getMatchingVisibleMetas().length&gt;0}_computeGridLineItems(t){const e=this.axis,i=this.chart,n=this.options,{grid:o,position:a,border:r}=n,h=o.offset,l=this.isHorizontal(),c=this.ticks.length+(h?1:0),d=ut(o),u=[],g=r.setContext(this.getContext()),f=g.display?g.width:0,p=f/2,x=function(t){return(0,s.X)(i,t,f)};let _,m,b,y,v,w,M,k,S,D,A,C;if("top"===a)_=x(this.bottom),w=this.bottom-d,k=_-p,D=x(t.top)+p,C=t.bottom;else if("bottom"===a)_=x(this.top),D=t.top,C=x(t.bottom)-p,w=_+p,k=this.top+d;else if("left"===a)_=x(this.right),v=this.right-d,M=_-p,S=x(t.left)+p,A=t.right;else if("right"===a)_=x(this.left),S=t.left,A=x(t.right)-p,v=_+p,M=this.left+d;else if("x"===e){if("center"===a)_=x((t.top+t.bottom)/2+.5);else if((0,s.i)(a)){const t=Object.keys(a)[0],e=a[t];_=x(this.chart.scales[t].getPixelForValue(e))}D=t.top,C=t.bottom,w=_+p,k=w+d}else if("y"===e){if("center"===a)_=x((t.left+t.right)/2);else if((0,s.i)(a)){const t=Object.keys(a)[0],e=a[t];_=x(this.chart.scales[t].getPixelForValue(e))}v=_-p,M=v-d,S=t.left,A=t.right}const E=(0,s.v)(n.ticks.maxTicksLimit,c),O=Math.max(1,Math.ceil(c/E));for(m=0;m&lt;c;m+=O){const t=this.getContext(m),e=o.setContext(t),n=r.setContext(t),a=e.lineWidth,c=e.color,d=n.dash||[],g=n.dashOffset,f=e.tickWidth,p=e.tickColor,x=e.tickBorderDash||[],_=e.tickBorderDashOffset;b=dt(this,m,h),void 0!==b&amp;&amp;(y=(0,s.X)(i,b,a),l?v=M=S=A=y:w=k=D=C=y,u.push({tx1:v,ty1:w,tx2:M,ty2:k,x1:S,y1:D,x2:A,y2:C,width:a,color:c,borderDash:d,borderDashOffset:g,tickWidth:f,tickColor:p,tickBorderDash:x,tickBorderDashOffset:_}))}return this._ticksLength=c,this._borderValue=_,u}_computeLabelItems(t){const e=this.axis,i=this.options,{position:n,ticks:o}=i,a=this.isHorizontal(),r=this.ticks,{align:h,crossAlign:l,padding:c,mirror:d}=o,u=ut(i.grid),g=u+c,f=d?-c:g,p=-(0,s.t)(this.labelRotation),x=[];let _,m,b,y,v,w,M,k,S,D,A,C,E="middle";if("top"===n)w=this.bottom-f,M=this._getXAxisLabelAlignment();else if("bottom"===n)w=this.top+f,M=this._getXAxisLabelAlignment();else if("left"===n){const t=this._getYAxisLabelAlignment(u);M=t.textAlign,v=t.x}else if("right"===n){const t=this._getYAxisLabelAlignment(u);M=t.textAlign,v=t.x}else if("x"===e){if("center"===n)w=(t.top+t.bottom)/2+g;else if((0,s.i)(n)){const t=Object.keys(n)[0],e=n[t];w=this.chart.scales[t].getPixelForValue(e)+g}M=this._getXAxisLabelAlignment()}else if("y"===e){if("center"===n)v=(t.left+t.right)/2-g;else if((0,s.i)(n)){const t=Object.keys(n)[0],e=n[t];v=this.chart.scales[t].getPixelForValue(e)}M=this._getYAxisLabelAlignment(u).textAlign}"y"===e&amp;&amp;("start"===h?E="top":"end"===h&amp;&amp;(E="bottom"));const O=this._getLabelSizes();for(_=0,m=r.length;_&lt;m;++_){b=r[_],y=b.label;const t=o.setContext(this.getContext(_));k=this.getPixelForTick(_)+o.labelOffset,S=this._resolveTickFontOptions(_),D=S.lineHeight,A=(0,s.b)(y)?y.length:1;const e=A/2,i=t.color,h=t.textStrokeColor,c=t.textStrokeWidth;let u,g=M;if(a?(v=k,"inner"===M&amp;&amp;(g=_===m-1?this.options.reverse?"left":"right":0===_?this.options.reverse?"right":"left":"center"),C="top"===n?"near"===l||0!==p?-A*D+D/2:"center"===l?-O.highest.height/2-e*D+D:-O.highest.height+D/2:"near"===l||0!==p?D/2:"center"===l?O.highest.height/2-e*D:O.highest.height-A*D,d&amp;&amp;(C*=-1),0===p||t.showLabelBackdrop||(v+=D/2*Math.sin(p))):(w=k,C=(1-A)*D/2),t.showLabelBackdrop){const e=(0,s.E)(t.backdropPadding),i=O.heights[_],n=O.widths[_];let o=C-e.top,a=0-e.left;switch(E){case"middle":o-=i/2;break;case"bottom":o-=i}switch(M){case"center":a-=n/2;break;case"right":a-=n;break;case"inner":_===m-1?a-=n:_&gt;0&amp;&amp;(a-=n/2)}u={left:a,top:o,width:n+e.width,height:i+e.height,color:t.backdropColor}}x.push({label:y,font:S,textOffset:C,options:{rotation:p,color:i,strokeColor:h,strokeWidth:c,textAlign:g,textBaseline:E,translation:[v,w],backdrop:u}})}return x}_getXAxisLabelAlignment(){const{position:t,ticks:e}=this.options;if(-(0,s.t)(this.labelRotation))return"top"===t?"left":"right";let i="center";return"start"===e.align?i="left":"end"===e.align?i="right":"inner"===e.align&amp;&amp;(i="inner"),i}_getYAxisLabelAlignment(t){const{position:e,ticks:{crossAlign:i,mirror:s,padding:n}}=this.options,o=t+n,a=this._getLabelSizes().widest.width;let r,h;return"left"===e?s?(h=this.right+n,"near"===i?r="left":"center"===i?(r="center",h+=a/2):(r="right",h+=a)):(h=this.right-o,"near"===i?r="right":"center"===i?(r="center",h-=a/2):(r="left",h=this.left)):"right"===e?s?(h=this.left+n,"near"===i?r="right":"center"===i?(r="center",h-=a/2):(r="left",h-=a)):(h=this.left+o,"near"===i?r="left":"center"===i?(r="center",h+=a/2):(r="right",h=this.right)):r="right",{textAlign:r,x:h}}_computeLabelArea(){if(this.options.ticks.mirror)return;const t=this.chart,e=this.options.position;return"left"===e||"right"===e?{top:0,left:this.left,bottom:t.height,right:this.right}:"top"===e||"bottom"===e?{top:this.top,left:0,bottom:this.bottom,right:t.width}:void 0}drawBackground(){const{ctx:t,options:{backgroundColor:e},left:i,top:s,width:n,height:o}=this;e&amp;&amp;(t.save(),t.fillStyle=e,t.fillRect(i,s,n,o),t.restore())}getLineWidthForValue(t){const e=this.options.grid;if(!this._isVisible()||!e.display)return 0;const i=this.ticks.findIndex((e=&gt;e.value===t));if(i&gt;=0){return e.setContext(this.getContext(i)).lineWidth}return 0}drawGrid(t){const e=this.options.grid,i=this.ctx,s=this._gridLineItems||(this._gridLineItems=this._computeGridLineItems(t));let n,o;const a=(t,e,s)=&gt;{s.width&amp;&amp;s.color&amp;&amp;(i.save(),i.lineWidth=s.width,i.strokeStyle=s.color,i.setLineDash(s.borderDash||[]),i.lineDashOffset=s.borderDashOffset,i.beginPath(),i.moveTo(t.x,t.y),i.lineTo(e.x,e.y),i.stroke(),i.restore())};if(e.display)for(n=0,o=s.length;n&lt;o;++n){const t=s[n];e.drawOnChartArea&amp;&amp;a({x:t.x1,y:t.y1},{x:t.x2,y:t.y2},t),e.drawTicks&amp;&amp;a({x:t.tx1,y:t.ty1},{x:t.tx2,y:t.ty2},{color:t.tickColor,width:t.tickWidth,borderDash:t.tickBorderDash,borderDashOffset:t.tickBorderDashOffset})}}drawBorder(){const{chart:t,ctx:e,options:{border:i,grid:n}}=this,o=i.setContext(this.getContext()),a=i.display?o.width:0;if(!a)return;const r=n.setContext(this.getContext(0)).lineWidth,h=this._borderValue;let l,c,d,u;this.isHorizontal()?(l=(0,s.X)(t,this.left,a)-a/2,c=(0,s.X)(t,this.right,r)+r/2,d=u=h):(d=(0,s.X)(t,this.top,a)-a/2,u=(0,s.X)(t,this.bottom,r)+r/2,l=c=h),e.save(),e.lineWidth=o.width,e.strokeStyle=o.color,e.beginPath(),e.moveTo(l,d),e.lineTo(c,u),e.stroke(),e.restore()}drawLabels(t){if(!this.options.ticks.display)return;const e=this.ctx,i=this._computeLabelArea();i&amp;&amp;(0,s.Y)(e,i);const n=this.getLabelItems(t);for(const o of n){const t=o.options,i=o.font,n=o.label,a=o.textOffset;(0,s.Z)(e,n,0,a,i,t)}i&amp;&amp;(0,s.$)(e)}drawTitle(){const{ctx:t,options:{position:e,title:i,reverse:n}}=this;if(!i.display)return;const o=(0,s.a0)(i.font),a=(0,s.E)(i.padding),r=i.align;let h=o.lineHeight/2;"bottom"===e||"center"===e||(0,s.i)(e)?(h+=a.bottom,(0,s.b)(i.text)&amp;&amp;(h+=o.lineHeight*(i.text.length-1))):h+=a.top;const{titleX:l,titleY:c,maxWidth:d,rotation:u}=function(t,e,i,n){const{top:o,left:a,bottom:r,right:h,chart:l}=t,{chartArea:c,scales:d}=l;let u,g,f,p=0;const x=r-o,_=h-a;if(t.isHorizontal()){if(g=(0,s.a2)(n,a,h),(0,s.i)(i)){const t=Object.keys(i)[0],s=i[t];f=d[t].getPixelForValue(s)+x-e}else f="center"===i?(c.bottom+c.top)/2+x-e:ht(t,i,e);u=h-a}else{if((0,s.i)(i)){const t=Object.keys(i)[0],s=i[t];g=d[t].getPixelForValue(s)-_+e}else g="center"===i?(c.left+c.right)/2-_+e:ht(t,i,e);f=(0,s.a2)(n,r,o),p="left"===i?-s.H:s.H}return{titleX:g,titleY:f,maxWidth:u,rotation:p}}(this,h,e,r);(0,s.Z)(t,i.text,0,0,o,{color:i.color,maxWidth:d,rotation:u,textAlign:ft(r,e,n),textBaseline:"middle",translation:[l,c]})}draw(t){this._isVisible()&amp;&amp;(this.drawBackground(),this.drawGrid(t),this.drawBorder(),this.drawTitle(),this.drawLabels(t))}_layers(){const t=this.options,e=t.ticks&amp;&amp;t.ticks.z||0,i=(0,s.v)(t.grid&amp;&amp;t.grid.z,-1),n=(0,s.v)(t.border&amp;&amp;t.border.z,0);return this._isVisible()&amp;&amp;this.draw===pt.prototype.draw?[{z:i,draw:t=&gt;{this.drawBackground(),this.drawGrid(t),this.drawTitle()}},{z:n,draw:()=&gt;{this.drawBorder()}},{z:e,draw:t=&gt;{this.drawLabels(t)}}]:[{z:e,draw:t=&gt;{this.draw(t)}}]}getMatchingVisibleMetas(t){const e=this.chart.getSortedVisibleDatasetMetas(),i=this.axis+"AxisID",s=[];let n,o;for(n=0,o=e.length;n&lt;o;++n){const o=e[n];o[i]!==this.id||t&amp;&amp;o.type!==t||s.push(o)}return s}_resolveTickFontOptions(t){const e=this.options.ticks.setContext(this.getContext(t));return(0,s.a0)(e.font)}_maxDigits(){const t=this._resolveTickFontOptions(0).lineHeight;return(this.isHorizontal()?this.width:this.height)/t}}class xt{constructor(t,e,i){this.type=t,this.scope=e,this.override=i,this.items=Object.create(null)}isForType(t){return Object.prototype.isPrototypeOf.call(this.type.prototype,t.prototype)}register(t){const e=Object.getPrototypeOf(t);let i;(function(t){return"id"in t&amp;&amp;"defaults"in t})(e)&amp;&amp;(i=this.register(e));const n=this.items,o=t.id,a=this.scope+"."+o;if(!o)throw new Error("class does not have id: "+t);return o in n||(n[o]=t,function(t,e,i){const n=(0,s.a4)(Object.create(null),[i?s.d.get(i):{},s.d.get(e),t.defaults]);s.d.set(e,n),t.defaultRoutes&amp;&amp;function(t,e){Object.keys(e).forEach((i=&gt;{const n=i.split("."),o=n.pop(),a=[t].concat(n).join("."),r=e[i].split("."),h=r.pop(),l=r.join(".");s.d.route(a,o,l,h)}))}(e,t.defaultRoutes);t.descriptors&amp;&amp;s.d.describe(e,t.descriptors)}(t,a,i),this.override&amp;&amp;s.d.override(t.id,t.overrides)),a}get(t){return this.items[t]}unregister(t){const e=this.items,i=t.id,n=this.scope;i in e&amp;&amp;delete e[i],n&amp;&amp;i in s.d[n]&amp;&amp;(delete s.d[n][i],this.override&amp;&amp;delete s.a3[i])}}class _t{constructor(){this.controllers=new xt(v,"datasets",!0),this.elements=new xt(ot,"elements"),this.plugins=new xt(Object,"plugins"),this.scales=new xt(pt,"scales"),this._typedRegistries=[this.controllers,this.scales,this.elements]}add(...t){this._each("register",t)}remove(...t){this._each("unregister",t)}addControllers(...t){this._each("register",t,this.controllers)}addElements(...t){this._each("register",t,this.elements)}addPlugins(...t){this._each("register",t,this.plugins)}addScales(...t){this._each("register",t,this.scales)}getController(t){return this._get(t,this.controllers,"controller")}getElement(t){return this._get(t,this.elements,"element")}getPlugin(t){return this._get(t,this.plugins,"plugin")}getScale(t){return this._get(t,this.scales,"scale")}removeControllers(...t){this._each("unregister",t,this.controllers)}removeElements(...t){this._each("unregister",t,this.elements)}removePlugins(...t){this._each("unregister",t,this.plugins)}removeScales(...t){this._each("unregister",t,this.scales)}_each(t,e,i){[...e].forEach((e=&gt;{const n=i||this._getRegistryForType(e);i||n.isForType(e)||n===this.plugins&amp;&amp;e.id?this._exec(t,n,e):(0,s.F)(e,(e=&gt;{const s=i||this._getRegistryForType(e);this._exec(t,s,e)}))}))}_exec(t,e,i){const n=(0,s.a5)(t);(0,s.Q)(i["before"+n],[],i),e[t](i),(0,s.Q)(i["after"+n],[],i)}_getRegistryForType(t){for(let e=0;e&lt;this._typedRegistries.length;e++){const i=this._typedRegistries[e];if(i.isForType(t))return i}return this.plugins}_get(t,e,i){const s=e.get(t);if(void 0===s)throw new Error('"'+t+'" is not a registered '+i+".");return s}}var mt=new _t;class bt{constructor(){this._init=[]}notify(t,e,i,s){"beforeInit"===e&amp;&amp;(this._init=this._createDescriptors(t,!0),this._notify(this._init,t,"install"));const n=s?this._descriptors(t).filter(s):this._descriptors(t),o=this._notify(n,t,e,i);return"afterDestroy"===e&amp;&amp;(this._notify(n,t,"stop"),this._notify(this._init,t,"uninstall")),o}_notify(t,e,i,n){n=n||{};for(const o of t){const t=o.plugin,a=t[i],r=[e,n,o.options];if(!1===(0,s.Q)(a,r,t)&amp;&amp;n.cancelable)return!1}return!0}invalidate(){(0,s.k)(this._cache)||(this._oldCache=this._cache,this._cache=void 0)}_descriptors(t){if(this._cache)return this._cache;const e=this._cache=this._createDescriptors(t);return this._notifyStateChanges(t),e}_createDescriptors(t,e){const i=t&amp;&amp;t.config,n=(0,s.v)(i.options&amp;&amp;i.options.plugins,{}),o=function(t){const e={},i=[],s=Object.keys(mt.plugins.items);for(let o=0;o&lt;s.length;o++)i.push(mt.getPlugin(s[o]));const n=t.plugins||[];for(let o=0;o&lt;n.length;o++){const t=n[o];-1===i.indexOf(t)&amp;&amp;(i.push(t),e[t.id]=!0)}return{plugins:i,localIds:e}}(i);return!1!==n||e?function(t,{plugins:e,localIds:i},s,n){const o=[],a=t.getContext();for(const r of e){const e=r.id,h=yt(s[e],n);null!==h&amp;&amp;o.push({plugin:r,options:vt(t.config,{plugin:r,local:i[e]},h,a)})}return o}(t,o,n,e):[]}_notifyStateChanges(t){const e=this._oldCache||[],i=this._cache,s=(t,e)=&gt;t.filter((t=&gt;!e.some((e=&gt;t.plugin.id===e.plugin.id))));this._notify(s(e,i),t,"stop"),this._notify(s(i,e),t,"start")}}function yt(t,e){return e||!1!==t?!0===t?{}:t:null}function vt(t,{plugin:e,local:i},s,n){const o=t.pluginScopeKeys(e),a=t.getOptionScopes(s,o);return i&amp;&amp;e.defaults&amp;&amp;a.push(e.defaults),t.createResolver(a,n,[""],{scriptable:!1,indexable:!1,allKeys:!0})}function wt(t,e){const i=s.d.datasets[t]||{};return((e.datasets||{})[t]||{}).indexAxis||e.indexAxis||i.indexAxis||"x"}function Mt(t){if("x"===t||"y"===t||"r"===t)return t}function kt(t,...e){if(Mt(t))return t;for(const s of e){const e=s.axis||("top"===(i=s.position)||"bottom"===i?"x":"left"===i||"right"===i?"y":void 0)||t.length&gt;1&amp;&amp;Mt(t[0].toLowerCase());if(e)return e}var i;throw new Error(`Cannot determine type of '${t}' axis. Please provide 'axis' or 'position' option.`)}function St(t,e,i){if(i[e+"AxisID"]===t)return{axis:e}}function Dt(t,e){const i=s.a3[t.type]||{scales:{}},n=e.scales||{},o=wt(t.type,e),a=Object.create(null);return Object.keys(n).forEach((e=&gt;{const r=n[e];if(!(0,s.i)(r))return console.error(`Invalid scale configuration for scale: ${e}`);if(r._proxy)return console.warn(`Ignoring resolver passed as options for scale: ${e}`);const h=kt(e,r,function(t,e){if(e.data&amp;&amp;e.data.datasets){const i=e.data.datasets.filter((e=&gt;e.xAxisID===t||e.yAxisID===t));if(i.length)return St(t,"x",i[0])||St(t,"y",i[0])}return{}}(e,t),s.d.scales[r.type]),l=function(t,e){return t===e?"_index_":"_value_"}(h,o),c=i.scales||{};a[e]=(0,s.ab)(Object.create(null),[{axis:h},r,c[h],c[l]])})),t.data.datasets.forEach((i=&gt;{const o=i.type||t.type,r=i.indexAxis||wt(o,e),h=(s.a3[o]||{}).scales||{};Object.keys(h).forEach((t=&gt;{const e=function(t,e){let i=t;return"_index_"===t?i=e:"_value_"===t&amp;&amp;(i="x"===e?"y":"x"),i}(t,r),o=i[e+"AxisID"]||e;a[o]=a[o]||Object.create(null),(0,s.ab)(a[o],[{axis:e},n[o],h[t]])}))})),Object.keys(a).forEach((t=&gt;{const e=a[t];(0,s.ab)(e,[s.d.scales[e.type],s.d.scale])})),a}function At(t){const e=t.options||(t.options={});e.plugins=(0,s.v)(e.plugins,{}),e.scales=Dt(t,e)}function Ct(t){return(t=t||{}).datasets=t.datasets||[],t.labels=t.labels||[],t}const Et=new Map,Ot=new Set;function Pt(t,e){let i=Et.get(t);return i||(i=e(),Et.set(t,i),Ot.add(i)),i}const Tt=(t,e,i)=&gt;{const n=(0,s.f)(e,i);void 0!==n&amp;&amp;t.add(n)};class It{constructor(t){this._config=function(t){return(t=t||{}).data=Ct(t.data),At(t),t}(t),this._scopeCache=new Map,this._resolverCache=new Map}get platform(){return this._config.platform}get type(){return this._config.type}set type(t){this._config.type=t}get data(){return this._config.data}set data(t){this._config.data=Ct(t)}get options(){return this._config.options}set options(t){this._config.options=t}get plugins(){return this._config.plugins}update(){const t=this._config;this.clearCache(),At(t)}clearCache(){this._scopeCache.clear(),this._resolverCache.clear()}datasetScopeKeys(t){return Pt(t,(()=&gt;[[`datasets.${t}`,""]]))}datasetAnimationScopeKeys(t,e){return Pt(`${t}.transition.${e}`,(()=&gt;[[`datasets.${t}.transitions.${e}`,`transitions.${e}`],[`datasets.${t}`,""]]))}datasetElementScopeKeys(t,e){return Pt(`${t}-${e}`,(()=&gt;[[`datasets.${t}.elements.${e}`,`datasets.${t}`,`elements.${e}`,""]]))}pluginScopeKeys(t){const e=t.id;return Pt(`${this.type}-plugin-${e}`,(()=&gt;[[`plugins.${e}`,...t.additionalOptionScopes||[]]]))}_cachedScopes(t,e){const i=this._scopeCache;let s=i.get(t);return s&amp;&amp;!e||(s=new Map,i.set(t,s)),s}getOptionScopes(t,e,i){const{options:n,type:o}=this,a=this._cachedScopes(t,i),r=a.get(e);if(r)return r;const h=new Set;e.forEach((e=&gt;{t&amp;&amp;(h.add(t),e.forEach((e=&gt;Tt(h,t,e)))),e.forEach((t=&gt;Tt(h,n,t))),e.forEach((t=&gt;Tt(h,s.a3[o]||{},t))),e.forEach((t=&gt;Tt(h,s.d,t))),e.forEach((t=&gt;Tt(h,s.a6,t)))}));const l=Array.from(h);return 0===l.length&amp;&amp;l.push(Object.create(null)),Ot.has(e)&amp;&amp;a.set(e,l),l}chartOptionScopes(){const{options:t,type:e}=this;return[t,s.a3[e]||{},s.d.datasets[e]||{},{type:e},s.d,s.a6]}resolveNamedOptions(t,e,i,n=[""]){const o={$shared:!0},{resolver:a,subPrefixes:r}=Lt(this._resolverCache,t,n);let h=a;if(function(t,e){const{isScriptable:i,isIndexable:n}=(0,s.aa)(t);for(const o of e){const e=i(o),a=n(o),r=(a||e)&amp;&amp;t[o];if(e&amp;&amp;((0,s.a7)(r)||Rt(r))||a&amp;&amp;(0,s.b)(r))return!0}return!1}(a,e)){o.$shared=!1,i=(0,s.a7)(i)?i():i;const e=this.createResolver(t,i,r);h=(0,s.a8)(a,i,e)}for(const s of e)o[s]=h[s];return o}createResolver(t,e,i=[""],n){const{resolver:o}=Lt(this._resolverCache,t,i);return(0,s.i)(e)?(0,s.a8)(o,e,void 0,n):o}}function Lt(t,e,i){let n=t.get(e);n||(n=new Map,t.set(e,n));const o=i.join();let a=n.get(o);if(!a){a={resolver:(0,s.a9)(e,i),subPrefixes:i.filter((t=&gt;!t.toLowerCase().includes("hover")))},n.set(o,a)}return a}const Rt=t=&gt;(0,s.i)(t)&amp;&amp;Object.getOwnPropertyNames(t).some((e=&gt;(0,s.a7)(t[e])));const zt=["top","bottom","left","right","chartArea"];function Ft(t,e){return"top"===t||"bottom"===t||-1===zt.indexOf(t)&amp;&amp;"x"===e}function Bt(t,e){return function(i,s){return i[t]===s[t]?i[e]-s[e]:i[t]-s[t]}}function Ht(t){const e=t.chart,i=e.options.animation;e.notifyPlugins("afterRender"),(0,s.Q)(i&amp;&amp;i.onComplete,[t],e)}function Vt(t){const e=t.chart,i=e.options.animation;(0,s.Q)(i&amp;&amp;i.onProgress,[t],e)}function jt(t){return(0,s.M)()&amp;&amp;"string"===typeof t?t=document.getElementById(t):t&amp;&amp;t.length&amp;&amp;(t=t[0]),t&amp;&amp;t.canvas&amp;&amp;(t=t.canvas),t}const Wt={},$t=t=&gt;{const e=jt(t);return Object.values(Wt).filter((t=&gt;t.canvas===e)).pop()};function Nt(t,e,i){const s=Object.keys(t);for(const n of s){const s=+n;if(s&gt;=e){const o=t[n];delete t[n],(i&gt;0||s&gt;e)&amp;&amp;(t[s+i]=o)}}}function Ut(t,e,i){return t.options.clip?t[i]:e[i]}class Yt{static defaults=s.d;static instances=Wt;static overrides=s.a3;static registry=mt;static version="4.4.3";static getChart=$t;static register(...t){mt.add(...t),Xt()}static unregister(...t){mt.remove(...t),Xt()}constructor(t,e){const i=this.config=new It(e),n=jt(t),a=$t(n);if(a)throw new Error("Canvas is already in use. Chart with ID '"+a.id+"' must be destroyed before the canvas with ID '"+a.canvas.id+"' can be reused.");const r=i.createResolver(i.chartOptionScopes(),this.getContext());this.platform=new(i.platform||function(t){return!(0,s.M)()||"undefined"!==typeof OffscreenCanvas&amp;&amp;t instanceof OffscreenCanvas?N:nt}(n)),this.platform.updateConfig(i);const h=this.platform.acquireContext(n,r.aspectRatio),l=h&amp;&amp;h.canvas,c=l&amp;&amp;l.height,d=l&amp;&amp;l.width;this.id=(0,s.ac)(),this.ctx=h,this.canvas=l,this.width=d,this.height=c,this._options=r,this._aspectRatio=this.aspectRatio,this._layers=[],this._metasets=[],this._stacks=void 0,this.boxes=[],this.currentDevicePixelRatio=void 0,this.chartArea=void 0,this._active=[],this._lastEvent=void 0,this._listeners={},this._responsiveListeners=void 0,this._sortedMetasets=[],this.scales={},this._plugins=new bt,this.$proxies={},this._hiddenIndices={},this.attached=!1,this._animationsDisabled=void 0,this.$context=void 0,this._doResize=(0,s.ad)((t=&gt;this.update(t)),r.resizeDelay||0),this._dataChanges=[],Wt[this.id]=this,h&amp;&amp;l?(o.listen(this,"complete",Ht),o.listen(this,"progress",Vt),this._initialize(),this.attached&amp;&amp;this.update()):console.error("Failed to create chart: can't acquire context from the given item")}get aspectRatio(){const{options:{aspectRatio:t,maintainAspectRatio:e},width:i,height:n,_aspectRatio:o}=this;return(0,s.k)(t)?e&amp;&amp;o?o:n?i/n:null:t}get data(){return this.config.data}set data(t){this.config.data=t}get options(){return this._options}set options(t){this.config.options=t}get registry(){return mt}_initialize(){return this.notifyPlugins("beforeInit"),this.options.responsive?this.resize():(0,s.ae)(this,this.options.devicePixelRatio),this.bindEvents(),this.notifyPlugins("afterInit"),this}clear(){return(0,s.af)(this.canvas,this.ctx),this}stop(){return o.stop(this),this}resize(t,e){o.running(this)?this._resizeBeforeDraw={width:t,height:e}:this._resize(t,e)}_resize(t,e){const i=this.options,n=this.canvas,o=i.maintainAspectRatio&amp;&amp;this.aspectRatio,a=this.platform.getMaximumSize(n,t,e,o),r=i.devicePixelRatio||this.platform.getDevicePixelRatio(),h=this.width?"resize":"attach";this.width=a.width,this.height=a.height,this._aspectRatio=this.aspectRatio,(0,s.ae)(this,r,!0)&amp;&amp;(this.notifyPlugins("resize",{size:a}),(0,s.Q)(i.onResize,[this,a],this),this.attached&amp;&amp;this._doResize(h)&amp;&amp;this.render())}ensureScalesHaveIDs(){const t=this.options.scales||{};(0,s.F)(t,((t,e)=&gt;{t.id=e}))}buildOrUpdateScales(){const t=this.options,e=t.scales,i=this.scales,n=Object.keys(i).reduce(((t,e)=&gt;(t[e]=!1,t)),{});let o=[];e&amp;&amp;(o=o.concat(Object.keys(e).map((t=&gt;{const i=e[t],s=kt(t,i),n="r"===s,o="x"===s;return{options:i,dposition:n?"chartArea":o?"bottom":"left",dtype:n?"radialLinear":o?"category":"linear"}})))),(0,s.F)(o,(e=&gt;{const o=e.options,a=o.id,r=kt(a,o),h=(0,s.v)(o.type,e.dtype);void 0!==o.position&amp;&amp;Ft(o.position,r)===Ft(e.dposition)||(o.position=e.dposition),n[a]=!0;let l=null;if(a in i&amp;&amp;i[a].type===h)l=i[a];else{l=new(mt.getScale(h))({id:a,type:h,ctx:this.ctx,chart:this}),i[l.id]=l}l.init(o,t)})),(0,s.F)(n,((t,e)=&gt;{t||delete i[e]})),(0,s.F)(i,(t=&gt;{W.configure(this,t,t.options),W.addBox(this,t)}))}_updateMetasets(){const t=this._metasets,e=this.data.datasets.length,i=t.length;if(t.sort(((t,e)=&gt;t.index-e.index)),i&gt;e){for(let t=e;t&lt;i;++t)this._destroyDatasetMeta(t);t.splice(e,i-e)}this._sortedMetasets=t.slice(0).sort(Bt("order","index"))}_removeUnreferencedMetasets(){const{_metasets:t,data:{datasets:e}}=this;t.length&gt;e.length&amp;&amp;delete this._stacks,t.forEach(((t,i)=&gt;{0===e.filter((e=&gt;e===t._dataset)).length&amp;&amp;this._destroyDatasetMeta(i)}))}buildOrUpdateControllers(){const t=[],e=this.data.datasets;let i,n;for(this._removeUnreferencedMetasets(),i=0,n=e.length;i&lt;n;i++){const n=e[i];let o=this.getDatasetMeta(i);const a=n.type||this.config.type;if(o.type&amp;&amp;o.type!==a&amp;&amp;(this._destroyDatasetMeta(i),o=this.getDatasetMeta(i)),o.type=a,o.indexAxis=n.indexAxis||wt(a,this.options),o.order=n.order||0,o.index=i,o.label=""+n.label,o.visible=this.isDatasetVisible(i),o.controller)o.controller.updateIndex(i),o.controller.linkScales();else{const e=mt.getController(a),{datasetElementType:n,dataElementType:r}=s.d.datasets[a];Object.assign(e,{dataElementType:mt.getElement(r),datasetElementType:n&amp;&amp;mt.getElement(n)}),o.controller=new e(this,i),t.push(o.controller)}}return this._updateMetasets(),t}_resetElements(){(0,s.F)(this.data.datasets,((t,e)=&gt;{this.getDatasetMeta(e).controller.reset()}),this)}reset(){this._resetElements(),this.notifyPlugins("reset")}update(t){const e=this.config;e.update();const i=this._options=e.createResolver(e.chartOptionScopes(),this.getContext()),n=this._animationsDisabled=!i.animation;if(this._updateScales(),this._checkEventBindings(),this._updateHiddenIndices(),this._plugins.invalidate(),!1===this.notifyPlugins("beforeUpdate",{mode:t,cancelable:!0}))return;const o=this.buildOrUpdateControllers();this.notifyPlugins("beforeElementsUpdate");let a=0;for(let s=0,l=this.data.datasets.length;s&lt;l;s++){const{controller:t}=this.getDatasetMeta(s),e=!n&amp;&amp;-1===o.indexOf(t);t.buildOrUpdateElements(e),a=Math.max(+t.getMaxOverflow(),a)}a=this._minPadding=i.layout.autoPadding?a:0,this._updateLayout(a),n||(0,s.F)(o,(t=&gt;{t.reset()})),this._updateDatasets(t),this.notifyPlugins("afterUpdate",{mode:t}),this._layers.sort(Bt("z","_idx"));const{_active:r,_lastEvent:h}=this;h?this._eventHandler(h,!0):r.length&amp;&amp;this._updateHoverStyles(r,r,!0),this.render()}_updateScales(){(0,s.F)(this.scales,(t=&gt;{W.removeBox(this,t)})),this.ensureScalesHaveIDs(),this.buildOrUpdateScales()}_checkEventBindings(){const t=this.options,e=new Set(Object.keys(this._listeners)),i=new Set(t.events);(0,s.ag)(e,i)&amp;&amp;!!this._responsiveListeners===t.responsive||(this.unbindEvents(),this.bindEvents())}_updateHiddenIndices(){const{_hiddenIndices:t}=this,e=this._getUniformDataChanges()||[];for(const{method:i,start:s,count:n}of e){Nt(t,s,"_removeElements"===i?-n:n)}}_getUniformDataChanges(){const t=this._dataChanges;if(!t||!t.length)return;this._dataChanges=[];const e=this.data.datasets.length,i=e=&gt;new Set(t.filter((t=&gt;t[0]===e)).map(((t,e)=&gt;e+","+t.splice(1).join(",")))),n=i(0);for(let o=1;o&lt;e;o++)if(!(0,s.ag)(n,i(o)))return;return Array.from(n).map((t=&gt;t.split(","))).map((t=&gt;({method:t[1],start:+t[2],count:+t[3]})))}_updateLayout(t){if(!1===this.notifyPlugins("beforeLayout",{cancelable:!0}))return;W.update(this,this.width,this.height,t);const e=this.chartArea,i=e.width&lt;=0||e.height&lt;=0;this._layers=[],(0,s.F)(this.boxes,(t=&gt;{i&amp;&amp;"chartArea"===t.position||(t.configure&amp;&amp;t.configure(),this._layers.push(...t._layers()))}),this),this._layers.forEach(((t,e)=&gt;{t._idx=e})),this.notifyPlugins("afterLayout")}_updateDatasets(t){if(!1!==this.notifyPlugins("beforeDatasetsUpdate",{mode:t,cancelable:!0})){for(let t=0,e=this.data.datasets.length;t&lt;e;++t)this.getDatasetMeta(t).controller.configure();for(let e=0,i=this.data.datasets.length;e&lt;i;++e)this._updateDataset(e,(0,s.a7)(t)?t({datasetIndex:e}):t);this.notifyPlugins("afterDatasetsUpdate",{mode:t})}}_updateDataset(t,e){const i=this.getDatasetMeta(t),s={meta:i,index:t,mode:e,cancelable:!0};!1!==this.notifyPlugins("beforeDatasetUpdate",s)&amp;&amp;(i.controller._update(e),s.cancelable=!1,this.notifyPlugins("afterDatasetUpdate",s))}render(){!1!==this.notifyPlugins("beforeRender",{cancelable:!0})&amp;&amp;(o.has(this)?this.attached&amp;&amp;!o.running(this)&amp;&amp;o.start(this):(this.draw(),Ht({chart:this})))}draw(){let t;if(this._resizeBeforeDraw){const{width:t,height:e}=this._resizeBeforeDraw;this._resize(t,e),this._resizeBeforeDraw=null}if(this.clear(),this.width&lt;=0||this.height&lt;=0)return;if(!1===this.notifyPlugins("beforeDraw",{cancelable:!0}))return;const e=this._layers;for(t=0;t&lt;e.length&amp;&amp;e[t].z&lt;=0;++t)e[t].draw(this.chartArea);for(this._drawDatasets();t&lt;e.length;++t)e[t].draw(this.chartArea);this.notifyPlugins("afterDraw")}_getSortedDatasetMetas(t){const e=this._sortedMetasets,i=[];let s,n;for(s=0,n=e.length;s&lt;n;++s){const n=e[s];t&amp;&amp;!n.visible||i.push(n)}return i}getSortedVisibleDatasetMetas(){return this._getSortedDatasetMetas(!0)}_drawDatasets(){if(!1===this.notifyPlugins("beforeDatasetsDraw",{cancelable:!0}))return;const t=this.getSortedVisibleDatasetMetas();for(let e=t.length-1;e&gt;=0;--e)this._drawDataset(t[e]);this.notifyPlugins("afterDatasetsDraw")}_drawDataset(t){const e=this.ctx,i=t._clip,n=!i.disabled,o=function(t,e){const{xScale:i,yScale:s}=t;return i&amp;&amp;s?{left:Ut(i,e,"left"),right:Ut(i,e,"right"),top:Ut(s,e,"top"),bottom:Ut(s,e,"bottom")}:e}(t,this.chartArea),a={meta:t,index:t.index,cancelable:!0};!1!==this.notifyPlugins("beforeDatasetDraw",a)&amp;&amp;(n&amp;&amp;(0,s.Y)(e,{left:!1===i.left?0:o.left-i.left,right:!1===i.right?this.width:o.right+i.right,top:!1===i.top?0:o.top-i.top,bottom:!1===i.bottom?this.height:o.bottom+i.bottom}),t.controller.draw(),n&amp;&amp;(0,s.$)(e),a.cancelable=!1,this.notifyPlugins("afterDatasetDraw",a))}isPointInArea(t){return(0,s.C)(t,this.chartArea,this._minPadding)}getElementsAtEventForMode(t,e,i,s){const n=E.modes[e];return"function"===typeof n?n(this,t,i,s):[]}getDatasetMeta(t){const e=this.data.datasets[t],i=this._metasets;let s=i.filter((t=&gt;t&amp;&amp;t._dataset===e)).pop();return s||(s={type:null,data:[],dataset:null,controller:null,hidden:null,xAxisID:null,yAxisID:null,order:e&amp;&amp;e.order||0,index:t,_dataset:e,_parsed:[],_sorted:!1},i.push(s)),s}getContext(){return this.$context||(this.$context=(0,s.j)(null,{chart:this,type:"chart"}))}getVisibleDatasetCount(){return this.getSortedVisibleDatasetMetas().length}isDatasetVisible(t){const e=this.data.datasets[t];if(!e)return!1;const i=this.getDatasetMeta(t);return"boolean"===typeof i.hidden?!i.hidden:!e.hidden}setDatasetVisibility(t,e){this.getDatasetMeta(t).hidden=!e}toggleDataVisibility(t){this._hiddenIndices[t]=!this._hiddenIndices[t]}getDataVisibility(t){return!this._hiddenIndices[t]}_updateVisibility(t,e,i){const n=i?"show":"hide",o=this.getDatasetMeta(t),a=o.controller._resolveAnimations(void 0,n);(0,s.h)(e)?(o.data[e].hidden=!i,this.update()):(this.setDatasetVisibility(t,i),a.update(o,{visible:i}),this.update((e=&gt;e.datasetIndex===t?n:void 0)))}hide(t,e){this._updateVisibility(t,e,!1)}show(t,e){this._updateVisibility(t,e,!0)}_destroyDatasetMeta(t){const e=this._metasets[t];e&amp;&amp;e.controller&amp;&amp;e.controller._destroy(),delete this._metasets[t]}_stop(){let t,e;for(this.stop(),o.remove(this),t=0,e=this.data.datasets.length;t&lt;e;++t)this._destroyDatasetMeta(t)}destroy(){this.notifyPlugins("beforeDestroy");const{canvas:t,ctx:e}=this;this._stop(),this.config.clearCache(),t&amp;&amp;(this.unbindEvents(),(0,s.af)(t,e),this.platform.releaseContext(e),this.canvas=null,this.ctx=null),delete Wt[this.id],this.notifyPlugins("afterDestroy")}toBase64Image(...t){return this.canvas.toDataURL(...t)}bindEvents(){this.bindUserEvents(),this.options.responsive?this.bindResponsiveEvents():this.attached=!0}bindUserEvents(){const t=this._listeners,e=this.platform,i=(i,s)=&gt;{e.addEventListener(this,i,s),t[i]=s},n=(t,e,i)=&gt;{t.offsetX=e,t.offsetY=i,this._eventHandler(t)};(0,s.F)(this.options.events,(t=&gt;i(t,n)))}bindResponsiveEvents(){this._responsiveListeners||(this._responsiveListeners={});const t=this._responsiveListeners,e=this.platform,i=(i,s)=&gt;{e.addEventListener(this,i,s),t[i]=s},s=(i,s)=&gt;{t[i]&amp;&amp;(e.removeEventListener(this,i,s),delete t[i])},n=(t,e)=&gt;{this.canvas&amp;&amp;this.resize(t,e)};let o;const a=()=&gt;{s("attach",a),this.attached=!0,this.resize(),i("resize",n),i("detach",o)};o=()=&gt;{this.attached=!1,s("resize",n),this._stop(),this._resize(0,0),i("attach",a)},e.isAttached(this.canvas)?a():o()}unbindEvents(){(0,s.F)(this._listeners,((t,e)=&gt;{this.platform.removeEventListener(this,e,t)})),this._listeners={},(0,s.F)(this._responsiveListeners,((t,e)=&gt;{this.platform.removeEventListener(this,e,t)})),this._responsiveListeners=void 0}updateHoverStyle(t,e,i){const s=i?"set":"remove";let n,o,a,r;for("dataset"===e&amp;&amp;(n=this.getDatasetMeta(t[0].datasetIndex),n.controller["_"+s+"DatasetHoverStyle"]()),a=0,r=t.length;a&lt;r;++a){o=t[a];const e=o&amp;&amp;this.getDatasetMeta(o.datasetIndex).controller;e&amp;&amp;e[s+"HoverStyle"](o.element,o.datasetIndex,o.index)}}getActiveElements(){return this._active||[]}setActiveElements(t){const e=this._active||[],i=t.map((({datasetIndex:t,index:e})=&gt;{const i=this.getDatasetMeta(t);if(!i)throw new Error("No dataset found at index "+t);return{datasetIndex:t,element:i.data[e],index:e}}));!(0,s.ah)(i,e)&amp;&amp;(this._active=i,this._lastEvent=null,this._updateHoverStyles(i,e))}notifyPlugins(t,e,i){return this._plugins.notify(this,t,e,i)}isPluginEnabled(t){return 1===this._plugins._cache.filter((e=&gt;e.plugin.id===t)).length}_updateHoverStyles(t,e,i){const s=this.options.hover,n=(t,e)=&gt;t.filter((t=&gt;!e.some((e=&gt;t.datasetIndex===e.datasetIndex&amp;&amp;t.index===e.index)))),o=n(e,t),a=i?t:n(t,e);o.length&amp;&amp;this.updateHoverStyle(o,s.mode,!1),a.length&amp;&amp;s.mode&amp;&amp;this.updateHoverStyle(a,s.mode,!0)}_eventHandler(t,e){const i={event:t,replay:e,cancelable:!0,inChartArea:this.isPointInArea(t)},s=e=&gt;(e.options.events||this.options.events).includes(t.native.type);if(!1===this.notifyPlugins("beforeEvent",i,s))return;const n=this._handleEvent(t,e,i.inChartArea);return i.cancelable=!1,this.notifyPlugins("afterEvent",i,s),(n||i.changed)&amp;&amp;this.render(),this}_handleEvent(t,e,i){const{_active:n=[],options:o}=this,a=e,r=this._getActiveElements(t,n,i,a),h=(0,s.ai)(t),l=function(t,e,i,s){return i&amp;&amp;"mouseout"!==t.type?s?e:t:null}(t,this._lastEvent,i,h);i&amp;&amp;(this._lastEvent=null,(0,s.Q)(o.onHover,[t,r,this],this),h&amp;&amp;(0,s.Q)(o.onClick,[t,r,this],this));const c=!(0,s.ah)(r,n);return(c||e)&amp;&amp;(this._active=r,this._updateHoverStyles(r,n,e)),this._lastEvent=l,c}_getActiveElements(t,e,i,s){if("mouseout"===t.type)return[];if(!i)return e;const n=this.options.hover;return this.getElementsAtEventForMode(t,n.mode,n,s)}}function Xt(){return(0,s.F)(Yt.instances,(t=&gt;t._plugins.invalidate()))}function Qt(t,e,i,n){const o=(a=t.options.borderRadius,(0,s.ak)(a,["outerStart","outerEnd","innerStart","innerEnd"]));var a;const r=(i-e)/2,h=Math.min(r,n*e/2),l=t=&gt;{const e=(i-Math.min(r,t))*n/2;return(0,s.S)(t,0,Math.min(r,e))};return{outerStart:l(o.outerStart),outerEnd:l(o.outerEnd),innerStart:(0,s.S)(o.innerStart,0,h),innerEnd:(0,s.S)(o.innerEnd,0,h)}}function Kt(t,e,i,s){return{x:i+t*Math.cos(e),y:s+t*Math.sin(e)}}function qt(t,e,i,n,o,a){const{x:r,y:h,startAngle:l,pixelMargin:c,innerRadius:d}=e,u=Math.max(e.outerRadius+n+i-c,0),g=d&gt;0?d+n+i+c:0;let f=0;const p=o-l;if(n){const t=((d&gt;0?d-n:0)+(u&gt;0?u-n:0))/2;f=(p-(0!==t?p*t/(t+n):p))/2}const x=(p-Math.max(.001,p*u-i/s.P)/u)/2,_=l+x+f,m=o-x-f,{outerStart:b,outerEnd:y,innerStart:v,innerEnd:w}=Qt(e,g,u,m-_),M=u-b,k=u-y,S=_+b/M,D=m-y/k,A=g+v,C=g+w,E=_+v/A,O=m-w/C;if(t.beginPath(),a){const e=(S+D)/2;if(t.arc(r,h,u,S,e),t.arc(r,h,u,e,D),y&gt;0){const e=Kt(k,D,r,h);t.arc(e.x,e.y,y,D,m+s.H)}const i=Kt(C,m,r,h);if(t.lineTo(i.x,i.y),w&gt;0){const e=Kt(C,O,r,h);t.arc(e.x,e.y,w,m+s.H,O+Math.PI)}const n=(m-w/g+(_+v/g))/2;if(t.arc(r,h,g,m-w/g,n,!0),t.arc(r,h,g,n,_+v/g,!0),v&gt;0){const e=Kt(A,E,r,h);t.arc(e.x,e.y,v,E+Math.PI,_-s.H)}const o=Kt(M,_,r,h);if(t.lineTo(o.x,o.y),b&gt;0){const e=Kt(M,S,r,h);t.arc(e.x,e.y,b,_-s.H,S)}}else{t.moveTo(r,h);const e=Math.cos(S)*u+r,i=Math.sin(S)*u+h;t.lineTo(e,i);const s=Math.cos(D)*u+r,n=Math.sin(D)*u+h;t.lineTo(s,n)}t.closePath()}function Gt(t,e,i,n,o){const{fullCircles:a,startAngle:r,circumference:h,options:l}=e,{borderWidth:c,borderJoinStyle:d,borderDash:u,borderDashOffset:g}=l,f="inner"===l.borderAlign;if(!c)return;t.setLineDash(u||[]),t.lineDashOffset=g,f?(t.lineWidth=2*c,t.lineJoin=d||"round"):(t.lineWidth=c,t.lineJoin=d||"bevel");let p=e.endAngle;if(a){qt(t,e,i,n,p,o);for(let e=0;e&lt;a;++e)t.stroke();isNaN(h)||(p=r+(h%s.T||s.T))}f&amp;&amp;function(t,e,i){const{startAngle:n,pixelMargin:o,x:a,y:r,outerRadius:h,innerRadius:l}=e;let c=o/h;t.beginPath(),t.arc(a,r,h,n-c,i+c),l&gt;o?(c=o/l,t.arc(a,r,l,i+c,n-c,!0)):t.arc(a,r,o,i+s.H,n-s.H),t.closePath(),t.clip()}(t,e,p),a||(qt(t,e,i,n,p,o),t.stroke())}class Jt extends ot{static id="arc";static defaults={borderAlign:"center",borderColor:"#fff",borderDash:[],borderDashOffset:0,borderJoinStyle:void 0,borderRadius:0,borderWidth:2,offset:0,spacing:0,angle:void 0,circular:!0};static defaultRoutes={backgroundColor:"backgroundColor"};static descriptors={_scriptable:!0,_indexable:t=&gt;"borderDash"!==t};circumference;endAngle;fullCircles;innerRadius;outerRadius;pixelMargin;startAngle;constructor(t){super(),this.options=void 0,this.circumference=void 0,this.startAngle=void 0,this.endAngle=void 0,this.innerRadius=void 0,this.outerRadius=void 0,this.pixelMargin=0,this.fullCircles=0,t&amp;&amp;Object.assign(this,t)}inRange(t,e,i){const n=this.getProps(["x","y"],i),{angle:o,distance:a}=(0,s.D)(n,{x:t,y:e}),{startAngle:r,endAngle:h,innerRadius:l,outerRadius:c,circumference:d}=this.getProps(["startAngle","endAngle","innerRadius","outerRadius","circumference"],i),u=(this.options.spacing+this.options.borderWidth)/2,g=(0,s.v)(d,h-r)&gt;=s.T||(0,s.p)(o,r,h),f=(0,s.aj)(a,l+u,c+u);return g&amp;&amp;f}getCenterPoint(t){const{x:e,y:i,startAngle:s,endAngle:n,innerRadius:o,outerRadius:a}=this.getProps(["x","y","startAngle","endAngle","innerRadius","outerRadius"],t),{offset:r,spacing:h}=this.options,l=(s+n)/2,c=(o+a+h+r)/2;return{x:e+Math.cos(l)*c,y:i+Math.sin(l)*c}}tooltipPosition(t){return this.getCenterPoint(t)}draw(t){const{options:e,circumference:i}=this,n=(e.offset||0)/4,o=(e.spacing||0)/2,a=e.circular;if(this.pixelMargin="inner"===e.borderAlign?.33:0,this.fullCircles=i&gt;s.T?Math.floor(i/s.T):0,0===i||this.innerRadius&lt;0||this.outerRadius&lt;0)return;t.save();const r=(this.startAngle+this.endAngle)/2;t.translate(Math.cos(r)*n,Math.sin(r)*n);const h=n*(1-Math.sin(Math.min(s.P,i||0)));t.fillStyle=e.backgroundColor,t.strokeStyle=e.borderColor,function(t,e,i,n,o){const{fullCircles:a,startAngle:r,circumference:h}=e;let l=e.endAngle;if(a){qt(t,e,i,n,l,o);for(let e=0;e&lt;a;++e)t.fill();isNaN(h)||(l=r+(h%s.T||s.T))}qt(t,e,i,n,l,o),t.fill()}(t,this,h,o,a),Gt(t,this,h,o,a),t.restore()}}new WeakMap;const Zt={average(t){if(!t.length)return!1;let e,i,s=new Set,n=0,o=0;for(e=0,i=t.length;e&lt;i;++e){const i=t[e].element;if(i&amp;&amp;i.hasValue()){const t=i.tooltipPosition();s.add(t.x),n+=t.y,++o}}return{x:[...s].reduce(((t,e)=&gt;t+e))/s.size,y:n/o}},nearest(t,e){if(!t.length)return!1;let i,n,o,a=e.x,r=e.y,h=Number.POSITIVE_INFINITY;for(i=0,n=t.length;i&lt;n;++i){const n=t[i].element;if(n&amp;&amp;n.hasValue()){const t=n.getCenterPoint(),i=(0,s.aE)(e,t);i&lt;h&amp;&amp;(h=i,o=n)}}if(o){const t=o.tooltipPosition();a=t.x,r=t.y}return{x:a,y:r}}};function te(t,e){return e&amp;&amp;((0,s.b)(e)?Array.prototype.push.apply(t,e):t.push(e)),t}function ee(t){return("string"===typeof t||t instanceof String)&amp;&amp;t.indexOf("\n")&gt;-1?t.split("\n"):t}function ie(t,e){const{element:i,datasetIndex:s,index:n}=e,o=t.getDatasetMeta(s).controller,{label:a,value:r}=o.getLabelAndValue(n);return{chart:t,label:a,parsed:o.getParsed(n),raw:t.data.datasets[s].data[n],formattedValue:r,dataset:o.getDataset(),dataIndex:n,datasetIndex:s,element:i}}function se(t,e){const i=t.chart.ctx,{body:n,footer:o,title:a}=t,{boxWidth:r,boxHeight:h}=e,l=(0,s.a0)(e.bodyFont),c=(0,s.a0)(e.titleFont),d=(0,s.a0)(e.footerFont),u=a.length,g=o.length,f=n.length,p=(0,s.E)(e.padding);let x=p.height,_=0,m=n.reduce(((t,e)=&gt;t+e.before.length+e.lines.length+e.after.length),0);if(m+=t.beforeBody.length+t.afterBody.length,u&amp;&amp;(x+=u*c.lineHeight+(u-1)*e.titleSpacing+e.titleMarginBottom),m){x+=f*(e.displayColors?Math.max(h,l.lineHeight):l.lineHeight)+(m-f)*l.lineHeight+(m-1)*e.bodySpacing}g&amp;&amp;(x+=e.footerMarginTop+g*d.lineHeight+(g-1)*e.footerSpacing);let b=0;const y=function(t){_=Math.max(_,i.measureText(t).width+b)};return i.save(),i.font=c.string,(0,s.F)(t.title,y),i.font=l.string,(0,s.F)(t.beforeBody.concat(t.afterBody),y),b=e.displayColors?r+2+e.boxPadding:0,(0,s.F)(n,(t=&gt;{(0,s.F)(t.before,y),(0,s.F)(t.lines,y),(0,s.F)(t.after,y)})),b=0,i.font=d.string,(0,s.F)(t.footer,y),i.restore(),_+=p.width,{width:_,height:x}}function ne(t,e,i,s){const{x:n,width:o}=i,{width:a,chartArea:{left:r,right:h}}=t;let l="center";return"center"===s?l=n&lt;=(r+h)/2?"left":"right":n&lt;=o/2?l="left":n&gt;=a-o/2&amp;&amp;(l="right"),function(t,e,i,s){const{x:n,width:o}=s,a=i.caretSize+i.caretPadding;return"left"===t&amp;&amp;n+o+a&gt;e.width||"right"===t&amp;&amp;n-o-a&lt;0||void 0}(l,t,e,i)&amp;&amp;(l="center"),l}function oe(t,e,i){const s=i.yAlign||e.yAlign||function(t,e){const{y:i,height:s}=e;return i&lt;s/2?"top":i&gt;t.height-s/2?"bottom":"center"}(t,i);return{xAlign:i.xAlign||e.xAlign||ne(t,e,i,s),yAlign:s}}function ae(t,e,i,n){const{caretSize:o,caretPadding:a,cornerRadius:r}=t,{xAlign:h,yAlign:l}=i,c=o+a,{topLeft:d,topRight:u,bottomLeft:g,bottomRight:f}=(0,s.aw)(r);let p=function(t,e){let{x:i,width:s}=t;return"right"===e?i-=s:"center"===e&amp;&amp;(i-=s/2),i}(e,h);const x=function(t,e,i){let{y:s,height:n}=t;return"top"===e?s+=i:s-="bottom"===e?n+i:n/2,s}(e,l,c);return"center"===l?"left"===h?p+=c:"right"===h&amp;&amp;(p-=c):"left"===h?p-=Math.max(d,g)+o:"right"===h&amp;&amp;(p+=Math.max(u,f)+o),{x:(0,s.S)(p,0,n.width-e.width),y:(0,s.S)(x,0,n.height-e.height)}}function re(t,e,i){const n=(0,s.E)(i.padding);return"center"===e?t.x+t.width/2:"right"===e?t.x+t.width-n.right:t.x+n.left}function he(t){return te([],ee(t))}function le(t,e){const i=e&amp;&amp;e.dataset&amp;&amp;e.dataset.tooltip&amp;&amp;e.dataset.tooltip.callbacks;return i?t.override(i):t}const ce={beforeTitle:s.aF,title(t){if(t.length&gt;0){const e=t[0],i=e.chart.data.labels,s=i?i.length:0;if(this&amp;&amp;this.options&amp;&amp;"dataset"===this.options.mode)return e.dataset.label||"";if(e.label)return e.label;if(s&gt;0&amp;&amp;e.dataIndex&lt;s)return i[e.dataIndex]}return""},afterTitle:s.aF,beforeBody:s.aF,beforeLabel:s.aF,label(t){if(this&amp;&amp;this.options&amp;&amp;"dataset"===this.options.mode)return t.label+": "+t.formattedValue||t.formattedValue;let e=t.dataset.label||"";e&amp;&amp;(e+=": ");const i=t.formattedValue;return(0,s.k)(i)||(e+=i),e},labelColor(t){const e=t.chart.getDatasetMeta(t.datasetIndex).controller.getStyle(t.dataIndex);return{borderColor:e.borderColor,backgroundColor:e.backgroundColor,borderWidth:e.borderWidth,borderDash:e.borderDash,borderDashOffset:e.borderDashOffset,borderRadius:0}},labelTextColor(){return this.options.bodyColor},labelPointStyle(t){const e=t.chart.getDatasetMeta(t.datasetIndex).controller.getStyle(t.dataIndex);return{pointStyle:e.pointStyle,rotation:e.rotation}},afterLabel:s.aF,afterBody:s.aF,beforeFooter:s.aF,footer:s.aF,afterFooter:s.aF};function de(t,e,i,s){const n=t[e].call(i,s);return"undefined"===typeof n?ce[e].call(i,s):n}class ue extends ot{static positioners=Zt;constructor(t){super(),this.opacity=0,this._active=[],this._eventPosition=void 0,this._size=void 0,this._cachedAnimations=void 0,this._tooltipItems=[],this.$animations=void 0,this.$context=void 0,this.chart=t.chart,this.options=t.options,this.dataPoints=void 0,this.title=void 0,this.beforeBody=void 0,this.body=void 0,this.afterBody=void 0,this.footer=void 0,this.xAlign=void 0,this.yAlign=void 0,this.x=void 0,this.y=void 0,this.height=void 0,this.width=void 0,this.caretX=void 0,this.caretY=void 0,this.labelColors=void 0,this.labelPointStyles=void 0,this.labelTextColors=void 0}initialize(t){this.options=t,this._cachedAnimations=void 0,this.$context=void 0}_resolveAnimations(){const t=this._cachedAnimations;if(t)return t;const e=this.chart,i=this.options.setContext(this.getContext()),s=i.enabled&amp;&amp;e.options.animation&amp;&amp;i.animations,n=new l(this.chart,s);return s._cacheable&amp;&amp;(this._cachedAnimations=Object.freeze(n)),n}getContext(){return this.$context||(this.$context=(t=this.chart.getContext(),e=this,i=this._tooltipItems,(0,s.j)(t,{tooltip:e,tooltipItems:i,type:"tooltip"})));var t,e,i}getTitle(t,e){const{callbacks:i}=e,s=de(i,"beforeTitle",this,t),n=de(i,"title",this,t),o=de(i,"afterTitle",this,t);let a=[];return a=te(a,ee(s)),a=te(a,ee(n)),a=te(a,ee(o)),a}getBeforeBody(t,e){return he(de(e.callbacks,"beforeBody",this,t))}getBody(t,e){const{callbacks:i}=e,n=[];return(0,s.F)(t,(t=&gt;{const e={before:[],lines:[],after:[]},s=le(i,t);te(e.before,ee(de(s,"beforeLabel",this,t))),te(e.lines,de(s,"label",this,t)),te(e.after,ee(de(s,"afterLabel",this,t))),n.push(e)})),n}getAfterBody(t,e){return he(de(e.callbacks,"afterBody",this,t))}getFooter(t,e){const{callbacks:i}=e,s=de(i,"beforeFooter",this,t),n=de(i,"footer",this,t),o=de(i,"afterFooter",this,t);let a=[];return a=te(a,ee(s)),a=te(a,ee(n)),a=te(a,ee(o)),a}_createItems(t){const e=this._active,i=this.chart.data,n=[],o=[],a=[];let r,h,l=[];for(r=0,h=e.length;r&lt;h;++r)l.push(ie(this.chart,e[r]));return t.filter&amp;&amp;(l=l.filter(((e,s,n)=&gt;t.filter(e,s,n,i)))),t.itemSort&amp;&amp;(l=l.sort(((e,s)=&gt;t.itemSort(e,s,i)))),(0,s.F)(l,(e=&gt;{const i=le(t.callbacks,e);n.push(de(i,"labelColor",this,e)),o.push(de(i,"labelPointStyle",this,e)),a.push(de(i,"labelTextColor",this,e))})),this.labelColors=n,this.labelPointStyles=o,this.labelTextColors=a,this.dataPoints=l,l}update(t,e){const i=this.options.setContext(this.getContext()),s=this._active;let n,o=[];if(s.length){const t=Zt[i.position].call(this,s,this._eventPosition);o=this._createItems(i),this.title=this.getTitle(o,i),this.beforeBody=this.getBeforeBody(o,i),this.body=this.getBody(o,i),this.afterBody=this.getAfterBody(o,i),this.footer=this.getFooter(o,i);const e=this._size=se(this,i),a=Object.assign({},t,e),r=oe(this.chart,i,a),h=ae(i,a,r,this.chart);this.xAlign=r.xAlign,this.yAlign=r.yAlign,n={opacity:1,x:h.x,y:h.y,width:e.width,height:e.height,caretX:t.x,caretY:t.y}}else 0!==this.opacity&amp;&amp;(n={opacity:0});this._tooltipItems=o,this.$context=void 0,n&amp;&amp;this._resolveAnimations().update(this,n),t&amp;&amp;i.external&amp;&amp;i.external.call(this,{chart:this.chart,tooltip:this,replay:e})}drawCaret(t,e,i,s){const n=this.getCaretPosition(t,i,s);e.lineTo(n.x1,n.y1),e.lineTo(n.x2,n.y2),e.lineTo(n.x3,n.y3)}getCaretPosition(t,e,i){const{xAlign:n,yAlign:o}=this,{caretSize:a,cornerRadius:r}=i,{topLeft:h,topRight:l,bottomLeft:c,bottomRight:d}=(0,s.aw)(r),{x:u,y:g}=t,{width:f,height:p}=e;let x,_,m,b,y,v;return"center"===o?(y=g+p/2,"left"===n?(x=u,_=x-a,b=y+a,v=y-a):(x=u+f,_=x+a,b=y-a,v=y+a),m=x):(_="left"===n?u+Math.max(h,c)+a:"right"===n?u+f-Math.max(l,d)-a:this.caretX,"top"===o?(b=g,y=b-a,x=_-a,m=_+a):(b=g+p,y=b+a,x=_+a,m=_-a),v=b),{x1:x,x2:_,x3:m,y1:b,y2:y,y3:v}}drawTitle(t,e,i){const n=this.title,o=n.length;let a,r,h;if(o){const l=(0,s.az)(i.rtl,this.x,this.width);for(t.x=re(this,i.titleAlign,i),e.textAlign=l.textAlign(i.titleAlign),e.textBaseline="middle",a=(0,s.a0)(i.titleFont),r=i.titleSpacing,e.fillStyle=i.titleColor,e.font=a.string,h=0;h&lt;o;++h)e.fillText(n[h],l.x(t.x),t.y+a.lineHeight/2),t.y+=a.lineHeight+r,h+1===o&amp;&amp;(t.y+=i.titleMarginBottom-r)}}_drawColorBox(t,e,i,n,o){const a=this.labelColors[i],r=this.labelPointStyles[i],{boxHeight:h,boxWidth:l}=o,c=(0,s.a0)(o.bodyFont),d=re(this,"left",o),u=n.x(d),g=h&lt;c.lineHeight?(c.lineHeight-h)/2:0,f=e.y+g;if(o.usePointStyle){const e={radius:Math.min(l,h)/2,pointStyle:r.pointStyle,rotation:r.rotation,borderWidth:1},i=n.leftForLtr(u,l)+l/2,c=f+h/2;t.strokeStyle=o.multiKeyBackground,t.fillStyle=o.multiKeyBackground,(0,s.at)(t,e,i,c),t.strokeStyle=a.borderColor,t.fillStyle=a.backgroundColor,(0,s.at)(t,e,i,c)}else{t.lineWidth=(0,s.i)(a.borderWidth)?Math.max(...Object.values(a.borderWidth)):a.borderWidth||1,t.strokeStyle=a.borderColor,t.setLineDash(a.borderDash||[]),t.lineDashOffset=a.borderDashOffset||0;const e=n.leftForLtr(u,l),i=n.leftForLtr(n.xPlus(u,1),l-2),r=(0,s.aw)(a.borderRadius);Object.values(r).some((t=&gt;0!==t))?(t.beginPath(),t.fillStyle=o.multiKeyBackground,(0,s.au)(t,{x:e,y:f,w:l,h:h,radius:r}),t.fill(),t.stroke(),t.fillStyle=a.backgroundColor,t.beginPath(),(0,s.au)(t,{x:i,y:f+1,w:l-2,h:h-2,radius:r}),t.fill()):(t.fillStyle=o.multiKeyBackground,t.fillRect(e,f,l,h),t.strokeRect(e,f,l,h),t.fillStyle=a.backgroundColor,t.fillRect(i,f+1,l-2,h-2))}t.fillStyle=this.labelTextColors[i]}drawBody(t,e,i){const{body:n}=this,{bodySpacing:o,bodyAlign:a,displayColors:r,boxHeight:h,boxWidth:l,boxPadding:c}=i,d=(0,s.a0)(i.bodyFont);let u=d.lineHeight,g=0;const f=(0,s.az)(i.rtl,this.x,this.width),p=function(i){e.fillText(i,f.x(t.x+g),t.y+u/2),t.y+=u+o},x=f.textAlign(a);let _,m,b,y,v,w,M;for(e.textAlign=a,e.textBaseline="middle",e.font=d.string,t.x=re(this,x,i),e.fillStyle=i.bodyColor,(0,s.F)(this.beforeBody,p),g=r&amp;&amp;"right"!==x?"center"===a?l/2+c:l+2+c:0,y=0,w=n.length;y&lt;w;++y){for(_=n[y],m=this.labelTextColors[y],e.fillStyle=m,(0,s.F)(_.before,p),b=_.lines,r&amp;&amp;b.length&amp;&amp;(this._drawColorBox(e,t,y,f,i),u=Math.max(d.lineHeight,h)),v=0,M=b.length;v&lt;M;++v)p(b[v]),u=d.lineHeight;(0,s.F)(_.after,p)}g=0,u=d.lineHeight,(0,s.F)(this.afterBody,p),t.y-=o}drawFooter(t,e,i){const n=this.footer,o=n.length;let a,r;if(o){const h=(0,s.az)(i.rtl,this.x,this.width);for(t.x=re(this,i.footerAlign,i),t.y+=i.footerMarginTop,e.textAlign=h.textAlign(i.footerAlign),e.textBaseline="middle",a=(0,s.a0)(i.footerFont),e.fillStyle=i.footerColor,e.font=a.string,r=0;r&lt;o;++r)e.fillText(n[r],h.x(t.x),t.y+a.lineHeight/2),t.y+=a.lineHeight+i.footerSpacing}}drawBackground(t,e,i,n){const{xAlign:o,yAlign:a}=this,{x:r,y:h}=t,{width:l,height:c}=i,{topLeft:d,topRight:u,bottomLeft:g,bottomRight:f}=(0,s.aw)(n.cornerRadius);e.fillStyle=n.backgroundColor,e.strokeStyle=n.borderColor,e.lineWidth=n.borderWidth,e.beginPath(),e.moveTo(r+d,h),"top"===a&amp;&amp;this.drawCaret(t,e,i,n),e.lineTo(r+l-u,h),e.quadraticCurveTo(r+l,h,r+l,h+u),"center"===a&amp;&amp;"right"===o&amp;&amp;this.drawCaret(t,e,i,n),e.lineTo(r+l,h+c-f),e.quadraticCurveTo(r+l,h+c,r+l-f,h+c),"bottom"===a&amp;&amp;this.drawCaret(t,e,i,n),e.lineTo(r+g,h+c),e.quadraticCurveTo(r,h+c,r,h+c-g),"center"===a&amp;&amp;"left"===o&amp;&amp;this.drawCaret(t,e,i,n),e.lineTo(r,h+d),e.quadraticCurveTo(r,h,r+d,h),e.closePath(),e.fill(),n.borderWidth&gt;0&amp;&amp;e.stroke()}_updateAnimationTarget(t){const e=this.chart,i=this.$animations,s=i&amp;&amp;i.x,n=i&amp;&amp;i.y;if(s||n){const i=Zt[t.position].call(this,this._active,this._eventPosition);if(!i)return;const o=this._size=se(this,t),a=Object.assign({},i,this._size),r=oe(e,t,a),h=ae(t,a,r,e);s._to===h.x&amp;&amp;n._to===h.y||(this.xAlign=r.xAlign,this.yAlign=r.yAlign,this.width=o.width,this.height=o.height,this.caretX=i.x,this.caretY=i.y,this._resolveAnimations().update(this,h))}}_willRender(){return!!this.opacity}draw(t){const e=this.options.setContext(this.getContext());let i=this.opacity;if(!i)return;this._updateAnimationTarget(e);const n={width:this.width,height:this.height},o={x:this.x,y:this.y};i=Math.abs(i)&lt;.001?0:i;const a=(0,s.E)(e.padding),r=this.title.length||this.beforeBody.length||this.body.length||this.afterBody.length||this.footer.length;e.enabled&amp;&amp;r&amp;&amp;(t.save(),t.globalAlpha=i,this.drawBackground(o,t,n,e),(0,s.aA)(t,e.textDirection),o.y+=a.top,this.drawTitle(o,t,e),this.drawBody(o,t,e),this.drawFooter(o,t,e),(0,s.aC)(t,e.textDirection),t.restore())}getActiveElements(){return this._active||[]}setActiveElements(t,e){const i=this._active,n=t.map((({datasetIndex:t,index:e})=&gt;{const i=this.chart.getDatasetMeta(t);if(!i)throw new Error("Cannot find a dataset at index "+t);return{datasetIndex:t,element:i.data[e],index:e}})),o=!(0,s.ah)(i,n),a=this._positionChanged(n,e);(o||a)&amp;&amp;(this._active=n,this._eventPosition=e,this._ignoreReplayEvents=!0,this.update(!0))}handleEvent(t,e,i=!0){if(e&amp;&amp;this._ignoreReplayEvents)return!1;this._ignoreReplayEvents=!1;const n=this.options,o=this._active||[],a=this._getActiveElements(t,o,e,i),r=this._positionChanged(a,t),h=e||!(0,s.ah)(a,o)||r;return h&amp;&amp;(this._active=a,(n.enabled||n.external)&amp;&amp;(this._eventPosition={x:t.x,y:t.y},this.update(!0,e))),h}_getActiveElements(t,e,i,s){const n=this.options;if("mouseout"===t.type)return[];if(!s)return e.filter((t=&gt;this.chart.data.datasets[t.datasetIndex]&amp;&amp;void 0!==this.chart.getDatasetMeta(t.datasetIndex).controller.getParsed(t.index)));const o=this.chart.getElementsAtEventForMode(t,n.mode,n,i);return n.reverse&amp;&amp;o.reverse(),o}_positionChanged(t,e){const{caretX:i,caretY:s,options:n}=this,o=Zt[n.position].call(this,t,e);return!1!==o&amp;&amp;(i!==o.x||s!==o.y)}}var ge={id:"tooltip",_element:ue,positioners:Zt,afterInit(t,e,i){i&amp;&amp;(t.tooltip=new ue({chart:t,options:i}))},beforeUpdate(t,e,i){t.tooltip&amp;&amp;t.tooltip.initialize(i)},reset(t,e,i){t.tooltip&amp;&amp;t.tooltip.initialize(i)},afterDraw(t){const e=t.tooltip;if(e&amp;&amp;e._willRender()){const i={tooltip:e};if(!1===t.notifyPlugins("beforeTooltipDraw",{...i,cancelable:!0}))return;e.draw(t.ctx),t.notifyPlugins("afterTooltipDraw",i)}},afterEvent(t,e){if(t.tooltip){const i=e.replay;t.tooltip.handleEvent(e.event,i,e.inChartArea)&amp;&amp;(e.changed=!0)}},defaults:{enabled:!0,external:null,position:"average",backgroundColor:"rgba(0,0,0,0.8)",titleColor:"#fff",titleFont:{weight:"bold"},titleSpacing:2,titleMarginBottom:6,titleAlign:"left",bodyColor:"#fff",bodySpacing:2,bodyFont:{},bodyAlign:"left",footerColor:"#fff",footerSpacing:2,footerMarginTop:6,footerFont:{weight:"bold"},footerAlign:"left",padding:6,caretPadding:2,caretSize:5,cornerRadius:6,boxHeight:(t,e)=&gt;e.bodyFont.size,boxWidth:(t,e)=&gt;e.bodyFont.size,multiKeyBackground:"#fff",displayColors:!0,boxPadding:0,borderColor:"rgba(0,0,0,0)",borderWidth:0,animation:{duration:400,easing:"easeOutQuart"},animations:{numbers:{type:"number",properties:["x","y","width","height","caretX","caretY"]},opacity:{easing:"linear",duration:200}},callbacks:ce},defaultRoutes:{bodyFont:"font",footerFont:"font",titleFont:"font"},descriptors:{_scriptable:t=&gt;"filter"!==t&amp;&amp;"itemSort"!==t&amp;&amp;"external"!==t,_indexable:!1,callbacks:{_scriptable:!1,_indexable:!1},animation:{_fallback:!1},animations:{_fallback:"animation"}},additionalOptionScopes:["interaction"]};s.aL.formatters.numeric;s.aL.formatters.logarithmic;s.aL.formatters.numeric}}]);</pre></body></html>