g&&!1!==k.enabled?(this.clipHeight=E=Math.max(g-20-this.titleHeight-\nh,0),this.currentPage=C(this.currentPage,1),this.fullHeight=b,t.forEach(function(b,a){var c=b._legendItemPos[1],d=Math.round(b.legendItem.getBBox().height),e=r.length;if(!e||c-r[e-1]>E&&(B||c)!==r[e-1])r.push(B||c),e++;b.pageIx=e-1;B&&(t[a-1].pageIx=e-1);a===t.length-1&&c+d-r[e-1]>E&&d<=E&&(r.push(c),b.pageIx=e);c!==B&&(B=c)}),v||(v=a.clipRect=d.clipRect(0,h,9999,0),a.contentGroup.clip(v)),q(E),N||(this.nav=N=d.g().attr({zIndex:1}).add(this.group),this.up=d.symbol(\"triangle\",0,0,n,n).add(N),w(\"upTracker\").on(\"click\",\nfunction(){a.scroll(-1,p)}),this.pager=d.text(\"\",15,10).addClass(\"highcharts-legend-navigation\"),c.styledMode||this.pager.css(k.style),this.pager.add(N),this.down=d.symbol(\"triangle-down\",0,0,n,n).add(N),w(\"downTracker\").on(\"click\",function(){a.scroll(1,p)})),a.scroll(0),b=g):N&&(q(),this.nav=N.destroy(),this.scrollGroup.attr({translateY:1}),this.clipHeight=0);return b};a.prototype.scroll=function(a,c){var d=this,e=this.chart,g=this.pages,f=g.length,h=this.clipHeight,l=this.options.navigation,m=this.pager,\nk=this.padding,p=this.currentPage+a;p>f&&(p=f);0=Math.max(l+g,p.pos)&&h<=Math.min(l+g+e.width,p.pos+p.len)||(b.isInsidePlot=!1)}!c.ignoreY&&\nb.isInsidePlot&&(d=m&&(d?m.xAxis:m.yAxis)||{pos:f,len:Infinity},c=c.paneCoordinates?d.pos+a:f+a,c>=Math.max(k+f,d.pos)&&c<=Math.min(k+f+e.height,d.pos+d.len)||(b.isInsidePlot=!1));Q(this,\"afterIsInsidePlot\",b);return b.isInsidePlot};a.prototype.redraw=function(b){Q(this,\"beforeRedraw\");var a=this.hasCartesianSeries?this.axes:this.colorAxis||[],c=this.series,d=this.pointer,e=this.legend,g=this.userOptions.legend,f=this.renderer,h=f.isHidden(),l=[],k=this.isDirtyBox,m=this.isDirtyLegend;this.setResponsive&&\nthis.setResponsive(!1);B(this.hasRendered?b:!1,this);h&&this.temporaryDisplay();this.layOutTitles();for(b=c.length;b--;){var p=c[b];if(p.options.stacking||p.options.centerInCategory){var n=!0;if(p.isDirty){var E=!0;break}}}if(E)for(b=c.length;b--;)p=c[b],p.options.stacking&&(p.isDirty=!0);c.forEach(function(b){b.isDirty&&(\"point\"===b.options.legendType?(\"function\"===typeof b.updateTotals&&b.updateTotals(),m=!0):g&&(g.labelFormatter||g.labelFormat)&&(m=!0));b.isDirtyData&&Q(b,\"updatedData\")});m&&e&&\ne.options.enabled&&(e.render(),this.isDirtyLegend=!1);n&&this.getStacks();a.forEach(function(b){b.updateNames();b.setScale()});this.getMargins();a.forEach(function(b){b.isDirty&&(k=!0)});a.forEach(function(b){var a=b.min+\",\"+b.max;b.extKey!==a&&(b.extKey=a,l.push(function(){Q(b,\"afterSetExtremes\",M(b.eventArgs,b.getExtremes()));delete b.eventArgs}));(k||n)&&b.redraw()});k&&this.drawChartBox();Q(this,\"predraw\");c.forEach(function(b){(k||b.isDirty)&&b.visible&&b.redraw();b.isDirtyData=!1});d&&d.reset(!0);\nf.draw();Q(this,\"redraw\");Q(this,\"render\");h&&this.temporaryDisplay(!0);l.forEach(function(b){b.call()})};a.prototype.get=function(b){function a(a){return a.id===b||a.options&&a.options.id===b}for(var c=this.series,d=da(this.axes,a)||da(this.series,a),e=0;!d&&e=h&&d<=l||k||!U(d))m=!0;c[k?\"zoomX\":\"zoomY\"]&&m&&(g=f.zoom(b.min,b.max),f.displayBtn&&(e=!0))});var f=a.resetZoomButton;e&&!f?a.showResetZoom():!e&&N(f)&&(a.resetZoomButton=f.destroy());g&&a.redraw(R(a.options.chart.animation,\nb&&b.animation,100>a.pointCount))};a.prototype.pan=function(b,a){var c=this,d=c.hoverPoints;a=\"object\"===typeof a?a:{enabled:a,type:\"x\"};var e=c.options.chart,g=c.options.mapNavigation&&c.options.mapNavigation.enabled;e&&e.panning&&(e.panning=a);var f=a.type,h;Q(this,\"pan\",{originalEvent:b},function(){d&&d.forEach(function(b){b.setState()});var a=c.xAxis;\"xy\"===f?a=a.concat(c.yAxis):\"y\"===f&&(a=c.yAxis);var e={};a.forEach(function(a){if(a.options.panningEnabled&&!a.options.isInternal){var d=a.horiz,\nl=b[d?\"chartX\":\"chartY\"];d=d?\"mouseDownX\":\"mouseDownY\";var k=c[d],m=a.minPointOffset||0,p=a.reversed&&!c.inverted||!a.reversed&&c.inverted?-1:1,n=a.getExtremes(),E=a.toValue(k-l,!0)+m*p,r=a.toValue(k+a.len-l,!0)-(m*p||a.isXAxis&&a.pointRangePadding||0),t=r=p&&E<=r&&(a.setExtremes(k,E,!1,\n!1,{trigger:\"pan\"}),c.resetZoomButton||g||k===p||E===r||!f.match(\"y\")||(c.showResetZoom(),a.displayBtn=!1),h=!0),e[d]=l)}});X(e,function(b,a){c[a]=b});h&&c.redraw(!1);O(c.container,{cursor:\"move\"})})};return a}();M(a.prototype,{callbacks:[],collectionsWithInit:{xAxis:[a.prototype.addAxis,[!0]],yAxis:[a.prototype.addAxis,[!1]],series:[a.prototype.addSeries]},collectionsWithUpdate:[\"xAxis\",\"yAxis\",\"series\"],propsRequireDirtyBox:\"backgroundColor borderColor borderWidth borderRadius plotBackgroundColor plotBackgroundImage plotBorderColor plotBorderWidth plotShadow shadow\".split(\" \"),\npropsRequireReflow:\"margin marginTop marginRight marginBottom marginLeft spacing spacingTop spacingRight spacingBottom spacingLeft\".split(\" \"),propsRequireUpdateSeries:\"chart.inverted chart.polar chart.ignoreHiddenSeries chart.type colors plotOptions time tooltip\".split(\" \")});\"\";return a});M(a,\"Core/Legend/LegendSymbol.js\",[a[\"Core/Utilities.js\"]],function(a){var v=a.merge,z=a.pick,F;(function(a){a.drawLineMarker=function(a){var u=this.options,A=a.symbolWidth,q=a.symbolHeight,n=q/2,k=this.chart.renderer,\ne=this.legendGroup;a=a.baseline-Math.round(.3*a.fontMetrics.b);var c={},h=u.marker;this.chart.styledMode||(c={\"stroke-width\":u.lineWidth||0},u.dashStyle&&(c.dashstyle=u.dashStyle));this.legendLine=k.path([[\"M\",0,a],[\"L\",A,a]]).addClass(\"highcharts-graph\").attr(c).add(e);h&&!1!==h.enabled&&A&&(u=Math.min(z(h.radius,n),n),0===this.symbol.indexOf(\"url\")&&(h=v(h,{width:q,height:q}),u=0),this.legendSymbol=A=k.symbol(this.symbol,A/2-u,a-u,2*u,2*u,h).addClass(\"highcharts-point\").add(e),A.isMarker=!0)};a.drawRectangle=\nfunction(a,v){var u=a.symbolHeight,q=a.options.squareSymbol;v.legendSymbol=this.chart.renderer.rect(q?(a.symbolWidth-u)/2:0,a.baseline-u+1,q?u:a.symbolWidth,u,z(a.options.symbolRadius,u/2)).addClass(\"highcharts-point\").attr({zIndex:3}).add(v.legendGroup)}})(F||(F={}));return F});M(a,\"Core/Series/SeriesDefaults.js\",[],function(){return{lineWidth:2,allowPointSelect:!1,crisp:!0,showCheckbox:!1,animation:{duration:1E3},events:{},marker:{enabledThreshold:2,lineColor:\"#ffffff\",lineWidth:0,radius:4,states:{normal:{animation:!0},\nhover:{animation:{duration:50},enabled:!0,radiusPlus:2,lineWidthPlus:1},select:{fillColor:\"#cccccc\",lineColor:\"#000000\",lineWidth:2}}},point:{events:{}},dataLabels:{animation:{},align:\"center\",defer:!0,formatter:function(){var a=this.series.chart.numberFormatter;return\"number\"!==typeof this.y?\"\":a(this.y,-1)},padding:5,style:{fontSize:\"11px\",fontWeight:\"bold\",color:\"contrast\",textOutline:\"1px contrast\"},verticalAlign:\"bottom\",x:0,y:0},cropThreshold:300,opacity:1,pointRange:0,softThreshold:!0,states:{normal:{animation:!0},\nhover:{animation:{duration:50},lineWidthPlus:1,marker:{},halo:{size:10,opacity:.25}},select:{animation:{duration:0}},inactive:{animation:{duration:50},opacity:.2}},stickyTracking:!0,turboThreshold:1E3,findNearestPointBy:\"x\"}});M(a,\"Core/Series/Series.js\",[a[\"Core/Animation/AnimationUtilities.js\"],a[\"Core/DefaultOptions.js\"],a[\"Core/Foundation.js\"],a[\"Core/Globals.js\"],a[\"Core/Legend/LegendSymbol.js\"],a[\"Core/Series/Point.js\"],a[\"Core/Series/SeriesDefaults.js\"],a[\"Core/Series/SeriesRegistry.js\"],a[\"Core/Renderer/SVG/SVGElement.js\"],\na[\"Core/Utilities.js\"]],function(a,u,z,F,y,G,H,A,q,n){var k=a.animObject,e=a.setAnimation,c=u.defaultOptions,h=z.registerEventOptions,f=F.hasTouch,w=F.svg,p=F.win,B=A.seriesTypes,t=n.addEvent,v=n.arrayMax,C=n.arrayMin,r=n.clamp,l=n.cleanRecursively,b=n.correctFloat,g=n.defined,d=n.erase,m=n.error,D=n.extend,x=n.find,I=n.fireEvent,P=n.getNestedProperty,S=n.isArray,O=n.isNumber,U=n.isString,Y=n.merge,L=n.objectEach,K=n.pick,M=n.removeEvent,da=n.splat,Q=n.syncTimeout;a=function(){function a(){this.zones=\nthis.yAxis=this.xAxis=this.userOptions=this.tooltipOptions=this.processedYData=this.processedXData=this.points=this.options=this.linkedSeries=this.index=this.eventsToUnbind=this.eventOptions=this.data=this.chart=this._i=void 0}a.prototype.init=function(a,b){I(this,\"init\",{options:b});var c=this,d=a.series;this.eventsToUnbind=[];c.chart=a;c.options=c.setOptions(b);b=c.options;c.linkedSeries=[];c.bindAxes();D(c,{name:b.name,state:\"\",visible:!1!==b.visible,selected:!0===b.selected});h(this,b);var e=\nb.events;if(e&&e.click||b.point&&b.point.events&&b.point.events.click||b.allowPointSelect)a.runTrackerClick=!0;c.getColor();c.getSymbol();c.parallelArrays.forEach(function(a){c[a+\"Data\"]||(c[a+\"Data\"]=[])});c.isCartesian&&(a.hasCartesianSeries=!0);var g;d.length&&(g=d[d.length-1]);c._i=K(g&&g._i,-1)+1;c.opacity=c.options.opacity;a.orderSeries(this.insert(d));b.dataSorting&&b.dataSorting.enabled?c.setDataSortingOptions():c.points||c.data||c.setData(b.data,!1);I(this,\"afterInit\")};a.prototype.is=function(a){return B[a]&&\nthis instanceof B[a]};a.prototype.insert=function(a){var b=this.options.index,c;if(O(b)){for(c=a.length;c--;)if(b>=K(a[c].options.index,a[c]._i)){a.splice(c+1,0,this);break}-1===c&&a.unshift(this);c+=1}else a.push(this);return K(c,a.length-1)};a.prototype.bindAxes=function(){var a=this,b=a.options,c=a.chart,d;I(this,\"bindAxes\",null,function(){(a.axisTypes||[]).forEach(function(e){var g=0;c[e].forEach(function(c){d=c.options;if(b[e]===g&&!d.isInternal||\"undefined\"!==typeof b[e]&&b[e]===d.id||\"undefined\"===\ntypeof b[e]&&0===d.index)a.insert(c.series),a[e]=c,c.isDirty=!0;d.isInternal||g++});a[e]||a.optionalAxis===e||m(18,!0,c)})});I(this,\"afterBindAxes\")};a.prototype.updateParallelArrays=function(a,b){var c=a.series,d=arguments,e=O(b)?function(d){var e=\"y\"===d&&c.toYData?c.toYData(a):a[d];c[d+\"Data\"][b]=e}:function(a){Array.prototype[b].apply(c[a+\"Data\"],Array.prototype.slice.call(d,2))};c.parallelArrays.forEach(e)};a.prototype.hasData=function(){return this.visible&&\"undefined\"!==typeof this.dataMax&&\n\"undefined\"!==typeof this.dataMin||this.visible&&this.yData&&0=this.cropStart?l-this.cropStart:l);!h&&O(l)&&e[l]&&e[l].touched&&(l=void 0);return l};a.prototype.updateData=function(a,b){var c=this.options,d=c.dataSorting,e=this.points,f=[],h=this.requireSorting,l=a.length===e.length,k,m,p,n=!0;this.xIncrement=null;a.forEach(function(a,\nb){var m=g(a)&&this.pointClass.prototype.optionsToObject.call({series:this},a)||{},n=m.x;if(m.id||O(n)){if(m=this.findPointIndex(m,p),-1===m||\"undefined\"===typeof m?f.push(a):e[m]&&a!==c.data[m]?(e[m].update(a,!1,null,!1),e[m].touched=!0,h&&(p=m+1)):e[m]&&(e[m].touched=!0),!l||b!==m||d&&d.enabled||this.hasDerivedData)k=!0}else f.push(a)},this);if(k)for(a=e.length;a--;)(m=e[a])&&!m.touched&&m.remove&&m.remove(!1,b);else!l||d&&d.enabled?n=!1:(a.forEach(function(a,b){a!==e[b].y&&e[b].update&&e[b].update(a,\n!1,null,!1)}),f.length=0);e.forEach(function(a){a&&(a.touched=!1)});if(!n)return!1;f.forEach(function(a){this.addPoint(a,!1,null,null,!1)},this);null===this.xIncrement&&this.xData&&this.xData.length&&(this.xIncrement=v(this.xData),this.autoIncrement());return!0};a.prototype.setData=function(a,b,c,d){var e=this,g=e.points,f=g&&g.length||0,h=e.options,l=e.chart,k=h.dataSorting,p=e.xAxis,n=h.turboThreshold,r=this.xData,E=this.yData,t=e.pointArrayMap;t=t&&t.length;var q=h.keys,w,B=0,C=1,x=null;a=a||[];\nvar v=a.length;b=K(b,!0);k&&k.enabled&&(a=this.sortData(a));!1!==d&&v&&f&&!e.cropped&&!e.hasGroupedData&&e.visible&&!e.isSeriesBoosting&&(w=this.updateData(a,c));if(!w){e.xIncrement=null;e.colorCounter=0;this.parallelArrays.forEach(function(a){e[a+\"Data\"].length=0});if(n&&v>n)if(x=e.getFirstValidPoint(a),O(x))for(c=0;ca?1:0}).forEach(function(a,b){a.x=b},this);b.linkedSeries&&b.linkedSeries.forEach(function(b){var c=\nb.options,e=c.data;c.dataSorting&&c.dataSorting.enabled||!e||(e.forEach(function(c,g){e[g]=d(b,c);a[g]&&(e[g].x=a[g].x,e[g].index=g)}),b.setData(e,!1))});return a};a.prototype.getProcessedData=function(a){var b=this.xAxis,c=this.options,d=c.cropThreshold,e=a||this.getExtremesFromAll||c.getExtremesFromAll,g=this.isCartesian;a=b&&b.val2lin;c=!(!b||!b.logarithmic);var f=0,h=this.xData,l=this.yData,k=this.requireSorting;var p=!1;var n=h.length;if(b){p=b.getExtremes();var r=p.min;var E=p.max;p=b.categories&&\n!b.names.length}if(g&&this.sorted&&!e&&(!d||n>d||this.forceCrop))if(h[n-1]E)h=[],l=[];else if(this.yData&&(h[0]E)){var t=this.cropData(this.xData,this.yData,r,E);h=t.xData;l=t.yData;f=t.start;t=!0}for(d=h.length||1;--d;)if(b=c?a(h[d])-a(h[d-1]):h[d]-h[d-1],0b&&k&&!p&&(m(15,!1,this.chart),k=!1);return{xData:h,yData:l,cropped:t,cropStart:f,closestPointRange:q}};a.prototype.processData=function(a){var b=this.xAxis;if(this.isCartesian&&\n!this.isDirty&&!b.isDirty&&!this.yAxis.isDirty&&!a)return!1;a=this.getProcessedData();this.cropped=a.cropped;this.cropStart=a.cropStart;this.processedXData=a.xData;this.processedYData=a.yData;this.closestPointRange=this.basePointRange=a.closestPointRange;I(this,\"afterProcessData\")};a.prototype.cropData=function(a,b,c,d,e){var g=a.length,f,h=0,l=g;e=K(e,this.cropShoulder);for(f=0;f=c){h=Math.max(0,f-e);break}for(c=f;cd){l=c+e;break}return{xData:a.slice(h,l),yData:b.slice(h,\nl),start:h,end:l}};a.prototype.generatePoints=function(){var a=this.options,b=a.data,c=this.processedXData,d=this.processedYData,e=this.pointClass,g=c.length,f=this.cropStart||0,h=this.hasGroupedData,l=a.keys,k=[];a=a.dataGrouping&&a.dataGrouping.groupAll?f:0;var m,p,n=this.data;if(!n&&!h){var r=[];r.length=b.length;n=this.data=r}l&&h&&(this.options.keys=!1);for(p=0;p=l&&(e[h-f]||r)<=k;if(t&&r)if(t=n.length)for(;t--;)O(n[t])&&(g[m++]=n[t]);else g[m++]=n}a={activeYData:g,dataMin:C(g),dataMax:v(g)};\nI(this,\"afterGetExtremes\",{dataExtremes:a});return a};a.prototype.applyExtremes=function(){var a=this.getExtremes();this.dataMin=a.dataMin;this.dataMax=a.dataMax;return a};a.prototype.getFirstValidPoint=function(a){for(var b=a.length,c=0,d=null;null===d&&c=A&&(A=null),x.total=x.stackTotal=u.total,x.percentage=u.total&&x.y/u.total*100,x.stackY=J,this.irregularWidths||u.setOffset(this.pointXOffset||0,this.barW||0));x.yBottom=g(A)?r(h.translate(A,0,1,0,1),-1E5,1E5):null;this.dataModify&&(J=this.dataModify.modifyValue(J,w));x.plotY=void 0;O(J)&&(u=h.translate(J,!1,!0,!1,!0),\"undefined\"!==typeof u&&(x.plotY=r(u,\n-1E5,1E5)));x.isInside=this.isPointInside(x);x.clientX=p?b(d.translate(v,0,0,0,1,m)):B;x.negative=x[q]<(a[q+\"Threshold\"]||n||0);x.category=e&&\"undefined\"!==typeof e[x.x]?e[x.x]:x.x;if(!x.isNull&&!1!==x.visible){\"undefined\"!==typeof F&&(C=Math.min(C,Math.abs(B-F)));var F=B}x.zone=this.zones.length?x.getZone():void 0;!x.graphic&&this.group&&f&&(x.isNew=!0)}this.closestPointRangePx=C;I(this,\"afterTranslate\")};a.prototype.getValidPoints=function(a,b,c){var d=this.chart;return(a||this.points||[]).filter(function(a){return b&&\n!d.isInsidePlot(a.plotX,a.plotY,{inverted:d.inverted})?!1:!1!==a.visible&&(c||!a.isNull)})};a.prototype.getClipBox=function(){var a=this.chart,b=this.xAxis,c=this.yAxis,d=Y(a.clipBox);b&&b.len!==a.plotSizeX&&(d.width=b.len);c&&c.len!==a.plotSizeY&&(d.height=c.len);return d};a.prototype.getSharedClipKey=function(){return this.sharedClipKey=(this.options.xAxis||0)+\",\"+(this.options.yAxis||0)};a.prototype.setClip=function(){var a=this.chart,b=this.group,c=this.markerGroup,d=a.sharedClips;a=a.renderer;\nvar e=this.getClipBox(),g=this.getSharedClipKey(),f=d[g];f?f.animate(e):d[g]=f=a.clipRect(e);b&&b.clip(!1===this.options.clip?void 0:f);c&&c.clip()};a.prototype.animate=function(a){var b=this.chart,c=this.group,d=this.markerGroup,e=b.inverted,g=k(this.options.animation),f=[this.getSharedClipKey(),g.duration,g.easing,g.defer].join(),h=b.sharedClips[f],l=b.sharedClips[f+\"m\"];if(a&&c)g=this.getClipBox(),h?h.attr(\"height\",g.height):(g.width=0,e&&(g.x=b.plotHeight),h=b.renderer.clipRect(g),b.sharedClips[f]=\nh,l=b.renderer.clipRect({x:e?(b.plotSizeX||0)+99:-99,y:e?-b.plotLeft:-b.plotTop,width:99,height:e?b.chartWidth:b.chartHeight}),b.sharedClips[f+\"m\"]=l),c.clip(h),d&&d.clip(l);else if(h&&!h.hasClass(\"highcharts-animating\")){b=this.getClipBox();var m=g.step;d&&d.element.childNodes.length&&(g.step=function(a,b){m&&m.apply(b,arguments);l&&l.element&&l.attr(b.prop,\"width\"===b.prop?a+99:a)});h.addClass(\"highcharts-animating\").animate(b,g)}};a.prototype.afterAnimate=function(){var a=this;this.setClip();L(this.chart.sharedClips,\nfunction(b,c,d){b&&!a.chart.container.querySelector('[clip-path=\"url(#'+b.id+')\"]')&&(b.destroy(),delete d[c])});this.finishedAnimating=!0;I(this,\"afterAnimate\")};a.prototype.drawPoints=function(){var a=this.points,b=this.chart,c=this.options.marker,d=this[this.specialGroup]||this.markerGroup,e=this.xAxis,g=K(c.enabled,!e||e.isRadial?!0:null,this.closestPointRangePx>=c.enabledThreshold*c.radius),f,h;if(!1!==c.enabled||this._hasPointMarkers)for(f=0;fD.max;a.resetZones&&0===p&&(p=void 0)});this.clips=e}else a.visible&&(g&&g.show(!0),f&&f.show(!0))};a.prototype.invertGroups=function(a){function b(){[\"group\",\"markerGroup\"].forEach(function(b){c[b]&&(d.renderer.isVML&&c[b].attr({width:c.yAxis.len,height:c.xAxis.len}),\nc[b].width=c.yAxis.len,c[b].height=c.xAxis.len,c[b].invert(c.isRadialSeries?!1:a))})}var c=this,d=c.chart;c.xAxis&&(c.eventsToUnbind.push(t(d,\"resize\",b)),b(),c.invertGroups=b)};a.prototype.plotGroup=function(a,b,c,d,e){var f=this[a],h=!f;c={visibility:c,zIndex:d||.1};\"undefined\"===typeof this.opacity||this.chart.styledMode||\"inactive\"===this.state||(c.opacity=this.opacity);h&&(this[a]=f=this.chart.renderer.g().add(e));f.addClass(\"highcharts-\"+b+\" highcharts-series-\"+this.index+\" highcharts-\"+this.type+\n\"-series \"+(g(this.colorIndex)?\"highcharts-color-\"+this.colorIndex+\" \":\"\")+(this.options.className||\"\")+(f.hasClass(\"highcharts-tracker\")?\" highcharts-tracker\":\"\"),!0);f.attr(c)[h?\"attr\":\"animate\"](this.getPlotBox());return f};a.prototype.getPlotBox=function(){var a=this.chart,b=this.xAxis,c=this.yAxis;a.inverted&&(b=c,c=this.xAxis);return{translateX:b?b.left:a.plotLeft,translateY:c?c.top:a.plotTop,scaleX:1,scaleY:1}};a.prototype.removeEvents=function(a){a||M(this);this.eventsToUnbind.length&&(this.eventsToUnbind.forEach(function(a){a()}),\nthis.eventsToUnbind.length=0)};a.prototype.render=function(){var a=this,b=a.chart,c=a.options,d=k(c.animation),e=a.visible?\"inherit\":\"hidden\",g=c.zIndex,f=a.hasRendered,h=b.seriesGroup,l=b.inverted;b=!a.finishedAnimating&&b.renderer.isSVG?d.duration:0;I(this,\"render\");var m=a.plotGroup(\"group\",\"series\",e,g,h);a.markerGroup=a.plotGroup(\"markerGroup\",\"markers\",e,g,h);!1!==c.clip&&a.setClip();a.animate&&b&&a.animate(!0);m.inverted=K(a.invertible,a.isCartesian)?l:!1;a.drawGraph&&(a.drawGraph(),a.applyZones());\na.visible&&a.drawPoints();a.drawDataLabels&&a.drawDataLabels();a.redrawPoints&&a.redrawPoints();a.drawTracker&&!1!==a.options.enableMouseTracking&&a.drawTracker();a.invertGroups(l);a.animate&&b&&a.animate();f||(b&&d.defer&&(b+=d.defer),a.animationTimeout=Q(function(){a.afterAnimate()},b||0));a.isDirty=!1;a.hasRendered=!0;I(a,\"afterRender\")};a.prototype.redraw=function(){var a=this.chart,b=this.isDirty||this.isDirtyData,c=this.group,d=this.xAxis,e=this.yAxis;c&&(a.inverted&&c.attr({width:a.plotWidth,\nheight:a.plotHeight}),c.animate({translateX:K(d&&d.left,a.plotLeft),translateY:K(e&&e.top,a.plotTop)}));this.translate();this.render();b&&delete this.kdTree};a.prototype.searchPoint=function(a,b){var c=this.xAxis,d=this.yAxis,e=this.chart.inverted;return this.searchKDTree({clientX:e?c.len-a.chartY+c.pos:a.chartX-c.pos,plotY:e?d.len-a.chartX+d.pos:a.chartY-d.pos},b,a)};a.prototype.buildKDTree=function(a){function b(a,d,e){var g=a&&a.length;if(g){var f=c.kdAxisArray[d%e];a.sort(function(a,b){return a[f]-\nb[f]});g=Math.floor(g/2);return{point:a[g],left:b(a.slice(0,g),d+1,e),right:b(a.slice(g+1),d+1,e)}}}this.buildingKdTree=!0;var c=this,d=-1p?\"left\":\"right\";r=0>p?\"right\":\"left\";b[t]&&(t=d(a,b[t],c+1,k),n=t[l]r;)t--;this.updateParallelArrays(n,\"splice\",t,0,0);this.updateParallelArrays(n,t);l&&n.name&&(l[r]=n.name);m.splice(t,0,a);p&&(this.data.splice(t,0,null),this.processData());\"point\"===g.legendType&&this.generatePoints();c&&(f[0]&&f[0].remove?f[0].remove(!1):(f.shift(),this.updateParallelArrays(n,\"shift\"),m.shift()));!1!==e&&I(this,\"addPoint\",{point:n});this.isDirtyData=this.isDirty=!0;b&&h.redraw(d)};a.prototype.removePoint=\nfunction(a,b,c){var d=this,g=d.data,f=g[a],h=d.points,l=d.chart,k=function(){h&&h.length===g.length&&h.splice(a,1);g.splice(a,1);d.options.data.splice(a,1);d.updateParallelArrays(f||{series:d},\"splice\",a,1);f&&f.destroy();d.isDirty=!0;d.isDirtyData=!0;b&&l.redraw()};e(c,l);b=K(b,!0);f?f.firePointEvent(\"remove\",null,k):k()};a.prototype.remove=function(a,b,c,d){function e(){g.destroy(d);f.isDirtyLegend=f.isDirtyBox=!0;f.linkSeries();K(a,!0)&&f.redraw(b)}var g=this,f=g.chart;!1!==c?I(g,\"remove\",null,\ne):e()};a.prototype.update=function(a,b){a=l(a,this.userOptions);I(this,\"update\",{options:a});var c=this,d=c.chart,e=c.userOptions,g=c.initialType||c.type,f=d.options.plotOptions,h=B[g].prototype,k=c.finishedAnimating&&{animation:!1},p={},n,r=[\"eventOptions\",\"navigatorSeries\",\"baseSeries\"],t=a.type||e.type||d.options.chart.type,q=!(this.hasDerivedData||t&&t!==this.type||\"undefined\"!==typeof a.pointStart||\"undefined\"!==typeof a.pointInterval||\"undefined\"!==typeof a.relativeXValue||c.hasOptionChanged(\"dataGrouping\")||\nc.hasOptionChanged(\"pointStart\")||c.hasOptionChanged(\"pointInterval\")||c.hasOptionChanged(\"pointIntervalUnit\")||c.hasOptionChanged(\"keys\"));t=t||g;q&&(r.push(\"data\",\"isDirtyData\",\"points\",\"processedXData\",\"processedYData\",\"xIncrement\",\"cropped\",\"_hasPointMarkers\",\"_hasPointLabels\",\"clips\",\"nodes\",\"layout\",\"mapMap\",\"mapData\",\"minY\",\"maxY\",\"minX\",\"maxX\"),!1!==a.visible&&r.push(\"area\",\"graph\"),c.parallelArrays.forEach(function(a){r.push(a+\"Data\")}),a.data&&(a.dataSorting&&D(c.options.dataSorting,a.dataSorting),\nthis.setData(a.data,!1)));a=Y(e,k,{index:\"undefined\"===typeof e.index?c.index:e.index,pointStart:K(f&&f.series&&f.series.pointStart,e.pointStart,c.xData[0])},!q&&{data:c.options.data},a);q&&a.data&&(a.data=c.options.data);r=[\"group\",\"markerGroup\",\"dataLabelsGroup\",\"transformGroup\"].concat(r);r.forEach(function(a){r[a]=c[a];delete c[a]});f=!1;if(B[t]){if(f=t!==c.type,c.remove(!1,!1,!1,!0),f)if(Object.setPrototypeOf)Object.setPrototypeOf(c,B[t].prototype);else{k=Object.hasOwnProperty.call(c,\"hcEvents\")&&\nc.hcEvents;for(n in h)c[n]=void 0;D(c,B[t].prototype);k?c.hcEvents=k:delete c.hcEvents}}else m(17,!0,d,{missingModuleFor:t});r.forEach(function(a){c[a]=r[a]});c.init(d,a);if(q&&this.points){var x=c.options;!1===x.visible?(p.graphic=1,p.dataLabel=1):c._hasPointLabels||(a=x.marker,h=x.dataLabels,!a||!1!==a.enabled&&(e.marker&&e.marker.symbol)===a.symbol||(p.graphic=1),h&&!1===h.enabled&&(p.dataLabel=1));this.points.forEach(function(a){a&&a.series&&(a.resolveColor(),Object.keys(p).length&&a.destroyElements(p),\n!1===x.showInLegend&&a.legendItem&&d.legend.destroyItem(a))},this)}c.initialType=g;d.linkSeries();f&&c.linkedSeries.length&&(c.isDirtyData=!0);I(this,\"afterUpdate\");K(b,!0)&&d.redraw(q?void 0:!1)};a.prototype.setName=function(a){this.name=this.options.name=this.userOptions.name=a;this.chart.isDirtyLegend=!0};a.prototype.hasOptionChanged=function(a){var b=this.options[a],c=this.chart.options.plotOptions,d=this.userOptions[a];return d?b!==d:b!==K(c&&c[this.type]&&c[this.type][a],c&&c.series&&c.series[a],\nb)};a.prototype.onMouseOver=function(){var a=this.chart,b=a.hoverSeries;a.pointer.setHoverChartIndex();if(b&&b!==this)b.onMouseOut();this.options.events.mouseOver&&I(this,\"mouseOver\");this.setState(\"hover\");a.hoverSeries=this};a.prototype.onMouseOut=function(){var a=this.options,b=this.chart,c=b.tooltip,d=b.hoverPoint;b.hoverSeries=null;if(d)d.onMouseOut();this&&a.events.mouseOut&&I(this,\"mouseOut\");!c||this.stickyTracking||c.shared&&!this.noSharedTooltip||c.hide();b.series.forEach(function(a){a.setState(\"\",\n!0)})};a.prototype.setState=function(a,b){var c=this,d=c.options,e=c.graph,g=d.inactiveOtherPoints,f=d.states,h=K(f[a||\"normal\"]&&f[a||\"normal\"].animation,c.chart.options.chart.animation),l=d.lineWidth,k=0,m=d.opacity;a=a||\"\";if(c.state!==a&&([c.group,c.markerGroup,c.dataLabelsGroup].forEach(function(b){b&&(c.state&&b.removeClass(\"highcharts-series-\"+c.state),a&&b.addClass(\"highcharts-series-\"+a))}),c.state=a,!c.chart.styledMode)){if(f[a]&&!1===f[a].enabled)return;a&&(l=f[a].lineWidth||l+(f[a].lineWidthPlus||\n0),m=K(f[a].opacity,m));if(e&&!e.dashstyle)for(d={\"stroke-width\":l},e.animate(d,h);c[\"zone-graph-\"+k];)c[\"zone-graph-\"+k].animate(d,h),k+=1;g||[c.group,c.markerGroup,c.dataLabelsGroup,c.labelBySeries].forEach(function(a){a&&a.animate({opacity:m},h)})}b&&g&&c.points&&c.setAllPointsToState(a||void 0)};a.prototype.setAllPointsToState=function(a){this.points.forEach(function(b){b.setState&&b.setState(a)})};a.prototype.setVisible=function(a,b){var c=this,d=c.chart,e=c.legendItem,g=d.options.chart.ignoreHiddenSeries,\nf=c.visible,h=(c.visible=a=c.options.visible=c.userOptions.visible=\"undefined\"===typeof a?!f:a)?\"show\":\"hide\";[\"group\",\"dataLabelsGroup\",\"markerGroup\",\"tracker\",\"tt\"].forEach(function(a){if(c[a])c[a][h]()});if(d.hoverSeries===c||(d.hoverPoint&&d.hoverPoint.series)===c)c.onMouseOut();e&&d.legend.colorizeItem(c,a);c.isDirty=!0;c.options.stacking&&d.series.forEach(function(a){a.options.stacking&&a.visible&&(a.isDirty=!0)});c.linkedSeries.forEach(function(b){b.setVisible(a,!1)});g&&(d.isDirtyBox=!0);\nI(c,h);!1!==b&&d.redraw()};a.prototype.show=function(){this.setVisible(!0)};a.prototype.hide=function(){this.setVisible(!1)};a.prototype.select=function(a){this.selected=a=this.options.selected=\"undefined\"===typeof a?!this.selected:a;this.checkbox&&(this.checkbox.checked=a);I(this,a?\"select\":\"unselect\")};a.prototype.shouldShowTooltip=function(a,b,c){void 0===c&&(c={});c.series=this;c.visiblePlotOnly=!0;return this.chart.isInsidePlot(a,b,c)};a.defaultOptions=H;return a}();D(a.prototype,{axisTypes:[\"xAxis\",\n\"yAxis\"],coll:\"series\",colorCounter:0,cropShoulder:1,directTouch:!1,drawLegendSymbol:y.drawLineMarker,isCartesian:!0,kdAxisArray:[\"clientX\",\"plotY\"],parallelArrays:[\"x\",\"y\"],pointClass:G,requireSorting:!0,sorted:!0});A.series=a;\"\";\"\";return a});M(a,\"Extensions/ScrollablePlotArea.js\",[a[\"Core/Animation/AnimationUtilities.js\"],a[\"Core/Axis/Axis.js\"],a[\"Core/Chart/Chart.js\"],a[\"Core/Series/Series.js\"],a[\"Core/Renderer/RendererRegistry.js\"],a[\"Core/Utilities.js\"]],function(a,u,z,F,y,G){var v=a.stop,A=\nG.addEvent,q=G.createElement,n=G.merge,k=G.pick;A(z,\"afterSetChartSize\",function(a){var c=this.options.chart.scrollablePlotArea,e=c&&c.minWidth;c=c&&c.minHeight;if(!this.renderer.forExport){if(e){if(this.scrollablePixelsX=e=Math.max(0,e-this.chartWidth)){this.scrollablePlotBox=this.renderer.scrollablePlotBox=n(this.plotBox);this.plotBox.width=this.plotWidth+=e;this.inverted?this.clipBox.height+=e:this.clipBox.width+=e;var f={1:{name:\"right\",value:e}}}}else c&&(this.scrollablePixelsY=e=Math.max(0,\nc-this.chartHeight))&&(this.scrollablePlotBox=this.renderer.scrollablePlotBox=n(this.plotBox),this.plotBox.height=this.plotHeight+=e,this.inverted?this.clipBox.width+=e:this.clipBox.height+=e,f={2:{name:\"bottom\",value:e}});f&&!a.skipAxes&&this.axes.forEach(function(a){f[a.side]?a.getPlotLinePath=function(){var c=f[a.side].name,e=this[c];this[c]=e-f[a.side].value;var h=u.prototype.getPlotLinePath.apply(this,arguments);this[c]=e;return h}:(a.setAxisSize(),a.setAxisTranslation())})}});A(z,\"render\",function(){this.scrollablePixelsX||\nthis.scrollablePixelsY?(this.setUpScrolling&&this.setUpScrolling(),this.applyFixed()):this.fixedDiv&&this.applyFixed()});z.prototype.setUpScrolling=function(){var a=this,c={WebkitOverflowScrolling:\"touch\",overflowX:\"hidden\",overflowY:\"hidden\"};this.scrollablePixelsX&&(c.overflowX=\"auto\");this.scrollablePixelsY&&(c.overflowY=\"auto\");this.scrollingParent=q(\"div\",{className:\"highcharts-scrolling-parent\"},{position:\"relative\"},this.renderTo);this.scrollingContainer=q(\"div\",{className:\"highcharts-scrolling\"},\nc,this.scrollingParent);A(this.scrollingContainer,\"scroll\",function(){a.pointer&&delete a.pointer.chartPosition});this.innerContainer=q(\"div\",{className:\"highcharts-inner-container\"},null,this.scrollingContainer);this.innerContainer.appendChild(this.container);this.setUpScrolling=null};z.prototype.moveFixedElements=function(){var a=this.container,c=this.fixedRenderer,h=\".highcharts-contextbutton .highcharts-credits .highcharts-legend .highcharts-legend-checkbox .highcharts-navigator-series .highcharts-navigator-xaxis .highcharts-navigator-yaxis .highcharts-navigator .highcharts-reset-zoom .highcharts-drillup-button .highcharts-scrollbar .highcharts-subtitle .highcharts-title\".split(\" \"),\nf;this.scrollablePixelsX&&!this.inverted?f=\".highcharts-yaxis\":this.scrollablePixelsX&&this.inverted?f=\".highcharts-xaxis\":this.scrollablePixelsY&&!this.inverted?f=\".highcharts-xaxis\":this.scrollablePixelsY&&this.inverted&&(f=\".highcharts-yaxis\");f&&h.push(f+\":not(.highcharts-radial-axis)\",f+\"-labels:not(.highcharts-radial-axis-labels)\");h.forEach(function(e){[].forEach.call(a.querySelectorAll(e),function(a){(a.namespaceURI===c.SVG_NS?c.box:c.box.parentNode).appendChild(a);a.style.pointerEvents=\"auto\"})})};\nz.prototype.applyFixed=function(){var a=!this.fixedDiv,c=this.options.chart,h=c.scrollablePlotArea,f=y.getRendererType();a?(this.fixedDiv=q(\"div\",{className:\"highcharts-fixed\"},{position:\"absolute\",overflow:\"hidden\",pointerEvents:\"none\",zIndex:(c.style&&c.style.zIndex||0)+2,top:0},null,!0),this.scrollingContainer&&this.scrollingContainer.parentNode.insertBefore(this.fixedDiv,this.scrollingContainer),this.renderTo.style.overflow=\"visible\",this.fixedRenderer=c=new f(this.fixedDiv,this.chartWidth,this.chartHeight,\nthis.options.chart.style),this.scrollableMask=c.path().attr({fill:this.options.chart.backgroundColor||\"#fff\",\"fill-opacity\":k(h.opacity,.85),zIndex:-1}).addClass(\"highcharts-scrollable-mask\").add(),A(this,\"afterShowResetZoom\",this.moveFixedElements),A(this,\"afterDrilldown\",this.moveFixedElements),A(this,\"afterLayOutTitles\",this.moveFixedElements)):this.fixedRenderer.setSize(this.chartWidth,this.chartHeight);if(this.scrollableDirty||a)this.scrollableDirty=!1,this.moveFixedElements();c=this.chartWidth+\n(this.scrollablePixelsX||0);f=this.chartHeight+(this.scrollablePixelsY||0);v(this.container);this.container.style.width=c+\"px\";this.container.style.height=f+\"px\";this.renderer.boxWrapper.attr({width:c,height:f,viewBox:[0,0,c,f].join(\" \")});this.chartBackground.attr({width:c,height:f});this.scrollingContainer.style.height=this.chartHeight+\"px\";a&&(h.scrollPositionX&&(this.scrollingContainer.scrollLeft=this.scrollablePixelsX*h.scrollPositionX),h.scrollPositionY&&(this.scrollingContainer.scrollTop=this.scrollablePixelsY*\nh.scrollPositionY));f=this.axisOffset;a=this.plotTop-f[0]-1;h=this.plotLeft-f[3]-1;c=this.plotTop+this.plotHeight+f[2]+1;f=this.plotLeft+this.plotWidth+f[1]+1;var n=this.plotLeft+this.plotWidth-(this.scrollablePixelsX||0),p=this.plotTop+this.plotHeight-(this.scrollablePixelsY||0);a=this.scrollablePixelsX?[[\"M\",0,a],[\"L\",this.plotLeft-1,a],[\"L\",this.plotLeft-1,c],[\"L\",0,c],[\"Z\"],[\"M\",n,a],[\"L\",this.chartWidth,a],[\"L\",this.chartWidth,c],[\"L\",n,c],[\"Z\"]]:this.scrollablePixelsY?[[\"M\",h,0],[\"L\",h,this.plotTop-\n1],[\"L\",f,this.plotTop-1],[\"L\",f,0],[\"Z\"],[\"M\",h,p],[\"L\",h,this.chartHeight],[\"L\",f,this.chartHeight],[\"L\",f,p],[\"Z\"]]:[[\"M\",0,0]];\"adjustHeight\"!==this.redrawTrigger&&this.scrollableMask.attr({d:a})};A(u,\"afterInit\",function(){this.chart.scrollableDirty=!0});A(F,\"show\",function(){this.chart.scrollableDirty=!0});\"\"});M(a,\"Core/Axis/StackingAxis.js\",[a[\"Core/Animation/AnimationUtilities.js\"],a[\"Core/Axis/Axis.js\"],a[\"Core/Utilities.js\"]],function(a,u,z){var v=a.getDeferredAnimation,y=z.addEvent,G=\nz.destroyObjectProperties,H=z.fireEvent,A=z.isNumber,q=z.objectEach,n;(function(a){function e(){var a=this.stacking;if(a){var c=a.stacks;q(c,function(a,e){G(a);c[e]=null});a&&a.stackTotalGroup&&a.stackTotalGroup.destroy()}}function c(){this.stacking||(this.stacking=new f(this))}var h=[];a.compose=function(a){-1===h.indexOf(a)&&(h.push(a),y(a,\"init\",c),y(a,\"destroy\",e));return a};var f=function(){function a(a){this.oldStacks={};this.stacks={};this.stacksTouched=0;this.axis=a}a.prototype.buildStacks=\nfunction(){var a=this.axis,c=a.series,e=a.options.reversedStacks,f=c.length,h;if(!a.isXAxis){this.usePercentage=!1;for(h=f;h--;){var k=c[e?h:f-h-1];k.setStackedPoints();k.setGroupedPoints()}for(h=0;hf&&n.shadow));p&&(p.startX=k.xMap,p.isArea=k.isArea)})};A.prototype.getGraphPath=function(a,n,k){var e=this,c=e.options,h=[],f=[],q,p=c.step;a=a||e.points;var v=a.reversed;v&&a.reverse();\n(p={right:1,center:2}[p]||p&&3)&&v&&(p=4-p);a=this.getValidPoints(a,!1,!(c.connectNulls&&!n&&!k));a.forEach(function(t,v){var w=t.plotX,r=t.plotY,l=a[v-1];(t.leftCliff||l&&l.rightCliff)&&!k&&(q=!0);t.isNull&&!y(n)&&0a&&v>c?(v=Math.max(a,c),t=2*c-v):vk&&t>c?(t=Math.max(k,c),v=2*c-t):t=Math.abs(c)&&.5a.closestPointRange*a.xAxis.transA;f=a.borderWidth=J(d.borderWidth,f?0:1);var l=a.xAxis,k=a.yAxis,n=d.threshold,p=a.translatedThreshold=k.getThreshold(n),r=J(d.minPointLength,5),q=a.getColumnMetrics(),t=q.width,v=a.pointXOffset=q.offset,u=a.dataMin,w=a.dataMax,C=a.barW=Math.max(t,1+2*f);c.inverted&&(p-=.5);d.pointPadding&&(C=Math.ceil(C));y.prototype.translate.apply(a);a.points.forEach(function(b){var g=\nJ(b.yBottom,p),f=999+Math.abs(g),m=b.plotX||0;f=e(b.plotY,-f,k.len+f);var x=Math.min(f,g),D=Math.max(f,g)-x,y=t,A=m+v,z=C;r&&Math.abs(D)r?g-r:p-(m?r:0));h(b.options.pointWidth)&&(y=z=Math.ceil(b.options.pointWidth),A-=Math.round((y-t)/2));d.centerInCategory&&(A=a.adjustForMissingColumns(A,y,b,q));b.barX=A;b.pointWidth=y;b.tooltipPos=c.inverted?[e(k.len+\nk.pos-c.plotLeft-f,k.pos-c.plotLeft,k.len+k.pos-c.plotLeft),l.len+l.pos-c.plotTop-A-z/2,D]:[l.left-c.plotLeft+A+z/2,e(f+k.pos-c.plotTop,k.pos-c.plotTop,k.len+k.pos-c.plotTop),D];b.shapeType=a.pointClass.prototype.shapeType||\"rect\";b.shapeArgs=a.crispCol.apply(a,b.isNull?[A,p,z,0]:[A,x,z,D])})};l.prototype.drawGraph=function(){this.group[this.dense?\"addClass\":\"removeClass\"](\"highcharts-dense-data\")};l.prototype.pointAttribs=function(a,c){var b=this.options,e=this.pointAttrToOptions||{},g=e.stroke||\n\"borderColor\",f=e[\"stroke-width\"]||\"borderWidth\",h=a&&a.color||this.color,l=a&&a[g]||b[g]||h;e=a&&a.options.dashStyle||b.dashStyle;var k=a&&a[f]||b[f]||this[f]||0,p=J(a&&a.opacity,b.opacity,1);if(a&&this.zones.length){var r=a.getZone();h=a.options.color||r&&(r.color||a.nonZonedColor)||this.color;r&&(l=r.borderColor||l,e=r.dashStyle||e,k=r.borderWidth||k)}c&&a&&(a=t(b.states[c],a.options.states&&a.options.states[c]||{}),c=a.brightness,h=a.color||\"undefined\"!==typeof c&&n(h).brighten(a.brightness).get()||\nh,l=a[g]||l,k=a[f]||k,e=a.dashStyle||e,p=J(a.opacity,p));g={fill:h,stroke:l,\"stroke-width\":k,opacity:p};e&&(g.dashstyle=e);return g};l.prototype.drawPoints=function(){var a=this,c=this.chart,d=a.options,e=c.renderer,f=d.animationLimit||250,h;a.points.forEach(function(b){var g=b.graphic,l=!!g,k=g&&c.pointCountv,\"left\"===q?m.y-=v?p.height:0:\"center\"===q?(m.x-=p.width/2,m.y-=p.height/2):\"right\"===q&&(m.x-=p.width,m.y-=v?0:p.height),b.placed=!0,b.alignAttr=m):(v(d),b.align(c,void 0,d),m=b.alignAttr);u&&0<=d.height?this.justifyDataLabel(b,c,m,p,d,f):e(c.crop,!0)&&(w=h.isInsidePlot(m.x,m.y,{paneCoordinates:!0,series:g})&&h.isInsidePlot(m.x+p.width,m.y+p.height,{paneCoordinates:!0,\nseries:g}));if(c.shape&&!r)b[f?\"attr\":\"animate\"]({anchorX:l?h.plotWidth-a.plotY:a.plotX,anchorY:l?h.plotHeight-a.plotX:a.plotY})}f&&k&&(b.placed=!1);w||k&&!u||(b.hide(!0),b.placed=!1)}function h(a,b){var c=b.filter;return c?(b=c.operator,a=a[c.property],c=c.value,\">\"===b&&a>c||\"<\"===b&&a=\"===b&&a>=c||\"<=\"===b&&a<=c||\"==\"===b&&a==c||\"===\"===b&&a===c?!0:!1):!0}function u(){var a=this,b=a.chart,g=a.options,d=a.points,f=a.hasRendered||0,n=b.renderer,p=g.dataLabels,r,t=p.animation;t=p.defer?v(b,\nt,a):{defer:0,duration:0};p=z(z(b.options.plotOptions&&b.options.plotOptions.series&&b.options.plotOptions.series.dataLabels,b.options.plotOptions&&b.options.plotOptions[a.type]&&b.options.plotOptions[a.type].dataLabels),p);A(this,\"drawDataLabels\");if(q(p)||p.enabled||a._hasPointLabels){var u=a.plotGroup(\"dataLabelsGroup\",\"data-labels\",f?\"inherit\":\"hidden\",p.zIndex||6);u.attr({opacity:+f});!f&&(f=a.dataLabelsGroup)&&(a.visible&&u.show(!0),f[g.animation?\"animate\":\"attr\"]({opacity:1},t));d.forEach(function(d){r=\nc(z(p,d.dlOptions||d.options&&d.options.dataLabels));r.forEach(function(c,f){var l=c.enabled&&(!d.isNull||d.dataLabelOnNull)&&h(d,c),m=d.connectors?d.connectors[f]:d.connector,p=d.dataLabels?d.dataLabels[f]:d.dataLabel,r=e(c.distance,d.labelDistance),q=!p;if(l){var t=d.getLabelConfig();var v=e(c[d.formatPrefix+\"Format\"],c.format);t=G(v)?y(v,t,b):(c[d.formatPrefix+\"Formatter\"]||c.formatter).call(t,c);v=c.style;var w=c.rotation;b.styledMode||(v.color=e(c.color,v.color,a.color,\"#000000\"),\"contrast\"===\nv.color?(d.contrastColor=n.getContrast(d.color||a.color),v.color=!G(r)&&c.inside||0>r||g.stacking?d.contrastColor:\"#000000\"):delete d.contrastColor,g.cursor&&(v.cursor=g.cursor));var C={r:c.borderRadius||0,rotation:w,padding:c.padding,zIndex:1};b.styledMode||(C.fill=c.backgroundColor,C.stroke=c.borderColor,C[\"stroke-width\"]=c.borderWidth);k(C,function(a,b){\"undefined\"===typeof a&&delete C[b]})}!p||l&&G(t)&&!!p.div===!!c.useHTML||(d.dataLabel=p=d.dataLabel&&d.dataLabel.destroy(),d.dataLabels&&(1===\nd.dataLabels.length?delete d.dataLabels:delete d.dataLabels[f]),f||delete d.dataLabel,m&&(d.connector=d.connector.destroy(),d.connectors&&(1===d.connectors.length?delete d.connectors:delete d.connectors[f])));l&&G(t)&&(p?C.text=t:(d.dataLabels=d.dataLabels||[],p=d.dataLabels[f]=w?n.text(t,0,-9999,c.useHTML).addClass(\"highcharts-data-label\"):n.label(t,0,-9999,c.shape,null,null,c.useHTML,null,\"data-label\"),f||(d.dataLabel=p),p.addClass(\" highcharts-data-label-color-\"+d.colorIndex+\" \"+(c.className||\n\"\")+(c.useHTML?\" highcharts-tracker\":\"\"))),p.options=c,p.attr(C),b.styledMode||p.css(v).shadow(c.shadow),p.added||p.add(u),c.textPath&&!c.useHTML&&(p.setTextPath(d.getDataLabelPath&&d.getDataLabelPath(p)||d.graphic,c.textPath),d.dataLabelPath&&!c.textPath.enabled&&(d.dataLabelPath=d.dataLabelPath.destroy())),a.alignDataLabel(d,p,c,null,q))})})}A(this,\"afterDrawDataLabels\")}function t(a,b,c,d,e,f){var g=this.chart,h=b.align,k=b.verticalAlign,l=a.box?0:a.padding||0,m=b.x;m=void 0===m?0:m;var n=b.y;\nn=void 0===n?0:n;var p=(c.x||0)+l;if(0>p){\"right\"===h&&0<=m?(b.align=\"left\",b.inside=!0):m-=p;var r=!0}p=(c.x||0)+d.width-l;p>g.plotWidth&&(\"left\"===h&&0>=m?(b.align=\"right\",b.inside=!0):m+=g.plotWidth-p,r=!0);p=c.y+l;0>p&&(\"bottom\"===k&&0<=n?(b.verticalAlign=\"top\",b.inside=!0):n-=p,r=!0);p=(c.y||0)+d.height-l;p>g.plotHeight&&(\"top\"===k&&0>=n?(b.verticalAlign=\"bottom\",b.inside=!0):n+=g.plotHeight-p,r=!0);r&&(b.x=m,b.y=n,a.placed=!f,a.align(b,void 0,e));return r}function z(a,b){var c=[],d;if(q(a)&&\n!q(b))c=a.map(function(a){return n(a,b)});else if(q(b)&&!q(a))c=b.map(function(b){return n(a,b)});else if(q(a)||q(b))for(d=Math.max(a.length,b.length);d--;)c[d]=n(a[d],b[d]);else c=n(a,b);return c}function C(a,b,c,d,e){var g=this.chart,f=g.inverted,h=this.xAxis,k=h.reversed,l=f?b.height/2:b.width/2;a=(a=a.pointWidth)?a/2:0;b.startXPos=f?e.x:k?-l-a:h.width-l+a;b.startYPos=f?k?this.yAxis.height-l+a:-l-a:e.y;d?\"hidden\"===b.visibility&&(b.show(),b.attr({opacity:0}).animate({opacity:1})):b.attr({opacity:1}).animate({opacity:0},\nvoid 0,b.hide);g.hasRendered&&(c&&b.attr({x:b.startXPos,y:b.startYPos}),b.placed=!0)}var r=[];a.compose=function(a){if(-1===r.indexOf(a)){var b=a.prototype;r.push(a);b.alignDataLabel=f;b.drawDataLabels=u;b.justifyDataLabel=t;b.setDataLabelStartPos=C}}})(h||(h={}));\"\";return h});M(a,\"Series/Column/ColumnDataLabel.js\",[a[\"Core/Series/DataLabel.js\"],a[\"Core/Series/SeriesRegistry.js\"],a[\"Core/Utilities.js\"]],function(a,u,z){var v=u.series,y=z.merge,G=z.pick,H;(function(u){function q(a,e,c,h,f){var k=\nthis.chart.inverted,n=a.series,q=(n.xAxis?n.xAxis.len:this.chart.plotSizeX)||0;n=(n.yAxis?n.yAxis.len:this.chart.plotSizeY)||0;var t=a.dlBox||a.shapeArgs,u=G(a.below,a.plotY>G(this.translatedThreshold,n)),C=G(c.inside,!!this.options.stacking);t&&(h=y(t),0>h.y&&(h.height+=h.y,h.y=0),t=h.y+h.height-n,0\\u25cf {series.name}
',\npointFormat:\"x: {point.x}
y: {point.y}
\"}});return n}(u);H(F.prototype,{drawTracker:a.prototype.drawTracker,sorted:!1,requireSorting:!1,noSharedTooltip:!0,trackerGroups:[\"group\",\"markerGroup\",\"dataLabelsGroup\"],takeOrdinalPosition:!1});G(F,\"afterTranslate\",function(){this.applyJitter()});z.registerSeriesType(\"scatter\",F);\"\";return F});M(a,\"Series/CenteredUtilities.js\",[a[\"Core/Globals.js\"],a[\"Core/Series/Series.js\"],a[\"Core/Utilities.js\"]],function(a,u,z){var v=a.deg2rad,y=z.isNumber,\nG=z.pick,H=z.relativeLength,A;(function(a){a.getCenter=function(){var a=this.options,k=this.chart,e=2*(a.slicedOffset||0),c=k.plotWidth-2*e,h=k.plotHeight-2*e,f=a.center,q=Math.min(c,h),p=a.size,v=a.innerSize||0;\"string\"===typeof p&&(p=parseFloat(p));\"string\"===typeof v&&(v=parseFloat(v));a=[G(f[0],\"50%\"),G(f[1],\"50%\"),G(p&&0>p?void 0:a.size,\"100%\"),G(v&&0>v?void 0:a.innerSize||0,\"0%\")];!k.angular||this instanceof u||(a[3]=0);for(f=0;4>f;++f)p=a[f],k=2>f||2===f&&/%$/.test(p),a[f]=H(p,[c,h,q,a[2]][f])+\n(k?e:0);a[3]>a[2]&&(a[3]=a[2]);return a};a.getStartAndEndRadians=function(a,k){a=y(a)?a:0;k=y(k)&&k>a&&360>k-a?k:a+360;return{start:v*(a+-90),end:v*(k+-90)}}})(A||(A={}));\"\";return A});M(a,\"Series/Pie/PiePoint.js\",[a[\"Core/Animation/AnimationUtilities.js\"],a[\"Core/Series/Point.js\"],a[\"Core/Utilities.js\"]],function(a,u,z){var v=this&&this.__extends||function(){var a=function(e,c){a=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(a,c){a.__proto__=c}||function(a,c){for(var e in c)c.hasOwnProperty(e)&&\n(a[e]=c[e])};return a(e,c)};return function(e,c){function h(){this.constructor=e}a(e,c);e.prototype=null===c?Object.create(c):(h.prototype=c.prototype,new h)}}(),y=a.setAnimation,G=z.addEvent,H=z.defined;a=z.extend;var A=z.isNumber,q=z.pick,n=z.relativeLength;u=function(a){function e(){var c=null!==a&&a.apply(this,arguments)||this;c.labelDistance=void 0;c.options=void 0;c.series=void 0;return c}v(e,a);e.prototype.getConnectorPath=function(){var a=this.labelPosition,e=this.series.options.dataLabels,\nf=this.connectorShapes,k=e.connectorShape;f[k]&&(k=f[k]);return k.call(this,{x:a.final.x,y:a.final.y,alignment:a.alignment},a.connectorPosition,e)};e.prototype.getTranslate=function(){return this.sliced?this.slicedTranslation:{translateX:0,translateY:0}};e.prototype.haloPath=function(a){var c=this.shapeArgs;return this.sliced||!this.visible?[]:this.series.chart.renderer.symbols.arc(c.x,c.y,c.r+a,c.r+a,{innerR:c.r-1,start:c.start,end:c.end})};e.prototype.init=function(){var c=this;a.prototype.init.apply(this,\narguments);this.name=q(this.name,\"Slice\");var e=function(a){c.slice(\"select\"===a.type)};G(this,\"select\",e);G(this,\"unselect\",e);return this};e.prototype.isValid=function(){return A(this.y)&&0<=this.y};e.prototype.setVisible=function(a,e){var c=this,h=this.series,k=h.chart,n=h.options.ignoreHiddenPoint;e=q(e,n);a!==this.visible&&(this.visible=this.options.visible=a=\"undefined\"===typeof a?!this.visible:a,h.options.data[h.data.indexOf(this)]=this.options,[\"graphic\",\"dataLabel\",\"connector\",\"shadowGroup\"].forEach(function(e){if(c[e])c[e][a?\n\"show\":\"hide\"](a)}),this.legendItem&&k.legend.colorizeItem(this,a),a||\"hover\"!==this.state||this.setState(\"\"),n&&(h.isDirty=!0),e&&k.redraw())};e.prototype.slice=function(a,e,f){var c=this.series;y(f,c.chart);q(e,!0);this.sliced=this.options.sliced=H(a)?a:!this.sliced;c.options.data[c.data.indexOf(this)]=this.options;this.graphic&&this.graphic.animate(this.getTranslate());this.shadowGroup&&this.shadowGroup.animate(this.getTranslate())};return e}(u);a(u.prototype,{connectorShapes:{fixedOffset:function(a,\ne,c){var h=e.breakAt;e=e.touchingSliceAt;return[[\"M\",a.x,a.y],c.softConnector?[\"C\",a.x+(\"left\"===a.alignment?-5:5),a.y,2*h.x-e.x,2*h.y-e.y,h.x,h.y]:[\"L\",h.x,h.y],[\"L\",e.x,e.y]]},straight:function(a,e){e=e.touchingSliceAt;return[[\"M\",a.x,a.y],[\"L\",e.x,e.y]]},crookedLine:function(a,e,c){e=e.touchingSliceAt;var h=this.series,f=h.center[0],k=h.chart.plotWidth,p=h.chart.plotLeft;h=a.alignment;var q=this.shapeArgs.r;c=n(c.crookDistance,1);k=\"left\"===h?f+q+(k+p-f-q)*(1-c):p+(f-q)*c;c=[\"L\",k,a.y];f=!0;if(\"left\"===\nh?k>a.x||ke.x)f=!1;a=[[\"M\",a.x,a.y]];f&&a.push(c);a.push([\"L\",e.x,e.y]);return a}}});return u});M(a,\"Series/Pie/PieSeries.js\",[a[\"Series/CenteredUtilities.js\"],a[\"Series/Column/ColumnSeries.js\"],a[\"Core/Globals.js\"],a[\"Core/Legend/LegendSymbol.js\"],a[\"Series/Pie/PiePoint.js\"],a[\"Core/Series/Series.js\"],a[\"Core/Series/SeriesRegistry.js\"],a[\"Core/Renderer/SVG/Symbols.js\"],a[\"Core/Utilities.js\"]],function(a,u,z,F,y,G,H,A,q){var n=this&&this.__extends||function(){var a=function(c,e){a=Object.setPrototypeOf||\n{__proto__:[]}instanceof Array&&function(a,c){a.__proto__=c}||function(a,c){for(var e in c)c.hasOwnProperty(e)&&(a[e]=c[e])};return a(c,e)};return function(c,e){function f(){this.constructor=c}a(c,e);c.prototype=null===e?Object.create(e):(f.prototype=e.prototype,new f)}}(),k=a.getStartAndEndRadians;z=z.noop;var e=q.clamp,c=q.extend,h=q.fireEvent,f=q.merge,v=q.pick,p=q.relativeLength;q=function(a){function c(){var c=null!==a&&a.apply(this,arguments)||this;c.center=void 0;c.data=void 0;c.maxLabelDistance=\nvoid 0;c.options=void 0;c.points=void 0;return c}n(c,a);c.prototype.animate=function(a){var c=this,e=c.points,f=c.startAngleRad;a||e.forEach(function(a){var b=a.graphic,d=a.shapeArgs;b&&d&&(b.attr({r:v(a.startR,c.center&&c.center[3]/2),start:f,end:f}),b.animate({r:d.r,start:d.start,end:d.end},c.options.animation))})};c.prototype.drawEmpty=function(){var a=this.startAngleRad,c=this.endAngleRad,e=this.options;if(0===this.total&&this.center){var f=this.center[0];var b=this.center[1];this.graph||(this.graph=\nthis.chart.renderer.arc(f,b,this.center[1]/2,0,a,c).addClass(\"highcharts-empty-series\").add(this.group));this.graph.attr({d:A.arc(f,b,this.center[2]/2,0,{start:a,end:c,innerR:this.center[3]/2})});this.chart.styledMode||this.graph.attr({\"stroke-width\":e.borderWidth,fill:e.fillColor||\"none\",stroke:e.color||\"#cccccc\"})}else this.graph&&(this.graph=this.graph.destroy())};c.prototype.drawPoints=function(){var a=this.chart.renderer;this.points.forEach(function(c){c.graphic&&c.hasNewShapeType()&&(c.graphic=\nc.graphic.destroy());c.graphic||(c.graphic=a[c.shapeType](c.shapeArgs).add(c.series.group),c.delayedRendering=!0)})};c.prototype.generatePoints=function(){a.prototype.generatePoints.call(this);this.updateTotals()};c.prototype.getX=function(a,c,f){var h=this.center,b=this.radii?this.radii[f.index]||0:h[2]/2;a=Math.asin(e((a-h[1])/(b+f.labelDistance),-1,1));return h[0]+(c?-1:1)*Math.cos(a)*(b+f.labelDistance)+(01.5*Math.PI?y-=2*Math.PI:y<-Math.PI/2&&(y+=2*Math.PI);u.slicedTranslation={translateX:Math.round(Math.cos(y)*e),translateY:Math.round(Math.sin(y)*e)};B=Math.cos(y)*a[2]/2;var A=Math.sin(y)*a[2]/2;u.tooltipPos=[a[0]+.7*B,a[1]+.7*A];u.half=y<-Math.PI/2||y>Math.PI/2?1:0;u.angle=y;w=Math.min(f,u.labelDistance/5);u.labelPosition={natural:{x:a[0]+B+\nMath.cos(y)*u.labelDistance,y:a[1]+A+Math.sin(y)*u.labelDistance},\"final\":{},alignment:0>u.labelDistance?\"center\":u.half?\"right\":\"left\",connectorPosition:{breakAt:{x:a[0]+B+Math.cos(y)*w,y:a[1]+A+Math.sin(y)*w},touchingSliceAt:{x:a[0]+B,y:a[1]+A}}}}h(this,\"afterTranslate\")};c.prototype.updateTotals=function(){var a=this.points,c=a.length,e=this.options.ignoreHiddenPoint,f,b=0;for(f=0;fv&&(a.dataLabel.css({width:Math.round(.7*\nv)+\"px\"}),a.dataLabel.shortened=!0)):(a.dataLabel=a.dataLabel.destroy(),a.dataLabels&&1===a.dataLabels.length&&delete a.dataLabels))}),C.forEach(function(e,f){var l=e.length,m=[],r;if(l){a.sortByAngle(e,f-.5);if(0h-d&&0===f&&(q=Math.round(N+M-h+d),y[1]=Math.max(q,y[1])),0>V-T/2?y[0]=Math.max(Math.round(-V+T/2),y[0]):V+T/2>n&&(y[2]=Math.max(Math.round(V+T/2-n),y[2])),\nJ.sideOverflow=q)}}}),0===q(y)||this.verifyDataLabelOverflow(y))&&(this.placeDataLabels(),this.points.forEach(function(d){R=e(g,d.options.dataLabels);if(F=c(R.connectorWidth,1)){var f;G=d.connector;if((J=d.dataLabel)&&J._pos&&d.visible&&0c.bottom-2?e:b,c.half,c)},justify:function(a,c,b){return b[0]+(a.half?-1:1)*(c+a.labelDistance)},alignToPlotEdges:function(a,c,b,e){a=a.getBBox().width;return c?a+e:b-a-e},alignToConnectors:function(a,c,b,e){var d=0,g;a.forEach(function(a){g=a.dataLabel.getBBox().width;g>d&&(d=g)});return c?d+e:b-d-e}};f.compose=function(c){a.compose(A);-1===w.indexOf(c)&&(w.push(c),c=c.prototype,c.dataLabelPositioners=C,c.alignDataLabel=\nv,c.drawDataLabels=p,c.placeDataLabels=u,c.verifyDataLabelOverflow=t)}})(f||(f={}));return f});M(a,\"Extensions/OverlappingDataLabels.js\",[a[\"Core/Chart/Chart.js\"],a[\"Core/Utilities.js\"]],function(a,u){function v(a,k){var e=!1;if(a){var c=a.newOpacity;a.oldOpacity!==c&&(a.alignAttr&&a.placed?(a[c?\"removeClass\":\"addClass\"](\"highcharts-data-label-hidden\"),e=!0,a.alignAttr.opacity=c,a[a.isOld?\"animate\":\"attr\"](a.alignAttr,null,function(){k.styledMode||a.css({pointerEvents:c?\"auto\":\"none\"})}),y(k,\"afterHideOverlappingLabel\")):\na.attr({opacity:c}));a.isOld=!0}return e}var F=u.addEvent,y=u.fireEvent,G=u.isArray,H=u.isNumber,A=u.objectEach,q=u.pick;F(a,\"render\",function(){var a=this,k=[];(this.labelCollectors||[]).forEach(function(a){k=k.concat(a())});(this.yAxis||[]).forEach(function(a){a.stacking&&a.options.stackLabels&&!a.options.stackLabels.allowOverlap&&A(a.stacking.stacks,function(a){A(a,function(a){a.label&&\"hidden\"!==a.label.visibility&&k.push(a.label)})})});(this.series||[]).forEach(function(e){var c=e.options.dataLabels;\ne.visible&&(!1!==c.enabled||e._hasPointLabels)&&(c=function(c){return c.forEach(function(c){c.visible&&(G(c.dataLabels)?c.dataLabels:c.dataLabel?[c.dataLabel]:[]).forEach(function(e){var f=e.options;e.labelrank=q(f.labelrank,c.labelrank,c.shapeArgs&&c.shapeArgs.height);f.allowOverlap?(e.oldOpacity=e.opacity,e.newOpacity=1,v(e,a)):k.push(e)})})},c(e.nodes||[]),c(e.points))});this.hideOverlappingLabels(k)});a.prototype.hideOverlappingLabels=function(a){var k=this,e=a.length,c=k.renderer,h,f,n,p=!1;\nvar q=function(a){var e,f=a.box?0:a.padding||0,b=e=0,g;if(a&&(!a.alignAttr||a.placed)){var d=a.alignAttr||{x:a.attr(\"x\"),y:a.attr(\"y\")};var h=a.parentGroup;a.width||(e=a.getBBox(),a.width=e.width,a.height=e.height,e=c.fontMetrics(null,a.element).h);var k=a.width-2*f;(g={left:\"0\",center:\"0.5\",right:\"1\"}[a.alignValue])?b=+g*k:H(a.x)&&Math.round(a.x)!==a.translateX&&(b=a.x-a.translateX);return{x:d.x+(h.translateX||0)+f-(b||0),y:d.y+(h.translateY||0)+f-e,width:a.width-2*f,height:a.height-2*f}}};for(f=\n0;f=t.x+t.width||u.x+u.width<=t.x||u.y>=t.y+t.height||u.y+u.height<=t.y||((q.labelrank=A(e.minWidth,0)&&this.chartHeight>=A(e.minHeight,0)}).call(this)&&c.push(a._id)};a.prototype.setResponsive=\nfunction(a,c){var e=this,f=this.options.responsive,h=this.currentResponsive,k=[];!c&&f&&f.rules&&f.rules.forEach(function(a){\"undefined\"===typeof a._id&&(a._id=n());e.matchResponsiveRule(a,k)},this);c=G.apply(void 0,k.map(function(a){return z((f||{}).rules||[],function(c){return c._id===a})}).map(function(a){return a&&a.chartOptions}));c.isResponsiveOptions=!0;k=k.toString()||void 0;k!==(h&&h.ruleIds)&&(h&&this.update(h.undoOptions,a,!0),k?(h=this.currentOptions(c),h.isResponsiveOptions=!0,this.currentResponsive=\n{ruleIds:k,mergedOptions:c,undoOptions:h},this.update(c,a,!0)):this.currentResponsive=void 0)};return a}()})(k||(k={}));\"\";\"\";return k});M(a,\"masters/highcharts.src.js\",[a[\"Core/Globals.js\"],a[\"Core/Utilities.js\"],a[\"Core/DefaultOptions.js\"],a[\"Core/Animation/Fx.js\"],a[\"Core/Animation/AnimationUtilities.js\"],a[\"Core/Renderer/HTML/AST.js\"],a[\"Core/FormatUtilities.js\"],a[\"Core/Renderer/RendererUtilities.js\"],a[\"Core/Renderer/SVG/SVGElement.js\"],a[\"Core/Renderer/SVG/SVGRenderer.js\"],a[\"Core/Renderer/HTML/HTMLElement.js\"],\na[\"Core/Renderer/HTML/HTMLRenderer.js\"],a[\"Core/Axis/Axis.js\"],a[\"Core/Axis/DateTimeAxis.js\"],a[\"Core/Axis/LogarithmicAxis.js\"],a[\"Core/Axis/PlotLineOrBand/PlotLineOrBand.js\"],a[\"Core/Axis/Tick.js\"],a[\"Core/Tooltip.js\"],a[\"Core/Series/Point.js\"],a[\"Core/Pointer.js\"],a[\"Core/MSPointer.js\"],a[\"Core/Legend/Legend.js\"],a[\"Core/Chart/Chart.js\"],a[\"Core/Series/Series.js\"],a[\"Core/Series/SeriesRegistry.js\"],a[\"Series/Column/ColumnSeries.js\"],a[\"Series/Column/ColumnDataLabel.js\"],a[\"Series/Pie/PieSeries.js\"],\na[\"Series/Pie/PieDataLabel.js\"],a[\"Core/Series/DataLabel.js\"],a[\"Core/Responsive.js\"],a[\"Core/Color/Color.js\"],a[\"Core/Time.js\"]],function(a,u,z,F,y,G,H,A,q,n,k,e,c,h,f,w,p,B,t,J,C,r,l,b,g,d,m,D,x,I,M,S,O){a.animate=y.animate;a.animObject=y.animObject;a.getDeferredAnimation=y.getDeferredAnimation;a.setAnimation=y.setAnimation;a.stop=y.stop;a.timers=F.timers;a.AST=G;a.Axis=c;a.Chart=l;a.chart=l.chart;a.Fx=F;a.Legend=r;a.PlotLineOrBand=w;a.Point=t;a.Pointer=C.isRequired()?C:J;a.Series=b;a.SVGElement=\nq;a.SVGRenderer=n;a.Tick=p;a.Time=O;a.Tooltip=B;a.Color=S;a.color=S.parse;e.compose(n);k.compose(q);a.defaultOptions=z.defaultOptions;a.getOptions=z.getOptions;a.time=z.defaultTime;a.setOptions=z.setOptions;a.dateFormat=H.dateFormat;a.format=H.format;a.numberFormat=H.numberFormat;a.addEvent=u.addEvent;a.arrayMax=u.arrayMax;a.arrayMin=u.arrayMin;a.attr=u.attr;a.clearTimeout=u.clearTimeout;a.correctFloat=u.correctFloat;a.createElement=u.createElement;a.css=u.css;a.defined=u.defined;a.destroyObjectProperties=\nu.destroyObjectProperties;a.discardElement=u.discardElement;a.distribute=A.distribute;a.erase=u.erase;a.error=u.error;a.extend=u.extend;a.extendClass=u.extendClass;a.find=u.find;a.fireEvent=u.fireEvent;a.getMagnitude=u.getMagnitude;a.getStyle=u.getStyle;a.inArray=u.inArray;a.isArray=u.isArray;a.isClass=u.isClass;a.isDOMElement=u.isDOMElement;a.isFunction=u.isFunction;a.isNumber=u.isNumber;a.isObject=u.isObject;a.isString=u.isString;a.keys=u.keys;a.merge=u.merge;a.normalizeTickInterval=u.normalizeTickInterval;\na.objectEach=u.objectEach;a.offset=u.offset;a.pad=u.pad;a.pick=u.pick;a.pInt=u.pInt;a.relativeLength=u.relativeLength;a.removeEvent=u.removeEvent;a.seriesType=g.seriesType;a.splat=u.splat;a.stableSort=u.stableSort;a.syncTimeout=u.syncTimeout;a.timeUnits=u.timeUnits;a.uniqueKey=u.uniqueKey;a.useSerialIds=u.useSerialIds;a.wrap=u.wrap;m.compose(d);I.compose(b);h.compose(c);f.compose(c);x.compose(D);w.compose(c);M.compose(l);return a});a[\"masters/highcharts.src.js\"]._modules=a;return a[\"masters/highcharts.src.js\"]});\n//# sourceMappingURL=highcharts.js.map","/*\n Highcharts JS v7.1.3 (2019-08-14)\n\n Accessibility module\n\n (c) 2010-2019 Highsoft AS\n Author: Oystein Moseng\n\n License: www.highcharts.com/license\n*/\n(function (f) { \"object\" === typeof module && module.exports ? (f[\"default\"] = f, module.exports = f) : \"function\" === typeof define && define.amd ? define(\"highcharts/modules/accessibility\", [\"highcharts\"], function (n) { f(n); f.Highcharts = n; return f }) : f(\"undefined\" !== typeof Highcharts ? Highcharts : void 0) })(function (f) {\r\n function n(c, f, l, h) { c.hasOwnProperty(f) || (c[f] = h.apply(null, l)) } f = f ? f._modules : {}; n(f, \"modules/accessibility/KeyboardNavigationHandler.js\", [f[\"parts/Globals.js\"]], function (c) {\r\n function f(c, b) {\r\n this.chart = c; this.keyCodeMap =\n b.keyCodeMap || []; this.validate = b.validate; this.init = b.init; this.terminate = b.terminate; this.response = { success: 1, prev: 2, next: 3, noHandler: 4, fail: 5 }\r\n } var l = c.find; f.prototype = { run: function (c) { var b = c.which || c.keyCode, a = this.response.noHandler, d = l(this.keyCodeMap, function (a) { return -1 < a[0].indexOf(b) }); d ? a = d[1].call(this, b, c) : 9 === b ? a = this.response[c.shiftKey ? \"prev\" : \"next\"] : 27 === b && (this.chart && this.chart.tooltip && this.chart.tooltip.hide(0), a = this.response.success); return a } }; return f\r\n }); n(f, \"modules/accessibility/AccessibilityComponent.js\",\n [f[\"parts/Globals.js\"]], function (c) {\r\n function f() { } var l = c.win, h = l.document, b = c.merge, a = c.addEvent; f.prototype = {\r\n initBase: function (a) { this.chart = a; this.eventRemovers = []; this.domElements = []; this.keyCodes = { left: 37, right: 39, up: 38, down: 40, enter: 13, space: 32, esc: 27, tab: 9 }; this.hiddenStyle = { position: \"absolute\", width: \"1px\", height: \"1px\", overflow: \"hidden\" } }, addEvent: function () { var a = c.addEvent.apply(c, arguments); this.eventRemovers.push(a); return a }, createElement: function () {\r\n var a = c.win.document.createElement.apply(c.win.document,\n arguments); this.domElements.push(a); return a\r\n }, cloneMouseEvent: function (a) { if (\"function\" === typeof l.MouseEvent) return new l.MouseEvent(a.type, a); if (h.createEvent) { var b = h.createEvent(\"MouseEvent\"); if (b.initMouseEvent) return b.initMouseEvent(a.type, \"click\" === a.type || a.canBubble, a.cancelable, a.view, a.detail, a.screenX, a.screenY, a.clientX, a.clientY, a.ctrlKey, a.altKey, a.shiftKey, a.metaKey, a.button, a.relatedTarget), b; b = h.createEvent(\"Event\"); if (b.initEvent) return b.initEvent(a.type, !0, !0), b } }, fakeClickEvent: function (a) {\r\n if (a &&\n a.onclick && h.createEvent) { var b = h.createEvent(\"Event\"); b.initEvent(\"click\", !0, !1); a.onclick(b) }\r\n }, createProxyButton: function (d, e, k, c, g) {\r\n var m = d.element, v = this, p = this.createElement(\"button\"), h = b({ \"aria-label\": m.getAttribute(\"aria-label\") }, k); if (d = this.getElementPosition(c || d)) return Object.keys(h).forEach(function (a) { null !== h[a] && p.setAttribute(a, h[a]) }), b(!0, p.style, {\r\n \"border-width\": 0, \"background-color\": \"transparent\", position: \"absolute\", width: (d.width || 1) + \"px\", height: (d.height || 1) + \"px\", display: \"block\",\n cursor: \"pointer\", overflow: \"hidden\", outline: \"none\", opacity: .001, filter: \"alpha(opacity=1)\", \"-ms-filter\": \"progid:DXImageTransform.Microsoft.Alpha(Opacity=1)\", zIndex: 999, padding: 0, margin: 0, left: d.x + \"px\", top: d.y - this.chart.chartHeight + \"px\"\r\n }), g && a(p, \"click\", g), [\"click\", \"mouseover\", \"mouseenter\", \"mouseleave\", \"mouseout\"].forEach(function (g) { a(p, g, function (a) { var b = v.cloneMouseEvent(a); if (m) if (b) m.fireEvent ? m.fireEvent(b) : m.dispatchEvent && m.dispatchEvent(b); else if (m[\"on\" + g]) m[\"on\" + g](a) }) }), e.appendChild(p),\n h[\"aria-hidden\"] || this.unhideElementFromScreenReaders(p), p\r\n }, getElementPosition: function (a) { var b = a.element; if ((a = this.chart.renderTo) && b && b.getBoundingClientRect) return b = b.getBoundingClientRect(), a = a.getBoundingClientRect(), { x: b.left - a.left, y: b.top - a.top, width: b.right - b.left, height: b.bottom - b.top } }, addProxyGroup: function (a) {\r\n var b = this.chart; b.a11yProxyContainer || (b.a11yProxyContainer = h.createElement(\"div\"), b.a11yProxyContainer.style.position = \"relative\"); b.container.nextSibling !== b.a11yProxyContainer &&\n b.renderTo.insertBefore(b.a11yProxyContainer, b.container.nextSibling); var d = this.createElement(\"div\"); Object.keys(a || {}).forEach(function (b) { null !== a[b] && d.setAttribute(b, a[b]) }); b.a11yProxyContainer.appendChild(d); return d\r\n }, removeElement: function (a) { a && a.parentNode && a.parentNode.removeChild(a) }, unhideElementFromScreenReaders: function (a) {\r\n a.setAttribute(\"aria-hidden\", !1); a !== this.chart.renderTo && a.parentNode && (Array.prototype.forEach.call(a.parentNode.childNodes, function (a) {\r\n a.hasAttribute(\"aria-hidden\") ||\n a.setAttribute(\"aria-hidden\", !0)\r\n }), this.unhideElementFromScreenReaders(a.parentNode))\r\n }, destroyBase: function () { var a = this; this.removeElement((this.chart || {}).a11yProxyContainer); this.eventRemovers.forEach(function (a) { a() }); this.domElements.forEach(function (b) { a.removeElement(b) }); this.eventRemovers = []; this.domElements = [] }, stripTags: function (a) { return \"string\" === typeof a ? a.replace(/<\\/?[^>]+(>|$)/g, \"\") : a }, htmlencode: function (a) {\r\n return a.replace(/&/g, \"&\").replace(//g, \">\").replace(/\"/g,\n \""\").replace(/'/g, \"'\").replace(/\\//g, \"/\")\r\n }, init: function () { }, getKeyboardNavigation: function () { }, onChartUpdate: function () { }, onChartRender: function () { }, destroy: function () { this.destroyBase() }\r\n }; return f\r\n }); n(f, \"modules/accessibility/KeyboardNavigation.js\", [f[\"parts/Globals.js\"], f[\"modules/accessibility/KeyboardNavigationHandler.js\"]], function (c, f) {\r\n function l(a, b, d) { this.init(a, b, d) } var h = c.merge, b = c.addEvent, a = c.win, d = a.document; l.prototype = {\r\n init: function (a, k) {\r\n var e = this; this.chart = a; this.components =\n k; this.modules = []; this.currentModuleIx = 0; a.container.hasAttribute(\"tabIndex\") || a.container.setAttribute(\"tabindex\", \"0\"); this.addExitAnchor(); this.unbindKeydownHandler = b(a.renderTo, \"keydown\", function (a) { e.onKeydown(a) }); this.unbindMouseUpHandler = b(d, \"mouseup\", function () { e.onMouseUp() }); this.update(); this.modules.length && this.modules[0].init(1)\r\n }, update: function (a) {\r\n var b = this.chart.options.accessibility; b = b && b.keyboardNavigation; var d = this.components; b && b.enabled && a && a.length ? this.modules = a.reduce(function (a,\n b) { b = d[b].getKeyboardNavigation(); return b.length ? a.concat(b) : (a.push(b), a) }, [new f(this.chart, {})]) : (this.modules = [], this.currentModuleIx = 0)\r\n }, onMouseUp: function () { if (!(this.keyboardReset || this.chart.pointer && this.chart.pointer.chartPosition)) { var a = this.chart, b = this.modules && this.modules[this.currentModuleIx || 0]; b && b.terminate && b.terminate(); a.focusElement && a.focusElement.removeFocusBorder(); this.currentModuleIx = 0; this.keyboardReset = !0 } }, onKeydown: function (b) {\r\n b = b || a.event; var d, e = this.modules && this.modules.length &&\n this.modules[this.currentModuleIx]; this.keyboardReset = !1; if (e) { var g = e.run(b); g === e.response.success ? d = !0 : g === e.response.prev ? d = this.prev() : g === e.response.next && (d = this.next()); d && b.preventDefault() }\r\n }, prev: function () { return this.move(-1) }, next: function () { return this.move(1) }, move: function (a) {\r\n var b = this.modules && this.modules[this.currentModuleIx]; b && b.terminate && b.terminate(a); this.chart.focusElement && this.chart.focusElement.removeFocusBorder(); this.currentModuleIx += a; if (b = this.modules && this.modules[this.currentModuleIx]) {\r\n if (b.validate &&\n !b.validate()) return this.move(a); if (b.init) return b.init(a), !0\r\n } this.currentModuleIx = 0; 0 < a ? (this.exiting = !0, this.exitAnchor.focus()) : this.chart.renderTo.focus(); return !1\r\n }, addExitAnchor: function () {\r\n var e = this.chart, k = this.exitAnchorWrapper = d.createElement(\"div\"), c = this.exitAnchor = d.createElement(\"h6\"), g = this, m = e.langFormat(\"accessibility.svgContainerEnd\", { chart: e }); c.innerHTML = m; k.setAttribute(\"aria-hidden\", \"false\"); k.setAttribute(\"class\", \"highcharts-exit-anchor-wrapper\"); k.style.position = \"relative\";\n k.style.outline = \"none\"; c.setAttribute(\"tabindex\", \"0\"); c.setAttribute(\"aria-hidden\", !1); h(!0, c.style, { position: \"absolute\", width: \"1px\", height: \"1px\", bottom: \"5px\", zIndex: 0, overflow: \"hidden\", outline: \"none\" }); k.appendChild(c); e.renderTo.appendChild(k); this.unbindExitAnchorUpdate = b(e, \"render\", function () { this.renderTo.appendChild(k) }); this.unbindExitAnchorFocus = b(c, \"focus\", function (b) {\r\n b = b || a.event; g.exiting ? g.exiting = !1 : (e.renderTo.focus(), b.preventDefault(), g.modules && g.modules.length && (g.currentModuleIx =\n g.modules.length - 1, (b = g.modules[g.currentModuleIx]) && b.validate && !b.validate() ? g.prev() : b && b.init(-1)))\r\n })\r\n }, destroy: function () {\r\n this.unbindExitAnchorFocus && (this.unbindExitAnchorFocus(), delete this.unbindExitAnchorFocus); this.unbindExitAnchorUpdate && (this.unbindExitAnchorUpdate(), delete this.unbindExitAnchorUpdate); this.exitAnchorWrapper && this.exitAnchorWrapper.parentNode && (this.exitAnchorWrapper.parentNode.removeChild(this.exitAnchorWrapper), delete this.exitAnchor, delete this.exitAnchorWrapper); this.unbindKeydownHandler &&\n this.unbindKeydownHandler(); this.unbindMouseUpHandler && this.unbindMouseUpHandler()\r\n }\r\n }; return l\r\n }); n(f, \"modules/accessibility/components/LegendComponent.js\", [f[\"parts/Globals.js\"], f[\"modules/accessibility/AccessibilityComponent.js\"], f[\"modules/accessibility/KeyboardNavigationHandler.js\"]], function (c, f, l) {\r\n c.Chart.prototype.highlightLegendItem = function (b) {\r\n var a = this.legend.allItems, d = this.highlightedLegendItemIx; return a[b] ? (a[d] && c.fireEvent(a[d].legendGroup.element, \"mouseout\"), void 0 !== a[b].pageIx &&\n a[b].pageIx + 1 !== this.legend.currentPage && this.legend.scroll(1 + a[b].pageIx - this.legend.currentPage), this.setFocusToElement(a[b].legendItem, a[b].a11yProxyElement), c.fireEvent(a[b].legendGroup.element, \"mouseover\"), !0) : !1\r\n }; c.addEvent(c.Legend, \"afterColorizeItem\", function (b) { var a = b.item; this.chart.options.accessibility.enabled && a && a.a11yProxyElement && a.a11yProxyElement.setAttribute(\"aria-pressed\", b.visible ? \"false\" : \"true\") }); var h = function (b) { this.initBase(b) }; h.prototype = new f; c.extend(h.prototype, {\r\n onChartRender: function () {\r\n var b =\n this.chart, a = b.options.accessibility, d = b.legend && b.legend.allItems, e = this; e.legendProxyButtonClicked ? delete e.legendProxyButtonClicked : (this.removeElement(this.legendProxyGroup), !d || !d.length || b.colorAxis && b.colorAxis.length || !b.options.legend.accessibility.enabled || (this.legendProxyGroup = this.addProxyGroup({ \"aria-label\": b.langFormat(\"accessibility.legendLabel\"), role: \"all\" === a.landmarkVerbosity ? \"region\" : null }), d.forEach(function (a) {\r\n a.legendItem && a.legendItem.element && (a.a11yProxyElement = e.createProxyButton(a.legendItem,\n e.legendProxyGroup, { tabindex: -1, \"aria-pressed\": !a.visible, \"aria-label\": b.langFormat(\"accessibility.legendItem\", { chart: b, itemName: e.stripTags(a.name) }) }, a.legendGroup.div ? a.legendItem : a.legendGroup, function () { e.legendProxyButtonClicked = !0 }))\r\n })))\r\n }, getKeyboardNavigation: function () {\r\n var b = this.keyCodes, a = this, d = this.chart, e = d.options.accessibility; return new l(d, {\r\n keyCodeMap: [[[b.left, b.right, b.up, b.down], function (k) {\r\n k = k === b.left || k === b.up ? -1 : 1; return d.highlightLegendItem(a.highlightedLegendItemIx + k) ?\n (a.highlightedLegendItemIx += k, this.response.success) : 1 < d.legend.allItems.length && e.keyboardNavigation.wrapAround ? (this.init(k), this.response.success) : this.response[0 < k ? \"next\" : \"prev\"]\r\n }], [[b.enter, b.space], function () { var b = d.legend.allItems[a.highlightedLegendItemIx]; b && b.a11yProxyElement && c.fireEvent(b.a11yProxyElement, \"click\"); return this.response.success }]], validate: function () {\r\n var a = d.options.legend; return d.legend && d.legend.allItems && d.legend.display && !(d.colorAxis && d.colorAxis.length) && a && a.accessibility &&\n a.accessibility.enabled && a.accessibility.keyboardNavigation && a.accessibility.keyboardNavigation.enabled\r\n }, init: function (b) { b = 0 < b ? 0 : d.legend.allItems.length - 1; d.highlightLegendItem(b); a.highlightedLegendItemIx = b }\r\n })\r\n }\r\n }); return h\r\n }); n(f, \"modules/accessibility/components/MenuComponent.js\", [f[\"parts/Globals.js\"], f[\"modules/accessibility/AccessibilityComponent.js\"], f[\"modules/accessibility/KeyboardNavigationHandler.js\"]], function (c, f, l) {\r\n c.Chart.prototype.showExportMenu = function () {\r\n this.exportSVGElements && this.exportSVGElements[0] &&\n (this.exportSVGElements[0].element.onclick(), this.highlightExportItem(0))\r\n }; c.Chart.prototype.hideExportMenu = function () { var b = this.exportDivElements; b && this.exportContextMenu && (b.forEach(function (a) { if (\"highcharts-menu-item\" === a.className && a.onmouseout) a.onmouseout() }), this.highlightedExportItemIx = 0, this.exportContextMenu.hideMenu(), this.container.focus()) }; c.Chart.prototype.highlightExportItem = function (b) {\r\n var a = this.exportDivElements && this.exportDivElements[b], d = this.exportDivElements && this.exportDivElements[this.highlightedExportItemIx];\n if (a && \"DIV\" === a.tagName && (!a.children || !a.children.length)) { var e = !!(this.renderTo.getElementsByTagName(\"g\")[0] || {}).focus; a.focus && e && a.focus(); if (d && d.onmouseout) d.onmouseout(); if (a.onmouseover) a.onmouseover(); this.highlightedExportItemIx = b; return !0 }\r\n }; c.Chart.prototype.highlightLastExportItem = function () { var b; if (this.exportDivElements) for (b = this.exportDivElements.length; b--;)if (this.highlightExportItem(b)) return !0; return !1 }; var h = function (b) { this.initBase(b); this.init() }; h.prototype = new f; c.extend(h.prototype,\n {\r\n init: function () { this.addEvent(this.chart, \"exportMenuHidden\", function () { var b = this.exportContextMenu; b && b.setAttribute(\"aria-hidden\", !0) }) }, onChartRender: function () {\r\n var b = this, a = this.chart, d = a.options.accessibility; this.removeElement(this.exportProxyGroup); if (a.options.exporting && !1 !== a.options.exporting.enabled && a.options.exporting.accessibility && a.options.exporting.accessibility.enabled && a.exportSVGElements && a.exportSVGElements[0] && a.exportSVGElements[0].element) {\r\n var e = a.exportSVGElements[0], k =\n e.element, c = k.onclick; this.wrappedButton !== k && (k.onclick = function () { c.apply(this, Array.prototype.slice.call(arguments)); b.addAccessibleContextMenuAttribs(); a.highlightExportItem(0) }, this.wrappedButton = k); this.exportProxyGroup = this.addProxyGroup(\"all\" === d.landmarkVerbosity ? { \"aria-label\": a.langFormat(\"accessibility.exporting.exportRegionLabel\", { chart: a }), role: \"region\" } : null); this.exportButtonProxy = this.createProxyButton(e, this.exportProxyGroup, {\r\n \"aria-label\": a.langFormat(\"accessibility.exporting.menuButtonLabel\",\n { chart: a })\r\n })\r\n }\r\n }, addAccessibleContextMenuAttribs: function () { var b = this.chart, a = b.exportDivElements, d = b.exportContextMenu; a && a.length && (a.forEach(function (a) { \"DIV\" !== a.tagName || a.children && a.children.length || (a.setAttribute(\"role\", \"menuitem\"), a.setAttribute(\"tabindex\", -1)) }), a[0].parentNode.setAttribute(\"role\", \"menu\"), a[0].parentNode.setAttribute(\"aria-label\", b.langFormat(\"accessibility.exporting.chartMenuLabel\", { chart: b }))); d && this.unhideElementFromScreenReaders(d) }, getKeyboardNavigation: function () {\r\n var b =\n this.keyCodes, a = this.chart, d = a.options.accessibility, e = this; return new l(a, {\r\n keyCodeMap: [[[b.left, b.up], function () { for (var b = a.highlightedExportItemIx || 0; b--;)if (a.highlightExportItem(b)) return this.response.success; return d.keyboardNavigation.wrapAround ? (a.highlightLastExportItem(), this.response.success) : this.response.prev }], [[b.right, b.down], function () {\r\n for (var b = (a.highlightedExportItemIx || 0) + 1; b < a.exportDivElements.length; ++b)if (a.highlightExportItem(b)) return this.response.success; return d.keyboardNavigation.wrapAround ?\n (a.highlightExportItem(0), this.response.success) : this.response.next\r\n }], [[b.enter, b.space], function () { e.fakeClickEvent(a.exportDivElements[a.highlightedExportItemIx]); return this.response.success }], [[b.esc], function () { return this.response.prev }]], validate: function () { return a.exportChart && !1 !== a.options.exporting.enabled && !1 !== a.options.exporting.accessibility.enabled }, init: function (b) { a.showExportMenu(); 0 > b && a.highlightLastExportItem() }, terminate: function () { a.hideExportMenu() }\r\n })\r\n }\r\n }); return h\r\n }); n(f, \"modules/accessibility/components/SeriesComponent.js\",\n [f[\"parts/Globals.js\"], f[\"parts/Utilities.js\"], f[\"modules/accessibility/AccessibilityComponent.js\"], f[\"modules/accessibility/KeyboardNavigationHandler.js\"]], function (c, f, l, h) {\r\n function b(a) { var b = a.index, g = a.series.points, d = g.length; if (g[b] !== a) for (; d--;) { if (g[d] === a) return d } else return b } function a(a) {\r\n var b = a.chart.options.accessibility, g = a.options.accessibility || {}, d = g.keyboardNavigation; return d && !1 === d.enabled || !1 === g.enabled || !1 === a.options.enableMouseTracking || !a.visible || b.pointNavigationThreshold &&\n b.pointNavigationThreshold <= a.points.length\r\n } function d(b) { var g = b.series.chart.options.accessibility; return b.isNull && g.keyboardNavigation.skipNullPoints || !1 === b.visible || a(b.series) } var e = f.isNumber, k = c.merge, t = c.pick; c.Series.prototype.keyboardMoveVertical = !0;[\"column\", \"pie\"].forEach(function (a) { c.seriesTypes[a] && (c.seriesTypes[a].prototype.keyboardMoveVertical = !1) }); c.addEvent(c.Series, \"render\", function () {\r\n var a = this.options, b = this.chart.options.accessibility || {}, d = this.points || [], e = d.length, c =\n this.resetA11yMarkerOptions; if (b.enabled && !1 !== (a.accessibility && a.accessibility.enabled) && (e < b.pointDescriptionThreshold || !1 === b.pointDescriptionThreshold || e < b.pointNavigationThreshold || !1 === b.pointNavigationThreshold)) {\r\n if (a.marker && !1 === a.marker.enabled && (this.a11yMarkersForced = !0, k(!0, this.options, { marker: { enabled: !0, states: { normal: { opacity: 0 } } } })), this._hasPointMarkers && this.points && this.points.length) for (a = e; a--;)b = d[a].options, b.marker && (b.marker.enabled ? k(!0, b.marker, {\r\n states: {\r\n normal: {\r\n opacity: b.marker.states &&\n b.marker.states.normal && b.marker.states.normal.opacity || 1\r\n }\r\n }\r\n }) : k(!0, b.marker, { enabled: !0, states: { normal: { opacity: 0 } } }))\r\n } else this.a11yMarkersForced && c && (delete this.a11yMarkersForced, k(!0, this.options, { marker: { enabled: c.enabled, states: { normal: { opacity: c.states && c.states.normal && c.states.normal.opacity } } } }))\r\n }); c.addEvent(c.Series, \"afterSetOptions\", function (a) { this.resetA11yMarkerOptions = k(a.options.marker || {}, this.userOptions.marker || {}) }); c.Point.prototype.highlight = function () {\r\n var a = this.series.chart;\n if (this.isNull) a.tooltip && a.tooltip.hide(0); else this.onMouseOver(); this.graphic && a.setFocusToElement(this.graphic); a.highlightedPoint = this; return this\r\n }; c.Chart.prototype.highlightAdjacentPoint = function (g) {\r\n var m = this.series, e = this.highlightedPoint, c = e && b(e) || 0, k = e && e.series.points, h = this.series && this.series[this.series.length - 1]; h = h && h.points && h.points[h.points.length - 1]; if (!m[0] || !m[0].points) return !1; if (e) {\r\n if (m = m[e.series.index + (g ? 1 : -1)], c = k[c + (g ? 1 : -1)], !c && m && (c = m.points[g ? 0 : m.points.length - 1]),\n !c) return !1\r\n } else c = g ? m[0].points[0] : h; return d(c) ? (m = c.series, a(m) ? this.highlightedPoint = g ? m.points[m.points.length - 1] : m.points[0] : this.highlightedPoint = c, this.highlightAdjacentPoint(g)) : c.highlight()\r\n }; c.Series.prototype.highlightFirstValidPoint = function () { var a = this.chart.highlightedPoint, e = (a && a.series) === this ? b(a) : 0; a = this.points; var c = a.length; if (a && c) { for (var k = e; k < c; ++k)if (!d(a[k])) return a[k].highlight(); for (; 0 <= e; --e)if (!d(a[e])) return a[e].highlight() } return !1 }; c.Chart.prototype.highlightAdjacentSeries =\n function (b) {\r\n var g, d, e = this.highlightedPoint, c = (g = this.series && this.series[this.series.length - 1]) && g.points && g.points[g.points.length - 1]; if (!this.highlightedPoint) return g = b ? this.series && this.series[0] : g, (d = b ? g && g.points && g.points[0] : c) ? d.highlight() : !1; g = this.series[e.series.index + (b ? -1 : 1)]; if (!g) return !1; c = Infinity; var k = g.points.length; if (void 0 === e.plotX || void 0 === e.plotY) d = void 0; else {\r\n for (; k--;) {\r\n var h = g.points[k]; void 0 !== h.plotX && void 0 !== h.plotY && (h = (e.plotX - h.plotX) * (e.plotX - h.plotX) * 4 + (e.plotY -\n h.plotY) * (e.plotY - h.plotY), h < c && (c = h, d = k))\r\n } d = void 0 !== d && g.points[d]\r\n } if (!d) return !1; if (a(g)) return d.highlight(), b = this.highlightAdjacentSeries(b), b ? b : (e.highlight(), !1); d.highlight(); return d.series.highlightFirstValidPoint()\r\n }; c.Chart.prototype.highlightAdjacentPointVertical = function (b) {\r\n var g = this.highlightedPoint, e = Infinity, c; if (void 0 === g.plotX || void 0 === g.plotY) return !1; this.series.forEach(function (m) {\r\n a(m) || m.points.forEach(function (a) {\r\n if (void 0 !== a.plotY && void 0 !== a.plotX && a !== g) {\r\n var k = a.plotY -\n g.plotY, h = Math.abs(a.plotX - g.plotX); h = Math.abs(k) * Math.abs(k) + h * h * 4; m.yAxis.reversed && (k *= -1); !(0 >= k && b || 0 <= k && !b || 5 > h || d(a)) && h < e && (e = h, c = a)\r\n }\r\n })\r\n }); return c ? c.highlight() : !1\r\n }; c.Point.prototype.getA11yTimeDescription = function () {\r\n var a = this.series, b = a.chart, d = b.options.accessibility; if (a.xAxis && a.xAxis.isDatetimeAxis) return b.time.dateFormat(d.pointDateFormatter && d.pointDateFormatter(this) || d.pointDateFormat || c.Tooltip.prototype.getXDateFormat.call({ getDateFormat: c.Tooltip.prototype.getDateFormat, chart: b },\n this, b.options.tooltip, a.xAxis), this.x)\r\n }; f = function (a) { this.initBase(a); this.init() }; f.prototype = new l; c.extend(f.prototype, {\r\n init: function () {\r\n var a = this; this.addEvent(c.Series, \"destroy\", function () { var b = this.chart; b === a.chart && b.highlightedPoint && b.highlightedPoint.series === this && (delete b.highlightedPoint, b.focusElement && b.focusElement.removeFocusBorder()) }); this.addEvent(c.Tooltip, \"refresh\", function () {\r\n this.chart === a.chart && this.label && this.label.element && this.label.element.setAttribute(\"aria-hidden\",\n !0)\r\n }); this.addEvent(this.chart, \"afterDrawSeriesLabels\", function () { this.series.forEach(function (a) { a.labelBySeries && a.labelBySeries.attr(\"aria-hidden\", !0) }) }); this.initAnnouncer()\r\n }, onChartRender: function () { var a = this; this.chart.series.forEach(function (b) { a[!1 !== (b.options.accessibility && b.options.accessibility.enabled) && b.visible ? \"addSeriesDescription\" : \"hideSeriesFromScreenReader\"](b) }) }, getKeyboardNavigation: function () {\r\n var a = this.keyCodes, b = this.chart, d = b.inverted, e = b.options.accessibility, c = function (a) {\r\n return b.highlightAdjacentPoint(a) ?\n this.response.success : e.keyboardNavigation.wrapAround ? this.init(a ? 1 : -1) : this.response[a ? \"next\" : \"prev\"]\r\n }; return new h(b, {\r\n keyCodeMap: [[[d ? a.up : a.left, d ? a.down : a.right], function (b) { return c.call(this, b === a.right || b === a.down) }], [[d ? a.left : a.up, d ? a.right : a.down], function (d) {\r\n d = d === a.down || d === a.right; var g = e.keyboardNavigation; if (g.mode && \"serialize\" === g.mode) return c.call(this, d); b[b.highlightedPoint && b.highlightedPoint.series.keyboardMoveVertical ? \"highlightAdjacentPointVertical\" : \"highlightAdjacentSeries\"](d);\n return this.response.success\r\n }], [[a.enter, a.space], function () { b.highlightedPoint && b.highlightedPoint.firePointEvent(\"click\") }]], init: function (a) { var d = b.series.length, g = 0 < a ? 0 : d; if (0 < a) for (delete b.highlightedPoint; g < d && !(a = b.series[g].highlightFirstValidPoint());)++g; else for (; g-- && !(b.highlightedPoint = b.series[g].points[b.series[g].points.length - 1], a = b.series[g].highlightFirstValidPoint());); return this.response.success }, terminate: function () { b.tooltip && b.tooltip.hide(0); delete b.highlightedPoint }\r\n })\r\n },\n isPointClickable: function (a) { var b = a.series.options || {}; b = b.point && b.point.events; return a && a.graphic && a.graphic.element && (a.hcEvents && a.hcEvents.click || b && b.click || a.options && a.options.events && a.options.events.click) }, initAnnouncer: function () {\r\n var a = this.chart, b = a.options.accessibility, d = this; this.lastAnnouncementTime = 0; this.dirty = { allSeries: {} }; this.announceRegion = this.createElement(\"div\"); this.announceRegion.setAttribute(\"aria-hidden\", !1); this.announceRegion.setAttribute(\"aria-live\", b.announceNewData.interruptUser ?\n \"assertive\" : \"polite\"); k(!0, this.announceRegion.style, this.hiddenStyle); a.renderTo.insertBefore(this.announceRegion, a.renderTo.firstChild); this.addEvent(this.chart, \"afterDrilldown\", function () { a.highlightedPoint = null; if (a.options.accessibility.announceNewData.enabled) { if (this.series && this.series.length) { var b = d.getSeriesElement(this.series[0]); b.focus && b.getAttribute(\"aria-label\") ? b.focus() : this.series[0].highlightFirstValidPoint() } d.lastAnnouncementTime = 0; a.focusElement && a.focusElement.removeFocusBorder() } });\n this.addEvent(c.Series, \"updatedData\", function () { this.chart === a && this.chart.options.accessibility.announceNewData.enabled && (d.dirty.hasDirty = !0, d.dirty.allSeries[this.name + this.index] = this) }); this.addEvent(a, \"afterAddSeries\", function (a) { this.options.accessibility.announceNewData.enabled && (a = a.series, d.dirty.hasDirty = !0, d.dirty.allSeries[a.name + a.index] = a, d.dirty.newSeries = void 0 === d.dirty.newSeries ? a : null) }); this.addEvent(c.Series, \"addPoint\", function (b) {\r\n this.chart === a && this.chart.options.accessibility.announceNewData.enabled &&\n (d.dirty.newPoint = void 0 === d.dirty.newPoint ? b.point : null)\r\n }); this.addEvent(a, \"redraw\", function () { if (this.options.accessibility.announceNewData && d.dirty.hasDirty) { var a = d.dirty.newPoint; if (a) { var b = a.series.data.filter(function (b) { return b.x === a.x && b.y === a.y }); a = 1 === b.length ? b[0] : a } d.announceNewData(Object.keys(d.dirty.allSeries).map(function (a) { return d.dirty.allSeries[a] }), d.dirty.newSeries, a); d.dirty = { allSeries: {} } } })\r\n }, announceNewData: function (a, b, d) {\r\n var e = this.chart.options.accessibility.announceNewData;\n if (e.enabled) {\r\n var g = this, c = +new Date; e = Math.max(0, e.minAnnounceInterval - (c - this.lastAnnouncementTime)); if (this.queuedAnnouncement) { var k = (this.queuedAnnouncement.series || []).concat(a).reduce(function (a, b) { a[b.name + b.index] = b; return a }, {}); a = Object.keys(k).map(function (a) { return k[a] }) } else a = [].concat(a); if (b = this.buildAnnouncementMessage(a, b, d)) this.queuedAnnouncement && clearTimeout(this.queuedAnnouncementTimer), this.queuedAnnouncement = { time: c, message: b, series: a }, g.queuedAnnouncementTimer = setTimeout(function () {\r\n g &&\n g.announceRegion && (g.lastAnnouncementTime = +new Date, g.announceRegion.innerHTML = g.queuedAnnouncement.message, g.clearAnnouncementContainerTimer && clearTimeout(g.clearAnnouncementContainerTimer), g.clearAnnouncementContainerTimer = setTimeout(function () { g.announceRegion.innerHTML = \"\"; delete g.clearAnnouncementContainerTimer }, 1E3), delete g.queuedAnnouncement, delete g.queuedAnnouncementTimer)\r\n }, e)\r\n }\r\n }, buildAnnouncementMessage: function (a, b, d) {\r\n var e = this.chart, g = e.options.accessibility.announceNewData; if (g.announcementFormatter &&\n (a = g.announcementFormatter(a, b, d), !1 !== a)) return a.length ? a : null; a = c.charts && 1 < c.charts.length ? \"Multiple\" : \"Single\"; return e.langFormat(\"accessibility.announceNewData.\" + (b ? \"newSeriesAnnounce\" + a : d ? \"newPointAnnounce\" + a : \"newDataAnnounce\"), { chartTitle: this.stripTags(e.options.title.text || e.langFormat(\"accessibility.defaultChartTitle\", { chart: e })), seriesDesc: b ? this.defaultSeriesDescriptionFormatter(b) : null, pointDesc: d ? this.defaultPointDescriptionFormatter(d) : null, point: d, series: b })\r\n }, reverseChildNodes: function (a) {\r\n for (var b =\n a.childNodes.length; b--;)a.appendChild(a.childNodes[b])\r\n }, getSeriesFirstPointElement: function (a) { return a.points && a.points.length && a.points[0].graphic && a.points[0].graphic.element }, getSeriesElement: function (a) { var b = this.getSeriesFirstPointElement(a); return b && b.parentNode || a.graph && a.graph.element || a.group && a.group.element }, hideSeriesFromScreenReader: function (a) { (a = this.getSeriesElement(a)) && a.setAttribute(\"aria-hidden\", !0) }, addSeriesDescription: function (a) {\r\n var b = this, d = a.chart, e = d.options.accessibility,\n g = a.options.accessibility || {}, c = b.getSeriesFirstPointElement(a), k = b.getSeriesElement(a), h = a.points && (a.points.length < e.pointDescriptionThreshold || !1 === e.pointDescriptionThreshold) && !g.exposeAsGroupOnly, f = a.points && (a.points.length < e.pointNavigationThreshold || !1 === e.pointNavigationThreshold); k && (k.lastChild === c && b.reverseChildNodes(k), b.unhideElementFromScreenReaders(k), (h || f) && a.points.forEach(function (a) {\r\n var d = a.graphic && a.graphic.element; d && (d.setAttribute(\"tabindex\", \"-1\"), h ? (d.setAttribute(\"role\",\n \"img\"), d.setAttribute(\"aria-label\", b.stripTags(g.pointDescriptionFormatter && g.pointDescriptionFormatter(a) || e.pointDescriptionFormatter && e.pointDescriptionFormatter(a) || b.defaultPointDescriptionFormatter(a)))) : d.setAttribute(\"aria-hidden\", !0))\r\n }), 1 < d.series.length || e.describeSingleSeries ? (g.exposeAsGroupOnly ? k.setAttribute(\"role\", \"img\") : \"all\" === e.landmarkVerbosity && k.setAttribute(\"role\", \"region\"), k.setAttribute(\"tabindex\", \"-1\"), k.setAttribute(\"aria-label\", b.stripTags(e.seriesDescriptionFormatter &&\n e.seriesDescriptionFormatter(a) || b.defaultSeriesDescriptionFormatter(a)))) : k.setAttribute(\"aria-label\", \"\"))\r\n }, defaultSeriesDescriptionFormatter: function (a) {\r\n var b = a.chart, d = (a.options.accessibility || {}).description; d = d && b.langFormat(\"accessibility.series.description\", { description: d, series: a }); var e = b.langFormat(\"accessibility.series.xAxisDescription\", { name: a.xAxis && a.xAxis.getDescription(), series: a }), c = b.langFormat(\"accessibility.series.yAxisDescription\", { name: a.yAxis && a.yAxis.getDescription(), series: a }),\n g = { name: a.name || \"\", ix: a.index + 1, numSeries: b.series && b.series.length, numPoints: a.points && a.points.length, series: a }, k = b.types && 1 < b.types.length ? \"Combination\" : \"\"; return (b.langFormat(\"accessibility.series.summary.\" + a.type + k, g) || b.langFormat(\"accessibility.series.summary.default\" + k, g)) + (d ? \" \" + d : \"\") + (b.yAxis && 1 < b.yAxis.length && this.yAxis ? \" \" + c : \"\") + (b.xAxis && 1 < b.xAxis.length && this.xAxis ? \" \" + e : \"\")\r\n }, defaultPointDescriptionFormatter: function (a) {\r\n var b = a.series, d = b.chart, k = d.options.accessibility, g = a.series.tooltipOptions ||\n {}, h = k.pointValuePrefix || g.valuePrefix || \"\", f = k.pointValueSuffix || g.valueSuffix || \"\", l = a.options && a.options.accessibility && a.options.accessibility.description, n = a.getA11yTimeDescription(), r = function (a) { if (e(a)) { var b = c.defaultOptions.lang; return c.numberFormat(a, k.pointValueDecimals || g.valueDecimals || -1, b.decimalPoint, b.accessibility.thousandsSep || b.thousandsSep) } return a }, w = t(b.xAxis && b.xAxis.options.accessibility && b.xAxis.options.accessibility.enabled, !d.angular), u = b.xAxis && b.xAxis.categories && void 0 !==\n a.category && \"\" + a.category; n = a.name || n || u && u.replace(\"
\", \" \") || (a.id && 0 > a.id.indexOf(\"highcharts-\") ? a.id : \"x, \" + a.x); u = a.series.pointArrayMap ? a.series.pointArrayMap.reduce(function (b, d) { return b + (b.length ? \", \" : \"\") + d + \": \" + h + r(t(a[d], a.options[d])) + f }, \"\") : void 0 !== a.value ? h + r(a.value) + f : h + r(a.y) + f; return (void 0 !== a.index ? a.index + 1 + \". \" : \"\") + (w ? n + \", \" : \"\") + u + \".\" + (l ? \" \" + l : \"\") + (1 < d.series.length && b.name ? \" \" + b.name : \"\")\r\n }\r\n }); return f\r\n }); n(f, \"modules/accessibility/components/ZoomComponent.js\", [f[\"parts/Globals.js\"],\n f[\"modules/accessibility/AccessibilityComponent.js\"], f[\"modules/accessibility/KeyboardNavigationHandler.js\"]], function (c, f, l) {\r\n c.Axis.prototype.panStep = function (b, a) { var d = a || 3; a = this.getExtremes(); var e = (a.max - a.min) / d * b; d = a.max + e; e = a.min + e; var c = d - e; 0 > b && e < a.dataMin ? (e = a.dataMin, d = e + c) : 0 < b && d > a.dataMax && (d = a.dataMax, e = d - c); this.setExtremes(e, d) }; var h = function (b) { this.initBase(b); this.init() }; h.prototype = new f; c.extend(h.prototype, {\r\n init: function () {\r\n var b = this, a = this.chart;[\"afterShowResetZoom\", \"afterDrilldown\",\n \"drillupall\"].forEach(function (d) { b.addEvent(a, d, function () { b.updateProxyOverlays() }) })\r\n }, onChartUpdate: function () { var b = this.chart, a = this; b.mapNavButtons && b.mapNavButtons.forEach(function (d, e) { a.unhideElementFromScreenReaders(d.element); d.element.setAttribute(\"tabindex\", -1); d.element.setAttribute(\"role\", \"button\"); d.element.setAttribute(\"aria-label\", b.langFormat(\"accessibility.mapZoom\" + (e ? \"Out\" : \"In\"), { chart: b })) }) }, onChartRender: function () { this.updateProxyOverlays() }, updateProxyOverlays: function () {\r\n var b =\n this, a = this.chart, d = function (a, d, c, g) { b.removeElement(b[c]); b[c] = b.addProxyGroup(); b[d] = b.createProxyButton(a, b[c], { \"aria-label\": g, tabindex: -1 }) }; b.removeElement(b.drillUpProxyGroup); b.removeElement(b.resetZoomProxyGroup); a.resetZoomButton && d(a.resetZoomButton, \"resetZoomProxyButton\", \"resetZoomProxyGroup\", a.langFormat(\"accessibility.resetZoomButton\", { chart: a })); a.drillUpButton && d(a.drillUpButton, \"drillUpProxyButton\", \"drillUpProxyGroup\", a.langFormat(\"accessibility.drillUpButton\", { chart: a, buttonText: a.getDrilldownBackText() }))\r\n },\n getMapZoomNavigation: function () {\r\n var b = this.keyCodes, a = this.chart, d = this; return new l(a, {\r\n keyCodeMap: [[[b.up, b.down, b.left, b.right], function (d) { a[d === b.up || d === b.down ? \"yAxis\" : \"xAxis\"][0].panStep(d === b.left || d === b.up ? -1 : 1); return this.response.success }], [[b.tab], function (b, c) {\r\n a.mapNavButtons[d.focusedMapNavButtonIx].setState(0); if (c.shiftKey && !d.focusedMapNavButtonIx || !c.shiftKey && d.focusedMapNavButtonIx) return a.mapZoom(), this.response[c.shiftKey ? \"prev\" : \"next\"]; d.focusedMapNavButtonIx += c.shiftKey ? -1 :\n 1; b = a.mapNavButtons[d.focusedMapNavButtonIx]; a.setFocusToElement(b.box, b.element); b.setState(2); return this.response.success\r\n }], [[b.space, b.enter], function () { d.fakeClickEvent(a.mapNavButtons[d.focusedMapNavButtonIx].element); return this.response.success }]], validate: function () { return a.mapZoom && a.mapNavButtons && 2 === a.mapNavButtons.length }, init: function (b) { var e = a.mapNavButtons[0], c = a.mapNavButtons[1]; e = 0 < b ? e : c; a.setFocusToElement(e.box, e.element); e.setState(2); d.focusedMapNavButtonIx = 0 < b ? 0 : 1 }\r\n })\r\n }, simpleButtonNavigation: function (b,\n a, d) { var e = this.keyCodes, c = this, h = this.chart; return new l(h, { keyCodeMap: [[[e.tab, e.up, e.down, e.left, e.right], function (a, b) { return this.response[a === this.tab && b.shiftKey || a === e.left || a === e.up ? \"prev\" : \"next\"] }], [[e.space, e.enter], function () { d(h); return this.response.success }]], validate: function () { return h[b] && h[b].box && c[a] }, init: function () { h.setFocusToElement(h[b].box, c[a]) } }) }, getKeyboardNavigation: function () {\r\n return [this.simpleButtonNavigation(\"resetZoomButton\", \"resetZoomProxyButton\", function (b) { b.zoomOut() }),\n this.simpleButtonNavigation(\"drillUpButton\", \"drillUpProxyButton\", function (b) { b.drillUp() }), this.getMapZoomNavigation()]\r\n }\r\n }); return h\r\n }); n(f, \"modules/accessibility/components/RangeSelectorComponent.js\", [f[\"parts/Globals.js\"], f[\"modules/accessibility/AccessibilityComponent.js\"], f[\"modules/accessibility/KeyboardNavigationHandler.js\"]], function (c, f, l) {\r\n c.Chart.prototype.highlightRangeSelectorButton = function (b) {\r\n var a = this.rangeSelector.buttons; a[this.highlightedRangeSelectorItemIx] && a[this.highlightedRangeSelectorItemIx].setState(this.oldRangeSelectorItemState ||\n 0); this.highlightedRangeSelectorItemIx = b; return a[b] ? (this.setFocusToElement(a[b].box, a[b].element), this.oldRangeSelectorItemState = a[b].state, a[b].setState(2), !0) : !1\r\n }; var h = function (b) { this.initBase(b) }; h.prototype = new f; c.extend(h.prototype, {\r\n onChartUpdate: function () {\r\n var b = this.chart, a = this, d = b.rangeSelector; d && (d.buttons && d.buttons.length && d.buttons.forEach(function (d) {\r\n a.unhideElementFromScreenReaders(d.element); d.element.setAttribute(\"tabindex\", \"-1\"); d.element.setAttribute(\"role\", \"button\"); d.element.setAttribute(\"aria-label\",\n b.langFormat(\"accessibility.rangeSelectorButton\", { chart: b, buttonText: d.text && d.text.textStr }))\r\n }), d.maxInput && d.minInput && [\"minInput\", \"maxInput\"].forEach(function (e, c) { d[e] && (a.unhideElementFromScreenReaders(d[e]), d[e].setAttribute(\"tabindex\", \"-1\"), d[e].setAttribute(\"role\", \"textbox\"), d[e].setAttribute(\"aria-label\", b.langFormat(\"accessibility.rangeSelector\" + (c ? \"MaxInput\" : \"MinInput\"), { chart: b }))) }))\r\n }, getRangeSelectorButtonNavigation: function () {\r\n var b = this.chart, a = this.keyCodes, d = b.options.accessibility,\n e = this; return new l(b, {\r\n keyCodeMap: [[[a.left, a.right, a.up, a.down], function (e) { e = e === a.left || e === a.up ? -1 : 1; if (!b.highlightRangeSelectorButton(b.highlightedRangeSelectorItemIx + e)) return d.keyboardNavigation.wrapAround ? (this.init(e), this.response.success) : this.response[0 < e ? \"next\" : \"prev\"] }], [[a.enter, a.space], function () { 3 !== b.oldRangeSelectorItemState && e.fakeClickEvent(b.rangeSelector.buttons[b.highlightedRangeSelectorItemIx].element) }]], validate: function () {\r\n return b.rangeSelector && b.rangeSelector.buttons &&\n b.rangeSelector.buttons.length\r\n }, init: function (a) { b.highlightRangeSelectorButton(0 < a ? 0 : b.rangeSelector.buttons.length - 1) }\r\n })\r\n }, getRangeSelectorInputNavigation: function () {\r\n var b = this.chart, a = this.keyCodes; return new l(b, {\r\n keyCodeMap: [[[a.tab, a.up, a.down], function (d, e) { d = d === a.tab && e.shiftKey || d === a.up ? -1 : 1; e = b.highlightedInputRangeIx += d; if (1 < e || 0 > e) return this.response[0 < d ? \"next\" : \"prev\"]; b.rangeSelector[e ? \"maxInput\" : \"minInput\"].focus(); return this.response.success }]], validate: function () {\r\n return b.rangeSelector &&\n b.rangeSelector.inputGroup && \"hidden\" !== b.rangeSelector.inputGroup.element.getAttribute(\"visibility\") && !1 !== b.options.rangeSelector.inputEnabled && b.rangeSelector.minInput && b.rangeSelector.maxInput\r\n }, init: function (a) { b.highlightedInputRangeIx = 0 < a ? 0 : 1; b.rangeSelector[b.highlightedInputRangeIx ? \"maxInput\" : \"minInput\"].focus() }, terminate: function () { var a = b.rangeSelector; a && a.maxInput && a.minInput && (a.hideInput(\"max\"), a.hideInput(\"min\")) }\r\n })\r\n }, getKeyboardNavigation: function () {\r\n return [this.getRangeSelectorButtonNavigation(),\n this.getRangeSelectorInputNavigation()]\r\n }\r\n }); return h\r\n }); n(f, \"modules/accessibility/components/InfoRegionComponent.js\", [f[\"parts/Globals.js\"], f[\"modules/accessibility/AccessibilityComponent.js\"]], function (c, f) {\r\n var l = c.merge, h = c.pick; c.Chart.prototype.getTypeDescription = function (a) {\r\n a = a[0]; var b = this.series && this.series[0] || {}, e = b.mapTitle; b = { numSeries: this.series.length, numPoints: b.points && b.points.length, chart: this, mapTitle: e }; if (!a) return this.langFormat(\"accessibility.chartTypes.emptyChart\", b); if (\"map\" ===\n a) return e ? this.langFormat(\"accessibility.chartTypes.mapTypeDescription\", b) : this.langFormat(\"accessibility.chartTypes.unknownMap\", b); if (1 < this.types.length) return this.langFormat(\"accessibility.chartTypes.combinationChart\", b); e = this.langFormat(\"accessibility.seriesTypeDescriptions.\" + a, { chart: this }); var c = this.series && 1 === this.series.length ? \"Single\" : \"Multiple\"; return (this.langFormat(\"accessibility.chartTypes.\" + a + c, b) || this.langFormat(\"accessibility.chartTypes.default\" + c, b)) + (e ? \" \" + e : \"\")\r\n }; var b = function (a) {\r\n this.initBase(a);\n this.init()\r\n }; b.prototype = new f; c.extend(b.prototype, {\r\n init: function () { var a = this.chart, b = this; this.addEvent(a, \"afterGetTable\", function (d) { a.options.accessibility.enabled && (b.tableAnchor.setAttribute(\"aria-expanded\", !0), d.html = d.html.replace(\"\" + (b.accessibility.typeDescription || a.getTypeDescription(e)) + \"\" + (b.subtitle &&\n b.subtitle.text ? \"\" + this.htmlencode(b.subtitle.text) + \"
\" : \"\") + (b.accessibility.description ? \"\" + b.accessibility.description + \"
\" : \"\") + (c.xAxis ? \"\" + c.xAxis + \"
\" : \"\") + (c.yAxis ? \"\" + c.yAxis + \"
\" : \"\")\r\n }, getAxesDescription: function () {\r\n var a = this.chart, b = this, e = a.xAxis, c = 1 < e.length || e[0] && h(e[0].options.accessibility && e[0].options.accessibility.enabled, !a.angular && a.hasCartesianSeries && 0 > a.types.indexOf(\"map\")), f = a.yAxis, g = 1 < f.length || f[0] && h(f[0].options.accessibility && f[0].options.accessibility.enabled,\n a.hasCartesianSeries && 0 > a.types.indexOf(\"map\")), l = {}; c && (l.xAxis = a.langFormat(\"accessibility.axis.xAxisDescription\" + (1 < e.length ? \"Plural\" : \"Singular\"), { chart: a, names: a.xAxis.map(function (a) { return a.getDescription() }), ranges: a.xAxis.map(function (a) { return b.getAxisRangeDescription(a) }), numAxes: e.length })); g && (l.yAxis = a.langFormat(\"accessibility.axis.yAxisDescription\" + (1 < f.length ? \"Plural\" : \"Singular\"), {\r\n chart: a, names: a.yAxis.map(function (a) { return a.getDescription() }), ranges: a.yAxis.map(function (a) { return b.getAxisRangeDescription(a) }),\n numAxes: f.length\r\n })); return l\r\n }, getAxisRangeDescription: function (a) {\r\n var b = this.chart, e = a.options || {}; if (e.accessibility && void 0 !== e.accessibility.rangeDescription) return e.accessibility.rangeDescription; if (a.categories) return b.langFormat(\"accessibility.axis.rangeCategories\", { chart: b, axis: a, numCategories: a.dataMax - a.dataMin + 1 }); if (a.isDatetimeAxis && (0 === a.min || 0 === a.dataMin)) {\r\n var c = {}, h = \"Seconds\"; c.Seconds = (a.max - a.min) / 1E3; c.Minutes = c.Seconds / 60; c.Hours = c.Minutes / 60; c.Days = c.Hours / 24;[\"Minutes\", \"Hours\",\n \"Days\"].forEach(function (a) { 2 < c[a] && (h = a) }); c.value = c[h].toFixed(\"Seconds\" !== h && \"Minutes\" !== h ? 1 : 0); return b.langFormat(\"accessibility.axis.timeRange\" + h, { chart: b, axis: a, range: c.value.replace(\".0\", \"\") })\r\n } e = b.options.accessibility; return b.langFormat(\"accessibility.axis.rangeFromTo\", { chart: b, axis: a, rangeFrom: a.isDatetimeAxis ? b.time.dateFormat(e.axisRangeDateFormat, a.min) : a.min, rangeTo: a.isDatetimeAxis ? b.time.dateFormat(e.axisRangeDateFormat, a.max) : a.max })\r\n }\r\n }); return b\r\n }); n(f, \"modules/accessibility/components/ContainerComponent.js\",\n [f[\"parts/Globals.js\"], f[\"modules/accessibility/AccessibilityComponent.js\"]], function (c, f) {\r\n var l = c.win.document, h = function (b) { this.initBase(b) }; h.prototype = new f; c.extend(h.prototype, {\r\n onChartUpdate: function () {\r\n var b = this.chart, a = b.options.accessibility, d = \"highcharts-title-\" + b.index, c = b.options.title.text || b.langFormat(\"accessibility.defaultChartTitle\", { chart: b }), h = this.stripTags(b.langFormat(\"accessibility.svgContainerTitle\", { chartTitle: c })), f = this.stripTags(b.langFormat(\"accessibility.svgContainerLabel\",\n { chartTitle: c })); if (h.length) { var g = this.svgTitleElement = this.svgTitleElement || l.createElementNS(\"http://www.w3.org/2000/svg\", \"title\"); g.textContent = h; g.id = d; b.renderTo.insertBefore(g, b.renderTo.firstChild) } b.renderer.box && f.length && b.renderer.box.setAttribute(\"aria-label\", f); \"disabled\" !== a.landmarkVerbosity ? b.renderTo.setAttribute(\"role\", \"region\") : b.renderTo.removeAttribute(\"role\"); b.renderTo.setAttribute(\"aria-label\", b.langFormat(\"accessibility.chartContainerLabel\", { title: this.stripTags(c), chart: b }));\n if (a = b.credits && b.credits.element) b.credits.textStr && a.setAttribute(\"aria-label\", this.stripTags(b.langFormat(\"accessibility.credits\", { creditsStr: b.credits.textStr }))), this.unhideElementFromScreenReaders(a)\r\n }, destroy: function () { this.chart.renderTo.setAttribute(\"aria-hidden\", !0); this.destroyBase() }\r\n }); return h\r\n }); n(f, \"modules/accessibility/high-contrast-mode.js\", [f[\"parts/Globals.js\"]], function (c) {\r\n var f = c.isMS, l = c.win, h = l.document; return {\r\n isHighContrastModeActive: function () {\r\n if (l.matchMedia && f && /Edge\\/\\d./i.test(l.navigator.userAgent)) return l.matchMedia(\"(-ms-high-contrast: active)\").matches;\n if (f && l.getComputedStyle) { var b = h.createElement(\"div\"); b.style.backgroundImage = \"url(#)\"; h.body.appendChild(b); var a = (b.currentStyle || l.getComputedStyle(b)).backgroundImage; h.body.removeChild(b); return \"none\" === a } return !1\r\n }, setHighContrastTheme: function (b) {\r\n b.highContrastModeActive = !0; var a = b.options.accessibility.highContrastTheme; b.update(a, !1); b.series.forEach(function (b) {\r\n var d = a.plotOptions[b.type] || {}; b.update({\r\n color: d.color || \"windowText\", colors: [d.color || \"windowText\"], borderColor: d.borderColor ||\n \"window\"\r\n }); b.points.forEach(function (a) { a.options && a.options.color && a.update({ color: d.color || \"windowText\", borderColor: d.borderColor || \"window\" }, !1) })\r\n }); b.redraw()\r\n }\r\n }\r\n }); n(f, \"modules/accessibility/high-contrast-theme.js\", [], function () {\r\n return {\r\n chart: { backgroundColor: \"window\" }, title: { style: { color: \"windowText\" } }, subtitle: { style: { color: \"windowText\" } }, colorAxis: { minColor: \"windowText\", maxColor: \"windowText\", stops: null }, colors: [\"windowText\"], xAxis: {\r\n gridLineColor: \"windowText\", labels: { style: { color: \"windowText\" } },\n lineColor: \"windowText\", minorGridLineColor: \"windowText\", tickColor: \"windowText\", title: { style: { color: \"windowText\" } }\r\n }, yAxis: { gridLineColor: \"windowText\", labels: { style: { color: \"windowText\" } }, lineColor: \"windowText\", minorGridLineColor: \"windowText\", tickColor: \"windowText\", title: { style: { color: \"windowText\" } } }, tooltip: { backgroundColor: \"window\", borderColor: \"windowText\", style: { color: \"windowText\" } }, plotOptions: {\r\n series: {\r\n lineColor: \"windowText\", fillColor: \"window\", borderColor: \"windowText\", edgeColor: \"windowText\", borderWidth: 1,\n dataLabels: { connectorColor: \"windowText\", color: \"windowText\", style: { color: \"windowText\", textOutline: \"none\" } }, marker: { lineColor: \"windowText\", fillColor: \"windowText\" }\r\n }, pie: { color: \"window\", colors: [\"window\"], borderColor: \"windowText\", borderWidth: 1 }, boxplot: { fillColor: \"window\" }, candlestick: { lineColor: \"windowText\", fillColor: \"window\" }, errorbar: { fillColor: \"window\" }\r\n }, legend: { backgroundColor: \"window\", itemStyle: { color: \"windowText\" }, itemHoverStyle: { color: \"windowText\" }, itemHiddenStyle: { color: \"#555\" }, title: { style: { color: \"windowText\" } } },\n credits: { style: { color: \"windowText\" } }, labels: { style: { color: \"windowText\" } }, drilldown: { activeAxisLabelStyle: { color: \"windowText\" }, activeDataLabelStyle: { color: \"windowText\" } }, navigation: { buttonOptions: { symbolStroke: \"windowText\", theme: { fill: \"window\" } } }, rangeSelector: {\r\n buttonTheme: { fill: \"window\", stroke: \"windowText\", style: { color: \"windowText\" }, states: { hover: { fill: \"window\", stroke: \"windowText\", style: { color: \"windowText\" } }, select: { fill: \"#444\", stroke: \"windowText\", style: { color: \"windowText\" } } } }, inputBoxBorderColor: \"windowText\",\n inputStyle: { backgroundColor: \"window\", color: \"windowText\" }, labelStyle: { color: \"windowText\" }\r\n }, navigator: { handles: { backgroundColor: \"window\", borderColor: \"windowText\" }, outlineColor: \"windowText\", maskFill: \"transparent\", series: { color: \"windowText\", lineColor: \"windowText\" }, xAxis: { gridLineColor: \"windowText\" } }, scrollbar: {\r\n barBackgroundColor: \"#444\", barBorderColor: \"windowText\", buttonArrowColor: \"windowText\", buttonBackgroundColor: \"window\", buttonBorderColor: \"windowText\", rifleColor: \"windowText\", trackBackgroundColor: \"window\",\n trackBorderColor: \"windowText\"\r\n }\r\n }\r\n }); n(f, \"modules/accessibility/options.js\", [], function () {\r\n return {\r\n accessibility: {\r\n enabled: !0, pointDescriptionThreshold: 200, pointNavigationThreshold: !1, addTableShortcut: !0, axisRangeDateFormat: \"%Y-%m-%d %H:%M:%S\", describeSingleSeries: !1, landmarkVerbosity: \"all\", keyboardNavigation: {\r\n enabled: !0, skipNullPoints: !0, focusBorder: { enabled: !0, hideBrowserFocusOutline: !0, style: { color: \"#335cad\", lineWidth: 2, borderRadius: 3 }, margin: 2 }, order: [\"series\", \"zoom\", \"rangeSelector\", \"chartMenu\", \"legend\"],\n wrapAround: !0\r\n }, announceNewData: { enabled: !1, minAnnounceInterval: 5E3, interruptUser: !1 }\r\n }, legend: { accessibility: { enabled: !0, keyboardNavigation: { enabled: !0 } } }, exporting: { accessibility: { enabled: !0 } }\r\n }\r\n }); n(f, \"modules/accessibility/a11y-i18n.js\", [f[\"parts/Globals.js\"]], function (c) {\r\n function f(c, b) {\r\n var a = c.indexOf(\"#each(\"), d = c.indexOf(\"#plural(\"), e = c.indexOf(\"[\"), f = c.indexOf(\"]\"); if (-1 < a) {\r\n e = c.slice(a).indexOf(\")\") + a; var h = c.substring(0, a); d = c.substring(e + 1); e = c.substring(a + 6, e).split(\",\"); a = Number(e[1]); c =\n \"\"; if (b = b[e[0]]) for (a = isNaN(a) ? b.length : a, a = 0 > a ? b.length + a : Math.min(a, b.length), e = 0; e < a; ++e)c += h + b[e] + d; return c.length ? c : \"\"\r\n } if (-1 < d) { h = c.slice(d).indexOf(\")\") + d; c = c.substring(d + 8, h).split(\",\"); switch (Number(b[c[0]])) { case 0: c = l(c[4], c[1]); break; case 1: c = l(c[2], c[1]); break; case 2: c = l(c[3], c[1]); break; default: c = c[1] }c ? (b = c, b = b.trim && b.trim() || b.replace(/^\\s+|\\s+$/g, \"\")) : b = \"\"; return b } return -1 < e ? (d = c.substring(0, e), c = Number(c.substring(e + 1, f)), b = b[d], !isNaN(c) && b && (0 > c ? (h = b[b.length + c], void 0 === h &&\n (h = b[0])) : (h = b[c], void 0 === h && (h = b[b.length - 1]))), void 0 !== h ? h : \"\") : \"{\" + c + \"}\"\r\n } var l = c.pick; c.i18nFormat = function (h, b, a) {\r\n var d = function (a, b) { a = a.slice(b || 0); var c = a.indexOf(\"{\"), d = a.indexOf(\"}\"); if (-1 < c && d > c) return { statement: a.substring(c + 1, d), begin: b + c + 1, end: b + d } }, e = []; var k = 0; do { var l = d(h, k); k = h.substring(k, l && l.begin - 1); k.length && e.push({ value: k, type: \"constant\" }); l && e.push({ value: l.statement, type: \"statement\" }); k = l && l.end + 1 } while (l); e.forEach(function (a) { \"statement\" === a.type && (a.value = f(a.value, b)) });\n return c.format(e.reduce(function (a, b) { return a + b.value }, \"\"), b, a)\r\n }; c.Chart.prototype.langFormat = function (f, b, a) { f = f.split(\".\"); for (var d = this.options.lang, e = 0; e < f.length; ++e)d = d && d[f[e]]; return \"string\" === typeof d && c.i18nFormat(d, b, a) }; c.setOptions({\r\n lang: {\r\n accessibility: {\r\n screenReaderRegionLabel: \"Chart screen reader information.\", defaultChartTitle: \"Chart\", viewAsDataTable: \"View as data table.\", chartHeading: \"Chart graphic.\", chartContainerLabel: \"{title}. Highcharts interactive chart.\", credits: \"Chart credits: {creditsStr}\",\n svgContainerLabel: \"Interactive chart\", rangeSelectorMinInput: \"Select start date.\", rangeSelectorMaxInput: \"Select end date.\", tableSummary: \"Table representation of chart.\", mapZoomIn: \"Zoom chart\", mapZoomOut: \"Zoom out chart\", resetZoomButton: \"Reset zoom\", drillUpButton: \"{buttonText}\", rangeSelectorButton: \"Select range {buttonText}\", legendLabel: \"Toggle series visibility\", legendItem: \"Toggle visibility of {itemName}\", thousandsSep: \",\", svgContainerTitle: \"\", svgContainerEnd: \"End of interactive chart\", announceNewData: {\r\n newDataAnnounce: \"Updated data for chart {chartTitle}\",\n newSeriesAnnounceSingle: \"New data series: {seriesDesc}\", newPointAnnounceSingle: \"New data point: {pointDesc}\", newSeriesAnnounceMultiple: \"New data series in chart {chartTitle}: {seriesDesc}\", newPointAnnounceMultiple: \"New data point in chart {chartTitle}: {pointDesc}\"\r\n }, seriesTypeDescriptions: {\r\n boxplot: \"Box plot charts are typically used to display groups of statistical data. Each data point in the chart can have up to 5 values: minimum, lower quartile, median, upper quartile, and maximum.\", arearange: \"Arearange charts are line charts displaying a range between a lower and higher value for each point.\",\n areasplinerange: \"These charts are line charts displaying a range between a lower and higher value for each point.\", bubble: \"Bubble charts are scatter charts where each data point also has a size value.\", columnrange: \"Columnrange charts are column charts displaying a range between a lower and higher value for each point.\", errorbar: \"Errorbar series are used to display the variability of the data.\", funnel: \"Funnel charts are used to display reduction of data in stages.\", pyramid: \"Pyramid charts consist of a single pyramid with item heights corresponding to each point value.\",\n waterfall: \"A waterfall chart is a column chart where each column contributes towards a total end value.\"\r\n }, chartTypes: {\r\n emptyChart: \"Empty chart\", mapTypeDescription: \"Map of {mapTitle} with {numSeries} data series.\", unknownMap: \"Map of unspecified region with {numSeries} data series.\", combinationChart: \"Combination chart with {numSeries} data series.\", defaultSingle: \"Chart with {numPoints} data {#plural(numPoints, points, point)}.\", defaultMultiple: \"Chart with {numSeries} data series.\", splineSingle: \"Line chart with {numPoints} data {#plural(numPoints, points, point)}.\",\n splineMultiple: \"Line chart with {numSeries} lines.\", lineSingle: \"Line chart with {numPoints} data {#plural(numPoints, points, point)}.\", lineMultiple: \"Line chart with {numSeries} lines.\", columnSingle: \"Bar chart with {numPoints} {#plural(numPoints, bars, bar)}.\", columnMultiple: \"Bar chart with {numSeries} data series.\", barSingle: \"Bar chart with {numPoints} {#plural(numPoints, bars, bar)}.\", barMultiple: \"Bar chart with {numSeries} data series.\", pieSingle: \"Pie chart with {numPoints} {#plural(numPoints, slices, slice)}.\",\n pieMultiple: \"Pie chart with {numSeries} pies.\", scatterSingle: \"Scatter chart with {numPoints} {#plural(numPoints, points, point)}.\", scatterMultiple: \"Scatter chart with {numSeries} data series.\", boxplotSingle: \"Boxplot with {numPoints} {#plural(numPoints, boxes, box)}.\", boxplotMultiple: \"Boxplot with {numSeries} data series.\", bubbleSingle: \"Bubble chart with {numPoints} {#plural(numPoints, bubbles, bubble)}.\", bubbleMultiple: \"Bubble chart with {numSeries} data series.\"\r\n }, axis: {\r\n xAxisDescriptionSingular: \"The chart has 1 X axis displaying {names[0]}. {ranges[0]}\",\n xAxisDescriptionPlural: \"The chart has {numAxes} X axes displaying {#each(names, -1) }and {names[-1]}.\", yAxisDescriptionSingular: \"The chart has 1 Y axis displaying {names[0]}. {ranges[0]}\", yAxisDescriptionPlural: \"The chart has {numAxes} Y axes displaying {#each(names, -1) }and {names[-1]}.\", timeRangeDays: \"Range: {range} days.\", timeRangeHours: \"Range: {range} hours.\", timeRangeMinutes: \"Range: {range} minutes.\", timeRangeSeconds: \"Range: {range} seconds.\", rangeFromTo: \"Range: {rangeFrom} to {rangeTo}.\", rangeCategories: \"Range: {numCategories} categories.\"\r\n },\n exporting: { chartMenuLabel: \"Chart export\", menuButtonLabel: \"View export menu\", exportRegionLabel: \"Chart export menu\" }, series: {\r\n summary: {\r\n \"default\": \"{name}, series {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.\", defaultCombination: \"{name}, series {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.\", line: \"{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.\", lineCombination: \"{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.\",\n spline: \"{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.\", splineCombination: \"{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.\", column: \"{name}, bar series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bars, bar)}.\", columnCombination: \"{name}, series {ix} of {numSeries}. Bar series with {numPoints} {#plural(numPoints, bars, bar)}.\", bar: \"{name}, bar series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bars, bar)}.\",\n barCombination: \"{name}, series {ix} of {numSeries}. Bar series with {numPoints} {#plural(numPoints, bars, bar)}.\", pie: \"{name}, pie {ix} of {numSeries} with {numPoints} {#plural(numPoints, slices, slice)}.\", pieCombination: \"{name}, series {ix} of {numSeries}. Pie with {numPoints} {#plural(numPoints, slices, slice)}.\", scatter: \"{name}, scatter plot {ix} of {numSeries} with {numPoints} {#plural(numPoints, points, point)}.\", scatterCombination: \"{name}, series {ix} of {numSeries}, scatter plot with {numPoints} {#plural(numPoints, points, point)}.\",\n boxplot: \"{name}, boxplot {ix} of {numSeries} with {numPoints} {#plural(numPoints, boxes, box)}.\", boxplotCombination: \"{name}, series {ix} of {numSeries}. Boxplot with {numPoints} {#plural(numPoints, boxes, box)}.\", bubble: \"{name}, bubble series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bubbles, bubble)}.\", bubbleCombination: \"{name}, series {ix} of {numSeries}. Bubble series with {numPoints} {#plural(numPoints, bubbles, bubble)}.\", map: \"{name}, map {ix} of {numSeries} with {numPoints} {#plural(numPoints, areas, area)}.\",\n mapCombination: \"{name}, series {ix} of {numSeries}. Map with {numPoints} {#plural(numPoints, areas, area)}.\", mapline: \"{name}, line {ix} of {numSeries} with {numPoints} data {#plural(numPoints, points, point)}.\", maplineCombination: \"{name}, series {ix} of {numSeries}. Line with {numPoints} data {#plural(numPoints, points, point)}.\", mapbubble: \"{name}, bubble series {ix} of {numSeries} with {numPoints} {#plural(numPoints, bubbles, bubble)}.\", mapbubbleCombination: \"{name}, series {ix} of {numSeries}. Bubble series with {numPoints} {#plural(numPoints, bubbles, bubble)}.\"\r\n },\n description: \"{description}\", xAxisDescription: \"X axis, {name}\", yAxisDescription: \"Y axis, {name}\"\r\n }\r\n }\r\n }\r\n })\r\n }); n(f, \"modules/accessibility/accessibility.js\", [f[\"parts/Globals.js\"], f[\"modules/accessibility/KeyboardNavigationHandler.js\"], f[\"modules/accessibility/AccessibilityComponent.js\"], f[\"modules/accessibility/KeyboardNavigation.js\"], f[\"modules/accessibility/components/LegendComponent.js\"], f[\"modules/accessibility/components/MenuComponent.js\"], f[\"modules/accessibility/components/SeriesComponent.js\"], f[\"modules/accessibility/components/ZoomComponent.js\"],\n f[\"modules/accessibility/components/RangeSelectorComponent.js\"], f[\"modules/accessibility/components/InfoRegionComponent.js\"], f[\"modules/accessibility/components/ContainerComponent.js\"], f[\"modules/accessibility/high-contrast-mode.js\"], f[\"modules/accessibility/high-contrast-theme.js\"], f[\"modules/accessibility/options.js\"]], function (c, f, l, h, b, a, d, e, k, n, g, m, v, p) {\r\n function r(a) { this.init(a) } var q = c.addEvent, t = c.win.document, x = c.pick, y = c.merge, z = c.extend, w = c.error; y(!0, c.defaultOptions, p, { accessibility: { highContrastTheme: v } });\n c.KeyboardNavigationHandler = f; c.AccessibilityComponent = l; c.extend(c.SVGElement.prototype, {\r\n addFocusBorder: function (a, b) {\r\n this.focusBorder && this.removeFocusBorder(); var c = this.getBBox(); a = x(a, 3); c.x += this.translateX ? this.translateX : 0; c.y += this.translateY ? this.translateY : 0; this.focusBorder = this.renderer.rect(c.x - a, c.y - a, c.width + 2 * a, c.height + 2 * a, b && b.borderRadius).addClass(\"highcharts-focus-border\").attr({ zIndex: 99 }).add(this.parentGroup); this.renderer.styledMode || this.focusBorder.attr({\r\n stroke: b && b.stroke,\n \"stroke-width\": b && b.strokeWidth\r\n })\r\n }, removeFocusBorder: function () { this.focusBorder && (this.focusBorder.destroy(), delete this.focusBorder) }\r\n }); c.Chart.prototype.setFocusToElement = function (a, b) {\r\n var c = this.options.accessibility.keyboardNavigation.focusBorder; (b = b || a.element) && b.focus && (b.hcEvents && b.hcEvents.focusin || q(b, \"focusin\", function () { }), b.focus(), c.hideBrowserFocusOutline && (b.style.outline = \"none\")); c.enabled && (this.focusElement && this.focusElement.removeFocusBorder(), a.addFocusBorder(c.margin, {\r\n stroke: c.style.color,\n strokeWidth: c.style.lineWidth, borderRadius: c.style.borderRadius\r\n }), this.focusElement = a)\r\n }; c.Axis.prototype.getDescription = function () { return this.userOptions && this.userOptions.accessibility && this.userOptions.accessibility.description || this.axisTitle && this.axisTitle.textStr || this.options.id || this.categories && \"categories\" || this.isDatetimeAxis && \"Time\" || \"values\" }; r.prototype = {\r\n init: function (c) {\r\n var f = c.options.accessibility; this.chart = c; if (t.addEventListener && c.renderer.isSVG) {\r\n this.copyDeprecatedOptions();\n var l = this.components = { container: new g(c), infoRegion: new n(c), legend: new b(c), chartMenu: new a(c), rangeSelector: new k(c), series: new d(c), zoom: new e(c) }; f.customComponents && z(this.components, f.customComponents); this.keyboardNavigation = new h(c, l); this.update()\r\n } else c.renderTo.setAttribute(\"aria-hidden\", !0)\r\n }, update: function () {\r\n var a = this.components, b = this.chart, c = b.options.accessibility; b.types = this.getChartTypes(); Object.keys(a).forEach(function (b) { a[b].onChartUpdate() }); this.keyboardNavigation.update(c.keyboardNavigation.order);\n !b.highContrastModeActive && m.isHighContrastModeActive(b) && m.setHighContrastTheme(b)\r\n }, destroy: function () { var a = this.chart || {}, b = this.components; Object.keys(b).forEach(function (a) { b[a].destroy() }); this.keyboardNavigation && this.keyboardNavigation.destroy(); a.renderTo && a.renderTo.setAttribute(\"aria-hidden\", !0); a.focusElement && a.focusElement.removeFocusBorder() }, getChartTypes: function () { var a = {}; this.chart.series.forEach(function (b) { a[b.type] = 1 }); return Object.keys(a) }, copyDeprecatedOptions: function () {\r\n var a =\n this.chart, b = function (b, c) { w(\"Highcharts: Deprecated option \" + b + \" used. Use \" + c + \" instead.\", !1, a) }, c = { description: [\"accessibility\", \"description\"], exposeElementToA11y: [\"accessibility\", \"exposeAsGroupOnly\"], pointDescriptionFormatter: [\"accessibility\", \"pointDescriptionFormatter\"], skipKeyboardNavigation: [\"accessibility\", \"keyboardNavigation\", \"enabled\"] }, d = a.options.chart || {}, e = a.options.accessibility || {};[\"description\", \"typeDescription\"].forEach(function (a) {\r\n d[a] && (e[a] = d[a], b(\"chart.\" + a, \"accessibility.\" +\n a))\r\n }); a.axes.forEach(function (a) { (a = a.options) && a.description && (a.accessibility = a.accessibility || {}, a.accessibility.description = a.description, b(\"axis.description\", \"axis.accessibility.description\")) }); a.series && a.series.forEach(function (a) {\r\n Object.keys(c).forEach(function (d) { var e = a.options[d]; if (void 0 !== e) { e = \"skipKeyboardNavigation\" === d ? !e : e; for (var f = c[d], g = a.options, h, k = 0; k < f.length - 1; ++k)h = f[k], g = g[h] = x(g[h], {}); g[f[f.length - 1]] = e; b(\"series.\" + d, \"series.\" + c[d].join(\".\")) } }); a.points && a.points.forEach(function (a) {\r\n a.options &&\n a.options.description && (a.options.accessibility = a.options.accessibility || {}, a.options.accessibility.description = a.options.description, b(\"point.description\", \"point.accessibility.description\"))\r\n })\r\n })\r\n }\r\n }; q(c.Chart, \"render\", function (a) {\r\n var b = this.accessibility; if (this.a11yDirty && this.renderTo) { delete this.a11yDirty; var c = this.options.accessibility; c && c.enabled ? b ? b.update() : this.accessibility = b = new r(this) : b ? (b.destroy && b.destroy(), delete this.accessibility) : this.renderTo.setAttribute(\"aria-hidden\", !0) } b &&\n Object.keys(b.components).forEach(function (c) { b.components[c].onChartRender(a) })\r\n }); q(c.Chart, \"update\", function (a) { if (a = a.options.accessibility) a.customComponents && (this.options.accessibility.customComponents = a.customComponents, delete a.customComponents), y(!0, this.options.accessibility, a), this.accessibility && this.accessibility.destroy && (this.accessibility.destroy(), delete this.accessibility); this.a11yDirty = !0 }); q(c.Point, \"update\", function () {\r\n this.series.chart.accessibility && (this.series.chart.a11yDirty =\n !0)\r\n });[\"addSeries\", \"init\"].forEach(function (a) { q(c.Chart, a, function () { this.a11yDirty = !0 }) });[\"update\", \"updatedData\", \"remove\"].forEach(function (a) { q(c.Series, a, function () { this.chart.accessibility && (this.chart.a11yDirty = !0) }) });[\"afterDrilldown\", \"drillupall\"].forEach(function (a) { q(c.Chart, a, function () { this.accessibility && this.accessibility.update() }) }); q(c.Chart, \"destroy\", function () { this.accessibility && this.accessibility.destroy() })\r\n }); n(f, \"masters/modules/accessibility.src.js\", [], function () { })\r\n});\n//# sourceMappingURL=accessibility.js.map","import Highcharts from \"highcharts\";\r\nimport Exporting from \"highcharts/modules/exporting\";\r\nExporting(Highcharts);\r\n\r\nwindow.Highcharts = Highcharts;","/*\r\n Highcharts JS v8.1.0 (2020-05-05)\r\n\r\n Boost module\r\n\r\n (c) 2010-2019 Highsoft AS\r\n Author: Torstein Honsi\r\n\r\n License: www.highcharts.com/license\r\n\r\n This is a Highcharts module that draws long data series on a canvas in order\r\n to increase performance of the initial load time and tooltip responsiveness.\r\n\r\n Compatible with WebGL compatible browsers (not IE < 11).\r\n\r\n If this module is taken in as part of the core\r\n - All the loading logic should be merged with core. Update styles in the\r\n core.\r\n - Most of the method wraps should probably be added directly in parent\r\n methods.\r\n).slick\r\n Notes for boost mode\r\n - Area lines are not drawn\r\n - Lines are not drawn on scatter charts\r\n - Zones and negativeColor don't work\r\n - Dash styles are not rendered on lines.\r\n - Columns are always one pixel wide. Don't set the threshold too low.\r\n - Disable animations\r\n - Marker shapes are not supported: markers will always be circles, except\r\n heatmap series, where markers are always rectangles.\r\n\r\n Optimizing tips for users\r\n - Set extremes (min, max) explicitly on the axes in order for Highcharts to\r\n avoid computing extremes.\r\n - Set enableMouseTracking to false on the series to improve total rendering\r\n time.\r\n - The default threshold is set based on one series. If you have multiple,\r\n dense series, the combined number of points drawn gets higher, and you may\r\n want to set the threshold lower in order to use optimizations.\r\n - If drawing large scatter charts, it's beneficial to set the marker radius\r\n to a value less than 1. This is to add additional spacing to make the chart\r\n more readable.\r\n - If the value increments on both the X and Y axis aren't small, consider\r\n setting useGPUTranslations to true on the boost settings object. If you do\r\n this and the increments are small (e.g. datetime axis with small time\r\n increments) it may cause rendering issues due to floating point rounding\r\n errors, so your millage may vary.\r\n\r\n Settings\r\n There are two ways of setting the boost threshold:\r\n - Per series: boost based on number of points in individual series\r\n - Per chart: boost based on the number of series\r\n\r\n To set the series boost threshold, set seriesBoostThreshold on the chart\r\n object.\r\n To set the series-specific threshold, set boostThreshold on the series\r\n object.\r\n\r\n In addition, the following can be set in the boost object:\r\n {\r\n //Wether or not to use alpha blending\r\n useAlpha: boolean - default: true\r\n //Set to true to perform translations on the GPU.\r\n //Much faster, but may cause rendering issues\r\n //when using values far from 0 due to floating point\r\n //rounding issues\r\n useGPUTranslations: boolean - default: false\r\n //Use pre-allocated buffers, much faster,\r\n //but may cause rendering issues with some data sets\r\n usePreallocated: boolean - default: false\r\n }\r\n*/\r\n(function(c){\"object\"===typeof module&&module.exports?(c[\"default\"]=c,module.exports=c):\"function\"===typeof define&&define.amd?define(\"highcharts/modules/boost\",[\"highcharts\"],function(m){c(m);c.Highcharts=m;return c}):c(\"undefined\"!==typeof Highcharts?Highcharts:void 0)})(function(c){function m(c,E,f,C){c.hasOwnProperty(E)||(c[E]=C.apply(null,f))}c=c?c._modules:{};m(c,\"modules/boost/boostables.js\",[],function(){return\"area arearange column columnrange bar line scatter heatmap bubble treemap\".split(\" \")});\r\nm(c,\"modules/boost/boostable-map.js\",[c[\"modules/boost/boostables.js\"]],function(c){var k={};c.forEach(function(c){k[c]=1});return k});m(c,\"modules/boost/wgl-shader.js\",[c[\"parts/Utilities.js\"]],function(c){var k=c.clamp,f=c.error,C=c.pick;return function(d){function c(){v.length&&f(\"[highcharts boost] shader error - \"+v.join(\"\\n\"))}function w(b,a){var g=d.createShader(\"vertex\"===a?d.VERTEX_SHADER:d.FRAGMENT_SHADER);d.shaderSource(g,b);d.compileShader(g);return d.getShaderParameter(g,d.COMPILE_STATUS)?\r\ng:(v.push(\"when compiling \"+a+\" shader:\\n\"+d.getShaderInfoLog(g)),!1)}function r(){function g(a){return d.getUniformLocation(b,a)}var k=w(\"#version 100\\n#define LN10 2.302585092994046\\nprecision highp float;\\nattribute vec4 aVertexPosition;\\nattribute vec4 aColor;\\nvarying highp vec2 position;\\nvarying highp vec4 vColor;\\nuniform mat4 uPMatrix;\\nuniform float pSize;\\nuniform float translatedThreshold;\\nuniform bool hasThreshold;\\nuniform bool skipTranslation;\\nuniform float xAxisTrans;\\nuniform float xAxisMin;\\nuniform float xAxisMinPad;\\nuniform float xAxisPointRange;\\nuniform float xAxisLen;\\nuniform bool xAxisPostTranslate;\\nuniform float xAxisOrdinalSlope;\\nuniform float xAxisOrdinalOffset;\\nuniform float xAxisPos;\\nuniform bool xAxisCVSCoord;\\nuniform bool xAxisIsLog;\\nuniform bool xAxisReversed;\\nuniform float yAxisTrans;\\nuniform float yAxisMin;\\nuniform float yAxisMinPad;\\nuniform float yAxisPointRange;\\nuniform float yAxisLen;\\nuniform bool yAxisPostTranslate;\\nuniform float yAxisOrdinalSlope;\\nuniform float yAxisOrdinalOffset;\\nuniform float yAxisPos;\\nuniform bool yAxisCVSCoord;\\nuniform bool yAxisIsLog;\\nuniform bool yAxisReversed;\\nuniform bool isBubble;\\nuniform bool bubbleSizeByArea;\\nuniform float bubbleZMin;\\nuniform float bubbleZMax;\\nuniform float bubbleZThreshold;\\nuniform float bubbleMinSize;\\nuniform float bubbleMaxSize;\\nuniform bool bubbleSizeAbs;\\nuniform bool isInverted;\\nfloat bubbleRadius(){\\nfloat value = aVertexPosition.w;\\nfloat zMax = bubbleZMax;\\nfloat zMin = bubbleZMin;\\nfloat radius = 0.0;\\nfloat pos = 0.0;\\nfloat zRange = zMax - zMin;\\nif (bubbleSizeAbs){\\nvalue = value - bubbleZThreshold;\\nzMax = max(zMax - bubbleZThreshold, zMin - bubbleZThreshold);\\nzMin = 0.0;\\n}\\nif (value < zMin){\\nradius = bubbleZMin / 2.0 - 1.0;\\n} else {\\npos = zRange > 0.0 ? (value - zMin) / zRange : 0.5;\\nif (bubbleSizeByArea && pos > 0.0){\\npos = sqrt(pos);\\n}\\nradius = ceil(bubbleMinSize + pos * (bubbleMaxSize - bubbleMinSize)) / 2.0;\\n}\\nreturn radius * 2.0;\\n}\\nfloat translate(float val,\\nfloat pointPlacement,\\nfloat localA,\\nfloat localMin,\\nfloat minPixelPadding,\\nfloat pointRange,\\nfloat len,\\nbool cvsCoord,\\nbool isLog,\\nbool reversed\\n){\\nfloat sign = 1.0;\\nfloat cvsOffset = 0.0;\\nif (cvsCoord) {\\nsign *= -1.0;\\ncvsOffset = len;\\n}\\nif (isLog) {\\nval = log(val) / LN10;\\n}\\nif (reversed) {\\nsign *= -1.0;\\ncvsOffset -= sign * len;\\n}\\nreturn sign * (val - localMin) * localA + cvsOffset + \\n(sign * minPixelPadding);\\n}\\nfloat xToPixels(float value) {\\nif (skipTranslation){\\nreturn value;// + xAxisPos;\\n}\\nreturn translate(value, 0.0, xAxisTrans, xAxisMin, xAxisMinPad, xAxisPointRange, xAxisLen, xAxisCVSCoord, xAxisIsLog, xAxisReversed);// + xAxisPos;\\n}\\nfloat yToPixels(float value, float checkTreshold) {\\nfloat v;\\nif (skipTranslation){\\nv = value;// + yAxisPos;\\n} else {\\nv = translate(value, 0.0, yAxisTrans, yAxisMin, yAxisMinPad, yAxisPointRange, yAxisLen, yAxisCVSCoord, yAxisIsLog, yAxisReversed);// + yAxisPos;\\nif (v > yAxisLen) {\\nv = yAxisLen;\\n}\\n}\\nif (checkTreshold > 0.0 && hasThreshold) {\\nv = min(v, translatedThreshold);\\n}\\nreturn v;\\n}\\nvoid main(void) {\\nif (isBubble){\\ngl_PointSize = bubbleRadius();\\n} else {\\ngl_PointSize = pSize;\\n}\\nvColor = aColor;\\nif (skipTranslation && isInverted) {\\ngl_Position = uPMatrix * vec4(aVertexPosition.y + yAxisPos, aVertexPosition.x + xAxisPos, 0.0, 1.0);\\n} else if (isInverted) {\\ngl_Position = uPMatrix * vec4(yToPixels(aVertexPosition.y, aVertexPosition.z) + yAxisPos, xToPixels(aVertexPosition.x) + xAxisPos, 0.0, 1.0);\\n} else {\\ngl_Position = uPMatrix * vec4(xToPixels(aVertexPosition.x) + xAxisPos, yToPixels(aVertexPosition.y, aVertexPosition.z) + yAxisPos, 0.0, 1.0);\\n}\\n}\",\r\n\"vertex\"),e=w(\"precision highp float;\\nuniform vec4 fillColor;\\nvarying highp vec2 position;\\nvarying highp vec4 vColor;\\nuniform sampler2D uSampler;\\nuniform bool isCircle;\\nuniform bool hasColor;\\nvoid main(void) {\\nvec4 col = fillColor;\\nvec4 tcol;\\nif (hasColor) {\\ncol = vColor;\\n}\\nif (isCircle) {\\ntcol = texture2D(uSampler, gl_PointCoord.st);\\ncol *= tcol;\\nif (tcol.r < 0.0) {\\ndiscard;\\n} else {\\ngl_FragColor = col;\\n}\\n} else {\\ngl_FragColor = col;\\n}\\n}\",\"fragment\");if(!k||!e)return b=!1,\r\nc(),!1;b=d.createProgram();d.attachShader(b,k);d.attachShader(b,e);d.linkProgram(b);if(!d.getProgramParameter(b,d.LINK_STATUS))return v.push(d.getProgramInfoLog(b)),c(),b=!1;d.useProgram(b);d.bindAttribLocation(b,0,\"aVertexPosition\");N=g(\"uPMatrix\");p=g(\"pSize\");n=g(\"fillColor\");l=g(\"isBubble\");D=g(\"bubbleSizeAbs\");G=g(\"bubbleSizeByArea\");M=g(\"uSampler\");a=g(\"skipTranslation\");t=g(\"isCircle\");H=g(\"isInverted\");return!0}function q(a,c){d&&b&&(a=h[a]=h[a]||d.getUniformLocation(b,a),d.uniform1f(a,c))}\r\nvar h={},b,N,p,n,l,D,G,a,t,H,v=[],M;return d&&!r()?!1:{psUniform:function(){return p},pUniform:function(){return N},fillColorUniform:function(){return n},setBubbleUniforms:function(a,c,e){var g=a.options,p=Number.MAX_VALUE,H=-Number.MAX_VALUE;d&&b&&\"bubble\"===a.type&&(p=C(g.zMin,k(c,!1===g.displayNegative?g.zThreshold:-Number.MAX_VALUE,p)),H=C(g.zMax,Math.max(H,e)),d.uniform1i(l,1),d.uniform1i(t,1),d.uniform1i(G,\"width\"!==a.options.sizeBy),d.uniform1i(D,a.options.sizeByAbsoluteValue),q(\"bubbleZMin\",\r\np),q(\"bubbleZMax\",H),q(\"bubbleZThreshold\",a.options.zThreshold),q(\"bubbleMinSize\",a.minPxSize),q(\"bubbleMaxSize\",a.maxPxSize))},bind:function(){d&&b&&d.useProgram(b)},program:function(){return b},create:r,setUniform:q,setPMatrix:function(a){d&&b&&d.uniformMatrix4fv(N,!1,a)},setColor:function(a){d&&b&&d.uniform4f(n,a[0]/255,a[1]/255,a[2]/255,a[3])},setPointSize:function(a){d&&b&&d.uniform1f(p,a)},setSkipTranslation:function(g){d&&b&&d.uniform1i(a,!0===g?1:0)},setTexture:function(a){d&&b&&d.uniform1i(M,\r\na)},setDrawAsCircle:function(a){d&&b&&d.uniform1i(t,a?1:0)},reset:function(){d&&b&&(d.uniform1i(l,0),d.uniform1i(t,0))},setInverted:function(a){d&&b&&d.uniform1i(H,a)},destroy:function(){d&&b&&(d.deleteProgram(b),b=!1)}}}});m(c,\"modules/boost/wgl-vbuffer.js\",[],function(){return function(c,E,f){function k(){d&&(c.deleteBuffer(d),A=d=!1);q=0;w=f||2;h=[]}var d=!1,A=!1,w=f||2,r=!1,q=0,h;return{destroy:k,bind:function(){if(!d)return!1;c.vertexAttribPointer(A,w,c.FLOAT,!1,0,0)},data:h,build:function(b,\r\nf,p){var n;h=b||[];if(!(h&&0!==h.length||r))return k(),!1;w=p||w;d&&c.deleteBuffer(d);r||(n=new Float32Array(h));d=c.createBuffer();c.bindBuffer(c.ARRAY_BUFFER,d);c.bufferData(c.ARRAY_BUFFER,r||n,c.STATIC_DRAW);A=c.getAttribLocation(E.program(),f);c.enableVertexAttribArray(A);return!0},render:function(b,k,p){var n=r?r.length:h.length;if(!d||!n)return!1;if(!b||b>n||0>b)b=0;if(!k||k>n)k=n;c.drawArrays(c[(p||\"points\").toUpperCase()],b/w,(k-b)/w);return!0},allocate:function(b){q=-1;r=new Float32Array(4*\r\nb)},push:function(b,c,d,n){r&&(r[++q]=b,r[++q]=c,r[++q]=d,r[++q]=n)}}}});m(c,\"modules/boost/wgl-renderer.js\",[c[\"parts/Globals.js\"],c[\"modules/boost/wgl-shader.js\"],c[\"modules/boost/wgl-vbuffer.js\"],c[\"parts/Color.js\"],c[\"parts/Utilities.js\"]],function(c,E,f,C,d){var k=C.parse,w=d.isNumber,r=d.isObject,q=d.merge,h=d.objectEach,b=d.pick,N=c.win.document;return function(d){function p(a){if(a.isSeriesBoosting){var b=!!a.options.stacking;var R=a.xData||a.options.xData||a.processedXData;b=(b?a.data:R||\r\na.options.data).length;\"treemap\"===a.type?b*=12:\"heatmap\"===a.type?b*=6:U[a.type]&&(b*=2);return b}return 0}function l(){e.clear(e.COLOR_BUFFER_BIT|e.DEPTH_BUFFER_BIT)}function D(a,b){function c(a){a&&(b.colorData.push(a[0]),b.colorData.push(a[1]),b.colorData.push(a[2]),b.colorData.push(a[3]))}function e(a,b,e,g,d){c(d);z.usePreallocated?A.push(a,b,e?1:0,g||1):(O.push(a),O.push(b),O.push(e?1:0),O.push(g||1))}function g(){b.segments.length&&(b.segments[b.segments.length-1].to=O.length)}function d(){b.segments.length&&\r\nb.segments[b.segments.length-1].from===O.length||(g(),b.segments.push({from:O.length}))}function p(a,b,g,d,y){c(y);e(a+g,b);c(y);e(a,b);c(y);e(a,b+d);c(y);e(a,b+d);c(y);e(a+g,b+d);c(y);e(a+g,b)}function t(a,c){z.useGPUTranslations||(b.skipTranslation=!0,a.x=m.toPixels(a.x,!0),a.y=q.toPixels(a.y,!0));c?O=[a.x,a.y,0,2].concat(O):e(a.x,a.y,0,2)}var R=a.pointArrayMap&&\"low,high\"===a.pointArrayMap.join(\",\"),H=a.chart,y=a.options,n=!!y.stacking,w=y.data,l=a.xAxis.getExtremes(),v=l.min;l=l.max;var h=a.yAxis.getExtremes(),\r\nM=h.min;h=h.max;var f=a.xData||y.xData||a.processedXData,G=a.yData||y.yData||a.processedYData,D=a.zData||y.zData||a.processedZData,q=a.yAxis,m=a.xAxis,E=a.chart.plotWidth,N=!f||0===f.length,K=y.connectNulls,u=a.points||!1,J=!1,L=!1,S;f=n?a.data:f||w;var P={x:Number.MAX_VALUE,y:0},Q={x:-Number.MAX_VALUE,y:0},Y=0,la=!1,I=-1,T=!1,W=!1,ba=\"undefined\"===typeof H.index,ha=!1,ia=!1;var x=!1;var va=U[a.type],ja=!1,ra=!0,sa=!0,aa=y.zones||!1,X=!1,ta=y.threshold,ka=!1;if(!(y.boostData&&0b.node.levelDynamic)return 1;if(a.node.levelDynamicb.zMax&&(b.zMax=F[2]);F[2]b.zMax&&(b.zMax=D[I]),D[I]=v&&W<=l&&(ha=!0);T&&T>=v&&T<=l&&(ia=!0);if(R){N&&(B=F.slice(1,3));var ca=\r\nB[0];B=B[1]}else n&&(u=F.x,B=F.stackY,ca=B-F.y);null!==M&&\"undefined\"!==typeof M&&null!==h&&\"undefined\"!==typeof h&&(ra=B>=M&&B<=h);u>l&&Q.xv&&(P.x=u,P.y=B);if(null!==B||!K)if(null!==B&&(ra||ha||ia)){if((W>=v||u>=v)&&(T<=l||u<=l)&&(ja=!0),ja||ha||ia){ka&&u-T>ka&&d();aa&&(x=X.rgba,aa.some(function(a,b){b=aa[b-1];if(\"undefined\"!==typeof a.value&&B<=a.value){if(!b||B>=b.value)x=k(a.color).rgba;return!0}return!1}),x[0]/=255,x[1]/=255,x[2]/=255);if(!z.useGPUTranslations&&(b.skipTranslation=\r\n!0,u=m.toPixels(u,!0),B=q.toPixels(B,!0),u>E&&\"points\"===b.drawMode))continue;if(va){F=ca;if(!1===ca||\"undefined\"===typeof ca)F=0>B?B:0;R||n||(F=Math.max(null===ta?M:ta,M));z.useGPUTranslations||(F=q.toPixels(F,!0));e(u,F,0,0,x)}b.hasMarkers&&ja&&!1!==J&&(a.closestPointRangePx=Math.min(a.closestPointRangePx,Math.abs(u-J)));!z.useGPUTranslations&&!z.usePreallocated&&J&&1>Math.abs(u-J)&&L&&1>Math.abs(B-L)?z.debug.showSkipSummary&&++Y:(y.step&&!sa&&e(u,L,0,2,x),e(u,B,0,\"bubble\"===a.type?ua||1:2,x),J=\r\nu,L=B,la=!0,sa=!1)}}else d()}else d()}z.debug.showSkipSummary&&console.log(\"skipped points:\",Y);la||!1===K||\"line_strip\"!==a.drawMode||(P.x-Number.MAX_VALUE&&t(Q))}g()}}function G(){K=[];Q.data=O=[];Y=[];A&&A.destroy()}function a(a){g&&(g.setUniform(\"xAxisTrans\",a.transA),g.setUniform(\"xAxisMin\",a.min),g.setUniform(\"xAxisMinPad\",a.minPixelPadding),g.setUniform(\"xAxisPointRange\",a.pointRange),g.setUniform(\"xAxisLen\",a.len),g.setUniform(\"xAxisPos\",a.pos),g.setUniform(\"xAxisCVSCoord\",\r\n!a.horiz),g.setUniform(\"xAxisIsLog\",!!a.logarithmic),g.setUniform(\"xAxisReversed\",!!a.reversed))}function t(a){g&&(g.setUniform(\"yAxisTrans\",a.transA),g.setUniform(\"yAxisMin\",a.min),g.setUniform(\"yAxisMinPad\",a.minPixelPadding),g.setUniform(\"yAxisPointRange\",a.pointRange),g.setUniform(\"yAxisLen\",a.len),g.setUniform(\"yAxisPos\",a.pos),g.setUniform(\"yAxisCVSCoord\",!a.horiz),g.setUniform(\"yAxisIsLog\",!!a.logarithmic),g.setUniform(\"yAxisReversed\",!!a.reversed))}function H(a,b){g.setUniform(\"hasThreshold\",\r\na);g.setUniform(\"translatedThreshold\",b)}function v(p){if(p)m=p.chartWidth||800,J=p.chartHeight||400;else return!1;if(!(e&&m&&J&&g))return!1;z.debug.timeRendering&&console.time(\"gl rendering\");e.canvas.width=m;e.canvas.height=J;g.bind();e.viewport(0,0,m,J);g.setPMatrix([2/m,0,0,0,0,-(2/J),0,0,0,0,-2,0,-1,1,-1,1]);12*((n.marker?n.marker.radius:10)||10));l=L[l&&l.symbol||c.series.symbol]||L.circle;if(!(0===c.segments.length||c.segmentslength&&c.segments[0].from===c.segments[0].to)){l.isReady&&(e.bindTexture(e.TEXTURE_2D,l.handle),g.setTexture(l.handle));p.styledMode?l=c.series.markerGroup&&c.series.markerGroup.getStyle(\"fill\"):\r\n(l=c.series.pointAttribs&&c.series.pointAttribs().fill||c.series.color,n.colorByPoint&&(l=c.series.chart.options.colors[d]));c.series.fillOpacity&&n.fillOpacity&&(l=(new C(l)).setOpacity(b(n.fillOpacity,1)).get());l=k(l).rgba;z.useAlpha||(l[3]=1);\"lines\"===c.drawMode&&z.useAlpha&&1>l[3]&&(l[3]/=10);\"add\"===n.boostBlending?(e.blendFunc(e.SRC_ALPHA,e.ONE),e.blendEquation(e.FUNC_ADD)):\"mult\"===n.boostBlending||\"multiply\"===n.boostBlending?e.blendFunc(e.DST_COLOR,e.ZERO):\"darken\"===n.boostBlending?(e.blendFunc(e.ONE,\r\ne.ONE),e.blendEquation(e.FUNC_MIN)):e.blendFuncSeparate(e.SRC_ALPHA,e.ONE_MINUS_SRC_ALPHA,e.ONE,e.ONE_MINUS_SRC_ALPHA);g.reset();0=(a.options.boostThreshold||Number.MAX_VALUE)&&++c)}b.boostForceChartBoost=k&&(f===b.series.length&&0=D&&t<=N);if(null!==t&&h>=r&&h<=A&&f)if(a=k.toPixels(h,!0),ba){if(\"undefined\"===typeof V||a===U){y||(c=t);if(\"undefined\"===typeof Z||t>ea)ea=t,Z=b;if(\"undefined\"===typeof V||c=(c.options.boostThreshold||Number.MAX_VALUE)}var c=this,d=this.options.data;p(this.chart)&&A[this.type]?(b(d)&&\"heatmap\"!==this.type&&\"treemap\"!==this.type&&\r\n!this.options.stacking&&this.hasExtremes&&this.hasExtremes(!0)||(a.apply(this,Array.prototype.slice.call(arguments,1)),d=this.processedXData),(this.isSeriesBoosting=b(d))?(d=this.getFirstValidPoint(this.options.data),h(d)||q(d)||r(12,!1,this.chart),this.enterBoost()):this.exitBoost&&this.exitBoost()):a.apply(this,Array.prototype.slice.call(arguments,1))});k(l,\"hide\",function(){this.canvas&&this.renderTarget&&(this.ogl&&this.ogl.clear(),this.boostClear())});l.prototype.enterBoost=function(){this.alteredByBoost=\r\n[];[\"allowDG\",\"directTouch\",\"stickyTracking\"].forEach(function(a){this.alteredByBoost.push({prop:a,val:this[a],own:Object.hasOwnProperty.call(this,a)})},this);this.directTouch=this.allowDG=!1;this.stickyTracking=!0;this.labelBySeries&&(this.labelBySeries=this.labelBySeries.destroy())};l.prototype.exitBoost=function(){(this.alteredByBoost||[]).forEach(function(a){a.own?this[a.prop]=a.val:delete this[a.prop]},this);this.boostClear&&this.boostClear()};l.prototype.hasExtremes=function(a){var b=this.options,\r\nc=this.xAxis&&this.xAxis.options,d=this.yAxis&&this.yAxis.options,f=this.colorAxis&&this.colorAxis.options;return b.data.length>(b.boostThreshold||Number.MAX_VALUE)&&h(d.min)&&h(d.max)&&(!a||h(c.min)&&h(c.max))&&(!f||h(f.min)&&h(f.max))};l.prototype.destroyGraphics=function(){var a=this,b=this.points,c,d;if(b)for(d=0;dx||x>n?(++x,\r\n p=\"\"):(!isNaN(parseFloat(p))&&isFinite(p)?(p=parseFloat(p),f(\"number\")):isNaN(Date.parse(p))?f(\"string\"):(p=p.replace(/\\//g,\"-\"),f(\"date\")),v.lengthq[\",\"]?\";\":\",\";f.decimalPoint||(f.decimalPoint=d>c?\".\":\",\",g.decimalRegex=new RegExp(\"^(-?[0-9]+)\"+\r\n f.decimalPoint+\"([0-9]+)$\"));return e}function e(a,d){var c=[],e=0,b=!1,h=[],k=[],m;if(!d||d>a.length)d=a.length;for(;el[m]?\"YY\":\"YYYY\":12=l[m]?(c[m]=\"dd\",b=!0):c[m].length||\r\n (c[m]=\"mm\")))}if(b){for(m=0;ma)a=0;if(!h||h>=b.length)h=b.length-1;if(f.itemDelimiter)var B=f.itemDelimiter;else B=null,B=c(b);var w=0;for(l=a;l<=h;l++)\"#\"===b[l][0]?w++:d(b[l],l-a-w);f.columnTypes&&0!==f.columnTypes.length||!t.length||!t[0].length||\"date\"!==t[0][1]||f.dateFormat||(f.dateFormat=e(v[0]));this.dataFound()}return v},\r\n parseTable:function(){var a=this.options,d=a.table,c=this.columns,e=a.startRow||0,g=a.endRow||Number.MAX_VALUE,f=a.startColumn||0,b=a.endColumn||Number.MAX_VALUE;d&&(\"string\"===typeof d&&(d=I.getElementById(d)),[].forEach.call(d.getElementsByTagName(\"tr\"),function(a,d){d>=e&&d<=g&&[].forEach.call(a.children,function(a,g){var h=c[g-f],k=1;if((\"TD\"===a.tagName||\"TH\"===a.tagName)&&g>=f&&g<=b)for(c[g-f]||(c[g-f]=[]),c[g-f][d-e]=a.innerHTML;d-e>=k&&void 0===h[d-e-k];)h[d-e-k]=null,k++})}),this.dataFound());\r\n return c},fetchLiveData:function(){function a(k){function n(h,n,q){function l(){f&&c.liveDataURL===h&&(d.liveDataTimeout=setTimeout(a,x))}if(!h||0!==h.indexOf(\"http\"))return h&&e.error&&e.error(\"Invalid URL\"),!1;k&&(clearTimeout(d.liveDataTimeout),c.liveDataURL=h);b.ajax({url:h,dataType:q||\"json\",success:function(a){c&&c.series&&n(a);l()},error:function(a,d){3>++g&&l();return e.error&&e.error(d,a)}});return!0}n(h.csvURL,function(a){c.update({data:{csv:a}})},\"text\")||n(h.rowsURL,function(a){c.update({data:{rows:a}})})||\r\n n(h.columnsURL,function(a){c.update({data:{columns:a}})})}var d=this,c=this.chart,e=this.options,g=0,f=e.enablePolling,x=1E3*(e.dataRefreshRate||2),h=C(e);if(!this.hasURLOption(e))return!1;1E3>x&&(x=1E3);delete e.csvURL;delete e.rowsURL;delete e.columnsURL;a(!0);return this.hasURLOption(e)},parseGoogleSpreadsheet:function(){function a(d){var g=[\"https://spreadsheets.google.com/feeds/cells\",e,f,\"public/values?alt=json\"].join(\"/\");b.ajax({url:g,dataType:\"json\",success:function(e){d(e);c.enablePolling&&\r\n setTimeout(function(){a(d)},1E3*(c.dataRefreshRate||2))},error:function(a,d){return c.error&&c.error(d,a)}})}var d=this,c=this.options,e=c.googleSpreadsheetKey,g=this.chart,f=c.googleSpreadsheetWorksheet||1,x=c.startRow||0,h=c.endRow||Number.MAX_VALUE,k=c.startColumn||0,n=c.endColumn||Number.MAX_VALUE,l=1E3*(c.dataRefreshRate||2);4E3>l&&(l=4E3);e&&(delete c.googleSpreadsheetKey,a(function(a){var c=[];a=a.feed.entry;var e=(a||[]).length,f=0,b;if(!a||0===a.length)return!1;for(b=0;b=k&&b<=n&&(c[b-k]=[]);for(b=0;b=k&&t<=n&&f>=x&&f<=h){var p=l.gs$cell||l.content;l=null;p.numericValue?l=0<=p.$t.indexOf(\"/\")||0<=p.$t.indexOf(\"-\")?p.$t:0a[g+1])):(v&&v.length&&(h=this.parseDate(q)),n&&F(h)&&\"float\"!==t?(k[g]=q,a[g]=h,a.isDatetime=!0,\"undefined\"!==typeof a[g+1]&&(q=h>a[g+1],q!==l&&\"undefined\"!==\r\n typeof l&&(this.alternativeFormat?(this.dateFormat=this.alternativeFormat,g=a.length,this.alternativeFormat=this.dateFormats[this.dateFormat].alternative):a.unsorted=!0),l=q)):(a[g]=\"\"===v?null:v,0!==g&&(a.isDatetime||a.isNumeric)&&(a.mixed=!0)))}n&&a.mixed&&(e[d]=c[d]);if(n&&l&&this.options.sort)for(d=0;d(new Date).getFullYear()-2E3?d+1900:d+2E3;return Date.UTC(d,a[2]-1,+a[1])},alternative:\"mm/dd/YY\"},\r\n \"mm/dd/YY\":{regex:/^([0-9]{1,2})[\\-\\/\\.]([0-9]{1,2})[\\-\\/\\.]([0-9]{2})$/,parser:function(a){return Date.UTC(+a[3]+2E3,a[1]-1,+a[2])}}},parseDate:function(a){var d=this.options.parseDate,c,e=this.options.dateFormat||this.dateFormat,b;if(d)var f=d(a);else if(\"string\"===typeof a){if(e)(d=this.dateFormats[e])||(d=this.dateFormats[\"YYYY/mm/dd\"]),(b=a.match(d.regex))&&(f=d.parser(b));else for(c in this.dateFormats)if(d=this.dateFormats[c],b=a.match(d.regex)){this.dateFormat=c;this.alternativeFormat=d.alternative;\r\n f=d.parser(b);break}b||(b=Date.parse(a),\"object\"===typeof b&&null!==b&&b.getTime?f=b.getTime()-6E4*b.getTimezoneOffset():F(b)&&(f=b-6E4*(new Date(b)).getTimezoneOffset()))}return f},rowsToColumns:function(a){var d,c;if(a){var e=[];var b=a.length;for(d=0;d.*?$/,\"\").replace(/(fill|stroke)=\"rgba\\(([ 0-9]+,[ 0-9]+,[ 0-9]+),([ 0-9\\.]+)\\)\"/g,'$1=\"rgb($2)\" $1-opacity=\"$3\"').replace(/ /g,\"\\u00a0\").replace(//g,\"\\u00ad\").replace(/
/g,\"<$1title>\").replace(/height=([^\" ]+)/g,'height=\"$1\"').replace(/width=([^\" ]+)/g,'width=\"$1\"').replace(/hc-svg-href=\"([^\"]+)\">/g,'xlink:href=\"$1\"/>').replace(/ id=([^\" >]+)/g,\r\n' id=\"$1\"').replace(/class=([^\" >]+)/g,'class=\"$1\"').replace(/ transform /g,\" \").replace(/:(path|rect)/g,\"$1\").replace(/style=\"([^\"]+)\"/g,function(a){return a.toLowerCase()})},getChartHTML:function(){return this.container.innerHTML},getSVG:function(a){var b=this,e,c,g,j,h,d=l(b.options,a),m=d.exporting.allowHTML;if(!k.createElementNS)k.createElementNS=function(a,b){return k.createElement(b)};c=s(\"div\",null,{position:\"absolute\",top:\"-9999em\",width:b.chartWidth+\"px\",height:b.chartHeight+\"px\"},k.body);\r\ng=b.renderTo.style.width;h=b.renderTo.style.height;g=d.exporting.sourceWidth||d.chart.width||/px$/.test(g)&&parseInt(g,10)||600;h=d.exporting.sourceHeight||d.chart.height||/px$/.test(h)&&parseInt(h,10)||400;r(d.chart,{animation:!1,renderTo:c,forExport:!0,renderer:\"SVGRenderer\",width:g,height:h});d.exporting.enabled=!1;delete d.data;d.series=[];q(b.series,function(a){j=l(a.userOptions,{animation:!1,enableMouseTracking:!1,showCheckbox:!1,visible:a.visible});j.isInternal||d.series.push(j)});a&&q([\"xAxis\",\r\n\"yAxis\"],function(b){q(F(a[b]),function(a,c){d[b][c]=l(d[b][c],a)})});e=new f.Chart(d,b.callback);q([\"xAxis\",\"yAxis\"],function(a){q(b[a],function(b,c){var d=e[a][c],f=b.getExtremes(),g=f.userMin,f=f.userMax;d&&(g!==void 0||f!==void 0)&&d.setExtremes(g,f,!0,!1)})});g=e.getChartHTML();d=null;e.destroy();u(c);if(m&&(c=g.match(/<\\/svg>(.*?$)/)))c=''+c[1]+\"\",g=g.replace(\"\",c+\"\");\r\ng=this.sanitizeSVG(g);return g=g.replace(/(url\\(#highcharts-[0-9]+)"/g,\"$1\").replace(/"/g,\"'\")},getSVGForExport:function(a,b){var e=this.options.exporting;return this.getSVG(l({chart:{borderRadius:0}},e.chartOptions,b,{exporting:{sourceWidth:a&&a.sourceWidth||e.sourceWidth,sourceHeight:a&&a.sourceHeight||e.sourceHeight}}))},exportChart:function(a,b){var e=this.getSVGForExport(a,b),a=l(this.options.exporting,a);f.post(a.url,{filename:a.filename||\"chart\",type:a.type,width:a.width||0,scale:a.scale||\r\n2,svg:e},a.formAttributes)},print:function(){var a=this,b=a.container,e=[],c=b.parentNode,f=k.body,j=f.childNodes,h=a.options.exporting.printMaxWidth,d,m,n;if(!a.isPrinting){a.isPrinting=!0;a.pointer.reset(null,0);E(a,\"beforePrint\");if(n=h&&a.chartWidth>h)d=a.hasUserSize,m=[a.chartWidth,a.chartHeight,!1],a.setSize(h,a.chartHeight,!1);q(j,function(a,b){if(a.nodeType===1)e[b]=a.style.display,a.style.display=\"none\"});f.appendChild(b);t.focus();t.print();setTimeout(function(){c.appendChild(b);q(j,function(a,\r\nb){if(a.nodeType===1)a.style.display=e[b]});a.isPrinting=!1;if(n)a.setSize.apply(a,m),a.hasUserSize=d;E(a,\"afterPrint\")},1E3)}},contextMenu:function(a,b,e,c,f,j,h){var d=this,m=d.options.navigation,n=m.menuItemStyle,o=d.chartWidth,p=d.chartHeight,l=\"cache-\"+a,i=d[l],w=G(f,j),y,z,t,u=function(b){d.pointer.inClass(b.target,a)||z()};if(!i)d[l]=i=s(\"div\",{className:a},{position:\"absolute\",zIndex:1E3,padding:w+\"px\"},d.container),y=s(\"div\",null,r({MozBoxShadow:\"3px 3px 10px #888\",WebkitBoxShadow:\"3px 3px 10px #888\",\r\nboxShadow:\"3px 3px 10px #888\"},m.menuStyle),i),z=function(){x(i,{display:\"none\"});h&&h.setState(0);d.openMenu=!1},v(i,\"mouseleave\",function(){t=setTimeout(z,500)}),v(i,\"mouseenter\",function(){clearTimeout(t)}),v(k,\"mouseup\",u),v(d,\"destroy\",function(){D(k,\"mouseup\",u)}),q(b,function(a){if(a){var b=a.separator?s(\"hr\",null,null,y):s(\"div\",{onmouseover:function(){x(this,m.menuItemHoverStyle)},onmouseout:function(){x(this,n)},onclick:function(b){b&&b.stopPropagation();z();a.onclick&&a.onclick.apply(d,\r\narguments)},innerHTML:a.text||d.options.lang[a.textKey]},r({cursor:\"pointer\"},n),y);d.exportDivElements.push(b)}}),d.exportDivElements.push(y,i),d.exportMenuWidth=i.offsetWidth,d.exportMenuHeight=i.offsetHeight;b={display:\"block\"};e+d.exportMenuWidth>o?b.right=o-e-f-w+\"px\":b.left=e-w+\"px\";c+j+d.exportMenuHeight>p&&h.alignOptions.verticalAlign!==\"top\"?b.bottom=p-c-w+\"px\":b.top=c+j-w+\"px\";x(i,b);d.openMenu=!0},addButton:function(a){var b=this,e=b.renderer,c=l(b.options.navigation.buttonOptions,a),g=\r\nc.onclick,j=c.menuItems,h,d,m={stroke:c.symbolStroke,fill:c.symbolFill},n=c.symbolSize||12;if(!b.btnCount)b.btnCount=0;if(!b.exportDivElements)b.exportDivElements=[],b.exportSVGElements=[];if(c.enabled!==!1){var o=c.theme,p=o.states,k=p&&p.hover,p=p&&p.select,i;delete o.states;g?i=function(a){a.stopPropagation();g.call(b,a)}:j&&(i=function(){b.contextMenu(d.menuClassName,j,d.translateX,d.translateY,d.width,d.height,d);d.setState(2)});c.text&&c.symbol?o.paddingLeft=f.pick(o.paddingLeft,25):c.text||\r\nr(o,{width:c.width,height:c.height,padding:0});d=e.button(c.text,0,0,i,o,k,p).attr({title:b.options.lang[c._titleKey],\"stroke-linecap\":\"round\",zIndex:3});d.menuClassName=a.menuClassName||\"highcharts-menu-\"+b.btnCount++;c.symbol&&(h=e.symbol(c.symbol,c.symbolX-n/2,c.symbolY-n/2,n,n).attr(r(m,{\"stroke-width\":c.symbolStrokeWidth||1,zIndex:1})).add(d));d.add().align(r(c,{width:d.width,x:f.pick(c.x,B)}),!0,\"spacingBox\");B+=(d.width+c.buttonSpacing)*(c.align===\"right\"?-1:1);b.exportSVGElements.push(d,h)}},\r\ndestroyExport:function(a){var a=a.target,b,e;for(b=0;bd&&(\"right\"===\r\ng?b.align=\"left\":b.x=-d);d=c+n.width-e;d>a.plotWidth&&(\"left\"===g?b.align=\"right\":b.x=a.plotWidth-d);d=l+e;0>d&&(\"bottom\"===f?b.verticalAlign=\"top\":b.y=-d);d=l+n.height-e;d>a.plotHeight&&(\"top\"===f?b.verticalAlign=\"bottom\":b.y=a.plotHeight-d);return b};m.attrsMap={backgroundColor:\"fill\",borderColor:\"stroke\",borderWidth:\"stroke-width\",zIndex:\"zIndex\",borderRadius:\"r\",padding:\"padding\"};a(!0,m.prototype,e,{translatePoint:function(b,a){e.translatePoint.call(this,b,a,0)},translate:function(b,a){var c=\r\n this.annotation.chart,d=this.annotation.userOptions,g=c.annotations.indexOf(this.annotation);g=c.options.annotations[g];c.inverted&&(c=b,b=a,a=c);this.options.x+=b;this.options.y+=a;g[this.collection][this.index].x=this.options.x;g[this.collection][this.index].y=this.options.y;d[this.collection][this.index].x=this.options.x;d[this.collection][this.index].y=this.options.y},render:function(b){var a=this.options,c=this.attrsFromOptions(a),d=a.style;this.graphic=this.annotation.chart.renderer.label(\"\",\r\n 0,-9999,a.shape,null,null,a.useHTML,null,\"annotation-label\").attr(c).add(b);this.annotation.chart.styledMode||(\"contrast\"===d.color&&(d.color=this.annotation.chart.renderer.getContrast(-1A&&(A=-d-A);Aa+d?n.push(\"L\",b+g,a+d):eb+c&&n.push(\"L\",b+c,a+d/2)}return n||[]};return m});\r\n m(e,\"annotations/controllable/ControllableImage.js\",[e[\"parts/Utilities.js\"],e[\"annotations/controllable/controllableMixin.js\"],e[\"annotations/controllable/ControllableLabel.js\"]],function(d,c,e){d=d.merge;var k=function(b,c,d){this.init(b,c,d);this.collection=\"shapes\"};k.attrsMap={width:\"width\",height:\"height\",zIndex:\"zIndex\"};d(!0,k.prototype,c,{type:\"image\",translate:c.translateShape,render:function(b){var d=this.attrsFromOptions(this.options),e=this.options;this.graphic=this.annotation.chart.renderer.image(e.src,\r\n 0,-9E9,e.width,e.height).attr(d).add(b);this.graphic.width=e.width;this.graphic.height=e.height;c.render.call(this)},redraw:function(b){var d=this.anchor(this.points[0]);if(d=e.prototype.position.call(this,d))this.graphic[b?\"animate\":\"attr\"]({x:d.x,y:d.y});else this.graphic.attr({x:0,y:-9E9});this.graphic.placed=!!d;c.redraw.call(this,b)}});return k});m(e,\"annotations/annotations.src.js\",[e[\"parts/Globals.js\"],e[\"parts/Utilities.js\"],e[\"annotations/controllable/controllableMixin.js\"],e[\"annotations/controllable/ControllableRect.js\"],\r\n e[\"annotations/controllable/ControllableCircle.js\"],e[\"annotations/controllable/ControllablePath.js\"],e[\"annotations/controllable/ControllableImage.js\"],e[\"annotations/controllable/ControllableLabel.js\"],e[\"annotations/eventEmitterMixin.js\"],e[\"annotations/MockPoint.js\"],e[\"annotations/ControlPoint.js\"]],function(d,c,e,k,b,m,q,v,a,h,C){var f=c.addEvent,g=c.defined,l=c.destroyObjectProperties,p=c.erase,z=c.extend,u=c.find,r=c.merge,n=c.pick,A=c.splat;c=c.wrap;var w=d.fireEvent,D=d.reduce,x=d.Chart.prototype,\r\n y=d.Annotation=function(b,a){this.chart=b;this.points=[];this.controlPoints=[];this.coll=\"annotations\";this.labels=[];this.shapes=[];this.options=r(this.defaultOptions,a);this.userOptions=a;a=this.getLabelsAndShapesOptions(this.options,a);this.options.labels=a.labels;this.options.shapes=a.shapes;this.init(b,this.options)};r(!0,y.prototype,e,a,{nonDOMEvents:[\"add\",\"afterUpdate\",\"drag\",\"remove\"],defaultOptions:{visible:!0,draggable:\"xy\",labelOptions:{align:\"center\",allowOverlap:!1,backgroundColor:\"rgba(0, 0, 0, 0.75)\",\r\n borderColor:\"black\",borderRadius:3,borderWidth:1,className:\"\",crop:!1,formatter:function(){return g(this.y)?this.y:\"Annotation label\"},overflow:\"justify\",padding:5,shadow:!1,shape:\"callout\",style:{fontSize:\"11px\",fontWeight:\"normal\",color:\"contrast\"},useHTML:!1,verticalAlign:\"bottom\",x:0,y:-16},shapeOptions:{stroke:\"rgba(0, 0, 0, 0.75)\",strokeWidth:1,fill:\"rgba(0, 0, 0, 0.75)\",r:0,snap:2},controlPointOptions:{symbol:\"circle\",width:10,height:10,style:{stroke:\"black\",\"stroke-width\":2,fill:\"white\"},\r\n visible:!1,events:{}},events:{},zIndex:6},init:function(){this.linkPoints();this.addControlPoints();this.addShapes();this.addLabels();this.addClipPaths();this.setLabelCollector()},getLabelsAndShapesOptions:function(a,b){var c={};[\"labels\",\"shapes\"].forEach(function(d){a[d]&&(c[d]=A(b[d]).map(function(b,c){return r(a[d][c],b)}))});return c},addShapes:function(){(this.options.shapes||[]).forEach(function(a,b){a=this.initShape(a,b);r(!0,this.options.shapes[b],a.options)},this)},addLabels:function(){(this.options.labels||\r\n []).forEach(function(a,b){a=this.initLabel(a,b);r(!0,this.options.labels[b],a.options)},this)},addClipPaths:function(){this.setClipAxes();this.clipXAxis&&this.clipYAxis&&(this.clipRect=this.chart.renderer.clipRect(this.getClipBox()))},setClipAxes:function(){var a=this.chart.xAxis,b=this.chart.yAxis,c=D((this.options.labels||[]).concat(this.options.shapes||[]),function(c,d){return[a[d&&d.point&&d.point.xAxis]||c[0],b[d&&d.point&&d.point.yAxis]||c[1]]},[]);this.clipXAxis=c[0];this.clipYAxis=c[1]},getClipBox:function(){return{x:this.clipXAxis.left,\r\n y:this.clipYAxis.top,width:this.clipXAxis.width,height:this.clipYAxis.height}},setLabelCollector:function(){var a=this;a.labelCollector=function(){return a.labels.reduce(function(a,b){b.options.allowOverlap||a.push(b.graphic);return a},[])};a.chart.labelCollectors.push(a.labelCollector)},setOptions:function(a){this.options=r(this.defaultOptions,a)},redraw:function(a){this.linkPoints();this.graphic||this.render();this.clipRect&&this.clipRect.animate(this.getClipBox());this.redrawItems(this.shapes,\r\n a);this.redrawItems(this.labels,a);e.redraw.call(this,a)},redrawItems:function(a,b){for(var c=a.length;c--;)this.redrawItem(a[c],b)},render:function(){var a=this.chart.renderer;this.graphic=a.g(\"annotation\").attr({zIndex:this.options.zIndex,visibility:this.options.visible?\"visible\":\"hidden\"}).add();this.shapesGroup=a.g(\"annotation-shapes\").add(this.graphic).clip(this.chart.plotBoxClip);this.labelsGroup=a.g(\"annotation-labels\").attr({translateX:0,translateY:0}).add(this.graphic);this.clipRect&&this.graphic.clip(this.clipRect);\r\n this.addEvents();e.render.call(this)},setVisibility:function(a){var b=this.options;a=n(a,!b.visible);this.graphic.attr(\"visibility\",a?\"visible\":\"hidden\");a||this.setControlPointsVisibility(!1);b.visible=a},setControlPointsVisibility:function(a){var b=function(b){b.setControlPointsVisibility(a)};e.setControlPointsVisibility.call(this,a);this.shapes.forEach(b);this.labels.forEach(b)},destroy:function(){var b=this.chart,c=function(a){a.destroy()};this.labels.forEach(c);this.shapes.forEach(c);this.clipYAxis=\r\n this.clipXAxis=null;p(b.labelCollectors,this.labelCollector);a.destroy.call(this);e.destroy.call(this);l(this,b)},remove:function(){return this.chart.removeAnnotation(this)},update:function(a){var b=this.chart,c=this.getLabelsAndShapesOptions(this.userOptions,a),d=b.annotations.indexOf(this);a=r(!0,this.userOptions,a);a.labels=c.labels;a.shapes=c.shapes;this.destroy();this.constructor(b,a);b.options.annotations[d]=a;this.isUpdating=!0;this.redraw();this.isUpdating=!1;w(this,\"afterUpdate\")},initShape:function(a,\r\n b){a=r(this.options.shapeOptions,{controlPointOptions:this.options.controlPointOptions},a);b=new y.shapesMap[a.type](this,a,b);b.itemType=\"shape\";this.shapes.push(b);return b},initLabel:function(a,b){a=r(this.options.labelOptions,{controlPointOptions:this.options.controlPointOptions},a);b=new v(this,a,b);b.itemType=\"label\";this.labels.push(b);return b},redrawItem:function(a,b){a.linkPoints();a.shouldBeDrawn()?(a.graphic||this.renderItem(a),a.redraw(n(b,!0)&&a.graphic.placed),a.points.length&&this.adjustVisibility(a)):\r\n this.destroyItem(a)},adjustVisibility:function(a){var b=!1,c=a.graphic;a.points.forEach(function(a){!1!==a.series.visible&&!1!==a.visible&&(b=!0)});b?\"hidden\"===c.visibility&&c.show():c.hide()},destroyItem:function(a){p(this[a.itemType+\"s\"],a);a.destroy()},renderItem:function(a){a.render(\"label\"===a.itemType?this.labelsGroup:this.shapesGroup)}});y.shapesMap={rect:k,circle:b,path:m,image:q};y.types={};y.MockPoint=h;y.ControlPoint=C;d.extendAnnotation=function(a,b,c,d){b=b||y;r(!0,a.prototype,b.prototype,\r\n c);a.prototype.defaultOptions=r(a.prototype.defaultOptions,d||{})};z(x,{initAnnotation:function(a){a=new (y.types[a.type]||y)(this,a);this.annotations.push(a);return a},addAnnotation:function(a,b){a=this.initAnnotation(a);this.options.annotations.push(a.options);n(b,!0)&&a.redraw();return a},removeAnnotation:function(a){var b=this.annotations,c=\"annotations\"===a.coll?a:u(b,function(b){return b.options.id===a});c&&(w(c,\"remove\"),p(this.options.annotations,c.options),p(b,c),c.destroy())},drawAnnotations:function(){this.plotBoxClip.attr(this.plotBox);\r\n this.annotations.forEach(function(a){a.redraw()})}});x.collectionsWithUpdate.push(\"annotations\");x.collectionsWithInit.annotations=[x.addAnnotation];x.callbacks.push(function(a){a.annotations=[];a.options.annotations||(a.options.annotations=[]);a.plotBoxClip=this.renderer.clipRect(this.plotBox);a.controlPointsGroup=a.renderer.g(\"control-points\").attr({zIndex:99}).clip(a.plotBoxClip).add();a.options.annotations.forEach(function(b,c){b=a.initAnnotation(b);a.options.annotations[c]=b.options});a.drawAnnotations();\r\n f(a,\"redraw\",a.drawAnnotations);f(a,\"destroy\",function(){a.plotBoxClip.destroy();a.controlPointsGroup.destroy()})});c(d.Pointer.prototype,\"onContainerMouseDown\",function(a){this.chart.hasDraggedAnnotation||a.apply(this,Array.prototype.slice.call(arguments,1))})});m(e,\"mixins/navigation.js\",[],function(){return{initUpdate:function(d){d.navigation||(d.navigation={updates:[],update:function(c,d){this.updates.forEach(function(e){e.update.call(e.context,c,d)})}})},addUpdate:function(d,c){c.navigation||\r\n this.initUpdate(c);c.navigation.updates.push({update:d,context:c})}}});m(e,\"annotations/navigationBindings.js\",[e[\"parts/Globals.js\"],e[\"parts/Utilities.js\"],e[\"mixins/navigation.js\"]],function(d,c,e){function k(b){var c=b.prototype.defaultOptions.events&&b.prototype.defaultOptions.events.click;l(!0,b.prototype.defaultOptions.events,{click:function(b){var d=this,e=d.chart.navigationBindings,f=e.activeAnnotation;c&&c.click.call(d,b);f!==d?(e.deselectAnnotation(),e.activeAnnotation=d,d.setControlPointsVisibility(!0),\r\n a(e,\"showPopup\",{annotation:d,formType:\"annotation-toolbar\",options:e.annotationToFields(d),onSubmit:function(a){var b={};\"remove\"===a.actionType?(e.activeAnnotation=!1,e.chart.removeAnnotation(d)):(e.fieldsToOptions(a.fields,b),e.deselectAnnotation(),a=b.typeOptions,\"measure\"===d.options.type&&(a.crosshairY.enabled=0!==a.crosshairY.strokeWidth,a.crosshairX.enabled=0!==a.crosshairX.strokeWidth),d.update(b))}})):(e.deselectAnnotation(),a(e,\"closePopup\"));b.activeAnnotation=!0}})}var b=c.addEvent,m=\r\n c.attr,q=c.extend,B=c.format,a=c.fireEvent,h=c.isArray,C=c.isFunction,f=c.isNumber,g=c.isObject,l=c.merge,p=c.objectEach,z=c.pick,u=d.doc,r=d.win;d.NavigationBindings=function(a,b){this.chart=a;this.options=b;this.eventsToUnbind=[];this.container=u.getElementsByClassName(this.options.bindingsClassName)};d.NavigationBindings.annotationsEditable={nestedOptions:{labelOptions:[\"style\",\"format\",\"backgroundColor\"],labels:[\"style\"],label:[\"style\"],style:[\"fontSize\",\"color\"],background:[\"fill\",\"strokeWidth\",\r\n \"stroke\"],innerBackground:[\"fill\",\"strokeWidth\",\"stroke\"],outerBackground:[\"fill\",\"strokeWidth\",\"stroke\"],shapeOptions:[\"fill\",\"strokeWidth\",\"stroke\"],shapes:[\"fill\",\"strokeWidth\",\"stroke\"],line:[\"strokeWidth\",\"stroke\"],backgroundColors:[!0],connector:[\"fill\",\"strokeWidth\",\"stroke\"],crosshairX:[\"strokeWidth\",\"stroke\"],crosshairY:[\"strokeWidth\",\"stroke\"]},circle:[\"shapes\"],verticalLine:[],label:[\"labelOptions\"],measure:[\"background\",\"crosshairY\",\"crosshairX\"],fibonacci:[],tunnel:[\"background\",\"line\",\r\n \"height\"],pitchfork:[\"innerBackground\",\"outerBackground\"],rect:[\"shapes\"],crookedLine:[]};d.NavigationBindings.annotationsNonEditable={rectangle:[\"crosshairX\",\"crosshairY\",\"label\"]};q(d.NavigationBindings.prototype,{initEvents:function(){var a=this,c=a.chart,d=a.container,e=a.options;a.boundClassNames={};p(e.bindings,function(b){a.boundClassNames[b.className]=b});[].forEach.call(d,function(c){a.eventsToUnbind.push(b(c,\"click\",function(b){var c=a.getButtonEvents(d,b);c&&a.bindingsButtonClick(c.button,\r\n c.events,b)}))});p(e.events||{},function(c,d){C(c)&&a.eventsToUnbind.push(b(a,d,c))});a.eventsToUnbind.push(b(c.container,\"click\",function(b){!c.cancelClick&&c.isInsidePlot(b.chartX-c.plotLeft,b.chartY-c.plotTop)&&a.bindingsChartClick(this,b)}));a.eventsToUnbind.push(b(c.container,\"mousemove\",function(b){a.bindingsContainerMouseMove(this,b)}))},initUpdate:function(){var a=this;e.addUpdate(function(b){a.update(b)},this.chart)},bindingsButtonClick:function(b,c,d){var e=this.chart;this.selectedButtonElement&&\r\n (a(this,\"deselectButton\",{button:this.selectedButtonElement}),this.nextEvent&&(this.currentUserDetails&&\"annotations\"===this.currentUserDetails.coll&&e.removeAnnotation(this.currentUserDetails),this.mouseMoveEvent=this.nextEvent=!1));this.selectedButton=c;this.selectedButtonElement=b;a(this,\"selectButton\",{button:b});c.init&&c.init.call(this,b,d);(c.start||c.steps)&&e.renderer.boxWrapper.addClass(\"highcharts-draw-mode\")},bindingsChartClick:function(b,c){b=this.chart;var d=this.selectedButton;b=b.renderer.boxWrapper;\r\n var e;if(e=this.activeAnnotation&&!c.activeAnnotation&&c.target.parentNode){a:{e=c.target;var f=r.Element.prototype,g=f.matches||f.msMatchesSelector||f.webkitMatchesSelector,n=null;if(f.closest)n=f.closest.call(e,\".highcharts-popup\");else{do{if(g.call(e,\".highcharts-popup\"))break a;e=e.parentElement||e.parentNode}while(null!==e&&1===e.nodeType)}e=n}e=!e}e&&(a(this,\"closePopup\"),this.deselectAnnotation());d&&d.start&&(this.nextEvent?(this.nextEvent(c,this.currentUserDetails),this.steps&&(this.stepIndex++,\r\n d.steps[this.stepIndex]?this.mouseMoveEvent=this.nextEvent=d.steps[this.stepIndex]:(a(this,\"deselectButton\",{button:this.selectedButtonElement}),b.removeClass(\"highcharts-draw-mode\"),d.end&&d.end.call(this,c,this.currentUserDetails),this.mouseMoveEvent=this.nextEvent=!1,this.selectedButton=null))):(this.currentUserDetails=d.start.call(this,c),d.steps?(this.stepIndex=0,this.steps=!0,this.mouseMoveEvent=this.nextEvent=d.steps[this.stepIndex]):(a(this,\"deselectButton\",{button:this.selectedButtonElement}),\r\n b.removeClass(\"highcharts-draw-mode\"),this.steps=!1,this.selectedButton=null,d.end&&d.end.call(this,c,this.currentUserDetails))))},bindingsContainerMouseMove:function(a,b){this.mouseMoveEvent&&this.mouseMoveEvent(b,this.currentUserDetails)},fieldsToOptions:function(a,b){p(a,function(a,c){var d=parseFloat(a),e=c.split(\".\"),g=b,n=e.length-1;!f(d)||a.match(/px/g)||c.match(/format/g)||(a=d);\"\"!==a&&\"undefined\"!==a&&e.forEach(function(b,c){var d=z(e[c+1],\"\");n===c?g[b]=a:(g[b]||(g[b]=d.match(/\\d/g)?[]:\r\n {}),g=g[b])})});return b},deselectAnnotation:function(){this.activeAnnotation&&(this.activeAnnotation.setControlPointsVisibility(!1),this.activeAnnotation=!1)},annotationToFields:function(a){function b(c,d,e,l){if(e&&-1===k.indexOf(d)&&(0<=(e.indexOf&&e.indexOf(d))||e[d]||!0===e))if(h(c))l[d]=[],c.forEach(function(a,c){g(a)?(l[d][c]={},p(a,function(a,e){b(a,e,f[d],l[d][c])})):b(a,0,f[d],l[d])});else if(g(c)){var w={};h(l)?(l.push(w),w[d]={},w=w[d]):l[d]=w;p(c,function(a,c){b(a,c,0===d?e:f[d],w)})}else\"format\"===\r\n d?l[d]=[B(c,a.labels[0].points[0]).toString(),\"text\"]:h(l)?l.push([c,n(c)]):l[d]=[c,n(c)]}var c=a.options,e=d.NavigationBindings.annotationsEditable,f=e.nestedOptions,n=this.utils.getFieldType,l=z(c.type,c.shapes&&c.shapes[0]&&c.shapes[0].type,c.labels&&c.labels[0]&&c.labels[0].itemType,\"label\"),k=d.NavigationBindings.annotationsNonEditable[c.langKey]||[],u={langKey:c.langKey,type:l};p(c,function(a,d){\"typeOptions\"===d?(u[d]={},p(c[d],function(a,c){b(a,c,f,u[d],!0)})):b(a,d,e[l],u)});return u},getClickedClassNames:function(a,\r\n b){var c=b.target;b=[];for(var d;c&&((d=m(c,\"class\"))&&(b=b.concat(d.split(\" \").map(function(a){return[a,c]}))),c=c.parentNode,c!==a););return b},getButtonEvents:function(a,b){var c=this,d;this.getClickedClassNames(a,b).forEach(function(a){c.boundClassNames[a[0]]&&!d&&(d={events:c.boundClassNames[a[0]],button:a[1]})});return d},update:function(a){this.options=l(!0,this.options,a);this.removeEvents();this.initEvents()},removeEvents:function(){this.eventsToUnbind.forEach(function(a){a()})},destroy:function(){this.removeEvents()},\r\n utils:{updateRectSize:function(a,b){var c=b.chart,d=b.options.typeOptions,e=c.pointer.getCoordinates(a);a=e.xAxis[0].value-d.point.x;d=d.point.y-e.yAxis[0].value;b.update({typeOptions:{background:{width:c.inverted?d:a,height:c.inverted?a:d}}})},getFieldType:function(a){return{string:\"text\",number:\"number\",\"boolean\":\"checkbox\"}[typeof a]}}});d.Chart.prototype.initNavigationBindings=function(){var a=this.options;a&&a.navigation&&a.navigation.bindings&&(this.navigationBindings=new d.NavigationBindings(this,\r\n a.navigation),this.navigationBindings.initEvents(),this.navigationBindings.initUpdate())};b(d.Chart,\"load\",function(){this.initNavigationBindings()});b(d.Chart,\"destroy\",function(){this.navigationBindings&&this.navigationBindings.destroy()});b(d.NavigationBindings,\"deselectButton\",function(){this.selectedButtonElement=null});b(d.Annotation,\"remove\",function(){this.chart.navigationBindings&&this.chart.navigationBindings.deselectAnnotation()});d.Annotation&&(k(d.Annotation),p(d.Annotation.types,function(a){k(a)}));\r\n d.setOptions({lang:{navigation:{popup:{simpleShapes:\"Simple shapes\",lines:\"Lines\",circle:\"Circle\",rectangle:\"Rectangle\",label:\"Label\",shapeOptions:\"Shape options\",typeOptions:\"Details\",fill:\"Fill\",format:\"Text\",strokeWidth:\"Line width\",stroke:\"Line color\",title:\"Title\",name:\"Name\",labelOptions:\"Label options\",labels:\"Labels\",backgroundColor:\"Background color\",backgroundColors:\"Background colors\",borderColor:\"Border color\",borderRadius:\"Border radius\",borderWidth:\"Border width\",style:\"Style\",padding:\"Padding\",\r\n fontSize:\"Font size\",color:\"Color\",height:\"Height\",shapes:\"Shape options\"}}},navigation:{bindingsClassName:\"highcharts-bindings-container\",bindings:{circleAnnotation:{className:\"highcharts-circle-annotation\",start:function(a){a=this.chart.pointer.getCoordinates(a);var b=this.chart.options.navigation;return this.chart.addAnnotation(l({langKey:\"circle\",shapes:[{type:\"circle\",point:{xAxis:0,yAxis:0,x:a.xAxis[0].value,y:a.yAxis[0].value},r:5,controlPoints:[{positioner:function(a){var b=d.Annotation.MockPoint.pointToPixels(a.points[0]);\r\n a=a.options.r;return{x:b.x+a*Math.cos(Math.PI/4)-this.graphic.width/2,y:b.y+a*Math.sin(Math.PI/4)-this.graphic.height/2}},events:{drag:function(a,b){var c=b.annotation;a=this.mouseMoveToTranslation(a);b.setRadius(Math.max(b.options.r+a.y/Math.sin(Math.PI/4),5));c.options.shapes[0]=c.userOptions.shapes[0]=b.options;b.redraw(!1)}}}]}]},b.annotationsOptions,b.bindings.circleAnnotation.annotationsOptions))},steps:[function(a,b){var c=b.options.shapes[0].point,d=this.chart.xAxis[0].toPixels(c.x);c=this.chart.yAxis[0].toPixels(c.y);\r\n var e=this.chart.inverted;b.update({shapes:[{r:Math.max(Math.sqrt(Math.pow(e?c-a.chartX:d-a.chartX,2)+Math.pow(e?d-a.chartY:c-a.chartY,2)),5)}]})}]},rectangleAnnotation:{className:\"highcharts-rectangle-annotation\",start:function(a){var b=this.chart.pointer.getCoordinates(a),c=this.chart.options.navigation,e=b.xAxis[0].value;b=b.yAxis[0].value;return this.chart.addAnnotation(l({langKey:\"rectangle\",shapes:[{type:\"path\",points:[{xAxis:0,yAxis:0,x:e,y:b},{xAxis:0,yAxis:0,x:e,y:b},{xAxis:0,yAxis:0,x:e,\r\n y:b},{xAxis:0,yAxis:0,x:e,y:b}]}],controlPoints:[{positioner:function(a){a=d.Annotation.MockPoint.pointToPixels(a.shapes[0].points[2]);return{x:a.x-4,y:a.y-4}},events:{drag:function(b){var c=this.chart.pointer.getCoordinates(a),d=c.xAxis[0].value;c=c.yAxis[0].value;var e=b.options.shapes[0].points;e[1].x=d;e[2].x=d;e[2].y=c;e[3].y=c;b.options.shapes[0].points=e;b.redraw(!1)}}}]},c.annotationsOptions,c.bindings.rectangleAnnotation.annotationsOptions))},steps:[function(a,b){var c=b.options.shapes[0].points,\r\n d=this.chart.pointer.getCoordinates(a);a=d.xAxis[0].value;d=d.yAxis[0].value;c[1].x=a;c[2].x=a;c[2].y=d;c[3].y=d;b.update({shapes:[{points:c}]})}]},labelAnnotation:{className:\"highcharts-label-annotation\",start:function(a){a=this.chart.pointer.getCoordinates(a);var b=this.chart.options.navigation;return this.chart.addAnnotation(l({langKey:\"label\",labelOptions:{format:\"{y:.2f}\"},labels:[{point:{xAxis:0,yAxis:0,x:a.xAxis[0].value,y:a.yAxis[0].value},overflow:\"none\",crop:!0,controlPoints:[{symbol:\"triangle-down\",\r\n positioner:function(a){if(!a.graphic.placed)return{x:0,y:-9E7};a=d.Annotation.MockPoint.pointToPixels(a.points[0]);return{x:a.x-this.graphic.width/2,y:a.y-this.graphic.height/2}},events:{drag:function(a,b){a=this.mouseMoveToTranslation(a);b.translatePoint(a.x,a.y);b.annotation.labels[0].options=b.options;b.redraw(!1)}}},{symbol:\"square\",positioner:function(a){return a.graphic.placed?{x:a.graphic.alignAttr.x-this.graphic.width/2,y:a.graphic.alignAttr.y-this.graphic.height/2}:{x:0,y:-9E7}},events:{drag:function(a,\r\n b){a=this.mouseMoveToTranslation(a);b.translate(a.x,a.y);b.annotation.labels[0].options=b.options;b.redraw(!1)}}}]}]},b.annotationsOptions,b.bindings.labelAnnotation.annotationsOptions))}}},events:{},annotationsOptions:{}}})});m(e,\"annotations/popup.js\",[e[\"parts/Globals.js\"],e[\"parts/Utilities.js\"]],function(d,c){var e=c.addEvent,k=c.createElement,b=c.defined,m=c.isArray,q=c.isObject,v=c.isString,a=c.objectEach,h=c.pick;c=c.wrap;var C=/\\d/g;c(d.Pointer.prototype,\"onContainerMouseDown\",function(a,\r\n b){var c=b.target&&b.target.className;v(c)&&0<=c.indexOf(\"highcharts-popup-field\")||a.apply(this,Array.prototype.slice.call(arguments,1))});d.Popup=function(a,b){this.init(a,b)};d.Popup.prototype={init:function(a,b){this.container=k(\"div\",{className:\"highcharts-popup\"},null,a);this.lang=this.getLangpack();this.iconsURL=b;this.addCloseBtn()},addCloseBtn:function(){var a=this;var b=k(\"div\",{className:\"highcharts-popup-close\"},null,this.container);b.style[\"background-image\"]=\"url(\"+this.iconsURL+\"close.svg)\";\r\n [\"click\",\"touchstart\"].forEach(function(c){e(b,c,function(){a.closePopup()})})},addColsContainer:function(a){var b=k(\"div\",{className:\"highcharts-popup-lhs-col\"},null,a);a=k(\"div\",{className:\"highcharts-popup-rhs-col\"},null,a);k(\"div\",{className:\"highcharts-popup-rhs-col-wrapper\"},null,a);return{lhsCol:b,rhsCol:a}},addInput:function(a,b,c,d){var e=a.split(\".\");e=e[e.length-1];var f=this.lang;b=\"highcharts-\"+b+\"-\"+e;b.match(C)||k(\"label\",{innerHTML:f[e]||e,htmlFor:b},null,c);k(\"input\",{name:b,value:d[0],\r\n type:d[1],className:\"highcharts-popup-field\"},null,c).setAttribute(\"highcharts-data-name\",a)},addButton:function(a,b,c,d,h){var f=this,g=this.closePopup,l=this.getFields;var p=k(\"button\",{innerHTML:b},null,a);[\"click\",\"touchstart\"].forEach(function(a){e(p,a,function(){g.call(f);return d(l(h,c))})});return p},getFields:function(a,b){var c=a.querySelectorAll(\"input\"),d=a.querySelectorAll(\"#highcharts-select-series > option:checked\")[0];a=a.querySelectorAll(\"#highcharts-select-volume > option:checked\")[0];\r\n var e,f;var g={actionType:b,linkedTo:d&&d.getAttribute(\"value\"),fields:{}};[].forEach.call(c,function(a){f=a.getAttribute(\"highcharts-data-name\");(e=a.getAttribute(\"highcharts-data-series-id\"))?g.seriesId=a.value:f?g.fields[f]=a.value:g.type=a.value});a&&(g.fields[\"params.volumeSeriesID\"]=a.getAttribute(\"value\"));return g},showPopup:function(){var a=this.container,b=a.querySelectorAll(\".highcharts-popup-close\")[0];a.innerHTML=\"\";0<=a.className.indexOf(\"highcharts-annotation-toolbar\")&&(a.classList.remove(\"highcharts-annotation-toolbar\"),\r\n a.removeAttribute(\"style\"));a.appendChild(b);a.style.display=\"block\"},closePopup:function(){this.popup.container.style.display=\"none\"},showForm:function(a,b,c,d){this.popup=b.navigationBindings.popup;this.showPopup();\"indicators\"===a&&this.indicators.addForm.call(this,b,c,d);\"annotation-toolbar\"===a&&this.annotations.addToolbar.call(this,b,c,d);\"annotation-edit\"===a&&this.annotations.addForm.call(this,b,c,d);\"flag\"===a&&this.annotations.addForm.call(this,b,c,d,!0)},getLangpack:function(){return d.getOptions().lang.navigation.popup},\r\n annotations:{addToolbar:function(a,b,c){var d=this,e=this.lang,f=this.popup.container,g=this.showForm;-1===f.className.indexOf(\"highcharts-annotation-toolbar\")&&(f.className+=\" highcharts-annotation-toolbar\");f.style.top=a.plotTop+10+\"px\";k(\"span\",{innerHTML:h(e[b.langKey]||b.langKey,b.shapes&&b.shapes[0].type)},null,f);var l=this.addButton(f,e.removeButton||\"remove\",\"remove\",c,f);l.className+=\" highcharts-annotation-remove-button\";l.style[\"background-image\"]=\"url(\"+this.iconsURL+\"destroy.svg)\";l=\r\n this.addButton(f,e.editButton||\"edit\",\"edit\",function(){g.call(d,\"annotation-edit\",a,b,c)},f);l.className+=\" highcharts-annotation-edit-button\";l.style[\"background-image\"]=\"url(\"+this.iconsURL+\"edit.svg)\"},addForm:function(a,b,c,d){var e=this.popup.container,f=this.lang;k(\"h2\",{innerHTML:f[b.langKey]||b.langKey,className:\"highcharts-popup-main-title\"},null,e);var g=k(\"div\",{className:\"highcharts-popup-lhs-col highcharts-popup-lhs-full\"},null,e);var l=k(\"div\",{className:\"highcharts-popup-bottom-row\"},\r\n null,e);this.annotations.addFormFields.call(this,g,a,\"\",b,[],!0);this.addButton(l,d?f.addButton||\"add\":f.saveButton||\"save\",d?\"add\":\"save\",c,e)},addFormFields:function(b,c,d,e,h,u){var f=this,g=this.annotations.addFormFields,l=this.addInput,p=this.lang,z,x;a(e,function(a,e){z=\"\"!==d?d+\".\"+e:e;q(a)&&(!m(a)||m(a)&&q(a[0])?(x=p[e]||e,x.match(C)||h.push([!0,x,b]),g.call(f,b,c,z,a,h,!1)):h.push([f,z,\"annotation\",b,a]))});u&&(h=h.sort(function(a){return a[1].match(/format/g)?-1:1}),h.forEach(function(a){!0===\r\n a[0]?k(\"span\",{className:\"highcharts-annotation-title\",innerHTML:a[1]},null,a[2]):l.apply(a[0],a.splice(1))}))}},indicators:{addForm:function(a,b,c){var d=this.indicators,e=this.lang;this.tabs.init.call(this,a);b=this.popup.container.querySelectorAll(\".highcharts-tab-item-content\");this.addColsContainer(b[0]);d.addIndicatorList.call(this,a,b[0],\"add\");var f=b[0].querySelectorAll(\".highcharts-popup-rhs-col\")[0];this.addButton(f,e.addButton||\"add\",\"add\",c,f);this.addColsContainer(b[1]);d.addIndicatorList.call(this,\r\n a,b[1],\"edit\");f=b[1].querySelectorAll(\".highcharts-popup-rhs-col\")[0];this.addButton(f,e.saveButton||\"save\",\"edit\",c,f);this.addButton(f,e.removeButton||\"remove\",\"remove\",c,f)},addIndicatorList:function(b,c,d){var f=this,g=c.querySelectorAll(\".highcharts-popup-lhs-col\")[0];c=c.querySelectorAll(\".highcharts-popup-rhs-col\")[0];var l=\"edit\"===d,h=l?b.series:b.options.plotOptions,n=this.indicators.addFormFields,m;var q=k(\"ul\",{className:\"highcharts-indicator-list\"},null,g);var t=c.querySelectorAll(\".highcharts-popup-rhs-col-wrapper\")[0];\r\n a(h,function(a,c){var d=a.options;if(a.params||d&&d.params){var g=f.indicators.getNameType(a,c),p=g.type;m=k(\"li\",{className:\"highcharts-indicator-list\",innerHTML:g.name},null,q);[\"click\",\"touchstart\"].forEach(function(c){e(m,c,function(){n.call(f,b,l?a:h[p],g.type,t);l&&a.options&&k(\"input\",{type:\"hidden\",name:\"highcharts-id-\"+p,value:a.options.id},null,t).setAttribute(\"highcharts-data-series-id\",a.options.id)})})}});0