UNPKG

highcharts

Version:
1 lines 88.8 kB
let t,e;import*as i from"../highcharts.js";import"./broken-axis.js";import"./datagrouping.js";import"./mouse-wheel-zoom.js";var s,o,a,r,n,l,h,d={};d.n=t=>{var e=t&&t.__esModule?()=>t.default:()=>t;return d.d(e,{a:e}),e},d.d=(t,e)=>{for(var i in e)d.o(e,i)&&!d.o(t,i)&&Object.defineProperty(t,i,{enumerable:!0,get:e[i]})},d.o=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);let p=i.default;var c=d.n(p);let u=i.default.Axis;var g=d.n(u);let m=i.default.Point;var x=d.n(m);let f=i.default.Series;var b=d.n(f);let{tooltipFormatter:v}=x().prototype,{addEvent:y,arrayMax:M,arrayMin:A,correctFloat:w,defined:k,isArray:S,isNumber:O,isString:E,pick:C}=c();!function(t){function e(t,e,i){!this.isXAxis&&(this.series.forEach(function(i){"compare"===t&&"boolean"!=typeof e?i.setCompare(e,!1):"cumulative"!==t||E(e)||i.setCumulative(e,!1)}),C(i,!0)&&this.chart.redraw())}function i(t){let e=this,{numberFormatter:i}=e.series.chart,s=function(s){t=t.replace("{point."+s+"}",(e[s]>0&&"change"===s?"+":"")+i(e[s],C(e.series.tooltipOptions.changeDecimals,2)))};return k(e.change)&&s("change"),k(e.cumulativeSum)&&s("cumulativeSum"),v.apply(this,[t])}function s(){let t,e=this.options.compare;("percent"===e||"value"===e||this.options.cumulative)&&(t=new d(this),"percent"===e||"value"===e?t.initCompare(e):t.initCumulative()),this.dataModify=t}function o(t){let e=t.dataExtremes,i=e.activeYData;if(this.dataModify&&e){let t;this.options.compare?t=[this.dataModify.modifyValue(e.dataMin),this.dataModify.modifyValue(e.dataMax)]:this.options.cumulative&&S(i)&&i.length>=2&&(t=d.getCumulativeExtremes(i)),t&&(e.dataMin=A(t),e.dataMax=M(t))}}function a(t,e){this.options.compare=this.userOptions.compare=t,this.update({},C(e,!0)),this.dataModify&&("value"===t||"percent"===t)?this.dataModify.initCompare(t):this.points.forEach(t=>{delete t.change})}function r(){let t=this.getColumn(this.pointArrayMap&&(this.options.pointValKey||this.pointValKey)||"y",!0);if(this.xAxis&&t.length&&this.dataModify){let e=this.getColumn("x",!0),i=this.dataTable.rowCount,s=+(!0!==this.options.compareStart);for(let o=0;o<i-s;o++){let i=t[o];if(O(i)&&0!==i&&e[o+s]>=(this.xAxis.min||0)){this.dataModify.compareValue=i;break}}}}function n(t,e){this.setModifier("compare",t,e)}function l(t,e){t=C(t,!1),this.options.cumulative=this.userOptions.cumulative=t,this.update({},C(e,!0)),this.dataModify?this.dataModify.initCumulative():this.points.forEach(t=>{delete t.cumulativeSum})}function h(t,e){this.setModifier("cumulative",t,e)}t.compose=function(t,d,p){let c=d.prototype,u=p.prototype,g=t.prototype;return g.setCompare||(g.setCompare=a,g.setCumulative=l,y(t,"afterInit",s),y(t,"afterGetExtremes",o),y(t,"afterProcessData",r)),c.setCompare||(c.setCompare=n,c.setModifier=e,c.setCumulative=h,u.tooltipFormatter=i),t};class d{constructor(t){this.series=t}modifyValue(){return 0}static getCumulativeExtremes(t){let e=1/0,i=-1/0;return t.reduce((t,s)=>{let o=t+s;return e=Math.min(e,o,t),i=Math.max(i,o,t),o}),[e,i]}initCompare(t){this.modifyValue=function(e,i){null===e&&(e=0);let s=this.compareValue;if(void 0!==e&&void 0!==s){if("value"===t?e-=s:e=e/s*100-100*(100!==this.series.options.compareBase),void 0!==i){let t=this.series.points[i];t&&(t.change=e)}return e}return 0}}initCumulative(){this.modifyValue=function(t,e){if(null===t&&(t=0),void 0!==t&&void 0!==e){let i=e>0?this.series.points[e-1]:null;i&&i.cumulativeSum&&(t=w(i.cumulativeSum+t));let s=this.series.points[e],o=s.series.options.cumulativeStart,a=s.x<=this.series.xAxis.max&&s.x>=this.series.xAxis.min;return s&&(!o||a?s.cumulativeSum=t:s.cumulativeSum=void 0),t}return 0}}}t.Additions=d}(o||(o={}));let T=o,{isTouchDevice:B}=c(),{addEvent:D,merge:P,pick:R}=c(),z=[];function I(){this.navigator&&this.navigator.setBaseSeries(null,!1)}function L(){let t,e,i,s=this.legend,o=this.navigator;if(o){t=s&&s.options,e=o.xAxis,i=o.yAxis;let{scrollbarHeight:a,scrollButtonSize:r}=o;this.inverted?(o.left=o.opposite?this.chartWidth-a-o.height:this.spacing[3]+a,o.top=this.plotTop+r):(o.left=R(e.left,this.plotLeft+r),o.top=o.navigatorOptions.top||this.chartHeight-o.height-a-(this.scrollbar?.options.margin||0)-this.spacing[2]-(this.rangeSelector&&this.extraBottomMargin?this.rangeSelector.getHeight():0)-(t&&"bottom"===t.verticalAlign&&"proximate"!==t.layout&&t.enabled&&!t.floating?s.legendHeight+R(t.margin,10):0)-(this.titleOffset?this.titleOffset[2]:0)),e&&i&&(this.inverted?e.options.left=i.options.left=o.left:e.options.top=i.options.top=o.top,e.setAxisSize(),i.setAxisSize())}}function W(e){!this.navigator&&!this.scroller&&(this.options.navigator.enabled||this.options.scrollbar.enabled)&&(this.scroller=this.navigator=new t(this),R(e.redraw,!0)&&this.redraw(e.animation))}function X(){let e=this.options;(e.navigator.enabled||e.scrollbar.enabled)&&(this.scroller=this.navigator=new t(this))}function G(){let t=this.options,e=t.navigator,i=t.rangeSelector;if((e&&e.enabled||i&&i.enabled)&&(!B&&"x"===this.zooming.type||B&&"x"===this.zooming.pinchType))return!1}function Y(t){let e=t.navigator;if(e&&t.xAxis[0]){let i=t.xAxis[0].getExtremes();e.render(i.min,i.max)}}function U(t){let e=t.options.navigator||{},i=t.options.scrollbar||{};!this.navigator&&!this.scroller&&(e.enabled||i.enabled)&&(P(!0,this.options.navigator,e),P(!0,this.options.scrollbar,i),delete t.options.navigator,delete t.options.scrollbar)}let N=function(e,i){if(c().pushUnique(z,e)){let s=e.prototype;t=i,s.callbacks.push(Y),D(e,"afterAddSeries",I),D(e,"afterSetChartSize",L),D(e,"afterUpdate",W),D(e,"beforeRender",X),D(e,"beforeShowResetZoom",G),D(e,"update",U)}},{isTouchDevice:H}=c(),{addEvent:F,correctFloat:V,defined:_,isNumber:j,pick:Z}=c();function q(){this.navigatorAxis||(this.navigatorAxis=new $(this))}function K(t){let e,i=this.chart,s=i.options,o=s.navigator,a=this.navigatorAxis,r=i.zooming.pinchType,n=s.rangeSelector,l=i.zooming.type;if(this.isXAxis&&(o?.enabled||n?.enabled)){if("y"===l&&"zoom"===t.trigger)e=!1;else if(("zoom"===t.trigger&&"xy"===l||H&&"xy"===r)&&this.options.range){let e=a.previousZoom;_(t.min)?a.previousZoom=[this.min,this.max]:e&&(t.min=e[0],t.max=e[1],a.previousZoom=void 0)}}void 0!==e&&t.preventDefault()}class ${static compose(t){t.keepProps.includes("navigatorAxis")||(t.keepProps.push("navigatorAxis"),F(t,"init",q),F(t,"setExtremes",K))}constructor(t){this.axis=t}destroy(){this.axis=void 0}toFixedRange(t,e,i,s){let o=this.axis,a=(o.pointRange||0)/2,r=Z(i,o.translate(t,!0,!o.horiz)),n=Z(s,o.translate(e,!0,!o.horiz));return _(i)||(r=V(r+a)),_(s)||(n=V(n-a)),j(r)&&j(n)||(r=n=void 0),{min:r,max:n}}}let J=i.default.Color;var Q=d.n(J);let tt=i.default.SeriesRegistry;var te=d.n(tt);let{parse:ti}=Q(),{seriesTypes:ts}=te(),to={height:40,margin:22,maskInside:!0,handles:{width:7,borderRadius:0,height:15,symbols:["navigator-handle","navigator-handle"],enabled:!0,lineWidth:1,backgroundColor:"#f2f2f2",borderColor:"#999999"},maskFill:ti("#667aff").setOpacity(.3).get(),outlineColor:"#999999",outlineWidth:1,series:{type:void 0===ts.areaspline?"line":"areaspline",fillOpacity:.05,lineWidth:1,compare:null,sonification:{enabled:!1},dataGrouping:{approximation:"average",enabled:!0,groupPixelWidth:2,firstAnchor:"firstPoint",anchor:"middle",lastAnchor:"lastPoint",units:[["millisecond",[1,2,5,10,20,25,50,100,200,500]],["second",[1,2,5,10,15,30]],["minute",[1,2,5,10,15,30]],["hour",[1,2,3,4,6,8,12]],["day",[1,2,3,4]],["week",[1,2,3]],["month",[1,3,6]],["year",null]]},dataLabels:{enabled:!1,zIndex:2},id:"highcharts-navigator-series",className:"highcharts-navigator-series",lineColor:null,marker:{enabled:!1},threshold:null},xAxis:{className:"highcharts-navigator-xaxis",tickLength:0,lineWidth:0,gridLineColor:"#e6e6e6",id:"navigator-x-axis",gridLineWidth:1,tickPixelInterval:200,labels:{align:"left",style:{color:"#000000",fontSize:"0.7em",opacity:.6,textOutline:"2px contrast"},x:3,y:-4},crosshair:!1},yAxis:{className:"highcharts-navigator-yaxis",gridLineWidth:0,startOnTick:!1,endOnTick:!1,minPadding:.1,id:"navigator-y-axis",maxPadding:.1,labels:{enabled:!1},crosshair:!1,title:{text:void 0},tickLength:0,tickWidth:0}},{defined:ta,isNumber:tr,pick:tn}=c(),{relativeLength:tl}=c(),th={"navigator-handle":function(t,e,i,s,o={}){var a,r,n,l,h;let d=o.width?o.width/2:i,p=tl(o.borderRadius||0,Math.min(2*d,s));return[["M",-1.5,(s=o.height||s)/2-3.5],["L",-1.5,s/2+4.5],["M",.5,s/2-3.5],["L",.5,s/2+4.5],...(a=-d-1,r=.5,n=2*d+1,l=s,h={r:p},h?.r?function(t,e,i,s,o){let a=o?.r||0;return[["M",t+a,e],["L",t+i-a,e],["A",a,a,0,0,1,t+i,e+a],["L",t+i,e+s-a],["A",a,a,0,0,1,t+i-a,e+s],["L",t+a,e+s],["A",a,a,0,0,1,t,e+s-a],["L",t,e+a],["A",a,a,0,0,1,t+a,e],["Z"]]}(a,.5,n,l,h):[["M",a,r],["L",a+n,r],["L",a+n,r+l],["L",a,r+l],["Z"]])]}},td=i.default.RendererRegistry;var tp=d.n(td);let{defined:tc}=c(),tu={setFixedRange:function(t){let e=this.xAxis[0];tc(e.dataMax)&&tc(e.dataMin)&&t?this.fixedRange=Math.min(t,e.dataMax-e.dataMin):this.fixedRange=t}},{setOptions:tg}=c(),{composed:tm}=c(),{getRendererType:tx}=tp(),{setFixedRange:tf}=tu,{addEvent:tb,extend:tv,pushUnique:ty}=c();function tM(){this.chart.navigator&&!this.options.isInternal&&this.chart.navigator.setBaseSeries(null,!1)}let tA=function(t,e,i){$.compose(e),ty(tm,"Navigator")&&(t.prototype.setFixedRange=tf,tv(tx().prototype.symbols,th),tb(i,"afterUpdate",tM),tg({navigator:to}))},{composed:tw}=c(),{addEvent:tk,defined:tS,pick:tO,pushUnique:tE}=c();!function(t){let e;function i(t){let e=tO(t.options?.min,t.min),i=tO(t.options?.max,t.max);return{axisMin:e,axisMax:i,scrollMin:tS(t.dataMin)?Math.min(e,t.min,t.dataMin,tO(t.threshold,1/0)):e,scrollMax:tS(t.dataMax)?Math.max(i,t.max,t.dataMax,tO(t.threshold,-1/0)):i}}function s(){let t=this.scrollbar,e=t&&!t.options.opposite,i=this.horiz?2:e?3:1;t&&(this.chart.scrollbarsOffsets=[0,0],this.chart.axisOffset[i]+=t.size+(t.options.margin||0))}function o(){let t=this;t.options?.scrollbar?.enabled&&(t.options.scrollbar.vertical=!t.horiz,t.options.startOnTick=t.options.endOnTick=!1,t.scrollbar=new e(t.chart.renderer,t.options.scrollbar,t.chart),tk(t.scrollbar,"changed",function(e){let s,o,{axisMin:a,axisMax:r,scrollMin:n,scrollMax:l}=i(t),h=l-n;if(tS(a)&&tS(r)){if(t.horiz&&!t.reversed||!t.horiz&&t.reversed?(s=n+h*this.to,o=n+h*this.from):(s=n+h*(1-this.from),o=n+h*(1-this.to)),this.shouldUpdateExtremes(e.DOMType)){let i="mousemove"!==e.DOMType&&"touchmove"!==e.DOMType&&void 0;t.setExtremes(o,s,!0,i,e)}else this.setRange(this.from,this.to)}}))}function a(){let t,e,s,{scrollMin:o,scrollMax:a}=i(this),r=this.scrollbar,n=this.axisTitleMargin+(this.titleOffset||0),l=this.chart.scrollbarsOffsets,h=this.options.margin||0;if(r&&l){if(this.horiz)this.opposite||(l[1]+=n),r.position(this.left,this.top+this.height+2+l[1]-(this.opposite?h:0),this.width,this.height),this.opposite||(l[1]+=h),t=1;else{let e;this.opposite&&(l[0]+=n),e=r.options.opposite?this.left+this.width+2+l[0]-(this.opposite?0:h):this.opposite?0:h,r.position(e,this.top,this.width,this.height),this.opposite&&(l[0]+=h),t=0}if(l[t]+=r.size+(r.options.margin||0),isNaN(o)||isNaN(a)||!tS(this.min)||!tS(this.max)||this.dataMin===this.dataMax)r.setRange(0,1);else if(this.min===this.max){let t=this.pointRange/(this.dataMax+1);e=t*this.min,s=t*(this.max+1),r.setRange(e,s)}else e=(this.min-o)/(a-o),s=(this.max-o)/(a-o),this.horiz&&!this.reversed||!this.horiz&&this.reversed?r.setRange(e,s):r.setRange(1-s,1-e)}}t.compose=function(t,i){tE(tw,"Axis.Scrollbar")&&(e=i,tk(t,"afterGetOffset",s),tk(t,"afterInit",o),tk(t,"afterRender",a))}}(a||(a={}));let tC=a,tT={height:10,barBorderRadius:5,buttonBorderRadius:0,buttonsEnabled:!1,liveRedraw:void 0,margin:void 0,minWidth:6,opposite:!0,step:.2,zIndex:3,barBackgroundColor:"#cccccc",barBorderWidth:0,barBorderColor:"#cccccc",buttonArrowColor:"#333333",buttonBackgroundColor:"#e6e6e6",buttonBorderColor:"#cccccc",buttonBorderWidth:1,rifleColor:"none",trackBackgroundColor:"rgba(255, 255, 255, 0.001)",trackBorderColor:"#cccccc",trackBorderRadius:5,trackBorderWidth:1},{defaultOptions:tB}=c(),{addEvent:tD,correctFloat:tP,crisp:tR,defined:tz,destroyObjectProperties:tI,fireEvent:tL,merge:tW,pick:tX,removeEvent:tG}=c();class tY{static compose(t){tC.compose(t,tY)}static swapXY(t,e){return e&&t.forEach(t=>{let e,i=t.length;for(let s=0;s<i;s+=2)"number"==typeof(e=t[s+1])&&(t[s+1]=t[s+2],t[s+2]=e)}),t}constructor(t,e,i){this._events=[],this.chartX=0,this.chartY=0,this.from=0,this.scrollbarButtons=[],this.scrollbarLeft=0,this.scrollbarStrokeWidth=1,this.scrollbarTop=0,this.size=0,this.to=0,this.trackBorderWidth=1,this.x=0,this.y=0,this.init(t,e,i)}addEvents(){let t=this.options.inverted?[1,0]:[0,1],e=this.scrollbarButtons,i=this.scrollbarGroup.element,s=this.track.element,o=this.mouseDownHandler.bind(this),a=this.mouseMoveHandler.bind(this),r=this.mouseUpHandler.bind(this),n=[[e[t[0]].element,"click",this.buttonToMinClick.bind(this)],[e[t[1]].element,"click",this.buttonToMaxClick.bind(this)],[s,"click",this.trackClick.bind(this)],[i,"mousedown",o],[i.ownerDocument,"mousemove",a],[i.ownerDocument,"mouseup",r],[i,"touchstart",o],[i.ownerDocument,"touchmove",a],[i.ownerDocument,"touchend",r]];n.forEach(function(t){tD.apply(null,t)}),this._events=n}buttonToMaxClick(t){let e=(this.to-this.from)*tX(this.options.step,.2);this.updatePosition(this.from+e,this.to+e),tL(this,"changed",{from:this.from,to:this.to,trigger:"scrollbar",DOMEvent:t})}buttonToMinClick(t){let e=tP(this.to-this.from)*tX(this.options.step,.2);this.updatePosition(tP(this.from-e),tP(this.to-e)),tL(this,"changed",{from:this.from,to:this.to,trigger:"scrollbar",DOMEvent:t})}cursorToScrollbarPosition(t){let e=this.options,i=e.minWidth>this.calculatedWidth?e.minWidth:0;return{chartX:(t.chartX-this.x-this.xOffset)/(this.barWidth-i),chartY:(t.chartY-this.y-this.yOffset)/(this.barWidth-i)}}destroy(){let t=this,e=t.chart.scroller;t.removeEvents(),["track","scrollbarRifles","scrollbar","scrollbarGroup","group"].forEach(function(e){t[e]&&t[e].destroy&&(t[e]=t[e].destroy())}),e&&t===e.scrollbar&&(e.scrollbar=null,tI(e.scrollbarButtons))}drawScrollbarButton(t){let e=this.renderer,i=this.scrollbarButtons,s=this.options,o=this.size,a=e.g().add(this.group);if(i.push(a),s.buttonsEnabled){let r=e.rect().addClass("highcharts-scrollbar-button").add(a);this.chart.styledMode||r.attr({stroke:s.buttonBorderColor,"stroke-width":s.buttonBorderWidth,fill:s.buttonBackgroundColor}),r.attr(r.crisp({x:-.5,y:-.5,width:o,height:o,r:s.buttonBorderRadius},r.strokeWidth()));let n=e.path(tY.swapXY([["M",o/2+(t?-1:1),o/2-3],["L",o/2+(t?-1:1),o/2+3],["L",o/2+(t?2:-2),o/2]],s.vertical)).addClass("highcharts-scrollbar-arrow").add(i[t]);this.chart.styledMode||n.attr({fill:s.buttonArrowColor})}}init(t,e,i){this.scrollbarButtons=[],this.renderer=t,this.userOptions=e,this.options=tW(tT,tB.scrollbar,e),this.options.margin=tX(this.options.margin,10),this.chart=i,this.size=tX(this.options.size,this.options.height),e.enabled&&(this.render(),this.addEvents())}mouseDownHandler(t){let e=this.chart.pointer?.normalize(t)||t,i=this.cursorToScrollbarPosition(e);this.chartX=i.chartX,this.chartY=i.chartY,this.initPositions=[this.from,this.to],this.grabbedCenter=!0}mouseMoveHandler(t){let e,i=this.chart.pointer?.normalize(t)||t,s=this.options.vertical?"chartY":"chartX",o=this.initPositions||[];this.grabbedCenter&&(!t.touches||0!==t.touches[0][s])&&(e=this.cursorToScrollbarPosition(i)[s]-this[s],this.hasDragged=!0,this.updatePosition(o[0]+e,o[1]+e),this.hasDragged&&tL(this,"changed",{from:this.from,to:this.to,trigger:"scrollbar",DOMType:t.type,DOMEvent:t}))}mouseUpHandler(t){this.hasDragged&&tL(this,"changed",{from:this.from,to:this.to,trigger:"scrollbar",DOMType:t.type,DOMEvent:t}),this.grabbedCenter=this.hasDragged=this.chartX=this.chartY=null}position(t,e,i,s){let{buttonsEnabled:o,margin:a=0,vertical:r}=this.options,n=this.rendered?"animate":"attr",l=s,h=0;this.group.show(),this.x=t,this.y=e+this.trackBorderWidth,this.width=i,this.height=s,this.xOffset=l,this.yOffset=h,r?(this.width=this.yOffset=i=h=this.size,this.xOffset=l=0,this.yOffset=h=o?this.size:0,this.barWidth=s-(o?2*i:0),this.x=t+=a):(this.height=s=this.size,this.xOffset=l=o?this.size:0,this.barWidth=i-(o?2*s:0),this.y=this.y+a),this.group[n]({translateX:t,translateY:this.y}),this.track[n]({width:i,height:s}),this.scrollbarButtons[1][n]({translateX:r?0:i-l,translateY:r?s-h:0})}removeEvents(){this._events.forEach(function(t){tG.apply(null,t)}),this._events.length=0}render(){let t=this.renderer,e=this.options,i=this.size,s=this.chart.styledMode,o=t.g("scrollbar").attr({zIndex:e.zIndex}).hide().add();this.group=o,this.track=t.rect().addClass("highcharts-scrollbar-track").attr({r:e.trackBorderRadius||0,height:i,width:i}).add(o),s||this.track.attr({fill:e.trackBackgroundColor,stroke:e.trackBorderColor,"stroke-width":e.trackBorderWidth});let a=this.trackBorderWidth=this.track.strokeWidth();this.track.attr({x:-tR(0,a),y:-tR(0,a)}),this.scrollbarGroup=t.g().add(o),this.scrollbar=t.rect().addClass("highcharts-scrollbar-thumb").attr({height:i-a,width:i-a,r:e.barBorderRadius||0}).add(this.scrollbarGroup),this.scrollbarRifles=t.path(tY.swapXY([["M",-3,i/4],["L",-3,2*i/3],["M",0,i/4],["L",0,2*i/3],["M",3,i/4],["L",3,2*i/3]],e.vertical)).addClass("highcharts-scrollbar-rifles").add(this.scrollbarGroup),s||(this.scrollbar.attr({fill:e.barBackgroundColor,stroke:e.barBorderColor,"stroke-width":e.barBorderWidth}),this.scrollbarRifles.attr({stroke:e.rifleColor,"stroke-width":1})),this.scrollbarStrokeWidth=this.scrollbar.strokeWidth(),this.scrollbarGroup.translate(-tR(0,this.scrollbarStrokeWidth),-tR(0,this.scrollbarStrokeWidth)),this.drawScrollbarButton(0),this.drawScrollbarButton(1)}setRange(t,e){let i,s,o=this.options,a=o.vertical,r=o.minWidth,n=this.barWidth,l=!this.rendered||this.hasDragged||this.chart.navigator&&this.chart.navigator.hasDragged?"attr":"animate";if(!tz(n))return;let h=n*Math.min(e,1);i=Math.ceil(n*(t=Math.max(t,0))),this.calculatedWidth=s=tP(h-i),s<r&&(i=(n-r+s)*t,s=r);let d=Math.floor(i+this.xOffset+this.yOffset),p=s/2-.5;this.from=t,this.to=e,a?(this.scrollbarGroup[l]({translateY:d}),this.scrollbar[l]({height:s}),this.scrollbarRifles[l]({translateY:p}),this.scrollbarTop=d,this.scrollbarLeft=0):(this.scrollbarGroup[l]({translateX:d}),this.scrollbar[l]({width:s}),this.scrollbarRifles[l]({translateX:p}),this.scrollbarLeft=d,this.scrollbarTop=0),s<=12?this.scrollbarRifles.hide():this.scrollbarRifles.show(),!1===o.showFull&&(t<=0&&e>=1?this.group.hide():this.group.show()),this.rendered=!0}shouldUpdateExtremes(t){return tX(this.options.liveRedraw,c().svg&&!c().isTouchDevice&&!this.chart.boosted)||"mouseup"===t||"touchend"===t||!tz(t)}trackClick(t){let e=this.chart.pointer?.normalize(t)||t,i=this.to-this.from,s=this.y+this.scrollbarTop,o=this.x+this.scrollbarLeft;this.options.vertical&&e.chartY>s||!this.options.vertical&&e.chartX>o?this.updatePosition(this.from+i,this.to+i):this.updatePosition(this.from-i,this.to-i),tL(this,"changed",{from:this.from,to:this.to,trigger:"scrollbar",DOMEvent:t})}update(t){this.destroy(),this.init(this.chart.renderer,tW(!0,this.options,t),this.chart)}updatePosition(t,e){e>1&&(t=tP(1-tP(e-t)),e=1),t<0&&(e=tP(e-t),t=0),this.from=t,this.to=e}}tY.defaultOptions=tT,tB.scrollbar=tW(!0,tY.defaultOptions,tB.scrollbar);let tU=i.default.SVGRenderer;var tN=d.n(tU);let{defaultOptions:tH}=c(),{isTouchDevice:tF}=c(),{prototype:{symbols:tV}}=tN(),{addEvent:t_,clamp:tj,correctFloat:tZ,defined:tq,destroyObjectProperties:tK,erase:t$,extend:tJ,find:tQ,fireEvent:t0,isArray:t1,isNumber:t2,merge:t3,pick:t5,removeEvent:t6,splat:t9}=c();function t4(t,...e){let i=[].filter.call(e,t2);if(i.length)return Math[t].apply(0,i)}class t8{static compose(t,e,i){N(t,t8),tA(t,e,i)}constructor(t){this.isDirty=!1,this.scrollbarHeight=0,this.init(t)}drawHandle(t,e,i,s){let o=this.navigatorOptions.handles.height;this.handles[e][s](i?{translateX:Math.round(this.left+this.height/2),translateY:Math.round(this.top+parseInt(t,10)+.5-o)}:{translateX:Math.round(this.left+parseInt(t,10)),translateY:Math.round(this.top+this.height/2-o/2-1)})}drawOutline(t,e,i,s){let o=this.navigatorOptions.maskInside,a=this.outline.strokeWidth(),r=a/2,n=a%2/2,l=this.scrollButtonSize,h=this.size,d=this.top,p=this.height,c=d-r,u=d+p,g=this.left,m,x;i?(m=d+e+n,e=d+t+n,x=[["M",g+p,d-l-n],["L",g+p,m],["L",g,m],["M",g,e],["L",g+p,e],["L",g+p,d+h+l]],o&&x.push(["M",g+p,m-r],["L",g+p,e+r])):(g-=l,t+=g+l-n,e+=g+l-n,x=[["M",g,c],["L",t,c],["L",t,u],["M",e,u],["L",e,c],["L",g+h+2*l,c]],o&&x.push(["M",t-r,c],["L",e+r,c])),this.outline[s]({d:x})}drawMasks(t,e,i,s){let o,a,r,n,l=this.left,h=this.top,d=this.height;i?(r=[l,l,l],n=[h,h+t,h+e],a=[d,d,d],o=[t,e-t,this.size-e]):(r=[l,l+t,l+e],n=[h,h,h],a=[t,e-t,this.size-e],o=[d,d,d]),this.shades.forEach((t,e)=>{t[s]({x:r[e],y:n[e],width:a[e],height:o[e]})})}renderElements(){let t=this,e=t.navigatorOptions,i=e.maskInside,s=t.chart,o=s.inverted,a=s.renderer,r={cursor:o?"ns-resize":"ew-resize"},n=t.navigatorGroup??(t.navigatorGroup=a.g("navigator").attr({zIndex:8,visibility:"hidden"}).add());if([!i,i,!i].forEach((i,o)=>{let l=t.shades[o]??(t.shades[o]=a.rect().addClass("highcharts-navigator-mask"+(1===o?"-inside":"-outside")).add(n));s.styledMode||(l.attr({fill:i?e.maskFill:"rgba(0,0,0,0)"}),1===o&&l.css(r))}),t.outline||(t.outline=a.path().addClass("highcharts-navigator-outline").add(n)),s.styledMode||t.outline.attr({"stroke-width":e.outlineWidth,stroke:e.outlineColor}),e.handles?.enabled){let i=e.handles,{height:o,width:l}=i;[0,1].forEach(e=>{let h=i.symbols[e];if(t.handles[e]&&t.handles[e].symbolUrl===h){if(!t.handles[e].isImg&&t.handles[e].symbolName!==h){let i=tV[h].call(tV,-l/2-1,0,l,o);t.handles[e].attr({d:i}),t.handles[e].symbolName=h}}else t.handles[e]?.destroy(),t.handles[e]=a.symbol(h,-l/2-1,0,l,o,i),t.handles[e].attr({zIndex:7-e}).addClass("highcharts-navigator-handle highcharts-navigator-handle-"+["left","right"][e]).add(n),t.addMouseEvents();s.inverted&&t.handles[e].attr({rotation:90,rotationOriginX:Math.floor(-l/2),rotationOriginY:(o+l)/2}),s.styledMode||t.handles[e].attr({fill:i.backgroundColor,stroke:i.borderColor,"stroke-width":i.lineWidth,width:i.width,height:i.height,x:-l/2-1,y:0}).css(r)})}}update(t,e=!1){let i=this.chart,s=i.options.chart.inverted!==i.scrollbar?.options.vertical;if(t3(!0,i.options.navigator,t),this.navigatorOptions=i.options.navigator||{},this.setOpposite(),tq(t.enabled)||s)return this.destroy(),this.navigatorEnabled=t.enabled||this.navigatorEnabled,this.init(i);if(this.navigatorEnabled&&(this.isDirty=!0,!1===t.adaptToUpdatedData&&this.baseSeries.forEach(t=>{t6(t,"updatedData",this.updatedDataHandler)},this),t.adaptToUpdatedData&&this.baseSeries.forEach(t=>{t.eventsToUnbind.push(t_(t,"updatedData",this.updatedDataHandler))},this),(t.series||t.baseSeries)&&this.setBaseSeries(void 0,!1),t.height||t.xAxis||t.yAxis)){this.height=t.height??this.height;let e=this.getXAxisOffsets();this.xAxis.update({...t.xAxis,offsets:e,[i.inverted?"width":"height"]:this.height,[i.inverted?"height":"width"]:void 0},!1),this.yAxis.update({...t.yAxis,[i.inverted?"width":"height"]:this.height},!1)}e&&i.redraw()}render(t,e,i,s){let o=this.chart,a=this.xAxis,r=a.pointRange||0,n=a.navigatorAxis.fake?o.xAxis[0]:a,l=this.navigatorEnabled,h=this.rendered,d=o.inverted,p=o.xAxis[0].minRange,c=o.xAxis[0].options.maxRange,u=this.scrollButtonSize,g,m,x,f=this.scrollbarHeight,b,v;if(this.hasDragged&&!tq(i))return;if(this.isDirty&&this.renderElements(),t=tZ(t-r/2),e=tZ(e+r/2),!t2(t)||!t2(e)){if(!h)return;i=0,s=t5(a.width,n.width)}this.left=t5(a.left,o.plotLeft+u+(d?o.plotWidth:0));let y=this.size=b=t5(a.len,(d?o.plotHeight:o.plotWidth)-2*u);g=d?f:b+2*u,i=t5(i,a.toPixels(t,!0)),s=t5(s,a.toPixels(e,!0)),t2(i)&&Math.abs(i)!==1/0||(i=0,s=g);let M=a.toValue(i,!0),A=a.toValue(s,!0),w=Math.abs(tZ(A-M));w<p?this.grabbedLeft?i=a.toPixels(A-p-r,!0):this.grabbedRight&&(s=a.toPixels(M+p+r,!0)):tq(c)&&tZ(w-r)>c&&(this.grabbedLeft?i=a.toPixels(A-c-r,!0):this.grabbedRight&&(s=a.toPixels(M+c+r,!0))),this.zoomedMax=tj(Math.max(i,s),0,y),this.zoomedMin=tj(this.fixedWidth?this.zoomedMax-this.fixedWidth:Math.min(i,s),0,y),this.range=this.zoomedMax-this.zoomedMin,y=Math.round(this.zoomedMax);let k=Math.round(this.zoomedMin);l&&(this.navigatorGroup.attr({visibility:"inherit"}),v=h&&!this.hasDragged?"animate":"attr",this.drawMasks(k,y,d,v),this.drawOutline(k,y,d,v),this.navigatorOptions.handles.enabled&&(this.drawHandle(k,0,d,v),this.drawHandle(y,1,d,v))),this.scrollbar&&(d?(x=this.top-u,m=this.left-f+(l||!n.opposite?0:(n.titleOffset||0)+n.axisTitleMargin),f=b+2*u):(x=this.top+(l?this.height:-f),m=this.left-u),this.scrollbar.position(m,x,g,f),this.scrollbar.setRange(this.zoomedMin/(b||1),this.zoomedMax/(b||1))),this.rendered=!0,this.isDirty=!1,t0(this,"afterRender")}addMouseEvents(){let t=this,e=t.chart,i=e.container,s=[],o,a;t.mouseMoveHandler=o=function(e){t.onMouseMove(e)},t.mouseUpHandler=a=function(e){t.onMouseUp(e)},(s=t.getPartsEvents("mousedown")).push(t_(e.renderTo,"mousemove",o),t_(i.ownerDocument,"mouseup",a),t_(e.renderTo,"touchmove",o),t_(i.ownerDocument,"touchend",a)),s.concat(t.getPartsEvents("touchstart")),t.eventsToUnbind=s,t.series&&t.series[0]&&s.push(t_(t.series[0].xAxis,"foundExtremes",function(){e.navigator.modifyNavigatorAxisExtremes()}))}getPartsEvents(t){let e=this,i=[];return["shades","handles"].forEach(function(s){e[s].forEach(function(o,a){i.push(t_(o.element,t,function(t){e[s+"Mousedown"](t,a)}))})}),i}shadesMousedown(t,e){t=this.chart.pointer?.normalize(t)||t;let i=this.chart,s=this.xAxis,o=this.zoomedMin,a=this.size,r=this.range,n=this.left,l=t.chartX,h,d,p,c;i.inverted&&(l=t.chartY,n=this.top),1===e?(this.grabbedCenter=l,this.fixedWidth=r,this.dragOffset=l-o):(c=l-n-r/2,0===e?c=Math.max(0,c):2===e&&c+r>=a&&(c=a-r,this.reversedExtremes?(c-=r,d=this.getUnionExtremes().dataMin):h=this.getUnionExtremes().dataMax),c!==o&&(this.fixedWidth=r,tq((p=s.navigatorAxis.toFixedRange(c,c+r,d,h)).min)&&t0(this,"setRange",{min:Math.min(p.min,p.max),max:Math.max(p.min,p.max),redraw:!0,eventArguments:{trigger:"navigator"}})))}handlesMousedown(t,e){t=this.chart.pointer?.normalize(t)||t;let i=this.chart,s=i.xAxis[0],o=this.reversedExtremes;0===e?(this.grabbedLeft=!0,this.otherHandlePos=this.zoomedMax,this.fixedExtreme=o?s.min:s.max):(this.grabbedRight=!0,this.otherHandlePos=this.zoomedMin,this.fixedExtreme=o?s.max:s.min),i.setFixedRange(void 0)}onMouseMove(t){let e=this,i=e.chart,s=e.navigatorSize,o=e.range,a=e.dragOffset,r=i.inverted,n=e.left,l;(!t.touches||0!==t.touches[0].pageX)&&(l=(t=i.pointer?.normalize(t)||t).chartX,r&&(n=e.top,l=t.chartY),e.grabbedLeft?(e.hasDragged=!0,e.render(0,0,l-n,e.otherHandlePos)):e.grabbedRight?(e.hasDragged=!0,e.render(0,0,e.otherHandlePos,l-n)):e.grabbedCenter&&(e.hasDragged=!0,l<a?l=a:l>s+a-o&&(l=s+a-o),e.render(0,0,l-a,l-a+o)),e.hasDragged&&e.scrollbar&&t5(e.scrollbar.options.liveRedraw,!tF&&!this.chart.boosted)&&(t.DOMType=t.type,setTimeout(function(){e.onMouseUp(t)},0)))}onMouseUp(t){let e,i,s,o,a,r,n=this.chart,l=this.xAxis,h=this.scrollbar,d=t.DOMEvent||t,p=n.inverted,c=this.rendered&&!this.hasDragged?"animate":"attr";(this.hasDragged&&(!h||!h.hasDragged)||"scrollbar"===t.trigger)&&(s=this.getUnionExtremes(),this.zoomedMin===this.otherHandlePos?o=this.fixedExtreme:this.zoomedMax===this.otherHandlePos&&(a=this.fixedExtreme),this.zoomedMax===this.size&&(a=this.reversedExtremes?s.dataMin:s.dataMax),0===this.zoomedMin&&(o=this.reversedExtremes?s.dataMax:s.dataMin),tq((r=l.navigatorAxis.toFixedRange(this.zoomedMin,this.zoomedMax,o,a)).min)&&t0(this,"setRange",{min:Math.min(r.min,r.max),max:Math.max(r.min,r.max),redraw:!0,animation:!this.hasDragged&&null,eventArguments:{trigger:"navigator",triggerOp:"navigator-drag",DOMEvent:d}})),"mousemove"!==t.DOMType&&"touchmove"!==t.DOMType&&(this.grabbedLeft=this.grabbedRight=this.grabbedCenter=this.fixedWidth=this.fixedExtreme=this.otherHandlePos=this.hasDragged=this.dragOffset=null),this.navigatorEnabled&&t2(this.zoomedMin)&&t2(this.zoomedMax)&&(i=Math.round(this.zoomedMin),e=Math.round(this.zoomedMax),this.shades&&this.drawMasks(i,e,p,c),this.outline&&this.drawOutline(i,e,p,c),this.navigatorOptions.handles.enabled&&Object.keys(this.handles).length===this.handles.length&&(this.drawHandle(i,0,p,c),this.drawHandle(e,1,p,c)))}removeEvents(){this.eventsToUnbind&&(this.eventsToUnbind.forEach(function(t){t()}),this.eventsToUnbind=void 0),this.removeBaseSeriesEvents()}removeBaseSeriesEvents(){let t=this.baseSeries||[];this.navigatorEnabled&&t[0]&&(!1!==this.navigatorOptions.adaptToUpdatedData&&t.forEach(function(t){t6(t,"updatedData",this.updatedDataHandler)},this),t[0].xAxis&&t6(t[0].xAxis,"foundExtremes",this.modifyBaseAxisExtremes))}getXAxisOffsets(){return this.chart.inverted?[this.scrollButtonSize,0,-this.scrollButtonSize,0]:[0,-this.scrollButtonSize,0,this.scrollButtonSize]}init(t){let e=t.options,i=e.navigator||{},s=i.enabled,o=e.scrollbar||{},a=o.enabled,r=s&&i.height||0,n=a&&o.height||0,l=o.buttonsEnabled&&n||0;this.handles=[],this.shades=[],this.chart=t,this.setBaseSeries(),this.height=r,this.scrollbarHeight=n,this.scrollButtonSize=l,this.scrollbarEnabled=a,this.navigatorEnabled=s,this.navigatorOptions=i,this.scrollbarOptions=o,this.setOpposite();let h=this,d=h.baseSeries,p=t.xAxis.length,c=t.yAxis.length,u=d&&d[0]&&d[0].xAxis||t.xAxis[0]||{options:{}};if(t.isDirtyBox=!0,h.navigatorEnabled){let e=this.getXAxisOffsets();h.xAxis=new(g())(t,t3({breaks:u.options.breaks,ordinal:u.options.ordinal,overscroll:u.options.overscroll},i.xAxis,{type:"datetime",yAxis:i.yAxis?.id,index:p,isInternal:!0,offset:0,keepOrdinalPadding:!0,startOnTick:!1,endOnTick:!1,minPadding:u.options.ordinal?0:u.options.minPadding,maxPadding:u.options.ordinal?0:u.options.maxPadding,zoomEnabled:!1},t.inverted?{offsets:e,width:r}:{offsets:e,height:r}),"xAxis"),h.yAxis=new(g())(t,t3(i.yAxis,{alignTicks:!1,offset:0,index:c,isInternal:!0,reversed:t5(i.yAxis&&i.yAxis.reversed,t.yAxis[0]&&t.yAxis[0].reversed,!1),zoomEnabled:!1},t.inverted?{width:r}:{height:r}),"yAxis"),d||i.series.data?h.updateNavigatorSeries(!1):0===t.series.length&&(h.unbindRedraw=t_(t,"beforeRedraw",function(){t.series.length>0&&!h.series&&(h.setBaseSeries(),h.unbindRedraw())})),h.reversedExtremes=t.inverted&&!h.xAxis.reversed||!t.inverted&&h.xAxis.reversed,h.renderElements(),h.addMouseEvents()}else h.xAxis={chart:t,navigatorAxis:{fake:!0},translate:function(e,i){let s=t.xAxis[0],o=s.getExtremes(),a=s.len-2*l,r=t4("min",s.options.min,o.dataMin),n=t4("max",s.options.max,o.dataMax)-r;return i?e*n/a+r:a*(e-r)/n},toPixels:function(t){return this.translate(t)},toValue:function(t){return this.translate(t,!0)}},h.xAxis.navigatorAxis.axis=h.xAxis,h.xAxis.navigatorAxis.toFixedRange=$.prototype.toFixedRange.bind(h.xAxis.navigatorAxis);if(t.options.scrollbar?.enabled){let e=t3(t.options.scrollbar,{vertical:t.inverted});t2(e.margin)||(e.margin=t.inverted?-3:3),t.scrollbar=h.scrollbar=new tY(t.renderer,e,t),t_(h.scrollbar,"changed",function(t){let e=h.size,i=e*this.to,s=e*this.from;h.hasDragged=h.scrollbar.hasDragged,h.render(0,0,s,i),this.shouldUpdateExtremes(t.DOMType)&&setTimeout(function(){h.onMouseUp(t)})})}h.addBaseSeriesEvents(),h.addChartEvents()}setOpposite(){let t=this.navigatorOptions,e=this.navigatorEnabled,i=this.chart;this.opposite=t5(t.opposite,!!(!e&&i.inverted))}getUnionExtremes(t){let e,i=this.chart.xAxis[0],s=this.chart.time,o=this.xAxis,a=o.options,r=i.options;return t&&null===i.dataMin||(e={dataMin:t5(s.parse(a?.min),t4("min",s.parse(r.min),i.dataMin,o.dataMin,o.min)),dataMax:t5(s.parse(a?.max),t4("max",s.parse(r.max),i.dataMax,o.dataMax,o.max))}),e}setBaseSeries(t,e){let i=this.chart,s=this.baseSeries=[];t=t||i.options&&i.options.navigator.baseSeries||(i.series.length?tQ(i.series,t=>!t.options.isInternal).index:0),(i.series||[]).forEach((e,i)=>{!e.options.isInternal&&(e.options.showInNavigator||(i===t||e.options.id===t)&&!1!==e.options.showInNavigator)&&s.push(e)}),this.xAxis&&!this.xAxis.navigatorAxis.fake&&this.updateNavigatorSeries(!0,e)}updateNavigatorSeries(t,e){let i=this,s=i.chart,o=i.baseSeries,a={enableMouseTracking:!1,index:null,linkedTo:null,group:"nav",padXAxis:!1,xAxis:this.navigatorOptions.xAxis?.id,yAxis:this.navigatorOptions.yAxis?.id,showInLegend:!1,stacking:void 0,isInternal:!0,states:{inactive:{opacity:1}}},r=i.series=(i.series||[]).filter(t=>{let e=t.baseSeries;return!(0>o.indexOf(e))||(e&&(t6(e,"updatedData",i.updatedDataHandler),delete e.navigatorSeries),t.chart&&t.destroy(),!1)}),n,l,h=i.navigatorOptions.series,d;o&&o.length&&o.forEach(t=>{let p=t.navigatorSeries,c=tJ({color:t.color,visible:t.visible},t1(h)?tH.navigator.series:h);if(p&&!1===i.navigatorOptions.adaptToUpdatedData)return;a.name="Navigator "+o.length,d=(n=t.options||{}).navigatorOptions||{},c.dataLabels=t9(c.dataLabels),(l=t3(n,a,c,d)).pointRange=t5(c.pointRange,d.pointRange,tH.plotOptions[l.type||"line"].pointRange);let u=d.data||c.data;i.hasNavigatorData=i.hasNavigatorData||!!u,l.data=u||n.data?.slice(0),p&&p.options?p.update(l,e):(t.navigatorSeries=s.initSeries(l),s.setSortedData(),t.navigatorSeries.baseSeries=t,r.push(t.navigatorSeries))}),(h.data&&!(o&&o.length)||t1(h))&&(i.hasNavigatorData=!1,(h=t9(h)).forEach((t,e)=>{a.name="Navigator "+(r.length+1),(l=t3(tH.navigator.series,{color:s.series[e]&&!s.series[e].options.isInternal&&s.series[e].color||s.options.colors[e]||s.options.colors[0]},a,t)).data=t.data,l.data&&(i.hasNavigatorData=!0,r.push(s.initSeries(l)))})),t&&this.addBaseSeriesEvents()}addBaseSeriesEvents(){let t=this,e=t.baseSeries||[];e[0]&&e[0].xAxis&&e[0].eventsToUnbind.push(t_(e[0].xAxis,"foundExtremes",this.modifyBaseAxisExtremes)),e.forEach(i=>{i.eventsToUnbind.push(t_(i,"show",function(){this.navigatorSeries&&this.navigatorSeries.setVisible(!0,!1)})),i.eventsToUnbind.push(t_(i,"hide",function(){this.navigatorSeries&&this.navigatorSeries.setVisible(!1,!1)})),!1!==this.navigatorOptions.adaptToUpdatedData&&i.xAxis&&i.eventsToUnbind.push(t_(i,"updatedData",this.updatedDataHandler)),i.eventsToUnbind.push(t_(i,"remove",function(){e&&t$(e,i),this.navigatorSeries&&t.series&&(t$(t.series,this.navigatorSeries),tq(this.navigatorSeries.options)&&this.navigatorSeries.remove(!1),delete this.navigatorSeries)}))})}getBaseSeriesMin(t){return this.baseSeries.reduce(function(t,e){return Math.min(t,e.getColumn("x")[0]??t)},t)}modifyNavigatorAxisExtremes(){let t=this.xAxis;if(void 0!==t.getExtremes){let e=this.getUnionExtremes(!0);e&&(e.dataMin!==t.min||e.dataMax!==t.max)&&(t.min=e.dataMin,t.max=e.dataMax)}}modifyBaseAxisExtremes(){let t,e,i=this.chart.navigator,s=this.getExtremes(),o=s.min,a=s.max,r=s.dataMin,n=s.dataMax,l=a-o,h=i.stickToMin,d=i.stickToMax,p=t5(this.ordinal?.convertOverscroll(this.options.overscroll),0),c=i.series&&i.series[0],u=!!this.setExtremes;!(this.eventArgs&&"rangeSelectorButton"===this.eventArgs.trigger)&&(h&&(t=(e=r)+l),d&&(t=n+p,h||(e=Math.max(r,t-l,i.getBaseSeriesMin(c&&c.xData?c.xData[0]:-Number.MAX_VALUE)))),u&&(h||d)&&t2(e)&&(this.min=this.userMin=e,this.max=this.userMax=t)),i.stickToMin=i.stickToMax=null}updatedDataHandler(){let t=this.chart.navigator,e=this.navigatorSeries,i=t.reversedExtremes?0===Math.round(t.zoomedMin):Math.round(t.zoomedMax)>=Math.round(t.size);t.stickToMax=t5(this.chart.options.navigator&&this.chart.options.navigator.stickToMax,i),t.stickToMin=t.shouldStickToMin(this,t),e&&!t.hasNavigatorData&&(e.options.pointStart=this.getColumn("x")[0],e.setData(this.options.data,!1,null,!1))}shouldStickToMin(t,e){let i=e.getBaseSeriesMin(t.getColumn("x")[0]),s=t.xAxis,o=s.max,a=s.min,r=s.options.range,n=!0;return!!(t2(o)&&t2(a))&&(r&&o-i>0?o-i<r:a<=i)}addChartEvents(){this.eventsToUnbind||(this.eventsToUnbind=[]),this.eventsToUnbind.push(t_(this.chart,"redraw",function(){let t=this.navigator,e=t&&(t.baseSeries&&t.baseSeries[0]&&t.baseSeries[0].xAxis||this.xAxis[0]);e&&t.render(e.min,e.max)}),t_(this.chart,"getMargins",function(){let t=this.navigator,e=t.opposite?"plotTop":"marginBottom";this.inverted&&(e=t.opposite?"marginRight":"plotLeft"),this[e]=(this[e]||0)+(t.navigatorEnabled||!this.inverted?t.height+(this.scrollbar?.options.margin||0)+t.scrollbarHeight:0)+(t.navigatorOptions.margin||0)}),t_(t8,"setRange",function(t){this.chart.xAxis[0].setExtremes(t.min,t.max,t.redraw,t.animation,t.eventArguments)}))}destroy(){this.removeEvents(),this.xAxis&&(t$(this.chart.xAxis,this.xAxis),t$(this.chart.axes,this.xAxis)),this.yAxis&&(t$(this.chart.yAxis,this.yAxis),t$(this.chart.axes,this.yAxis)),(this.series||[]).forEach(t=>{t.destroy&&t.destroy()}),["series","xAxis","yAxis","shades","outline","scrollbarTrack","scrollbarRifles","scrollbarGroup","scrollbar","navigatorGroup","rendered"].forEach(t=>{this[t]&&this[t].destroy&&this[t].destroy(),this[t]=null}),[this.handles].forEach(t=>{tK(t)}),this.baseSeries.forEach(t=>{t.navigatorSeries=void 0}),this.navigatorEnabled=!1}}(s=r||(r={})).setLength=function(t,e,i){return Array.isArray(t)?(t.length=e,t):t[i?"subarray":"slice"](0,e)},s.splice=function(t,e,i,s,o=[]){if(Array.isArray(t))return Array.isArray(o)||(o=Array.from(o)),{removed:t.splice(e,i,...o),array:t};let a=Object.getPrototypeOf(t).constructor,r=t[s?"subarray":"slice"](e,e+i),n=new a(t.length-i+o.length);return n.set(t.subarray(0,e),0),n.set(o,e),n.set(t.subarray(e+i),e+o.length),{removed:r,array:n}};let{setLength:t7,splice:et}=r,{fireEvent:ee,objectEach:ei,uniqueKey:es}=c(),eo=class{constructor(t={}){this.autoId=!t.id,this.columns={},this.id=t.id||es(),this.modified=this,this.rowCount=0,this.versionTag=es();let e=0;ei(t.columns||{},(t,i)=>{this.columns[i]=t.slice(),e=Math.max(e,t.length)}),this.applyRowCount(e)}applyRowCount(t){this.rowCount=t,ei(this.columns,(e,i)=>{e.length!==t&&(this.columns[i]=t7(e,t))})}deleteRows(t,e=1){if(e>0&&t<this.rowCount){let i=0;ei(this.columns,(s,o)=>{this.columns[o]=et(s,t,e).array,i=s.length}),this.rowCount=i}ee(this,"afterDeleteRows",{rowIndex:t,rowCount:e}),this.versionTag=es()}getColumn(t,e){return this.columns[t]}getColumns(t,e){return(t||Object.keys(this.columns)).reduce((t,e)=>(t[e]=this.columns[e],t),{})}getRow(t,e){return(e||Object.keys(this.columns)).map(e=>this.columns[e]?.[t])}setColumn(t,e=[],i=0,s){this.setColumns({[t]:e},i,s)}setColumns(t,e,i){let s=this.rowCount;ei(t,(t,e)=>{this.columns[e]=t.slice(),s=t.length}),this.applyRowCount(s),i?.silent||(ee(this,"afterSetColumns"),this.versionTag=es())}setRow(t,e=this.rowCount,i,s){let{columns:o}=this,a=i?this.rowCount+1:e+1;ei(t,(t,r)=>{let n=o[r]||s?.addColumns!==!1&&Array(a);n&&(i?n=et(n,e,0,!0,[t]).array:n[e]=t,o[r]=n)}),a>this.rowCount&&this.applyRowCount(a),s?.silent||(ee(this,"afterSetRows"),this.versionTag=es())}},{addEvent:ea,correctFloat:er,css:en,defined:el,error:eh,isNumber:ed,pick:ep,timeUnits:ec,isString:eu}=c();!function(t){function e(t,i,s,o,a=[],r=0,n){let l={},h=this.options.tickPixelInterval,d=this.chart.time,p=[],c,u,g,m,x,f=0,b=[],v=-Number.MAX_VALUE;if(!this.options.ordinal&&!this.options.breaks||!a||a.length<3||void 0===i)return d.getTimeTicks.apply(d,arguments);let y=a.length;for(c=0;c<y;c++){if(x=c&&a[c-1]>s,a[c]<i&&(f=c),c===y-1||a[c+1]-a[c]>5*r||x){if(a[c]>v){for(u=d.getTimeTicks(t,a[f],a[c],o);u.length&&u[0]<=v;)u.shift();u.length&&(v=u[u.length-1]),p.push(b.length),b=b.concat(u)}f=c+1}if(x)break}if(u){if(m=u.info,n&&m.unitRange<=ec.hour){for(f=1,c=b.length-1;f<c;f++)d.dateFormat("%d",b[f])!==d.dateFormat("%d",b[f-1])&&(l[b[f]]="day",g=!0);g&&(l[b[0]]="day"),m.higherRanks=l}m.segmentStarts=p,b.info=m}else eh(12,!1,this.chart);if(n&&el(h)){let t=b.length,e=[],i=[],o,a,r,n,d,p=t;for(;p--;)a=this.translate(b[p]),r&&(i[p]=r-a),e[p]=r=a;for(i.sort((t,e)=>t-e),(n=i[Math.floor(i.length/2)])<.6*h&&(n=null),p=b[t-1]>s?t-1:t,r=void 0;p--;)d=Math.abs(r-(a=e[p])),r&&d<.8*h&&(null===n||d<.8*n)?(l[b[p]]&&!l[b[p+1]]?(o=p+1,r=a):o=p,b.splice(o,1)):r=a}return b}function i(t){let e=this.ordinal.positions;if(!e)return t;let i=e.length-1,s;return(t<0?t=e[0]:t>i?t=e[i]:(i=Math.floor(t),s=t-i),void 0!==s&&void 0!==e[i])?e[i]+(s?s*(e[i+1]-e[i]):0):t}function s(t){let e=this.ordinal,i=this.old?this.old.min:this.min,s=this.old?this.old.transA:this.transA,o=e.getExtendedPositions();if(o?.length){let a=er((t-i)*s+this.minPixelPadding),r=er(e.getIndexOfPoint(a,o)),n=er(r%1);if(r>=0&&r<=o.length-1){let t=o[Math.floor(r)],e=o[Math.ceil(r)];return o[Math.floor(r)]+n*(e-t)}}return t}function o(e,i){let s=t.Additions.findIndexOf(e,i,!0);if(e[s]===i)return s;let o=(i-e[s])/(e[s+1]-e[s]);return s+o}function a(){this.ordinal||(this.ordinal=new t.Additions(this))}function r(){let{eventArgs:t,options:e}=this;if(this.isXAxis&&el(e.overscroll)&&0!==e.overscroll&&ed(this.max)&&ed(this.min)&&(this.options.ordinal&&!this.ordinal.originalOrdinalRange&&this.ordinal.getExtendedPositions(!1),this.max===this.dataMax&&(t?.trigger!=="pan"||this.isInternal)&&t?.trigger!=="navigator")){let i=this.ordinal.convertOverscroll(e.overscroll);this.max+=i,!this.isInternal&&el(this.userMin)&&t?.trigger!=="mousewheel"&&(this.min+=i)}}function n(){this.horiz&&!this.isDirty&&(this.isDirty=this.isOrdinal&&this.chart.navigator&&!this.chart.navigator.adaptToUpdatedData)}function l(){this.ordinal&&(this.ordinal.beforeSetTickPositions(),this.tickInterval=this.ordinal.postProcessTickInterval(this.tickInterval))}function h(t){let e=this.xAxis[0],i=e.ordinal.convertOverscroll(e.options.overscroll),s=t.originalEvent.chartX,o=this.options.chart.panning,a=!1;if(o&&"y"!==o.type&&e.options.ordinal&&e.series.length&&(!t.touches||t.touches.length<=1)){let t,o,r=this.mouseDownX,n=e.getExtremes(),l=n.dataMin,h=n.dataMax,d=n.min,p=n.max,c=this.hoverPoints,u=e.closestPointRange||e.ordinal?.overscrollPointsRange,g=Math.round((r-s)/(e.translationSlope*(e.ordinal.slope||u))),m=e.ordinal.getExtendedPositions(),x={ordinal:{positions:m,extendedOrdinalPositions:m}},f=e.index2val,b=e.val2lin;if(d<=l&&g<0||p+i>=h&&g>0)return;x.ordinal.positions?Math.abs(g)>1&&(c&&c.forEach(function(t){t.setState()}),h>(o=x.ordinal.positions)[o.length-1]&&o.push(h),this.setFixedRange(p-d),(t=e.navigatorAxis.toFixedRange(void 0,void 0,f.apply(x,[b.apply(x,[d,!0])+g]),f.apply(x,[b.apply(x,[p,!0])+g]))).min>=Math.min(o[0],d)&&t.max<=Math.max(o[o.length-1],p)+i&&e.setExtremes(t.min,t.max,!0,!1,{trigger:"pan"}),this.mouseDownX=s,en(this.container,{cursor:"move"})):a=!0}else a=!0;a||o&&/y/.test(o.type)?i&&(e.max=e.dataMax+i):t.preventDefault()}function d(){let t=this.xAxis;t?.options.ordinal&&(delete t.ordinal.index,delete t.ordinal.originalOrdinalRange)}function p(t,e){let i,s=this.ordinal,a=s.positions,r=s.slope,n;if(!a)return t;let l=a.length;if(a[0]<=t&&a[l-1]>=t)i=o(a,t);else{if(n=s.getExtendedPositions?.(),!n?.length)return t;let l=n.length;r||(r=(n[l-1]-n[0])/l);let h=o(n,a[0]);if(t>=n[0]&&t<=n[l-1])i=o(n,t)-h;else{if(!e)return t;i=t<n[0]?-h-(n[0]-t)/r:(t-n[l-1])/r+l-h}}return e?i:r*(i||0)+s.offset}t.compose=function(t,o,c){let u=t.prototype;return u.ordinal2lin||(u.getTimeTicks=e,u.index2val=i,u.lin2val=s,u.val2lin=p,u.ordinal2lin=u.val2lin,ea(t,"afterInit",a),ea(t,"foundExtremes",r),ea(t,"afterSetScale",n),ea(t,"initialAxisTranslation",l),ea(c,"pan",h),ea(c,"touchpan",h),ea(o,"updatedData",d)),t},t.Additions=class{constructor(t){this.index={},this.axis=t}beforeSetTickPositions(){let t=this.axis,e=t.ordinal,i=t.getExtremes(),s=i.min,o=i.max,a=t.brokenAxis?.hasBreaks,r=t.options.ordinal,n,l,h,d,p,c,u,g=[],m=Number.MAX_VALUE,x=!1,f=!1,b=!1;if(r||a){let i=0;if(t.series.forEach(function(t,e){let s=t.getColumn("x",!0);if(l=[],e>0&&"highcharts-navigator-series"!==t.options.id&&s.length>1&&(f=i!==s[1]-s[0]),i=s[1]-s[0],t.boosted&&(b=t.boosted),t.reserveSpace()&&(!1!==t.takeOrdinalPosition||a)&&(n=(g=g.concat(s)).length,g.sort(function(t,e){return t-e}),m=Math.min(m,ep(t.closestPointRange,m)),n)){for(e=0;e<n-1;)g[e]!==g[e+1]&&l.push(g[e+1]),e++;l[0]!==g[0]&&l.unshift(g[0]),g=l}}),t.ordinal.originalOrdinalRange||(t.ordinal.originalOrdinalRange=(g.length-1)*m),f&&b&&(g.pop(),g.shift()),(n=g.length)>2){for(h=g[1]-g[0],u=n-1;u--&&!x;)g[u+1]-g[u]!==h&&(x=!0);!t.options.keepOrdinalPadding&&(g[0]-s>h||o-g[g.length-1]>h)&&(x=!0)}else t.options.overscroll&&(2===n?m=g[1]-g[0]:1===n?(m=t.ordinal.convertOverscroll(t.options.overscroll),g=[g[0],g[0]+m]):m=e.overscrollPointsRange);x||t.forceOrdinal?(t.options.overscroll&&(e.overscrollPointsRange=m,g=g.concat(e.getOverscrollPositions())),e.positions=g,d=t.ordinal2lin(Math.max(s,g[0]),!0),p=Math.max(t.ordinal2lin(Math.min(o,g[g.length-1]),!0),1),e.slope=c=(o-s)/(p-d),e.offset=s-d*c):(e.overscrollPointsRange=ep(t.closestPointRange,e.overscrollPointsRange),e.positions=t.ordinal.slope=e.offset=void 0)}t.isOrdinal=r&&x,e.groupIntervalFactor=null}static findIndexOf(t,e,i){let s=0,o=t.length-1,a;for(;s<o;)t[a=Math.ceil((s+o)/2)]<=e?s=a:o=a-1;return t[s]===e?s:i?s:-1}getExtendedPositions(t=!0){let e=this,i=e.axis,s=i.constructor.prototype,o=i.chart,a=i.series.reduce((t,e)=>{let i=e.currentDataGrouping;return t+(i?i.count+i.unitName:"raw")},""),r=t?i.ordinal.convertOverscroll(i.options.overscroll):0,n=i.getExtremes(),l,h,d=e.index;return d||(d=e.index={}),!d[a]&&((l={series:[],chart:o,forceOrdinal:!1,getExtremes:function(){return{min:n.dataMin,max:n.dataMax+r}},applyGrouping:s.applyGrouping,getGroupPixelWidth:s.getGroupPixelWidth,getTimeTicks:s.getTimeTicks,options:{ordinal:!0},ordinal:{getGroupIntervalFactor:this.getGroupIntervalFactor},ordinal2lin:s.ordinal2lin,getIndexOfPoint:s.getIndexOfPoint,val2lin:s.val2lin}).ordinal.axis=l,i.series.forEach(i=>{h={xAxis:l,chart:o,groupPixelWidth:i.groupPixelWidth,destroyGroupedData:c().noop,getColumn:i.getColumn,applyGrouping:i.applyGrouping,getProcessedData:i.getProcessedData,reserveSpace:i.reserveSpace,visible:i.visible};let s=i.getColumn("x").concat(t?e.getOverscrollPositions():[]);h.dataTable=new eo({columns:{x:s}}),h.options={...i.options,dataGrouping:i.currentDataGrouping?{firstAnchor:i.options.dataGrouping?.firstAnchor,anchor:i.options.dataGrouping?.anchor,lastAnchor:i.options.dataGrouping?.firstAnchor,enabled:!0,forced:!0,approximation:"open",units:[[i.currentDataGrouping.unitName,[i.currentDataGrouping.count]]]}:{enabled:!1}},l.series.push(h),i.processData.apply(h)}),l.applyGrouping({hasExtremesChanged:!0}),h?.closestPointRange!==h?.basePointRange&&h.currentDataGrouping&&(l.forceOrdinal=!0),i.ordinal.beforeSetTickPositions.apply({axis:l}),!i.ordinal.originalOrdinalRange&&l.ordinal.originalOrdinalRange&&(i.ordinal.originalOrdinalRange=l.ordinal.originalOrdinalRange),l.ordinal.positions&&(d[a]=l.ordinal.positions)),d[a]}getGroupIntervalFactor(t,e,i){let s=i.getColumn("x",!0),o=s.length,a=[],r,n,l=this.groupIntervalFactor;if(!l){for(n=0;n<o-1;n++)a[n]=s[n+1]-s[n];a.sort(function(t,e){return t-e}),r=a[Math.floor(o/2)],t=Math.max(t,s[0]),e=Math.min(e,s[o-1]),this.groupIntervalFactor=l=o*r/(e-t)}return l}getIndexOfPoint(t,e){let i=this.axis,s=i.min,a=i.minPixelPadding;return o(e,s)+er((t-a)/(i.translationSlope*(this.slope||i.closestPointRange||this.overscrollPointsRange)))}getOverscrollPositions(){let t=this.axis,e=this.convertOverscroll(t.options.overscroll),i=this.overscrollPointsRange,s=[],o=t.dataMax;if(el(i))for(;o<t.dataMax+e;)s.push(o+=i);return s}postProcessTickInterval(t){let e,i=this.axis,s=this.slope,o=i.closestPointRange;return s&&o?i.options.breaks?o||t:t/(s/o):t}convertOverscroll(t=0){let e=this,i=e.axis,s=function(t){return ep(e.originalOrdinalRange,el(i.dataMax)&&el(i.dataMin)?i.dataMax-i.dataMin:0)*t};if(eu(t)){let e,o=parseInt(t,10);if(el(i.min)&&el(i.max)&&el(i.dataMin)&&el(i.dataMax)&&!(e=i.max-i.min==i.dataMax-i.dataMin)&&(this.originalOrdinalRange=i.max-i.min),/%$/.test(t))return s(o/100);if(/px/.test(t)){let t=Math.min(o,.9*i.len)/i.len;return s(t/(e?1-t:1))}return 0}return t}}}(n||(n={}));let eg=n,em={lang:{rangeSelectorZoom:"Zoom",rangeSelectorFrom:"",rangeSelectorTo:"→",rangeSelector:{allText:"All",allTitle:"View all",monthText:"{count}m",monthTitle:"View {count} {#eq count 1}month{else}months{/eq}",yearText:"{count}y",yearTitle:"View {count} {#eq count 1}year{else}years{/eq}",ytdText:"YTD",ytdTitle:"View year to date"}},rangeSelector:{allButtonsEnabled:!1,buttons:[{type:"month",count:1},{type:"month",count:3},{type:"month",count:6},{type:"ytd"},{type:"year",count:1},{type:"all"}],buttonSpacing:5,dropdown:"responsive",enabled:void 0,verticalAlign:"top",buttonTheme:{width:28,height:18,padding:2,zIndex:7},floating:!1,x:0,y:0,height:void 0,inputBoxBorderColor:"none",inputBoxHeight:17,inputBoxWidth:void 0,inputDateFormat:"%[ebY]",inputDateParser:void 0,inputEditDateFormat:"%Y-%m-%d",inputEnabled:!0,inputPosition:{align:"right",x:0,y:0},inputSpacing:5,selected:void 0,buttonPosition:{align:"left",x:0,y:0},inputStyle:{color:"#334eff",cursor:"pointer",fontSize:"0.8em"},labelStyle:{color:"#666666",fontSize:"0.8em"}}},{defaultOptions:ex}=c(),{composed:ef}=c(),{addEvent:eb,defined:ev,extend:ey,isNumber:eM,merge:eA,pick:ew,pushUnique:ek}=c(),eS=[];function eO(){let t,e,i=this.range,s=i.type,o=this.max,a=this.chart.time,r=function(t,e){let i=a.toParts(t),o=i.slice();"year"===s?o[0]+=e:o[1]+=e;let r=a.makeTime.apply(a,o),n=a.toParts(r);return"month"===s&&i[1]===n[1]&&1===Math.abs(e)&&(o[0]=i[0],o[1]=i[1],o[2]=0),(r=a.makeTime.apply(a,o))-t};eM(i)?(t=o-i,e=i):i&&(t=o+r(o,-(i.count||1)),this.chart&&this.chart.setFixedRange(o-t));let n=ew(this.dataMin,Number.MIN_VALUE);return eM(t)||(t=n),t<=n&&(t=n,void 0===e&&(e=r(t,i.count)),this.newMax=Math.min(t+e,ew(this.dataMax,Number.MAX_VALUE))),eM(o)?!eM(i)&&i&&i._offsetMin&&(t+=i._offsetMin):t=void 0,t}function eE(){this.rangeSelector?.redrawElements()}function eC(){this.options.rangeSelector&&this.options.rangeSelector.enabled&&(this.rangeSelector=new e(this))}function eT(){let t=this.rangeSelector;if(t){eM(t.deferredYTDClick)&&(t.clickButton(t.deferredYTDClick),delete t.deferredYTDClick);let e=t.options.verticalAlign;t.options.floating||("bottom"===e?this.extraBottomMargin=!0:"top"!==e||(this.extraTopMargin=!0))}}function eB(){let t,e=this.rangeSelector;if(!e)return;let i=this.xAxis[0].getExtremes(),s=this.legend,o=e&&e.options.verticalAlign;eM(i.min)&&e.render(i.min,i.max),s.display&&"top"===o&&o=