diff --git a/assets/Loading-ad1d8aa1.js b/assets/Loading-e28fecd7.js similarity index 99% rename from assets/Loading-ad1d8aa1.js rename to assets/Loading-e28fecd7.js index 431c1ac..d03ad8e 100644 --- a/assets/Loading-ad1d8aa1.js +++ b/assets/Loading-e28fecd7.js @@ -34,6 +34,6 @@ ${i.stack}`:n}function Fd(i,t){const e=t(i.length*1,1)>>>0;return ln().set(i,e/1 * Released under the MIT License */class U0{constructor(){this._request=null,this._charts=new Map,this._running=!1,this._lastDate=void 0}_notify(t,e,n,s){const o=e.listeners[s],r=e.duration;o.forEach(a=>a({chart:t,initial:e.initial,numSteps:r,currentStep:Math.min(n-e.start,r)}))}_refresh(){this._request||(this._running=!0,this._request=fu.call(window,()=>{this._update(),this._request=null,this._running&&this._refresh()}))}_update(t=Date.now()){let e=0;this._charts.forEach((n,s)=>{if(!n.running||!n.items.length)return;const o=n.items;let r=o.length-1,a=!1,l;for(;r>=0;--r)l=o[r],l._active?(l._total>n.duration&&(n.duration=l._total),l.tick(t),a=!0):(o[r]=o[o.length-1],o.pop());a&&(s.draw(),this._notify(s,n,t,"progress")),o.length||(n.running=!1,this._notify(s,n,t,"complete"),n.initial=!1),e+=o.length}),this._lastDate=t,e===0&&(this._running=!1)}_getAnims(t){const e=this._charts;let n=e.get(t);return n||(n={running:!1,initial:!0,items:[],listeners:{complete:[],progress:[]}},e.set(t,n)),n}listen(t,e,n){this._getAnims(t).listeners[e].push(n)}add(t,e){!e||!e.length||this._getAnims(t).items.push(...e)}has(t){return this._getAnims(t).items.length>0}start(t){const e=this._charts.get(t);e&&(e.running=!0,e.start=Date.now(),e.duration=e.items.reduce((n,s)=>Math.max(n,s._duration),0),this._refresh())}running(t){if(!this._running)return!1;const e=this._charts.get(t);return!(!e||!e.running||!e.items.length)}stop(t){const e=this._charts.get(t);if(!e||!e.items.length)return;const n=e.items;let s=n.length-1;for(;s>=0;--s)n[s].cancel();e.items=[],this._notify(t,e,Date.now(),"complete")}remove(t){return this._charts.delete(t)}}var re=new U0;const nc="transparent",q0={boolean(i,t,e){return e>.5?t:i},color(i,t,e){const n=Ul(i||nc),s=n.valid&&Ul(t||nc);return s&&s.valid?s.mix(n,e).hexString():t},number(i,t,e){return i+(t-i)*e}};class K0{constructor(t,e,n,s){const o=e[n];s=is([t.to,s,o,t.from]);const r=is([t.from,o,s]);this._active=!0,this._fn=t.fn||q0[t.type||typeof r],this._easing=mn[t.easing]||mn.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=n,this._from=r,this._to=s,this._promises=void 0}active(){return this._active}update(t,e,n){if(this._active){this._notify(!1);const s=this._target[this._prop],o=n-this._start,r=this._duration-o;this._start=n,this._duration=Math.floor(Math.max(r,t.duration)),this._total+=o,this._loop=!!t.loop,this._to=is([t.to,e,s,t.from]),this._from=is([t.from,s,e])}}cancel(){this._active&&(this.tick(Date.now()),this._active=!1,this._notify(!1))}tick(t){const e=t-this._start,n=this._duration,s=this._prop,o=this._from,r=this._loop,a=this._to;let l;if(this._active=o!==a&&(r||e1?2-l:l,l=this._easing(Math.min(1,Math.max(0,l))),this._target[s]=this._fn(o,a,l)}wait(){const t=this._promises||(this._promises=[]);return new Promise((e,n)=>{t.push({res:e,rej:n})})}_notify(t){const e=t?"res":"rej",n=this._promises||[];for(let s=0;si!=="onProgress"&&i!=="onComplete"&&i!=="fn"});N.set("animations",{colors:{type:"color",properties:Z0},numbers:{type:"number",properties:G0}});N.describe("animations",{_fallback:"animation"});N.set("transitions",{active:{animation:{duration:400}},resize:{animation:{duration:0}},show:{animations:{colors:{from:"transparent"},visible:{type:"boolean",duration:0}}},hide:{animations:{colors:{to:"transparent"},visible:{type:"boolean",easing:"linear",fn:i=>i|0}}}});class Ru{constructor(t,e){this._chart=t,this._properties=new Map,this.configure(e)}configure(t){if(!j(t))return;const e=this._properties;Object.getOwnPropertyNames(t).forEach(n=>{const s=t[n];if(!j(s))return;const o={};for(const r of J0)o[r]=s[r];(et(s.properties)&&s.properties||[n]).forEach(r=>{(r===n||!e.has(r))&&e.set(r,o)})})}_animateOptions(t,e){const n=e.options,s=tx(t,n);if(!s)return[];const o=this._createAnimations(s,n);return n.$shared&&Q0(t.options.$animations,n).then(()=>{t.options=n},()=>{}),o}_createAnimations(t,e){const n=this._properties,s=[],o=t.$animations||(t.$animations={}),r=Object.keys(e),a=Date.now();let l;for(l=r.length-1;l>=0;--l){const c=r[l];if(c.charAt(0)==="$")continue;if(c==="options"){s.push(...this._animateOptions(t,e));continue}const h=e[c];let u=o[c];const d=n.get(c);if(u)if(d&&u.active()){u.update(d,h,a);continue}else u.cancel();if(!d||!d.duration){t[c]=h;continue}o[c]=u=new K0(d,t,c,h),s.push(u)}return s}update(t,e){if(this._properties.size===0){Object.assign(t,e);return}const n=this._createAnimations(t,e);if(n.length)return re.add(this._chart,n),!0}}function Q0(i,t){const e=[],n=Object.keys(t);for(let s=0;s0||!e&&o<0)return s.index}return null}function lc(i,t){const{chart:e,_cachedMeta:n}=i,s=e._stacks||(e._stacks={}),{iScale:o,vScale:r,index:a}=n,l=o.axis,c=r.axis,h=sx(o,r,n),u=t.length;let d;for(let f=0;fe[n].axis===t).shift()}function ax(i,t){return Fe(i,{active:!1,dataset:void 0,datasetIndex:t,index:t,mode:"default",type:"dataset"})}function lx(i,t,e){return Fe(i,{active:!1,dataIndex:t,parsed:void 0,raw:void 0,element:e,index:t,mode:"default",type:"data"})}function Ei(i,t){const e=i.controller.index,n=i.vScale&&i.vScale.axis;if(n){t=t||i._parsed;for(const s of t){const o=s._stacks;if(!o||o[n]===void 0||o[n][e]===void 0)return;delete o[n][e]}}}const Io=i=>i==="reset"||i==="none",cc=(i,t)=>t?i:Object.assign({},i),cx=(i,t,e)=>i&&!t.hidden&&t._stacked&&{keys:Eu(e,!0),values:null};class Ht{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.initialize()}initialize(){const t=this._cachedMeta;this.configure(),this.linkScales(),t._stacked=rc(t.vScale,t),this.addElements()}updateIndex(t){this.index!==t&&Ei(this._cachedMeta),this.index=t}linkScales(){const t=this.chart,e=this._cachedMeta,n=this.getDataset(),s=(u,d,f,g)=>u==="x"?d:u==="r"?g:f,o=e.xAxisID=V(n.xAxisID,Eo(t,"x")),r=e.yAxisID=V(n.yAxisID,Eo(t,"y")),a=e.rAxisID=V(n.rAxisID,Eo(t,"r")),l=e.indexAxis,c=e.iAxisID=s(l,o,r,a),h=e.vAxisID=s(l,r,o,a);e.xScale=this.getScaleForId(o),e.yScale=this.getScaleForId(r),e.rScale=this.getScaleForId(a),e.iScale=this.getScaleForId(c),e.vScale=this.getScaleForId(h)}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&&Bl(this._data,this),t._stacked&&Ei(t)}_dataCheck(){const t=this.getDataset(),e=t.data||(t.data=[]),n=this._data;if(j(e))this._data=nx(e);else if(n!==e){if(n){Bl(n,this);const s=this._cachedMeta;Ei(s),s._parsed=[]}e&&Object.isExtensible(e)&&S_(e,this),this._syncList=[],this._data=e}}addElements(){const t=this._cachedMeta;this._dataCheck(),this.datasetElementType&&(t.dataset=new this.datasetElementType)}buildOrUpdateElements(t){const e=this._cachedMeta,n=this.getDataset();let s=!1;this._dataCheck();const o=e._stacked;e._stacked=rc(e.vScale,e),e.stack!==n.stack&&(s=!0,Ei(e),e.stack=n.stack),this._resyncElements(t),(s||o!==e._stacked)&&lc(this,e._parsed)}configure(){const t=this.chart.config,e=t.datasetScopeKeys(this._type),n=t.getOptionScopes(this.getDataset(),e,!0);this.options=t.createResolver(n,this.getContext()),this._parsing=this.options.parsing,this._cachedDataOpts={}}parse(t,e){const{_cachedMeta:n,_data:s}=this,{iScale:o,_stacked:r}=n,a=o.axis;let l=t===0&&e===s.length?!0:n._sorted,c=t>0&&n._parsed[t-1],h,u,d;if(this._parsing===!1)n._parsed=s,n._sorted=!0,d=s;else{et(s[t])?d=this.parseArrayData(n,s,t,e):j(s[t])?d=this.parseObjectData(n,s,t,e):d=this.parsePrimitiveData(n,s,t,e);const f=()=>u[a]===null||c&&u[a]p||u=0;--d)if(!g()){this.updateRangeFromParsed(c,t,f,l);break}}return c}getAllParsedValues(t){const e=this._cachedMeta._parsed,n=[];let s,o,r;for(s=0,o=e.length;s=0&&tthis.getContext(n,s),p=c.resolveNamedOptions(d,f,g,u);return p.$shared&&(p.$shared=l,o[r]=Object.freeze(cc(p,l))),p}_resolveAnimations(t,e,n){const s=this.chart,o=this._cachedDataOpts,r=`animation-${e}`,a=o[r];if(a)return a;let l;if(s.options.animation!==!1){const h=this.chart.config,u=h.datasetAnimationScopeKeys(this._type,e),d=h.getOptionScopes(this.getDataset(),u);l=h.createResolver(d,this.getContext(t,n,e))}const c=new Ru(s,l&&l.animations);return l&&l._cacheable&&(o[r]=Object.freeze(c)),c}getSharedOptions(t){if(t.$shared)return this._sharedOptions||(this._sharedOptions=Object.assign({},t))}includeOptions(t,e){return!e||Io(t)||this.chart._animationsDisabled}_getSharedOptions(t,e){const n=this.resolveDataElementOptions(t,e),s=this._sharedOptions,o=this.getSharedOptions(n),r=this.includeOptions(e,o)||o!==s;return this.updateSharedOptions(o,e,n),{sharedOptions:o,includeOptions:r}}updateElement(t,e,n,s){Io(s)?Object.assign(t,n):this._resolveAnimations(e,s).update(t,n)}updateSharedOptions(t,e,n){t&&!Io(e)&&this._resolveAnimations(void 0,e).update(t,n)}_setStyle(t,e,n,s){t.active=s;const o=this.getStyle(e,s);this._resolveAnimations(e,n,s).update(t,{options:!s&&this.getSharedOptions(o)||o})}removeHoverStyle(t,e,n){this._setStyle(t,n,"active",!1)}setHoverStyle(t,e,n){this._setStyle(t,n,"active",!0)}_removeDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&&this._setStyle(t,void 0,"active",!1)}_setDatasetHoverStyle(){const t=this._cachedMeta.dataset;t&&this._setStyle(t,void 0,"active",!0)}_resyncElements(t){const e=this._data,n=this._cachedMeta.data;for(const[a,l,c]of this._syncList)this[a](l,c);this._syncList=[];const s=n.length,o=e.length,r=Math.min(o,s);r&&this.parse(0,r),o>s?this._insertElements(s,o-s,t):o{for(c.length+=e,a=c.length-1;a>=r;a--)c[a]=c[a-e]};for(l(o),a=t;as-o))}return i._cache.$bar}function ux(i){const t=i.iScale,e=hx(t,i.type);let n=t._length,s,o,r,a;const l=()=>{r===32767||r===-32768||(Ft(a)&&(n=Math.min(n,Math.abs(r-a)||n)),a=r)};for(s=0,o=e.length;s0?s[i-1]:null,a=iMath.abs(a)&&(l=a,c=r),t[e.axis]=c,t._custom={barStart:l,barEnd:c,start:s,end:o,min:r,max:a}}function Iu(i,t,e,n){return et(i)?gx(i,t,e,n):t[e.axis]=e.parse(i,n),t}function hc(i,t,e,n){const s=i.iScale,o=i.vScale,r=s.getLabels(),a=s===o,l=[];let c,h,u,d;for(c=e,h=e+n;c=e?1:-1)}function mx(i){let t,e,n,s,o;return i.horizontal?(t=i.base>i.x,e="left",n="right"):(t=i.basel.controller.options.grouped),o=n.options.stacked,r=[],a=l=>{const c=l.controller.getParsed(e),h=c&&c[l.vScale.axis];if(q(h)||isNaN(h))return!0};for(const l of s)if(!(e!==void 0&&a(l))&&((o===!1||r.indexOf(l.stack)===-1||o===void 0&&l.stack===void 0)&&r.push(l.stack),l.index===t))break;return r.length||r.push(void 0),r}_getStackCount(t){return this._getStacks(void 0,t).length}_getStackIndex(t,e,n){const s=this._getStacks(t,n),o=e!==void 0?s.indexOf(e):-1;return o===-1?s.length-1:o}_getRuler(){const t=this.options,e=this._cachedMeta,n=e.iScale,s=[];let o,r;for(o=0,r=e.data.length;o=0;--n)e=Math.max(e,t[n].size(this.resolveDataElementOptions(n))/2);return e>0&&e}getLabelAndValue(t){const e=this._cachedMeta,{xScale:n,yScale:s}=e,o=this.getParsed(t),r=n.getLabelForValue(o.x),a=s.getLabelForValue(o.y),l=o._custom;return{label:e.label,value:"("+r+", "+a+(l?", "+l:"")+")"}}update(t){const e=this._cachedMeta.data;this.updateElements(e,0,e.length,t)}updateElements(t,e,n,s){const o=s==="reset",{iScale:r,vScale:a}=this._cachedMeta,{sharedOptions:l,includeOptions:c}=this._getSharedOptions(e,s),h=r.axis,u=a.axis;for(let d=e;dSn(v,a,l,!0)?1:Math.max(b,b*e,y,y*e),g=(v,b,y)=>Sn(v,a,l,!0)?-1:Math.min(b,b*e,y,y*e),p=f(0,c,u),m=f(lt,h,d),_=g(ct,c,u),x=g(ct+lt,h,d);n=(p-_)/2,s=(m-x)/2,o=-(p+_)/2,r=-(m+x)/2}return{ratioX:n,ratioY:s,offsetX:o,offsetY:r}}class Fn extends Ht{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 n=this.getDataset().data,s=this._cachedMeta;if(this._parsing===!1)s._parsed=n;else{let o=l=>+n[l];if(j(n[t])){const{key:l="value"}=this._parsing;o=c=>+Le(n[c],l)}let r,a;for(r=t,a=t+e;r0&&!isNaN(t)?K*(Math.abs(t)/e):0}getLabelAndValue(t){const e=this._cachedMeta,n=this.chart,s=n.data.labels||[],o=In(e._parsed[t],n.options.locale);return{label:s[t]||"",value:o}}getMaxBorderWidth(t){let e=0;const n=this.chart;let s,o,r,a,l;if(!t){for(s=0,o=n.data.datasets.length;si!=="spacing",_indexable:i=>i!=="spacing"};Fn.overrides={aspectRatio:1,plugins:{legend:{labels:{generateLabels(i){const t=i.data;if(t.labels.length&&t.datasets.length){const{labels:{pointStyle:e}}=i.legend.options;return t.labels.map((n,s)=>{const r=i.getDatasetMeta(0).controller.getStyle(s);return{text:n,fillStyle:r.backgroundColor,strokeStyle:r.borderColor,lineWidth:r.borderWidth,pointStyle:e,hidden:!i.getDataVisibility(s),index:s}})}return[]}},onClick(i,t,e){e.chart.toggleDataVisibility(t.index),e.chart.update()}},tooltip:{callbacks:{title(){return""},label(i){let t=i.label;const e=": "+i.formattedValue;return et(t)?(t=t.slice(),t[0]+=e):t+=e,t}}}}};class Jr extends Ht{initialize(){this.enableOptionSharing=!0,this.supportsDecimation=!0,super.initialize()}update(t){const e=this._cachedMeta,{dataset:n,data:s=[],_dataset:o}=e,r=this.chart._animationsDisabled;let{start:a,count:l}=pu(e,s,r);this._drawStart=a,this._drawCount=l,mu(e)&&(a=0,l=s.length),n._chart=this.chart,n._datasetIndex=this.index,n._decimated=!!o._decimated,n.points=s;const c=this.resolveDatasetElementOptions(t);this.options.showLine||(c.borderWidth=0),c.segment=this.options.segment,this.updateElement(n,void 0,{animated:!r,options:c},t),this.updateElements(s,a,l,t)}updateElements(t,e,n,s){const o=s==="reset",{iScale:r,vScale:a,_stacked:l,_dataset:c}=this._cachedMeta,{sharedOptions:h,includeOptions:u}=this._getSharedOptions(e,s),d=r.axis,f=a.axis,{spanGaps:g,segment:p}=this.options,m=Mi(g)?g:Number.POSITIVE_INFINITY,_=this.chart._animationsDisabled||o||s==="none";let x=e>0&&this.getParsed(e-1);for(let v=e;v0&&Math.abs(y[d]-x[d])>m,p&&(M.parsed=y,M.raw=c.data[v]),u&&(M.options=h||this.resolveDataElementOptions(v,b.active?"active":s)),_||this.updateElement(b,v,M,s),x=y}}getMaxOverflow(){const t=this._cachedMeta,e=t.dataset,n=e.options&&e.options.borderWidth||0,s=t.data||[];if(!s.length)return n;const o=s[0].size(this.resolveDataElementOptions(0)),r=s[s.length-1].size(this.resolveDataElementOptions(s.length-1));return Math.max(n,o,r)/2}draw(){const t=this._cachedMeta;t.dataset.updateControlPoints(this.chart.chartArea,t.iScale.axis),super.draw()}}Jr.id="line";Jr.defaults={datasetElementType:"line",dataElementType:"point",showLine:!0,spanGaps:!1};Jr.overrides={scales:{_index_:{type:"category"},_value_:{type:"linear"}}};class Qr extends Ht{constructor(t,e){super(t,e),this.innerRadius=void 0,this.outerRadius=void 0}getLabelAndValue(t){const e=this._cachedMeta,n=this.chart,s=n.data.labels||[],o=In(e._parsed[t].r,n.options.locale);return{label:s[t]||"",value:o}}parseObjectData(t,e,n,s){return Du.bind(this)(t,e,n,s)}update(t){const e=this._cachedMeta.data;this._updateRadius(),this.updateElements(e,0,e.length,t)}getMinMax(){const t=this._cachedMeta,e={min:Number.POSITIVE_INFINITY,max:Number.NEGATIVE_INFINITY};return t.data.forEach((n,s)=>{const o=this.getParsed(s).r;!isNaN(o)&&this.chart.getDataVisibility(s)&&(oe.max&&(e.max=o))}),e}_updateRadius(){const t=this.chart,e=t.chartArea,n=t.options,s=Math.min(e.right-e.left,e.bottom-e.top),o=Math.max(s/2,0),r=Math.max(n.cutoutPercentage?o/100*n.cutoutPercentage:1,0),a=(o-r)/t.getVisibleDatasetCount();this.outerRadius=o-a*this.index,this.innerRadius=this.outerRadius-a}updateElements(t,e,n,s){const o=s==="reset",r=this.chart,l=r.options.animation,c=this._cachedMeta.rScale,h=c.xCenter,u=c.yCenter,d=c.getIndexAngle(0)-.5*ct;let f=d,g;const p=360/this.countVisibleElements();for(g=0;g{!isNaN(this.getParsed(s).r)&&this.chart.getDataVisibility(s)&&e++}),e}_computeAngle(t,e,n){return this.chart.getDataVisibility(t)?Vt(this.resolveDataElementOptions(t,e).angle||n):0}}Qr.id="polarArea";Qr.defaults={dataElementType:"arc",animation:{animateRotate:!0,animateScale:!0},animations:{numbers:{type:"number",properties:["x","y","startAngle","endAngle","innerRadius","outerRadius"]}},indexAxis:"r",startAngle:0};Qr.overrides={aspectRatio:1,plugins:{legend:{labels:{generateLabels(i){const t=i.data;if(t.labels.length&&t.datasets.length){const{labels:{pointStyle:e}}=i.legend.options;return t.labels.map((n,s)=>{const r=i.getDatasetMeta(0).controller.getStyle(s);return{text:n,fillStyle:r.backgroundColor,strokeStyle:r.borderColor,lineWidth:r.borderWidth,pointStyle:e,hidden:!i.getDataVisibility(s),index:s}})}return[]}},onClick(i,t,e){e.chart.toggleDataVisibility(t.index),e.chart.update()}},tooltip:{callbacks:{title(){return""},label(i){return i.chart.data.labels[i.dataIndex]+": "+i.formattedValue}}}},scales:{r:{type:"radialLinear",angleLines:{display:!1},beginAtZero:!0,grid:{circular:!0},pointLabels:{display:!1},startAngle:0}}};class Fu extends Fn{}Fu.id="pie";Fu.defaults={cutout:0,rotation:0,circumference:360,radius:"100%"};class ta extends Ht{getLabelAndValue(t){const e=this._cachedMeta.vScale,n=this.getParsed(t);return{label:e.getLabels()[t],value:""+e.getLabelForValue(n[e.axis])}}parseObjectData(t,e,n,s){return Du.bind(this)(t,e,n,s)}update(t){const e=this._cachedMeta,n=e.dataset,s=e.data||[],o=e.iScale.getLabels();if(n.points=s,t!=="resize"){const r=this.resolveDatasetElementOptions(t);this.options.showLine||(r.borderWidth=0);const a={_loop:!0,_fullLoop:o.length===s.length,options:r};this.updateElement(n,void 0,a,t)}this.updateElements(s,0,s.length,t)}updateElements(t,e,n,s){const o=this._cachedMeta.rScale,r=s==="reset";for(let a=e;a{s[o]=n[o]&&n[o].active()?n[o]._to:this[o]}),s}}be.defaults={};be.defaultRoutes=void 0;const $u={values(i){return et(i)?i:""+i},numeric(i,t,e){if(i===0)return"0";const n=this.chart.options.locale;let s,o=i;if(e.length>1){const c=Math.max(Math.abs(e[0].value),Math.abs(e[e.length-1].value));(c<1e-4||c>1e15)&&(s="scientific"),o=vx(i,e)}const r=It(Math.abs(o)),a=Math.max(Math.min(-1*Math.floor(r),20),0),l={notation:s,minimumFractionDigits:a,maximumFractionDigits:a};return Object.assign(l,this.options.ticks.format),In(i,n,l)},logarithmic(i,t,e){if(i===0)return"0";const n=i/Math.pow(10,Math.floor(It(i)));return n===1||n===2||n===5?$u.numeric.call(this,i,t,e):""}};function vx(i,t){let e=t.length>3?t[2].value-t[1].value:t[1].value-t[0].value;return Math.abs(e)>=1&&i!==Math.floor(i)&&(e=i-Math.floor(i)),e}var oo={formatters:$u};N.set("scale",{display:!0,offset:!1,reverse:!1,beginAtZero:!1,bounds:"ticks",grace:0,grid:{display:!0,lineWidth:1,drawBorder:!0,drawOnChartArea:!0,drawTicks:!0,tickLength:8,tickWidth:(i,t)=>t.lineWidth,tickColor:(i,t)=>t.color,offset:!1,borderDash:[],borderDashOffset:0,borderWidth:1},title:{display:!1,text:"",padding:{top:4,bottom:4}},ticks:{minRotation:0,maxRotation:50,mirror:!1,textStrokeWidth:0,textStrokeColor:"",padding:3,display:!0,autoSkip:!0,autoSkipPadding:3,labelOffset:0,callback:oo.formatters.values,minor:{},major:{},align:"center",crossAlign:"near",showLabelBackdrop:!1,backdropColor:"rgba(255, 255, 255, 0.75)",backdropPadding:2}});N.route("scale.ticks","color","","color");N.route("scale.grid","color","","borderColor");N.route("scale.grid","borderColor","","borderColor");N.route("scale.title","color","","color");N.describe("scale",{_fallback:!1,_scriptable:i=>!i.startsWith("before")&&!i.startsWith("after")&&i!=="callback"&&i!=="parser",_indexable:i=>i!=="borderDash"&&i!=="tickBorderDash"});N.describe("scales",{_fallback:"scale"});N.describe("scale.ticks",{_scriptable:i=>i!=="backdropPadding"&&i!=="callback",_indexable:i=>i!=="backdropPadding"});function wx(i,t){const e=i.options.ticks,n=e.maxTicksLimit||Mx(i),s=e.major.enabled?Sx(t):[],o=s.length,r=s[0],a=s[o-1],l=[];if(o>n)return Px(t,l,s,o/n),l;const c=kx(s,t,n);if(o>0){let h,u;const d=o>1?Math.round((a-r)/(o-1)):null;for(ss(t,l,c,q(d)?0:r-d,r),h=0,u=o-1;hs)return l}return Math.max(s,1)}function Sx(i){const t=[];let e,n;for(e=0,n=i.length;ei==="left"?"right":i==="right"?"left":i,fc=(i,t,e)=>t==="top"||t==="left"?i[t]+e:i[t]-e;function gc(i,t){const e=[],n=i.length/t,s=i.length;let o=0;for(;or+a)))return l}function Ox(i,t){U(i,e=>{const n=e.gc,s=n.length/2;let o;if(s>t){for(o=0;on?n:e,n=s&&e>n?e:n,{min:Rt(e,Rt(n,e)),max:Rt(n,Rt(e,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||[]}beforeLayout(){this._cache={},this._dataLimitsCached=!1}beforeUpdate(){nt(this.options.beforeUpdate,[this])}update(t,e,n){const{beginAtZero:s,grace:o,ticks:r}=this.options,a=r.sampleSize;this.beforeUpdate(),this.maxWidth=t,this.maxHeight=e,this._margins=n=Object.assign({left:0,right:0,top:0,bottom:0},n),this.ticks=null,this._labelSizes=null,this._gridLineItems=null,this._labelItems=null,this.beforeSetDimensions(),this.setDimensions(),this.afterSetDimensions(),this._maxLength=this.isHorizontal()?this.width+n.left+n.right:this.height+n.top+n.bottom,this._dataLimitsCached||(this.beforeDataLimits(),this.determineDataLimits(),this.afterDataLimits(),this._range=l0(this,o,s),this._dataLimitsCached=!0),this.beforeBuildTicks(),this.ticks=this.buildTicks()||[],this.afterBuildTicks();const l=a=o||n<=1||!this.isHorizontal()){this.labelRotation=s;return}const h=this._getLabelSizes(),u=h.widest.width,d=h.highest.height,f=yt(this.chart.width-u,0,this.maxWidth);a=t.offset?this.maxWidth/n:f/(n-1),u+6>a&&(a=f/(n-(t.offset?.5:1)),l=this.maxHeight-Ii(t.grid)-e.padding-pc(t.title,this.chart.options.font),c=Math.sqrt(u*u+d*d),r=Nr(Math.min(Math.asin(yt((h.highest.height+6)/a,-1,1)),Math.asin(yt(l/c,-1,1))-Math.asin(yt(d/c,-1,1)))),r=Math.max(s,Math.min(o,r))),this.labelRotation=r}afterCalculateLabelRotation(){nt(this.options.afterCalculateLabelRotation,[this])}afterAutoSkip(){}beforeFit(){nt(this.options.beforeFit,[this])}fit(){const t={width:0,height:0},{chart:e,options:{ticks:n,title:s,grid:o}}=this,r=this._isVisible(),a=this.isHorizontal();if(r){const l=pc(s,e.options.font);if(a?(t.width=this.maxWidth,t.height=Ii(o)+l):(t.height=this.maxHeight,t.width=Ii(o)+l),n.display&&this.ticks.length){const{first:c,last:h,widest:u,highest:d}=this._getLabelSizes(),f=n.padding*2,g=Vt(this.labelRotation),p=Math.cos(g),m=Math.sin(g);if(a){const _=n.mirror?0:m*u.width+p*d.height;t.height=Math.min(this.maxHeight,t.height+_+f)}else{const _=n.mirror?0:p*u.width+m*d.height;t.width=Math.min(this.maxWidth,t.width+_+f)}this._calculatePadding(c,h,m,p)}}this._handleMargins(),a?(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,n,s){const{ticks:{align:o,padding:r},position:a}=this.options,l=this.labelRotation!==0,c=a!=="top"&&this.axis==="x";if(this.isHorizontal()){const h=this.getPixelForTick(0)-this.left,u=this.right-this.getPixelForTick(this.ticks.length-1);let d=0,f=0;l?c?(d=s*t.width,f=n*e.height):(d=n*t.height,f=s*e.width):o==="start"?f=e.width:o==="end"?d=t.width:o!=="inner"&&(d=t.width/2,f=e.width/2),this.paddingLeft=Math.max((d-h+r)*this.width/(this.width-h),0),this.paddingRight=Math.max((f-u+r)*this.width/(this.width-u),0)}else{let h=e.height/2,u=t.height/2;o==="start"?(h=0,u=t.height):o==="end"&&(h=e.height,u=0),this.paddingTop=h+r,this.paddingBottom=u+r}}_handleMargins(){this._margins&&(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(){nt(this.options.afterFit,[this])}isHorizontal(){const{axis:t,position:e}=this.options;return e==="top"||e==="bottom"||t==="x"}isFullSize(){return this.options.fullSize}_convertTicksToLabels(t){this.beforeTickToLabelConversion(),this.generateTickLabels(t);let e,n;for(e=0,n=t.length;e({width:o[w]||0,height:r[w]||0});return{first:M(0),last:M(e-1),widest:M(b),highest:M(y),widths:o,heights:r}}getLabelForValue(t){return t}getPixelForValue(t,e){return NaN}getValueForPixel(t){}getPixelForTick(t){const e=this.ticks;return t<0||t>e.length-1?null:this.getPixelForValue(e[t].value)}getPixelForDecimal(t){this._reversePixels&&(t=1-t);const e=this._startPixel+t*this._length;return w_(this._alignToPixels?We(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<0&&e<0?e:t>0&&e>0?t:0}getContext(t){const e=this.ticks||[];if(t>=0&&ta*s?a/n:l/s:l*s0}_computeGridLineItems(t){const e=this.axis,n=this.chart,s=this.options,{grid:o,position:r}=s,a=o.offset,l=this.isHorizontal(),h=this.ticks.length+(a?1:0),u=Ii(o),d=[],f=o.setContext(this.getContext()),g=f.drawBorder?f.borderWidth:0,p=g/2,m=function(A){return We(n,A,g)};let _,x,v,b,y,M,w,k,S,P,D,O;if(r==="top")_=m(this.bottom),M=this.bottom-u,k=_-p,P=m(t.top)+p,O=t.bottom;else if(r==="bottom")_=m(this.top),P=t.top,O=m(t.bottom)-p,M=_+p,k=this.top+u;else if(r==="left")_=m(this.right),y=this.right-u,w=_-p,S=m(t.left)+p,D=t.right;else if(r==="right")_=m(this.left),S=t.left,D=m(t.right)-p,y=_+p,w=this.left+u;else if(e==="x"){if(r==="center")_=m((t.top+t.bottom)/2+.5);else if(j(r)){const A=Object.keys(r)[0],L=r[A];_=m(this.chart.scales[A].getPixelForValue(L))}P=t.top,O=t.bottom,M=_+p,k=M+u}else if(e==="y"){if(r==="center")_=m((t.left+t.right)/2);else if(j(r)){const A=Object.keys(r)[0],L=r[A];_=m(this.chart.scales[A].getPixelForValue(L))}y=_-p,w=y-u,S=t.left,D=t.right}const H=V(s.ticks.maxTicksLimit,h),z=Math.max(1,Math.ceil(h/H));for(x=0;xo.value===t);return s>=0?e.setContext(this.getContext(s)).lineWidth:0}drawGrid(t){const e=this.options.grid,n=this.ctx,s=this._gridLineItems||(this._gridLineItems=this._computeGridLineItems(t));let o,r;const a=(l,c,h)=>{!h.width||!h.color||(n.save(),n.lineWidth=h.width,n.strokeStyle=h.color,n.setLineDash(h.borderDash||[]),n.lineDashOffset=h.borderDashOffset,n.beginPath(),n.moveTo(l.x,l.y),n.lineTo(c.x,c.y),n.stroke(),n.restore())};if(e.display)for(o=0,r=s.length;o{this.draw(s)}}]:[{z:n,draw:s=>{this.drawBackground(),this.drawGrid(s),this.drawTitle()}},{z:n+1,draw:()=>{this.drawBorder()}},{z:e,draw:s=>{this.drawLabels(s)}}]}getMatchingVisibleMetas(t){const e=this.chart.getSortedVisibleDatasetMetas(),n=this.axis+"AxisID",s=[];let o,r;for(o=0,r=e.length;o{const n=e.split("."),s=n.pop(),o=[i].concat(n).join("."),r=t[e].split("."),a=r.pop(),l=r.join(".");N.route(o,s,l,a)})}function $x(i){return"id"in i&&"defaults"in i}class zx{constructor(){this.controllers=new os(Ht,"datasets",!0),this.elements=new os(be,"elements"),this.plugins=new os(Object,"plugins"),this.scales=new os(ri,"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,n){[...e].forEach(s=>{const o=n||this._getRegistryForType(s);n||o.isForType(s)||o===this.plugins&&s.id?this._exec(t,o,s):U(s,r=>{const a=n||this._getRegistryForType(r);this._exec(t,a,r)})})}_exec(t,e,n){const s=Br(t);nt(n["before"+s],[],n),e[t](n),nt(n["after"+s],[],n)}_getRegistryForType(t){for(let e=0;e0&&this.getParsed(e-1);for(let b=e;b0&&Math.abs(M[f]-v[f])>_,m&&(w.parsed=M,w.raw=c.data[b]),d&&(w.options=u||this.resolveDataElementOptions(b,y.active?"active":s)),x||this.updateElement(y,b,w,s),v=M}this.updateSharedOptions(u,s,h)}getMaxOverflow(){const t=this._cachedMeta,e=t.data||[];if(!this.options.showLine){let a=0;for(let l=e.length-1;l>=0;--l)a=Math.max(a,e[l].size(this.resolveDataElementOptions(l))/2);return a>0&&a}const n=t.dataset,s=n.options&&n.options.borderWidth||0;if(!e.length)return s;const o=e[0].size(this.resolveDataElementOptions(0)),r=e[e.length-1].size(this.resolveDataElementOptions(e.length-1));return Math.max(s,o,r)/2}}ea.id="scatter";ea.defaults={datasetElementType:!1,dataElementType:"point",showLine:!1,fill:!1};ea.overrides={interaction:{mode:"point"},plugins:{tooltip:{callbacks:{title(){return""},label(i){return"("+i.label+", "+i.formattedValue+")"}}}},scales:{x:{type:"linear"},y:{type:"linear"}}};function je(){throw new Error("This method is not implemented: Check that a complete date adapter is provided.")}class lr{constructor(t){this.options=t||{}}init(t){}formats(){return je()}parse(t,e){return je()}format(t,e){return je()}add(t,e,n){return je()}diff(t,e,n){return je()}startOf(t,e,n){return je()}endOf(t,e){return je()}}lr.override=function(i){Object.assign(lr.prototype,i)};var Bx={_date:lr};function Nx(i,t,e,n){const{controller:s,data:o,_sorted:r}=i,a=s._cachedMeta.iScale;if(a&&t===a.axis&&t!=="r"&&r&&o.length){const l=a._reversePixels?M_:Je;if(n){if(s._sharedOptions){const c=o[0],h=typeof c.getRange=="function"&&c.getRange(t);if(h){const u=l(o,t,e-h),d=l(o,t,e+h);return{lo:u.lo,hi:d.hi}}}}else return l(o,t,e)}return{lo:0,hi:o.length-1}}function $n(i,t,e,n,s){const o=i.getSortedVisibleDatasetMetas(),r=e[t];for(let a=0,l=o.length;a{l[r](t[e],s)&&(o.push({element:l,datasetIndex:c,index:h}),a=a||l.inRange(t.x,t.y,s))}),n&&!a?[]:o}var Hx={evaluateInteractionItems:$n,modes:{index(i,t,e,n){const s=Xe(t,i),o=e.axis||"x",r=e.includeInvisible||!1,a=e.intersect?$o(i,s,o,n,r):zo(i,s,o,!1,n,r),l=[];return a.length?(i.getSortedVisibleDatasetMetas().forEach(c=>{const h=a[0].index,u=c.data[h];u&&!u.skip&&l.push({element:u,datasetIndex:c.index,index:h})}),l):[]},dataset(i,t,e,n){const s=Xe(t,i),o=e.axis||"xy",r=e.includeInvisible||!1;let a=e.intersect?$o(i,s,o,n,r):zo(i,s,o,!1,n,r);if(a.length>0){const l=a[0].datasetIndex,c=i.getDatasetMeta(l).data;a=[];for(let h=0;he.pos===t)}function bc(i,t){return i.filter(e=>zu.indexOf(e.pos)===-1&&e.box.axis===t)}function $i(i,t){return i.sort((e,n)=>{const s=t?n:e,o=t?e:n;return s.weight===o.weight?s.index-o.index:s.weight-o.weight})}function Yx(i){const t=[];let e,n,s,o,r,a;for(e=0,n=(i||[]).length;ec.box.fullSize),!0),n=$i(Fi(t,"left"),!0),s=$i(Fi(t,"right")),o=$i(Fi(t,"top"),!0),r=$i(Fi(t,"bottom")),a=bc(t,"x"),l=bc(t,"y");return{fullSize:e,leftAndTop:n.concat(o),rightAndBottom:s.concat(l).concat(r).concat(a),chartArea:Fi(t,"chartArea"),vertical:n.concat(s).concat(l),horizontal:o.concat(r).concat(a)}}function _c(i,t,e,n){return Math.max(i[e],t[e])+Math.max(i[n],t[n])}function Bu(i,t){i.top=Math.max(i.top,t.top),i.left=Math.max(i.left,t.left),i.bottom=Math.max(i.bottom,t.bottom),i.right=Math.max(i.right,t.right)}function Kx(i,t,e,n){const{pos:s,box:o}=e,r=i.maxPadding;if(!j(s)){e.size&&(i[s]-=e.size);const u=n[e.stack]||{size:0,count:1};u.size=Math.max(u.size,e.horizontal?o.height:o.width),e.size=u.size/u.count,i[s]+=e.size}o.getPadding&&Bu(r,o.getPadding());const a=Math.max(0,t.outerWidth-_c(r,i,"left","right")),l=Math.max(0,t.outerHeight-_c(r,i,"top","bottom")),c=a!==i.w,h=l!==i.h;return i.w=a,i.h=l,e.horizontal?{same:c,other:h}:{same:h,other:c}}function Gx(i){const t=i.maxPadding;function e(n){const s=Math.max(t[n]-i[n],0);return i[n]+=s,s}i.y+=e("top"),i.x+=e("left"),e("right"),e("bottom")}function Zx(i,t){const e=t.maxPadding;function n(s){const o={left:0,top:0,right:0,bottom:0};return s.forEach(r=>{o[r]=Math.max(t[r],e[r])}),o}return n(i?["left","right"]:["top","bottom"])}function on(i,t,e,n){const s=[];let o,r,a,l,c,h;for(o=0,r=i.length,c=0;o{typeof p.beforeLayout=="function"&&p.beforeLayout()});const h=l.reduce((p,m)=>m.box.options&&m.box.options.display===!1?p:p+1,0)||1,u=Object.freeze({outerWidth:t,outerHeight:e,padding:s,availableWidth:o,availableHeight:r,vBoxMaxWidth:o/2/h,hBoxMaxHeight:r/2}),d=Object.assign({},s);Bu(d,$t(n));const f=Object.assign({maxPadding:d,w:o,h:r,x:s.left,y:s.top},s),g=Ux(l.concat(c),u);on(a.fullSize,f,u,g),on(l,f,u,g),on(c,f,u,g)&&on(l,f,u,g),Gx(f),xc(a.leftAndTop,f,u,g),f.x+=f.w,f.y+=f.h,xc(a.rightAndBottom,f,u,g),i.chartArea={left:f.left,top:f.top,right:f.left+f.w,bottom:f.top+f.h,height:f.h,width:f.w},U(a.chartArea,p=>{const m=p.box;Object.assign(m,i.chartArea),m.update(f.w,f.h,{left:0,top:0,right:0,bottom:0})})}};class Nu{acquireContext(t,e){}releaseContext(t){return!1}addEventListener(t,e,n){}removeEventListener(t,e,n){}getDevicePixelRatio(){return 1}getMaximumSize(t,e,n,s){return e=Math.max(0,e||t.width),n=n||t.height,{width:e,height:Math.max(0,s?Math.floor(e/s):n)}}isAttached(t){return!0}updateConfig(t){}}class Jx extends Nu{acquireContext(t){return t&&t.getContext&&t.getContext("2d")||null}updateConfig(t){t.options.animation=!1}}const Ms="$chartjs",Qx={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup",pointerenter:"mouseenter",pointerdown:"mousedown",pointermove:"mousemove",pointerup:"mouseup",pointerleave:"mouseout",pointerout:"mouseout"},yc=i=>i===null||i==="";function ty(i,t){const e=i.style,n=i.getAttribute("height"),s=i.getAttribute("width");if(i[Ms]={initial:{height:n,width:s,style:{display:e.display,height:e.height,width:e.width}}},e.display=e.display||"block",e.boxSizing=e.boxSizing||"border-box",yc(s)){const o=Jl(i,"width");o!==void 0&&(i.width=o)}if(yc(n))if(i.style.height==="")i.height=i.width/(t||2);else{const o=Jl(i,"height");o!==void 0&&(i.height=o)}return i}const Vu=T0?{passive:!0}:!1;function ey(i,t,e){i.addEventListener(t,e,Vu)}function iy(i,t,e){i.canvas.removeEventListener(t,e,Vu)}function ny(i,t){const e=Qx[i.type]||i.type,{x:n,y:s}=Xe(i,t);return{type:e,chart:t,native:i,x:n!==void 0?n:null,y:s!==void 0?s:null}}function Hs(i,t){for(const e of i)if(e===t||e.contains(t))return!0}function sy(i,t,e){const n=i.canvas,s=new MutationObserver(o=>{let r=!1;for(const a of o)r=r||Hs(a.addedNodes,n),r=r&&!Hs(a.removedNodes,n);r&&e()});return s.observe(document,{childList:!0,subtree:!0}),s}function oy(i,t,e){const n=i.canvas,s=new MutationObserver(o=>{let r=!1;for(const a of o)r=r||Hs(a.removedNodes,n),r=r&&!Hs(a.addedNodes,n);r&&e()});return s.observe(document,{childList:!0,subtree:!0}),s}const Cn=new Map;let vc=0;function Wu(){const i=window.devicePixelRatio;i!==vc&&(vc=i,Cn.forEach((t,e)=>{e.currentDevicePixelRatio!==i&&t()}))}function ry(i,t){Cn.size||window.addEventListener("resize",Wu),Cn.set(i,t)}function ay(i){Cn.delete(i),Cn.size||window.removeEventListener("resize",Wu)}function ly(i,t,e){const n=i.canvas,s=n&&Kr(n);if(!s)return;const o=gu((a,l)=>{const c=s.clientWidth;e(a,l),c{const l=a[0],c=l.contentRect.width,h=l.contentRect.height;c===0&&h===0||o(c,h)});return r.observe(s),ry(i,o),r}function Bo(i,t,e){e&&e.disconnect(),t==="resize"&&ay(i)}function cy(i,t,e){const n=i.canvas,s=gu(o=>{i.ctx!==null&&e(ny(o,i))},i,o=>{const r=o[0];return[r,r.offsetX,r.offsetY]});return ey(n,t,s),s}class hy extends Nu{acquireContext(t,e){const n=t&&t.getContext&&t.getContext("2d");return n&&n.canvas===t?(ty(t,e),n):null}releaseContext(t){const e=t.canvas;if(!e[Ms])return!1;const n=e[Ms].initial;["height","width"].forEach(o=>{const r=n[o];q(r)?e.removeAttribute(o):e.setAttribute(o,r)});const s=n.style||{};return Object.keys(s).forEach(o=>{e.style[o]=s[o]}),e.width=e.width,delete e[Ms],!0}addEventListener(t,e,n){this.removeEventListener(t,e);const s=t.$proxies||(t.$proxies={}),r={attach:sy,detach:oy,resize:ly}[e]||cy;s[e]=r(t,e,n)}removeEventListener(t,e){const n=t.$proxies||(t.$proxies={}),s=n[e];if(!s)return;({attach:Bo,detach:Bo,resize:Bo}[e]||iy)(t,e,s),n[e]=void 0}getDevicePixelRatio(){return window.devicePixelRatio}getMaximumSize(t,e,n,s){return O0(t,e,n,s)}isAttached(t){const e=Kr(t);return!!(e&&e.isConnected)}}function uy(i){return!Tu()||typeof OffscreenCanvas<"u"&&i instanceof OffscreenCanvas?Jx:hy}class dy{constructor(){this._init=[]}notify(t,e,n,s){e==="beforeInit"&&(this._init=this._createDescriptors(t,!0),this._notify(this._init,t,"install"));const o=s?this._descriptors(t).filter(s):this._descriptors(t),r=this._notify(o,t,e,n);return e==="afterDestroy"&&(this._notify(o,t,"stop"),this._notify(this._init,t,"uninstall")),r}_notify(t,e,n,s){s=s||{};for(const o of t){const r=o.plugin,a=r[n],l=[e,s,o.options];if(nt(a,l,r)===!1&&s.cancelable)return!1}return!0}invalidate(){q(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 n=t&&t.config,s=V(n.options&&n.options.plugins,{}),o=fy(n);return s===!1&&!e?[]:py(t,o,s,e)}_notifyStateChanges(t){const e=this._oldCache||[],n=this._cache,s=(o,r)=>o.filter(a=>!r.some(l=>a.plugin.id===l.plugin.id));this._notify(s(e,n),t,"stop"),this._notify(s(n,e),t,"start")}}function fy(i){const t={},e=[],n=Object.keys(Kt.plugins.items);for(let o=0;o{const l=n[a];if(!j(l))return console.error(`Invalid scale configuration for scale: ${a}`);if(l._proxy)return console.warn(`Ignoring resolver passed as options for scale: ${a}`);const c=hr(a,l),h=_y(c,s),u=e.scales||{};o[c]=o[c]||a,r[a]=gn(Object.create(null),[{axis:c},l,u[c],u[h]])}),i.data.datasets.forEach(a=>{const l=a.type||i.type,c=a.indexAxis||cr(l,t),u=(oi[l]||{}).scales||{};Object.keys(u).forEach(d=>{const f=by(d,c),g=a[f+"AxisID"]||o[f]||f;r[g]=r[g]||Object.create(null),gn(r[g],[{axis:f},n[g],u[d]])})}),Object.keys(r).forEach(a=>{const l=r[a];gn(l,[N.scales[l.type],N.scale])}),r}function ju(i){const t=i.options||(i.options={});t.plugins=V(t.plugins,{}),t.scales=yy(i,t)}function Hu(i){return i=i||{},i.datasets=i.datasets||[],i.labels=i.labels||[],i}function vy(i){return i=i||{},i.data=Hu(i.data),ju(i),i}const wc=new Map,Yu=new Set;function ls(i,t){let e=wc.get(i);return e||(e=t(),wc.set(i,e),Yu.add(e)),e}const zi=(i,t,e)=>{const n=Le(t,e);n!==void 0&&i.add(n)};class wy{constructor(t){this._config=vy(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=Hu(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(),ju(t)}clearCache(){this._scopeCache.clear(),this._resolverCache.clear()}datasetScopeKeys(t){return ls(t,()=>[[`datasets.${t}`,""]])}datasetAnimationScopeKeys(t,e){return ls(`${t}.transition.${e}`,()=>[[`datasets.${t}.transitions.${e}`,`transitions.${e}`],[`datasets.${t}`,""]])}datasetElementScopeKeys(t,e){return ls(`${t}-${e}`,()=>[[`datasets.${t}.elements.${e}`,`datasets.${t}`,`elements.${e}`,""]])}pluginScopeKeys(t){const e=t.id,n=this.type;return ls(`${n}-plugin-${e}`,()=>[[`plugins.${e}`,...t.additionalOptionScopes||[]]])}_cachedScopes(t,e){const n=this._scopeCache;let s=n.get(t);return(!s||e)&&(s=new Map,n.set(t,s)),s}getOptionScopes(t,e,n){const{options:s,type:o}=this,r=this._cachedScopes(t,n),a=r.get(e);if(a)return a;const l=new Set;e.forEach(h=>{t&&(l.add(t),h.forEach(u=>zi(l,t,u))),h.forEach(u=>zi(l,s,u)),h.forEach(u=>zi(l,oi[o]||{},u)),h.forEach(u=>zi(l,N,u)),h.forEach(u=>zi(l,rr,u))});const c=Array.from(l);return c.length===0&&c.push(Object.create(null)),Yu.has(e)&&r.set(e,c),c}chartOptionScopes(){const{options:t,type:e}=this;return[t,oi[e]||{},N.datasets[e]||{},{type:e},N,rr]}resolveNamedOptions(t,e,n,s=[""]){const o={$shared:!0},{resolver:r,subPrefixes:a}=Mc(this._resolverCache,t,s);let l=r;if(ky(r,e)){o.$shared=!1,n=Re(n)?n():n;const c=this.createResolver(t,n,a);l=ki(r,n,c)}for(const c of e)o[c]=l[c];return o}createResolver(t,e,n=[""],s){const{resolver:o}=Mc(this._resolverCache,t,n);return j(e)?ki(o,e,void 0,s):o}}function Mc(i,t,e){let n=i.get(t);n||(n=new Map,i.set(t,n));const s=e.join();let o=n.get(s);return o||(o={resolver:Xr(t,e),subPrefixes:e.filter(a=>!a.toLowerCase().includes("hover"))},n.set(s,o)),o}const My=i=>j(i)&&Object.getOwnPropertyNames(i).reduce((t,e)=>t||Re(i[e]),!1);function ky(i,t){const{isScriptable:e,isIndexable:n}=Su(i);for(const s of t){const o=e(s),r=n(s),a=(r||o)&&i[s];if(o&&(Re(a)||My(a))||r&&et(a))return!0}return!1}var Sy="3.9.1";const Py=["top","bottom","left","right","chartArea"];function kc(i,t){return i==="top"||i==="bottom"||Py.indexOf(i)===-1&&t==="x"}function Sc(i,t){return function(e,n){return e[i]===n[i]?e[t]-n[t]:e[i]-n[i]}}function Pc(i){const t=i.chart,e=t.options.animation;t.notifyPlugins("afterRender"),nt(e&&e.onComplete,[i],t)}function Cy(i){const t=i.chart,e=t.options.animation;nt(e&&e.onProgress,[i],t)}function Xu(i){return Tu()&&typeof i=="string"?i=document.getElementById(i):i&&i.length&&(i=i[0]),i&&i.canvas&&(i=i.canvas),i}const Ys={},Uu=i=>{const t=Xu(i);return Object.values(Ys).filter(e=>e.canvas===t).pop()};function Ay(i,t,e){const n=Object.keys(i);for(const s of n){const o=+s;if(o>=t){const r=i[s];delete i[s],(e>0||o>t)&&(i[o+e]=r)}}}function Dy(i,t,e,n){return!e||i.type==="mouseout"?null:n?t:i}class ia{constructor(t,e){const n=this.config=new wy(e),s=Xu(t),o=Uu(s);if(o)throw new Error("Canvas is already in use. Chart with ID '"+o.id+"' must be destroyed before the canvas with ID '"+o.canvas.id+"' can be reused.");const r=n.createResolver(n.chartOptionScopes(),this.getContext());this.platform=new(n.platform||uy(s)),this.platform.updateConfig(n);const a=this.platform.acquireContext(s,r.aspectRatio),l=a&&a.canvas,c=l&&l.height,h=l&&l.width;if(this.id=h_(),this.ctx=a,this.canvas=l,this.width=h,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 dy,this.$proxies={},this._hiddenIndices={},this.attached=!1,this._animationsDisabled=void 0,this.$context=void 0,this._doResize=P_(u=>this.update(u),r.resizeDelay||0),this._dataChanges=[],Ys[this.id]=this,!a||!l){console.error("Failed to create chart: can't acquire context from the given item");return}re.listen(this,"complete",Pc),re.listen(this,"progress",Cy),this._initialize(),this.attached&&this.update()}get aspectRatio(){const{options:{aspectRatio:t,maintainAspectRatio:e},width:n,height:s,_aspectRatio:o}=this;return q(t)?e&&o?o:s?n/s: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}_initialize(){return this.notifyPlugins("beforeInit"),this.options.responsive?this.resize():Zl(this,this.options.devicePixelRatio),this.bindEvents(),this.notifyPlugins("afterInit"),this}clear(){return ql(this.canvas,this.ctx),this}stop(){return re.stop(this),this}resize(t,e){re.running(this)?this._resizeBeforeDraw={width:t,height:e}:this._resize(t,e)}_resize(t,e){const n=this.options,s=this.canvas,o=n.maintainAspectRatio&&this.aspectRatio,r=this.platform.getMaximumSize(s,t,e,o),a=n.devicePixelRatio||this.platform.getDevicePixelRatio(),l=this.width?"resize":"attach";this.width=r.width,this.height=r.height,this._aspectRatio=this.aspectRatio,Zl(this,a,!0)&&(this.notifyPlugins("resize",{size:r}),nt(n.onResize,[this,r],this),this.attached&&this._doResize(l)&&this.render())}ensureScalesHaveIDs(){const e=this.options.scales||{};U(e,(n,s)=>{n.id=s})}buildOrUpdateScales(){const t=this.options,e=t.scales,n=this.scales,s=Object.keys(n).reduce((r,a)=>(r[a]=!1,r),{});let o=[];e&&(o=o.concat(Object.keys(e).map(r=>{const a=e[r],l=hr(r,a),c=l==="r",h=l==="x";return{options:a,dposition:c?"chartArea":h?"bottom":"left",dtype:c?"radialLinear":h?"category":"linear"}}))),U(o,r=>{const a=r.options,l=a.id,c=hr(l,a),h=V(a.type,r.dtype);(a.position===void 0||kc(a.position,c)!==kc(r.dposition))&&(a.position=r.dposition),s[l]=!0;let u=null;if(l in n&&n[l].type===h)u=n[l];else{const d=Kt.getScale(h);u=new d({id:l,type:h,ctx:this.ctx,chart:this}),n[u.id]=u}u.init(a,t)}),U(s,(r,a)=>{r||delete n[a]}),U(n,r=>{as.configure(this,r,r.options),as.addBox(this,r)})}_updateMetasets(){const t=this._metasets,e=this.data.datasets.length,n=t.length;if(t.sort((s,o)=>s.index-o.index),n>e){for(let s=e;se.length&&delete this._stacks,t.forEach((n,s)=>{e.filter(o=>o===n._dataset).length===0&&this._destroyDatasetMeta(s)})}buildOrUpdateControllers(){const t=[],e=this.data.datasets;let n,s;for(this._removeUnreferencedMetasets(),n=0,s=e.length;n{this.getDatasetMeta(e).controller.reset()},this)}reset(){this._resetElements(),this.notifyPlugins("reset")}update(t){const e=this.config;e.update();const n=this._options=e.createResolver(e.chartOptionScopes(),this.getContext()),s=this._animationsDisabled=!n.animation;if(this._updateScales(),this._checkEventBindings(),this._updateHiddenIndices(),this._plugins.invalidate(),this.notifyPlugins("beforeUpdate",{mode:t,cancelable:!0})===!1)return;const o=this.buildOrUpdateControllers();this.notifyPlugins("beforeElementsUpdate");let r=0;for(let c=0,h=this.data.datasets.length;c{c.reset()}),this._updateDatasets(t),this.notifyPlugins("afterUpdate",{mode:t}),this._layers.sort(Sc("z","_idx"));const{_active:a,_lastEvent:l}=this;l?this._eventHandler(l,!0):a.length&&this._updateHoverStyles(a,a,!0),this.render()}_updateScales(){U(this.scales,t=>{as.removeBox(this,t)}),this.ensureScalesHaveIDs(),this.buildOrUpdateScales()}_checkEventBindings(){const t=this.options,e=new Set(Object.keys(this._listeners)),n=new Set(t.events);(!Il(e,n)||!!this._responsiveListeners!==t.responsive)&&(this.unbindEvents(),this.bindEvents())}_updateHiddenIndices(){const{_hiddenIndices:t}=this,e=this._getUniformDataChanges()||[];for(const{method:n,start:s,count:o}of e){const r=n==="_removeElements"?-o:o;Ay(t,s,r)}}_getUniformDataChanges(){const t=this._dataChanges;if(!t||!t.length)return;this._dataChanges=[];const e=this.data.datasets.length,n=o=>new Set(t.filter(r=>r[0]===o).map((r,a)=>a+","+r.splice(1).join(","))),s=n(0);for(let o=1;oo.split(",")).map(o=>({method:o[1],start:+o[2],count:+o[3]}))}_updateLayout(t){if(this.notifyPlugins("beforeLayout",{cancelable:!0})===!1)return;as.update(this,this.width,this.height,t);const e=this.chartArea,n=e.width<=0||e.height<=0;this._layers=[],U(this.boxes,s=>{n&&s.position==="chartArea"||(s.configure&&s.configure(),this._layers.push(...s._layers()))},this),this._layers.forEach((s,o)=>{s._idx=o}),this.notifyPlugins("afterLayout")}_updateDatasets(t){if(this.notifyPlugins("beforeDatasetsUpdate",{mode:t,cancelable:!0})!==!1){for(let e=0,n=this.data.datasets.length;e=0;--e)this._drawDataset(t[e]);this.notifyPlugins("afterDatasetsDraw")}_drawDataset(t){const e=this.ctx,n=t._clip,s=!n.disabled,o=this.chartArea,r={meta:t,index:t.index,cancelable:!0};this.notifyPlugins("beforeDatasetDraw",r)!==!1&&(s&&wu(e,{left:n.left===!1?0:o.left-n.left,right:n.right===!1?this.width:o.right+n.right,top:n.top===!1?0:o.top-n.top,bottom:n.bottom===!1?this.height:o.bottom+n.bottom}),t.controller.draw(),s&&Mu(e),r.cancelable=!1,this.notifyPlugins("afterDatasetDraw",r))}isPointInArea(t){return Pn(t,this.chartArea,this._minPadding)}getElementsAtEventForMode(t,e,n,s){const o=Hx.modes[e];return typeof o=="function"?o(this,t,n,s):[]}getDatasetMeta(t){const e=this.data.datasets[t],n=this._metasets;let s=n.filter(o=>o&&o._dataset===e).pop();return s||(s={type:null,data:[],dataset:null,controller:null,hidden:null,xAxisID:null,yAxisID:null,order:e&&e.order||0,index:t,_dataset:e,_parsed:[],_sorted:!1},n.push(s)),s}getContext(){return this.$context||(this.$context=Fe(null,{chart:this,type:"chart"}))}getVisibleDatasetCount(){return this.getSortedVisibleDatasetMetas().length}isDatasetVisible(t){const e=this.data.datasets[t];if(!e)return!1;const n=this.getDatasetMeta(t);return typeof n.hidden=="boolean"?!n.hidden:!e.hidden}setDatasetVisibility(t,e){const n=this.getDatasetMeta(t);n.hidden=!e}toggleDataVisibility(t){this._hiddenIndices[t]=!this._hiddenIndices[t]}getDataVisibility(t){return!this._hiddenIndices[t]}_updateVisibility(t,e,n){const s=n?"show":"hide",o=this.getDatasetMeta(t),r=o.controller._resolveAnimations(void 0,s);Ft(e)?(o.data[e].hidden=!n,this.update()):(this.setDatasetVisibility(t,n),r.update(o,{visible:n}),this.update(a=>a.datasetIndex===t?s: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&&e.controller&&e.controller._destroy(),delete this._metasets[t]}_stop(){let t,e;for(this.stop(),re.remove(this),t=0,e=this.data.datasets.length;t{e.addEventListener(this,o,r),t[o]=r},s=(o,r,a)=>{o.offsetX=r,o.offsetY=a,this._eventHandler(o)};U(this.options.events,o=>n(o,s))}bindResponsiveEvents(){this._responsiveListeners||(this._responsiveListeners={});const t=this._responsiveListeners,e=this.platform,n=(l,c)=>{e.addEventListener(this,l,c),t[l]=c},s=(l,c)=>{t[l]&&(e.removeEventListener(this,l,c),delete t[l])},o=(l,c)=>{this.canvas&&this.resize(l,c)};let r;const a=()=>{s("attach",a),this.attached=!0,this.resize(),n("resize",o),n("detach",r)};r=()=>{this.attached=!1,s("resize",o),this._stop(),this._resize(0,0),n("attach",a)},e.isAttached(this.canvas)?a():r()}unbindEvents(){U(this._listeners,(t,e)=>{this.platform.removeEventListener(this,e,t)}),this._listeners={},U(this._responsiveListeners,(t,e)=>{this.platform.removeEventListener(this,e,t)}),this._responsiveListeners=void 0}updateHoverStyle(t,e,n){const s=n?"set":"remove";let o,r,a,l;for(e==="dataset"&&(o=this.getDatasetMeta(t[0].datasetIndex),o.controller["_"+s+"DatasetHoverStyle"]()),a=0,l=t.length;a{const a=this.getDatasetMeta(o);if(!a)throw new Error("No dataset found at index "+o);return{datasetIndex:o,element:a.data[r],index:r}});!Is(n,e)&&(this._active=n,this._lastEvent=null,this._updateHoverStyles(n,e))}notifyPlugins(t,e,n){return this._plugins.notify(this,t,e,n)}_updateHoverStyles(t,e,n){const s=this.options.hover,o=(l,c)=>l.filter(h=>!c.some(u=>h.datasetIndex===u.datasetIndex&&h.index===u.index)),r=o(e,t),a=n?t:o(t,e);r.length&&this.updateHoverStyle(r,s.mode,!1),a.length&&s.mode&&this.updateHoverStyle(a,s.mode,!0)}_eventHandler(t,e){const n={event:t,replay:e,cancelable:!0,inChartArea:this.isPointInArea(t)},s=r=>(r.options.events||this.options.events).includes(t.native.type);if(this.notifyPlugins("beforeEvent",n,s)===!1)return;const o=this._handleEvent(t,e,n.inChartArea);return n.cancelable=!1,this.notifyPlugins("afterEvent",n,s),(o||n.changed)&&this.render(),this}_handleEvent(t,e,n){const{_active:s=[],options:o}=this,r=e,a=this._getActiveElements(t,s,n,r),l=m_(t),c=Dy(t,this._lastEvent,n,l);n&&(this._lastEvent=null,nt(o.onHover,[t,a,this],this),l&&nt(o.onClick,[t,a,this],this));const h=!Is(a,s);return(h||e)&&(this._active=a,this._updateHoverStyles(a,s,e)),this._lastEvent=c,h}_getActiveElements(t,e,n,s){if(t.type==="mouseout")return[];if(!n)return e;const o=this.options.hover;return this.getElementsAtEventForMode(t,o.mode,o,s)}}const Cc=()=>U(ia.instances,i=>i._plugins.invalidate()),_e=!0;Object.defineProperties(ia,{defaults:{enumerable:_e,value:N},instances:{enumerable:_e,value:Ys},overrides:{enumerable:_e,value:oi},registry:{enumerable:_e,value:Kt},version:{enumerable:_e,value:Sy},getChart:{enumerable:_e,value:Uu},register:{enumerable:_e,value:(...i)=>{Kt.add(...i),Cc()}},unregister:{enumerable:_e,value:(...i)=>{Kt.remove(...i),Cc()}}});function qu(i,t,e){const{startAngle:n,pixelMargin:s,x:o,y:r,outerRadius:a,innerRadius:l}=t;let c=s/a;i.beginPath(),i.arc(o,r,a,n-c,e+c),l>s?(c=s/l,i.arc(o,r,l,e+c,n-c,!0)):i.arc(o,r,s,e+lt,n-lt),i.closePath(),i.clip()}function Oy(i){return Yr(i,["outerStart","outerEnd","innerStart","innerEnd"])}function Ty(i,t,e,n){const s=Oy(i.options.borderRadius),o=(e-t)/2,r=Math.min(o,n*t/2),a=l=>{const c=(e-Math.min(o,l))*n/2;return yt(l,0,Math.min(o,c))};return{outerStart:a(s.outerStart),outerEnd:a(s.outerEnd),innerStart:yt(s.innerStart,0,r),innerEnd:yt(s.innerEnd,0,r)}}function hi(i,t,e,n){return{x:e+i*Math.cos(t),y:n+i*Math.sin(t)}}function ur(i,t,e,n,s,o){const{x:r,y:a,startAngle:l,pixelMargin:c,innerRadius:h}=t,u=Math.max(t.outerRadius+n+e-c,0),d=h>0?h+n+e+c:0;let f=0;const g=s-l;if(n){const A=h>0?h-n:0,L=u>0?u-n:0,E=(A+L)/2,ht=E!==0?g*E/(E+n):g;f=(g-ht)/2}const p=Math.max(.001,g*u-e/ct)/u,m=(g-p)/2,_=l+m+f,x=s-m-f,{outerStart:v,outerEnd:b,innerStart:y,innerEnd:M}=Ty(t,d,u,x-_),w=u-v,k=u-b,S=_+v/w,P=x-b/k,D=d+y,O=d+M,H=_+y/D,z=x-M/O;if(i.beginPath(),o){if(i.arc(r,a,u,S,P),b>0){const E=hi(k,P,r,a);i.arc(E.x,E.y,b,P,x+lt)}const A=hi(O,x,r,a);if(i.lineTo(A.x,A.y),M>0){const E=hi(O,z,r,a);i.arc(E.x,E.y,M,x+lt,z+Math.PI)}if(i.arc(r,a,d,x-M/d,_+y/d,!0),y>0){const E=hi(D,H,r,a);i.arc(E.x,E.y,y,H+Math.PI,_-lt)}const L=hi(w,_,r,a);if(i.lineTo(L.x,L.y),v>0){const E=hi(w,S,r,a);i.arc(E.x,E.y,v,_-lt,S)}}else{i.moveTo(r,a);const A=Math.cos(S)*u+r,L=Math.sin(S)*u+a;i.lineTo(A,L);const E=Math.cos(P)*u+r,ht=Math.sin(P)*u+a;i.lineTo(E,ht)}i.closePath()}function Ly(i,t,e,n,s){const{fullCircles:o,startAngle:r,circumference:a}=t;let l=t.endAngle;if(o){ur(i,t,e,n,r+K,s);for(let c=0;c=K||Sn(o,a,l),p=zs(r,c+d,h+d);return g&&p}getCenterPoint(t){const{x:e,y:n,startAngle:s,endAngle:o,innerRadius:r,outerRadius:a}=this.getProps(["x","y","startAngle","endAngle","innerRadius","outerRadius","circumference"],t),{offset:l,spacing:c}=this.options,h=(s+o)/2,u=(r+a+c+l)/2;return{x:e+Math.cos(h)*u,y:n+Math.sin(h)*u}}tooltipPosition(t){return this.getCenterPoint(t)}draw(t){const{options:e,circumference:n}=this,s=(e.offset||0)/2,o=(e.spacing||0)/2,r=e.circular;if(this.pixelMargin=e.borderAlign==="inner"?.33:0,this.fullCircles=n>K?Math.floor(n/K):0,n===0||this.innerRadius<0||this.outerRadius<0)return;t.save();let a=0;if(s){a=s/2;const c=(this.startAngle+this.endAngle)/2;t.translate(Math.cos(c)*a,Math.sin(c)*a),this.circumference>=ct&&(a=s)}t.fillStyle=e.backgroundColor,t.strokeStyle=e.borderColor;const l=Ly(t,this,a,o,r);Ey(t,this,a,o,l,r),t.restore()}}na.id="arc";na.defaults={borderAlign:"center",borderColor:"#fff",borderJoinStyle:void 0,borderRadius:0,borderWidth:2,offset:0,spacing:0,angle:void 0,circular:!0};na.defaultRoutes={backgroundColor:"backgroundColor"};function Ku(i,t,e=t){i.lineCap=V(e.borderCapStyle,t.borderCapStyle),i.setLineDash(V(e.borderDash,t.borderDash)),i.lineDashOffset=V(e.borderDashOffset,t.borderDashOffset),i.lineJoin=V(e.borderJoinStyle,t.borderJoinStyle),i.lineWidth=V(e.borderWidth,t.borderWidth),i.strokeStyle=V(e.borderColor,t.borderColor)}function Iy(i,t,e){i.lineTo(e.x,e.y)}function Fy(i){return i.stepped?t0:i.tension||i.cubicInterpolationMode==="monotone"?e0:Iy}function Gu(i,t,e={}){const n=i.length,{start:s=0,end:o=n-1}=e,{start:r,end:a}=t,l=Math.max(s,r),c=Math.min(o,a),h=sa&&o>a;return{count:n,start:l,loop:t.loop,ilen:c(r+(c?a-b:b))%o,v=()=>{p!==m&&(i.lineTo(h,m),i.lineTo(h,p),i.lineTo(h,_))};for(l&&(f=s[x(0)],i.moveTo(f.x,f.y)),d=0;d<=a;++d){if(f=s[x(d)],f.skip)continue;const b=f.x,y=f.y,M=b|0;M===g?(ym&&(m=y),h=(u*h+b)/++u):(v(),i.lineTo(b,y),g=M,u=0,p=m=y),_=y}v()}function dr(i){const t=i.options,e=t.borderDash&&t.borderDash.length;return!i._decimated&&!i._loop&&!t.tension&&t.cubicInterpolationMode!=="monotone"&&!t.stepped&&!e?zy:$y}function By(i){return i.stepped?L0:i.tension||i.cubicInterpolationMode==="monotone"?R0:Ue}function Ny(i,t,e,n){let s=t._path;s||(s=t._path=new Path2D,t.path(s,e,n)&&s.closePath()),Ku(i,t.options),i.stroke(s)}function Vy(i,t,e,n){const{segments:s,options:o}=t,r=dr(t);for(const a of s)Ku(i,o,a.style),i.beginPath(),r(i,t,a,{start:e,end:e+n-1})&&i.closePath(),i.stroke()}const Wy=typeof Path2D=="function";function jy(i,t,e,n){Wy&&!t.options.segment?Ny(i,t,e,n):Vy(i,t,e,n)}class ro extends be{constructor(t){super(),this.animated=!0,this.options=void 0,this._chart=void 0,this._loop=void 0,this._fullLoop=void 0,this._path=void 0,this._points=void 0,this._segments=void 0,this._decimated=!1,this._pointsUpdated=!1,this._datasetIndex=void 0,t&&Object.assign(this,t)}updateControlPoints(t,e){const n=this.options;if((n.tension||n.cubicInterpolationMode==="monotone")&&!n.stepped&&!this._pointsUpdated){const s=n.spanGaps?this._loop:this._fullLoop;k0(this._points,n,t,s,e),this._pointsUpdated=!0}}set points(t){this._points=t,delete this._segments,delete this._path,this._pointsUpdated=!1}get points(){return this._points}get segments(){return this._segments||(this._segments=H0(this,this.options.segment))}first(){const t=this.segments,e=this.points;return t.length&&e[t[0].start]}last(){const t=this.segments,e=this.points,n=t.length;return n&&e[t[n-1].end]}interpolate(t,e){const n=this.options,s=t[e],o=this.points,r=V0(this,{property:e,start:s,end:s});if(!r.length)return;const a=[],l=By(n);let c,h;for(c=0,h=r.length;ci!=="borderDash"&&i!=="fill"};function Ac(i,t,e,n){const s=i.options,{[e]:o}=i.getProps([e],n);return Math.abs(t-o)-1?i.split(` -`):i}function Ky(i,t){const{element:e,datasetIndex:n,index:s}=t,o=i.getDatasetMeta(n).controller,{label:r,value:a}=o.getLabelAndValue(s);return{chart:i,label:r,parsed:o.getParsed(s),raw:i.data.datasets[n].data[s],formattedValue:a,dataset:o.getDataset(),dataIndex:s,datasetIndex:n,element:e}}function Dc(i,t){const e=i.chart.ctx,{body:n,footer:s,title:o}=i,{boxWidth:r,boxHeight:a}=t,l=Ot(t.bodyFont),c=Ot(t.titleFont),h=Ot(t.footerFont),u=o.length,d=s.length,f=n.length,g=$t(t.padding);let p=g.height,m=0,_=n.reduce((b,y)=>b+y.before.length+y.lines.length+y.after.length,0);if(_+=i.beforeBody.length+i.afterBody.length,u&&(p+=u*c.lineHeight+(u-1)*t.titleSpacing+t.titleMarginBottom),_){const b=t.displayColors?Math.max(a,l.lineHeight):l.lineHeight;p+=f*b+(_-f)*l.lineHeight+(_-1)*t.bodySpacing}d&&(p+=t.footerMarginTop+d*h.lineHeight+(d-1)*t.footerSpacing);let x=0;const v=function(b){m=Math.max(m,e.measureText(b).width+x)};return e.save(),e.font=c.string,U(i.title,v),e.font=l.string,U(i.beforeBody.concat(i.afterBody),v),x=t.displayColors?r+2+t.boxPadding:0,U(n,b=>{U(b.before,v),U(b.lines,v),U(b.after,v)}),x=0,e.font=h.string,U(i.footer,v),e.restore(),m+=g.width,{width:m,height:p}}function Gy(i,t){const{y:e,height:n}=t;return ei.height-n/2?"bottom":"center"}function Zy(i,t,e,n){const{x:s,width:o}=n,r=e.caretSize+e.caretPadding;if(i==="left"&&s+o+r>t.width||i==="right"&&s-o-r<0)return!0}function Jy(i,t,e,n){const{x:s,width:o}=e,{width:r,chartArea:{left:a,right:l}}=i;let c="center";return n==="center"?c=s<=(a+l)/2?"left":"right":s<=o/2?c="left":s>=r-o/2&&(c="right"),Zy(c,i,t,e)&&(c="center"),c}function Oc(i,t,e){const n=e.yAlign||t.yAlign||Gy(i,e);return{xAlign:e.xAlign||t.xAlign||Jy(i,t,e,n),yAlign:n}}function Qy(i,t){let{x:e,width:n}=i;return t==="right"?e-=n:t==="center"&&(e-=n/2),e}function t1(i,t,e){let{y:n,height:s}=i;return t==="top"?n+=e:t==="bottom"?n-=s+e:n-=s/2,n}function Tc(i,t,e,n){const{caretSize:s,caretPadding:o,cornerRadius:r}=i,{xAlign:a,yAlign:l}=e,c=s+o,{topLeft:h,topRight:u,bottomLeft:d,bottomRight:f}=_i(r);let g=Qy(t,a);const p=t1(t,l,c);return l==="center"?a==="left"?g+=c:a==="right"&&(g-=c):a==="left"?g-=Math.max(h,d)+s:a==="right"&&(g+=Math.max(u,f)+s),{x:yt(g,0,n.width-t.width),y:yt(p,0,n.height-t.height)}}function cs(i,t,e){const n=$t(e.padding);return t==="center"?i.x+i.width/2:t==="right"?i.x+i.width-n.right:i.x+n.left}function Lc(i){return Xt([],ae(i))}function e1(i,t,e){return Fe(i,{tooltip:t,tooltipItems:e,type:"tooltip"})}function Rc(i,t){const e=t&&t.dataset&&t.dataset.tooltip&&t.dataset.tooltip.callbacks;return e?i.override(e):i}class i1 extends be{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||t._chart,this._chart=this.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,n=this.options.setContext(this.getContext()),s=n.enabled&&e.options.animation&&n.animations,o=new Ru(this.chart,s);return s._cacheable&&(this._cachedAnimations=Object.freeze(o)),o}getContext(){return this.$context||(this.$context=e1(this.chart.getContext(),this,this._tooltipItems))}getTitle(t,e){const{callbacks:n}=e,s=n.beforeTitle.apply(this,[t]),o=n.title.apply(this,[t]),r=n.afterTitle.apply(this,[t]);let a=[];return a=Xt(a,ae(s)),a=Xt(a,ae(o)),a=Xt(a,ae(r)),a}getBeforeBody(t,e){return Lc(e.callbacks.beforeBody.apply(this,[t]))}getBody(t,e){const{callbacks:n}=e,s=[];return U(t,o=>{const r={before:[],lines:[],after:[]},a=Rc(n,o);Xt(r.before,ae(a.beforeLabel.call(this,o))),Xt(r.lines,a.label.call(this,o)),Xt(r.after,ae(a.afterLabel.call(this,o))),s.push(r)}),s}getAfterBody(t,e){return Lc(e.callbacks.afterBody.apply(this,[t]))}getFooter(t,e){const{callbacks:n}=e,s=n.beforeFooter.apply(this,[t]),o=n.footer.apply(this,[t]),r=n.afterFooter.apply(this,[t]);let a=[];return a=Xt(a,ae(s)),a=Xt(a,ae(o)),a=Xt(a,ae(r)),a}_createItems(t){const e=this._active,n=this.chart.data,s=[],o=[],r=[];let a=[],l,c;for(l=0,c=e.length;lt.filter(h,u,d,n))),t.itemSort&&(a=a.sort((h,u)=>t.itemSort(h,u,n))),U(a,h=>{const u=Rc(t.callbacks,h);s.push(u.labelColor.call(this,h)),o.push(u.labelPointStyle.call(this,h)),r.push(u.labelTextColor.call(this,h))}),this.labelColors=s,this.labelPointStyles=o,this.labelTextColors=r,this.dataPoints=a,a}update(t,e){const n=this.options.setContext(this.getContext()),s=this._active;let o,r=[];if(!s.length)this.opacity!==0&&(o={opacity:0});else{const a=ks[n.position].call(this,s,this._eventPosition);r=this._createItems(n),this.title=this.getTitle(r,n),this.beforeBody=this.getBeforeBody(r,n),this.body=this.getBody(r,n),this.afterBody=this.getAfterBody(r,n),this.footer=this.getFooter(r,n);const l=this._size=Dc(this,n),c=Object.assign({},a,l),h=Oc(this.chart,n,c),u=Tc(n,c,h,this.chart);this.xAlign=h.xAlign,this.yAlign=h.yAlign,o={opacity:1,x:u.x,y:u.y,width:l.width,height:l.height,caretX:a.x,caretY:a.y}}this._tooltipItems=r,this.$context=void 0,o&&this._resolveAnimations().update(this,o),t&&n.external&&n.external.call(this,{chart:this.chart,tooltip:this,replay:e})}drawCaret(t,e,n,s){const o=this.getCaretPosition(t,n,s);e.lineTo(o.x1,o.y1),e.lineTo(o.x2,o.y2),e.lineTo(o.x3,o.y3)}getCaretPosition(t,e,n){const{xAlign:s,yAlign:o}=this,{caretSize:r,cornerRadius:a}=n,{topLeft:l,topRight:c,bottomLeft:h,bottomRight:u}=_i(a),{x:d,y:f}=t,{width:g,height:p}=e;let m,_,x,v,b,y;return o==="center"?(b=f+p/2,s==="left"?(m=d,_=m-r,v=b+r,y=b-r):(m=d+g,_=m+r,v=b-r,y=b+r),x=m):(s==="left"?_=d+Math.max(l,h)+r:s==="right"?_=d+g-Math.max(c,u)-r:_=this.caretX,o==="top"?(v=f,b=v-r,m=_-r,x=_+r):(v=f+p,b=v+r,m=_+r,x=_-r),y=v),{x1:m,x2:_,x3:x,y1:v,y2:b,y3:y}}drawTitle(t,e,n){const s=this.title,o=s.length;let r,a,l;if(o){const c=Ro(n.rtl,this.x,this.width);for(t.x=cs(this,n.titleAlign,n),e.textAlign=c.textAlign(n.titleAlign),e.textBaseline="middle",r=Ot(n.titleFont),a=n.titleSpacing,e.fillStyle=n.titleColor,e.font=r.string,l=0;lv!==0)?(t.beginPath(),t.fillStyle=o.multiKeyBackground,Ws(t,{x:m,y:p,w:c,h:l,radius:x}),t.fill(),t.stroke(),t.fillStyle=r.backgroundColor,t.beginPath(),Ws(t,{x:_,y:p+1,w:c-2,h:l-2,radius:x}),t.fill()):(t.fillStyle=o.multiKeyBackground,t.fillRect(m,p,c,l),t.strokeRect(m,p,c,l),t.fillStyle=r.backgroundColor,t.fillRect(_,p+1,c-2,l-2))}t.fillStyle=this.labelTextColors[n]}drawBody(t,e,n){const{body:s}=this,{bodySpacing:o,bodyAlign:r,displayColors:a,boxHeight:l,boxWidth:c,boxPadding:h}=n,u=Ot(n.bodyFont);let d=u.lineHeight,f=0;const g=Ro(n.rtl,this.x,this.width),p=function(k){e.fillText(k,g.x(t.x+f),t.y+d/2),t.y+=d+o},m=g.textAlign(r);let _,x,v,b,y,M,w;for(e.textAlign=r,e.textBaseline="middle",e.font=u.string,t.x=cs(this,m,n),e.fillStyle=n.bodyColor,U(this.beforeBody,p),f=a&&m!=="right"?r==="center"?c/2+h:c+2+h:0,b=0,M=s.length;b0&&e.stroke()}_updateAnimationTarget(t){const e=this.chart,n=this.$animations,s=n&&n.x,o=n&&n.y;if(s||o){const r=ks[t.position].call(this,this._active,this._eventPosition);if(!r)return;const a=this._size=Dc(this,t),l=Object.assign({},r,this._size),c=Oc(e,t,l),h=Tc(t,l,c,e);(s._to!==h.x||o._to!==h.y)&&(this.xAlign=c.xAlign,this.yAlign=c.yAlign,this.width=a.width,this.height=a.height,this.caretX=r.x,this.caretY=r.y,this._resolveAnimations().update(this,h))}}_willRender(){return!!this.opacity}draw(t){const e=this.options.setContext(this.getContext());let n=this.opacity;if(!n)return;this._updateAnimationTarget(e);const s={width:this.width,height:this.height},o={x:this.x,y:this.y};n=Math.abs(n)<.001?0:n;const r=$t(e.padding),a=this.title.length||this.beforeBody.length||this.body.length||this.afterBody.length||this.footer.length;e.enabled&&a&&(t.save(),t.globalAlpha=n,this.drawBackground(o,t,s,e),$0(t,e.textDirection),o.y+=r.top,this.drawTitle(o,t,e),this.drawBody(o,t,e),this.drawFooter(o,t,e),z0(t,e.textDirection),t.restore())}getActiveElements(){return this._active||[]}setActiveElements(t,e){const n=this._active,s=t.map(({datasetIndex:a,index:l})=>{const c=this.chart.getDatasetMeta(a);if(!c)throw new Error("Cannot find a dataset at index "+a);return{datasetIndex:a,element:c.data[l],index:l}}),o=!Is(n,s),r=this._positionChanged(s,e);(o||r)&&(this._active=s,this._eventPosition=e,this._ignoreReplayEvents=!0,this.update(!0))}handleEvent(t,e,n=!0){if(e&&this._ignoreReplayEvents)return!1;this._ignoreReplayEvents=!1;const s=this.options,o=this._active||[],r=this._getActiveElements(t,o,e,n),a=this._positionChanged(r,t),l=e||!Is(r,o)||a;return l&&(this._active=r,(s.enabled||s.external)&&(this._eventPosition={x:t.x,y:t.y},this.update(!0,e))),l}_getActiveElements(t,e,n,s){const o=this.options;if(t.type==="mouseout")return[];if(!s)return e;const r=this.chart.getElementsAtEventForMode(t,o.mode,o,n);return o.reverse&&r.reverse(),r}_positionChanged(t,e){const{caretX:n,caretY:s,options:o}=this,r=ks[o.position].call(this,t,e);return r!==!1&&(n!==r.x||s!==r.y)}}i1.positioners=ks;const n1=(i,t,e,n)=>(typeof t=="string"?(e=i.push(t)-1,n.unshift({index:e,label:t})):isNaN(t)&&(e=null),e);function s1(i,t,e,n){const s=i.indexOf(t);if(s===-1)return n1(i,t,e,n);const o=i.lastIndexOf(t);return s!==o?e:s}const o1=(i,t)=>i===null?null:yt(Math.round(i),0,t);class fr extends ri{constructor(t){super(t),this._startValue=void 0,this._valueRange=0,this._addedLabels=[]}init(t){const e=this._addedLabels;if(e.length){const n=this.getLabels();for(const{index:s,label:o}of e)n[s]===o&&n.splice(s,1);this._addedLabels=[]}super.init(t)}parse(t,e){if(q(t))return null;const n=this.getLabels();return e=isFinite(e)&&n[e]===t?e:s1(n,t,V(e,t),this._addedLabels),o1(e,n.length-1)}determineDataLimits(){const{minDefined:t,maxDefined:e}=this.getUserBounds();let{min:n,max:s}=this.getMinMax(!0);this.options.bounds==="ticks"&&(t||(n=0),e||(s=this.getLabels().length-1)),this.min=n,this.max=s}buildTicks(){const t=this.min,e=this.max,n=this.options.offset,s=[];let o=this.getLabels();o=t===0&&e===o.length-1?o:o.slice(t,e+1),this._valueRange=Math.max(o.length-(n?0:1),1),this._startValue=this.min-(n?.5:0);for(let r=t;r<=e;r++)s.push({value:r});return s}getLabelForValue(t){const e=this.getLabels();return t>=0&&te.length-1?null:this.getPixelForValue(e[t].value)}getValueForPixel(t){return Math.round(this._startValue+this.getDecimalForPixel(t)*this._valueRange)}getBasePixel(){return this.bottom}}fr.id="category";fr.defaults={ticks:{callback:fr.prototype.getLabelForValue}};function r1(i,t){const e=[],{bounds:s,step:o,min:r,max:a,precision:l,count:c,maxTicks:h,maxDigits:u,includeBounds:d}=i,f=o||1,g=h-1,{min:p,max:m}=t,_=!q(r),x=!q(a),v=!q(c),b=(m-p)/(u+1);let y=$l((m-p)/g/f)*f,M,w,k,S;if(y<1e-14&&!_&&!x)return[{value:p},{value:m}];S=Math.ceil(m/y)-Math.floor(p/y),S>g&&(y=$l(S*y/g/f)*f),q(l)||(M=Math.pow(10,l),y=Math.ceil(y*M)/M),s==="ticks"?(w=Math.floor(p/y)*y,k=Math.ceil(m/y)*y):(w=p,k=m),_&&x&&o&&y_((a-r)/o,y/1e3)?(S=Math.round(Math.min((a-r)/y,h)),y=(a-r)/S,w=r,k=a):v?(w=_?r:w,k=x?a:k,S=c-1,y=(k-w)/S):(S=(k-w)/y,pn(S,Math.round(S),y/1e3)?S=Math.round(S):S=Math.ceil(S));const P=Math.max(zl(y),zl(w));M=Math.pow(10,q(l)?P:l),w=Math.round(w*M)/M,k=Math.round(k*M)/M;let D=0;for(_&&(d&&w!==r?(e.push({value:r}),ws=e?s:l,a=l=>o=n?o:l;if(t){const l=Zt(s),c=Zt(o);l<0&&c<0?a(0):l>0&&c>0&&r(0)}if(s===o){let l=1;(o>=Number.MAX_SAFE_INTEGER||s<=Number.MIN_SAFE_INTEGER)&&(l=Math.abs(o*.05)),a(o+l),t||r(s-l)}this.min=s,this.max=o}getTickLimit(){const t=this.options.ticks;let{maxTicksLimit:e,stepSize:n}=t,s;return n?(s=Math.ceil(this.max/n)-Math.floor(this.min/n)+1,s>1e3&&(console.warn(`scales.${this.id}.ticks.stepSize: ${n} would result generating up to ${s} ticks. Limiting to 1000.`),s=1e3)):(s=this.computeTickLimit(),e=e||11),e&&(s=Math.min(e,s)),s}computeTickLimit(){return Number.POSITIVE_INFINITY}buildTicks(){const t=this.options,e=t.ticks;let n=this.getTickLimit();n=Math.max(2,n);const s={maxTicks:n,bounds:t.bounds,min:t.min,max:t.max,precision:e.precision,step:e.stepSize,count:e.count,maxDigits:this._maxDigits(),horizontal:this.isHorizontal(),minRotation:e.minRotation||0,includeBounds:e.includeBounds!==!1},o=this._range||this,r=r1(s,o);return t.bounds==="ticks"&&cu(r,this,"value"),t.reverse?(r.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),r}configure(){const t=this.ticks;let e=this.min,n=this.max;if(super.configure(),this.options.offset&&t.length){const s=(n-e)/Math.max(t.length-1,1)/2;e-=s,n+=s}this._startValue=e,this._endValue=n,this._valueRange=n-e}getLabelForValue(t){return In(t,this.chart.options.locale,this.options.ticks.format)}}class Ju extends Xs{determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=mt(t)?t:0,this.max=mt(e)?e:1,this.handleTickRangeOptions()}computeTickLimit(){const t=this.isHorizontal(),e=t?this.width:this.height,n=Vt(this.options.ticks.minRotation),s=(t?Math.sin(n):Math.cos(n))||.001,o=this._resolveTickFontOptions(0);return Math.ceil(e/Math.min(40,o.lineHeight/s))}getPixelForValue(t){return t===null?NaN:this.getPixelForDecimal((t-this._startValue)/this._valueRange)}getValueForPixel(t){return this._startValue+this.getDecimalForPixel(t)*this._valueRange}}Ju.id="linear";Ju.defaults={ticks:{callback:oo.formatters.numeric}};function Ic(i){return i/Math.pow(10,Math.floor(It(i)))===1}function a1(i,t){const e=Math.floor(It(t.max)),n=Math.ceil(t.max/Math.pow(10,e)),s=[];let o=Rt(i.min,Math.pow(10,Math.floor(It(t.min)))),r=Math.floor(It(o)),a=Math.floor(o/Math.pow(10,r)),l=r<0?Math.pow(10,Math.abs(r)):1;do s.push({value:o,major:Ic(o)}),++a,a===10&&(a=1,++r,l=r>=0?1:l),o=Math.round(a*Math.pow(10,r)*l)/l;while(r0?n:null}determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=mt(t)?Math.max(0,t):null,this.max=mt(e)?Math.max(0,e):null,this.options.beginAtZero&&(this._zero=!0),this.handleTickRangeOptions()}handleTickRangeOptions(){const{minDefined:t,maxDefined:e}=this.getUserBounds();let n=this.min,s=this.max;const o=l=>n=t?n:l,r=l=>s=e?s:l,a=(l,c)=>Math.pow(10,Math.floor(It(l))+c);n===s&&(n<=0?(o(1),r(10)):(o(a(n,-1)),r(a(s,1)))),n<=0&&o(a(s,-1)),s<=0&&r(a(n,1)),this._zero&&this.min!==this._suggestedMin&&n===a(this.min,0)&&o(a(n,-1)),this.min=n,this.max=s}buildTicks(){const t=this.options,e={min:this._userMin,max:this._userMax},n=a1(e,this);return t.bounds==="ticks"&&cu(n,this,"value"),t.reverse?(n.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),n}getLabelForValue(t){return t===void 0?"0":In(t,this.chart.options.locale,this.options.ticks.format)}configure(){const t=this.min;super.configure(),this._startValue=It(t),this._valueRange=It(this.max)-It(t)}getPixelForValue(t){return(t===void 0||t===0)&&(t=this.min),t===null||isNaN(t)?NaN:this.getPixelForDecimal(t===this.min?0:(It(t)-this._startValue)/this._valueRange)}getValueForPixel(t){const e=this.getDecimalForPixel(t);return Math.pow(10,this._startValue+e*this._valueRange)}}Qu.id="logarithmic";Qu.defaults={ticks:{callback:oo.formatters.logarithmic,major:{enabled:!0}}};function gr(i){const t=i.ticks;if(t.display&&i.display){const e=$t(t.backdropPadding);return V(t.font&&t.font.size,N.font.size)+e.height}return 0}function l1(i,t,e){return e=et(e)?e:[e],{w:J_(i,t.string,e),h:e.length*t.lineHeight}}function Fc(i,t,e,n,s){return i===n||i===s?{start:t-e/2,end:t+e/2}:is?{start:t-e,end:t}:{start:t,end:t+e}}function c1(i){const t={l:i.left+i._padding.left,r:i.right-i._padding.right,t:i.top+i._padding.top,b:i.bottom-i._padding.bottom},e=Object.assign({},t),n=[],s=[],o=i._pointLabels.length,r=i.options.pointLabels,a=r.centerPointLabels?ct/o:0;for(let l=0;lt.r&&(a=(n.end-t.r)/o,i.r=Math.max(i.r,t.r+a)),s.startt.b&&(l=(s.end-t.b)/r,i.b=Math.max(i.b,t.b+l))}function u1(i,t,e){const n=[],s=i._pointLabels.length,o=i.options,r=gr(o)/2,a=i.drawingArea,l=o.pointLabels.centerPointLabels?ct/s:0;for(let c=0;c270||e<90)&&(i-=t),i}function p1(i,t){const{ctx:e,options:{pointLabels:n}}=i;for(let s=t-1;s>=0;s--){const o=n.setContext(i.getPointLabelContext(s)),r=Ot(o.font),{x:a,y:l,textAlign:c,left:h,top:u,right:d,bottom:f}=i._pointLabelItems[s],{backdropColor:g}=o;if(!q(g)){const p=_i(o.borderRadius),m=$t(o.backdropPadding);e.fillStyle=g;const _=h-m.left,x=u-m.top,v=d-h+m.width,b=f-u+m.height;Object.values(p).some(y=>y!==0)?(e.beginPath(),Ws(e,{x:_,y:x,w:v,h:b,radius:p}),e.fill()):e.fillRect(_,x,v,b)}Vs(e,i._pointLabels[s],a,l+r.lineHeight/2,r,{color:o.color,textAlign:c,textBaseline:"middle"})}}function td(i,t,e,n){const{ctx:s}=i;if(e)s.arc(i.xCenter,i.yCenter,t,0,K);else{let o=i.getPointPosition(0,t);s.moveTo(o.x,o.y);for(let r=1;r{const s=nt(this.options.pointLabels.callback,[e,n],this);return s||s===0?s:""}).filter((e,n)=>this.chart.getDataVisibility(n))}fit(){const t=this.options;t.display&&t.pointLabels.display?c1(this):this.setCenterPoint(0,0,0,0)}setCenterPoint(t,e,n,s){this.xCenter+=Math.floor((t-e)/2),this.yCenter+=Math.floor((n-s)/2),this.drawingArea-=Math.min(this.drawingArea/2,Math.max(t,e,n,s))}getIndexAngle(t){const e=K/(this._pointLabels.length||1),n=this.options.startAngle||0;return Bt(t*e+Vt(n))}getDistanceFromCenterForValue(t){if(q(t))return NaN;const e=this.drawingArea/(this.max-this.min);return this.options.reverse?(this.max-t)*e:(t-this.min)*e}getValueForDistanceFromCenter(t){if(q(t))return NaN;const e=t/(this.drawingArea/(this.max-this.min));return this.options.reverse?this.max-e:this.min+e}getPointLabelContext(t){const e=this._pointLabels||[];if(t>=0&&t{if(h!==0){a=this.getDistanceFromCenterForValue(c.value);const u=s.setContext(this.getContext(h-1));m1(this,u,a,o)}}),n.display){for(t.save(),r=o-1;r>=0;r--){const c=n.setContext(this.getPointLabelContext(r)),{color:h,lineWidth:u}=c;!u||!h||(t.lineWidth=u,t.strokeStyle=h,t.setLineDash(c.borderDash),t.lineDashOffset=c.borderDashOffset,a=this.getDistanceFromCenterForValue(e.ticks.reverse?this.min:this.max),l=this.getPointPosition(r,a),t.beginPath(),t.moveTo(this.xCenter,this.yCenter),t.lineTo(l.x,l.y),t.stroke())}t.restore()}}drawBorder(){}drawLabels(){const t=this.ctx,e=this.options,n=e.ticks;if(!n.display)return;const s=this.getIndexAngle(0);let o,r;t.save(),t.translate(this.xCenter,this.yCenter),t.rotate(s),t.textAlign="center",t.textBaseline="middle",this.ticks.forEach((a,l)=>{if(l===0&&!e.reverse)return;const c=n.setContext(this.getContext(l)),h=Ot(c.font);if(o=this.getDistanceFromCenterForValue(this.ticks[l].value),c.showLabelBackdrop){t.font=h.string,r=t.measureText(a.label).width,t.fillStyle=c.backdropColor;const u=$t(c.backdropPadding);t.fillRect(-r/2-u.left,-o-h.size/2-u.top,r+u.width,h.size+u.height)}Vs(t,a.label,0,-o,h,{color:c.color})}),t.restore()}drawTitle(){}}ao.id="radialLinear";ao.defaults={display:!0,animate:!0,position:"chartArea",angleLines:{display:!0,lineWidth:1,borderDash:[],borderDashOffset:0},grid:{circular:!1},startAngle:0,ticks:{showLabelBackdrop:!0,callback:oo.formatters.numeric},pointLabels:{backdropColor:void 0,backdropPadding:2,display:!0,font:{size:10},callback(i){return i},padding:5,centerPointLabels:!1}};ao.defaultRoutes={"angleLines.color":"borderColor","pointLabels.color":"color","ticks.color":"color"};ao.descriptors={angleLines:{_fallback:"grid"}};const lo={millisecond:{common:!0,size:1,steps:1e3},second:{common:!0,size:1e3,steps:60},minute:{common:!0,size:6e4,steps:60},hour:{common:!0,size:36e5,steps:24},day:{common:!0,size:864e5,steps:30},week:{common:!1,size:6048e5,steps:4},month:{common:!0,size:2628e6,steps:12},quarter:{common:!1,size:7884e6,steps:4},year:{common:!0,size:3154e7}},St=Object.keys(lo);function _1(i,t){return i-t}function $c(i,t){if(q(t))return null;const e=i._adapter,{parser:n,round:s,isoWeekday:o}=i._parseOpts;let r=t;return typeof n=="function"&&(r=n(r)),mt(r)||(r=typeof n=="string"?e.parse(r,n):e.parse(r)),r===null?null:(s&&(r=s==="week"&&(Mi(o)||o===!0)?e.startOf(r,"isoWeek",o):e.startOf(r,s)),+r)}function zc(i,t,e,n){const s=St.length;for(let o=St.indexOf(i);o=St.indexOf(e);o--){const r=St[o];if(lo[r].common&&i._adapter.diff(s,n,r)>=t-1)return r}return St[e?St.indexOf(e):0]}function y1(i){for(let t=St.indexOf(i)+1,e=St.length;t=t?e[n]:e[s];i[o]=!0}}function v1(i,t,e,n){const s=i._adapter,o=+s.startOf(t[0].value,n),r=t[t.length-1].value;let a,l;for(a=o;a<=r;a=+s.add(a,1,n))l=e[a],l>=0&&(t[l].major=!0);return t}function Nc(i,t,e){const n=[],s={},o=t.length;let r,a;for(r=0;r+t.value))}initOffsets(t){let e=0,n=0,s,o;this.options.offset&&t.length&&(s=this.getDecimalForValue(t[0]),t.length===1?e=1-s:e=(this.getDecimalForValue(t[1])-s)/2,o=this.getDecimalForValue(t[t.length-1]),t.length===1?n=o:n=(o-this.getDecimalForValue(t[t.length-2]))/2);const r=t.length<3?.5:.25;e=yt(e,0,r),n=yt(n,0,r),this._offsets={start:e,end:n,factor:1/(e+1+n)}}_generate(){const t=this._adapter,e=this.min,n=this.max,s=this.options,o=s.time,r=o.unit||zc(o.minUnit,e,n,this._getLabelCapacity(e)),a=V(o.stepSize,1),l=r==="week"?o.isoWeekday:!1,c=Mi(l)||l===!0,h={};let u=e,d,f;if(c&&(u=+t.startOf(u,"isoWeek",l)),u=+t.startOf(u,c?"day":r),t.diff(n,e,r)>1e5*a)throw new Error(e+" and "+n+" are too far apart with stepSize of "+a+" "+r);const g=s.ticks.source==="data"&&this.getDataTimestamps();for(d=u,f=0;dp-m).map(p=>+p)}getLabelForValue(t){const e=this._adapter,n=this.options.time;return n.tooltipFormat?e.format(t,n.tooltipFormat):e.format(t,n.displayFormats.datetime)}_tickFormatFunction(t,e,n,s){const o=this.options,r=o.time.displayFormats,a=this._unit,l=this._majorUnit,c=a&&r[a],h=l&&r[l],u=n[e],d=l&&h&&u&&u.major,f=this._adapter.format(t,s||(d?h:c)),g=o.ticks.callback;return g?nt(g,[f,e,n],this):f}generateTickLabels(t){let e,n,s;for(e=0,n=t.length;e0?a:1}getDataTimestamps(){let t=this._cache.data||[],e,n;if(t.length)return t;const s=this.getMatchingVisibleMetas();if(this._normalized&&s.length)return this._cache.data=s[0].controller.getAllParsedValues(this);for(e=0,n=s.length;e=i[n].pos&&t<=i[s].pos&&({lo:n,hi:s}=Je(i,"pos",t)),{pos:o,time:a}=i[n],{pos:r,time:l}=i[s]):(t>=i[n].time&&t<=i[s].time&&({lo:n,hi:s}=Je(i,"time",t)),{time:o,pos:a}=i[n],{time:r,pos:l}=i[s]);const c=r-o;return c?a+(l-a)*(t-o)/c:a}class ed extends co{constructor(t){super(t),this._table=[],this._minPos=void 0,this._tableRange=void 0}initOffsets(){const t=this._getTimestampsForTable(),e=this._table=this.buildLookupTable(t);this._minPos=hs(e,this.min),this._tableRange=hs(e,this.max)-this._minPos,super.initOffsets(t)}buildLookupTable(t){const{min:e,max:n}=this,s=[],o=[];let r,a,l,c,h;for(r=0,a=t.length;r=e&&c<=n&&s.push(c);if(s.length<2)return[{time:e,pos:0},{time:n,pos:1}];for(r=0,a=s.length;r{}};function id(){for(var i,t=0,e=arguments.length,n={};t=0&&(n=e.slice(s+1),e=e.slice(0,s)),e&&!t.hasOwnProperty(e))throw new Error("unknown type: "+e);return{type:e,name:n}})}function k1(i,t){for(var e,n=0,s=i.length;n0)for(var e,n,s=new Array(e),o=0;o=0&&(t=i.slice(0,e))!=="xmlns"&&(i=i.slice(e+1)),Wc.hasOwnProperty(t)?{space:Wc[t],local:i}:i}function S1(i){return function(){var t=this.ownerDocument,e=this.namespaceURI;return e===pr&&t.documentElement.namespaceURI===pr?t.createElement(i):t.createElementNS(e,i)}}function P1(i){return function(){return this.ownerDocument.createElementNS(i.space,i.local)}}function jc(i){var t=nd(i);return(t.local?P1:S1)(t)}function C1(){}function Hc(i){return i==null?C1:function(){return this.querySelector(i)}}function A1(i){return i==null?[]:Array.isArray(i)?i:Array.from(i)}function D1(){return[]}function Yc(i){return function(t){return t.matches(i)}}var O1=Array.prototype.find;function T1(){return this.firstElementChild}var L1=Array.prototype.filter;function R1(){return Array.from(this.children)}function Xc(i){return new Array(i.length)}function Us(i,t){this.ownerDocument=i.ownerDocument,this.namespaceURI=i.namespaceURI,this._next=null,this._parent=i,this.__data__=t}function E1(i){return function(){return i}}function I1(i,t,e,n,s,o){for(var r,a=0,l=t.length,c=o.length;at?1:i>=t?0:NaN}function N1(i){return function(){this.removeAttribute(i)}}function V1(i){return function(){this.removeAttributeNS(i.space,i.local)}}function W1(i,t){return function(){this.setAttribute(i,t)}}function j1(i,t){return function(){this.setAttributeNS(i.space,i.local,t)}}function H1(i,t){return function(){var e=t.apply(this,arguments);e==null?this.removeAttribute(i):this.setAttribute(i,e)}}function Y1(i,t){return function(){var e=t.apply(this,arguments);e==null?this.removeAttributeNS(i.space,i.local):this.setAttributeNS(i.space,i.local,e)}}function sd(i){return i.ownerDocument&&i.ownerDocument.defaultView||i.document&&i||i.defaultView}function X1(i){return function(){this.style.removeProperty(i)}}function U1(i,t,e){return function(){this.style.setProperty(i,t,e)}}function q1(i,t,e){return function(){var n=t.apply(this,arguments);n==null?this.style.removeProperty(i):this.style.setProperty(i,n,e)}}function K1(i,t){return i.style.getPropertyValue(t)||sd(i).getComputedStyle(i,null).getPropertyValue(t)}function G1(i){return function(){delete this[i]}}function Z1(i,t){return function(){this[i]=t}}function J1(i,t){return function(){var e=t.apply(this,arguments);e==null?delete this[i]:this[i]=e}}function od(i){return i.trim().split(/^|\s+/)}function ra(i){return i.classList||new rd(i)}function rd(i){this._node=i,this._names=od(i.getAttribute("class")||"")}function ad(i,t){for(var e=ra(i),n=-1,s=t.length;++n=0&&(e=t.slice(n+1),t=t.slice(0,n)),{type:t,name:e}})}function pv(i){return function(){var t=this.__on;if(t){for(var e,n=0,s=-1,o=t.length;n=0&&(this._names.splice(t,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(i){return this._names.indexOf(i)>=0}};var xv=[null];function Et(i,t){this._groups=i,this._parents=t}function rn(i){return typeof i=="string"?new Et([[document.querySelector(i)]],[document.documentElement]):new Et([[i]],xv)}function Uc(i,t){if(i=function(o){let r;for(;r=o.sourceEvent;)o=r;return o}(i),t===void 0&&(t=i.currentTarget),t){var e=t.ownerSVGElement||t;if(e.createSVGPoint){var n=e.createSVGPoint();return n.x=i.clientX,n.y=i.clientY,[(n=n.matrixTransform(t.getScreenCTM().inverse())).x,n.y]}if(t.getBoundingClientRect){var s=t.getBoundingClientRect();return[i.clientX-s.left-t.clientLeft,i.clientY-s.top-t.clientTop]}}return[i.pageX,i.pageY]}Et.prototype={constructor:Et,select:function(i){typeof i!="function"&&(i=Hc(i));for(var t=this._groups,e=t.length,n=new Array(e),s=0;s=y&&(y=b+1);!(v=m[y])&&++y=0;)(n=s[o])&&(r&&4^n.compareDocumentPosition(r)&&r.parentNode.insertBefore(n,r),r=n);return this},sort:function(i){function t(u,d){return u&&d?i(u.__data__,d.__data__):!u-!d}i||(i=B1);for(var e=this._groups,n=e.length,s=new Array(n),o=0;o1?this.each((t==null?X1:typeof t=="function"?q1:U1)(i,t,e??"")):K1(this.node(),i)},property:function(i,t){return arguments.length>1?this.each((t==null?G1:typeof t=="function"?J1:Z1)(i,t)):this.node()[i]},classed:function(i,t){var e=od(i+"");if(arguments.length<2){for(var n=ra(this.node()),s=-1,o=e.length;++s()=>i;function mr(i,{sourceEvent:t,subject:e,target:n,identifier:s,active:o,x:r,y:a,dx:l,dy:c,dispatch:h}){Object.defineProperties(this,{type:{value:i,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},subject:{value:e,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},identifier:{value:s,enumerable:!0,configurable:!0},active:{value:o,enumerable:!0,configurable:!0},x:{value:r,enumerable:!0,configurable:!0},y:{value:a,enumerable:!0,configurable:!0},dx:{value:l,enumerable:!0,configurable:!0},dy:{value:c,enumerable:!0,configurable:!0},_:{value:h}})}function vv(i){return!i.ctrlKey&&!i.button}function wv(){return this.parentNode}function Mv(i,t){return t??{x:i.x,y:i.y}}function kv(){return navigator.maxTouchPoints||"ontouchstart"in this}function Sv(){var i,t,e,n,s=vv,o=wv,r=Mv,a=kv,l={},c=id("start","drag","end"),h=0,u=0;function d(b){b.on("mousedown.drag",f).filter(a).on("touchstart.drag",m).on("touchmove.drag",_,yv).on("touchend.drag touchcancel.drag",x).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function f(b,y){if(!n&&s.call(this,b,y)){var M=v(this,o.call(this,b,y),b,y,"mouse");M&&(rn(b.view).on("mousemove.drag",g,Bi).on("mouseup.drag",p,Bi),function(w){var k=w.document.documentElement,S=rn(w).on("dragstart.drag",ui,Bi);"onselectstart"in k?S.on("selectstart.drag",ui,Bi):(k.__noselect=k.style.MozUserSelect,k.style.MozUserSelect="none")}(b.view),Wo(b),e=!1,i=b.clientX,t=b.clientY,M("start",b))}}function g(b){if(ui(b),!e){var y=b.clientX-i,M=b.clientY-t;e=y*y+M*M>u}l.mouse("drag",b)}function p(b){rn(b.view).on("mousemove.drag mouseup.drag",null),function(y,M){var w=y.document.documentElement,k=rn(y).on("dragstart.drag",null);M&&(k.on("click.drag",ui,Bi),setTimeout(function(){k.on("click.drag",null)},0)),"onselectstart"in w?k.on("selectstart.drag",null):(w.style.MozUserSelect=w.__noselect,delete w.__noselect)}(b.view,e),ui(b),l.mouse("end",b)}function m(b,y){if(s.call(this,b,y)){var M,w,k=b.changedTouches,S=o.call(this,b,y),P=k.length;for(M=0;Mt.scales[qt].max?t.scales[qt].max:o,o=ot.scales[he].max?t.scales[he].max:r,r=r{if(Mt){di=Mt.datasetIndex,qe=Mt.index,br=!0;let s=t.data.datasets[di].data[qe];qs==="radar"||qs==="polarArea"?s=function(o,r){let a,l,c;o.touches?(a=o.touches[0].clientX-r.canvas.getBoundingClientRect().left,l=o.touches[0].clientY-r.canvas.getBoundingClientRect().top):(a=o.clientX-r.canvas.getBoundingClientRect().left,l=o.clientY-r.canvas.getBoundingClientRect().top);let h=r.scales[ye],u=Math.sqrt(Math.pow(a-h.xCenter,2)+Math.pow(l-h.yCenter,2)),d=h.drawingArea/(h.max-h.min);return c=h.options.ticks.reverse?h.max-u/d:h.min+u/d,c=Ks(c,r.config.options.plugins.dragData.round),c=c>r.scales[ye].max?r.scales[ye].max:c,c=c((n,s,o)=>{if(Mt=s.getElementsAtEventForMode(n,"nearest",{intersect:!0},!1)[0],qs=s.config.type,Mt){let r=Mt.datasetIndex,a=Mt.index;qc=function(u){try{return u()}catch{return""}}(()=>s.config.options.plugins.tooltip.animation);const l=s.data.datasets[r],c=s.getDatasetMeta(r);let h=l.data[a];if(qt=c.xAxisID,he=c.yAxisID,ye=c.rAxisID,l.dragData===!1||s.config.options.scales[qt]&&s.config.options.scales[qt].dragData===!1||s.config.options.scales[he]&&s.config.options.scales[he].dragData===!1||s.config.options.scales[ye]&&s.config.options.scales[ye].rAxisID===!1||l.data[Mt.index].dragData===!1)return void(Mt=null);if(qs==="bar"){hd=s.config.options.scales[qt].stacked;const u=s.data.datasets[0].data[0];ud=u!==null&&Array.isArray(u)&&u.length==2,dd=_r(n,s,r,a)-h}(s.config.options.plugins.dragData.showTooltip===void 0||s.config.options.plugins.dragData.showTooltip)&&(s.config.options.plugins.tooltip||(s.config.options.plugins.tooltip={}),s.config.options.plugins.tooltip.animation=!1),typeof o=="function"&&Mt&&o(n,r,a,h)===!1&&(Mt=null)}})(e.sourceEvent,i,t.onDragStart)).on("drag",e=>Pv(e.sourceEvent,i,t,t.onDrag)).on("end",e=>((n,s,o)=>{if(qe=void 0,br=!1,s.config.options.plugins.tooltip&&(s.config.options.plugins.tooltip.animation=qc,s.update("none")),typeof o=="function"&&Mt){const r=Mt.datasetIndex,a=Mt.index;let l=function(c,h,u){const d=c.config.options.plugins.dragData;if(!d.magnet)return c.data.datasets[h].data[u];{const f=d.magnet;if(f.to&&typeof f.to=="function"){let g=c.data.datasets[h].data[u];return g=f.to(g),c.data.datasets[h].data[u]=g,c.update("none"),g}}}(s,r,a);return o(n,r,a,l)}})(e.sourceEvent,i,t.onDragEnd)))}},beforeEvent:function(i){if(br)return i.tooltip&&i.tooltip.update(),!1}};ia.register(fd);function Cv(i){let t,e,n,s,o,r=(100*i[0]/i[3]).toFixed(0)+"",a,l,c,h,u,d=(100*i[1]/i[3]).toFixed(0)+"",f,g,p,m,_,x=(100*i[2]/i[3]).toFixed(0)+"",v,b,y,M;return{c(){t=$("canvas"),e=Wt(),n=$("ul"),s=$("li"),o=pt("LTS: "),a=pt(r),l=pt("%"),c=Wt(),h=$("li"),u=pt("Nearby amenities: "),f=pt(d),g=pt("%"),p=Wt(),m=$("li"),_=pt("Greenspace proximity: "),v=pt(x),b=pt("%"),Ke(t,"width","100%"),Ke(t,"height","400px"),Ke(s,"color",i[4][0]),Ke(h,"color",i[4][1]),Ke(m,"color",i[4][2])},m(w,k){st(w,t,k),st(w,e,k),st(w,n,k),R(n,s),R(s,o),R(s,a),R(s,l),R(n,c),R(n,h),R(h,u),R(h,f),R(h,g),R(n,p),R(n,m),R(m,_),R(m,v),R(m,b),y||(M=Sd(i[5].call(null,t)),y=!0)},p(w,[k]){k&9&&r!==(r=(100*w[0]/w[3]).toFixed(0)+"")&&an(a,r),k&10&&d!==(d=(100*w[1]/w[3]).toFixed(0)+"")&&an(f,d),k&12&&x!==(x=(100*w[2]/w[3]).toFixed(0)+"")&&an(v,x)},i:jt,o:jt,d(w){w&&(ot(t),ot(e),ot(n)),y=!1,M()}}}function Av(i,t,e){let n;ws.register(...c_),ws.register(fd);let{lts:s=50}=t,{nearbyAmenities:o=30}=t,{greenspace:r=20}=t,a=["red","blue","green"];function l(c){let h={type:"radar",data:{labels:["LTS","Amenities","Greenspace"],datasets:[{label:"Routing preferences",data:[s,o,r],pointHitRadius:25}]},options:{responsive:!1,onHover(u){const d=u.chart.getElementsAtEventForMode(u,"nearest",{intersect:!0},!1);u.native.target.style.cursor=d.length?"grab":"default"},plugins:{dragData:{round:1,showTooltip:!0,onDragStart(u){u.target.style.cursor="grabbing"},onDragEnd(u,d,f,g){u.target.style.cursor="default",f==0?e(0,s=g):f==1?e(1,o=g):f==2&&e(2,r=g)}}},scales:{r:{min:0,max:100,stepSize:1,pointLabels:{color:a,font:{weight:"bold",size:15}}}}}};new ws(c.getContext("2d"),h)}return i.$$set=c=>{"lts"in c&&e(0,s=c.lts),"nearbyAmenities"in c&&e(1,o=c.nearbyAmenities),"greenspace"in c&&e(2,r=c.greenspace)},i.$$.update=()=>{i.$$.dirty&7&&e(3,n=s+o+r)},[s,o,r,n,a,l]}class Dv extends An{constructor(t){super(),Dn(this,t,Av,Cv,Pi,{lts:0,nearbyAmenities:1,greenspace:2})}}function Kc(i,t,e){const n=i.slice();return n[17]=t[e],n[22]=t,n[23]=e,n}function Gc(i,t,e){const n=i.slice();return n[17]=t[e],n[20]=t,n[21]=e,n}function Zc(i,t,e){const n=i.slice();return n[17]=t[e],n[18]=t,n[19]=e,n}function Ov(i){let t,e,n,s,o,r,a,l,c,h,u,d,f,g,p,m;function _(w){i[10](w)}function x(w){i[11](w)}function v(w){i[12](w)}let b={};i[2].tradeoff_lts!==void 0&&(b.lts=i[2].tradeoff_lts),i[2].tradeoff_amenities!==void 0&&(b.nearbyAmenities=i[2].tradeoff_amenities),i[2].tradeoff_greenspace!==void 0&&(b.greenspace=i[2].tradeoff_greenspace),t=new Dv({props:b}),fo.push(()=>go(t,"lts",_)),fo.push(()=>go(t,"nearbyAmenities",x)),fo.push(()=>go(t,"greenspace",v));let y=xi(["lts1","lts2","lts3","lts4"]),M=[];for(let w=0;w<4;w+=1)M[w]=Jc(Kc(i,y,w));return{c(){Pd(t.$$.fragment),o=Wt(),r=$("ul");for(let w=0;w<4;w+=1)M[w].c();a=Wt(),l=$("div"),c=$("label"),h=pt(`Give roads a good score if they have at least this many nearby amenities: +`):i}function Ky(i,t){const{element:e,datasetIndex:n,index:s}=t,o=i.getDatasetMeta(n).controller,{label:r,value:a}=o.getLabelAndValue(s);return{chart:i,label:r,parsed:o.getParsed(s),raw:i.data.datasets[n].data[s],formattedValue:a,dataset:o.getDataset(),dataIndex:s,datasetIndex:n,element:e}}function Dc(i,t){const e=i.chart.ctx,{body:n,footer:s,title:o}=i,{boxWidth:r,boxHeight:a}=t,l=Ot(t.bodyFont),c=Ot(t.titleFont),h=Ot(t.footerFont),u=o.length,d=s.length,f=n.length,g=$t(t.padding);let p=g.height,m=0,_=n.reduce((b,y)=>b+y.before.length+y.lines.length+y.after.length,0);if(_+=i.beforeBody.length+i.afterBody.length,u&&(p+=u*c.lineHeight+(u-1)*t.titleSpacing+t.titleMarginBottom),_){const b=t.displayColors?Math.max(a,l.lineHeight):l.lineHeight;p+=f*b+(_-f)*l.lineHeight+(_-1)*t.bodySpacing}d&&(p+=t.footerMarginTop+d*h.lineHeight+(d-1)*t.footerSpacing);let x=0;const v=function(b){m=Math.max(m,e.measureText(b).width+x)};return e.save(),e.font=c.string,U(i.title,v),e.font=l.string,U(i.beforeBody.concat(i.afterBody),v),x=t.displayColors?r+2+t.boxPadding:0,U(n,b=>{U(b.before,v),U(b.lines,v),U(b.after,v)}),x=0,e.font=h.string,U(i.footer,v),e.restore(),m+=g.width,{width:m,height:p}}function Gy(i,t){const{y:e,height:n}=t;return ei.height-n/2?"bottom":"center"}function Zy(i,t,e,n){const{x:s,width:o}=n,r=e.caretSize+e.caretPadding;if(i==="left"&&s+o+r>t.width||i==="right"&&s-o-r<0)return!0}function Jy(i,t,e,n){const{x:s,width:o}=e,{width:r,chartArea:{left:a,right:l}}=i;let c="center";return n==="center"?c=s<=(a+l)/2?"left":"right":s<=o/2?c="left":s>=r-o/2&&(c="right"),Zy(c,i,t,e)&&(c="center"),c}function Oc(i,t,e){const n=e.yAlign||t.yAlign||Gy(i,e);return{xAlign:e.xAlign||t.xAlign||Jy(i,t,e,n),yAlign:n}}function Qy(i,t){let{x:e,width:n}=i;return t==="right"?e-=n:t==="center"&&(e-=n/2),e}function t1(i,t,e){let{y:n,height:s}=i;return t==="top"?n+=e:t==="bottom"?n-=s+e:n-=s/2,n}function Tc(i,t,e,n){const{caretSize:s,caretPadding:o,cornerRadius:r}=i,{xAlign:a,yAlign:l}=e,c=s+o,{topLeft:h,topRight:u,bottomLeft:d,bottomRight:f}=_i(r);let g=Qy(t,a);const p=t1(t,l,c);return l==="center"?a==="left"?g+=c:a==="right"&&(g-=c):a==="left"?g-=Math.max(h,d)+s:a==="right"&&(g+=Math.max(u,f)+s),{x:yt(g,0,n.width-t.width),y:yt(p,0,n.height-t.height)}}function cs(i,t,e){const n=$t(e.padding);return t==="center"?i.x+i.width/2:t==="right"?i.x+i.width-n.right:i.x+n.left}function Lc(i){return Xt([],ae(i))}function e1(i,t,e){return Fe(i,{tooltip:t,tooltipItems:e,type:"tooltip"})}function Rc(i,t){const e=t&&t.dataset&&t.dataset.tooltip&&t.dataset.tooltip.callbacks;return e?i.override(e):i}class i1 extends be{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||t._chart,this._chart=this.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,n=this.options.setContext(this.getContext()),s=n.enabled&&e.options.animation&&n.animations,o=new Ru(this.chart,s);return s._cacheable&&(this._cachedAnimations=Object.freeze(o)),o}getContext(){return this.$context||(this.$context=e1(this.chart.getContext(),this,this._tooltipItems))}getTitle(t,e){const{callbacks:n}=e,s=n.beforeTitle.apply(this,[t]),o=n.title.apply(this,[t]),r=n.afterTitle.apply(this,[t]);let a=[];return a=Xt(a,ae(s)),a=Xt(a,ae(o)),a=Xt(a,ae(r)),a}getBeforeBody(t,e){return Lc(e.callbacks.beforeBody.apply(this,[t]))}getBody(t,e){const{callbacks:n}=e,s=[];return U(t,o=>{const r={before:[],lines:[],after:[]},a=Rc(n,o);Xt(r.before,ae(a.beforeLabel.call(this,o))),Xt(r.lines,a.label.call(this,o)),Xt(r.after,ae(a.afterLabel.call(this,o))),s.push(r)}),s}getAfterBody(t,e){return Lc(e.callbacks.afterBody.apply(this,[t]))}getFooter(t,e){const{callbacks:n}=e,s=n.beforeFooter.apply(this,[t]),o=n.footer.apply(this,[t]),r=n.afterFooter.apply(this,[t]);let a=[];return a=Xt(a,ae(s)),a=Xt(a,ae(o)),a=Xt(a,ae(r)),a}_createItems(t){const e=this._active,n=this.chart.data,s=[],o=[],r=[];let a=[],l,c;for(l=0,c=e.length;lt.filter(h,u,d,n))),t.itemSort&&(a=a.sort((h,u)=>t.itemSort(h,u,n))),U(a,h=>{const u=Rc(t.callbacks,h);s.push(u.labelColor.call(this,h)),o.push(u.labelPointStyle.call(this,h)),r.push(u.labelTextColor.call(this,h))}),this.labelColors=s,this.labelPointStyles=o,this.labelTextColors=r,this.dataPoints=a,a}update(t,e){const n=this.options.setContext(this.getContext()),s=this._active;let o,r=[];if(!s.length)this.opacity!==0&&(o={opacity:0});else{const a=ks[n.position].call(this,s,this._eventPosition);r=this._createItems(n),this.title=this.getTitle(r,n),this.beforeBody=this.getBeforeBody(r,n),this.body=this.getBody(r,n),this.afterBody=this.getAfterBody(r,n),this.footer=this.getFooter(r,n);const l=this._size=Dc(this,n),c=Object.assign({},a,l),h=Oc(this.chart,n,c),u=Tc(n,c,h,this.chart);this.xAlign=h.xAlign,this.yAlign=h.yAlign,o={opacity:1,x:u.x,y:u.y,width:l.width,height:l.height,caretX:a.x,caretY:a.y}}this._tooltipItems=r,this.$context=void 0,o&&this._resolveAnimations().update(this,o),t&&n.external&&n.external.call(this,{chart:this.chart,tooltip:this,replay:e})}drawCaret(t,e,n,s){const o=this.getCaretPosition(t,n,s);e.lineTo(o.x1,o.y1),e.lineTo(o.x2,o.y2),e.lineTo(o.x3,o.y3)}getCaretPosition(t,e,n){const{xAlign:s,yAlign:o}=this,{caretSize:r,cornerRadius:a}=n,{topLeft:l,topRight:c,bottomLeft:h,bottomRight:u}=_i(a),{x:d,y:f}=t,{width:g,height:p}=e;let m,_,x,v,b,y;return o==="center"?(b=f+p/2,s==="left"?(m=d,_=m-r,v=b+r,y=b-r):(m=d+g,_=m+r,v=b-r,y=b+r),x=m):(s==="left"?_=d+Math.max(l,h)+r:s==="right"?_=d+g-Math.max(c,u)-r:_=this.caretX,o==="top"?(v=f,b=v-r,m=_-r,x=_+r):(v=f+p,b=v+r,m=_+r,x=_-r),y=v),{x1:m,x2:_,x3:x,y1:v,y2:b,y3:y}}drawTitle(t,e,n){const s=this.title,o=s.length;let r,a,l;if(o){const c=Ro(n.rtl,this.x,this.width);for(t.x=cs(this,n.titleAlign,n),e.textAlign=c.textAlign(n.titleAlign),e.textBaseline="middle",r=Ot(n.titleFont),a=n.titleSpacing,e.fillStyle=n.titleColor,e.font=r.string,l=0;lv!==0)?(t.beginPath(),t.fillStyle=o.multiKeyBackground,Ws(t,{x:m,y:p,w:c,h:l,radius:x}),t.fill(),t.stroke(),t.fillStyle=r.backgroundColor,t.beginPath(),Ws(t,{x:_,y:p+1,w:c-2,h:l-2,radius:x}),t.fill()):(t.fillStyle=o.multiKeyBackground,t.fillRect(m,p,c,l),t.strokeRect(m,p,c,l),t.fillStyle=r.backgroundColor,t.fillRect(_,p+1,c-2,l-2))}t.fillStyle=this.labelTextColors[n]}drawBody(t,e,n){const{body:s}=this,{bodySpacing:o,bodyAlign:r,displayColors:a,boxHeight:l,boxWidth:c,boxPadding:h}=n,u=Ot(n.bodyFont);let d=u.lineHeight,f=0;const g=Ro(n.rtl,this.x,this.width),p=function(k){e.fillText(k,g.x(t.x+f),t.y+d/2),t.y+=d+o},m=g.textAlign(r);let _,x,v,b,y,M,w;for(e.textAlign=r,e.textBaseline="middle",e.font=u.string,t.x=cs(this,m,n),e.fillStyle=n.bodyColor,U(this.beforeBody,p),f=a&&m!=="right"?r==="center"?c/2+h:c+2+h:0,b=0,M=s.length;b0&&e.stroke()}_updateAnimationTarget(t){const e=this.chart,n=this.$animations,s=n&&n.x,o=n&&n.y;if(s||o){const r=ks[t.position].call(this,this._active,this._eventPosition);if(!r)return;const a=this._size=Dc(this,t),l=Object.assign({},r,this._size),c=Oc(e,t,l),h=Tc(t,l,c,e);(s._to!==h.x||o._to!==h.y)&&(this.xAlign=c.xAlign,this.yAlign=c.yAlign,this.width=a.width,this.height=a.height,this.caretX=r.x,this.caretY=r.y,this._resolveAnimations().update(this,h))}}_willRender(){return!!this.opacity}draw(t){const e=this.options.setContext(this.getContext());let n=this.opacity;if(!n)return;this._updateAnimationTarget(e);const s={width:this.width,height:this.height},o={x:this.x,y:this.y};n=Math.abs(n)<.001?0:n;const r=$t(e.padding),a=this.title.length||this.beforeBody.length||this.body.length||this.afterBody.length||this.footer.length;e.enabled&&a&&(t.save(),t.globalAlpha=n,this.drawBackground(o,t,s,e),$0(t,e.textDirection),o.y+=r.top,this.drawTitle(o,t,e),this.drawBody(o,t,e),this.drawFooter(o,t,e),z0(t,e.textDirection),t.restore())}getActiveElements(){return this._active||[]}setActiveElements(t,e){const n=this._active,s=t.map(({datasetIndex:a,index:l})=>{const c=this.chart.getDatasetMeta(a);if(!c)throw new Error("Cannot find a dataset at index "+a);return{datasetIndex:a,element:c.data[l],index:l}}),o=!Is(n,s),r=this._positionChanged(s,e);(o||r)&&(this._active=s,this._eventPosition=e,this._ignoreReplayEvents=!0,this.update(!0))}handleEvent(t,e,n=!0){if(e&&this._ignoreReplayEvents)return!1;this._ignoreReplayEvents=!1;const s=this.options,o=this._active||[],r=this._getActiveElements(t,o,e,n),a=this._positionChanged(r,t),l=e||!Is(r,o)||a;return l&&(this._active=r,(s.enabled||s.external)&&(this._eventPosition={x:t.x,y:t.y},this.update(!0,e))),l}_getActiveElements(t,e,n,s){const o=this.options;if(t.type==="mouseout")return[];if(!s)return e;const r=this.chart.getElementsAtEventForMode(t,o.mode,o,n);return o.reverse&&r.reverse(),r}_positionChanged(t,e){const{caretX:n,caretY:s,options:o}=this,r=ks[o.position].call(this,t,e);return r!==!1&&(n!==r.x||s!==r.y)}}i1.positioners=ks;const n1=(i,t,e,n)=>(typeof t=="string"?(e=i.push(t)-1,n.unshift({index:e,label:t})):isNaN(t)&&(e=null),e);function s1(i,t,e,n){const s=i.indexOf(t);if(s===-1)return n1(i,t,e,n);const o=i.lastIndexOf(t);return s!==o?e:s}const o1=(i,t)=>i===null?null:yt(Math.round(i),0,t);class fr extends ri{constructor(t){super(t),this._startValue=void 0,this._valueRange=0,this._addedLabels=[]}init(t){const e=this._addedLabels;if(e.length){const n=this.getLabels();for(const{index:s,label:o}of e)n[s]===o&&n.splice(s,1);this._addedLabels=[]}super.init(t)}parse(t,e){if(q(t))return null;const n=this.getLabels();return e=isFinite(e)&&n[e]===t?e:s1(n,t,V(e,t),this._addedLabels),o1(e,n.length-1)}determineDataLimits(){const{minDefined:t,maxDefined:e}=this.getUserBounds();let{min:n,max:s}=this.getMinMax(!0);this.options.bounds==="ticks"&&(t||(n=0),e||(s=this.getLabels().length-1)),this.min=n,this.max=s}buildTicks(){const t=this.min,e=this.max,n=this.options.offset,s=[];let o=this.getLabels();o=t===0&&e===o.length-1?o:o.slice(t,e+1),this._valueRange=Math.max(o.length-(n?0:1),1),this._startValue=this.min-(n?.5:0);for(let r=t;r<=e;r++)s.push({value:r});return s}getLabelForValue(t){const e=this.getLabels();return t>=0&&te.length-1?null:this.getPixelForValue(e[t].value)}getValueForPixel(t){return Math.round(this._startValue+this.getDecimalForPixel(t)*this._valueRange)}getBasePixel(){return this.bottom}}fr.id="category";fr.defaults={ticks:{callback:fr.prototype.getLabelForValue}};function r1(i,t){const e=[],{bounds:s,step:o,min:r,max:a,precision:l,count:c,maxTicks:h,maxDigits:u,includeBounds:d}=i,f=o||1,g=h-1,{min:p,max:m}=t,_=!q(r),x=!q(a),v=!q(c),b=(m-p)/(u+1);let y=$l((m-p)/g/f)*f,M,w,k,S;if(y<1e-14&&!_&&!x)return[{value:p},{value:m}];S=Math.ceil(m/y)-Math.floor(p/y),S>g&&(y=$l(S*y/g/f)*f),q(l)||(M=Math.pow(10,l),y=Math.ceil(y*M)/M),s==="ticks"?(w=Math.floor(p/y)*y,k=Math.ceil(m/y)*y):(w=p,k=m),_&&x&&o&&y_((a-r)/o,y/1e3)?(S=Math.round(Math.min((a-r)/y,h)),y=(a-r)/S,w=r,k=a):v?(w=_?r:w,k=x?a:k,S=c-1,y=(k-w)/S):(S=(k-w)/y,pn(S,Math.round(S),y/1e3)?S=Math.round(S):S=Math.ceil(S));const P=Math.max(zl(y),zl(w));M=Math.pow(10,q(l)?P:l),w=Math.round(w*M)/M,k=Math.round(k*M)/M;let D=0;for(_&&(d&&w!==r?(e.push({value:r}),ws=e?s:l,a=l=>o=n?o:l;if(t){const l=Zt(s),c=Zt(o);l<0&&c<0?a(0):l>0&&c>0&&r(0)}if(s===o){let l=1;(o>=Number.MAX_SAFE_INTEGER||s<=Number.MIN_SAFE_INTEGER)&&(l=Math.abs(o*.05)),a(o+l),t||r(s-l)}this.min=s,this.max=o}getTickLimit(){const t=this.options.ticks;let{maxTicksLimit:e,stepSize:n}=t,s;return n?(s=Math.ceil(this.max/n)-Math.floor(this.min/n)+1,s>1e3&&(console.warn(`scales.${this.id}.ticks.stepSize: ${n} would result generating up to ${s} ticks. Limiting to 1000.`),s=1e3)):(s=this.computeTickLimit(),e=e||11),e&&(s=Math.min(e,s)),s}computeTickLimit(){return Number.POSITIVE_INFINITY}buildTicks(){const t=this.options,e=t.ticks;let n=this.getTickLimit();n=Math.max(2,n);const s={maxTicks:n,bounds:t.bounds,min:t.min,max:t.max,precision:e.precision,step:e.stepSize,count:e.count,maxDigits:this._maxDigits(),horizontal:this.isHorizontal(),minRotation:e.minRotation||0,includeBounds:e.includeBounds!==!1},o=this._range||this,r=r1(s,o);return t.bounds==="ticks"&&cu(r,this,"value"),t.reverse?(r.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),r}configure(){const t=this.ticks;let e=this.min,n=this.max;if(super.configure(),this.options.offset&&t.length){const s=(n-e)/Math.max(t.length-1,1)/2;e-=s,n+=s}this._startValue=e,this._endValue=n,this._valueRange=n-e}getLabelForValue(t){return In(t,this.chart.options.locale,this.options.ticks.format)}}class Ju extends Xs{determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=mt(t)?t:0,this.max=mt(e)?e:1,this.handleTickRangeOptions()}computeTickLimit(){const t=this.isHorizontal(),e=t?this.width:this.height,n=Vt(this.options.ticks.minRotation),s=(t?Math.sin(n):Math.cos(n))||.001,o=this._resolveTickFontOptions(0);return Math.ceil(e/Math.min(40,o.lineHeight/s))}getPixelForValue(t){return t===null?NaN:this.getPixelForDecimal((t-this._startValue)/this._valueRange)}getValueForPixel(t){return this._startValue+this.getDecimalForPixel(t)*this._valueRange}}Ju.id="linear";Ju.defaults={ticks:{callback:oo.formatters.numeric}};function Ic(i){return i/Math.pow(10,Math.floor(It(i)))===1}function a1(i,t){const e=Math.floor(It(t.max)),n=Math.ceil(t.max/Math.pow(10,e)),s=[];let o=Rt(i.min,Math.pow(10,Math.floor(It(t.min)))),r=Math.floor(It(o)),a=Math.floor(o/Math.pow(10,r)),l=r<0?Math.pow(10,Math.abs(r)):1;do s.push({value:o,major:Ic(o)}),++a,a===10&&(a=1,++r,l=r>=0?1:l),o=Math.round(a*Math.pow(10,r)*l)/l;while(r0?n:null}determineDataLimits(){const{min:t,max:e}=this.getMinMax(!0);this.min=mt(t)?Math.max(0,t):null,this.max=mt(e)?Math.max(0,e):null,this.options.beginAtZero&&(this._zero=!0),this.handleTickRangeOptions()}handleTickRangeOptions(){const{minDefined:t,maxDefined:e}=this.getUserBounds();let n=this.min,s=this.max;const o=l=>n=t?n:l,r=l=>s=e?s:l,a=(l,c)=>Math.pow(10,Math.floor(It(l))+c);n===s&&(n<=0?(o(1),r(10)):(o(a(n,-1)),r(a(s,1)))),n<=0&&o(a(s,-1)),s<=0&&r(a(n,1)),this._zero&&this.min!==this._suggestedMin&&n===a(this.min,0)&&o(a(n,-1)),this.min=n,this.max=s}buildTicks(){const t=this.options,e={min:this._userMin,max:this._userMax},n=a1(e,this);return t.bounds==="ticks"&&cu(n,this,"value"),t.reverse?(n.reverse(),this.start=this.max,this.end=this.min):(this.start=this.min,this.end=this.max),n}getLabelForValue(t){return t===void 0?"0":In(t,this.chart.options.locale,this.options.ticks.format)}configure(){const t=this.min;super.configure(),this._startValue=It(t),this._valueRange=It(this.max)-It(t)}getPixelForValue(t){return(t===void 0||t===0)&&(t=this.min),t===null||isNaN(t)?NaN:this.getPixelForDecimal(t===this.min?0:(It(t)-this._startValue)/this._valueRange)}getValueForPixel(t){const e=this.getDecimalForPixel(t);return Math.pow(10,this._startValue+e*this._valueRange)}}Qu.id="logarithmic";Qu.defaults={ticks:{callback:oo.formatters.logarithmic,major:{enabled:!0}}};function gr(i){const t=i.ticks;if(t.display&&i.display){const e=$t(t.backdropPadding);return V(t.font&&t.font.size,N.font.size)+e.height}return 0}function l1(i,t,e){return e=et(e)?e:[e],{w:J_(i,t.string,e),h:e.length*t.lineHeight}}function Fc(i,t,e,n,s){return i===n||i===s?{start:t-e/2,end:t+e/2}:is?{start:t-e,end:t}:{start:t,end:t+e}}function c1(i){const t={l:i.left+i._padding.left,r:i.right-i._padding.right,t:i.top+i._padding.top,b:i.bottom-i._padding.bottom},e=Object.assign({},t),n=[],s=[],o=i._pointLabels.length,r=i.options.pointLabels,a=r.centerPointLabels?ct/o:0;for(let l=0;lt.r&&(a=(n.end-t.r)/o,i.r=Math.max(i.r,t.r+a)),s.startt.b&&(l=(s.end-t.b)/r,i.b=Math.max(i.b,t.b+l))}function u1(i,t,e){const n=[],s=i._pointLabels.length,o=i.options,r=gr(o)/2,a=i.drawingArea,l=o.pointLabels.centerPointLabels?ct/s:0;for(let c=0;c270||e<90)&&(i-=t),i}function p1(i,t){const{ctx:e,options:{pointLabels:n}}=i;for(let s=t-1;s>=0;s--){const o=n.setContext(i.getPointLabelContext(s)),r=Ot(o.font),{x:a,y:l,textAlign:c,left:h,top:u,right:d,bottom:f}=i._pointLabelItems[s],{backdropColor:g}=o;if(!q(g)){const p=_i(o.borderRadius),m=$t(o.backdropPadding);e.fillStyle=g;const _=h-m.left,x=u-m.top,v=d-h+m.width,b=f-u+m.height;Object.values(p).some(y=>y!==0)?(e.beginPath(),Ws(e,{x:_,y:x,w:v,h:b,radius:p}),e.fill()):e.fillRect(_,x,v,b)}Vs(e,i._pointLabels[s],a,l+r.lineHeight/2,r,{color:o.color,textAlign:c,textBaseline:"middle"})}}function td(i,t,e,n){const{ctx:s}=i;if(e)s.arc(i.xCenter,i.yCenter,t,0,K);else{let o=i.getPointPosition(0,t);s.moveTo(o.x,o.y);for(let r=1;r{const s=nt(this.options.pointLabels.callback,[e,n],this);return s||s===0?s:""}).filter((e,n)=>this.chart.getDataVisibility(n))}fit(){const t=this.options;t.display&&t.pointLabels.display?c1(this):this.setCenterPoint(0,0,0,0)}setCenterPoint(t,e,n,s){this.xCenter+=Math.floor((t-e)/2),this.yCenter+=Math.floor((n-s)/2),this.drawingArea-=Math.min(this.drawingArea/2,Math.max(t,e,n,s))}getIndexAngle(t){const e=K/(this._pointLabels.length||1),n=this.options.startAngle||0;return Bt(t*e+Vt(n))}getDistanceFromCenterForValue(t){if(q(t))return NaN;const e=this.drawingArea/(this.max-this.min);return this.options.reverse?(this.max-t)*e:(t-this.min)*e}getValueForDistanceFromCenter(t){if(q(t))return NaN;const e=t/(this.drawingArea/(this.max-this.min));return this.options.reverse?this.max-e:this.min+e}getPointLabelContext(t){const e=this._pointLabels||[];if(t>=0&&t{if(h!==0){a=this.getDistanceFromCenterForValue(c.value);const u=s.setContext(this.getContext(h-1));m1(this,u,a,o)}}),n.display){for(t.save(),r=o-1;r>=0;r--){const c=n.setContext(this.getPointLabelContext(r)),{color:h,lineWidth:u}=c;!u||!h||(t.lineWidth=u,t.strokeStyle=h,t.setLineDash(c.borderDash),t.lineDashOffset=c.borderDashOffset,a=this.getDistanceFromCenterForValue(e.ticks.reverse?this.min:this.max),l=this.getPointPosition(r,a),t.beginPath(),t.moveTo(this.xCenter,this.yCenter),t.lineTo(l.x,l.y),t.stroke())}t.restore()}}drawBorder(){}drawLabels(){const t=this.ctx,e=this.options,n=e.ticks;if(!n.display)return;const s=this.getIndexAngle(0);let o,r;t.save(),t.translate(this.xCenter,this.yCenter),t.rotate(s),t.textAlign="center",t.textBaseline="middle",this.ticks.forEach((a,l)=>{if(l===0&&!e.reverse)return;const c=n.setContext(this.getContext(l)),h=Ot(c.font);if(o=this.getDistanceFromCenterForValue(this.ticks[l].value),c.showLabelBackdrop){t.font=h.string,r=t.measureText(a.label).width,t.fillStyle=c.backdropColor;const u=$t(c.backdropPadding);t.fillRect(-r/2-u.left,-o-h.size/2-u.top,r+u.width,h.size+u.height)}Vs(t,a.label,0,-o,h,{color:c.color})}),t.restore()}drawTitle(){}}ao.id="radialLinear";ao.defaults={display:!0,animate:!0,position:"chartArea",angleLines:{display:!0,lineWidth:1,borderDash:[],borderDashOffset:0},grid:{circular:!1},startAngle:0,ticks:{showLabelBackdrop:!0,callback:oo.formatters.numeric},pointLabels:{backdropColor:void 0,backdropPadding:2,display:!0,font:{size:10},callback(i){return i},padding:5,centerPointLabels:!1}};ao.defaultRoutes={"angleLines.color":"borderColor","pointLabels.color":"color","ticks.color":"color"};ao.descriptors={angleLines:{_fallback:"grid"}};const lo={millisecond:{common:!0,size:1,steps:1e3},second:{common:!0,size:1e3,steps:60},minute:{common:!0,size:6e4,steps:60},hour:{common:!0,size:36e5,steps:24},day:{common:!0,size:864e5,steps:30},week:{common:!1,size:6048e5,steps:4},month:{common:!0,size:2628e6,steps:12},quarter:{common:!1,size:7884e6,steps:4},year:{common:!0,size:3154e7}},St=Object.keys(lo);function _1(i,t){return i-t}function $c(i,t){if(q(t))return null;const e=i._adapter,{parser:n,round:s,isoWeekday:o}=i._parseOpts;let r=t;return typeof n=="function"&&(r=n(r)),mt(r)||(r=typeof n=="string"?e.parse(r,n):e.parse(r)),r===null?null:(s&&(r=s==="week"&&(Mi(o)||o===!0)?e.startOf(r,"isoWeek",o):e.startOf(r,s)),+r)}function zc(i,t,e,n){const s=St.length;for(let o=St.indexOf(i);o=St.indexOf(e);o--){const r=St[o];if(lo[r].common&&i._adapter.diff(s,n,r)>=t-1)return r}return St[e?St.indexOf(e):0]}function y1(i){for(let t=St.indexOf(i)+1,e=St.length;t=t?e[n]:e[s];i[o]=!0}}function v1(i,t,e,n){const s=i._adapter,o=+s.startOf(t[0].value,n),r=t[t.length-1].value;let a,l;for(a=o;a<=r;a=+s.add(a,1,n))l=e[a],l>=0&&(t[l].major=!0);return t}function Nc(i,t,e){const n=[],s={},o=t.length;let r,a;for(r=0;r+t.value))}initOffsets(t){let e=0,n=0,s,o;this.options.offset&&t.length&&(s=this.getDecimalForValue(t[0]),t.length===1?e=1-s:e=(this.getDecimalForValue(t[1])-s)/2,o=this.getDecimalForValue(t[t.length-1]),t.length===1?n=o:n=(o-this.getDecimalForValue(t[t.length-2]))/2);const r=t.length<3?.5:.25;e=yt(e,0,r),n=yt(n,0,r),this._offsets={start:e,end:n,factor:1/(e+1+n)}}_generate(){const t=this._adapter,e=this.min,n=this.max,s=this.options,o=s.time,r=o.unit||zc(o.minUnit,e,n,this._getLabelCapacity(e)),a=V(o.stepSize,1),l=r==="week"?o.isoWeekday:!1,c=Mi(l)||l===!0,h={};let u=e,d,f;if(c&&(u=+t.startOf(u,"isoWeek",l)),u=+t.startOf(u,c?"day":r),t.diff(n,e,r)>1e5*a)throw new Error(e+" and "+n+" are too far apart with stepSize of "+a+" "+r);const g=s.ticks.source==="data"&&this.getDataTimestamps();for(d=u,f=0;dp-m).map(p=>+p)}getLabelForValue(t){const e=this._adapter,n=this.options.time;return n.tooltipFormat?e.format(t,n.tooltipFormat):e.format(t,n.displayFormats.datetime)}_tickFormatFunction(t,e,n,s){const o=this.options,r=o.time.displayFormats,a=this._unit,l=this._majorUnit,c=a&&r[a],h=l&&r[l],u=n[e],d=l&&h&&u&&u.major,f=this._adapter.format(t,s||(d?h:c)),g=o.ticks.callback;return g?nt(g,[f,e,n],this):f}generateTickLabels(t){let e,n,s;for(e=0,n=t.length;e0?a:1}getDataTimestamps(){let t=this._cache.data||[],e,n;if(t.length)return t;const s=this.getMatchingVisibleMetas();if(this._normalized&&s.length)return this._cache.data=s[0].controller.getAllParsedValues(this);for(e=0,n=s.length;e=i[n].pos&&t<=i[s].pos&&({lo:n,hi:s}=Je(i,"pos",t)),{pos:o,time:a}=i[n],{pos:r,time:l}=i[s]):(t>=i[n].time&&t<=i[s].time&&({lo:n,hi:s}=Je(i,"time",t)),{time:o,pos:a}=i[n],{time:r,pos:l}=i[s]);const c=r-o;return c?a+(l-a)*(t-o)/c:a}class ed extends co{constructor(t){super(t),this._table=[],this._minPos=void 0,this._tableRange=void 0}initOffsets(){const t=this._getTimestampsForTable(),e=this._table=this.buildLookupTable(t);this._minPos=hs(e,this.min),this._tableRange=hs(e,this.max)-this._minPos,super.initOffsets(t)}buildLookupTable(t){const{min:e,max:n}=this,s=[],o=[];let r,a,l,c,h;for(r=0,a=t.length;r=e&&c<=n&&s.push(c);if(s.length<2)return[{time:e,pos:0},{time:n,pos:1}];for(r=0,a=s.length;r{}};function id(){for(var i,t=0,e=arguments.length,n={};t=0&&(n=e.slice(s+1),e=e.slice(0,s)),e&&!t.hasOwnProperty(e))throw new Error("unknown type: "+e);return{type:e,name:n}})}function k1(i,t){for(var e,n=0,s=i.length;n0)for(var e,n,s=new Array(e),o=0;o=0&&(t=i.slice(0,e))!=="xmlns"&&(i=i.slice(e+1)),Wc.hasOwnProperty(t)?{space:Wc[t],local:i}:i}function S1(i){return function(){var t=this.ownerDocument,e=this.namespaceURI;return e===pr&&t.documentElement.namespaceURI===pr?t.createElement(i):t.createElementNS(e,i)}}function P1(i){return function(){return this.ownerDocument.createElementNS(i.space,i.local)}}function jc(i){var t=nd(i);return(t.local?P1:S1)(t)}function C1(){}function Hc(i){return i==null?C1:function(){return this.querySelector(i)}}function A1(i){return i==null?[]:Array.isArray(i)?i:Array.from(i)}function D1(){return[]}function Yc(i){return function(t){return t.matches(i)}}var O1=Array.prototype.find;function T1(){return this.firstElementChild}var L1=Array.prototype.filter;function R1(){return Array.from(this.children)}function Xc(i){return new Array(i.length)}function Us(i,t){this.ownerDocument=i.ownerDocument,this.namespaceURI=i.namespaceURI,this._next=null,this._parent=i,this.__data__=t}function E1(i){return function(){return i}}function I1(i,t,e,n,s,o){for(var r,a=0,l=t.length,c=o.length;at?1:i>=t?0:NaN}function N1(i){return function(){this.removeAttribute(i)}}function V1(i){return function(){this.removeAttributeNS(i.space,i.local)}}function W1(i,t){return function(){this.setAttribute(i,t)}}function j1(i,t){return function(){this.setAttributeNS(i.space,i.local,t)}}function H1(i,t){return function(){var e=t.apply(this,arguments);e==null?this.removeAttribute(i):this.setAttribute(i,e)}}function Y1(i,t){return function(){var e=t.apply(this,arguments);e==null?this.removeAttributeNS(i.space,i.local):this.setAttributeNS(i.space,i.local,e)}}function sd(i){return i.ownerDocument&&i.ownerDocument.defaultView||i.document&&i||i.defaultView}function X1(i){return function(){this.style.removeProperty(i)}}function U1(i,t,e){return function(){this.style.setProperty(i,t,e)}}function q1(i,t,e){return function(){var n=t.apply(this,arguments);n==null?this.style.removeProperty(i):this.style.setProperty(i,n,e)}}function K1(i,t){return i.style.getPropertyValue(t)||sd(i).getComputedStyle(i,null).getPropertyValue(t)}function G1(i){return function(){delete this[i]}}function Z1(i,t){return function(){this[i]=t}}function J1(i,t){return function(){var e=t.apply(this,arguments);e==null?delete this[i]:this[i]=e}}function od(i){return i.trim().split(/^|\s+/)}function ra(i){return i.classList||new rd(i)}function rd(i){this._node=i,this._names=od(i.getAttribute("class")||"")}function ad(i,t){for(var e=ra(i),n=-1,s=t.length;++n=0&&(e=t.slice(n+1),t=t.slice(0,n)),{type:t,name:e}})}function pv(i){return function(){var t=this.__on;if(t){for(var e,n=0,s=-1,o=t.length;n=0&&(this._names.splice(t,1),this._node.setAttribute("class",this._names.join(" ")))},contains:function(i){return this._names.indexOf(i)>=0}};var xv=[null];function Et(i,t){this._groups=i,this._parents=t}function rn(i){return typeof i=="string"?new Et([[document.querySelector(i)]],[document.documentElement]):new Et([[i]],xv)}function Uc(i,t){if(i=function(o){let r;for(;r=o.sourceEvent;)o=r;return o}(i),t===void 0&&(t=i.currentTarget),t){var e=t.ownerSVGElement||t;if(e.createSVGPoint){var n=e.createSVGPoint();return n.x=i.clientX,n.y=i.clientY,[(n=n.matrixTransform(t.getScreenCTM().inverse())).x,n.y]}if(t.getBoundingClientRect){var s=t.getBoundingClientRect();return[i.clientX-s.left-t.clientLeft,i.clientY-s.top-t.clientTop]}}return[i.pageX,i.pageY]}Et.prototype={constructor:Et,select:function(i){typeof i!="function"&&(i=Hc(i));for(var t=this._groups,e=t.length,n=new Array(e),s=0;s=y&&(y=b+1);!(v=m[y])&&++y=0;)(n=s[o])&&(r&&4^n.compareDocumentPosition(r)&&r.parentNode.insertBefore(n,r),r=n);return this},sort:function(i){function t(u,d){return u&&d?i(u.__data__,d.__data__):!u-!d}i||(i=B1);for(var e=this._groups,n=e.length,s=new Array(n),o=0;o1?this.each((t==null?X1:typeof t=="function"?q1:U1)(i,t,e??"")):K1(this.node(),i)},property:function(i,t){return arguments.length>1?this.each((t==null?G1:typeof t=="function"?J1:Z1)(i,t)):this.node()[i]},classed:function(i,t){var e=od(i+"");if(arguments.length<2){for(var n=ra(this.node()),s=-1,o=e.length;++s()=>i;function mr(i,{sourceEvent:t,subject:e,target:n,identifier:s,active:o,x:r,y:a,dx:l,dy:c,dispatch:h}){Object.defineProperties(this,{type:{value:i,enumerable:!0,configurable:!0},sourceEvent:{value:t,enumerable:!0,configurable:!0},subject:{value:e,enumerable:!0,configurable:!0},target:{value:n,enumerable:!0,configurable:!0},identifier:{value:s,enumerable:!0,configurable:!0},active:{value:o,enumerable:!0,configurable:!0},x:{value:r,enumerable:!0,configurable:!0},y:{value:a,enumerable:!0,configurable:!0},dx:{value:l,enumerable:!0,configurable:!0},dy:{value:c,enumerable:!0,configurable:!0},_:{value:h}})}function vv(i){return!i.ctrlKey&&!i.button}function wv(){return this.parentNode}function Mv(i,t){return t??{x:i.x,y:i.y}}function kv(){return navigator.maxTouchPoints||"ontouchstart"in this}function Sv(){var i,t,e,n,s=vv,o=wv,r=Mv,a=kv,l={},c=id("start","drag","end"),h=0,u=0;function d(b){b.on("mousedown.drag",f).filter(a).on("touchstart.drag",m).on("touchmove.drag",_,yv).on("touchend.drag touchcancel.drag",x).style("touch-action","none").style("-webkit-tap-highlight-color","rgba(0,0,0,0)")}function f(b,y){if(!n&&s.call(this,b,y)){var M=v(this,o.call(this,b,y),b,y,"mouse");M&&(rn(b.view).on("mousemove.drag",g,Bi).on("mouseup.drag",p,Bi),function(w){var k=w.document.documentElement,S=rn(w).on("dragstart.drag",ui,Bi);"onselectstart"in k?S.on("selectstart.drag",ui,Bi):(k.__noselect=k.style.MozUserSelect,k.style.MozUserSelect="none")}(b.view),Wo(b),e=!1,i=b.clientX,t=b.clientY,M("start",b))}}function g(b){if(ui(b),!e){var y=b.clientX-i,M=b.clientY-t;e=y*y+M*M>u}l.mouse("drag",b)}function p(b){rn(b.view).on("mousemove.drag mouseup.drag",null),function(y,M){var w=y.document.documentElement,k=rn(y).on("dragstart.drag",null);M&&(k.on("click.drag",ui,Bi),setTimeout(function(){k.on("click.drag",null)},0)),"onselectstart"in w?k.on("selectstart.drag",null):(w.style.MozUserSelect=w.__noselect,delete w.__noselect)}(b.view,e),ui(b),l.mouse("end",b)}function m(b,y){if(s.call(this,b,y)){var M,w,k=b.changedTouches,S=o.call(this,b,y),P=k.length;for(M=0;Mt.scales[qt].max?t.scales[qt].max:o,o=ot.scales[he].max?t.scales[he].max:r,r=r{if(Mt){di=Mt.datasetIndex,qe=Mt.index,br=!0;let s=t.data.datasets[di].data[qe];qs==="radar"||qs==="polarArea"?s=function(o,r){let a,l,c;o.touches?(a=o.touches[0].clientX-r.canvas.getBoundingClientRect().left,l=o.touches[0].clientY-r.canvas.getBoundingClientRect().top):(a=o.clientX-r.canvas.getBoundingClientRect().left,l=o.clientY-r.canvas.getBoundingClientRect().top);let h=r.scales[ye],u=Math.sqrt(Math.pow(a-h.xCenter,2)+Math.pow(l-h.yCenter,2)),d=h.drawingArea/(h.max-h.min);return c=h.options.ticks.reverse?h.max-u/d:h.min+u/d,c=Ks(c,r.config.options.plugins.dragData.round),c=c>r.scales[ye].max?r.scales[ye].max:c,c=c((n,s,o)=>{if(Mt=s.getElementsAtEventForMode(n,"nearest",{intersect:!0},!1)[0],qs=s.config.type,Mt){let r=Mt.datasetIndex,a=Mt.index;qc=function(u){try{return u()}catch{return""}}(()=>s.config.options.plugins.tooltip.animation);const l=s.data.datasets[r],c=s.getDatasetMeta(r);let h=l.data[a];if(qt=c.xAxisID,he=c.yAxisID,ye=c.rAxisID,l.dragData===!1||s.config.options.scales[qt]&&s.config.options.scales[qt].dragData===!1||s.config.options.scales[he]&&s.config.options.scales[he].dragData===!1||s.config.options.scales[ye]&&s.config.options.scales[ye].rAxisID===!1||l.data[Mt.index].dragData===!1)return void(Mt=null);if(qs==="bar"){hd=s.config.options.scales[qt].stacked;const u=s.data.datasets[0].data[0];ud=u!==null&&Array.isArray(u)&&u.length==2,dd=_r(n,s,r,a)-h}(s.config.options.plugins.dragData.showTooltip===void 0||s.config.options.plugins.dragData.showTooltip)&&(s.config.options.plugins.tooltip||(s.config.options.plugins.tooltip={}),s.config.options.plugins.tooltip.animation=!1),typeof o=="function"&&Mt&&o(n,r,a,h)===!1&&(Mt=null)}})(e.sourceEvent,i,t.onDragStart)).on("drag",e=>Pv(e.sourceEvent,i,t,t.onDrag)).on("end",e=>((n,s,o)=>{if(qe=void 0,br=!1,s.config.options.plugins.tooltip&&(s.config.options.plugins.tooltip.animation=qc,s.update("none")),typeof o=="function"&&Mt){const r=Mt.datasetIndex,a=Mt.index;let l=function(c,h,u){const d=c.config.options.plugins.dragData;if(!d.magnet)return c.data.datasets[h].data[u];{const f=d.magnet;if(f.to&&typeof f.to=="function"){let g=c.data.datasets[h].data[u];return g=f.to(g),c.data.datasets[h].data[u]=g,c.update("none"),g}}}(s,r,a);return o(n,r,a,l)}})(e.sourceEvent,i,t.onDragEnd)))}},beforeEvent:function(i){if(br)return i.tooltip&&i.tooltip.update(),!1}};ia.register(fd);function Cv(i){let t,e,n,s,o,r=i[0].toFixed(0)+"",a,l,c,h,u,d=i[1].toFixed(0)+"",f,g,p,m,_,x=i[2].toFixed(0)+"",v,b,y,M;return{c(){t=$("canvas"),e=Wt(),n=$("ul"),s=$("li"),o=pt("LTS: "),a=pt(r),l=pt("%"),c=Wt(),h=$("li"),u=pt("Nearby amenities: "),f=pt(d),g=pt("%"),p=Wt(),m=$("li"),_=pt("Greenspace proximity: "),v=pt(x),b=pt("%"),Ke(t,"width","100%"),Ke(t,"height","400px"),Ke(s,"color",i[3][0]),Ke(h,"color",i[3][1]),Ke(m,"color",i[3][2])},m(w,k){st(w,t,k),st(w,e,k),st(w,n,k),R(n,s),R(s,o),R(s,a),R(s,l),R(n,c),R(n,h),R(h,u),R(h,f),R(h,g),R(n,p),R(n,m),R(m,_),R(m,v),R(m,b),y||(M=Sd(i[4].call(null,t)),y=!0)},p(w,[k]){k&1&&r!==(r=w[0].toFixed(0)+"")&&an(a,r),k&2&&d!==(d=w[1].toFixed(0)+"")&&an(f,d),k&4&&x!==(x=w[2].toFixed(0)+"")&&an(v,x)},i:jt,o:jt,d(w){w&&(ot(t),ot(e),ot(n)),y=!1,M()}}}function Av(i,t,e){ws.register(...c_),ws.register(fd);let{lts:n}=t,{nearbyAmenities:s}=t,{greenspace:o}=t,r=null,a=["red","blue","green"];l();function l(){let h=n+s+o;e(0,n=100*n/h),e(1,s=100*s/h),e(2,o=100*o/h)}function c(h){let u={type:"radar",data:{labels:["LTS","Amenities","Greenspace"],datasets:[{label:"Routing preferences",data:[n,s,o],pointHitRadius:25}]},options:{responsive:!1,onHover(d){const f=d.chart.getElementsAtEventForMode(d,"nearest",{intersect:!0},!1);d.native.target.style.cursor=f.length?"grab":"default"},plugins:{dragData:{round:1,showTooltip:!0,onDragStart(d){d.target.style.cursor="grabbing"},onDragEnd(d,f,g,p){d.target.style.cursor="default",g==0?e(0,n=p):g==1?e(1,s=p):g==2&&e(2,o=p),l()}}},scales:{r:{min:0,max:100,stepSize:1,pointLabels:{color:a,font:{weight:"bold",size:15}}}}}};r=new ws(h.getContext("2d"),u)}return i.$$set=h=>{"lts"in h&&e(0,n=h.lts),"nearbyAmenities"in h&&e(1,s=h.nearbyAmenities),"greenspace"in h&&e(2,o=h.greenspace)},[n,s,o,a,c]}class Dv extends An{constructor(t){super(),Dn(this,t,Av,Cv,Pi,{lts:0,nearbyAmenities:1,greenspace:2})}}function Kc(i,t,e){const n=i.slice();return n[17]=t[e],n[22]=t,n[23]=e,n}function Gc(i,t,e){const n=i.slice();return n[17]=t[e],n[20]=t,n[21]=e,n}function Zc(i,t,e){const n=i.slice();return n[17]=t[e],n[18]=t,n[19]=e,n}function Ov(i){let t,e,n,s,o,r,a,l,c,h,u,d,f,g,p,m;function _(w){i[10](w)}function x(w){i[11](w)}function v(w){i[12](w)}let b={};i[2].tradeoff_lts!==void 0&&(b.lts=i[2].tradeoff_lts),i[2].tradeoff_amenities!==void 0&&(b.nearbyAmenities=i[2].tradeoff_amenities),i[2].tradeoff_greenspace!==void 0&&(b.greenspace=i[2].tradeoff_greenspace),t=new Dv({props:b}),fo.push(()=>go(t,"lts",_)),fo.push(()=>go(t,"nearbyAmenities",x)),fo.push(()=>go(t,"greenspace",v));let y=xi(["lts1","lts2","lts3","lts4"]),M=[];for(let w=0;w<4;w+=1)M[w]=Jc(Kc(i,y,w));return{c(){Pd(t.$$.fragment),o=Wt(),r=$("ul");for(let w=0;w<4;w+=1)M[w].c();a=Wt(),l=$("div"),c=$("label"),h=pt(`Give roads a good score if they have at least this many nearby amenities: `),u=$("input"),d=Wt(),f=$("button"),f.textContent="Recalculate",Pt(u,"type","number"),Pt(u,"min","0"),Pt(f,"type","button")},m(w,k){Cd(t,w,k),st(w,o,k),st(w,r,k);for(let S=0;S<4;S+=1)M[S]&&M[S].m(r,null);st(w,a,k),st(w,l,k),R(l,c),R(c,h),R(c,u),ft(u,i[2].minimum_amenities),st(w,d,k),st(w,f,k),g=!0,p||(m=[Jt(u,"input",i[14]),Jt(f,"click",i[15])],p=!0)},p(w,k){const S={};if(!e&&k&4&&(e=!0,S.lts=w[2].tradeoff_lts,po(()=>e=!1)),!n&&k&4&&(n=!0,S.nearbyAmenities=w[2].tradeoff_amenities,po(()=>n=!1)),!s&&k&4&&(s=!0,S.greenspace=w[2].tradeoff_greenspace,po(()=>s=!1)),t.$set(S),k&4){y=xi(["lts1","lts2","lts3","lts4"]);let P;for(P=0;P<4;P+=1){const D=Kc(w,y,P);M[P]?M[P].p(D,k):(M[P]=Jc(D),M[P].c(),M[P].m(r,null))}for(;P<4;P+=1)M[P].d(1)}k&4&&Ze(u.value)!==w[2].minimum_amenities&&ft(u,w[2].minimum_amenities)},i(w){g||(pe(t.$$.fragment,w),g=!0)},o(w){De(t.$$.fragment,w),g=!1},d(w){w&&(ot(o),ot(r),ot(a),ot(l),ot(d),ot(f)),Ad(t,w),vr(M,w),p=!1,Zs(m)}}}function Tv(i){let t,e=xi(["lts1","lts2","lts3","lts4"]),n=[];for(let s=0;s<4;s+=1)n[s]=Qc(Gc(i,e,s));return{c(){t=$("ul");for(let s=0;s<4;s+=1)n[s].c()},m(s,o){st(s,t,o);for(let r=0;r<4;r+=1)n[r]&&n[r].m(t,null)},p(s,o){if(o&9){e=xi(["lts1","lts2","lts3","lts4"]);let r;for(r=0;r<4;r+=1){const a=Gc(s,e,r);n[r]?n[r].p(a,o):(n[r]=Qc(a),n[r].c(),n[r].m(t,null))}for(;r<4;r+=1)n[r].d(1)}},i:jt,o:jt,d(s){s&&ot(t),vr(n,s)}}}function Lv(i){let t,e=xi(Object.keys(i[4])),n=[];for(let s=0;si[5].call(s))},m(v,b){st(v,t,b),R(t,e),R(e,n),R(e,s),R(s,o),R(s,r),R(s,a),R(s,l),Ps(s,i[1],!0),st(v,c,b),~h&&_[h].m(v,b),st(v,d,b),f=!0,g||(p=Jt(s,"change",i[5]),g=!0)},p(v,[b]){b&2&&Ps(s,v[1]);let y=h;h=x(v),h===y?~h&&_[h].p(v,b):(u&&(xr(),De(_[y],1,1,()=>{_[y]=null}),yr()),~h?(u=_[h],u?u.p(v,b):(u=_[h]=m[h](v),u.c()),pe(u,1),u.m(d.parentNode,d)):u=null)},i(v){f||(pe(u),f=!0)},o(v){De(u),f=!1},d(v){v&&(ot(t),ot(c),ot(d)),~h&&_[h].d(v),g=!1,p()}}}function Ev(i,t,e){let{cost:n}=t,s="Distance",o={tradeoff_lts:50,tradeoff_amenities:30,tradeoff_greenspace:20,lts1:0,lts2:.2,lts3:.6,lts4:1,minimum_amenities:1},r={lts1:1,lts2:1,lts3:1,lts4:1},a={};for(let b of["cycleway","footway","living_street","motorway","motorway_link","path","pedestrian","primary","primary_link","residential","secondary","secondary_link","service","steps","tertiary","tertiary_link","track","trunk","trunk_link","unclassified"])a[b]=1;function l(b){b=="OsmHighwayType"?e(0,n={OsmHighwayType:a}):b=="ByLTS"?e(0,n={ByLTS:r}):b=="Generalized"?e(0,n={Generalized:o}):e(0,n=b)}function c(){s=nh(this),e(1,s)}function h(b){a[b]=Ze(this.value),e(4,a)}const u=()=>e(0,n);function d(b){r[b]=Ze(this.value),e(3,r)}const f=()=>e(0,n);function g(b){i.$$.not_equal(o.tradeoff_lts,b)&&(o.tradeoff_lts=b,e(2,o))}function p(b){i.$$.not_equal(o.tradeoff_amenities,b)&&(o.tradeoff_amenities=b,e(2,o))}function m(b){i.$$.not_equal(o.tradeoff_greenspace,b)&&(o.tradeoff_greenspace=b,e(2,o))}function _(b){o[b]=Ze(this.value),e(2,o)}function x(){o.minimum_amenities=Ze(this.value),e(2,o)}const v=()=>e(0,n);return i.$$set=b=>{"cost"in b&&e(0,n=b.cost)},i.$$.update=()=>{i.$$.dirty&2&&l(s)},[n,s,o,r,a,c,h,u,d,f,g,p,m,_,x,v]}class vw extends An{constructor(t){super(),Dn(this,t,Ev,Rv,Pi,{cost:0})}}function eh(i){let t;return{c(){t=$("div"),t.textContent="Loading",Pt(t,"class","svelte-1uuov7f")},m(e,n){st(e,t,n)},d(e){e&&ot(t)}}}function Iv(i){let t,e=i[0]&&eh();return{c(){e&&e.c(),t=Gs()},m(n,s){e&&e.m(n,s),st(n,t,s)},p(n,[s]){n[0]?e||(e=eh(),e.c(),e.m(t.parentNode,t)):e&&(e.d(1),e=null)},i:jt,o:jt,d(n){n&&ot(t),e&&e.d(n)}}}function Fv(i,t,e){let{loading:n=!1}=t;return i.$$set=s=>{"loading"in s&&e(0,n=s.loading)},[n]}class ww extends An{constructor(t){super(),Dn(this,t,Fv,Iv,Pi,{loading:0})}}export{Nv as C,Bv as G,Yo as J,ww as L,Vd as _,vw as a}; diff --git a/assets/x2-a4784f4a.js b/assets/x2-a2d3d460.js similarity index 99% rename from assets/x2-a4784f4a.js rename to assets/x2-a2d3d460.js index d927c85..39c0ac0 100644 --- a/assets/x2-a4784f4a.js +++ b/assets/x2-a2d3d460.js @@ -1,4 +1,4 @@ -import{S as te,i as ne,s as se,G as fe,e as E,h as P,z as G,l as I,I as Q,q as O,J as ue,K as ce,N as pe,O as de,t as h,b as C,v as S,w as me,Q as ge,R as _e,T as U,U as V,m as be,L as he,c as D,f as j,a as q,d as J,o as we,H as Le,x as T,y as H,g as W,n as M,A as K,r as X,u as Y,M as ye,_ as ve,V as ae,j as $,D as Ce,E as ke,W as Me}from"./Legend-36db5a45.js";import{L as Be,C as ze,_ as Ee,J as Ie,a as Se,G as De}from"./Loading-ad1d8aa1.js";import{S as qe,L as Je}from"./SidebarControls-5b3d2c73.js";function Ne(a){let e,t,l,n,o,f,c;const s=a[16].default,r=fe(s,a,a[15],null);return{c(){e=E("div"),r&&r.c(),P(e,"tabindex",t=a[1]?0:void 0),P(e,"role",l=a[1]?"button":void 0),G(e,"z-index",a[2])},m(i,p){I(i,e,p),r&&r.m(e,null),o=!0,f||(c=[Q(a[6].call(null,e)),Q(n=Oe.call(null,e,a[0])),O(e,"click",a[17]),O(e,"dblclick",a[18]),O(e,"contextmenu",a[19]),O(e,"mouseenter",a[20]),O(e,"mouseleave",a[21]),O(e,"mousemove",a[22]),O(e,"keydown",a[7])],f=!0)},p(i,[p]){r&&r.p&&(!o||p&32768)&&ue(r,s,i,i[15],o?pe(s,i[15],p,null):ce(i[15]),null),(!o||p&2&&t!==(t=i[1]?0:void 0))&&P(e,"tabindex",t),(!o||p&2&&l!==(l=i[1]?"button":void 0))&&P(e,"role",l),n&&de(n.update)&&p&1&&n.update.call(null,i[0]),p&4&&G(e,"z-index",i[2])},i(i){o||(h(r,i),o=!0)},o(i){C(r,i),o=!1},d(i){i&&S(e),r&&r.d(i),f=!1,me(c)}}}function Oe(a,e){const t=a.className;function l(n){n?a.className=`${t} ${n}`:a.className=t}return l(e),{update:l}}function Pe(a,e,t){let l,n,o,{$$slots:f={},$$scope:c}=e,{lngLat:s}=e,{class:r=void 0}=e,{interactive:i=!0}=e,{asButton:p=!1}=e,{draggable:w=!1}=e,{feature:B=null}=e,{offset:y=void 0}=e,{zIndex:d=void 0}=e;const v=ge(),{map:N,layerEvent:A,self:m}=_e();U(a,N,u=>t(24,o=u)),U(a,A,u=>t(23,l=u)),U(a,m,u=>t(14,n=u));function _(u){V(m,n=new be.Marker({element:u,draggable:w,offset:y}).setLngLat(s).addTo(o),n);const R=()=>L("dragstart"),F=()=>{g(),L("drag")},Z=()=>{g(),L("dragend")};return w&&(n.on("dragstart",R),n.on("drag",F),n.on("dragend",Z)),{destroy(){w&&(n==null||n.off("dragstart",R),n==null||n.off("drag",F),n==null||n.off("dragend",Z)),n==null||n.remove()}}}function g(){let u=n==null?void 0:n.getLngLat();u&&(Array.isArray(s)?t(9,s=[u.lng,u.lat]):s&&"lon"in s?t(9,s={lon:u.lng,lat:u.lat}):t(9,s=u))}function z(u){u.key===" "&&(u.preventDefault(),u.stopPropagation(),L("click"))}function L(u){if(!i)return;let R=n==null?void 0:n.getLngLat();if(!R)return;const F=[R.lng,R.lat];let Z={map:o,marker:n,lngLat:F,features:[{type:"Feature",properties:(B==null?void 0:B.properties)??{},geometry:{type:"Point",coordinates:F}}]};V(A,l={...Z,layerType:"marker",type:u},l),v(u,Z)}const b=()=>L("click"),k=()=>L("dblclick"),le=()=>L("contextmenu"),oe=u=>{L("mouseenter")},ie=()=>{L("mouseleave")},re=()=>L("mousemove");return a.$$set=u=>{"lngLat"in u&&t(9,s=u.lngLat),"class"in u&&t(0,r=u.class),"interactive"in u&&t(10,i=u.interactive),"asButton"in u&&t(1,p=u.asButton),"draggable"in u&&t(11,w=u.draggable),"feature"in u&&t(12,B=u.feature),"offset"in u&&t(13,y=u.offset),"zIndex"in u&&t(2,d=u.zIndex),"$$scope"in u&&t(15,c=u.$$scope)},a.$$.update=()=>{a.$$.dirty&16896&&(n==null||n.setLngLat(s)),a.$$.dirty&24576&&(n==null||n.setOffset(y??[0,0]))},[r,p,d,N,A,m,_,z,L,s,i,w,B,y,n,c,f,b,k,le,oe,ie,re]}class je extends te{constructor(e){super(),ne(this,e,Pe,Ne,se,{lngLat:9,class:0,interactive:10,asButton:1,draggable:11,feature:12,offset:13,zIndex:2})}}const Ae=` +import{S as te,i as ne,s as se,G as fe,e as E,h as P,z as G,l as I,I as Q,q as O,J as ue,K as ce,N as pe,O as de,t as h,b as C,v as S,w as me,Q as ge,R as _e,T as U,U as V,m as be,L as he,c as D,f as j,a as q,d as J,o as we,H as Le,x as T,y as H,g as W,n as M,A as K,r as X,u as Y,M as ye,_ as ve,V as ae,j as $,D as Ce,E as ke,W as Me}from"./Legend-36db5a45.js";import{L as Be,C as ze,_ as Ee,J as Ie,a as Se,G as De}from"./Loading-e28fecd7.js";import{S as qe,L as Je}from"./SidebarControls-5b3d2c73.js";function Ne(a){let e,t,l,n,o,f,c;const s=a[16].default,r=fe(s,a,a[15],null);return{c(){e=E("div"),r&&r.c(),P(e,"tabindex",t=a[1]?0:void 0),P(e,"role",l=a[1]?"button":void 0),G(e,"z-index",a[2])},m(i,p){I(i,e,p),r&&r.m(e,null),o=!0,f||(c=[Q(a[6].call(null,e)),Q(n=Oe.call(null,e,a[0])),O(e,"click",a[17]),O(e,"dblclick",a[18]),O(e,"contextmenu",a[19]),O(e,"mouseenter",a[20]),O(e,"mouseleave",a[21]),O(e,"mousemove",a[22]),O(e,"keydown",a[7])],f=!0)},p(i,[p]){r&&r.p&&(!o||p&32768)&&ue(r,s,i,i[15],o?pe(s,i[15],p,null):ce(i[15]),null),(!o||p&2&&t!==(t=i[1]?0:void 0))&&P(e,"tabindex",t),(!o||p&2&&l!==(l=i[1]?"button":void 0))&&P(e,"role",l),n&&de(n.update)&&p&1&&n.update.call(null,i[0]),p&4&&G(e,"z-index",i[2])},i(i){o||(h(r,i),o=!0)},o(i){C(r,i),o=!1},d(i){i&&S(e),r&&r.d(i),f=!1,me(c)}}}function Oe(a,e){const t=a.className;function l(n){n?a.className=`${t} ${n}`:a.className=t}return l(e),{update:l}}function Pe(a,e,t){let l,n,o,{$$slots:f={},$$scope:c}=e,{lngLat:s}=e,{class:r=void 0}=e,{interactive:i=!0}=e,{asButton:p=!1}=e,{draggable:w=!1}=e,{feature:B=null}=e,{offset:y=void 0}=e,{zIndex:d=void 0}=e;const v=ge(),{map:N,layerEvent:A,self:m}=_e();U(a,N,u=>t(24,o=u)),U(a,A,u=>t(23,l=u)),U(a,m,u=>t(14,n=u));function _(u){V(m,n=new be.Marker({element:u,draggable:w,offset:y}).setLngLat(s).addTo(o),n);const R=()=>L("dragstart"),F=()=>{g(),L("drag")},Z=()=>{g(),L("dragend")};return w&&(n.on("dragstart",R),n.on("drag",F),n.on("dragend",Z)),{destroy(){w&&(n==null||n.off("dragstart",R),n==null||n.off("drag",F),n==null||n.off("dragend",Z)),n==null||n.remove()}}}function g(){let u=n==null?void 0:n.getLngLat();u&&(Array.isArray(s)?t(9,s=[u.lng,u.lat]):s&&"lon"in s?t(9,s={lon:u.lng,lat:u.lat}):t(9,s=u))}function z(u){u.key===" "&&(u.preventDefault(),u.stopPropagation(),L("click"))}function L(u){if(!i)return;let R=n==null?void 0:n.getLngLat();if(!R)return;const F=[R.lng,R.lat];let Z={map:o,marker:n,lngLat:F,features:[{type:"Feature",properties:(B==null?void 0:B.properties)??{},geometry:{type:"Point",coordinates:F}}]};V(A,l={...Z,layerType:"marker",type:u},l),v(u,Z)}const b=()=>L("click"),k=()=>L("dblclick"),le=()=>L("contextmenu"),oe=u=>{L("mouseenter")},ie=()=>{L("mouseleave")},re=()=>L("mousemove");return a.$$set=u=>{"lngLat"in u&&t(9,s=u.lngLat),"class"in u&&t(0,r=u.class),"interactive"in u&&t(10,i=u.interactive),"asButton"in u&&t(1,p=u.asButton),"draggable"in u&&t(11,w=u.draggable),"feature"in u&&t(12,B=u.feature),"offset"in u&&t(13,y=u.offset),"zIndex"in u&&t(2,d=u.zIndex),"$$scope"in u&&t(15,c=u.$$scope)},a.$$.update=()=>{a.$$.dirty&16896&&(n==null||n.setLngLat(s)),a.$$.dirty&24576&&(n==null||n.setOffset(y??[0,0]))},[r,p,d,N,A,m,_,z,L,s,i,w,B,y,n,c,f,b,k,le,oe,ie,re]}class je extends te{constructor(e){super(),ne(this,e,Pe,Ne,se,{lngLat:9,class:0,interactive:10,asButton:1,draggable:11,feature:12,offset:13,zIndex:2})}}const Ae=` diff --git a/assets/x3-d073bd9b.js b/assets/x3-adc74180.js similarity index 99% rename from assets/x3-d073bd9b.js rename to assets/x3-adc74180.js index d239c39..e656d4a 100644 --- a/assets/x3-d073bd9b.js +++ b/assets/x3-adc74180.js @@ -1,4 +1,4 @@ -import{S as me,i as de,s as ge,ab as Z,e as g,f as q,z as E,l as h,E as se,v as w,ac as oe,g as G,n as k,a6 as he,L as we,c as N,a as j,t as v,b as C,d as B,o as ke,H as ye,x as V,y as te,h as K,q as x,A as ne,r as $e,u as be,M as ve,_ as Ce,$ as Se,a3 as A,ad as ie,C as Fe,j as Y,k as Le,p as ae,w as Ne,ae as ee,a0 as je,a9 as Be,aa as H,a2 as Me,a4 as Oe,a5 as qe}from"./Legend-36db5a45.js";import{L as Ee,C as Je,_ as Te,J as Ae,a as He,G as Pe}from"./Loading-ad1d8aa1.js";function re(s,t,n){const e=s.slice();return e[2]=t[n],e}function fe(s,t,n){const e=s.slice();return e[5]=t[n],e}function pe(s){let t,n;return{c(){t=g("span"),n=G(`  +import{S as me,i as de,s as ge,ab as Z,e as g,f as q,z as E,l as h,E as se,v as w,ac as oe,g as G,n as k,a6 as he,L as we,c as N,a as j,t as v,b as C,d as B,o as ke,H as ye,x as V,y as te,h as K,q as x,A as ne,r as $e,u as be,M as ve,_ as Ce,$ as Se,a3 as A,ad as ie,C as Fe,j as Y,k as Le,p as ae,w as Ne,ae as ee,a0 as je,a9 as Be,aa as H,a2 as Me,a4 as Oe,a5 as qe}from"./Legend-36db5a45.js";import{L as Ee,C as Je,_ as Te,J as Ae,a as He,G as Pe}from"./Loading-e28fecd7.js";function re(s,t,n){const e=s.slice();return e[2]=t[n],e}function fe(s,t,n){const e=s.slice();return e[5]=t[n],e}function pe(s){let t,n;return{c(){t=g("span"),n=G(`  `),E(t,"background",s[5]),E(t,"width","100%"),E(t,"border","1px solid black")},m(e,o){h(e,t,o),k(t,n)},p(e,o){o&1&&E(t,"background",e[5])},d(e){e&&w(t)}}}function ue(s){let t,n=s[2].toFixed(1)+"",e;return{c(){t=g("span"),e=G(n)},m(o,l){h(o,t,l),k(t,e)},p(o,l){l&2&&n!==(n=o[2].toFixed(1)+"")&&he(e,n)},d(o){o&&w(t)}}}function De(s){let t,n,e,o=Z(s[0]),l=[];for(let i=0;i{"colorScale"in l&&n(0,e=l.colorScale),"limits"in l&&n(1,o=l.limits)},[e,o]}class Ie extends me{constructor(t){super(),de(this,t,Ge,De,ge,{colorScale:0,limits:1})}}function ce(s){let t,n,e,o,l,p,r,i,c,a,_,$,S,F,J,M,P,m,d,O,L,I,D,R,z;const U=[ze,Re],T=[];function W(f,y){return f[5]=="lts"?0:1}_=W(s),$=T[_]=U[_](s);function u(f){s[21](f)}let b={};return s[1]!==void 0&&(b.cost=s[1]),L=new He({props:b}),V.push(()=>te(L,"cost",u)),{c(){t=g("hr"),n=q(),e=g("div"),o=g("label"),l=G(`Color edges by: `),p=g("select"),r=g("option"),r.textContent="LTS",i=g("option"),i.textContent="Edge cost (relative to length)",c=g("option"),c.textContent="Nearby amenities",a=q(),$.c(),S=q(),F=g("div"),J=g("label"),M=g("input"),P=G(` Show cyclists not allowed`),m=q(),d=g("hr"),O=q(),N(L.$$.fragment),r.__value="lts",Y(r,r.__value),i.__value="cost",Y(i,i.__value),c.__value="nearby_amenities",Y(c,c.__value),s[5]===void 0&&Le(()=>s[19].call(p)),K(M,"type","checkbox"),E(J,"color",A.lts_not_allowed)},m(f,y){h(f,t,y),h(f,n,y),h(f,e,y),k(e,o),k(o,l),k(o,p),k(p,r),k(p,i),k(p,c),ae(p,s[5],!0),h(f,a,y),T[_].m(f,y),h(f,S,y),h(f,F,y),k(F,J),k(J,M),M.checked=s[6],k(J,P),h(f,m,y),h(f,d,y),h(f,O,y),j(L,f,y),D=!0,R||(z=[x(p,"change",s[19]),x(M,"change",s[20])],R=!0)},p(f,y){y&32&&ae(p,f[5]);let X=_;_=W(f),_===X?T[_].p(f,y):($e(),C(T[X],1,1,()=>{T[X]=null}),be(),$=T[_],$?$.p(f,y):($=T[_]=U[_](f),$.c()),v($,1),$.m(S.parentNode,S)),y&64&&(M.checked=f[6]);const le={};!I&&y&2&&(I=!0,le.cost=f[1],ne(()=>I=!1)),L.$set(le)},i(f){D||(v($),v(L.$$.fragment,f),D=!0)},o(f){C($),C(L.$$.fragment,f),D=!1},d(f){f&&(w(t),w(n),w(e),w(a),w(S),w(F),w(m),w(d),w(O)),T[_].d(f),B(L,f),R=!1,Ne(z)}}}function Re(s){let t,n;return t=new Ie({props:{colorScale:ee,limits:Q(s[5],s[9],s[10])}}),{c(){N(t.$$.fragment)},m(e,o){j(t,e,o),n=!0},p(e,o){const l={};o&1568&&(l.limits=Q(e[5],e[9],e[10])),t.$set(l)},i(e){n||(v(t.$$.fragment,e),n=!0)},o(e){C(t.$$.fragment,e),n=!1},d(e){B(t,e)}}}function ze(s){let t,n,e,o;return t=new Be({props:{rows:[[`${H.lts1}: ${s[8][1].toFixed(0)}% of roads by distance`,A.lts1],[`${H.lts2}: ${s[8][2].toFixed(0)}%`,A.lts2],[`${H.lts3}: ${s[8][3].toFixed(0)}%`,A.lts3],[`${H.lts4}: ${s[8][4].toFixed(0)}%`,A.lts4]]}}),{c(){N(t.$$.fragment),n=q(),e=g("p"),e.innerHTML='Note: LTS model from BikeOttawa'},m(l,p){j(t,l,p),h(l,n,p),h(l,e,p),o=!0},p(l,p){const r={};p&256&&(r.rows=[[`${H.lts1}: ${l[8][1].toFixed(0)}% of roads by distance`,A.lts1],[`${H.lts2}: ${l[8][2].toFixed(0)}%`,A.lts2],[`${H.lts3}: ${l[8][3].toFixed(0)}%`,A.lts3],[`${H.lts4}: ${l[8][4].toFixed(0)}%`,A.lts4]]),t.$set(r)},i(l){o||(v(t.$$.fragment,l),o=!0)},o(l){C(t.$$.fragment,l),o=!1},d(l){l&&(w(n),w(e)),B(t,l)}}}function Ue(s){let t,n,e,o,l,p,r,i,c,a,_,$,S,F,J;n=new ye({props:{app:"costs"}});function M(d){s[18](d)}let P={};s[0]!==void 0&&(P.example=s[0]),a=new Je({props:P}),V.push(()=>te(a,"example",M));let m=s[3]&&ce(s);return{c(){t=g("div"),N(n.$$.fragment),e=q(),o=g("label"),l=G("Open an "),p=g("i"),p.textContent=".osm.pbf",r=G(` file diff --git a/edge_cost.html b/edge_cost.html index 767ed71..e67c70d 100644 --- a/edge_cost.html +++ b/edge_cost.html @@ -4,9 +4,9 @@ od2net edge cost mode - + - + diff --git a/interactive.html b/interactive.html index 1ab6771..d6c2c0e 100644 --- a/interactive.html +++ b/interactive.html @@ -4,9 +4,9 @@ od2net interactive mode - + - +