/* Highcharts JS v8.1.2 (2020-06-16) Annotations module (c) 2009-2019 Torstein Honsi License: www.highcharts.com/license */ (function(d){"object"===typeof module&&module.exports?(d["default"]=d,module.exports=d):"function"===typeof define&&define.amd?define("highcharts/modules/annotations-advanced",["highcharts"],function(t){d(t);d.Highcharts=t;return d}):d("undefined"!==typeof Highcharts?Highcharts:void 0)})(function(d){function t(d,f,l,g){d.hasOwnProperty(f)||(d[f]=g.apply(null,l))}d=d?d._modules:{};t(d,"annotations/eventEmitterMixin.js",[d["parts/Globals.js"],d["parts/Utilities.js"]],function(d,f){var l=f.addEvent, g=f.fireEvent,r=f.inArray,e=f.objectEach,k=f.pick,b=f.removeEvent;return{addEvents:function(){var a=this,c=function(c){l(c,d.isTouchDevice?"touchstart":"mousedown",function(c){a.onMouseDown(c)})};c(this.graphic.element);(a.labels||[]).forEach(function(a){a.options.useHTML&&a.graphic.text&&c(a.graphic.text.element)});e(a.options.events,function(c,b){var h=function(h){"click"===b&&a.cancelClick||c.call(a,a.chart.pointer.normalize(h),a.target)};if(-1===r(b,a.nonDOMEvents||[]))a.graphic.on(b,h);else l(a, b,h)});if(a.options.draggable&&(l(a,d.isTouchDevice?"touchmove":"drag",a.onDrag),!a.graphic.renderer.styledMode)){var b={cursor:{x:"ew-resize",y:"ns-resize",xy:"move"}[a.options.draggable]};a.graphic.css(b);(a.labels||[]).forEach(function(a){a.options.useHTML&&a.graphic.text&&a.graphic.text.css(b)})}a.isUpdating||g(a,"add")},removeDocEvents:function(){this.removeDrag&&(this.removeDrag=this.removeDrag());this.removeMouseUp&&(this.removeMouseUp=this.removeMouseUp())},onMouseDown:function(a){var c=this, b=c.chart.pointer;a.preventDefault&&a.preventDefault();if(2!==a.button){a=b.normalize(a);var p=a.chartX;var m=a.chartY;c.cancelClick=!1;c.chart.hasDraggedAnnotation=!0;c.removeDrag=l(d.doc,d.isTouchDevice?"touchmove":"mousemove",function(a){c.hasDragged=!0;a=b.normalize(a);a.prevChartX=p;a.prevChartY=m;g(c,"drag",a);p=a.chartX;m=a.chartY});c.removeMouseUp=l(d.doc,d.isTouchDevice?"touchend":"mouseup",function(a){c.cancelClick=c.hasDragged;c.hasDragged=!1;c.chart.hasDraggedAnnotation=!1;g(k(c.target, c),"afterUpdate");c.onMouseUp(a)})}},onMouseUp:function(a){var c=this.chart;a=this.target||this;var b=c.options.annotations;c=c.annotations.indexOf(a);this.removeDocEvents();b[c]=a.options},onDrag:function(a){if(this.chart.isInsidePlot(a.chartX-this.chart.plotLeft,a.chartY-this.chart.plotTop)){var c=this.mouseMoveToTranslation(a);"x"===this.options.draggable&&(c.y=0);"y"===this.options.draggable&&(c.x=0);this.points.length?this.translate(c.x,c.y):(this.shapes.forEach(function(a){a.translate(c.x,c.y)}), this.labels.forEach(function(a){a.translate(c.x,c.y)}));this.redraw(!1)}},mouseMoveToRadians:function(a,c,b){var h=a.prevChartY-b,m=a.prevChartX-c;b=a.chartY-b;a=a.chartX-c;this.chart.inverted&&(c=m,m=h,h=c,c=a,a=b,b=c);return Math.atan2(b,a)-Math.atan2(h,m)},mouseMoveToTranslation:function(a){var c=a.chartX-a.prevChartX;a=a.chartY-a.prevChartY;if(this.chart.inverted){var b=a;a=c;c=b}return{x:c,y:a}},mouseMoveToScale:function(a,c,b){c=(a.chartX-c||1)/(a.prevChartX-c||1);a=(a.chartY-b||1)/(a.prevChartY- b||1);this.chart.inverted&&(b=a,a=c,c=b);return{x:c,y:a}},destroy:function(){this.removeDocEvents();b(this);this.hcEvents=null}}});t(d,"annotations/ControlPoint.js",[d["parts/Utilities.js"],d["annotations/eventEmitterMixin.js"]],function(d,f){var l=d.merge,g=d.pick;return function(){function d(e,k,b,a){this.addEvents=f.addEvents;this.graphic=void 0;this.mouseMoveToRadians=f.mouseMoveToRadians;this.mouseMoveToScale=f.mouseMoveToScale;this.mouseMoveToTranslation=f.mouseMoveToTranslation;this.onDrag= f.onDrag;this.onMouseDown=f.onMouseDown;this.onMouseUp=f.onMouseUp;this.removeDocEvents=f.removeDocEvents;this.nonDOMEvents=["drag"];this.chart=e;this.target=k;this.options=b;this.index=g(b.index,a)}d.prototype.setVisibility=function(e){this.graphic.attr("visibility",e?"visible":"hidden");this.options.visible=e};d.prototype.render=function(){var e=this.chart,k=this.options;this.graphic=e.renderer.symbol(k.symbol,0,0,k.width,k.height).add(e.controlPointsGroup).css(k.style);this.setVisibility(k.visible); this.addEvents()};d.prototype.redraw=function(e){this.graphic[e?"animate":"attr"](this.options.positioner.call(this,this.target))};d.prototype.destroy=function(){f.destroy.call(this);this.graphic&&(this.graphic=this.graphic.destroy());this.options=this.target=this.chart=null};d.prototype.update=function(e){var k=this.chart,b=this.target,a=this.index;e=l(!0,this.options,e);this.destroy();this.constructor(k,b,e,a);this.render(k.controlPointsGroup);this.redraw()};return d}()});t(d,"annotations/MockPoint.js", [d["parts/Globals.js"],d["parts/Utilities.js"]],function(d,f){var l=f.defined,g=f.fireEvent;return function(){function f(e,k,b){this.y=this.x=this.plotY=this.plotX=this.isInside=void 0;this.mock=!0;this.series={visible:!0,chart:e,getPlotBox:d.Series.prototype.getPlotBox};this.target=k||null;this.options=b;this.applyOptions(this.getOptions())}f.fromPoint=function(e){return new f(e.series.chart,null,{x:e.x,y:e.y,xAxis:e.series.xAxis,yAxis:e.series.yAxis})};f.pointToPixels=function(e,k){var b=e.series, a=b.chart,c=e.plotX,h=e.plotY;a.inverted&&(e.mock?(c=e.plotY,h=e.plotX):(c=a.plotWidth-e.plotY,h=a.plotHeight-e.plotX));b&&!k&&(e=b.getPlotBox(),c+=e.translateX,h+=e.translateY);return{x:c,y:h}};f.pointToOptions=function(e){return{x:e.x,y:e.y,xAxis:e.series.xAxis,yAxis:e.series.yAxis}};f.prototype.hasDynamicOptions=function(){return"function"===typeof this.options};f.prototype.getOptions=function(){return this.hasDynamicOptions()?this.options(this.target):this.options};f.prototype.applyOptions=function(e){this.command= e.command;this.setAxis(e,"x");this.setAxis(e,"y");this.refresh()};f.prototype.setAxis=function(e,k){k+="Axis";e=e[k];var b=this.series.chart;this.series[k]=e instanceof d.Axis?e:l(e)?b[k][e]||b.get(e):null};f.prototype.toAnchor=function(){var e=[this.plotX,this.plotY,0,0];this.series.chart.inverted&&(e[0]=this.plotY,e[1]=this.plotX);return e};f.prototype.getLabelConfig=function(){return{x:this.x,y:this.y,point:this}};f.prototype.isInsidePlot=function(){var e=this.plotX,k=this.plotY,b=this.series.xAxis, a=this.series.yAxis,c={x:e,y:k,isInsidePlot:!0};b&&(c.isInsidePlot=l(e)&&0<=e&&e<=b.len);a&&(c.isInsidePlot=c.isInsidePlot&&l(k)&&0<=k&&k<=a.len);g(this.series.chart,"afterIsInsidePlot",c);return c.isInsidePlot};f.prototype.refresh=function(){var e=this.series,k=e.xAxis;e=e.yAxis;var b=this.getOptions();k?(this.x=b.x,this.plotX=k.toPixels(b.x,!0)):(this.x=null,this.plotX=b.x);e?(this.y=b.y,this.plotY=e.toPixels(b.y,!0)):(this.y=null,this.plotY=b.y);this.isInside=this.isInsidePlot()};f.prototype.translate= function(e,k,b,a){this.hasDynamicOptions()||(this.plotX+=b,this.plotY+=a,this.refreshOptions())};f.prototype.scale=function(e,k,b,a){if(!this.hasDynamicOptions()){var c=this.plotY*a;this.plotX=(1-b)*e+this.plotX*b;this.plotY=(1-a)*k+c;this.refreshOptions()}};f.prototype.rotate=function(e,k,b){if(!this.hasDynamicOptions()){var a=Math.cos(b);b=Math.sin(b);var c=this.plotX,h=this.plotY;c-=e;h-=k;this.plotX=c*a-h*b+e;this.plotY=c*b+h*a+k;this.refreshOptions()}};f.prototype.refreshOptions=function(){var e= this.series,k=e.xAxis;e=e.yAxis;this.x=this.options.x=k?this.options.x=k.toValue(this.plotX,!0):this.plotX;this.y=this.options.y=e?e.toValue(this.plotY,!0):this.plotY};return f}()});t(d,"annotations/controllable/controllableMixin.js",[d["annotations/ControlPoint.js"],d["annotations/MockPoint.js"],d["parts/Tooltip.js"],d["parts/Utilities.js"]],function(d,f,l,g){var r=g.isObject,e=g.isString,k=g.merge,b=g.splat;return{init:function(a,c,b){this.annotation=a;this.chart=a.chart;this.options=c;this.points= [];this.controlPoints=[];this.index=b;this.linkPoints();this.addControlPoints()},attr:function(){this.graphic.attr.apply(this.graphic,arguments)},getPointsOptions:function(){var a=this.options;return a.points||a.point&&b(a.point)},attrsFromOptions:function(a){var c=this.constructor.attrsMap,b={},p,m=this.chart.styledMode;for(p in a){var e=c[p];!e||m&&-1!==["fill","stroke","stroke-width"].indexOf(e)||(b[e]=a[p])}return b},anchor:function(a){var c=a.series.getPlotBox();a=a.mock?a.toAnchor():l.prototype.getAnchor.call({chart:a.series.chart}, a);a={x:a[0]+(this.options.x||0),y:a[1]+(this.options.y||0),height:a[2]||0,width:a[3]||0};return{relativePosition:a,absolutePosition:k(a,{x:a.x+c.translateX,y:a.y+c.translateY})}},point:function(a,c){if(a&&a.series)return a;c&&null!==c.series||(r(a)?c=new f(this.chart,this,a):e(a)?c=this.chart.get(a)||null:"function"===typeof a&&(c=a.call(c,this),c=c.series?c:new f(this.chart,this,a)));return c},linkPoints:function(){var a=this.getPointsOptions(),c=this.points,b=a&&a.length||0,p;for(p=0;ph&&("right"===p?b.align="left":b.x=-h);h=c+d.width-m;h>a.plotWidth&&("left"===p?b.align="right":b.x=a.plotWidth-h);h=n+m;0>h&&("bottom"===e?b.verticalAlign="top":b.y=-h);h=n+d.height-m;h>a.plotHeight&&("top"===e?b.verticalAlign="bottom":b.y=a.plotHeight-h);return b};h.attrsMap={backgroundColor:"fill",borderColor:"stroke",borderWidth:"stroke-width",zIndex:"zIndex",borderRadius:"r",padding:"padding"};a(!0,h.prototype,d,{translatePoint:function(a,b){d.translatePoint.call(this,a, b,0)},translate:function(a,b){var c=this.annotation.chart,h=this.annotation.userOptions,e=c.annotations.indexOf(this.annotation);e=c.options.annotations[e];c.inverted&&(c=a,a=b,b=c);this.options.x+=a;this.options.y+=b;e[this.collection][this.index].x=this.options.x;e[this.collection][this.index].y=this.options.y;h[this.collection][this.index].x=this.options.x;h[this.collection][this.index].y=this.options.y},render:function(a){var b=this.options,c=this.attrsFromOptions(b),e=b.style;this.graphic=this.annotation.chart.renderer.label("", 0,-9999,b.shape,null,null,b.useHTML,null,"annotation-label").attr(c).add(a);this.annotation.chart.styledMode||("contrast"===e.color&&(e.color=this.annotation.chart.renderer.getContrast(-1n&&(n=-e-n);nc+e?k.push(["L",a+m,c+e]):da+h&&k.push(["L",a+h,c+e/2])}return k|| []};return h});t(d,"annotations/controllable/ControllableImage.js",[d["annotations/controllable/ControllableLabel.js"],d["annotations/controllable/controllableMixin.js"],d["parts/Utilities.js"]],function(d,f,l){l=l.merge;var g=function(d,e,k){this.init(d,e,k);this.collection="shapes"};g.attrsMap={width:"width",height:"height",zIndex:"zIndex"};l(!0,g.prototype,f,{type:"image",translate:f.translateShape,render:function(d){var e=this.attrsFromOptions(this.options),k=this.options;this.graphic=this.annotation.chart.renderer.image(k.src, 0,-9E9,k.width,k.height).attr(e).add(d);this.graphic.width=k.width;this.graphic.height=k.height;f.render.call(this)},redraw:function(g){var e=this.anchor(this.points[0]);if(e=d.prototype.position.call(this,e))this.graphic[g?"animate":"attr"]({x:e.x,y:e.y});else this.graphic.attr({x:0,y:-9E9});this.graphic.placed=!!e;f.redraw.call(this,g)}});return g});t(d,"annotations/annotations.src.js",[d["parts/Chart.js"],d["annotations/controllable/controllableMixin.js"],d["annotations/controllable/ControllableRect.js"], d["annotations/controllable/ControllableCircle.js"],d["annotations/controllable/ControllablePath.js"],d["annotations/controllable/ControllableImage.js"],d["annotations/controllable/ControllableLabel.js"],d["annotations/ControlPoint.js"],d["annotations/eventEmitterMixin.js"],d["parts/Globals.js"],d["annotations/MockPoint.js"],d["parts/Pointer.js"],d["parts/Utilities.js"]],function(d,f,l,g,r,e,k,b,a,c,h,p,m){d=d.prototype;var B=m.addEvent,n=m.defined,q=m.destroyObjectProperties,x=m.erase,A=m.extend, v=m.find,w=m.fireEvent,u=m.merge,y=m.pick,C=m.splat;m=m.wrap;var z=function(){function c(a,b){this.annotation=void 0;this.coll="annotations";this.shapesGroup=this.labelsGroup=this.labelCollector=this.group=this.graphic=this.collection=void 0;this.chart=a;this.points=[];this.controlPoints=[];this.coll="annotations";this.labels=[];this.shapes=[];this.options=u(this.defaultOptions,b);this.userOptions=b;b=this.getLabelsAndShapesOptions(this.options,b);this.options.labels=b.labels;this.options.shapes= b.shapes;this.init(a,this.options)}c.prototype.init=function(){this.linkPoints();this.addControlPoints();this.addShapes();this.addLabels();this.setLabelCollector()};c.prototype.getLabelsAndShapesOptions=function(a,b){var c={};["labels","shapes"].forEach(function(h){a[h]&&(c[h]=C(b[h]).map(function(b,c){return u(a[h][c],b)}))});return c};c.prototype.addShapes=function(){(this.options.shapes||[]).forEach(function(a,b){a=this.initShape(a,b);u(!0,this.options.shapes[b],a.options)},this)};c.prototype.addLabels= function(){(this.options.labels||[]).forEach(function(a,b){a=this.initLabel(a,b);u(!0,this.options.labels[b],a.options)},this)};c.prototype.addClipPaths=function(){this.setClipAxes();this.clipXAxis&&this.clipYAxis&&(this.clipRect=this.chart.renderer.clipRect(this.getClipBox()))};c.prototype.setClipAxes=function(){var a=this.chart.xAxis,b=this.chart.yAxis,c=(this.options.labels||[]).concat(this.options.shapes||[]).reduce(function(c,h){return[a[h&&h.point&&h.point.xAxis]||c[0],b[h&&h.point&&h.point.yAxis]|| c[1]]},[]);this.clipXAxis=c[0];this.clipYAxis=c[1]};c.prototype.getClipBox=function(){if(this.clipXAxis&&this.clipYAxis)return{x:this.clipXAxis.left,y:this.clipYAxis.top,width:this.clipXAxis.width,height:this.clipYAxis.height}};c.prototype.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)};c.prototype.setOptions=function(a){this.options=u(this.defaultOptions, a)};c.prototype.redraw=function(a){this.linkPoints();this.graphic||this.render();this.clipRect&&this.clipRect.animate(this.getClipBox());this.redrawItems(this.shapes,a);this.redrawItems(this.labels,a);f.redraw.call(this,a)};c.prototype.redrawItems=function(a,b){for(var c=a.length;c--;)this.redrawItem(a[c],b)};c.prototype.renderItems=function(a){for(var b=a.length;b--;)this.renderItem(a[b])};c.prototype.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.addClipPaths();this.clipRect&&this.graphic.clip(this.clipRect);this.renderItems(this.shapes);this.renderItems(this.labels);this.addEvents();f.render.call(this)};c.prototype.setVisibility=function(a){var b=this.options;a=y(a,!b.visible);this.graphic.attr("visibility", a?"visible":"hidden");a||this.setControlPointsVisibility(!1);b.visible=a};c.prototype.setControlPointsVisibility=function(a){var b=function(b){b.setControlPointsVisibility(a)};f.setControlPointsVisibility.call(this,a);this.shapes.forEach(b);this.labels.forEach(b)};c.prototype.destroy=function(){var b=this.chart,c=function(a){a.destroy()};this.labels.forEach(c);this.shapes.forEach(c);this.clipYAxis=this.clipXAxis=null;x(b.labelCollectors,this.labelCollector);a.destroy.call(this);f.destroy.call(this); q(this,b)};c.prototype.remove=function(){return this.chart.removeAnnotation(this)};c.prototype.update=function(a,b){var c=this.chart,h=this.getLabelsAndShapesOptions(this.userOptions,a),e=c.annotations.indexOf(this);a=u(!0,this.userOptions,a);a.labels=h.labels;a.shapes=h.shapes;this.destroy();this.constructor(c,a);c.options.annotations[e]=a;this.isUpdating=!0;y(b,!0)&&c.redraw();w(this,"afterUpdate");this.isUpdating=!1};c.prototype.initShape=function(a,b){a=u(this.options.shapeOptions,{controlPointOptions:this.options.controlPointOptions}, a);b=new c.shapesMap[a.type](this,a,b);b.itemType="shape";this.shapes.push(b);return b};c.prototype.initLabel=function(a,b){a=u(this.options.labelOptions,{controlPointOptions:this.options.controlPointOptions},a);b=new k(this,a,b);b.itemType="label";this.labels.push(b);return b};c.prototype.redrawItem=function(a,b){a.linkPoints();a.shouldBeDrawn()?(a.graphic||this.renderItem(a),a.redraw(y(b,!0)&&a.graphic.placed),a.points.length&&this.adjustVisibility(a)):this.destroyItem(a)};c.prototype.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()};c.prototype.destroyItem=function(a){x(this[a.itemType+"s"],a);a.destroy()};c.prototype.renderItem=function(a){a.render("label"===a.itemType?this.labelsGroup:this.shapesGroup)};c.ControlPoint=b;c.MockPoint=h;c.shapesMap={rect:l,circle:g,path:r,image:e};c.types={};return c}();u(!0,z.prototype,f,a,u(z.prototype,{nonDOMEvents:["add","afterUpdate", "drag","remove"],defaultOptions:{visible:!0,draggable:"xy",labelOptions:{align:"center",allowOverlap:!1,backgroundColor:"rgba(0, 0, 0, 0.75)",borderColor:"black",borderRadius:3,borderWidth:1,className:"",crop:!1,formatter:function(){return n(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"},visible:!1,events:{}},events:{},zIndex:6}}));c.extendAnnotation=function(a,b,c,h){b=b||z;u(!0,a.prototype,b.prototype,c);a.prototype.defaultOptions=u(a.prototype.defaultOptions,h||{})};A(d,{initAnnotation:function(a){a=new (z.types[a.type]||z)(this,a);this.annotations.push(a);return a},addAnnotation:function(a,b){a=this.initAnnotation(a);this.options.annotations.push(a.options); y(b,!0)&&a.redraw();return a},removeAnnotation:function(a){var b=this.annotations,c="annotations"===a.coll?a:v(b,function(b){return b.options.id===a});c&&(w(c,"remove"),x(this.options.annotations,c.options),x(b,c),c.destroy())},drawAnnotations:function(){this.plotBoxClip.attr(this.plotBox);this.annotations.forEach(function(a){a.redraw()})}});d.collectionsWithUpdate.push("annotations");d.collectionsWithInit.annotations=[d.addAnnotation];d.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();B(a,"redraw",a.drawAnnotations);B(a,"destroy",function(){a.plotBoxClip.destroy();a.controlPointsGroup.destroy()})});m(p.prototype,"onContainerMouseDown",function(a){this.chart.hasDraggedAnnotation||a.apply(this, Array.prototype.slice.call(arguments,1))});return c.Annotation=z});t(d,"annotations/types/BasicAnnotation.js",[d["annotations/annotations.src.js"],d["annotations/MockPoint.js"],d["parts/Utilities.js"]],function(d,f,l){var g=this&&this.__extends||function(){var e=function(d,b){e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(a,b){a.__proto__=b}||function(a,b){for(var c in b)b.hasOwnProperty(c)&&(a[c]=b[c])};return e(d,b)};return function(d,b){function a(){this.constructor=d}e(d,b); d.prototype=null===b?Object.create(b):(a.prototype=b.prototype,new a)}}();l=l.merge;var r=function(e){function d(b,a){return e.call(this,b,a)||this}g(d,e);d.prototype.addControlPoints=function(){var b=this.options,a=d.basicControlPoints,c=b.langKey;(b.labels||b.shapes).forEach(function(b){c&&(b.controlPoints=a[c])})};d.basicControlPoints={label:[{symbol:"triangle-down",positioner:function(b){if(!b.graphic.placed)return{x:0,y:-9E7};b=f.pointToPixels(b.points[0]);return{x:b.x-this.graphic.width/2,y:b.y- this.graphic.height/2}},events:{drag:function(b,a){b=this.mouseMoveToTranslation(b);a.translatePoint(b.x,b.y);a.annotation.userOptions.labels[0].point=a.options.point;a.redraw(!1)}}},{symbol:"square",positioner:function(b){return b.graphic.placed?{x:b.graphic.alignAttr.x-this.graphic.width/2,y:b.graphic.alignAttr.y-this.graphic.height/2}:{x:0,y:-9E7}},events:{drag:function(b,a){b=this.mouseMoveToTranslation(b);a.translate(b.x,b.y);a.annotation.userOptions.labels[0].point=a.options.point;a.redraw(!1)}}}], rectangle:[{positioner:function(b){b=f.pointToPixels(b.points[2]);return{x:b.x-4,y:b.y-4}},events:{drag:function(b,a){var c=a.annotation,h=this.chart.pointer.getCoordinates(b);b=h.xAxis[0].value;h=h.yAxis[0].value;var e=a.options.points;e[1].x=b;e[2].x=b;e[2].y=h;e[3].y=h;c.userOptions.shapes[0].points=a.options.points;c.redraw(!1)}}}],circle:[{positioner:function(b){var a=f.pointToPixels(b.points[0]);b=b.options.r;return{x:a.x+b*Math.cos(Math.PI/4)-this.graphic.width/2,y:a.y+b*Math.sin(Math.PI/4)- this.graphic.height/2}},events:{drag:function(b,a){var c=a.annotation;b=this.mouseMoveToTranslation(b);a.setRadius(Math.max(a.options.r+b.y/Math.sin(Math.PI/4),5));c.userOptions.shapes[0].r=a.options.r;c.userOptions.shapes[0].point=a.options.point;a.redraw(!1)}}}]};return d}(d);r.prototype.defaultOptions=l(d.prototype.defaultOptions,{});return d.types.basicAnnotation=r});t(d,"annotations/types/CrookedLine.js",[d["annotations/annotations.src.js"],d["annotations/ControlPoint.js"],d["annotations/MockPoint.js"], d["parts/Utilities.js"]],function(d,f,l,g){var r=this&&this.__extends||function(){var e=function(b,a){e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(a,b){a.__proto__=b}||function(a,b){for(var c in b)b.hasOwnProperty(c)&&(a[c]=b[c])};return e(b,a)};return function(b,a){function c(){this.constructor=b}e(b,a);b.prototype=null===a?Object.create(a):(c.prototype=a.prototype,new c)}}(),e=g.merge;g=function(d){function b(a,b){return d.call(this,a,b)||this}r(b,d);b.prototype.setClipAxes= function(){this.clipXAxis=this.chart.xAxis[this.options.typeOptions.xAxis];this.clipYAxis=this.chart.yAxis[this.options.typeOptions.yAxis]};b.prototype.getPointsOptions=function(){var a=this.options.typeOptions;return(a.points||[]).map(function(b){b.xAxis=a.xAxis;b.yAxis=a.yAxis;return b})};b.prototype.getControlPointsOptions=function(){return this.getPointsOptions()};b.prototype.addControlPoints=function(){this.getControlPointsOptions().forEach(function(a,b){b=new f(this.chart,this,e(this.options.controlPointOptions, a.controlPoint),b);this.controlPoints.push(b);a.controlPoint=b.options},this)};b.prototype.addShapes=function(){var a=this.options.typeOptions,b=this.initShape(e(a.line,{type:"path",points:this.points.map(function(a,b){return function(a){return a.annotation.points[b]}})}),!1);a.line=b.options};return b}(d);g.prototype.defaultOptions=e(d.prototype.defaultOptions,{typeOptions:{xAxis:0,yAxis:0,line:{fill:"none"}},controlPointOptions:{positioner:function(e){var b=this.graphic;e=l.pointToPixels(e.points[this.index]); return{x:e.x-b.width/2,y:e.y-b.height/2}},events:{drag:function(e,b){b.chart.isInsidePlot(e.chartX-b.chart.plotLeft,e.chartY-b.chart.plotTop)&&(e=this.mouseMoveToTranslation(e),b.translatePoint(e.x,e.y,this.index),b.options.typeOptions.points[this.index].x=b.points[this.index].x,b.options.typeOptions.points[this.index].y=b.points[this.index].y,b.redraw(!1))}}}});return d.types.crookedLine=g});t(d,"annotations/types/ElliottWave.js",[d["annotations/annotations.src.js"],d["annotations/types/CrookedLine.js"], d["parts/Utilities.js"]],function(d,f,l){var g=this&&this.__extends||function(){var e=function(d,b){e=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(a,b){a.__proto__=b}||function(a,b){for(var c in b)b.hasOwnProperty(c)&&(a[c]=b[c])};return e(d,b)};return function(d,b){function a(){this.constructor=d}e(d,b);d.prototype=null===b?Object.create(b):(a.prototype=b.prototype,new a)}}(),r=l.merge;l=function(e){function d(b,a){return e.call(this,b,a)||this}g(d,e);d.prototype.addLabels=function(){this.getPointsOptions().forEach(function(b, a){var c=this.initLabel(r(b.label,{text:this.options.typeOptions.labels[a],point:function(b){return b.annotation.points[a]}}),!1);b.label=c.options},this)};return d}(f);l.prototype.defaultOptions=r(f.prototype.defaultOptions,{typeOptions:{labels:"(0) (A) (B) (C) (D) (E)".split(" "),line:{strokeWidth:1}},labelOptions:{align:"center",allowOverlap:!0,crop:!0,overflow:"none",type:"rect",backgroundColor:"none",borderWidth:0,y:-5}});return d.types.elliottWave=l});t(d,"annotations/types/Tunnel.js",[d["annotations/annotations.src.js"], d["annotations/ControlPoint.js"],d["annotations/types/CrookedLine.js"],d["annotations/MockPoint.js"],d["parts/Utilities.js"]],function(d,f,l,g,r){var e=this&&this.__extends||function(){var b=function(a,c){b=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(a,b){a.__proto__=b}||function(a,b){for(var c in b)b.hasOwnProperty(c)&&(a[c]=b[c])};return b(a,c)};return function(a,c){function e(){this.constructor=a}b(a,c);a.prototype=null===c?Object.create(c):(e.prototype=c.prototype,new e)}}(), k=r.merge;r=function(b){function a(a,e){return b.call(this,a,e)||this}e(a,b);a.prototype.getPointsOptions=function(){var a=l.prototype.getPointsOptions.call(this);a[2]=this.heightPointOptions(a[1]);a[3]=this.heightPointOptions(a[0]);return a};a.prototype.getControlPointsOptions=function(){return this.getPointsOptions().slice(0,2)};a.prototype.heightPointOptions=function(a){a=k(a);a.y+=this.options.typeOptions.height;return a};a.prototype.addControlPoints=function(){l.prototype.addControlPoints.call(this); var a=this.options,b=a.typeOptions;a=new f(this.chart,this,k(a.controlPointOptions,b.heightControlPoint),2);this.controlPoints.push(a);b.heightControlPoint=a.options};a.prototype.addShapes=function(){this.addLine();this.addBackground()};a.prototype.addLine=function(){var a=this.initShape(k(this.options.typeOptions.line,{type:"path",points:[this.points[0],this.points[1],function(a){a=g.pointToOptions(a.annotation.points[2]);a.command="M";return a},this.points[3]]}),!1);this.options.typeOptions.line= a.options};a.prototype.addBackground=function(){var a=this.initShape(k(this.options.typeOptions.background,{type:"path",points:this.points.slice()}));this.options.typeOptions.background=a.options};a.prototype.translateSide=function(a,b,e){e=Number(e);var c=0===e?3:2;this.translatePoint(a,b,e);this.translatePoint(a,b,c)};a.prototype.translateHeight=function(a){this.translatePoint(0,a,2);this.translatePoint(0,a,3);this.options.typeOptions.height=this.points[3].y-this.points[0].y};return a}(l);r.prototype.defaultOptions= k(l.prototype.defaultOptions,{typeOptions:{xAxis:0,yAxis:0,background:{fill:"rgba(130, 170, 255, 0.4)",strokeWidth:0},line:{strokeWidth:1},height:-2,heightControlPoint:{positioner:function(b){var a=g.pointToPixels(b.points[2]);b=g.pointToPixels(b.points[3]);var c=(a.x+b.x)/2;return{x:c-this.graphic.width/2,y:(b.y-a.y)/(b.x-a.x)*(c-a.x)+a.y-this.graphic.height/2}},events:{drag:function(b,a){a.chart.isInsidePlot(b.chartX-a.chart.plotLeft,b.chartY-a.chart.plotTop)&&(a.translateHeight(this.mouseMoveToTranslation(b).y), a.redraw(!1))}}}},controlPointOptions:{events:{drag:function(b,a){a.chart.isInsidePlot(b.chartX-a.chart.plotLeft,b.chartY-a.chart.plotTop)&&(b=this.mouseMoveToTranslation(b),a.translateSide(b.x,b.y,this.index),a.redraw(!1))}}}});return d.types.tunnel=r});t(d,"annotations/types/InfinityLine.js",[d["annotations/annotations.src.js"],d["annotations/types/CrookedLine.js"],d["annotations/MockPoint.js"],d["parts/Utilities.js"]],function(d,f,l,g){var r=this&&this.__extends||function(){var e=function(b,a){e= Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(a,b){a.__proto__=b}||function(a,b){for(var c in b)b.hasOwnProperty(c)&&(a[c]=b[c])};return e(b,a)};return function(b,a){function c(){this.constructor=b}e(b,a);b.prototype=null===a?Object.create(a):(c.prototype=a.prototype,new c)}}(),e=g.merge;g=function(d){function b(a,b){return d.call(this,a,b)||this}r(b,d);b.edgePoint=function(a,c){return function(e){e=e.annotation;var d=e.points,h=e.options.typeOptions.type;"horizontalLine"===h?d= [d[0],new l(e.chart,d[0].target,{x:d[0].x+1,y:d[0].y,xAxis:d[0].options.xAxis,yAxis:d[0].options.yAxis})]:"verticalLine"===h&&(d=[d[0],new l(e.chart,d[0].target,{x:d[0].x,y:d[0].y+1,xAxis:d[0].options.xAxis,yAxis:d[0].options.yAxis})]);return b.findEdgePoint(d[a],d[c])}};b.findEdgeCoordinate=function(a,b,e,d){var c="x"===e?"y":"x";return(b[e]-a[e])*(d-a[c])/(b[c]-a[c])+a[e]};b.findEdgePoint=function(a,c){var e=a.series.xAxis,d=c.series.yAxis,m=l.pointToPixels(a),f=l.pointToPixels(c),n=f.x-m.x,q=f.y- m.y;c=e.left;var k=c+e.width;e=d.top;d=e+d.height;var g=0>n?c:k,v=0>q?e:d;k={x:0===n?m.x:g,y:0===q?m.y:v};0!==n&&0!==q&&(n=b.findEdgeCoordinate(m,f,"y",g),m=b.findEdgeCoordinate(m,f,"x",v),n>=e&&n<=d?(k.x=g,k.y=n):(k.x=m,k.y=v));k.x-=c;k.y-=e;a.series.chart.inverted&&(a=k.x,k.x=k.y,k.y=a);return k};b.prototype.addShapes=function(){var a=this.options.typeOptions,c=[this.points[0],b.endEdgePoint];a.type.match(/Line/g)&&(c[0]=b.startEdgePoint);c=this.initShape(e(a.line,{type:"path",points:c}),!1);a.line= c.options};b.endEdgePoint=b.edgePoint(0,1);b.startEdgePoint=b.edgePoint(1,0);return b}(f);g.prototype.defaultOptions=e(f.prototype.defaultOptions,{});return d.types.infinityLine=g});t(d,"annotations/types/Fibonacci.js",[d["annotations/annotations.src.js"],d["annotations/MockPoint.js"],d["annotations/types/Tunnel.js"],d["parts/Utilities.js"]],function(d,f,l,g){var r=this&&this.__extends||function(){var b=function(a,c){b=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(a,b){a.__proto__= b}||function(a,b){for(var c in b)b.hasOwnProperty(c)&&(a[c]=b[c])};return b(a,c)};return function(a,c){function e(){this.constructor=a}b(a,c);a.prototype=null===c?Object.create(c):(e.prototype=c.prototype,new e)}}(),e=g.merge,k=function(b,a){return function(){var c=this.annotation,e=this.anchor(c.startRetracements[b]).absolutePosition,d=this.anchor(c.endRetracements[b]).absolutePosition;e=[["M",Math.round(e.x),Math.round(e.y)],["L",Math.round(d.x),Math.round(d.y)]];a&&(d=this.anchor(c.endRetracements[b- 1]).absolutePosition,c=this.anchor(c.startRetracements[b-1]).absolutePosition,e.push(["L",Math.round(d.x),Math.round(d.y)],["L",Math.round(c.x),Math.round(c.y)]));return e}};g=function(b){function a(a,e){return b.call(this,a,e)||this}r(a,b);a.prototype.linkPoints=function(){b.prototype.linkPoints.call(this);this.linkRetracementsPoints()};a.prototype.linkRetracementsPoints=function(){var b=this.points,e=b[0].y-b[3].y,d=b[1].y-b[2].y,m=b[0].x,f=b[1].x;a.levels.forEach(function(a,c){var h=b[0].y-e*a; a=b[1].y-d*a;this.startRetracements=this.startRetracements||[];this.endRetracements=this.endRetracements||[];this.linkRetracementPoint(c,m,h,this.startRetracements);this.linkRetracementPoint(c,f,a,this.endRetracements)},this)};a.prototype.linkRetracementPoint=function(a,b,e,d){var c=d[a],h=this.options.typeOptions;c?(c.options.x=b,c.options.y=e,c.refresh()):d[a]=new f(this.chart,this,{x:b,y:e,xAxis:h.xAxis,yAxis:h.yAxis})};a.prototype.addShapes=function(){a.levels.forEach(function(a,b){this.initShape({type:"path", d:k(b)},!1);0e.label.offset&&(c*=-1);return{x:a.x,xAxis:a.series.xAxis,y:b+c}};f.extendAnnotation(e, null,{getPointsOptions:function(){return[this.options.typeOptions.point]},addShapes:function(){var d=this.options.typeOptions,b=this.initShape(r(d.connector,{type:"path",points:[e.connectorFirstPoint,e.connectorSecondPoint]}),!1);d.connector=b.options},addLabels:function(){var e=this.options.typeOptions,b=e.label,a=0,c=b.offset,d=0>b.offset?"bottom":"top",f="center";this.chart.inverted&&(a=b.offset,c=0,d="middle",f=0>b.offset?"right":"left");b=this.initLabel(r(b,{verticalAlign:d,align:f,x:a,y:c})); e.label=b.options}},{typeOptions:{yOffset:10,label:{offset:-40,point:function(e){return e.annotation.points[0]},allowOverlap:!0,backgroundColor:"none",borderWidth:0,crop:!0,overflow:"none",shape:"rect",text:"{y:.2f}"},connector:{strokeWidth:1,markerEnd:"arrow"}}});return d.types.verticalLine=e});t(d,"annotations/types/Measure.js",[d["annotations/annotations.src.js"],d["annotations/ControlPoint.js"],d["parts/Globals.js"],d["parts/Utilities.js"]],function(d,f,l,g){var r=g.extend,e=g.isNumber,k=g.merge; g=function(){d.apply(this,arguments)};d.types.measure=g;l.extendAnnotation(g,null,{init:function(){d.prototype.init.apply(this,arguments);this.resizeY=this.resizeX=this.offsetY=this.offsetX=0;this.calculations.init.call(this);this.addValues();this.addShapes()},setClipAxes:function(){this.clipXAxis=this.chart.xAxis[this.options.typeOptions.xAxis];this.clipYAxis=this.chart.yAxis[this.options.typeOptions.yAxis]},pointsOptions:function(){return this.options.points},shapePointsOptions:function(){var b= this.options.typeOptions,a=b.xAxis;b=b.yAxis;return[{x:this.xAxisMin,y:this.yAxisMin,xAxis:a,yAxis:b},{x:this.xAxisMax,y:this.yAxisMin,xAxis:a,yAxis:b},{x:this.xAxisMax,y:this.yAxisMax,xAxis:a,yAxis:b},{x:this.xAxisMin,y:this.yAxisMax,xAxis:a,yAxis:b}]},addControlPoints:function(){var b=this.options.typeOptions.selectType;var a=new f(this.chart,this,this.options.controlPointOptions,0);this.controlPoints.push(a);"xy"!==b&&(a=new f(this.chart,this,this.options.controlPointOptions,1),this.controlPoints.push(a))}, addValues:function(b){var a=this.options.typeOptions,c=a.label.formatter;this.calculations.recalculate.call(this,b);a.label.enabled&&(0Max: "+this.max+"
Average: "+this.average+"
Bins: "+this.bins},getExtremes:function(b,a,c,e){return{xAxisMin:Math.min(a,b),xAxisMax:Math.max(a,b),yAxisMin:Math.min(e,c),yAxisMax:Math.max(e,c)}},min:function(){var b=Infinity,a=this.chart.series,c=this.calculations.getExtremes(this.xAxisMin,this.xAxisMax,this.yAxisMin,this.yAxisMax),e=!1;a.forEach(function(a){a.visible&&"highcharts-navigator-series"!== a.options.id&&a.points.forEach(function(a){!a.isNull&&a.yc.xAxisMin&&a.x<=c.xAxisMax&&a.y>c.yAxisMin&&a.y<=c.yAxisMax&&(b=a.y,e=!0)})});e||(b="");return b},max:function(){var b=-Infinity,a=this.chart.series,c=this.calculations.getExtremes(this.xAxisMin,this.xAxisMax,this.yAxisMin,this.yAxisMax),e=!1;a.forEach(function(a){a.visible&&"highcharts-navigator-series"!==a.options.id&&a.points.forEach(function(a){!a.isNull&&a.y>b&&a.x>c.xAxisMin&&a.x<=c.xAxisMax&&a.y>c.yAxisMin&&a.y<=c.yAxisMax&& (b=a.y,e=!0)})});e||(b="");return b},average:function(){var b="";""!==this.max&&""!==this.min&&(b=(this.max+this.min)/2);return b},bins:function(){var b=0,a=this.chart.series,c=this.calculations.getExtremes(this.xAxisMin,this.xAxisMax,this.yAxisMin,this.yAxisMax),e=!1;a.forEach(function(a){a.visible&&"highcharts-navigator-series"!==a.options.id&&a.points.forEach(function(a){!a.isNull&&a.x>c.xAxisMin&&a.x<=c.xAxisMax&&a.y>c.yAxisMin&&a.y<=c.yAxisMax&&(b++,e=!0)})});e||(b="");return b}}},{typeOptions:{selectType:"xy", xAxis:0,yAxis:0,background:{fill:"rgba(130, 170, 255, 0.4)",strokeWidth:0,stroke:void 0},crosshairX:{enabled:!0,zIndex:6,dashStyle:"Dash",markerEnd:"arrow"},crosshairY:{enabled:!0,zIndex:6,dashStyle:"Dash",markerEnd:"arrow"},label:{enabled:!0,style:{fontSize:"11px",color:"#666666"},formatter:void 0}},controlPointOptions:{positioner:function(b){var a=this.index,c=b.chart,e=b.options,d=e.typeOptions,f=d.selectType;e=e.controlPointOptions;var g=c.inverted,n=c.xAxis[d.xAxis];c=c.yAxis[d.yAxis];d=b.xAxisMax; var q=b.yAxisMax,k=b.calculations.getExtremes(b.xAxisMin,b.xAxisMax,b.yAxisMin,b.yAxisMax);"x"===f&&(q=(k.yAxisMax-k.yAxisMin)/2,0===a&&(d=b.xAxisMin));"y"===f&&(d=k.xAxisMin+(k.xAxisMax-k.xAxisMin)/2,0===a&&(q=b.yAxisMin));g?(b=c.toPixels(q),a=n.toPixels(d)):(b=n.toPixels(d),a=c.toPixels(q));return{x:b-e.width/2,y:a-e.height/2}},events:{drag:function(b,a){var c=this.mouseMoveToTranslation(b);b=a.options.typeOptions.selectType;var e="y"===b?0:c.x;c="x"===b?0:c.y;a.resize(e,c,this.index,b);a.resizeX+= e;a.resizeY+=c;a.redraw(!1,!0)}}}});return d.types.measure=g});t(d,"mixins/navigation.js",[],function(){return{initUpdate:function(d){d.navigation||(d.navigation={updates:[],update:function(d,l){this.updates.forEach(function(f){f.update.call(f.context,d,l)})}})},addUpdate:function(d,f){f.navigation||this.initUpdate(f);f.navigation.updates.push({update:d,context:f})}}});t(d,"annotations/navigationBindings.js",[d["annotations/annotations.src.js"],d["mixins/navigation.js"],d["parts/Globals.js"],d["parts/Utilities.js"]], function(d,f,l,g){function r(b){var c=b.prototype.defaultOptions.events&&b.prototype.defaultOptions.events.click;t(!0,b.prototype.defaultOptions.events,{click:function(b){var e=this,d=e.chart.navigationBindings,f=d.activeAnnotation;c&&c.call(e,b);f!==e?(d.deselectAnnotation(),d.activeAnnotation=e,e.setControlPointsVisibility(!0),a(d,"showPopup",{annotation:e,formType:"annotation-toolbar",options:d.annotationToFields(e),onSubmit:function(a){var b={};"remove"===a.actionType?(d.activeAnnotation=!1,d.chart.removeAnnotation(e)): (d.fieldsToOptions(a.fields,b),d.deselectAnnotation(),a=b.typeOptions,"measure"===e.options.type&&(a.crosshairY.enabled=0!==a.crosshairY.strokeWidth,a.crosshairX.enabled=0!==a.crosshairX.strokeWidth),e.update(b))}})):(d.deselectAnnotation(),a(d,"closePopup"));b.activeAnnotation=!0}})}var e=g.addEvent,k=g.attr,b=g.format,a=g.fireEvent,c=g.isArray,h=g.isFunction,p=g.isNumber,m=g.isObject,t=g.merge,n=g.objectEach,q=g.pick;g=g.setOptions;var x=l.doc,A=l.win,v=function(){function d(a,b){this.selectedButton= this.boundClassNames=void 0;this.chart=a;this.options=b;this.eventsToUnbind=[];this.container=x.getElementsByClassName(this.options.bindingsClassName||"")}d.prototype.initEvents=function(){var a=this,b=a.chart,c=a.container,d=a.options;a.boundClassNames={};n(d.bindings||{},function(b){a.boundClassNames[b.className]=b});[].forEach.call(c,function(b){a.eventsToUnbind.push(e(b,"click",function(c){var d=a.getButtonEvents(b,c);d&&a.bindingsButtonClick(d.button,d.events,c)}))});n(d.events||{},function(b, c){h(b)&&a.eventsToUnbind.push(e(a,c,b))});a.eventsToUnbind.push(e(b.container,"click",function(c){!b.cancelClick&&b.isInsidePlot(c.chartX-b.plotLeft,c.chartY-b.plotTop)&&a.bindingsChartClick(this,c)}));a.eventsToUnbind.push(e(b.container,l.isTouchDevice?"touchmove":"mousemove",function(b){a.bindingsContainerMouseMove(this,b)}))};d.prototype.initUpdate=function(){var a=this;f.addUpdate(function(b){a.update(b)},this.chart)};d.prototype.bindingsButtonClick=function(b,c,d){var e=this.chart;this.selectedButtonElement&& (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")};d.prototype.bindingsChartClick=function(b,c){b=this.chart;var d=this.selectedButton; b=b.renderer.boxWrapper;var e;if(e=this.activeAnnotation&&!c.activeAnnotation&&c.target.parentNode){a:{e=c.target;var f=A.Element.prototype,n=f.matches||f.msMatchesSelector||f.webkitMatchesSelector,q=null;if(f.closest)q=f.closest.call(e,".highcharts-popup");else{do{if(n.call(e,".highcharts-popup"))break a;e=e.parentElement||e.parentNode}while(null!==e&&1===e.nodeType)}e=q}e=!e}e&&(a(this,"closePopup"),this.deselectAnnotation());d&&d.start&&(this.nextEvent?(this.nextEvent(c,this.currentUserDetails), this.steps&&(this.stepIndex++,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}), b.removeClass("highcharts-draw-mode"),this.steps=!1,this.selectedButton=null,d.end&&d.end.call(this,c,this.currentUserDetails))))};d.prototype.bindingsContainerMouseMove=function(a,b){this.mouseMoveEvent&&this.mouseMoveEvent(b,this.currentUserDetails)};d.prototype.fieldsToOptions=function(a,b){n(a,function(a,c){var d=parseFloat(a),e=c.split("."),f=b,n=e.length-1;!p(d)||a.match(/px/g)||c.match(/format/g)||(a=d);""!==a&&"undefined"!==a&&e.forEach(function(b,c){var d=q(e[c+1],"");n===c?f[b]=a:(f[b]|| (f[b]=d.match(/\d/g)?[]:{}),f=f[b])})});return b};d.prototype.deselectAnnotation=function(){this.activeAnnotation&&(this.activeAnnotation.setControlPointsVisibility(!1),this.activeAnnotation=!1)};d.prototype.annotationToFields=function(a){function e(d,f,q,g){if(q&&-1===l.indexOf(f)&&(0<=(q.indexOf&&q.indexOf(f))||q[f]||!0===q))if(c(d))g[f]=[],d.forEach(function(a,b){m(a)?(g[f][b]={},n(a,function(a,c){e(a,c,h[f],g[f][b])})):e(a,0,h[f],g[f])});else if(m(d)){var w={};c(g)?(g.push(w),w[f]={},w=w[f]): g[f]=w;n(d,function(a,b){e(a,b,0===f?q:h[f],w)})}else"format"===f?g[f]=[b(d,a.labels[0].points[0]).toString(),"text"]:c(g)?g.push([d,k(d)]):g[f]=[d,k(d)]}var f=a.options,g=d.annotationsEditable,h=g.nestedOptions,k=this.utils.getFieldType,w=q(f.type,f.shapes&&f.shapes[0]&&f.shapes[0].type,f.labels&&f.labels[0]&&f.labels[0].itemType,"label"),l=d.annotationsNonEditable[f.langKey]||[],u={langKey:f.langKey,type:w};n(f,function(a,b){"typeOptions"===b?(u[b]={},n(f[b],function(a,c){e(a,c,h,u[b],!0)})):e(a, b,g[w],u)});return u};d.prototype.getClickedClassNames=function(a,b){var c=b.target;b=[];for(var d;c&&((d=k(c,"class"))&&(b=b.concat(d.split(" ").map(function(a){return[a,c]}))),c=c.parentNode,c!==a););return b};d.prototype.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};d.prototype.update=function(a){this.options=t(!0,this.options,a);this.removeEvents();this.initEvents()}; d.prototype.removeEvents=function(){this.eventsToUnbind.forEach(function(a){a()})};d.prototype.destroy=function(){this.removeEvents()};d.annotationsEditable={nestedOptions:{labelOptions:["style","format","backgroundColor"],labels:["style"],label:["style"],style:["fontSize","color"],background:["fill","strokeWidth","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","height"],pitchfork:["innerBackground","outerBackground"],rect:["shapes"],crookedLine:[],basicAnnotation:[]};d.annotationsNonEditable={rectangle:["crosshairX","crosshairY","label"]};return d}(); v.prototype.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]}};l.Chart.prototype.initNavigationBindings=function(){var a=this.options;a&&a.navigation&&a.navigation.bindings&&(this.navigationBindings=new v(this,a.navigation), this.navigationBindings.initEvents(),this.navigationBindings.initUpdate())};e(l.Chart,"load",function(){this.initNavigationBindings()});e(l.Chart,"destroy",function(){this.navigationBindings&&this.navigationBindings.destroy()});e(v,"deselectButton",function(){this.selectedButtonElement=null});e(d,"remove",function(){this.chart.navigationBindings&&this.chart.navigationBindings.deselectAnnotation()});l.Annotation&&(r(d),n(d.types,function(a){r(a)}));g({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",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(t({langKey:"circle",type:"basicAnnotation",shapes:[{type:"circle",point:{xAxis:0,yAxis:0,x:a.xAxis[0].value,y:a.yAxis[0].value},r:5}]},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);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);a=this.chart.options.navigation;var c=b.xAxis[0].value;b=b.yAxis[0].value;return this.chart.addAnnotation(t({langKey:"rectangle",type:"basicAnnotation",shapes:[{type:"path", points:[{xAxis:0,yAxis:0,x:c,y:b},{xAxis:0,yAxis:0,x:c,y:b},{xAxis:0,yAxis:0,x:c,y:b},{xAxis:0,yAxis:0,x:c,y:b}]}]},a.annotationsOptions,a.bindings.rectangleAnnotation.annotationsOptions))},steps:[function(a,b){var c=b.options.shapes[0].points,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(t({langKey:"label",type:"basicAnnotation",labelOptions:{format:"{y:.2f}"},labels:[{point:{xAxis:0,yAxis:0,x:a.xAxis[0].value,y:a.yAxis[0].value},overflow:"none",crop:!0}]},b.annotationsOptions,b.bindings.labelAnnotation.annotationsOptions))}}},events:{},annotationsOptions:{}}});return v});t(d,"annotations/popup.js",[d["parts/Globals.js"],d["annotations/navigationBindings.js"],d["parts/Pointer.js"],d["parts/Utilities.js"]],function(d, f,l,g){var r=g.addEvent,e=g.createElement,k=g.defined,b=g.getOptions,a=g.isArray,c=g.isObject,h=g.isString,p=g.objectEach,m=g.pick;g=g.wrap;var t=/\d/g;g(l.prototype,"onContainerMouseDown",function(a,b){var c=b.target&&b.target.className;h(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=e("div",{className:"highcharts-popup"},null,a);this.lang=this.getLangpack(); this.iconsURL=b;this.addCloseBtn()},addCloseBtn:function(){var a=this;var b=e("div",{className:"highcharts-popup-close"},null,this.container);b.style["background-image"]="url("+this.iconsURL+"close.svg)";["click","touchstart"].forEach(function(c){r(b,c,function(){a.closePopup()})})},addColsContainer:function(a){var b=e("div",{className:"highcharts-popup-lhs-col"},null,a);a=e("div",{className:"highcharts-popup-rhs-col"},null,a);e("div",{className:"highcharts-popup-rhs-col-wrapper"},null,a);return{lhsCol:b, rhsCol:a}},addInput:function(a,b,c,d){var f=a.split(".");f=f[f.length-1];var g=this.lang;b="highcharts-"+b+"-"+f;b.match(t)||e("label",{innerHTML:g[f]||f,htmlFor:b},null,c);e("input",{name:b,value:d[0],type:d[1],className:"highcharts-popup-field"},null,c).setAttribute("highcharts-data-name",a)},addButton:function(a,b,c,d,f){var g=this,h=this.closePopup,n=this.getFields;var q=e("button",{innerHTML:b},null,a);["click","touchstart"].forEach(function(a){r(q,a,function(){h.call(g);return d(n(f,c))})}); return q},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];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"),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 b().lang.navigation.popup},annotations:{addToolbar:function(a,b,c){var d=this,f=this.lang,g=this.popup.container,h=this.showForm;-1===g.className.indexOf("highcharts-annotation-toolbar")&&(g.className+=" highcharts-annotation-toolbar");g.style.top=a.plotTop+10+"px";e("span", {innerHTML:m(f[b.langKey]||b.langKey,b.shapes&&b.shapes[0].type)},null,g);var k=this.addButton(g,f.removeButton||"remove","remove",c,g);k.className+=" highcharts-annotation-remove-button";k.style["background-image"]="url("+this.iconsURL+"destroy.svg)";k=this.addButton(g,f.editButton||"edit","edit",function(){h.call(d,"annotation-edit",a,b,c)},g);k.className+=" highcharts-annotation-edit-button";k.style["background-image"]="url("+this.iconsURL+"edit.svg)"},addForm:function(a,b,c,d){var f=this.popup.container, g=this.lang;e("h2",{innerHTML:g[b.langKey]||b.langKey,className:"highcharts-popup-main-title"},null,f);var h=e("div",{className:"highcharts-popup-lhs-col highcharts-popup-lhs-full"},null,f);var k=e("div",{className:"highcharts-popup-bottom-row"},null,f);this.annotations.addFormFields.call(this,h,a,"",b,[],!0);this.addButton(k,d?g.addButton||"add":g.saveButton||"save",d?"add":"save",c,f)},addFormFields:function(b,d,f,g,h,k){var q=this,n=this.annotations.addFormFields,l=this.addInput,m=this.lang,r, x;p(g,function(e,g){r=""!==f?f+"."+g:g;c(e)&&(!a(e)||a(e)&&c(e[0])?(x=m[g]||g,x.match(t)||h.push([!0,x,b]),n.call(q,b,d,r,e,h,!1)):h.push([q,r,"annotation",b,e]))});k&&(h=h.sort(function(a){return a[1].match(/format/g)?-1:1}),h.forEach(function(a){!0===a[0]?e("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,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(a,b,c){var d=this,f=b.querySelectorAll(".highcharts-popup-lhs-col")[0]; b=b.querySelectorAll(".highcharts-popup-rhs-col")[0];var g="edit"===c,h=g?a.series:a.options.plotOptions,k=this.indicators.addFormFields,q;var n=e("ul",{className:"highcharts-indicator-list"},null,f);var l=b.querySelectorAll(".highcharts-popup-rhs-col-wrapper")[0];p(h,function(b,c){var f=b.options;if(b.params||f&&f.params){var m=d.indicators.getNameType(b,c),p=m.type;q=e("li",{className:"highcharts-indicator-list",innerHTML:m.name},null,n);["click","touchstart"].forEach(function(c){r(q,c,function(){k.call(d, a,g?b:h[p],m.type,l);g&&b.options&&e("input",{type:"hidden",name:"highcharts-id-"+p,value:b.options.id},null,l).setAttribute("highcharts-data-series-id",b.options.id)})})}});0